/* =========================================================
   LERNEN — Arcade HUD Theme
   Bricolage Grotesque (Display) + JetBrains Mono (numerisch)
   Dark navy + Lime + Magenta. Brutalistisch-präzise.
   ========================================================= */

@import url('https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,600;12..96,800&family=JetBrains+Mono:wght@400;500;700&display=swap');

:root {
  --bg:        #0a0e1c;
  --bg-tiefer: #060912;
  --flaeche:   #131a32;
  --flaeche-2: #1a2342;
  --rand:      #2a3460;
  --rand-glow: #3a4880;
  --text:      #eef1ff;
  --text-dim:  #8693c4;
  --muted:     #5b6796;
  --akzent:    #c5f04a;   /* Lime — primär, korrekt */
  --akzent-2:  #3df9c5;   /* Cyber-Mint — sekundär */
  --warn:      #ff3d8b;   /* Magenta — Fehler */
  --warn-tief: #b8285f;
  --gold:      #ffc857;   /* Streak */

  --schrift-display: 'Bricolage Grotesque', 'Helvetica Neue', sans-serif;
  --schrift-mono:    'JetBrains Mono', ui-monospace, 'SF Mono', monospace;

  --speed: 220ms;
  --speed-langsam: 480ms;
  --ease: cubic-bezier(.2,.8,.2,1);
  --overshoot: cubic-bezier(.34,1.56,.64,1);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--schrift-display);
  font-feature-settings: "ss01", "ss02";
  min-height: 100dvh;
  -webkit-font-smoothing: antialiased;
  -webkit-tap-highlight-color: transparent;
  overflow-x: hidden;
  touch-action: manipulation;
}

/* Subtile Scanline + Grain für HUD-Atmosphäre */
body::before {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 100;
  background:
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.012) 0,
      rgba(255,255,255,0.012) 1px,
      transparent 1px,
      transparent 3px
    ),
    radial-gradient(ellipse at 50% 0%, rgba(61,249,197,0.06), transparent 60%);
  mix-blend-mode: screen;
}

/* Noise-Layer (SVG-data-uri, sehr leicht) */
body::after {
  content: '';
  position: fixed; inset: 0; pointer-events: none; z-index: 99;
  opacity: 0.045;
  background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' stitchTiles='stitch'/></filter><rect width='100%25' height='100%25' filter='url(%23n)' opacity='0.5'/></svg>");
}

/* =================== TOP-LEISTE =================== */
.top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 22px;
  border-bottom: 1px solid var(--rand);
  background: linear-gradient(180deg, rgba(255,255,255,0.02), transparent);
  position: sticky; top: 0; z-index: 10;
  backdrop-filter: blur(8px);
}
.top strong { font-weight: 800; letter-spacing: -0.01em; font-size: 1.1rem; }
.top-links { display: flex; gap: 12px; align-items: center; }

.pill {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 8px 14px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-decoration: none;
  color: var(--bg);
  background: var(--akzent);
  border: 1px solid var(--akzent);
  border-radius: 0;
  transition: transform var(--speed) var(--ease), box-shadow var(--speed) var(--ease);
}
.pill:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); }
.pill.ghost { background: transparent; color: var(--text-dim); border-color: var(--rand); }
.pill.ghost:hover { color: var(--text); border-color: var(--rand-glow); box-shadow: 4px 4px 0 var(--flaeche-2); }

/* =================== STREAK =================== */
.streak {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: 12px;
  padding: 22px;
  max-width: 920px;
  margin: 0 auto;
}
.kachel {
  position: relative;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  padding: 22px 18px;
  text-align: left;
  overflow: hidden;
}
.kachel::before {
  content: '';
  position: absolute; top: 0; left: 0;
  width: 28px; height: 1px;
  background: var(--akzent-2);
}
.kachel .zahl {
  font-family: var(--schrift-mono);
  font-size: 2.6rem;
  font-weight: 700;
  letter-spacing: -0.04em;
  color: var(--text);
  line-height: 1;
}
.kachel .label {
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
  margin-top: 10px;
}
.kachel.hervor { background: linear-gradient(135deg, var(--flaeche), #1d1228); border-color: var(--gold); }
.kachel.hervor::before { background: var(--gold); width: 40px; }
.kachel.hervor .zahl { color: var(--gold); }

/* =================== MODI-GRID =================== */
.modi {
  max-width: 920px;
  margin: 12px auto 60px;
  padding: 22px;
}
.modi h2 {
  font-size: clamp(1.6rem, 4vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  margin-bottom: 22px;
  font-variation-settings: "opsz" 96;
}
.modi h2::after {
  content: ' ▸';
  color: var(--akzent);
  font-family: var(--schrift-mono);
}
.grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: 14px;
}

.modus {
  position: relative;
  display: block;
  padding: 26px 22px 22px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  text-decoration: none;
  color: var(--text);
  overflow: hidden;
  transition: transform var(--speed) var(--ease), border-color var(--speed) var(--ease);
}
.modus::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--akzent);
  transform: scaleX(0); transform-origin: left;
  transition: transform var(--speed-langsam) var(--ease);
}
.modus:hover { transform: translate(-3px,-3px); border-color: var(--rand-glow); box-shadow: 6px 6px 0 var(--bg-tiefer); }
.modus:hover::before { transform: scaleX(1); }
.modus .emoji { font-size: 2rem; margin-bottom: 14px; display: block; filter: saturate(0.85); }
.modus h3 { font-size: 1.25rem; font-weight: 700; margin-bottom: 6px; letter-spacing: -0.02em; }
.modus p { font-family: var(--schrift-mono); font-size: 0.78rem; color: var(--text-dim); line-height: 1.5; }

.modus.sprint::before     { background: var(--akzent); }
.modus.schwaechen::before { background: var(--warn); }
.modus.reihe::before      { background: var(--akzent-2); }
.modus.tagesziel::before  { background: var(--gold); }

/* =================== REIHEN-WAHL =================== */
.reihen-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 10px;
  max-width: 700px;
  margin: 30px auto;
}
.reihen-kachel {
  display: flex; align-items: center; justify-content: center;
  aspect-ratio: 1;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  color: var(--text);
  text-decoration: none;
  font-family: var(--schrift-mono);
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  transition: all var(--speed) var(--ease);
}
.reihen-kachel:hover {
  background: var(--akzent);
  color: var(--bg);
  transform: translate(-2px,-2px);
  box-shadow: 4px 4px 0 var(--bg-tiefer);
}

/* =================== ÜBUNG / BÜHNE =================== */
.uebung-body {
  display: flex;
  flex-direction: column;
  min-height: 100dvh;
}
.fortschritt {
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
  color: var(--text-dim);
  letter-spacing: 0.05em;
}
.fortschritt-balken {
  position: absolute; bottom: -1px; left: 0;
  height: 2px;
  background: var(--akzent);
  width: 0%;
  transition: width 240ms var(--ease);
  box-shadow: 0 0 12px var(--akzent);
}

.bühne {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 22px;
  position: relative;
}

.aufgabe-platz {
  font-family: var(--schrift-display);
  font-weight: 800;
  font-size: clamp(4.5rem, 18vw, 9rem);
  letter-spacing: -0.045em;
  line-height: 0.9;
  text-align: center;
  color: var(--text);
  font-variation-settings: "opsz" 96;
  margin-bottom: 30px;
  user-select: none;
  position: relative;
}
.aufgabe-platz .x {
  color: var(--akzent);
  font-family: var(--schrift-mono);
  font-weight: 400;
  margin: 0 0.15em;
  display: inline-block;
  transform: translateY(-0.05em);
  font-size: 0.7em;
}
.aufgabe-platz .gleich {
  color: var(--muted);
  font-weight: 400;
  margin-left: 0.15em;
}

/* Eingang/Ausgang der Aufgabe */
.aufgabe-platz.eintritt {
  animation: aufgabe-rein 360ms var(--overshoot);
}
.aufgabe-platz.austritt {
  animation: aufgabe-raus 220ms var(--ease) forwards;
}
@keyframes aufgabe-rein {
  0%   { opacity: 0; transform: scale(0.55) translateY(20px); filter: blur(10px); }
  60%  { opacity: 1; }
  100% { transform: scale(1) translateY(0); filter: blur(0); }
}
@keyframes aufgabe-raus {
  to { opacity: 0; transform: scale(1.15) translateY(-20px); filter: blur(8px); }
}

/* Antwort-Eingabe */
#antwort {
  font-family: var(--schrift-mono);
  font-size: clamp(2.4rem, 10vw, 4rem);
  font-weight: 700;
  text-align: center;
  width: min(280px, 70vw);
  background: transparent;
  border: none;
  border-bottom: 3px solid var(--rand);
  color: var(--text);
  padding: 8px 0 14px;
  outline: none;
  letter-spacing: -0.02em;
  caret-color: var(--akzent);
  transition: border-color var(--speed) var(--ease);
}
#antwort:focus { border-bottom-color: var(--akzent); }
#antwort::placeholder { color: var(--muted); opacity: 0.4; }

/* Feedback-Layer */
.feedback {
  margin-top: 26px;
  font-family: var(--schrift-mono);
  font-size: 0.95rem;
  letter-spacing: 0.04em;
  color: var(--text-dim);
  height: 24px;
  text-align: center;
}

/* Erfolgs-Flash über die ganze Bühne */
.bühne.korrekt::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at center, rgba(197,240,74,0.28), transparent 60%);
  pointer-events: none;
  animation: flash 380ms var(--ease) forwards;
}
@keyframes flash { to { opacity: 0; } }

.bühne.falsch #antwort,
.bühne.falsch .aufgabe-platz {
  animation: shake 320ms cubic-bezier(.36,.07,.19,.97);
}
.bühne.falsch::after {
  content: '';
  position: absolute; inset: 0;
  background: radial-gradient(circle at center, rgba(255,61,139,0.22), transparent 60%);
  pointer-events: none;
  animation: flash 380ms var(--ease) forwards;
}
@keyframes shake {
  10%, 90% { transform: translateX(-2px); }
  20%, 80% { transform: translateX(4px); }
  30%, 50%, 70% { transform: translateX(-8px); }
  40%, 60% { transform: translateX(8px); }
}

/* Korrekt-Hinweis (kleines Lime-Ack) */
.feedback.ack { color: var(--akzent); }
.feedback.miss { color: var(--warn); }

/* Konfetti-Particles */
.partikel {
  position: absolute;
  width: 6px; height: 6px;
  background: var(--akzent);
  pointer-events: none;
  z-index: 5;
}
.partikel.gold { background: var(--gold); }
.partikel.mint { background: var(--akzent-2); }

