/* ============================================================
   Kimiko Festival Timetable — Style angelehnt an kimiko-festival.de
   Palette: #161616 bg, #ededed text, #ff4949 accent
   ============================================================ */
:root {
  --bg: #161616;
  --bg-2: #1f1f1f;
  --bg-3: #262626;
  --panel: #1c1c1c;
  --ink: #ededed;
  --ink-dim: #8c8c8c;
  --line: #2e2e2e;
  --line-2: #3a3a3a;
  --accent: #ff4949;
  --accent-soft: #ffeded;
  --picked: #ff4949;
  --going: #ffd54a;
  --food: #f7a440;
  --break: #5dc5e8;
  --custom: #b88dff;
  --row-height: 44px;
  --col-min-width: 200px;
  --topbar-h: 60px;
  --tabs-h: 56px;
  --font-sans: Helvetica, "Helvetica Neue", Arial, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }

html, body {
  margin: 0; padding: 0;
  background: var(--bg); color: var(--ink);
  font-family: var(--font-sans);
  -webkit-text-size-adjust: 100%;
  -webkit-font-smoothing: antialiased;
  /* Native-Feel: kein iOS-Bounce, keine Browser-Scroll-Anker, keine Pull-to-Refresh */
  overscroll-behavior-y: contain;
  overflow-anchor: none;
  max-width: 100vw;
}
/* v28: overflow-x NUR auf body — html muss `visible` bleiben, sonst zwingt die
   CSS-Regel "overflow-x ≠ visible ⇒ overflow-y wird auto" den Browser dazu,
   html UND body zu Scroll-Containern zu machen. Folge auf Desktop-Chrome:
   Wheel-Events übers Content scrollen NICHTS mehr, nur die Scrollbar greift.
   Auf body bleibt overflow-x: clip (besser als hidden — kein scroll-context). */
body {
  overflow-x: clip;
}
html {
  /* iOS: vermeidet, dass die Scroll-Position beim Re-Layout (Tastatur, Adressleiste)
     willkürlich nach oben springt */
  scroll-behavior: auto;
}
body {
  min-height: 100vh;
  padding-bottom: calc(6rem + env(safe-area-inset-bottom, 0));
  padding-top: env(safe-area-inset-top, 0);
  /* iOS PWA: Safe-Area Hintergrund */
  background: var(--bg);
}
/* Im PWA-Standalone-Modus: Top-Notch-Bereich auch dunkel */
@media (display-mode: standalone) {
  body { padding-top: env(safe-area-inset-top, 0); }
  .topbar { padding-top: calc(.65rem + env(safe-area-inset-top, 0)); }
}

[hidden] { display: none !important; }

button {
  font-family: inherit;
  -webkit-tap-highlight-color: rgba(255,73,73,.35);
  touch-action: manipulation;
  user-select: none;
}
/* Mobile-Native: Text-Selection auf interaktiven Elementen aus */
.artist, .slot-band, .poll-opt, .day-tabs button,
.fab, .fab-action, .a-pick-btn, .poll-badge,
.tba-card, .poll-artist-pick, .buf-chip {
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}

a { color: var(--accent); text-decoration: none; }
a:hover { text-decoration: underline; }

/* --- Topbar --- */
.topbar {
  position: sticky; top: 0; z-index: 30;
  display: flex; justify-content: space-between; align-items: center;
  gap: .8rem;
  padding: .65rem 1.2rem;
  height: var(--topbar-h);
  background: var(--bg);
  border-bottom: 1px solid var(--line);
}
.brand { min-width: 0; display: flex; flex-direction: column; justify-content: center; line-height: 1; }
.brand h1 {
  margin: 0;
  font-size: 1.45rem;
  letter-spacing: .03em;
  font-weight: 900;
  color: var(--ink);
  text-transform: uppercase;
  display: flex; align-items: center; gap: .45rem;
  line-height: 1;
}
.brand h1::after {
  content: "";
  display: inline-block;
  width: 9px; height: 9px;
  background: var(--ink-dim);   /* default: offline = grau, kein Blinken */
  border-radius: 50%;
  flex-shrink: 0;
  transition: background-color .2s;
}
body.live-on .brand h1::after {
  background: var(--accent);
  animation: blink 1.8s infinite;
}
@keyframes blink { 0%,49%{opacity:1} 50%,100%{opacity:.2} }
@keyframes slide-up { from { transform: translateY(100%); } to { transform: translateY(0); } }
.brand h1[title]::after {} /* keep selector lightweight */
.brand-sub {
  display: block;
  font-size: .62rem;
  color: var(--ink-dim);
  letter-spacing: .22em;
  text-transform: uppercase;
  margin-top: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.user-area { display: flex; align-items: center; gap: .5rem; flex-shrink: 0; }
.user-area button {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line-2); border-radius: 0;
  padding: .42rem .8rem;
  font-size: .75rem; text-transform: uppercase; letter-spacing: .1em; font-weight: 700;
  cursor: pointer;
  white-space: nowrap;
}
.user-area button:hover { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.user-area .settings-btn {
  width: 2.1rem;
  height: 2.1rem;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: .95rem;
  letter-spacing: 0;
}
.user-area .who {
  color: var(--accent); font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  font-size: .85rem;
  max-width: 8rem; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* --- "Gleich los"-Banner --- */
.now-banner {
  position: sticky; top: var(--topbar-h); z-index: 25;
  background: var(--accent); color: var(--bg);
  padding: .55rem 1.2rem;
  font-size: .85rem; font-weight: 700;
  display: flex; align-items: center; gap: .8rem;
  text-transform: uppercase; letter-spacing: .05em;
}
.now-banner .pulse {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--bg);
  animation: blink 1s infinite;
  flex-shrink: 0;
}
.now-banner-text { flex: 1; min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.now-banner button {
  background: var(--bg); color: var(--accent);
  border: none; padding: .35rem .8rem;
  font-weight: 800; cursor: pointer;
  text-transform: uppercase; font-size: .75rem; letter-spacing: .08em;
}

/* --- Day tabs --- */
.day-tabs {
  display: flex; gap: 0; padding: 0 1.2rem;
  overflow-x: auto;
  border-bottom: 1px solid var(--line);
  background: var(--bg);
  position: sticky; top: var(--topbar-h); z-index: 20;
  height: var(--tabs-h);
}
.day-tabs button {
  background: transparent; color: var(--ink-dim);
  border: none; border-bottom: 3px solid transparent;
  padding: 1rem 1.2rem;
  cursor: pointer; white-space: nowrap;
  font-size: .9rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
}
.day-tabs button:hover { color: var(--ink); }
.day-tabs button.active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}
.day-tabs button .date {
  display: block; font-size: .65rem; color: var(--ink-dim);
  font-weight: 400; letter-spacing: .15em; margin-top: 2px;
}
.day-tabs button.active .date { color: var(--accent); }

/* --- Plan-Bar (Buttons über dem Timetable) --- */
.plan-bar {
  display: flex; flex-wrap: wrap; gap: .5rem; align-items: center;
  padding: 1rem 1.2rem 0;
}
.plan-btn {
  background: transparent; color: var(--ink);
  border: 1px dashed var(--line-2);
  padding: .6rem .9rem;
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .1em;
  cursor: pointer;
}
.plan-btn.slot-btn { color: var(--food); border-color: var(--food); }
.plan-btn.slot-btn:hover { background: rgba(247,164,64,.1); }
.plan-btn.poll-btn { color: var(--accent); border-color: var(--accent); }
.plan-btn.poll-btn:hover { background: rgba(255,73,73,.08); }
.plan-hint {
  font-size: .65rem; color: var(--ink-dim);
  letter-spacing: .04em;
  flex: 1 1 100%;
  margin-top: .2rem;
}

/* --- Polls Bar --- */
.polls-bar {
  padding: 1.2rem 1.2rem 0;
}
.polls-bar h2 {
  margin: 0 0 .6rem; font-size: .85rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .15em; color: var(--ink-dim);
}
.poll-card {
  background: var(--bg-2); border: 1px solid var(--line);
  padding: 1rem 1.1rem; margin-bottom: .8rem;
}
.poll-card.closed {
  border-color: var(--going);
  background: linear-gradient(180deg, rgba(255,213,74,.07), var(--bg-2));
}
.poll-card.closed .poll-q small { color: var(--going); }
.poll-opt.closed { cursor: default; }
.poll-opt.closed:hover { border-color: var(--line); }
.poll-opt.closed:not(.winner) { opacity: .55; }
.poll-opt.winner {
  border-color: var(--going) !important;
  border-width: 2px;
  background: rgba(255,213,74,.08);
}
.poll-opt.winner .opt-fill { background: rgba(255,213,74,.25); }
.poll-opt .opt-crown {
  position: absolute; top: -8px; left: 8px;
  background: var(--going); color: var(--bg);
  font-size: .8rem; padding: 1px 6px;
  z-index: 4;
  border-radius: 0;
}
.poll-card .poll-q {
  font-weight: 800; font-size: 1rem; margin: 0 0 .8rem;
  text-transform: uppercase; letter-spacing: .03em;
}
.poll-card .poll-q small { font-size: .65rem; color: var(--ink-dim); font-weight: 400; text-transform: uppercase; letter-spacing: .1em; display: block; margin-top: 3px; }

.poll-options { display: grid; gap: .5rem; }
.poll-opt {
  display: grid;
  grid-template-columns: 60px 1fr auto;
  gap: .7rem;
  align-items: stretch;
  background: var(--bg-3); border: 1px solid var(--line);
  cursor: pointer; position: relative; overflow: hidden;
  min-height: 64px;
  transition: border-color .15s, transform .08s ease;
}
.poll-opt:hover { border-color: var(--accent); }
.poll-opt.voted { border-color: var(--accent); border-width: 2px; }
.poll-opt .opt-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  background: rgba(255,73,73,.18);
  transition: width .3s ease;
  z-index: 0;
}
.poll-opt .opt-img {
  background-size: cover; background-position: center;
  background-color: var(--bg);
  position: relative; z-index: 1;
}
.poll-opt .opt-icon {
  font-size: 1.6rem;
  display: flex; align-items: center; justify-content: center;
  position: relative; z-index: 1;
}
.poll-opt.kind-food   .opt-icon { background: rgba(247,164,64,.2);   color: var(--food); }
.poll-opt.kind-break  .opt-icon { background: rgba(93,197,232,.2);   color: var(--break); }
.poll-opt.kind-custom .opt-icon { background: rgba(184,141,255,.2);  color: var(--custom); }

.poll-opt .opt-text {
  position: relative; z-index: 1;
  padding: .55rem .2rem;
  display: flex; flex-direction: column; justify-content: center;
  min-width: 0;
}
.poll-opt .opt-label {
  font-weight: 700; font-size: .95rem;
  text-transform: uppercase; letter-spacing: .02em;
  line-height: 1.2;
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.poll-opt .opt-meta {
  font-size: .7rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
  margin-top: 2px;
}
.poll-opt .opt-voters {
  display: flex; flex-wrap: wrap; gap: 3px;
  margin-top: 4px;
}
.poll-opt .opt-voters .v-chip {
  background: rgba(255,73,73,.85); color: #fff;
  font-size: .6rem; font-weight: 700;
  padding: 1px 6px;
  text-transform: uppercase; letter-spacing: .05em;
}
.poll-opt .opt-tally {
  position: relative; z-index: 1;
  padding: .55rem .8rem;
  display: flex; flex-direction: column; align-items: flex-end; justify-content: center;
  font-variant-numeric: tabular-nums;
  border-left: 1px solid var(--line);
}
.poll-opt .opt-count { font-size: 1.1rem; font-weight: 800; }
.poll-opt .opt-pct { font-size: .65rem; color: var(--ink-dim); }
.poll-opt.voted::after {
  content: "✓"; position: absolute; top: 4px; right: 4px;
  background: var(--accent); color: var(--bg);
  width: 18px; height: 18px;
  display: flex; align-items: center; justify-content: center;
  font-size: .8rem; font-weight: 800;
  z-index: 3;
}
/* Mitmachen-Knopf in Polls-Liste */
.poll-opt .opt-join {
  position: absolute; bottom: 4px; right: 4px;
  background: rgba(255,213,74,.18); color: var(--going);
  border: 1px solid var(--going);
  padding: 2px 7px;
  font-size: .58rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .07em;
  cursor: pointer;
  z-index: 4;
}
.poll-opt .opt-join:hover { background: var(--going); color: var(--bg); }
.poll-opt .opt-join.joined { background: var(--going); color: var(--bg); }

.poll-actions { margin-top: .7rem; display: flex; gap: .4rem; flex-wrap: wrap; }
.poll-actions button {
  background: transparent; color: var(--ink-dim);
  border: 1px solid var(--line-2); padding: .3rem .7rem;
  font-size: .68rem; text-transform: uppercase; letter-spacing: .08em; cursor: pointer;
}
.poll-actions button:hover { color: var(--accent); border-color: var(--accent); }

.poll-new-btn {
  background: transparent; color: var(--accent); border: 1px dashed var(--line-2);
  padding: .7rem 1rem; font-size: .8rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; cursor: pointer;
  width: 100%;
  margin-bottom: 1.2rem;
}
.poll-new-btn:hover { border-color: var(--accent); background: rgba(255,73,73,.08); }

/* --- Board --- */
#boardWrap {
  overflow-x: auto; padding: 1rem 1.2rem;
  /* Native: kein Scroll-Anker, kein horizontaler Bounce */
  overflow-anchor: none;
  overscroll-behavior-x: contain;
  /* iOS: GPU-Komposition fürs Smooth Scrolling */
  -webkit-overflow-scrolling: touch;
  scroll-snap-type: none;
}
.board {
  display: grid;
  grid-template-columns: 56px repeat(var(--stage-count, 4), minmax(var(--col-min-width), 1fr));
  position: relative; gap: 0;
  background: var(--bg-2);
  border: 1px solid var(--line);
  min-width: max-content;
}

.board .stage-head, .board .time-head {
  position: sticky; top: 0;
  background: var(--bg-2); z-index: 4;
  border-bottom: 1px solid var(--line);
  padding: .7rem .5rem;
  text-align: center; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em;
  font-size: .8rem;
}
.board .time-head { font-size: .65rem; color: var(--ink-dim); }
.board .stage-head .stage-dot {
  display: inline-block; width: 10px; height: 10px; border-radius: 50%;
  margin-right: .4rem; vertical-align: middle;
}

.board .time-cell {
  font-size: .65rem; color: var(--ink-dim);
  border-right: 1px solid var(--line); border-top: 1px solid var(--line);
  padding: .15rem .35rem; text-align: right;
  height: var(--row-height);
  font-variant-numeric: tabular-nums;
}
.board .stage-col {
  position: relative;
  border-right: 1px solid var(--line);
  border-top: 1px solid var(--line);
}
.board .stage-col:last-child { border-right: none; }
.board .slot-line {
  position: absolute; left: 0; right: 0; height: 1px;
  background: var(--line); opacity: .5;
}

/* --- Artist Block: Bild als Background, Text-Overlay unten --- */
.artist {
  position: absolute; left: 4px; right: 4px;
  background-size: cover; background-position: center;
  background-color: var(--bg-3);
  border: 1px solid var(--line-2);
  cursor: pointer;
  overflow: hidden;
  transition: transform .08s ease, border-color .15s;
  -webkit-tap-highlight-color: rgba(255,73,73,.35);
  touch-action: manipulation;
  z-index: 2;
}
.artist::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg,
    rgba(22,22,22,.25) 0%,
    rgba(22,22,22,.45) 35%,
    rgba(22,22,22,.85) 70%,
    rgba(22,22,22,.97) 100%);
  pointer-events: none;
  z-index: 1;
}
.artist:hover { border-color: var(--accent); }
.artist.picked { border-color: var(--accent); border-width: 2px; }
/* Hauptaktion: Hingehen-Knopf — beschriftet, prominent (statt Mini-Stern) */
.artist .a-pick-btn {
  position: absolute; top: 4px; right: 4px;
  background: rgba(0,0,0,.75); color: #fff;
  border: 1.5px solid rgba(255,255,255,.55);
  font-size: .62rem; font-weight: 800; line-height: 1;
  text-transform: uppercase; letter-spacing: .04em;
  padding: 5px 8px;
  cursor: pointer;
  z-index: 3;
  font-family: inherit;
  white-space: nowrap;
  -webkit-tap-highlight-color: rgba(255,73,73,.4);
  transition: background-color .15s, border-color .15s, transform .08s;
}
.artist .a-pick-btn:hover { background: var(--accent); border-color: var(--accent); }
.artist .a-pick-btn:active { transform: scale(.94); }
.artist.picked .a-pick-btn {
  background: var(--accent); color: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(255,73,73,.35);
}

.artist .a-overlay {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: .45rem .55rem;
  z-index: 2;
  display: flex; flex-direction: column; gap: 3px;
}
.artist .a-name {
  font-weight: 800; font-size: .95rem; line-height: 1.15;
  text-transform: uppercase; letter-spacing: .01em;
  color: #fff;
  text-shadow: 0 1px 4px rgba(0,0,0,.85);
  overflow: hidden; text-overflow: ellipsis;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical;
}
.artist .a-time {
  font-size: .68rem; color: rgba(255,255,255,.8);
  font-variant-numeric: tabular-nums;
  text-shadow: 0 1px 3px rgba(0,0,0,.85);
}
.artist .a-friends {
  display: flex; flex-wrap: wrap; gap: 3px 4px;
  margin-top: 3px;
}
.f-chip {
  background: var(--accent); color: #fff;
  font-size: .6rem; font-weight: 700;
  padding: 1px 6px;
  text-transform: uppercase; letter-spacing: .04em;
  white-space: nowrap;
  max-width: 100%; overflow: hidden; text-overflow: ellipsis;
}
.artist .a-friends .f-chip { background: var(--going); color: var(--bg); }

