/* ============================================================
   Planungstool – App-spezifische CSS-Erweiterungen
   ------------------------------------------------------------
   Die Grund-Optik wird 1:1 vom Statistikportal übernommen
   (htdocs/index.html lädt dessen app.css via shared.php).
   Hier stehen nur die wenigen Regeln, die das Statistikportal
   selbst nicht mitbringt, aber im Header/Footer der Hülle
   gebraucht werden. App-spezifische Ergänzungen kommen mit dem
   fachlichen Inhalt hinzu.
   ============================================================ */

/* Avatar im Profil-Button: grüner Online-Punkt
   (im Statistikportal-app.css nicht enthalten) */
.user-online-dot {
  position: absolute; bottom: 0; right: 0;
  width: 10px; height: 10px; border-radius: 50%;
  background: #22c55e;
  border: 2px solid var(--surface);
  transform: translate(35%, 35%);
  pointer-events: none; z-index: 2;
}

/* Modal-Container für den Footer-Rechtsseiten-Editor.
   .modal-overlay / .modal-close / .modal-actions liefert app.css;
   die Karte selbst ergänzen wir hier. */
.modal-card {
  background: var(--surface); border-radius: var(--radius);
  box-shadow: var(--shadow-lg); max-width: 640px; width: 100%;
  max-height: 90vh; overflow-y: auto; overflow-x: hidden;
}
.modal-head {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 18px 20px 12px; border-bottom: 1px solid var(--border);
}
.modal-title {
  font-family: 'Barlow Condensed', sans-serif; font-weight: 800;
  font-size: 22px; letter-spacing: .3px; color: var(--text); margin: 4px 0 2px;
}
.modal-body { padding: 14px 20px 20px; }

/* ============================================================
   Sportfest-Planung
   ============================================================ */