/* =================== ZUSAMMENFASSUNG =================== */
.zusammenfassung {
  max-width: 600px;
  margin: 60px auto;
  padding: 40px 26px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  text-align: center;
}
.zusammenfassung.versteckt { display: none; }
.zusammenfassung h2 {
  font-size: clamp(2rem, 6vw, 3rem);
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 30px;
}
.zusammenfassung-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 14px;
  margin-bottom: 30px;
}
.zusammenfassung-stats .kachel {
  text-align: center;
  padding: 18px 12px;
}
.zusammenfassung-stats .kachel::before { left: 50%; transform: translateX(-50%); width: 32px; }
.aktionen { display: flex; gap: 12px; justify-content: center; }
.aktionen .primary, .aktionen .ghost {
  display: inline-block;
  padding: 14px 26px;
  font-family: var(--schrift-mono);
  font-weight: 600;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  text-decoration: none;
  border: 1px solid var(--akzent);
  background: var(--akzent);
  color: var(--bg);
  transition: all var(--speed) var(--ease);
}
.aktionen .ghost { background: transparent; color: var(--text); border-color: var(--rand); }
.aktionen .primary:hover, .aktionen .ghost:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--bg-tiefer); }

/* =================== LOGIN =================== */
.login-body {
  display: grid;
  place-items: center;
  min-height: 100dvh;
  background: radial-gradient(ellipse at top, #1a2452, var(--bg) 60%);
}
.login-karte {
  width: min(420px, 92vw);
  background: var(--flaeche);
  border: 1px solid var(--rand);
  padding: 44px 34px;
  position: relative;
}
.login-karte::before {
  content: 'LERNEN.SYSTEM';
  position: absolute; top: -12px; left: 22px;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  background: var(--bg);
  padding: 0 10px;
  color: var(--akzent);
}
.login-karte h1 {
  font-size: 2.6rem;
  font-weight: 800;
  letter-spacing: -0.04em;
  margin-bottom: 4px;
  font-variation-settings: "opsz" 96;
}
.login-karte .muted {
  font-family: var(--schrift-mono);
  font-size: 0.8rem;
  color: var(--text-dim);
  margin-bottom: 26px;
}
.login-karte form { display: grid; gap: 14px; }
.login-karte label {
  display: grid; gap: 6px;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
}
.login-karte input {
  font-family: var(--schrift-mono);
  font-size: 1.05rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
  transition: border-color var(--speed) var(--ease);
}
.login-karte input:focus { border-color: var(--akzent); }
.login-karte button.primary {
  margin-top: 8px;
  padding: 14px;
  background: var(--akzent);
  border: 1px solid var(--akzent);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: all var(--speed) var(--ease);
}
.login-karte button.primary:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); }
.fehler {
  background: rgba(255,61,139,0.1);
  border-left: 3px solid var(--warn);
  color: var(--warn);
  padding: 10px 14px;
  margin-bottom: 14px;
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
}

/* =================== ADMIN =================== */
.admin-bereich { max-width: 1100px; margin: 0 auto; padding: 26px; }
.admin-bereich h2 {
  font-size: 2rem; font-weight: 800; letter-spacing: -0.03em;
  margin-bottom: 24px;
}
.admin-bereich h2::after { content: ' /'; color: var(--akzent); font-family: var(--schrift-mono); }
.admin-bereich h3 { font-size: 1.1rem; margin: 30px 0 14px; font-weight: 600; }

.user-tabs { display: flex; gap: 4px; margin-bottom: 22px; }
.user-tabs a {
  padding: 10px 18px;
  font-family: var(--schrift-mono);
  font-size: 0.8rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  color: var(--text-dim);
  text-decoration: none;
}
.user-tabs a.aktiv { background: var(--akzent); color: var(--bg); border-color: var(--akzent); }

.heatmap-wrap { overflow-x: auto; padding: 4px; }
.heatmap {
  border-collapse: collapse;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  width: 100%;
  min-width: 720px;
}
.heatmap th, .heatmap td {
  width: 7.6%;
  aspect-ratio: 1;
  text-align: center;
  vertical-align: middle;
  border: 1px solid var(--bg);
  position: relative;
}
.heatmap th {
  background: transparent;
  color: var(--muted);
  font-weight: 500;
  font-size: 0.72rem;
  border: none;
}
.heatmap td {
  background: var(--flaeche);
  color: var(--text-dim);
  cursor: default;
  transition: transform 120ms var(--ease);
}
.heatmap td:hover { transform: scale(1.08); z-index: 2; outline: 2px solid var(--akzent); }
.heatmap td .ms { display: block; font-weight: 700; color: var(--text); font-size: 0.82rem; }
.heatmap td .pct { display: block; opacity: 0.6; font-size: 0.7rem; }

/* Heatmap-Stufen */
.h-leer  { background: var(--flaeche); color: var(--muted); }
.h-stark { background: linear-gradient(135deg, #1f3530, #0e1f1c); }
.h-stark .ms { color: var(--akzent); }
.h-mittel{ background: linear-gradient(135deg, #2e2a16, #1a1810); }
.h-mittel .ms { color: var(--gold); }
.h-schwach { background: linear-gradient(135deg, #3a1d2a, #1f1018); }
.h-schwach .ms { color: var(--warn); }
.h-kritisch { background: linear-gradient(135deg, var(--warn-tief), #2a0814); animation: puls 2s infinite ease-in-out; }
.h-kritisch .ms { color: #fff; }
@keyframes puls { 0%,100% { filter: brightness(1); } 50% { filter: brightness(1.3); } }

.legende {
  display: flex; gap: 14px; margin-top: 14px;
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  color: var(--muted);
  flex-wrap: wrap;
}
.legende span { display: inline-flex; align-items: center; gap: 6px; }
.legende .swatch { width: 14px; height: 14px; border: 1px solid var(--rand); }

.verlauf-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  max-width: 600px;
}
.verlauf-grid .tag {
  aspect-ratio: 1;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  display: flex; align-items: center; justify-content: center;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  color: var(--muted);
  position: relative;
}
.verlauf-grid .tag.gefuellt { background: var(--akzent); color: var(--bg); font-weight: 700; }
.verlauf-grid .tag.heute { outline: 2px solid var(--gold); }

.tabelle {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
  margin-top: 10px;
}
.tabelle th, .tabelle td {
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--rand);
}
.tabelle th {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  font-weight: 500;
}
.tabelle tr:hover td { background: var(--flaeche); }

/* =================== Mobile-Tweaks =================== */
@media (max-width: 600px) {
  .streak { grid-template-columns: 1fr 1fr; }
  .kachel.hervor { grid-column: span 2; }
  .top { padding: 14px 16px; }
  .modi { padding: 16px; }
  .login-karte { padding: 36px 24px; }
}

/* Reduzierte Bewegung respektieren */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

.erfolg {
  background: rgba(197,240,74,0.1);
  border-left: 3px solid var(--akzent);
  color: var(--akzent);
  padding: 10px 14px;
  margin-bottom: 14px;
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
}

/* admin-streak mobile */
.admin-bereich .streak { grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); }
.admin-bereich .streak .kachel.hervor { grid-column: auto; }

/* =================== MOTIVATIONS-BANNER =================== */
.motiv-banner {
  position: fixed;
  top: 20%;
  left: 50%;
  transform: translate(-50%, -120%) scale(0.85);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  padding: 18px 32px;
  background: var(--flaeche);
  border: 1px solid var(--akzent);
  box-shadow: 0 0 0 1px rgba(197,240,74,0.2), 0 20px 60px rgba(0,0,0,0.5), 0 0 80px rgba(197,240,74,0.15);
  z-index: 200;
  pointer-events: none;
  opacity: 0;
  transition: transform 320ms cubic-bezier(.34,1.56,.64,1), opacity 220ms ease;
  text-align: center;
  min-width: 260px;
}
.motiv-banner.rein {
  transform: translate(-50%, 0) scale(1);
  opacity: 1;
}
.motiv-banner.raus {
  transform: translate(-50%, -40%) scale(0.9);
  opacity: 0;
}
.motiv-emoji {
  font-size: 2rem;
  line-height: 1;
  margin-bottom: 2px;
}
.motiv-kopf {
  font-family: var(--schrift-display);
  font-weight: 800;
  font-size: 1.6rem;
  letter-spacing: -0.02em;
  color: var(--akzent);
  font-variation-settings: "opsz" 96;
  text-shadow: 0 0 24px rgba(197,240,74,0.4);
}
.motiv-detail {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  letter-spacing: 0.04em;
  color: var(--text-dim);
  text-transform: uppercase;
}

/* Stufen */
.motiv-banner.stufe-rekord { border-color: var(--akzent); }
.motiv-banner.stufe-rekord .motiv-kopf { color: var(--akzent); }

.motiv-banner.stufe-comeback { border-color: var(--akzent-2); box-shadow: 0 0 0 1px rgba(61,249,197,0.2), 0 20px 60px rgba(0,0,0,0.5), 0 0 80px rgba(61,249,197,0.15); }
.motiv-banner.stufe-comeback .motiv-kopf { color: var(--akzent-2); text-shadow: 0 0 24px rgba(61,249,197,0.4); }

.motiv-banner.stufe-erstes { border-color: var(--gold); box-shadow: 0 0 0 1px rgba(255,200,87,0.25), 0 20px 60px rgba(0,0,0,0.5), 0 0 80px rgba(255,200,87,0.15); }
.motiv-banner.stufe-erstes .motiv-kopf { color: var(--gold); text-shadow: 0 0 24px rgba(255,200,87,0.4); }

.motiv-banner.stufe-combo-a { border-color: var(--gold); }
.motiv-banner.stufe-combo-a .motiv-kopf { color: var(--gold); }
.motiv-banner.stufe-combo-b { border-color: #ff9f1c; box-shadow: 0 0 80px rgba(255,159,28,0.3); }
.motiv-banner.stufe-combo-b .motiv-kopf { color: #ff9f1c; text-shadow: 0 0 28px rgba(255,159,28,0.5); }
.motiv-banner.stufe-combo-c { border-color: #ff5722; box-shadow: 0 0 100px rgba(255,87,34,0.4); animation: combo-puls 1.4s ease-in-out infinite; }
.motiv-banner.stufe-combo-c .motiv-kopf { color: #ff5722; text-shadow: 0 0 32px rgba(255,87,34,0.7); }
.motiv-banner.stufe-combo-d { border-color: var(--warn); box-shadow: 0 0 120px rgba(255,61,139,0.5); animation: combo-puls 1s ease-in-out infinite; }
.motiv-banner.stufe-combo-d .motiv-kopf {
  background: linear-gradient(90deg, var(--akzent), var(--warn), var(--gold));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  text-shadow: none;
}
@keyframes combo-puls {
  0%,100% { transform: translate(-50%, 0) scale(1); }
  50%     { transform: translate(-50%, 0) scale(1.04); }
}

/* =================== WOCHENPLAN =================== */
.wochen-bereich { max-width: 1300px; margin: 0 auto; padding: 22px; }

.wochen-kopf {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 22px;
  flex-wrap: wrap;
}
.wochen-nav { display: flex; align-items: center; gap: 14px; }
.wochen-nav h2 {
  font-size: clamp(1.4rem, 3vw, 1.9rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  font-variation-settings: "opsz" 96;
}
.wochen-stat {
  display: flex; flex-direction: column; align-items: flex-end;
  font-family: var(--schrift-mono);
}
.ws-zahl { font-size: 1.6rem; font-weight: 700; color: var(--akzent); letter-spacing: -0.02em; }
.ws-label {
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.12em;
  color: var(--muted);
}

.wochen-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 8px;
}
.wt-spalte {
  display: flex;
  flex-direction: column;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  min-height: 220px;
  position: relative;
  transition: border-color 200ms var(--ease);
}
.wt-spalte.heute {
  border-color: var(--akzent);
  box-shadow: 0 0 0 1px var(--akzent), 0 0 40px rgba(197,240,74,0.1);
}
.wt-spalte.heute::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--akzent);
  box-shadow: 0 0 12px var(--akzent);
}
.wt-spalte.vergangen { opacity: 0.55; }

.wt-kopf {
  padding: 12px 12px 10px;
  border-bottom: 1px solid var(--rand);
  display: flex;
  justify-content: space-between;
  align-items: baseline;
}
.wt-name {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--text);
}
.wt-marker {
  display: inline-block;
  font-size: 0.62rem;
  letter-spacing: 0.15em;
  background: var(--akzent);
  color: var(--bg);
  padding: 2px 6px;
  margin-left: 4px;
  vertical-align: middle;
}
.wt-datum {
  font-family: var(--schrift-mono);
  font-size: 0.75rem;
  color: var(--muted);
}

.wt-aufgaben { padding: 8px; display: flex; flex-direction: column; gap: 6px; flex: 1; }
.wt-leer {
  text-align: center; color: var(--muted);
  font-family: var(--schrift-mono); font-size: 0.85rem; padding: 12px 0;
}

.wt-aufgabe {
  position: relative;
  display: grid;
  grid-template-columns: 18px 1fr auto;
  align-items: center;
  gap: 8px;
  text-align: left;
  padding: 10px 12px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--rand);
  border-left: 3px solid var(--art-farbe, var(--muted));
  color: var(--text);
  font-family: var(--schrift-display);
  font-size: 0.92rem;
  cursor: pointer;
  transition: all 180ms var(--ease);
}
.wt-aufgabe:hover { background: rgba(255,255,255,0.04); border-color: var(--rand-glow); }
.wt-aufgabe:active { transform: scale(0.98); }

.wt-check {
  width: 16px; height: 16px;
  border: 1.5px solid var(--art-farbe, var(--muted));
  border-radius: 0;
  position: relative;
  flex-shrink: 0;
}
.wt-aufgabe.erledigt {
  opacity: 0.45;
  background: var(--bg-tiefer);
}
.wt-aufgabe.erledigt .wt-titel {
  text-decoration: line-through;
  text-decoration-color: var(--art-farbe);
}
.wt-aufgabe.erledigt .wt-check {
  background: var(--art-farbe);
}
.wt-aufgabe.erledigt .wt-check::after {
  content: '';
  position: absolute;
  inset: 2px;
  background: var(--bg);
  clip-path: polygon(14% 50%, 0 65%, 38% 100%, 100% 22%, 86% 8%, 38% 70%);
}

.wt-titel { line-height: 1.25; word-break: break-word; }
.wt-dauer {
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  color: var(--muted);
  letter-spacing: 0.05em;
}
.wt-einmalig {
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--gold);
  width: 16px; height: 16px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--gold);
  margin-left: 4px;
}

/* HEUTE-BOX auf Index */
.heute-box {
  max-width: 920px; margin: 0 auto 22px; padding: 0 22px;
}
.heute-box-inhalt {
  background: var(--flaeche);
  border: 1px solid var(--akzent);
  padding: 18px 18px 14px;
  position: relative;
}
.heute-box-inhalt::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--akzent);
  box-shadow: 0 0 12px var(--akzent);
}
.heute-box h3 {
  font-size: 0.72rem;
  font-family: var(--schrift-mono);
  text-transform: uppercase;
  letter-spacing: 0.18em;
  color: var(--akzent);
  margin-bottom: 12px;
}
.heute-box .wt-aufgaben { padding: 0; }
.heute-box-fuss {
  margin-top: 10px;
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  color: var(--muted);
  text-align: right;
}
.heute-box-fuss a { color: var(--text-dim); text-decoration: none; }
.heute-box-fuss a:hover { color: var(--akzent); }

/* =================== ADMIN-Bearbeitung Wochenplan =================== */
.wp-formular {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  padding: 22px;
  margin-bottom: 24px;
}
.wp-formular label {
  display: grid;
  gap: 6px;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
}
.wp-formular label.span2 { grid-column: span 2; }
.wp-formular input,
.wp-formular select,
.wp-formular textarea {
  font-family: var(--schrift-mono);
  font-size: 0.95rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 10px 12px;
  outline: none;
}
.wp-formular textarea { min-height: 70px; resize: vertical; }
.wp-formular button {
  grid-column: span 2;
  padding: 12px;
  background: var(--akzent);
  border: 1px solid var(--akzent);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: all 180ms var(--ease);
}
.wp-formular button:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); }

