@import url("https://fonts.googleapis.com/css2?family=Fraunces:wght@300;500;700&family=Space+Grotesk:wght@400;500;600;700&display=swap" );:root{--bg:#0e1118;--bg-soft:#161b26;--panel:#1e2433;--panel-2:#222a3c;--ink:#f2f4fa;--muted:#a7afc2;--accent:#64f0c2;--accent-2:#ffcf6d;--accent-3:#7aa6ff;--danger:#ff6b6b;--border:hsla(0,0%,100%,.08);--radius:18px;--shadow:0 25px 70px rgba(0,0,0,.45)}*{box-sizing:border-box}body{margin:0;font-family:Space Grotesk,system-ui,-apple-system,sans-serif;color:var(--ink);background:radial-gradient(circle at 12% 20%,rgba(122,166,255,.2) 0,transparent 40%),radial-gradient(circle at 80% 10%,rgba(100,240,194,.18) 0,transparent 35%),radial-gradient(circle at 90% 80%,rgba(255,207,109,.15) 0,transparent 38%),var(--bg);min-height:100vh}main{max-width:1200px;margin:0 auto;padding:48px 28px 80px}a{color:inherit;text-decoration:none}header{justify-content:space-between;gap:24px;margin-bottom:32px}.logo,header{display:flex;align-items:center}.logo{gap:14px;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.logo-badge{width:46px;height:46px;border-radius:16px;background:linear-gradient(135deg,var(--accent),var(--accent-3));display:grid;place-items:center;color:#0e1118;font-weight:700;box-shadow:var(--shadow)}.tagline{color:var(--muted);font-size:.95rem}.hero{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));grid-gap:26px;gap:26px;margin-bottom:32px}.hero h1{font-family:Fraunces,serif;font-size:clamp(2.2rem,3vw,3.5rem);margin:0 0 16px}.hero p{margin:0 0 24px;color:var(--muted)}.pill-row{display:flex;flex-wrap:wrap;gap:10px}.pill{padding:8px 14px;border-radius:999px;background:hsla(0,0%,100%,.06);font-size:.85rem}.panel,.pill{border:1px solid var(--border)}.panel{background:var(--panel);border-radius:var(--radius);box-shadow:var(--shadow);padding:22px}.panel h3{margin:0 0 12px}.stats{display:grid;grid-gap:12px;gap:12px}.stat{display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);padding:10px 0;color:var(--muted);font-size:.95rem}.stat:last-child{border-bottom:none}.section-title{display:flex;align-items:center;justify-content:space-between;margin:36px 0 18px}.section-title h2{margin:0;font-size:1.5rem}.grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:16px;gap:16px}.card{background:var(--panel-2);border:1px solid var(--border);border-radius:var(--radius);padding:18px}.card h4{margin:0 0 10px}.card p{margin:0;color:var(--muted);font-size:.93rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));grid-gap:14px;gap:14px}label{display:flex;flex-direction:column;gap:8px;font-size:.9rem;color:var(--muted)}input,select,textarea{background:#0f131f;border:1px solid var(--border);color:var(--ink);padding:10px 12px;border-radius:12px;font-family:inherit}textarea{min-height:80px;resize:vertical}.actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}button{background:linear-gradient(120deg,var(--accent),var(--accent-2));color:#0e1118;border:none;border-radius:999px;padding:10px 18px;font-weight:600;cursor:pointer;box-shadow:var(--shadow)}button.secondary{background:transparent;color:var(--ink);border:1px solid var(--border);box-shadow:none}.table{width:100%;border-collapse:collapse;font-size:.92rem}.table td,.table th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--border)}.table th{font-weight:600}.footer,.table th{color:var(--muted)}.footer{display:flex;justify-content:space-between;flex-wrap:wrap;gap:12px;margin-top:40px;font-size:.85rem}.notice{border-left:3px solid var(--accent);padding:14px 18px;border-radius:12px;background:rgba(100,240,194,.1);color:var(--muted);font-size:.92rem}.fade-in{animation:fadeIn .9s ease-out both}.fade-in.delay{animation-delay:.2s}.fade-in.delay-2{animation-delay:.35s}@keyframes fadeIn{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@media (max-width:760px){header{align-items:flex-start}.filter-bar,header{flex-direction:column}.table-wrap{overflow-x:auto}}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:24px}.login-card{background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:36px 32px;width:100%;max-width:400px}.tab-bar{display:flex;gap:4px;margin:24px 0 8px;border-bottom:2px solid var(--border);padding-bottom:0}.tab{background:transparent;color:var(--muted);border:none;border-radius:12px 12px 0 0;padding:10px 20px;font-weight:600;cursor:pointer;box-shadow:none;transition:color .2s,background .2s}.tab:hover{color:var(--ink);background:hsla(0,0%,100%,.04)}.tab.active{color:var(--accent);background:var(--panel);border:1px solid var(--border);border-bottom:2px solid var(--bg);margin-bottom:-2px}.filter-bar{display:flex;flex-wrap:wrap;gap:12px;align-items:flex-end;padding:16px;background:var(--panel);border:1px solid var(--border);border-radius:var(--radius);margin-top:12px}.filter-field{display:flex;flex-direction:column;gap:4px;font-size:.82rem;color:var(--muted);min-width:120px}.filter-field input,.filter-field select{padding:8px 10px;font-size:.88rem}.filter-search{flex:1 1;min-width:180px}.filter-reset{padding:8px 14px;font-size:.82rem;align-self:flex-end}.table-wrap{overflow-x:auto}.sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.sortable:hover{color:var(--accent)}.row-income td:first-child{border-left:3px solid var(--accent)}.row-expense td:first-child{border-left:3px solid var(--danger)}.action-cell{display:flex;gap:6px;white-space:nowrap}.icon-btn{background:transparent;border:1px solid var(--border);border-radius:8px;padding:4px 8px;cursor:pointer;font-size:.85rem;color:var(--ink);box-shadow:none}.icon-btn:hover{background:hsla(0,0%,100%,.06)}.icon-btn.danger:hover{background:hsla(0,100%,71%,.15);border-color:var(--danger)}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:.78rem;font-weight:600}.badge.income{background:rgba(100,240,194,.15);color:var(--accent)}.badge.expense{background:hsla(0,100%,71%,.15);color:var(--danger)}.badge-btn{background:transparent;border:1px solid var(--border);border-radius:999px;padding:3px 10px;font-size:.78rem;font-weight:600;cursor:pointer;box-shadow:none;color:var(--muted);transition:all .2s}.badge-btn.bezahlt{background:rgba(100,240,194,.12);color:var(--accent);border-color:rgba(100,240,194,.3)}.badge-btn.offen{background:rgba(255,207,109,.12);color:var(--accent-2);border-color:rgba(255,207,109,.3)}.badge-btn:hover{opacity:.8}.income-color{color:var(--accent)}.expense-color{color:var(--danger)}.muted{color:var(--muted)}.amount{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;text-align:right;white-space:nowrap}.total-row{border-top:2px solid var(--border)}.error-msg{margin-top:10px;padding:10px 14px;border-radius:10px;background:hsla(0,100%,71%,.12);border:1px solid hsla(0,100%,71%,.3);color:var(--danger);font-size:.9rem}.toast{position:fixed;top:22px;right:22px;background:var(--panel-2);color:var(--accent);border:1px solid var(--accent);border-radius:12px;padding:12px 22px;font-weight:600;font-size:.9rem;z-index:9999;box-shadow:var(--shadow);animation:toastIn .3s ease-out}@keyframes toastIn{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.big-number{font-size:1.6rem;font-weight:700;margin:8px 0 4px;font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.link{text-decoration:none;font-size:1.1rem}.link:hover{opacity:.7}