.appShell{
  /* Kein Grid: linke Spalte fixieren, sonst bricht position:sticky oft (overflow auf Seiten-Containern). */
  display:block;
  min-height:100%;
  padding-left:72px;
  box-sizing:border-box;
  transition:padding-left 280ms ease;
}
body:has(.appShell .appSidebar:hover) .appShell,
body.appMenu--pinned:has(.appShell) .appShell{
  padding-left:220px;
}

.appSidebar{
  position:fixed;
  left:0;
  top:0;
  bottom:0;
  width:72px;
  /* Browser-UI kann 100vh minimal anders ausfallen lassen -> 100dvh stabil */
  height:100dvh;
  max-height:100dvh;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:18px;
  padding:12px 10px;
  border-right:1px solid rgba(255,255,255,.1);
  background:rgba(10,14,20,.72);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
  z-index:100;
  pointer-events:auto;
  overflow-x:visible;
  overflow-y:auto;
  transition:width 280ms ease, box-shadow 280ms ease;
  --nav-sub-open-max-height:1200px;
  --nav-sub-shift-closed:-4px;
  --nav-sub-anim-maxheight:300ms cubic-bezier(.22,.61,.36,1);
  --nav-sub-anim-opacity:220ms ease;
  --nav-sub-anim-transform:260ms cubic-bezier(.22,.61,.36,1);
  --nav-sub-item-anim-opacity:180ms ease;
  --nav-sub-item-anim-transform:220ms cubic-bezier(.22,.61,.36,1);
}
.appSidebar:hover{
  width:220px;
  box-shadow:12px 0 32px rgba(0,0,0,.45);
  z-index:110;
}

/* Legacy Nav-Eintrag „Eventkalender“ global ausblenden */
.appSidebar .appSidebar__link[data-app-nav="dash-calendar"]{
  display:none !important;
}

/* Fixiert: Sidebar bleibt breit wie bei Hover (ohne Maus darauf) */
body.appMenu--pinned .appSidebar{
  width:220px;
  box-shadow:12px 0 32px rgba(0,0,0,.45);
  z-index:110;
}
body.appMenu--pinned .appSidebar__text{
  opacity:1;
  transform:translateX(0);
  pointer-events:auto;
}
body.appMenu--pinned .appSidebar__sublink{
  font-size:12px;
  justify-content:flex-start;
  padding:6px 6px;
}
body.appMenu--pinned .appSidebar .appSidebar__eventGroup{
  margin-left:8px;
  margin-right:2px;
  margin-top:4px;
  padding:8px 8px 8px 10px;
  border-left:1px solid rgba(255,255,255,.15);
  border-radius:0 10px 10px 0;
  background:rgba(255,255,255,.03);
}
body.appMenu--pinned .appSidebar:not(:hover) .appSidebar__eventGroup{
  margin-left:8px;
  margin-right:2px;
  padding:8px 8px 8px 10px;
  border-left:1px solid rgba(255,255,255,.15);
  border-radius:0 10px 10px 0;
  background:rgba(255,255,255,.03);
}

.appSidebar__menuModeBtn{
  flex-shrink:0;
}
@keyframes appLockToggle{
  0%{ transform:scale(1) rotate(0deg); opacity:1; }
  45%{ transform:scale(.78) rotate(-22deg); opacity:.45; }
  100%{ transform:scale(1) rotate(0deg); opacity:1; }
}
.appSidebar__menuModeBtn .appSidebar__icon--lock{
  display:flex;
  align-items:center;
  justify-content:center;
  transform-origin:center center;
  transition:transform .18s ease, opacity .18s ease;
}
.appSidebar__menuModeBtn .appSidebar__icon--lock.is-lock-toggling{
  animation:appLockToggle .34s cubic-bezier(.34,1.2,.64,1);
}
.appSidebar__menuModeBtn .appSidebar__icon--lock svg{
  display:block;
  width:18px;
  height:18px;
  margin:0 auto;
}
.appSidebar__menuModeBtn:active .appSidebar__icon--lock:not(.is-lock-toggling){
  transform:scale(.92);
}
.appSidebar__menuModeBtn.is-locked{
  background:rgba(255,255,255,.05);
  border-color:rgba(255,30,45,.55);
  box-shadow:none;
}
.appSidebar__menuModeBtn.is-locked:hover{
  border-color:rgba(255,30,45,.72);
  background:rgba(255,30,45,.10);
}

