@import url('https://fonts.googleapis.com/css2?family=Fraunces:opsz,wght@9..144,400;9..144,600&family=Public+Sans:wght@400;500;600&display=swap');
:root{
  --paper:#f5f2ea;--ink:#22251f;--muted:#6b6f63;--line:#d9d3c4;--line2:#e7e2d6;
  --teal:#2f5d50;--teal-dk:#244a40;--amber:#bd6a35;--field:#fffdf8;
  --warn:#fbecd9;--warn-line:#e3b483;--bad:#a23b2d;--ok:#2f5d50;
  --shadow:0 1px 0 rgba(0,0,0,.03),0 10px 30px -18px rgba(34,37,31,.35);
}
*{box-sizing:border-box}
body{margin:0;background:radial-gradient(120% 80% at 0% 0%,#fbf9f3 0%,transparent 55%),var(--paper);
  color:var(--ink);font-family:'Public Sans',sans-serif;line-height:1.5}
h1{font-family:'Fraunces',serif;font-weight:600;font-size:27px;letter-spacing:-.01em;margin:0 0 4px}
h2{font-family:'Fraunces',serif;font-weight:600;font-size:20px;margin:0 0 12px}
.sub{color:var(--muted);margin:0 0 22px;font-size:14px}
.hidden{display:none !important}
.wrap{max-width:1080px;margin:0 auto;padding:26px 22px 70px}

/* topbar / nav */
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:18px;flex-wrap:wrap;
  padding:12px 22px;background:rgba(245,242,234,.9);backdrop-filter:blur(8px);border-bottom:1px solid var(--line)}
.brand{font-family:'Fraunces',serif;font-weight:600;font-size:17px}
nav{display:flex;gap:4px;flex:1}
nav button{font:inherit;font-weight:600;font-size:14px;color:var(--muted);background:none;border:none;
  padding:8px 14px;border-radius:9px;cursor:pointer}
