*{margin:0;padding:0;box-sizing:border-box}:root{--green: #4CAF50;--green-dark: #2E7D32;--green-light: #E8F5E9;--pink: #E91E63;--pink-light: #FCE4EC;--red: #C62828;--red-light: #FFEBEE;--blue-input: #E8F0FE;--yellow: #FFF8E1;--gray-50: #FAFAFA;--gray-100: #F5F5F5;--gray-200: #EEEEEE;--gray-300: #E0E0E0;--gray-400: #BDBDBD;--gray-500: #9E9E9E;--gray-600: #757575;--gray-700: #616161;--gray-800: #424242;--gray-900: #212529;--shadow-sm: 0 1px 2px rgba(0,0,0,.05);--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.06);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05);--radius: 8px;--radius-lg: 12px}body{font-family:Inter,-apple-system,sans-serif;background:var(--gray-50);color:var(--gray-900);line-height:1.5}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--green-dark) 0%,#1B5E20 100%)}.auth-card{background:#fff;border-radius:var(--radius-lg);padding:40px;width:100%;max-width:420px;box-shadow:var(--shadow-lg)}.auth-logo{text-align:center;margin-bottom:32px}.auth-logo h1{font-size:28px;font-weight:700;color:var(--green-dark)}.auth-logo h1 span{color:var(--pink)}.auth-logo p{color:var(--gray-500);font-size:14px;margin-top:4px}.auth-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.form-group label{font-size:13px;font-weight:500;color:var(--gray-700)}.form-group input,.form-group select{padding:10px 14px;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:14px;font-family:inherit;transition:border-color .2s,box-shadow .2s;outline:none}.form-group input:focus,.form-group select:focus{border-color:var(--green);box-shadow:0 0 0 3px #4caf501a}.btn{padding:10px 20px;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:var(--green-dark);color:#fff}.btn-primary:hover{background:#1b5e20;transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn-danger{background:var(--red);color:#fff}.btn-danger:hover{background:#b71c1c}.btn-ghost{background:transparent;color:var(--gray-600)}.btn-ghost:hover{background:var(--gray-100)}.btn-sm{padding:6px 12px;font-size:13px}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.auth-toggle{text-align:center;margin-top:16px;font-size:13px;color:var(--gray-500)}.auth-toggle button{background:none;border:none;color:var(--green-dark);font-weight:600;cursor:pointer;font-family:inherit}.layout{min-height:100vh;display:flex;flex-direction:column}.topbar{background:#fff;border-bottom:1px solid var(--gray-200);padding:0 24px;height:64px;display:flex;align-items:center;justify-content:space-between;box-shadow:var(--shadow-sm);position:sticky;top:0;z-index:100}.topbar-brand{display:flex;align-items:center;gap:12px}.topbar-brand h1{font-size:20px;font-weight:700;color:var(--green-dark)}.topbar-brand h1 span{color:var(--pink)}.topbar-badge{background:var(--green-light);color:var(--green-dark);font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px}.topbar-right{display:flex;align-items:center;gap:16px}.topbar-user{font-size:13px;color:var(--gray-600)}.topbar-role{font-size:11px;font-weight:600;padding:2px 8px;border-radius:99px}.topbar-role.admin{background:var(--pink-light);color:var(--pink)}.topbar-role.user{background:var(--blue-input);color:#1565c0}.main-content{flex:1;padding:24px;max-width:1400px;margin:0 auto;width:100%}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:24px}.dash-card{background:#fff;border-radius:var(--radius-lg);padding:20px;box-shadow:var(--shadow);border-left:4px solid var(--green)}.dash-card.expense{border-left-color:var(--pink)}.dash-card.balance{border-left-color:var(--green-dark)}.dash-card.count{border-left-color:#ff9800}.dash-card-label{font-size:12px;font-weight:500;color:var(--gray-500);text-transform:uppercase;letter-spacing:.5px}.dash-card-value{font-size:28px;font-weight:700;margin-top:4px}.dash-card-value.green{color:var(--green-dark)}.dash-card-value.red{color:var(--red)}.dash-card-value.blue{color:#1565c0}.toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:16px;flex-wrap:wrap}.toolbar-filters{display:flex;gap:8px;flex-wrap:wrap}.toolbar-filters select,.toolbar-filters input{padding:8px 12px;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:13px;font-family:inherit;background:#fff;outline:none}.toolbar-filters select:focus,.toolbar-filters input:focus{border-color:var(--green)}.table-container{background:#fff;border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.table-scroll{overflow-x:auto}table{width:100%;border-collapse:collapse;font-size:14px}thead th{background:#1b5e20;color:#fff;padding:14px 12px;text-align:left;font-weight:600;font-size:13px;white-space:nowrap;position:sticky;top:0}thead th.col-einnahme{background:var(--green-dark)}thead th.col-ausgabe{background:#ad1457}tbody tr{border-bottom:1px solid var(--gray-200);transition:background .15s}tbody tr:hover{background:var(--gray-50)}tbody tr.confirmed{background:var(--green-light)}tbody tr.confirmed:hover{background:#c8e6c9}tbody td{padding:10px 12px}tbody td.nr{color:var(--gray-400);font-size:12px;text-align:center}tbody td.weekday{color:var(--gray-500);font-size:12px;font-style:italic}tbody td.einnahme{color:var(--green-dark);font-weight:600;text-align:right}tbody td.ausgabe{color:var(--red);font-weight:600;text-align:right}tbody td.saldo{font-weight:700;text-align:right}tbody td.saldo.positive{color:var(--green-dark)}tbody td.saldo.negative{color:var(--red)}.weekend{background:#fff3e0}.confirm-btn{width:20px;height:20px;cursor:pointer;accent-color:var(--green-dark)}.confirm-btn:disabled{cursor:not-allowed}.lock-icon{font-size:16px}.add-form{background:#fff;border-radius:var(--radius-lg);padding:24px;box-shadow:var(--shadow);margin-bottom:24px;border:2px dashed var(--gray-300)}.add-form h3{font-size:16px;font-weight:600;color:var(--green-dark);margin-bottom:16px}.add-form-grid{display:grid;grid-template-columns:140px 1fr 160px 160px 160px 1fr;gap:12px;align-items:end}.add-form-grid input,.add-form-grid select{padding:10px 12px;border:1px solid var(--gray-300);border-radius:var(--radius);font-size:14px;font-family:inherit;background:var(--blue-input);outline:none}.add-form-grid input:focus,.add-form-grid select:focus{border-color:var(--green);box-shadow:0 0 0 3px #4caf501a}.add-form-actions{display:flex;gap:8px;margin-top:16px}.empty-state{text-align:center;padding:60px 20px;color:var(--gray-500)}.empty-state-icon{font-size:48px;margin-bottom:12px}.empty-state p{font-size:14px}.toast-success{background:var(--green-dark)!important}@media (max-width: 768px){.main-content{padding:16px}.dashboard-cards{grid-template-columns:repeat(2,1fr)}.add-form-grid{grid-template-columns:1fr 1fr}.topbar{padding:0 16px}.topbar-user{display:none}}.accent-bar{height:4px;background:linear-gradient(90deg,var(--green) 60%,var(--pink) 60%)}.error-msg{color:var(--red);font-size:13px;text-align:center;margin-top:8px}