/* Tier-Akzent (kleiner Streifen oben) */
.artist::after { z-index: 2; }
.artist.tier-small  { box-shadow: inset 0 3px 0 #6fb3ff; }
.artist.tier-medium { box-shadow: inset 0 3px 0 #b88dff; }
.artist.tier-main   { box-shadow: inset 0 3px 0 var(--accent); }

/* Poll-Badge auf Künstler-Block — klickbar zum Abstimmen */
.artist .poll-badge {
  position: absolute; top: 6px; left: 6px;
  z-index: 3;
  background: rgba(22,22,22,.9);
  color: var(--accent); border: 1px solid var(--accent);
  font-size: .6rem; font-weight: 800;
  padding: 2px 6px;
  text-transform: uppercase; letter-spacing: .04em;
  cursor: pointer;
  -webkit-tap-highlight-color: rgba(255,73,73,.5);
}
.artist .poll-badge.inline-vote:hover { background: var(--accent); color: var(--bg); }
.artist .poll-badge.voted {
  background: var(--accent); color: #fff;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px rgba(255,73,73,.3);
}

/* Visueller Hinweis: dieser Block ist Teil einer Poll, aber du hast für 'ne andere Option gestimmt */
.artist.poll-alt {
  outline: 1px dashed rgba(255,73,73,.55);
  outline-offset: -3px;
}
/* Du hast für diesen gestimmt */
.artist.poll-voted {
  box-shadow: inset 0 0 0 2px var(--accent), inset 0 3px 0 var(--accent);
}
/* Geschlossene Poll: Gewinner-Badge */
.artist .poll-badge.winner {
  background: var(--going);
  color: var(--bg);
  border-color: var(--going);
  font-weight: 900;
}

/* "Gleich los"-Glow */
.artist.starting-soon {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 0 20px rgba(255,73,73,.5), inset 0 3px 0 var(--accent);
  animation: pulse-soft 1.8s infinite;
}
@keyframes pulse-soft {
  0%, 100% { box-shadow: 0 0 0 1px var(--accent), 0 0 20px rgba(255,73,73,.4), inset 0 3px 0 var(--accent); }
  50%      { box-shadow: 0 0 0 1px var(--accent), 0 0 30px rgba(255,73,73,.7), inset 0 3px 0 var(--accent); }
}

/* --- Plan-Spalte (rechts neben den Bühnen) --- */
.plan-head {
  background: var(--bg-2);
  color: var(--going) !important;
  display: flex !important; align-items: center; justify-content: space-between;
  gap: .3rem;
  padding: .35rem .45rem !important;
}
.plan-head .ph-label { font-size: .75rem; }
.plan-head .brush-row {
  display: inline-flex; gap: 2px;
}
.plan-head .brush {
  background: var(--bg); color: var(--ink-dim);
  border: 1px solid var(--line-2);
  width: 28px; height: 28px;
  display: flex; align-items: center; justify-content: center;
  font-size: 1rem; padding: 0; cursor: pointer;
  line-height: 1;
}
.plan-head .brush.active { background: var(--bg-3); border-color: var(--going); color: var(--ink); }
.plan-head .brush.kind-food.active   { border-color: var(--food); box-shadow: inset 0 -3px 0 var(--food); }
.plan-head .brush.kind-break.active  { border-color: var(--break); box-shadow: inset 0 -3px 0 var(--break); }
.plan-head .brush.kind-custom.active { border-color: var(--custom); box-shadow: inset 0 -3px 0 var(--custom); }

/* Draft-Band während des Ziehens */
.slot-band.draft {
  opacity: .85;
  border-style: dashed !important;
  animation: draft-pulse 1s infinite;
}
@keyframes draft-pulse {
  0%, 100% { opacity: .85; }
  50%      { opacity: 1; }
}
.plan-col {
  position: relative;
  border-left: 2px solid var(--line);
  background: linear-gradient(180deg, rgba(255,213,74,.025), rgba(255,213,74,.01));
}
.plan-col .lp-hint {
  position: absolute; left: 6px; right: 6px;
  text-align: center;
  font-size: .58rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .1em;
  pointer-events: none;
  opacity: .6;
}
.plan-col.lp-active {
  background: rgba(247,164,64,.12);
}

/* Slots in der Plan-Spalte */
.slot-band {
  position: absolute; left: 3px; right: 3px;
  padding: .3rem .45rem;
  cursor: pointer;
  overflow: hidden;
  display: flex; flex-direction: column; gap: 1px;
  font-size: .68rem;
  border: 1px solid transparent;
  border-left-width: 3px;
  z-index: 2;
}
/* Eigene Slots: prominent gelb */
.slot-band.mine {
  background: rgba(255,213,74,.18);
  border-color: var(--going);
  color: var(--ink);
}
.slot-band.mine.kind-food   { border-left-color: var(--food); }
.slot-band.mine.kind-break  { border-left-color: var(--break); }
.slot-band.mine.kind-custom { border-left-color: var(--custom); }
.slot-band.mine:hover { background: rgba(255,213,74,.26); }
/* Freundes-Slots: stark ausgegraut */
.slot-band.theirs {
  background: rgba(255,255,255,.02);
  border-color: var(--line);
  color: var(--ink-dim);
  opacity: .58;
}
.slot-band.theirs:hover { opacity: 1; background: rgba(255,255,255,.06); }
.slot-band.theirs.kind-food   { border-left-color: rgba(247,164,64,.5); }
.slot-band.theirs.kind-break  { border-left-color: rgba(93,197,232,.5); }
.slot-band.theirs.kind-custom { border-left-color: rgba(184,141,255,.5); }
.slot-band .sb-title {
  font-weight: 700; font-size: .72rem;
  text-transform: uppercase; letter-spacing: .03em;
  line-height: 1.15;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.slot-band .sb-who {
  font-size: .58rem;
  text-transform: uppercase; letter-spacing: .08em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.slot-band.mine .sb-who { color: var(--going); }
.slot-band.theirs .sb-who { color: var(--ink-dim); }
.slot-band .sb-time {
  font-size: .58rem;
  font-variant-numeric: tabular-nums;
  opacity: .85;
}
.slot-band .sb-edit-hint {
  position: absolute; top: 3px; right: 5px;
  font-size: .55rem;
  opacity: .7;
}
/* Edit-Button (✎) für eigene Slots */
.slot-band .sb-edit {
  position: absolute; top: 2px; right: 3px;
  background: rgba(0,0,0,.45); border: none; color: var(--going);
  width: 22px; height: 22px;
  cursor: pointer; font-size: .8rem; padding: 0;
  z-index: 3;
}
.slot-band .sb-edit:hover { background: var(--going); color: var(--bg); }
/* Hint im Band (Mitmachen / Aussteigen) */
.slot-band .sb-hint {
  font-size: .56rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .08em;
  margin-top: 2px;
  opacity: .85;
}
.slot-band.theirs .sb-hint { color: var(--going); }
.slot-band.mine .sb-hint { color: var(--accent); }
/* Selection-Mark (für Poll-Select-Modus auch auf Slots) */
.slot-band .sel-mark {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 34px; height: 34px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: rgba(0,0,0,.65);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1rem;
  z-index: 4; pointer-events: none;
}
.slot-band.sel-on { box-shadow: inset 0 0 0 2px var(--accent); }
.slot-band.sel-on .sel-mark {
  background: var(--accent); border-color: var(--accent);
}

/* Slot-Vote (legacy poll slots) — kleines Band oben in der Plan-Spalte */
.slot-band.vote-legacy {
  border-color: var(--accent); color: var(--ink);
  background: rgba(255,73,73,.1);
}
.slot-band.vote-legacy .sb-title small { font-weight: 400; opacity: .7; }
/* ✋ Mitmachen-Button auf Slot-Bändern (separate Aktion zum Voten) */
.slot-band .sb-join {
  position: absolute; bottom: 3px; right: 3px;
  width: 26px; height: 22px;
  background: rgba(0,0,0,.55); color: var(--going);
  border: 1px solid var(--going);
  cursor: pointer;
  font-size: .8rem; padding: 0;
  z-index: 3;
}
.slot-band .sb-join:hover { background: var(--going); color: var(--bg); }
.slot-band .sb-join.joined { background: var(--going); color: var(--bg); }

/* --- Abstimmungs-Modus: Auswahl direkt im Timetable --- */
.board.poll-select-mode { cursor: crosshair; }
.board.poll-select-mode .artist { cursor: pointer; }
.board.poll-select-mode .artist::before {
  background: linear-gradient(180deg,
    rgba(22,22,22,.45) 0%,
    rgba(22,22,22,.95) 100%);
}
.artist .sel-mark {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 42px; height: 42px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: rgba(0,0,0,.55);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: 1.3rem;
  z-index: 4;
  pointer-events: none;
  text-shadow: 0 1px 4px rgba(0,0,0,.8);
}
.artist.sel-on .sel-mark {
  background: var(--accent); border-color: var(--accent); color: #fff;
}
.artist.sel-on { box-shadow: inset 0 0 0 3px var(--accent), inset 0 3px 0 var(--accent); }

/* Floating Bottom-Bar im Abstimmungs-Modus */
.poll-action-bar {
  position: fixed; left: 0; right: 0; bottom: 0;
  background: var(--bg-2);
  border-top: 2px solid var(--accent);
  padding: .7rem .9rem;
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  gap: .5rem;
  align-items: center;
  z-index: 60;
  box-shadow: 0 -8px 24px rgba(0,0,0,.5);
}
.poll-action-bar .pab-count {
  background: var(--accent); color: var(--bg);
  padding: .35rem .6rem;
  font-weight: 800; font-size: .85rem;
  text-transform: uppercase; letter-spacing: .08em;
  white-space: nowrap;
}
.poll-action-bar input[type="text"] {
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .55rem .7rem;
  font-size: .9rem; font-family: inherit;
  min-width: 0;
}
.poll-action-bar input[type="text"]:focus { outline: none; border-color: var(--accent); }
.poll-action-bar button {
  border: none; cursor: pointer;
  padding: .55rem .9rem;
  font-weight: 800; font-size: .75rem;
  text-transform: uppercase; letter-spacing: .08em;
  white-space: nowrap;
}
.poll-action-bar .pab-cancel { background: transparent; color: var(--ink-dim); border: 1px solid var(--line-2); }
.poll-action-bar .pab-start  { background: var(--accent); color: var(--bg); }
.poll-action-bar .pab-start:disabled { background: var(--bg-3); color: var(--ink-dim); cursor: not-allowed; }
.poll-action-bar .pab-hint {
  grid-column: 1 / -1;
  font-size: .62rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
  margin-top: 2px;
}

/* --- Legend --- */
.legend {
  display: flex; flex-wrap: wrap; gap: .8rem; align-items: center;
  font-size: .7rem; color: var(--ink-dim);
  padding: 0 1.2rem 1rem;
  text-transform: uppercase; letter-spacing: .1em;
}
.tier-dot { display: inline-block; width: 10px; height: 10px; margin-right: .3rem; vertical-align: middle; }
.tier-dot.small  { background: #6fb3ff; }
.tier-dot.medium { background: #b88dff; }
.tier-dot.main   { background: var(--accent); }
.tier-dot.food   { background: var(--food); }
.tier-dot.break  { background: var(--break); }
.tier-dot.custom { background: var(--custom); }
.legend .sep { width: 1px; height: 14px; background: var(--line-2); margin: 0 .3rem; }

/* --- Modal & Sheet --- */
.modal-back, .sheet-back {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.78);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  z-index: 100; padding: 1rem;
}
.modal {
  background: var(--bg-2); border: 1px solid var(--line-2);
  padding: 1.6rem; max-width: 520px; width: 100%;
  display: flex; flex-direction: column; gap: 1rem;
  max-height: 90vh; overflow-y: auto;
}
.modal h2 {
  margin: 0; font-size: 1.4rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .04em;
}
.modal p { margin: 0; color: var(--ink-dim); font-size: .9rem; line-height: 1.4; }
.modal label {
  display: flex; flex-direction: column; gap: .3rem;
  font-size: .68rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .12em; font-weight: 700;
}
.modal input, .modal select, .modal textarea {
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .65rem .75rem; font-size: 1rem;
  font-family: inherit;
}
.modal input:focus, .modal select:focus, .modal textarea:focus {
  outline: none; border-color: var(--accent);
}
.modal .primary, .sheet .pick-btn, .sheet .secondary {
  background: var(--accent); color: var(--bg);
  border: none; padding: .85rem 1rem;
  font-weight: 800; cursor: pointer;
  font-size: .85rem; text-transform: uppercase; letter-spacing: .12em;
}
.modal .primary:hover { background: var(--ink); }
.modal .secondary {
  background: transparent; color: var(--ink); border: 1px solid var(--line-2);
}
.modal .secondary:hover { border-color: var(--accent); color: var(--accent); }
.modal .hint { font-size: .72rem; line-height: 1.4; }

/* --- Poll Modal — neuer Builder --- */
.poll-builder { display: flex; flex-direction: column; gap: 1.1rem; }
.poll-builder .day-chips {
  display: flex; gap: .35rem; flex-wrap: wrap;
}
.poll-builder .day-chip {
  background: var(--bg); color: var(--ink-dim);
  border: 1px solid var(--line-2); padding: .5rem .9rem;
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  cursor: pointer;
}
.poll-builder .day-chip.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }

.poll-tabs {
  display: flex; gap: 0; border-bottom: 1px solid var(--line);
}
.poll-tabs button {
  flex: 1;
  background: transparent; color: var(--ink-dim);
  border: none; border-bottom: 2px solid transparent;
  padding: .7rem .5rem;
  font-size: .75rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .08em;
  cursor: pointer;
}
.poll-tabs button.active { color: var(--ink); border-bottom-color: var(--accent); }

.poll-tab-content { display: none; }
.poll-tab-content.active { display: block; }

.poll-artist-search {
  width: 100%;
  margin-bottom: .7rem;
}
.poll-artist-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: .4rem;
  max-height: 320px; overflow-y: auto;
  padding: 2px;
}
.poll-artist-pick {
  position: relative;
  background: var(--bg-3); border: 1px solid var(--line);
  cursor: pointer; overflow: hidden;
  aspect-ratio: 1/1.1;
  background-size: cover; background-position: center;
  display: flex; flex-direction: column; justify-content: flex-end;
  -webkit-tap-highlight-color: rgba(255,73,73,.35);
  transition: transform .08s ease;
}
.poll-artist-pick::before {
  content: ''; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.9) 100%);
}
.poll-artist-pick .p-name {
  position: relative; z-index: 1;
  padding: .35rem .4rem;
  font-size: .68rem; font-weight: 800; color: #fff;
  text-transform: uppercase; letter-spacing: .02em;
  text-shadow: 0 1px 3px rgba(0,0,0,.9);
  line-height: 1.1;
}
.poll-artist-pick .p-meta {
  position: relative; z-index: 1;
  padding: 0 .4rem .35rem;
  font-size: .58rem; color: rgba(255,255,255,.75);
  text-shadow: 0 1px 3px rgba(0,0,0,.9);
}
.poll-artist-pick.selected {
  border: 2px solid var(--accent);
  transform: scale(.96);
}
.poll-artist-pick.selected::after {
  content: '✓'; position: absolute; top: 4px; right: 4px;
  background: var(--accent); color: var(--bg);
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; z-index: 2;
}

.slot-builder { display: flex; flex-direction: column; gap: .7rem; }
.slot-kind-row { display: flex; gap: .35rem; }
.slot-kind {
  flex: 1;
  background: var(--bg); color: var(--ink-dim);
  border: 1px solid var(--line-2);
  padding: .65rem .4rem;
  font-size: .72rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: .3rem;
}
.slot-kind.active { border-color: var(--accent); color: var(--ink); background: rgba(255,73,73,.08); }
.slot-kind.kind-food.active   { border-color: var(--food); background: rgba(247,164,64,.1); }
.slot-kind.kind-break.active  { border-color: var(--break); background: rgba(93,197,232,.1); }
.slot-kind.kind-custom.active { border-color: var(--custom); background: rgba(184,141,255,.1); }
.slot-time-row { display: flex; gap: .5rem; }
.slot-time-row label { flex: 1; }

.added-options {
  display: flex; flex-direction: column; gap: .35rem;
  margin-top: .3rem;
}
.added-options:empty { display: none; }
.added-options .ao-row {
  display: flex; align-items: center; gap: .5rem;
  background: var(--bg-3); border: 1px solid var(--line);
  padding: .45rem .55rem;
}
.added-options .ao-icon {
  width: 26px; height: 26px;
  display: flex; align-items: center; justify-content: center;
  font-weight: 800; font-size: .9rem;
  flex-shrink: 0;
}
.added-options .ao-icon.kind-artist { background: var(--accent); color: var(--bg); }
.added-options .ao-icon.kind-food   { background: var(--food); color: var(--bg); }
.added-options .ao-icon.kind-break  { background: var(--break); color: var(--bg); }
.added-options .ao-icon.kind-custom { background: var(--custom); color: var(--bg); }
.added-options .ao-label { flex: 1; font-size: .85rem; font-weight: 700; }
.added-options .ao-meta  { font-size: .66rem; color: var(--ink-dim); text-transform: uppercase; letter-spacing: .08em; }
.added-options .ao-rm {
  background: transparent; color: var(--ink-dim); border: none;
  cursor: pointer; font-size: 1.1rem; padding: 0 .3rem;
}
.added-options .ao-rm:hover { color: var(--accent); }

/* --- Slot-Modal (persönlicher Plan-Slot anlegen/editieren) --- */
.slot-modal { gap: .9rem; }
.slot-time-controls {
  display: flex; gap: .6rem;
}
.slot-time-controls .stepper-group {
  flex: 1; display: flex; flex-direction: column; gap: .3rem;
}
.slot-time-controls .stepper-group label {
  font-size: .65rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .1em; font-weight: 700;
}
.time-stepper {
  display: grid; grid-template-columns: 36px 1fr 36px;
  background: var(--bg);
  border: 1px solid var(--line-2);
}
.time-stepper input[type="time"] {
  border: none; background: transparent;
  text-align: center; font-size: 1rem; font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--ink);
  min-width: 0; padding: .55rem .25rem;
}
.time-stepper input[type="time"]:focus { outline: none; background: rgba(255,73,73,.08); }
.step-btn {
  background: var(--bg-3); color: var(--ink);
  border: none; border-right: 1px solid var(--line-2);
  cursor: pointer; font-weight: 800; font-size: 1rem;
  padding: 0;
}
.step-btn:last-child { border-right: none; border-left: 1px solid var(--line-2); }
.step-btn:hover { background: var(--accent); color: var(--bg); }
.step-btn:active { transform: scale(.94); }

.snap-toggle {
  flex-direction: row !important; align-items: center; gap: .5rem !important;
  text-transform: none !important; letter-spacing: 0 !important;
  font-size: .78rem !important; color: var(--ink) !important; font-weight: 500 !important;
  padding: .2rem 0; cursor: pointer;
}
.snap-toggle input { width: 18px; height: 18px; accent-color: var(--food); }

.slot-btn-row { display: flex; gap: .5rem; }
.modal .danger {
  background: transparent; color: var(--accent);
  border: 1px solid var(--accent); padding: .85rem 1rem;
  font-weight: 800; cursor: pointer;
  font-size: .85rem; text-transform: uppercase; letter-spacing: .12em;
}
.modal .danger:hover { background: var(--accent); color: var(--bg); }

/* --- Detail-Sheet --- */
.sheet {
  background: var(--bg-2); border: 1px solid var(--line-2);
  max-width: 600px; width: 100%; position: relative;
  max-height: 92vh; overflow-y: auto;
}
.sheet-hero {
  width: 100%; aspect-ratio: 16/10;
  background-size: cover; background-position: center;
  background-color: var(--bg);
  border-bottom: 1px solid var(--line);
  position: relative;
}
.sheet-hero::after {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, transparent 50%, var(--bg-2) 100%);
}
.sheet-body { padding: 1.4rem; }
.sheet-close {
  position: absolute; top: .6rem; right: .8rem;
  background: rgba(0,0,0,.65); color: var(--ink);
  border: none; width: 36px; height: 36px;
  font-size: 1.4rem; cursor: pointer; z-index: 2;
}
.sheet-close:hover { background: var(--accent); color: var(--bg); }
.sheet h3 {
  margin: 0 0 .4rem; font-size: 1.6rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .02em; line-height: 1.1;
}
.sheet .meta {
  color: var(--ink-dim); font-size: .8rem;
  margin-bottom: 1rem; text-transform: uppercase; letter-spacing: .08em;
}
.sheet .info { font-size: .92rem; line-height: 1.5; margin: .8rem 0; }
.sheet .pick-btn {
  margin-top: 1rem; width: 100%;
  background: transparent; color: var(--ink);
  border: 2px solid var(--ink); padding: .9rem 1rem;
}
.sheet .pick-btn:hover { border-color: var(--accent); color: var(--accent); }
.sheet .pick-btn.picked {
  background: var(--accent); color: var(--bg); border-color: var(--accent);
}
.sheet .actions-row {
  display: flex; gap: .5rem; margin-top: .6rem;
}
.sheet .actions-row button {
  flex: 1; padding: .7rem .5rem;
  background: transparent; color: var(--ink-dim);
  border: 1px solid var(--line-2);
  font-weight: 700; cursor: pointer;
  font-size: .7rem; text-transform: uppercase; letter-spacing: .1em;
}
.sheet .actions-row button:hover { color: var(--accent); border-color: var(--accent); }
.sheet .friends-list {
  margin-top: 1rem; padding-top: 1rem;
  border-top: 1px solid var(--line);
  font-size: .85rem; color: var(--ink-dim);
}
.sheet .friends-list strong {
  color: var(--going); text-transform: uppercase; letter-spacing: .08em;
  font-size: .72rem; display: block; margin-bottom: .4rem;
}
.sheet .friends-list .f-chips {
  display: flex; flex-wrap: wrap; gap: 4px;
}

