/* ── Reset ─────────────────────────────────────────────── */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html, body {
  overscroll-behavior-x: none;
}

/* ── Design Tokens ─────────────────────────────────────── */
:root {
  /* Colors */
  --bg:            #0F0F10;
  --surface:       #161616;
  --card-bg:       #1C1C1C;
  --card-border:   rgba(255, 255, 255, 0.07);
  --text-primary:  #FFFFFF;
  --accent:        #8EBBFF;
  --accent-dim:    rgba(142, 187, 255, 0.15);
  --btn-fg:        #000000;
  --text-secondary: #8895A0;
  --text-muted:     #5C6B78;

  /* Surface overlays (white on dark) */
  --overlay-xs:     rgba(255, 255, 255, 0.04);
  --overlay-sm:     rgba(255, 255, 255, 0.06);
  --overlay-md:     rgba(255, 255, 255, 0.08);
  --overlay-hover:  rgba(255, 255, 255, 0.07);

  /* Border tokens */
  --border-subtle:  rgba(255, 255, 255, 0.08);
  --border-dim:     rgba(255, 255, 255, 0.10);
  --border-med:     rgba(255, 255, 255, 0.15);

  /* Header */
  --header-bg:      rgba(0, 0, 0, 0.55);
  --header-border:  rgba(255, 255, 255, 0.10);
  --header-pill-border: 2px solid rgba(255, 255, 255, 0.15);

  /* Dropdown / popup surfaces */
  --dropdown-bg:    #1a1a1a;
  --dropdown-border: rgba(255, 255, 255, 0.08);
  --dropdown-shadow: rgba(0, 0, 0, 0.7);

  /* Sidebar / top-nav */
  --nav-bg:         rgba(15, 15, 16, 0.89);
  --nav-border:     rgba(255, 255, 255, 0.15);

  /* Sticky title shadow */
  --title-scrolled-bg:     rgba(15, 15, 16, 0.92);
  --title-scrolled-shadow: rgba(15, 15, 16, 0.85);

  /* Radii */
  --card-radius:  26px;
  --pill-radius:  100px;
  --btn-radius:   16px;
  --input-radius: 14px;

  /* Spacing scale */
  --space-1: 4px;
  --space-2: 8px;
  --space-3: 12px;
  --space-4: 16px;
  --space-5: 20px;
  --space-6: 24px;
  --space-8: 32px;
  --space-10: 40px;

  /* Layout */
  --sidebar-w:      220px;
  --panel-w:        400px;
  --mobile-max:     480px;

  /* Typography */
  font-family: 'Open Sans', -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, sans-serif;
  font-size: 16px;
  line-height: 1.5;
  color-scheme: dark;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

/* Mobile + tablet (dark theme): revert app + title to pure black —
   the grey #0F0F10 is desktop-only design. */
@media (max-width: 1279px) {
  :root {
    --bg:                    #000000;
    --title-scrolled-bg:     rgba(0, 0, 0, 0.82);
    --title-scrolled-shadow: rgba(0, 0, 0, 0.85);
  }
}

/* ── Light theme ─────────────────────────────────────────── */
[data-theme="light"] {
  --bg:            #F0F0F5;
  --surface:       #FAFAFA;
  --card-bg:       #FFFFFF;
  --card-border:   rgba(0, 0, 0, 0.08);
  --text-primary:  #0A0A14;
  --accent:        #000000;
  --accent-dim:    rgba(0, 0, 0, 0.08);
  --btn-fg:        #FFFFFF;
  --btn-fg:        #FFFFFF;
  --text-secondary: #5A6878;
  --text-muted:     #8895A0;

  --overlay-xs:     rgba(0, 0, 0, 0.03);
  --overlay-sm:     rgba(0, 0, 0, 0.05);
  --overlay-md:     rgba(0, 0, 0, 0.07);
  --overlay-hover:  rgba(0, 0, 0, 0.05);

  --border-subtle:  rgba(0, 0, 0, 0.09);
  --border-dim:     rgba(0, 0, 0, 0.11);
  --border-med:     rgba(0, 0, 0, 0.14);

  --header-bg:      rgba(240, 240, 245, 0.92);
  --header-border:  rgba(0, 0, 0, 0.09);
  --header-pill-border: 2px solid rgba(0, 0, 0, 0.12);

  --dropdown-bg:    #FFFFFF;
  --dropdown-border: rgba(0, 0, 0, 0.09);
  --dropdown-shadow: rgba(0, 0, 0, 0.18);

  --nav-bg:         rgba(240, 240, 245, 0.89);
  --nav-border:     rgba(0, 0, 0, 0.10);

  --title-scrolled-bg:     rgba(240, 240, 245, 0.88);
  --title-scrolled-shadow: rgba(0, 0, 0, 0.18);

  color-scheme: light;
}

/* ── Base ──────────────────────────────────────────────── */
body {
  background: var(--bg);
  color: var(--text-primary);
  margin: 0;
}

#root {
  width: 100%;
  height: 100dvh;
  overflow: hidden;
}

/* ── Interactive reset ─────────────────────────────────── */
button {
  cursor: pointer;
  border: none;
  background: none;
  font-family: inherit;
  color: inherit;
  font-size: inherit;
}

input, textarea, select {
  font-family: inherit;
  font-size: inherit;
}

a {
  text-decoration: none;
  color: inherit;
}

/* ── Accessibility: focus ring ─────────────────────────── */
:focus-visible {
  outline: 2px solid #fff;
  outline-offset: 3px;
  border-radius: 6px;
}

/* Skip-to-content link */
.skip-link {
  position: fixed;
  top: -100%;
  left: 50%;
  transform: translateX(-50%);
  background: #fff;
  color: #000;
  padding: 10px 20px;
  border-radius: 0 0 12px 12px;
  font-weight: 700;
  z-index: 9999;
  transition: top 0.15s;
}
.skip-link:focus { top: 0; }

/* Minimum touch target (WCAG 2.5.5) */
button, a, [role="button"] {
  min-height: 44px;
  min-width: 44px;
}

/* Exception: inline text buttons can be smaller */
button.inline { min-height: unset; min-width: unset; }

/* ── Sticky title scroll shadow ────────────────────────── */
.titleScrolled {
  background: var(--title-scrolled-bg) !important;
  backdrop-filter: blur(40px) !important;
  -webkit-backdrop-filter: blur(40px) !important;
  box-shadow: 0 16px 60px 8px var(--title-scrolled-shadow) !important;
}

/* ── iOS zoom fix: inputs < 16px trigger auto-zoom ─────── */
@media (max-width: 767px) {
  input, textarea, select {
    font-size: max(16px, 1em) !important;
  }
}

/* ── Scrollbar ─────────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--border-med); border-radius: 4px; }
/* ── Strip: arrows auto, heute auto, 7 day cols equal ───────*/
._strip_1k04s_2 {
  display: grid;
  grid-template-columns: auto auto repeat(7, 1fr) auto;
  align-items: center;
  gap: 5px;
  padding-inline: 16px;
  padding-bottom: 16px;
  touch-action: pan-y;
  user-select: none;
  -webkit-user-select: none;
}

/* Mobile 5-day-centered mode: arrow + 5 day-cols + arrow (heute-btn is display:none on mobile anyway) */
._stripCentered5_1k04s_15 {
  grid-template-columns: auto auto repeat(5, 1fr) auto;
  gap: 8px;
}

/* Mobile only: reduzierte padding-bottom für vertikale Balance in
   der collapsibleren Calendar-Card (sonst wirkt die Card unten zu leer). */
@media (max-width: 639px) { ._strip_1k04s_2 { padding-bottom: 4px; } }

@media (min-width: 640px)  { ._strip_1k04s_2 { padding-inline: var(--space-5); gap: 6px; } }
@media (min-width: 768px)  { ._strip_1k04s_2 { padding-inline: var(--space-6); } }
@media (min-width: 1024px) { ._strip_1k04s_2 { padding-inline: var(--space-8); } }

/* ── Arrow buttons ─────────────────────────────────────────*/
._arrowBtn_1k04s_29 {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.15);
  width: 44px;
  height: 44px;
  padding: 0;
  min-height: unset;
  min-width: 0;
  color: var(--text-secondary);
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s;
}
._arrowBtn_1k04s_29:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._arrowBtn_1k04s_29 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._arrowBtn_1k04s_29:hover { border-color: rgba(0, 0, 0, 0.35); }

@media (min-width: 640px) {
  ._arrowBtn_1k04s_29 { width: 44px; height: 44px; border-radius: 16px; }
}

/* ── Heute button ──────────────────────────────────────────*/
._heuteBtn_1k04s_54 {
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 14px;
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.15);
  height: 36px;
  padding: 0 10px;
  min-height: unset;
  min-width: 0;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  cursor: pointer;
  white-space: nowrap;
  letter-spacing: 0.03em;
  transition: border-color 0.15s, color 0.15s;
}
._heuteBtn_1k04s_54:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._heuteBtn_1k04s_54 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._heuteBtn_1k04s_54:hover { border-color: rgba(0, 0, 0, 0.35); }

@media (max-width: 1279px) {
  ._heuteBtn_1k04s_54 { display: none; }
}
@media (min-width: 1280px) {
  ._heuteBtn_1k04s_54 { height: 44px; padding: 0 13px; font-size: 12px; border-radius: 16px; }
}

._heuteBtnActive_1k04s_84 {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--btn-fg) !important;
}

/* ── Day cells ─────────────────────────────────────────────*/
._day_1k04s_91 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  padding: 10px 4px 8px;
  border-radius: 16px;
  background: transparent;
  border: 2px solid transparent;
  min-height: 64px;
  min-width: 0;
  cursor: default;
  opacity: 0.35;
  transition: opacity 0.15s;
}

._dayHasEvent_1k04s_108 {
  opacity: 1;
  border-color: rgba(255,255,255,0.12);
  cursor: pointer;
}
._dayHasEvent_1k04s_108:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.22); }
[data-theme="light"] ._dayHasEvent_1k04s_108 { border-color: rgba(0, 0, 0, 0.12); }
[data-theme="light"] ._dayHasEvent_1k04s_108:hover { background: rgba(0, 0, 0, 0.05); border-color: rgba(0, 0, 0, 0.22); }

/* "Today" when also selected → falls through to .daySelected (solid accent bg).
   "Today" when NOT selected → transparent bg with an accent-colored outline so
   it's marked as the current date without competing with the selected day. */
._dayToday_1k04s_120 { background: transparent !important; border-color: var(--text-secondary) !important; opacity: 1; }
._dayToday_1k04s_120:hover { background: var(--overlay-xs) !important; }
._dayToday_1k04s_120 ._dayNum_1k04s_122  { color: var(--text-primary); }
._dayToday_1k04s_120 ._dayName_1k04s_123 { color: var(--text-secondary); }

._dayTodayUnfocused_1k04s_125 { background: transparent !important; border-color: var(--text-secondary) !important; opacity: 1; }
._dayTodayUnfocused_1k04s_125 ._dayNum_1k04s_122  { color: var(--text-primary); }
._dayTodayUnfocused_1k04s_125 ._dayName_1k04s_123 { color: var(--text-secondary); }
._dayTodayUnfocused_1k04s_125 ._dot_1k04s_128     { background: var(--text-primary); }
._dayTodayUnfocused_1k04s_125 ._dotBookmark_1k04s_129 { background: var(--text-primary); }

._daySelected_1k04s_117 {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  opacity: 1;
  transition: none;
}
._daySelected_1k04s_117 ._dayName_1k04s_123 { color: rgba(0,0,0,0.6) !important; }
._daySelected_1k04s_117 ._dayNum_1k04s_122  { color: var(--btn-fg) !important; }
._daySelected_1k04s_117 ._dot_1k04s_128     { background: rgba(0,0,0,0.3); }
._daySelected_1k04s_117 ._dotBookmark_1k04s_129 { background: rgba(180,100,0,0.8); }

/* Light theme: .daySelected bg is black (accent = #000) → invert text color */
[data-theme="light"] ._daySelected_1k04s_117 ._dayName_1k04s_123 { color: rgba(255,255,255,0.6) !important; }
[data-theme="light"] ._daySelected_1k04s_117 ._dot_1k04s_128     { background: rgba(255,255,255,0.4); }

._dayNum_1k04s_122 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  line-height: 1;
}

._dayName_1k04s_123 {
  font-size: 9px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.07em;
}

/* ── Borderless days across all sizes (today + selected keep accent border) ── */
._dayHasEvent_1k04s_108       { border-color: transparent; }
._dayHasEvent_1k04s_108:hover { border-color: transparent; }

@media (min-width: 640px) {
  ._day_1k04s_91    { min-height: 72px; border-radius: 18px; }
  ._dayNum_1k04s_122 { font-size: 22px; }
}

/* ── Tablet (640–1279px): 20% smaller ───────────────────────*/
@media (min-width: 640px) and (max-width: 1279px) {
  ._strip_1k04s_2  { gap: 5px; }
  ._arrowBtn_1k04s_29 { width: 35px; height: 35px; border-radius: 13px; }
  ._heuteBtn_1k04s_54 { display: none; }
  ._day_1k04s_91    { min-height: 58px; border-radius: 14px; }
  ._dayNum_1k04s_122 { font-size: 18px; }
}

/* ── Dot indicator ─────────────────────────────────────────*/
._dotRow_1k04s_180 {
  height: 6px;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 1px;
}

._dot_1k04s_128 {
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.7;
}

._dotBookmark_1k04s_129 { background: #ff9500; opacity: 1; }
._wrap_ywocd_1 { position: relative; }

._trigger_ywocd_3 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  padding: 9px 12px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-height: unset;
}
._trigger_ywocd_3:hover { border-color: rgba(255,255,255,0.32); }
._triggerOpen_ywocd_23 { border-color: var(--accent); background: var(--accent-dim); }
[data-theme="light"] ._trigger_ywocd_3 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._trigger_ywocd_3:hover { border-color: rgba(0,0,0,0.32); }

._value_ywocd_30 { color: var(--text-primary); }
._placeholder_ywocd_31 { color: var(--text-secondary); font-weight: 500; }

._chevron_ywocd_33 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._chevronOpen_ywocd_38 { transform: rotate(180deg); }

._popup_ywocd_40 {
  position: fixed;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 12px;
  z-index: 1300;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
  /* width is set inline to match the trigger field's width */
  min-width: 288px;
}

._popupHeader_ywocd_52 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}

/* ── Wide mode (tablet/desktop) ────────────────────────────── */
._dateDisplay_ywocd_60 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 4px 4px 14px;
  letter-spacing: -0.3px;
  text-transform: capitalize;
}

._todayBtn_ywocd_69 {
  padding: 6px 12px;
  border-radius: 8px;
  background: var(--accent-dim);
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
  min-width: unset;
  cursor: pointer;
  transition: background 0.12s;
}
._todayBtn_ywocd_69:hover { background: rgba(142, 187, 255, 0.2); }

._todayBtnActive_ywocd_83 {
  background: var(--accent) !important;
  color: var(--btn-fg) !important;
}
._todayBtnActive_ywocd_83:hover { background: var(--accent) !important; opacity: 0.9; }

/* Larger day cells in wide mode (tablet/desktop) */
._popupWide_ywocd_90 ._day_ywocd_90 {
  height: 40px;
}

._navBtn_ywocd_94 {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--overlay-sm);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: unset;
  min-width: unset;
  transition: background 0.12s;
  cursor: pointer;
}
._navBtn_ywocd_94:hover { background: var(--accent-dim); color: var(--accent); }

._monthLabel_ywocd_110 {
  flex: 1;
  text-align: center;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  text-transform: capitalize;
}

._weekRow_ywocd_119 {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
  margin-bottom: 4px;
}
._weekday_ywocd_125 {
  text-align: center;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  padding: 4px 0;
}

._grid_ywocd_135 {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 2px;
}

._day_ywocd_90 {
  height: 36px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 8px;
  background: none;
  border: 2px solid transparent;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  cursor: pointer;
  min-height: unset;
  min-width: 0;
  padding: 0;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
._day_ywocd_90:hover { background: var(--overlay-sm); }

._dayOutside_ywocd_160 { color: var(--text-secondary); opacity: 0.4; }

/* Today: transparent fill + solid grey 2px border (theme-aware, well visible).
   When today is also selected, .daySelected below wins (solid accent fill). */
._dayToday_ywocd_164 {
  border-color: var(--text-secondary);
}

._daySelected_ywocd_163,
._daySelected_ywocd_163:hover {
  background: var(--accent);
  color: var(--btn-fg);
  border-color: var(--accent);
}
._backdrop_f45y7_1 {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.9);
  backdrop-filter: blur(8px);
  z-index: 1400;
  display: flex;
  align-items: center;
  justify-content: center;
}

[data-theme="light"] ._modal_f45y7_12 {
  background: #fff;
}
[data-theme="light"] ._cropArea_f45y7_15 {
  background: #f0f0f5;
  box-shadow: 0 0 0 3px rgba(0,0,0,0.15);
}

._modal_f45y7_12 {
  background: #000;
  border: none;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 20px rgba(142,187,255,0.15);
  border-radius: 24px;
  padding: 28px 24px 24px;
  width: 320px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 20px;
}

._title_f45y7_33 {
  font-size: 16px;
  font-weight: 800;
  color: var(--text-primary);
  align-self: flex-start;
}

._cropArea_f45y7_15 {
  width: 240px;
  height: 240px;
  border-radius: 50%;
  overflow: hidden;
  position: relative;
  background: #111;
  cursor: grab;
  flex-shrink: 0;
  box-shadow: 0 0 0 3px rgba(255,255,255,0.15);
  touch-action: none;
}

._cropArea_f45y7_15:active { cursor: grabbing; }

._cropImg_f45y7_55 {
  position: absolute;
  pointer-events: none;
  user-select: none;
  -webkit-user-drag: none;
}

._zoomRow_f45y7_62 {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 10px;
}

._zoomLabel_f45y7_69 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  white-space: nowrap;
}

._zoomSlider_f45y7_78 {
  flex: 1;
  accent-color: var(--text-primary);
  height: 4px;
}

._actions_f45y7_84 {
  display: flex;
  gap: 10px;
  width: 100%;
}

._cancelBtn_f45y7_90 {
  flex: 1;
  padding: 12px;
  border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 700;
  transition: background 0.15s;
}
._cancelBtn_f45y7_90:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }

._confirmBtn_f45y7_102 {
  flex: 2;
  padding: 12px;
  border-radius: var(--btn-radius);
  background: #2f7bff;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  transition: background 0.15s;
}
._confirmBtn_f45y7_102:hover { background: #4a8fff; }
._confirmBtn_f45y7_102:disabled { opacity: 0.5; }
._wrap_1hjfz_1 {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: center;
  flex-wrap: nowrap;
}

._box_1hjfz_9 {
  width: 44px;
  height: 56px;
  padding: 0;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.05);
  border: 1.5px solid rgba(255, 255, 255, 0.18);
  font-size: 24px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  color: var(--text-primary);
  text-align: center;
  caret-color: var(--accent);
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
  -webkit-appearance: none;
  appearance: none;
  min-height: unset;
  min-width: 0;
}
._box_1hjfz_9:focus {
  border-color: var(--accent);
  background: rgba(142, 187, 255, 0.08);
  outline: none;
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.15);
}
._boxFilled_1hjfz_34 {
  border-color: rgba(142, 187, 255, 0.45);
}
._box_1hjfz_9:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

._separator_1hjfz_42 {
  color: var(--text-muted);
  font-weight: 800;
  font-size: 22px;
  padding: 0 2px;
  user-select: none;
}

[data-theme="light"] ._box_1hjfz_9 {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.15);
}
[data-theme="light"] ._box_1hjfz_9:focus {
  background: rgba(0, 112, 243, 0.06);
}
[data-theme="light"] ._boxFilled_1hjfz_34 {
  border-color: rgba(0, 112, 243, 0.5);
}

@media (max-width: 480px) {
  ._wrap_1hjfz_1 { gap: 6px; }
  ._box_1hjfz_9 { width: 40px; height: 52px; font-size: 22px; border-radius: 10px; }
  ._separator_1hjfz_42 { font-size: 20px; padding: 0; }
}
._footerDivider_1o2ax_1 {
  width: 100%;
  height: 1px;
  background: var(--border-dim);
  flex-shrink: 0;
  margin-top: 250px;
}

._footer_1o2ax_1 { padding: 48px 40px 64px; }
@media (max-width: 767px) { ._footer_1o2ax_1 { padding: 40px 24px 56px; } }

/* Mobile/Tablet: extra bottom-padding so the FAB cluster
   (~56px FAB + 16px gap + 24px safety) sits above the footer */
@media (max-width: 1279px) {
  ._footer_1o2ax_1 {
    padding-bottom: calc(56px + 24px + env(safe-area-inset-bottom, 0px));
  }
}

/* Desktop: the WeekCalendar strip is a bottom-fixed pill (~110px tall + 8px gap).
   Push the footer up so its links are fully readable above the pill. */
@media (min-width: 1280px) {
  ._footer_1o2ax_1 {
    padding-bottom: 160px;
  }
}

._footerInner_1o2ax_28 {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

._footerRow_1o2ax_37 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: center;
  margin: 0;
  line-height: 1.8;
}
._footerRow_1o2ax_37 a {
  color: var(--text-secondary);
  font-weight: 600;
  text-decoration: none;
  transition: color 0.15s;
}
._footerRow_1o2ax_37 a:hover { color: var(--text-primary); }

._footerLogo_1o2ax_53 {
  display: flex;
  align-items: center;
  gap: 8px;
}
._page_d6mj5_1 {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  scrollbar-width: none;
  background: var(--bg);
}
._page_d6mj5_1::-webkit-scrollbar { display: none; }

._inner_d6mj5_11 {
  width: 100%;
  display: flex;
  flex-direction: column;
  flex: 1;
}

@media (min-width: 1280px) {
  ._inner_d6mj5_11 {
    max-width: 520px;
    margin: 0 auto;
  }
}

/* ── Modal layout (single column) ── */
._bodyModal_d6mj5_26 {
  padding: 8px 20px 24px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
._colLeft_d6mj5_32, ._colRight_d6mj5_32 { display: contents; }
._colFull_d6mj5_33  { display: flex; flex-direction: column; gap: 8px; }

/* ── Header ── */
._header_d6mj5_36 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 24px 24px 8px;
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 5;
  transition: box-shadow 0.25s, backdrop-filter 0.25s;
}

._backBtn_d6mj5_48 {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  border-radius: 50%;
  border: 1.5px solid var(--border-subtle);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  padding: 0;
  flex-shrink: 0;
  transition: border-color 0.15s, color 0.15s;
}
._backBtn_d6mj5_48:hover { border-color: var(--border-med); color: var(--text-primary); }
._backBtn_d6mj5_48 { display: none; }

._title_d6mj5_67 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

/* ── Body ── */
._body_d6mj5_26 {
  flex: 1;
  padding: 8px 20px 24px;
}

/* ── Card ── */
._card_d6mj5_80 {
  background: #000;
  border: none;
  border-radius: 20px;
  overflow: visible;
  box-shadow: none;
  border: 1px solid rgba(255,255,255,0.15);
}
[data-theme="light"] ._card_d6mj5_80 {
  background: #fff;
  border-color: rgba(0,0,0,0.12);
}

/* ── Divider ── */
._divider_d6mj5_94 {
  height: 1px;
  background: var(--card-border);
  margin: 0;
}

/* ── Section ── */
._section_d6mj5_101 {
  padding: 18px 16px 16px;
}

._sectionLabel_d6mj5_105 {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--text-secondary);
  margin-bottom: 12px;
}

/* ── City grid ── */
._cityGrid_d6mj5_115 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

._cityBtn_d6mj5_121 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 13px 12px;
  border-radius: 14px;
  background: var(--overlay-xs);
  border: 1.5px solid var(--border-subtle);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  transition: all 0.15s;
}
._cityBtn_d6mj5_121:hover { border-color: var(--border-dim); color: var(--text-primary); }
._cityBtnActive_d6mj5_136 {
  background: var(--text-primary) !important;
  border-color: var(--text-primary) !important;
  color: var(--btn-fg) !important;
}

/* ── Month dropdown ── */
._monthWrap_d6mj5_143 {
  position: relative;
}

._monthPill_d6mj5_147 {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  border-radius: var(--pill-radius);
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
}
._monthPill_d6mj5_147:hover { background: var(--overlay-md); border-color: var(--border-dim); }
._monthPillOpen_d6mj5_162 { border-color: var(--accent); background: var(--accent-dim); }

._chevron_d6mj5_164 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._chevronOpen_d6mj5_169 { transform: rotate(180deg); }

._monthDropdown_d6mj5_171 {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 200px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 16px;
  padding: 6px;
  z-index: 100;
  box-shadow: 0 12px 40px rgba(0,0,0,0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

._monthDropdownScrollable_d6mj5_186 {
  max-height: 260px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border-med) transparent;
}
._monthDropdownScrollable_d6mj5_186::-webkit-scrollbar { width: 4px; }
._monthDropdownScrollable_d6mj5_186::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.15); border-radius: 4px; }

._monthItem_d6mj5_195 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  transition: background 0.12s, color 0.12s;
}
._monthItem_d6mj5_195:hover { background: var(--overlay-sm); color: var(--text-primary); }
._monthItemActive_d6mj5_210 { color: var(--accent); }
._monthItemActive_d6mj5_210:hover { background: var(--accent-dim); }

._itemSpacer_d6mj5_213 { width: 13px; flex-shrink: 0; }

._applyBtn_d6mj5_215 {
  display: block;
  width: 100%;
  margin-top: 16px;
  padding: 15px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 16px;
  font-weight: 800;
  transition: opacity 0.15s;
}
._applyBtn_d6mj5_215:hover { opacity: 0.9; }

/* ── Legal card ── */
._legalCard_d6mj5_230 {
  background: #000;
  border: none;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: none;
  border: 1px solid rgba(255,255,255,0.15);
}
[data-theme="light"] ._legalCard_d6mj5_230 {
  background: #fff;
  border-color: rgba(0,0,0,0.12);
}
._legalCardBtn_d6mj5_242 {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  background: transparent;
  transition: background 0.15s;
}
._legalCardBtn_d6mj5_242:hover { background: var(--overlay-sm); }
._legalCardBody_d6mj5_253 {
  padding: 0 20px 16px;
  border-top: 1px solid var(--card-border);
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  animation: _legalExpand_d6mj5_1 0.22s ease;
}

@keyframes _legalExpand_d6mj5_1 {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Avatar card ── */
._avatarSection_d6mj5_268 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 16px 20px;
}

._avatarBtn_d6mj5_276 {
  position: relative;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
}

._avatarImg_d6mj5_286 {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

._avatarInitials_d6mj5_294 {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--overlay-md);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 800;
  color: var(--text-primary);
}

._avatarOverlay_d6mj5_307 {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 0;
  transition: opacity 0.15s;
}
._avatarBtn_d6mj5_276:hover ._avatarOverlay_d6mj5_307 { opacity: 1; }

._hiddenFile_d6mj5_321 { display: none; }

._avatarName_d6mj5_323 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
}

._avatarRole_d6mj5_329 {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
}

/* ── Theme toggle ─────────────────────────────────────────── */
._themeToggle_d6mj5_338 {
  display: flex;
  gap: 8px;
}

._themeBtn_d6mj5_343 {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 16px;
  border-radius: var(--btn-radius);
  background: var(--overlay-xs);
  border: 1.5px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 600;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  min-height: unset;
}
._themeBtn_d6mj5_343:hover {
  background: var(--overlay-sm);
  border-color: var(--border-dim);
  color: var(--text-primary);
}
._themeBtnActive_d6mj5_364 {
  background: var(--accent-dim) !important;
  border-color: var(--accent) !important;
  color: var(--accent) !important;
}
._container_1tf8z_1 {
  position: relative;
  width: 100%;
}

._input_1tf8z_6 {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
  box-sizing: border-box;
}
._input_1tf8z_6:focus { border-color: rgba(255,255,255,0.3); }
._input_1tf8z_6::placeholder { color: #333; }

._dropdown_1tf8z_22 {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--card-bg);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  z-index: 200;
  max-height: 220px;
  overflow-y: auto;
  list-style: none;
  padding: 4px;
  margin: 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45);
}

._option_1tf8z_39 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.1s;
}
._option_1tf8z_39:hover { background: rgba(255,255,255,0.06); }

._name_1tf8z_51 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

._city_1tf8z_61 {
  font-size: 11px;
  color: var(--text-secondary);
  flex-shrink: 0;
}
._wrap_11x6v_1 { position: relative; }

._trigger_11x6v_3 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  padding: 9px 12px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-height: unset;
}
._trigger_11x6v_3:hover { border-color: rgba(255,255,255,0.32); }
._triggerOpen_11x6v_23 { border-color: var(--accent); background: var(--accent-dim); }
[data-theme="light"] ._trigger_11x6v_3 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._trigger_11x6v_3:hover { border-color: rgba(0,0,0,0.32); }

._value_11x6v_30 { color: var(--text-primary); }
._placeholder_11x6v_31 { color: var(--text-secondary); font-weight: 500; }

._chevron_11x6v_33 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._chevronOpen_11x6v_38 { transform: rotate(180deg); }

._popup_11x6v_40 {
  position: fixed;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 18px;
  z-index: 1300;
  min-width: 180px;
  padding: 12px;
  box-shadow: 0 16px 48px rgba(0,0,0,0.6);
  overflow: hidden;
  box-sizing: border-box;
}

._wheels_11x6v_53 {
  display: flex;
  align-items: stretch;
  gap: 4px;
  position: relative;
  height: 200px;
}

._selectionFrame_11x6v_61 {
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  height: 40px;
  transform: translateY(-50%);
  border-top: 1px solid var(--accent-dim);
  border-bottom: 1px solid var(--accent-dim);
  pointer-events: none;
  z-index: 2;
}

._wheel_11x6v_53 {
  flex: 1;
  height: 200px;
  overflow-y: scroll;
  overflow-x: hidden;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(to bottom, transparent 0%, black 32%, black 68%, transparent 100%);
  mask-image: linear-gradient(to bottom, transparent 0%, black 32%, black 68%, transparent 100%);
  scroll-behavior: smooth;
}
._wheel_11x6v_53::-webkit-scrollbar { display: none; width: 0; height: 0; }

._spacer_11x6v_88 {
  height: 80px;
  scroll-snap-align: none;
  pointer-events: none;
}

._item_11x6v_94 {
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  scroll-snap-align: center;
  scroll-snap-stop: always;
  font-size: 16px;
  font-weight: 500;
  color: var(--text-secondary);
  background: none;
  border: none;
  cursor: pointer;
  min-height: unset;
  padding: 0;
  width: 100%;
  font-family: inherit;
  transition: color 0.18s, font-size 0.18s, font-weight 0.18s;
}
._itemSelected_11x6v_113 {
  color: var(--accent);
  font-size: 18px;
  font-weight: 700;
}

._separator_11x6v_119 {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 700;
  color: var(--accent);
  padding-bottom: 2px;
  flex: 0 0 12px;
  z-index: 1;
}

._footer_11x6v_131 {
  margin-top: 10px;
  display: flex;
  justify-content: center;
}

._confirmBtn_11x6v_137 {
  background: var(--accent);
  color: var(--btn-fg);
  border: none;
  width: 100%;
  padding: 10px 18px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  min-height: unset;
  transition: opacity 0.15s;
}
._confirmBtn_11x6v_137:hover { opacity: 0.88; }
@keyframes _fadeIn_15b2x_1 {
  from { opacity: 0; }
  to   { opacity: 1; }
}
@keyframes _fadeOut_15b2x_1 {
  from { opacity: 1; }
  to   { opacity: 0; }
}
@keyframes _slideUp_15b2x_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

._backdrop_15b2x_14 {
  position: fixed;
  inset: 0;
  z-index: 1250;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: _fadeIn_15b2x_1 0.2s ease;
}

._backdropClosing_15b2x_26 {
  animation: _fadeOut_15b2x_1 0.2s ease forwards;
}

[data-theme="light"] ._modal_15b2x_30 {
  background: #fff;
}

._modal_15b2x_30 {
  background: #000;
  border: none;
  border-radius: 20px;
  width: 100%;
  max-width: 400px;
  max-height: 90dvh;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  animation: _slideUp_15b2x_1 0.2s ease;
}

._modalHeader_15b2x_48 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 0;
}

._modalTitle_15b2x_55 {
  font-size: 18px;
  font-weight: 800;
  color: var(--text-primary);
}

._closeBtn_15b2x_61 {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--overlay-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
}
._closeBtn_15b2x_61:hover { background: var(--overlay-md); color: var(--text-primary); }

._modalBody_15b2x_74 { padding: 20px; }

/* ── Shared dropdown classes (also consumed by Header & AdminPage) ───
   Kept here because Header.tsx and AdminPage.tsx import this module
   for their month/scrape filter dropdowns. */
._typeWrap_15b2x_79 { position: relative; }
._typeBtn_15b2x_80 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  padding: 10px 14px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-height: unset;
}
._typeBtn_15b2x_80:hover { border-color: rgba(255,255,255,0.32); }
._typeBtnOpen_15b2x_100 { border-color: var(--accent); background: var(--accent-dim); }

[data-theme="light"] ._typeBtn_15b2x_80 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._typeBtn_15b2x_80:hover { border-color: rgba(0,0,0,0.32); }

._typeChevron_15b2x_108 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._typeChevronOpen_15b2x_113 { transform: rotate(180deg); }

