:root{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,sans-serif;--bg-main: #f3f6fb;--bg-accent-1: #dbeafe;--bg-accent-2: #c7d2fe;--text-main: #0f172a;--text-muted: #475569;--text-soft: #334155;--card-bg: rgba(255, 255, 255, .9);--card-border: rgba(148, 163, 184, .35);--table-border: #e2e8f0;--table-head: #f8fafc;--table-stripe: rgba(248, 250, 252, .72);--input-bg: #ffffff;--input-border: #cbd5e1;--focus-ring: rgba(96, 165, 250, .22);--button-bg: #f8fafc;--button-border: #cbd5e1;--button-hover-bg: #f1f5f9;--button-hover-border: #94a3b8;--primary-1: #2563eb;--primary-2: #1d4ed8;--primary-3: #1e40af;--danger-1: #ef4444;--danger-2: #dc2626;--danger-3: #b91c1c;--budget-under: #16a34a;--shadow-1: rgba(15, 23, 42, .03);--shadow-2: rgba(15, 23, 42, .08)}:root[data-theme=dark]{--bg-main: #0b1220;--bg-accent-1: #0f172a;--bg-accent-2: #1e293b;--text-main: #e2e8f0;--text-muted: #94a3b8;--text-soft: #cbd5e1;--card-bg: rgba(15, 23, 42, .82);--card-border: rgba(100, 116, 139, .45);--table-border: #334155;--table-head: #1e293b;--table-stripe: rgba(30, 41, 59, .55);--input-bg: #0f172a;--input-border: #334155;--focus-ring: rgba(59, 130, 246, .28);--button-bg: #1e293b;--button-border: #334155;--button-hover-bg: #273449;--button-hover-border: #475569;--primary-1: #3b82f6;--primary-2: #2563eb;--primary-3: #1d4ed8;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #22c55e;--shadow-1: rgba(2, 6, 23, .35);--shadow-2: rgba(2, 6, 23, .45)}:root[data-theme=forest]{--bg-main: #eff8f1;--bg-accent-1: #d1fae5;--bg-accent-2: #dcfce7;--text-main: #052e16;--text-muted: #166534;--text-soft: #14532d;--card-bg: rgba(255, 255, 255, .9);--card-border: rgba(34, 197, 94, .3);--table-border: #bbf7d0;--table-head: #f0fdf4;--table-stripe: rgba(240, 253, 244, .78);--input-bg: #ffffff;--input-border: #86efac;--focus-ring: rgba(34, 197, 94, .22);--button-bg: #f0fdf4;--button-border: #86efac;--button-hover-bg: #dcfce7;--button-hover-border: #4ade80;--primary-1: #16a34a;--primary-2: #15803d;--primary-3: #166534;--danger-1: #ef4444;--danger-2: #dc2626;--danger-3: #b91c1c;--budget-under: #16a34a;--shadow-1: rgba(21, 128, 61, .05);--shadow-2: rgba(21, 128, 61, .14)}:root[data-theme=sage-light]{--bg-main: #edf9ed;--bg-accent-1: #c9efcc;--bg-accent-2: #d6f4dc;--text-main: #0e301c;--text-muted: #1f6b3e;--text-soft: #185532;--card-bg: rgba(255, 255, 255, .92);--card-border: rgba(34, 139, 78, .35);--table-border: #9fdfb5;--table-head: #e8f9ee;--table-stripe: rgba(232, 249, 238, .82);--input-bg: #ffffff;--input-border: #65c98b;--focus-ring: rgba(22, 163, 74, .24);--button-bg: #e8f9ee;--button-border: #65c98b;--button-hover-bg: #d4f3df;--button-hover-border: #2fa35e;--primary-1: #22a35f;--primary-2: #198a4e;--primary-3: #126f3e;--danger-1: #ef4444;--danger-2: #dc2626;--danger-3: #b91c1c;--budget-under: #16a34a;--shadow-1: rgba(16, 94, 48, .05);--shadow-2: rgba(16, 94, 48, .14)}:root[data-theme=mint-light]{--bg-main: #f5fff5;--bg-accent-1: rgba(120, 224, 120, .462);--bg-accent-2: rgba(120, 224, 120, .462);--text-main: #1b2344;--text-muted: #4b5b95;--text-soft: #3b4a7e;--card-bg: rgba(255, 255, 255, .92);--card-border: rgba(99, 214, 118, .34);--table-border: #c8cff5;--table-head: #f3f5ff;--table-stripe: rgba(120, 224, 120, .462);--input-bg: #ffffff;--input-border: #9aa7ea;--focus-ring: rgba(99, 102, 241, .2);--button-bg: #f3f5ff;--button-border: #9aa7ea;--button-hover-bg: #e7ebff;--button-hover-border: #76d669;--primary-1: #0a9716;--primary-2: #087a11;--primary-3: #065d0e;--danger-1: #ef4444;--danger-2: #dc2626;--danger-3: #b91c1c;--budget-under: #087a11;--shadow-1: rgba(46, 58, 120, .05);--shadow-2: rgba(46, 58, 120, .14)}:root[data-theme=pine-light]{--bg-main: #cfe4d8;--bg-accent-1: #add2bf;--bg-accent-2: #badacb;--text-main: #0d241c;--text-muted: #22493b;--text-soft: #1a3c2f;--card-bg: rgba(227, 241, 233, .92);--card-border: rgba(35, 98, 74, .36);--table-border: #86b9a1;--table-head: #cde5d8;--table-stripe: rgba(190, 219, 204, .9);--input-bg: #edf6f1;--input-border: #448f73;--focus-ring: rgba(22, 94, 67, .28);--button-bg: #cfe5d9;--button-border: #448f73;--button-hover-bg: #bddacb;--button-hover-border: #246b4d;--primary-1: #1b6f51;--primary-2: #155d43;--primary-3: #104a35;--danger-1: #ef4444;--danger-2: #dc2626;--danger-3: #b91c1c;--budget-under: #166f45;--shadow-1: rgba(13, 55, 41, .09);--shadow-2: rgba(13, 55, 41, .18)}:root[data-theme=pine-dark]{--bg-main: #0b1712;--bg-accent-1: #102119;--bg-accent-2: #173126;--text-main: #e6f5ec;--text-muted: #9bc4ae;--text-soft: #c0ddcd;--card-bg: rgba(16, 33, 25, .86);--card-border: rgba(98, 150, 123, .42);--table-border: #355746;--table-head: #1e3b2f;--table-stripe: rgba(30, 59, 47, .54);--input-bg: #173026;--input-border: #486e5b;--focus-ring: rgba(74, 222, 128, .27);--button-bg: #29503f;--button-border: #5f9078;--button-hover-bg: #33624d;--button-hover-border: #7cb396;--primary-1: #4ade80;--primary-2: #22c55e;--primary-3: #16a34a;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #4ade80;--shadow-1: rgba(4, 11, 8, .43);--shadow-2: rgba(4, 11, 8, .56)}:root[data-theme=midnight]{--bg-main: #070b14;--bg-accent-1: #0b1220;--bg-accent-2: #111b30;--text-main: #e6edf7;--text-muted: #96a8c4;--text-soft: #c3d1e7;--card-bg: rgba(10, 18, 32, .86);--card-border: rgba(88, 112, 150, .44);--table-border: #2b3b55;--table-head: #152238;--table-stripe: rgba(21, 34, 56, .56);--input-bg: #0d182b;--input-border: #334764;--focus-ring: rgba(96, 165, 250, .28);--button-bg: #1a2841;--button-border: #3a4e6f;--button-hover-bg: #233452;--button-hover-border: #536d95;--primary-1: #60a5fa;--primary-2: #3b82f6;--primary-3: #2563eb;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #22c55e;--shadow-1: rgba(1, 4, 10, .45);--shadow-2: rgba(1, 4, 10, .56)}:root[data-theme=graphite]{--bg-main: #111214;--bg-accent-1: #171a1f;--bg-accent-2: #20252b;--text-main: #eceff3;--text-muted: #a2a9b3;--text-soft: #c8ced8;--card-bg: rgba(23, 26, 31, .88);--card-border: rgba(122, 130, 143, .4);--table-border: #3a4049;--table-head: #272d35;--table-stripe: rgba(39, 45, 53, .56);--input-bg: #1b2026;--input-border: #424b57;--focus-ring: rgba(148, 163, 184, .26);--button-bg: #2a313a;--button-border: #495363;--button-hover-bg: #343d48;--button-hover-border: #667489;--primary-1: #94a3b8;--primary-2: #64748b;--primary-3: #475569;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #22c55e;--shadow-1: rgba(0, 0, 0, .4);--shadow-2: rgba(0, 0, 0, .52)}:root[data-theme=violet-night]{--bg-main: #130d24;--bg-accent-1: #1a1230;--bg-accent-2: #271a44;--text-main: #efe9ff;--text-muted: #b8acd9;--text-soft: #d4c8f1;--card-bg: rgba(28, 19, 49, .86);--card-border: rgba(142, 116, 212, .42);--table-border: #4c3b73;--table-head: #2f2252;--table-stripe: rgba(47, 34, 82, .52);--input-bg: #23183f;--input-border: #5f4a92;--focus-ring: rgba(167, 139, 250, .3);--button-bg: #34235c;--button-border: #6a52a1;--button-hover-bg: #452f74;--button-hover-border: #876bc3;--primary-1: #a78bfa;--primary-2: #8b5cf6;--primary-3: #7c3aed;--danger-1: #fda4af;--danger-2: #fb7185;--danger-3: #f43f5e;--budget-under: #34d399;--shadow-1: rgba(11, 7, 20, .42);--shadow-2: rgba(11, 7, 20, .56)}:root[data-theme=ocean-dark]{--bg-main: #071a1f;--bg-accent-1: #0a242b;--bg-accent-2: #12353e;--text-main: #e5f6f9;--text-muted: #94bfc7;--text-soft: #bde0e6;--card-bg: rgba(11, 32, 38, .86);--card-border: rgba(84, 149, 163, .42);--table-border: #2f5963;--table-head: #1a424b;--table-stripe: rgba(26, 66, 75, .53);--input-bg: #102d34;--input-border: #3f7280;--focus-ring: rgba(45, 212, 191, .28);--button-bg: #1d4651;--button-border: #4a7f8d;--button-hover-bg: #285c69;--button-hover-border: #5e98a8;--primary-1: #2dd4bf;--primary-2: #14b8a6;--primary-3: #0d9488;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #22c55e;--shadow-1: rgba(2, 13, 16, .44);--shadow-2: rgba(2, 13, 16, .56)}:root[data-theme=ember-dark]{--bg-main: #1a0f0a;--bg-accent-1: #25160e;--bg-accent-2: #392215;--text-main: #fff1e8;--text-muted: #d7ab90;--text-soft: #efc8b1;--card-bg: rgba(33, 19, 13, .87);--card-border: rgba(191, 116, 74, .42);--table-border: #6b3c27;--table-head: #472919;--table-stripe: rgba(71, 41, 25, .53);--input-bg: #2b190f;--input-border: #895338;--focus-ring: rgba(251, 146, 60, .3);--button-bg: #542f1b;--button-border: #996042;--button-hover-bg: #6d3d23;--button-hover-border: #bb7752;--primary-1: #fb923c;--primary-2: #f97316;--primary-3: #ea580c;--danger-1: #fca5a5;--danger-2: #f87171;--danger-3: #ef4444;--budget-under: #4ade80;--shadow-1: rgba(10, 5, 2, .44);--shadow-2: rgba(10, 5, 2, .56)}:root[data-theme=neon-dark]{--bg-main: #0a0f13;--bg-accent-1: #0f1520;--bg-accent-2: #152132;--text-main: #eafff7;--text-muted: #8fd9c6;--text-soft: #b9f1e2;--card-bg: rgba(13, 22, 32, .86);--card-border: rgba(45, 212, 191, .44);--table-border: #2d5960;--table-head: #1b3942;--table-stripe: rgba(27, 57, 66, .55);--input-bg: #132532;--input-border: #3b7782;--focus-ring: rgba(45, 212, 191, .3);--button-bg: #1d3c49;--button-border: #4d9baa;--button-hover-bg: #275060;--button-hover-border: #66bfce;--primary-1: #2dd4bf;--primary-2: #14b8a6;--primary-3: #0d9488;--danger-1: #fb7185;--danger-2: #f43f5e;--danger-3: #e11d48;--budget-under: #22c55e;--shadow-1: rgba(1, 8, 12, .44);--shadow-2: rgba(1, 8, 12, .56)}:root[data-theme=slate-dark]{--bg-main: #0f141b;--bg-accent-1: #161d27;--bg-accent-2: #202a36;--text-main: #edf3fb;--text-muted: #9fb0c3;--text-soft: #c5d2e2;--card-bg: rgba(20, 29, 39, .86);--card-border: rgba(115, 137, 160, .42);--table-border: #3a4d63;--table-head: #253447;--table-stripe: rgba(37, 52, 71, .54);--input-bg: #1b2938;--input-border: #49627f;--focus-ring: rgba(96, 165, 250, .27);--button-bg: #2c4057;--button-border: #5f7d9f;--button-hover-bg: #39526f;--button-hover-border: #7a9bbf;--primary-1: #60a5fa;--primary-2: #3b82f6;--primary-3: #2563eb;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #22c55e;--shadow-1: rgba(3, 8, 14, .43);--shadow-2: rgba(3, 8, 14, .56)}:root[data-theme=plum-dark]{--bg-main: #1a1020;--bg-accent-1: #23142c;--bg-accent-2: #331d40;--text-main: #f8ecff;--text-muted: #c8a3d8;--text-soft: #e0c2eb;--card-bg: rgba(33, 19, 42, .87);--card-border: rgba(170, 115, 194, .42);--table-border: #6a3f7e;--table-head: #46295a;--table-stripe: rgba(70, 41, 90, .54);--input-bg: #2d1a3a;--input-border: #82539a;--focus-ring: rgba(217, 70, 239, .28);--button-bg: #54306a;--button-border: #9b67b5;--button-hover-bg: #6b3f84;--button-hover-border: #bb84d5;--primary-1: #d946ef;--primary-2: #c026d3;--primary-3: #a21caf;--danger-1: #fb7185;--danger-2: #f43f5e;--danger-3: #e11d48;--budget-under: #4ade80;--shadow-1: rgba(10, 4, 14, .44);--shadow-2: rgba(10, 4, 14, .56)}:root[data-theme=moss-dark]{--bg-main: #10170f;--bg-accent-1: #192218;--bg-accent-2: #263326;--text-main: #eaf6e8;--text-muted: #a9c4a4;--text-soft: #c6dec2;--card-bg: rgba(24, 34, 22, .86);--card-border: rgba(111, 150, 103, .42);--table-border: #3f5d3b;--table-head: #2a4328;--table-stripe: rgba(42, 67, 40, .53);--input-bg: #20311e;--input-border: #577853;--focus-ring: rgba(74, 222, 128, .27);--button-bg: #345130;--button-border: #6d9567;--button-hover-bg: #446940;--button-hover-border: #8cb886;--primary-1: #4ade80;--primary-2: #22c55e;--primary-3: #16a34a;--danger-1: #f87171;--danger-2: #ef4444;--danger-3: #dc2626;--budget-under: #4ade80;--shadow-1: rgba(5, 9, 4, .43);--shadow-2: rgba(5, 9, 4, .55)}:root[data-theme=cyber-dark]{--bg-main: #090c14;--bg-accent-1: #0f1320;--bg-accent-2: #1a2040;--text-main: #f2f6ff;--text-muted: #aab8df;--text-soft: #cad5f1;--card-bg: rgba(15, 20, 35, .87);--card-border: rgba(111, 137, 255, .43);--table-border: #3d4d86;--table-head: #27345f;--table-stripe: rgba(39, 52, 95, .54);--input-bg: #161f3b;--input-border: #5468a8;--focus-ring: rgba(99, 102, 241, .3);--button-bg: #2a3769;--button-border: #6279c8;--button-hover-bg: #39488a;--button-hover-border: #8799e2;--primary-1: #818cf8;--primary-2: #6366f1;--primary-3: #4f46e5;--danger-1: #fb7185;--danger-2: #f43f5e;--danger-3: #e11d48;--budget-under: #22c55e;--shadow-1: rgba(2, 4, 11, .45);--shadow-2: rgba(2, 4, 11, .57)}html{scroll-behavior:smooth}body{margin:0;color:var(--text-main);font-size:.8rem;background:radial-gradient(circle at 0% 0%,var(--bg-accent-1) 0,transparent 42%),radial-gradient(circle at 100% 0%,var(--bg-accent-2) 0,transparent 36%),var(--bg-main)}.app{max-width:1700px;margin:0 auto;padding:1.5rem}.app-header{justify-content:space-between}.header-actions{align-items:center;justify-content:flex-end}.top-shortcuts{display:flex;justify-content:center;gap:.65rem;flex-wrap:wrap}body.panel-modal-open{overflow:hidden}.panel-modal-backdrop{position:fixed;inset:0;z-index:10001;display:grid;place-items:center;padding:1rem;background:var(--focus-ring)}.panel-modal{width:min(96vw,1100px);max-height:min(86vh,900px);overflow:auto}.panel-modal-header{justify-content:space-between;align-items:center}.panel-modal-body{margin-top:.6rem}.export-warning{display:inline-flex;align-items:center;padding:.35rem .6rem;border:1px solid var(--danger-2);border-radius:999px;background:var(--table-stripe);color:var(--danger-2);font-weight:700;line-height:1.1}.export-warning-button{cursor:pointer}.change-log-list{margin:0;padding-left:1.1rem;display:grid;gap:.45rem}.change-log-list li{display:grid;gap:.15rem}.app-title{font-size:clamp(1.6rem,1.2vw + 1.1rem,2.2rem);letter-spacing:-.02em}h1,h2,h3{margin:0}.grid{display:grid;gap:1.1rem}.month-year-sticky{position:sticky;top:.5rem;z-index:20;display:grid;gap:.65rem;padding:.6rem .7rem;border:1px solid var(--card-border);border-radius:12px;background:var(--card-bg);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.grid-4{grid-template-columns:1fr;gap:1.25rem}.grid-4>.card{font-size:.86rem}.grid-4>.card h3{font-size:1.5rem;padding:1rem 0}.grid-4>.card th,.grid-4>.card td{font-size:.82rem;padding:.42rem .36rem}.grid-4>.card input,.grid-4>.card select,.grid-4>.card button,.grid-4>.card textarea,.grid-4>.card label{font-size:.82rem}@media(min-width:900px){.grid-4{grid-template-columns:repeat(2,minmax(0,1fr))}}.card{background:var(--card-bg);border:1px solid var(--card-border);border-radius:14px;padding:1rem;box-shadow:0 1px 1px var(--shadow-1),0 10px 24px var(--shadow-2);-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px)}article.card{overflow-x:auto}h2{font-size:1.15rem}h3{font-size:1.5rem;padding:1rem 0;margin-bottom:.45rem}label{font-size:.9rem;display:grid;gap:.35rem;color:var(--text-soft)}input,select,button,textarea{font:inherit;padding:.5rem .65rem;border:1px solid var(--input-border);border-radius:10px;color:var(--text-main);transition:border-color .18s ease,box-shadow .18s ease,background-color .18s ease,transform .12s ease}input,select,textarea{background:var(--input-bg)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--primary-1);box-shadow:0 0 0 3px var(--focus-ring)}.btn,button{cursor:pointer;border:1px solid var(--button-border);border-radius:10px;padding:.5rem .65rem;background:var(--button-bg);color:var(--text-main);font-weight:600}a.btn,a.btn:visited{display:inline-flex;align-items:center;justify-content:center;text-decoration:none;color:var(--text-main)}.btn:hover,button:hover{transform:translateY(-1px);border-color:var(--button-hover-border);background:var(--button-hover-bg)}.btn:active,button:active{transform:translateY(0)}.btn:disabled,button:disabled{cursor:not-allowed;opacity:.6;transform:none}.btn-primary{color:#fff;background:linear-gradient(180deg,var(--primary-1) 0%,var(--primary-2) 100%);border-color:var(--primary-2)}.btn-primary:hover{background:linear-gradient(180deg,var(--primary-2) 0%,var(--primary-3) 100%);border-color:var(--primary-3)}.btn-danger{color:#fff;background:linear-gradient(180deg,var(--danger-1) 0%,var(--danger-2) 100%);border-color:var(--danger-2)}.btn-danger:hover{background:linear-gradient(180deg,var(--danger-2) 0%,var(--danger-3) 100%);border-color:var(--danger-3)}.btn-quiet{background:var(--button-hover-bg);color:var(--text-soft)}table{width:100%;border-collapse:collapse;border:1px solid var(--table-border);border-radius:10px;overflow:hidden}thead{background:var(--table-head)}th,td{border-bottom:1px solid var(--table-border);padding:.55rem .5rem;text-align:left;vertical-align:top;white-space:nowrap}th{color:var(--text-soft);font-size:.86rem;font-weight:700;position:sticky;top:0;z-index:1}tbody tr:nth-child(2n){background:var(--table-stripe)}.daily-table th:nth-child(2),.daily-table td:nth-child(2){width:82px}.daily-table th:nth-child(3),.daily-table td:nth-child(3){width:82px}.daily-table .today-row td{background:var(--focus-ring)}.daily-table .day-has-entry td{background:var(--table-head)}.daily-table .day-has-entry td:first-child{font-weight:700}.daily-table .today-row.day-has-entry td{background:var(--focus-ring)}.daily-table .day-input-has-value{border-color:var(--budget-under);background:var(--table-head);box-shadow:0 0 0 2px var(--focus-ring);font-weight:700}.amount-input{max-width:64px;width:64px;font-size:.7rem}@media(max-width:768px){.grid-4>.card input.amount-input,.amount-input{font-size:1rem}}.inline{display:flex;gap:.65rem;align-items:end;flex-wrap:wrap;margin:30px 0;background:var(--bg-accent-2);padding:20px 10px}.column-overview{display:grid;gap:.25rem;margin:0 0 .6rem}.eval-grid{display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));margin:.35rem 0 .75rem}.eval-tile{border:1px solid var(--table-border);border-radius:12px;padding:.8rem;background:var(--table-stripe)}.eval-tile-header{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.35rem}.eval-tile h4{margin:0;font-size:.95rem}.eval-tile-columns{display:grid;grid-template-columns:repeat(2,minmax(90px,max-content));gap:.6rem;color:var(--text-muted);font-size:.8rem}.eval-rows{display:grid}.eval-row{display:grid;grid-template-columns:1fr minmax(90px,max-content) minmax(90px,max-content);gap:.6rem;padding:.28rem 0;border-top:1px solid var(--table-border);align-items:baseline}.eval-row:first-child{border-top:0}.eval-label{color:var(--text-soft)}.eval-value{text-align:right;font-variant-numeric:tabular-nums}.eval-diff{margin-left:.35rem;font-size:.8rem;font-weight:500;white-space:nowrap;color:var(--text-muted)}.eval-strong .eval-label,.eval-strong .eval-value{font-weight:700}.compact-month-overview{display:grid;gap:.85rem}.compact-month-overview>h3{margin:0;padding:0;font-size:1.15rem}.compact-income-panel{border:1px solid color-mix(in srgb,var(--budget-under) 38%,transparent);border-radius:12px;background:color-mix(in srgb,var(--budget-under) 12%,var(--card-bg));padding:.7rem .8rem;display:grid;gap:.2rem}.compact-income-row{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;padding:.2rem 0}.compact-income-row>strong{font-variant-numeric:tabular-nums;text-align:right}.compact-income-total{border-top:1px solid color-mix(in srgb,var(--budget-under) 48%,transparent);margin-top:.15rem;padding-top:.4rem}.compact-costs-grid{display:grid;gap:.65rem}.compact-cost-section{border:1px solid var(--table-border);border-radius:12px;background:var(--table-stripe);display:grid;grid-template-columns:84px minmax(0,1fr);overflow:hidden}.compact-cost-kicker{writing-mode:vertical-rl;transform:rotate(180deg);display:flex;justify-self:stretch;align-self:stretch;justify-content:center;align-items:center;text-align:center;font-weight:700;font-size:.92rem;letter-spacing:.02em;color:var(--text-soft);background:color-mix(in srgb,var(--bg-accent-2) 72%,transparent);border-inline-end:1px solid var(--table-border);padding:.8rem .65rem}.compact-cost-table{display:grid}.compact-cost-head,.compact-cost-row{display:grid;grid-template-columns:minmax(220px,2.4fr) minmax(150px,1fr) minmax(150px,1fr);gap:.95rem;align-items:baseline;padding:.42rem .9rem}.compact-cost-head{background:var(--table-head);color:var(--text-muted);font-size:.78rem;text-transform:uppercase;letter-spacing:.03em}.compact-cost-head>:nth-child(2),.compact-cost-head>:nth-child(3){text-align:right}.compact-cost-row{border-top:1px solid var(--table-border)}.compact-cost-row-total{font-weight:700;background:color-mix(in srgb,var(--table-head) 84%,transparent)}.compact-cost-name{min-width:0;text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.compact-cost-budget,.compact-cost-actual{text-align:right;font-variant-numeric:tabular-nums}.compact-cost-row-empty .compact-cost-name{white-space:normal}@media(min-width:1024px){.compact-month-overview{display:grid}.compact-cost-section{grid-template-columns:104px minmax(0,1fr)}.compact-cost-head,.compact-cost-row{grid-template-columns:minmax(300px,2.8fr) minmax(190px,1fr) minmax(190px,1fr)}}.chart-grid{display:grid;gap:.9rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin:.6rem 0 1rem}.chart-grid-wide{grid-template-columns:repeat(auto-fit,minmax(364px,1fr))}.chart-grid-wide .chart-dot-budget{background:var(--primary-1)}.chart-tile{border:1px solid var(--table-border);border-radius:12px;padding:.8rem;background:var(--card-bg)}.chart-tile-trend{grid-column:1 / -1}.chart-tile-header{display:flex;justify-content:space-between;align-items:baseline;gap:.75rem;margin-bottom:.55rem}.chart-tile h4{margin:0;font-size:.95rem}.chart-legend{display:flex;flex-wrap:wrap;gap:.6rem;color:var(--text-muted);font-size:.8rem}.chart-legend-item{display:inline-flex;align-items:center;gap:.35rem}.chart-dot{width:10px;height:10px;border-radius:999px;border:1px solid var(--table-border);background:var(--table-border)}.chart-dot-budget{background:var(--text-muted)}.chart-dot-actual,.chart-dot-net{background:var(--budget-under)}.chart-dot-income{background:var(--primary-1)}.chart-dot-expense{background:var(--danger-2)}.bar-chart,.budget-canvas-grid{display:grid;gap:.55rem}.budget-canvas-card{border:1px solid var(--table-border);border-radius:10px;background:var(--table-stripe);padding:.35rem .5rem;cursor:crosshair}.budget-vs-canvas{display:block;width:100%;height:96px}.trend-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.32rem .6rem;border:1px solid var(--table-border);border-radius:999px;background:var(--table-stripe);color:var(--text-main);font-size:.78rem;font-weight:700;white-space:nowrap}.trend-badge-positive{color:var(--budget-under)}.trend-badge-negative{color:var(--danger-2)}.trend-badge-neutral{color:var(--text-muted)}.year-trend-chart{display:grid;gap:.8rem}.year-trend-summary{display:grid;gap:.7rem;padding:.75rem .8rem;border:1px solid var(--table-border);border-radius:12px;background:linear-gradient(180deg,color-mix(in srgb,var(--primary-1) 8%,var(--card-bg)) 0%,var(--card-bg) 100%)}.year-trend-summary-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:.45rem}.year-trend-kicker{color:var(--text-muted);font-size:.78rem;letter-spacing:.04em;text-transform:uppercase}.year-trend-summary-head strong{font-size:1.02rem}.year-trend-metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.55rem}.year-trend-metric{display:grid;gap:.18rem;padding:.55rem .6rem;border:1px solid var(--table-border);border-radius:10px;background:var(--table-stripe)}.year-trend-metric span{color:var(--text-muted);font-size:.76rem}.year-trend-metric strong{font-size:.96rem;font-variant-numeric:tabular-nums}.year-trend-visual{position:relative;min-height:320px;border:1px solid var(--table-border);border-radius:14px;padding:.25rem;background:radial-gradient(circle at top,color-mix(in srgb,var(--primary-1) 10%,transparent) 0%,transparent 55%),linear-gradient(180deg,color-mix(in srgb,var(--table-stripe) 80%,var(--card-bg)) 0%,var(--card-bg) 100%);overflow:hidden}.year-trend-svg{display:block;width:100%;height:320px}.year-trend-grid-line{stroke:var(--table-border);stroke-width:1;stroke-dasharray:4 6;opacity:.8}.year-trend-zero-line{stroke:var(--text-muted);stroke-width:1.5;opacity:.75}.year-trend-axis-label,.year-trend-month-label{fill:var(--text-muted);font-size:11px}.year-trend-line{fill:none;stroke:var(--primary-1);stroke-width:4;stroke-linecap:round;stroke-linejoin:round;filter:drop-shadow(0 10px 16px var(--shadow-2))}.year-trend-area{fill:url(#year-trend-fill-gradient)}.year-trend-node{fill:var(--card-bg);stroke:var(--primary-1);stroke-width:3}.year-trend-node.is-negative{stroke:var(--danger-2)}.year-trend-point-layer{position:absolute;inset:0}.year-trend-point-hit{position:absolute;width:18px;height:18px;margin:0;padding:0;border:0;border-radius:999px;background:transparent;transform:translate(-50%,-50%);cursor:pointer;box-shadow:0 0 0 0 transparent}.year-trend-point-hit:before{content:"";position:absolute;inset:3px;border-radius:999px;border:2px solid var(--primary-1);background:color-mix(in srgb,var(--card-bg) 70%,transparent);transition:transform .16s ease,box-shadow .16s ease,border-color .16s ease}.year-trend-point-hit:hover:before,.year-trend-point-hit:focus-visible:before,.year-trend-point-hit.is-active:before{transform:scale(1.18);box-shadow:0 0 0 6px color-mix(in srgb,var(--primary-1) 16%,transparent)}.year-trend-point-hit:focus-visible{outline:none}.year-trend-footer{margin-top:-.15rem}.year-trend-live{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.circle-chart-container{margin-top:.8rem;padding-top:.8rem;border-top:1px solid var(--table-border);display:grid;grid-template-columns:repeat(auto-fit,minmax(130px,1fr));gap:.65rem}.circle-chart-item{display:grid;justify-items:center;gap:.22rem;padding:.4rem .35rem;border:1px solid var(--table-border);border-radius:10px;background:var(--table-stripe)}.circle-chart-ring{--circle-pct: 0%;width:66px;height:66px;border-radius:999px;display:grid;place-items:center;background:conic-gradient(var(--budget-under) var(--circle-pct),var(--table-border) 0);position:relative}.circle-chart-ring:after{content:"";position:absolute;inset:9px;border-radius:999px;background:var(--card-bg);border:1px solid var(--table-border)}.circle-chart-ring.circle-negative{background:conic-gradient(var(--danger-2) var(--circle-pct),var(--table-border) 0)}.circle-chart-value{position:relative;z-index:1;font-size:.78rem;font-weight:700;color:var(--text-main);font-variant-numeric:tabular-nums}.circle-chart-label{font-size:.82rem;color:var(--text-soft)}.circle-chart-meta{font-size:.74rem;text-align:center;font-variant-numeric:tabular-nums}.bar-row{display:grid;grid-template-columns:minmax(92px,1fr) 2fr minmax(140px,1.2fr);gap:.6rem;align-items:center}.bar-label{color:var(--text-soft);font-size:.86rem}.bar-track{position:relative;height:12px;border-radius:999px;border:1px solid var(--table-border);background:var(--table-stripe);overflow:hidden}.bullet-track{height:16px}.bullet-track .bar-actual{top:3px;bottom:3px;border-radius:6px}.bullet-track .bar-marker{width:3px;transform:translate(-1.5px);background:var(--text-main);opacity:.9}.bullet-band{position:absolute;top:0;bottom:0;background:var(--text-muted);z-index:0}.bullet-band-low{left:0;width:60%;opacity:.08}.bullet-band-mid{left:60%;width:25%;opacity:.12}.bullet-band-high{left:85%;width:15%;opacity:.16}.bar{position:absolute;inset:0 auto 0 0;width:0;border-radius:999px;z-index:1}.bar-budget{background:var(--text-muted);opacity:.18;z-index:1}.bar-marker{position:absolute;top:-1px;bottom:-1px;width:2px;transform:translate(-1px);background:var(--text-muted);opacity:.55;z-index:3}.bar-actual{z-index:2}.bar-actual.bar-positive,.bar-positive{background:var(--budget-under)}.bar-actual.bar-negative,.bar-negative{background:var(--danger-2)}.bar-income{background:var(--primary-1)}.bar-expense{background:var(--danger-2)}.bar-meta{display:flex;justify-content:flex-end;gap:.5rem;font-size:.82rem;font-variant-numeric:tabular-nums;white-space:nowrap}.spark-bars{display:grid;grid-template-columns:repeat(12,minmax(0,1fr));gap:.3rem;align-items:end;height:440px;padding:.35rem .2rem;border:1px solid var(--table-border);border-radius:12px;background:var(--table-stripe)}.spark-bar{display:grid;height:100%;grid-template-rows:1fr auto;gap:.2rem;align-items:end;justify-items:center;min-width:0}.spark-bar-stack{height:100%;width:100%;display:flex;flex-direction:column;justify-content:flex-end;align-items:center;gap:.15rem}.spark-bar-track{position:relative;flex:1;width:100%;display:flex;align-items:flex-end;justify-content:center}.spark-bar-fill-layered{position:absolute;bottom:0;left:50%;transform:translate(-50%)}.spark-bar-fill.spark-bar-fill-budget{background:var(--primary-1);opacity:.6;z-index:1;max-width:19px}.spark-bar-fill-actual{z-index:2}.spark-bar-value{font-size:.7rem;font-variant-numeric:tabular-nums;color:var(--text-main);white-space:nowrap;line-height:1.1;padding:.05rem .3rem;border-radius:10px;border:1px solid var(--table-border);background:var(--card-bg)}.spark-bar-fill{width:100%;max-width:14px;border-radius:8px;background:var(--danger-2);min-height:6px;align-self:end;display:flex;justify-content:center;align-items:flex-start}.spark-bar-fill-value{margin-top:6px;padding:.05rem .28rem;font-size:.68rem;font-variant-numeric:tabular-nums;line-height:1.1;white-space:nowrap;color:var(--text-main);background:var(--card-bg);border:1px solid var(--table-border);border-radius:2px;pointer-events:none}.spark-bar-label{font-size:.72rem;color:var(--text-muted);white-space:nowrap}.income-flow-overview{margin-top:.6rem}.column-overview-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.45rem}.column-overview-row{display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding:.24rem .4rem;border:1px solid var(--table-border);border-radius:8px;background:var(--table-stripe)}.column-overview-row strong{font-weight:700}.danger{color:var(--danger-2)}.muted{color:var(--text-muted);font-size:.84rem;line-height:1.35}.budget-over{color:var(--danger-2);font-weight:700}.budget-under{color:var(--budget-under);font-weight:700}.amount-modal-backdrop{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:1rem;background:var(--focus-ring)}.amount-modal{width:min(92vw,360px)}.amount-modal h3{margin:0 0 .6rem}.amount-modal .amount-modal-body{display:grid;gap:.6rem}.amount-modal .amount-modal-meta{display:grid;gap:.15rem;color:var(--text-muted);font-size:.86rem}.amount-modal .amount-modal-actions{display:flex;justify-content:flex-end;gap:.55rem;flex-wrap:wrap}.weekly-shopping-modal-backdrop{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;padding:1rem;background:var(--focus-ring)}.weekly-shopping-modal{width:min(92vw,560px)}.weekly-shopping-modal h3{margin:0 0 .6rem}.weekly-shopping-modal .weekly-shopping-modal-body{display:grid;gap:.7rem}.weekly-shopping-modal .weekly-shopping-eval{display:grid;gap:.32rem}.toast-root{position:fixed;right:1rem;bottom:1rem;z-index:9999;display:grid;gap:.55rem;pointer-events:none}.toast{min-width:220px;max-width:min(90vw,360px);padding:.65rem .8rem;border-radius:10px;border:1px solid var(--card-border);border-left:4px solid var(--primary-2);background:green;color:#fff;box-shadow:0 1px 1px var(--shadow-1),0 10px 24px var(--shadow-2);opacity:0;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease}.toast.toast-visible{opacity:1;transform:translateY(0)}.toast.toast-error{border-left-color:var(--danger-2)}.scroll-up-btn{position:fixed;right:1rem;bottom:4.25rem;z-index:9998;width:2.6rem;height:2.6rem;border-radius:999px;border:1px solid var(--primary-2);background:linear-gradient(180deg,var(--primary-1) 0%,var(--primary-2) 100%);color:#fff;font-size:1.1rem;font-weight:700;display:inline-flex;align-items:center;justify-content:center;box-shadow:0 1px 1px var(--shadow-1),0 10px 24px var(--shadow-2);opacity:0;visibility:hidden;pointer-events:none;transform:translateY(8px);transition:opacity .2s ease,transform .2s ease,visibility .2s ease}.scroll-up-btn.is-visible{opacity:1;visibility:visible;pointer-events:auto;transform:translateY(0)}.scroll-up-btn:hover{border-color:var(--primary-3);background:linear-gradient(180deg,var(--primary-2) 0%,var(--primary-3) 100%)}@media(max-width:1024px){.app{padding:1rem}.panel-modal{width:min(98vw,1100px);max-height:min(92vh,900px)}}@media(max-width:768px){body{font-size:.9rem}.app{padding:.75rem}.card{padding:.8rem}.app-header{align-items:flex-start;gap:.55rem}.header-actions{width:100%;justify-content:flex-start;gap:.55rem}.top-shortcuts{justify-content:stretch;gap:.5rem}.top-shortcuts .btn{flex:1 1 48%}.inline{display:grid;grid-template-columns:1fr;align-items:stretch;gap:.5rem}.inline>*{min-width:0;width:100%}input,select,button,textarea{min-height:24px;padding:.55rem .7rem}input,select,textarea{font-size:max(16px,1rem)}.grid-4>.card input.amount-input,.amount-input{min-width:55px;max-width:120px;width:100%;font-size:.95rem}.card table{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}.compact-cost-section{grid-template-columns:56px minmax(0,1fr)}.compact-cost-kicker{font-size:.78rem;letter-spacing:.01em;padding:.45rem .32rem}.compact-cost-head,.compact-cost-row{grid-template-columns:minmax(0,1fr) minmax(72px,max-content) minmax(72px,max-content);gap:.45rem;padding:.36rem .55rem}.chart-grid{grid-template-columns:1fr}.month-year-sticky{top:.3rem;padding:.5rem .55rem}.chart-tile{padding:.7rem}.chart-tile-trend{grid-column:auto}.chart-tile-header{flex-direction:column;align-items:flex-start;gap:.35rem}.year-trend-summary-head{align-items:flex-start}.year-trend-metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.year-trend-visual,.year-trend-svg{min-height:260px;height:260px}.bar-row{grid-template-columns:1fr;gap:.35rem}.bar-meta{justify-content:flex-start;white-space:normal;flex-wrap:wrap}.circle-chart-container{grid-template-columns:1fr}.circle-chart-item{width:min(100%,180px);justify-self:center}.spark-bars{min-width:0;width:100%;height:300px}.trend-badge{white-space:normal}.daily-table th,.daily-table td{white-space:nowrap}.column-overview-grid{grid-template-columns:1fr}.panel-modal-backdrop,.amount-modal-backdrop,.weekly-shopping-modal-backdrop{padding:.6rem}.toast-root{left:.75rem;right:.75rem;bottom:.75rem}.scroll-up-btn{right:.75rem;bottom:4.6rem}.toast{min-width:0;max-width:100%}}@media(max-width:480px){.app-title{font-size:1.3rem}.header-actions .export-warning{width:100%;justify-content:center}.top-shortcuts .btn{flex-basis:100%}}