/* --- TBA Section --- */
.tba { padding: 1.5rem 1.2rem 2rem; }
.tba h2 {
  margin: 0 0 .3rem; font-size: .85rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .15em; color: var(--ink-dim);
}
.tba-hint { margin: 0 0 1rem; font-size: .82rem; color: var(--ink-dim); line-height: 1.4; }
.tba-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: .7rem;
}
.tba-card {
  background: var(--bg-2); border: 1px solid var(--line-2);
  cursor: pointer; position: relative; overflow: hidden;
  aspect-ratio: 4/3;
  background-size: cover; background-position: center;
  -webkit-tap-highlight-color: rgba(255,73,73,.35);
  display: flex; flex-direction: column; justify-content: flex-end;
}
.tba-card::before {
  content: ""; position: absolute; inset: 0;
  background: linear-gradient(180deg, rgba(22,22,22,.15) 30%, rgba(22,22,22,.95) 100%);
  pointer-events: none;
  z-index: 1;
}
.tba-card:hover { border-color: var(--accent); }
.tba-card.picked { border-color: var(--accent); border-width: 2px; }
.tba-card .a-pick-btn {
  position: absolute; top: 8px; right: 8px;
  background: rgba(0,0,0,.75); color: #fff;
  border: 1.5px solid rgba(255,255,255,.55);
  font-size: .68rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .04em;
  padding: 6px 10px;
  cursor: pointer;
  z-index: 3;
  font-family: inherit;
  white-space: nowrap;
}
.tba-card .a-pick-btn:hover { background: var(--accent); border-color: var(--accent); }
.tba-card.picked .a-pick-btn {
  background: var(--accent); color: #fff;
  border-color: var(--accent);
}
.tba-card .a-overlay {
  position: relative; z-index: 2;
  padding: .7rem .8rem;
  display: flex; flex-direction: column; gap: 3px;
}
.tba-card .a-name {
  font-weight: 800; font-size: 1rem;
  text-transform: uppercase; letter-spacing: .02em;
  color: #fff;
  line-height: 1.15;
  text-shadow: 0 1px 4px rgba(0,0,0,.85);
}
.tba-card .a-meta {
  font-size: .68rem; color: rgba(255,255,255,.8);
  text-transform: uppercase; letter-spacing: .08em;
  text-shadow: 0 1px 3px rgba(0,0,0,.85);
}
.tba-card .a-friends {
  display: flex; flex-wrap: wrap; gap: 3px; margin-top: 4px;
}
.tba-card .a-friends .f-chip { background: var(--going); color: var(--bg); }

/* --- FAB (nur Mobile) + Action-Sheet --- */
.fab { display: none; }
.fab-sheet { display: none; }
.fab-backdrop { display: none; }
@media (max-width: 720px) {
  .fab {
    display: flex;
    position: fixed; right: 16px; bottom: 16px;
    width: 60px; height: 60px;
    border-radius: 50%;
    background: var(--accent); color: var(--bg);
    border: none;
    font-size: 2.2rem; font-weight: 800; line-height: 1;
    padding: 0;
    box-shadow: 0 6px 20px rgba(255,73,73,.4), 0 4px 12px rgba(0,0,0,.5);
    align-items: center; justify-content: center;
    cursor: pointer;
    z-index: 55;
    transition: transform .18s ease-out, background .15s;
    -webkit-tap-highlight-color: rgba(0,0,0,0);
  }
  .fab:active { transform: scale(.92); }
  .fab.open { transform: rotate(45deg); background: var(--ink); }
  body.poll-select-active .fab { display: none; }

  .fab-backdrop {
    display: block;
    position: fixed; inset: 0;
    background: rgba(0,0,0,.55);
    z-index: 54; opacity: 0; transition: opacity .2s;
    pointer-events: none;
  }
  .fab-backdrop.show { opacity: 1; pointer-events: auto; }

  .fab-sheet {
    display: flex; flex-direction: column;
    position: fixed; left: 0; right: 0; bottom: 0;
    background: var(--bg-2);
    border-top: 1px solid var(--line-2);
    border-radius: 18px 18px 0 0;
    padding: .6rem 1rem 1.4rem;
    z-index: 55;
    transform: translateY(100%);
    transition: transform .25s cubic-bezier(.22,.61,.36,1);
    box-shadow: 0 -8px 32px rgba(0,0,0,.7);
    max-height: 75vh; overflow-y: auto;
    padding-bottom: calc(1.4rem + env(safe-area-inset-bottom, 0));
  }
  .fab-sheet.open { transform: translateY(0); }
  .fab-sheet[hidden] { display: flex; }
  .fab-handle {
    width: 44px; height: 4px;
    background: var(--line-2);
    border-radius: 2px;
    margin: .3rem auto .8rem;
  }
  .fab-title {
    font-weight: 800; text-transform: uppercase; letter-spacing: .1em;
    font-size: .78rem; color: var(--ink-dim);
    margin-bottom: .8rem; text-align: center;
  }
  .fab-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: .55rem;
    margin-bottom: .8rem;
  }
  .fab-action {
    background: var(--bg-3); border: 2px solid var(--line-2);
    padding: 1.1rem .8rem;
    cursor: pointer; color: var(--ink);
    display: flex; flex-direction: column; align-items: center; gap: .35rem;
    min-height: 92px;
    font-family: inherit;
    -webkit-tap-highlight-color: rgba(255,73,73,.4);
  }
  .fab-action:active { transform: scale(.96); }
  .fab-action.kind-food   { border-color: var(--food); }
  .fab-action.kind-break  { border-color: var(--break); }
  .fab-action.kind-custom { border-color: var(--custom); }
  .fab-action.kind-poll   { border-color: var(--accent); }
  .fab-action .fa-icon { font-size: 2rem; line-height: 1; }
  .fab-action .fa-label {
    font-size: .82rem; font-weight: 800;
    text-transform: uppercase; letter-spacing: .06em;
  }
  .fab-close {
    background: transparent; border: 1px solid var(--line-2);
    color: var(--ink-dim);
    padding: .7rem;
    font-size: .75rem; font-weight: 700;
    text-transform: uppercase; letter-spacing: .1em;
    cursor: pointer;
  }
  .fab-close:active { background: var(--bg-3); }
}

/* --- Mobile --- */
@media (max-width: 720px) {
  :root {
    /* Ausgewogen: Bühnen lesbar, Horizontal-Scroll mit Snap erlaubt.
       Für eine "alles auf einen Blick"-Ansicht ist die Listenansicht da. */
    --col-min-width: 96px;
    --row-height: 46px;
    --topbar-h: 54px;
    --tabs-h: 50px;
  }
  /* Mobile-Plan: scrollbar mit Snap an Bühnen-Spalten */
  #boardWrap {
    overflow-x: auto;
    padding: .5rem .5rem;
    scroll-snap-type: x proximity;
    scroll-padding-left: 42px; /* = Zeit-Spalte */
    -webkit-overflow-scrolling: touch;
  }
  .board { min-width: max-content; }
  .stage-col { scroll-snap-align: start; }
  .topbar { padding: .5rem .7rem; gap: .5rem; }
  .brand h1 { font-size: 1.1rem; }
  .brand h1::after { width: 7px; height: 7px; }
  .brand-sub { font-size: .54rem; letter-spacing: .18em; margin-top: 3px; }
  .user-area { gap: .35rem; }
  .user-area button { padding: .3rem .55rem; font-size: .62rem; letter-spacing: .07em; }
  .user-area .who { font-size: .72rem; max-width: 5rem; }

  /* Day-Tabs als richtige Pills auf Handy */
  .day-tabs {
    padding: .6rem .7rem;
    gap: .4rem;
    border-bottom: 1px solid var(--line);
    height: auto;
    scroll-snap-type: x mandatory;
  }
  .day-tabs button {
    padding: .55rem .8rem;
    font-size: .68rem;
    background: var(--bg-3);
    border: 1px solid var(--line-2);
    border-bottom: 1px solid var(--line-2);
    border-radius: 999px;
    scroll-snap-align: center;
    flex-shrink: 0;
  }
  .day-tabs button.active {
    background: var(--accent); color: var(--bg);
    border-color: var(--accent);
  }
  .day-tabs button .date {
    color: rgba(22,22,22,.7);
    font-size: .54rem;
  }
  .day-tabs button:not(.active) .date { color: var(--ink-dim); }
  .day-tabs button.active .date { color: var(--bg); }

  .now-banner { padding: .55rem .8rem; font-size: .78rem; }

  /* Plan-Bar verschwindet auf Handy — wird durch FAB ersetzt */
  .plan-bar { display: none; }

  /* Polls-Bar kompakter */
  .polls-bar { padding: .8rem .7rem 0; }
  .polls-bar h2 { font-size: .72rem; }

  .board .time-cell {
    font-size: .62rem; padding: .15rem .3rem;
    font-variant-numeric: tabular-nums;
  }
  .board .stage-head {
    font-size: .68rem; padding: .45rem .25rem; letter-spacing: .06em;
    line-height: 1.1;
  }
  .board .stage-head .stage-dot { width: 8px; height: 8px; margin-right: .2rem; }

  /* Artist-Karte: lesbar, mit Bild, Name, Zeit, Friends-Chip-Vorschau */
  .artist {
    left: 2px; right: 2px;
    border-width: 1px;
  }
  /* Picked → starker roter Akzent + Glow (auf einen Blick erkennbar) */
  .artist.picked {
    border-color: var(--accent); border-width: 2px;
    box-shadow: inset 0 0 0 1px var(--accent),
                inset 0 3px 0 var(--accent),
                0 0 14px rgba(255,73,73,.3);
  }
  /* Unpicked → dezenter aber lesbar */
  .artist:not(.picked) { opacity: .92; }
  .artist .a-overlay { padding: .35rem .42rem; gap: 2px; }
  .artist .a-name {
    font-size: .78rem; line-height: 1.13;
    letter-spacing: 0;
    -webkit-line-clamp: 2;
  }
  .artist .a-time { font-size: .6rem; }
  /* Hingehen-Knopf: kompakt mit Text */
  .artist .a-pick-btn {
    top: 3px; right: 3px;
    padding: 4px 7px;
    font-size: .55rem;
    border-width: 1.5px;
    min-height: 20px;
    font-weight: 800;
    border-radius: 0;
  }
  /* Friends-Chips kompakter */
  .artist .a-friends { gap: 2px; }
  .artist .a-friends .f-chip {
    font-size: .54rem; padding: 1px 4px;
    line-height: 1.3;
    max-width: 100%;
  }
  .artist .poll-badge { top: 3px; left: 3px; font-size: .52rem; padding: 2px 4px; }

  /* Plan-Spalte: schmaler als die Bühnen-Spalten, aber lesbar */
  .plan-col { background: rgba(255,213,74,.03); }
  .slot-band { left: 2px; right: 2px; padding: .25rem .35rem; }
  .slot-band .sb-title {
    font-size: .62rem; letter-spacing: 0;
    text-transform: none; font-weight: 800;
  }
  .slot-band .sb-time { font-size: .54rem; }
  .slot-band .sb-who  { font-size: .54rem; }
  .slot-band .sb-hint { font-size: .52rem; }
  .slot-band .sb-edit { width: 22px; height: 22px; font-size: .8rem; }
  .slot-band .sb-join { width: 24px; height: 22px; font-size: .85rem; bottom: 2px; right: 2px; }
  .plan-head { padding: .35rem .35rem !important; }
  .plan-head .ph-label { font-size: .65rem; }
  .plan-head .brush-row { gap: 2px; }
  .plan-head .brush { width: 24px; height: 24px; font-size: .85rem; }

  .poll-action-bar {
    grid-template-columns: auto 1fr;
    grid-template-areas: "count title" "cancel slot" "cancel start";
    grid-template-areas: "count title" "actions actions";
    padding: .55rem .6rem;
  }
  .poll-action-bar .pab-count { grid-area: count; }
  .poll-action-bar input[type="text"] { grid-area: title; }
  .poll-action-bar .pab-cancel,
  .poll-action-bar .pab-slot,
  .poll-action-bar .pab-start {
    grid-row: 2;
  }
  .poll-action-bar { grid-template-columns: auto 1fr 1fr 1fr; }
  .poll-action-bar .pab-count, .poll-action-bar input { grid-row: 1; }
  .poll-action-bar input[type="text"] { grid-column: 2 / 5; }
  .artist .sel-mark { width: 34px; height: 34px; font-size: 1.1rem; }

  .legend { font-size: .62rem; padding: 0 .8rem .8rem; gap: .5rem; }
  .tba { padding: 1rem .8rem 2rem; }
  .tba-grid { grid-template-columns: repeat(auto-fill, minmax(160px, 1fr)); gap: .5rem; }

  .modal-back, .sheet-back {
    padding: 0;
    align-items: flex-end;
    background: rgba(0,0,0,.55);
  }
  .modal, .sheet {
    width: 100%; max-width: none;
    max-height: 94vh;
    border-radius: 18px 18px 0 0;
    border-width: 0;
    animation: slide-up .26s cubic-bezier(.22,.61,.36,1);
    padding-bottom: calc(1.2rem + env(safe-area-inset-bottom, 0));
  }
  /* Pull-Indicator */
  .modal::before, .sheet::before {
    content: '';
    display: block;
    width: 44px; height: 4px;
    background: var(--line-2);
    border-radius: 2px;
    margin: -.4rem auto .8rem;
    flex-shrink: 0;
  }
  .modal { padding: 1.2rem; }
  .sheet-hero { aspect-ratio: 16/9; border-radius: 18px 18px 0 0; }
  .sheet h3 { font-size: 1.25rem; }
  .sheet-body { padding: 1.2rem; }

  /* Hingehen-Knopf auf Mobile etwas größer und besser tappbar */
  .artist .a-pick-btn {
    font-size: .62rem;
    padding: 6px 9px;
    top: 5px; right: 5px;
    min-height: 28px;
  }
  .tba-card .a-pick-btn {
    font-size: .72rem; padding: 8px 12px;
    top: 8px; right: 8px;
  }

  /* Poll-Badge: fetter, lesbarer */
  .artist .poll-badge {
    font-size: .56rem;
    padding: 3px 7px;
    top: 5px; left: 5px;
  }
  .artist .poll-badge.voted { font-size: .58rem; }

  .plan-bar { padding: .8rem .8rem 0; }
  .plan-btn { padding: .5rem .7rem; font-size: .68rem; }
  .plan-hint { font-size: .58rem; }

  .slot-time-controls { flex-direction: row; }
  .time-stepper { grid-template-columns: 32px 1fr 32px; }
  .step-btn { font-size: .9rem; }

  .poll-card { padding: .8rem .9rem; }
  .poll-opt { grid-template-columns: 50px 1fr auto; min-height: 56px; }
  .poll-opt .opt-label { font-size: .85rem; }
  .poll-opt .opt-meta { font-size: .62rem; }
  .poll-artist-grid { grid-template-columns: repeat(auto-fill, minmax(100px, 1fr)); max-height: 260px; }
  .poll-artist-pick .p-name { font-size: .62rem; }
}

@media (max-width: 400px) {
  /* Ganz kleine Phones (iPhone SE etc.): minimal kompakter — Scroll bleibt erlaubt */
  :root { --col-min-width: 88px; }
  .artist .a-name { font-size: .72rem; }
  .board .stage-head { font-size: .62rem; padding: .35rem .15rem; }
  .artist .a-pick-btn { font-size: .5rem; padding: 3px 6px; }
}

/* ============================================================
   Buffer-Chips in der Poll-Action-Bar (wann schließt die Poll?)
   ============================================================ */
.poll-action-bar .pab-buffer {
  grid-column: 1 / -1;
  display: flex; flex-wrap: wrap; gap: .35rem; align-items: center;
  font-size: .65rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
  padding-top: .3rem; border-top: 1px solid var(--line);
  margin-top: .3rem;
}
.poll-action-bar .pab-buffer-label { font-weight: 800; color: var(--ink); }
.poll-action-bar .pab-buffer-suffix { color: var(--ink-dim); }
.buf-chip {
  background: var(--bg); color: var(--ink-dim);
  border: 1px solid var(--line-2);
  padding: .25rem .55rem;
  font-size: .68rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  font-family: inherit;
  cursor: pointer;
  transition: background-color .12s, border-color .12s, color .12s, transform .08s;
}
.buf-chip:active { transform: scale(.94); }
.buf-chip.active {
  background: var(--accent); color: var(--bg);
  border-color: var(--accent);
}

/* ============================================================
   Countdown-Animationen (Gamefication)
   ============================================================ */
/* Countdown auf Poll-Card im Titel */
.poll-countdown {
  display: inline-block;
  margin-left: .4rem;
  padding: 1px 7px;
  background: var(--bg-3); color: var(--going);
  font-weight: 800; font-size: .68rem;
  letter-spacing: .04em;
  font-variant-numeric: tabular-nums;
  border: 1px solid var(--going);
  border-radius: 999px;
  vertical-align: middle;
}
/* Kritisch: < 5 min — orange Puls */
.poll-countdown.warn {
  background: rgba(247,164,64,.12);
  color: var(--food);
  border-color: var(--food);
  animation: cd-pulse 1.4s ease-in-out infinite;
}
/* Heiß: < 60s — rot, schneller Puls */
.poll-countdown.hot {
  background: rgba(255,73,73,.18);
  color: var(--accent);
  border-color: var(--accent);
  animation: cd-pulse 0.7s ease-in-out infinite;
  font-size: .78rem;
  padding: 2px 9px;
  box-shadow: 0 0 12px rgba(255,73,73,.4);
}
@keyframes cd-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%      { transform: scale(1.08); opacity: .85; }
}

/* Poll-Card wenn "soon" → leichter Glow am Rand */
.poll-card.soon {
  border-color: var(--food);
  box-shadow: 0 0 0 1px var(--food), 0 0 20px rgba(247,164,64,.2);
}
.poll-card.hot {
  border-color: var(--accent);
  box-shadow: 0 0 0 1px var(--accent), 0 0 24px rgba(255,73,73,.35);
  animation: card-hot 0.9s ease-in-out infinite;
}
@keyframes card-hot {
  0%, 100% { box-shadow: 0 0 0 1px var(--accent), 0 0 24px rgba(255,73,73,.35); }
  50%      { box-shadow: 0 0 0 2px var(--accent), 0 0 36px rgba(255,73,73,.55); }
}

/* ============================================================
   Reveal-Overlay (Sieger-Animation beim Schließen)
   ============================================================ */
.reveal-overlay {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.82);
  backdrop-filter: blur(8px);
  z-index: 150;
  display: flex; align-items: center; justify-content: center;
  padding: 1.5rem;
  animation: ov-in .25s ease-out;
}
@keyframes ov-in { from { opacity: 0; } to { opacity: 1; } }
.reveal-card {
  background: linear-gradient(180deg, var(--bg-2), var(--bg));
  border: 2px solid var(--going);
  max-width: 420px; width: 100%;
  padding: 2.4rem 1.5rem 1.7rem;
  text-align: center;
  position: relative;
  box-shadow: 0 0 0 4px rgba(255,213,74,.18), 0 12px 60px rgba(255,213,74,.35);
  animation: reveal-pop .55s cubic-bezier(.22,1.5,.36,1);
}
@keyframes reveal-pop {
  0%   { transform: scale(.6) rotate(-3deg); opacity: 0; }
  60%  { transform: scale(1.05) rotate(0.5deg); opacity: 1; }
  100% { transform: scale(1) rotate(0); opacity: 1; }
}
.reveal-card::before, .reveal-card::after {
  content: ''; position: absolute;
  width: 10px; height: 10px;
  background: var(--accent);
  border-radius: 50%;
  animation: confetti 2s ease-out infinite;
}
.reveal-card::before { top: 12%; left: 18%; background: var(--going); animation-delay: .1s; }
.reveal-card::after  { top: 22%; right: 16%; background: var(--break); animation-delay: .35s; }
@keyframes confetti {
  0%   { transform: translateY(0) scale(1); opacity: 1; }
  100% { transform: translateY(120px) scale(.3); opacity: 0; }
}
.reveal-crown {
  font-size: 4.5rem; line-height: 1;
  filter: drop-shadow(0 6px 16px rgba(255,213,74,.6));
  animation: crown-spin 1.2s ease-out;
}
@keyframes crown-spin {
  from { transform: rotate(-30deg) scale(.5); opacity: 0; }
  to   { transform: rotate(0) scale(1); opacity: 1; }
}
.reveal-title {
  margin-top: 1rem;
  font-size: 1.6rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .04em;
  color: var(--going);
  line-height: 1.15;
}
.reveal-sub {
  margin-top: .5rem;
  font-size: .85rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .1em;
}
.reveal-close {
  margin-top: 1.6rem;
  background: var(--going); color: var(--bg);
  border: none; padding: .85rem 2rem;
  font-weight: 900; font-size: .85rem;
  text-transform: uppercase; letter-spacing: .15em;
  cursor: pointer;
  font-family: inherit;
}
.reveal-close:active { transform: scale(.96); }