._typeDropdown_15b2x_115 {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 6px;
  z-index: 100;
  box-shadow: 0 12px 40px rgba(0,0,0,0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
._typeOption_15b2x_129 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  background: none;
  transition: background 0.12s, color 0.12s;
  cursor: pointer;
}
._typeOption_15b2x_129:hover { background: var(--overlay-sm); color: var(--text-primary); }
._typeOptionActive_15b2x_146 { color: var(--accent); }
._typeOptionActive_15b2x_146:hover { background: var(--accent-dim); }
._typeOptionSpacer_15b2x_148 { width: 13px; flex-shrink: 0; }
._pageLayout_zkw1h_1 {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

._page_zkw1h_1 {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  overflow-x: clip;
  scrollbar-width: none;
  padding-bottom: 32px;
}
._page_zkw1h_1::-webkit-scrollbar { display: none; }

._inner_zkw1h_21 {
  max-width: 70%;
  width: 100%;
  margin-left: 15vw;
  display: flex;
  flex-direction: column;
  flex: 1;
}

._innerContributor_zkw1h_30 {
  max-width: 70%;
  margin-left: 15vw;
}

@media (max-width: 639px) {
  ._inner_zkw1h_21 { max-width: 100%; margin-left: 0; }
  ._innerContributor_zkw1h_30 { max-width: 100%; margin-left: 0; }
}

/* Tablet: match BookmarksPage content width */
@media (min-width: 640px) and (max-width: 1279px) {
  ._inner_zkw1h_21 { max-width: 92%; margin: 0 auto; }
  ._innerContributor_zkw1h_30 { max-width: 92%; margin: 0 auto; }
}

._header_zkw1h_46 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0;
  padding: 24px 24px 8px;
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 5;
  transition: box-shadow 0.25s, backdrop-filter 0.25s;
}
@media (max-width: 1279px) {
  ._header_zkw1h_46 { top: 0; padding-top: 8px; }
}

/* Desktop: break header out of the centered .inner (max-width: 70%) so the
   sticky-scroll background + drop-shadow span the full page width. */
@media (min-width: 1280px) {
  ._header_zkw1h_46 {
    width: 100vw;
    margin-left: -15vw;
    padding: 24px 15vw 8px;
  }
}

._headerLeft_zkw1h_72 {
  display: flex;
  align-items: center;
  gap: 6px;
}

._titleGroup_zkw1h_78 {
  display: flex;
  align-items: center;
  gap: 6px;
}

._titleIcon_zkw1h_84 {
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-primary);
}

._countBadge_zkw1h_91 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
  flex-shrink: 0;
}

._backBtn_zkw1h_101 {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  border-radius: 50%;
  border: 1.5px solid rgba(255, 255, 255, 0.2);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  padding: 0;
  flex-shrink: 0;
  transition: border-color 0.15s, color 0.15s;
}
._backBtn_zkw1h_101:hover { border-color: rgba(255, 255, 255, 0.5); color: var(--text-primary); }
._backBtn_zkw1h_101 { display: none; }

._title_zkw1h_78 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

._subtitle_zkw1h_126 {
  display: block;
  font-size: 12px;
  color: var(--text-secondary);
  margin-top: 2px;
}

._dbExportBtn_zkw1h_133 {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: 10px;
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  margin-left: auto;
  transition: color 0.15s, background 0.15s;
}
._dbExportBtn_zkw1h_133:hover { color: var(--text-primary); background: var(--overlay-md); }

._logoutBtn_zkw1h_149 {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--card-bg);
  border-radius: 12px;
  padding: 8px 14px;
  transition: color 0.15s;
}
._logoutBtn_zkw1h_149:hover { color: var(--text-primary); }

/* ── Top 2-column grid ── */
._topGrid_zkw1h_164 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: start;
  gap: 0;
}

._toolsCol_zkw1h_171 {
  display: flex;
  flex-direction: column;
}

@media (max-width: 900px) {
  ._topGrid_zkw1h_164 { grid-template-columns: 1fr; }
}

._section_zkw1h_180 { padding: 12px 20px; }

._sectionTitle_zkw1h_182 {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 14px;
}

._form_zkw1h_191 {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--card-bg);
  border-radius: 20px;
  padding: 20px;
}

._row_zkw1h_200 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

._field_zkw1h_206 {
  display: flex;
  flex-direction: column;
  gap: 5px;
  min-width: 0;
}

._field_zkw1h_206 label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

._field_zkw1h_206 input,
._field_zkw1h_206 textarea,
._extraSupportBlock_zkw1h_223 input,
._extraSupportBlock_zkw1h_223 textarea {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  outline: none;
  width: 100%;
  box-sizing: border-box;
  min-width: 0;
  transition: border-color 0.15s;
  resize: none;
}
/* Description textareas get a vertical resize handle (only place where user
   benefit is real — long event descriptions). */
._field_zkw1h_206 textarea._descriptionTextarea_zkw1h_240,
._extraSupportBlock_zkw1h_223 textarea._descriptionTextarea_zkw1h_240 {
  resize: vertical;
  min-height: 80px;
}
._field_zkw1h_206 input[type="date"] { color-scheme: dark; max-width: 100%; }
._field_zkw1h_206 input:focus, ._field_zkw1h_206 textarea:focus { border-color: rgba(255,255,255,0.3); }
._field_zkw1h_206 input::placeholder, ._field_zkw1h_206 textarea::placeholder { color: #555; }

/* Image input */
._imageInput_zkw1h_250 {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

._imageUrlInput_zkw1h_256 {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.15s;
}
._imageUrlInput_zkw1h_256:focus { border-color: rgba(255,255,255,0.3); }
._imageUrlInput_zkw1h_256::placeholder { color: #555; }

._orDivider_zkw1h_269 {
  font-size: 11px;
  color: var(--text-secondary);
  text-align: center;
  position: relative;
}
._orDivider_zkw1h_269::before, ._orDivider_zkw1h_269::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 40%;
  height: 1px;
  background: rgba(255,255,255,0.08);
}
._orDivider_zkw1h_269::before { left: 0; }
._orDivider_zkw1h_269::after { right: 0; }

._hiddenFile_zkw1h_286 { display: none; }

._uploadLabel_zkw1h_288 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgba(255,255,255,0.05);
  border: 1px dashed rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}
._uploadLabel_zkw1h_288:hover {
  border-color: rgba(255,255,255,0.35);
  color: var(--text-primary);
}

._imgPreview_zkw1h_308 {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 16/7;
}
._imgPreview_zkw1h_308 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
._imgPreview_zkw1h_308 button {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: rgba(0,0,0,0.7);
  color: #fff;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
}

._submitBtn_zkw1h_334 {
  padding: 14px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 16px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._submitBtn_zkw1h_334:hover { opacity: 0.9; }
._submitBtn_zkw1h_334:disabled { opacity: 0.5; }

._extraSupportBlock_zkw1h_223 {
  display: flex; flex-direction: column; gap: 8px;
  padding: 12px; background: rgba(255,255,255,0.03);
  border-radius: 10px; border: 1px solid rgba(255,255,255,0.08);
}
[data-theme="light"] ._extraSupportBlock_zkw1h_223 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.10);
}
._extraSupportHeader_zkw1h_355 {
  display: flex; justify-content: space-between; align-items: center;
}
._extraSupportHeader_zkw1h_355 label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-secondary); }
._removeExtraBtn_zkw1h_359 { font-size: 12px; color: var(--text-secondary); background: none; padding: 2px 6px; transition: color 0.15s; }
._removeExtraBtn_zkw1h_359:hover { color: var(--text-primary); }
._addSupportBtn_zkw1h_361 {
  font-size: 13px; font-weight: 600; color: var(--accent);
  background: rgba(142,187,255,0.07); border: 1px dashed rgba(142,187,255,0.3);
  border-radius: 10px; padding: 10px; transition: background 0.15s; width: 100%;
}
._addSupportBtn_zkw1h_361:hover { background: rgba(142,187,255,0.12); }

._filterSelects_zkw1h_368 {
  display: flex;
  gap: 10px;
  margin-left: auto;
  align-items: flex-end;
}

@media (max-width: 639px) {
  ._filterSelects_zkw1h_368 { display: none; }
}

/* ── Mobile filter toggle ───────────────────────────────── */
._mobileFilterWrap_zkw1h_380 {
  display: none;
  position: relative;
  margin-left: auto;
}

@media (max-width: 639px) {
  ._mobileFilterWrap_zkw1h_380 { display: block; }
}

._mobileFilterBtn_zkw1h_390 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 5px;
  padding: 6px 10px;
  border-radius: 10px;
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  min-height: unset;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  position: relative;
}
._mobileFilterBtn_zkw1h_390:hover { background: var(--overlay-sm); color: var(--text-primary); }
._mobileFilterBtnOpen_zkw1h_407   { border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }

._mobileFilterDot_zkw1h_409 {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  position: absolute;
  top: 4px;
  right: 4px;
}

._mobileFilterDropdown_zkw1h_419 {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  width: 260px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 12px;
  z-index: 50;
  box-shadow: 0 12px 40px var(--dropdown-shadow);
  display: flex;
  flex-direction: column;
  gap: 12px;
}

._mobileFilterItem_zkw1h_435 {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

._searchInputFull_zkw1h_441 {
  width: 100% !important;
}
._searchInputFull_zkw1h_441:focus {
  width: 100% !important;
}

._selectFull_zkw1h_448 {
  width: 100%;
}

._filterSelectGroup_zkw1h_452 {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

._filterSelectLabel_zkw1h_458 {
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
  padding-left: 2px;
}

._searchWrapper_zkw1h_467 {
  position: relative;
  display: flex;
  align-items: center;
}

._searchIcon_zkw1h_473 {
  position: absolute;
  left: 10px;
  color: var(--text-secondary);
  pointer-events: none;
  flex-shrink: 0;
}

._searchInput_zkw1h_441 {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 6px 28px 6px 28px;
  font-size: 12px;
  font-weight: 500;
  font-family: inherit;
  color: var(--text-primary);
  outline: none;
  width: 180px;
  transition: border-color 0.15s, width 0.2s;
}
._searchInput_zkw1h_441:focus {
  border-color: rgba(255,255,255,0.3);
  width: 220px;
}
._searchInput_zkw1h_441::placeholder { color: #444; }

._searchClear_zkw1h_500 {
  position: absolute;
  right: 8px;
  font-size: 14px;
  line-height: 1;
  color: var(--text-secondary);
  padding: 0 2px;
  transition: color 0.15s;
}
._searchClear_zkw1h_500:hover { color: var(--text-primary); }

/* ── PAST badge ── */
._pastBadge_zkw1h_512 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: #8b8b8b;
  background: rgba(139,139,139,0.15);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

/* Scraper auto-published, recent — "★ NEU" */
._newBadge_zkw1h_524 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: var(--text-secondary);
  background: var(--overlay-md);
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

/* Scraper updated recently — "↻ DD.MM." */
._updatedBadge_zkw1h_537 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
  background: var(--overlay-md);
  border: 1px solid var(--border-dim);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

/* Event list */
._listHeader_zkw1h_550 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
  gap: 12px;
}

._selectAllLabel_zkw1h_558 {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
}
._selectAllLabel_zkw1h_558 input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--text-primary);
  cursor: pointer;
  flex-shrink: 0;
}

._bulkActions_zkw1h_572 {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}

._bulkPublishBtn_zkw1h_579 {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  color: #4caf50;
  background: rgba(76, 175, 80, 0.12);
  border-radius: 10px;
  padding: 6px 10px;
  transition: background 0.15s;
  white-space: nowrap;
}
._bulkPublishBtn_zkw1h_579:hover { background: rgba(76, 175, 80, 0.22); }

._bulkDraftBtn_zkw1h_594 {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  padding: 6px 10px;
  transition: background 0.15s;
  white-space: nowrap;
}
._bulkDraftBtn_zkw1h_594:hover { background: rgba(255, 255, 255, 0.12); }

._bulkDeleteBtn_zkw1h_609 {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 12px;
  font-weight: 700;
  color: #ff4444;
  background: rgba(255, 68, 68, 0.1);
  border-radius: 10px;
  padding: 6px 10px;
  transition: background 0.15s;
  white-space: nowrap;
}
._bulkDeleteBtn_zkw1h_609:hover { background: rgba(255, 68, 68, 0.2); }

._venueFilterSelect_zkw1h_624 {
  appearance: auto;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 10px;
  padding: 6px 10px;
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  color: var(--text-primary);
  cursor: pointer;
  outline: none;
  color-scheme: dark;
  transition: border-color 0.15s;
  max-width: 180px;
}
._venueFilterSelect_zkw1h_624:hover { border-color: rgba(255,255,255,0.2); }
._venueFilterSelect_zkw1h_624:focus { border-color: rgba(255,255,255,0.35); }

._eventList_zkw1h_643 { display: flex; flex-direction: column; gap: 4px; }

._eventRow_zkw1h_645 {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--card-bg);
  border-radius: 14px;
  padding: 10px 14px;
  transition: background 0.15s, border-color 0.15s;
  cursor: pointer;
  border: 1px solid transparent;
}
._eventRow_zkw1h_645:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }

._eventRowSelected_zkw1h_658 {
  background: rgba(255, 255, 255, 0.07);
}

._eventRowActive_zkw1h_662 {
  background: var(--overlay-sm);
  border-color: var(--accent);
  border-width: 1px;
}

._rowCheckbox_zkw1h_668 {
  width: 16px;
  height: 16px;
  accent-color: var(--text-primary);
  cursor: pointer;
  flex-shrink: 0;
}

._eventThumb_zkw1h_676 {
  width: 48px;
  height: 48px;
  border-radius: 10px;
  overflow: hidden;
  background: rgba(255,255,255,0.05);
  flex-shrink: 0;
}
._eventThumb_zkw1h_676 img { width: 100%; height: 100%; object-fit: cover; }

._eventInfo_zkw1h_686 { flex: 1; display: flex; flex-direction: column; gap: 2px; min-width: 0; }

._eventArtistRow_zkw1h_688 {
  display: flex;
  align-items: center;
  gap: 6px;
}

._draftBadge_zkw1h_694 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: var(--text-secondary);
  background: var(--overlay-md);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

/* ── Contributor approval section ── */
._contributorSection_zkw1h_706 {
  margin: 0 24px 4px;
  background: rgba(142, 187, 255, 0.05);
  border: 1px solid rgba(142, 187, 255, 0.2);
  border-radius: 16px;
  overflow: hidden;
}

._contributorSectionHeader_zkw1h_714 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px 10px;
  color: #8EBBFF;
  border-bottom: 1px solid rgba(142, 187, 255, 0.12);
}

._contributorSectionTitle_zkw1h_723 {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}

._contributorList_zkw1h_730 {
  display: flex;
  flex-direction: column;
}

._contributorRow_zkw1h_735 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  border-bottom: 1px solid rgba(142, 187, 255, 0.08);
}
._contributorRow_zkw1h_735:last-child { border-bottom: none; }

._contributorThumb_zkw1h_744 {
  width: 40px;
  height: 40px;
  border-radius: 8px;
  background: rgba(255,255,255,0.05);
  flex-shrink: 0;
  overflow: hidden;
}
._contributorThumb_zkw1h_744 img { width: 100%; height: 100%; object-fit: cover; }

._contributorInfo_zkw1h_754 {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

._contributorArtist_zkw1h_762 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

._contributorMeta_zkw1h_768 {
  font-size: 12px;
  color: var(--text-secondary);
}

._contributorBy_zkw1h_773 {
  font-size: 11px;
  color: #8EBBFF;
}

._contributorActions_zkw1h_778 {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

._reviewBtn_zkw1h_785 {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 700;
  min-height: unset;
  transition: background 0.15s, color 0.15s;
}
._reviewBtn_zkw1h_785:hover { background: rgba(255, 255, 255, 0.1); color: var(--text-primary); }

._approveBtn_zkw1h_801,
._rejectBtn_zkw1h_802 {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px 10px;
  border-radius: 8px;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.12);
  color: var(--text-primary);
  font-size: 12px;
  font-weight: 700;
  min-height: unset;
  transition: background 0.15s, border-color 0.15s;
}
._approveBtn_zkw1h_801:hover,
._rejectBtn_zkw1h_802:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

[data-theme="light"] ._approveBtn_zkw1h_801,
[data-theme="light"] ._rejectBtn_zkw1h_802 {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.12);
  color: var(--text-primary);
}
[data-theme="light"] ._approveBtn_zkw1h_801:hover,
[data-theme="light"] ._rejectBtn_zkw1h_802:hover {
  background: rgba(0, 0, 0, 0.07);
  border-color: rgba(0, 0, 0, 0.2);
}

@media (max-width: 480px) {
  ._contributorSection_zkw1h_706 { margin: 0 12px 4px; }
  ._contributorRow_zkw1h_735 { flex-wrap: wrap; }
  ._contributorInfo_zkw1h_754 { flex-basis: calc(100% - 52px); }
  ._contributorActions_zkw1h_778 { width: 100%; margin-top: 8px; }
  ._reviewBtn_zkw1h_785,
  ._approveBtn_zkw1h_801,
  ._rejectBtn_zkw1h_802 { flex: 1; justify-content: center; padding: 8px 6px; }
}

._rejectedBadge_zkw1h_844 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: var(--text-secondary);
  background: var(--overlay-md);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

._contributorBadge_zkw1h_855 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: var(--text-secondary);
  background: var(--overlay-md);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

._contributorNotice_zkw1h_866 {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 0 24px 0;
  padding: 10px 14px;
  background: rgba(142, 187, 255, 0.08);
  border: 1px solid rgba(142, 187, 255, 0.2);
  border-radius: 12px;
  font-size: 13px;
  color: #8EBBFF;
}

._eventArtist_zkw1h_688 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
._eventMeta_zkw1h_887 { font-size: 11px; color: var(--text-secondary); }

/* Import box */
._importBox_zkw1h_890 {
  background: var(--card-bg);
  border-radius: 20px;
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

._uploadLabelDisabled_zkw1h_899 {
  opacity: 0.5;
  cursor: not-allowed;
  pointer-events: none;
}

._importHint_zkw1h_905 {
  font-size: 11px;
  color: var(--text-secondary);
  text-align: center;
  line-height: 1.4;
}

._importSuccess_zkw1h_912 {
  font-size: 12px;
  font-weight: 700;
  color: #4caf50;
  text-align: center;
}

/* Per-row publish/draft toggle */
._publishBtn_zkw1h_920 {
  color: #4caf50;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._publishBtn_zkw1h_920:hover { background: rgba(76, 175, 80, 0.15); }

._unpublishBtn_zkw1h_929 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._unpublishBtn_zkw1h_929:hover { color: #ff9500; background: rgba(255, 149, 0, 0.1); }

._deleteBtn_zkw1h_938 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
}
._deleteBtn_zkw1h_938:hover { color: #ff4444; background: rgba(255,68,68,0.1); }

._confirmRow_zkw1h_947 {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
}
._confirmYes_zkw1h_954 {
  font-size: 12px;
  font-weight: 700;
  color: #ff4444;
  background: rgba(255,68,68,0.1);
  border-radius: 8px;
  padding: 4px 10px;
}
._confirmNo_zkw1h_962 {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  padding: 4px 10px;
}

/* ── Sync Venues ────────────────────────────────────────── */
@keyframes _spin_zkw1h_1 {
  to { transform: rotate(360deg); }
}

._syncBox_zkw1h_976 {
  background: var(--card-bg);
  border-radius: 20px;
  padding: 16px 20px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

._syncStopBtn_zkw1h_985 {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 8px 14px;
  border-radius: 12px;
  background: rgba(255, 68, 68, 0.12);
  border: 1px solid rgba(255, 68, 68, 0.3);
  color: #ff6b6b;
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
  transition: background 0.15s;
}
._syncStopBtn_zkw1h_985:hover { background: rgba(255, 68, 68, 0.22); }

._syncVenueSelect_zkw1h_1001 {
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  cursor: pointer;
  color-scheme: dark;
  transition: border-color 0.15s;
  width: 100%;
}
._syncVenueSelect_zkw1h_1001:focus { border-color: rgba(255,255,255,0.3); }

._syncBtn_zkw1h_1018 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  border: none;
  transition: opacity 0.15s;
}
._syncBtn_zkw1h_1018:hover:not(:disabled) { opacity: 0.88; }
._syncBtn_zkw1h_1018:disabled { opacity: 0.5; cursor: not-allowed; }
._syncBtnActive_zkw1h_1034 { opacity: 0.75; }

._syncLog_zkw1h_1036 {
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: rgba(0,0,0,0.2);
  border-radius: 12px;
  padding: 12px 14px;
}

._syncLogRow_zkw1h_1045 {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 12px;
}

._syncDot_zkw1h_1052 {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #4caf50;
  flex-shrink: 0;
}
._syncDotError_zkw1h_1058 {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #ff4444;
  flex-shrink: 0;
}
._syncDotPending_zkw1h_1064 {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #63b3ed;
  flex-shrink: 0;
  animation: _pulse_zkw1h_1 1s ease-in-out infinite;
}
@keyframes _pulse_zkw1h_1 {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.3; }
}

._syncVenueName_zkw1h_1076 {
  font-weight: 600;
  color: var(--text-primary);
  flex: 1;
}
._syncStatus_zkw1h_1081 { color: var(--text-secondary); }

/* ── Row action group ───────────────────────────────────── */
._rowActions_zkw1h_1084 {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
  margin-left: auto;
}

@media (max-width: 639px) {
  ._rowActions_zkw1h_1084 { gap: 0; }
}

/* ── Edit button ────────────────────────────────────────── */
._editBtn_zkw1h_1097 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._editBtn_zkw1h_1097:hover { color: var(--text-primary); background: rgba(255,255,255,0.08); }

/* ── Edit panel ─────────────────────────────────────────── */
._editBackdrop_zkw1h_1107 {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  z-index: 200;
  opacity: 0;
  transition: opacity 0.25s ease;
}
._editBackdropVisible_zkw1h_1117 { opacity: 1; }

@media (max-width: 1279px) {
  ._editBackdrop_zkw1h_1107 {
    display: block;
    top: calc(56px + env(safe-area-inset-top));
    inset: unset;
    left: 0; right: 0; bottom: 0;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
  }
}

/* Desktop: in-flow within panelSlot */
._editPanel_zkw1h_1130 {
  width: 100%;
  height: 100%;
  background: var(--bg);
  border-left: 1px solid var(--nav-border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  scrollbar-width: none;
  touch-action: pan-y;
  overscroll-behavior-x: contain;
}
._editPanel_zkw1h_1130::-webkit-scrollbar { display: none; }
._editPanelVisible_zkw1h_1143 { transform: none; }

/* Panel slot — flex sibling on desktop, fixed overlay on mobile */
._panelSlot_zkw1h_1146 {
  width: 0;
  flex-shrink: 0;
  overflow: hidden;
  transition: width 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}
._panelSlotOpen_zkw1h_1152 { width: 420px; }

@media (max-width: 1279px) {
  ._panelSlot_zkw1h_1146 {
    position: fixed !important;
    top: calc(56px + env(safe-area-inset-top)); right: 0;
    width: 420px !important;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
    z-index: 201;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
    overflow: hidden;
  }
  ._panelSlotOpen_zkw1h_1152 { transform: translateX(0) !important; }
}
@media (max-width: 480px) {
  ._panelSlot_zkw1h_1146 { width: 100vw !important; }
  ._editPanelHeader_zkw1h_1169 { padding-top: 20px; }
  ._row_zkw1h_200 { grid-template-columns: 1fr; }
}

/* ── Embedded inside MainMenuSheet sub-screen (mobile) ──────────
   Panel slides in over the sub-screen body but NOT the sheet's
   sub-header. Override .pageLayout's `display: contents` so it
   becomes a real bounded container that the panel can absolute-fill. */
@media (max-width: 1279px) {
  ._pageLayoutModal_zkw1h_1178 {
    display: flex !important;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    max-height: calc(100dvh - 82px - max(40px, env(safe-area-inset-top, 0px) + 20px));
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  ._pageLayoutModal_zkw1h_1178 ._page_zkw1h_1 { flex: 1; min-height: 0; }
  ._pageLayoutModal_zkw1h_1178 ._panelSlot_zkw1h_1146 {
    position: absolute !important;
    top: 0 !important;
    bottom: 0 !important;
    right: 0 !important;
    left: 0 !important;
    height: auto !important;
    width: 100% !important;
    z-index: 5;
    display: block;
    transform: none !important;
    /* When panel is closed, don't block clicks on the event list below. */
    pointer-events: none;
  }
  ._pageLayoutModal_zkw1h_1178 ._panelSlotOpen_zkw1h_1152 {
    transform: none !important;
    pointer-events: auto;
  }
  ._pageLayoutModal_zkw1h_1178 ._editPanel_zkw1h_1130 {
    background: #000;
    width: 100%;
    height: 100%;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden;
    animation: _editPanelFadeIn_zkw1h_1 0.28s ease both;
  }
  ._pageLayoutModal_zkw1h_1178 ._editPanelHeader_zkw1h_1169 { flex: 0 0 auto; }
  ._pageLayoutModal_zkw1h_1178 ._editPanelBody_zkw1h_1217 {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }
  ._pageLayoutModal_zkw1h_1178 ._editPanelFooter_zkw1h_1222 {
    flex: 0 0 auto;
    background: #000;
    padding: 16px 20px calc(16px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--card-border);
  }
}
@keyframes _editPanelFadeIn_zkw1h_1 {
  from { opacity: 0; }
  to { opacity: 1; }
}
@media (max-width: 1279px) {
  /* Panel fills the entire sub-screen body, so the backdrop has no visible
     click area. Hide it — user closes via the X button on panel header. */
  ._editBackdropModal_zkw1h_1236 {
    display: none !important;
  }
  ._pageLayoutModal_zkw1h_1178 ._editPanelHeader_zkw1h_1169 { padding-top: 16px; }
}

._editPanelHeader_zkw1h_1169 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--card-border);
  flex-shrink: 0;
}

._editPanelTitle_zkw1h_1251 {
  font-size: 16px;
  font-weight: 800;
  color: var(--text-primary);
}

._editCloseBtn_zkw1h_1257 {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
}
._editCloseBtn_zkw1h_1257:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }

._editPanelBody_zkw1h_1217 {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: none;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
._editPanelBody_zkw1h_1217::-webkit-scrollbar { display: none; }

._editImgPreview_zkw1h_1281 {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 3/4;
  background: rgba(255,255,255,0.04);
  flex-shrink: 0;
}
._editImgPreview_zkw1h_1281 img { width: 100%; height: 100%; object-fit: cover; }

._positionPicker_zkw1h_1291 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: repeat(3, 18px);
  gap: 4px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  padding: 6px;
  border-radius: 10px;
}

._positionDot_zkw1h_1305 {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.35);
  border: none;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  min-height: unset;
  min-width: unset;
  padding: 0;
}
._positionDot_zkw1h_1305:hover { background: rgba(255,255,255,0.65); transform: scale(1.15); }
._positionDotActive_zkw1h_1318 { background: #fff !important; transform: scale(1.15); }

._editSelect_zkw1h_1320 {
  appearance: auto;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  color-scheme: dark;
  transition: border-color 0.15s;
}
._editSelect_zkw1h_1320:focus { border-color: rgba(255,255,255,0.3); }

._editPanelFooter_zkw1h_1222 {
  display: flex;
  gap: 10px;
  padding: 16px 20px;
  border-top: 1px solid var(--card-border);
  flex-shrink: 0;
}

._editCancelBtn_zkw1h_1343 {
  flex: 1;
  padding: 13px;
  border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 700;
  transition: background 0.15s;
}
._editCancelBtn_zkw1h_1343:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }

._editSaveBtn_zkw1h_1355 {
  flex: 2;
  padding: 13px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._editSaveBtn_zkw1h_1355:hover { opacity: 0.9; }
._editSaveBtn_zkw1h_1355:disabled { opacity: 0.5; }

/* ── User list ──────────────────────────────────────────── */
._userList_zkw1h_1369 {
  display: flex;
  flex-direction: column;
  gap: 4px;
  margin-bottom: 20px;
}

._userRow_zkw1h_1376 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--card-bg);
  border-radius: 14px;
  padding: 12px 14px;
}

._userInfo_zkw1h_1385 {
  display: flex;
  align-items: center;
  gap: 10px;
}

._userUsername_zkw1h_1391 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

._userRole_zkw1h_1397 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  background: rgba(142, 187, 255, 0.1);
  border-radius: 6px;
  padding: 2px 7px;
}

._userActions_zkw1h_1408 {
  display: flex;
  align-items: center;
  gap: 4px;
}

._subSectionTitle_zkw1h_1414 {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 10px;
}

/* ── Tab navigation ── */
._tabNav_zkw1h_1424 {
  display: flex;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  margin: 50px 24px 8px;
  gap: 0;
}

._tab_zkw1h_1424 {
  position: relative;
  padding: 10px 18px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  background: none;
  border: none;
  white-space: nowrap;
  transition: color 0.15s;
  letter-spacing: 0.01em;
}
._tab_zkw1h_1424:hover { color: var(--text-primary); }
._tab_zkw1h_1424::after {
  content: '';
  position: absolute;
  bottom: -1px;
  left: 0;
  right: 0;
  height: 2px;
  background: var(--text-primary);
  border-radius: 2px 2px 0 0;
  opacity: 0;
  transform: scaleX(0.4);
  transition: opacity 0.15s, transform 0.15s;
}
._tabActive_zkw1h_1457 {
  color: var(--text-primary) !important;
}
._tabActive_zkw1h_1457::after {
  opacity: 1 !important;
  transform: scaleX(1) !important;
}

/* ── Venue list ── */
._venueListHeader_zkw1h_1466 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 14px;
}

