@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,500;1,300;1,400&display=swap');

:root {
  --ivory:      #F5F2EC;
  --paper:      #FDFCF8;
  --surface-light: #EAE6DF; /* Light taupe for sidebar and buttons */
  --ink:        #4A4641;    /* Soft medium-dark gray */
  --ink-mid:    #6B6560;
  --ink-soft:   #8C8680;
  --ink-faint:  #CCC7BC;
  --border:     rgba(74, 70, 65, 0.12);
  --border-mid: rgba(74, 70, 65, 0.32);
  --shadow:     0 1px 20px rgba(74, 70, 65, 0.06);
  --radius:     0px;
  color-scheme: light;

  /* Legacy-Aliases damit bestehende Referenzen greifen */
  --cream:      var(--ivory);
  --gold:       var(--ink-mid);
  --gold-dark:  var(--ink);
  --text:       var(--ink);
  --text-light: var(--ink-mid);
  --white:      var(--paper);
}

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

body {
  font-family: 'Cormorant Garamond', Georgia, serif;
  background: var(--ivory);
  color: var(--ink);
  min-height: 100vh;
  font-size: 17px;
  font-weight: 300;
  line-height: 1.65;
}

/* ── Header ─────────────────────────────────────────────────────────────── */
.site-header {
  text-align: center;
  padding: 3.5rem 1rem 2.5rem;
  background: var(--paper);
  border-bottom: 1px solid var(--border);
}

.site-header h1 {
  font-size: clamp(2rem, 6vw, 3.2rem);
  color: var(--ink);
  font-weight: 300;
  letter-spacing: 0.16em;
  text-transform: uppercase;
}

.site-header .subtitle {
  color: var(--ink-soft);
  font-style: italic;
  margin-top: 0.5rem;
  font-size: 1.05rem;
  letter-spacing: 0.03em;
}

.ornament { display: none; }

/* ── Navigation ──────────────────────────────────────────────────────────── */
.site-nav {
  display: flex;
  justify-content: center;
  gap: 0;
  margin-top: 1.75rem;
}

.site-nav-link {
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 0.82rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  padding: 0.25rem 1.5rem;
  position: relative;
  transition: color 0.2s;
}

.site-nav-link + .site-nav-link::before {
  content: '·';
  position: absolute;
  left: -0.05rem;
  top: 50%;
  transform: translateY(-50%);
  color: var(--ink-faint);
  pointer-events: none;
}

.site-nav-link:hover  { color: var(--ink); }
.site-nav-link.active { color: var(--ink); }

/* ── Container ───────────────────────────────────────────────────────────── */
.container {
  max-width: 900px;
  margin: 0 auto;
  padding: 3rem 1.5rem;
}

/* ── Upload-Bereich ──────────────────────────────────────────────────────── */
.upload-area {
  background: var(--paper);
  border: 1px dashed var(--ink-faint);
  padding: 4.5rem 2rem;
  text-align: center;
  cursor: pointer;
  transition: border-color 0.2s;
}

.upload-area:hover,
.upload-area.drag-over {
  border-color: var(--ink-mid);
}

.upload-area .icon {
  margin-bottom: 1.5rem;
  opacity: 0.5;
  color: var(--ink);
}

.upload-area h2 {
  font-size: 1rem;
  font-weight: 400;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  margin-bottom: 0.75rem;
}

.upload-area p { color: var(--ink-soft); font-size: 0.95rem; }

/* ── Buttons ─────────────────────────────────────────────────────────────── */
.btn {
  display: inline-block;
  padding: 0.7rem 2.25rem;
  border: 1px solid var(--ink);
  cursor: pointer;
  font-size: 0.72rem;
  font-family: inherit;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  transition: all 0.2s;
  text-decoration: none;
  font-weight: 400;
  border-radius: 0;
}

.btn-primary {
  background: var(--surface-light);
  color: var(--ink);
  border-color: var(--border-mid);
}
.btn-primary:hover {
  background: var(--paper);
  color: var(--ink);
}