nav button:hover{color:var(--ink);background:#ece8dd}
nav button.on{color:var(--teal-dk);background:#e6efe9}
.userbox{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--muted)}
.userbox b{color:var(--ink)}
.userbox button{font:inherit;font-size:12px;font-weight:600;color:var(--teal-dk);background:none;
  border:1px solid var(--line);padding:6px 11px;border-radius:99px;cursor:pointer}

/* cards / forms */
.card{background:var(--field);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:22px 24px;margin-bottom:18px}
.seclabel{font-family:'Fraunces',serif;font-size:13px;letter-spacing:.16em;text-transform:uppercase;color:var(--amber);margin:0 0 14px;display:flex;align-items:center;gap:10px}
.seclabel:after{content:"";height:1px;flex:1;background:var(--line2)}
.grid{display:grid;gap:12px 18px}.g3{grid-template-columns:repeat(3,1fr)}.g2{grid-template-columns:repeat(2,1fr)}
@media(max-width:640px){.g3,.g2{grid-template-columns:1fr}}
label.f{display:block;font-size:12px;color:var(--muted);margin:0 0 4px;font-weight:500}
input,textarea,select{width:100%;font:inherit;font-size:14px;color:var(--ink);background:#fff;border:1px solid var(--line);border-radius:9px;padding:9px 11px;outline:none}
input:focus,textarea:focus,select:focus{border-color:var(--teal);box-shadow:0 0 0 3px rgba(47,93,80,.12)}
input[readonly]{background:#f1efe7;color:var(--muted)}
textarea{resize:vertical;min-height:130px;line-height:1.55}
.types{display:flex;gap:10px;flex-wrap:wrap}
.type{flex:1;min-width:110px;cursor:pointer;border:1px solid var(--line);border-radius:12px;padding:11px 14px;background:#fff}
.type b{font-family:'Fraunces',serif;font-size:16px}.type small{display:block;color:var(--muted);font-size:12px;margin-top:2px}
.type.on{border-color:var(--teal);background:#f0f5f2;box-shadow:0 0 0 3px rgba(47,93,80,.12)}
.type.dis{opacity:.55;cursor:not-allowed;background:#f3f1ea}
.rulebox textarea{min-height:96px;background:#fbfaf5;font-size:13px}
.hint{font-size:12px;color:var(--muted);margin-top:6px}
.actions{display:flex;gap:12px;flex-wrap:wrap;align-items:center;margin-top:6px}
button.btn{font:inherit;font-weight:600;cursor:pointer;border-radius:11px;padding:11px 18px;border:1px solid transparent}
.primary{background:var(--teal);color:#fff}.primary:hover{background:var(--teal-dk)}
.ghost{background:#fff;color:var(--ink);border-color:var(--line)}.ghost:hover{border-color:var(--teal)}
.danger{background:#fff;color:var(--bad);border-color:#e3bdb5}.danger:hover{background:#fbeae7}
button:disabled{opacity:.5;cursor:not-allowed}
.status{font-size:13px;color:var(--muted)}
.err{color:var(--bad);font-size:13px;margin-top:8px;white-space:pre-wrap}
.okmsg{color:var(--ok);font-size:13px;margin-top:8px}

/* editable session table */
.ptable{width:100%;border-collapse:collapse;margin-top:8px;font-size:13px}
.ptable th{text-align:left;font-weight:600;color:var(--muted);font-size:11px;letter-spacing:.06em;text-transform:uppercase;padding:6px 8px;border-bottom:1px solid var(--line)}
.ptable td{padding:4px 6px;border-bottom:1px solid var(--line2);vertical-align:top}
.ptable input,.ptable textarea{padding:6px 8px;font-size:13px;border-color:var(--line2)}
.ptable textarea{min-height:0;height:42px}
.col-d{width:108px}.col-u{width:62px}.col-x{width:34px}
.uebad{border-color:var(--bad)!important;background:#fbeae7!important}
.rm{background:none;border:none;color:var(--amber);font-size:18px;padding:2px 6px;cursor:pointer}
.sumline{font-family:'Fraunces',serif;font-size:15px}.sumline b{color:var(--teal-dk)}
.banner{border:1px solid var(--warn-line);background:var(--warn);border-radius:12px;padding:14px 16px;margin-top:14px;font-size:13px}
.banner b{color:#8a4a1f}

/* overview table */
.dtable{width:100%;border-collapse:collapse;font-size:14px;background:var(--field);border:1px solid var(--line);border-radius:14px;overflow:hidden}
.dtable th{text-align:left;font-size:11px;letter-spacing:.05em;text-transform:uppercase;color:var(--muted);font-weight:600;padding:11px 14px;background:#efece3;border-bottom:1px solid var(--line)}
.dtable td{padding:11px 14px;border-bottom:1px solid var(--line2)}
.dtable tr:last-child td{border-bottom:none}
.dtable tr.clickable:hover td{background:#f6f3ec;cursor:pointer}
.badge{display:inline-block;font-size:11px;font-weight:600;letter-spacing:.03em;padding:2px 9px;border-radius:99px;border:1px solid var(--line)}
.badge.coach{background:#eef3f0;color:var(--teal-dk)}
.badge.fallmanager{background:#f1eef6;color:#5b4a86}
.badge.admin{background:#f7ece2;color:#8a4a1f}
.badge.entwurf{background:#f3f1ea;color:var(--muted)}
.badge.fertig{background:#e6efe9;color:var(--teal-dk)}
.rowbtns{display:flex;gap:6px;flex-wrap:wrap}
.rowbtns button{font:inherit;font-size:12px;font-weight:600;padding:5px 10px;border-radius:8px;border:1px solid var(--line);background:#fff;cursor:pointer;color:var(--ink)}
.rowbtns button:hover{border-color:var(--teal)}
.rowbtns button.del{color:var(--bad);border-color:#e3bdb5}
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:14px;align-items:end}
.filters>div{min-width:150px}
.empty{color:var(--muted);font-size:14px;padding:26px;text-align:center}

/* login */
#login{position:fixed;inset:0;background:radial-gradient(120% 90% at 100% 0%,#eef3ef 0%,var(--paper) 60%);display:flex;align-items:center;justify-content:center;padding:20px;z-index:9}
.lcard{width:100%;max-width:380px;background:var(--field);border:1px solid var(--line);border-radius:18px;box-shadow:var(--shadow);padding:30px 28px}
.lcard h2{font-size:24px}.lcard p{color:var(--muted);margin:0 0 20px;font-size:13px}

/* modal */
#modal{position:fixed;inset:0;background:rgba(34,37,31,.4);display:flex;align-items:center;justify-content:center;padding:20px;z-index:20}
.mcard{width:100%;max-width:460px;background:var(--field);border:1px solid var(--line);border-radius:16px;box-shadow:var(--shadow);padding:24px;max-height:90vh;overflow:auto}
.spin{display:inline-block;width:14px;height:14px;border:2px solid var(--line);border-top-color:var(--teal);border-radius:50%;animation:s .7s linear infinite;vertical-align:-2px;margin-right:7px}
@keyframes s{to{transform:rotate(360deg)}}
