/* AÜ Campus — Corporate-Design-Umsetzung (E4 Design-Audit Runde 1).
   Aesthetik: editorial-institutionell, warm, vertrauenswürdig — das AÜ-CD mit Präzision.
   CSP-fest: keine externen URLs. Schriften selbst gehostet (static/fonts/, OFL-Lizenz). */

/* ---- Selbst gehostete AÜ-Schriften (Merriweather = Serif-Display, PT Sans = Body) ---- */
@font-face{font-family:"Merriweather";font-style:normal;font-weight:400;font-display:swap;
  src:url("/static/fonts/merriweather-400.woff2") format("woff2")}
@font-face{font-family:"Merriweather";font-style:normal;font-weight:700;font-display:swap;
  src:url("/static/fonts/merriweather-700.woff2") format("woff2")}
@font-face{font-family:"PT Sans";font-style:normal;font-weight:400;font-display:swap;
  src:url("/static/fonts/pt-sans-400.woff2") format("woff2")}
@font-face{font-family:"PT Sans";font-style:normal;font-weight:700;font-display:swap;
  src:url("/static/fonts/pt-sans-700.woff2") format("woff2")}

:root{
  --rot:#e20613; --rot-dunkel:#9a1d28; --beige:#faf6e5; --hellgrau:#f4f4f4; --karte:#ffffff;
  --text:#54575a; --head:#1c1f22; --grau:#666b6e; --linie:#ece2c8;
  --gala:#436c59; --kauf:#174476; --gesund:#5189ac; --sprach:#52abb0; --it:#605690; --orient:#d99a3a;
  --serif:"Merriweather",Georgia,"Times New Roman",serif;
  --sans:"PT Sans",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Helvetica,Arial,sans-serif;
  --schatten-karte:0 6px 20px rgba(120,90,30,.08);
  --schatten-hover:0 18px 38px rgba(60,40,10,.14);
  --rund:16px;
}
*{box-sizing:border-box;margin:0;padding:0}
html{-webkit-text-size-adjust:100%}
body{font-family:var(--sans);color:var(--text);font-size:15px;line-height:1.5;min-height:100vh;
     background:
       radial-gradient(120% 80% at 88% -12%,#fdf3d6 0,rgba(253,243,214,0) 46%),
       radial-gradient(90% 70% at 6% 108%,#f7edd2 0,rgba(247,237,210,0) 52%),
       #f5edd8;
     background-attachment:fixed}

/* Sichtbarer Tastatur-Fokus (A11y) — überall einheitlich */
a:focus-visible,button:focus-visible,input:focus-visible,[tabindex]:focus-visible{
  outline:3px solid rgba(226,6,19,.55);outline-offset:2px;border-radius:8px}

/* ---- Topbar (rote Kopfleiste) ---- */
/* Tiefes, entsättigtes AÜ-Rot (Akzentrot-Familie) statt grellem Signalrot:
   nimmt das „Flimmern" von weißem Text auf gesättigtem Rot heraus, bleibt CD-konform. */
.topbar{background:linear-gradient(180deg,#a41722 0%,#8c1a26 100%);color:#fff;
  box-shadow:0 2px 14px rgba(70,14,22,.30);position:relative;z-index:5}
.topbar .inner{display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:10px 30px;flex-wrap:wrap}
.topbar nav{display:flex;align-items:center;flex-wrap:wrap;gap:6px}
.topbar nav a{color:rgba(255,255,255,.92);text-decoration:none;font-size:14.5px;cursor:pointer;
  padding:7px 13px;border-radius:9px;letter-spacing:.1px;transition:background .15s,color .15s;white-space:nowrap}
.topbar nav a:hover{background:rgba(255,255,255,.14);opacity:1}
.topbar nav a.aktiv{background:rgba(255,255,255,.18);font-weight:700;opacity:1;
  box-shadow:inset 0 -2px 0 rgba(255,255,255,.85)}
.topbar .rechts{display:flex;align-items:center;gap:12px;flex-wrap:wrap;justify-content:flex-end}
.konto{background:rgba(255,255,255,.16);border-radius:20px;padding:7px 15px;font-size:13.5px;color:#fff;
  max-width:34vw;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.abmelden{background:rgba(0,0,0,.20);border:none;color:#fff;border-radius:20px;padding:7px 15px;
  font-size:13px;cursor:pointer;font-family:var(--sans);transition:background .15s}
.abmelden:hover{background:rgba(0,0,0,.34)}
.au-chip{background:#fff;border-radius:11px;padding:7px 13px;display:flex;align-items:center;
  box-shadow:0 4px 14px rgba(0,0,0,.20)}
.au-chip img{height:30px;width:auto;display:block}

/* ---- Subhead + Suche (mit Hero-Akzent, angelehnt ans AÜ-Wellenelement) ---- */
.subhead{position:relative;overflow:hidden;background:linear-gradient(180deg,#fdfaef 0%,var(--beige) 100%)}
.subhead::before{content:"";position:absolute;right:-70px;top:-90px;width:300px;height:300px;
  background:radial-gradient(circle,rgba(226,6,19,.11) 0,rgba(226,6,19,0) 66%);pointer-events:none;z-index:0}
.subhead::after{content:"";position:absolute;left:0;right:0;bottom:0;height:3px;pointer-events:none;
  background:linear-gradient(90deg,var(--rot) 0,rgba(226,6,19,.55) 30%,rgba(226,6,19,0) 72%)}
.subhead .inner{position:relative;z-index:1;padding:18px 30px;display:flex;align-items:center;justify-content:space-between;gap:22px;flex-wrap:wrap}
.subhead .marke{display:flex;align-items:center;gap:20px;min-width:0}
.subhead .marke::after{content:"";width:1px;align-self:stretch;background:var(--linie);margin:2px 0}
.campus-gross{height:74px;width:auto;display:block;flex:0 0 auto}
.subhead h1{font-family:var(--serif);font-size:25px;line-height:1.15;color:var(--head);font-weight:700;letter-spacing:-.2px}
.suche{position:relative;min-width:240px;flex:1 1 280px;max-width:440px}
.suche input{width:100%;border:1.5px solid #e6dcc0;border-radius:26px;padding:12px 18px 12px 46px;
  font-family:var(--sans);font-size:15px;color:var(--head);background:#fff;
  box-shadow:0 2px 8px rgba(120,90,30,.06);transition:border-color .15s,box-shadow .15s}
.suche input::placeholder{color:#9aa0a4}
.suche input:focus{outline:none;border-color:var(--rot);box-shadow:0 0 0 4px rgba(226,6,19,.12)}
.suche::before{content:"\2315";position:absolute;left:17px;top:50%;transform:translateY(-50%);
  font-size:21px;color:var(--rot);pointer-events:none}

/* ---- Hauptbereich (volle Breite, kein zentrierter Schmal-Kasten — Sergej-Entscheid) ---- */
main{padding:26px 30px 70px}
main.mit-detail{display:grid;grid-template-columns:minmax(0,1fr) 384px;gap:30px;align-items:start}

/* ---- Filterzeile ---- */
.filterzeile{display:flex;gap:10px;flex-wrap:wrap;align-items:center;margin-bottom:24px}
.chip{background:#fcf6ea;border:1.6px solid rgba(226,6,19,.26);border-radius:21px;padding:8px 17px;
  font-size:13.5px;color:var(--grau);cursor:pointer;transition:border-color .15s,color .15s,background .15s,box-shadow .15s;
  font-family:var(--sans);line-height:1.1}
.chip:hover{border-color:var(--rot);color:var(--head);background:#fff}
.chip.an{background:var(--rot);border-color:var(--rot);color:#fff;font-weight:700;
  box-shadow:0 4px 12px rgba(226,6,19,.26)}
/* Ansicht-Umschalter rechts, eigene Gruppe mit klarer Trennung */
.ansicht-toggle{margin-left:auto;display:inline-flex;gap:4px;background:#fff;border:1.5px solid #e6dcc0;
  border-radius:23px;padding:4px}
.ansicht-toggle .chip{border:none;background:transparent;box-shadow:none;padding:7px 16px;border-radius:19px;color:var(--grau)}
.ansicht-toggle .chip:hover{background:#f6efe1;color:var(--head)}
.ansicht-toggle .chip.an{background:var(--rot);color:#fff;box-shadow:none}

/* ---- Anzahl-Zeile über dem Raster ---- */
.raster-meta{color:var(--grau);font-size:12.5px;font-weight:700;text-transform:uppercase;
  letter-spacing:.7px;margin:2px 2px 14px;text-align:right}

/* ---- Kachel-Raster ---- */
.raster{display:grid;grid-template-columns:repeat(auto-fill,minmax(272px,1fr));gap:22px;align-content:start}
.karte{position:relative;background:linear-gradient(180deg,#fffdf9 0%,#fbf4e4 100%);border-radius:var(--rund);
  padding:22px 20px 18px 24px;cursor:pointer;border:1px solid #ecdfc6;box-shadow:var(--schatten-karte);
  overflow:hidden;transition:transform .2s ease,box-shadow .2s ease,border-color .2s ease;
  display:flex;flex-direction:column;min-height:172px}
.karte::before{content:"";position:absolute;left:0;top:0;bottom:0;width:6px;
  background:var(--akz,var(--rot)); /* Fallback: solides Rot, falls color-mix() nicht unterstützt wird */
  background:linear-gradient(180deg,var(--akz,var(--rot)),color-mix(in srgb,var(--akz,var(--rot)) 70%,#000 8%))}
.karte:hover{transform:translateY(-5px);box-shadow:var(--schatten-hover);border-color:#e3d2b2}
.karte:hover::before{width:8px}
.kdatum{display:flex;align-items:baseline;gap:8px;color:var(--akz,var(--rot));font-weight:700}
.kdatum .d{font-family:var(--serif);font-size:27px;line-height:1}
.kdatum .m{font-size:13px;text-transform:uppercase;letter-spacing:1.2px}
.kdatum .wd{font-size:12px;color:var(--grau);font-weight:700;margin-left:auto;
  background:rgba(102,107,110,.10);padding:2px 9px;border-radius:9px;text-transform:uppercase;letter-spacing:.5px}
.karte h3{font-family:var(--serif);font-size:17px;color:var(--head);margin-top:11px;line-height:1.3;font-weight:700}
.kmeta{font-size:13px;color:var(--grau);margin-top:7px}
.kfuss{display:flex;align-items:center;justify-content:space-between;margin-top:auto;padding-top:14px}
.ampel{display:inline-flex;align-items:center;gap:7px;font-size:12.5px;font-weight:700}
.punkt{width:10px;height:10px;border-radius:50%;display:inline-block;flex:0 0 auto}
.gruen{background:#3fae6a} .gelb{background:#e8a020} .rotp{background:var(--rot-dunkel)}
.ampel .frei{color:var(--gala)} .ampel .wl{color:var(--rot-dunkel)}
.ktag{font-size:11px;color:#fff;background:var(--akz,var(--rot));padding:3px 9px;border-radius:7px;font-weight:700}
/* Titelbild (Cover) auf der Kachel — randvoll oben über die volle Kachelbreite
   (Kachel-Padding ist 24px links / 20px rechts → +44px), mittig beschnitten. */
.karte-cover{display:block;width:calc(100% + 44px);height:150px;object-fit:cover;object-position:center;
  margin:-22px -20px 14px -24px;border-bottom:1px solid #ecdfc6;background:#f0e9d8}
.hat-cover::before{top:150px}
/* Titelbild-Vorschau im Veranstalter-Formular */
.vb-bild-vorschau{display:block;max-width:300px;width:100%;height:auto;margin-top:10px;
  border-radius:10px;border:1px solid #ecdfc6}
.vb-datei{padding:8px 10px}

/* ---- Detailspalte (Aside) ---- */
aside.detail{background:#fff;border-radius:var(--rund);border:1px solid #ececec;
  box-shadow:0 12px 34px rgba(0,0,0,.08);position:sticky;top:18px;overflow:hidden}
.cta{margin-top:20px;width:100%;border:none;background:var(--rot);color:#fff;font-weight:700;font-size:16px;
  font-family:var(--sans);padding:15px;border-radius:12px;cursor:pointer;transition:background .15s,transform .1s}
.cta:hover{background:var(--rot-dunkel)}
.cta:active{transform:translateY(1px)}

/* ---- Login ---- */
.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.login-karte{background:#fff;border-radius:20px;box-shadow:0 22px 56px rgba(60,40,10,.16);
  padding:40px 36px;width:100%;max-width:404px;border:1px solid #efe6d2}
.login-karte h1{font-family:var(--serif);font-size:26px;color:var(--head);margin-bottom:5px;letter-spacing:-.3px}
.login-karte p.unter{color:var(--grau);font-size:14px;margin-bottom:24px}
.feld{margin-bottom:16px}
.feld label{display:block;font-size:13px;color:var(--grau);margin-bottom:6px;font-weight:700}
.feld input{width:100%;border:1.5px solid #e6dcc0;border-radius:11px;padding:12px 14px;
  font-family:var(--sans);font-size:15px;color:var(--head);transition:border-color .15s,box-shadow .15s}
.feld input:focus{outline:none;border-color:var(--rot);box-shadow:0 0 0 4px rgba(226,6,19,.12)}
.meldung{font-size:13.5px;color:var(--rot-dunkel);min-height:18px;margin-bottom:6px}
.feld select{width:100%;border:1.5px solid #e6dcc0;border-radius:11px;padding:12px 14px;font-size:15px;background:#fff;color:var(--text)}
.feld select:focus{outline:none;border-color:var(--rot);box-shadow:0 0 0 4px rgba(226,6,19,.12)}
.feld .hilfe{display:block;font-size:12px;color:var(--grau);margin-top:5px;font-weight:400}
.login-karte .erfolg{color:#557555;font-size:14.5px;line-height:1.55;margin:8px 0}
.login-links{margin-top:18px;display:flex;flex-direction:column;gap:9px;text-align:center}
.login-links a{color:var(--rot-dunkel);font-size:13.5px;text-decoration:none;font-weight:700}
.login-links a:hover{text-decoration:underline}

/* ---- Leer-Hinweis ---- */
.leer-hinweis{color:var(--grau);font-size:15px;padding:40px 6px;text-align:center;
  background:#fff;border:1px dashed #e6dcc0;border-radius:var(--rund)}
.leer-hinweis .leer-titel{font-family:var(--serif);font-size:19px;color:var(--head);margin:0 0 6px}
.leer-aktion{margin-top:18px}
.listen-kopf{display:flex;justify-content:flex-end;margin-bottom:14px}

/* ---- Monatskalender ---- */
.kalender{background:#fff;border:1px solid #ececec;border-radius:var(--rund);box-shadow:var(--schatten-karte);padding:18px 20px}
.kal-kopf{display:flex;align-items:center;justify-content:center;gap:18px;margin-bottom:14px}
.kal-titel{font-family:var(--serif);font-size:21px;color:var(--head);min-width:200px;text-align:center}
.kal-nav{border:1.5px solid #e6dcc0;background:#fff;color:var(--rot);border-radius:10px;width:38px;height:38px;
  font-size:20px;cursor:pointer;line-height:1;transition:border-color .15s,background .15s}
.kal-nav:hover{border-color:var(--rot);background:#fdf3f3}
.kal-gitter{display:grid;grid-template-columns:repeat(7,minmax(0,1fr));gap:6px}
.kal-wt{font-size:12px;font-weight:700;color:var(--grau);text-align:center;padding:4px 0;text-transform:uppercase;letter-spacing:.5px}
.kal-zelle{min-height:84px;border:1px solid #f0ece0;border-radius:8px;padding:5px 6px;background:#fdfbf6}
.kal-zelle.leer{background:transparent;border:none}
.kal-tag{font-size:12px;color:var(--grau);font-weight:700;margin-bottom:3px}
.kal-ev{font-size:11px;color:#fff;border-radius:6px;padding:3px 7px;margin-bottom:3px;cursor:pointer;
  white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;max-width:100%;
  background:var(--gala);transition:filter .15s}
.kal-ev:hover{filter:brightness(1.08)}
.kal-ev.punkt-gruen{background:#3fae6a}
.kal-ev.punkt-gelb{background:#e8a020}
.kal-ev.punkt-rotp{background:var(--rot-dunkel)}

/* ---- Lade-Choreografie (einmalig, persistente Hülle) ---- */
@keyframes auf{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}
@keyframes kachelAuf{from{opacity:0;transform:translateY(16px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:no-preference){
  .topbar{animation:auf .5s ease both}
  .subhead{animation:auf .5s .07s ease both}
  main{animation:auf .55s .14s ease both}
  .login-karte{animation:auf .5s ease both}
  /* Gestaffelte Kachel-Einblendung — NUR beim ersten Laden (Klasse von liste.js), nicht bei jeder Suche */
  .raster.ersteinblendung .karte{animation:kachelAuf .5s ease both}
  .raster.ersteinblendung .karte:nth-child(1){animation-delay:.18s}
  .raster.ersteinblendung .karte:nth-child(2){animation-delay:.24s}
  .raster.ersteinblendung .karte:nth-child(3){animation-delay:.30s}
  .raster.ersteinblendung .karte:nth-child(4){animation-delay:.36s}
  .raster.ersteinblendung .karte:nth-child(5){animation-delay:.42s}
  .raster.ersteinblendung .karte:nth-child(6){animation-delay:.48s}
  .raster.ersteinblendung .karte:nth-child(7){animation-delay:.54s}
  .raster.ersteinblendung .karte:nth-child(8){animation-delay:.60s}
  .raster.ersteinblendung .karte:nth-child(9){animation-delay:.66s}
  .raster.ersteinblendung .karte:nth-child(10){animation-delay:.72s}
  .raster.ersteinblendung .karte:nth-child(n+11){animation-delay:.78s}
}

/* ---- Detailseite (E4c) — Lese-Layout, lesefreundliche Maximalbreite ---- */
.zurueck{display:inline-block;color:var(--rot);text-decoration:none;font-weight:700;font-size:14px;
  margin-bottom:16px}
.zurueck:hover{text-decoration:underline}
.detail-seite{max-width:880px;background:#fff;border:1px solid #ecdfc6;border-radius:var(--rund);
  box-shadow:var(--schatten-karte);padding:30px 32px 26px;overflow:hidden}
.detail-kopf{border-bottom:1px solid var(--linie);padding-bottom:18px;margin-bottom:20px}
.detail-titel{font-family:var(--serif);font-size:28px;line-height:1.2;color:var(--head);margin:10px 0 12px;font-weight:700}
.badge{display:inline-block;font-size:11.5px;font-weight:700;text-transform:uppercase;letter-spacing:.6px;
  padding:4px 11px;border-radius:20px;color:#fff;background:var(--gala)}
.badge-veroeffentlicht{background:#3fae6a}
.badge-abgesagt{background:var(--rot-dunkel)}
.badge-entwurf{background:var(--grau)}
.badge-abgeschlossen{background:var(--kauf)}
.detail-stand{display:inline-flex;align-items:center;gap:8px;font-size:13.5px;font-weight:700;color:var(--grau)}
.detail-bild{display:block;width:100%;max-height:300px;object-fit:cover;border-radius:12px;margin-bottom:22px}
.info-grid{display:grid;gap:1px;background:var(--linie);border:1px solid var(--linie);border-radius:12px;
  overflow:hidden;margin-bottom:22px}
.info-zeile{display:grid;grid-template-columns:200px 1fr;gap:14px;background:#fffdf9;padding:11px 16px}
.info-label{color:var(--grau);font-size:13px;font-weight:700}
.info-wert{color:var(--head);font-size:14.5px}
.info-link{color:var(--rot);text-decoration:none;word-break:break-all}
.info-link:hover{text-decoration:underline}
.abschnitt-titel{font-family:var(--serif);font-size:19px;color:var(--head);margin:6px 0 12px;font-weight:700}
.detail-beschreibung{margin-bottom:24px}
.detail-beschreibung p{margin-bottom:10px;line-height:1.6}

/* Aktionsbereich (genau EIN Knopf) */
.aktion{background:#fdf8ec;border:1px solid #ecdfc6;border-radius:14px;padding:20px;margin-bottom:24px}
.aktion .cta{margin-top:14px;max-width:340px}
.cta-sekundaer{background:#fff;color:var(--rot-dunkel);border:2px solid var(--rot-dunkel)}
.cta-sekundaer:hover{background:#fdf3f3}
.aktion-ok{color:var(--gala);font-weight:700;font-size:15px}
.aktion-hinweis{color:var(--text);font-size:14.5px;line-height:1.55}
.aktion-angebot{color:var(--rot-dunkel);font-weight:700;font-size:14.5px;line-height:1.55}
.aktion-meldung{min-height:18px;font-size:13.5px;margin-top:8px}
.aktion-meldung.ist-fehler{color:var(--rot-dunkel)}
.optionen{border:1px solid #e6dcc0;border-radius:10px;padding:14px 16px;margin-bottom:4px}
.optionen legend{font-size:13px;font-weight:700;color:var(--grau);padding:0 6px}
.option-zeile{display:flex;align-items:center;gap:10px;padding:7px 0;font-size:14.5px;color:var(--head);cursor:pointer}
.option-zeile input{width:18px;height:18px;accent-color:var(--rot)}

/* Kommentare */
.kommentare{border-top:1px solid var(--linie);padding-top:22px}
.kommentar-liste{margin-bottom:18px;display:flex;flex-direction:column;gap:12px}
.kommentar{background:#fcfaf4;border:1px solid #efe6d2;border-radius:10px;padding:12px 14px}
.kommentar-text{color:var(--head);font-size:14.5px;line-height:1.5;white-space:pre-wrap;word-break:break-word}
.kommentar-meta{color:var(--grau);font-size:12px;margin-top:6px}
.leer-klein{color:var(--grau);font-size:14px}
.kommentar-form{display:flex;flex-direction:column;gap:10px}
.kommentar-eingabe{width:100%;min-height:80px;resize:vertical;border:1.5px solid #e6dcc0;border-radius:10px;
  padding:12px 14px;font-family:var(--sans);font-size:14.5px;color:var(--head)}
.kommentar-eingabe:focus{outline:none;border-color:var(--rot);box-shadow:0 0 0 4px rgba(226,6,19,.12)}
.cta-klein{max-width:240px;font-size:14px;padding:12px}

@media(max-width:560px){
  .detail-seite{padding:22px 18px}
  .detail-titel{font-size:23px}
  .info-zeile{grid-template-columns:1fr;gap:3px}
}

/* ---- Allgemein / Verborgen ---- */
.verborgen{display:none!important}

/* ---- Responsiv ---- */
@media(max-width:900px){
  main.mit-detail{grid-template-columns:1fr}
  aside.detail{position:static}
  .campus-gross{height:58px}
  .subhead h1{font-size:22px}
}
@media(max-width:760px){
  .topbar .inner{padding:9px 18px;gap:10px}
  .subhead .inner{padding:15px 18px;gap:14px}
  .subhead .marke{gap:14px}
  .subhead .marke::after{display:none}
  .suche{flex-basis:100%;max-width:none;order:3}
  main{padding:22px 18px 60px}
  .ansicht-toggle{margin-left:0}
}
@media(max-width:560px){
  .topbar nav a{font-size:13.5px;padding:6px 10px}
  .konto{max-width:48vw}
  .au-chip{order:-1}
  .au-chip img{height:26px}
  .campus-gross{height:48px}
  .subhead h1{font-size:20px}
}
@media(max-width:430px){
  .topbar nav{width:100%;justify-content:center;gap:2px;order:2}
  .topbar .rechts{width:100%;justify-content:space-between;gap:8px;order:1}
  .konto{max-width:none;flex:1 1 auto}
  .kal-zelle{min-height:60px}
  .kal-ev{font-size:0;padding:6px}
}

/* ===== E4d — Veranstalter-Bereich ===== */
.vb-kopf{display:flex;justify-content:space-between;align-items:center;gap:16px;margin-bottom:18px;flex-wrap:wrap}
.vb-ueberschrift{font-family:var(--serif);font-size:24px;color:var(--head);margin:0}
.vb-knopf{font-family:var(--sans);font-size:14px;padding:9px 16px;border-radius:10px;border:1.5px solid var(--linie);
  background:var(--karte);color:var(--head);cursor:pointer;transition:.15s}
.vb-knopf:hover{border-color:var(--rot);color:var(--rot)}
.vb-knopf.primaer{background:var(--rot);border-color:var(--rot);color:#fff}
.vb-knopf.primaer:hover{background:var(--rot-dunkel);border-color:var(--rot-dunkel);color:#fff}
.vb-knopf:disabled{opacity:.55;cursor:default}

.vb-liste{display:flex;flex-direction:column;gap:12px}
.vb-zeile{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  background:var(--karte);border:1px solid var(--linie);border-radius:var(--rund);padding:16px 18px;
  box-shadow:var(--schatten-karte)}
.vb-titelzeile{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.vb-titel{font-family:var(--serif);font-size:18px;color:var(--head)}
.vb-zeile-meta{color:var(--grau);font-size:14px;margin-top:4px}
.vb-zahlen{display:flex;gap:10px;margin-top:8px;flex-wrap:wrap}
.vb-zahl{font-size:13px;color:var(--text);background:var(--hellgrau);border-radius:8px;padding:3px 9px}
.vb-zahl.warte{background:#fbeede;color:var(--rot-dunkel)}
.vb-zeile-knoepfe{display:flex;gap:8px;flex-wrap:wrap}
.vb-status{font-size:12px;font-weight:700;padding:3px 9px;border-radius:20px}
.vb-status-entwurf{background:#f0eede;color:#8a7a3a}
.vb-status-veroeffentlicht{background:#e6f0e8;color:var(--gala)}
.vb-status-abgesagt{background:#fbe3e3;color:var(--rot-dunkel)}

.vb-form{display:flex;flex-direction:column;gap:14px;max-width:680px;background:var(--karte);
  border:1px solid var(--linie);border-radius:var(--rund);padding:22px;box-shadow:var(--schatten-karte)}
.vb-feld{display:flex;flex-direction:column;gap:5px}
.vb-label{font-size:13px;font-weight:700;color:var(--head)}
.vb-eingabe{font-family:var(--sans);font-size:15px;padding:9px 11px;border:1.5px solid var(--linie);
  border-radius:10px;background:#fffdf6;color:var(--head)}
.vb-eingabe:focus-visible{outline:none;border-color:var(--rot);box-shadow:0 0 0 3px rgba(226,6,19,.12)}
textarea.vb-eingabe{min-height:80px;resize:vertical}
.vb-checkfeld{display:flex;align-items:center;gap:9px}
.vb-check{width:17px;height:17px;accent-color:var(--rot);cursor:pointer}
.vb-checklabel{font-size:14px;color:var(--head);cursor:pointer}
.vb-formleiste{display:flex;gap:10px;margin-top:6px}
.vb-formfehler{color:var(--rot);font-size:14px;min-height:1px}

.vb-ampel{border-radius:12px;border:1.5px solid var(--linie);padding:14px 16px;background:#fffdf6}
.vb-ampel-rot{border-color:var(--rot);background:#fdf0f0}
.vb-ampel-gelb{border-color:#d99a3a;background:#fdf6ea}
.vb-ampel-gruen{border-color:var(--gala);background:#eef4ef}
.vb-ampel-kopf{display:flex;align-items:center;gap:9px;font-weight:700;color:var(--head);font-size:15px}
.vb-ampel-punkt{width:13px;height:13px;border-radius:50%;display:inline-block}
.vb-ampel-punkt.rot{background:var(--rot)}
.vb-ampel-punkt.gelb{background:#d99a3a}
.vb-ampel-punkt.gruen{background:var(--gala)}
.vb-ampel-inhalt{margin-top:6px;color:var(--text);font-size:14px}
.vb-befunde{list-style:none;margin:10px 0 0;padding:0;display:flex;flex-direction:column;gap:8px}
.vb-befund{display:flex;flex-direction:column;gap:2px;padding:9px 12px;border-radius:9px;background:var(--karte);
  border-left:4px solid var(--linie)}
.vb-befund-rot{border-left-color:var(--rot)}
.vb-befund-gelb{border-left-color:#d99a3a}
.vb-befund-problem{font-weight:700;color:var(--head);font-size:14px}
.vb-befund-tipp{color:var(--grau);font-size:13px}

.vb-kzleiste{display:flex;gap:12px;flex-wrap:wrap;margin:14px 0 20px}
.vb-kz{flex:1 1 120px;background:var(--karte);border:1px solid var(--linie);border-radius:12px;
  padding:14px;text-align:center;box-shadow:var(--schatten-karte)}
.vb-kz-wert{font-family:var(--serif);font-size:26px;color:var(--rot)}
.vb-kz-label{font-size:13px;color:var(--grau);margin-top:2px}
.vb-tabelle{width:100%;border-collapse:collapse;background:var(--karte);border-radius:var(--rund);overflow:hidden;
  box-shadow:var(--schatten-karte)}
.vb-tabelle th{background:var(--rot);color:#fff;text-align:left;padding:10px 12px;font-size:13px}
.vb-tabelle td{padding:9px 12px;border-top:1px solid var(--linie);font-size:14px;color:var(--text)}
.vb-tr-abgemeldet td,.vb-tr-abgelehnt td{color:var(--grau);text-decoration:line-through}
@media(max-width:560px){
  .vb-zeile{flex-direction:column;align-items:flex-start}
  .vb-tabelle{display:block;overflow-x:auto;white-space:nowrap}
}

/* ---------- E4e: Mein Bereich + Verwaltung ---------- */
.mb-block{margin-bottom:34px}
.mb-tn{font-size:12px;font-weight:700;padding:3px 10px;border-radius:20px}
.mb-tn-angemeldet{background:#e6f0e8;color:var(--gala)}
.mb-tn-warteliste{background:#f0eede;color:#8a7a3a}
.mb-tn-nachrueck_angebot{background:#e4eef4;color:var(--gesund)}
.mb-tn-teilgenommen,.mb-tn-nicht_erschienen{background:var(--hellgrau);color:var(--grau)}
.mb-hinweis{margin-top:6px;font-size:14px;color:var(--gesund);font-weight:600}
.mb-fest{background:var(--hellgrau);border:1px solid var(--linie);border-radius:10px;
  padding:10px 12px;display:flex;flex-direction:column;gap:3px}
.mb-fest-zeile{font-size:14px;color:var(--grau)}
.mb-ok{color:var(--gala) !important;font-weight:700}
.adm-status{display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.adm-offen{font-size:11.5px;font-weight:700;color:var(--rot-dunkel);
  background:#fbe3e3;padding:2px 8px;border-radius:20px}

/* ===== E5 Steuerpult (Event-Ampel-Cockpit + Statistik-Dashboard) ===== */
:root{--amp-rot:#e20613;--amp-gelb:#d98a1f;--amp-gruen:#2f8f5b;--amp-grau:#9aa0a3}

/* Ansicht-Wechsel (Event-Ampel | Statistik) */
.sp-ansicht{display:flex;gap:8px;margin-bottom:18px;flex-wrap:wrap}
.sp-tab{font-family:var(--sans);font-size:14px;font-weight:700;cursor:pointer;
  padding:9px 18px;border-radius:22px;border:1.5px solid var(--linie);background:var(--karte);color:var(--grau)}
.sp-tab.aktiv{background:var(--rot);border-color:var(--rot);color:#fff}

/* --- Cockpit-Raster --- */
.sp-cockpit{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}
.sp-amp{background:var(--karte);border-radius:var(--rund);padding:16px 18px;
  box-shadow:var(--schatten-karte);border-left:6px solid var(--amp-grau);display:flex;flex-direction:column;gap:8px}
.sp-amp-rot{border-left-color:var(--amp-rot)}
.sp-amp-gelb{border-left-color:var(--amp-gelb)}
.sp-amp-gruen{border-left-color:var(--amp-gruen)}
.sp-amp-grau{border-left-color:var(--amp-grau);opacity:.85}
.sp-amp-kopf{display:flex;align-items:center;gap:8px}
.sp-punkt{width:13px;height:13px;border-radius:50%;display:inline-block;flex:0 0 auto}
.sp-punkt-rot{background:var(--amp-rot)}
.sp-punkt-gelb{background:var(--amp-gelb)}
.sp-punkt-gruen{background:var(--amp-gruen)}
.sp-punkt-grau{background:var(--amp-grau)}
.sp-amp-zustand{font-weight:700;font-size:13px;text-transform:uppercase;letter-spacing:.04em;color:var(--head)}
.sp-amp-titel{font-family:var(--serif);font-size:18px;color:var(--head);line-height:1.25}
.sp-amp-meta{font-size:13.5px;color:var(--grau)}
.sp-amp-zahlen{display:flex;flex-wrap:wrap;gap:6px}
.sp-chip{font-size:12.5px;font-weight:600;background:var(--hellgrau);color:var(--grau);
  padding:3px 9px;border-radius:20px}
.sp-chip.warte{background:#f0eede;color:#8a7a3a}
.sp-amp-grund{font-size:13.5px;color:var(--rot-dunkel);background:#fbf1ec;border-radius:8px;padding:6px 10px}
.sp-amp-gruen .sp-amp-grund{color:var(--gala);background:#eef5ef}

/* Aktionen + Inline-Panels */
.sp-aktionen{display:flex;gap:8px;flex-wrap:wrap;margin-top:4px}
.sp-knopf{font-family:var(--sans);font-size:13px;font-weight:700;cursor:pointer;
  padding:7px 13px;border-radius:9px;border:1.5px solid var(--linie);background:var(--karte);color:var(--head)}
.sp-knopf:hover{border-color:var(--rot);color:var(--rot)}
.sp-knopf.primaer{background:var(--rot);border-color:var(--rot);color:#fff}
.sp-knopf.gefahr{background:var(--rot-dunkel);border-color:var(--rot-dunkel);color:#fff}
.sp-aktion-bereich:empty{display:none}
.sp-panel{margin-top:10px;background:var(--hellgrau);border:1px solid var(--linie);
  border-radius:10px;padding:12px;display:flex;flex-direction:column;gap:9px}
.sp-panel-frage{font-size:14px;color:var(--head);font-weight:600}
.sp-panel-leiste{display:flex;gap:8px;flex-wrap:wrap}
.sp-eingabe{font-family:var(--sans);font-size:14px;padding:8px 10px;border:1.5px solid var(--linie);
  border-radius:8px;background:var(--karte);color:var(--head);width:100%}
.sp-meldung{font-size:14px;font-weight:600}
.sp-meldung.gut{color:var(--gala)}
.sp-meldung.fehler{color:var(--rot)}

/* --- Statistik-Dashboard --- */
.sp-stat-raster{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}
.sp-karte{background:var(--karte);border-radius:var(--rund);padding:18px 20px;
  box-shadow:var(--schatten-karte);display:flex;flex-direction:column;gap:10px}
.sp-karte-titel{font-family:var(--serif);font-size:17px;color:var(--head)}
.sp-bar-zeile{display:grid;grid-template-columns:1fr 2.2fr auto;align-items:center;gap:10px}
.sp-bar-label{font-size:13.5px;color:var(--head);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sp-bar-spur{background:var(--hellgrau);border-radius:20px;height:14px;overflow:hidden}
.sp-bar-fuell{height:100%;background:linear-gradient(90deg,var(--rot),var(--rot-dunkel));
  border-radius:20px;min-width:2px}
.sp-bar-wert{font-size:12.5px;font-weight:700;color:var(--grau);white-space:nowrap}
.sp-toggle{display:flex;gap:6px;flex-wrap:wrap}
.sp-toggle-knopf{font-size:12.5px;font-weight:700;cursor:pointer;padding:5px 12px;border-radius:18px;
  border:1.5px solid var(--linie);background:var(--karte);color:var(--grau)}
.sp-toggle-knopf.aktiv{background:var(--kauf);border-color:var(--kauf);color:#fff}
.sp-liste{list-style:none;display:flex;flex-direction:column;gap:6px}
.sp-listzeile{display:flex;justify-content:space-between;gap:10px;font-size:14px;
  padding:6px 0;border-bottom:1px solid var(--linie)}
.sp-listtitel{color:var(--head);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.sp-listwert{font-weight:700;color:var(--grau);white-space:nowrap}
.sp-kennzahl-gross{font-family:var(--serif);font-size:20px;color:var(--rot-dunkel)}
.sp-platzhalter{font-size:14px;color:var(--grau);font-style:italic}

/* ===== E6 — Wunsch-Schulungen + Schulungs-Pass + Check-in ===== */
/* Wunsch-Status-Badges (ergänzen die mb-tn-*-Familie) */
.mb-tn-offen{background:#e4eef4;color:var(--gesund)}
.mb-tn-in_pruefung{background:#f0eede;color:#8a7a3a}
.mb-tn-umgesetzt{background:#e6f0e8;color:var(--gala)}
.mb-tn-abgelehnt{background:var(--hellgrau);color:var(--grau)}

/* Wunsch-Liste */
.wunsch-form{margin-bottom:8px}
.wunsch-thema{font-size:12px;font-weight:600;background:var(--hellgrau);color:var(--grau);
  padding:3px 10px;border-radius:20px}
.wunsch-rechts{align-items:center;gap:12px}
.wunsch-stimmen{font-family:var(--serif);font-size:15px;font-weight:700;color:var(--rot-dunkel)}

/* PE-Auswertungs-Tabellen */
.stat-karte{background:var(--karte);border-radius:var(--rund);padding:16px 18px;
  box-shadow:var(--schatten-karte);margin-bottom:16px}
.stat-titel{font-family:var(--serif);font-size:17px;color:var(--head);margin-bottom:10px}
.stat-tabelle{width:100%;border-collapse:collapse}
.stat-tabelle th{background:var(--rot);color:#fff;text-align:left;padding:9px 12px;font-size:13px}
.stat-tabelle td{padding:8px 12px;border-top:1px solid var(--linie);font-size:14px;color:var(--text)}

/* Schulungs-Pass (Mein Bereich) */
.pass-raster{display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(240px,1fr))}
.pass-karte{background:var(--karte);border-radius:var(--rund);padding:16px;text-align:center;
  box-shadow:var(--schatten-karte);border-top:4px solid var(--rot);display:flex;flex-direction:column;gap:8px}
.pass-titel{font-family:var(--serif);font-size:16px;color:var(--head);line-height:1.25}
.pass-meta{font-size:13px;color:var(--grau)}
.pass-qr{width:160px;height:160px;align-self:center;background:#fff;padding:8px;
  border:1px solid var(--linie);border-radius:8px}
.pass-hinweis{font-size:12.5px;color:var(--grau)}

/* Check-in (Trainer-Sicht + QR-Deeplink-Ergebnis) */
.checkin-liste{margin-top:14px}
.checkin-ergebnis{text-align:center;display:flex;flex-direction:column;gap:10px;align-items:center;
  padding:30px 16px}
.checkin-ok-symbol,.checkin-fehler-symbol{width:64px;height:64px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;font-size:34px;color:#fff}
.checkin-ok-symbol{background:var(--amp-gruen)}
.checkin-fehler-symbol{background:var(--amp-rot)}
@media(max-width:560px){.pass-qr{width:200px;height:200px}}

/* F3 Umfrage — Teilnehmer-Formular (Mein Bereich) */
.mb-umfrage-karte{flex-direction:column;align-items:stretch;gap:14px;border-left:4px solid var(--rot)}
.mb-umfrage-form{display:flex;flex-direction:column;gap:16px;margin-top:6px}
.mb-skala-label{font-weight:700;color:var(--head);margin-bottom:6px}
.mb-skala-optionen{display:flex;gap:8px;flex-wrap:wrap}
.mb-skala-opt{position:relative;cursor:pointer}
.mb-skala-opt input{position:absolute;opacity:0;width:0;height:0}
.mb-skala-zahl{display:flex;align-items:center;justify-content:center;width:46px;height:46px;
  border:1.5px solid var(--linie);border-radius:12px;background:var(--karte);
  font-weight:700;color:var(--grau);transition:all .12s ease}
.mb-skala-opt:hover .mb-skala-zahl{border-color:var(--rot);color:var(--rot)}
.mb-skala-opt input:checked + .mb-skala-zahl{background:var(--rot);border-color:var(--rot);color:#fff;
  box-shadow:0 4px 12px rgba(226,6,19,.25)}
.mb-skala-opt input:focus-visible + .mb-skala-zahl{outline:2px solid var(--rot);outline-offset:2px}
.mb-skala-hinweis{font-size:12px;color:var(--grau);margin-top:5px}

/* F3 Umfrage — Veranstalter-Auswertung */
.vb-umfrage{background:var(--karte);border-radius:var(--rund);padding:18px 20px;margin:18px 0;
  box-shadow:var(--schatten-karte);border-top:4px solid var(--rot)}
.vb-umfrage-titel{font-family:var(--serif);font-size:18px;color:var(--head);margin:0 0 4px}
.vb-umfrage-meta{font-size:13px;color:var(--grau);margin-bottom:14px}
.vb-skala{display:grid;grid-template-columns:200px 1fr 70px;align-items:center;gap:12px;margin:8px 0}
.vb-skala-label{font-size:14px;color:var(--head)}
.vb-skala-bahn{height:14px;background:var(--hellgrau);border-radius:7px;overflow:hidden}
.vb-skala-balken{height:100%;background:linear-gradient(90deg,var(--rot-dunkel),var(--rot));border-radius:7px}
.vb-skala-wert{font-weight:700;color:var(--rot);text-align:right;font-variant-numeric:tabular-nums}
.vb-ft-block{margin-top:14px}
.vb-ft-titel{font-weight:700;color:var(--head);margin-bottom:6px}
.vb-ft-liste{margin:0;padding-left:18px;display:flex;flex-direction:column;gap:5px}
.vb-ft-eintrag{color:var(--text);line-height:1.4}
.vb-ft-leer{font-size:13px;color:var(--grau)}
@media(max-width:560px){.vb-skala{grid-template-columns:1fr;gap:4px}.vb-skala-wert{text-align:left}}