.wp-liste { display: grid; gap: 8px; }
.wp-zeile {
  display: grid;
  grid-template-columns: auto 1fr auto auto auto;
  gap: 14px;
  align-items: center;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  border-left: 3px solid var(--art-farbe, var(--muted));
  padding: 12px 14px;
  font-family: var(--schrift-mono);
  font-size: 0.82rem;
}
.wp-zeile-titel { color: var(--text); font-weight: 600; font-size: 0.95rem; }
.wp-zeile-meta { color: var(--muted); }
.wp-zeile button.loeschen, .wp-zeile a {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: transparent;
  border: 1px solid var(--rand);
  color: var(--text-dim);
  padding: 6px 10px;
  cursor: pointer;
  text-decoration: none;
}
.wp-zeile button.loeschen:hover { border-color: var(--warn); color: var(--warn); }
.wp-zeile a:hover { border-color: var(--akzent); color: var(--akzent); }

/* Mobile: Wochengrid wird vertikal */
@media (max-width: 900px) {
  .wochen-grid { grid-template-columns: 1fr; }
  .wt-spalte { min-height: 0; }
  .wt-spalte.heute { order: -1; } /* heute zuerst */
  .wp-formular { grid-template-columns: 1fr; }
  .wp-formular label.span2 { grid-column: auto; }
  .wp-formular button { grid-column: auto; }
}

/* =================== ENGLISCH-LEKTIONEN =================== */
.lektionen-bereich { max-width: 1100px; margin: 0 auto; padding: 22px; }
.lektionen-kopf { margin-bottom: 24px; }
.lektionen-kopf h2 {
  font-size: clamp(1.7rem, 4vw, 2.4rem);
  font-weight: 800;
  letter-spacing: -0.025em;
  font-variation-settings: "opsz" 96;
}
.englisch-bereich .lektionen-kopf h2::after { content: ' EN'; color: var(--akzent-2); font-family: var(--schrift-mono); font-size: 0.7em; letter-spacing: 0.1em; }
.muted-mono {
  font-family: var(--schrift-mono);
  font-size: 0.78rem; color: var(--text-dim);
  letter-spacing: 0.04em;
  margin-top: 4px;
}

.lektionen-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 14px;
}

.lekt-karte {
  position: relative;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  padding: 22px 22px 18px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  transition: transform 220ms var(--ease), border-color 220ms var(--ease);
}
.lekt-karte::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--akzent), var(--akzent-2));
  transform: scaleX(0); transform-origin: left;
  transition: transform 360ms var(--ease);
}
.lekt-karte:hover { transform: translate(-2px,-2px); border-color: var(--rand-glow); }
.lekt-karte:hover::before { transform: scaleX(1); }
.lekt-karte.gesperrt { opacity: 0.55; }
/* MEISTER-Karte: edler Gold-Look, Karte bleibt lesbar */
.lekt-karte.komplett {
  border-color: var(--gold);
  background:
    linear-gradient(135deg, rgba(255,200,87,0.06), rgba(197,240,74,0.04)),
    var(--flaeche);
  box-shadow: 0 0 0 1px rgba(255,200,87,0.2), 0 12px 32px rgba(255,200,87,0.08);
}
.lekt-karte.komplett::before {
  transform: scaleX(1);
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  height: 3px;
  box-shadow: 0 0 16px rgba(255,200,87,0.5);
}
.lekt-karte.komplett .lekt-nummer {
  color: var(--gold);
  text-shadow: 0 0 8px rgba(255,200,87,0.4);
}
.lekt-karte.komplett .lekt-kopf h3 {
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
/* Meister-Banner als eigenes Kind statt Pseudo (verhindert Konflikt mit anderen ::after) */
.lekt-meister-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px 4px 8px;
  background: linear-gradient(90deg, var(--gold), #ffe08a);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-size: 0.68rem;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.16em;
  position: absolute;
  top: 14px; right: 14px;
  box-shadow: 0 4px 16px rgba(255,200,87,0.3);
  z-index: 2;
}
.lekt-meister-badge .krone { font-size: 0.85rem; filter: drop-shadow(0 0 4px rgba(255,255,255,0.6)); }
.lekt-meister-badge::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.45) 50%, transparent 70%);
  transform: translateX(-100%);
  animation: meister-shimmer 3s ease-in-out infinite;
}
@keyframes meister-shimmer {
  0%, 60% { transform: translateX(-100%); }
  100%    { transform: translateX(100%); }
}


.lekt-nummer {
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 0.2em;
  color: var(--akzent-2);
  text-transform: uppercase;
}
.lekt-kopf h3 {
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 96;
  line-height: 1.1;
}
.lekt-kopf p {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  color: var(--text-dim);
  margin-top: 6px;
  letter-spacing: 0.02em;
}

.lekt-sperre {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  color: var(--muted);
  background: var(--bg-tiefer);
  border-left: 2px solid var(--rand);
  padding: 12px 14px;
}
.lekt-sperre .schloss { font-size: 1.2rem; }