.btn-outline {
  background: transparent;
  color: var(--ink);
}
.btn-outline:hover {
  background: var(--ink);
  color: var(--paper);
}

.btn-sm     { padding: 0.35rem 1.1rem; font-size: 0.68rem; }
.btn-danger { background: transparent; color: #b03030; border-color: #b03030; }
.btn-danger:hover { background: #b03030; color: white; }

/* ── Fortschrittsbalken ──────────────────────────────────────────────────── */
.progress-bar-wrap {
  background: var(--ink-faint);
  height: 1px;
  margin-top: 1.75rem;
  overflow: hidden;
  display: none;
  border-radius: 0;
}
.progress-bar {
  height: 100%;
  background: var(--ink);
  transition: width 0.3s;
  width: 0%;
}

/* ── Aufgaben ────────────────────────────────────────────────────────────── */
.tasks-box {
  background: var(--paper);
  border: 1px solid var(--border);
  padding: 1.75rem;
  margin-bottom: 2rem;
  box-shadow: var(--shadow);
}
.tasks-box h3 {
  color: var(--ink);
  margin-bottom: 1rem;
  font-size: 0.72rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 400;
}
.task-list { list-style: none; }
.task-list li {
  padding: 0.6rem 0;
  border-bottom: 1px solid var(--border);
  color: var(--ink-mid);
  font-size: 0.95rem;
}
.task-list li:last-child { border-bottom: none; }
.task-list li::before { content: '— '; color: var(--ink-faint); }

/* ── Galerie ─────────────────────────────────────────────────────────────── */
.gallery-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 6px;
  margin-top: 1.5rem;
}

.gallery-item {
  position: relative;
  aspect-ratio: 1;
  overflow: hidden;
  background: var(--ink-faint);
  cursor: pointer;
}

.gallery-item img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.4s ease;
}
.gallery-item:hover img { transform: scale(1.04); }

.gallery-item .badge {
  position: absolute;
  bottom: 6px;
  right: 6px;
  background: rgba(28,25,20,0.55);
  color: white;
  font-size: 0.65rem;
  letter-spacing: 0.04em;
  padding: 2px 6px;
}