._newVenueBtn_zkw1h_1473 {
  padding: 7px 14px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._newVenueBtn_zkw1h_1473:hover { opacity: 0.85; }

._syncVenuesBtn_zkw1h_1484 {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 6px 12px;
  border-radius: 10px;
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  transition: color 0.15s, background 0.15s;
}
._syncVenuesBtn_zkw1h_1484:hover:not(:disabled) { color: var(--text-primary); background: var(--overlay-md); }
._syncVenuesBtn_zkw1h_1484:disabled { opacity: 0.5; }

._venueEditImgRow_zkw1h_1500 {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

._venueEditImgPreview_zkw1h_1507 {
  width: 64px;
  height: 64px;
  object-fit: cover;
  border-radius: 10px;
  flex-shrink: 0;
}

._venueEditImgRemove_zkw1h_1515 {
  font-size: 13px;
  color: var(--text-secondary);
  padding: 4px 8px;
  border-radius: 6px;
  background: rgba(255,255,255,0.06);
  transition: background 0.15s, color 0.15s;
}
._venueEditImgRemove_zkw1h_1515:hover { background: rgba(255,68,68,0.12); color: #ff4444; }

._venueList_zkw1h_1466 {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

._venueRow_zkw1h_1531 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-radius: 14px;
  background: var(--card-bg);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
._venueRow_zkw1h_1531:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._venueRowActive_zkw1h_1543 { background: var(--overlay-sm); border-color: var(--accent); }
._venueRowHidden_zkw1h_1544 { opacity: 0.45; }

._venueImgLabel_zkw1h_1546 {
  width: 44px;
  height: 44px;
  flex-shrink: 0;
  cursor: pointer;
  border-radius: 10px;
  overflow: hidden;
}

._venueImgThumb_zkw1h_1555 {
  width: 44px;
  height: 44px;
  object-fit: cover;
  border-radius: 10px;
  display: block;
}

._venueImgPlaceholder_zkw1h_1563 {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  background: rgba(255,255,255,0.05);
  border: 1px dashed rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: border-color 0.15s;
}
._venueImgLabel_zkw1h_1546:hover ._venueImgPlaceholder_zkw1h_1563 {
  border-color: rgba(255,255,255,0.35);
  color: var(--text-primary);
}

._venueImgSpinner_zkw1h_1580 { font-size: 11px; color: var(--text-secondary); }

._venueInfo_zkw1h_1582 {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

._venueName_zkw1h_1590 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._venueMeta_zkw1h_1599 {
  font-size: 11px;
  color: var(--text-secondary);
}

._venueUrl_zkw1h_1604 {
  font-size: 10px;
  color: var(--text-secondary);
  opacity: 0.6;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._venueActions_zkw1h_1613 {
  display: flex;
  align-items: center;
  gap: 4px;
  flex-shrink: 0;
}

._venueHideBtn_zkw1h_1620 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._venueHideBtn_zkw1h_1620:hover { color: #ff9500; background: rgba(255,149,0,0.1); }

._venueShowBtn_zkw1h_1629 {
  color: #34c759;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  background: rgba(52,199,89,0.08);
  transition: color 0.15s, background 0.15s;
}
._venueShowBtn_zkw1h_1629:hover { background: rgba(52,199,89,0.18); }

._emptyHint_zkw1h_1639 {
  font-size: 12px;
  color: var(--text-secondary);
  text-align: center;
  padding: 20px;
  background: var(--card-bg);
  border-radius: 14px;
}

/* ── Contributor success splash ── */
._splash_zkw1h_1649 {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 64px 24px;
  text-align: center;
}

._splashIcon_zkw1h_1659 {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--btn-fg);
  flex-shrink: 0;
}

._splashTitle_zkw1h_1671 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}

._splashSub_zkw1h_1678 {
  font-size: 14px;
  color: var(--text-secondary);
  margin: 0;
}

._splashBtn_zkw1h_1684 {
  margin-top: 8px;
  padding: 13px 28px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._splashBtn_zkw1h_1684:hover { opacity: 0.85; }

/* ── Contributor submissions list ── */
._submissionList_zkw1h_1697 {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

._submissionRow_zkw1h_1703 {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--card-bg);
  border-radius: 14px;
  padding: 10px 14px;
}

._submissionThumb_zkw1h_1712 {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  overflow: hidden;
  flex-shrink: 0;
}
._submissionThumb_zkw1h_1712 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

._submissionInfo_zkw1h_1726 {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
  min-width: 0;
}

._submissionArtist_zkw1h_1734 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._submissionMeta_zkw1h_1743 {
  font-size: 11px;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._submissionBadge_zkw1h_1751 {
  font-size: 10px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 3px 9px;
  border-radius: 999px;
  flex-shrink: 0;
}

._badgePending_zkw1h_1761,
._badgeApproved_zkw1h_1762,
._badgeRejected_zkw1h_1763 {
  background: var(--overlay-md);
  color: var(--text-secondary);
}

._submissionActions_zkw1h_1768 {
  display: flex;
  align-items: center;
  gap: 2px;
  flex-shrink: 0;
}

._submissionEditBtn_zkw1h_1775,
._submissionDeleteBtn_zkw1h_1776 {
  padding: 6px;
  border-radius: 8px;
  color: #505C66;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
}
._submissionEditBtn_zkw1h_1775:hover { color: var(--text-primary); background: rgba(255,255,255,0.08); }
._submissionDeleteBtn_zkw1h_1776:hover { color: #ff4444; background: rgba(255,68,68,0.1); }

/* ── Venue merge ── */
._mergeVenueBox_zkw1h_1787 {
  border-top: 1px solid var(--card-border);
  padding: 16px 20px 4px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

._mergeVenueLabel_zkw1h_1795 {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

._mergeVenueRow_zkw1h_1803 {
  display: flex;
  gap: 8px;
  align-items: center;
}

._mergeVenueSelect_zkw1h_1809 {
  flex: 1;
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 8px 10px;
  font-size: 13px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  color-scheme: dark;
}

._mergeVenueBtn_zkw1h_1822 {
  padding: 8px 14px;
  border-radius: 10px;
  background: rgba(255,68,68,0.1);
  border: 1px solid rgba(255,68,68,0.25);
  color: #ff6b6b;
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
  transition: background 0.15s;
}
._mergeVenueBtn_zkw1h_1822:hover:not(:disabled) { background: rgba(255,68,68,0.18); }
._mergeVenueBtn_zkw1h_1822:disabled { opacity: 0.4; }

._confidenceBadge_zkw1h_1836 {
  font-size: 10px;
  font-weight: 700;
  margin-left: 6px;
  color: var(--text-secondary);
}

/* ── Scraper collapsible card ── */
._scraperCard_zkw1h_1844 {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 20px;
  overflow: hidden;
}
[data-theme="light"] ._scraperCard_zkw1h_1844,
[data-theme="light"] ._scrapingCard_zkw1h_1851 {
  border-color: #a1a1aa;
}

._scraperCardHeader_zkw1h_1855 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 16px 20px;
  flex-wrap: wrap;
}

._scraperToggleBtn_zkw1h_1863 {
  margin-left: auto;
  width: 28px;
  height: 28px;
  border-radius: 8px;
  background: var(--overlay-sm);
  border: 1px solid var(--border-subtle);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
  flex-shrink: 0;
}
._scraperToggleBtn_zkw1h_1863:hover { background: var(--overlay-md); color: var(--text-primary); }
._scraperToggleBtn_zkw1h_1863 svg { transition: transform 0.2s; }
._scraperToggleBtnOpen_zkw1h_1879 svg { transform: rotate(180deg); }

._scraperCardBody_zkw1h_1881 {
  padding: 0 20px 16px;
}

/* ── Collapsible flagged card ── */
._collapsibleCard_zkw1h_1886 {
  border: 1px solid rgba(239,83,80,0.25);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 8px;
}
._collapsibleHeader_zkw1h_1892 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 14px 16px;
  background: rgba(239,83,80,0.06);
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  transition: background 0.15s;
}
._collapsibleHeader_zkw1h_1892:hover { background: rgba(239,83,80,0.1); }
._collapsibleChevron_zkw1h_1906 { margin-left: auto; color: var(--text-secondary); transition: transform 0.2s; }
._collapsibleChevronOpen_zkw1h_1907 { transform: rotate(180deg); }
._collapsibleBody_zkw1h_1908 { padding: 12px 16px 16px; display: flex; flex-direction: column; gap: 10px; }
._flagBadge_zkw1h_1909 { background: var(--overlay-md); color: var(--text-secondary); border-radius: 10px; padding: 1px 7px; font-size: 11px; font-weight: 800; }

/* ── Scraping dashboard ── */
._scrapingGrid_zkw1h_1912 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 24px;
}
._scrapingCard_zkw1h_1851 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 28px 16px 22px;
  border-radius: 16px;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  text-align: center;
}
._scrapingCard_zkw1h_1851:hover { border-color: var(--accent); background: var(--overlay-xs); }
._scrapingCardIcon_zkw1h_1932 { color: var(--accent); }
._scrapingCardTitle_zkw1h_1933 { font-size: 13px; font-weight: 700; color: var(--text-primary); line-height: 1.3; }
._scrapingCardDesc_zkw1h_1934 { font-size: 11px; color: var(--text-secondary); line-height: 1.5; text-align: center; }

/* ── Scraping modal ── */
[data-theme="light"] ._scrapingModalBox_zkw1h_1937 {
  background: #fff;
}

._scrapingModalBox_zkw1h_1937 {
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  width: 100%;
  max-width: min(65vw, 860px);
  max-height: 85dvh;
  overflow-y: auto;
  scrollbar-width: none;
  display: flex; flex-direction: column;
  animation: _modalFadeIn_zkw1h_1 0.2s ease both;
}
._scrapingModalBox_zkw1h_1937::-webkit-scrollbar { display: none; }
._scrapingModalHeader_zkw1h_1954 {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}
._scrapingModalTitle_zkw1h_1960 { font-size: 18px; font-weight: 800; color: var(--text-primary); margin: 0; }
._scrapingModalClose_zkw1h_1961 {
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
  flex-shrink: 0;
}
._scrapingModalClose_zkw1h_1961:hover { background: rgba(255,255,255,0.14); }

/* ── Venue Modal ── */
._venueModalBox_zkw1h_1973 {
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  width: 100%;
  max-width: min(55vw, 720px);
  max-height: 85dvh;
  overflow-y: auto;
  scrollbar-width: none;
  display: flex; flex-direction: column;
  animation: _slideUp_zkw1h_1 0.2s ease both;
}
._venueModalBox_zkw1h_1973::-webkit-scrollbar { display: none; }
._venueModalHeader_zkw1h_1986 {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 24px 16px;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  flex-shrink: 0;
}

@keyframes _modalFadeIn_zkw1h_1 {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Backups tab ── */
._backupsHeader_zkw1h_1999 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 24px 0;
  gap: 12px;
}
._dbSizeHint_zkw1h_2006 { font-size: 12px; color: var(--text-secondary); }
._backupList_zkw1h_2007 { display: flex; flex-direction: column; gap: 4px; padding: 16px 24px 80px; }
._backupRow_zkw1h_2008 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  transition: background 0.15s, border-color 0.15s;
  cursor: default;
}
._backupRow_zkw1h_2008:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._backupName_zkw1h_2020 { flex: 1; font-size: 13px; font-weight: 600; color: var(--text-primary); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
._backupMeta_zkw1h_2021 { font-size: 12px; color: var(--text-secondary); white-space: nowrap; }
._backupActions_zkw1h_2022 { display: flex; gap: 4px; flex-shrink: 0; }
._backupDownloadBtn_zkw1h_2023 { padding: 6px; border-radius: 8px; color: var(--accent); transition: background 0.15s; }
._backupDownloadBtn_zkw1h_2023:hover { background: var(--overlay-sm); }
._backupDeleteBtn_zkw1h_2025 { padding: 6px; border-radius: 8px; color: var(--text-secondary); transition: color 0.15s, background 0.15s; }
._backupDeleteBtn_zkw1h_2025:hover { color: #ff4444; background: rgba(255,68,68,0.1); }
._backupHint_zkw1h_2027 { font-size: 12px; color: var(--text-secondary); padding: 0 24px 12px; opacity: 0.6; margin-top: 16px; }

._tabContent_zkw1h_2029 { animation: _tabFadeIn_zkw1h_1 0.15s ease both; }
@keyframes _tabFadeIn_zkw1h_1 { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } }

/* ── Responsive grid for stats (Fix 5) ── */
._statsGrid3_zkw1h_2033 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 12px; }
@media (max-width: 767px) { ._statsGrid3_zkw1h_2033 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 480px) { ._statsGrid3_zkw1h_2033 { grid-template-columns: 1fr; } }

/* ── Mobile fixes ── */
@media (max-width: 767px) {
  /* Fix 3: Scraping tools single column */
  ._scrapingGrid_zkw1h_1912 {
    grid-template-columns: 1fr;
    padding: 16px;
  }

  /* Fix 4: Tab nav horizontal scroll */
  ._tabNav_zkw1h_1424 {
    overflow-x: auto;
    scrollbar-width: none;
    margin: 24px 16px 8px;
    -webkit-overflow-scrolling: touch;
    touch-action: pan-x;
    user-select: none;
    -webkit-user-select: none;
  }
  ._tabNav_zkw1h_1424::-webkit-scrollbar { display: none; }
  ._tab_zkw1h_1424 {
    padding: 10px 14px;
    font-size: 12px;
    flex-shrink: 0;
  }
}

/* ── Light theme: ensure borders are visible (hardcoded white borders become invisible on light bg) ── */
[data-theme="light"] ._backBtn_zkw1h_101,
[data-theme="light"] ._field_zkw1h_206 input,
[data-theme="light"] ._field_zkw1h_206 textarea,
[data-theme="light"] ._field_zkw1h_206 select,
[data-theme="light"] ._extraSupportBlock_zkw1h_223 input,
[data-theme="light"] ._extraSupportBlock_zkw1h_223 textarea,
[data-theme="light"] ._imageUrlInput_zkw1h_256,
[data-theme="light"] ._editSelect_zkw1h_1320,
[data-theme="light"] ._syncVenueSelect_zkw1h_1001,
[data-theme="light"] ._venueFilterSelect_zkw1h_624,
[data-theme="light"] ._reviewBtn_zkw1h_785 {
  border-color: rgba(0, 0, 0, 0.15);
}
[data-theme="light"] ._backBtn_zkw1h_101:hover,
[data-theme="light"] ._field_zkw1h_206 input:focus,
[data-theme="light"] ._field_zkw1h_206 textarea:focus,
[data-theme="light"] ._extraSupportBlock_zkw1h_223 input:focus,
[data-theme="light"] ._extraSupportBlock_zkw1h_223 textarea:focus,
[data-theme="light"] ._imageUrlInput_zkw1h_256:focus,
[data-theme="light"] ._editSelect_zkw1h_1320:focus,
[data-theme="light"] ._syncVenueSelect_zkw1h_1001:hover,
[data-theme="light"] ._syncVenueSelect_zkw1h_1001:focus,
[data-theme="light"] ._venueFilterSelect_zkw1h_624:hover,
[data-theme="light"] ._venueFilterSelect_zkw1h_624:focus {
  border-color: rgba(0, 0, 0, 0.35);
}
/* ── Flex layout: page + panel slot ── */
._pageLayout_14bus_2 {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

._page_14bus_2 {
  display: flex;
  flex-direction: column;
  flex: 1;
  min-width: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  padding-bottom: 32px;
}
._page_14bus_2::-webkit-scrollbar { display: none; }

/* Panel slot — desktop: flex sibling pushing content left */
._panelSlot_14bus_23 {
  width: 0;
  flex-shrink: 0;
  overflow: hidden;
  transition: width 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}
._panelSlotOpen_14bus_29 { width: 380px; }

/* Mobile: panel slot becomes a fixed overlay */
@media (max-width: 1279px) {
  ._pageLayout_14bus_2 { display: contents; }
  ._panelSlot_14bus_23 {
    position: fixed !important;
    top: calc(56px + env(safe-area-inset-top)); right: 0;
    width: 380px !important;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
    z-index: 201;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
    overflow: hidden;
  }
  ._panelSlotOpen_14bus_29 { transform: translateX(0) !important; }
  ._editBackdrop_14bus_45 {
    display: block;
    top: calc(56px + env(safe-area-inset-top));
    inset: unset;
    left: 0; right: 0; bottom: 0;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
  }
}
@media (max-width: 480px) {
  ._panelSlot_14bus_23 { width: 100vw !important; }
  ._editPanelHeader_14bus_55 { padding-top: 20px; }
}

/* ── Embedded inside MainMenuSheet sub-screen (mobile) ──────────
   Panel slides in over the sub-screen body but NOT the sheet's
   sub-header. Override .pageLayout's `display: contents` so it
   becomes a real bounded container that the panel can absolute-fill. */
@media (max-width: 1279px) {
  ._pageLayoutModal_14bus_63 {
    display: flex !important;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    /* Hard clamp: viewport minus sheet chrome (handle 25px + sub-header 57px = 82px)
       minus dynamic sheet-top (which matches .sheetTall: max(40px, env-top + 20px)).
       Prevents footer from clipping below viewport on notched + non-notched devices. */
    max-height: calc(100dvh - 82px - max(40px, env(safe-area-inset-top, 0px) + 20px));
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  /* User list scrolls internally instead of pushing .pageLayoutModal taller. */
  ._pageLayoutModal_14bus_63 ._page_14bus_2 { flex: 1; min-height: 0; }
  ._pageLayoutModal_14bus_63 ._panelSlot_14bus_23 {
    position: absolute !important;
    top: 0 !important;
    bottom: 0 !important;
    right: 0 !important;
    left: 0 !important;
    height: auto !important;
    width: 100% !important;
    z-index: 5;
    display: block;
    /* Kill the slide-in transform — sub-screen has its own animation;
       transform creates a containing block that traps position:fixed. */
    transform: none !important;
    /* When panel is closed, don't block clicks on the user list below. */
    pointer-events: none;
  }
  ._pageLayoutModal_14bus_63 ._panelSlotOpen_14bus_29 {
    transform: none !important;
    pointer-events: auto;
  }
  ._pageLayoutModal_14bus_63 ._editPanel_14bus_55 {
    background: #000;
    width: 100%;
    height: 100%;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden;
    animation: _editPanelFadeIn_14bus_1 0.28s ease both;
  }
  ._pageLayoutModal_14bus_63 ._editPanelHeader_14bus_55 { flex: 0 0 auto; }
  ._pageLayoutModal_14bus_63 ._editPanelBody_14bus_108 {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }
  ._pageLayoutModal_14bus_63 ._editPanelFooter_14bus_113 {
    flex: 0 0 auto;
    background: #000;
    padding: 16px 20px calc(16px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--card-border);
  }
}
@keyframes _editPanelFadeIn_14bus_1 {
  from { opacity: 0; }
  to { opacity: 1; }
}
@media (max-width: 1279px) {
  /* Panel fills the entire sub-screen body, so the backdrop has no visible
     click area. Hide it — user closes via the X button on panel header. */
  ._editBackdropModal_14bus_127 {
    display: none !important;
  }
  ._pageLayoutModal_14bus_63 ._editPanelHeader_14bus_55 { padding-top: 16px; }
}

._inner_14bus_133 {
  max-width: 70%;
  width: 100%;
  margin-left: 15vw;
  display: flex;
  flex-direction: column;
}

/* Role filter — multi-select dropdown */
._roleFilterWrap_14bus_142 {
  width: 100%;
  margin-bottom: 14px;
}
._roleCheckbox_14bus_146 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 5px;
  border: 1.5px solid var(--card-border);
  background: transparent;
  color: var(--btn-fg);
  flex-shrink: 0;
  transition: background 0.12s, border-color 0.12s;
}
._roleCheckboxOn_14bus_159 {
  background: var(--accent);
  border-color: var(--accent);
}
._roleFilterAll_14bus_163 {
  font-weight: 700 !important;
  color: var(--text-primary) !important;
  border-bottom: 1px solid var(--card-border);
  border-radius: 0 !important;
  margin-bottom: 4px;
  padding-bottom: 12px !important;
}

@media (max-width: 639px) {
  ._inner_14bus_133 { max-width: 100%; margin-left: 0; }
}

/* Tablet: match BookmarksPage content width */
@media (min-width: 640px) and (max-width: 1279px) {
  ._inner_14bus_133 { max-width: 92%; margin: 0 auto; }
}

._header_14bus_181 {
  display: flex;
  align-items: center;
  gap: 0;
  padding: 24px 24px 8px;
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 5;
  transition: box-shadow 0.25s, backdrop-filter 0.25s;
}

/* Desktop: break header out of the centered .inner (max-width: 70%) so the
   sticky-scroll background + drop-shadow span the full page width. */
@media (min-width: 1280px) {
  ._header_14bus_181 {
    width: 100vw;
    margin-left: -15vw;
    padding: 24px 15vw 8px;
  }
}

._headerLeft_14bus_203 {
  display: flex;
  align-items: center;
  gap: 6px;
}

._titleGroup_14bus_209 {
  display: flex;
  align-items: center;
  gap: 6px;
}

._title_14bus_209 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

._countBadge_14bus_221 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
  flex-shrink: 0;
}

._backBtn_14bus_231 {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  border-radius: 50%;
  border: 1.5px solid rgba(255,255,255,0.2);
  background: transparent;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  padding: 0;
  flex-shrink: 0;
  transition: border-color 0.15s, color 0.15s;
}
._backBtn_14bus_231:hover { border-color: rgba(255,255,255,0.5); color: var(--text-primary); }
._backBtn_14bus_231 { display: none; }

/* ── Two-column layout ── */
._columns_14bus_251 {
  display: grid;
  grid-template-columns: 1fr;
  gap: 32px;
  align-items: start;
  padding: 24px 0 16px;
}

._col_14bus_251 {
  padding: 0 24px;
  min-width: 0;
}

@media (max-width: 700px) {
  ._col_14bus_251 { padding: 0 16px; }
  ._col_14bus_251 + ._col_14bus_251 { border-left: none; border-top: 1px solid rgba(255,255,255,0.06); padding-top: 24px; margin-top: 8px; }
  ._columns_14bus_251 { padding-top: 16px; }
  ._header_14bus_181 { top: 0; padding-top: 8px; }
}

._colTitle_14bus_271 {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 14px;
}

/* ── Form ── */
._form_14bus_281 {
  display: flex;
  flex-direction: column;
  gap: 12px;
  background: var(--card-bg);
  border-radius: 20px;
  padding: 20px;
}

._field_14bus_290 {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

._field_14bus_290 label {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

._field_14bus_290 input,
._field_14bus_290 select {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
  color-scheme: dark;
}
._field_14bus_290 input:focus,
._field_14bus_290 select:focus { border-color: rgba(255,255,255,0.3); }
._field_14bus_290 input::placeholder { color: #333; }

._submitBtn_14bus_322 {
  padding: 13px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
  margin-top: 4px;
}
._submitBtn_14bus_322:hover { opacity: 0.9; }
._submitBtn_14bus_322:disabled { opacity: 0.5; }

/* ── User list ── */
._userList_14bus_336 {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

._userRow_14bus_342 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: var(--card-bg);
  border-radius: 14px;
  padding: 12px 14px;
  cursor: pointer;
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s;
}
._userRow_14bus_342:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._userRowActive_14bus_354 { background: var(--overlay-sm); border-color: var(--accent); }

._userInfo_14bus_356 {
  display: flex;
  align-items: center;
  gap: 10px;
}

._userAvatar_14bus_362 {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}

._userAvatarInitials_14bus_371 {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 800;
  color: var(--text-primary);
  flex-shrink: 0;
}

._userUsername_14bus_385 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

._userEmail_14bus_391 {
  font-size: 11px;
  color: var(--text-secondary);
}

._userLastLogin_14bus_396 {
  font-size: 10px;
  color: var(--text-muted);
}

._lastLoginValue_14bus_401 {
  font-size: 13px;
  color: var(--text-secondary);
  padding: 4px 0;
}

._userRole_14bus_407 {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--accent);
  background: rgba(142,187,255,0.1);
  border-radius: 6px;
  padding: 2px 7px;
}

._userActions_14bus_418 {
  display: flex;
  align-items: center;
  gap: 4px;
}

._editBtn_14bus_424 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._editBtn_14bus_424:hover { color: var(--text-primary); background: rgba(255,255,255,0.08); }

._deleteBtn_14bus_433 {
  color: #505C66;
  padding: 6px;
  border-radius: 8px;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
}
._deleteBtn_14bus_433:hover { color: #ff4444; background: rgba(255,68,68,0.1); }

._confirmRow_14bus_442 {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
}
._confirmYes_14bus_449 {
  font-size: 12px;
  font-weight: 700;
  color: #ff4444;
  background: rgba(255,68,68,0.1);
  border-radius: 8px;
  padding: 4px 10px;
}
._confirmNo_14bus_457 {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  background: rgba(255,255,255,0.05);
  border-radius: 8px;
  padding: 4px 10px;
}

._emptyHint_14bus_466 {
  font-size: 13px;
  color: var(--text-secondary);
  padding: 8px 0;
}

/* ── Edit slide-in panel ── */
._editBackdrop_14bus_45 {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  z-index: 200;
  opacity: 0;
  transition: opacity 0.25s ease;
}
._editBackdropVisible_14bus_483 { opacity: 1; }

@media (max-width: 1279px) {
  ._editBackdrop_14bus_45 { display: block; }
}

/* Desktop: in-flow within panelSlot */
._editPanel_14bus_55 {
  width: 100%;
  height: 100%;
  background: var(--bg);
  border-left: 1px solid var(--nav-border);
  display: flex;
  flex-direction: column;
  overflow-y: auto;
  scrollbar-width: none;
}
._editPanel_14bus_55::-webkit-scrollbar { display: none; }
._editPanelVisible_14bus_501 { transform: none; } /* unused on desktop, kept for safety */

._editPanelHeader_14bus_55 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 16px;
  border-bottom: 1px solid var(--card-border);
  flex-shrink: 0;
}

._editPanelTitle_14bus_512 {
  font-size: 16px;
  font-weight: 800;
  color: var(--text-primary);
}

._editCloseBtn_14bus_518 {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
}
._editCloseBtn_14bus_518:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }

._editPanelBody_14bus_108 {
  flex: 1;
  overflow-y: auto;
  scrollbar-width: none;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
._editPanelBody_14bus_108::-webkit-scrollbar { display: none; }

._editPanelFooter_14bus_113 {
  display: flex;
  gap: 10px;
  padding: 16px 20px;
  border-top: 1px solid var(--card-border);
  flex-shrink: 0;
}

._editCancelBtn_14bus_550 {
  flex: 1;
  padding: 13px;
  border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 700;
  transition: background 0.15s;
}
._editCancelBtn_14bus_550:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }

._editSaveBtn_14bus_562 {
  flex: 2;
  padding: 13px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._editSaveBtn_14bus_562:hover { opacity: 0.9; }
._editSaveBtn_14bus_562:disabled { opacity: 0.5; }

/* ── Edit panel avatar ── */
._editAvatarRow_14bus_576 {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 4px 0 8px;
}

._editAvatarBtn_14bus_583 {
  position: relative;
  width: 60px;
  height: 60px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
}

._editAvatarImg_14bus_593 {
  width: 60px;
  height: 60px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

._editAvatarInitials_14bus_601 {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
}

._editAvatarOverlay_14bus_614 {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.5);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 0;
  transition: opacity 0.15s;
}
._editAvatarBtn_14bus_583:hover ._editAvatarOverlay_14bus_614 { opacity: 1; }

._editAvatarHint_14bus_628 {
  font-size: 13px;
  color: var(--text-secondary);
}

/* ── Join requests card ── */
._requestsCard_14bus_634 {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  border-radius: 20px;
  padding: 20px 24px;
  margin: 0 0 24px;
}

._requestsTitle_14bus_642 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 16px;
  display: flex;
  align-items: center;
  gap: 8px;
}

._requestsBadge_14bus_654 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 999px;
}

._requestsList_14bus_663 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

._requestRow_14bus_669 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 14px;
  background: var(--overlay-xs);
  border-radius: 14px;
  flex-wrap: wrap;
}

._requestInfo_14bus_680 {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

._requestName_14bus_687 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

._requestEmail_14bus_693 {
  font-size: 12px;
  color: var(--text-secondary);
}

._requestDate_14bus_698 {
  font-size: 11px;
  color: var(--text-muted);
}

._requestActions_14bus_703 {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

._acceptBtn_14bus_709 {
  padding: 7px 14px;
  border-radius: 10px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
  transition: opacity 0.15s;
}
._acceptBtn_14bus_709:hover { opacity: 0.85; }

._rejectBtn_14bus_721 {
  padding: 7px 14px;
  border-radius: 10px;
  background: rgba(255,68,68,0.1);
  color: #ff4444;
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
  transition: background 0.15s;
}
._rejectBtn_14bus_721:hover { background: rgba(255,68,68,0.2); }

._acceptForm_14bus_733 {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 4px;
}

._acceptInput_14bus_741 {
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  border-radius: 10px;
  padding: 8px 12px;
  font-size: 13px;
  font-family: inherit;
  color: var(--text-primary);
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
}
._acceptInput_14bus_741:focus { border-color: var(--accent); }

._acceptError_14bus_755 {
  font-size: 12px;
  color: #ff4444;
}

._acceptActions_14bus_760 {
  display: flex;
  gap: 8px;
}

._acceptCancelBtn_14bus_765 {
  flex: 1;
  padding: 8px;
  border-radius: 10px;
  background: var(--overlay-sm);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 600;
  min-height: unset;
}

._acceptConfirmBtn_14bus_776 {
  flex: 2;
  padding: 8px;
  border-radius: 10px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
  transition: opacity 0.15s;
}
._acceptConfirmBtn_14bus_776:disabled { opacity: 0.5; }

/* ── No requests placeholder ── */
._noRequestsPlaceholder_14bus_790 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 48px 24px;
  border: 1px dashed var(--border-subtle);
  border-radius: 20px;
}

._noRequestsText_14bus_799 {
  font-size: 13px;
  color: var(--text-muted);
  font-weight: 600;
}


/* ── Create User Modal ── */
._createModal_14bus_807 {
  position: relative;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 60px rgba(142,187,255,0.3), 0 32px 80px rgba(0,0,0,0.6);
  border-radius: 24px;
  padding: 32px;
  width: 100%;
  max-width: 420px;
  animation: _slideUp_14bus_1 0.25s ease;
}
@keyframes _slideUp_14bus_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}
._createModalTitle_14bus_821 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 20px;
}
._createModalCloseBtn_14bus_827 {
  position: absolute;
  top: 16px; right: 16px;
  width: 32px; height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
}
._createModalCloseBtn_14bus_827:hover { background: rgba(255,255,255,0.14); }
._newUserBtn_14bus_838 {
  padding: 9px 18px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  margin-left: auto;
}

/* ── Role filter pills ── */
._roleFilters_14bus_849 {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 14px;
}
._rolePill_14bus_855 {
  padding: 4px 10px;
  border-radius: 14px;
  font-size: 10px;
  font-size: 11px;
  font-weight: 700;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
._rolePill_14bus_855:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }
._rolePillActive_14bus_868 {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--btn-fg) !important;
}

/* ── Email verification ── */
._unverifiedBadge_14bus_875 {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.06em;
  color: #ff9500;
  background: rgba(255,149,0,0.12);
  border-radius: 4px;
  padding: 2px 6px;
  flex-shrink: 0;
}

._verifySection_14bus_889 {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 10px 12px;
  background: rgba(255,149,0,0.06);
  border: 1px solid rgba(255,149,0,0.2);
  border-radius: 10px;
}

._verifyActions_14bus_899 {
  display: flex;
  gap: 8px;
}

._resendVerifyBtn_14bus_904 {
  flex: 1;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  color: var(--accent);
  background: rgba(142,187,255,0.08);
  border: 1px solid rgba(142,187,255,0.2);
  transition: background 0.15s;
}
._resendVerifyBtn_14bus_904:hover { background: rgba(142,187,255,0.15); }

._manualVerifyBtn_14bus_917 {
  flex: 1;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 700;
  color: #4caf50;
  background: rgba(76,175,80,0.08);
  border: 1px solid rgba(76,175,80,0.2);
  transition: background 0.15s;
}
._manualVerifyBtn_14bus_917:hover { background: rgba(76,175,80,0.15); }

._verifyOk_14bus_930 { font-size: 12px; color: #4caf50; margin: 0; }
._verifyErr_14bus_931 { font-size: 12px; color: #ff5555; margin: 0; }

._newVenueBtn_14bus_933 {
  padding: 7px 14px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._newVenueBtn_14bus_933:hover { opacity: 0.85; }

/* Desktop: wrapper is invisible to layout — children flow inline in .userInfo. */
._userNameRole_14bus_945 { display: contents; }

/* ── Mobile/Tablet user row ── */
@media (max-width: 767px) {
  ._userRow_14bus_342 { padding: 10px 12px; gap: 8px; }
  ._userInfo_14bus_356 { gap: 11px; min-width: 0; flex: 1; align-items: center; }
  /* Username + role badge: inline when there's room, badge wraps to line 2
     only when it doesn't fit beside the (truncated) username. */
  ._userNameRole_14bus_945 {
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    column-gap: 8px;
    row-gap: 3px;
    min-width: 0;
    flex: 1;
  }
  ._userUsername_14bus_385 { font-size: 13px; max-width: 100%; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
  ._userEmail_14bus_391 { display: none; }
  ._userLastLogin_14bus_396 { display: none; }
  ._userRole_14bus_407 { font-size: 9px; padding: 1px 5px; }
  ._userActions_14bus_418 { gap: 0; flex-shrink: 0; }
}

/* ── Safe-area for edit panel on mobile ── */
@media (max-width: 480px) {
  ._editPanelHeader_14bus_55 { padding-top: calc(20px + env(safe-area-inset-top)); }
}

/* ── Matched Events rows ── */
._matchedEventRow_14bus_976 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 4px;
  border-bottom: 1px solid rgba(255,255,255,0.04);
  cursor: pointer;
  border-radius: 8px;
  transition: background 0.15s;
}
._matchedEventRow_14bus_976:hover { background: var(--overlay-sm); }
._matchedEventRowActive_14bus_987 { background: var(--overlay-sm); }
._card_1kxm6_1 {
  background: var(--card-bg);
  border-radius: var(--card-radius);
  overflow: hidden;
  border: 1px solid var(--card-border);
  display: flex;
  flex-direction: column;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
  cursor: pointer;
  transform: translateZ(0);
}

._card_1kxm6_1:hover {
  transform: translateY(-2px);
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.6);
}

[data-theme="light"] ._card_1kxm6_1:hover {
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.12);
}

._cardBookmarked_1kxm6_22 {
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.5);
}
._cardBookmarked_1kxm6_22:hover {
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.5), 0 16px 48px rgba(0, 0, 0, 0.6);
}
[data-theme="light"] ._cardBookmarked_1kxm6_22:hover {
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.5), 0 8px 24px rgba(0, 0, 0, 0.12);
}

._cardSelected_1kxm6_32 {
  box-shadow: 0 0 0 3px var(--accent);
  position: relative;
  z-index: 1;
}
._cardSelected_1kxm6_32:hover {
  box-shadow: 0 0 0 3px var(--accent), 0 16px 48px rgba(0, 0, 0, 0.6);
}
[data-theme="light"] ._cardSelected_1kxm6_32:hover {
  box-shadow: 0 0 0 3px var(--accent), 0 8px 24px rgba(0, 0, 0, 0.12);
}

/* ── Image button ──────────────────────────────────────── */
._imageBtn_1kxm6_45 {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  display: block;
  border: none;
  padding: 0;
  cursor: pointer;
  min-height: unset;
  background: linear-gradient(90deg,
    rgba(142,187,255,0.04) 0%,
    rgba(142,187,255,0.12) 50%,
    rgba(142,187,255,0.04) 100%
  );
  background-size: 200% 100%;
  animation: _shimmer_1kxm6_1 1.8s ease-in-out infinite;
}

/* Stop the shimmer once the image is loaded — kills the per-frame repaint
   cost that drove Chrome's scroll flicker on 20+ visible cards. */
._imageBtnLoaded_1kxm6_66 {
  animation: none;
  background: rgba(255, 255, 255, 0.04);
}

@keyframes _shimmer_1kxm6_1 {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}

._image_1kxm6_45 {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.4s ease;
}

._imageHidden_1kxm6_84 { opacity: 0; }

._imageLoaded_1kxm6_86 {
  animation: _imageReveal_1kxm6_1 0.65s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}

@keyframes _imageReveal_1kxm6_1 {
  from { opacity: 0; filter: blur(16px); transform: scale(1.06); }
  to   { opacity: 1; filter: blur(0px);  transform: scale(1); }
}

._imageBtn_1kxm6_45:hover ._image_1kxm6_45,
._imageBtn_1kxm6_45:focus-visible ._image_1kxm6_45 {
  transform: scale(1.04);
}

._overlay_1kxm6_100 {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    transparent 40%,
    rgba(16, 16, 16, 0.9) 100%
  );
  transition: opacity 0.2s;
}

/* Category badge */
._badge_1kxm6_112 {
  position: absolute;
  top: 14px;
  left: 14px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  padding: 4px 11px;
  border-radius: var(--pill-radius);
}

._priceBadge_1kxm6_127 {
  position: absolute;
  bottom: 14px;
  left: 14px;
  background: rgba(0, 0, 0, 0.6);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: var(--pill-radius);
}

/* ── Card footer ───────────────────────────────────────── */
._footer_1kxm6_141 {
  padding: 14px 16px 16px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  flex: 1;
}

._meta_1kxm6_149 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}

._dateTime_1kxm6_156 {
  display: flex;
  align-items: baseline;
  gap: 4px;
  flex-shrink: 0;
}

._date_1kxm6_156 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  flex-shrink: 0;
}