.lekt-fortschritt { display: flex; flex-direction: column; gap: 6px; }
.lf-zeile {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--schrift-mono);
  font-size: 0.74rem;
  letter-spacing: 0.04em;
  color: var(--text-dim);
  margin-top: 4px;
}
.lf-name { display: inline-flex; align-items: center; gap: 6px; text-transform: uppercase; }
.lf-zahl { color: var(--text); font-weight: 600; }
.lf-lock { font-size: 0.72rem; opacity: 0.7; }
.lf-balken {
  height: 6px;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  position: relative;
  overflow: hidden;
}
.lf-balken.inaktiv { opacity: 0.4; }
.lf-fuell {
  height: 100%;
  background: linear-gradient(90deg, var(--akzent), #d8ff66);
  box-shadow: 0 0 12px rgba(197,240,74,0.3);
  transition: width 600ms var(--ease);
}
.lf-fuell.mint { background: linear-gradient(90deg, var(--akzent-2), #6fffd9); box-shadow: 0 0 12px rgba(61,249,197,0.3); }

.lekt-aktionen { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 6px; }
.lekt-btn {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 12px 14px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  text-decoration: none;
  background: transparent;
  border: 1px solid var(--rand);
  color: var(--text);
  transition: all 200ms var(--ease);
}
.lekt-btn:hover { border-color: var(--akzent-2); color: var(--akzent-2); transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--bg-tiefer); }
.lekt-btn.primary { background: var(--akzent); border-color: var(--akzent); color: var(--bg); }
.lekt-btn.primary:hover { color: var(--bg); border-color: var(--akzent); box-shadow: 4px 4px 0 var(--rand-glow); }
.lekt-btn.disabled { opacity: 0.4; cursor: not-allowed; }
.lekt-btn .arrow { font-family: var(--schrift-mono); }

/* =================== ENGLISCH-UEBUNG =================== */
.zuord-buehne, .lueck-buehne {
  align-items: stretch;
  justify-content: flex-start;
  padding: 24px 22px;
  gap: 22px;
}
.zuord-hinweis {
  text-align: center;
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
  color: var(--text-dim);
  letter-spacing: 0.04em;
  padding: 10px 14px;
  background: var(--flaeche);
  border-left: 2px solid var(--akzent-2);
  margin: 0 auto 10px;
  max-width: 600px;
}
.zuord-feld {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
  max-width: 720px;
  width: 100%;
  margin: 0 auto;
}
.zuord-spalte {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.zuord-spalte::before {
  content: '';
  display: block;
  height: 24px;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  color: var(--muted);
  letter-spacing: 0.2em;
}
.zuord-spalte:nth-child(1)::before { content: 'DEUTSCH'; }
.zuord-spalte:nth-child(2)::before { content: 'ENGLISH'; }

.zuord-wort {
  font-family: var(--schrift-display);
  font-weight: 600;
  font-size: clamp(1.05rem, 2.6vw, 1.3rem);
  letter-spacing: -0.01em;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 18px 16px;
  text-align: center;
  cursor: pointer;
  transition: all 200ms var(--ease);
  min-height: 56px;
}
.zuord-wort:hover { border-color: var(--rand-glow); transform: translate(-1px,-1px); }
.zuord-wort.aktiv {
  border-color: var(--akzent);
  background: rgba(197,240,74,0.08);
  box-shadow: 0 0 0 1px var(--akzent), 0 0 24px rgba(197,240,74,0.2);
}
.zuord-wort.treffer {
  border-color: var(--akzent);
  background: var(--akzent);
  color: var(--bg);
  animation: zuord-treffer 480ms var(--ease);
}
.zuord-wort.falsch {
  border-color: var(--warn);
  background: rgba(255,61,139,0.12);
  animation: shake 320ms cubic-bezier(.36,.07,.19,.97);
}
.zuord-wort.weg {
  opacity: 0;
  transform: scale(0.85);
  pointer-events: none;
  height: 0;
  min-height: 0;
  padding: 0;
  border-width: 0;
  margin: 0;
  transition: all 360ms var(--ease);
}
@keyframes zuord-treffer {
  0%   { transform: scale(1); }
  50%  { transform: scale(1.08); }
  100% { transform: scale(1); }
}

@media (max-width: 540px) {
  .zuord-wort { font-size: 1rem; padding: 14px 10px; min-height: 48px; }
}

/* ---------- LUECKENTEXT ---------- */
.lueck-buehne {
  align-items: center;
  justify-content: center;
  gap: 32px;
}
.lueck-satz {
  font-family: var(--schrift-display);
  font-weight: 700;
  font-size: clamp(1.4rem, 4vw, 2.1rem);
  line-height: 1.45;
  letter-spacing: -0.01em;
  text-align: center;
  max-width: 760px;
  color: var(--text);
}
.lueck-loch {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 130px;
  padding: 6px 14px;
  margin: 0 4px;
  border-bottom: 3px dashed var(--akzent-2);
  color: var(--akzent-2);
  font-family: var(--schrift-mono);
  font-weight: 600;
  position: relative;
  transition: all 220ms var(--ease);
}
.lueck-loch.gefuellt {
  background: rgba(61,249,197,0.12);
  border-bottom-color: var(--akzent);
  color: var(--akzent);
  border-bottom-style: solid;
}
.lueck-loch.korrekt {
  background: rgba(197,240,74,0.18);
  border-bottom-color: var(--akzent);
  color: var(--akzent);
  border-bottom-style: solid;
  box-shadow: 0 4px 24px rgba(197,240,74,0.25);
}
.lueck-loch.falsch {
  background: rgba(255,61,139,0.15);
  border-bottom-color: var(--warn);
  color: var(--warn);
  border-bottom-style: solid;
  animation: shake 320ms cubic-bezier(.36,.07,.19,.97);
}

.lueck-optionen {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 10px;
  max-width: 720px;
}
.lueck-wort {
  font-family: var(--schrift-mono);
  font-weight: 600;
  font-size: 1.05rem;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 12px 22px;
  cursor: pointer;
  transition: all 200ms var(--ease);
  letter-spacing: 0.02em;
}
.lueck-wort:hover { border-color: var(--akzent-2); color: var(--akzent-2); transform: translate(-1px,-1px); }
.lueck-wort.fliegt { transition: transform 480ms var(--ease), opacity 320ms ease; }
.lueck-wort.weg { opacity: 0; transform: scale(0.8); pointer-events: none; }
.lueck-wort.falsch-flash {
  border-color: var(--warn);
  background: rgba(255,61,139,0.15);
  color: var(--warn);
  animation: shake 320ms cubic-bezier(.36,.07,.19,.97);
}

@media (max-width: 540px) {
  .lueck-satz { font-size: 1.25rem; }
  .lueck-loch { min-width: 100px; }
}

.modus.englisch::before { background: linear-gradient(90deg, var(--akzent-2), var(--akzent)); }
.modus.englisch h3 { color: var(--akzent-2); }

/* =================== ADMIN-TABS =================== */
.fach-tabs {
  display: flex;
  gap: 4px;
  margin: 18px 0 28px;
  border-bottom: 1px solid var(--rand);
  overflow-x: auto;
}
.fach-tabs a {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 12px 18px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: all 200ms var(--ease);
  white-space: nowrap;
}
.fach-tabs a:hover { color: var(--text); }
.fach-tabs a.aktiv {
  color: var(--akzent);
  border-bottom-color: var(--akzent);
  background: linear-gradient(180deg, transparent, rgba(197,240,74,0.06));
}
.fach-tabs .ft-emoji { font-size: 1rem; }

/* Übersichts-Karten */
.uebersicht-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 14px;
  margin-top: 22px;
}
.uebersicht-karte {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 22px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  text-decoration: none;
  color: var(--text);
  transition: all 220ms var(--ease);
  position: relative;
  overflow: hidden;
}
.uebersicht-karte::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--akzent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 360ms var(--ease);
}
.uebersicht-karte:hover { transform: translate(-2px,-2px); border-color: var(--rand-glow); box-shadow: 6px 6px 0 var(--bg-tiefer); }
.uebersicht-karte:hover::before { transform: scaleX(1); }
.uebersicht-karte.englisch::before   { background: var(--akzent-2); }
.uebersicht-karte.wochenplan::before { background: var(--gold); }

.uk-kopf { display: flex; align-items: center; gap: 12px; }
.uk-emoji { font-size: 1.6rem; }
.uk-kopf h3 {
  font-size: 1.4rem; font-weight: 800; letter-spacing: -0.02em;
  font-variation-settings: "opsz" 96;
}
.uk-zahlen {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.uk-zahl {
  font-family: var(--schrift-mono);
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  color: var(--text);
}
.uk-label {
  font-family: var(--schrift-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--muted);
  margin-top: 2px;
}
.uk-fuss {
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  color: var(--text-dim);
  letter-spacing: 0.05em;
  margin-top: auto;
  padding-top: 8px;
  border-top: 1px solid var(--rand);
}
.uebersicht-karte:hover .uk-fuss { color: var(--akzent); }
.uebersicht-karte.englisch:hover .uk-fuss { color: var(--akzent-2); }
.uebersicht-karte.wochenplan:hover .uk-fuss { color: var(--gold); }

/* =================== WOCHENPLAN-ADMIN-FORM =================== */
.wpa-bereich { max-width: 900px; margin: 0 auto; padding: 22px; }

.wpa-form {
  background: var(--flaeche);
  border: 1px solid var(--rand);
  margin: 18px 0 30px;
  padding: 26px;
  display: flex;
  flex-direction: column;
  gap: 26px;
}
.wpa-form-kopf {
  display: flex;
  justify-content: space-between;
  align-items: center;
  border-bottom: 1px solid var(--rand);
  padding-bottom: 14px;
}
.wpa-titel-zeile { display: flex; align-items: center; gap: 12px; }
.wpa-form-marker { color: var(--akzent); font-size: 1.4rem; line-height: 1; }
.wpa-form-kopf h2 {
  font-size: 1.4rem;
  font-weight: 800;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 96;
}

/* Toggle-Switch */
.wpa-toggle { display: inline-flex; align-items: center; gap: 10px; cursor: pointer; user-select: none; }
.wpa-toggle input { position: absolute; opacity: 0; width: 1px; height: 1px; }
.wpa-toggle-track {
  width: 42px; height: 22px;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  position: relative;
  transition: all 200ms var(--ease);
}
.wpa-toggle-track::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  top: 3px; left: 3px;
  background: var(--text-dim);
  transition: all 220ms var(--ease);
}
.wpa-toggle input:checked + .wpa-toggle-track {
  background: rgba(197,240,74,0.15);
  border-color: var(--akzent);
}
.wpa-toggle input:checked + .wpa-toggle-track::after {
  left: 23px;
  background: var(--akzent);
  box-shadow: 0 0 12px var(--akzent);
}
.wpa-toggle-label {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
}

/* Block */
.wpa-block { display: flex; flex-direction: column; gap: 14px; }
.wpa-block-kopf { display: flex; align-items: center; gap: 12px; }
.wpa-num {
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--akzent);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 0.85rem;
}
.wpa-block-kopf h3 {
  font-size: 1.05rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  font-variation-settings: "opsz" 96;
}

/* Inputs */
.wpa-titel-input {
  font-family: var(--schrift-display);
  font-size: 1.2rem;
  font-weight: 600;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 14px 16px;
  outline: none;
  transition: border-color 200ms var(--ease);
}
.wpa-titel-input:focus { border-color: var(--akzent); }
.wpa-beschr {
  font-family: var(--schrift-mono);
  font-size: 0.92rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
  resize: vertical;
  min-height: 60px;
  transition: border-color 200ms var(--ease);
}
.wpa-beschr:focus { border-color: var(--akzent); }
.wpa-feld { display: flex; flex-direction: column; gap: 6px; }
.wpa-feld-label {
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
}
.wpa-num-input {
  font-family: var(--schrift-mono);
  font-size: 1rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 10px 14px;
  outline: none;
  width: 140px;
  transition: border-color 200ms var(--ease);
}
.wpa-num-input:focus { border-color: var(--akzent); }

/* Art-Pills */
.wpa-pill-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.wpa-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 16px;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text-dim);
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
  font-weight: 500;
  cursor: pointer;
  transition: all 200ms var(--ease);
  border-left-width: 3px;
  border-left-color: var(--art-farbe, var(--rand));
}
.wpa-pill:hover { color: var(--text); border-color: var(--rand-glow); }
.wpa-pill.aktiv {
  background: rgba(255,255,255,0.04);
  color: var(--text);
  border-color: var(--art-farbe);
  box-shadow: 0 0 0 1px var(--art-farbe), 0 0 24px rgba(255,255,255,0.05);
}
.wpa-pill-emoji { font-size: 1rem; }