.plan-wrap {
  max-width: 960px; margin: 0 auto; padding: 20px 16px 48px;
}
.plan-loading, .plan-error, .plan-empty {
  padding: 32px; text-align: center; color: var(--text2);
}
.plan-error { color: var(--danger, #e53e3e); }

.plan-h1 {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 800; font-size: 30px; letter-spacing: .3px;
  color: var(--primary); margin: 0 0 4px;
}
.plan-h2 {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 20px; margin: 0 0 12px;
  color: var(--text);
}
.plan-back { margin-bottom: 12px; display: inline-flex; }
.plan-label { font-size: 13px; font-weight: 600; color: var(--text2); margin-bottom: 4px; display: block; }
.plan-opt { font-weight: 400; }
.plan-input {
  width: 100%; padding: 8px 10px; border: 1.5px solid var(--border);
  border-radius: 6px; background: var(--surf2, var(--surface));
  color: var(--text); font-size: 14px; box-sizing: border-box;
}
.plan-input:focus { outline: none; border-color: var(--primary); }
.plan-textarea { min-height: 80px; resize: vertical; }
.plan-input-min { width: 56px; text-align: center; padding: 6px 4px; }
.plan-section-label {
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 14px; letter-spacing: .5px;
  text-transform: uppercase; color: var(--text2);
  margin: 20px 0 8px;
}
.plan-info {
  background: var(--surf2, var(--surface)); border: 1.5px solid var(--border);
  border-radius: 8px; padding: 12px 16px; font-size: 14px;
  color: var(--text2); margin-bottom: 16px;
}

/* Eventliste */
.plan-list-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 16px; flex-wrap: wrap; gap: 8px;
}
.plan-cards { display: grid; gap: 12px; margin-bottom: 4px; }
@media (min-width: 600px) { .plan-cards { grid-template-columns: 1fr 1fr; } }
@media (min-width: 900px) { .plan-cards { grid-template-columns: 1fr 1fr 1fr; } }

.plan-card {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 10px; padding: 16px; display: flex;
  flex-direction: column; gap: 4px; cursor: default;
  transition: box-shadow .15s;
}
.plan-card:hover { box-shadow: var(--shadow, 0 2px 8px rgba(0,0,0,.1)); }
.plan-card-past { opacity: .65; }
.plan-card-date { font-size: 12px; color: var(--text2); }
.plan-card-title { font-family: 'Barlow Condensed', sans-serif; font-weight: 700; font-size: 18px; color: var(--text); }
.plan-card-ort  { font-size: 13px; color: var(--text2); }
.plan-card-actions { display: flex; gap: 6px; margin-top: 10px; flex-wrap: wrap; }
.plan-btn-del { color: var(--danger, #e53e3e) !important; }

.plan-past summary { user-select: none; }
.plan-past .plan-cards { margin-top: 8px; }

/* Event-Hero */
.plan-event-hero { margin-bottom: 20px; }
.plan-meta { display: flex; flex-wrap: wrap; gap: 8px; font-size: 13px; color: var(--text2); margin: 6px 0 8px; }
.plan-desc { font-size: 14px; color: var(--text2); margin-bottom: 8px; white-space: pre-wrap; }
.plan-badge {
  display: inline-block; padding: 2px 8px; border-radius: 20px;
  background: var(--primary-light, #fee2e2); color: var(--primary);
  font-size: 12px; font-weight: 600;
}
.plan-badge-locked { background: var(--surf2, #f3f4f6); color: var(--text2); }
.plan-hero-btns { display: flex; gap: 6px; flex-wrap: wrap; margin-top: 10px; }

/* Anmelde-Formular */
.plan-form-card, .plan-edit-card {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 10px; padding: 20px; margin-bottom: 16px;
}
.plan-fg { margin-bottom: 14px; }
.plan-fg-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 500px) { .plan-fg-row { grid-template-columns: 1fr; } }

/* Athlet-Suche */
.plan-search-wrap { position: relative; }
.plan-dropdown {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 100;
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 0 0 8px 8px; max-height: 240px; overflow-y: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
}
.plan-dd-item {
  padding: 9px 12px; cursor: pointer; font-size: 14px;
  display: flex; align-items: center; gap: 8px;
}
.plan-dd-item:hover { background: var(--surf2, var(--surface)); color: var(--primary); }
.plan-dd-hint { font-size: 11px; color: var(--text2); margin-left: auto; }

.plan-selected-chip {
  display: flex; align-items: center; gap: 8px;
  background: var(--primary-light, #fee2e2);
  color: var(--primary); border-radius: 20px;
  padding: 5px 12px; font-size: 14px; font-weight: 600;
  width: fit-content;
}
.plan-chip-clear {
  background: none; border: none; cursor: pointer;
  font-size: 18px; line-height: 1; color: var(--primary);
  padding: 0; display: flex; align-items: center;
}
.plan-nullmeld-label { display: flex; align-items: center; gap: 8px; font-size: 14px; }

/* Aufgaben-Tags */
.plan-tags { display: flex; flex-wrap: wrap; gap: 8px; }
.plan-tag {
  padding: 6px 12px; border-radius: 20px;
  border: 1.5px solid var(--border); background: var(--surface);
  color: var(--text); font-size: 13px; cursor: pointer;
  transition: all .12s; display: flex; align-items: center; gap: 4px;
}
.plan-tag:hover { border-color: var(--primary); color: var(--primary); }
.plan-tag-sel { background: var(--primary); border-color: var(--primary); color: #fff; }
.plan-tag-hint { font-size: 11px; opacity: .75; }

/* Zeitslot-Checkboxen */
.plan-slots { display: flex; flex-direction: column; gap: 6px; }
.plan-slot-cb { font-size: 14px; display: flex; align-items: center; gap: 8px; cursor: pointer; }

.plan-form-actions {
  display: flex; gap: 8px; margin-top: 6px; flex-wrap: wrap;
}

/* Statistik */
.plan-stats { margin-bottom: 16px; }
.plan-warn-badge { color: #f59e0b; font-size: 18px; }

/* ── Aufgaben-Übersicht: Sektionskopf-Ampel ── */
/* Ampel-Färbung: auf td setzen, da td-bg tr-bg überlagert – muss nach .plan-tr-gruppe td stehen */
.pst-empty    { opacity: .4; }
.plan-stat-label { font-size: 13px; font-weight: 600; }
.plan-stat-bar-wrap {
  height: 8px; background: var(--surf2, #f3f4f6);
  border-radius: 4px; overflow: hidden;
}
.plan-stat-bar { height: 100%; background: var(--primary); border-radius: 4px; transition: width .3s; }
.plan-bar-ok   { background: #22c55e; }
.plan-bar-warn { background: #f59e0b; }
.plan-stat-row-click { cursor: pointer; border-radius: 6px; }
.plan-stat-row-click:hover { background: rgba(0,0,0,.04); }
.plan-stat-count { font-size: 12px; color: var(--text2); text-align: right; }
.plan-count-warn { color: #f59e0b; font-weight: 700; }
.plan-stat-icon { font-size: 16px; color: #f59e0b; }
.plan-stat-warn { background: rgba(245,158,11,.05); border-radius: 6px; padding: 4px 8px; }

/* Tabelle */
.plan-tabelle-section { margin-bottom: 20px; }
.plan-table-scroll { overflow-x: auto; }
.plan-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
  white-space: nowrap;
}
.plan-table th, .plan-table td {
  padding: 7px 10px; border: 1px solid var(--border);
  text-align: left; background: var(--surface);
}
.plan-table thead th {
  background: var(--surf2, #f9fafb);
  font-weight: 700; font-family: 'Barlow Condensed', sans-serif;
  font-size: 13px; letter-spacing: .3px;
}
.plan-th-slot { max-width: 120px; white-space: normal; min-width: 72px; }
.plan-td-aufg { white-space: normal; }
.plan-td-x { text-align: center; }
.plan-x { font-weight: 700; color: var(--primary); }
.plan-table tr:hover td { background: var(--surf2, #f9fafb); }

/* Gruppen-Header in der Tabelle */
.plan-tr-gruppe td {
  background: var(--surf2, #f3f4f6) !important;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 12px; letter-spacing: .5px;
  text-transform: uppercase; color: var(--text2);
  padding: 4px 10px !important;
}
/* Hint wenn kein Zeitabschnitt gewählt */
.plan-tags-noslot-hint {
  font-size: 13px; color: var(--text2); font-style: italic;
  padding: 4px 0;
}

/* Zeitslot-Gruppen im Anmeldeformular */
.plan-slot-group-header {
  font-size: 11px; font-weight: 700; letter-spacing: .5px;
  text-transform: uppercase; color: var(--text2);
  margin: 10px 0 4px; padding-bottom: 3px;
  border-bottom: 1px solid var(--border);
}

/* Auto-Slot-Zuweisung in der Aufgabenzeile */
.aufg-auto-slot {
  font-size: 11px; padding: 2px 4px; border-radius: 4px;
  border: 1.5px solid var(--primary); color: var(--primary);
  background: transparent; cursor: pointer; max-width: 140px;
  appearance: auto;
}

/* Teilnehmer-Gruppe in der Aufgabenzeile */
.aufg-gruppe-wrap { width: 100%; padding: 3px 0 2px; }
.aufg-gruppe-sel {
  font-size: 11px; padding: 2px 4px; border-radius: 4px;
  border: 1.5px solid #6366f1; color: #6366f1;
  background: transparent; cursor: pointer; max-width: 160px;
  appearance: auto;
}

/* Gruppen-Header in der Tabelle (colspan-Zeile) */
.plan-tr-gruppe td {
  background: var(--surf2, #f3f4f6) !important;
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 12px; letter-spacing: .5px;
  text-transform: uppercase; color: var(--text2);
  padding: 5px 10px !important; border-top: 2px solid var(--border) !important;
}

/* Ampel-Färbung Aufgaben-Übersicht – Header-Zeile (muss nach .plan-tr-gruppe td stehen) */
.pst-row-err  td { background: rgba(239,68,68,.22) !important; color: #991b1b !important; }
.pst-row-warn td { background: rgba(245,158,11,.22) !important; color: #92400e !important; }
/* Ampel-Färbung: zugehörige Teilnehmer-Zeilen */
.pst-member-err  td { background: rgba(239,68,68,.07); }
.pst-member-warn td { background: rgba(245,158,11,.07); }

/* Erwartete Teilnehmer */
.plan-tr-erwartet td { color: var(--text2); font-style: italic; }
.plan-badge-erwartet {
  display: inline-block; font-size: 10px; font-weight: 700;
  font-style: normal; letter-spacing: .4px; text-transform: uppercase;
  background: var(--surf2, #f3f4f6); color: var(--text2);
  border-radius: 4px; padding: 1px 5px; vertical-align: middle;
  margin-left: 4px;
}

.plan-empty-small { font-size: 14px; color: var(--text2); padding: 12px 0; }
.plan-nullm-wrap { margin-top: 12px; }
.plan-nullm-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.plan-nullm-chip {
  background: var(--surf2, #f3f4f6); color: var(--text2);
  border-radius: 20px; padding: 3px 10px; font-size: 12px;
}

/* Edit-Formular */
.plan-edit-section-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.plan-edit-hint { font-size: 12px; color: var(--text2); margin: -4px 0 10px; }
.plan-edit-list { display: flex; flex-direction: column; gap: 6px; }
.plan-edit-row {
  display: flex; align-items: center; gap: 6px;
}
.plan-edit-row .plan-input { flex: 1; }
.plan-edit-del {
  padding: 6px 10px; font-size: 16px; line-height: 1;
  flex-shrink: 0;
}
.plan-add-btn {
  margin-top: 8px; width: 100%;
  border-style: dashed !important;
  color: var(--text2) !important;
}
.plan-edit-min-label {
  display: flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--text2); white-space: nowrap;
  flex-shrink: 0;
}

/* Fallback-Karte im Bearbeitungsformular */
.plan-fallback-card {
  border-color: #f59e0b !important;
  background: rgba(245,158,11,.04) !important;
}

/* Organisations-Karte */
.plan-org-card, .plan-org-card-modal, .plan-org-admin-block {
  border-color: #6366f1 !important;
  background: rgba(99,102,241,.04) !important;
}
.plan-org-admin-block {
  border-radius: 8px; padding: 10px 12px; border: 1.5px solid;
}
.plan-tag-org {
  border-color: #6366f1 !important; color: #6366f1 !important;
}
.plan-tag-org.plan-tag-sel {
  background: #6366f1 !important; color: #fff !important;
}

/* Aufgaben-Zeile: zweizeilig */
.plan-aufg-row { flex-wrap: wrap; }
.plan-aufg-row > .plan-input,
.plan-aufg-row > .plan-edit-min-label,
.plan-aufg-row > .plan-fallback-label,
.plan-aufg-row > .plan-edit-del { flex-shrink: 0; }

/* Slot-Einschränkungen: eigene Zeile unter den anderen Controls */
.aufg-slot-cbs {
  display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
  width: 100%; padding: 4px 0 2px; border-top: 1px solid var(--border);
  margin-top: 2px;
}
.plan-slot-cbs-prefix {
  font-size: 11px; font-weight: 600; color: var(--text2);
  white-space: nowrap; margin-right: 2px;
}
.aufg-slot-cb-label {
  display: flex; align-items: center; gap: 3px;
  font-size: 11px; color: var(--text2); cursor: pointer;
  background: var(--surf2, #f3f4f6); border-radius: 4px;
  padding: 2px 6px; white-space: nowrap;
}
.aufg-slot-cb-label input { accent-color: var(--primary); }
.aufg-slot-cb-label:has(input:checked) {
  background: rgba(var(--primary-rgb,180,0,0),.12);
  color: var(--primary); font-weight: 600;
}

/* Fallback-Hint auf Registrierungsseite */
.plan-fallback-hint {
  font-size: 13px; color: var(--text2);
  background: rgba(245,158,11,.08); border: 1px solid #f59e0b44;
  border-radius: 6px; padding: 8px 12px; margin-top: 4px;
}

/* Fallback-Zelle in der Tabelle */
.plan-td-fallback { color: var(--text2); font-style: italic; }

/* Vorlage-Auswahl */
.plan-vorlage-card { border-color: var(--primary) !important; }
.plan-vorlage-btns { display: flex; flex-wrap: wrap; gap: 8px; }
.plan-vorlage-btn  {
  border: 1.5px solid var(--border) !important;
  border-radius: 20px !important; padding: 6px 16px !important;
  transition: all .12s;
}
.plan-vorlage-btn:hover { border-color: var(--primary) !important; color: var(--primary); }
.plan-vorlage-btn-sel  {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: #fff !important;
}

/* ── Tag-Input-Widget (Athleten vorbelegen) ──────────────────── */
.plan-ti {
  position: relative;
  border: 1.5px solid var(--border);
  border-radius: 6px;
  background: var(--surf2, var(--surface));
  padding: 4px 8px;
  display: flex; flex-wrap: wrap; align-items: center; gap: 4px;
  cursor: text; margin-top: 6px;
  width: 100%; box-sizing: border-box;
}
.plan-ti:focus-within { border-color: var(--primary); }
.plan-ti-chips { display: contents; }
.plan-ti-chip {
  display: inline-flex; align-items: center; gap: 3px;
  background: var(--primary-light, #fee2e2); color: var(--primary);
  border-radius: 14px; padding: 2px 8px;
  font-size: 12px; font-weight: 600; white-space: nowrap;
}
.plan-ti-chip-del {
  background: none; border: none; cursor: pointer;
  font-size: 13px; line-height: 1; padding: 0;
  color: var(--primary); display: flex; align-items: center; opacity: .7;
}
.plan-ti-chip-del:hover { opacity: 1; }
.plan-ti-input {
  border: none; background: transparent; color: var(--text);
  font-size: 13px; outline: none; min-width: 120px; flex: 1; padding: 3px 2px;
}
.plan-ti-dd {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 200;
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 0 0 8px 8px; max-height: 200px; overflow-y: auto;
  box-shadow: 0 4px 12px rgba(0,0,0,.12);
}

/* ── Erwartet-Badge & Gruppen in der Tabelle ──────────────────── */
.plan-tr-erwartet td { font-style: italic; opacity: .8; }
.plan-badge-erwartet {
  display: inline-block; padding: 0 6px; border-radius: 10px;
  font-size: 11px; font-weight: 600;
  background: rgba(245,158,11,.12); color: #b45309;
}
.plan-gruppe-block { margin-bottom: 16px; }
.plan-tr-gruppe {
  background: var(--surf2, #f3f4f6);
  font-family: 'Barlow Condensed', sans-serif;
  font-weight: 700; font-size: 12px; letter-spacing: .5px;
  text-transform: uppercase; color: var(--text2);
  padding: 4px 10px; border-radius: 4px; margin-bottom: 4px;
}
.plan-tr-gruppe-none { opacity: .6; }
.plan-tr-gruppe-nullm { opacity: .55; }

/* Nullmeldungen in der Tabelle: durchgestrichen */
.plan-tr-nullm td { color: var(--text2); opacity: .65; }
.plan-tr-nullm s  { text-decoration-color: var(--text2); }
/* Gruppen-Hinweis in Absagen-Zeile */
.plan-nullm-grp { font-size: .82em; color: var(--text2); }
/* Admin-Präferenz-Select in Absagen-Zeile */
.plan-praef-sel {
  font-size: 11px; padding: 1px 3px; height: 20px;
  border: 1px dashed var(--border); border-radius: 3px;
  background: var(--bg); color: var(--text); cursor: pointer;
  opacity: .75;
}
.plan-praef-sel:hover { opacity: 1; border-style: solid; }

/* ============================================================
   Wettkampf-Zeitplan – Mobile-first (Smartphone-optimiert)
   ============================================================ */

.plan-zeitplan-section { margin-bottom: 24px; }

/* Live-Kopfzeile */
.plan-zeitplan-live {
  display: flex; align-items: center; gap: 7px;
  font-size: 13px; color: var(--text2); margin-bottom: 10px;
}
.plan-live-dot {
  width: 9px; height: 9px; border-radius: 50%;
  background: #22c55e; flex-shrink: 0;
  animation: plan-live-pulse 1.8s ease-in-out infinite;
}
@keyframes plan-live-pulse {
  0%, 100% { opacity: 1; } 50% { opacity: .3; }
}
.plan-zeitplan-ts { font-size: 12px; color: var(--text2); }

/* LIVE-Badge (pulsierend, auffällig) */
.pzt-live-badge {
  background: #dc2626; color: #fff;
  border-radius: 20px; padding: 2px 9px;
  font-size: 12px; font-weight: 800; letter-spacing: .5px;
  animation: plan-live-pulse 1.8s ease-in-out infinite;
  flex-shrink: 0;
}

/* Countdown „in X Sek." */
.pzt-countdown-wrap {
  margin-left: auto; font-size: 11px; color: var(--text2);
  white-space: nowrap;
}

/* Karten-Liste */
.pzt-list { display: flex; flex-direction: column; gap: 8px; }

/* Einzelne Karte */
.pzt-card {
  background: var(--surface); border: 1.5px solid var(--border);
  border-radius: 12px; padding: 14px 16px;
  display: flex; flex-direction: column; gap: 6px;
}
.pzt-card-past { opacity: .38; }
.pzt-card-next {
  border-color: var(--primary); border-width: 2px;
  box-shadow: 0 0 0 3px rgba(180,0,0,.07);
}

/* Laufendes Event – blau hinterlegt, Schrift unverändert */
.pzt-card-running {
  background: #dbeafe !important;
  border-color: #3b82f6 !important;
  border-width: 2px !important;
}

/* "im Anschluss"-Badge – gedämpftes Blau statt Grün */
.pzt-next-badge--soon {
  background: #3b82f6;
}

/* Abgelaufene Events – nur auf externem Display ausblenden */
.pzt-display-wrap .pzt-card-gone { display: none !important; }

/* ── Departure-Board-Animation bei Datenänderung ──────────────────── */
/* Flip-in für Zeitwert (unverändert) */
@keyframes pzt-time-flipin {
  0%   { transform: translateY(-60%) rotateX(90deg); opacity: 0; }
  55%  { transform: translateY(4%)   rotateX(-6deg); opacity: 1; }
  100% { transform: translateY(0)    rotateX(0deg);  opacity: 1; }
}

/* Departure-Board: 2× Aufblitzen mit Primärfarbe */
@keyframes pzt-card-flash {
  0%,30%,60%,100% { background: transparent;    box-shadow: none; }
  12%,18%         { background: var(--primary);  box-shadow: 0 0 0 4px var(--primary-dark, var(--primary)); }
  42%,48%         { background: var(--primary);  box-shadow: 0 0 0 4px var(--primary-dark, var(--primary)); }
}
/* Zeitwert + Badges während Primär-Flash invertieren */
@keyframes pzt-head-invert {
  0%,30%,60%,100% { color: inherit; }
  12%,18%         { color: #fff; }
  42%,48%         { color: #fff; }
}
@keyframes pzt-badge-invert {
  0%,30%,60%,100% { background: var(--primary); color: #fff; }
  12%,18%         { background: #fff;            color: var(--primary); }
  42%,48%         { background: #fff;            color: var(--primary); }
}

.pzt-card-changed {
  animation: pzt-card-flash 2s ease-out;
}
.pzt-card-changed .pzt-new-time,
.pzt-card-changed .pzt-time-plain {
  display: inline-block;
  transform-origin: top center;
  animation: pzt-time-flipin 0.45s cubic-bezier(.22,.61,.36,1) forwards,
             pzt-head-invert 2s ease-out;
}
.pzt-card-changed .pzt-orig-time,
.pzt-card-changed .pzt-arrow      { animation: pzt-head-invert 2s ease-out; }
.pzt-card-changed .pzt-delay-badge { animation: pzt-badge-invert 2s ease-out; }

/* Kopfzeile: Zeit + Badges */
.pzt-card-head {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.pzt-time-plain {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px; font-weight: 800; color: var(--text);
}
.pzt-orig-time {
  font-size: 16px; text-decoration: line-through;
  color: var(--text2); font-weight: 400;
}
.pzt-arrow { color: var(--text2); font-size: 14px; }
.pzt-new-time {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 26px; font-weight: 800; color: var(--primary);
}
.pzt-delay-badge {
  background: var(--primary); color: #fff;
  border-radius: 20px; padding: 2px 9px;
  font-size: 12px; font-weight: 700;
}
.pzt-next-badge {
  background: #22c55e; color: #fff;
  border-radius: 20px; padding: 2px 9px;
  font-size: 12px; font-weight: 700;
  margin-left: auto;
}

/* Disziplin + Klassen */
.pzt-card-disz {
  font-family: 'Barlow Condensed', sans-serif;
  font-size: 20px; font-weight: 700; color: var(--text);
  line-height: 1.2;
}
.pzt-card-klass { font-size: 14px; color: var(--text2); }

/* Admin-Steuerleiste */
.pzt-controls {
  display: flex; align-items: center; gap: 6px;
  margin-top: 8px; padding-top: 10px;
  border-top: 1px solid var(--border);
}
.pzt-btn {
  min-width: 54px; min-height: 52px;
  border: none; border-radius: 10px;
  font-size: 18px; font-weight: 800;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  touch-action: manipulation; user-select: none;
  -webkit-tap-highlight-color: transparent;
  transition: filter .1s, transform .08s;
}
.pzt-btn:active { filter: brightness(.82); transform: scale(.94); }
.pzt-btn-minus { background: #dcfce7; color: #15803d; }
.pzt-btn-plus  { background: #fee2e2; color: #dc2626; }
.pzt-editor-name {
  flex: 1; text-align: center;
  font-size: 11px; color: var(--text2);
  overflow: hidden;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.pzt-hist-entry { font-weight: 600; }
.pzt-hist-arrow { font-weight: 400; opacity: .75; }
.pzt-hist-sep   { opacity: .4; }
.pzt-editor-leer { opacity: .35; }
.pzt-hint {
  text-align: center; font-size: 12px; color: var(--text2);
  margin: 4px 0 0;
}

/* ── Vollbild-Modus für externen Zeitplan-Link (#event/{hash}) ── */
body.pzt-fullscreen header,
body.pzt-fullscreen footer,
body.pzt-fullscreen #mobile-nav-overlay,
body.pzt-fullscreen #mobile-nav-drawer { display: none !important; }

body.pzt-fullscreen #main-content { padding-top: 0 !important; }

/* ── Zeitplan-Infodisplay-Wrapper ────────────────────────────── */
.pzt-display-wrap {
  padding: 16px 16px 32px;
  max-width: 100%;
  box-sizing: border-box;
}

/* Kopfzeile: Titel links, QR rechts */
.pzt-display-header {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 16px;
  margin-bottom: 10px;
}
.pzt-display-meta { flex: 1; }

/* LIVE + Stand direkt unter Datum/Ort im Display-Header */
.pzt-live-meta {
  display: none; /* nur im Desktop-Display-Modus sichtbar */
  align-items: center; gap: 7px;
  margin-top: 6px;
}
.pzt-qr {
  display: none; /* auf Smartphone verborgen */
  border-radius: 0; border: 1.5px solid var(--border);
  flex-shrink: 0;
}

/* Vereinslogo (externe Seite, Desktop-Display-Modus) */
.pzt-display-logo {
  display: none; /* auf Smartphone verborgen */
  flex-shrink: 0;
  object-fit: contain;
  border-radius: 6px;
}
.pzt-display-logo--empty {
  width: 140px; height: 140px;
}

/* Rechte Gruppe: Uhrzeit + QR nebeneinander */
.pzt-display-right {
  display: none; /* auf Smartphone verborgen */
  flex-shrink: 0;
  align-items: center;
  gap: 10px;
}

/* Sekunden-Teil der Uhr: halb so groß, kein Doppelpunkt davor */
.pzt-clock-sec {
  font-size: .5em;
  vertical-align: middle;
  margin-left: .1em;
}

/* Live-Uhrzeit: Zeichenhöhe ≈ QR-Code-Höhe, frei (keine Box) */
.pzt-liveclock {
  display: none; /* auf Smartphone verborgen */
  font-size: clamp(80px, 9vw, 140px);
  line-height: 1;
  font-variant-numeric: tabular-nums;
  font-weight: 700;
  color: var(--primary);
  letter-spacing: 0.02em;
  white-space: nowrap;
  align-self: center;
}

/* Hinweis-Banner */
.pzt-disclaimer {
  font-size: 13px; color: var(--text2);
  background: rgba(245,158,11,.07);
  border: 1px solid rgba(245,158,11,.3);
  border-radius: 8px; padding: 9px 14px;
  margin-bottom: 14px; line-height: 1.5;
}

/* Bearbeiten-Button: nur Smartphones (Admins) */
.pzt-edit-btn { margin-top: 8px; }

/* ── Desktop-Infodisplay (≥ 960 px) – NUR für .pzt-display-wrap ─
   Der interne Zeitplan (plan-wrap) behält auf Desktop das
   identische Smartphone-Card-Layout inkl. Admin-Controls.       */
@media (min-width: 960px) {
  /* Vollbild-Wrapper: gesamte Viewport-Höhe, kein Scrollen */
  .pzt-display-wrap {
    height: calc(100vh - 68px);
    overflow: hidden;
    display: flex; flex-direction: column;
    padding: 14px 24px 10px;
  }

  /* Rechte Gruppe + Logo + Uhrzeit nur im Desktop-Display-Modus sichtbar */
  .pzt-display-wrap .pzt-display-right { display: flex; }
  .pzt-display-wrap .pzt-display-right .pzt-qr { display: block; }
  .pzt-display-wrap .pzt-display-right .pzt-liveclock { display: block; }
  .pzt-display-wrap .pzt-display-logo { display: block; }

  /* LIVE-Meta unter Datum/Ort einblenden, plan-zeitplan-live im Kartenteil ausblenden */
  .pzt-display-wrap .pzt-live-meta { display: flex; }
  .pzt-display-wrap .plan-zeitplan-live { display: none; }

  /* Disclaimer größer (Infodisplay, Lesbarkeit aus Distanz) */
  .pzt-display-wrap .pzt-disclaimer {
    font-size: 24px; padding: 10px 16px; margin-bottom: 8px; line-height: 1.4;
  }

  /* Zeitplan-Sektion füllt verbleibende Höhe */
  .pzt-display-wrap .plan-zeitplan-section {
    flex: 1; overflow: hidden; margin-bottom: 0;
    display: flex; flex-direction: column;
  }
  .pzt-display-wrap .plan-zeitplan-live { margin-bottom: 6px; flex-shrink: 0; }

  /* Karten-Liste: 3 Spalten, Höhe aufteilen */
  .pzt-display-wrap .pzt-list {
    flex: 1; overflow: hidden;
    display: grid !important;
    grid-template-columns: repeat(3, 1fr);
    grid-auto-rows: minmax(auto, 1fr);
    align-content: start;
    gap: 6px;
  }

  /* Karten kompakter */
  .pzt-display-wrap .pzt-card {
    padding: 8px 12px; gap: 3px; border-radius: 8px;
  }
  .pzt-display-wrap .pzt-time-plain,
  .pzt-display-wrap .pzt-new-time { font-size: clamp(16px, 1.8vw, 26px); }
  .pzt-display-wrap .pzt-orig-time { font-size: 13px; }
  .pzt-display-wrap .pzt-card-disz { font-size: clamp(13px, 1.3vw, 18px); }
  .pzt-display-wrap .pzt-card-klass { font-size: 11px; }
  .pzt-display-wrap .pzt-delay-badge,
  .pzt-display-wrap .pzt-next-badge { font-size: 11px; padding: 1px 7px; }

  /* Controls + Hint nur im Display-Modus ausblenden */
  .pzt-display-wrap .pzt-controls { display: none !important; }
  .pzt-display-wrap .pzt-hint { display: none; }
  .pzt-display-wrap .pzt-edit-btn { display: none; }
}

/* ── Drucken ─────────────────────────────────────────────────── */
@media print {
  header, footer, #mobile-nav-overlay, #mobile-nav-drawer,
  #modal-container, #notification-container,
  .plan-back, .plan-hero-btns, .plan-form-card,
  .plan-stats, .plan-nullm-wrap, .plan-list-header,
  .plan-zeitplan-live, .pzt-controls, .pzt-hint,
  .pzt-next-badge, .pzt-edit-btn, .pzt-qr { display: none !important; }
  .plan-wrap { padding: 0; max-width: 100%; }
  .plan-table { font-size: 11px; }
  .plan-table th, .plan-table td { padding: 4px 6px; }
  .plan-event-hero { margin-bottom: 10px; }
  .plan-h1 { font-size: 20px; }
  .plan-h2 { font-size: 16px; }
}