._time_1kxm6_170 {
  font-size: 13px;
  font-weight: 500;
  color: var(--text-secondary);
}

._genres_1kxm6_176 {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

._genrePill_1kxm6_183 {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.06);
  border-radius: var(--pill-radius);
  padding: 2px 9px;
  white-space: nowrap;
}

._titleRow_1kxm6_193 {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 8px;
}

._artist_1kxm6_200 {
  font-size: 22px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.3px;
  line-height: 1.15;
}

@media (min-width: 1024px) {
  ._artist_1kxm6_200 { font-size: 20px; }
}

._bookmarkArea_1kxm6_212 {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}

._bookmarkCount_1kxm6_219 {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-secondary);
  line-height: 1;
}

._bookmarkBtn_1kxm6_226 {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
._bookmarkBtn_1kxm6_226:hover { background: var(--accent-dim); color: var(--accent); }
._bookmarkBtn_1kxm6_226._bookmarked_1kxm6_241 { background: var(--accent); color: var(--btn-fg); }
._bookmarkDisabled_1kxm6_242 { opacity: 0.35; cursor: default; }
._bookmarkDisabled_1kxm6_242:hover { background: rgba(255,255,255,0.06) !important; color: var(--text-secondary) !important; }

._bookmarkWrap_1kxm6_245 { position: relative; }
._loginPopup_1kxm6_246 {
  position: absolute;
  bottom: calc(100% + 10px);
  right: 0;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 8px 24px rgba(0,0,0,0.6);
  border-radius: 14px;
  padding: 12px 14px;
  min-width: 190px;
  z-index: 30;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.15s;
  text-align: center;
}
._bookmarkWrap_1kxm6_245:hover ._loginPopup_1kxm6_246 { opacity: 1; pointer-events: auto; }
._loginPopupVisible_1kxm6_262 { opacity: 1 !important; pointer-events: auto !important; }
._loginPopupText_1kxm6_263 { font-size: 12px; color: var(--text-secondary); margin: 0 0 10px; line-height: 1.4; }
._loginPopupBtn_1kxm6_264 {
  width: 100%; padding: 8px; border-radius: 10px;
  background: var(--accent); color: var(--btn-fg);
  font-size: 13px; font-weight: 700; transition: opacity 0.15s;
}
._loginPopupBtn_1kxm6_264:hover { opacity: 0.85; }

._bottomRow_1kxm6_271 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-top: auto;
  padding-top: 4px;
}

._venue_1kxm6_280 {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--text-secondary);
  font-size: 14px;
  min-width: 0;
  flex: 1;
}
._venue_1kxm6_280 span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Past event state: muted, restored on hover ──────────── */
._cardPast_1kxm6_296 {
  opacity: 0.55;
  filter: grayscale(0.5);
  transition: opacity 0.25s ease, filter 0.25s ease;
}
._cardPast_1kxm6_296:hover,
._cardPast_1kxm6_296:focus-within {
  opacity: 1;
  filter: none;
}

._pastBadge_1kxm6_307 {
  position: absolute;
  top: 12px;
  right: 12px;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--text-secondary);
  background: rgba(255, 255, 255, 0.1);
  border: 1px solid var(--border-subtle);
  border-radius: 6px;
  padding: 3px 7px;
  z-index: 2;
  pointer-events: none;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
[data-theme="light"] ._pastBadge_1kxm6_307 {
  background: rgba(0, 0, 0, 0.06);
}
._page_efvrm_1 {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  height: 100%;
  scroll-behavior: smooth;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-y: contain;
  scrollbar-width: none;
  /* Reserve scrollbar space so toggling overflow:hidden (e.g. when sticky-month
     dropdown opens) doesn't reflow content. */
  scrollbar-gutter: stable;
}
._page_efvrm_1::-webkit-scrollbar { display: none; }

/* Desktop padding-top moved to App.module.css → .sidebarSlot reserves space
   for the fixed sidebar globally, so every routed page is correctly offset. */

._inner_efvrm_20 {
  max-width: 95%;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  flex: 1;
}

/* Tablet (no sidebar): wider content */
@media (min-width: 640px) and (max-width: 1279px) {
  ._inner_efvrm_20 { max-width: 92%; }
}

/* Mobile: full width */
@media (max-width: 639px) {
  ._inner_efvrm_20 { max-width: 100%; }
}

/* ── Feed: mobile single column ────────────────────────── */
._feed_efvrm_40 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-4) var(--space-10);
}

/* Mobile + tablet: no bottom nav, just normal padding */
@media (max-width: 1279px) {
  ._feed_efvrm_40 { padding-bottom: var(--space-10); }
}

/* ── Tablet 768px+: 2 columns ──────────────────────────── */
@media (min-width: 768px) {
  ._feed_efvrm_40 {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: var(--space-5);
    padding: var(--space-5) var(--space-6) var(--space-10);
    align-content: start;
  }
}

/* ── Desktop md 1280px+: 4 columns ─────────────────────── */
@media (min-width: 1280px) {
  ._feed_efvrm_40 {
    grid-template-columns: repeat(4, minmax(0, 1fr));
    /* Extra bottom padding to clear the bottom-fixed Header pill (experiment). */
    padding: var(--space-6) var(--space-8) 96px;
    gap: var(--space-6);
  }
}


/* ── States ─────────────────────────────────────────────── */
._empty_efvrm_76 {
  text-align: center;
  color: var(--text-secondary);
  font-size: 14px;
  padding: var(--space-10) 0;
  grid-column: 1 / -1;
}

._emptyState_efvrm_84 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
  padding: 60px var(--space-6);
  text-align: center;
  grid-column: 1 / -1;
}

._emptyState_efvrm_84 p {
  font-size: 17px;
  font-weight: 700;
  color: var(--text-primary);
}

._emptyState_efvrm_84 span {
  font-size: 14px;
  color: var(--text-secondary);
  max-width: 240px;
}

._emptyState_efvrm_84 button {
  margin-top: var(--space-2);
  padding: 10px 22px;
  border-radius: var(--pill-radius);
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 700;
  min-height: unset;
}
/* ── Mobile title section (matches AdminPage header style) ── */
._mobileTitleHeader_qq5zi_2 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 16px 24px 8px;
  position: -webkit-sticky;
  position: sticky;
  top: calc(49px + env(safe-area-inset-top));
  background: var(--bg);
  z-index: 35;
  flex-shrink: 0;
  transition: box-shadow 0.25s, backdrop-filter 0.25s;
}

@media (min-width: 640px) {
  ._mobileTitleHeader_qq5zi_2 { display: none; }
}

._mobileTitleText_qq5zi_20 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

._mobileTitleCount_qq5zi_26 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
}

/* Hide the calendar card entirely on mobile */
._mobileCalendarHidden_qq5zi_36 {
  display: none !important;
}

@media (min-width: 640px) {
  ._mobileCalendarHidden_qq5zi_36 { display: block !important; }
}

/* ── Desktop-only title header ── */
._header_qq5zi_45 {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-6) var(--space-4) var(--space-2);
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 5;
  border-bottom: 1px solid var(--card-border);
}

/* Hide desktop header on mobile (title lives in the card) */
@media (max-width: 639px) {
  ._header_qq5zi_45 { display: none; }
}

@media (min-width: 768px) { ._header_qq5zi_45 { padding-inline: var(--space-6); } }
@media (min-width: 1024px) { ._header_qq5zi_45 { padding-inline: var(--space-8); } }

._title_qq5zi_65 {
  font-size: 24px;
  font-weight: 900;
  color: var(--text-primary);
  letter-spacing: -0.5px;
}

._count_qq5zi_72 {
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 700;
  padding: 3px 12px;
  border-radius: var(--pill-radius);
}

/* ── Card top row (mobile calendar card header) ── */
._cardTopRow_qq5zi_83 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 4px 8px;
}

/* Hide card top row on tablet/desktop (desktop has its own header) */
@media (min-width: 640px) {
  ._cardTopRow_qq5zi_83 { display: none; }
}

._cardTitleGroup_qq5zi_95 {
  display: flex;
  align-items: center;
  gap: 8px;
}

._backBtn_qq5zi_101 {
  display: none;
}

._cardTitle_qq5zi_95 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.3px;
}

._cardCount_qq5zi_112 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 7px;
  border-radius: 999px;
}

/* ── Compact month nav (inside card, right side) ── */
._monthNavCompact_qq5zi_122 {
  display: none;
}

/* ── Calendar section (hidden on mobile) ── */
._calendarSection_qq5zi_127 {
  display: none;
}

/* ── Desktop alignment with logo (15vw) ── */
@media (min-width: 1280px) {
  ._pageInner_qq5zi_133 {
    margin-left: 15vw !important;
    max-width: 70% !important;
    margin-right: 0 !important;
  }
}

/* ── Page title ── */
._pageHeader_qq5zi_141 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 24px 24px 8px;
  position: sticky;
  top: 0;
  background: var(--bg);
  z-index: 5;
}
._pageTitle_qq5zi_151 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}
._pageCount_qq5zi_157 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
  flex-shrink: 0;
}

/* ── Modal embed mode (rendered inside MainMenuSheet sub-screen) ── */
/* No nested overflow or height%, otherwise the sheet's .screens
   scroll container can't receive touch/wheel events. */
._pageModal_qq5zi_170 {
  display: flex;
  flex-direction: column;
  width: 100%;
}
._innerModal_qq5zi_175 {
  max-width: 100% !important;
  margin: 0 !important;
}
/* Mobile-only: shrink event cards inside the sheet's Mein-Kalender
   screen by narrowing the feed AND reducing internal text/padding.
   Substring class match catches the hashed EventCard module classes. */
@media (max-width: 639px) {
  ._pageModal_qq5zi_170 [role="list"] {
    max-width: 88% !important;
    margin: 0 auto !important;
    padding-left: 0 !important;
    padding-right: 0 !important;
    gap: 17px !important;
  }
  ._pageModal_qq5zi_170 [class*="artist"] {
    font-size: 17px !important;
  }
  ._pageModal_qq5zi_170 [class*="footer"] {
    padding: 10px 12px 12px !important;
  }
  ._pageModal_qq5zi_170 [class*="date"]:not([class*="dateTime"]),
  ._pageModal_qq5zi_170 [class*="time"] {
    font-size: 11px !important;
  }
  ._pageModal_qq5zi_170 [class*="genrePill"] {
    font-size: 10px !important;
    padding: 2px 7px !important;
  }
  ._pageModal_qq5zi_170 [class*="badge"] {
    font-size: 10px !important;
    padding: 3px 9px !important;
  }
  ._pageModal_qq5zi_170 [class*="bookmarkCount"] {
    font-size: 11px !important;
  }
}
/* ── Mobile-only calendar block ──────────────────────────
   .mobileCalendar = sticky positioning slot (KEIN transform hier,
   sonst bricht der backdrop-filter auf .calendarCard wegen Stacking-Context).
   .calendarCard = der eigentliche sichtbare Container mit bg + blur + transform. */
._mobileCalendar_s2ho2_2 {
  display: block;
  position: sticky;
  /* --mobile-header-h wird von Header.tsx auf die CONTENT-Höhe des Headers
     gesetzt (ohne safe-area-padding). Safe-Area wird hier separat im calc()
     addiert, damit PWA und Browser identisch positionieren. */
  top: calc(var(--mobile-header-h, 54px) + env(safe-area-inset-top));
  z-index: 30;
}
@media (min-width: 640px) { ._mobileCalendar_s2ho2_2 { display: none; } }

._calendarCard_s2ho2_3 {
  /* Force dark text colors (matches Header, das ebenfalls always-dark ist),
     damit Card + Header in beiden Themes als ein durchgehender Strip wirken. */
  --text-primary: #FFFFFF;
  --text-secondary: #8895A0;
  --accent: #8EBBFF;
  margin: 0 var(--space-4);
  background: rgba(0, 0, 0, 0.40);
  backdrop-filter: blur(28px) saturate(180%) brightness(0.85);
  -webkit-backdrop-filter: blur(28px) saturate(180%) brightness(0.85);
  border: none;
  border-radius: 0 0 22px 22px;
  overflow: hidden;
  padding: 10px 10px 10px;
  /* Instagram-Pattern: transform + opacity werden inline von Home.tsx pro Frame
     gesetzt. backdrop-filter + transform müssen auf DEMSELBEN Element sitzen,
     sonst sampelt der Filter nichts hinter sich (Stacking-Context-Issue). */
  will-change: transform, opacity;
}


._searchSection_s2ho2_37 {
  padding-top: var(--space-3);
}

/* ── Mobile Heute button (below calendar) ───────────────── */
._heuteMobile_s2ho2_42 {
  display: none;
}

._heuteMobileBtn_s2ho2_46 {
  width: 100%;
  padding: 12px;
  border-radius: 9999px;
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.15);
  color: var(--text-secondary);
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.03em;
  min-height: unset;
  transition: border-color 0.15s, color 0.15s;
}
._heuteMobileBtn_s2ho2_46:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._heuteMobileBtn_s2ho2_46 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._heuteMobileBtn_s2ho2_46:hover { border-color: rgba(0, 0, 0, 0.35); }

._heuteMobileBtnActive_s2ho2_63 {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--btn-fg) !important;
}


._dateSection_s2ho2_70 {
  /* creates visual breathing room between search and date strip */
}

/* Filter bar — shows when a date is active */
._filterLabel_s2ho2_75 {
  font-size: 12px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: center;
}

._showAllRow_s2ho2_82 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 10px;
  padding: 0 var(--space-4) var(--space-3);
}

@media (min-width: 768px)  { ._showAllRow_s2ho2_82 { padding-inline: var(--space-6); } }
@media (min-width: 1280px) { ._showAllRow_s2ho2_82 { padding-inline: var(--space-8); } }

._showAllBtn_s2ho2_93 {
  padding: 12px 32px;
  border-radius: var(--btn-radius);
  background: transparent;
  border: 1.5px solid rgba(255,255,255,0.35);
  color: var(--text-primary);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: -0.2px;
  min-height: unset;
  transition: border-color 0.15s, background 0.15s, transform 0.15s;
}
._showAllBtn_s2ho2_93:hover  { border-color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.06); transform: translateY(-1px); }
._showAllBtn_s2ho2_93:active { transform: translateY(0); }

/* ── Card swipe animations (Tinder-style) ───────────────── */
@keyframes _slideFromRight_s2ho2_126 {
  from { transform: translateX(72px) scale(0.96); opacity: 0; }
  to   { transform: translateX(0)    scale(1);    opacity: 1; }
}
@keyframes _slideFromLeft_s2ho2_127 {
  from { transform: translateX(-72px) scale(0.96); opacity: 0; }
  to   { transform: translateX(0)     scale(1);    opacity: 1; }
}
@keyframes _exitToLeft_s2ho2_128 {
  from { transform: translateX(0)     scale(1);    opacity: 1; }
  to   { transform: translateX(-72px) scale(0.96); opacity: 0; }
}
@keyframes _exitToRight_s2ho2_129 {
  from { transform: translateX(0)    scale(1);    opacity: 1; }
  to   { transform: translateX(72px) scale(0.96); opacity: 0; }
}

._slideFromRight_s2ho2_126 { animation: _slideFromRight_s2ho2_126 0.24s cubic-bezier(0.25, 0.46, 0.45, 0.94) both; }
._slideFromLeft_s2ho2_127  { animation: _slideFromLeft_s2ho2_127  0.24s cubic-bezier(0.25, 0.46, 0.45, 0.94) both; }
._exitToLeft_s2ho2_128     { animation: _exitToLeft_s2ho2_128     0.2s  cubic-bezier(0.55, 0,    0.1,  1)    both; }
._exitToRight_s2ho2_129    { animation: _exitToRight_s2ho2_129    0.2s  cubic-bezier(0.55, 0,    0.1,  1)    both; }

/* Loading skeleton */
._skeleton_s2ho2_132 {
  border-radius: var(--card-radius);
  background: linear-gradient(
    90deg,
    var(--card-bg) 25%,
    rgba(255,255,255,0.04) 50%,
    var(--card-bg) 75%
  );
  background-size: 200% 100%;
  animation: _shimmer_s2ho2_1 1.4s infinite;
  aspect-ratio: 3 / 2;
  min-height: 200px;
}

@keyframes _shimmer_s2ho2_1 {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* ── Pull-to-refresh indicator (mobile + PWA) ───────────────
   Lives inside the scrollable .page container, absolute-positioned at the top.
   z-index 1250 → above the sticky Header (z-index 1200) so the favicon shows ON TOP.
   Snaps back when pullSnap class is present (= touch released). */
._pullIndicator_s2ho2_155 {
  position: absolute;
  top: 0;
  left: 50%;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--card-bg);
  border: 1px solid var(--card-border);
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.28);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 1250;
  pointer-events: none;
  /* transform is set inline; transition only kicks in on snap-back */
}
._pullIndicator_s2ho2_155 img {
  width: 24px;
  height: 24px;
  display: block;
  /* Slight subtle scale-in as the user pulls — feels "alive" before refresh */
  animation: _pullBreathe_s2ho2_1 1.6s ease-in-out infinite;
  transform-origin: 50% 50%;
}
._pullSnap_s2ho2_180 {
  transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1), opacity 0.2s;
}
/* Active refresh: faster spin + accent-ring orbiting around the favicon */
._pullSpinning_s2ho2_184 img {
  animation: _pullSpin_s2ho2_184 0.9s linear infinite;
}
._pullSpinning_s2ho2_184::before {
  content: '';
  position: absolute;
  inset: -2px;
  border-radius: 50%;
  border: 2px solid transparent;
  border-top-color: var(--accent);
  border-right-color: var(--accent);
  animation: _pullRing_s2ho2_1 0.9s linear infinite;
}
@keyframes _pullSpin_s2ho2_184 {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
@keyframes _pullBreathe_s2ho2_1 {
  0%, 100% { transform: scale(1); }
  50%      { transform: scale(1.08); }
}
@keyframes _pullRing_s2ho2_1 {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}
/* Desktop: no touch input, hide indicator entirely */
@media (hover: hover) and (pointer: fine) {
  ._pullIndicator_s2ho2_155 { display: none; }
}

/* ── Guest-only register CTA card (first card in feed grid, all viewports) ──
   Desktop: grid `align-items: stretch` (default) auto-matches row neighbor height,
   button is push to the bottom with margin-top: auto.
   Mobile: 1-col grid → height follows content with tight padding. */
._registerPromoCard_s2ho2_218 {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 10px;
  padding: 22px 20px;
  border-radius: var(--card-radius);
  background: var(--accent);
  color: var(--btn-fg);
  border: 1px solid var(--accent);
}
._registerPromoClose_s2ho2_230 {
  position: absolute;
  top: 14px;
  right: 14px;
  width: 30px;
  height: 30px;
  border-radius: 50%;
  border: none;
  background: rgba(0, 0, 0, 0.15);
  color: var(--btn-fg);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  min-height: unset;
  min-width: unset;
  padding: 0;
  transition: background 0.15s;
}
._registerPromoClose_s2ho2_230:hover { background: rgba(0, 0, 0, 0.28); }
._registerPromoTitle_s2ho2_250 {
  font-size: 18px;
  font-weight: 800;
  margin: 0;
  letter-spacing: -0.01em;
  line-height: 1.25;
  padding-right: 40px;  /* avoid overlap with close button */
}
._registerPromoSub_s2ho2_258 {
  font-size: 13px;
  font-weight: 600;
  margin: 0;
  opacity: 0.85;
  line-height: 1.4;
}
._registerPromoBtn_s2ho2_265 {
  margin-top: auto;     /* push to bottom when desktop stretches the card */
  width: 100%;          /* full card width */
  padding: 12px 18px;
  border-radius: 100px;
  background: var(--btn-fg);
  color: var(--accent);
  border: none;
  font-size: 14px;
  font-weight: 800;
  cursor: pointer;
  min-height: unset;
  min-width: unset;
  transition: opacity 0.15s, transform 0.05s;
}
._registerPromoBtn_s2ho2_265:hover { opacity: 0.9; }
._registerPromoBtn_s2ho2_265:active { transform: scale(0.98); }
/* Mobile: no row to stretch against — keep button tight to content above */
@media (max-width: 639px) {
  ._registerPromoBtn_s2ho2_265 { margin-top: 8px; }
}

/* Desktop: card has more vertical room (matches event-card row height) → bump type sizes,
   center the title+sub block vertically, keep the button pinned to the bottom. */
@media (min-width: 1280px) {
  ._registerPromoCard_s2ho2_218 {
    padding: 28px 26px;
    gap: 14px;
    justify-content: flex-start;
    text-align: left;
  }
  /* Auto margins split the free space equally: title pushed down by margin-top:auto,
     sub pushes button down by margin-bottom:auto → text-block centered, button bottom. */
  ._registerPromoTitle_s2ho2_250 {
    font-size: 26px;
    line-height: 1.2;
    padding-right: 48px;
    margin-top: auto;
  }
  ._registerPromoSub_s2ho2_258 { font-size: 16px; margin-bottom: auto; }
  ._registerPromoBtn_s2ho2_265 { font-size: 16px; padding: 14px 20px; margin-top: 0; }
  ._registerPromoClose_s2ho2_230 { width: 34px; height: 34px; top: 16px; right: 16px; }
}

/* ── Premium FAB (Neues Konzi) — same style as Search FAB, blue border ── */
._fab_s2ho2_310 {
  position: fixed;
  bottom: 24px;
  right: 16px;
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1.5px solid #8EBBFF;
  color: #8EBBFF;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 100;
  box-shadow: 0 0 16px 2px rgba(0, 0, 0, 0.5);
  transition: right 0.35s cubic-bezier(0.32, 0.72, 0, 1), transform 0.2s ease, box-shadow 0.2s ease;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}
._fab_s2ho2_310:hover {
  transform: translateY(-2px) scale(1.04) translateZ(0);
  box-shadow: 0 0 22px 3px rgba(0, 0, 0, 0.65);
}
._fab_s2ho2_310:active { transform: scale(0.98) translateZ(0); }

/* Light theme: clean white pill with accent-colored border + icon */
[data-theme="light"] ._fab_s2ho2_310 {
  background: rgba(255, 255, 255, 0.85);
  border-color: var(--accent);
  color: var(--accent);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._fab_s2ho2_310:hover {
  box-shadow: 0 6px 22px rgba(0, 0, 0, 0.18);
}

/* Mobile & Tablet: dock FAB-cluster to viewport bottom (safe-area protected); hide when event panel is open. */
@media (max-width: 1279px) {
  ._fab_s2ho2_310 {
    bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  }
  ._fabPanelOpen_s2ho2_354 { display: none; }
}

/* Desktop: FAB removed, replaced by "+ Neues Konzi" CTA in the Sidebar top-nav. */
@media (min-width: 1280px) {
  ._fab_s2ho2_310,
  ._fabPanelOpen_s2ho2_354 { display: none !important; }
}

/* ── Past-day banner (subtle pill above cards, aligned to calendar card) ──── */
._pastBanner_s2ho2_364 {
  margin: var(--space-4) var(--space-4) var(--space-4);
  padding: 14px 18px;
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}
@media (min-width: 768px) {
  ._pastBanner_s2ho2_364 { margin: var(--space-5) var(--space-6); }
}
/* Desktop: align banner with Header pill bar (70% width, 15vw from each side).
   Banner sits inside .inner (max-width: 95% = 2.5vw gutter), so add 12.5vw to reach 15vw. */
@media (min-width: 1280px) {
  ._pastBanner_s2ho2_364 {
    margin: var(--space-5) 12.5vw;
  }
}
._pastBannerText_s2ho2_386 { display: flex; flex-direction: column; gap: 2px; }
._pastBannerText_s2ho2_386 strong { font-size: 14px; font-weight: 800; color: var(--text-primary); }
._pastBannerText_s2ho2_386 span { font-size: 13px; color: var(--text-secondary); }
._pastBannerBtn_s2ho2_389 {
  padding: 8px 16px;
  border-radius: 100px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  border: none;
  cursor: pointer;
  white-space: nowrap;
  transition: opacity 0.15s;
}
._pastBannerBtn_s2ho2_389:hover { opacity: 0.88; }
._container_1n08y_1 {
  position: relative;
  width: 100%;
}

._input_1n08y_6 {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  padding: 9px 12px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
  box-sizing: border-box;
  min-width: 0;
}
._input_1n08y_6:focus { border-color: rgba(255,255,255,0.4); }
._input_1n08y_6::placeholder { color: var(--text-secondary); }

[data-theme="light"] ._input_1n08y_6 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}

._dropdown_1n08y_28 {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  right: 0;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 12px;
  z-index: 200;
  max-height: 220px;
  overflow-y: auto;
  list-style: none;
  padding: 4px;
  margin: 0;
  box-shadow: 0 8px 32px rgba(0,0,0,0.45);
}

._option_1n08y_45 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  padding: 9px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.1s;
}
._option_1n08y_45:hover { background: var(--overlay-sm); }

._name_1n08y_57 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