/* ── Lightbox ────────────────────────────────────────────────────────────── */
.lightbox {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(238, 235, 229, 0.98);
  z-index: 1000;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
.lightbox.open { display: flex; }

.lightbox-close {
  position: absolute;
  top: 1.25rem;
  right: 1.75rem;
  color: rgba(28,25,20,0.35);
  font-size: 1.25rem;
  cursor: pointer;
  background: none;
  border: none;
  letter-spacing: 0.05em;
  transition: color 0.2s;
}
.lightbox-close:hover { color: var(--ink); }

.lightbox-download {
  margin-top: 0.75rem;
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
}
.lightbox-download:hover { color: var(--ink); }

.lightbox-prev,
.lightbox-next {
  position: absolute;
  top: calc(1.75rem + 28vh);
  transform: translateY(-50%);
  background: transparent;
  border: 1px solid rgba(28,25,20,0.18);
  color: rgba(28,25,20,0.45);
  font-size: 1.6rem;
  line-height: 1;
  padding: 0.4rem 0.85rem;
  cursor: pointer;
  transition: all 0.2s;
  user-select: none;
  border-radius: 0;
}
.lightbox-prev { left: 1rem; }
.lightbox-next { right: 1rem; }
.lightbox-prev:hover,
.lightbox-next:hover { border-color: rgba(28,25,20,0.5); color: var(--ink); }
.lightbox-prev:disabled,
.lightbox-next:disabled { opacity: 0.12; cursor: default; }

/* ── Diashow ─────────────────────────────────────────────────────────────── */
.slideshow-container {
  position: fixed;
  inset: 0;
  background: #0E0D0B;
  display: flex;
  align-items: center;
  justify-content: center;
}
.slideshow-img {
  max-width: 100vw;
  max-height: 100vh;
  object-fit: contain;
  opacity: 0;
  transition: opacity 0.9s ease;
}
.slideshow-img.visible { opacity: 1; }

.slideshow-time {
  position: absolute;
  bottom: 2rem;
  right: 2rem;
  color: rgba(253,252,248,0.22);
  font-size: 0.72rem;
  letter-spacing: 0.08em;
}
.slideshow-waiting {
  color: rgba(253,252,248,0.2);
  font-size: 1rem;
  font-style: italic;
  letter-spacing: 0.06em;
}

/* ── Toast ───────────────────────────────────────────────────────────────── */
.toast {
  position: fixed;
  bottom: 2rem;
  left: 50%;
  transform: translateX(-50%);
  background: var(--surface-light);
  color: var(--ink);
  border: 1px solid var(--border-mid);
  padding: 0.7rem 1.75rem;
  font-size: 0.78rem;
  letter-spacing: 0.08em;
  z-index: 2000;
  opacity: 0;
  transition: opacity 0.3s;
  pointer-events: none;
  border-radius: 0;
}
.toast.show { opacity: 1; }
.toast.error { background: #fdf0f0; border-color: #c0a0a0; color: #8b2020; }

/* ── Admin Layout ────────────────────────────────────────────────────────── */
.admin-layout { display: flex; min-height: 100vh; }

.sidebar {
  width: 220px;
  background: var(--surface-light);
  color: var(--ink);
  padding: 2.5rem 1.5rem;
  flex-shrink: 0;
  border-right: 1px solid var(--border);
}
.sidebar h2 {
  font-size: 0.65rem;
  color: var(--ink-soft);
  margin-bottom: 2rem;
  text-align: center;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-weight: 400;
}
.sidebar nav a {
  display: block;
  color: var(--ink-mid);
  text-decoration: none;
  padding: 0.55rem 0;
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  transition: color 0.2s;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  margin-bottom: 0;
}
.sidebar nav a:hover,
.sidebar nav a.active {
  background: none;
  color: var(--ink);
}

.admin-main { flex: 1; padding: 2.5rem; background: var(--ivory); overflow-y: auto; }
.admin-main h1 {
  font-size: 1.5rem;
  font-weight: 300;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-bottom: 2rem;
  color: var(--ink);
}

/* ── Stat-Karten ─────────────────────────────────────────────────────────── */
.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 1rem;
  margin-bottom: 2rem;
}
.stat-card {
  background: var(--paper);
  border: 1px solid var(--border);
  padding: 1.5rem;
  text-align: center;
  box-shadow: var(--shadow);
}
.stat-card .number {
  font-size: 2.5rem;
  font-weight: 300;
  color: var(--ink);
}
.stat-card .label {
  color: var(--ink-soft);
  font-size: 0.68rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  margin-top: 0.3rem;
}
.stat-card .sub {
  color: var(--ink-soft);
  font-size: 0.72rem;
  margin-top: 0.45rem;
  font-style: italic;
}

/* ── Admin-Tabelle ───────────────────────────────────────────────────────── */
.admin-table {
  width: 100%;
  border-collapse: collapse;
  background: var(--paper);
  box-shadow: var(--shadow);
  border: 1px solid var(--border);
}
.admin-table th {
  background: var(--ink);
  color: rgba(253,252,248,0.75);
  padding: 0.7rem 1rem;
  text-align: left;
  font-size: 0.65rem;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 400;
}
.admin-table td {
  padding: 0.75rem 1rem;
  border-bottom: 1px solid var(--border);
  font-size: 0.9rem;
  vertical-align: middle;
}
.admin-table tr:last-child td { border-bottom: none; }
.admin-table img { width: 48px; height: 48px; object-fit: cover; }

/* ── Formulare ───────────────────────────────────────────────────────────── */
.form-row { display: flex; gap: 0.75rem; margin-bottom: 1rem; align-items: flex-start; flex-wrap: wrap; }

.form-input {
  padding: 0.6rem 0.9rem;
  border: 1px solid var(--border-mid);
  font-family: inherit;
  font-size: 0.95rem;
  background: var(--paper);
  flex: 1;
  min-width: 160px;
  color: var(--ink);
  border-radius: 0;
}
.form-input:focus { outline: none; border-color: var(--ink); }

/* ── Login ───────────────────────────────────────────────────────────────── */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--ivory);
}
.login-box {
  background: var(--paper);
  padding: 4rem 3rem;
  border: 1px solid var(--border-mid);
  width: 100%;
  max-width: 360px;
  text-align: center;
}
.login-box h1 {
  font-size: 1.3rem;
  font-weight: 300;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  margin-bottom: 0.4rem;
}
.login-box > p {
  color: var(--ink-soft);
  margin-bottom: 2.5rem;
  font-size: 0.9rem;
  font-style: italic;
}
.login-box .form-input { width: 100%; margin-bottom: 1rem; }