/* Typ-Toggle */
.wpa-typ-toggle { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; }
.wpa-typ {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 18px 20px;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.wpa-typ:hover { border-color: var(--rand-glow); transform: translate(-1px,-1px); }
.wpa-typ.aktiv {
  border-color: var(--akzent);
  background: rgba(197,240,74,0.06);
  box-shadow: 0 0 0 1px var(--akzent);
}
.wpa-typ-emoji { font-size: 1.5rem; }
.wpa-typ-titel {
  font-family: var(--schrift-display);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
}
.wpa-typ-detail {
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  color: var(--text-dim);
  letter-spacing: 0.04em;
}

/* Wochentag-Pills */
.wpa-tage { display: grid; grid-template-columns: repeat(7, 1fr); gap: 6px; }
.wpa-tag {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 14px 4px;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text-dim);
  cursor: pointer;
  transition: all 200ms var(--ease);
  font-family: var(--schrift-mono);
}
.wpa-tag:hover { color: var(--text); border-color: var(--rand-glow); }
.wpa-tag.aktiv {
  border-color: var(--akzent);
  background: var(--akzent);
  color: var(--bg);
  box-shadow: 0 0 16px rgba(197,240,74,0.3);
}
.wpa-tag-kurz { font-weight: 700; font-size: 1rem; letter-spacing: 0.05em; }
.wpa-tag-lang { font-size: 0.62rem; letter-spacing: 0.08em; opacity: 0.7; text-transform: uppercase; }

@media (max-width: 540px) {
  .wpa-tag-lang { display: none; }
  .wpa-typ-toggle { grid-template-columns: 1fr; }
}

/* Datum */
.wpa-datum-input {
  font-family: var(--schrift-mono);
  font-size: 1.05rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 12px 14px;
  outline: none;
  width: 100%;
  max-width: 240px;
  transition: border-color 200ms var(--ease);
  color-scheme: dark;
}
.wpa-datum-input:focus { border-color: var(--akzent); }

/* Aktionen */
.wpa-aktionen {
  display: flex;
  gap: 12px;
  align-items: center;
  border-top: 1px solid var(--rand);
  padding-top: 18px;
}
.wpa-submit {
  padding: 14px 28px;
  background: var(--akzent);
  border: 1px solid var(--akzent);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.wpa-submit:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); }
.wpa-abbrechen {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-dim);
  text-decoration: none;
  padding: 12px 14px;
  border: 1px solid var(--rand);
}
.wpa-abbrechen:hover { color: var(--text); border-color: var(--rand-glow); }

/* Liste */
.wpa-listen-kopf {
  font-size: 1.2rem;
  font-weight: 700;
  letter-spacing: -0.02em;
  margin: 30px 0 12px;
}
.wpa-gruppe-kopf {
  font-family: var(--schrift-mono);
  font-size: 0.82rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-dim);
  margin: 22px 0 10px;
}
.wpa-karten { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 10px; }
.wpa-karte {
  background: var(--flaeche);
  border: 1px solid var(--rand);
  border-left: 3px solid var(--art-farbe, var(--muted));
  padding: 14px 16px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  position: relative;
}
.wpa-karte.inaktiv { opacity: 0.5; }
.wpa-karte.vergangen { opacity: 0.55; }
.wpa-karte-meta {
  display: flex;
  gap: 10px;
  align-items: center;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  letter-spacing: 0.08em;
  color: var(--muted);
  text-transform: uppercase;
}
.wpa-karte-tag {
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  padding: 3px 8px;
  color: var(--text);
  font-weight: 700;
}
.wpa-karte-titel {
  font-family: var(--schrift-display);
  font-weight: 700;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
}
.wpa-karte-beschr {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  color: var(--text-dim);
  line-height: 1.4;
}
.wpa-karte-fuss {
  display: flex;
  gap: 6px;
  margin-top: auto;
  padding-top: 4px;
}
.wpa-mini-btn {
  font-family: var(--schrift-mono);
  font-size: 0.68rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  background: transparent;
  border: 1px solid var(--rand);
  color: var(--text-dim);
  padding: 5px 10px;
  cursor: pointer;
  text-decoration: none;
  transition: all 200ms var(--ease);
}
.wpa-mini-btn:hover { color: var(--akzent); border-color: var(--akzent); }
.wpa-mini-btn.warn:hover { color: var(--warn); border-color: var(--warn); }

/* =================== KONTO + PUSH =================== */
.konto-karte { width: min(520px, 92vw); }
.konto-h2 {
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  margin-top: 24px;
  padding-top: 20px;
  border-top: 1px solid var(--rand);
}
.konto-form { display: grid; gap: 12px; margin-top: 14px; }
.konto-form label {
  display: grid; gap: 6px;
  font-family: var(--schrift-mono);
  font-size: 0.7rem; text-transform: uppercase; letter-spacing: 0.1em;
  color: var(--text-dim);
}
.konto-form input {
  font-family: var(--schrift-mono);
  font-size: 1rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 11px 14px;
  outline: none;
}
.konto-form input:focus { border-color: var(--akzent); }
.konto-form button { margin-top: 4px; }

.push-status {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  letter-spacing: 0.06em;
  border: 1px solid var(--rand);
  margin-bottom: 14px;
}
.ps-punkt {
  width: 10px; height: 10px;
  background: var(--muted);
  border-radius: 50%;
}
.push-status.aktiv {
  border-color: var(--akzent);
  color: var(--akzent);
}
.push-status.aktiv .ps-punkt {
  background: var(--akzent);
  box-shadow: 0 0 12px var(--akzent);
  animation: ps-puls 1.6s ease-in-out infinite;
}
@keyframes ps-puls { 0%,100% { opacity: 1; } 50% { opacity: 0.4; } }

.push-buttons { display: flex; gap: 8px; flex-wrap: wrap; }
.push-buttons button {
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  padding: 11px 18px;
  background: transparent;
  border: 1px solid var(--rand);
  color: var(--text);
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.push-buttons button:hover { border-color: var(--akzent-2); color: var(--akzent-2); }
.push-buttons button.primary {
  background: var(--akzent); border-color: var(--akzent); color: var(--bg);
}
.push-buttons button.primary:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); color: var(--bg); border-color: var(--akzent); }
.push-buttons button[hidden] { display: none; }

.modus.mathe::before { background: linear-gradient(90deg, var(--akzent), var(--gold)); }
.modus.mathe h3 { color: var(--akzent); }
.lekt-karte.mathe::before { background: linear-gradient(90deg, var(--akzent), var(--gold)); }
.lekt-karte.mathe .lekt-nummer { color: var(--akzent); }

.lekt-hinweis {
  margin-top: 8px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  letter-spacing: 0.02em;
  padding: 8px 12px;
  border-left: 2px solid var(--rand);
  color: var(--text-dim);
  line-height: 1.4;
}
.lekt-hinweis.nah {
  color: var(--akzent);
  border-left-color: var(--akzent);
  background: rgba(197,240,74,0.06);
}
.lekt-hinweis.komplett {
  color: var(--gold);
  border-left-color: var(--gold);
  background: rgba(255,200,87,0.06);
  font-weight: 600;
}
.lekt-hinweis strong { color: var(--text); font-weight: 700; }
.lekt-hinweis.nah strong { color: var(--akzent); }
.lekt-hinweis.komplett strong { color: var(--gold); }

/* =================== DASHBOARD =================== */
.dashboard-bereich { max-width: 760px; margin: 0 auto; padding: 22px 22px 60px; }

/* Hero-Timer */
.timer-hero {
  position: relative;
  background: linear-gradient(180deg, var(--flaeche), var(--bg-tiefer));
  border: 1px solid var(--rand);
  padding: 24px 22px 22px;
  margin-bottom: 28px;
  overflow: hidden;
  transition: border-color 300ms var(--ease);
}
.timer-hero::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--rand);
}
.timer-hero.laeuft::before {
  background: var(--akzent);
  box-shadow: 0 0 16px var(--akzent);
  animation: timer-puls 1.4s ease-in-out infinite;
}
.timer-hero.erreicht {
  border-color: var(--gold);
  background: linear-gradient(180deg, rgba(255,200,87,0.08), var(--bg-tiefer));
}
.timer-hero.erreicht::before { background: var(--gold); box-shadow: 0 0 24px var(--gold); }
@keyframes timer-puls {
  0%,100% { opacity: 1; }
  50% { opacity: 0.4; }
}

.timer-zeile-oben {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-family: var(--schrift-mono);
  font-size: 0.72rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-dim);
  margin-bottom: 14px;
}
.timer-zeile-oben strong { color: var(--text); font-weight: 700; }
.timer-streak { color: var(--gold); }

.timer-anzeige {
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: clamp(4rem, 18vw, 7.5rem);
  line-height: 0.95;
  letter-spacing: -0.04em;
  text-align: center;
  color: var(--text);
  font-variant-numeric: tabular-nums;
  margin: 8px 0 4px;
  transition: color 300ms var(--ease);
}
.timer-hero.laeuft .timer-anzeige { color: var(--akzent); text-shadow: 0 0 32px rgba(197,240,74,0.4); }
.timer-hero.erreicht .timer-anzeige { color: var(--gold); text-shadow: 0 0 32px rgba(255,200,87,0.5); }
.timer-trenn {
  display: inline-block;
  margin: 0 4px;
  opacity: 0.6;
}
.timer-hero.laeuft .timer-trenn { animation: trenn-blink 1s steps(2, start) infinite; }
@keyframes trenn-blink { 50% { opacity: 0.15; } }

.timer-status {
  text-align: center;
  font-family: var(--schrift-mono);
  font-size: 0.85rem;
  letter-spacing: 0.05em;
  color: var(--text-dim);
  margin-bottom: 14px;
}
.timer-hero.laeuft .timer-status { color: var(--akzent); }
.timer-hero.erreicht .timer-status { color: var(--gold); font-weight: 700; }

.timer-balken {
  height: 4px;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  margin: 4px 0 16px;
  overflow: hidden;
}
.timer-fuell {
  height: 100%;
  background: linear-gradient(90deg, var(--akzent), var(--akzent-2));
  transition: width 800ms var(--ease);
  box-shadow: 0 0 12px rgba(197,240,74,0.4);
}
.timer-hero.erreicht .timer-fuell {
  background: linear-gradient(90deg, var(--gold), var(--akzent));
}

.timer-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  text-align: center;
}
.timer-stats > div {
  display: flex;
  flex-direction: column;
  gap: 2px;
  padding: 10px;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
}
.timer-stats strong {
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: -0.02em;
  color: var(--text);
}
.timer-stats span {
  font-family: var(--schrift-mono);
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

/* Sektionen */
.dash-h2 {
  font-size: 1rem;
  font-family: var(--schrift-mono);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--text-dim);
  margin: 22px 0 12px;
}

.dash-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
.dash-karte {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 22px 18px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  text-decoration: none;
  color: var(--text);
  position: relative;
  overflow: hidden;
  transition: all 220ms var(--ease);
}
.dash-karte::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: var(--akzent);
  transform: scaleX(0); transform-origin: left;
  transition: transform 360ms var(--ease);
}
.dash-karte:hover { transform: translate(-2px,-2px); border-color: var(--rand-glow); box-shadow: 4px 4px 0 var(--bg-tiefer); }
.dash-karte:hover::before { transform: scaleX(1); }
.dash-karte.mathe::before    { background: linear-gradient(90deg, var(--akzent), var(--gold)); }
.dash-karte.englisch::before { background: linear-gradient(90deg, var(--akzent-2), var(--akzent)); }
.dk-emoji { font-size: 1.6rem; }
.dk-titel { font-family: var(--schrift-display); font-size: 1.5rem; font-weight: 800; letter-spacing: -0.02em; }
.dk-detail { font-family: var(--schrift-mono); font-size: 0.78rem; color: var(--text-dim); letter-spacing: 0.04em; }