._type_1n08y_67 {
  font-size: 11px;
  font-weight: 600;
  color: var(--text-secondary);
  flex-shrink: 0;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
/* ── Page layout ── */
._pageLayout_1bqn1_2 {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

._page_1bqn1_2 {
  flex: 1;
  min-width: 0;
  height: 100%;
  overflow-y: auto;
  scrollbar-width: none;
  display: flex;
  flex-direction: column;
}
._page_1bqn1_2::-webkit-scrollbar { display: none; }

._inner_1bqn1_21 { max-width: 70%; width: 100%; margin-left: 15vw; padding: 0 24px; display: flex; flex-direction: column; flex: 1; gap: 8px; }
@media (max-width: 639px) { ._inner_1bqn1_21 { max-width: 100%; margin-left: 0; padding: 0 16px; } }
@media (min-width: 640px) and (max-width: 1279px) { ._inner_1bqn1_21 { max-width: 92%; margin: 0 auto; } }

/* ── Header ── */
._header_1bqn1_26 { display: flex; flex-direction: column; align-items: flex-start; gap: 12px; padding: 24px 0 16px; position: sticky; top: 0; background: var(--bg); z-index: 5; transition: box-shadow 0.25s, backdrop-filter 0.25s; }

/* Desktop: break header out of the centered .inner (max-width: 70%) so the
   sticky-scroll background + drop-shadow span the full page width. */
@media (min-width: 1280px) {
  ._header_1bqn1_26 {
    width: 100vw;
    margin-left: calc(-15vw - 24px);
    padding: 24px calc(15vw + 24px) 16px;
  }
}
._title_1bqn1_37 { font-size: 24px; font-weight: 800; color: var(--text-primary); margin: 0; }
._headerActions_1bqn1_38 { display: flex; gap: 10px; align-items: center; }
._newBtn_1bqn1_39 { padding: 9px 18px; border-radius: var(--btn-radius); background: var(--accent); color: var(--btn-fg); font-size: 13px; font-weight: 700; }

._successMsg_1bqn1_41 { font-size: 14px; color: #4caf50; background: rgba(76,175,80,0.1); border-radius: 10px; padding: 10px 14px; margin: 0 24px; }

/* ── Event list ── */
._eventList_1bqn1_44 { display: flex; flex-direction: column; gap: 4px; }

._eventRow_1bqn1_46 {
  display: flex;
  align-items: center;
  gap: 12px;
  background: var(--card-bg);
  border-radius: 14px;
  padding: 10px 14px;
  transition: background 0.15s, border-color 0.15s;
  cursor: pointer;
  border: 1px solid transparent;
}
._eventRow_1bqn1_46:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._eventRowActive_1bqn1_58 { background: var(--overlay-sm); border-color: var(--accent); }

._eventThumb_1bqn1_60 {
  width: 52px; height: 52px;
  border-radius: 10px; overflow: hidden;
  background: rgba(255,255,255,0.05);
  flex-shrink: 0;
}
._eventThumb_1bqn1_60 img { width: 100%; height: 100%; object-fit: cover; }

._eventInfo_1bqn1_68 { flex: 1; display: flex; flex-direction: column; gap: 3px; min-width: 0; }

._eventArtistRow_1bqn1_70 { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }

._eventArtist_1bqn1_70 {
  font-size: 14px; font-weight: 700; color: var(--text-primary);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
._eventDate_1bqn1_76 { font-size: 13px; font-weight: 700; color: var(--text-primary); }
._eventVenue_1bqn1_77 { font-size: 12px; color: var(--text-secondary); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
._eventMeta_1bqn1_78 { font-size: 11px; color: var(--text-secondary); }

._draftBadge_1bqn1_80 { font-size: 9px; font-weight: 800; letter-spacing: 0.07em; color: #ff9500; background: rgba(255,149,0,0.15); border-radius: 4px; padding: 2px 5px; flex-shrink: 0; }
._rejectedBadge_1bqn1_81 { font-size: 9px; font-weight: 800; letter-spacing: 0.07em; color: #ff5555; background: rgba(255,85,85,0.15); border-radius: 4px; padding: 2px 5px; flex-shrink: 0; }
._pastBadge_1bqn1_82 { font-size: 9px; font-weight: 800; letter-spacing: 0.07em; color: #8b8b8b; background: rgba(139,139,139,0.15); border-radius: 4px; padding: 2px 5px; flex-shrink: 0; }
._flaggedBadge_1bqn1_83 { font-size: 9px; font-weight: 800; letter-spacing: 0.07em; color: #ef5350; background: rgba(239,83,80,0.15); border-radius: 4px; padding: 2px 5px; flex-shrink: 0; }

._rowActions_1bqn1_85 { display: flex; align-items: center; flex-shrink: 0; }

._menuWrap_1bqn1_87 { position: relative; }
._menuBtn_1bqn1_88 {
  padding: 8px; border-radius: 8px;
  color: var(--text-secondary);
  transition: color 0.15s, background 0.15s;
}
._menuBtn_1bqn1_88:hover { color: var(--text-primary); background: rgba(255,255,255,0.08); }

._menuDropdown_1bqn1_95 {
  position: absolute;
  right: 0; top: calc(100% + 4px);
  background: #111;
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 12px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
  min-width: 160px;
  z-index: 10;
  overflow: hidden;
  animation: _menuIn_1bqn1_1 0.12s ease both;
}
@keyframes _menuIn_1bqn1_1 {
  from { opacity: 0; transform: scale(0.95) translateY(-4px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}
._menuItem_1bqn1_111 {
  display: flex; align-items: center; gap: 10px;
  width: 100%; padding: 11px 14px;
  font-size: 13px; font-weight: 600;
  color: var(--text-primary);
  transition: background 0.12s;
}
._menuItem_1bqn1_111:hover { background: rgba(255,255,255,0.06); }
._menuItemDelete_1bqn1_119 { color: #ff5f57; }
._menuItemDelete_1bqn1_119:hover { background: rgba(255,95,87,0.1); color: #ff5f57; }
._editBtn_1bqn1_121 { padding: 8px; border-radius: 8px; color: var(--text-secondary); transition: color 0.15s, background 0.15s; }
._editBtn_1bqn1_121:hover { color: var(--text-primary); background: rgba(255,255,255,0.08); }
._deleteBtn_1bqn1_123 { padding: 8px; border-radius: 8px; color: var(--text-secondary); transition: color 0.15s, background 0.15s; }
._deleteBtn_1bqn1_123:hover { color: #ff4444; background: rgba(255,68,68,0.1); }
._lastEdit_1bqn1_125 { font-size: 10px; color: var(--text-secondary); opacity: 0.55; margin-top: 2px; }

._empty_1bqn1_127 { text-align: center; color: var(--text-secondary); padding: 48px 24px; font-size: 15px; }
._hint_1bqn1_128 { text-align: center; color: var(--text-secondary); padding: 48px 24px; }

/* ── Panel slot ── */
._panelSlot_1bqn1_131 {
  width: 0;
  flex-shrink: 0;
  overflow: hidden;
  transition: width 0.32s cubic-bezier(0.32, 0.72, 0, 1);
}
._panelSlotOpen_1bqn1_137 { width: 480px; }

@media (max-width: 1279px) {
  ._panelSlot_1bqn1_131 {
    position: fixed !important;
    top: calc(56px + env(safe-area-inset-top)); right: 0;
    width: 100vw !important;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
    z-index: 201;
    transform: translateX(100%);
    transition: transform 0.32s cubic-bezier(0.32, 0.72, 0, 1);
    overflow: hidden;
  }
  ._panelSlotOpen_1bqn1_137 { transform: translateX(0) !important; }
  ._editBackdrop_1bqn1_151 {
    display: block;
    top: calc(56px + env(safe-area-inset-top));
    inset: unset;
    left: 0; right: 0; bottom: 0;
    height: calc(100dvh - 56px - env(safe-area-inset-top));
  }
}
@media (max-width: 480px) {
  ._editPanelHeader_1bqn1_160 { padding-top: 20px; }
}

._editBackdrop_1bqn1_151 {
  display: none;
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.7);
  backdrop-filter: blur(4px);
  z-index: 200; opacity: 0;
  transition: opacity 0.25s ease;
}
._editBackdropVisible_1bqn1_171 { opacity: 1; }
@media (max-width: 1279px) { ._editBackdrop_1bqn1_151 { display: block; } }

/* ── Edit panel ── */
._editPanel_1bqn1_160 {
  width: 100%; height: 100%;
  background: var(--bg);
  border-left: 1px solid var(--nav-border);
  display: flex; flex-direction: column;
  overflow-y: auto; scrollbar-width: none;
}
._editPanel_1bqn1_160::-webkit-scrollbar { display: none; }

._editPanelHeader_1bqn1_160 {
  display: flex; align-items: center; justify-content: space-between;
  padding: 20px 20px 16px;
  position: sticky; top: 0;
  background: var(--card-bg); z-index: 2;
  border-bottom: 1px solid var(--card-border);
  flex-shrink: 0;
}

/* Mobile + tablet: black panel + header for visual separation from sheet/page */
@media (max-width: 1279px) {
  ._editPanel_1bqn1_160 { background: #000; }
  ._editPanelHeader_1bqn1_160 { background: #000; }
}

/* ── Embedded inside MainMenuSheet sub-screen (mobile) ──────────
   Same pattern as UserManagementPage/AdminPage. */
@media (max-width: 1279px) {
  ._pageLayoutModal_1bqn1_202 {
    display: flex !important;
    flex-direction: column;
    flex: 1;
    min-height: 0;
    max-height: calc(100dvh - 82px - max(40px, env(safe-area-inset-top, 0px) + 20px));
    overflow: hidden;
    position: relative;
    width: 100%;
  }
  ._pageLayoutModal_1bqn1_202 ._page_1bqn1_2 { flex: 1; min-height: 0; }
  ._pageLayoutModal_1bqn1_202 ._panelSlot_1bqn1_131 {
    position: absolute !important;
    top: 0 !important; bottom: 0 !important; right: 0 !important; left: 0 !important;
    height: auto !important; width: 100% !important;
    z-index: 5;
    display: block;
    transform: none !important;
    pointer-events: none;
  }
  ._pageLayoutModal_1bqn1_202 ._panelSlotOpen_1bqn1_137 {
    transform: none !important;
    pointer-events: auto;
  }
  ._pageLayoutModal_1bqn1_202 ._editPanel_1bqn1_160 {
    background: #000;
    position: absolute !important;
    inset: 0 !important;
    width: auto !important;
    height: auto !important;
    overflow: hidden;
    display: flex !important;
    flex-direction: column !important;
    animation: _dashFadeIn_1bqn1_1 0.28s ease both;
  }
  ._pageLayoutModal_1bqn1_202 ._editPanelHeader_1bqn1_160 { flex: 0 0 auto; }
  ._pageLayoutModal_1bqn1_202 ._editPanelBody_1bqn1_238 {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }
  ._pageLayoutModal_1bqn1_202 ._editPanelFooter_1bqn1_243 {
    flex: 0 0 auto;
    background: #000;
    padding: 16px 20px calc(16px + env(safe-area-inset-bottom));
    border-top: 1px solid var(--card-border);
  }
  ._editBackdropModal_1bqn1_249 {
    display: none !important;
  }
}
@keyframes _dashFadeIn_1bqn1_1 {
  from { opacity: 0; }
  to { opacity: 1; }
}
._editPanelTitle_1bqn1_257 { font-size: 16px; font-weight: 800; color: var(--text-primary); margin: 0; }
._editCloseBtn_1bqn1_258 {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary); transition: background 0.15s;
}
._editCloseBtn_1bqn1_258:hover { background: rgba(255,255,255,0.14); }

._editPanelBody_1bqn1_238 { flex: 1; padding: 16px 20px; display: flex; flex-direction: column; gap: 12px; overflow-y: auto; scrollbar-width: none; }
._editPanelBody_1bqn1_238::-webkit-scrollbar { display: none; }

._editPanelFooter_1bqn1_243 {
  display: flex; gap: 10px; justify-content: flex-end;
  padding: 16px 20px;
  border-top: 1px solid var(--card-border);
  flex-shrink: 0;
}
._editCancelBtn_1bqn1_275 { padding: 10px 16px; border-radius: var(--btn-radius); background: rgba(255,255,255,0.06); color: var(--text-secondary); font-size: 14px; font-weight: 600; }
._editSaveBtn_1bqn1_276 { padding: 10px 20px; border-radius: var(--btn-radius); background: var(--accent); color: var(--btn-fg); font-size: 14px; font-weight: 700; transition: opacity 0.15s; }
._editSaveBtn_1bqn1_276:hover { opacity: 0.88; }
._editSaveBtn_1bqn1_276:disabled { opacity: 0.5; }

/* ── Form fields (used in edit panel) ── */
._row_1bqn1_85 { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
@media (max-width: 639px) { ._row_1bqn1_85 { grid-template-columns: 1fr; } }
._field_1bqn1_283 { display: flex; flex-direction: column; gap: 5px; }
._field_1bqn1_283 label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-secondary); }
._field_1bqn1_283 input, ._field_1bqn1_283 textarea, ._field_1bqn1_283 select,
._extraSupportBlock_1bqn1_286 input, ._extraSupportBlock_1bqn1_286 textarea {
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px; padding: 9px 12px; font-size: 14px; color: var(--text-primary);
  font-family: inherit; outline: none; resize: none;
  width: 100%; box-sizing: border-box; min-width: 0;
}
._field_1bqn1_283 input:focus, ._field_1bqn1_283 textarea:focus, ._field_1bqn1_283 select:focus,
._extraSupportBlock_1bqn1_286 input:focus, ._extraSupportBlock_1bqn1_286 textarea:focus { border-color: rgba(255,255,255,0.4); }

[data-theme="light"] ._field_1bqn1_283 input,
[data-theme="light"] ._field_1bqn1_283 textarea,
[data-theme="light"] ._field_1bqn1_283 select,
[data-theme="light"] ._extraSupportBlock_1bqn1_286 input,
[data-theme="light"] ._extraSupportBlock_1bqn1_286 textarea {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.15);
}
[data-theme="light"] ._field_1bqn1_283 input:focus,
[data-theme="light"] ._field_1bqn1_283 textarea:focus,
[data-theme="light"] ._field_1bqn1_283 select:focus,
[data-theme="light"] ._extraSupportBlock_1bqn1_286 input:focus,
[data-theme="light"] ._extraSupportBlock_1bqn1_286 textarea:focus {
  border-color: rgba(0,0,0,0.35);
}

/* Only the main description textarea has a vertical resize handle */
._field_1bqn1_283 textarea._descriptionTextarea_1bqn1_312 {
  resize: vertical;
  min-height: 100px;
}

/* ── Custom dropdown (typeWrap pattern, mirror of AuthModal) ── */
._typeWrap_1bqn1_318 { position: relative; }
._typeBtn_1bqn1_319 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  padding: 9px 12px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px;
  font-size: 14px;
  font-weight: 500;
  color: var(--text-primary);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-height: unset;
}
._typeBtn_1bqn1_319:hover { border-color: rgba(255,255,255,0.32); }
._typeBtnOpen_1bqn1_339 { border-color: var(--accent); background: var(--accent-dim); }
[data-theme="light"] ._typeBtn_1bqn1_319 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._typeBtn_1bqn1_319:hover { border-color: rgba(0,0,0,0.32); }
._typeChevron_1bqn1_345 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._typeChevronOpen_1bqn1_350 { transform: rotate(180deg); }
._typeDropdown_1bqn1_351 {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 6px;
  z-index: 100;
  box-shadow: 0 12px 40px rgba(0,0,0,0.5);
}
._typeOption_1bqn1_363 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  background: none;
  transition: background 0.12s, color 0.12s;
  cursor: pointer;
}
._typeOption_1bqn1_363:hover { background: var(--overlay-sm); color: var(--text-primary); }
._typeOptionActive_1bqn1_380 { color: var(--accent); }
._typeOptionActive_1bqn1_380:hover { background: var(--accent-dim); }
._typeOptionSpacer_1bqn1_382 { width: 13px; flex-shrink: 0; }

._imageRow_1bqn1_384 { display: flex; gap: 8px; }
._imageInput_1bqn1_385 { flex: 1; }
._uploadLabel_1bqn1_386 { padding: 9px 14px; border-radius: 10px; background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1); font-size: 13px; font-weight: 600; color: var(--text-secondary); cursor: pointer; white-space: nowrap; }

/* ── Edit panel image preview + position dots ── */
._editImgPreview_1bqn1_389 {
  position: relative;
  border-radius: 14px;
  overflow: hidden;
  aspect-ratio: 3/4;
  background: rgba(255,255,255,0.04);
  flex-shrink: 0;
}
._editImgPreview_1bqn1_389 img { width: 100%; height: 100%; object-fit: cover; }

._positionPicker_1bqn1_399 {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: repeat(3, 18px);
  gap: 4px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  padding: 6px;
  border-radius: 10px;
}
._positionDot_1bqn1_411 {
  width: 18px; height: 18px;
  border-radius: 50%;
  background: rgba(255,255,255,0.35);
  border: none;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  min-height: unset; min-width: unset; padding: 0;
}
._positionDot_1bqn1_411:hover { background: rgba(255,255,255,0.65); transform: scale(1.15); }
._positionDotActive_1bqn1_421 { background: #fff !important; transform: scale(1.15); }

._editSelect_1bqn1_423 {
  appearance: auto;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  color-scheme: dark;
  transition: border-color 0.15s;
}
._editSelect_1bqn1_423:focus { border-color: rgba(255,255,255,0.3); }

/* Edit panel bild input */
._editBildInput_1bqn1_439 { display: flex; flex-direction: column; gap: 8px; }
._editBildUrl_1bqn1_440 {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.15s;
}
._editBildUrl_1bqn1_440:focus { border-color: rgba(255,255,255,0.3); }
._editBildUrl_1bqn1_440::placeholder { color: #555; }
._editOrDivider_1bqn1_452 {
  font-size: 11px;
  color: var(--text-secondary);
  text-align: center;
  position: relative;
}
._editOrDivider_1bqn1_452::before, ._editOrDivider_1bqn1_452::after {
  content: '';
  position: absolute;
  top: 50%;
  width: 40%;
  height: 1px;
  background: rgba(255,255,255,0.08);
}
._editOrDivider_1bqn1_452::before { left: 0; }
._editOrDivider_1bqn1_452::after { right: 0; }
._editHiddenFile_1bqn1_468 { display: none; }
._editUploadBtn_1bqn1_469 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  background: rgba(255,255,255,0.05);
  border: 1px dashed rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 12px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  cursor: pointer;
  transition: all 0.15s;
}
._editUploadBtn_1bqn1_469:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
._editUploadBtnDisabled_1bqn1_485 { opacity: 0.5; cursor: not-allowed; pointer-events: none; }

/* Publish / unpublish toggle */
._publishBtn_1bqn1_488 {
  color: #4caf50;
  padding: 8px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._publishBtn_1bqn1_488:hover { background: rgba(76, 175, 80, 0.15); }
._unpublishBtn_1bqn1_496 {
  color: #505C66;
  padding: 8px;
  border-radius: 8px;
  flex-shrink: 0;
  transition: color 0.15s, background 0.15s;
}
._unpublishBtn_1bqn1_496:hover { color: #ff9500; background: rgba(255, 149, 0, 0.1); }

._extraSupportBlock_1bqn1_286 { display: flex; flex-direction: column; gap: 8px; padding: 10px; background: rgba(255,255,255,0.03); border-radius: 10px; border: 1px solid rgba(255,255,255,0.08); }
[data-theme="light"] ._extraSupportBlock_1bqn1_286 { background: rgba(0,0,0,0.03); border-color: rgba(0,0,0,0.10); }
._extraSupportHeader_1bqn1_507 { display: flex; justify-content: space-between; align-items: center; }
._extraSupportHeader_1bqn1_507 label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-secondary); }
._removeBtn_1bqn1_509 { font-size: 12px; color: var(--text-secondary); background: none; padding: 2px 6px; transition: color 0.15s; }
._removeBtn_1bqn1_509:hover { color: var(--text-primary); }
._supportInput_1bqn1_511, ._supportTextarea_1bqn1_511 { background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.18); border-radius: 10px; padding: 8px 12px; font-size: 14px; color: var(--text-primary); font-family: inherit; outline: none; width: 100%; }
._addSupportBtn_1bqn1_512 { font-size: 13px; font-weight: 600; color: var(--accent); background: rgba(142,187,255,0.07); border: 1px dashed rgba(142,187,255,0.3); border-radius: 10px; padding: 10px; transition: background 0.15s; }
._addSupportBtn_1bqn1_512:hover { background: rgba(142,187,255,0.12); }

/* Old formCard — kept for "Neues Event" modal */
._formCard_1bqn1_516 {
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  padding: 28px;
  width: 100%;
  max-width: min(70vw, 1000px);
  max-height: 85dvh;
  overflow-y: auto;
  scrollbar-width: none;
}
._formCard_1bqn1_516::-webkit-scrollbar { display: none; }
._formTitle_1bqn1_528 { font-size: 18px; font-weight: 800; color: var(--text-primary); margin: 0 0 20px; }
._form_1bqn1_516 { display: flex; flex-direction: column; gap: 12px; }
._formActions_1bqn1_530 { display: flex; gap: 10px; justify-content: flex-end; margin-top: 4px; }
._saveBtn_1bqn1_531 { padding: 12px 24px; border-radius: var(--btn-radius); background: var(--accent); color: var(--btn-fg); font-size: 14px; font-weight: 700; }
._saveBtn_1bqn1_531:disabled { opacity: 0.5; }
._cancelBtn_1bqn1_533 { padding: 12px 18px; border-radius: var(--btn-radius); background: rgba(255,255,255,0.06); color: var(--text-secondary); font-size: 14px; font-weight: 600; }

@media (max-width: 480px) {
  ._editPanelHeader_1bqn1_160 { padding-top: calc(20px + env(safe-area-inset-top)); }
}
/* Shared form styles used by AuthModal (desktop) and MainMenuSheet sub-screens (mobile). */

._formContainer_1ip0r_3 {
  padding: 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

._form_1ip0r_3 { display: flex; flex-direction: column; gap: 14px; }

._field_1ip0r_12 { display: flex; flex-direction: column; gap: 5px; }
._field_1ip0r_12 label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
}
._field_1ip0r_12 input {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  width: 100%;
  transition: border-color 0.15s;
}
._field_1ip0r_12 input:focus { border-color: rgba(255,255,255,0.45); }
._field_1ip0r_12 input::placeholder { color: rgba(255,255,255,0.38); }

[data-theme="light"] ._field_1ip0r_12 input {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._field_1ip0r_12 input:focus { border-color: rgba(0,0,0,0.45); }
[data-theme="light"] ._field_1ip0r_12 input::placeholder { color: rgba(0,0,0,0.38); }

._pwRow_1ip0r_42 { position: relative; }
._pwRow_1ip0r_42 input { padding-right: 42px; }

/* ── Custom dropdown for "Ich bin…" selector ───────────────────── */
._typeWrap_1ip0r_46 { position: relative; }
._typeBtn_1ip0r_47 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 6px;
  width: 100%;
  padding: 10px 14px;
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  font-family: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color 0.15s, background 0.15s;
  min-height: unset;
}
._typeBtn_1ip0r_47:hover { border-color: rgba(255,255,255,0.32); }
._typeBtnOpen_1ip0r_67 { border-color: var(--accent); background: var(--accent-dim); }

[data-theme="light"] ._typeBtn_1ip0r_47 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.18);
}
[data-theme="light"] ._typeBtn_1ip0r_47:hover { border-color: rgba(0,0,0,0.32); }

._typeChevron_1ip0r_75 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._typeChevronOpen_1ip0r_80 { transform: rotate(180deg); }

._typeDropdown_1ip0r_82 {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 6px;
  z-index: 100;
  box-shadow: 0 12px 40px rgba(0,0,0,0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}
._typeOption_1ip0r_96 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  background: none;
  transition: background 0.12s, color 0.12s;
  cursor: pointer;
}
._typeOption_1ip0r_96:hover { background: var(--overlay-sm); color: var(--text-primary); }
._typeOptionActive_1ip0r_113 { color: var(--accent); }
._typeOptionActive_1ip0r_113:hover { background: var(--accent-dim); }
._typeOptionSpacer_1ip0r_115 { width: 13px; flex-shrink: 0; }

._eyeBtn_1ip0r_117 {
  position: absolute;
  right: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-secondary);
  padding: 4px;
}
._eyeBtn_1ip0r_117:hover { color: var(--text-primary); }

._submitBtn_1ip0r_127 {
  padding: 12px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
  margin-top: 4px;
}
._submitBtn_1ip0r_127:hover { opacity: 0.9; }
._submitBtn_1ip0r_127:disabled { opacity: 0.5; }

._links_1ip0r_140 {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  flex-wrap: wrap;
}
._link_1ip0r_140 {
  font-size: 13px;
  color: var(--accent);
  background: none;
  padding: 0;
  min-height: unset;
}
._link_1ip0r_140:hover { text-decoration: underline; }

._error_1ip0r_155 {
  background: rgba(255,68,68,0.1);
  color: #ff6b6b;
  border-radius: 10px;
  padding: 10px 14px;
  font-size: 13px;
}

._successMsg_1ip0r_163 {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(76,175,80,0.1);
  color: #4caf50;
  border-radius: 10px;
  padding: 12px 14px;
  font-size: 13px;
  line-height: 1.5;
}

._successBlock_1ip0r_175 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
  padding: 12px 0 4px;
  text-align: center;
}

._successTitle_1ip0r_184 {
  margin: 0;
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  line-height: 1.5;
}

._successHint_1ip0r_192 {
  margin: -4px 0 0;
  font-size: 12px;
  color: var(--text-secondary);
  line-height: 1.5;
}

._hint_1ip0r_199 {
  font-size: 13px;
  color: var(--text-secondary);
  margin-bottom: -4px;
}

._agbLabel_1ip0r_205 {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  font-size: 12px;
  color: var(--text-secondary);
  cursor: pointer;
  margin-top: 4px;
}
._agbLabel_1ip0r_205 input[type="checkbox"] {
  width: auto;
  padding: 0;
  border: none;
  border-radius: 0;
  background: none;
  margin-top: 2px;
  flex-shrink: 0;
}
._agbLabel_1ip0r_205 a { color: var(--accent); }
._wrap_1ur2r_1 {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

._pills_1ur2r_7 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

._pill_1ur2r_7 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 10px 18px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  min-height: unset;
  line-height: 1;
  transition: border-color 0.15s, background 0.15s, color 0.15s;
}
._pill_1ur2r_7:hover {
  border-color: rgba(255, 255, 255, 0.32);
  color: var(--text-primary);
  background: rgba(255, 255, 255, 0.04);
}

._pillActive_1ur2r_37 {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--btn-fg);
}
._pillActive_1ur2r_37:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: var(--btn-fg);
  opacity: 0.92;
}

[data-theme="light"] ._pill_1ur2r_7 {
  border-color: rgba(0, 0, 0, 0.18);
}
[data-theme="light"] ._pill_1ur2r_7:hover {
  border-color: rgba(0, 0, 0, 0.32);
  background: rgba(0, 0, 0, 0.03);
}

._hint_1ur2r_57 {
  padding: 12px 14px;
  background: rgba(142, 187, 255, 0.08);
  border: 1px solid rgba(142, 187, 255, 0.25);
  border-radius: 12px;
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-secondary);
}
._hint_1ur2r_57 strong { color: var(--text-primary); font-weight: 700; }
/* ── Modal chrome (only used by CreateEventModal wrapper) ────── */
@keyframes _ceFadeIn_rjihr_1 { from { opacity: 0; } to { opacity: 1; } }
@keyframes _ceFadeOut_rjihr_1 { from { opacity: 1; } to { opacity: 0; } }
@keyframes _ceSlideUp_rjihr_1 { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: translateY(0); } }
@keyframes _ceSlideDown_rjihr_1 { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(16px); } }

._backdrop_rjihr_7 {
  position: fixed;
  inset: 0;
  z-index: 1250;
  background: rgba(0, 0, 0, 0.85);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  animation: _ceFadeIn_rjihr_1 0.2s ease;
}
._backdropOut_rjihr_18 { animation: _ceFadeOut_rjihr_1 0.2s ease forwards; }

._modal_rjihr_20 {
  background: #0F0F10;
  border-radius: 20px;
  width: 100%;
  max-width: 520px;
  max-height: 90dvh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.4), 0 0 60px rgba(142, 187, 255, 0.18);
  animation: _ceSlideUp_rjihr_1 0.22s ease;
}
._modalOut_rjihr_32 { animation: _ceSlideDown_rjihr_1 0.2s ease forwards; }

/* Desktop: add 20vw on top of the mobile/tablet default 520px */
@media (min-width: 1280px) {
  ._modal_rjihr_20 { max-width: calc(520px + 20vw); }
}

._modalHeader_rjihr_39 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 20px 0;
  flex-shrink: 0;
}
._modalTitle_rjihr_46 {
  font-size: 17px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}
._closeBtn_rjihr_52 {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
}
._closeBtn_rjihr_52:hover { background: rgba(255, 255, 255, 0.12); color: var(--text-primary); }

/* ── Form wrapper (shared between sheet sub-screen + modal) ──── */
._formWrap_rjihr_66 {
  display: flex;
  flex-direction: column;
  height: 100%;
  min-height: 0;
  width: 100%;
  color: var(--text-primary);
}

._inlineHeader_rjihr_75 {
  padding: 4px 22px 14px;
}
._eyebrow_rjihr_78 {
  display: block;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 4px;
}
._formTitle_rjihr_87 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.5px;
}

._formBody_rjihr_95 {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  padding: 4px 22px 8px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  scrollbar-width: none;
}
._formBody_rjihr_95::-webkit-scrollbar { display: none; }

/* ── Cover Upload Card ─────────────────────────────────────── */
._coverCard_rjihr_108 {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
  border: 1.5px dashed rgba(255, 255, 255, 0.18);
  border-radius: 16px;
  cursor: pointer;
  transition: border-color 0.2s, background 0.2s;
  background: rgba(255, 255, 255, 0.02);
  min-height: 76px;
}
._coverCard_rjihr_108:not(._coverCardFilled_rjihr_120):hover { border-color: var(--accent); background: rgba(142, 187, 255, 0.05); }
[data-theme="light"] ._coverCard_rjihr_108 {
  border-color: rgba(0, 0, 0, 0.18);
  background: rgba(0, 0, 0, 0.02);
}
._coverCardFilled_rjihr_120 {
  width: 100%;
  aspect-ratio: 3 / 2;
  padding: 0;
  background-size: cover;
  background-position: center;
  position: relative;
  border-style: solid;
  border-color: rgba(255, 255, 255, 0.1);
  transition: none;
  min-height: 0;       /* lift the 76px floor from .coverCard so aspect-ratio wins */
  flex-shrink: 0;      /* don't let the form-flex compress the preview */
}

/* Once filled, the card is no longer an upload affordance — suppress EVERY hover
   visual. transform: none kills any scale inherited from parent rules. border-color
   stays put, background-color (NOT shorthand) is forced transparent without wiping
   the inline background-image. */
._coverCardFilled_rjihr_120:hover,
._coverCardFilled_rjihr_120:focus,
._coverCardFilled_rjihr_120:focus-visible,
._coverCardFilled_rjihr_120:focus-within,
._coverCardFilled_rjihr_120:active {
  border-color: rgba(255, 255, 255, 0.1) !important;
  background-color: transparent !important;
  transform: none !important;
  filter: none !important;
  opacity: 1 !important;
}
[data-theme="light"] ._coverCardFilled_rjihr_120:hover,
[data-theme="light"] ._coverCardFilled_rjihr_120:focus,
[data-theme="light"] ._coverCardFilled_rjihr_120:focus-visible,
[data-theme="light"] ._coverCardFilled_rjihr_120:focus-within,
[data-theme="light"] ._coverCardFilled_rjihr_120:active {
  border-color: rgba(0, 0, 0, 0.1) !important;
  background-color: transparent !important;
  transform: none !important;
  filter: none !important;
  opacity: 1 !important;
}

/* Tablet+/desktop: cap the uploaded preview width (form is wider here, so the
   full-width 3:2 preview was visually overwhelming). Explicit width + height
   keeps it robust against flex sizing edge-cases. */
@media (min-width: 768px) {
  ._coverCardFilled_rjihr_120 {
    width: 340px !important;
    height: 227px !important;
    min-height: 227px !important;
    flex-shrink: 0;
    align-self: flex-start;
  }
}
._coverIcon_rjihr_178 { color: var(--text-secondary); flex-shrink: 0; }
._coverText_rjihr_179 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
._coverTitle_rjihr_186 { font-size: 14px; font-weight: 700; color: var(--text-primary); }
._coverHint_rjihr_187 { font-size: 11px; color: var(--text-muted); }
._coverPlus_rjihr_188 { color: var(--text-muted); flex-shrink: 0; }
._coverEditOverlay_rjihr_189 {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  backdrop-filter: blur(6px);
  -webkit-backdrop-filter: blur(6px);
}

/* 3×3 image position picker overlay (mirrors AdminPage edit form). */
._positionPicker_rjihr_206 {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: grid;
  grid-template-columns: repeat(3, 18px);
  gap: 4px;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  padding: 6px;
  border-radius: 10px;
}
._positionDot_rjihr_220 {
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.35);
  border: none;
  cursor: pointer;
  transition: background 0.15s, transform 0.15s;
  min-height: unset;
  min-width: unset;
  padding: 0;
}
._positionDot_rjihr_220:hover { background: rgba(255, 255, 255, 0.65); transform: scale(1.15); }
._positionDotActive_rjihr_233 { background: #fff !important; transform: scale(1.15); }

/* Category UI viewport split: dropdown on mobile/tablet, chips on desktop ≥768px. */
._categoryMobile_rjihr_236 { display: block; }
._categoryDesktop_rjihr_237 { display: none; }
@media (min-width: 768px) {
  ._categoryMobile_rjihr_236 { display: none; }
  ._categoryDesktop_rjihr_237 { display: block; }
}

._sonstigesHint_rjihr_243 {
  font-size: 12px;
  line-height: 1.5;
  color: var(--text-secondary);
  background: var(--overlay-sm);
  border: 1px solid var(--border-dim);
  border-radius: 10px;
  padding: 10px 12px;
}
._sonstigesHint_rjihr_243 strong { color: var(--text-primary); font-weight: 700; }

/* ── Section (numbered group) ──────────────────────────────── */
._section_rjihr_255 {
  display: flex;
  flex-direction: column;
  padding: 14px 0 8px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
}
[data-theme="light"] ._section_rjihr_255 { border-top-color: rgba(0, 0, 0, 0.1); }
._section_rjihr_255:first-of-type { border-top: none; padding-top: 4px; }

._sectionHead_rjihr_264 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  background: none;
  border: none;
  padding: 6px 0;
  cursor: pointer;
  text-align: left;
  min-height: unset;
  transition: opacity 0.15s;
}
._sectionHead_rjihr_264:hover { opacity: 0.85; }
._sectionChev_rjihr_278 {
  margin-left: auto;
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._sectionChevOpen_rjihr_284 { transform: rotate(180deg); }

._sectionBody_rjihr_286 {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-top: 16px;
}
._sectionBadge_rjihr_292 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 12px;
  font-weight: 800;
  flex-shrink: 0;
}
._sectionTitle_rjihr_305 {
  font-size: 24px;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--accent);
  margin: 0;
}

/* ── Fields ─────────────────────────────────────────────────── */
._field_rjihr_315 {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
._fieldLabel_rjihr_320 {
  display: flex;
  align-items: baseline;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}
._required_rjihr_327 {
  color: var(--accent);
  font-weight: 700;
}
._optional_rjihr_331 {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 500;
  margin-left: auto;
}

._input_rjihr_338 {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 12px 16px;
  font-size: 15px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  width: 100%;
  transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
  min-height: unset;
}
._input_rjihr_338::placeholder { color: rgba(255, 255, 255, 0.32); }
._input_rjihr_338:focus,
._input_rjihr_338:focus-within {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.15);
  background: rgba(255, 255, 255, 0.06);
}

[data-theme="light"] ._input_rjihr_338 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.14);
}
[data-theme="light"] ._input_rjihr_338::placeholder { color: rgba(0, 0, 0, 0.32); }

._textarea_rjihr_365 {
  resize: vertical;
  line-height: 1.5;
  min-height: 90px;
}

/* Field with leading icon */
._fieldWithIcon_rjihr_372 {
  position: relative;
}
._fieldIcon_rjihr_375 {
  position: absolute;
  left: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  pointer-events: none;
  z-index: 1;
  display: flex;
  align-items: center;
}
._fieldWithIcon_rjihr_372 > input,
._fieldWithIcon_rjihr_372 input {
  padding-left: 42px;
}

/* Price field with € suffix */
._priceField_rjihr_392 { position: relative; }
._priceField_rjihr_392 ._input_rjihr_338 { padding-right: 36px; }
._priceUnit_rjihr_394 {
  position: absolute;
  right: 16px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-muted);
  font-size: 14px;
  pointer-events: none;
}

._row2_rjihr_404 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}

/* ── Category Dropdown ─────────────────────────────────────── */
._catWrap_rjihr_411 { position: relative; }
._catBtn_rjihr_412 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  cursor: pointer;
  font-weight: 600;
  text-align: left;
}
._catBtnOpen_rjihr_420 {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.15);
}
._catVal_rjihr_424 {
  display: flex;
  align-items: center;
  gap: 10px;
}
._catDot_rjihr_429 {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
._catChev_rjihr_436 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._catChevOpen_rjihr_441 { transform: rotate(180deg); }

._catDropdown_rjihr_443 {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 6px;
  z-index: 100;
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
._catOption_rjihr_460 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  background: none;
  cursor: pointer;
  text-align: left;
  min-height: unset;
  transition: background 0.12s, color 0.12s;
}
._catOption_rjihr_460:hover { background: rgba(255, 255, 255, 0.06); color: var(--text-primary); }
._catOptionActive_rjihr_477 { color: var(--text-primary); }
._catOptionLabel_rjihr_478 { flex: 1; }

/* ── Mehr Details Collapse ─────────────────────────────────── */
._detailsToggle_rjihr_481 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  text-align: left;
  background: none;
  border: none;
  padding: 14px 0;
  cursor: pointer;
  font-size: 18px;
  font-weight: 700;
  color: var(--accent);
  border-top: 1px solid rgba(255, 255, 255, 0.06);
  min-height: unset;
}
[data-theme="light"] ._detailsToggle_rjihr_481 { border-top-color: rgba(0, 0, 0, 0.06); }
._detailsHint_rjihr_499 {
  font-weight: 500;
  color: var(--text-muted);
  font-size: 12px;
  margin-left: 4px;
}
._detailsChevron_rjihr_505 { transition: transform 0.2s; flex-shrink: 0; }
._detailsChevronOpen_rjihr_506 { transform: rotate(180deg); }

._detailsBody_rjihr_508 {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding-top: 4px;
}

._supportBlock_rjihr_515 {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px;
  background: rgba(255, 255, 255, 0.03);
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 14px;
}
._supportHead_rjihr_524 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
}
._removeChip_rjihr_530 {
  font-size: 12px;
  color: #ff6b6b;
  background: none;
  padding: 4px 8px;
  border-radius: 8px;
  cursor: pointer;
  min-height: unset;
  transition: background 0.15s;
}
._removeChip_rjihr_530:hover { background: rgba(255, 107, 107, 0.1); }

._addSupportBtn_rjihr_542 {
  padding: 12px;
  border-radius: 12px;
  background: rgba(142, 187, 255, 0.08);
  border: 1px solid rgba(142, 187, 255, 0.25);
  color: var(--accent);
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  min-height: unset;
  transition: background 0.15s;
}
._addSupportBtn_rjihr_542:hover { background: rgba(142, 187, 255, 0.16); }

/* ── Fine print ─────────────────────────────────────────────── */
._finePrint_rjihr_557 {
  font-size: 11px;
  color: var(--text-muted);
  line-height: 1.6;
  text-align: center;
  padding: 16px 8px 0;
  margin: 0;
}

/* AGB confirm checkbox — left aligned, larger than fine print */
._agbConfirmLabel_rjihr_567 {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 16px 0 4px;
  font-size: 13px;
  line-height: 1.5;
  color: var(--text-secondary);
  cursor: pointer;
}
._agbConfirmCheckbox_rjihr_577 {
  flex-shrink: 0;
  width: 18px;
  height: 18px;
  margin: 2px 0 0;
  accent-color: var(--accent);
  cursor: pointer;
}

/* ── Sticky Footer ──────────────────────────────────────────── */
._stickyFooter_rjihr_587 {
  position: sticky;
  bottom: 0;
  z-index: 10;
  display: flex;
  gap: 10px;
  padding: 14px 22px calc(14px + env(safe-area-inset-bottom, 0px));
  background: rgba(0, 0, 0, 0.86);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-top: 1px solid rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}
[data-theme="light"] ._stickyFooter_rjihr_587 {
  background: rgba(255, 255, 255, 0.92);
  border-top-color: rgba(0, 0, 0, 0.08);
}

._cancelBtn_rjihr_605 {
  flex: 0 0 auto;
  padding: 13px 20px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.06);
  color: var(--text-secondary);
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
  min-height: unset;
}
._cancelBtn_rjihr_605:hover { background: rgba(255, 255, 255, 0.1); color: var(--text-primary); }

._publishBtn_rjihr_619 {
  flex: 1;
  padding: 14px;
  border-radius: 14px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 15px;
  font-weight: 800;
  cursor: pointer;
  transition: opacity 0.15s, transform 0.05s;
  box-shadow: 0 0 28px rgba(142, 187, 255, 0.3);
  min-height: unset;
}
._publishBtn_rjihr_619:hover { opacity: 0.92; }
._publishBtn_rjihr_619:active { transform: scale(0.99); }
._publishBtn_rjihr_619:disabled { opacity: 0.5; cursor: not-allowed; box-shadow: none; }

/* ─── Light theme overrides ──────────────────────────────────
   Modal originally designed for dark mode (hardcoded #000 +
   rgba(255,255,255,…) surfaces). Override the key surfaces so
   the form stays readable on light bg. */