/* ── Slideshow-Branding ──────────────────────────────────────────────────── */
.slideshow-branding {
  position: absolute;
  bottom: 2rem;
  left: 2rem;
  color: rgba(253,252,248,0.25);
  font-style: italic;
  font-size: 0.88rem;
  letter-spacing: 0.04em;
  pointer-events: none;
}

/* ── Tag-Chips ───────────────────────────────────────────────────────────── */
.tag-chip {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  background: transparent;
  color: var(--ink-mid);
  border: 1px solid var(--border-mid);
  padding: 0.2rem 0.65rem;
  font-size: 0.75rem;
  letter-spacing: 0.06em;
  font-family: inherit;
  white-space: nowrap;
  border-radius: 0;
}
.tag-chip--sm { font-size: 0.7rem; padding: 0.1rem 0.5rem; }
.tag-remove {
  background: none; border: none; cursor: pointer;
  color: var(--ink-soft); font-size: 0.72rem; padding: 0; line-height: 1;
}
.tag-remove:hover { color: #b03030; }

/* ── Kategorie-Chips ─────────────────────────────────────────────────────── */

/* ── Tag-Filter-Bar ──────────────────────────────────────────────────────── */
.tag-filter-bar { display: flex; flex-wrap: wrap; gap: 0.4rem; margin-bottom: 1.25rem; }
.tag-filter-chip {
  background: transparent;
  border: 1px solid var(--border-mid);
  color: var(--ink-mid);
  padding: 0.3rem 0.9rem;
  font-size: 0.68rem;
  letter-spacing: 0.1em;
  font-family: inherit;
  cursor: pointer;
  transition: all 0.2s;
  border-radius: 0;
}
.tag-filter-chip:hover  { background: rgba(28,25,20,0.05); }
.tag-filter-chip.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ── Lightbox erweitert ──────────────────────────────────────────────────── */
.lightbox-scroll {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 680px;
  height: 100%;
  overflow: hidden;
}
.lightbox-media-wrap {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1.75rem 1.5rem 0.5rem;
  width: 100%;
}
.lightbox-media-wrap img,
.lightbox-media-wrap video {
  max-width: 100%;
  max-height: 56vh;
  object-fit: contain;
}
@media (max-height: 600px) {
  .lightbox-media-wrap img,
  .lightbox-media-wrap video { max-height: 35vh; }
}
@media (min-height: 800px) {
  .lightbox-media-wrap img,
  .lightbox-media-wrap video { max-height: 63vh; }
}

.lightbox-panel {
  flex: 1;
  min-height: 0;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior: contain;
  width: 100%;
  padding: 0.5rem 1rem 1.5rem;
  border-top: 1px solid rgba(28,25,20,0.10);
}
.lb-section-label {
  display: block;
  font-size: 0.65rem;
  text-transform: uppercase;
  letter-spacing: 0.14em;
  color: var(--ink-soft);
  margin-bottom: 0.5rem;
}

.lightbox-tags-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
  margin-bottom: 0.75rem;
}
.lb-tags { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.lb-add-btn {
  background: rgba(28,25,20,0.05);
  border: 1px solid rgba(28,25,20,0.20);
  color: var(--ink-mid);
  width: 1.8rem; height: 1.8rem;
  font-size: 1.1rem; line-height: 1;
  cursor: pointer;
  transition: all 0.2s;
  border-radius: 0;
}
.lb-add-btn:hover { background: rgba(28,25,20,0.10); }
.lb-add-tag { width: 100%; margin-top: 0.4rem; }
.lb-tag-options { display: flex; flex-wrap: wrap; gap: 0.4rem; }
.tag-option-btn {
  background: rgba(28,25,20,0.04);
  border: 1px solid rgba(28,25,20,0.20);
  color: var(--ink-mid);
  padding: 0.2rem 0.7rem;
  font-size: 0.75rem;
  font-family: inherit;
  cursor: pointer;
  transition: background 0.2s;
  border-radius: 0;
}
.tag-option-btn:hover { background: rgba(28,25,20,0.09); }

/* Kommentar-Sektion */
.lightbox-comments { width: 100%; }
.comment-list { margin-bottom: 0.5rem; }
.comment-wrap { margin-bottom: 0.4rem; }

.comment-bubble {
  background: rgba(28,25,20,0.04);
  padding: 0.4rem 0.7rem;
  max-width: 100%;
  border-radius: 0;
}
.comment-deleted     { background: rgba(28,25,20,0.02); }
.comment-deleted-text { color: var(--ink-soft); font-style: italic; font-size: 0.85rem; }

.comment-author {
  display: block;
  font-size: 0.68rem;
  color: var(--ink-soft);
  margin-bottom: 0.2rem;
  font-weight: 400;
  letter-spacing: 0.1em;
  text-transform: uppercase;
}
.comment-text  { color: var(--ink); font-size: 0.85rem; line-height: 1.5; word-break: break-word; }
.comment-meta  { display: flex; gap: 0.75rem; align-items: center; margin-top: 0.35rem; }
.comment-time  { font-size: 0.75rem; color: var(--ink-soft); }
.comment-action {
  background: none; border: none; cursor: pointer;
  font-size: 0.75rem; color: var(--ink-soft);
  padding: 0; font-family: inherit;
}
.comment-action:hover { color: var(--ink); }

.twisty-btn {
  background: none; border: none; cursor: pointer;
  font-size: 0.75rem; color: var(--ink-soft);
  padding: 0.25rem 0; margin-left: 0.75rem;
  font-family: inherit;
}
.twisty-btn:hover { color: var(--ink); }

.replies-wrap { margin-left: 1.5rem; margin-top: 0.4rem; display: flex; flex-direction: column; gap: 0.4rem; }
.reply-bubble { background: rgba(28,25,20,0.03); border-radius: 0; }
.reply-form   { margin-left: 1.5rem; margin-top: 0.4rem; }

.comment-form { margin-top: 0.4rem; }

.comment-author,
input.comment-author {
  width: 100%;
  background: rgba(28,25,20,0.04);
  border: 1px solid rgba(28,25,20,0.18);
  color: var(--ink);
  padding: 0.45rem 0.75rem;
  font-size: 0.85rem;
  font-family: inherit;
  margin-bottom: 0.4rem;
  border-radius: 0;
  display: block;
}
input.comment-author::placeholder { color: var(--ink-soft); }
input.comment-author:focus { outline: none; border-color: var(--ink-mid); }

.comment-input-row { display: flex; gap: 0.5rem; align-items: flex-end; }
.comment-textarea {
  flex: 1;
  background: rgba(28,25,20,0.04);
  border: 1px solid rgba(28,25,20,0.18);
  color: var(--ink);
  padding: 0.45rem 0.75rem;
  font-size: 0.9rem;
  font-family: inherit;
  resize: none;
  border-radius: 0;
}
.comment-textarea::placeholder { color: var(--ink-soft); }
.comment-textarea:focus { outline: none; border-color: var(--ink-mid); }

.comment-send-btn {
  background: transparent;
  border: 1px solid rgba(28,25,20,0.28);
  color: var(--ink-mid);
  padding: 0.5rem 1rem;
  font-family: inherit;
  font-size: 0.68rem;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  cursor: pointer;
  white-space: nowrap;
  transition: all 0.2s;
  border-radius: 0;
}
.comment-send-btn:hover { background: rgba(28,25,20,0.06); color: var(--ink); border-color: var(--ink-mid); }

/* ── Admin Tag-Liste ─────────────────────────────────────────────────────── */
.admin-tag-list { font-size: 0.78rem; color: var(--ink-mid); }

/* ── Admin Event-Tasks: Reihenfolge-Buttons ──────────────────────────────── */
.ev-order-col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.1rem;
}
.ev-order-btn {
  background: transparent;
  border: none;
  color: var(--ink-soft);
  font-size: 0.85rem;
  line-height: 1;
  padding: 0.1rem 0.25rem;
  cursor: pointer;
  transition: color 0.15s;
}
.ev-order-btn:hover { color: var(--ink); }