/* Heute-Aufgaben — wt-aufgabe.auto = leicht zurückgesetzt, kein klick-handler */
.wt-aufgabe.auto { cursor: default; }
.wt-aufgabe.auto:hover { transform: none; background: rgba(255,255,255,0.02); }
.wt-aufgabe.auto:active { transform: none; }
.wt-aufgabe.auto .wt-check { opacity: 0.3; }
.wt-auto-marker {
  font-size: 0.85rem;
  color: var(--akzent-2);
  margin-left: auto;
}

@media (max-width: 540px) {
  .dash-grid-2 { grid-template-columns: 1fr; }
  .timer-anzeige { font-size: 4.5rem; }
}

/* =================== POLISH-PASS — mehr Atmosphäre =================== */

/* Animierter Gradient-Mesh im Hintergrund (sehr subtil) */
body {
  background: var(--bg);
  position: relative;
}
body::before {
  /* überschreibt das vorherige scanline-only — jetzt mit zusätzlichem mesh */
  background:
    radial-gradient(800px 400px at 15% 0%,  rgba(197,240,74,0.05), transparent 60%),
    radial-gradient(600px 500px at 90% 30%, rgba(61,249,197,0.04), transparent 60%),
    radial-gradient(700px 600px at 30% 100%, rgba(255,200,87,0.03), transparent 60%),
    repeating-linear-gradient(
      0deg,
      rgba(255,255,255,0.012) 0,
      rgba(255,255,255,0.012) 1px,
      transparent 1px,
      transparent 3px
    );
  animation: mesh-drift 28s ease-in-out infinite alternate;
}
@keyframes mesh-drift {
  0%   { transform: translate(0, 0); }
  100% { transform: translate(-30px, 20px); }
}

/* H2 mit dekorativem Marker links */
.lektionen-kopf h2,
.modi h2,
.dash-h2 + .dash-h2,
.admin-bereich > h2,
.wpa-bereich > h2 {
  position: relative;
}
.modi h2::before,
.lektionen-kopf h2::before,
.admin-bereich > h2::before {
  content: '';
  display: inline-block;
  width: 6px; height: 22px;
  background: linear-gradient(180deg, var(--akzent), var(--akzent-2));
  margin-right: 12px;
  vertical-align: -3px;
  box-shadow: 0 0 16px rgba(197,240,74,0.4);
}

/* Karten — mehr Tiefe + Hover-Glow */
.modus,
.lekt-karte,
.dash-karte,
.uebersicht-karte,
.kachel {
  position: relative;
}
.modus > .glow,
.lekt-karte > .glow {
  /* hover glow ist jetzt nur über die existierenden ::before-Verläufe + box-shadow */
}
.modus:hover, .lekt-karte:hover, .dash-karte:hover, .uebersicht-karte:hover {
  box-shadow: 6px 6px 0 var(--bg-tiefer), 0 0 40px rgba(197,240,74,0.10);
}

/* Konsistente "ECKEN-MARKER" auf allen größeren Containern (HUD-Optik) */
.timer-hero::after,
.login-karte::after,
.zusammenfassung::after {
  content: '';
  position: absolute;
  width: 14px; height: 14px;
  bottom: -1px; right: -1px;
  border-right: 2px solid var(--akzent-2);
  border-bottom: 2px solid var(--akzent-2);
  pointer-events: none;
}

/* Buttons mit shimmer-effekt bei hover */
.lekt-btn.primary,
.wpa-submit,
.aktionen .primary,
.login-karte button.primary,
.push-buttons button.primary,
.pill {
  position: relative;
  overflow: hidden;
  isolation: isolate;
}
.lekt-btn.primary::before,
.wpa-submit::before,
.aktionen .primary::before,
.login-karte button.primary::before,
.push-buttons button.primary::before {
  content: '';
  position: absolute;
  inset: 0;
  background: linear-gradient(110deg, transparent 30%, rgba(255,255,255,0.35) 50%, transparent 70%);
  transform: translateX(-150%);
  transition: transform 600ms var(--ease);
  pointer-events: none;
  z-index: -1;
}
.lekt-btn.primary:hover::before,
.wpa-submit:hover::before,
.aktionen .primary:hover::before,
.login-karte button.primary:hover::before,
.push-buttons button.primary:hover::before {
  transform: translateX(150%);
}

/* Top-Bar bekommt einen sehr dezenten gradient */
.top {
  background: linear-gradient(180deg, rgba(197,240,74,0.04), transparent 70%);
  border-bottom: 1px solid var(--rand);
}
.top strong {
  background: linear-gradient(90deg, var(--text), var(--akzent-2));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-weight: 800;
  letter-spacing: -0.01em;
}

/* Streak-Kacheln: kleine Grafik-Marker */
.kachel { transition: transform 220ms var(--ease), border-color 220ms var(--ease); }
.kachel:hover { transform: translateY(-2px); border-color: var(--rand-glow); }
.kachel::after {
  content: '';
  position: absolute;
  bottom: 8px; right: 10px;
  width: 6px; height: 6px;
  background: var(--akzent);
  opacity: 0.4;
  border-radius: 50%;
}
.kachel.hervor::after { background: var(--gold); opacity: 0.6; box-shadow: 0 0 12px var(--gold); }

/* Status-Punkt im Top-Bar (Online-Indikator) */
.top::after {
  content: 'LIVE';
  position: absolute;
  right: 50%;
  top: 50%;
  transform: translateY(-50%);
  font-family: var(--schrift-mono);
  font-size: 0.6rem;
  letter-spacing: 0.2em;
  color: var(--akzent-2);
  opacity: 0.4;
  pointer-events: none;
  display: none; /* erstmal verstecken — kann pro Seite enabled werden */
}

/* Modi-Karten — überarbeitete hover */
.modus { transition: transform 240ms var(--ease), border-color 240ms var(--ease), box-shadow 240ms var(--ease); }
.modus:hover {
  transform: translate(-3px, -3px) rotate(-0.3deg);
  box-shadow:
    6px 6px 0 var(--bg-tiefer),
    0 0 40px rgba(197,240,74,0.08);
}

/* Headlines mit subtle "fluo" */
h1, .modi h2, .lektionen-kopf h2, .login-karte h1, .timer-anzeige {
  text-shadow: 0 1px 0 rgba(255,255,255,0.04);
}

/* Subtle ASCII-Marker oben links auf großen Sektionen */
.dashboard-bereich::before,
.lektionen-bereich::before,
.wpa-bereich::before,
.admin-bereich::before {
  content: '◢';
  position: absolute;
  left: 6px;
  top: 78px;
  color: var(--akzent);
  opacity: 0.3;
  font-size: 0.7rem;
  pointer-events: none;
}

/* Decorative Linien hinter Titeln */
.dash-h2 {
  display: flex;
  align-items: center;
  gap: 14px;
}
.dash-h2::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(90deg, var(--rand), transparent);
}

/* Listen-Items haben einen feinen Lime-Strich beim Hover */
.tabelle tr {
  position: relative;
  transition: background 200ms var(--ease);
}
.tabelle tbody tr:hover td:first-child {
  border-left: 2px solid var(--akzent);
  padding-left: 10px;
}

/* Login-Karte: animated border */
.login-karte {
  position: relative;
}
.login-karte::before {
  /* lassen wir, ergänzen aber animation */
  animation: badge-glow 3s ease-in-out infinite alternate;
}
@keyframes badge-glow {
  0%   { color: var(--akzent); }
  100% { color: var(--akzent-2); }
}

/* Auf reduzierte Bewegung Rücksicht nehmen */
@media (prefers-reduced-motion: reduce) {
  body::before { animation: none !important; }
  .login-karte::before { animation: none !important; }
}
/* Doppel-Timer */
.dash-streak {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--schrift-mono);
  font-size: 0.8rem;
  letter-spacing: 0.05em;
  color: var(--gold);
  background: rgba(255,200,87,0.08);
  border: 1px solid rgba(255,200,87,0.3);
  padding: 8px 14px;
  margin-bottom: 18px;
  width: fit-content;
}
.ds-flamme { font-size: 1.1rem; }
.ds-zahl { color: var(--gold); font-weight: 800; font-size: 1.05rem; }
.ds-text { color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.7rem; }

.dash-timer-doppel {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 28px;
}
.timer-hero.kompakt {
  padding: 16px 18px 14px;
  margin-bottom: 0;
}
.timer-hero.kompakt .timer-anzeige { font-size: clamp(2.5rem, 8vw, 4rem); margin: 4px 0; }
.timer-hero.kompakt .timer-status { font-size: 0.72rem; margin-bottom: 10px; }
.timer-hero.kompakt .timer-stats { font-size: 0.85rem; }
.timer-hero.kompakt .timer-stats strong { font-size: 1.1rem; }

.timer-hero.mathe::before    { background: linear-gradient(90deg, var(--akzent), var(--gold)); }
.timer-hero.englisch::before { background: linear-gradient(90deg, var(--akzent-2), var(--akzent)); }
.timer-hero.englisch.laeuft .timer-anzeige { color: var(--akzent-2); text-shadow: 0 0 28px rgba(61,249,197,0.45); }
.timer-hero.englisch.laeuft .timer-status   { color: var(--akzent-2); }

@media (max-width: 540px) {
  .dash-timer-doppel { grid-template-columns: 1fr; }
}

/* MASTERCHALLENGE-Karte */
.lekt-karte.master {
  grid-column: 1 / -1;
  background:
    linear-gradient(135deg, rgba(255,200,87,0.06), rgba(197,240,74,0.04)),
    var(--flaeche);
  border-color: var(--gold);
  position: relative;
  overflow: hidden;
}
.lekt-karte.master::before {
  background: linear-gradient(90deg, var(--gold), var(--akzent), var(--warn));
  transform: scaleX(1);
  height: 3px;
  box-shadow: 0 0 24px rgba(255,200,87,0.4);
}
.lekt-karte.master:not(.gesperrt)::after {
  content: '';
  position: absolute;
  inset: 0;
  pointer-events: none;
  background: radial-gradient(circle at 80% 20%, rgba(255,200,87,0.15), transparent 60%);
}
.lekt-karte.master .lekt-nummer {
  color: var(--gold);
  font-size: 0.75rem;
  letter-spacing: 0.18em;
  text-shadow: 0 0 12px rgba(255,200,87,0.4);
}
.lekt-karte.master .lekt-kopf h3 {
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  font-size: 1.6rem;
}
.lekt-karte.master .lekt-btn.primary {
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  border-color: var(--gold);
  color: var(--bg);
  font-weight: 800;
}
.lekt-karte.master.gesperrt { opacity: 0.55; }
.lekt-karte.master.gesperrt::before { background: var(--rand); box-shadow: none; }