[data-theme="light"] ._modal_rjihr_20 {
  background: #FFFFFF;
  box-shadow: 0 0 0 1px rgba(0, 0, 0, 0.08), 0 16px 60px rgba(0, 0, 0, 0.18);
}
[data-theme="light"] ._closeBtn_rjihr_52 {
  background: rgba(0, 0, 0, 0.05);
}
[data-theme="light"] ._closeBtn_rjihr_52:hover {
  background: rgba(0, 0, 0, 0.1);
}
[data-theme="light"] ._formBody_rjihr_95 {
  border-top-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] ._supportBlock_rjihr_515 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] ._catOption_rjihr_460:hover {
  background: rgba(0, 0, 0, 0.05);
}
[data-theme="light"] ._cancelBtn_rjihr_605 {
  background: rgba(0, 0, 0, 0.05);
}
[data-theme="light"] ._cancelBtn_rjihr_605:hover {
  background: rgba(0, 0, 0, 0.08);
}
[data-theme="light"] ._publishBtn_rjihr_619 {
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}
/* ── Desktop: hide ──────────────────────────────────────── */
@media (min-width: 1280px) {
  ._scrim_1wvq9_3, ._sheet_1wvq9_3 { display: none !important; }
}

/* ── Scrim ──────────────────────────────────────────────── */
._scrim_1wvq9_3 {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.78);
  backdrop-filter: blur(2px);
  -webkit-backdrop-filter: blur(2px);
  z-index: 1250;
  animation: _fadeIn_1wvq9_1 0.22s ease both;
}
._scrimClosing_1wvq9_16 {
  animation: _fadeOut_1wvq9_1 0.22s ease forwards;
}

/* ── Sheet (content-based height) ───────────────────────── */
._sheet_1wvq9_3 {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1260;
  max-height: calc(100dvh - 40px);
  background: rgba(0, 0, 0, 0.92);
  backdrop-filter: blur(20px) saturate(140%);
  -webkit-backdrop-filter: blur(20px) saturate(140%);
  border-radius: 28px 28px 0 0;
  border-top: 1px solid rgba(142, 187, 255, 0.28);
  box-shadow:
    0 -6px 24px rgba(142, 187, 255, 0.22),
    0 -20px 50px rgba(0, 0, 0, 0.5);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  animation: _slideUp_1wvq9_1 0.32s cubic-bezier(0.32, 0.72, 0, 1) both;
}
._sheetClosing_1wvq9_41 {
  animation: _slideDown_1wvq9_1 0.26s cubic-bezier(0.32, 0.72, 0, 1) forwards;
}

._sheetTall_1wvq9_45 {
  top: max(40px, calc(env(safe-area-inset-top, 0px) + 20px));
  max-height: none;
  height: auto;
}

[data-theme="light"] ._sheet_1wvq9_3 {
  background: rgba(247, 247, 249, 0.92);
  border-top-color: rgba(0, 0, 0, 0.06);
}

/* ── Handle ─────────────────────────────────────────────── */
/* Wider touch-zone around the visual handle so drag-to-dismiss is easy to hit */
._handleZone_1wvq9_58 {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 10px 0 6px;
  cursor: grab;
  flex-shrink: 0;
  touch-action: none;  /* let JS handle touch instead of default scroll */
}
._handleZone_1wvq9_58:active { cursor: grabbing; }
._handle_1wvq9_58 {
  width: 40px;
  height: 5px;
  border-radius: 3px;
  background: rgba(255, 255, 255, 0.25);
  pointer-events: none;
  flex-shrink: 0;
}
[data-theme="light"] ._handle_1wvq9_58 {
  background: rgba(0, 0, 0, 0.18);
}

/* ── Profile Header (main screen) ──────────────────────── */
._profile_1wvq9_81 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 22px 18px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}
[data-theme="light"] ._profile_1wvq9_81 {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

._profileGuest_1wvq9_93 {
  padding: 6px 22px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}
._profileGuestTitle_1wvq9_98 {
  font-size: 22px;
  font-weight: 800;
  letter-spacing: -0.4px;
  color: var(--text-primary);
  margin: 0;
}
[data-theme="light"] ._profileGuest_1wvq9_93 {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

._profileMain_1wvq9_109 {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 13px;
  background: none;
  border: none;
  padding: 0;
  text-align: left;
  cursor: pointer;
  min-height: unset;
  color: inherit;
  font-family: inherit;
}

._avatar_1wvq9_124,
._avatarFallback_1wvq9_125 {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  flex: 0 0 auto;
  border: 1px solid rgba(255, 255, 255, 0.14);
  object-fit: cover;
}
._avatarFallback_1wvq9_125 {
  display: flex;
  align-items: center;
  justify-content: center;
  background: radial-gradient(circle at 35% 30%, #3a3a40, #131316);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
}
[data-theme="light"] ._avatar_1wvq9_124,
[data-theme="light"] ._avatarFallback_1wvq9_125 {
  border-color: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._avatarFallback_1wvq9_125 {
  background: radial-gradient(circle at 35% 30%, #d8d8dc, #b6b6bc);
}

._profileText_1wvq9_150 {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
._profileName_1wvq9_156 {
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.2px;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._profileLink_1wvq9_165 {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
}

._gear_1wvq9_174 {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.04);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #9a9aa0;
  flex-shrink: 0;
  cursor: pointer;
  min-height: unset;
  min-width: unset;
  padding: 0;
  transition: background 0.15s, border-color 0.15s;
}
._gear_1wvq9_174:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.18);
}
[data-theme="light"] ._gear_1wvq9_174 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.1);
  color: #6c6c70;
}

/* ── Sub-Screen Header (search / filter) ───────────────── */
._subHeader_1wvq9_202 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 16px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  flex-shrink: 0;
}
[data-theme="light"] ._subHeader_1wvq9_202 {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

._subHeaderBack_1wvq9_214,
._subHeaderClose_1wvq9_215 {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.07);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  transition: background 0.15s;
  min-height: unset;
  min-width: unset;
  padding: 0;
}
._subHeaderBack_1wvq9_214:hover,
._subHeaderClose_1wvq9_215:hover {
  background: rgba(255, 255, 255, 0.14);
}
[data-theme="light"] ._subHeaderBack_1wvq9_214,
[data-theme="light"] ._subHeaderClose_1wvq9_215 {
  background: rgba(0, 0, 0, 0.05);
}

._subHeaderTitle_1wvq9_241 {
  flex: 1;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: -0.3px;
  color: var(--text-primary);
  margin: 0;
  text-align: left;
  display: flex;
  align-items: center;
  gap: 8px;
}

._subHeaderCount_1wvq9_254 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 22px;
  padding: 0 8px;
  border-radius: 11px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 12px;
  font-weight: 700;
  line-height: 1;
}

._subHeaderTrail_1wvq9_269 {
  display: flex;
  align-items: center;
  gap: 8px;
}

._resetLink_1wvq9_275 {
  background: none;
  border: none;
  font-size: 14px;
  font-weight: 600;
  color: var(--accent);
  cursor: pointer;
  padding: 4px 8px;
  min-height: unset;
  font-family: inherit;
}

/* ── Screens Container ──────────────────────────────────── */
._screens_1wvq9_288 {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  position: relative;
}
._screens_1wvq9_288::-webkit-scrollbar { display: none; }

._screen_1wvq9_288 {
  min-height: 100%;
  display: flex;
  flex-direction: column;
  position: relative;
}

._screenEnterRight_1wvq9_306 {
  animation: _slideInRight_1wvq9_1 0.3s cubic-bezier(0.32, 0.72, 0, 1) both;
}
._screenEnterLeft_1wvq9_309 {
  animation: _slideInLeft_1wvq9_1 0.3s cubic-bezier(0.32, 0.72, 0, 1) both;
}

/* ── Menu (main screen body) ───────────────────────────── */
._menu_1wvq9_314 {
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 14px 22px 0;
}

._row_1wvq9_321 {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  text-align: left;
  padding: 13px 14px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
  cursor: pointer;
  font-family: inherit;
  min-height: 60px;
  transition: background 0.12s, border-color 0.12s, transform 0.1s;
}
._row_1wvq9_321:active { transform: scale(0.98); }
._row_1wvq9_321:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}
[data-theme="light"] ._row_1wvq9_321 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] ._row_1wvq9_321:hover {
  background: rgba(0, 0, 0, 0.05);
}

._rowActive_1wvq9_350 {
  border-color: var(--accent);
  background: var(--accent-dim);
}

._rowPrimary_1wvq9_355 {
  background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 75%, #000));
  border: none;
  color: var(--btn-fg);
  box-shadow: 0 8px 22px color-mix(in srgb, var(--accent) 40%, transparent);
}
._rowPrimary_1wvq9_355:hover {
  background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 75%, #000));
}

._rowLogout_1wvq9_365,
._rowLogin_1wvq9_366 {
  background: transparent;
  /* color + border inherited from .row defaults */
}
._rowLogout_1wvq9_365:hover,
._rowLogin_1wvq9_366:hover {
  background: transparent;
  border-color: rgba(255, 255, 255, 0.1);
}
[data-theme="light"] ._rowLogout_1wvq9_365,
[data-theme="light"] ._rowLogin_1wvq9_366 {
  background: transparent;
}
[data-theme="light"] ._rowLogout_1wvq9_365:hover,
[data-theme="light"] ._rowLogin_1wvq9_366:hover {
  background: transparent;
}

._logoutSection_1wvq9_384,
._loginSection_1wvq9_385 {
  /* Sibling of .menu — mirror its horizontal padding so the row aligns with
     the other menu items. Top padding matches .menu's gap (7px). */
  padding: 7px 22px calc(20px + env(safe-area-inset-bottom, 0px));
}

._rowLogin_1wvq9_366 {
  /* same default look as a .row, but explicit hook for future styling */
}

._icon_1wvq9_395 {
  width: 42px;
  height: 42px;
  flex: 0 0 auto;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-primary);
}
[data-theme="light"] ._icon_1wvq9_395 {
  background: rgba(0, 0, 0, 0.05);
}
._iconPrimary_1wvq9_409 {
  background: rgba(255, 255, 255, 0.18) !important;
  color: var(--btn-fg);
}

._text_1wvq9_414 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
._label_1wvq9_421 {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.1px;
}
._rowPrimary_1wvq9_355 ._label_1wvq9_421 { font-weight: 700; }
._sub_1wvq9_202 {
  font-size: 13px;
  font-weight: 400;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._rowPrimary_1wvq9_355 ._sub_1wvq9_202 { color: rgba(255, 255, 255, 0.78); }

._badge_1wvq9_437 {
  min-width: 22px;
  height: 22px;
  padding: 0 7px;
  border-radius: 11px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

._chev_1wvq9_452 {
  display: flex;
  align-items: center;
  color: #6a6a6e;
  flex-shrink: 0;
}

/* ── SEARCH screen ─────────────────────────────────────── */
._searchBody_1wvq9_460 {
  padding: 16px 22px calc(26px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 14px;
}

._searchInputWrap_1wvq9_467 {
  position: relative;
  display: flex;
  align-items: center;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.18);
  border-radius: 14px;
  padding: 0 14px;
}
[data-theme="light"] ._searchInputWrap_1wvq9_467 {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.12);
}
._searchInputWrap_1wvq9_467:focus-within {
  border-color: var(--accent);
}

._searchIcon_1wvq9_484 {
  color: var(--text-secondary);
  flex-shrink: 0;
}

._searchInput_1wvq9_467 {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  padding: 14px 10px;
  font-size: 16px;
  color: var(--text-primary);
  font-family: inherit;
  min-width: 0;
}
._searchInput_1wvq9_467::placeholder { color: var(--text-secondary); }

._searchClear_1wvq9_502 {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  border: none;
  background: rgba(255, 255, 255, 0.1);
  color: var(--text-primary);
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  flex-shrink: 0;
  min-height: unset;
  min-width: unset;
  padding: 0;
}
._searchClear_1wvq9_502:hover { background: rgba(255, 255, 255, 0.16); }

._searchHint_1wvq9_520 {
  font-size: 14px;
  color: var(--text-secondary);
  margin: 8px 4px 0;
}

._searchResults_1wvq9_526 {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

._searchResult_1wvq9_526 {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  min-height: unset;
  transition: background 0.12s;
}
._searchResult_1wvq9_526:hover {
  background: rgba(255, 255, 255, 0.07);
}
[data-theme="light"] ._searchResult_1wvq9_526 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}

._searchResultThumb_1wvq9_559,
._searchResultThumbFallback_1wvq9_560 {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  flex-shrink: 0;
  object-fit: cover;
}
._searchResultThumbFallback_1wvq9_560 {
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
}

._searchResultText_1wvq9_571 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
._searchResultArtist_1wvq9_578 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._searchResultMeta_1wvq9_586 {
  font-size: 12px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── FILTER screen ─────────────────────────────────────── */
._filterBody_1wvq9_595 {
  padding: 14px 22px calc(26px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
}

._filterSubTitle_1wvq9_601 {
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.6px;
  color: var(--text-secondary);
  margin: 0 0 12px;
  text-transform: uppercase;
}

._filterGrid_1wvq9_610 {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

._filterRow_1wvq9_616 {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 15px;
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  cursor: pointer;
  width: 100%;
  min-height: unset;
  font-family: inherit;
  color: var(--text-primary);
  text-align: left;
  transition: background 0.12s, border-color 0.12s, transform 0.1s;
}
._filterRow_1wvq9_616:active { transform: scale(0.98); }
._filterRowActive_1wvq9_633 {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}
[data-theme="light"] ._filterRow_1wvq9_616 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}

._filterDot_1wvq9_642 {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  flex-shrink: 0;
}

._filterLabel_1wvq9_649 {
  flex: 1;
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.1px;
}

._filterBox_1wvq9_656 {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  border: 1.5px solid rgba(255, 255, 255, 0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  color: var(--btn-fg);
  background: transparent;
  transition: background 0.15s, border-color 0.15s;
}
._filterBoxActive_1wvq9_669 {
  background: var(--accent);
  border-color: var(--accent);
}
[data-theme="light"] ._filterBox_1wvq9_656 {
  border-color: rgba(0, 0, 0, 0.2);
}

._filterHint_1wvq9_677 {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 16px 4px 0;
  line-height: 1.45;
}

._filterApply_1wvq9_684 {
  width: 100%;
  margin-top: 18px;
  padding: 16px;
  border: none;
  border-radius: 16px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 17px;
  font-weight: 700;
  cursor: pointer;
  min-height: unset;
  font-family: inherit;
  transition: opacity 0.15s;
}
._filterApply_1wvq9_684:hover { opacity: 0.92; }

/* ── Category switch (iOS-style, matches desktop FilterPopup) ── */
._filterSwitch_1wvq9_702 {
  position: relative;
  width: 40px;
  height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  flex-shrink: 0;
  margin-left: auto;
  transition: background 0.2s ease;
}
._filterSwitchKnob_1wvq9_712 {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0, 0, 0, 0.3);
  transition: transform 0.2s cubic-bezier(0.32, 0.72, 0, 1);
}
._filterSwitch_1wvq9_702._filterSwitchOn_1wvq9_723 {
  background: var(--accent);
}
._filterSwitchOn_1wvq9_723 ._filterSwitchKnob_1wvq9_712 {
  transform: translateX(16px);
}
[data-theme="light"] ._filterSwitch_1wvq9_702 {
  background: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._filterSwitch_1wvq9_702._filterSwitchOn_1wvq9_723 {
  background: var(--accent);
}

/* ── Genres-Sektion ── */
._filterSectionHead_1wvq9_737 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  /* min-height reserves space so the row is the same size whether the
     reset link is mounted or not — kein Layout-Shift. */
  min-height: 28px;
  margin: 22px 4px 0;
}
._filterResetLink_1wvq9_746 {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  padding: 0 8px;
  min-height: unset;
  font-family: inherit;
  line-height: 1;
}
._filterResetLink_1wvq9_746:hover { color: var(--text-primary); }

._genreChipGrid_1wvq9_760 {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
  padding: 0 4px;
}
._genreChip_1wvq9_760 {
  flex: 0 0 auto;
  padding: 8px 14px;
  border-radius: 999px;
  border: 1px solid var(--border-med, rgba(255, 255, 255, 0.15));
  background: transparent;
  color: var(--text-primary);
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  min-height: unset;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
._genreChip_1wvq9_760:hover {
  border-color: var(--border-dim, rgba(255, 255, 255, 0.25));
  background: var(--overlay-hover, rgba(255, 255, 255, 0.04));
}
._genreChipActive_1wvq9_785 {
  background: var(--accent);
  color: var(--btn-fg);
  border-color: var(--accent);
}
._genreChipActive_1wvq9_785:hover {
  background: var(--accent);
  color: var(--btn-fg);
  border-color: var(--accent);
}

/* ── Generic List Sub-Screens (Calendar, Concerts-Mgmt, Users-Mgmt) ── */
._listBody_1wvq9_797 {
  padding: 14px 22px calc(26px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 12px;
}
._listHint_1wvq9_803 {
  font-size: 13px;
  color: var(--text-secondary);
  margin: 4px 0 0;
  line-height: 1.4;
}
._list_1wvq9_797 {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
._listItem_1wvq9_817 {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 14px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.06);
  color: var(--text-primary);
  text-align: left;
  cursor: pointer;
  font-family: inherit;
  min-height: unset;
  transition: background 0.12s;
}
._listItem_1wvq9_817:hover { background: rgba(255, 255, 255, 0.07); }
[data-theme="light"] ._listItem_1wvq9_817 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}
._listThumb_1wvq9_838,
._listThumbFallback_1wvq9_839 {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  flex-shrink: 0;
  object-fit: cover;
}
._listThumbFallback_1wvq9_839 {
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
}
._listText_1wvq9_849 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
._listArtist_1wvq9_856 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._listMeta_1wvq9_864 {
  font-size: 12px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._listBadge_1wvq9_871 {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: #ff9500;
  background: rgba(255, 149, 0, 0.12);
  border: 1px solid rgba(255, 149, 0, 0.3);
  border-radius: 8px;
  padding: 3px 6px;
  flex-shrink: 0;
}
._listCta_1wvq9_883 {
  margin-top: 12px;
  width: 100%;
  padding: 14px;
  border: none;
  border-radius: 14px;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 15px;
  font-weight: 700;
  cursor: pointer;
  min-height: unset;
  font-family: inherit;
  transition: opacity 0.15s;
}
._listCta_1wvq9_883:hover { opacity: 0.92; }

/* ── Embed Body (for full-page embeds: AdminPage / UserManagementPage / FilterPage) ── */
._embedBody_1wvq9_901 {
  display: contents;
}

/* ── Animations ────────────────────────────────────────── */
@keyframes _slideUp_1wvq9_1 {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}
@keyframes _slideDown_1wvq9_1 {
  from { transform: translateY(0); }
  to { transform: translateY(100%); }
}
@keyframes _fadeIn_1wvq9_1 {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes _fadeOut_1wvq9_1 {
  from { opacity: 1; }
  to { opacity: 0; }
}
@keyframes _slideInRight_1wvq9_1 {
  from { transform: translateX(40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
@keyframes _slideInLeft_1wvq9_1 {
  from { transform: translateX(-40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
._header_2625q_1 {
  /* iOS PWA: push content below status bar */
  padding-top: env(safe-area-inset-top);
  /* Always dark regardless of theme */
  --header-bg:           rgba(0, 0, 0, 0.55);
  --header-border:       rgba(255, 255, 255, 0.10);
  --header-pill-border:  2px solid rgba(255, 255, 255, 0.15);
  --overlay-xs:          rgba(255, 255, 255, 0.04);
  --overlay-sm:          rgba(255, 255, 255, 0.06);
  --overlay-md:          rgba(255, 255, 255, 0.08);
  --overlay-hover:       rgba(255, 255, 255, 0.07);
  --border-subtle:       rgba(255, 255, 255, 0.08);
  --border-dim:          rgba(255, 255, 255, 0.10);
  --border-med:          rgba(255, 255, 255, 0.15);
  --dropdown-bg:         #1a1a1a;
  --dropdown-border:     rgba(255, 255, 255, 0.08);
  --dropdown-shadow:     rgba(0, 0, 0, 0.70);
  --text-primary:        #FFFFFF;
  --text-secondary:      #8895A0;
  --accent:              #8EBBFF;
  --accent-dim:          rgba(142, 187, 255, 0.15);

  display: flex;
  flex-direction: column;
  position: sticky;
  top: 0;
  width: 100%;
  background: var(--header-bg);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border-bottom: 1px solid var(--header-border);
  z-index: 1200;
  flex-shrink: 0;
  will-change: backdrop-filter;
}

/* iOS Safari: force compositing layer for backdrop-filter on sticky elements */
@supports (-webkit-touch-callout: none) {
  ._header_2625q_1 {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}

._headerScrolled_2625q_45 {}
._header_2625q_1::after { display: none; }

/* Mobile: iOS-Materials "thick"-style mit brightness-Dämpfung, damit
   helle Event-Images hinter der Card NICHT zu hell durchblitzen und
   Header + Card als unified Strip wirken. */
@media (max-width: 639px) {
  ._header_2625q_1 {
    border-bottom: none;
    background: rgba(0, 0, 0, 0.40);
    backdrop-filter: blur(28px) saturate(180%) brightness(0.85);
    -webkit-backdrop-filter: blur(28px) saturate(180%) brightness(0.85);
    border-radius: 0 0 18px 18px;
  }
  /* Hairline trennt Header von CalendarCard, fade-out an Rändern für softe Optik. */
  ._header_2625q_1::after {
    content: '';
    display: block;
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 1px;
    background: linear-gradient(
      to right,
      transparent 0%,
      rgba(255, 255, 255, 0.12) 50%,
      transparent 100%
    );
    pointer-events: none;
  }
}

/* ── Pill row ────────────────────────────────────────────────*/
._pillRow_2625q_79 {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  width: 100%;
  position: relative;
}

/* ── Sticky month pill (mobile only, scroll-revealed) ───────*/
._stickyMonthLabel_2625q_89 {
  display: none;
}

@media (max-width: 639px) {
  ._stickyMonthLabel_2625q_89 {
    display: block;
    position: absolute;
    left: 50%;
    transform: translateX(-50%) translateY(-4px);
    opacity: 0;
    pointer-events: none;
    transition: opacity 0.22s ease, transform 0.22s ease, filter 0.22s ease;
    filter: blur(6px);
    z-index: 2;
  }
  ._stickyMonthLabelVisible_2625q_105 {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    filter: blur(0);
  }

  /* Pill-button override: no chrome, just text + chevron */
  ._stickyMonthBtn_2625q_113 {
    background: transparent !important;
    border-color: transparent !important;
    padding: 6px 8px;
  }
  ._stickyMonthBtn_2625q_113:hover {
    background: transparent !important;
    border-color: transparent !important;
  }

  /* Dropdown override: centered, wider, internal scroll, no visible scrollbar */
  ._stickyMonthDropdown_2625q_124 {
    left: 50% !important;
    right: auto !important;
    transform: translateX(-50%);
    min-width: 180px;
    max-height: 60vh;
    overflow-y: auto;
    scrollbar-width: none;
  }
  ._stickyMonthDropdown_2625q_124::-webkit-scrollbar { display: none; }
}

/* Desktop: floating pill at the BOTTOM of the viewport (experiment). 42% wide, centred. */
@media (min-width: 1280px) {
  ._header_2625q_1 {
    /* Desktop uses the grey-tinted bg for the floating calendar pill */
    --header-bg: rgba(15, 15, 16, 0.55);
    position: fixed;
    top: auto;
    bottom: 8px;
    left: 50%;
    transform: translateX(-50%);
    width: 42%;
    max-width: 42%;
    margin: 0;
    border-radius: 24px;
    border: var(--header-pill-border);
    border-bottom: var(--header-pill-border);
    background: var(--header-bg);
    z-index: 1200;
    transition: left 0.35s cubic-bezier(0.32, 0.72, 0, 1), transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
  }
  /* When EventDetailPanel is open, re-center the pill in the remaining left area */
  ._headerPanelOpen_2625q_157 {
    left: calc((100vw - var(--panel-w, 420px)) / 2);
  }
}

/* Light theme: frosted glass with dark text — applies on all viewports */
[data-theme="light"] ._header_2625q_1 {
  --header-bg:          rgba(240, 240, 245, 0.85);
  --header-border:      rgba(0, 0, 0, 0.09);
  --header-pill-border: 2px solid var(--border-subtle);
  --text-primary:       #0A0A14;
  --text-secondary:     #5A6878;
  --accent:             #000000;
  --accent-dim:         rgba(0, 0, 0, 0.08);
  --overlay-xs:         rgba(0, 0, 0, 0.03);
  --overlay-sm:         rgba(0, 0, 0, 0.05);
  --overlay-md:         rgba(0, 0, 0, 0.07);
  --overlay-hover:      rgba(0, 0, 0, 0.05);
  --border-subtle:      rgba(0, 0, 0, 0.09);
  --border-dim:         rgba(0, 0, 0, 0.11);
  --border-med:         rgba(0, 0, 0, 0.14);
  --dropdown-bg:        #FFFFFF;
  --dropdown-border:    rgba(0, 0, 0, 0.09);
  --dropdown-shadow:    rgba(0, 0, 0, 0.18);
}

/* Tablet portrait: row 1 pills + row 2 calendar */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: portrait) {
  ._pillRow_2625q_79 {
    flex-wrap: wrap;
    column-gap: 10px;
    row-gap: 10px;
    padding: var(--space-4) var(--space-5) var(--space-3);
    align-items: center;
  }
}


/* Tablet landscape: pills row 1, calendar row 2 */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._pillRow_2625q_79 {
    flex-wrap: wrap;
    column-gap: 10px;
    row-gap: 10px;
    padding: var(--space-4) var(--space-5) var(--space-3);
    align-items: center;
  }
}

/* Desktop: just page title (optional) + calendar strip */
@media (min-width: 1280px) {
  ._pillRow_2625q_79 {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 8px;
    padding: var(--space-3) var(--space-5) var(--space-4);
  }
}

/* ── Page title: mobile + desktop ───────────────────*/
._pageTitle_2625q_218 {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-left: 4px;
}

._pageTitleText_2625q_225 {
  font-size: 17px;
  font-weight: 800;
  color: var(--text-primary);
  letter-spacing: -0.2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 160px;
}

@media (min-width: 1280px) {
  ._pageTitleText_2625q_225 {
    font-size: 34px;
    font-weight: 900;
    letter-spacing: -0.4px;
    max-width: none;
  }
}

._pageTitleCount_2625q_245 {
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 999px;
}

/* ── Left group: city pill + month nav (side by side) ───────*/
._leftGroup_2625q_255 {
  display: contents; /* mobile: items flow into flex */
}

/* Tablet portrait: pills pushed right on row 1 */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: portrait) {
  ._leftGroup_2625q_255 {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    order: 3;
    margin-left: auto; /* push leftGroup + avatar (order 5) to row end */
  }
}

/* Tablet landscape: pills pushed right */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._leftGroup_2625q_255 {
    display: flex;
    align-items: center;
    gap: 8px;
    flex: 0 0 auto;
    order: 3;
    margin-left: auto;
  }
}

/* Desktop: city/month pills live in the top nav — hide here */
@media (min-width: 1280px) {
  ._leftGroup_2625q_255 { display: none; }
  ._locationWrap_2625q_286 { display: none; }
}

/* ── Calendar center (hidden on mobile) ─────────────────────*/
._calendarCenter_2625q_290 {
  display: none;
}

/* Tablet portrait: calendar as full-width second row */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: portrait) {
  ._calendarCenter_2625q_290 {
    display: flex;
    flex: 0 0 100%;
    order: 6;
    align-items: center;
    min-width: 0;
  }
  ._locationWrap_2625q_286 { order: 4; }
  ._mobileAvatar_2625q_304  { order: 5; }
}

/* Tablet landscape: calendar as full-width second row */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._calendarCenter_2625q_290 {
    display: flex;
    flex: 0 0 100%;
    order: 6;
    align-items: center;
    min-width: 0;
  }
  ._locationWrap_2625q_286 { order: 4; }
  ._mobileAvatar_2625q_304  { order: 5; }
}

/* Desktop: full width in flex-column container */
@media (min-width: 1280px) {
  ._calendarCenter_2625q_290 {
    display: flex;
    align-items: center;
    min-width: 0;
    width: 100%;
    align-self: stretch;
  }
}

/* Strip inside header: remove built-in padding, fills the flex space */
._calendarStrip_2625q_332 {
  padding-inline: 0 !important;
  padding-bottom: 0;
  width: 100%;
}

/* Tablet: Heute button is hidden → its auto column shifts day 1 into auto
   and pushes the right arrow into a 1fr cell, breaking symmetry.
   Remove the Heute column so both arrows get auto and all 7 days get 1fr. */
@media (min-width: 640px) and (max-width: 1279px) {
  ._calendarStrip_2625q_332 {
    grid-template-columns: auto repeat(7, 1fr) auto !important;
  }
}

/* ── Mobile + tablet logo (<1024px, sidebar not visible) ────*/
._mobileLogo_2625q_348 {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-shrink: 0;
  cursor: pointer;
  user-select: none;
}

/* Tablet portrait: logo natural size, same as landscape */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: portrait) {
  ._mobileLogo_2625q_348 {
    flex: 0 0 auto;
    order: 1;
  }
}

/* Tablet landscape: logo natural size */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._mobileLogo_2625q_348 {
    flex: 0 0 auto;
  }
}

@media (min-width: 1280px) {
  ._mobileLogo_2625q_348 { display: none; }
}

._mobileLogoText_2625q_376 {
  font-size: 17px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.3px;
}

/* ── Expandable search (mobile + tablet portrait) ────*/
._ctaBtn_2625q_384 {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: transparent;
  border: 2px solid var(--accent);
  color: var(--accent);
  display: none;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, opacity 0.15s;
}
._ctaBtn_2625q_384:hover { background: var(--accent); color: var(--btn-fg); }
@media (max-width: 1279px) { ._ctaBtn_2625q_384 { display: flex; } }
._ctaBtnDashboard_2625q_399 { margin-left: auto; }

._right_2625q_401 {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}

._locationWrap_2625q_286 {
  position: relative;
  min-width: 0;
  flex-shrink: 1;
}

@media (max-width: 1279px) {
  ._locationWrap_2625q_286 { display: none; }
}

/* ── Month dropdown replaced by pill everywhere ─────────────*/
/* Month picker wrapper — visible on tablet (mobile uses sticky-pill, desktop hides .leftGroup) */
._monthPickerWrap_2625q_419 {
  position: relative;
  display: none;
}
@media (min-width: 640px) and (max-width: 1279px) {
  ._monthPickerWrap_2625q_419 { display: block; }

  /* Match desktop Sidebar dropdown sizing exactly */
  ._monthPickerWrap_2625q_419 ._dropdown_2625q_427 {
    top: calc(100% + 6px);
    right: 0;
    left: auto;
    min-width: 160px;
    border-radius: 14px;
    padding: 5px;
  }
  ._monthPickerWrap_2625q_419 ._dropdownItem_2625q_435 {
    padding: 8px 9px;
    border-radius: 8px;
    font-size: 13px;
    gap: 7px;
  }
}


/* Mobile: hide search bar */
@media (max-width: 639px) {
  ._right_2625q_401 { display: none; }
}

/* Tablet portrait: hide full search bar, use icon search instead */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: portrait) {
  ._right_2625q_401 { display: none; }
}

/* Tablet landscape: hide full search bar */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._right_2625q_401 { display: none; }
}

/* Desktop: search lives in the top nav — hide here */
@media (min-width: 1280px) {
  ._right_2625q_401 { display: none; }
}

/* ── Shared pill style ──────────────────────────────────────*/
._pill_2625q_79 {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  padding: 6px 10px;
  border-radius: var(--pill-radius);
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  transition: background 0.15s, border-color 0.15s;
  min-height: unset;
  white-space: nowrap;
  min-width: 0;
  overflow: hidden;
}

/* Hide location icon on very small screens */
@media (max-width: 400px) {
  ._pill_2625q_79 svg:first-child { display: none; }
}

@media (min-width: 640px) {
  ._pill_2625q_79 { font-size: 14px; gap: 5px; padding: var(--space-2) var(--space-3); }
}

._pill_2625q_79:hover   { background: var(--overlay-md); border-color: var(--border-dim); }
._pillOpen_2625q_493     { border-color: var(--accent); background: var(--accent-dim); }
._pillActive_2625q_494   {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  color: var(--btn-fg) !important;
}

/* Ghost modifier — strips background + border (used for tablet month pill) */
._pillGhost_2625q_501,
._pillGhost_2625q_501:hover {
  background: transparent;
  border-color: transparent;
}
._pillGhost_2625q_501:hover { color: var(--accent); }

._chevron_2625q_508 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._chevronOpen_2625q_513 { transform: rotate(180deg); }

/* ── Month dropdown: scrollable, scrollbar hidden ────────────*/
._dropdownScrollable_2625q_516 {
  max-height: 260px;
  overflow-y: auto;
  scrollbar-width: none;
  -ms-overflow-style: none;
}
._dropdownScrollable_2625q_516::-webkit-scrollbar { display: none; }

/* ── Dropdown ───────────────────────────────────────────────*/
._dropdown_2625q_427 {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 170px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 16px;
  padding: 6px;
  z-index: 1200;
  box-shadow: 0 12px 40px var(--dropdown-shadow);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
}

/* Keep dropdown inside viewport on mobile + tablet */
@media (max-width: 1279px) {
  ._dropdown_2625q_427 { left: auto; right: 0; }
}

._dropdownItem_2625q_435 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  padding: 9px 10px;
  border-radius: 9px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  transition: background 0.12s, color 0.12s;
}
._dropdownItem_2625q_435:hover          { background: var(--overlay-hover); color: var(--text-primary); }
._dropdownItemActive_2625q_560          { color: var(--accent); }
._dropdownItemActive_2625q_560:hover    { background: var(--accent-dim); }

._dropdownSpacer_2625q_563 { width: 13px; flex-shrink: 0; }

._dropdownHint_2625q_565 {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-secondary);
  opacity: 0.45;
  text-align: center;
  padding: 6px 4px 2px;
  letter-spacing: 0.02em;
}

/* ── Mobile/tablet avatar menu ──────────────────────────────*/
._mobileAvatar_2625q_304 {
  position: relative;
  flex-shrink: 0;
}

/* Subtle dot indicator (top-right of avatar) when a genre filter is active.
   No layout impact — purely a visual cue. */
._mobileAvatarFiltered_2625q_583::after {
  content: '';
  position: absolute;
  top: -1px;
  right: -1px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--accent);
  pointer-events: none;
  z-index: 1;
}