/* ── Admin Uploads: Filter-Bar ───────────────────────────────────────────── */
.upload-filter-label {
  font-size: 0.62rem;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: 0.45rem;
}
.upload-filter-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
  align-items: center;
}
.upload-filter-clear {
  background: transparent;
  border: 1px solid var(--border-mid);
  color: var(--ink-soft);
  font-size: 0.68rem;
  font-family: inherit;
  padding: 0.3rem 0.75rem;
  cursor: pointer;
  letter-spacing: 0.06em;
  transition: border-color 0.15s, color 0.15s;
}
.upload-filter-clear:hover { border-color: var(--ink); color: var(--ink); }

/* ── Admin Uploads: Sort-Spaltenköpfe ────────────────────────────────────── */
.upload-sort-th { cursor: pointer; user-select: none; }
.upload-sort-th:hover { color: rgba(253,252,248,1); }
.upload-sort-th::after { content: ' ↕'; opacity: 0.3; font-size: 0.65em; }
.upload-sort-th.sort-asc::after  { content: ' ↑'; opacity: 0.85; }
.upload-sort-th.sort-desc::after { content: ' ↓'; opacity: 0.85; }

/* ── Settings-Karte ──────────────────────────────────────────────────────── */
.settings-card {
  background: var(--paper);
  border: 1px solid var(--border);
  box-shadow: var(--shadow);
  padding: 1.75rem;
  max-width: 560px;
}
.settings-row { display: flex; align-items: flex-start; justify-content: space-between; gap: 1.5rem; }
.settings-row p { font-size: 0.88rem; color: var(--ink-soft); margin-top: 0.3rem; }

