:root{
  --ink:#16181d; --paper:#f4f1ea; --card:#fffdf8; --line:#d9d3c6;
  --accent:#e2562b; --accent-dk:#b53d18;
  --green:#1f8a4c; --amber:#c98a13; --grey:#9a958a; --blue:#2f6fb0;
  --mono:ui-monospace,"SFMono-Regular",Menlo,Consolas,monospace;
  --sans:system-ui,-apple-system,"Segoe UI",Roboto,sans-serif;
}
*{box-sizing:border-box}
body{margin:0;font-family:var(--sans);background:var(--paper);color:var(--ink);
  -webkit-font-smoothing:antialiased}
a{color:var(--accent-dk)}
header.top{position:sticky;top:0;z-index:5;background:var(--ink);color:#fff;
  padding:.7rem 1rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;
  border-bottom:4px solid var(--accent)}
header.top h1{font-size:1.05rem;margin:0;letter-spacing:.04em;text-transform:uppercase;
  font-weight:800}
header.top .spacer{flex:1}
header.top a{color:#fff;opacity:.8;font-size:.85rem;text-decoration:none}
header.top a:hover{opacity:1}
.wrap{max-width:1000px;margin:0 auto;padding:1rem}
.chips{display:flex;gap:.4rem;flex-wrap:wrap;margin:.2rem 0 1rem}
.chip{border:1.5px solid var(--line);background:var(--card);border-radius:999px;
  padding:.35rem .8rem;cursor:pointer;font-weight:700;font-size:.9rem;font-family:var(--mono)}
.chip[data-fertig="1"]{border-color:var(--green)}
.chip.active{background:var(--ink);color:#fff;border-color:var(--ink)}
.searchbar{display:flex;gap:.6rem;align-items:center;margin-bottom:.8rem}
.searchbar input{flex:1;padding:.6rem .8rem;border:1.5px solid var(--line);border-radius:8px;
  font-size:1rem;background:var(--card)}
.meta{font-family:var(--mono);font-size:.85rem;color:#555;white-space:nowrap}
.row{display:flex;align-items:flex-start;gap:.7rem;background:var(--card);border:1px solid var(--line);
  border-left:5px solid var(--grey);border-radius:8px;padding:.5rem .7rem;margin-bottom:.4rem}
.row[data-status="vollständig"]{border-left-color:var(--green)}
.row[data-status="teilweise"]{border-left-color:var(--amber)}
.row[data-status="offen"]{border-left-color:var(--grey)}
.row[data-status="krank"]{border-left-color:#d9534f;background:#fdecec}
.name{flex:1 1 auto;min-width:0;font-weight:700;line-height:1.15;align-self:flex-start}
.name small{display:block;font-weight:500;color:#777;font-family:var(--mono);font-size:.72rem}
/* rechter Steuerblock: oben Eingaben+Urkunde, darunter Buttons (fixe Höhe -> kein vertikales Springen) */
.ctrl{flex:none;display:flex;flex-direction:column;align-items:flex-end;gap:.35rem}
.ctrl-top{display:flex;align-items:center;gap:.5rem}
.row input.pkt{width:5rem;padding:.5rem;border:2.5px solid var(--line);border-radius:6px;
  font-family:var(--mono);font-size:1.05rem;font-weight:700;text-align:center;background:#fff}
.row input.pkt:placeholder-shown{border-color:#d9534f;background:#fff5f5}      /* leer -> Eingabe nötig (rot) */
.row input.pkt:not(:placeholder-shown){border-color:var(--green);background:#f2fbf6}  /* eingetragen -> grün */
.row input.pkt:focus{outline:2px solid var(--accent);border-color:var(--accent);background:#fff}
.row input.pkt:disabled{border-color:var(--line);background:var(--paper);color:#bbb}
.row .summe{font-family:var(--mono);font-weight:800;text-align:center;font-size:1.05rem;width:3rem;flex:none}
.urk{width:7.5rem;flex:none;display:flex;justify-content:flex-start}
.badge{display:inline-flex;align-items:center;gap:.3rem;font-size:.72rem;font-family:var(--mono);
  text-transform:uppercase;font-weight:800;padding:.2rem .5rem;border-radius:5px;letter-spacing:.02em}
.urkicon{width:1.15em;height:1.15em;fill:currentColor;flex:none}
.b-Ehrenurkunde{background:#fde6c4;color:#8a5a00}
.b-Siegerurkunde{background:#dfeefb;color:#15556b}
.b-Teilnehmerurkunde{background:#eceae3;color:#555}
.bkrank{background:#f7d2d2;color:#a52121}
.actions{display:flex;gap:.3rem;justify-content:flex-end}
.btn.rst{color:var(--accent-dk);font-size:1.05rem;line-height:1;padding:.4rem .55rem}
button{font-family:var(--sans);cursor:pointer}
.btn{border:1.5px solid var(--line);background:var(--card);border-radius:7px;
  padding:.45rem .7rem;font-weight:700;font-size:.85rem}
.btn:hover{border-color:var(--ink)}
.btn:disabled{opacity:.4;cursor:not-allowed}
.btn:disabled:hover{border-color:var(--line)}
.btn.krank.on{background:var(--blue);color:#fff;border-color:var(--blue)}
.btn.primary{background:var(--accent);color:#fff;border-color:var(--accent-dk)}
.btn.primary:hover{background:var(--accent-dk)}
.saveind{position:fixed;bottom:1rem;right:1rem;font-family:var(--mono);font-size:.8rem;
  padding:.4rem .7rem;border-radius:6px;background:var(--ink);color:#fff;opacity:0;
  transition:opacity .2s;pointer-events:none}
.saveind.show{opacity:.92}
.saveind.err{background:var(--accent-dk)}
.empty{padding:2rem;text-align:center;color:#888}
.gate{position:fixed;inset:0;z-index:50;background:rgba(22,24,29,.92);
  display:flex;align-items:center;justify-content:center;padding:1rem}
.gatebox{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:1.6rem;max-width:340px;width:100%;text-align:center}
.gatebox h2{margin:.2rem 0 .6rem;font-size:1.2rem}
.gatebox p{font-size:.9rem;color:#555;margin:.4rem 0 1rem}
.gatebox input{width:100%;padding:.7rem;font-size:2rem;text-align:center;letter-spacing:.6rem;
  border:1.5px solid var(--line);border-radius:8px;font-family:var(--mono);margin-bottom:.8rem}
.gatebox .btn.primary{width:100%}
/* admin */
.card{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:1rem 1.1rem;margin-bottom:1rem}
.card h2{margin:.1rem 0 .8rem;font-size:1rem;text-transform:uppercase;letter-spacing:.04em}
.card h2.collapser{cursor:pointer;user-select:none;display:flex;align-items:center;gap:.45rem}
.card h2.collapser .caret{font-size:.7em;color:var(--accent-dk);transition:transform .15s}
.card h2.collapser:hover .caret{color:var(--accent)}
.card.collapsed h2.collapser{margin-bottom:0}
.card.collapsed h2.collapser .caret{transform:rotate(-90deg)}
.card.collapsed>.cardbody{display:none}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:.6rem}
label{font-size:.85rem;font-weight:700;display:block;margin:.4rem 0 .2rem}
input[type=text],input[type=number],input[type=password]{padding:.5rem;border:1.5px solid var(--line);
  border-radius:7px;font-size:1rem;width:100%;background:#fff;font-family:var(--mono)}
table{width:100%;border-collapse:collapse;font-size:.88rem}
th,td{text-align:left;padding:.45rem .5rem;border-bottom:1px solid var(--line)}
th{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;color:#666}
td.num,th.num{text-align:right;font-family:var(--mono)}
.tag{font-family:var(--mono);font-size:.72rem;font-weight:800;padding:.1rem .45rem;border-radius:4px}
.tag.ok{background:#d8efdf;color:var(--green)}
.tag.wait{background:#eceae3;color:#777}
.big{font-family:var(--mono);font-size:2.2rem;font-weight:800}
.note{font-size:.82rem;color:#777;margin:.3rem 0}
.err{color:var(--accent-dk);white-space:pre-wrap;font-family:var(--mono);font-size:.82rem}
@media(max-width:640px){
  .entrywrap{overflow-x:hidden}   /* Sidebar hier statisch -> kein sticky-Bruch; killt Streuüberlauf */
  .row{flex-direction:column;align-items:stretch;gap:.45rem}
  .ctrl{align-items:stretch}
  .ctrl-top{flex-wrap:wrap}
  .row input.pkt{flex:1 1 3.5rem;width:auto;min-width:3rem}
  .urk{width:auto}
  .actions{justify-content:flex-start}
  /* Admin mobil: zweispaltige Formulare untereinander, breite Tabellen scrollbar */
  .grid2{grid-template-columns:1fr}
  .card{overflow-x:auto}
  .evact{flex-wrap:wrap}
}
/* Admin: Punktetabelle + Import-Mapping */
.minput{width:5.5rem;padding:.3rem;text-align:center;font-family:var(--mono)}
table.thr td,table.thr th{padding:.3rem .4rem}
table.thr input{width:6rem;padding:.3rem;font-family:var(--mono);text-align:center;
  border:1.5px solid var(--line);border-radius:5px;font-size:.85rem}
.subtab{font-size:.82rem}
.subtab td,.subtab th{padding:.3rem .4rem}
.rowflex{display:flex;gap:.5rem;align-items:end;flex-wrap:wrap}
.steps{counter-reset:step}
.btn.sm{padding:.25rem .5rem;font-size:.78rem}
.del{color:var(--accent-dk);border-color:var(--line)}
.evact{display:flex;gap:.4rem;align-items:center;justify-content:flex-start}
/* Bestätigungsmodal (Sportfest löschen) */
.modal-overlay{position:fixed;inset:0;z-index:60;background:rgba(22,24,29,.72);
  display:flex;align-items:center;justify-content:center;padding:1rem}
.modal{background:var(--card);border:1px solid var(--line);border-radius:12px;
  padding:1.5rem;max-width:440px;width:100%;box-shadow:0 12px 40px rgba(0,0,0,.35)}
.modal h2{margin:0 0 .6rem;font-size:1.1rem;text-transform:none;letter-spacing:0}
.modal #del_body{font-size:.9rem;color:#444;line-height:1.45}
.modal-actions{display:flex;gap:.6rem;justify-content:flex-end;margin-top:1.4rem}
.btn.danger{background:var(--accent-dk);color:#fff;border-color:var(--accent-dk)}
.btn.danger:hover{background:#9a3414;border-color:#9a3414}
/* Import: Klassen-/Jahrgangs-Abwahl */
.clsgrid{display:flex;flex-wrap:wrap;gap:.35rem .5rem;margin-top:.3rem}
.clschip{display:inline-flex;align-items:center;gap:.35rem;font-weight:600;font-size:.85rem;
  border:1.5px solid var(--line);border-radius:7px;padding:.25rem .55rem;background:#fff;
  font-family:var(--mono);cursor:pointer;user-select:none}
.clschip:has(input:not(:checked)){opacity:.45;text-decoration:line-through;background:var(--paper)}
.grpdel{font-family:var(--mono);font-weight:600}
.grpdel:hover{border-color:var(--accent-dk);color:var(--accent-dk);background:#fbeae3}
/* Auswertung je Klasse (Admin) */
.lg{font-size:.78rem;font-weight:700;margin-right:.5rem;white-space:nowrap}
.lg::before{content:"■ ";}
.lg.voll{color:var(--green)} .lg.teil{color:var(--amber)}
.lg.offen{color:var(--grey)} .lg.krank{color:var(--blue)}
.klacard{border:1px solid var(--line);border-left:4px solid var(--amber);border-radius:8px;
  padding:.55rem .7rem;margin-bottom:.5rem;background:#fff}
.klacard[data-fertig="1"]{border-left-color:var(--green);background:#f4fbf6}
.klahead{display:flex;align-items:center;gap:.5rem;margin-bottom:.4rem;flex-wrap:wrap}
.klahead b{font-size:1.05rem}
.kbar{display:flex;height:15px;border-radius:5px;overflow:hidden;background:#eceae3}
.kseg{height:100%}
.kseg.voll{background:var(--green)} .kseg.teil{background:var(--amber)}
.kseg.offen{background:var(--grey)} .kseg.krank{background:var(--blue)}
.kchips{display:flex;flex-wrap:wrap;gap:.35rem;margin-top:.5rem}
.kchip{border:1.5px solid var(--line);background:var(--card);border-radius:6px;padding:.2rem .55rem;
  font-size:.8rem;font-family:var(--mono);cursor:pointer}
.kchip.leer{opacity:.4}
.kchip.voll{border-color:var(--green)} .kchip.teil{border-color:var(--amber)}
.kchip.offen{border-color:var(--grey)} .kchip.krank{border-color:var(--blue)}
.kchip.sel{background:var(--ink);color:#fff;border-color:var(--ink)}
.kchip:hover{filter:brightness(.97)}
.kdetail{margin-top:.45rem;padding:.45rem .55rem;background:var(--paper);border-radius:6px}
.kname{display:inline-block;font-family:var(--mono);font-size:.82rem;background:#fff;border:1px solid var(--line);
  border-radius:5px;padding:.12rem .4rem;margin:.15rem .25rem .15rem 0}
.kdetail .subtab td.miss{color:var(--accent-dk);font-weight:800}
.kdetail .subtab td.okv{color:var(--green)}
/* Eingabeseite: linke Spalte (Klassen-Fortschritt, kompakt+responsiv) + Urkunden */
.entrywrap{max-width:1640px;display:flex;gap:1.1rem;align-items:flex-start}
.entrymain{flex:1 1 0;min-width:0}
.sidepanel{flex:0 1 clamp(300px,33%,480px);position:sticky;top:4.3rem;background:var(--card);
  border:1px solid var(--line);border-radius:10px;padding:.7rem .75rem;
  max-height:calc(100vh - 5rem);overflow:auto}
.sidepanel:empty{display:none}
.sp-title{font-family:var(--mono);font-size:.7rem;text-transform:uppercase;letter-spacing:.04em;
  color:#666;font-weight:800;margin-bottom:.4rem}
/* Jahrgangs-Rahmen (gleiche Farben bei Pillen + Fortschritt) */
.jggroup{border:2px solid var(--line);border-radius:9px;padding:.4rem;margin-bottom:.5rem}
.jggroup-label{font-family:var(--mono);font-size:.68rem;font-weight:800;text-transform:uppercase;
  letter-spacing:.03em;margin-bottom:.3rem}
.jggrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(102px,1fr));gap:.35rem}
.sp-class{display:block;width:100%;text-align:left;border:1px solid var(--line);background:#fff;
  border-radius:7px;padding:.28rem .38rem;cursor:pointer;font-family:var(--sans)}
.sp-class:hover{border-color:var(--ink)}
.sp-class.sel{box-shadow:0 0 0 2px var(--ink);border-color:var(--ink)}
.sp-class.fertig{background:#eafaf0;border-color:var(--green)}
.sp-top{display:flex;justify-content:space-between;align-items:baseline;gap:.3rem}
.sp-k{font-weight:800;font-size:.84rem;line-height:1.1}
.sp-class.fertig .sp-k{color:var(--green)}
.sp-n{font-family:var(--mono);font-size:.68rem;color:#555;white-space:nowrap}
.sp-bar{display:flex;height:7px;border-radius:4px;overflow:hidden;background:#eceae3;margin:.18rem 0 .08rem}
.sp-seg{height:100%}
.sp-seg.voll{background:var(--green)} .sp-seg.krank{background:var(--blue)}
.sp-seg.teil{background:var(--amber)} .sp-seg.offen{background:var(--grey)}
.sp-sub{font-family:var(--mono);font-size:.63rem;color:#777}
.sp-hint{font-size:.68rem;color:#888;margin:.3rem 0 0;font-family:var(--sans)}
.sp-certs{display:grid;grid-template-columns:1fr 1fr;gap:.3rem}
.sp-cert{display:flex;justify-content:space-between;font-size:.78rem;padding:.28rem .45rem;border-radius:6px;
  font-weight:700}
.sp-cert b{font-family:var(--mono)}
.sp-cert.ehren{background:#fde6c4;color:#8a5a00}
.sp-cert.sieger{background:#dfeefb;color:#15556b}
.sp-cert.teiln{background:#eceae3;color:#555}
.sp-cert.ohne{background:var(--paper);color:#999}
/* Schul-Gesamtstatistik (Balken) – an Stelle der früheren Filterpillen */
.schoolstat{background:var(--card);border:1px solid var(--line);border-radius:10px;
  padding:.6rem .85rem;margin:.2rem 0 .8rem}
.schoolstat:empty{display:none}
.ss-head{display:flex;justify-content:space-between;align-items:baseline;gap:.6rem;margin-bottom:.4rem;flex-wrap:wrap}
.ss-title{font-family:var(--mono);font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;color:#666;font-weight:800}
.ss-big{font-family:var(--mono);font-weight:800;font-size:1.15rem}
.ss-big small{font-weight:600;font-size:.78rem;color:#777}
.ss-bar{display:flex;height:16px;border-radius:5px;overflow:hidden;background:#eceae3}
.ss-seg{height:100%}
.ss-seg.voll{background:var(--green)} .ss-seg.krank{background:var(--blue)}
.ss-seg.teil{background:var(--amber)} .ss-seg.offen{background:var(--grey)}
.ss-legend{display:flex;flex-wrap:wrap;gap:.25rem .9rem;margin-top:.45rem;font-size:.8rem;font-family:var(--mono)}
.ss-l b{font-weight:800}
.ss-l.voll{color:var(--green)} .ss-l.teil{color:var(--amber)}
.ss-l.offen{color:#777} .ss-l.krank{color:var(--blue)}
/* „Vollständige ausblenden" sitzt jetzt in der Suchzeile (Filterpillen entfernt) */
.hidedone{display:flex;align-items:center;gap:.4rem;font-size:.85rem;font-weight:600;white-space:nowrap;
  background:var(--card);border:1.5px solid var(--line);border-radius:8px;padding:.5rem .65rem;cursor:pointer;flex:none}
.hidedone input{width:1.05rem;height:1.05rem}
@media(max-width:880px){
  /* gestapelt: Klassen-Übersicht (= Auswahl) zuerst, dann Eingabe */
  .entrywrap{flex-direction:column}
  .sidepanel{position:static;width:auto;flex:none;max-height:none;order:1}
  .entrymain{order:2}
}

/* ===== Beamer-/Großanzeige (/anzeige) ===== */
body.anzeige{background:var(--paper);overflow:hidden}
.azgate{position:fixed;inset:0;display:flex;align-items:center;justify-content:center;padding:2rem}
.azgatebox{background:var(--card);border:1px solid var(--line);border-radius:14px;
  padding:2rem;text-align:center;max-width:440px}
.azgatebox h2{margin:.2rem 0 .8rem}
.azmain{display:flex;flex-direction:column;height:100vh;padding:.9rem 1.1rem;gap:.9rem}
.azhead{display:flex;align-items:center;gap:1.5rem;flex-wrap:wrap;background:var(--ink);color:#fff;
  border-radius:12px;padding:.7rem 1.2rem;border-bottom:4px solid var(--accent)}
.azttl{font-weight:800;font-size:1.7rem;letter-spacing:.02em;white-space:nowrap}
.azschool{flex:1;min-width:280px}
.azs-big{font-family:var(--mono);font-weight:800;font-size:1.6rem}
.azs-big small{font-size:1rem;opacity:.82;font-weight:600}
.azs-bar{display:flex;height:18px;border-radius:6px;overflow:hidden;background:#3a3d44;margin:.35rem 0}
.azs-seg{height:100%}
.azs-seg.voll{background:var(--green)} .azs-seg.krank{background:var(--blue)}
.azs-seg.teil{background:var(--amber)} .azs-seg.offen{background:#6b6f78}
.azs-leg{display:flex;gap:1.2rem;font-family:var(--mono);font-size:.95rem;flex-wrap:wrap}
.azs-leg .v{color:#7fe0a4}.azs-leg .t{color:#f1c46b}.azs-leg .o{color:#cbd0d8}.azs-leg .k{color:#8fc0ee}
.azmeta{display:flex;align-items:center;gap:.7rem;font-family:var(--mono);font-size:.95rem;color:#cfd2d8}
.azmeta .btn{background:#2a2d34;color:#fff;border-color:#454952;font-size:1.1rem;padding:.3rem .55rem}
.azgrid{flex:1;min-height:0;overflow:auto;display:grid;gap:.8rem;align-content:start;
  grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}
.azgroup{border:3px solid var(--line);border-radius:12px;padding:.6rem .7rem;background:#fffdf8}
.azgl{font-family:var(--mono);font-weight:800;font-size:1.15rem;text-transform:uppercase;
  letter-spacing:.03em;margin-bottom:.5rem}
.azcards{display:grid;grid-template-columns:repeat(auto-fit,minmax(125px,1fr));gap:.5rem}
.azcard{border:1px solid var(--line);background:#fff;border-radius:9px;padding:.45rem .6rem}
.azcard.fertig{background:#eafaf0;border-color:var(--green)}
.azc-top{display:flex;justify-content:space-between;align-items:baseline;gap:.4rem}
.azc-k{font-weight:800;font-size:1.35rem}
.azcard.fertig .azc-k{color:var(--green)}
.azc-n{font-family:var(--mono);font-size:1rem;color:#444}
.azc-bar{display:flex;height:12px;border-radius:5px;overflow:hidden;background:#eceae3;margin:.35rem 0 .2rem}
.azc-seg{height:100%}
.azc-seg.voll{background:var(--green)} .azc-seg.krank{background:var(--blue)}
.azc-seg.teil{background:var(--amber)} .azc-seg.offen{background:var(--grey)}
.azc-sub{font-family:var(--mono);font-size:.92rem;color:#777}
.azempty{padding:3rem;text-align:center;color:#888;font-size:1.5rem}