/* Gleiche Außenmaße wie .appSidebar__link (40px hoch, volle Breite der Spalte) */
.appSidebar__brand{
  width:100%;
  max-width:100%;
  height:40px;
  min-height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  font-weight:900;
  color:#fff;
  background:rgba(255,30,45,.2);
  border:1px solid rgba(255,30,45,.42);
  box-sizing:border-box;
  flex-shrink:0;
  align-self:stretch;
  overflow:hidden;
  transition:width 280ms ease, min-height 280ms ease, padding 280ms ease, border-radius 280ms ease;
}
/* Schmal: nur Favicon; ausgeklappt/fixiert: volles Logo in Header-Breite */
.appSidebar__brandMark{
  display:none;
  width:100%;
  height:auto;
  max-height:40px;
  object-fit:contain;
  object-position:center center;
}
.appSidebar__brandIcon{
  width:24px;
  height:24px;
  display:block;
  flex-shrink:0;
}
.appSidebar:hover .appSidebar__brand,
body.appMenu--pinned .appSidebar__brand{
  width:100%;
  align-self:stretch;
  min-height:44px;
  height:auto;
  padding:8px 10px;
  border-radius:14px;
  justify-content:center;
}
.appSidebar:hover .appSidebar__brandMark,
body.appMenu--pinned .appSidebar__brandMark{
  display:block;
}
.appSidebar:hover .appSidebar__brandIcon,
body.appMenu--pinned .appSidebar__brandIcon{
  display:none;
}

.appSidebar__nav{
  display:flex;
  flex-direction:column;
  gap:10px;
  width:100%;
}

.appSidebar__catalogWrap{
  display:flex;
  flex-direction:column;
  gap:0;
  width:100%;
}
/* Kein Katalog-Untermenü: nur der Hauptlink bleibt sichtbar. */
.appShell .appSidebar__catalogWrap .appSidebar__catalogSub{
  display:none !important;
}
/* Katalog-Unterpunkte nutzen exakt dieselbe Open/Close-Logik wie andere Nav-Gruppen (.is-open via app-shell.js). */
/* Unterpunkte in allen Nav-Gruppen konsistent klickbar */
.appSidebar__eventGroup .appSidebar__sublink,
.appSidebar__eventGroup .appSidebar__subText{
  pointer-events:auto;
}

.appSidebar__link{
  width:100%;
  height:40px;
  border-radius:12px;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  text-decoration:none;
  color:var(--ui-text-on-dark);
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.05);
  position:relative;
  margin:0;
  padding:0 10px;
  gap:10px;
}
.appSidebar__link:hover{
  border-color:rgba(255,255,255,.24);
  background:rgba(255,255,255,.11);
}
.appSidebar__link.is-active{
  border-color:rgba(255,30,45,.48);
  background:rgba(255,30,45,.22);
  color:#fff;
}
.appSidebar__link[data-tooltip]:hover::after{
  display:none;
}