/* =================== MASTER-ENDBILDSCHIRM =================== */
.master-scrim {
  position: fixed; inset: 0;
  background:
    radial-gradient(ellipse at top, rgba(255,200,87,0.18), transparent 60%),
    radial-gradient(ellipse at bottom, rgba(197,240,74,0.12), transparent 60%),
    rgba(10,14,28,0.96);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1000;
  opacity: 0;
  transition: opacity 600ms var(--ease);
  backdrop-filter: blur(8px);
}
.master-scrim.rein { opacity: 1; }

.master-inhalt {
  text-align: center;
  max-width: 600px;
  padding: 0 26px;
  transform: scale(0.85) translateY(40px);
  transition: transform 800ms cubic-bezier(.34,1.56,.64,1);
  position: relative;
}
.master-scrim.rein .master-inhalt {
  transform: scale(1) translateY(0);
}

.master-krone {
  font-size: 5rem;
  line-height: 1;
  filter: drop-shadow(0 0 40px rgba(255,200,87,0.7));
  animation: krone-tanz 2.4s ease-in-out infinite;
}
@keyframes krone-tanz {
  0%, 100% { transform: rotate(-4deg) scale(1); }
  50%      { transform: rotate(4deg) scale(1.05); }
}

.master-titel {
  font-family: var(--schrift-display);
  font-weight: 800;
  font-size: clamp(4rem, 16vw, 8rem);
  letter-spacing: -0.06em;
  font-variation-settings: "opsz" 96;
  line-height: 0.9;
  margin: 12px 0 8px;
  background: linear-gradient(120deg, var(--gold) 0%, var(--akzent) 50%, var(--warn) 100%);
  background-size: 200% 200%;
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
  animation: master-shine 4s ease-in-out infinite;
  text-shadow: 0 0 60px rgba(255,200,87,0.3);
}
@keyframes master-shine {
  0%, 100% { background-position: 0% 50%; }
  50%      { background-position: 100% 50%; }
}

.master-untertitel {
  font-family: var(--schrift-mono);
  font-size: 1rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--gold);
  margin-bottom: 32px;
}

.master-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin: 0 auto 30px;
  max-width: 480px;
}
.master-stats > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: 14px;
  background: var(--flaeche);
  border: 1px solid var(--rand);
  border-top: 2px solid var(--gold);
}
.master-stats strong {
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 1.5rem;
  color: var(--gold);
}
.master-stats span {
  font-family: var(--schrift-mono);
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--muted);
}

.master-aktionen { display: flex; gap: 12px; justify-content: center; }
.master-btn {
  display: inline-block;
  padding: 16px 32px;
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  border: 1px solid var(--gold);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 800;
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  text-decoration: none;
  transition: all 220ms var(--ease);
  box-shadow: 0 8px 32px rgba(255,200,87,0.3);
}
.master-btn:hover { transform: translate(-2px,-2px); box-shadow: 12px 12px 0 rgba(0,0,0,0.4), 0 0 40px rgba(255,200,87,0.5); }

@media (max-width: 540px) {
  .master-stats { grid-template-columns: 1fr; max-width: 280px; }
  .master-krone { font-size: 4rem; }
}

/* =================== TAMAGOTCHI =================== */
.tama-karte {
  background:
    radial-gradient(ellipse at 50% -20%, rgba(197,240,74,0.15), transparent 60%),
    var(--flaeche);
  border: 1px solid var(--rand);
  padding: 22px 22px 18px;
  margin-bottom: 22px;
  position: relative;
  overflow: hidden;
}
.tama-karte::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, var(--akzent-2), var(--akzent), var(--gold));
  opacity: 0.6;
}

.tama-buehne {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 8px 0 14px;
}
.tama-figur {
  font-size: 4rem;
  line-height: 1;
  filter: drop-shadow(0 0 24px rgba(197,240,74,0.3));
  animation: tama-atmen 3s ease-in-out infinite;
  cursor: pointer;
  user-select: none;
}
@keyframes tama-atmen {
  0%, 100% { transform: scale(1) translateY(0); }
  50%      { transform: scale(1.06) translateY(-4px); }
}
.tama-karte.stufe-0 .tama-figur { font-size: 3rem; }
.tama-karte.stufe-1 .tama-figur { font-size: 3.4rem; }
.tama-karte.stufe-2 .tama-figur { font-size: 3.8rem; }
.tama-karte.stufe-3 .tama-figur { font-size: 4.2rem; }
.tama-karte.stufe-4 .tama-figur { font-size: 4.6rem; filter: drop-shadow(0 0 30px rgba(197,240,74,0.45)); }
.tama-karte.stufe-5 .tama-figur { font-size: 5.2rem; filter: drop-shadow(0 0 40px rgba(255,200,87,0.55)); animation: tama-atmen 2.4s ease-in-out infinite; }

/* Sprechblase */
.tama-bubble {
  position: absolute;
  top: -4px;
  background: var(--bg-tiefer);
  border: 1px solid var(--akzent-2);
  color: var(--text);
  font-family: var(--schrift-mono);
  font-size: 0.92rem;
  padding: 10px 14px;
  max-width: 280px;
  text-align: center;
  box-shadow: 0 4px 20px rgba(61,249,197,0.15);
  animation: tama-bubble-rein 280ms cubic-bezier(.34,1.56,.64,1);
  z-index: 2;
}
.tama-bubble::after {
  content: '';
  position: absolute;
  bottom: -6px; left: 50%;
  transform: translateX(-50%) rotate(45deg);
  width: 10px; height: 10px;
  background: var(--bg-tiefer);
  border-right: 1px solid var(--akzent-2);
  border-bottom: 1px solid var(--akzent-2);
}
@keyframes tama-bubble-rein {
  0%   { opacity: 0; transform: translateY(-10px) scale(0.85); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}

/* Info-Zeile */
.tama-info { display: flex; flex-direction: column; gap: 6px; margin-bottom: 12px; }
.tama-name-zeile {
  display: flex; justify-content: space-between; align-items: baseline;
  font-family: var(--schrift-mono);
}
.tama-name-zeile strong {
  font-family: var(--schrift-display);
  font-size: 1.15rem;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--akzent-2);
}
.tama-stufe {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--text-dim);
}
.tama-balken {
  height: 4px;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  overflow: hidden;
}
.tama-fuell {
  height: 100%;
  background: linear-gradient(90deg, var(--akzent-2), var(--akzent));
  box-shadow: 0 0 12px rgba(61,249,197,0.4);
  transition: width 800ms var(--ease);
}
.tama-xp-text {
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  color: var(--muted);
  letter-spacing: 0.04em;
}

/* Frage-Form */
.tama-frage-form {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 6px;
}
.tama-frage-form input {
  font-family: var(--schrift-mono);
  font-size: 0.92rem;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 10px 14px;
  outline: none;
}
.tama-frage-form input:focus { border-color: var(--akzent-2); }
.tama-frage-form button {
  background: var(--akzent-2);
  border: 1px solid var(--akzent-2);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 800;
  padding: 0 16px;
  cursor: pointer;
  transition: transform 200ms var(--ease), box-shadow 200ms var(--ease);
}
.tama-frage-form button:hover { transform: translate(-1px,-1px); box-shadow: 3px 3px 0 var(--bg-tiefer); }
.tama-frage-form button:disabled { opacity: 0.5; cursor: not-allowed; }

/* Aufstiegs-Banner (eigenes, golden) */
.tama-aufstieg-banner {
  position: fixed;
  top: 18%;
  left: 50%;
  transform: translate(-50%, -120%) scale(0.85);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 22px 30px;
  background: linear-gradient(135deg, rgba(255,200,87,0.15), var(--flaeche));
  border: 2px solid var(--gold);
  box-shadow: 0 0 60px rgba(255,200,87,0.3), 0 16px 60px rgba(0,0,0,0.6);
  z-index: 300;
  pointer-events: none;
  opacity: 0;
  transition: transform 400ms cubic-bezier(.34,1.56,.64,1), opacity 280ms ease;
  text-align: center;
}
.tama-aufstieg-banner.rein { transform: translate(-50%, 0) scale(1); opacity: 1; }
.tama-aufstieg-banner.raus { transform: translate(-50%, -40%) scale(0.9); opacity: 0; }
.tab-emoji { font-size: 3rem; line-height: 1; filter: drop-shadow(0 0 20px var(--gold)); }
.tab-titel  {
  font-family: var(--schrift-display); font-weight: 800;
  font-size: 1.6rem; letter-spacing: -0.02em;
  background: linear-gradient(90deg, var(--gold), var(--akzent));
  -webkit-background-clip: text; background-clip: text;
  color: transparent;
}
.tab-detail { font-family: var(--schrift-mono); font-size: 0.78rem; color: var(--text-dim); letter-spacing: 0.06em; }

@media (max-width: 540px) {
  .tama-figur { font-size: 3.6rem; }
  .tama-bubble { font-size: 0.86rem; max-width: 240px; }
}

/* =================== TAMA-INTRO (Onboarding) =================== */
.tama-intro {
  position: fixed; inset: 0;
  background: rgba(10,14,28,0.92);
  backdrop-filter: blur(8px);
  display: flex; align-items: center; justify-content: center;
  z-index: 800;
  animation: ti-fade 280ms ease;
}
.tama-intro.weg { opacity: 0; transition: opacity 380ms ease; }
@keyframes ti-fade { from { opacity: 0; } to { opacity: 1; } }

