/*
Dateipfad: backend/static/styles.css
Abhaengigkeiten: keine
Funktionsbeschreibung:
Zentrales Styling der Vanilla-Weboberflaeche. Kein Node, kein Build-Step.
*/
:root{--bg:#f5f7fb;--panel:#fff;--panel2:#eef4ff;--text:#16213e;--muted:#64748b;--line:#dbe4f0;--brand:#2563eb;--brand2:#1d4ed8;--good:#16a34a;--bad:#dc2626;--warn:#f59e0b;--radius:18px;--shadow:0 18px 45px rgba(15,23,42,.08)}
*{box-sizing:border-box}body{margin:0;font-family:Inter,Segoe UI,Roboto,Arial,sans-serif;background:var(--bg);color:var(--text);display:flex;min-height:100vh}.sidebar{width:286px;background:linear-gradient(180deg,#102452,#183b84);color:white;padding:24px;display:flex;flex-direction:column;gap:24px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:14px}.logo{width:48px;height:48px;display:grid;place-items:center;background:rgba(255,255,255,.16);border-radius:16px;font-size:28px}.brand small{display:block;color:#cbd5e1;margin-top:4px}.sidebar nav{display:grid;gap:10px}.nav,.ghost,.primary,.danger,.soft{border:0;border-radius:14px;padding:12px 14px;font-weight:800;cursor:pointer;transition:.15s}.nav{text-align:left;background:rgba(255,255,255,.08);color:white}.nav:hover,.nav.active{background:white;color:#17346f;transform:translateX(3px)}.ghost{margin-top:auto;background:rgba(255,255,255,.14);color:white}.primary{background:var(--brand);color:white}.primary:hover{background:var(--brand2)}.danger{background:#fee2e2;color:#991b1b}.soft{background:#eaf1ff;color:#1e3a8a}main{flex:1;padding:28px;min-width:0}.topbar{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.topbar h1{margin:0;font-size:34px}.topbar p{margin:6px 0 0;color:var(--muted)}#toast{background:#ecfdf5;color:#166534;padding:10px 14px;border-radius:999px;opacity:0;transform:translateY(-6px);transition:.2s}#toast.show{opacity:1;transform:translateY(0)}.grid{display:grid;gap:18px}.grid.cards{grid-template-columns:repeat(4,minmax(180px,1fr))}.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px}.card h3{margin:0 0 8px}.metric{font-size:34px;font-weight:900}.muted{color:var(--muted)}.row{display:flex;gap:12px;align-items:center;flex-wrap:wrap}.between{justify-content:space-between}.tabs{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:16px}.tab{border:1px solid var(--line);background:white;border-radius:999px;padding:10px 14px;font-weight:800;cursor:pointer}.tab.active{background:var(--brand);color:white;border-color:var(--brand)}table{width:100%;border-collapse:separate;border-spacing:0 8px}th{text-align:left;color:#475569;font-size:13px;padding:0 12px}td{background:white;border-top:1px solid var(--line);border-bottom:1px solid var(--line);padding:12px}td:first-child{border-left:1px solid var(--line);border-radius:13px 0 0 13px}td:last-child{border-right:1px solid var(--line);border-radius:0 13px 13px 0}.pill{display:inline-flex;align-items:center;gap:6px;border-radius:999px;padding:6px 10px;font-weight:800;font-size:12px}.pill.good{background:#dcfce7;color:#166534}.pill.bad{background:#fee2e2;color:#991b1b}.pill.warn{background:#fef3c7;color:#92400e}.form{display:grid;gap:12px}.form.two{grid-template-columns:repeat(2,minmax(180px,1fr))}label{display:grid;gap:6px;font-weight:800;color:#334155}input,select,textarea{border:1px solid var(--line);border-radius:13px;padding:12px 13px;font:inherit;background:#fff;outline:none}input:focus,select:focus,textarea:focus{border-color:var(--brand);box-shadow:0 0 0 4px rgba(37,99,235,.12)}textarea{min-height:90px}.split{display:grid;grid-template-columns:1.1fr .9fr;gap:18px}.list{display:grid;gap:10px}.item{padding:14px;border:1px solid var(--line);background:white;border-radius:16px}.actions{display:flex;gap:8px;flex-wrap:wrap}.smallbtn{border:1px solid var(--line);background:#fff;border-radius:10px;padding:7px 10px;font-weight:800;cursor:pointer}dialog{border:0;border-radius:24px;box-shadow:0 30px 80px rgba(15,23,42,.25);width:min(720px,94vw)}dialog::backdrop{background:rgba(15,23,42,.45)}@media(max-width:980px){body{display:block}.sidebar{width:auto;height:auto;position:relative}.sidebar nav{grid-template-columns:repeat(2,1fr)}.grid.cards{grid-template-columns:repeat(2,1fr)}.split{grid-template-columns:1fr}.form.two{grid-template-columns:1fr}}@media(max-width:560px){main{padding:16px}.grid.cards{grid-template-columns:1fr}.topbar{display:block}.sidebar nav{grid-template-columns:1fr}}

/* Erweiterung: Original-naehere Spielabend-, Kassenbuch- und Statistik-Optik */
button:disabled{opacity:.55;cursor:not-allowed}.large{font-size:16px;padding:15px 18px}.hero-card{background:linear-gradient(135deg,#2563eb,#7c3aed);border-radius:30px;color:white;padding:24px;box-shadow:0 26px 60px rgba(37,99,235,.22);display:flex;justify-content:space-between;align-items:center;gap:18px;overflow:hidden;position:relative}.hero-card:before{content:"";position:absolute;right:-80px;top:-80px;width:260px;height:260px;background:rgba(255,255,255,.12);border-radius:999px}.hero-card h2{margin:8px 0 6px;font-size:30px}.hero-card p{margin:0;color:#e0e7ff}.hero-icon{width:56px;height:56px;border-radius:20px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:32px}.hero-btn{border:0;border-radius:18px;background:white;color:#17346f;padding:14px 18px;font-weight:900;cursor:pointer;z-index:1}.hero-btn.danger,.danger.hero-btn{background:#fee2e2;color:#991b1b}.hero-chips{display:flex;gap:8px;flex-wrap:wrap;margin-top:14px}.hero-chips span{background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.24);border-radius:999px;padding:8px 12px;font-weight:800}.metric-card{position:relative;overflow:hidden}.metric-icon{width:44px;height:44px;border-radius:16px;background:#eff6ff;display:grid;place-items:center;font-size:24px;margin-bottom:10px}.spielabend-empty{display:grid;grid-template-columns:1.05fr .95fr;gap:18px}.start-card{background:linear-gradient(135deg,#fff,#eef4ff)}.big-icon{width:70px;height:70px;border-radius:25px;background:#dbeafe;display:grid;place-items:center;font-size:38px;margin-bottom:14px}.spiel-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(320px,.75fr);gap:18px;margin-top:18px}.section-title{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.section-title span{font-weight:900;font-size:20px}.section-title small{color:var(--muted);font-weight:700}.empty-box{background:#f8fafc;border:1px dashed #cbd5e1;border-radius:18px;padding:18px}.live-game{background:linear-gradient(135deg,#eff6ff,#f5f3ff);border:1px solid #dbeafe;border-radius:22px;padding:18px;display:flex;align-items:center;justify-content:space-between;gap:14px}.live-game h3{font-size:24px;margin:8px 0}.checkline{display:flex!important;grid-template-columns:auto 1fr!important;align-items:center;margin-top:10px}.game-row{display:flex;gap:12px;align-items:center;border:1px solid var(--line);background:#fff;border-radius:18px;padding:12px}.game-order{width:38px;height:38px;border-radius:14px;background:#e0ecff;color:#1e3a8a;font-weight:900;display:grid;place-items:center}.grow{flex:1}.section-header{margin:22px 0 12px}.section-header h2{margin:0}.participant-grid{display:grid;grid-template-columns:repeat(3,minmax(220px,1fr));gap:14px;margin-bottom:18px}.participant-card{text-align:left;border:1px solid var(--line);background:#fff;border-radius:22px;padding:16px;box-shadow:var(--shadow);display:grid;gap:9px;cursor:pointer;transition:.16s}.participant-card:hover{transform:translateY(-3px);border-color:#93c5fd}.avatar{width:54px;height:54px;border-radius:19px;background:linear-gradient(135deg,#2563eb,#7c3aed);display:grid;place-items:center;color:white;font-size:24px;font-weight:900}.compact{gap:7px}.compact .item{padding:10px;border-radius:13px}.selector-list{display:grid;grid-template-columns:repeat(2,minmax(180px,1fr));gap:10px}.select-tile{display:flex!important;grid-template-columns:auto 1fr!important;gap:10px;align-items:center;border:1px solid var(--line);border-radius:16px;padding:12px;background:#fff}.select-tile small{display:block;color:var(--muted);font-weight:600}.action-grid{display:grid;grid-template-columns:repeat(2,minmax(230px,1fr));gap:12px}.action-box{border:1px solid var(--line);background:#f8fafc;border-radius:18px;padding:14px}.action-box h3{margin-top:0}.two-cards{grid-template-columns:repeat(2,minmax(240px,1fr))!important}.linkbtn{text-decoration:none;display:inline-flex;align-items:center}.kassen-days{display:grid;gap:12px;margin-top:16px}.day-card{border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:12px}.day-card summary{cursor:pointer;display:flex;gap:10px;align-items:center;flex-wrap:wrap}.day-card table{margin-top:10px}@media(max-width:1100px){.participant-grid{grid-template-columns:repeat(2,minmax(220px,1fr))}.spiel-grid,.spielabend-empty{grid-template-columns:1fr}}@media(max-width:680px){.participant-grid,.selector-list,.action-grid{grid-template-columns:1fr}.hero-card{display:block}.hero-btn{margin-top:16px}.two-cards{grid-template-columns:1fr!important}}

/* Fix: Spielabschluss ohne hakelige Multi-Select-Dropdowns */
.result-list{display:grid;gap:10px;margin-top:14px}.result-row{display:grid;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;border:1px solid var(--line);background:#fff;border-radius:18px;padding:12px 14px}.result-row:hover{border-color:#93c5fd;background:#f8fbff}.winner-radio,.loser-check{width:18px;height:18px}.loser-pill{display:flex!important;align-items:center;grid-template-columns:auto 1fr!important;gap:7px;border-radius:999px;background:#fee2e2;color:#991b1b;padding:8px 12px;font-weight:900}.loser-pill.disabled{opacity:.45;background:#e5e7eb;color:#64748b}


/* Fix 3: Quellen-Storno, kompaktes Kassenbuch und Spielabend-Abrechnung */
.danger-mini{background:#fee2e2!important;color:#991b1b!important;border-color:#fecaca!important}
.is-storno{opacity:.55;text-decoration:line-through;background:#f8fafc!important}
.kassen-layout{display:grid;grid-template-columns:minmax(0,1.35fr) minmax(320px,.65fr);gap:18px;margin-top:18px}
.kassen-compact .tabs{margin-bottom:0}.mini-tabs .tab{padding:8px 11px;font-size:13px}
.booking-list{display:grid;gap:7px;margin-top:10px}.booking-row{display:grid;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:10px;background:#fff;border:1px solid var(--line);border-radius:14px;padding:9px 10px}
.amount{font-weight:950;white-space:nowrap}.amount.in{color:#166534}.amount.out{color:#991b1b}
.spielabend-list-btn{width:100%;border:1px solid var(--line);border-radius:16px;background:#fff;padding:12px;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:10px;cursor:pointer}
.spielabend-list-btn:hover{border-color:#93c5fd;background:#f8fbff}
.abrechnung-list{display:grid;gap:12px;max-height:68vh;overflow:auto;padding-right:4px}.player-account{border:1px solid var(--line);border-radius:18px;background:#f8fafc;padding:12px}.player-account summary{cursor:pointer;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mini-section{margin-top:10px;padding:10px;background:white;border:1px solid var(--line);border-radius:14px}.mini-line{padding:6px 0;border-bottom:1px dashed #e2e8f0}.mini-line:last-child{border-bottom:0}
@media(max-width:1100px){.kassen-layout{grid-template-columns:1fr}.booking-row{grid-template-columns:1fr}.amount{white-space:normal}}

/* Fix4: pompöse Spielabend-/Pokal-Erweiterungen */
.event-log summary, .event-group summary { cursor: pointer; list-style: none; }
.event-log summary::-webkit-details-marker, .event-group summary::-webkit-details-marker { display: none; }
.event-log > summary { padding: 0; }
.event-log-body { margin-top: 14px; display: grid; gap: 10px; }
.event-group { border: 1px solid rgba(148, 163, 184, .25); border-radius: 16px; padding: 10px 12px; background: rgba(255,255,255,.55); }
.event-group > summary { display: flex; align-items: center; justify-content: space-between; gap: 12px; }
.select-tile.special { background: linear-gradient(135deg, rgba(255, 247, 237, .95), rgba(254, 243, 199, .9)); border-color: rgba(245, 158, 11, .45); }
.stechen-live { background: linear-gradient(135deg, #fff7ed, #fef3c7); border: 1px solid rgba(245, 158, 11, .35); }
.winner-pill { display: inline-flex; align-items: center; gap: 7px; background: rgba(34,197,94,.10); border: 1px solid rgba(34,197,94,.25); padding: 7px 10px; border-radius: 999px; }
.trophy-card { background: radial-gradient(circle at top left, rgba(250, 204, 21, .25), transparent 35%), white; }
.trophy-row { display: flex; align-items: center; gap: 14px; padding: 12px; border-radius: 16px; border: 1px solid rgba(148, 163, 184, .2); margin-top: 10px; background: rgba(255,255,255,.72); }
.trophy-row > span { font-size: 28px; }

/* Fix7: saubere Zahlungsaufteilung Betreiber/Kegelkasse */
.abrechnung-summary { margin: 16px 0; }
.mini-payments { align-items: stretch; gap: 12px; }
.pay-operator { border-left: 4px solid #2563eb; background: rgba(37, 99, 235, .06); }
.pay-club { border-left: 4px solid #16a34a; background: rgba(22, 163, 74, .06); }
.player-account summary .pill { margin-left: 6px; }

/* Fix8: kompakte, standardmaessig geschlossene Spielabend-Abrechnung + WhatsApp-Teilen */
.share-box{display:flex;justify-content:space-between;align-items:center;gap:14px;margin:14px 0 18px;padding:14px;border:1px solid var(--line);border-radius:18px;background:#f8fafc}
.player-account:not([open]){background:#fff}.player-account summary::before{content:'▶';font-size:12px;color:#64748b}.player-account[open] summary::before{content:'▼'}
.expand-hint{margin-left:auto;color:#64748b;font-size:12px;font-weight:800;background:#eef2ff;border-radius:999px;padding:6px 10px}.player-account[open] .expand-hint{display:none}
@media(max-width:680px){.share-box{display:grid}.expand-hint{margin-left:0}}

/* Fix10: Statistik-Akkordeons */
.accordion-list { display: grid; gap: 10px; }
.stat-detail { border: 1px solid rgba(15, 23, 42, .10); border-radius: 18px; background: rgba(255,255,255,.72); overflow: hidden; }
.stat-detail > summary { cursor: pointer; list-style: none; display: flex; align-items: center; justify-content: space-between; gap: 14px; padding: 14px 16px; }
.stat-detail > summary::-webkit-details-marker { display: none; }
.stat-detail > summary::after { content: 'aufklappen'; font-size: 12px; color: var(--muted); }
.stat-detail[open] > summary::after { content: 'zuklappen'; }
.stat-detail table { margin: 0; border-top: 1px solid rgba(15, 23, 42, .08); }

/* Fix14: Bahnkosten ohne Kegelkassen-Ausgleich exakt auf Mitglieder verteilt */
.info-box {
  margin: 14px 0;
  padding: 14px 16px;
  border-radius: 16px;
  border: 1px solid rgba(15, 23, 42, 0.10);
  background: rgba(255, 255, 255, 0.78);
  box-shadow: 0 10px 28px rgba(15, 23, 42, 0.08);
  line-height: 1.45;
}
.warn-box {
  background: linear-gradient(135deg, rgba(255, 247, 237, 0.96), rgba(254, 243, 199, 0.78));
  border-color: rgba(245, 158, 11, 0.28);
}

/* Fix15: Login, Ersteinrichtungswizard und Benutzerverwaltung */
body.auth-mode .sidebar{display:none}
body.auth-mode main{width:100%;padding:0;display:grid;place-items:center;min-height:100vh;background:
  radial-gradient(circle at top left, rgba(37,99,235,.18), transparent 32%),
  radial-gradient(circle at bottom right, rgba(124,58,237,.16), transparent 30%),
  var(--bg);}
body.auth-mode .topbar{position:fixed;top:22px;left:28px;right:28px}
body.auth-mode #app{width:min(1040px,94vw);margin-top:90px}
.auth-wrap,.setup-wrap{width:100%;display:grid;place-items:center}.auth-card{width:min(460px,94vw);background:white;border:1px solid var(--line);border-radius:30px;box-shadow:0 30px 80px rgba(15,23,42,.16);padding:28px;display:grid;gap:14px}.auth-card h2,.setup-card h2{margin:0}.setup-card{width:100%;padding:26px}.setup-card h3{margin:24px 0 12px}.setup-row{display:grid;grid-template-columns:repeat(4,minmax(120px,1fr)) auto;gap:10px;margin:8px 0;padding:10px;border:1px solid var(--line);border-radius:16px;background:#f8fafc}.setup-row.member-row{grid-template-columns:repeat(5,minmax(110px,1fr)) 95px auto}.setup-row button{border:0;border-radius:12px;background:#fee2e2;color:#991b1b;font-weight:900;cursor:pointer}.mini-check{display:flex!important;align-items:center;gap:6px;font-size:13px}.user-box{font-size:13px;color:#dbeafe;font-weight:800;line-height:1.35}.ghost + .ghost{margin-top:8px}@media(max-width:900px){.setup-row,.setup-row.member-row{grid-template-columns:1fr}.setup-row button{padding:10px}}

/* Fix16: Gefuehrter Ersteinrichtungswizard mit Datenbank-Pflichtseite */
.wizard-card{max-width:1120px}
.wizard-progress{display:flex;flex-wrap:wrap;gap:8px;margin:18px 0 22px}
.wizard-progress span{font-size:12px;font-weight:900;padding:8px 10px;border-radius:999px;background:#e5e7eb;color:#64748b}
.wizard-progress span.active{background:#2563eb;color:#fff;box-shadow:0 10px 26px rgba(37,99,235,.25)}
.wizard-progress span.done{background:#dcfce7;color:#166534}
.wizard-actions{display:flex;flex-wrap:wrap;gap:10px;justify-content:flex-end;margin-top:20px}
.setup-details{margin-top:14px;padding:12px 14px;border:1px solid var(--line);border-radius:16px;background:#f8fafc}
.setup-details summary{cursor:pointer;font-weight:900}
.summary-box{padding:16px;border:1px solid var(--line);border-radius:18px;background:#f8fafc;line-height:1.7}
.checkline{display:flex!important;align-items:center;gap:10px;min-height:44px}
.checkline input{width:auto!important}
code{background:#eef2ff;border:1px solid #dbeafe;border-radius:8px;padding:2px 6px}

.warning-box{border:1px solid rgba(220,38,38,.25);background:#fff1f2;color:#991b1b;border-radius:16px;padding:14px 16px;margin-top:12px}
.danger-zone{border-color:rgba(220,38,38,.25)}