/* ============================================================
   Install-Hint (iOS: "Zum Home-Bildschirm hinzufügen")
   ============================================================ */
.install-hint {
  position: fixed; left: 12px; right: 12px;
  bottom: calc(12px + env(safe-area-inset-bottom, 0));
  background: var(--bg-2);
  border: 1px solid var(--accent);
  border-left: 4px solid var(--accent);
  padding: .8rem 2.4rem .8rem 1rem;
  font-size: .78rem; line-height: 1.4;
  z-index: 70;
  box-shadow: 0 8px 30px rgba(0,0,0,.6);
  animation: hint-in .35s ease-out;
}
/* Auf Mobile: Hint über dem FAB, lässt Platz rechts frei */
@media (max-width: 720px) {
  .install-hint {
    right: calc(12px + 76px); /* FAB-Breite + Abstand */
    bottom: calc(20px + env(safe-area-inset-bottom, 0));
    padding: .65rem 2rem .65rem .85rem;
    font-size: .72rem;
  }
}
@keyframes hint-in {
  from { transform: translateY(20px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.install-hint strong {
  display: block;
  font-size: .68rem; text-transform: uppercase; letter-spacing: .12em;
  color: var(--accent); margin-bottom: 3px;
}
.install-hint b { color: var(--going); font-weight: 800; }
.install-hint-x {
  position: absolute; top: 6px; right: 8px;
  background: transparent; border: none;
  color: var(--ink-dim); font-size: 1.1rem;
  cursor: pointer; padding: 4px 8px;
  line-height: 1;
  font-family: inherit;
}
.install-hint-x:active { color: var(--accent); }
.install-hint-cta {
  display: inline-block; margin-top: .5rem;
  background: var(--accent); color: var(--bg);
  border: none; padding: .45rem .9rem;
  font-size: .72rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .07em;
  cursor: pointer; font-family: inherit;
}
.install-hint-cta:active { transform: scale(.96); }
@media (display-mode: standalone) { .install-hint { display: none !important; } }
@media (display-mode: minimal-ui) { .install-hint { display: none !important; } }
body.poll-select-active .install-hint { display: none !important; }

/* User-Einstellungen: Installation + Erinnerungen */
.settings-modal {
  width: min(680px, calc(100vw - 1.4rem));
}
.settings-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .8rem;
}
.settings-card {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .85rem;
  display: flex;
  flex-direction: column;
  gap: .75rem;
  min-width: 0;
}
.settings-card-head {
  display: grid;
  grid-template-columns: 2.1rem 1fr;
  gap: .65rem;
  align-items: start;
}
.settings-card-head strong {
  display: block;
  font-size: .92rem;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.settings-card-head p,
.settings-hint {
  margin: .25rem 0 0;
  color: var(--ink-dim);
  font-size: .72rem;
  line-height: 1.45;
}
.settings-icon {
  width: 2.1rem;
  height: 2.1rem;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--bg-3);
  border: 1px solid var(--line-2);
  color: var(--accent);
  border-radius: 7px;
  font-weight: 900;
}
.settings-primary {
  width: 100%;
  border: none;
  border-radius: 7px;
  background: var(--accent);
  color: var(--bg);
  padding: .68rem .8rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  cursor: pointer;
}
.settings-primary:disabled {
  opacity: .55;
  cursor: default;
  background: var(--bg-3);
  color: var(--ink-dim);
}
.settings-toggle {
  display: flex;
  align-items: center;
  gap: .55rem;
  font-weight: 800;
  font-size: .82rem;
}
.settings-toggle input {
  width: 1.15rem;
  height: 1.15rem;
  accent-color: var(--accent);
}
.settings-field {
  display: flex;
  flex-direction: column;
  gap: .35rem;
  font-size: .72rem;
  color: var(--ink-dim);
  font-weight: 700;
}
.settings-field select {
  width: 100%;
  background: var(--bg);
  color: var(--ink);
  border: 1px solid var(--line-2);
  border-radius: 7px;
  padding: .55rem .65rem;
  font: inherit;
}
@media (max-width: 720px) {
  .settings-modal {
    width: 100vw;
    max-height: 96vh;
    border-radius: 14px 14px 0 0;
  }
  .settings-grid {
    grid-template-columns: 1fr;
  }
}
/* v23: wenn Media-Overlay offen, install-hint + SW-Update-Toast nicht zeigen —
   die ploppen sonst hinter dem Overlay und sehen wie verstecktes Banner aus. */
body.media-overlay-open .install-hint { display: none !important; }
body.media-overlay-open #swUpdateToast { display: none !important; }
/* v28: Body-Scroll hart sperren, solange das Medien-Overlay offen ist.
   Sonst scrollt die Timetable hinter dem Overlay mit, sobald .mo-scroll
   am Ende ist oder das Wheel auf einer nicht-scrollenden Region landet. */
body.media-overlay-open {
  overflow: hidden !important;
  height: 100vh;
}

/* Gamified Reminder-HUD */
.reminder-hud {
  position: fixed;
  left: 50%;
  bottom: calc(1rem + env(safe-area-inset-bottom, 0));
  transform: translateX(-50%);
  z-index: 88;
  width: min(520px, calc(100vw - 1.2rem));
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: .6rem;
  align-items: stretch;
  pointer-events: none;
  animation: rh-in .24s ease-out;
}
.reminder-hud[hidden] { display: none !important; }
.rh-main,
.rh-count {
  pointer-events: auto;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(22,22,22,.94);
  color: var(--ink);
  box-shadow: 0 12px 34px rgba(0,0,0,.5);
}
.rh-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: .16rem;
  text-align: left;
  border-radius: 8px;
  padding: .68rem .78rem .7rem;
  cursor: pointer;
}
.rh-main:hover { border-color: var(--accent); }
.rh-kicker {
  color: var(--accent);
  font-size: .58rem;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .12em;
}
.rh-main strong {
  font-size: .9rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rh-main span[id="reminderHudSub"] {
  color: var(--ink-dim);
  font-size: .68rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.rh-bar {
  height: 3px;
  background: rgba(255,255,255,.09);
  border-radius: 99px;
  overflow: hidden;
  margin-top: .28rem;
}
.rh-bar i {
  display: block;
  height: 100%;
  width: 0;
  background: linear-gradient(90deg, var(--accent), var(--going));
  border-radius: inherit;
  transition: width .45s ease;
}
.rh-count {
  width: 4.4rem;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--going);
  font-size: 1rem;
  font-weight: 950;
  font-variant-numeric: tabular-nums;
}
.reminder-hud.is-now .rh-main,
.reminder-hud.is-now .rh-count {
  border-color: var(--accent);
  animation: rh-pulse .9s ease-in-out infinite alternate;
}
.reminder-hud.is-now .rh-count { color: var(--accent); }
@keyframes rh-in {
  from { transform: translate(-50%, 18px); opacity: 0; }
  to { transform: translate(-50%, 0); opacity: 1; }
}
@keyframes rh-pulse {
  from { box-shadow: 0 12px 34px rgba(0,0,0,.5); }
  to { box-shadow: 0 12px 34px rgba(255,73,73,.35); }
}
.kimiko-confetti {
  position: fixed;
  inset: 0;
  z-index: 130;
  pointer-events: none;
  overflow: hidden;
}
.kimiko-confetti i {
  position: absolute;
  top: 17%;
  width: 8px;
  height: 14px;
  border-radius: 2px;
  background: var(--c);
  opacity: 0;
  transform: translate3d(0,0,0) rotate(0deg);
  animation: confetti-pop 1.7s cubic-bezier(.2,.8,.2,1) forwards;
}
.kimiko-confetti strong {
  position: absolute;
  left: 50%;
  top: 13%;
  transform: translateX(-50%);
  max-width: min(520px, calc(100vw - 2rem));
  padding: .65rem .9rem;
  border-radius: 8px;
  background: var(--accent);
  color: var(--bg);
  font-size: .78rem;
  font-weight: 950;
  text-transform: uppercase;
  letter-spacing: .08em;
  text-align: center;
  box-shadow: 0 12px 34px rgba(0,0,0,.48);
  animation: confetti-badge 2.2s ease forwards;
}
@keyframes confetti-pop {
  0% { opacity: 0; transform: translate3d(0,0,0) rotate(0deg) scale(.6); }
  12% { opacity: 1; }
  100% { opacity: 0; transform: translate3d(var(--dx), var(--dy), 0) rotate(var(--rot)) scale(1); }
}
@keyframes confetti-badge {
  0% { opacity: 0; transform: translate(-50%, -10px) scale(.94); }
  12%, 72% { opacity: 1; transform: translate(-50%, 0) scale(1); }
  100% { opacity: 0; transform: translate(-50%, -8px) scale(.98); }
}
@media (max-width: 720px) {
  .reminder-hud {
    bottom: calc(4.7rem + env(safe-area-inset-bottom, 0));
    grid-template-columns: minmax(0, 1fr) 4rem;
  }
  .rh-main { padding: .62rem .68rem; }
  .rh-main strong { font-size: .82rem; }
  .rh-count { width: 4rem; font-size: .92rem; }
}

/* Service-Worker Update-Toast: sticky unten, prominenter als install-hint,
   damit der User direkt sieht „neue Version, jetzt aktivieren". */
#swUpdateToast {
  position: fixed;
  left: 12px; right: 12px;
  bottom: calc(12px + env(safe-area-inset-bottom, 0));
  z-index: 200;
  background: var(--accent); color: var(--bg);
  padding: .65rem .85rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: .7rem;
  font-size: .78rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em;
  box-shadow: 0 8px 28px rgba(0,0,0,.55);
  animation: hint-in .35s ease-out;
}
#swUpdateToast .swut-text { flex: 1 1 auto; min-width: 0; }
#swUpdateToast .swut-btn {
  background: var(--bg); color: var(--accent);
  border: none; padding: .45rem .9rem;
  font-size: .72rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .07em;
  cursor: pointer; font-family: inherit;
  flex-shrink: 0;
}
#swUpdateToast .swut-btn:active { transform: scale(.95); }

/* ============================================================
   Mobile-Native: weichere Touch-Animationen auf Buttons & Picks
   ============================================================ */
@media (max-width: 720px) {
  .artist:active { transform: scale(.985); }
  .slot-band:active { transform: scale(.985); }
  .poll-opt:active { transform: scale(.99); }
  .tba-card:active { transform: scale(.98); }
  .day-tabs button:active { transform: scale(.95); }
  .a-pick-btn:active { transform: scale(.9); }
  .buf-chip:active { transform: scale(.9); }
  /* Größere Action-Bar wenn Buffer-Chips dabei sind */
  .poll-action-bar .pab-buffer {
    font-size: .56rem; gap: .25rem;
  }
  .buf-chip { padding: .22rem .45rem; font-size: .6rem; }
  /* Reveal-Overlay auf Mobile als Bottom-Sheet */
  .reveal-overlay { align-items: flex-end; padding: 0; }
  .reveal-card {
    max-width: none; width: 100%;
    border-width: 0; border-top: 3px solid var(--going);
    border-radius: 22px 22px 0 0;
    padding: 2rem 1.2rem calc(1.2rem + env(safe-area-inset-bottom, 0));
    animation: reveal-pop-mobile .45s cubic-bezier(.22,1.4,.36,1);
  }
  @keyframes reveal-pop-mobile {
    from { transform: translateY(100%); opacity: 0; }
    to   { transform: translateY(0); opacity: 1; }
  }
  .reveal-title { font-size: 1.3rem; }
}

/* ============================================================
   Sticky-Header darf nicht doppelt rutschen: Z-Index sauber halten
   ============================================================ */
.topbar { will-change: transform; }
.day-tabs { will-change: transform; }
/* Smoothes Layout-Containment fürs Board */
.board { contain: layout style; }
.poll-card { contain: layout style; }

/* ============================================================
   Media-Overlay (Foto/Video-Galerie, Admin-only)
   ============================================================ */
.user-area .media-btn {
  background: transparent;
  color: var(--ink);
  border: 1px solid var(--line-2);
  width: 36px; height: 36px;
  padding: 0;
  font-size: 1.1rem;
  cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
}
.user-area .media-btn:hover { border-color: var(--accent); color: var(--accent); }
.user-area .media-btn .badge {
  position: absolute;
  margin-top: -14px; margin-left: 14px;
  background: var(--accent); color: var(--bg);
  font-size: .55rem; font-weight: 900;
  padding: 1px 5px; border-radius: 999px;
  min-width: 16px; text-align: center;
}

.media-overlay {
  position: fixed; inset: 0;
  background: var(--bg);
  z-index: 95;
  display: grid;
  grid-template-rows: auto 1fr auto;   /* head (sticky) · scroll-container · bulk-bar */
  overflow: hidden;
  animation: media-in .24s ease-out;
}
/* v23: alles unter dem Header scrollt zusammen (Upload + Action-Bar + Filter-Chips + Grid) */
.mo-scroll {
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  display: flex; flex-direction: column;
  min-height: 0;
  /* v28: Scroll-Chaining hart stoppen — Wheel am Grid-Ende soll NICHT
     die Page dahinter scrollen. */
  overscroll-behavior: contain;
}
/* v27: KEIN flex:1 fürs Grid — es soll seine Content-Höhe behalten.
   .mo-scroll ist der einzige Scroller; das Grid wächst nach unten ohne Limit. */
.mo-scroll > .mo-grid { flex: 0 0 auto; }
@keyframes media-in {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ──────────────────────────────────────────────────────────────
   Header v23 — minimal: Titel · Pille · × (Filter/Menü sind in Action-Bar)
   ────────────────────────────────────────────────────────────── */
.mo-head {
  display: grid;
  grid-template-columns: 1fr auto auto;          /* Title | Pille | × */
  gap: .5rem .6rem;
  align-items: center;
  padding: .55rem .8rem;
  padding-top: calc(.55rem + env(safe-area-inset-top, 0));
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  position: relative;                            /* nicht mehr sticky, Action-Bar übernimmt */
  z-index: 6;
  min-width: 0;
}
.mo-title {
  display: flex; align-items: center; gap: .55rem;
  min-width: 0;                                 /* erlaubt ellipsis */
}
.mo-title .mo-emoji { font-size: 1.3rem; flex-shrink: 0; }
.mo-title-text {
  display: flex; flex-direction: column;
  min-width: 0;
}
.mo-title-text strong {
  font-size: .95rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .04em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.mo-title-text .mo-stats {
  font-size: .62rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .06em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  margin-top: 1px;
}
/* Live-Size-Pille: 'N · X MB' — orange wenn Selection, gelb wenn Filter */
.mo-size-pill {
  background: var(--accent); color: var(--bg);
  font-size: .65rem; font-weight: 900;
  padding: 4px 9px;
  text-transform: uppercase; letter-spacing: .06em;
  font-variant-numeric: tabular-nums;
  border-radius: 999px;
  white-space: nowrap;
  flex-shrink: 0;
}
.mo-size-pill[data-mode="filter"] { background: var(--going); color: var(--bg); }

.mo-head-actions {
  display: flex; gap: .3rem;
  flex-shrink: 0;
}
/* Header-Icon-Buttons: 36x36 quadratisch, gleicher Style überall */
.mo-icon-btn {
  background: transparent;
  border: 1px solid var(--line-2); color: var(--ink);
  width: 38px; height: 38px;
  padding: 0; font-size: 1.05rem; line-height: 1;
  cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; justify-content: center;
  position: relative;
  flex-shrink: 0;
  transition: border-color .12s, color .12s, background-color .12s;
}
.mo-icon-btn:hover { border-color: var(--accent); color: var(--accent); }
.mo-icon-btn:active { transform: scale(.94); }
.mo-icon-btn.active { background: var(--accent); border-color: var(--accent); color: var(--bg); }
.mo-icon-close {
  border-color: var(--accent); color: var(--accent);
  font-size: 1.4rem;
}
.mo-icon-close:hover { background: var(--accent); color: var(--bg); }
.moi-dot {
  position: absolute; top: 4px; right: 4px;
  width: 8px; height: 8px;
  background: var(--going);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--bg-2);
}

/* Legacy-Aliasing für alte CSS-Rules die ich nicht überall ersetze */
.mo-actions {
  display: flex; gap: .35rem;
  flex-shrink: 0;
}
.mo-actions button {
  background: transparent;
  border: 1px solid var(--line-2); color: var(--ink);
  width: 36px; height: 36px;
  padding: 0; font-size: 1.05rem;
  cursor: pointer;
  flex-shrink: 0;
}
.mo-actions button:hover { border-color: var(--accent); color: var(--accent); }
.mo-actions .mo-close { font-size: 1.4rem; line-height: 1; }
.mo-actions button:active { transform: scale(.94); }

.mo-upload {
  padding: .8rem 1.2rem 0;
}
.mo-drop {
  display: block; cursor: pointer;
  border: 2px dashed var(--line-2);
  padding: 1rem 1rem;
  transition: border-color .15s, background-color .15s;
  background: var(--bg-2);
}
.mo-drop:hover, .mo-drop.dragging {
  border-color: var(--accent);
  background: rgba(255,73,73,.08);
}
.mo-drop-inner {
  display: flex; align-items: center; gap: 1rem;
}
.mo-drop-icon { font-size: 2rem; line-height: 1; }
.mo-drop-text strong {
  display: block; font-size: .95rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .03em;
}
.mo-drop-text span {
  font-size: .72rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
}
/* ── Sticky Upload-Drawer ───────────────────────────────────────────────── */
.mo-uploads {
  position: fixed;
  left: 0; right: 0; bottom: 0;
  z-index: 1200;
  background: var(--bg-2);
  border-top: 1px solid var(--line-2);
  box-shadow: 0 -8px 24px rgba(0,0,0,.4);
  max-height: 45vh;
  display: flex; flex-direction: column;
  padding-bottom: env(safe-area-inset-bottom);
}
.mo-uploads[hidden] { display: none; }
.mo-uploads.collapsed { display: none; }
.mo-uploads-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .55rem .9rem;
  border-bottom: 1px solid var(--line);
  background: var(--bg-3);
  cursor: pointer;     /* Klick auf Header minimiert */
}
.mo-uploads-head strong {
  font-size: .75rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .06em;
}
.mo-uploads-head-actions { display: flex; gap: .1rem; }
.mo-uploads-min, .mo-uploads-x {
  background: transparent; border: none; color: var(--ink-dim);
  font-size: 1.2rem; line-height: 1; cursor: pointer;
  padding: 0 .55rem;
}
.mo-uploads-x { font-size: 1.4rem; }
.mo-uploads-x:disabled { opacity: .25; cursor: not-allowed; }
.mo-uploads-min:hover, .mo-uploads-x:not(:disabled):hover { color: var(--accent); }

