/* ── 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_rb2qf_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_rb2qf_15 {
  grid-template-columns: auto auto repeat(5, 1fr) auto;
  gap: 8px;
}

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

/* ── Arrow buttons ─────────────────────────────────────────*/
._arrowBtn_rb2qf_25 {
  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_rb2qf_25:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._arrowBtn_rb2qf_25 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._arrowBtn_rb2qf_25:hover { border-color: rgba(0, 0, 0, 0.35); }

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

/* ── Heute button ──────────────────────────────────────────*/
._heuteBtn_rb2qf_50 {
  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_rb2qf_50:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._heuteBtn_rb2qf_50 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._heuteBtn_rb2qf_50:hover { border-color: rgba(0, 0, 0, 0.35); }

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

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

/* ── Day cells ─────────────────────────────────────────────*/
._day_rb2qf_87 {
  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_rb2qf_104 {
  opacity: 1;
  border-color: rgba(255,255,255,0.12);
  cursor: pointer;
}
._dayHasEvent_rb2qf_104:hover { background: rgba(255,255,255,0.07); border-color: rgba(255,255,255,0.22); }
[data-theme="light"] ._dayHasEvent_rb2qf_104 { border-color: rgba(0, 0, 0, 0.12); }
[data-theme="light"] ._dayHasEvent_rb2qf_104: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_rb2qf_116 { background: transparent !important; border-color: var(--text-secondary) !important; opacity: 1; }
._dayToday_rb2qf_116:hover { background: var(--overlay-xs) !important; }
._dayToday_rb2qf_116 ._dayNum_rb2qf_118  { color: var(--text-primary); }
._dayToday_rb2qf_116 ._dayName_rb2qf_119 { color: var(--text-secondary); }

._dayTodayUnfocused_rb2qf_121 { background: transparent !important; border-color: var(--text-secondary) !important; opacity: 1; }
._dayTodayUnfocused_rb2qf_121 ._dayNum_rb2qf_118  { color: var(--text-primary); }
._dayTodayUnfocused_rb2qf_121 ._dayName_rb2qf_119 { color: var(--text-secondary); }
._dayTodayUnfocused_rb2qf_121 ._dot_rb2qf_124     { background: var(--text-primary); }
._dayTodayUnfocused_rb2qf_121 ._dotBookmark_rb2qf_125 { background: var(--text-primary); }

._daySelected_rb2qf_113 {
  background: var(--accent) !important;
  border-color: var(--accent) !important;
  opacity: 1;
  transition: none;
}
._daySelected_rb2qf_113 ._dayName_rb2qf_119 { color: rgba(0,0,0,0.6) !important; }
._daySelected_rb2qf_113 ._dayNum_rb2qf_118  { color: var(--btn-fg) !important; }
._daySelected_rb2qf_113 ._dot_rb2qf_124     { background: rgba(0,0,0,0.3); }
._daySelected_rb2qf_113 ._dotBookmark_rb2qf_125 { background: rgba(180,100,0,0.8); }

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

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

._dayName_rb2qf_119 {
  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_rb2qf_104       { border-color: transparent; }
._dayHasEvent_rb2qf_104:hover { border-color: transparent; }

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

/* ── Tablet (640–1279px): 20% smaller ───────────────────────*/
@media (min-width: 640px) and (max-width: 1279px) {
  ._strip_rb2qf_2  { gap: 5px; }
  ._arrowBtn_rb2qf_25 { width: 35px; height: 35px; border-radius: 13px; }
  ._heuteBtn_rb2qf_50 { display: none; }
  ._day_rb2qf_87    { min-height: 58px; border-radius: 14px; }
  ._dayNum_rb2qf_118 { font-size: 18px; }
}

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

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

._dotBookmark_rb2qf_125 { 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_1cq5e_1 {
  display: flex;
  flex-direction: row;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

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

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

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

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

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

._header_1cq5e_45 {
  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_1cq5e_45 { 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_1cq5e_45 {
    width: 100vw;
    margin-left: -15vw;
    padding: 24px 15vw 8px;
  }
}

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

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

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

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

._backBtn_1cq5e_100 {
  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_1cq5e_100:hover { border-color: rgba(255, 255, 255, 0.5); color: var(--text-primary); }
._backBtn_1cq5e_100 { display: none; }

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

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

._dbExportBtn_1cq5e_132 {
  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_1cq5e_132:hover { color: var(--text-primary); background: var(--overlay-md); }

._logoutBtn_1cq5e_148 {
  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_1cq5e_148:hover { color: var(--text-primary); }

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

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

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

._section_1cq5e_179 { padding: 12px 20px; }

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

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

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

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

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

._field_1cq5e_205 input,
._field_1cq5e_205 textarea,
._extraSupportBlock_1cq5e_222 input,
._extraSupportBlock_1cq5e_222 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_1cq5e_205 textarea._descriptionTextarea_1cq5e_239,
._extraSupportBlock_1cq5e_222 textarea._descriptionTextarea_1cq5e_239 {
  resize: vertical;
  min-height: 80px;
}
._field_1cq5e_205 input[type="date"] { color-scheme: dark; max-width: 100%; }
._field_1cq5e_205 input:focus, ._field_1cq5e_205 textarea:focus { border-color: rgba(255,255,255,0.3); }
._field_1cq5e_205 input::placeholder, ._field_1cq5e_205 textarea::placeholder { color: #555; }

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

._imageUrlInput_1cq5e_255 {
  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_1cq5e_255:focus { border-color: rgba(255,255,255,0.3); }
._imageUrlInput_1cq5e_255::placeholder { color: #555; }

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

._hiddenFile_1cq5e_285 { display: none; }

._uploadLabel_1cq5e_287 {
  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_1cq5e_287:hover {
  border-color: rgba(255,255,255,0.35);
  color: var(--text-primary);
}

._imgPreview_1cq5e_307 {
  position: relative;
  border-radius: 12px;
  overflow: hidden;
  aspect-ratio: 16/7;
}
._imgPreview_1cq5e_307 img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
._imgPreview_1cq5e_307 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_1cq5e_333 {
  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_1cq5e_333:hover { opacity: 0.9; }
._submitBtn_1cq5e_333:disabled { opacity: 0.5; }

._extraSupportBlock_1cq5e_222 {
  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_1cq5e_222 {
  background: rgba(0,0,0,0.03);
  border-color: rgba(0,0,0,0.10);
}
._extraSupportHeader_1cq5e_354 {
  display: flex; justify-content: space-between; align-items: center;
}
._extraSupportHeader_1cq5e_354 label { font-size: 11px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-secondary); }
._removeExtraBtn_1cq5e_358 { font-size: 12px; color: var(--text-secondary); background: none; padding: 2px 6px; transition: color 0.15s; }
._removeExtraBtn_1cq5e_358:hover { color: var(--text-primary); }
._addSupportBtn_1cq5e_360 {
  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_1cq5e_360:hover { background: rgba(142,187,255,0.12); }

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

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

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

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

._mobileFilterBtn_1cq5e_389 {
  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_1cq5e_389:hover { background: var(--overlay-sm); color: var(--text-primary); }
._mobileFilterBtnOpen_1cq5e_406   { border-color: var(--accent); background: var(--accent-dim); color: var(--accent); }

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

._mobileFilterDropdown_1cq5e_418 {
  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_1cq5e_434 {
  display: flex;
  flex-direction: column;
  gap: 5px;
}

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

._selectFull_1cq5e_447 {
  width: 100%;
}

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

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

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

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

._searchInput_1cq5e_440 {
  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_1cq5e_440:focus {
  border-color: rgba(255,255,255,0.3);
  width: 220px;
}
._searchInput_1cq5e_440::placeholder { color: #444; }

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

/* ── PAST badge ── */
._pastBadge_1cq5e_511 {
  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_1cq5e_523 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.07em;
  color: var(--accent);
  background: var(--accent-dim);
  border: 1px solid var(--accent);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

/* Scraper updated recently — "↻ DD.MM." */
._updatedBadge_1cq5e_536 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #f0a93b;
  background: rgba(240, 169, 59, 0.12);
  border: 1px solid rgba(240, 169, 59, 0.35);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

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

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

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

._bulkPublishBtn_1cq5e_578 {
  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_1cq5e_578:hover { background: rgba(76, 175, 80, 0.22); }

._bulkDraftBtn_1cq5e_593 {
  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_1cq5e_593:hover { background: rgba(255, 255, 255, 0.12); }

._bulkDeleteBtn_1cq5e_608 {
  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_1cq5e_608:hover { background: rgba(255, 68, 68, 0.2); }

._venueFilterSelect_1cq5e_623 {
  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_1cq5e_623:hover { border-color: rgba(255,255,255,0.2); }
._venueFilterSelect_1cq5e_623:focus { border-color: rgba(255,255,255,0.35); }

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

._eventRow_1cq5e_644 {
  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_1cq5e_644:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }

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

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

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

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

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

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

._draftBadge_1cq5e_693 {
  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;
}

/* ── Contributor approval section ── */
._contributorSection_1cq5e_705 {
  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_1cq5e_713 {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px 10px;
  color: #8EBBFF;
  border-bottom: 1px solid rgba(142, 187, 255, 0.12);
}

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

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

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

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

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

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

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

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

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

._reviewBtn_1cq5e_784 {
  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_1cq5e_784:hover { background: rgba(255, 255, 255, 0.1); color: var(--text-primary); }

._approveBtn_1cq5e_800,
._rejectBtn_1cq5e_801 {
  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_1cq5e_800:hover,
._rejectBtn_1cq5e_801:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
}

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

@media (max-width: 480px) {
  ._contributorSection_1cq5e_705 { margin: 0 12px 4px; }
  ._contributorRow_1cq5e_734 { flex-wrap: wrap; }
  ._contributorInfo_1cq5e_753 { flex-basis: calc(100% - 52px); }
  ._contributorActions_1cq5e_777 { width: 100%; margin-top: 8px; }
  ._reviewBtn_1cq5e_784,
  ._approveBtn_1cq5e_800,
  ._rejectBtn_1cq5e_801 { flex: 1; justify-content: center; padding: 8px 6px; }
}

._rejectedBadge_1cq5e_843 {
  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;
}

._contributorBadge_1cq5e_854 {
  font-size: 9px;
  font-weight: 800;
  letter-spacing: 0.05em;
  color: #8EBBFF;
  background: rgba(142, 187, 255, 0.15);
  border-radius: 4px;
  padding: 2px 5px;
  flex-shrink: 0;
}

._contributorNotice_1cq5e_865 {
  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_1cq5e_687 {
  font-size: 14px;
  font-weight: 700;
  color: var(--text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
._eventMeta_1cq5e_886 { font-size: 11px; color: var(--text-secondary); }

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

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

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

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

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

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

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

._confirmRow_1cq5e_946 {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-secondary);
}
._confirmYes_1cq5e_953 {
  font-size: 12px;
  font-weight: 700;
  color: #ff4444;
  background: rgba(255,68,68,0.1);
  border-radius: 8px;
  padding: 4px 10px;
}
._confirmNo_1cq5e_961 {
  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_1cq5e_1 {
  to { transform: rotate(360deg); }
}

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

._syncStopBtn_1cq5e_984 {
  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_1cq5e_984:hover { background: rgba(255, 68, 68, 0.22); }

._syncVenueSelect_1cq5e_1000 {
  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_1cq5e_1000:focus { border-color: rgba(255,255,255,0.3); }

._syncBtn_1cq5e_1017 {
  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_1cq5e_1017:hover:not(:disabled) { opacity: 0.88; }
._syncBtn_1cq5e_1017:disabled { opacity: 0.5; cursor: not-allowed; }
._syncBtnActive_1cq5e_1033 { opacity: 0.75; }

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

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

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

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

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

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

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

/* ── Edit panel ─────────────────────────────────────────── */
._editBackdrop_1cq5e_1106 {
  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_1cq5e_1116 { opacity: 1; }

@media (max-width: 1279px) {
  ._editBackdrop_1cq5e_1106 {
    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_1cq5e_1129 {
  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_1cq5e_1129::-webkit-scrollbar { display: none; }
._editPanelVisible_1cq5e_1142 { transform: none; }

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

@media (max-width: 1279px) {
  ._panelSlot_1cq5e_1145 {
    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_1cq5e_1151 { transform: translateX(0) !important; }
}
@media (max-width: 480px) {
  ._panelSlot_1cq5e_1145 { width: 100vw !important; }
  ._editPanelHeader_1cq5e_1168 { padding-top: 20px; }
  ._row_1cq5e_199 { 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_1cq5e_1177 {
    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_1cq5e_1177 ._page_1cq5e_1 { flex: 1; min-height: 0; }
  ._pageLayoutModal_1cq5e_1177 ._panelSlot_1cq5e_1145 {
    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_1cq5e_1177 ._panelSlotOpen_1cq5e_1151 {
    transform: none !important;
    pointer-events: auto;
  }
  ._pageLayoutModal_1cq5e_1177 ._editPanel_1cq5e_1129 {
    background: #000;
    width: 100%;
    height: 100%;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden;
    animation: _editPanelFadeIn_1cq5e_1 0.28s ease both;
  }
  ._pageLayoutModal_1cq5e_1177 ._editPanelHeader_1cq5e_1168 { flex: 0 0 auto; }
  ._pageLayoutModal_1cq5e_1177 ._editPanelBody_1cq5e_1216 {
    flex: 1 1 0 !important;
    min-height: 0 !important;
    overflow-y: auto !important;
  }
  ._pageLayoutModal_1cq5e_1177 ._editPanelFooter_1cq5e_1221 {
    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_1cq5e_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_1cq5e_1235 {
    display: none !important;
  }
  ._pageLayoutModal_1cq5e_1177 ._editPanelHeader_1cq5e_1168 { padding-top: 16px; }
}

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

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

._editCloseBtn_1cq5e_1256 {
  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_1cq5e_1256:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }

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

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

._positionPicker_1cq5e_1290 {
  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_1cq5e_1304 {
  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_1cq5e_1304:hover { background: rgba(255,255,255,0.65); transform: scale(1.15); }
._positionDotActive_1cq5e_1317 { background: #fff !important; transform: scale(1.15); }

._editSelect_1cq5e_1319 {
  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_1cq5e_1319:focus { border-color: rgba(255,255,255,0.3); }

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

._editCancelBtn_1cq5e_1342 {
  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_1cq5e_1342:hover { background: rgba(255,255,255,0.1); color: var(--text-primary); }

._editSaveBtn_1cq5e_1354 {
  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_1cq5e_1354:hover { opacity: 0.9; }
._editSaveBtn_1cq5e_1354:disabled { opacity: 0.5; }

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

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

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

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

._userRole_1cq5e_1396 {
  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_1cq5e_1407 {
  display: flex;
  align-items: center;
  gap: 4px;
}

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

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

._tab_1cq5e_1423 {
  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_1cq5e_1423:hover { color: var(--text-primary); }
._tab_1cq5e_1423::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_1cq5e_1456 {
  color: var(--text-primary) !important;
}
._tabActive_1cq5e_1456::after {
  opacity: 1 !important;
  transform: scaleX(1) !important;
}

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

._newVenueBtn_1cq5e_1472 {
  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_1cq5e_1472:hover { opacity: 0.85; }

._syncVenuesBtn_1cq5e_1483 {
  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_1cq5e_1483:hover:not(:disabled) { color: var(--text-primary); background: var(--overlay-md); }
._syncVenuesBtn_1cq5e_1483:disabled { opacity: 0.5; }

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

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

._venueEditImgRemove_1cq5e_1514 {
  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_1cq5e_1514:hover { background: rgba(255,68,68,0.12); color: #ff4444; }

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

._venueRow_1cq5e_1530 {
  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_1cq5e_1530:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._venueRowActive_1cq5e_1542 { background: var(--overlay-sm); border-color: var(--accent); }
._venueRowHidden_1cq5e_1543 { opacity: 0.45; }

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

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

._venueImgPlaceholder_1cq5e_1562 {
  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_1cq5e_1545:hover ._venueImgPlaceholder_1cq5e_1562 {
  border-color: rgba(255,255,255,0.35);
  color: var(--text-primary);
}

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

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

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

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

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

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

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

._venueShowBtn_1cq5e_1628 {
  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_1cq5e_1628:hover { background: rgba(52,199,89,0.18); }

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

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

._splashIcon_1cq5e_1658 {
  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_1cq5e_1670 {
  font-size: 24px;
  font-weight: 800;
  color: var(--text-primary);
  margin: 0;
}

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

._splashBtn_1cq5e_1683 {
  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_1cq5e_1683:hover { opacity: 0.85; }

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

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

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

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

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

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

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

._badgePending_1cq5e_1760 {
  background: rgba(255,255,255,0.08);
  color: var(--text-secondary);
}

._badgeApproved_1cq5e_1765 {
  background: rgba(34,197,94,0.15);
  color: #22c55e;
}

._badgeRejected_1cq5e_1770 {
  background: rgba(255,68,68,0.12);
  color: #ff4444;
}

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

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

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

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

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

._mergeVenueSelect_1cq5e_1816 {
  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_1cq5e_1829 {
  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_1cq5e_1829:hover:not(:disabled) { background: rgba(255,68,68,0.18); }
._mergeVenueBtn_1cq5e_1829:disabled { opacity: 0.4; }

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

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

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

._scraperToggleBtn_1cq5e_1870 {
  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_1cq5e_1870:hover { background: var(--overlay-md); color: var(--text-primary); }
._scraperToggleBtn_1cq5e_1870 svg { transition: transform 0.2s; }
._scraperToggleBtnOpen_1cq5e_1886 svg { transform: rotate(180deg); }

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

/* ── Collapsible flagged card ── */
._collapsibleCard_1cq5e_1893 {
  border: 1px solid rgba(239,83,80,0.25);
  border-radius: 14px;
  overflow: hidden;
  margin-bottom: 8px;
}
._collapsibleHeader_1cq5e_1899 {
  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_1cq5e_1899:hover { background: rgba(239,83,80,0.1); }
._collapsibleChevron_1cq5e_1913 { margin-left: auto; color: var(--text-secondary); transition: transform 0.2s; }
._collapsibleChevronOpen_1cq5e_1914 { transform: rotate(180deg); }
._collapsibleBody_1cq5e_1915 { padding: 12px 16px 16px; display: flex; flex-direction: column; gap: 10px; }
._flagBadge_1cq5e_1916 { background: #ef5350; color: #fff; border-radius: 10px; padding: 1px 7px; font-size: 11px; font-weight: 800; }

/* ── Scraping dashboard ── */
._scrapingGrid_1cq5e_1919 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
  padding: 24px;
}
._scrapingCard_1cq5e_1858 {
  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_1cq5e_1858:hover { border-color: var(--accent); background: var(--overlay-xs); }
._scrapingCardIcon_1cq5e_1939 { color: var(--accent); }
._scrapingCardTitle_1cq5e_1940 { font-size: 13px; font-weight: 700; color: var(--text-primary); line-height: 1.3; }
._scrapingCardDesc_1cq5e_1941 { font-size: 11px; color: var(--text-secondary); line-height: 1.5; text-align: center; }

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

._scrapingModalBox_1cq5e_1944 {
  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_1cq5e_1 0.2s ease both;
}
._scrapingModalBox_1cq5e_1944::-webkit-scrollbar { display: none; }
._scrapingModalHeader_1cq5e_1961 {
  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_1cq5e_1967 { font-size: 18px; font-weight: 800; color: var(--text-primary); margin: 0; }
._scrapingModalClose_1cq5e_1968 {
  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_1cq5e_1968:hover { background: rgba(255,255,255,0.14); }

/* ── Venue Modal ── */
._venueModalBox_1cq5e_1980 {
  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_1cq5e_1 0.2s ease both;
}
._venueModalBox_1cq5e_1980::-webkit-scrollbar { display: none; }
._venueModalHeader_1cq5e_1993 {
  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_1cq5e_1 {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ── Backups tab ── */
._backupsHeader_1cq5e_2006 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 24px 24px 0;
  gap: 12px;
}
._dbSizeHint_1cq5e_2013 { font-size: 12px; color: var(--text-secondary); }
._backupList_1cq5e_2014 { display: flex; flex-direction: column; gap: 4px; padding: 16px 24px 80px; }
._backupRow_1cq5e_2015 {
  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_1cq5e_2015:hover { background: var(--overlay-sm); border-color: var(--border-subtle); }
._backupName_1cq5e_2027 { flex: 1; font-size: 13px; font-weight: 600; color: var(--text-primary); min-width: 0; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
._backupMeta_1cq5e_2028 { font-size: 12px; color: var(--text-secondary); white-space: nowrap; }
._backupActions_1cq5e_2029 { display: flex; gap: 4px; flex-shrink: 0; }
._backupDownloadBtn_1cq5e_2030 { padding: 6px; border-radius: 8px; color: var(--accent); transition: background 0.15s; }
._backupDownloadBtn_1cq5e_2030:hover { background: var(--overlay-sm); }
._backupDeleteBtn_1cq5e_2032 { padding: 6px; border-radius: 8px; color: var(--text-secondary); transition: color 0.15s, background 0.15s; }
._backupDeleteBtn_1cq5e_2032:hover { color: #ff4444; background: rgba(255,68,68,0.1); }
._backupHint_1cq5e_2034 { font-size: 12px; color: var(--text-secondary); padding: 0 24px 12px; opacity: 0.6; margin-top: 16px; }

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

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

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

  /* Fix 4: Tab nav horizontal scroll */
  ._tabNav_1cq5e_1423 {
    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_1cq5e_1423::-webkit-scrollbar { display: none; }
  ._tab_1cq5e_1423 {
    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_1cq5e_100,
[data-theme="light"] ._field_1cq5e_205 input,
[data-theme="light"] ._field_1cq5e_205 textarea,
[data-theme="light"] ._field_1cq5e_205 select,
[data-theme="light"] ._extraSupportBlock_1cq5e_222 input,
[data-theme="light"] ._extraSupportBlock_1cq5e_222 textarea,
[data-theme="light"] ._imageUrlInput_1cq5e_255,
[data-theme="light"] ._editSelect_1cq5e_1319,
[data-theme="light"] ._syncVenueSelect_1cq5e_1000,
[data-theme="light"] ._venueFilterSelect_1cq5e_623,
[data-theme="light"] ._reviewBtn_1cq5e_784 {
  border-color: rgba(0, 0, 0, 0.15);
}
[data-theme="light"] ._backBtn_1cq5e_100:hover,
[data-theme="light"] ._field_1cq5e_205 input:focus,
[data-theme="light"] ._field_1cq5e_205 textarea:focus,
[data-theme="light"] ._extraSupportBlock_1cq5e_222 input:focus,
[data-theme="light"] ._extraSupportBlock_1cq5e_222 textarea:focus,
[data-theme="light"] ._imageUrlInput_1cq5e_255:focus,
[data-theme="light"] ._editSelect_1cq5e_1319:focus,
[data-theme="light"] ._syncVenueSelect_1cq5e_1000:hover,
[data-theme="light"] ._syncVenueSelect_1cq5e_1000:focus,
[data-theme="light"] ._venueFilterSelect_1cq5e_623:hover,
[data-theme="light"] ._venueFilterSelect_1cq5e_623: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;
  }
}
._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_q2abe_3, ._sheet_q2abe_3 { display: none !important; }
}

/* ── Scrim ──────────────────────────────────────────────── */
._scrim_q2abe_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_q2abe_1 0.22s ease both;
}
._scrimClosing_q2abe_16 {
  animation: _fadeOut_q2abe_1 0.22s ease forwards;
}

/* ── Sheet (content-based height) ───────────────────────── */
._sheet_q2abe_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_q2abe_1 0.32s cubic-bezier(0.32, 0.72, 0, 1) both;
}
._sheetClosing_q2abe_41 {
  animation: _slideDown_q2abe_1 0.26s cubic-bezier(0.32, 0.72, 0, 1) forwards;
}

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

[data-theme="light"] ._sheet_q2abe_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_q2abe_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_q2abe_58:active { cursor: grabbing; }
._handle_q2abe_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_q2abe_58 {
  background: rgba(0, 0, 0, 0.18);
}

/* ── Profile Header (main screen) ──────────────────────── */
._profile_q2abe_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_q2abe_81 {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

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

._profileMain_q2abe_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_q2abe_124,
._avatarFallback_q2abe_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_q2abe_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_q2abe_124,
[data-theme="light"] ._avatarFallback_q2abe_125 {
  border-color: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._avatarFallback_q2abe_125 {
  background: radial-gradient(circle at 35% 30%, #d8d8dc, #b6b6bc);
}

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

._gear_q2abe_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_q2abe_174:hover {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.18);
}
[data-theme="light"] ._gear_q2abe_174 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.1);
  color: #6c6c70;
}

/* ── Sub-Screen Header (search / filter) ───────────────── */
._subHeader_q2abe_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_q2abe_202 {
  border-bottom-color: rgba(0, 0, 0, 0.08);
}

._subHeaderBack_q2abe_214,
._subHeaderClose_q2abe_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_q2abe_214:hover,
._subHeaderClose_q2abe_215:hover {
  background: rgba(255, 255, 255, 0.14);
}
[data-theme="light"] ._subHeaderBack_q2abe_214,
[data-theme="light"] ._subHeaderClose_q2abe_215 {
  background: rgba(0, 0, 0, 0.05);
}

._subHeaderTitle_q2abe_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_q2abe_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_q2abe_269 {
  display: flex;
  align-items: center;
  gap: 8px;
}

._resetLink_q2abe_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_q2abe_288 {
  flex: 1 1 auto;
  min-height: 0;
  overflow-y: auto;
  overflow-x: hidden;
  scrollbar-width: none;
  -webkit-overflow-scrolling: touch;
  position: relative;
}
._screens_q2abe_288::-webkit-scrollbar { display: none; }

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

._screenEnterRight_q2abe_306 {
  animation: _slideInRight_q2abe_1 0.3s cubic-bezier(0.32, 0.72, 0, 1) both;
}
._screenEnterLeft_q2abe_309 {
  animation: _slideInLeft_q2abe_1 0.3s cubic-bezier(0.32, 0.72, 0, 1) both;
}

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

._row_q2abe_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_q2abe_321:active { transform: scale(0.98); }
._row_q2abe_321:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}
[data-theme="light"] ._row_q2abe_321 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}
[data-theme="light"] ._row_q2abe_321:hover {
  background: rgba(0, 0, 0, 0.05);
}

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

._rowPrimary_q2abe_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_q2abe_355:hover {
  background: linear-gradient(180deg, var(--accent), color-mix(in srgb, var(--accent) 75%, #000));
}

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

._logoutSection_q2abe_384,
._loginSection_q2abe_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_q2abe_366 {
  /* same default look as a .row, but explicit hook for future styling */
}

._icon_q2abe_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_q2abe_395 {
  background: rgba(0, 0, 0, 0.05);
}
._iconPrimary_q2abe_409 {
  background: rgba(255, 255, 255, 0.18) !important;
  color: var(--btn-fg);
}

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

._badge_q2abe_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_q2abe_452 {
  display: flex;
  align-items: center;
  color: #6a6a6e;
  flex-shrink: 0;
}

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

._searchInputWrap_q2abe_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_q2abe_467 {
  background: rgba(0, 0, 0, 0.04);
  border-color: rgba(0, 0, 0, 0.12);
}
._searchInputWrap_q2abe_467:focus-within {
  border-color: var(--accent);
}

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

._searchInput_q2abe_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_q2abe_467::placeholder { color: var(--text-secondary); }

._searchClear_q2abe_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_q2abe_502:hover { background: rgba(255, 255, 255, 0.16); }

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

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

._searchResult_q2abe_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_q2abe_526:hover {
  background: rgba(255, 255, 255, 0.07);
}
[data-theme="light"] ._searchResult_q2abe_526 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}

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

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

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

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

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

._filterRow_q2abe_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_q2abe_616:active { transform: scale(0.98); }
._filterRowActive_q2abe_633 {
  background: color-mix(in srgb, var(--accent) 12%, transparent);
  border-color: color-mix(in srgb, var(--accent) 40%, transparent);
}
[data-theme="light"] ._filterRow_q2abe_616 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}

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

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

._filterBox_q2abe_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_q2abe_669 {
  background: var(--accent);
  border-color: var(--accent);
}
[data-theme="light"] ._filterBox_q2abe_656 {
  border-color: rgba(0, 0, 0, 0.2);
}

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

._filterApply_q2abe_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_q2abe_684:hover { opacity: 0.92; }

/* ── Generic List Sub-Screens (Calendar, Concerts-Mgmt, Users-Mgmt) ── */
._listBody_q2abe_702 {
  padding: 14px 22px calc(26px + env(safe-area-inset-bottom, 0px));
  display: flex;
  flex-direction: column;
  gap: 12px;
}
._listHint_q2abe_708 {
  font-size: 13px;
  color: var(--text-secondary);
  margin: 4px 0 0;
  line-height: 1.4;
}
._list_q2abe_702 {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
._listItem_q2abe_722 {
  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_q2abe_722:hover { background: rgba(255, 255, 255, 0.07); }
[data-theme="light"] ._listItem_q2abe_722 {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.06);
}
._listThumb_q2abe_743,
._listThumbFallback_q2abe_744 {
  width: 44px;
  height: 44px;
  border-radius: 10px;
  flex-shrink: 0;
  object-fit: cover;
}
._listThumbFallback_q2abe_744 {
  background: linear-gradient(135deg, rgba(255,255,255,0.08), rgba(255,255,255,0.02));
}
._listText_q2abe_754 {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
._listArtist_q2abe_761 {
  font-size: 15px;
  font-weight: 700;
  color: var(--text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._listMeta_q2abe_769 {
  font-size: 12px;
  color: var(--text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
._listBadge_q2abe_776 {
  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_q2abe_788 {
  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_q2abe_788:hover { opacity: 0.92; }

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

/* ── Animations ────────────────────────────────────────── */
@keyframes _slideUp_q2abe_1 {
  from { transform: translateY(100%); }
  to { transform: translateY(0); }
}
@keyframes _slideDown_q2abe_1 {
  from { transform: translateY(0); }
  to { transform: translateY(100%); }
}
@keyframes _fadeIn_q2abe_1 {
  from { opacity: 0; }
  to { opacity: 1; }
}
@keyframes _fadeOut_q2abe_1 {
  from { opacity: 1; }
  to { opacity: 0; }
}
@keyframes _slideInRight_q2abe_1 {
  from { transform: translateX(40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
@keyframes _slideInLeft_q2abe_1 {
  from { transform: translateX(-40px); opacity: 0; }
  to { transform: translateX(0); opacity: 1; }
}
._header_1kl8n_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_1kl8n_1 {
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
  }
}

._headerScrolled_1kl8n_45 {}
._header_1kl8n_1::after { display: none; }

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

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

@media (max-width: 639px) {
  ._stickyMonthLabel_1kl8n_59 {
    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_1kl8n_75 {
    opacity: 1;
    pointer-events: auto;
    transform: translateX(-50%) translateY(0);
    filter: blur(0);
  }

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

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

/* Desktop: floating pill at the BOTTOM of the viewport (experiment). 42% wide, centred. */
@media (min-width: 1280px) {
  ._header_1kl8n_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_1kl8n_127 {
    left: calc((100vw - var(--panel-w, 420px)) / 2);
  }
}

/* Light theme: frosted glass with dark text — applies on all viewports */
[data-theme="light"] ._header_1kl8n_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_1kl8n_49 {
    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_1kl8n_49 {
    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_1kl8n_49 {
    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_1kl8n_188 {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-left: 4px;
}

._pageTitleText_1kl8n_195 {
  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_1kl8n_195 {
    font-size: 34px;
    font-weight: 900;
    letter-spacing: -0.4px;
    max-width: none;
  }
}

._pageTitleCount_1kl8n_215 {
  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_1kl8n_225 {
  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_1kl8n_225 {
    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_1kl8n_225 {
    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_1kl8n_225 { display: none; }
  ._locationWrap_1kl8n_256 { display: none; }
}

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

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

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

/* Desktop: full width in flex-column container */
@media (min-width: 1280px) {
  ._calendarCenter_1kl8n_260 {
    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_1kl8n_302 {
  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_1kl8n_302 {
    grid-template-columns: auto repeat(7, 1fr) auto !important;
  }
}

/* ── Mobile + tablet logo (<1024px, sidebar not visible) ────*/
._mobileLogo_1kl8n_318 {
  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_1kl8n_318 {
    flex: 0 0 auto;
    order: 1;
  }
}

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

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

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

/* ── Expandable search (mobile + tablet portrait) ────*/
._ctaBtn_1kl8n_354 {
  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_1kl8n_354:hover { background: var(--accent); color: var(--btn-fg); }
@media (max-width: 1279px) { ._ctaBtn_1kl8n_354 { display: flex; } }
._ctaBtnDashboard_1kl8n_369 { margin-left: auto; }

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

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

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

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

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


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

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

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

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

/* ── Shared pill style ──────────────────────────────────────*/
._pill_1kl8n_49 {
  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_1kl8n_49 svg:first-child { display: none; }
}

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

._pill_1kl8n_49:hover   { background: var(--overlay-md); border-color: var(--border-dim); }
._pillOpen_1kl8n_463     { border-color: var(--accent); background: var(--accent-dim); }
._pillActive_1kl8n_464   {
  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_1kl8n_471,
._pillGhost_1kl8n_471:hover {
  background: transparent;
  border-color: transparent;
}
._pillGhost_1kl8n_471:hover { color: var(--accent); }

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

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

/* ── Dropdown ───────────────────────────────────────────────*/
._dropdown_1kl8n_397 {
  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_1kl8n_397 { left: auto; right: 0; }
}

._dropdownItem_1kl8n_405 {
  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_1kl8n_405:hover          { background: var(--overlay-hover); color: var(--text-primary); }
._dropdownItemActive_1kl8n_530          { color: var(--accent); }
._dropdownItemActive_1kl8n_530:hover    { background: var(--accent-dim); }

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

._dropdownHint_1kl8n_535 {
  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_1kl8n_274 {
  position: relative;
  flex-shrink: 0;
}

/* Mobile: pin avatar to right edge so it never shifts when search expands */
@media (max-width: 639px) {
  ._mobileAvatar_1kl8n_274 {
    position: absolute;
    right: 14px;
  }
  ._pillRow_1kl8n_49 {
    padding-right: calc(14px + 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_1kl8n_274 {
    margin-left: auto;
  }
}

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

._mobileAvatarBtn_1kl8n_575 {
  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_1kl8n_575:hover    { background: var(--overlay-md); border-color: var(--border-dim); }
._mobileAvatarBtnOpen_1kl8n_591      { background: var(--overlay-md); border-color: var(--accent); }

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

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

._mobileAvatarDropdown_1kl8n_608 {
  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_1kl8n_1 0.15s ease both;
}

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

._mobileAvatarItem_1kl8n_627 {
  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_1kl8n_627:hover        { background: var(--overlay-hover); color: var(--text-primary); }
._mobileAvatarItemActive_1kl8n_642        { color: var(--accent); }
._mobileAvatarItemActive_1kl8n_642:hover  { background: var(--accent-dim); }
._mobileAvatarItemLogout_1kl8n_644        { color: #ff5f57; }
._mobileAvatarItemLogout_1kl8n_644:hover  { background: rgba(255, 95, 87, 0.1); color: #ff5f57; }

._mobileAvatarBadge_1kl8n_647 {
  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_1kl8n_662 {
  height: 1px;
  background: var(--border-subtle);
  margin: 4px 6px;
}

/* ── Search bar ─────────────────────────────────────────────*/
._searchWrap_1kl8n_669 {
  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_1kl8n_669:focus-within { border-color: var(--accent); background: rgba(142,187,255,0.06); }

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

._searchInput_1kl8n_687 {
  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_1kl8n_687::placeholder { color: var(--text-secondary); }

._searchClear_1kl8n_702 {
  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_1kl8n_702:hover { background: rgba(255,255,255,0.12); color: var(--text-primary); }

._artistsLoginBtn_1kl8n_721 {
  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_1kl8n_721:hover { opacity: 0.88; }
._popup_11m1k_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_11m1k_14 {
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--text-muted);
  padding: 8px 12px 6px;
}

._row_11m1k_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_11m1k_23:hover { background: var(--overlay-hover); }

/* iOS-style toggle switch */
._switch_11m1k_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_11m1k_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_11m1k_44._switchOn_11m1k_65 {
  background: #8EBBFF;
}
._switchOn_11m1k_65 ._switchKnob_11m1k_53 {
  transform: translateX(14px);
}

[data-theme="light"] ._switch_11m1k_44 {
  background: rgba(0, 0, 0, 0.12);
}
[data-theme="light"] ._switch_11m1k_44._switchOn_11m1k_65 {
  background: #8EBBFF;
}
/* ── Top bar (desktop 1280px+) ───────────────────────────── */
._sidebar_1rdts_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_1rdts_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_1rdts_25 img { filter: brightness(0); }

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

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

._avatarBtn_1rdts_53 {
  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_1rdts_53:hover {
  background: rgba(255, 255, 255, 0.06);
  border-color: rgba(255, 255, 255, 0.1);
}
._avatarBtnOpen_1rdts_68 {
  background: rgba(255, 255, 255, 0.08);
  border-color: rgba(255, 255, 255, 0.14);
}

._avatar_1rdts_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_1rdts_88 {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  object-fit: cover;
  display: block;
  flex-shrink: 0;
}

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

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

/* ── Dropdown panel ──────────────────────────────────────── */
._dropdown_1rdts_114 {
  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_1rdts_1 0.15s ease;
}

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

._dropdownItem_1rdts_133 {
  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_1rdts_133:hover {
  background: var(--overlay-hover);
  color: var(--text-primary);
}
._dropdownItemActive_1rdts_150 {
  color: var(--accent);
}
._dropdownItemActive_1rdts_150:hover {
  color: var(--accent);
}

._dropdownItemAccent_1rdts_157 {
  background: var(--accent);
  color: var(--btn-fg);
}
._dropdownItemAccent_1rdts_157: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_1rdts_157 {
  background: #000;
  color: #8EBBFF;
}
[data-theme="light"] ._dropdownItemAccent_1rdts_157:hover {
  background: #000;
  color: #8EBBFF;
  opacity: 0.9;
}

._ctaBtn_1rdts_179 {
  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_1rdts_179:hover { background: var(--accent); color: var(--btn-fg); }

._dropdownBadge_1rdts_194 {
  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_1rdts_209 {
  height: 1px;
  background: var(--overlay-hover);
  margin: 4px 6px;
}

/* ── Right group: controls + avatar ──────────────────────── */
._rightGroup_1rdts_216 {
  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_1rdts_226 {
  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_1rdts_234 {
  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_1rdts_234:hover { opacity: 0.92; }
._createCta_1rdts_234:active { transform: scale(0.98); }

/* ── Filter count badge (blue circle inside Filter pill) ── */
._filterCountBadge_1rdts_262 {
  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_1rdts_278 {
  display: flex;
  align-items: center;
  gap: 16px;
  padding-right: 10px;
  margin-right: 6px;
}

._filterChip_1rdts_278 {
  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_1rdts_278:hover { color: var(--text-primary); }

._filterChipBox_1rdts_306 {
  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_1rdts_278:hover ._filterChipBox_1rdts_306 { border-color: var(--text-primary); }

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

._navPillWrap_1rdts_331 {
  position: relative;
}

._navPill_1rdts_331 {
  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_1rdts_331:hover        { background: var(--overlay-md); border-color: var(--border-dim); }
._navPillOpen_1rdts_355          { border-color: var(--accent); background: var(--accent-dim); }
._navPillActive_1rdts_356        { background: var(--accent) !important; border-color: var(--accent) !important; color: var(--btn-fg) !important; }

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

._navArrow_1rdts_366 {
  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_1rdts_366:hover { color: var(--text-primary); background: rgba(255,255,255,0.07); }

._navMonthLabel_1rdts_383 {
  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_1rdts_395 {
  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_1rdts_395: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_1rdts_415 {
  flex-shrink: 0;
  color: var(--text-secondary);
}
._searchCenterInput_1rdts_419 {
  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_1rdts_419::placeholder { color: var(--text-secondary); }
._searchCenterInput_1rdts_419::-webkit-search-cancel-button { display: none; }

._searchCenterClear_1rdts_434 {
  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_1rdts_434:hover {
  background: rgba(255, 255, 255, 0.14);
  color: var(--text-primary);
}

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

._navDropdown_1rdts_469 {
  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_1rdts_469::-webkit-scrollbar { display: none; }

._navDropdownItem_1rdts_485 {
  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_1rdts_485:hover         { background: rgba(255,255,255,0.07); color: var(--text-primary); }
._navDropdownItemActive_1rdts_499         { color: var(--accent); }
._navDropdownItemActive_1rdts_499:hover   { background: var(--accent-dim); }

._navDropdownHint_1rdts_502 {
  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_1rdts_513    { display: none; }
._footerText_1rdts_514 { display: none; }

/* ── Artists+Venues page login CTA ──────────────────────── */
._artistsLoginBtn_1rdts_517 {
  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_1rdts_517:hover { opacity: 0.88; }

._roleLabel_1rdts_529 {
  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_1rdts_529: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; }
/* ── Mobile-only calendar block ────────────────────────── */
._mobileCalendar_dfc59_2 {
  display: block;
  position: sticky;
  top: calc(2px + env(safe-area-inset-top));
  z-index: 30;
}
@media (min-width: 640px) { ._mobileCalendar_dfc59_2 { display: none; } }

._calendarCard_dfc59_10 {
  margin: 10px var(--space-4) 0;
  background: rgba(0, 0, 0, 0.55);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: none;
  border-radius: 22px;
  overflow: hidden;
  padding: 10px;
}

[data-theme="light"] ._calendarCard_dfc59_10 {
  background: rgba(255, 255, 255, 0.75);
  border: 1px solid rgba(0, 0, 0, 0.08);
}

/* ── Month nav ──────────────────────────────────────────── */
._monthNav_dfc59_27 {
  display: flex;
  align-items: center;
  padding: 0 0 4px;
}


/* Pill wrapper around arrows + label */
._monthNavPill_dfc59_35 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
  padding: 4px 6px;
  background: transparent;
  border: none;
}

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

._monthNavArrow_dfc59_56 {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  min-width: 44px;
  min-height: unset;
  border-radius: 50%;
  background: transparent;
  border: none;
  color: var(--text-secondary);
  padding: 0;
  transition: color 0.15s, background 0.15s;
  flex-shrink: 0;
}
._monthNavArrow_dfc59_56:hover { color: var(--text-primary); background: rgba(255,255,255,0.12); }
[data-theme="light"] ._monthNavArrow_dfc59_56:hover { background: rgba(0, 0, 0, 0.06); }


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

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

._heuteMobileBtn_dfc59_85 {
  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_dfc59_85:hover { border-color: rgba(255,255,255,0.35); color: var(--text-primary); }
[data-theme="light"] ._heuteMobileBtn_dfc59_85 { border-color: rgba(0, 0, 0, 0.15); }
[data-theme="light"] ._heuteMobileBtn_dfc59_85:hover { border-color: rgba(0, 0, 0, 0.35); }

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


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

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

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

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

._showAllBtn_dfc59_132 {
  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_dfc59_132:hover  { border-color: rgba(255,255,255,0.7); background: rgba(255,255,255,0.06); transform: translateY(-1px); }
._showAllBtn_dfc59_132:active { transform: translateY(0); }

/* ── Card swipe animations (Tinder-style) ───────────────── */
@keyframes _slideFromRight_dfc59_165 {
  from { transform: translateX(72px) scale(0.96); opacity: 0; }
  to   { transform: translateX(0)    scale(1);    opacity: 1; }
}
@keyframes _slideFromLeft_dfc59_166 {
  from { transform: translateX(-72px) scale(0.96); opacity: 0; }
  to   { transform: translateX(0)     scale(1);    opacity: 1; }
}
@keyframes _exitToLeft_dfc59_167 {
  from { transform: translateX(0)     scale(1);    opacity: 1; }
  to   { transform: translateX(-72px) scale(0.96); opacity: 0; }
}
@keyframes _exitToRight_dfc59_168 {
  from { transform: translateX(0)    scale(1);    opacity: 1; }
  to   { transform: translateX(72px) scale(0.96); opacity: 0; }
}

._slideFromRight_dfc59_165 { animation: _slideFromRight_dfc59_165 0.24s cubic-bezier(0.25, 0.46, 0.45, 0.94) both; }
._slideFromLeft_dfc59_166  { animation: _slideFromLeft_dfc59_166  0.24s cubic-bezier(0.25, 0.46, 0.45, 0.94) both; }
._exitToLeft_dfc59_167     { animation: _exitToLeft_dfc59_167     0.2s  cubic-bezier(0.55, 0,    0.1,  1)    both; }
._exitToRight_dfc59_168    { animation: _exitToRight_dfc59_168    0.2s  cubic-bezier(0.55, 0,    0.1,  1)    both; }

/* Loading skeleton */
._skeleton_dfc59_171 {
  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_dfc59_1 1.4s infinite;
  aspect-ratio: 3 / 2;
  min-height: 200px;
}

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

/* ── Premium FAB (Neues Konzi) — same style as Search FAB, blue border ── */
._fab_dfc59_191 {
  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_dfc59_191:hover {
  transform: translateY(-2px) scale(1.04) translateZ(0);
  box-shadow: 0 0 22px 3px rgba(0, 0, 0, 0.65);
}
._fab_dfc59_191:active { transform: scale(0.98) translateZ(0); }

/* Light theme: clean white pill with accent-colored border + icon */
[data-theme="light"] ._fab_dfc59_191 {
  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_dfc59_191: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_dfc59_191 {
    bottom: calc(16px + env(safe-area-inset-bottom, 0px));
  }
  ._fabPanelOpen_dfc59_235 { display: none; }
}

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

/* ── Past-day banner (subtle pill above cards, aligned to calendar card) ──── */
._pastBanner_dfc59_245 {
  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_dfc59_245 { 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_dfc59_245 {
    margin: var(--space-5) 12.5vw;
  }
}
._pastBannerText_dfc59_267 { display: flex; flex-direction: column; gap: 2px; }
._pastBannerText_dfc59_267 strong { font-size: 14px; font-weight: 800; color: var(--text-primary); }
._pastBannerText_dfc59_267 span { font-size: 13px; color: var(--text-secondary); }
._pastBannerBtn_dfc59_270 {
  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_dfc59_270:hover { opacity: 0.88; }
._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));
  }
}