/* Mobile: pin avatar to right edge so it never shifts when search expands */
@media (max-width: 639px) {
  ._mobileAvatar_2625q_304 {
    position: absolute;
    right: 20px;
  }
  ._pillRow_2625q_79 {
    padding-left: 20px;
    padding-right: calc(20px + 34px + 8px); /* reserve space for pinned avatar */
  }
}

/* Tablet: keep logo + avatar at the edges via flex flow.
   Avatar gets margin-left: auto so it's pushed to the right end of its line
   regardless of how many items are between it and the logo. */
@media (min-width: 640px) and (max-width: 1279px) {
  ._mobileAvatar_2625q_304 {
    margin-left: auto;
  }
}

@media (min-width: 1280px) {
  ._mobileAvatar_2625q_304 { display: none; }
}

._mobileAvatarBtn_2625q_621 {
  width: 34px;
  height: 34px;
  min-width: 34px;
  min-height: 34px;
  border-radius: 50%;
  background: var(--overlay-sm);
  border: 1.5px solid var(--border-subtle);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transition: background 0.15s, border-color 0.15s;
  overflow: hidden;
}
._mobileAvatarBtn_2625q_621:hover    { background: var(--overlay-md); border-color: var(--border-dim); }
._mobileAvatarBtnOpen_2625q_637      { background: var(--overlay-md); border-color: var(--accent); }

._mobileAvatarImg_2625q_639 {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

._mobileAvatarInitials_2625q_646 {
  font-size: 12px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: 0.03em;
  line-height: 1;
}

._mobileAvatarDropdown_2625q_654 {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 200px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 16px;
  padding: 6px;
  z-index: 1200;
  box-shadow: 0 12px 40px var(--dropdown-shadow);
  animation: _mobileAvatarDropIn_2625q_1 0.15s ease both;
}

@keyframes _mobileAvatarDropIn_2625q_1 {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

._mobileAvatarItem_2625q_673 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  min-height: unset;
  transition: background 0.12s, color 0.12s;
}
._mobileAvatarItem_2625q_673:hover        { background: var(--overlay-hover); color: var(--text-primary); }
._mobileAvatarItemActive_2625q_688        { color: var(--accent); }
._mobileAvatarItemActive_2625q_688:hover  { background: var(--accent-dim); }
._mobileAvatarItemLogout_2625q_690        { color: #ff5f57; }
._mobileAvatarItemLogout_2625q_690:hover  { background: rgba(255, 95, 87, 0.1); color: #ff5f57; }

._mobileAvatarBadge_2625q_693 {
  margin-left: auto;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 10px;
  font-weight: 800;
  min-width: 18px;
  height: 18px;
  border-radius: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
}

._mobileAvatarDivider_2625q_708 {
  height: 1px;
  background: var(--border-subtle);
  margin: 4px 6px;
}

/* ── Search bar ─────────────────────────────────────────────*/
._searchWrap_2625q_715 {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 200px;
  height: 34px;
  padding: 0 var(--space-3);
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  border-radius: var(--pill-radius);
  transition: border-color 0.15s, background 0.15s;
  box-sizing: border-box;
  overflow: hidden;
}
._searchWrap_2625q_715:focus-within { border-color: var(--accent); background: rgba(142,187,255,0.06); }

._searchIcon_2625q_731 { flex-shrink: 0; color: var(--text-secondary); }

._searchInput_2625q_733 {
  flex: 1;
  min-width: 0;
  background: none;
  border: none;
  outline: none;
  font-size: 14px;
  line-height: 1;
  color: var(--text-primary);
  height: 1.2em;
  padding: 0;
  margin: 0;
}
._searchInput_2625q_733::placeholder { color: var(--text-secondary); }

._searchClear_2625q_748 {
  flex-shrink: 0;
  align-self: center;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  min-width: 20px;
  min-height: unset;
  aspect-ratio: 1 / 1;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  color: var(--text-secondary);
  transition: background 0.15s;
  padding: 0;
}
._searchClear_2625q_748:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }

._artistsLoginBtn_2625q_767 {
  padding: 12px 20px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  transition: opacity 0.15s;
  margin-left: auto;
  white-space: nowrap;
}
._artistsLoginBtn_2625q_767:hover { opacity: 0.88; }
._popup_138tc_1 {
  position: fixed;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 16px;
  padding: 8px;
  box-shadow: 0 16px 48px var(--dropdown-shadow);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  min-width: 240px;
  z-index: 1300;
}

._heading_138tc_14 {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 8px 12px 6px;
}

._row_138tc_23 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
  font-family: inherit;
  min-height: unset;
  transition: background 0.12s;
}
._row_138tc_23:hover { background: var(--overlay-hover); }

/* iOS-style toggle switch */
._switch_138tc_44 {
  position: relative;
  width: 36px;
  height: 22px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.14);
  flex-shrink: 0;
  transition: background 0.2s ease;
}
._switchKnob_138tc_53 {
  position: absolute;
  top: 2px;
  left: 2px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  box-shadow: 0 1px 2px rgba(0,0,0,0.3);
  transition: transform 0.2s cubic-bezier(0.32, 0.72, 0, 1);
}
/* Combined selector to outweigh the [data-theme="light"] .switch override below */
._switch_138tc_44._switchOn_138tc_65 {
  background: #8EBBFF;
}
._switchOn_138tc_65 ._switchKnob_138tc_53 {
  transform: translateX(14px);
}

[data-theme="light"] ._switch_138tc_44 {
  background: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._switch_138tc_44._switchOn_138tc_65 {
  background: #8EBBFF;
}

/* ── Genres section ─────────────────────────────────────── */
._divider_138tc_80 {
  height: 1px;
  background: var(--border-subtle, rgba(255, 255, 255, 0.08));
  margin: 8px 4px;
}
._headingRow_138tc_85 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding-right: 12px;
}
._resetLink_138tc_91 {
  background: transparent;
  border: none;
  color: var(--text-secondary);
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  padding: 4px 8px;
  min-height: unset;
}
._resetLink_138tc_91:hover { color: var(--text-primary); }

._chipGrid_138tc_103 {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 4px 8px 8px;
}
._chip_138tc_103 {
  flex: 0 0 auto;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid var(--border-med, rgba(255, 255, 255, 0.15));
  background: transparent;
  color: var(--text-primary);
  font-size: 12px;
  font-weight: 600;
  font-family: inherit;
  cursor: pointer;
  min-height: unset;
  transition: background 0.12s, border-color 0.12s, color 0.12s;
}
._chip_138tc_103:hover {
  border-color: var(--border-dim, rgba(255, 255, 255, 0.25));
  background: var(--overlay-hover, rgba(255, 255, 255, 0.04));
}
._chipActive_138tc_127 {
  background: #8EBBFF;
  color: #000;
  border-color: #8EBBFF;
}
._chipActive_138tc_127:hover {
  background: #8EBBFF;
  color: #000;
  border-color: #8EBBFF;
}
/* ── Top bar (desktop 1280px+) ───────────────────────────── */
._sidebar_1uf04_2 {
  display: flex;
  flex-direction: row;
  align-items: center;
  width: 100%;
  height: calc(56px + env(safe-area-inset-top));
  padding-top: env(safe-area-inset-top);
  background: var(--nav-bg);
  /* backdrop-filter removed: even 2px caused Chrome compositor flicker on
     fast scroll. Higher --nav-bg alpha keeps the translucent dark look. */
  border-bottom: 1px solid var(--nav-border);
  padding: 0 24px;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 1200;
  /* Isolate paint: stops cards beneath from being repainted alongside the
     sidebar's backdrop-filter on every scroll frame (Chrome flicker fix). */
  contain: layout style paint;
}

/* ── Logo ────────────────────────────────────────────────── */
._logo_1uf04_25 {
  display: flex;
  align-items: center;
  gap: 10px;
  position: absolute;
  /* Align with the left edge of the event-card grid: .inner has max-width: 95%
     centered (= 2.5vw margin) + .feed adds var(--space-8) padding (= 32px). */
  left: calc(2.5vw + var(--space-8));
  flex-shrink: 0;
  cursor: pointer;
}
[data-theme="light"] ._logo_1uf04_25 img { filter: brightness(0); }

._logoText_1uf04_38 {
  font-size: 16px;
  font-weight: 800;
  color: var(--accent);
  letter-spacing: -0.3px;
}

/* ── Avatar + dropdown wrapper ───────────────────────────── */
._avatarWrap_1uf04_46 {
  display: flex;
  align-items: center;
  z-index: 1000;
  position: relative;
}


._avatarBtn_1uf04_54 {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 5px 10px 5px 5px;
  border-radius: 999px;
  background: transparent;
  border: 1px solid transparent;
  transition: background 0.15s, border-color 0.15s;
  cursor: pointer;
}
._avatarBtn_1uf04_54:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}
._avatarBtnOpen_1uf04_69 {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
}

._avatar_1uf04_46 {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: 0.03em;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}

._avatarImg_1uf04_89 {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}

._avatarName_1uf04_98 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  letter-spacing: 0.01em;
}

._chevron_1uf04_105 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._chevronOpen_1uf04_110 {
  transform: rotate(180deg);
}

/* ── Dropdown panel ──────────────────────────────────────── */
._dropdown_1uf04_115 {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  min-width: 200px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 16px;
  padding: 6px;
  box-shadow: 0 16px 48px var(--dropdown-shadow);
  z-index: 1000;
  animation: _dropIn_1uf04_1 0.15s ease;
}

@keyframes _dropIn_1uf04_1 {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

._dropdownItem_1uf04_134 {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  border-radius: 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  transition: background 0.12s, color 0.12s;
}
._dropdownItem_1uf04_134:hover {
  background: var(--overlay-hover);
  color: var(--text-primary);
}
._dropdownItemActive_1uf04_151 {
  color: var(--accent);
}
._dropdownItemActive_1uf04_151:hover {
  color: var(--accent);
}

._dropdownItemAccent_1uf04_158 {
  background: var(--accent);
  color: var(--btn-fg);
}
._dropdownItemAccent_1uf04_158:hover {
  background: var(--accent);
  color: var(--btn-fg);
  opacity: 0.9;
}

/* Light theme: invert — black surface + blue text (dark-mode accent).
   Keeps Login/Logout buttons visually distinct from the regular dropdown items. */
[data-theme="light"] ._dropdownItemAccent_1uf04_158 {
  background: #000;
  color: #8EBBFF;
}
[data-theme="light"] ._dropdownItemAccent_1uf04_158:hover {
  background: #000;
  color: #8EBBFF;
  opacity: 0.9;
}

._ctaBtn_1uf04_180 {
  width: 26px;
  height: 26px;
  border-radius: 50%;
  background: transparent;
  border: 2px solid var(--accent);
  color: var(--accent);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background 0.15s, opacity 0.15s;
}
._ctaBtn_1uf04_180:hover { background: var(--accent); color: var(--btn-fg); }

._dropdownBadge_1uf04_195 {
  margin-left: auto;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 9px;
  font-weight: 800;
  min-width: 16px;
  height: 16px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 3px;
}

._divider_1uf04_210 {
  height: 1px;
  background: var(--overlay-hover);
  margin: 4px 6px;
}

/* ── Right group: controls + avatar ──────────────────────── */
._rightGroup_1uf04_217 {
  position: absolute;
  /* Align with the right edge of the event-card grid (same formula as .logo). */
  right: calc(2.5vw + var(--space-8));
  display: flex;
  align-items: center;
  gap: 8px;
}

/* ── Nav controls: city · month · search ─────────────────── */
._navControls_1uf04_227 {
  display: flex;
  align-items: center;
  gap: 6px;
}

/* ── Primary CTA — "Neues Konzi" pill, embedded into the left edge of
   the search container so the whole thing reads as one big pill. ── */
._createCta_1uf04_235 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  /* Stretch to match the inner flex cross-axis; negative top/bottom margins
     extend the visual bounds to exactly the searchCenter's outer edge
     (= 8px padding + 1px border = -9px). */
  align-self: stretch;
  margin: -9px 10px -9px -15px;
  padding: 0 16px;
  border-radius: 999px 0 0 999px;
  background: var(--accent);
  border: 1px solid var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  font-family: inherit;
  cursor: pointer;
  white-space: nowrap;
  min-height: unset;
  line-height: 1;
  flex-shrink: 0;
  transition: opacity 0.15s, transform 0.05s;
}
._createCta_1uf04_235:hover { opacity: 0.92; }
._createCta_1uf04_235:active { transform: scale(0.98); }


/* ── Filter count badge (blue circle inside Filter pill) ── */
._filterCountBadge_1uf04_264 {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
  flex-shrink: 0;
}

/* ── Filter dot-indicator toggles (inline, no pill chrome) — unused ── */
._filterChips_1uf04_280 {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-right: 10px;
  margin-right: 6px;
}

._filterChip_1uf04_280 {
  display: flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0;
  border: none;
  background: transparent;
  color: var(--text-secondary);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  font-family: inherit;
  white-space: nowrap;
  min-height: unset;
  line-height: 1;
  transition: color 0.15s;
}
._filterChip_1uf04_280:hover { color: var(--text-primary); }

._filterChipBox_1uf04_308 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 1.5px solid var(--text-secondary);
  background: transparent;
  color: var(--btn-fg);
  flex-shrink: 0;
  transition: background 0.15s, border-color 0.15s;
}
._filterChip_1uf04_280:hover ._filterChipBox_1uf04_308 { border-color: var(--text-primary); }

._filterChipActive_1uf04_323 { color: var(--text-primary); }
._filterChipActive_1uf04_323 ._filterChipBox_1uf04_308 {
  background: var(--accent);
  border-color: var(--accent);
}
._filterChipActive_1uf04_323:hover ._filterChipBox_1uf04_308 {
  background: var(--accent);
  border-color: var(--accent);
}

._navPillWrap_1uf04_333 {
  position: relative;
}

/* Subtle dot indicator (top-LEFT of the Filter pill) when ANY filter is
   active — categories narrowed or genres selected. */
._navPillWrapFiltered_1uf04_339::after {
  content: '';
  position: absolute;
  top: -3px;
  left: -3px;
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: var(--accent);
  pointer-events: none;
  z-index: 1;
}

._navPill_1uf04_333 {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  padding: 0 10px;
  border-radius: var(--pill-radius);
  background: var(--overlay-xs);
  border: 1px solid var(--border-subtle);
  transition: background 0.15s, border-color 0.15s;
  white-space: nowrap;
  cursor: pointer;
  height: 32px;
  box-sizing: border-box;
  min-height: unset;
  line-height: 1;
}
._navPill_1uf04_333:hover        { background: var(--overlay-md); border-color: var(--border-dim); }
._navPillOpen_1uf04_372          { border-color: var(--accent); background: var(--accent-dim); }
._navPillActive_1uf04_373        { background: var(--accent) !important; border-color: var(--accent) !important; color: var(--btn-fg) !important; }

/* Ghost modifier — strips background + border (used for month pill) */
._navPillGhost_1uf04_376,
._navPillGhost_1uf04_376:hover {
  background: transparent;
  border-color: transparent;
}
._navPillGhost_1uf04_376:hover { color: var(--accent); }

._navArrow_1uf04_383 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  padding: 0;
  border-radius: 50%;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
  cursor: pointer;
}
._navArrow_1uf04_383:hover { color: var(--text-primary); background: rgba(255,255,255,0.07); }

._navMonthLabel_1uf04_400 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-primary);
  white-space: nowrap;
  padding: 0 4px;
  user-select: none;
  min-width: 100px;
  text-align: center;
}

/* ── Centered desktop search-pill (embeds the CTA on the left edge) ── */
._searchCenter_1uf04_412 {
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  width: clamp(420px, 44vw, 620px);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 14px;
  border: 1px solid rgba(255, 255, 255, 0.14);
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.04);
  transition: border-color 0.15s, background 0.15s, box-shadow 0.15s;
}
._searchCenter_1uf04_412:focus-within {
  border-color: var(--accent);
  background: rgba(255, 255, 255, 0.06);
  box-shadow: 0 0 0 3px rgba(142, 187, 255, 0.15);
}
._searchCenterIcon_1uf04_432 {
  flex-shrink: 0;
  color: var(--text-secondary);
}
._searchCenterInput_1uf04_436 {
  flex: 1;
  min-width: 0;
  background: none;
  border: none;
  outline: none;
  font-size: 14px;
  font-family: inherit;
  font-weight: 500;
  color: var(--text-primary);
  padding: 0;
}
._searchCenterInput_1uf04_436::placeholder { color: var(--text-secondary); }
._searchCenterInput_1uf04_436::-webkit-search-cancel-button { display: none; }

._searchCenterClear_1uf04_451 {
  flex-shrink: 0;
  width: 22px;
  height: 22px;
  min-width: unset;
  min-height: unset;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
._searchCenterClear_1uf04_451:hover {
  background: rgba(255, 255, 255, 0.14);
  color: var(--text-primary);
}

[data-theme="light"] ._searchCenter_1uf04_412 {
  border-color: rgba(0, 0, 0, 0.14);
  background: rgba(0, 0, 0, 0.03);
}
[data-theme="light"] ._searchCenter_1uf04_412:focus-within {
  background: rgba(0, 0, 0, 0.05);
}
[data-theme="light"] ._searchCenterClear_1uf04_451 {
  background: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] ._searchCenterClear_1uf04_451:hover {
  background: rgba(0, 0, 0, 0.12);
}

._navDropdown_1uf04_486 {
  position: absolute;
  top: calc(100% + 6px);
  right: 0;
  min-width: 160px;
  background: var(--dropdown-bg);
  border: 1px solid var(--dropdown-border);
  border-radius: 14px;
  padding: 5px;
  z-index: 200;
  box-shadow: 0 12px 40px rgba(0,0,0,0.7);
  scrollbar-width: none;
  -ms-overflow-style: none;
}
._navDropdown_1uf04_486::-webkit-scrollbar { display: none; }

._navDropdownItem_1uf04_502 {
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  padding: 8px 9px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: left;
  transition: background 0.12s, color 0.12s;
}
._navDropdownItem_1uf04_502:hover         { background: rgba(255,255,255,0.07); color: var(--text-primary); }
._navDropdownItemActive_1uf04_516         { color: var(--accent); }
._navDropdownItemActive_1uf04_516:hover   { background: var(--accent-dim); }

._navDropdownHint_1uf04_519 {
  font-size: 10px;
  font-weight: 600;
  color: var(--text-secondary);
  opacity: 0.45;
  text-align: center;
  padding: 5px 4px 2px;
  letter-spacing: 0.02em;
}

/* ── Footer (city labels) — hidden ───────────────────────── */
._footer_1uf04_530    { display: none; }
._footerText_1uf04_531 { display: none; }

/* ── Artists+Venues page login CTA ──────────────────────── */
._artistsLoginBtn_1uf04_534 {
  padding: 12px 20px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 13px;
  font-weight: 700;
  transition: opacity 0.15s;
  white-space: nowrap;
}
._artistsLoginBtn_1uf04_534:hover { opacity: 0.88; }

._roleLabel_1uf04_546 {
  background: rgba(142, 187, 255, 0.12);
  border: 1px solid rgba(142, 187, 255, 0.5);
  padding: 1px 8px;
  font-size: 10px;
  font-weight: 700;
  color: var(--accent);
  cursor: pointer;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s;
  border-radius: 999px;
  margin-left: 1px;
  letter-spacing: 0.04em;
  line-height: 1.4;
  min-height: unset;
}
._roleLabel_1uf04_546:hover {
  background: rgba(142, 187, 255, 0.2);
  border-color: var(--accent);
}
/* ── Backdrop (mobile/tablet) ──────────────────────────── */
._backdrop_1o7mh_2 {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  backdrop-filter: blur(4px);
  z-index: 1320;
  opacity: 0;
  transition: opacity 0.25s ease;
}

._backdropVisible_1o7mh_13 { opacity: 1; }

/* ── Panel ─────────────────────────────────────────────── */
._panel_1o7mh_16 {
  position: fixed;
  bottom: 0;
  left: 50%;
  transform: translateX(-50%) translateY(100%);
  width: calc(100vw - 20px);
  height: 92dvh;
  background: var(--card-bg);
  border-radius: 28px 28px 0 0;
  z-index: 1321;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.35s cubic-bezier(0.32, 0.72, 0, 1);
  will-change: transform;
}

._panelVisible_1o7mh_33 {
  transform: translateX(-50%) translateY(0);
}

/* Mobile + tablet: show backdrop, add accent-glow top border for contrast */
@media (max-width: 1279px) {
  ._backdrop_1o7mh_2 { display: block; }
  ._panel_1o7mh_16 {
    border-top: 1px solid rgba(142, 187, 255, 0.28);
    box-shadow:
      0 -6px 24px rgba(142, 187, 255, 0.22),
      0 -20px 50px rgba(0, 0, 0, 0.5);
  }
}

/* Tablet landscape: switch to block so hero + content scroll as one unit */
@media (min-width: 640px) and (max-width: 1279px) and (orientation: landscape) {
  ._panel_1o7mh_16 {
    height: 90dvh;
    overflow-y: auto;
    display: block;
  }
  ._content_1o7mh_55 {
    overflow-y: visible;
  }
}

/* ── Desktop: right-side flex-sibling panel, cards scale to fill ── */
@media (min-width: 1280px) {
  ._panel_1o7mh_16 {
    position: relative;
    /* Reset base z-index (1321) — on desktop the panel is in-flow, must not
       sit above portal dropdowns from the sidebar (z-index 1300). */
    z-index: auto;
    bottom: auto;
    left: auto;
    right: auto;
    /* Sidebar slot in App.module.css already reserves the 56px → panel sits
       below sidebar automatically as a flex-sibling of .main. */
    margin-top: 0;
    height: 100%;
    width: 0;
    min-width: 0;
    flex-shrink: 0;
    border-radius: 0;
    overflow-x: hidden;
    overflow-y: auto;
    scrollbar-width: none;
    transform: none;
    transition: width 0.35s cubic-bezier(0.32, 0.72, 0, 1);
  }
  ._panel_1o7mh_16::-webkit-scrollbar { display: none; }

  ._panelVisible_1o7mh_33 {
    width: var(--panel-w);
    border-left: 1px solid var(--card-border);
    transform: none;
  }
}

/* ── Desktop: pin inner content to panel width so it doesn't reflow ── */
@media (min-width: 1280px) {
  ._hero_1o7mh_95,
  ._content_1o7mh_55 {
    width: var(--panel-w);
  }
}

/* ── Drag handle (mobile/tablet) — overlay on hero, no flex-flow strip ── */
._dragHandle_1o7mh_102 {
  position: absolute;
  top: 8px;
  left: 50%;
  transform: translateX(-50%);
  width: 36px;
  height: 4px;
  border-radius: 2px;
  background: rgba(255, 255, 255, 0.55);
  z-index: 2;
  pointer-events: none;
}

@media (min-width: 1280px) {
  ._dragHandle_1o7mh_102 { display: none; }
}

/* ── Hero image ────────────────────────────────────────── */
@keyframes _shimmer_1o7mh_1 {
  0%   { background-position: -200% 0; }
  100% { background-position:  200% 0; }
}
@keyframes _imageReveal_1o7mh_1 {
  from { opacity: 0; filter: blur(16px); transform: scale(1.06); }
  to   { opacity: 1; filter: blur(0px);  transform: scale(1); }
}

._hero_1o7mh_95 {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  flex-shrink: 0;
  overflow: hidden;
  /* Match panel's rounded top corners. Without this, Chrome fails to clip the
     heroImg when its imageReveal animation (transform + filter) creates a
     composite layer that escapes the panel's overflow:hidden boundary. */
  border-radius: 28px 28px 0 0;
  /* Force own stacking context — additional safety against Chrome's
     transform/filter compositing bugs. */
  isolation: isolate;
  background: linear-gradient(90deg,
    rgba(142,187,255,0.04) 0%,
    rgba(142,187,255,0.12) 50%,
    rgba(142,187,255,0.04) 100%
  );
  background-size: 200% 100%;
  animation: _shimmer_1o7mh_1 1.8s ease-in-out infinite;
}

@media (min-width: 1024px) {
  ._hero_1o7mh_95 { aspect-ratio: 16 / 10; }
}

/* Desktop: panel is a right-side flex-sibling without rounded top — hero too. */
@media (min-width: 1280px) {
  ._hero_1o7mh_95 { border-radius: 0; }
}

._heroImg_1o7mh_160 {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

._heroImgHidden_1o7mh_167 { opacity: 0; }

._heroImgLoaded_1o7mh_169 {
  animation: _imageReveal_1o7mh_1 0.65s cubic-bezier(0.25, 0.46, 0.45, 0.94) both;
}

._heroOverlay_1o7mh_173 {
  position: absolute;
  inset: 0;
  background: linear-gradient(
    to bottom,
    rgba(0,0,0,0.15) 0%,
    transparent 35%,
    rgba(26,26,26,0.95) 100%
  );
}

._closeBtn_1o7mh_184 {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: 36px;
  border-radius: 50%;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  z-index: 2;
  transition: background 0.15s;
}
._closeBtn_1o7mh_184:hover { background: rgba(0,0,0,0.8); }

._heroBadge_1o7mh_204 {
  position: absolute;
  top: 16px;
  left: 16px;
  background: rgba(0,0,0,0.55);
  backdrop-filter: blur(8px);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  padding: 4px 12px;
  border-radius: 100px;
}

._heroBottom_1o7mh_219 {
  position: absolute;
  bottom: 16px;
  left: 20px;
  right: 20px;
  z-index: 2;
}

._heroArtist_1o7mh_227 {
  font-size: clamp(22px, 5vw, 28px);
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.5px;
  line-height: 1.1;
  text-shadow: 0 2px 12px rgba(0,0,0,0.5);
}

._heroGenres_1o7mh_236 {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 6px;
}

._genrePill_1o7mh_243 {
  font-size: 11px;
  font-weight: 600;
  color: rgba(255,255,255,0.75);
  background: rgba(255,255,255,0.15);
  backdrop-filter: blur(4px);
  border-radius: 100px;
  padding: 3px 10px;
}

/* ── Scrollable content ────────────────────────────────── */
._content_1o7mh_55 {
  flex: 1;
  overflow-y: auto;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 0;
  scrollbar-width: none;
}
._content_1o7mh_55::-webkit-scrollbar { display: none; }

/* ── Facts row ─────────────────────────────────────────── */
._facts_1o7mh_266 {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 24px;
}

._fact_1o7mh_266 {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  color: var(--text-secondary);
}

._fact_1o7mh_266 svg {
  flex-shrink: 0;
  margin-top: 3px;
}

._factLabel_1o7mh_285 {
  display: block;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-muted);
  margin-bottom: 2px;
}

._factValue_1o7mh_295 {
  display: block;
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary);
}

/* ── Divider ───────────────────────────────────────────── */
._divider_1o7mh_303 {
  height: 1px;
  background: var(--card-border);
  margin: 20px 0;
}

/* ── Section ───────────────────────────────────────────── */
._section_1o7mh_310 {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

._sectionTitle_1o7mh_316 {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-secondary);
}

._sectionText_1o7mh_324 {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
}

._supportBlock_1o7mh_330 {
  margin-top: 12px;
  padding: 14px;
  background: rgba(255,255,255,0.04);
  border-radius: 14px;
  border: 1px solid var(--card-border);
  display: flex;
  flex-direction: column;
  gap: 6px;
}

._supportTag_1o7mh_341 {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.1em;
  color: var(--text-secondary);
}

._supportName_1o7mh_348 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
}

._address_1o7mh_354 {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
  font-style: normal;
  white-space: pre-line;
}

/* ── Actions ───────────────────────────────────────────── */
._actions_1o7mh_363 {
  display: flex;
  flex-direction: column;
  gap: 12px;
  margin-top: 4px;
}

._ticketBtn_1o7mh_370 {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 16px;
  border-radius: var(--btn-radius);
  background: var(--text-primary);
  color: var(--btn-fg);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: 0.01em;
  transition: opacity 0.15s, transform 0.15s;
}
._ticketBtn_1o7mh_370:hover { opacity: 0.92; transform: scale(0.99); }
._ticketBtn_1o7mh_370:active { transform: scale(0.97); }

._secondaryActions_1o7mh_387 {
  display: flex;
  gap: 10px;
}

._iconBtn_1o7mh_392 {
  flex: 1;
  height: 48px;
  border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--card-border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s, color 0.15s;
}
._iconBtn_1o7mh_392:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }
._iconBtn_1o7mh_392._bookmarked_1o7mh_405 { background: var(--accent); color: var(--btn-fg); }
._bookmarkDisabled_1o7mh_406 { opacity: 0.35; cursor: default; }
._bookmarkDisabled_1o7mh_406:hover { background: rgba(255,255,255,0.06) !important; color: var(--text-secondary) !important; }

._bookmarkWrap_1o7mh_409 { position: relative; }
._loginPopupPortal_1o7mh_410 {
  position: fixed;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 8px 24px rgba(0,0,0,0.6);
  border-radius: 14px;
  padding: 12px 14px;
  min-width: 190px;
  z-index: 1400;
  text-align: center;
}
._loginPopupText_1o7mh_420 { font-size: 12px; color: var(--text-secondary); margin: 0 0 10px; line-height: 1.4; }
._loginPopupBtn_1o7mh_421 {
  width: 100%; padding: 8px; border-radius: 10px;
  background: var(--accent); color: var(--btn-fg);
  font-size: 13px; font-weight: 700; transition: opacity 0.15s;
}
._loginPopupBtn_1o7mh_421:hover { opacity: 0.85; }

._imageCredit_1o7mh_428 {
  font-size: 10px;
  color: var(--text-muted);
  text-align: left;
  padding: 8px 20px 20px;
  margin: 0;
}
/* ── Full-screen overlay ─────────────────────────────────── */
._overlay_f0fr8_2 {
  position: fixed;
  inset: 0;
  /* padding-top reserves notch space only; Page-Header sits behind the overlay backdrop */
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(24px);
  -webkit-backdrop-filter: blur(24px);
  z-index: 1250;
  display: flex;
  flex-direction: column;
  transform: translateY(100%);
  transition: transform 0.3s cubic-bezier(0.32, 0.72, 0, 1);
  overscroll-behavior: contain;
}

._overlayVisible_f0fr8_17 {
  transform: translateY(0);
}

/* ── Drag handle ─────────────────────────────────────────── */
._dragHandle_f0fr8_22 {
  width: 36px;
  height: 4px;
  border-radius: 2px;
  background: var(--border-med);
  margin: 12px auto 0;
  flex-shrink: 0;
}

/* ── Search header (2 rows: title+close, then input) ──────── */
._header_f0fr8_32 {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding: 12px 16px 16px;
  flex-shrink: 0;
  border-bottom: 1px solid var(--border-dim);
  background: rgba(0, 0, 0, 0.2);
}

._headerTopRow_f0fr8_42 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}

._title_f0fr8_49 {
  font-size: 28px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
  letter-spacing: -0.5px;
}

._closeBtn_f0fr8_57 {
  width: 36px;
  height: 36px;
  min-width: 36px;
  min-height: unset;
  border-radius: 50%;
  background: var(--overlay-sm);
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  flex-shrink: 0;
  transition: background 0.15s, color 0.15s;
}
._closeBtn_f0fr8_57:hover { background: var(--overlay-md); color: var(--text-primary); }

._inputWrap_f0fr8_74 {
  position: relative;
  flex: 1;
  min-width: 0;
  display: flex;
  align-items: center;
}

._input_f0fr8_74 {
  width: 100%;
  min-width: 0;
  background: none;
  border: 1px solid var(--border-dim);
  border-radius: 999px;
  outline: none;
  font-size: 16px; /* ≥16px — no iOS zoom */
  font-family: inherit;
  font-weight: 500;
  color: var(--text-primary);
  padding: 8px 36px 8px 16px; /* right padding makes room for inline clear button */
  height: 36px;
  box-sizing: border-box;
  transition: border-color 0.15s;
}
._input_f0fr8_74:focus { border-color: var(--border-med); }
._input_f0fr8_74::placeholder { color: var(--text-secondary); }

._clearBtn_f0fr8_101 {
  position: absolute;
  right: 10px;
  top: 50%;
  transform: translateY(-50%);
  width: 18px;
  height: 18px;
  min-width: 18px;
  min-height: unset;
  border-radius: 50%;
  background: none;
  border: none;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  opacity: 0.6;
  padding: 0;
  flex-shrink: 0;
  transition: opacity 0.12s, color 0.12s;
}
._clearBtn_f0fr8_101:hover { opacity: 1; color: var(--text-primary); background: none; }

/* ── Results list ────────────────────────────────────────── */
._results_f0fr8_125 {
  flex: 1;
  overflow-y: auto;
  padding: 8px 0 40px;
}

._hint_f0fr8_131 {
  font-size: 14px;
  color: var(--text-secondary);
  text-align: center;
  padding: 48px 24px;
}