/* Floating-Action-Button: minimierte Upload-Liste */
.mo-uploads-fab {
  position: fixed;
  right: max(1rem, env(safe-area-inset-right, 0));
  bottom: max(1rem, env(safe-area-inset-bottom, 0));
  z-index: 1199;
  width: 64px; height: 64px;
  border-radius: 50%;
  border: none;
  background: var(--bg-2);
  box-shadow: 0 6px 20px rgba(0,0,0,.45);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer; padding: 0;
  font-family: inherit;
  animation: mu-pop .25s ease-out;
}
@keyframes mu-pop { from { transform: scale(.3); opacity: 0; } to { transform: none; opacity: 1; } }
.mo-uploads-fab[hidden] { display: none; }
.mo-uploads-fab .mu-fab-ring {
  position: absolute; inset: 0;
  border-radius: 50%;
  /* CSS-Var --prog 0..360 grad */
  background: conic-gradient(var(--accent) var(--prog, 0deg), var(--line) 0);
  -webkit-mask: radial-gradient(circle, transparent 60%, #000 62%);
          mask: radial-gradient(circle, transparent 60%, #000 62%);
}
.mo-uploads-fab .mu-fab-icon {
  font-size: 1.4rem; line-height: 1;
  position: relative; z-index: 1;
}
.mo-uploads-fab .mu-fab-count {
  position: absolute; top: 2px; right: 2px;
  background: var(--accent); color: var(--bg);
  border-radius: 999px;
  font-size: .6rem; font-weight: 900;
  padding: 1px 6px; min-width: 18px;
  text-align: center;
  z-index: 2;
}
.mo-uploads-fab.done .mu-fab-icon::after {
  /* Wenn alle done: kleines Häkchen */
  content: '';
}
.mo-uploads-fab.err .mu-fab-count { background: var(--accent); }

/* Retry-Button für gescheiterte Rows */
.uu-row .uu-retry {
  background: transparent; border: 1px solid var(--accent);
  color: var(--accent); cursor: pointer;
  font-size: .65rem; font-weight: 700;
  padding: 2px 8px; border-radius: 4px;
  font-family: inherit;
  display: none;
}
.uu-row.err .uu-retry { display: inline-block; }
.uu-row .uu-retry:hover { background: var(--accent); color: var(--bg); }
.mo-uploads-list {
  overflow-y: auto; padding: .3rem 0;
}
.uu-row {
  display: grid;
  grid-template-columns: 1.5rem 1fr auto;
  align-items: center; gap: .55rem;
  padding: .4rem .9rem;
  font-size: .76rem;
  position: relative;
  border-bottom: 1px solid var(--line);
}
.uu-row:last-child { border-bottom: none; }
.uu-row .uu-ico { text-align: center; font-size: .9rem; }
.uu-row .uu-name { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; min-width: 0; }
.uu-row .uu-status {
  font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  color: var(--ink-dim);
}
.uu-row.ok { background: rgba(74,222,128,.06); }
.uu-row.ok .uu-status { color: var(--going); }
.uu-row.err { background: rgba(255,73,73,.08); }
.uu-row.err .uu-status { color: var(--accent); }
.uu-row::after {
  /* Progress-Bar als bottom border */
  content: '';
  position: absolute; left: 0; bottom: 0;
  height: 2px; width: var(--uu-pct, 0%);
  background: var(--accent); transition: width .25s;
}
.uu-row.ok::after  { width: 100%; background: var(--going); }
.uu-row.err::after { width: 100%; background: var(--accent); opacity: .6; }

.mo-filters {
  padding: .55rem 1.2rem;
  display: flex; gap: .35rem; align-items: center;
  overflow-x: auto;
  border-bottom: 1px solid var(--line);
  scrollbar-width: thin;
}
.mo-chip {
  background: var(--bg);
  border: 1px solid var(--line-2);
  color: var(--ink-dim);
  padding: .35rem .75rem;
  font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  cursor: pointer; white-space: nowrap;
  font-family: inherit;
}
.mo-chip:hover { color: var(--ink); border-color: var(--ink-dim); }
.mo-chip.active {
  background: var(--accent); color: var(--bg);
  border-color: var(--accent);
}
.mo-chip-sep {
  width: 1px; height: 22px; background: var(--line-2); margin: 0 .3rem;
  flex-shrink: 0;
}
.mo-select {
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .35rem .55rem;
  font-size: .7rem; font-family: inherit;
  text-transform: uppercase; letter-spacing: .06em;
  cursor: pointer;
  max-width: 140px;
}
.mo-select:focus { outline: none; border-color: var(--accent); }

/* Filter-Buttons im Picker-Sheet-Stil (Künstler / Tag / Person) */
.mo-filter-btn {
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .35rem .7rem;
  font-size: .7rem; font-family: inherit; font-weight: 700;
  text-transform: uppercase; letter-spacing: .06em;
  cursor: pointer; white-space: nowrap;
  max-width: 200px;
  overflow: hidden; text-overflow: ellipsis;
  flex-shrink: 0;
}
.mo-filter-btn:hover { color: var(--accent); border-color: var(--accent); }
.mo-filter-btn.active {
  background: var(--accent); color: var(--bg); border-color: var(--accent);
}

/* Inline-Tag-Chip auf .mo-item (klickbar zum Filtern) */
.mo-item .mo-i-tagchip {
  position: absolute; top: 4px; left: 4px;
  background: rgba(0,0,0,.7); color: #fff;
  font-size: .55rem; font-weight: 700;
  padding: 2px 6px; border-radius: 999px;
  max-width: calc(100% - 50px);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  text-transform: lowercase; letter-spacing: .04em;
  pointer-events: auto; cursor: pointer;
  z-index: 3;
}
.mo-item .mo-i-tagchip:hover { background: var(--accent); }

/* Burst-Badge (Serie) */
.mo-item .mo-i-burst {
  position: absolute; bottom: 4px; left: 4px;
  background: var(--going); color: var(--bg);
  font-size: .5rem; font-weight: 900;
  padding: 1px 5px; border-radius: 2px;
  text-transform: uppercase; letter-spacing: .08em;
  pointer-events: none;
  z-index: 2;
}

/* Selection-Mode: Checkbox auf jeder Kachel */
.mo-item .mo-check {
  position: absolute; top: 4px; right: 4px;
  width: 22px; height: 22px;
  border: 2px solid #fff;
  border-radius: 50%;
  background: rgba(0,0,0,.4);
  display: none;
  align-items: center; justify-content: center;
  font-size: .8rem; color: #fff; line-height: 1;
  pointer-events: none; /* Tap auf Kachel toggled, nicht direkt auf Checkbox */
  z-index: 4;
}
.mo-select-mode .mo-item .mo-check { display: flex; }
.mo-item.selected .mo-check {
  background: var(--going); border-color: var(--going);
}
.mo-item.selected .mo-check::after { content: '✓'; }
.mo-item.selected {
  outline: 3px solid var(--going);
  outline-offset: -3px;
}

/* Picker-Avatar mit Emoji-Tag-Icon */
.pk-av-emoji { font-size: 1.4rem; }

/* Burst-Sektion im Detail (horizontale Strip mit Thumbs der Geschwister) */
.md-burst {
  padding: .55rem .9rem;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
}
.md-burst[hidden] { display: none; }
.md-burst h4 {
  margin: 0 0 .4rem; font-size: .65rem;
  color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
}
.md-burst-row {
  display: flex; gap: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: thin;
}
.md-burst-row .mb-thumb {
  flex: 0 0 auto;
  width: 70px; height: 70px;
  background-size: cover; background-position: center;
  background-color: var(--bg-3);
  border: 2px solid transparent;
  cursor: pointer;
  position: relative;
}
.md-burst-row .mb-thumb:hover { border-color: var(--accent); }
.md-burst-row .mb-thumb.current { border-color: var(--going); }
.md-burst-row .mb-thumb.video::after {
  content: '▶';
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  color: #fff; font-size: .8rem;
  text-shadow: 0 0 4px rgba(0,0,0,.7);
}

/* Tag-Editor im Detail: + Knopf + × auf Tags (nur user-Tags) */
.md-tag-add {
  background: transparent; border: 1px dashed var(--line-2);
  color: var(--ink-dim);
  padding: .25rem .55rem; font-size: .7rem;
  font-family: inherit; cursor: pointer;
  margin-left: .25rem;
}
.md-tag-add:hover { color: var(--accent); border-color: var(--accent); }
.tag-chip .md-tag-x {
  background: transparent; border: none; color: inherit;
  cursor: pointer; padding: 0 0 0 .3rem;
  font-size: .85rem; line-height: 1;
  opacity: .55;
}
.tag-chip .md-tag-x:hover { opacity: 1; color: var(--accent); }
.tag-chip { display: inline-flex; align-items: center; }

.mo-grid {
  padding: .7rem 1rem 6rem;
  /* v27: kein eigener Scroll — wandert über .mo-scroll. Sonst zwei Scroller
     im Stack und das Grid kollabierte bei vielen Items in eine Reihe + Overlap. */
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(min(120px, 100%), 1fr));
  gap: 4px;
  align-content: start;
}
.mo-item {
  position: relative;
  display: block;
  aspect-ratio: 1 / 1;
  min-width: 0;                /* erlaubt grid-shrink unter Content-Größe */
  width: 100%;
  height: auto;
  background: var(--bg-3);
  background-size: cover; background-position: center;
  cursor: pointer; overflow: hidden;
  contain: content;            /* verhindert dass innere absolute-Kinder die Spalt-Höhe sprengen */
  transition: transform .12s;
}
/* Safari/iOS-Fallback: aspect-ratio wird nicht immer respektiert wenn das Grid-Item
   in einem flex/scroll-Container steckt. Fallback: padding-top trick. */
@supports not (aspect-ratio: 1) {
  .mo-item { aspect-ratio: auto; padding-top: 100%; }
  .mo-item > * { position: absolute; }
}
.mo-item:active { transform: scale(.97); }
.mo-item .mo-i-info {
  position: absolute; left: 0; right: 0; bottom: 0;
  padding: .4rem .5rem;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,.85));
  color: #fff;
  font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  line-height: 1.2;
  pointer-events: none;
}
.mo-item .mo-i-artist {
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.mo-item .mo-i-uploader {
  font-size: .55rem; color: rgba(255,255,255,.7);
  font-weight: 500; margin-top: 2px;
}
.mo-item .mo-i-play {
  position: absolute; top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  width: 44px; height: 44px;
  background: rgba(0,0,0,.7);
  border: 2px solid #fff;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  color: #fff; font-size: 1.2rem;
  pointer-events: none;
}
.mo-item .mo-i-duration {
  position: absolute; top: 4px; right: 4px;
  background: rgba(0,0,0,.75); color: #fff;
  font-size: .55rem; font-weight: 700;
  padding: 2px 5px;
  font-variant-numeric: tabular-nums;
}
.mo-item .mo-i-aibadge {
  position: absolute; top: 4px; left: 4px;
  background: var(--going); color: var(--bg);
  font-size: .5rem; font-weight: 900;
  padding: 1px 4px;
  text-transform: uppercase;
}
.mo-item.processing .mo-i-aibadge {
  background: var(--food); color: var(--bg);
}

.mo-empty {
  position: absolute; left: 0; right: 0; top: 200px; bottom: 0;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-start;
  padding: 2rem; text-align: center;
  color: var(--ink-dim);
  pointer-events: none;
}
.mo-empty .me-emoji { font-size: 4rem; opacity: .4; margin-bottom: 1rem; }
.mo-empty h3 { color: var(--ink); margin: 0 0 .4rem; }
.mo-empty p { line-height: 1.5; font-size: .85rem; }

/* === Media-Detail === */
.media-detail {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.95);
  backdrop-filter: blur(8px);
  z-index: 110;
  display: grid;
  grid-template-columns: 1fr 320px;
  animation: media-in .2s ease-out;
}
.md-stage {
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  background: #000;
  position: relative;
}
.md-stage img, .md-stage video {
  max-width: 100%; max-height: 100%;
  object-fit: contain;
  display: block;
}
.md-stage video { width: 100%; height: 100%; }
.md-stage .md-loading {
  position: absolute;
  color: var(--ink-dim); font-size: .85rem;
}
.md-side {
  background: var(--bg-2);
  border-left: 1px solid var(--line);
  padding: 1.2rem 1.2rem;
  padding-top: calc(1.2rem + env(safe-area-inset-top, 0));
  overflow-y: auto;
  position: relative;
}
.md-close {
  position: absolute; top: 8px; right: 8px;
  background: rgba(0,0,0,.7); color: #fff;
  border: none; width: 36px; height: 36px;
  font-size: 1.3rem; cursor: pointer;
  z-index: 2;
}
.md-close:hover { background: var(--accent); }
.md-meta {
  margin-bottom: 1rem;
}
.md-meta .md-row {
  display: grid; grid-template-columns: 90px 1fr; gap: .35rem;
  padding: .35rem 0; border-bottom: 1px solid var(--line);
  font-size: .78rem;
}
.md-meta .md-row dt {
  color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .06em;
  font-size: .65rem; font-weight: 700;
  margin: 0; align-self: center;
}
.md-meta .md-row dd {
  margin: 0; word-break: break-word;
}
.md-meta .md-row.artist dd { color: var(--accent); font-weight: 800; }

/* v24: Act-Karte — prominenter Hinweis ganz oben im Detail wenn ein Künstler
   bzw. Zonen-Typ erkannt wurde. Klickbar → öffnet Künstler-Picker. */