.appSidebar__icon{
  width:20px;
  flex:0 0 20px;
  text-align:center;
  font-size:14px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.appSidebar__icon svg,
.appSidebar__subIcon svg{
  display:block;
  width:18px;
  height:18px;
  flex-shrink:0;
}

.appSidebar__text{
  font-size:13px;
  font-weight:800;
  letter-spacing:.01em;
  white-space:nowrap;
  opacity:0;
  transform:translateX(-4px);
  pointer-events:none;
  transition:opacity 220ms ease, transform 220ms ease;
}

.appSidebar:hover .appSidebar__text{
  opacity:1;
  transform:translateX(0);
}

button.appSidebar__link{
  font:inherit;
  cursor:pointer;
  box-sizing:border-box;
}

.appSidebar__icon--logout svg{
  display:block;
  width:18px;
  height:18px;
  margin:0 auto;
}

/* Join-Karte: Kopfzeile + Code-Feld + Öffnen (eine Box) */
.appSidebar__joinBox{
  width:100%;
  margin:0 0 10px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
  box-shadow:0 4px 18px rgba(0,0,0,.22);
  overflow:hidden;
  box-sizing:border-box;
}

.appSidebar__joinHead{
  width:100%;
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:10px;
  min-height:40px;
  margin:0;
  padding:8px 10px;
  border:none;
  border-bottom:1px solid rgba(255,255,255,.1);
  border-radius:0;
  font:inherit;
  font-size:13px;
  font-weight:800;
  letter-spacing:.01em;
  color:var(--ui-text-on-dark);
  background:rgba(255,255,255,.04);
  cursor:pointer;
  text-align:left;
  box-sizing:border-box;
}
.appSidebar__joinHead:hover{
  background:rgba(255,255,255,.09);
}

/* Eingabe + Button unter der Kopfzeile; in schmaler Sidebar wie Nav-Text erst bei Hover / fixiert sichtbar */
.appSidebar__codePanel{
  position:static;
  z-index:auto;
  width:100%;
  max-width:100%;
  box-sizing:border-box;
  margin:0;
  padding:0;
  border:none;
  border-radius:0;
  background:transparent;
  display:flex;
  flex-direction:column;
  align-items:stretch;
  gap:8px;
  max-height:0;
  opacity:0;
  overflow:hidden;
  pointer-events:none;
  transition:opacity 220ms ease, max-height 0.38s cubic-bezier(.22,.61,.36,1), padding 0.2s ease;
}
.appSidebar:hover .appSidebar__codePanel,
body.appMenu--pinned .appSidebar__codePanel{
  max-height:280px;
  opacity:1;
  padding:8px 8px 10px;
  pointer-events:auto;
}
.appSidebar__codeInput{
  width:100%;
  min-width:0;
  box-sizing:border-box;
  font-size:12px;
  line-height:1.35;
  padding:9px 10px;
}
.appSidebar__codeInput::placeholder{
  font-size:11px;
  letter-spacing:.01em;
  opacity:.85;
}
.appSidebar__codeSubmit{
  width:100%;
  justify-content:center;
  box-sizing:border-box;
  padding-top:10px;
  padding-bottom:10px;
  font-size:13px;
  font-weight:800;
}
.appSidebar__codeHint{
  margin:0;
  font-size:11px;
  line-height:1.35;
}

.appSidebar__eventGroup{
  margin-top:4px;
  margin-left:8px;
  margin-right:2px;
  padding:8px 8px 8px 10px;
  border-left:1px solid rgba(255,255,255,.15);
  border-radius:0 10px 10px 0;
  background:rgba(255,255,255,.03);
  display:flex;
  flex-direction:column;
  gap:6px;
  max-height:0;
  opacity:0;
  transform:translateY(var(--nav-sub-shift-closed));
  overflow:hidden;
  pointer-events:none;
  transition:max-height var(--nav-sub-anim-maxheight), opacity var(--nav-sub-anim-opacity), transform var(--nav-sub-anim-transform), margin-top var(--nav-sub-anim-opacity);
}
.appSidebar__eventGroup.is-open{
  max-height:var(--nav-sub-open-max-height);
  opacity:1;
  transform:translateY(0);
  pointer-events:auto;
}
.appSidebar__eventGroup > *{
  opacity:0;
  transform:translateY(-3px);
  transition:opacity var(--nav-sub-item-anim-opacity), transform var(--nav-sub-item-anim-transform);
  transition-delay:var(--nav-item-delay, 0ms);
}
.appSidebar__eventGroup.is-open > *{
  opacity:1;
  transform:translateY(0);
}
.appSidebar__eventGroup[hidden]{ display:none !important; }
.appSidebar__eventName{
  color:var(--ui-text);
  font-size:12px;
  font-weight:800;
  line-height:1.2;
  padding:2px 4px 4px;
  opacity:.95;
  white-space:nowrap;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateX(-4px);
  transition:opacity 220ms ease, transform 220ms ease, max-height 220ms ease;
}
.appSidebar__catalogSubHead{
  color:var(--ui-text-muted);
  font-size:11px;
  font-weight:800;
  line-height:1.25;
  padding:8px 4px 2px;
  letter-spacing:0.05em;
  text-transform:uppercase;
  white-space:nowrap;
  opacity:0;
  max-height:0;
  overflow:hidden;
  transform:translateX(-4px);
  transition:opacity 220ms ease, transform 220ms ease, max-height 220ms ease;
}
.appSidebar__eventGroup.is-open .appSidebar__catalogSubHead{
  opacity:.78;
  max-height:36px;
  transform:translateX(0);
}
.appSidebar__sublink{
  display:flex;
  align-items:center;
  gap:8px;
  text-decoration:none;
  color:var(--ui-text-muted);
  font-size:12px;
  border:1px solid transparent;
  border-radius:8px;
  padding:6px 6px;
  white-space:nowrap;
  overflow:hidden;
}
.appSidebar__sublink:hover{
  color:var(--ui-text);
  border-color:rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
}
.appSidebar__sublink.is-active{
  color:#fff;
  border-color:rgba(255,30,45,.45);
  background:rgba(255,30,45,.20);
}
.appSidebar__subIcon{
  width:18px;
  flex:0 0 18px;
  text-align:center;
  font-size:13px;
  line-height:1;
  display:flex;
  align-items:center;
  justify-content:center;
}
.appSidebar__subText{
  max-width:0;
  overflow:hidden;
  opacity:0;
  transform:translateX(-4px);
  pointer-events:none;
  transition:opacity 220ms ease, transform 220ms ease, max-width 220ms ease;
}
.appSidebar__eventGroup.is-open .appSidebar__subText{
  max-width:140px;
  opacity:1;
  transform:translateX(0);
}
.appSidebar__eventGroup.is-open .appSidebar__eventName{
  opacity:.95;
  max-height:28px;
  transform:translateX(0);
}
/* Nur im kompakten Modus: ohne Hover schmale Icon-Leiste. Bei appMenu--pinned greift stattdessen body.appMenu--pinned … (sonst überschreibt :not(:hover) die fixierten Styles wegen höherer Klassen-Spezifität). */
body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__sublink{
  font-size:0;
  justify-content:center;
  padding:6px 0;
}
body:not(.appMenu--pinned) .appSidebar:hover .appSidebar__sublink{
  font-size:12px;
}
body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__eventGroup{
  margin-left:0;
  margin-right:0;
  padding:6px 4px;
  border-left:none;
  border-radius:8px;
  background:transparent;
}

/* Katalog-Untergruppe: auf Katalog-Seiten bleibt .is-open gesetzt — im zugeklappten Desktop-Sidebar trotzdem nur Icons (kein „von Athlon“, „KATALOG“, Subtext) */
@media (min-width:901px){
  body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__eventGroup .appSidebar__eventName{
    opacity:0 !important;
    max-height:0 !important;
    padding:0 !important;
    margin:0 !important;
    overflow:hidden !important;
    transform:translateX(-4px) !important;
    border:0 !important;
  }
  body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__catalogSub .appSidebar__subText{
    max-width:0 !important;
    opacity:0 !important;
    transform:translateX(-4px) !important;
    pointer-events:none !important;
  }
  body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__catalogSub .appSidebar__catalogSubHead,
  body:not(.appMenu--pinned) .appSidebar:not(:hover) .appSidebar__catalogSub .appSidebar__eventName{
    opacity:0 !important;
    max-height:0 !important;
    padding:0 !important;
    margin:0 !important;
    overflow:hidden !important;
    border:0 !important;
  }
}

.appContent{
  min-width:0;
}

.appTopbar{
  position:sticky;
  top:0;
  z-index:35;
  min-height:72px;
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:12px;
  padding:14px 22px;
  border-bottom:1px solid rgba(255,255,255,.1);
  background:rgba(10,14,20,.68);
  backdrop-filter:blur(12px);
  -webkit-backdrop-filter:blur(12px);
}

.appTopbar__left{ min-width:0; }
.appTopbar__kicker{
  display:flex;
  align-items:center;
  gap:6px;
  color:var(--ui-text-muted);
  font-size:11px;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.appTopbar__logo{
  width:14px;
  height:14px;
  border-radius:3px;
}
.appTopbar__title{
  margin:2px 0;
  font-size:clamp(18px,2vw,26px);
  line-height:1.2;
}
.appTopbar__status{
  color:var(--ui-text-muted);
  font-size:13px;
}
.appTopbar__right{
  display:flex;
  align-items:center;
  gap:10px;
  margin-left:auto;
}
.appTopbar__meta{
  color:var(--ui-text-muted);
  font-size:13px;
  text-decoration:none;
  border:1px solid transparent;
  border-radius:10px;
  padding:6px 8px;
}
.appTopbar__meta:hover{
  border-color:rgba(255,255,255,.14);
  color:var(--ui-text);
  background:rgba(255,255,255,.05);
}
/* "Zum Event" im Topbar global ausblenden (mobile + desktop). */
.appTopbar #backToEvent{
  display:none !important;
}

.appContent__inner{ padding-top:16px; }

/* Mobile Shell Controls: nur ≤900px sichtbar (siehe @media unten) */
.appMobileNav__menuBtn{
  display:none;
}
.appMobileNav__backdrop{
  display:none;
}

/* Nur Header *innerhalb* der Shell ausblenden (Duplikat), nicht #siteHeader oberhalb von .appShell (z. B. games-event-overview mit tpl_*). */
.appShell .siteHeader{ display:none !important; }
/* App-Seiten: beim Scroll-Block (overflow hidden) soll der Content im Viewport bleiben. */
body:has(.appShell) .siteMain{ padding-top:0; }

/* Wenn die Viewport-Höhe knapp wird (Fullscreen / kleine Laptop- / Tablet-Höhen),
   entfernen wir zusätzlich das vertikale Padding, damit Header/Footer + Content
   nicht durch minimale Browser-UI-Abweichungen "rauslaufen". */
@media (max-height: 820px){
  body:has(.appShell) .siteMain{ padding:0; }
}

/* Subtiler Content-Switch */
.appShell--context-opening .appContent{
  opacity:.985;
  transform:translateY(4px);
}
.appShell--context-opening-active .appContent{
  opacity:1;
  transform:translateY(0);
  transition:opacity 320ms ease, transform 320ms ease;
}

@media (max-width:900px){
  .appShell{
    padding-left:0;
    min-width:0;
    box-sizing:border-box;
    display:flex;
    flex-direction:column;
    flex:1 1 auto;
    min-height:0;
    max-height:100%;
  }
  body.appMenu--pinned:has(.appShell) .appShell,
  body:has(.appShell .appSidebar:hover) .appShell{
    padding-left:0 !important;
  }
  /* Gegen body.appMenu--pinned .appSidebar { width:220px } außerhalb dieses Blocks */
  body.appMenu--pinned:has(.appShell) .appSidebar,
  body.appMenu--pinned:has(.appShell) .appSidebar:hover{
    width:min(320px, 88vw) !important;
    max-width:min(320px, 88vw) !important;
    left:0;
  }
  .appShell .appContent{
    width:100%;
    max-width:100%;
    min-width:0;
    flex:1 1 auto;
    min-height:0;
    box-sizing:border-box;
  }

  /* Menü fixieren: auf Touch sinnlos — Button ausblenden */
  #appMenuModeBtn{
    display:none !important;
  }

  /* Backdrop hinter dem Drawer */
  .appMobileNav__backdrop{
    display:block;
    position:fixed;
    inset:0;
    z-index:240;
    background:rgba(0,0,0,.52);
    opacity:0;
    visibility:hidden;
    pointer-events:none;
    transition:opacity 280ms ease, visibility 0s linear 280ms;
    -webkit-tap-highlight-color:transparent;
  }
  body.appMobileNav--open .appMobileNav__backdrop{
    opacity:1;
    visibility:visible;
    pointer-events:auto;
    transition:opacity 280ms ease, visibility 0s linear 0s;
  }

  /* Slide-in: eigenes „Sheet“, nicht 1:1 Desktop-Sidebar-Optik */
  .appSidebar{
    position:fixed;
    left:0;
    top:0;
    bottom:0;
    width:min(340px, 92vw);
    max-width:100%;
    height:100dvh;
    height:100svh;
    max-height:none;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    padding:max(14px, env(safe-area-inset-top)) 16px max(20px, env(safe-area-inset-bottom));
    border-right:1px solid rgba(255,255,255,.14);
    border-bottom:none;
    border-radius:0 22px 22px 0;
    background:rgba(7,9,14,.94);
    backdrop-filter:saturate(140%) blur(20px);
    -webkit-backdrop-filter:saturate(140%) blur(20px);
    box-shadow:none;
    z-index:320;
    transform:translate3d(-105%, 0, 0);
    transition:transform 320ms cubic-bezier(.22,.61,.36,1), box-shadow 320ms ease;
    overflow-x:hidden;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior:contain;
  }
  .appSidebar:hover{
    width:min(340px, 92vw);
    box-shadow:none;
  }
  body.appMobileNav--open .appSidebar{
    transform:translate3d(0, 0, 0);
    box-shadow:12px 0 56px rgba(0,0,0,.6);
  }

  /* Über Backdrop (240): body.appMenu--pinned / :hover setzen sonst z-index:110 und fangen Klicks ab */
  body.appMenu--pinned:has(.appShell) .appSidebar,
  .appShell .appSidebar:hover{
    z-index:320;
  }

  .appSidebar__brand{
    width:100%;
    max-width:100%;
    min-height:48px;
    height:auto;
    padding:10px 12px;
    margin-bottom:12px;
    border-radius:14px;
    justify-content:center;
    flex-shrink:0;
    border:1px solid rgba(255,255,255,.1);
    background:rgba(255,255,255,.04);
    box-shadow:none;
  }
  .appSidebar__brandMark{
    display:block;
    max-height:34px;
  }
  .appSidebar__brandIcon{
    display:none;
  }

  .appSidebar__nav{
    flex-direction:column;
    flex-wrap:nowrap;
    gap:8px;
    flex:1 1 auto;
    min-height:0;
    padding-bottom:8px;
  }

  /* Logische Gruppen nur mit Abstand/Trennlinie (kein neuer Textinhalt) */
  .appSidebar__nav > .appSidebar__link[data-app-nav="dash-home"]{
    margin-bottom:2px;
  }
  .appSidebar__nav > .appSidebar__link[data-app-nav="dash-events"]{
    margin-top:10px;
    padding-top:12px;
    border-top:1px solid rgba(255,255,255,.1);
  }
  .appSidebar__nav > .appSidebar__catalogWrap{
    margin-top:10px;
    padding-top:12px;
    border-top:1px solid rgba(255,255,255,.1);
  }
  .appSidebar__nav > .appSidebar__logout{
    margin-top:auto;
    padding-top:14px;
    border-top:1px solid rgba(255,255,255,.12);
  }

  .appSidebar__link{
    width:100%;
    min-height:48px;
    margin:0;
    padding:0 14px;
    border-radius:14px;
    font-size:15px;
    font-weight:750;
    border:1px solid transparent;
    background:rgba(255,255,255,.05);
    box-shadow:none;
  }
  .appSidebar__link:active{
    transform:scale(.99);
  }
  .appSidebar__text{
    opacity:1;
    transform:none;
    pointer-events:auto;
    font-weight:800;
  }
  .appSidebar__icon{
    flex:0 0 22px;
    width:22px;
  }

  .appSidebar__joinBox{
    width:100%;
    max-width:100%;
    border-radius:14px;
    flex-shrink:0;
  }
  .appSidebar__joinHead{
    min-height:44px;
    font-size:14px;
  }
  .appSidebar__codePanel{
    max-height:none !important;
    opacity:1 !important;
    padding:8px 8px 10px !important;
    pointer-events:auto !important;
  }
  .appSidebar__codeInput{
    font-size:15px;
    min-height:44px;
  }
  .appSidebar__codeSubmit{
    min-height:44px;
  }

  .appSidebar__eventGroup{
    margin:8px 0 0;
    border-left:none;
    border-top:none;
    border-radius:12px;
    width:100%;
    padding:10px 10px 10px 12px;
    background:rgba(255,255,255,.04);
  }
  .appSidebar__eventGroup.is-open{
    max-height:min(70vh, 560px);
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
  }
  .appSidebar__sublink{
    display:flex;
    width:100%;
    min-height:42px;
    margin:0 0 4px;
    padding:8px 10px;
    border-radius:10px;
    font-size:13px;
    white-space:normal;
  }
  .appSidebar__subText{
    opacity:1;
    transform:none;
    pointer-events:auto;
    max-width:none !important;
    white-space:normal;
    line-height:1.25;
  }
  .appSidebar__eventName{
    opacity:.95;
    max-height:none;
    transform:none;
    white-space:normal;
    font-size:11px;
    letter-spacing:.06em;
    text-transform:uppercase;
    color:rgba(255,255,255,.55);
    padding:4px 4px 8px;
  }
  .appSidebar__catalogSubHead{
    opacity:.78;
    max-height:none;
    transform:none;
    white-space:normal;
    font-size:10px;
  }

  .appMobileNav__menuBtn{
    display:inline-flex;
    align-items:center;
    justify-content:center;
    width:38px;
    height:38px;
    margin:0;
    padding:0;
    flex-shrink:0;
    border-radius:11px;
    border:1px solid rgba(255,255,255,.18);
    background:rgba(255,255,255,.09);
    color:#fff;
    cursor:pointer;
    transition:border-color .2s ease, background .2s ease, transform .12s ease, box-shadow .2s ease;
    -webkit-tap-highlight-color:transparent;
    box-shadow:0 4px 18px rgba(0,0,0,.22);
  }
  .appMobileNav__menuBtn:hover{
    border-color:rgba(255,255,255,.28);
    background:rgba(255,255,255,.12);
  }
  .appMobileNav__menuBtn:active{
    transform:scale(.96);
  }
  body.appMobileNav--open .appMobileNav__menuBtn{
    border-color:rgba(255,30,45,.55);
    background:rgba(255,30,45,.22);
    box-shadow:0 6px 22px rgba(255,30,45,.2);
  }
  .appMobileNav__menuIconSvg{
    display:block;
    flex-shrink:0;
  }

  /* [Menü] | [Spalte: Kicker → Titel → Beschreibung] | rechts — kompakt, eine optische Achse */
  .appShell .appTopbar{
    position:sticky;
    top:0;
    z-index:80;
    display:flex !important;
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    justify-content:flex-start;
    gap:10px;
    padding:max(6px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left)) !important;
    min-height:0 !important;
    box-sizing:border-box;
  }
  /* Burger/Header über Backdrop (240), sonst wirkt Topbar abgedunkelt und Klicks gehen ins Overlay */
  body.appMobileNav--open .appShell .appTopbar{
    z-index:260;
  }
  /* event.css min-height/padding (.evPage .appTopbar) lädt nach app-shell */
  main.evPage .appShell .appTopbar{
    min-height:0 !important;
    padding:max(6px, env(safe-area-inset-top)) max(10px, env(safe-area-inset-right)) max(8px, env(safe-area-inset-bottom)) max(8px, env(safe-area-inset-left)) !important;
  }
  .appShell .appTopbar .appMobileNav__menuBtn{
    position:relative;
    left:auto;
    top:auto;
    margin:0;
    flex-shrink:0;
    align-self:center;
  }
  /* Textblock: nur eine Spalte, kein Quetsch-Nebeneinander */
  .appShell .appTopbar .appTopbar__left{
    position:relative;
    display:grid !important;
    grid-template-columns:minmax(0, 1fr);
    grid-template-rows:auto auto auto;
    row-gap:2px;
    column-gap:0;
    align-items:start;
    min-width:0;
    flex:1 1 auto;
    order:1;
    overflow:hidden;
  }
  .appShell .appTopbar .appTopbar__kicker{
    grid-column:1;
    grid-row:1;
    margin:0;
    font-size:9px;
    letter-spacing:.08em;
    line-height:1.2;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    max-width:100%;
  }
  .appShell .appTopbar .appTopbar__title{
    grid-column:1;
    grid-row:2;
    margin:0 !important;
    padding:0;
    min-width:0;
    max-width:100%;
    font-size:clamp(16px, 4.5vw, 19px) !important;
    font-weight:800;
    line-height:1.18 !important;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    word-break:normal;
  }
  .appShell .appTopbar .appTopbar__status{
    grid-column:1;
    grid-row:3;
    position:static !important;
    width:100% !important;
    max-width:100%;
    height:auto !important;
    margin:2px 0 0 !important;
    padding:0 !important;
    overflow:hidden;
    clip:auto !important;
    clip-path:none !important;
    border:0 !important;
    color:rgba(255,255,255,.52);
    font-size:10.5px;
    font-weight:550;
    line-height:1.38;
    letter-spacing:.01em;
    display:-webkit-box;
    -webkit-box-orient:vertical;
    -webkit-line-clamp:2;
    align-self:stretch;
    min-width:0;
    overflow-wrap:anywhere;
    hyphens:auto;
  }
  .appShell .appTopbar .appTopbar__right{
    flex:0 0 auto;
    order:3;
    margin-left:auto;
    align-self:flex-start;
    padding-top:1px;
  }
  /* Gegen dashboard.css: Topbar nicht als Spalte unter 720px */
  main.dashPage .appShell .appTopbar--dashNextCenter{
    flex-direction:row !important;
    flex-wrap:nowrap !important;
    align-items:center !important;
    gap:8px 10px !important;
  }
  main.dashPage .appShell .appTopbar--dashNextCenter .appTopbar__left{
    display:grid !important;
    grid-template-columns:minmax(0, 1fr);
    grid-template-rows:auto auto auto;
    row-gap:2px;
    align-items:start;
  }
  /* „Nächstes Event“: nur wenn sichtbar, schmal daneben; sonst keine Extra-Zeile */
  main.dashPage .appShell .appTopbar--dashNextCenter .appTopbar__center{
    position:static !important;
    transform:none !important;
    order:2;
    flex:0 1 auto;
    width:auto !important;
    max-width:min(38vw, 200px) !important;
    min-width:0;
    padding:0 !important;
    margin:0 !important;
    text-align:center;
    left:auto !important;
    top:auto !important;
  }
  main.dashPage .appShell .appTopbar--dashNextCenter .appTopbar__center:has(> a.u-hidden:only-child),
  main.dashPage .appShell .appTopbar--dashNextCenter .appTopbar__center:has(> .u-hidden:only-child){
    display:none !important;
  }
  .appShell .appTopbar--dashNextCenter .appTopbar__center .appTopbar__meta{
    font-size:11px;
    padding:4px 6px;
    white-space:nowrap;
    overflow:hidden;
    text-overflow:ellipsis;
    display:block;
    max-width:100%;
  }

  .appTopbar__kicker{
    font-size:10px;
  }
  .appTopbar__title{
    font-size:clamp(17px, 4.8vw, 22px);
    line-height:1.15;
    word-break:break-word;
  }
  .appTopbar__status{
    font-size:13px;
    line-height:1.35;
  }
  .appContent__inner{
    padding-left:max(14px, env(safe-area-inset-left));
    padding-right:max(14px, env(safe-area-inset-right));
    padding-bottom:max(20px, env(safe-area-inset-bottom));
  }
}