._resultItem_f0fr8_138 {
  display: flex;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 10px 16px;
  background: none;
  border: none;
  text-align: left;
  min-height: unset;
  transition: background 0.12s;
  cursor: pointer;
}
._resultItem_f0fr8_138:hover { background: var(--overlay-xs); }

._resultImg_f0fr8_153 {
  width: 52px;
  height: 52px;
  border-radius: 10px;
  overflow: hidden;
  flex-shrink: 0;
  background: var(--overlay-sm);
}
._resultImg_f0fr8_153 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
._resultImgPlaceholder_f0fr8_166 {
  width: 100%;
  height: 100%;
  background: var(--overlay-sm);
}

._resultInfo_f0fr8_172 {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

._resultArtist_f0fr8_180 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._resultMeta_f0fr8_189 {
  font-size: 12px;
  color: var(--text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

._resultChevron_f0fr8_197 {
  color: var(--text-secondary);
  flex-shrink: 0;
}
/* Search FAB — mobile + tablet only, dezent transparent + blur */
._fab_qfec9_2 {
  position: fixed;
  right: 16px;
  /* Default: stacked above Create-FAB (Create sits at calc(16 + safe), height 56, +12 gap) */
  bottom: calc(16px + 56px + 12px + env(safe-area-inset-bottom, 0px));
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.4);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.18);
  color: rgba(255, 255, 255, 0.7);
  display: none;
  align-items: center;
  justify-content: center;
  z-index: 100;
  cursor: pointer;
  box-shadow: 0 0 16px 2px rgba(0, 0, 0, 0.5);
  transition: transform 0.2s ease, box-shadow 0.2s ease,
              bottom 0.25s cubic-bezier(0.32, 0.72, 0, 1),
              color 0.15s, border-color 0.15s;
  -webkit-transform: translateZ(0);
  transform: translateZ(0);
}

@media (max-width: 1279px) {
  ._fab_qfec9_2 { display: flex; }
}

._fab_qfec9_2:hover {
  transform: translateY(-2px) scale(1.04) translateZ(0);
  box-shadow: 0 0 22px 3px rgba(0, 0, 0, 0.65);
  color: rgba(255, 255, 255, 0.9);
  border-color: rgba(255, 255, 255, 0.28);
}
._fab_qfec9_2:active { transform: scale(0.98) translateZ(0); }

/* Solo mode: no Create-FAB beneath → take the Create-FAB's bottom-right slot */
._fabSolo_qfec9_41 {
  bottom: calc(16px + env(safe-area-inset-bottom, 0px));
}

/* Hide when EventDetailPanel is open (matches .fabPanelOpen pattern from Home.module.css) */
._fabPanelOpen_qfec9_45 { display: none; }
._page_d2va4_1 {
  display: flex;
  flex-direction: column;
  flex: 1;
  overflow-y: auto;
  background: var(--bg);
}

._inner_d2va4_9 {
  width: 100%;
  display: flex;
  flex-direction: column;
  flex: 1;
}

@media (min-width: 1280px) {
  ._inner_d2va4_9 {
    max-width: 30%;
    margin: 0 auto;
  }
}

/* ── Header ── */
._header_d2va4_24 {
  display: flex;
  align-items: center;
  padding: 24px 24px 8px;
}

._title_d2va4_30 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
}

/* ── Body ── */
._body_d2va4_37 {
  flex: 1;
  padding: 8px 20px 24px;
}

/* ── Card ── */
._card_d2va4_43 {
  background: #000;
  border: none;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: none;
  border: 1px solid rgba(255,255,255,0.15);
}

/* ── Divider ── */
._divider_d2va4_53 {
  height: 1px;
  background: var(--card-border);
  margin: 0 16px;
}

/* ── Row ── */
._row_d2va4_60 {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 16px 16px;
  text-align: left;
  transition: background 0.12s;
  background: transparent;
  border: none;
}
._row_d2va4_60:hover { background: rgba(255, 255, 255, 0.04); }
._row_d2va4_60:active { background: rgba(255, 255, 255, 0.07); }

._rowIcon_d2va4_74 {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid rgba(255, 255, 255, 0.08);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  flex-shrink: 0;
}

._rowContent_d2va4_87 {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}

._rowLabel_d2va4_95 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
}

._rowDesc_d2va4_101 {
  font-size: 12px;
  font-weight: 500;
  color: var(--text-secondary);
}

._chevron_d2va4_107 {
  color: var(--text-secondary);
  flex-shrink: 0;
  opacity: 0.5;
}

._rowLogout_d2va4_113:hover { background: rgba(255, 85, 85, 0.08); }

._rowIconLogout_d2va4_115 {
  background: rgba(255, 85, 85, 0.12);
  border-color: rgba(255, 85, 85, 0.2);
  color: #ff5555;
}

._rowLabelLogout_d2va4_121 {
  color: #ff5555;
}

/* ── Avatar section ── */
._avatarSection_d2va4_126 {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 24px 0 8px;
}

._avatarBtn_d2va4_134 {
  position: relative;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  overflow: hidden;
  cursor: pointer;
  flex-shrink: 0;
}

._avatarImg_d2va4_144 {
  width: 80px;
  height: 80px;
  object-fit: cover;
  border-radius: 50%;
  display: block;
}

._avatarInitials_d2va4_152 {
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: rgba(255,255,255,0.12);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 28px;
  font-weight: 800;
  color: var(--text-primary);
}

._avatarOverlay_d2va4_165 {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.45);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 0;
  transition: opacity 0.15s;
}
._avatarBtn_d2va4_134:hover ._avatarOverlay_d2va4_165 { opacity: 1; }

._hiddenFile_d2va4_179 { display: none; }

._avatarLabel_d2va4_181 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
}

._avatarRole_d2va4_187 {
  font-size: 11px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
}

/* ── Legal collapsible cards ── */
._legalCard_d2va4_196 {
  background: #000;
  border: none;
  border-radius: 20px;
  overflow: hidden;
  box-shadow: none;
  border: 1px solid rgba(255,255,255,0.15);
}

._legalCardHeader_d2va4_205 {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  cursor: pointer;
  transition: background 0.15s;
}
._legalCardHeader_d2va4_205:hover { background: var(--overlay-xs); }

._legalCardTitle_d2va4_216 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}

._legalCardChevron_d2va4_222 {
  flex-shrink: 0;
  color: var(--text-secondary);
  transition: transform 0.2s;
}
._legalCardChevronOpen_d2va4_227 { transform: rotate(180deg); }

._legalCardBody_d2va4_229 {
  padding: 0 20px 16px;
  border-top: 1px solid var(--card-border);
}
._legalCardBody_d2va4_229 p, ._legalCardBody_d2va4_229 li {
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 8px 0 0;
}
._legalCardBody_d2va4_229 h2 {
  font-size: 10px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin: 16px 0 0;
}
._legalCardBody_d2va4_229 a { color: var(--accent); }
._page_17nq2_1 {
  min-height: 100dvh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  position: relative;
  overflow: hidden;
  background: #0a0a0a;
}

/* ── Blurred dummy background ── */
._bgBlur_17nq2_13 {
  position: absolute;
  inset: -40px;
  filter: blur(18px) saturate(1.2);
  z-index: 0;
  pointer-events: none;
}

._bgGrid_17nq2_21 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  padding: 12px;
  height: 100%;
}

._dummyCard_17nq2_29 {
  background: #161820;
  border-radius: 28px;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}

._dummyImg_17nq2_37 {
  height: 120px;
  background: linear-gradient(135deg, var(--c1, #1a3a6e), var(--c2, #0d1f42));
  flex-shrink: 0;
}

._dummyBody_17nq2_43 {
  padding: 12px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

._dummyLine_17nq2_50 {
  height: 12px;
  background: rgba(255,255,255,0.18);
  border-radius: 6px;
}

._dummyLineSm_17nq2_56 {
  height: 9px;
  background: rgba(255,255,255,0.09);
  border-radius: 6px;
}

/* ── Dark overlay ── */
._overlay_17nq2_63 {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(2px);
  z-index: 1;
  pointer-events: none;
}

/* ── Login content (no card) ── */
._content_17nq2_73 {
  position: relative;
  z-index: 2;
  width: 100%;
  max-width: 380px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}

._logo_17nq2_84 {
  margin-bottom: 6px;
}

._title_17nq2_88 {
  font-size: 22px;
  font-weight: 900;
  letter-spacing: 0.06em;
  color: var(--text-primary);
}

._backArrow_17nq2_95 {
  position: absolute;
  top: 20px;
  left: 20px;
  z-index: 3;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.15);
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(255,255,255,0.7);
  transition: background 0.15s, color 0.15s;
}
._backArrow_17nq2_95:hover { background: rgba(255,255,255,0.14); color: #fff; }

._form_17nq2_113 {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 28px;
}

._field_17nq2_121 {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

._field_17nq2_121 label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

._field_17nq2_121 input {
  width: 100%;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.45);
  border-radius: 14px;
  padding: 12px 16px;
  font-size: 16px;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.15s;
  -webkit-text-fill-color: var(--text-primary);
}

._field_17nq2_121 input:-webkit-autofill,
._field_17nq2_121 input:-webkit-autofill:hover,
._field_17nq2_121 input:-webkit-autofill:focus,
._field_17nq2_121 input:-webkit-autofill:active {
  -webkit-box-shadow: 0 0 0 1000px rgba(10, 10, 15, 0.8) inset;
  -webkit-text-fill-color: var(--text-primary);
  caret-color: var(--text-primary);
  border-color: rgba(255,255,255,0.45) !important;
  outline: none !important;
}

._field_17nq2_121 input:focus {
  border-color: rgba(255,255,255,0.45);
}

._field_17nq2_121 input::placeholder { color: #444; }

._pwWrapper_17nq2_165 {
  position: relative;
}

._pwWrapper_17nq2_165 input {
  padding-right: 52px;
}

/* Hide browser native password reveal buttons */
._pwWrapper_17nq2_165 input::-ms-reveal,
._pwWrapper_17nq2_165 input::-ms-clear,
._pwWrapper_17nq2_165 input::-webkit-credentials-auto-fill-button,
._pwWrapper_17nq2_165 input::-webkit-contacts-auto-fill-button,
._pwWrapper_17nq2_165 input::-moz-reveal {
  display: none;
}

._eyeBtn_17nq2_182 {
  position: absolute;
  right: 14px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-secondary);
  display: flex;
  align-items: center;
}

._error_17nq2_192 {
  font-size: 13px;
  color: #ff5555;
  text-align: center;
  background: rgba(255,85,85,0.1);
  border-radius: 10px;
  padding: 8px 12px;
}

._submitBtn_17nq2_201 {
  width: 100%;
  padding: 14px;
  border-radius: var(--btn-radius);
  background: #2f7bff;
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  transition: opacity 0.15s, background 0.15s;
  margin-top: 4px;
}

._submitBtn_17nq2_201:hover { background: #4a8fff; }
._submitBtn_17nq2_201:disabled { opacity: 0.5; }

/* ── Honeypot (hidden from real users) ── */
._honeypot_17nq2_217 {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  opacity: 0;
  pointer-events: none;
  tab-index: -1;
}

/* ── Join request section ── */
._requestSection_17nq2_228 {
  width: 100%;
  margin-top: 16px;
  display: flex;
  flex-direction: column;
  align-items: center;
}

._requestToggle_17nq2_236 {
  font-size: 13px;
  font-weight: 600;
  color: rgba(255,255,255,0.45);
  background: none;
  border: none;
  padding: 4px 0;
  transition: color 0.15s;
  min-height: unset;
}
._requestToggle_17nq2_236:hover { color: rgba(255,255,255,0.75); }

._requestForm_17nq2_248 {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 10px;
  animation: _fadeIn_17nq2_1 0.2s ease both;
}

@keyframes _fadeIn_17nq2_1 {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}

._requestLabel_17nq2_261 {
  font-size: 12px;
  font-weight: 700;
  color: rgba(255,255,255,0.5);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  text-align: center;
}

._requestInput_17nq2_270 {
  width: 100%;
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.15);
  border-radius: 12px;
  padding: 11px 14px;
  font-size: 14px;
  font-family: inherit;
  color: var(--text-primary);
  outline: none;
  transition: border-color 0.15s;
}
._requestInput_17nq2_270:focus { border-color: rgba(255,255,255,0.4); }
._requestInput_17nq2_270::placeholder { color: rgba(255,255,255,0.3); }

._requestActions_17nq2_285 {
  display: flex;
  gap: 8px;
}

._requestCancel_17nq2_290 {
  flex: 1;
  padding: 11px;
  border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06);
  border: 1px solid rgba(255,255,255,0.1);
  color: rgba(255,255,255,0.5);
  font-size: 14px;
  font-weight: 600;
  min-height: unset;
  transition: background 0.15s;
}
._requestCancel_17nq2_290:hover { background: rgba(255,255,255,0.1); }

._requestSubmit_17nq2_304 {
  flex: 1;
  padding: 11px;
  border-radius: var(--btn-radius);
  background: #2f7bff;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  min-height: unset;
  transition: opacity 0.15s;
}
._requestSubmit_17nq2_304:hover { opacity: 0.85; }
._requestSubmit_17nq2_304:disabled { opacity: 0.5; }

._requestSuccess_17nq2_318 {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.55);
  text-align: center;
  animation: _fadeIn_17nq2_1 0.2s ease both;
}
._page_vkw9f_1 {
  flex: 1;
  overflow-y: auto;
  padding: 24px 16px 48px;
  display: flex;
  flex-direction: column;
}

._content_vkw9f_9 {
  max-width: 680px;
  margin: 0 auto;
  width: 100%;
  flex: 1;
}

._content_vkw9f_9 h1 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 8px;
}

._content_vkw9f_9 h2 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  margin-top: 28px;
  margin-bottom: 8px;
}

._content_vkw9f_9 p, ._content_vkw9f_9 li {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin-bottom: 8px;
}

._content_vkw9f_9 ul {
  padding-left: 20px;
}

._content_vkw9f_9 a {
  color: var(--accent);
  text-decoration: underline;
}

._backBtn_vkw9f_49 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  background: none;
  padding: 0;
  margin-bottom: 24px;
  transition: color 0.15s;
  cursor: pointer;
}
._backBtn_vkw9f_49:hover { color: var(--text-primary); }
._page_19s69_1 {
  display: flex;
  flex-direction: column;
  padding: 40px 0 0;
}

._inner_19s69_7 {
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 760px;
  width: 100%;
  margin: 0 auto;
  padding: 0 24px 80px;
  flex: 1;
}

._backBtn_19s69_18 {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  background: none;
  padding: 0;
  margin-bottom: 24px;
  transition: color 0.15s;
  cursor: pointer;
}
._backBtn_19s69_18:hover { color: var(--text-primary); }

._title_19s69_33 {
  font-size: 28px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 6px;
}

._version_19s69_40 {
  font-size: 12px;
  color: var(--text-secondary);
  margin: 0 0 40px;
}

._section_19s69_46 {
  margin-bottom: 32px;
}

._section_19s69_46 h2 {
  font-size: 16px;
  font-weight: 700;
  color: var(--text-primary);
  margin: 0 0 10px;
}

._section_19s69_46 p, ._section_19s69_46 ul {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.7;
  margin: 0 0 10px;
}

._section_19s69_46 ul {
  padding-left: 20px;
}

._section_19s69_46 ul li {
  margin-bottom: 6px;
}

._section_19s69_46 a { color: var(--accent); }

._footer_19s69_74 {
  margin-top: 40px;
  font-size: 11px;
  color: var(--text-secondary);
  opacity: 0.5;
  text-align: center;
}
._page_y7s6z_1 {
  height: 100%;
  overflow-y: auto;
  scrollbar-width: none;
}
._page_y7s6z_1::-webkit-scrollbar { display: none; }

/* ── Section 1: Hero ── */
._heroSection_y7s6z_9 {
  position: relative;
  min-height: calc(100dvh - 56px);
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 72px 40px 48px;
}
@media (max-width: 1279px) {
  ._heroSection_y7s6z_9 { min-height: 100dvh; padding: 48px 24px; }
}

._heroGrid_y7s6z_21 {
  display: grid;
  grid-template-columns: 1fr 345px;
  gap: 60px;
  align-items: center;
  max-width: 960px;
  width: 100%;
}
@media (max-width: 767px) {
  ._heroGrid_y7s6z_21 { grid-template-columns: 1fr; gap: 40px; }
  ._mockupWrap_y7s6z_31 { order: -1; }
}

._hero_y7s6z_9 { display: flex; flex-direction: column; gap: 20px; }
._heroLabel_y7s6z_35 {
  font-size: 11px; font-weight: 700; letter-spacing: 0.14em;
  text-transform: uppercase; color: var(--accent);
}
._heroTitle_y7s6z_39 {
  font-size: 42px; font-weight: 900; color: var(--text-primary);
  margin: 0; line-height: 1.08;
}
@media (max-width: 639px) { ._heroTitle_y7s6z_39 { font-size: 30px; } }

._heroSub_y7s6z_45 {
  font-size: 16px; color: var(--text-secondary);
  line-height: 1.7; margin: 0; max-width: 460px;
}
._heroActions_y7s6z_49 { display: flex; gap: 12px; flex-wrap: wrap; margin-top: 8px; }

/* Mockup */
._mockupWrap_y7s6z_31 {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
}
._mockupWrap_y7s6z_31::before {
  content: '';
  position: absolute;
  inset: -5%;
  background: var(--accent);
  filter: blur(40px);
  opacity: 0.25;
  border-radius: 50%;
  z-index: 0;
}
._mockupImg_y7s6z_68 {
  width: 100%;
  max-width: 345px;
  height: auto;
  border-radius: 0;
  box-shadow: none;
  position: relative;
  z-index: 1;
}
@media (max-width: 767px) {
  ._mockupImg_y7s6z_68 { max-width: 230px; }
}

/* ── Hero back button ── */
._heroBackBtn_y7s6z_82 {
  position: absolute;
  top: 20px;
  left: 24px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  background: none;
  padding: 0;
  transition: color 0.15s;
  z-index: 2;
}
._heroBackBtn_y7s6z_82:hover { color: var(--text-primary); }

/* ── Section 2: Manifesto ── */
._manifestoSection_y7s6z_100 {
  padding: 80px 40px;
  background: #000;
}
@media (max-width: 767px) { ._manifestoSection_y7s6z_100 { padding: 60px 24px; } }

._manifestoInner_y7s6z_106 {
  max-width: 960px;
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 60px;
  align-items: start;
}
@media (max-width: 767px) { ._manifestoInner_y7s6z_106 { grid-template-columns: 1fr; gap: 28px; } }

._manifestoTitle_y7s6z_116 {
  font-size: 36px;
  font-weight: 900;
  color: var(--text-primary);
  line-height: 1.2;
  margin: 0;
}
@media (max-width: 639px) { ._manifestoTitle_y7s6z_116 { font-size: 26px; } }

._manifestoText_y7s6z_125 { display: flex; flex-direction: column; gap: 16px; }
._manifestoText_y7s6z_125 p { font-size: 15px; color: var(--text-secondary); line-height: 1.75; margin: 0; }

/* ── Section 3: Cards ── */
._featuresSection_y7s6z_129 { padding: 80px 40px 100px; }
@media (max-width: 767px) { ._featuresSection_y7s6z_129 { padding: 60px 24px 80px; } }
._featuresInner_y7s6z_131 { max-width: 960px; margin: 0 auto; }
._features_y7s6z_129 { display: grid; grid-template-columns: repeat(2, 1fr); gap: 14px; }
@media (max-width: 639px) { ._features_y7s6z_129 { grid-template-columns: 1fr; } }

._featureCard_y7s6z_135 {
  background: #000; border: 1px solid rgba(255,255,255,0.1);
  border-radius: 18px; padding: 24px;
  display: flex; flex-direction: column; gap: 10px;
  transition: border-color 0.2s;
}
._featureCard_y7s6z_135:hover { border-color: rgba(255,255,255,0.2); }
._featureIcon_y7s6z_142 {
  width: 44px; height: 44px; border-radius: 12px;
  background: rgba(142,187,255,0.1);
  display: flex; align-items: center; justify-content: center;
  color: var(--accent); flex-shrink: 0;
}
._featureTitle_y7s6z_148 { font-size: 15px; font-weight: 700; color: var(--text-primary); margin: 0; }
._featureDesc_y7s6z_149 { font-size: 13px; color: var(--text-secondary); line-height: 1.55; margin: 0; }

/* ── Form / Success section ── */
/* ── Registration modal ── */
._formModal_y7s6z_153 {
  position: fixed; inset: 0; z-index: 1250;
  background: rgba(0,0,0,0.85);
  display: flex; align-items: center; justify-content: center;
  padding: 24px; overflow-y: auto;
  animation: _fadeIn_y7s6z_1 0.2s ease both;
}
._formModalOut_y7s6z_160 { animation: _fadeOut_y7s6z_1 0.2s ease both; }

@keyframes _fadeIn_y7s6z_1  { from { opacity: 0; } to { opacity: 1; } }
@keyframes _fadeOut_y7s6z_1 { from { opacity: 1; } to { opacity: 0; } }
@keyframes _slideUp_y7s6z_1   { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes _slideDown_y7s6z_1 { from { opacity: 1; transform: translateY(0); } to { opacity: 0; transform: translateY(12px); } }

._formModalHeader_y7s6z_167 {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 24px;
}
._formCloseBtn_y7s6z_171 {
  width: 32px; height: 32px; border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary); transition: background 0.15s; flex-shrink: 0;
}
._formCloseBtn_y7s6z_171:hover { background: rgba(255,255,255,0.14); }

/* ── Buttons ── */
._ctaBtn_y7s6z_180 {
  padding: 14px 28px; border-radius: var(--btn-radius);
  background: var(--accent); color: var(--btn-fg);
  font-size: 15px; font-weight: 700; transition: opacity 0.15s;
}
._ctaBtn_y7s6z_180:hover { opacity: 0.88; }
._ctaBtn_y7s6z_180:disabled { opacity: 0.5; }
._secondaryBtn_y7s6z_187 {
  padding: 13px 22px; border-radius: var(--btn-radius);
  background: rgba(255,255,255,0.06); border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-secondary); font-size: 14px; font-weight: 600; transition: background 0.15s;
}
._secondaryBtn_y7s6z_187:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }

/* ── Form card ── */
._formCard_y7s6z_195 {
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px; padding: 36px 32px;
  max-width: 580px; width: 100%;
  max-height: 85dvh; overflow-y: auto; scrollbar-width: none;
  animation: _slideUp_y7s6z_1 0.2s ease both;
}
._formCard_y7s6z_195::-webkit-scrollbar { display: none; }
._formCardOut_y7s6z_204 { animation: _slideDown_y7s6z_1 0.2s ease both; }
._formTitle_y7s6z_205 { font-size: 22px; font-weight: 800; color: var(--text-primary); margin: 0; }
._form_y7s6z_153 { display: flex; flex-direction: column; gap: 14px; }
._field_y7s6z_207 { display: flex; flex-direction: column; gap: 5px; }
._field_y7s6z_207 label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-secondary); }
._field_y7s6z_207 input, ._field_y7s6z_207 select {
  background: rgba(255,255,255,0.07); border: 1px solid rgba(255,255,255,0.18);
  border-radius: 10px; padding: 10px 13px; font-size: 14px;
  color: var(--text-primary); font-family: inherit; outline: none;
}
._field_y7s6z_207 input:focus, ._field_y7s6z_207 select:focus { border-color: rgba(255,255,255,0.4); }
._field_y7s6z_207 select { cursor: pointer; padding-right: 32px; }
._agbRow_y7s6z_216 { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--text-secondary); line-height: 1.5; cursor: pointer; }
._agbRow_y7s6z_216 input[type="checkbox"] { margin-top: 2px; flex-shrink: 0; accent-color: var(--accent); }
._agbLink_y7s6z_218 { color: var(--accent); }
._agbLink_y7s6z_218:hover { text-decoration: underline; }
._error_y7s6z_220 { font-size: 13px; color: #ff6b6b; background: rgba(255,68,68,0.08); border-radius: 8px; padding: 10px 12px; }

/* ── Success card ── */
._successCard_y7s6z_223 {
  background: #000; box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.12);
  border-radius: 24px; padding: 48px 32px; text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
  max-width: 440px; width: 100%;
}
._successCard_y7s6z_223 h2 { font-size: 24px; font-weight: 800; color: var(--text-primary); margin: 0; }
._successCard_y7s6z_223 p { font-size: 15px; color: var(--text-secondary); line-height: 1.6; margin: 0; }

/* ── Divider ── */
._footerDivider_y7s6z_233 {
  width: 100%;
  height: 1px;
  background: rgba(255,255,255,0.1);
  flex-shrink: 0;
}

/* ── Footer ── */
._footer_y7s6z_233 { padding: 48px 40px 64px; }
@media (max-width: 767px) { ._footer_y7s6z_233 { padding: 40px 24px 56px; } }

._footerInner_y7s6z_244 {
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 32px;
}

._footerRow_y7s6z_253 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  text-align: center;
  margin: 0;
  line-height: 1.8;
}
._footerRow_y7s6z_253 a {
  color: var(--text-secondary);
  font-weight: 600;
  transition: color 0.15s;
}
._footerRow_y7s6z_253 a:hover { color: var(--text-primary); }
._footerLogo_y7s6z_267 {
  display: flex;
  align-items: center;
  gap: 8px;
}
._footerLogoText_y7s6z_272 {
  font-size: 16px;
  font-weight: 900;
  letter-spacing: 0.15em;
  color: var(--accent);
}
._footerText_y7s6z_278 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
}
._footerLink_y7s6z_283 {
  font-size: 13px;
  font-weight: 600;
  color: var(--text-secondary);
  transition: color 0.15s;
}
._footerLink_y7s6z_283:hover { color: var(--text-primary); }

._footerAccordions_y7s6z_291 {
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 14px;
}
._footerAccordionBtn_y7s6z_297 {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  background: transparent;
  cursor: pointer;
  transition: background 0.15s;
}
._footerAccordionBtn_y7s6z_297:hover { background: rgba(255,255,255,0.03); }
._footerAccordionTitle_y7s6z_308 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
}
._footerAccordionChevron_y7s6z_313 {
  color: var(--text-secondary);
  transition: transform 0.2s;
  flex-shrink: 0;
}
._footerAccordionChevronOpen_y7s6z_318 { transform: rotate(180deg); }
._footerAccordionBody_y7s6z_319 {
  padding: 0 18px 16px;
  border-top: 1px solid rgba(255,255,255,0.08);
  font-size: 13px;
  color: var(--text-secondary);
  line-height: 1.7;
  animation: _legalExpand_y7s6z_1 0.2s ease;
}
._footerAccordionBody_y7s6z_319 a { color: var(--accent); }
._footerAccordionBody_y7s6z_319 a:hover { text-decoration: underline; }
._footerAccordionDivider_y7s6z_329 {
  height: 1px;
  background: rgba(255,255,255,0.08);
}
[data-theme="light"] ._modal_169a5_1 {
  background: #fff;
}

._modal_169a5_1 {
  position: relative;
  background: #000;
  border: none;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  width: 100%;
  max-width: 90vw;
  max-height: 85dvh;
  overflow-y: auto;
  scrollbar-width: none;
  display: flex;
  flex-direction: column;
  animation: _slideUp_169a5_1 0.2s ease;
}

@media (min-width: 1280px) {
  ._modal_169a5_1 { max-width: 55vw; }
}
._modal_169a5_1::-webkit-scrollbar { display: none; }

@keyframes _slideUp_169a5_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

._closeBtn_169a5_31 {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: var(--card-border);
  color: var(--text-secondary);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s;
  z-index: 10;
}
._closeBtn_169a5_31:hover { background: var(--card-border-hover, rgba(255,255,255,0.15)); }

._header_169a5_50 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 20px 20px 0;
  flex-shrink: 0;
}

._title_169a5_58 {
  font-size: 18px;
  font-weight: 800;
  color: var(--text-primary);
}

._body_169a5_64 {
  flex: 1;
  overflow-y: auto;
}
[data-theme="light"] ._modal_1pcqx_1 {
  background: #fff;
}

._modal_1pcqx_1 {
  position: relative;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  padding: 40px 32px 36px;
  text-align: center;
  width: 100%;
  max-width: 340px;
  animation: _slideUp_1pcqx_1 0.2s ease;
}

@keyframes _slideUp_1pcqx_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

._icon_1pcqx_22 {
  font-size: 48px;
  margin-bottom: 14px;
  line-height: 1;
}

._title_1pcqx_28 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin-bottom: 8px;
}

._sub_1pcqx_35 {
  font-size: 14px;
  color: var(--text-secondary);
  line-height: 1.5;
}
._modal_5s5uy_1 {
  position: relative;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  padding: 40px 32px 36px;
  text-align: center;
  width: 100%;
  max-width: 360px;
  animation: _slideUp_5s5uy_1 0.2s ease;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 14px;
}

@keyframes _slideUp_5s5uy_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

._title_5s5uy_22 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}

._sub_5s5uy_29 {
  font-size: 15px;
  color: var(--text-secondary);
  line-height: 1.6;
  margin: 0;
}

._loginBtn_5s5uy_36 {
  width: 100%;
  margin-top: 6px;
  padding: 13px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 15px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._loginBtn_5s5uy_36:hover { opacity: 0.88; }
._modal_1sv17_1 {
  position: relative;
  background: #000;
  box-shadow: 0 0 0 1px rgba(142, 187, 255, 0.5), 0 0 40px rgba(142,187,255,0.15);
  border-radius: 20px;
  padding: 36px 32px;
  width: 100%;
  max-width: 400px;
  animation: _slideUp_1sv17_1 0.2s ease;
  display: flex;
  flex-direction: column;
  gap: 0;
}

@keyframes _slideUp_1sv17_1 {
  from { opacity: 0; transform: translateY(16px); }
  to   { opacity: 1; transform: translateY(0); }
}

._title_1sv17_20 {
  font-size: 20px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0 0 6px;
}

._sub_1sv17_27 {
  font-size: 14px;
  color: var(--text-secondary);
  margin: 0 0 20px;
  line-height: 1.5;
}

._closeBtn_1sv17_34 {
  position: absolute;
  top: 16px;
  right: 16px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-secondary);
  transition: background 0.15s;
}
._closeBtn_1sv17_34:hover { background: rgba(255,255,255,0.14); }

._form_1sv17_50 { display: flex; flex-direction: column; gap: 12px; }

._field_1sv17_52 { display: flex; flex-direction: column; gap: 5px; }
._field_1sv17_52 label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--text-secondary);
}
._field_1sv17_52 input {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 12px;
  padding: 10px 14px;
  font-size: 14px;
  color: var(--text-primary);
  font-family: inherit;
  outline: none;
  transition: border-color 0.15s;
}
._field_1sv17_52 input:focus { border-color: rgba(255,255,255,0.45); }

._submitBtn_1sv17_73 {
  padding: 12px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  margin-top: 4px;
  transition: opacity 0.15s;
}
._submitBtn_1sv17_73:hover { opacity: 0.88; }
._submitBtn_1sv17_73:disabled { opacity: 0.5; }

._error_1sv17_86 {
  font-size: 13px;
  color: #ff6b6b;
  background: rgba(255,68,68,0.08);
  border-radius: 8px;
  padding: 10px 12px;
}

._success_1sv17_94 {
  font-size: 14px;
  color: var(--text-secondary);
  text-align: center;
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 8px 0;
}

._successIcon_1sv17_106 {
  color: var(--accent);
}

._loginBtn_1sv17_110 {
  padding: 12px 28px;
  border-radius: var(--btn-radius);
  background: var(--accent);
  color: var(--btn-fg);
  font-size: 14px;
  font-weight: 700;
  transition: opacity 0.15s;
}
._loginBtn_1sv17_110:hover { opacity: 0.88; }
/* ── Mobile (default) ──────────────────────────────────── */
._shell_1fddp_2 {
  display: flex;
  height: 100dvh;
  overflow: hidden;
  background: var(--bg);
  position: relative;
}

._sidebarSlot_1fddp_10 {
  display: none;
}

._body_1fddp_14 {
  flex: 1;
  display: flex;
  flex-direction: row;
  overflow: hidden;
  min-height: 0;
}

._main_1fddp_22 {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  min-height: 0;
  overflow-y: auto;
  scrollbar-width: none;
  /* Reserve scrollbar space so toggling overflow:hidden (e.g. when sticky-month
     dropdown opens) doesn't reflow content. */
  scrollbar-gutter: stable;
}
._main_1fddp_22::-webkit-scrollbar { display: none; }

._pageTransition_1fddp_36 {
  animation: _pageFadeIn_1fddp_1 0.18s ease both;
  display: contents;
}
@keyframes _pageFadeIn_1fddp_1 { from { opacity: 0; } to { opacity: 1; } }

/* ── Tablet (768px+) ───────────────────────────────────── */
@media (min-width: 768px) {
  /* Cards switch to 2-col in Page.module.css */
}

/* Subpage header: mobile/tablet only */
._subpageHeader_1fddp_48 {
  display: contents;
}
@media (min-width: 1280px) {
  ._subpageHeader_1fddp_48 { display: none; }
}

/* ── Desktop (1280px+): top bar nav ────────────────────── */
@media (min-width: 1280px) {
  ._shell_1fddp_2 {
    flex-direction: column;
  }

  ._sidebarSlot_1fddp_10 {
    display: block;
    flex-shrink: 0;
    width: 100%;
    /* Reserve space so ALL routed pages start below the fixed sidebar
       (Home, Admin, Settings, Dashboard, etc. each have their own scroll
       containers, so a per-page padding-top approach would be inconsistent). */
    height: calc(56px + env(safe-area-inset-top));
  }
}