/* Toggle-Switch */
.toggle-switch { position: relative; display: inline-block; width: 44px; height: 24px; flex-shrink: 0; }
.toggle-switch input { opacity: 0; width: 0; height: 0; }
.toggle-slider {
  position: absolute; inset: 0;
  background: var(--ink-faint); border-radius: 999px; cursor: pointer;
  transition: background 0.2s;
}
.toggle-slider::before {
  content: '';
  position: absolute;
  width: 18px; height: 18px;
  left: 3px; top: 3px;
  background: white; border-radius: 50%;
  transition: transform 0.2s;
}
.toggle-switch input:checked + .toggle-slider { background: var(--ink); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); }

/* Slug-Input */
.slug-input-wrap {
  display: flex; align-items: center;
  border: 1px solid var(--border-mid);
  background: var(--paper); flex: 1; min-width: 140px;
  overflow: hidden; border-radius: 0;
}
.slug-prefix { padding: 0 0 0 0.75rem; font-size: 1.1rem; color: var(--ink-mid); user-select: none; }
.slug-input  { border: none !important; flex: 1; border-radius: 0 !important; }
.slug-input:focus { outline: none; }
.form-input--sm { padding: 0.35rem 0.6rem; font-size: 0.85rem; }

/* ── Challenges ──────────────────────────────────────────────────────────── */
.challenges-intro {
  text-align: center;
  color: var(--ink-soft);
  margin-bottom: 2.5rem;
  font-size: 1rem;
  font-style: italic;
  line-height: 1.7;
}
.challenges-loading,
.challenges-empty {
  text-align: center;
  color: var(--ink-soft);
  padding: 2rem 0;
  font-style: italic;
}
.challenges-list {
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
  max-width: 560px;
  margin: 0 auto;
}
.challenge-card {
  background: var(--paper);
  border: 1px solid var(--border);
  padding: 1.25rem 1.5rem;
  box-shadow: var(--shadow);
}
.challenge-header {
  display: flex;
  align-items: flex-start;
  gap: 1.25rem;
}
.challenge-upload-col {
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.35rem;
  margin-top: 0.1rem;
}
.challenge-upload-btn {
  font-family: inherit;
  font-size: 0.68rem;
  letter-spacing: 0.10em;
  text-transform: uppercase;
  border: 1px solid var(--border-mid);
  background: transparent;
  color: var(--ink-mid);
  padding: 0.3rem 0.65rem;
  cursor: pointer;
  white-space: nowrap;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.challenge-upload-btn:hover { border-color: var(--ink); color: var(--ink); }
.challenge-upload-btn:disabled { opacity: 0.5; cursor: default; }
.challenge-count-link {
  font-size: 0.72rem;
  letter-spacing: 0.04em;
  color: var(--ink-soft);
  text-decoration: none;
  white-space: nowrap;
}
a.challenge-count-link:hover { color: var(--ink); text-decoration: underline; }
.challenge-count-zero { color: var(--ink-faint); }
.challenge-number {
  flex-shrink: 0;
  width: 2rem; height: 2rem;
  border: 1px solid var(--border-mid);
  color: var(--ink-mid);
  font-size: 0.78rem;
  letter-spacing: 0.05em;
  font-weight: 400;
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 0.1rem;
}
.challenge-body  { flex: 1; min-width: 0; }
.challenge-title { font-size: 1.05rem; font-weight: 400; letter-spacing: 0.03em; color: var(--ink); margin-bottom: 0.35rem; }
.challenge-tag   { display: inline-block; margin-bottom: 0.5rem; }
.challenge-desc  { color: var(--ink-soft); font-size: 0.9rem; line-height: 1.55; margin: 0; font-style: italic; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .admin-main  { padding: 1.25rem; }
  .stats-grid  { grid-template-columns: repeat(2, 1fr); }
  .upload-area { padding: 3rem 1rem; }
}

@media (max-width: 600px) {
  .gallery-grid { grid-template-columns: repeat(auto-fill, minmax(110px, 1fr)); }
  .admin-layout { flex-direction: column; }
  .sidebar      { width: 100%; padding: 1.5rem 1.5rem 1rem; border-right: none; border-bottom: 1px solid var(--border); }
  .sidebar nav  { 
    display: flex; 
    flex-wrap: nowrap; 
    overflow-x: auto; 
    gap: 1.25rem; 
    padding-bottom: 0.5rem;
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* IE */
  }
  .sidebar nav::-webkit-scrollbar { display: none; } /* Chrome/Safari */
  .sidebar nav a { 
    white-space: nowrap; 
    border-bottom: none; 
    padding: 0.25rem 0;
  }
  .upload-area  { padding: 2.5rem 1rem; }
  .slideshow-branding { font-size: 0.8rem; bottom: 1.5rem; left: 1rem; }
}