@media (prefers-reduced-motion: reduce){
  .appSidebar,
  .appMobileNav__backdrop{
    transition:none !important;
  }
}

@media (max-width:420px){
  .appShell .appTopbar{
    padding-left:max(10px, env(safe-area-inset-left)) !important;
    padding-right:max(12px, env(safe-area-inset-right)) !important;
  }
}

/* Dashboard header block compact instead of hero */
.appShell--dashboard .dashHero__panel{
  box-shadow:none !important;
  background:rgba(255,255,255,.03) !important;
}
.appShell--dashboard .dashHero__panel::before,
.appShell--dashboard .dashHero__panel::after{
  display:none !important;
}
.appShell--dashboard .dashH1{
  font-size:22px !important;
  margin-top:4px !important;
  text-shadow:none !important;
}

/* Bearbeiten-Tabs unterhalb von „Bearbeiten“ im Event-Untermenü */
#appEventNavGroup .appSidebar__eventGroup--edit{
  margin-top:2px;
  margin-left:0;
  margin-right:0;
  padding:6px 4px 6px 8px;
  border-left:1px solid rgba(255,30,45,.22);
  border-radius:0 8px 8px 0;
  background:rgba(255,30,45,.06);
  gap:4px;
}

/* =========================================================
   Mobile: App-Shell — fixe Topbar, fixer Footer (#siteFooter), nur Hauptinhalt scrollt
   ≤900px, nur wenn .appShell im Dokument vorkommt.
========================================================= */
@media (max-width:900px){
  html:has(.appShell){
    height:100%;
    overflow:hidden;
    scrollbar-gutter:auto;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  html:has(.appShell)::-webkit-scrollbar{
    width:0;
    height:0;
    display:none;
  }
  body:has(.appShell){
    height:100dvh;
    max-height:100dvh;
    height:100svh;
    max-height:100svh;
    margin:0;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  body:has(.appShell)::-webkit-scrollbar{
    width:0;
    height:0;
    display:none;
  }
  body:has(.appShell) > main.siteMain{
    flex:1 1 auto;
    min-height:0;
    overflow:hidden;
    display:flex;
    flex-direction:column;
    padding-top:0;
    padding-bottom:0;
  }
  body:has(.appShell) > #siteFooter{
    flex-shrink:0;
  }
  /* Event: unterer Icon-Strip (nur mit data-ev-tab-bar-on, gesetzt von app-shell.js) */
  body:has(.appShell) > #evMobileTabBar{
    flex-shrink:0;
  }
  body:has(.appShell) .appShell{
    flex:1 1 auto;
    min-height:0;
    overflow:hidden;
  }
  body:has(.appShell) .appContent{
    display:flex !important;
    flex-direction:column !important;
    flex:1 1 auto;
    min-width:0;
    min-height:0;
    overflow:hidden;
    width:100%;
    max-width:100%;
    box-sizing:border-box;
  }
  body:has(.appShell) .appContent > header.appTopbar{
    flex-shrink:0;
    position:relative;
    top:auto;
    z-index:80;
  }
  body:has(.appShell) .appContent > *:not(.appTopbar){
    flex:1 1 auto;
    min-height:0;
    min-width:0;
    overflow-x:hidden;
    overflow-y:auto;
    -webkit-overflow-scrolling:touch;
    overscroll-behavior-y:contain;
  }
  body:has(.appShell) *{
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  body:has(.appShell) *::-webkit-scrollbar{
    width:0 !important;
    height:0 !important;
    display:none;
  }

  /* Event-Kontext (Mobil): gesamte Event-Gruppe aus — kein Eventname, keine Unterpunkte; nur „Meine Events“ bleibt als aktiver Reiter erkennbar. */
  #appEventNavGroup{
    display:none !important;
  }
  .appSidebar__nav > #appEditEventNavGroup{
    display:none !important;
  }

  /* Recap (Sidebar ausgeblendet): kein leerer Drawer-Button */
  body[data-recap-immersive="1"] .appMobileNav__menuBtn,
  body[data-recap-immersive="1"] .appMobileNav__backdrop{
    display:none !important;
  }

  body:has(.appShell) > .evMobileTabBar[data-ev-tab-bar-on="1"]{
    display:flex !important;
    flex-direction:row;
    align-items:stretch;
    justify-content:space-evenly;
    gap:0;
    width:100%;
    min-height:calc(50px + env(safe-area-inset-bottom, 0px));
    padding:4px 4px max(6px, env(safe-area-inset-bottom, 0px));
    border-top:1px solid rgba(255,255,255,.12);
    background:rgba(10,14,20,.94);
    backdrop-filter:blur(18px) saturate(1.2);
    -webkit-backdrop-filter:blur(18px) saturate(1.2);
    z-index:75;
    overflow-x:auto;
    overflow-y:hidden;
    -webkit-overflow-scrolling:touch;
    scrollbar-width:none;
    -ms-overflow-style:none;
  }
  body:has(.appShell) > .evMobileTabBar[data-ev-tab-bar-on="1"]::-webkit-scrollbar{
    display:none;
    width:0;
    height:0;
  }
  .evMobileTabBar__link{
    flex:1 1 0;
    min-width:40px;
    display:flex;
    align-items:center;
    justify-content:center;
    min-height:44px;
    padding:6px 2px;
    border-radius:12px;
    color:rgba(255,255,255,.62);
    text-decoration:none;
    -webkit-tap-highlight-color:transparent;
    transition:color .15s ease, background .15s ease;
  }
  .evMobileTabBar__link.is-active{
    color:rgba(255,255,255,.98);
    background:rgba(255,30,45,.2);
  }
  .evMobileTabBar__link:active{
    opacity:.88;
  }
  .evMobileTabBar__icon{
    display:flex;
    align-items:center;
    justify-content:center;
  }
  .evMobileTabBar__icon svg{
    width:22px;
    height:22px;
    display:block;
  }
}

/* Event-Mobil-Iconleiste: außerhalb ≤900px bzw. ohne Aktiv-Flag immer aus */
.evMobileTabBar{
  display:none !important;
  box-sizing:border-box;
}
