:root{
  --bg:#0f172a; --bg2:#1e293b; --card:#1e293b; --border:#334155;
  --text:#e2e8f0; --text2:#94a3b8; --accent:#3b82f6; --accent2:#2563eb;
  --green:#22c55e; --red:#ef4444; --amber:#f59e0b; --radius:10px;
}
*{box-sizing:border-box}
body{margin:0;background:var(--bg);color:var(--text);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;font-size:15px}
a{color:var(--accent);text-decoration:none}
.topbar{display:flex;align-items:center;gap:18px;padding:12px 22px;
  background:var(--bg2);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}
.topbar .brand{font-weight:700;letter-spacing:.3px}
.topbar nav{display:flex;gap:6px;margin-left:8px}
.topbar nav a{padding:6px 12px;border-radius:8px;color:var(--text2)}
.topbar nav a.active,.topbar nav a:hover{background:var(--bg);color:var(--text)}
.topbar .spacer{flex:1}
.topbar .who{color:var(--text2);font-size:13px}
.wrap{max-width:1100px;margin:0 auto;padding:24px 22px}
.card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);
  padding:18px 20px;margin-bottom:18px}
.card h2{margin:0 0 14px;font-size:17px}
h1{font-size:22px;margin:0 0 18px}
label{display:block;font-size:13px;color:var(--text2);margin-bottom:5px}
input,select,textarea{width:100%;padding:9px 11px;background:var(--bg);color:var(--text);
  border:1px solid var(--border);border-radius:8px;font-size:14px}
input:focus,select:focus{outline:none;border-color:var(--accent)}
.row{display:flex;gap:14px;flex-wrap:wrap}
.row>.form-group{flex:1;min-width:140px;margin-bottom:14px}
button,.btn{padding:9px 16px;border:none;border-radius:8px;background:var(--accent);
  color:#fff;font-size:14px;font-weight:600;cursor:pointer}
button:hover,.btn:hover{background:var(--accent2)}
.btn-ghost{background:var(--bg);border:1px solid var(--border);color:var(--text)}
.btn-ghost:hover{background:var(--border)}
.btn-green{background:var(--green)} .btn-green:hover{filter:brightness(.92)}
.btn-danger{background:var(--red)} .btn-sm{padding:5px 10px;font-size:13px}
table{width:100%;border-collapse:collapse;font-size:14px}
th,td{text-align:left;padding:9px 10px;border-bottom:1px solid var(--border)}
th{color:var(--text2);font-weight:600;font-size:12px;text-transform:uppercase;letter-spacing:.4px}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums}
.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:12px;font-weight:600}
.b-offen{background:#78350f;color:#fde68a} .b-freigegeben{background:#1e3a8a;color:#bfdbfe}
.b-ausgezahlt{background:#14532d;color:#bbf7d0} .b-storniert{background:#7f1d1d;color:#fecaca}
.stats{display:flex;gap:14px;flex-wrap:wrap;margin-bottom:18px}
.stat{flex:1;min-width:150px;background:var(--card);border:1px solid var(--border);
  border-radius:var(--radius);padding:14px 16px}
.stat .l{color:var(--text2);font-size:12px;text-transform:uppercase;letter-spacing:.4px}
.stat .v{font-size:22px;font-weight:700;margin-top:4px;font-variant-numeric:tabular-nums}
.msg{font-size:13px;margin-top:8px;min-height:18px}
.partner-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px}
.pcheck{display:flex;align-items:center;gap:10px;padding:10px 12px;background:var(--bg);
  border:1px solid var(--border);border-radius:8px;cursor:pointer}
.pcheck.on{border-color:var(--accent);background:#1e3a5f}
.pcheck .box{width:18px;height:18px;border:2px solid var(--border);border-radius:4px;
  display:flex;align-items:center;justify-content:center;font-size:12px;color:transparent}
.pcheck.on .box{background:var(--accent);border-color:var(--accent);color:#fff}
.muted{color:var(--text2);font-size:13px}
.right{text-align:right}
.flex{display:flex;gap:10px;align-items:center;flex-wrap:wrap}
.checkrow{display:flex;align-items:center;gap:8px}
.checkrow input[type=checkbox]{width:auto}
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-card{width:340px}
.toast{position:fixed;bottom:20px;right:20px;background:var(--card);border:1px solid var(--border);
  padding:12px 18px;border-radius:8px;opacity:0;transition:.2s;pointer-events:none}
.toast.show{opacity:1}