.ti-inhalt {
  position: relative;
  background: var(--flaeche);
  border: 1px solid var(--rand-glow);
  padding: 38px 32px 28px;
  max-width: 460px;
  width: min(440px, 92vw);
  text-align: center;
  box-shadow: 0 0 80px rgba(61,249,197,0.12), 0 24px 80px rgba(0,0,0,0.5);
}
.ti-inhalt::before {
  content: '';
  position: absolute; top: 0; left: 0; right: 0; height: 3px;
  background: linear-gradient(90deg, var(--akzent-2), var(--akzent), var(--gold));
  box-shadow: 0 0 24px rgba(197,240,74,0.4);
}
.ti-skip {
  position: absolute; top: 10px; right: 10px;
  background: transparent; border: 1px solid var(--rand);
  color: var(--text-dim);
  width: 30px; height: 30px;
  font-size: 1.2rem; line-height: 1;
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.ti-skip:hover { color: var(--warn); border-color: var(--warn); }

.ti-stage {
  display: flex; flex-direction: column; align-items: center; gap: 12px;
  animation: ti-stage-rein 360ms cubic-bezier(.34,1.56,.64,1);
}
.ti-stage[hidden] { display: none !important; }
@keyframes ti-stage-rein {
  0%   { opacity: 0; transform: translateY(15px) scale(0.92); }
  100% { opacity: 1; transform: translateY(0) scale(1); }
}
.ti-emoji { font-size: 3.4rem; line-height: 1; filter: drop-shadow(0 0 24px rgba(197,240,74,0.4)); }
.ti-stage h2 {
  font-family: var(--schrift-display);
  font-weight: 800;
  font-size: 1.7rem;
  letter-spacing: -0.02em;
  font-variation-settings: "opsz" 96;
}
.ti-stage p {
  font-family: var(--schrift-mono);
  font-size: 0.92rem;
  color: var(--text-dim);
  line-height: 1.55;
}
.ti-stage strong { color: var(--akzent); }
.ti-weiter, .ti-fertig {
  margin-top: 10px;
  padding: 12px 28px;
  background: var(--akzent);
  border: 1px solid var(--akzent);
  color: var(--bg);
  font-family: var(--schrift-mono);
  font-weight: 700;
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.ti-weiter:hover, .ti-fertig:hover { transform: translate(-2px,-2px); box-shadow: 4px 4px 0 var(--rand-glow); }
.ti-fertig { background: linear-gradient(90deg, var(--akzent), var(--gold)); }

.ti-punkte {
  display: flex; gap: 6px; justify-content: center;
  margin-top: 22px;
}
.ti-punkt {
  width: 6px; height: 6px; border-radius: 50%;
  background: var(--rand);
  transition: all 220ms var(--ease);
}
.ti-punkt.aktiv { background: var(--akzent); box-shadow: 0 0 8px var(--akzent); }

/* =================== SPRACHEINGABE-Mikro =================== */
.tama-frage-form { grid-template-columns: auto 1fr auto; gap: 6px; }
.tama-mikro {
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text-dim);
  font-size: 1.1rem;
  padding: 0 14px;
  cursor: pointer;
  transition: all 200ms var(--ease);
}
.tama-mikro:hover { color: var(--akzent); border-color: var(--akzent); }
.tama-mikro.lauschen {
  border-color: var(--warn);
  color: var(--warn);
  animation: mikro-puls 1s ease-in-out infinite;
}
@keyframes mikro-puls {
  0%,100% { box-shadow: 0 0 0 0 rgba(255,61,139,0.5); }
  50%     { box-shadow: 0 0 0 8px rgba(255,61,139,0); }
}

/* =================== ADMIN: Tamagotchi-Chat =================== */
.tama-chat-liste {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}
.tama-chat-eintrag {
  background: var(--flaeche);
  border: 1px solid var(--rand);
  border-left: 3px solid var(--akzent-2);
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.tama-chat-meta {
  display: flex; gap: 12px; align-items: center;
  font-family: var(--schrift-mono);
  font-size: 0.7rem;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.tama-chat-stufe {
  background: var(--bg-tiefer);
  border: 1px solid var(--akzent-2);
  color: var(--akzent-2);
  padding: 2px 8px;
  font-weight: 700;
}
.tama-chat-frage {
  font-family: var(--schrift-mono);
  font-size: 0.9rem;
  color: var(--text);
  padding-left: 14px;
  border-left: 2px solid var(--rand);
}
.tama-chat-frage::before { content: '› '; color: var(--muted); }
.tama-chat-antwort {
  font-family: var(--schrift-display);
  font-size: 1rem;
  color: var(--akzent-2);
  font-weight: 600;
}

/* Intro-Vollausbau-Vorschau */
.ti-vorschau {
  list-style: none;
  margin: 12px 0 14px;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
  text-align: left;
  max-width: 380px;
}
.ti-vorschau li {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: 10px;
  align-items: center;
  background: var(--bg-tiefer);
  border: 1px solid var(--rand);
  border-left: 2px solid var(--akzent-2);
  padding: 8px 10px;
  font-family: var(--schrift-mono);
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--text-dim);
}
.ti-vorschau .tv-emoji { font-size: 1.05rem; text-align: center; }
.ti-vorschau strong { color: var(--text); font-weight: 700; }
.ti-vorschau li:nth-child(1) { border-left-color: var(--akzent); }
.ti-vorschau li:nth-child(2) { border-left-color: var(--akzent-2); }
.ti-vorschau li:nth-child(3) { border-left-color: var(--gold); }
.ti-vorschau li:nth-child(4) { border-left-color: #ff9f1c; }
.ti-vorschau li:nth-child(5) { border-left-color: var(--warn); }

.ti-stand {
  font-family: var(--schrift-mono);
  font-size: 0.7rem !important;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--muted) !important;
}
.ti-stand strong {
  color: var(--akzent) !important;
  font-size: 1.05rem;
  letter-spacing: -0.01em;
  text-transform: none;
}

/* Knirps-Name Eingabe im Intro */
#ti-name-input {
  font-family: var(--schrift-display);
  font-size: 1.2rem;
  font-weight: 600;
  text-align: center;
  background: var(--bg);
  border: 1px solid var(--rand);
  color: var(--text);
  padding: 12px 18px;
  outline: none;
  width: 100%;
  max-width: 280px;
  margin: 12px auto 0;
  letter-spacing: -0.01em;
  transition: border-color 200ms var(--ease);
}
#ti-name-input:focus { border-color: var(--akzent-2); box-shadow: 0 0 0 1px var(--akzent-2); }

.tama-floater {
  position: fixed;
  transform: translate(-50%, 0);
  font-family: var(--schrift-mono);
  font-weight: 800;
  font-size: 1.1rem;
  color: var(--akzent);
  text-shadow: 0 0 12px rgba(197,240,74,0.6);
  pointer-events: none;
  z-index: 200;
  animation: floater 1.1s cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes floater {
  0%   { opacity: 0; transform: translate(-50%, 0) scale(0.7); }
  20%  { opacity: 1; transform: translate(-50%, -8px) scale(1.1); }
  100% { opacity: 0; transform: translate(-50%, -50px) scale(1); }
}

/* =================== TAMA-ANIM-PLUS =================== */

/* Idle: Fritz blinzelt + hopst alle 6 sek kurz */
.tama-figur {
  animation: tama-idle 6s ease-in-out infinite;
  transform-origin: 50% 100%;
}
@keyframes tama-idle {
  0%, 92%, 100% { transform: scale(1) translateY(0) rotate(0); }
  94%           { transform: scale(0.96) translateY(0) rotate(-2deg); }
  96%           { transform: scale(1.05) translateY(-12px) rotate(2deg); }
  98%           { transform: scale(1) translateY(-2px) rotate(-1deg); }
}

/* Reaktion bei Klick — wackeln */
.tama-figur.wackelt {
  animation: tama-wackel 600ms cubic-bezier(.36,.07,.19,.97);
}
@keyframes tama-wackel {
  0%, 100% { transform: rotate(0); }
  10%, 50% { transform: rotate(-12deg) scale(1.08); }
  30%, 70% { transform: rotate(12deg) scale(1.08); }
  90%      { transform: rotate(-4deg) scale(1.04); }
}

/* XP-Gewinn-Hopser */
.tama-figur.hop {
  animation: tama-hop 700ms cubic-bezier(.34,1.56,.64,1);
}
@keyframes tama-hop {
  0%   { transform: translateY(0) scale(1); }
  20%  { transform: translateY(-30px) scale(1.15); }
  40%  { transform: translateY(0) scale(0.92); }
  60%  { transform: translateY(-12px) scale(1.05); }
  100% { transform: translateY(0) scale(1); }
}

/* Sterne-Burst um Fritz wenn er XP bekommt */
.tama-stern {
  position: absolute;
  font-size: 1.2rem;
  pointer-events: none;
  z-index: 10;
  animation: stern-flieg 900ms cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes stern-flieg {
  0%   { opacity: 0; transform: translate(0, 0) scale(0.4) rotate(0); }
  20%  { opacity: 1; }
  100% { opacity: 0; transform: var(--ziel) scale(1) rotate(360deg); }
}

/* Sprechblase: typing-cursor effekt während des Renderns */
.tama-bubble.tippt::after {
  content: '▍';
  margin-left: 2px;
  animation: cursor-blink 0.8s steps(2, start) infinite;
  color: var(--akzent-2);
}
@keyframes cursor-blink { 50% { opacity: 0; } }

/* Abhak-Animation: bursts vom Häkchen */
.wt-aufgabe.feiert::before {
  content: '';
  position: absolute;
  inset: -8px;
  border: 2px solid var(--art-farbe, var(--akzent));
  pointer-events: none;
  animation: feier-ring 720ms cubic-bezier(.34,1.56,.64,1) forwards;
}
@keyframes feier-ring {
  0%   { transform: scale(0.5); opacity: 0.8; }
  100% { transform: scale(1.4); opacity: 0; }
}

.wt-aufgabe.feiert .wt-check {
  animation: check-pop 480ms cubic-bezier(.34,1.56,.64,1);
}
@keyframes check-pop {
  0%   { transform: scale(0.6); }
  60%  { transform: scale(1.4); }
  100% { transform: scale(1); }
}

/* Floater-Sterne neben +XP */
.xp-stern-mini {
  position: fixed;
  font-size: 0.9rem;
  pointer-events: none;
  z-index: 200;
  animation: xp-stern-float 1100ms cubic-bezier(.2,.8,.2,1) forwards;
}
@keyframes xp-stern-float {
  0%   { opacity: 0; transform: translate(0, 0) scale(0.5) rotate(0); }
  20%  { opacity: 1; }
  100% { opacity: 0; transform: var(--ziel) scale(1.2) rotate(540deg); }
}

/* Gewinner-Glühen wenn Aufgabe abgehakt wird */
.wt-aufgabe {
  position: relative;
  transition: all 240ms cubic-bezier(.34,1.56,.64,1);
}
.wt-aufgabe.feiert {
  animation: aufgabe-pulse 480ms ease-out;
}
@keyframes aufgabe-pulse {
  0%   { box-shadow: 0 0 0 0 rgba(197,240,74,0); }
  40%  { box-shadow: 0 0 0 12px rgba(197,240,74,0.25); transform: scale(1.02); }
  100% { box-shadow: 0 0 0 0 rgba(197,240,74,0); transform: scale(1); }
}

/* Tama-Karte — beim XP-Gewinn kurz pulsieren */
.tama-karte.xp-gewinn::before {
  animation: karte-glow 700ms ease-out;
}
@keyframes karte-glow {
  0%   { box-shadow: 0 0 0 0 rgba(197,240,74,0.6); }
  100% { box-shadow: 0 0 24px 8px rgba(197,240,74,0); }
}

/* Doppel-Timer im Dashboard — laufende Animation lebendiger */
.timer-hero.laeuft .timer-anzeige {
  animation: timer-laeuft 1.4s ease-in-out infinite;
}
@keyframes timer-laeuft {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.02); }
}

/* Dashboard-Karten: subtle Hover-Tilt */
.dash-karte {
  transition: transform 320ms cubic-bezier(.34,1.56,.64,1), border-color 220ms ease, box-shadow 240ms ease;
}
.dash-karte:hover {
  transform: translate(-3px, -3px) rotate(-0.4deg);
}
.dash-karte:active {
  transform: scale(0.97);
}

/* Lekt-Karten: Hover etwas verspielter */
.lekt-karte:hover {
  transform: translate(-3px, -3px) rotate(0.3deg);
}

/* Reduced motion — alles abschalten */
@media (prefers-reduced-motion: reduce) {
  .tama-figur, .tama-figur.wackelt, .tama-figur.hop,
  .timer-hero.laeuft .timer-anzeige,
  .wt-aufgabe.feiert, .wt-aufgabe.feiert::before, .wt-aufgabe.feiert .wt-check,
  .tama-stern, .xp-stern-mini, .tama-karte.xp-gewinn::before {
    animation: none !important;
  }
}