.md-actcard {
  display: grid;
  grid-template-columns: 56px 1fr auto;
  gap: .85rem;
  align-items: center;
  width: 100%;
  background: linear-gradient(135deg, var(--bg-3), var(--bg-2));
  border: 1px solid var(--accent);
  border-left: 4px solid var(--accent);
  padding: .85rem 1rem;
  margin: 0 0 1rem;
  cursor: pointer;
  font-family: inherit;
  text-align: left;
  color: var(--ink);
  transition: background-color .15s, transform .12s;
  box-shadow: 0 4px 12px rgba(255,73,73,.15);
}
.md-actcard:hover { background: linear-gradient(135deg, var(--bg-2), var(--bg-3)); }
.md-actcard:active { transform: scale(.99); }
.md-actcard .mdac-left {
  width: 56px; height: 56px;
  background: var(--accent);
  color: var(--bg);
  display: flex; align-items: center; justify-content: center;
  border-radius: 4px;
  flex-shrink: 0;
}
.md-actcard .mdac-icon { font-size: 1.8rem; }
.md-actcard .mdac-body { min-width: 0; }
.md-actcard .mdac-label {
  font-size: .58rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .12em;
  color: var(--accent);
  margin-bottom: 2px;
}
.md-actcard .mdac-name {
  font-size: 1.05rem; font-weight: 900;
  color: var(--ink);
  text-transform: uppercase; letter-spacing: .03em;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.md-actcard .mdac-sub {
  font-size: .68rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .06em;
  margin-top: 3px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.md-actcard .mdac-right { font-size: .55rem; color: var(--ink-dim); }
/* Varianten: Stand / Außerhalb / Kein Künstler */
.md-actcard--stand {
  border-color: var(--going);
  border-left-color: var(--going);
  box-shadow: 0 4px 12px rgba(255,213,74,.15);
}
.md-actcard--stand .mdac-left { background: var(--going); color: var(--bg); }
.md-actcard--stand .mdac-label { color: var(--going); }
.md-actcard--outside,
.md-actcard--none {
  border-color: var(--line-2);
  border-left-color: var(--ink-dim);
  background: var(--bg-3);
  box-shadow: none;
}
.md-actcard--outside .mdac-left,
.md-actcard--none .mdac-left { background: var(--ink-dim); color: var(--bg); }
.md-actcard--outside .mdac-label,
.md-actcard--none .mdac-label { color: var(--ink-dim); }
.md-actcard--outside .mdac-name,
.md-actcard--none .mdac-name { color: var(--ink-dim); font-size: .85rem; }

.md-tags { margin: 1rem 0; }
.md-tags h4, .md-faces h4 {
  margin: 0 0 .5rem;
  font-size: .65rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .12em; font-weight: 700;
}
.md-tags .tag-chip, .md-faces .face-chip {
  display: inline-block;
  background: var(--bg-3); color: var(--ink);
  padding: 3px 8px; margin: 0 4px 4px 0;
  font-size: .7rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  border: 1px solid var(--line);
}
.md-tags .tag-chip.ai-tag { border-color: var(--break); color: var(--break); }
.md-tags .tag-chip.user-tag { border-color: var(--going); color: var(--going); }
.md-faces .face-chip { border-color: var(--going); color: var(--going); }
.md-faces .face-chip.unknown { color: var(--ink-dim); border-color: var(--line-2); }

.md-actions {
  margin-top: 1rem;
  display: flex; flex-direction: column; gap: .5rem;
}
.md-actions a, .md-actions button {
  padding: .8rem; text-align: center;
  font-weight: 800; font-size: .8rem;
  text-transform: uppercase; letter-spacing: .08em;
  text-decoration: none !important;
  font-family: inherit;
  cursor: pointer; border-radius: 0;
}
.md-actions .md-dl {
  background: var(--bg-3); color: var(--ink);
  border: 1px solid var(--line-2);
}
.md-actions .md-dl:hover { border-color: var(--accent); color: var(--accent); }
.md-actions .md-del {
  background: transparent; color: var(--accent);
  border: 1px solid var(--accent);
}
.md-actions .md-del:hover { background: var(--accent); color: var(--bg); }

/* ──────────────────────────────────────────────────────────────
   v24 — Action-Bar im Kimiko-Stil (uppercase, scharf, equal-width).
   Klare Touch-Targets statt Header-Quetsche. Buttons sind alle gleich
   groß per grid-template-columns: repeat(5, 1fr).
   ────────────────────────────────────────────────────────────── */
.mo-action-bar {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line-2);
  border-bottom: 1px solid var(--line-2);
}
.mab-btn {
  position: relative;
  background: var(--bg-2);
  border: none;
  color: var(--ink);
  display: flex; flex-direction: column; align-items: center;
  justify-content: center;
  gap: 5px;
  padding: .85rem .3rem .7rem;
  cursor: pointer; font-family: inherit;
  font-size: .68rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .08em;
  min-height: 72px;
  transition: background-color .12s, color .12s;
}
.mab-btn:hover { background: var(--bg-3); color: var(--accent); }
/* v31: Refresh-Spin-Animation beim Klick */
.mab-btn.is-spinning .mab-icon { animation: mab-spin .4s ease-out; }
@keyframes mab-spin { from { transform: rotate(0); } to { transform: rotate(360deg); } }
/* v31: fs-Toggle Checkbox — Switch-Style mit erklärendem Sub-Text */
.fs-toggle {
  display: flex; flex-direction: column; gap: .2rem;
  cursor: pointer; user-select: none;
  padding: .35rem 0;
}
.fs-toggle input[type="checkbox"] {
  margin-right: .5rem;
  width: 1.1rem; height: 1.1rem;
  accent-color: var(--accent);
  vertical-align: middle;
}
.fs-toggle-text { font-weight: 700; font-size: .82rem; }
.fs-toggle-hint { font-size: .65rem; color: var(--ink-dim); margin-left: 1.65rem; }
/* v31: Sub-Card im System-Tab für Burst-Reanalyse */
#sysBurstCard { margin-top: .5rem; }
#sysBurstCard .primary {
  background: var(--accent); color: var(--bg);
  border: none; border-radius: 7px;
  padding: .6rem 1rem; font-weight: 800; font-size: .78rem;
  cursor: pointer; width: 100%; margin-top: .6rem;
}
#sysBurstCard .primary:disabled { opacity: .55; cursor: default; background: var(--bg-3); color: var(--ink-dim); }
#sysBurstCard .sys-hint { font-size: .68rem; color: var(--ink-dim); margin: 0 0 .5rem; }
/* v32: Settings-Block im Burst-Card */
.sys-settings {
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: 8px;
  padding: .65rem .75rem;
  margin-bottom: .6rem;
  display: flex; flex-direction: column; gap: .65rem;
}
.sys-setting { display: flex; flex-direction: column; gap: .3rem; cursor: pointer; user-select: none; }
.sys-setting-head { display: flex; justify-content: space-between; align-items: baseline; }
.sys-setting-label { font-weight: 800; font-size: .76rem; }
.sys-setting-val {
  font-variant-numeric: tabular-nums;
  font-weight: 900; font-size: 1rem;
  color: var(--accent);
  background: var(--bg-3); padding: .1rem .45rem; border-radius: 5px;
  min-width: 2.2rem; text-align: center;
}
.sys-setting input[type="range"] {
  width: 100%; accent-color: var(--accent);
  margin: .1rem 0 .15rem;
}
.sys-setting-scale {
  display: flex; justify-content: space-between;
  font-size: .58rem; color: var(--ink-dim);
  margin-top: .1rem;
}
.sys-setting-radios { display: flex; flex-direction: column; gap: .3rem; padding-left: .1rem; }
.sys-setting-radios label {
  font-size: .72rem; font-weight: 600;
  display: flex; align-items: center; gap: .45rem;
  cursor: pointer;
}
.sys-setting-radios input[type="radio"] { accent-color: var(--accent); }
.sys-setting-hint { font-size: .62rem; color: var(--ink-dim); line-height: 1.4; }
.sys-setting-save {
  background: var(--bg-3); color: var(--ink);
  border: 1px solid var(--line); border-radius: 6px;
  padding: .45rem .8rem; font: inherit; font-size: .72rem; font-weight: 700;
  cursor: pointer;
}
.sys-setting-save:not(:disabled) { background: #ffe04a; color: #161616; border-color: #ffe04a; }
.sys-setting-save:disabled { opacity: .5; cursor: default; }
.sys-text-input,
.sys-textarea,
.sys-select {
  width: 100%;
  background: var(--bg);
  color: var(--ink);
  border: 1px solid var(--line-2);
  border-radius: 7px;
  padding: .55rem .65rem;
  font: inherit;
  font-size: .78rem;
}
.sys-textarea {
  min-height: 4.8rem;
  resize: vertical;
  line-height: 1.35;
}
.sys-text-input:focus,
.sys-textarea:focus,
.sys-select:focus {
  outline: 2px solid var(--accent);
  outline-offset: -1px;
}
.sys-pane--notifications .primary {
  background: var(--accent);
  color: var(--bg);
  border: none;
  border-radius: 7px;
  padding: .6rem 1rem;
  font-weight: 800;
  font-size: .78rem;
  cursor: pointer;
  width: 100%;
  margin-top: .35rem;
}
.sys-pane--notifications .primary:disabled {
  opacity: .6;
  cursor: default;
}
.sys-notif-section {
  display: flex;
  flex-direction: column;
  gap: .45rem;
  margin-bottom: .8rem;
}
.sys-notif-section > strong {
  font-size: .72rem;
  text-transform: uppercase;
  letter-spacing: .08em;
  color: var(--ink-dim);
}
.sys-notif-pills {
  display: flex;
  flex-wrap: wrap;
  gap: .35rem;
}
.sys-notif-pill {
  display: inline-flex;
  align-items: center;
  padding: .28rem .5rem;
  border-radius: 6px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.08);
  font-size: .66rem;
  font-weight: 700;
}
.sys-notif-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: .8rem;
  padding: .55rem 0;
  border-top: 1px solid rgba(255,255,255,.06);
}
.sys-notif-row div {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: .18rem;
}
.sys-notif-row strong {
  font-size: .74rem;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sys-notif-row span,
.sys-notif-row em,
.sys-muted {
  font-size: .64rem;
  color: var(--ink-dim);
  font-style: normal;
}
/* v32: Display-Toggle für Best-Markierung */
.sys-display-toggle {
  margin-top: .6rem;
  padding: .55rem .75rem;
  background: var(--bg-2); border: 1px solid var(--line); border-radius: 8px;
  display: grid;
  grid-template-columns: 1.2rem 1fr;
  align-items: center;
  gap: .15rem .5rem;
}
.sys-display-toggle input[type="checkbox"] {
  grid-row: span 2;
  width: 1.1rem; height: 1.1rem; accent-color: var(--accent); margin: 0;
  align-self: start; margin-top: .15rem;
}
.sys-display-toggle span { font-size: .76rem; }
.sys-display-toggle .sys-setting-hint { grid-column: 2; }
/* v32: Stern-Badge fürs Beste-pro-Serie-Foto im Grid.
   Nur sichtbar, wenn der Admin-Toggle <body class="show-best-badge"> setzt.
   So sehen normale User keinen Badge, die KI-Markierung läuft im Hintergrund. */
.mo-i-best {
  position: absolute;
  top: 4px; right: 4px;
  font-size: 1.05rem;
  text-shadow: 0 1px 3px rgba(0,0,0,.7);
  pointer-events: none;
  display: none; /* Default off */
}
body.show-best-badge .mo-i-best { display: block; }
body.show-best-badge .mo-item.is-best-in-burst {
  box-shadow: inset 0 0 0 2px #ffe04a;
}
/* v38: Cluster-Farben — Farbe pro KI-Unterserie innerhalb eines Aufnahme-Bursts.
   --cluster-color wird per JS pro Item gesetzt, sichtbar nur mit body-Klasse.
   Wenn gleichzeitig "Beste" markiert ist, hat der gelbe Innenring Vorrang
   beim BEST-Item und der Cluster-Rahmen liegt außen rum als äußerer Ring. */
body.show-cluster-colors .mo-item.has-cluster-color {
  box-shadow: inset 0 0 0 4px var(--cluster-color, var(--accent));
}
body.show-cluster-colors.show-best-badge .mo-item.has-cluster-color.is-best-in-burst {
  box-shadow:
    inset 0 0 0 2px #ffe04a,
    inset 0 0 0 6px var(--cluster-color, var(--accent));
}
.mab-btn:active { background: var(--bg-3); transform: scale(.97); }
.mab-btn.active { background: var(--accent); color: var(--bg); }
.mab-btn.active:hover { background: var(--accent); color: var(--bg); }
.mab-btn.mab-primary {
  background: var(--bg-3);
  color: var(--accent);
  border-top: 2px solid var(--accent);
}
.mab-btn.mab-primary:hover { background: var(--accent); color: var(--bg); }
.mab-btn.mab-primary.active { background: var(--accent); color: var(--bg); }
.mab-icon {
  font-size: 1.45rem; line-height: 1;
  filter: grayscale(.15);
}
.mab-btn.active .mab-icon,
.mab-btn:hover .mab-icon { filter: grayscale(0); }
.mab-label { line-height: 1.1; text-align: center; }
.mab-dot {
  position: absolute; top: 10px; right: calc(50% - 24px);
  width: 9px; height: 9px;
  background: var(--going);
  border-radius: 50%;
  box-shadow: 0 0 0 2px var(--bg-2);
}
/* Desktop: deutlich präsentere Buttons */
@media (min-width: 721px) {
  .mab-btn {
    min-height: 88px;
    font-size: .78rem;
    padding: 1rem .4rem .85rem;
    gap: 7px;
  }
  .mab-icon { font-size: 1.7rem; }
}

/* Upload-Drop-Zone: nicht mehr sticky — scrollt mit dem Rest mit */
.mo-upload { flex-shrink: 0; }

/* ──────────────────────────────────────────────────────────────
   v22 — Active-Filter-Chips Bar (zwischen Action-Bar und Grid)
   ────────────────────────────────────────────────────────────── */
.mo-active-filters {
  display: flex; align-items: center; gap: .3rem;
  padding: .4rem .7rem;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  overflow-x: auto;
  scrollbar-width: none;
}
.mo-active-filters::-webkit-scrollbar { display: none; }
.maf-chip {
  display: inline-flex; align-items: center; gap: .3rem;
  background: var(--bg-3);
  border: 1px solid var(--line-2);
  padding: 3px 8px 3px 10px;
  font-size: .65rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em;
  color: var(--ink);
  white-space: nowrap;
  cursor: default;
  font-family: inherit;
}
.maf-chip .maf-x {
  background: transparent; border: none;
  color: var(--ink-dim); cursor: pointer;
  font-size: .9rem; line-height: 1;
  padding: 0 0 0 4px;
  font-family: inherit;
}
.maf-chip .maf-x:hover { color: var(--accent); }
.maf-clear {
  background: transparent; border: 1px dashed var(--line-2);
  color: var(--ink-dim);
  padding: 3px 10px;
  font-size: .62rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: .06em;
  font-family: inherit; cursor: pointer;
  white-space: nowrap;
}
.maf-clear:hover { color: var(--accent); border-color: var(--accent); }

/* ──────────────────────────────────────────────────────────────
   v22 — Filter-Sheet (Bottom-Sheet vom Header)
   ────────────────────────────────────────────────────────────── */
.filter-sheet-back {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(4px);
  z-index: 9990;                          /* v23: hoch, garantiert über Media-Overlay z:95 */
  display: flex; align-items: flex-end; justify-content: center;
  animation: fs-back-in .2s ease-out;
}
.filter-sheet-back[hidden] { display: none !important; }
@keyframes fs-back-in { from { opacity: 0; } to { opacity: 1; } }
.filter-sheet {
  width: 100%; max-width: 560px;
  background: var(--bg-2);
  border-top: 2px solid var(--accent);
  max-height: 86vh;
  display: flex; flex-direction: column;
  animation: fs-in .25s ease-out;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@keyframes fs-in {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}
.fs-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1.1rem;
  border-bottom: 1px solid var(--line);
  flex-shrink: 0;
}
.fs-head h3 { margin: 0; font-size: 1rem; }
.fs-x {
  background: transparent; border: none; color: var(--ink-dim);
  font-size: 1.5rem; line-height: 1; cursor: pointer;
  padding: 0 .3rem; font-family: inherit;
}
.fs-x:hover { color: var(--accent); }
.fs-body {
  overflow-y: auto;
  padding: .7rem .9rem 1.2rem;
  display: flex; flex-direction: column; gap: .55rem;
}
.fs-row {
  display: flex; align-items: center; gap: .6rem;
  padding: .55rem 0;
  border-bottom: 1px solid var(--line);
}
.fs-row:last-of-type { border-bottom: none; }
.fs-label {
  font-size: .7rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .07em;
  color: var(--ink-dim);
  flex: 0 0 90px;
}
.fs-chips {
  display: flex; gap: .3rem; flex-wrap: wrap;
}
.fs-chip {
  background: var(--bg-3);
  border: 1px solid var(--line-2);
  color: var(--ink-dim);
  padding: .35rem .7rem;
  font-size: .7rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em;
  cursor: pointer; font-family: inherit;
  white-space: nowrap;
}
.fs-chip.active {
  background: var(--accent); color: var(--bg);
  border-color: var(--accent);
}
/* v28: Treffer-Count am Chip; bei 0 leicht ausgegraut */
.fs-chip-count { opacity: .75; font-weight: 600; margin-left: .15rem; }
.fs-chip.is-empty { opacity: .45; }
/* v28: Multi-Apply mit Live-Count zeigt während Ladens spinner-mäßig */
.pk-multi-apply.is-counting { opacity: .75; font-style: italic; }
/* v28: Testuser anlegen + Löschen */
.sys-create-user {
  display: flex; gap: .4rem; margin-bottom: .9rem;
  padding: .55rem; background: var(--bg-3); border: 1px solid var(--line);
  border-radius: 8px;
}
.sys-create-user input {
  flex: 1; min-width: 0;
  background: var(--bg-2); color: var(--ink);
  border: 1px solid var(--line); border-radius: 6px;
  padding: .45rem .6rem; font: inherit; font-size: .78rem;
}
.sys-create-user input:focus { outline: 2px solid var(--accent); outline-offset: -1px; }
.sys-create-user button {
  background: var(--accent); color: var(--bg);
  border: none; border-radius: 6px;
  padding: .45rem .8rem; font: inherit; font-size: .72rem; font-weight: 800;
  cursor: pointer; white-space: nowrap;
}
.sys-create-user button:disabled { opacity: .55; cursor: default; }
.sys-user-del {
  margin-left: .5rem;
  background: none; border: 1px solid rgba(255,73,73,.4);
  color: #ff8a8a;
  padding: .15rem .4rem; border-radius: 5px;
  font-size: .7rem; cursor: pointer;
}
.sys-user-del:hover { background: rgba(255,73,73,.15); border-color: #ff4949; color: #ff4949; }
.fs-pick-row {
  display: grid;
  grid-template-columns: 28px 1fr 18px;
  gap: .6rem; align-items: center;
  background: var(--bg-3);
  border: 1px solid var(--line);
  padding: .65rem .8rem;
  font-family: inherit; text-align: left;
  cursor: pointer;
  color: var(--ink);
}
.fs-pick-row:hover { border-color: var(--accent); }
.fs-pr-icon { font-size: 1.15rem; }
.fs-pr-text { display: flex; flex-direction: column; min-width: 0; }
.fs-pr-label {
  font-size: .58rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .08em;
  color: var(--ink-dim);
}
.fs-pr-value {
  font-size: .85rem; font-weight: 700; color: var(--ink);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.fs-pr-value.active { color: var(--accent); }
.fs-pr-chev { font-size: 1.1rem; color: var(--ink-dim); justify-self: end; }
.fs-select {
  flex: 1; min-width: 0;
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .5rem .6rem;
  font-size: .8rem; font-family: inherit;
  cursor: pointer;
}
.fs-select:focus { outline: none; border-color: var(--accent); }
.fs-reset {
  margin-top: .6rem;
  background: var(--accent); color: var(--bg);
  border: none;
  padding: .8rem;
  font-size: .75rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .08em;
  cursor: pointer; font-family: inherit;
}
.fs-reset:active { transform: scale(.97); }

/* ──────────────────────────────────────────────────────────────
   v22 — Overflow-Menu (⋮)
   ────────────────────────────────────────────────────────────── */
.mo-menu-back {
  position: fixed; inset: 0;
  background: rgba(0,0,0,.4);
  z-index: 9991;                          /* v23: hoch, über Filter-Sheet wenn beide auf */
  animation: fs-back-in .15s ease-out;
  display: flex; align-items: flex-end;   /* Mobile: Bottom-Sheet, Desktop: Position übersteuert */
  justify-content: center;
}
.mo-menu-back[hidden] { display: none !important; }
.mo-menu {
  width: 100%; max-width: 420px;
  background: var(--bg-2);
  border-top: 2px solid var(--accent);
  box-shadow: 0 -12px 40px rgba(0,0,0,.6);
  display: flex; flex-direction: column;
  animation: fs-in .22s ease-out;
  padding-bottom: env(safe-area-inset-bottom, 0);
}
@media (min-width: 721px) {
  /* Auf Desktop: kompakter Dropdown rechts oben statt Bottom-Sheet */
  .mo-menu-back { display: block; }
  .mo-menu {
    position: absolute;
    top: 64px; right: 14px;
    max-width: 280px;
    border-top: none;
    border: 1px solid var(--line-2);
    box-shadow: 0 12px 40px rgba(0,0,0,.6);
    animation: fs-back-in .15s ease-out;
  }
}
.mo-menu-item {
  display: flex; align-items: center; gap: .7rem;
  background: transparent; border: none;
  color: var(--ink);
  padding: .8rem 1rem;
  font-size: .82rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .04em;
  cursor: pointer; font-family: inherit;
  text-align: left;
  border-bottom: 1px solid var(--line);
}
.mo-menu-item:last-of-type { border-bottom: none; }
.mo-menu-item:hover { background: var(--bg-3); color: var(--accent); }
.mo-menu-item .mmi-icon {
  font-size: 1.1rem; flex-shrink: 0;
  width: 22px; text-align: center;
}
.mo-menu-foot {
  padding: .5rem 1rem;
  background: var(--bg-3);
  border-top: 1px solid var(--line);
  font-size: .58rem; color: var(--ink-dim);
  font-variant-numeric: tabular-nums;
  letter-spacing: .08em;
  text-transform: uppercase;
}

/* ──────────────────────────────────────────────────────────────
   v22 — Bulk-Action-Bar (sticky bottom im Selection-Mode)
   ────────────────────────────────────────────────────────────── */
.mo-bulk-bar {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 1px;
  background: var(--line);
  border-top: 1px solid var(--line-2);
  padding-bottom: env(safe-area-inset-bottom, 0);
  position: relative;
  z-index: 10;
}
.mbb-btn {
  background: var(--bg-2); border: none;
  color: var(--ink);
  display: flex; flex-direction: column; align-items: center;
  gap: 3px;
  padding: .65rem .3rem .55rem;
  cursor: pointer; font-family: inherit;
  font-size: .58rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em;
  min-height: 56px;
}
.mbb-btn:active { background: var(--bg-3); }
.mbb-btn:disabled {
  color: var(--ink-dim); cursor: not-allowed;
  opacity: .55;
}
.mbb-btn.mbb-primary { background: var(--accent); color: var(--bg); }
.mbb-btn.mbb-primary:active { background: #e84040; }
.mbb-icon { font-size: 1.2rem; line-height: 1; }
.mbb-label { line-height: 1.2; text-align: center; }
.mbb-counter {
  display: inline-block;
  background: rgba(0,0,0,.3); color: inherit;
  padding: 0 5px; margin-left: 2px;
  font-variant-numeric: tabular-nums;
  border-radius: 3px;
}
.mbb-primary .mbb-counter { background: rgba(0,0,0,.3); color: var(--bg); }

/* ──────────────────────────────────────────────────────────────
   v22 — Toast-Host (zentriert oben, animiert)
   ────────────────────────────────────────────────────────────── */
.mo-toast-host {
  position: fixed;
  top: calc(70px + env(safe-area-inset-top, 0));
  left: 50%; transform: translateX(-50%);
  z-index: 9999;                          /* v23: über allem inkl. Filter-Sheet */
  display: flex; flex-direction: column;
  gap: .4rem; pointer-events: none;
  width: min(420px, calc(100vw - 24px));
}
.mo-toast {
  pointer-events: auto;
  background: var(--bg-2); color: var(--ink);
  border: 1px solid var(--line-2);
  border-left: 4px solid var(--ink-dim);
  box-shadow: 0 8px 28px rgba(0,0,0,.55);
  padding: .65rem .8rem;
  display: flex; align-items: center; gap: .55rem;
  font-size: .8rem; font-weight: 700;
  animation: toast-in .25s ease-out;
}
@keyframes toast-in {
  from { transform: translateY(-12px); opacity: 0; }
  to   { transform: translateY(0); opacity: 1; }
}
.mo-toast.is-leaving { animation: toast-out .25s ease-in forwards; }
@keyframes toast-out {
  from { transform: translateY(0); opacity: 1; }
  to   { transform: translateY(-12px); opacity: 0; }
}
.mo-toast--info     { border-left-color: var(--ink-dim); }
.mo-toast--success  { border-left-color: var(--going); }
.mo-toast--warning  { border-left-color: var(--break); }
.mo-toast--error    { border-left-color: var(--accent); }
.mo-toast--progress { border-left-color: var(--accent); }
.mo-toast-icon { font-size: 1.15rem; flex-shrink: 0; }
.mo-toast-text { flex: 1; min-width: 0; }
.mo-toast-x {
  background: transparent; border: none; color: var(--ink-dim);
  font-size: 1.1rem; line-height: 1; cursor: pointer;
  padding: 0 .2rem; font-family: inherit;
}
.mo-toast-x:hover { color: var(--accent); }
.mo-toast-spinner {
  width: 14px; height: 14px;
  border: 2px solid var(--ink-dim);
  border-top-color: var(--accent);
  border-radius: 50%;
  animation: spin 1s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ──────────────────────────────────────────────────────────────
   v22 — Detail: prominenter Tag-Edit-Button
   ────────────────────────────────────────────────────────────── */
.md-tag-edit-btn {
  background: var(--bg-3);
  border: 1px solid var(--going) !important;
  color: var(--going);
}
.md-tag-edit-btn:hover {
  background: var(--going); color: var(--bg);
}

/* ──────────────────────────────────────────────────────────────
   v22 — Mobile-Layout-Override
   ────────────────────────────────────────────────────────────── */
@media (max-width: 720px) {
  .media-detail {
    grid-template-columns: 1fr;
    grid-template-rows: 1fr auto;
  }
  .md-side {
    border-left: none; border-top: 1px solid var(--line);
    /* v23: 50vh war zu eng — Tag-Edit-Button + Künstler-Btn + Reanalyze + Delete
       müssen unten gleichzeitig erreichbar sein. 72vh + safe-area. */
    max-height: 72vh;
    padding-bottom: calc(1.2rem + env(safe-area-inset-bottom, 0));
  }
  .md-stage { min-height: 0; }
  .mo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    grid-auto-rows: auto;
    gap: 3px;
    padding: .5rem .5rem 4rem;    /* etwas Luft am Ende für Pull-Up unter Bulk-Bar */
  }
  .mo-head {
    padding: .5rem .65rem;
    padding-top: calc(.5rem + env(safe-area-inset-top, 0));
  }
  .mo-title-text strong { font-size: .9rem; }
  .mo-title-text .mo-stats { font-size: .58rem; }
  .mo-size-pill { font-size: .58rem; padding: 3px 7px; }
  .mo-icon-btn { width: 38px; height: 38px; font-size: 1rem; }
  .mo-icon-close { font-size: 1.4rem; }
  .mo-upload { padding: .55rem .7rem 0; }
  .mo-drop { padding: .7rem; }
  .mo-drop-icon { font-size: 1.5rem; }
  .mo-drop-text strong { font-size: .78rem; }
  .mo-drop-text span { font-size: .6rem; }
  /* Action-Bar Mobile: 5 Buttons à ~20% */
  .mab-btn { font-size: .54rem; padding: .55rem .15rem .45rem; min-height: 56px; }
  .mab-icon { font-size: 1.1rem; }
  .mbb-label { font-size: .55rem; }
  .mbb-icon { font-size: 1.1rem; }
  .fs-label { flex: 0 0 70px; font-size: .65rem; }
  .filter-sheet { max-height: 90vh; }
  .mo-active-filters { padding: .35rem .55rem; }
}
@media (max-width: 400px) {
  .mo-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .mo-icon-btn { width: 34px; height: 34px; font-size: .95rem; }
  .mo-head-actions { gap: .2rem; }
}

/* === Face-Tagging-Overlays auf dem Detail-Bild === */
.md-stage { position: relative; }
.md-canvas {
  position: absolute; inset: 0;
  pointer-events: none;
}
.md-canvas .face-box {
  position: absolute;
  border: 2px solid var(--going);
  box-shadow: 0 0 0 1px rgba(0,0,0,.5);
  pointer-events: auto;
  cursor: pointer;
  transition: border-color .15s, background-color .15s;
  background: rgba(255,213,74,.04);
}
.md-canvas .face-box.known {
  border-color: var(--accent);
  background: rgba(255,73,73,.06);
}
.md-canvas .face-box:hover {
  background: rgba(255,213,74,.18);
}
.md-canvas .face-box.known:hover {
  background: rgba(255,73,73,.2);
}
.md-canvas .face-label {
  position: absolute;
  left: -2px; top: -22px;
  background: var(--going);
  color: var(--bg);
  font-size: .58rem; font-weight: 800;
  padding: 1px 6px;
  text-transform: uppercase; letter-spacing: .04em;
  white-space: nowrap;
}
.md-canvas .face-box.known .face-label { background: var(--accent); color: #fff; }

/* Face-Picker-Dropdown (öffnet sich beim Klick auf bbox) */
.face-picker {
  position: absolute;
  background: var(--bg-2);
  border: 1px solid var(--accent);
  padding: .5rem;
  z-index: 5;
  min-width: 200px;
  box-shadow: 0 8px 24px rgba(0,0,0,.7);
}
.face-picker h4 {
  margin: 0 0 .4rem; font-size: .6rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .1em;
}
.face-picker .fp-list {
  display: flex; flex-direction: column; gap: 2px;
  max-height: 200px; overflow-y: auto;
}
.face-picker .fp-list button,
.face-picker .fp-new {
  background: transparent; border: 1px solid transparent;
  color: var(--ink); text-align: left;
  padding: .35rem .5rem;
  font-size: .8rem; cursor: pointer; font-family: inherit;
}
.face-picker .fp-list button:hover,
.face-picker .fp-new:hover { background: var(--bg-3); border-color: var(--line-2); }
.face-picker .fp-new { color: var(--accent); margin-top: .4rem; border-top: 1px solid var(--line); }
.face-picker .fp-clear {
  margin-top: .3rem;
  background: transparent; border: none; color: var(--ink-dim);
  font-size: .7rem; cursor: pointer;
  text-transform: uppercase; letter-spacing: .06em;
  font-family: inherit;
}

/* Context-Row (act / break / unknown) */
.md-context-row {
  margin: .8rem 0;
  display: flex; gap: .3rem; flex-wrap: wrap;
  align-items: center;
}
.md-context-row .ctx-chip {
  padding: 3px 9px;
  font-size: .65rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .06em;
  border: 1px solid var(--line-2);
  background: var(--bg-3); color: var(--ink-dim);
  cursor: pointer; font-family: inherit;
}
.md-context-row .ctx-chip.active { border-color: var(--accent); color: var(--accent); }
.md-context-row .ctx-chip.act.active   { border-color: var(--accent); background: rgba(255,73,73,.15); color: var(--accent); }
.md-context-row .ctx-chip.break.active { border-color: var(--food);   background: rgba(247,164,64,.15); color: var(--food); }

/* Match-Source-Badge im Meta */
.md-row .match-src {
  font-size: .55rem; padding: 1px 5px;
  background: var(--bg-3); color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
  margin-left: .4rem; vertical-align: middle;
}
.md-row .match-src.gps    { background: var(--break); color: var(--bg); }
.md-row .match-src.burst  { background: var(--custom); color: #fff; }
.md-row .match-src.scene  { background: var(--food); color: var(--bg); }
.md-row .match-src.manual { background: var(--accent); color: #fff; }

/* Artist-Picker-Modal (für manuellen Override) */
.md-artist-btn {
  background: transparent; color: var(--ink);
  border: 1px solid var(--line-2);
}
.md-artist-btn:hover { border-color: var(--accent); color: var(--accent); }

/* === Zonen-Modal === */
.zones-list, .persons-list {
  display: flex; flex-direction: column; gap: .35rem;
  max-height: 200px; overflow-y: auto;
  margin: .3rem 0 1rem;
}
.zones-list:empty::before, .persons-list:empty::before {
  content: 'Noch keine Einträge.';
  color: var(--ink-dim); font-size: .82rem;
  padding: .8rem 0;
}
.zone-row, .person-row {
  display: grid; grid-template-columns: 1fr auto;
  gap: .5rem; align-items: center;
  background: var(--bg-3); border: 1px solid var(--line);
  padding: .5rem .7rem;
  font-size: .78rem;
}
.person-row {
  grid-template-columns: 40px 1fr auto;       /* Avatar + Body + Delete */
}
.pr-avatar {
  width: 40px; height: 40px;
  background-size: cover; background-position: center;
  background-color: var(--bg-2);
  border: 1px solid var(--line);
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 999px;
  flex-shrink: 0;
  color: var(--ink-dim);
  font-size: .7rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .05em;
}
.pr-avatar-init { background-color: var(--bg-2); }
.zone-row .zr-meta, .person-row .pr-meta {
  font-size: .62rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .06em;
  margin-top: 2px;
}
.zone-row .zr-del, .person-row .pr-del {
  background: transparent; border: none; cursor: pointer;
  color: var(--ink-dim); font-size: 1rem;
  padding: 4px 8px; font-family: inherit;
}
.zone-row .zr-del:hover, .person-row .pr-del:hover { color: var(--accent); }

.zones-form { display: flex; flex-direction: column; gap: .6rem; }
.zones-row { display: flex; gap: .5rem; }
.zones-row label { flex: 1; }
.zones-sub {
  margin: .8rem 0 .2rem; font-size: .65rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .12em;
}

/* ============================================================
   View-Toggle (Plan vs Liste) — sauberer Segmented Control
   Der OUTER-Border sitzt auf dem Wrapper. Die Buttons selbst
   sind borderless — nur ein dünner Trennstrich dazwischen.
   So sieht der aktive Button immer komplett umrandet aus,
   egal welcher.
   ============================================================ */
.view-toggle {
  padding: .6rem 1.2rem .25rem;
  display: flex; justify-content: flex-end;
}
.view-toggle::after { content: ''; } /* spacer, falls flex weglässt */
.view-toggle > * {
  display: inline-flex; /* legacy: nicht wichtig */
}
/* Wenn man den Wrapper als Segmented gestalten will: */
.view-toggle {
  /* trick: wrapper-flex enthält die buttons, border kommt aus pseudo-inner-container */
}
.view-toggle .vt-group {
  display: inline-flex;
  border: 1px solid var(--line-2);
  background: var(--bg);
  overflow: hidden;
  /* Kanten klar zeigen */
  border-radius: 4px;
}
.view-toggle button {
  background: transparent;
  color: var(--ink-dim);
  border: none;
  padding: .42rem .9rem;
  font-size: .72rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .08em;
  font-family: inherit;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: .4rem;
  position: relative;
  transition: color .12s, background-color .12s;
}
.view-toggle button + button {
  border-left: 1px solid var(--line-2);
}
.view-toggle button.active {
  background: var(--accent);
  color: var(--bg);
}
.view-toggle button:not(.active):hover { color: var(--ink); }
.view-toggle button:active { transform: scale(.96); }
.view-toggle .vt-icon { font-size: 1rem; line-height: 1; }

/* ============================================================
   List-Modus: chronologische Anzeige aller Künstler ohne
   Horizontal-Scroll. Slots werden mit eingestreut.
   ============================================================ */
#boardWrap.list-mode { overflow-x: hidden; padding: .8rem 0 1.4rem; }
.board.list-mode {
  display: block;
  border: none; background: transparent;
  min-width: 0;
}
.list-head {
  position: sticky;
  top: calc(var(--topbar-h) + var(--tabs-h));
  z-index: 5;
  background: var(--bg);
  padding: .8rem 1.2rem .35rem;
  font-size: 1.05rem; font-weight: 900;
  font-variant-numeric: tabular-nums;
  letter-spacing: .06em;
  color: var(--going);
  border-bottom: 1px solid var(--line);
  text-shadow: 0 1px 2px rgba(0,0,0,.6);
}
/* Now-Indicator: roter Strich in Listenansicht zwischen zwei Items.
   Wenn an einem aktuellen Festival-Tag — zeigt klar wo „jetzt" ist. */
.list-now-bar {
  position: relative;
  height: 2px;
  background: var(--accent);
  margin: 0;
  box-shadow: 0 0 8px rgba(255,73,73,.6);
  z-index: 4;
}
.list-now-bar::before {
  content: ''; position: absolute;
  left: 12px; top: -4px;
  width: 10px; height: 10px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255,73,73,.35);
}
.list-now-bar .lnb-label {
  position: absolute;
  right: 12px; top: -10px;
  background: var(--accent); color: var(--bg);
  padding: 2px 8px;
  font-size: .62rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .08em;
  font-variant-numeric: tabular-nums;
}
/* Now-Indicator: rote Horizontale im Plan-Grid (Board). Spannt über alle
   Stage-Spalten + Plan-Spalte hinweg via grid-column: 1 / -1. */
.board-now-line {
  position: absolute;
  left: 0; right: 0;
  height: 2px;
  background: var(--accent);
  box-shadow: 0 0 12px rgba(255,73,73,.7);
  z-index: 6;
  pointer-events: none;
}
.board-now-line::before {
  content: ''; position: absolute;
  left: 4px; top: -4px;
  width: 10px; height: 10px;
  background: var(--accent);
  border-radius: 50%;
  box-shadow: 0 0 0 3px rgba(255,73,73,.35);
}
.board-now-line .bnl-label {
  position: absolute;
  right: 6px; top: -10px;
  background: var(--accent); color: var(--bg);
  padding: 2px 8px;
  font-size: .6rem; font-weight: 900;
  text-transform: uppercase; letter-spacing: .08em;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
.list-row {
  display: grid;
  grid-template-columns: 4px 56px 1fr auto;
  gap: 0;
  align-items: stretch;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
  position: relative;
  cursor: pointer;
  min-height: 70px;
  overflow: hidden;
  transition: background-color .12s;
}
.list-row:active { background: var(--bg-3); }
.list-row .lr-stage {
  background: var(--ink-dim);
}
.list-row .lr-img {
  background-size: cover; background-position: center;
  background-color: var(--bg-3);
}
.list-row .lr-img.empty {
  display: flex; align-items: center; justify-content: center;
  color: var(--ink-dim); font-size: 1.4rem; font-weight: 900;
  opacity: .35;
}
.list-row .lr-body {
  padding: .55rem .8rem;
  display: flex; flex-direction: column; gap: 3px;
  min-width: 0;
}
.list-row .lr-name {
  font-weight: 800; font-size: 1rem; line-height: 1.15;
  text-transform: uppercase; letter-spacing: .01em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.list-row .lr-meta {
  font-size: .68rem; color: var(--ink-dim);
  text-transform: uppercase; letter-spacing: .08em;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.list-row .lr-friends {
  display: flex; flex-wrap: wrap; gap: 3px;
  margin-top: 3px;
}
.list-row .lr-friends .f-chip {
  background: var(--going); color: var(--bg);
}
.list-row .lr-action {
  display: flex; align-items: center; padding: 0 .7rem;
}
.list-row .a-pick-btn {
  position: static;
  padding: 8px 12px;
  font-size: .68rem;
}
.list-row.picked { background: rgba(255,73,73,.06); }
.list-row.picked .lr-stage { box-shadow: inset 0 0 0 1px var(--accent); }
.list-row.sel-on { background: rgba(255,73,73,.2); box-shadow: inset 0 0 0 2px var(--accent); }
.list-row.starting-soon::after {
  content: ''; position: absolute; left: 0; top: 0; bottom: 0; width: 3px;
  background: var(--accent);
  animation: blink 1s infinite;
}
/* Parallel-Indikator: Klammer-Style mit dünner Linie zum Vor-/Nachfolger */
.list-row.parallel {
  border-left: 2px dashed var(--accent);
}
/* Slot-Row in der Liste */
.list-row.slot {
  background: rgba(255,213,74,.06);
  min-height: 56px;
}
.list-row.slot .lr-img {
  background: rgba(255,213,74,.12);
  display: flex; align-items: center; justify-content: center;
  font-size: 1.6rem;
}
.list-row.slot.theirs { opacity: .65; }
/* In-Poll-Marker am rechten Rand */
.list-row .lr-poll-mark {
  position: absolute; top: 4px; right: 4px;
  font-size: .55rem; font-weight: 800;
  background: rgba(255,73,73,.95); color: #fff;
  padding: 2px 6px;
  text-transform: uppercase; letter-spacing: .04em;
}
/* "Jetzt läuft"-Indikator */
.list-row.live-now {
  background: linear-gradient(90deg, rgba(255,73,73,.18), rgba(255,73,73,.04));
}
.list-row.live-now .lr-name::before {
  content: '● '; color: var(--accent); animation: blink 1.2s infinite;
}

/* ============================================================
   Spotify / Apple Music Buttons im Detail-Sheet
   ============================================================ */
.music-row {
  display: grid; grid-template-columns: 1fr 1fr;
  gap: .5rem; margin-top: .8rem;
}
.music-btn {
  display: flex; align-items: center; justify-content: center;
  gap: .5rem;
  padding: .8rem .6rem;
  font-weight: 800; font-size: .78rem;
  text-transform: uppercase; letter-spacing: .06em;
  font-family: inherit;
  text-decoration: none !important;
  border: 1.5px solid var(--line-2);
  background: var(--bg-3); color: var(--ink);
  cursor: pointer;
  transition: background-color .12s, border-color .12s, transform .08s;
}
.music-btn:hover { background: var(--bg-2); }
.music-btn:active { transform: scale(.96); }
.music-btn.spotify {
  border-color: #1db954;
}
.music-btn.spotify:hover { background: #1db954; color: #fff; }
.music-btn.apple {
  border-color: #fb5b6f;
}
.music-btn.apple:hover {
  background: linear-gradient(135deg, #fc6680, #fa233b);
  color: #fff; border-color: #fa233b;
}
.music-btn .m-svg {
  width: 18px; height: 18px;
  flex-shrink: 0;
}

/* ============================================================
   Mobile: List-View ist Default. Toggle bleibt verfügbar.
   ============================================================ */
@media (max-width: 720px) {
  .view-toggle { padding: .45rem .7rem .2rem; }
  .view-toggle button { padding: .4rem .7rem; font-size: .68rem; min-width: 64px; }
  .list-head { padding: .7rem .8rem .35rem; font-size: 1rem; }
  .list-row { grid-template-columns: 4px 52px 1fr auto; min-height: 64px; }
  .list-row .lr-name { font-size: .9rem; }
  .list-row .lr-meta { font-size: .62rem; }
  .list-row .lr-action { padding: 0 .5rem; }
  .list-row .a-pick-btn { padding: 7px 10px; font-size: .62rem; }
  .music-row { grid-template-columns: 1fr 1fr; gap: .4rem; }
  .music-btn { padding: .7rem .5rem; font-size: .72rem; }
}

/* ============================================================
   Bottom-Sheet Picker (Künstler / Personen / Generisch)
   ============================================================ */
.picker-back {
  position: fixed; inset: 0; z-index: 9995;   /* v23: über Filter-Sheet (9990) + Menu (9991) */
  background: rgba(0,0,0,.6);
  display: flex; align-items: flex-end; justify-content: center;
}
.picker-back[hidden] { display: none; }
.picker-sheet {
  width: 100%; max-width: 560px;
  background: var(--bg-2);
  border-top: 1px solid var(--line-2);
  border-radius: 14px 14px 0 0;
  display: flex; flex-direction: column;
  max-height: 88vh;
  padding-bottom: env(safe-area-inset-bottom);
  animation: pkSlide .22s ease-out;
}
@keyframes pkSlide { from { transform: translateY(100%); } to { transform: none; } }
.picker-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .8rem 1rem .6rem;
  border-bottom: 1px solid var(--line);
  position: sticky; top: 0; background: var(--bg-2); z-index: 2;
}
.picker-head h3 {
  margin: 0; font-size: .95rem; font-weight: 800;
  text-transform: uppercase; letter-spacing: .04em;
}
.picker-head::before {
  /* Drag-Handle (rein dekorativ) */
  content: ''; position: absolute; top: 6px; left: 50%;
  width: 40px; height: 4px; background: var(--line-2); border-radius: 2px;
  transform: translateX(-50%);
}
.picker-x {
  background: transparent; border: none; color: var(--ink-dim);
  font-size: 1.6rem; line-height: 1; cursor: pointer; padding: 0 .3rem;
}
.picker-x:hover { color: var(--accent); }
.picker-search {
  padding: .55rem .8rem;
  background: var(--bg-2);
  border-bottom: 1px solid var(--line);
}
.picker-search input {
  width: 100%; box-sizing: border-box;
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line-2);
  padding: .55rem .75rem; font: inherit;
  font-size: .85rem;
}
.picker-search input:focus { outline: none; border-color: var(--accent); }
.picker-chips {
  display: flex; gap: .3rem; padding: .4rem .8rem;
  overflow-x: auto; scrollbar-width: thin;
  border-bottom: 1px solid var(--line);
}
.picker-chips:empty { display: none; }
.pk-chip {
  background: var(--bg); border: 1px solid var(--line-2);
  color: var(--ink-dim);
  padding: .3rem .6rem; font-size: .65rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: .05em;
  white-space: nowrap; cursor: pointer; font-family: inherit;
  border-radius: 999px;
}
.pk-chip:hover { color: var(--ink); }
.pk-chip.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.picker-list { overflow-y: auto; flex: 1; padding: .3rem 0; }
.pk-empty { padding: 2rem 1rem; text-align: center; color: var(--ink-dim); font-size: .8rem; }
.pk-row {
  display: grid;
  grid-template-columns: 44px 1fr;
  align-items: center; gap: .7rem;
  width: 100%; box-sizing: border-box;
  background: transparent; border: none;
  border-bottom: 1px solid var(--line);
  padding: .55rem .9rem;
  text-align: left;
  cursor: pointer; font-family: inherit; color: var(--ink);
}
.pk-row:hover { background: var(--bg-3); }
.pk-row:active { background: var(--bg-4, var(--line)); }
.pk-row.pk-special {
  background: var(--bg-3); font-weight: 700;
}
.pk-av {
  width: 44px; height: 44px; border-radius: 50%;
  background-size: cover; background-position: center;
  background-color: var(--bg-3); border: 1px solid var(--line);
  display: flex; align-items: center; justify-content: center;
  font-size: .9rem; font-weight: 800; color: var(--ink-dim);
  text-transform: uppercase;
  flex-shrink: 0;
}
.pk-av-init { background-color: var(--bg-3); }
.pk-text { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.pk-label {
  font-size: .9rem; font-weight: 700;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.pk-sub {
  font-size: .7rem; color: var(--ink-dim);
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}

/* ============================================================
   Zonen-Karte (Leaflet im Modal)
   ============================================================ */
.zones-modal { padding: 0; }
/* v22: flex statt grid, damit die Map-Höhe nicht von Geschwister-Children kollabiert. */
.zones-modal-inner {
  width: 100%; max-width: 760px; height: 92vh;
  display: flex; flex-direction: column;
  background: var(--bg-2);
  padding: 0;
  min-height: 0;
}
.zones-modal-inner > .zones-head,
.zones-modal-inner > .zones-toolbar,
.zones-modal-inner > .zones-form { flex-shrink: 0; }
.zones-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: .7rem 1rem;
  border-bottom: 1px solid var(--line);
}
.zones-head h2 { margin: 0; font-size: 1rem; }
.modal-x {
  background: transparent; border: none; color: var(--ink-dim);
  font-size: 1.6rem; line-height: 1; cursor: pointer; padding: 0 .3rem;
}
.modal-x:hover { color: var(--accent); }
.zones-toolbar {
  display: flex; gap: .4rem; align-items: center;
  padding: .5rem .8rem;
  flex-wrap: wrap;
  background: var(--bg-3);
  border-bottom: 1px solid var(--line);
}
.zt-btn {
  background: var(--bg); border: 1px solid var(--line-2);
  color: var(--ink); padding: .4rem .7rem;
  font-size: .7rem; font-weight: 700; font-family: inherit;
  text-transform: uppercase; letter-spacing: .05em;
  cursor: pointer; white-space: nowrap;
}
.zt-btn:hover { border-color: var(--accent); color: var(--accent); }
.zt-btn.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }
.zt-hint {
  flex: 1; min-width: 200px;
  font-size: .7rem; color: var(--ink-dim);
}
.zones-map-wrap {
  position: relative;
  flex: 1 1 0;                   /* v22: nimmt verbleibenden Platz im flex-Container */
  min-height: 320px;
  border-bottom: 1px solid var(--line);
}
.zones-map {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  background: #222;
}
.zones-list-wrap {
  flex: 0 0 auto;
  max-height: 28vh;
  overflow-y: auto;
  background: var(--bg-2);
  border-top: 1px solid var(--line);
}
.zones-empty {
  padding: 1rem;
  font-size: .75rem; color: var(--ink-dim); text-align: center;
}
.zone-row .zr-actions { display: flex; gap: .2rem; }
.zone-row .zr-focus {
  background: transparent; border: none; color: var(--ink-dim);
  cursor: pointer; font-size: 1.1rem; padding: 0 .4rem;
}
.zone-row .zr-focus:hover { color: var(--ink); }
.zones-form {
  padding: .7rem .9rem;
  background: var(--bg-3);
  border-top: 1px solid var(--line);
  display: flex; flex-direction: column; gap: .55rem;
}
.zones-form[hidden] { display: none; }
.zones-form label {
  display: flex; flex-direction: column; gap: .25rem;
  font-size: .65rem; text-transform: uppercase; letter-spacing: .06em;
  color: var(--ink-dim);
}
.zones-form input, .zones-form select {
  background: var(--bg); border: 1px solid var(--line-2);
  color: var(--ink); padding: .5rem .6rem; font: inherit;
  font-size: .85rem;
}
.zones-form input:focus, .zones-form select:focus {
  outline: none; border-color: var(--accent);
}

/* Leaflet Tile-Bg auf Dark anpassen damit nicht Pixel-Glitch */
.leaflet-container { background: #1a1a1a !important; font-family: inherit !important; }
.leaflet-control-attribution { font-size: .55rem !important; opacity: .7; }
.leaflet-tooltip {
  background: var(--bg-2) !important; color: var(--ink) !important;
  border: 1px solid var(--line-2) !important; box-shadow: none !important;
  font-size: .7rem !important; font-weight: 700;
}

/* v22: Zone-Polygon-Farben pro Typ — wird beim drawAllZonesOnMap als CSS-Klasse gesetzt */
.zone-poly--stage  { stroke: var(--accent); fill: var(--accent); fill-opacity: .18; stroke-width: 2.2; }
.zone-poly--stand  { stroke: var(--going);  fill: var(--going);  fill-opacity: .18; stroke-width: 2.2; }
.zone-poly--outside{ stroke: #777; fill: #777; fill-opacity: .08; stroke-width: 1.6; stroke-dasharray: 6 4; }
/* Zone-Listen-Item Type-Badge */
.zl-type-badge {
  display: inline-block;
  font-size: .55rem; font-weight: 900;
  padding: 2px 6px; margin-right: 6px;
  text-transform: uppercase; letter-spacing: .06em;
  border-radius: 3px;
}
.zl-type-badge.t-stage   { background: var(--accent); color: var(--bg); }
.zl-type-badge.t-stand   { background: var(--going);  color: var(--bg); }
.zl-type-badge.t-outside { background: #777; color: var(--bg); }

@media (max-width: 720px) {
  .zones-modal-inner { height: 100vh; max-width: 100%; border-radius: 0; }
  .zones-toolbar { padding: .4rem .55rem; }
  .zt-btn { padding: .35rem .55rem; font-size: .65rem; }
  .zt-hint { font-size: .62rem; }
  .picker-sheet { max-height: 92vh; }
  .pk-row { padding: .5rem .7rem; }
  .pk-av { width: 40px; height: 40px; }
  .pk-label { font-size: .85rem; }
  .pk-sub { font-size: .65rem; }
  /* Mehr Platz für Drawer am unteren Rand */
  .mo-grid { padding-bottom: 0; }
}

/* === v25: ZIP-Job-Toast, System-Panel, Burst-Modal ====================== */

/* ZIP-Progress-Toast: detaillierter als der Standard-Toast */
.mo-toast--zip {
  min-width: 280px;
  max-width: 92vw;
}
.zt-title {
  font-size: .8rem;
  font-weight: 700;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--ink);
  margin: 0 0 .35rem;
}
.zt-sub {
  font-size: .7rem;
  color: var(--ink-dim);
  margin: 0 0 .5rem;
}
.zt-bar {
  height: 6px;
  background: rgba(255,255,255,.08);
  border-radius: 3px;
  overflow: hidden;
  margin: .25rem 0 .5rem;
}
.zt-bar-fill {
  height: 100%;
  background: var(--accent);
  width: 0%;
  transition: width .25s ease;
}
.zt-parts {
  display: flex; flex-wrap: wrap; gap: .35rem; margin-top: .5rem;
}
.zt-part {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .35rem .55rem;
  background: var(--accent);
  color: #111;
  border: none; border-radius: 8px;
  font-size: .68rem; font-weight: 700;
  text-decoration: none;
  cursor: pointer;
}
.zt-part--pending {
  background: rgba(255,255,255,.06);
  color: var(--ink-dim);
  cursor: default;
}
/* v28: Auffälliger CTA-Button im fertigen ZIP-Toast — größer, pulsierend */
.zt-part--cta {
  padding: .55rem .9rem;
  font-size: .82rem;
  font-weight: 900;
  background: #ffe04a; /* gelb statt accent-rot — sticht aus dem roten Brand-Set raus */
  color: #161616;
  box-shadow: 0 0 0 0 rgba(255,224,74,.7);
  animation: zt-pulse 1.4s ease-in-out infinite;
}
@keyframes zt-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(255,224,74,.55); transform: scale(1); }
  50%      { box-shadow: 0 0 0 8px rgba(255,224,74,0);  transform: scale(1.03); }
}
.mo-toast.is-done { border: 1px solid rgba(255,224,74,.5); }
.mo-toast.is-error { border: 1px solid rgba(255,73,73,.5); }
.zt-actions {
  display: flex; gap: .4rem; margin-top: .5rem;
  justify-content: flex-end;
}
.zt-actions button {
  background: none; border: 1px solid rgba(255,255,255,.14);
  color: var(--ink-dim);
  padding: .3rem .6rem; border-radius: 6px;
  font-size: .65rem; cursor: pointer;
}
.zt-actions button:hover { color: var(--ink); border-color: rgba(255,255,255,.28); }

/* System-Modal */
.sys-modal {
  max-width: 720px;
  width: 96vw;
  display: flex; flex-direction: column;
  max-height: 90vh;
}
.sys-tabs {
  display: flex; gap: 0;
  border-bottom: 1px solid rgba(255,255,255,.08);
  margin: 0 -1.2rem .8rem;
  padding: 0 1.2rem;
}
.sys-tab {
  background: none; border: none;
  padding: .7rem 1rem;
  color: var(--ink-dim);
  font-size: .72rem; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  cursor: pointer;
  border-bottom: 2px solid transparent;
}
.sys-tab.is-active {
  color: var(--ink);
  border-bottom-color: var(--accent);
}
.sys-pane {
  flex: 1; overflow-y: auto;
  display: flex; flex-direction: column; gap: .8rem;
}
.sys-card {
  background: rgba(255,255,255,.03);
  border: 1px solid rgba(255,255,255,.06);
  border-radius: 10px;
  padding: .8rem 1rem;
}
.sys-card-head {
  display: flex; align-items: center; gap: .5rem;
  font-size: .68rem; font-weight: 700;
  letter-spacing: .06em; text-transform: uppercase;
  color: var(--ink-dim);
  margin-bottom: .55rem;
}
.sys-card-icon { font-size: 1.1rem; }
.sys-stat-row {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: .5rem;
}
.sys-stat {
  text-align: center;
  padding: .5rem .3rem;
  background: rgba(255,255,255,.03);
  border-radius: 8px;
}
.sys-stat-n { font-size: 1.4rem; font-weight: 800; color: var(--ink); }
.sys-stat-l { font-size: .55rem; color: var(--ink-dim); text-transform: uppercase; letter-spacing: .08em; }
.sys-stat--pending .sys-stat-n { color: var(--accent); }
.sys-stat--processing .sys-stat-n { color: #ffc14a; }
.sys-stat--error .sys-stat-n { color: #ff6464; }

.sys-zip-job {
  padding: .6rem .7rem;
  background: rgba(255,255,255,.03);
  border-radius: 8px;
  margin-bottom: .5rem;
}
.sys-zip-job:last-child { margin-bottom: 0; }
.sys-zip-head {
  display: flex; justify-content: space-between; gap: .5rem;
  font-size: .72rem; margin-bottom: .35rem;
}
.sys-zip-status { color: var(--ink-dim); }
.sys-zip-status.is-running { color: #ffc14a; }
.sys-zip-status.is-done    { color: #6ee07c; }
.sys-zip-status.is-error   { color: #ff6464; }
.sys-zip-actions { display: flex; gap: .35rem; margin-top: .35rem; }
.sys-zip-actions a, .sys-zip-actions button {
  font-size: .62rem;
  padding: .3rem .55rem; border-radius: 6px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.08);
  color: var(--ink); text-decoration: none;
  cursor: pointer;
}
.sys-zip-actions .cancel { color: #ff8888; }

.sys-hint {
  font-size: .7rem; color: var(--ink-dim);
  margin: 0 0 .7rem;
}
.sys-perm-user {
  display: flex; align-items: center; justify-content: space-between;
  padding: .6rem .8rem;
  background: rgba(255,255,255,.03);
  border-radius: 8px;
  margin-bottom: .4rem;
}
.sys-perm-user-name { font-weight: 700; font-size: .8rem; }
.sys-perm-user-name .sys-admin-badge {
  font-size: .55rem; padding: .1rem .35rem;
  background: var(--accent); color: #111;
  border-radius: 4px; margin-left: .4rem;
  letter-spacing: .06em; text-transform: uppercase;
}
.sys-perm-toggles { display: flex; gap: .35rem; flex-wrap: wrap; }
.sys-perm-toggle {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .35rem .55rem;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.1);
  border-radius: 6px;
  font-size: .62rem; cursor: pointer;
  color: var(--ink-dim);
}
.sys-perm-toggle.is-on {
  background: var(--accent);
  color: #111; border-color: var(--accent);
  font-weight: 700;
}
.sys-perm-toggle.is-locked {
  opacity: .6; cursor: not-allowed;
}

/* Burst-Modal: Grid mit allen Serien-Bildern */
.burst-modal {
  max-width: 760px; width: 96vw;
  max-height: 90vh;
  display: flex; flex-direction: column;
}
.burst-grid {
  flex: 1; overflow-y: auto;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
  gap: 6px;
  padding: .3rem 0;
}
.burst-tile {
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  background: #1a1a1a center/cover no-repeat;
  cursor: pointer;
  position: relative;
  border: 2px solid transparent;
  overflow: hidden;
}
.burst-tile.is-current {
  border-color: var(--accent);
}
.burst-tile .bt-badge {
  position: absolute; top: 4px; left: 4px;
  background: rgba(0,0,0,.6);
  color: #fff;
  font-size: .55rem;
  padding: .1rem .3rem;
  border-radius: 4px;
}
.burst-foot {
  font-size: .68rem; color: var(--ink-dim);
  padding: .6rem 0 .2rem;
  border-top: 1px solid rgba(255,255,255,.06);
  margin-top: .5rem;
}

/* Burst-Aufruf-Button im Detail */
.md-burst {
  cursor: pointer;
  padding: .55rem .7rem;
  background: linear-gradient(90deg, rgba(255,76,76,.10), transparent);
  border-left: 3px solid var(--accent);
  border-radius: 0 8px 8px 0;
  font-size: .75rem;
  margin: .2rem 0 .4rem;
  display: flex; align-items: center; gap: .4rem;
  user-select: none;
}
.md-burst:hover { background: linear-gradient(90deg, rgba(255,76,76,.18), transparent); }
.md-burst::after { content: '›'; margin-left: auto; font-size: 1.2rem; color: var(--ink-dim); }

/* Festival-Bounds Polygon-Style */
.zone-poly--festival_bounds {
  /* Leaflet setzt das via setStyle — diese Klasse als Hook für theme */
}

/* Mobile-Anpassungen System-Modal */
@media (max-width: 720px) {
  .sys-modal { max-height: 96vh; width: 100vw; border-radius: 14px 14px 0 0; }
  .sys-stat-row { grid-template-columns: repeat(2, 1fr); }
  .burst-grid { grid-template-columns: repeat(auto-fill, minmax(90px, 1fr)); }
}

/* === v26: Download-FAB + Mobile-Grid-Fix + Multi-Picker + Burst-Stack ==== */

/* Sticky Download-Button rechts unten — immer sichtbar wenn Items da.
   Liegt über Grid + Bulk-Bar, aber unter Toasts und Pickern. */
.mo-download-fab {
  position: fixed;
  right: 1rem;
  bottom: calc(1rem + env(safe-area-inset-bottom));
  z-index: 60;
  display: inline-flex;
  align-items: center;
  gap: .55rem;
  padding: .75rem 1.1rem;
  background: var(--accent);
  color: #111;
  border: none;
  border-radius: 28px;
  box-shadow: 0 6px 22px rgba(0,0,0,.45);
  font-size: .78rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
  cursor: pointer;
  transition: transform .15s ease, box-shadow .15s ease;
}
.mo-download-fab:hover { transform: translateY(-1px); box-shadow: 0 10px 28px rgba(0,0,0,.55); }
.mo-download-fab .mdf-icon { font-size: 1.05rem; }
.mo-download-fab.selection { background: #ffc14a; }
/* Wenn Bulk-Bar sichtbar (Selection-Mode), schiebt der FAB nach oben damit
   sie sich nicht überlappen. */
body.mo-select-mode .mo-download-fab {
  bottom: calc(5.4rem + env(safe-area-inset-bottom));
}

/* Mobile-Grid-Überlappung: explizite Sizing-Regeln + Contain.
   Verhindert dass aspect-ratio + background-position auf älteren
   Mobile-Browsern (besonders iOS Safari ≤16) zusammen mit grid-implicit-tracks
   in eine kollabierte Höhe rutschen. */
.mo-item {
  width: 100%;
  aspect-ratio: 1 / 1;
  min-height: 0;
  min-width: 0;
  contain: layout paint;
  overflow: hidden;
}
/* v27: KEIN grid-auto-rows: 1fr — das stauchte alle Reihen zusammen, sodass
   mit vielen Items die Tiles sich überlagerten. min-content lässt jede Reihe
   exakt die aspect-ratio-Höhe der Tiles annehmen. */
.mo-grid {
  grid-auto-rows: min-content;
}
@media (max-width: 720px) {
  .mo-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 2px;
  }
}
@supports not (aspect-ratio: 1 / 1) {
  .mo-item::before {
    content: "";
    display: block;
    padding-top: 100%;
  }
}

/* Multi-Select im Picker */
.pk-row.is-selected {
  background: rgba(255, 76, 76, .12);
  outline: 2px solid var(--accent);
  outline-offset: -2px;
}
.pk-multi-mark {
  margin-left: auto;
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,.08);
  color: transparent;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 800;
  border: 1px solid rgba(255,255,255,.18);
  flex-shrink: 0;
}
.pk-row.is-selected .pk-multi-mark {
  background: var(--accent);
  color: #111;
  border-color: var(--accent);
}
.picker-multi-hint {
  display: flex; align-items: center; gap: .6rem;
  padding: .55rem .8rem;
  background: rgba(255,255,255,.04);
  border-bottom: 1px solid rgba(255,255,255,.06);
  font-size: .72rem;
  color: var(--ink-dim);
}
.pk-multi-apply {
  margin-left: auto;
  padding: .4rem .75rem;
  border: none;
  border-radius: 6px;
  background: var(--accent);
  color: #111;
  font-weight: 700;
  font-size: .68rem;
  cursor: pointer;
  text-transform: uppercase;
  letter-spacing: .04em;
}

/* Burst-Modal + Detail-Stacking */
.modal-back#burstModal { z-index: 1000; }
body.burst-detail-stack .media-detail { z-index: 1100; }

/* v27: Detail-Navigation — Pfeile am Rand. Buttons sind direkt in .media-detail
   damit sie nicht von stage.innerHTML-Resets zerschossen werden. */
.media-detail .md-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 44px; height: 44px;
  background: rgba(0,0,0,.55);
  color: #fff;
  border: none;
  border-radius: 50%;
  font-size: 1.6rem;
  font-weight: 700;
  cursor: pointer;
  z-index: 5;
  display: none;
  align-items: center; justify-content: center;
  user-select: none;
}
.media-detail .md-nav:hover { background: rgba(0,0,0,.85); }
.media-detail .md-nav--prev { left: .8rem; }
.media-detail .md-nav--next { right: .8rem; }
@media (min-width: 720px) {
  .media-detail .md-nav { display: inline-flex; }
  /* Detail-Seitenleiste verschiebt next-Pfeil weiter nach innen */
  .media-detail .md-nav--next { right: calc(var(--md-side-w, 340px) + .8rem); }
}

/* Drawer-Retry-Knopf */
.mo-uploads-retry {
  background: var(--accent);
  color: #111;
  border: none;
  padding: .35rem .65rem;
  border-radius: 6px;
  font-size: .68rem;
  font-weight: 700;
  margin-right: .4rem;
  cursor: pointer;
}
.mo-uploads-retry:hover { filter: brightness(1.08); }
