:root {
  --bg: #eef4ff;
  --bg2: #f8fafc;
  --card: #ffffff;
  --text: #172033;
  --muted: #64748b;
  --primary: var(--primary);
  --primary-dark: var(--primary-dark);
  --accent: var(--accent);
  --success: #15803d;
  --danger: #b91c1c;
  --warning: #b45309;
  --border: #e2e8f0;
  --soft-blue: color-mix(in srgb, var(--primary) 16%, white);
  --soft-green: #dcfce7;
  --soft-red: #fee2e2;
}
* { box-sizing: border-box; }
body {
  margin: 0;
  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, color-mix(in srgb, var(--primary) 16%, white) 0, transparent 35%), linear-gradient(135deg, var(--bg), var(--bg2));
  color: var(--text);
  min-height: 100vh;
}
a { color: inherit; text-decoration: none; }
.topbar {
  min-height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 28px;
  background: rgba(255,255,255,0.86);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid rgba(226, 232, 240, 0.9);
  position: sticky;
  top: 0;
  z-index: 10;
}
.brand { font-size: 23px; font-weight: 900; color: var(--primary); letter-spacing: -0.03em; }
nav { display: flex; gap: 18px; align-items: center; }
nav a { color: var(--muted); font-weight: 700; }
nav a:hover { color: var(--primary); }
.container { max-width: 1220px; margin: 32px auto; padding: 0 20px; }
.hero { margin-bottom: 24px; }
.dashboard-hero {
  border-radius: 28px;
  padding: 34px;
  background: linear-gradient(135deg, var(--primary-dark), var(--accent));
  color: white;
  box-shadow: 0 22px 50px rgba(37, 99, 235, 0.25);
}
.hero h1 { font-size: clamp(32px, 5vw, 54px); line-height: 1; margin: 0 0 12px; letter-spacing: -0.055em; }
.hero p { color: rgba(255,255,255,0.84); font-size: 18px; max-width: 760px; }
.eyebrow { margin: 0 0 8px; font-weight: 900; text-transform: uppercase; letter-spacing: 0.12em; font-size: 13px; }
.muted { color: var(--muted); }
.card {
  background: rgba(255,255,255,0.94);
  border: 1px solid rgba(226, 232, 240, 0.95);
  border-radius: 24px;
  padding: 24px;
  margin-bottom: 22px;
  box-shadow: 0 18px 45px rgba(15, 23, 42, 0.08);
}
.card h2 { margin-top: 0; letter-spacing: -0.03em; }
.narrow { max-width: 480px; margin-left: auto; margin-right: auto; }
.stack { display: grid; gap: 16px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr auto; gap: 16px; align-items: end; }
label { display: grid; gap: 8px; font-weight: 800; }
input, select {
  width: 100%;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 16px;
  background: #fff;
  color: var(--text);
}
input:focus, select:focus { outline: 3px solid rgba(37, 99, 235, 0.16); border-color: var(--primary); }
button, .button {
  border: 0;
  border-radius: 14px;
  padding: 12px 16px;
  font-size: 16px;
  font-weight: 900;
  cursor: pointer;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  color: white;
  display: inline-block;
  text-align: center;
  box-shadow: 0 10px 22px rgba(37, 99, 235, 0.18);
}
button:hover, .button:hover { filter: brightness(0.96); transform: translateY(-1px); }
.secondary { background: #e2e8f0; color: var(--text); box-shadow: none; }
.secondary:hover { background: #cbd5e1; }
.small { padding: 8px 10px; font-size: 14px; border-radius: 10px; }
.danger { background: var(--danger); }
.actions { display: flex; gap: 12px; margin-top: 18px; flex-wrap: wrap; }
table { width: 100%; border-collapse: collapse; }
th, td { padding: 12px; border-bottom: 1px solid var(--border); text-align: left; vertical-align: middle; }
th { color: var(--muted); font-size: 14px; }
.messages { margin-bottom: 18px; display: grid; gap: 10px; }
.message { padding: 13px 15px; border-radius: 14px; border: 1px solid var(--border); background: white; font-weight: 700; }
.message.success { border-color: #86efac; background: #f0fdf4; color: #166534; }
.message.error { border-color: #fecaca; background: #fef2f2; color: #991b1b; }
.pill { display: inline-block; padding: 5px 10px; border-radius: 999px; font-size: 13px; font-weight: 900; background: #e5e7eb; }
.pill.reserved { background: var(--soft-blue); color: var(--primary); }
.pill.cancelled { background: var(--soft-red); color: #991b1b; }

.planner-layout {
  display: grid;
  grid-template-columns: 330px 1fr;
  gap: 22px;
  align-items: start;
}
.ticket-card { position: sticky; top: 92px; }
.selected-ticket {
  margin-top: 20px;
  padding: 18px;
  border-radius: 20px;
  display: flex;
  gap: 14px;
  background: linear-gradient(135deg, color-mix(in srgb, var(--primary) 8%, white), #ecfeff);
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
}
.selected-ticket strong { font-size: 18px; }
.selected-ticket p { margin: 6px 0 0; color: var(--muted); }
.ticket-icon {
  width: 46px;
  height: 46px;
  border-radius: 16px;
  display: grid;
  place-items: center;
  background: white;
  box-shadow: inset 0 0 0 1px var(--border);
  font-size: 24px;
  flex: 0 0 auto;
}
.legend { margin-top: 20px; display: grid; gap: 10px; color: var(--muted); font-weight: 800; }
.dot { width: 12px; height: 12px; display: inline-block; border-radius: 99px; margin-right: 8px; vertical-align: middle; }
.dot.free { background: var(--success); }
.dot.booked { background: var(--danger); }
.dot.today { background: var(--primary); }
.calendar-card { overflow: hidden; }
.calendar-header {
  display: grid;
  grid-template-columns: 48px 1fr 48px;
  gap: 16px;
  align-items: center;
  margin-bottom: 18px;
}
.calendar-header h2 { margin: 0; font-size: 30px; }
.calendar-header p { margin: 4px 0 0; }
.calendar-nav {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  background: color-mix(in srgb, var(--primary) 8%, white);
  color: var(--primary);
  font-size: 34px;
  font-weight: 900;
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
}
.calendar-nav:hover { background: color-mix(in srgb, var(--primary) 16%, white); }
.calendar-grid { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
.weekdays {
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 8px;
}
.weekdays div { padding: 0 8px; }
.month-grid { gap: 10px; }
.calendar-day {
  min-height: 116px;
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 10px;
  background: #fff;
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: transform .12s ease, box-shadow .12s ease, border-color .12s ease;
}
.calendar-day:hover { transform: translateY(-2px); box-shadow: 0 14px 24px rgba(15, 23, 42, .08); border-color: color-mix(in srgb, var(--primary) 28%, white); }
.calendar-day.other-month { opacity: .35; background: #f8fafc; }
.calendar-day.past { background: #f8fafc; color: #94a3b8; }
.calendar-day.today { box-shadow: inset 0 0 0 2px var(--primary); }
.calendar-day.booked { background: #fff7f7; border-color: #fecaca; }
.day-number { font-weight: 950; font-size: 18px; }
.day-button {
  width: 100%;
  padding: 9px;
  font-size: 14px;
  border-radius: 12px;
  background: #dcfce7;
  color: #166534;
  box-shadow: none;
}
.day-button:hover { background: #bbf7d0; }
.day-status { font-weight: 900; color: var(--danger); }
.reserved-by { margin-top: 4px; font-size: 13px; color: var(--muted); overflow: hidden; text-overflow: ellipsis; }
.welcome-card { max-width: 720px; }

@media (max-width: 980px) {
  .planner-layout { grid-template-columns: 1fr; }
  .ticket-card { position: static; }
}
@media (max-width: 760px) {
  .topbar { height: auto; flex-direction: column; align-items: flex-start; gap: 12px; padding: 16px; }
  nav { flex-wrap: wrap; }
  .container { margin: 20px auto; padding: 0 14px; }
  .dashboard-hero { padding: 24px; border-radius: 22px; }
  .form-grid { grid-template-columns: 1fr; }
  table { font-size: 14px; }
  th, td { padding: 8px; }
  .calendar-header { grid-template-columns: 42px 1fr 42px; gap: 10px; }
  .calendar-header h2 { font-size: 22px; }
  .calendar-nav { width: 42px; height: 42px; font-size: 28px; }
  .month-grid { gap: 6px; }
  .calendar-day { min-height: 86px; border-radius: 14px; padding: 7px; }
  .day-number { font-size: 15px; }
  .day-button { padding: 7px 3px; font-size: 12px; }
  .reserved-by { display: none; }
  .day-status { font-size: 12px; }
}
textarea {
  width: 100%;
  min-height: 110px;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  font-size: 16px;
  background: #fff;
  color: var(--text);
  font-family: inherit;
}
textarea:focus { outline: 3px solid rgba(37, 99, 235, 0.16); border-color: var(--primary); }
.theme-green { --bg: #eefdf3; --bg2: #f7fee7; }
.theme-purple { --bg: #f5f3ff; --bg2: #fdf4ff; }
.theme-dark { --bg: #0f172a; --bg2: #111827; --card: #111827; --text: #e5e7eb; --muted: #94a3b8; --border: #334155; }
.theme-dark .card, .theme-dark .topbar, .theme-dark input, .theme-dark select, .theme-dark textarea, .theme-dark .calendar-day { background: rgba(17,24,39,.94); color: var(--text); }
.theme-dark .selected-ticket { background: rgba(30,41,59,.9); border-color: #334155; }
.theme-sand { --bg: #fff7ed; --bg2: #fefce8; }
.admin-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 22px; }
.admin-hero h1 { margin: 0 0 8px; font-size: 38px; letter-spacing: -0.045em; }
.two-cols { display: grid; grid-template-columns: 1fr 1fr; gap: 14px; }
.info-strip { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 14px; margin-bottom: 22px; }
.info-card { padding: 18px; border-radius: 20px; background: rgba(255,255,255,.92); border: 1px solid var(--border); box-shadow: 0 14px 30px rgba(15, 23, 42, .06); }
.info-card p { color: var(--muted); margin-bottom: 0; white-space: pre-wrap; }
.selected-ticket { align-items: center; }
.selected-ticket img { width: 88px; height: 88px; object-fit: cover; border-radius: 18px; box-shadow: 0 8px 18px rgba(15,23,42,.14); flex: 0 0 auto; }
.thumb { width: 74px; height: 54px; object-fit: cover; border-radius: 12px; display: block; }
.empty-thumb { width: 74px; height: 54px; display: grid; place-items: center; border-radius: 12px; background: color-mix(in srgb, var(--primary) 8%, white); font-size: 24px; }
.inline-edit { display: grid; grid-template-columns: 1fr 1fr 180px auto; gap: 8px; align-items: center; }
.inline-edit input { padding: 9px 10px; font-size: 14px; border-radius: 10px; }
.responsive-table { overflow-x: auto; }
.daypass-form { grid-template-columns: 1fr 1fr 1fr auto; }
input[type="color"] { height: 48px; padding: 4px; }
input[type="file"] { padding: 10px; }
@media (max-width: 980px) {
  .admin-grid, .info-strip { grid-template-columns: 1fr; }
  .daypass-form { grid-template-columns: 1fr; }
  .inline-edit { grid-template-columns: 1fr; min-width: 280px; }
}
.user-create-form { grid-template-columns: 1.2fr 1.4fr 1fr auto auto auto; align-items: end; }
.checkline, .mini-check { display: inline-flex; align-items: center; gap: 8px; font-weight: 800; color: var(--text); }
.checkline input, .mini-check input { width: auto; }
.user-edit { grid-template-columns: 1fr 1.2fr 1fr auto auto auto; min-width: 760px; }
.actions-cell { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 6px 10px; font-size: 13px; font-weight: 900; }
.pill.success { background: #dcfce7; color: #166534; }
.pill.warning { background: #fef3c7; color: #92400e; }
@media (max-width: 980px) {
  .user-create-form { grid-template-columns: 1fr; }
  .user-edit { grid-template-columns: 1fr; min-width: 320px; }
}

.rules-form { grid-template-columns: 1fr 1fr 1.3fr auto; align-items: end; }
.smtp-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.smtp-form .full-row, .smtp-form .template-help { grid-column: 1 / -1; }
.template-help { padding: 12px 14px; border-radius: 14px; background: #f8fafc; border: 1px dashed var(--border); color: var(--muted); }
.template-help code { display: inline-block; margin: 3px; padding: 3px 6px; border-radius: 8px; background: #e0f2fe; color: #075985; font-size: 13px; }
@media (max-width: 760px) {
  .rules-form, .smtp-form { grid-template-columns: 1fr; }
  .calendar-card { padding: 12px; }
  .calendar-grid.weekdays { display: grid; grid-template-columns: repeat(7, minmax(0, 1fr)); }
  .weekdays { font-size: 10px; letter-spacing: 0; margin-bottom: 5px; }
  .weekdays div { padding: 0; text-align: center; }
  .month-grid { grid-template-columns: repeat(7, minmax(0, 1fr)); gap: 3px; }
  .calendar-day {
    min-height: 58px;
    border-radius: 9px;
    padding: 4px;
    flex-direction: column;
    align-items: stretch;
    gap: 2px;
    justify-content: space-between;
  }
  .calendar-day.other-month { display: flex; opacity: .20; }
  .calendar-day:hover { transform: none; box-shadow: none; }
  .day-number { font-size: 13px; line-height: 1; }
  .day-button { width: 100%; margin-left: 0; padding: 4px 2px; font-size: 10px; border-radius: 7px; }
  .day-status { font-size: 10px; line-height: 1.1; }
  .reserved-by { display: none; }
}

@media (max-width: 430px) {
  .calendar-header { grid-template-columns: 36px 1fr 36px; gap: 6px; }
  .calendar-header h2 { font-size: 18px; }
  .calendar-header p { display: none; }
  .calendar-nav { width: 36px; height: 36px; border-radius: 12px; font-size: 24px; }
  .calendar-card { padding: 10px; }
  .month-grid { gap: 2px; }
  .calendar-day { min-height: 52px; padding: 3px; border-radius: 8px; }
  .day-number { font-size: 12px; }
  .day-button { font-size: 9px; padding: 3px 1px; }
  .day-status { font-size: 9px; }
}

.brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}
.brand-logo {
  width: auto;
  max-width: 170px;
  height: 42px;
  object-fit: contain;
  display: block;
  flex: 0 0 auto;
}
.brand-logo-fallback {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 13px;
  background: color-mix(in srgb, var(--primary) 8%, white);
  border: 1px solid var(--border);
  font-size: 22px;
  flex: 0 0 auto;
}
.logo-preview-box {
  display: grid;
  gap: 8px;
  padding: 14px;
  border-radius: 16px;
  border: 1px dashed var(--border);
  background: #f8fafc;
}
.logo-preview {
  max-width: 260px;
  max-height: 90px;
  width: auto;
  height: auto;
  object-fit: contain;
  display: block;
}
@media (max-width: 760px) {
  .brand-logo { max-width: 135px; height: 36px; }
  .brand-logo-fallback { width: 36px; height: 36px; }
}

/* Mobile Optimierung: Meine Reservationen */
.reservations-card { overflow: hidden; }
.reservations-card h1 { margin-top: 0; }
.reservation-action-cell { text-align: right; white-space: nowrap; }
.reservation-action-cell form { margin: 0; }
.reservation-list-mobile { display: none; }
.mobile-label {
  display: block;
  margin-bottom: 4px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 900;
  text-transform: uppercase;
  letter-spacing: .06em;
}

@media (max-width: 760px) {
  .reservations-card {
    padding: 18px;
    border-radius: 22px;
  }
  .reservations-card h1 {
    font-size: 34px;
    line-height: 1.05;
    letter-spacing: -0.05em;
    margin-bottom: 18px;
  }
  .reservations-table-wrap { display: none; }
  .reservation-list-mobile {
    display: grid;
    gap: 12px;
  }
  .reservation-mobile-card {
    display: grid;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: rgba(255,255,255,.88);
  }
  .mobile-status-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
    flex-wrap: wrap;
  }
  .mobile-status-row form { margin: 0; }
  .mobile-status-row .danger { width: auto; }
}

@media (max-width: 430px) {
  .reservations-card h1 { font-size: 30px; }
  .reservation-mobile-card { padding: 14px; border-radius: 16px; }
  .mobile-status-row .danger { padding: 9px 12px; }
}


/* V10: hart erzwungene Logo- und Mobile-Reservationen-Optimierung */
.brand-logo {
  display: block !important;
  width: auto !important;
  height: 42px !important;
  max-width: 170px !important;
  object-fit: contain !important;
}
.logo-preview {
  display: block !important;
  width: auto !important;
  height: auto !important;
  max-width: 260px !important;
  max-height: 90px !important;
  object-fit: contain !important;
}
@media (max-width: 760px) {
  .brand { max-width: 100%; }
  .brand-logo { height: 36px !important; max-width: 135px !important; }
  .reservations-table-wrap { display: none !important; }
  .reservation-list-mobile { display: grid !important; gap: 12px; }
  .reservation-mobile-card {
    display: grid !important;
    gap: 14px;
    padding: 16px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: rgba(255,255,255,.90);
  }
}

/* V12: schönere Tageskartenverwaltung im Admin-Bereich */
.section-title-row {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 18px;
}
.section-title-row h2 { margin-bottom: 4px; }
.daypass-admin-grid {
  display: grid;
  gap: 18px;
}
.daypass-admin-card {
  display: grid;
  grid-template-columns: 160px 1fr;
  gap: 22px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(248,250,252,.95), rgba(255,255,255,.98));
  box-shadow: 0 10px 28px rgba(15, 23, 42, .05);
}
.daypass-admin-media {
  min-height: 140px;
  border-radius: 20px;
  background: white;
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  padding: 16px;
  overflow: hidden;
}
.daypass-admin-media img {
  width: 100%;
  height: 100%;
  max-height: 116px;
  object-fit: contain;
}
.empty-thumb.large { font-size: 46px; }
.daypass-admin-content { min-width: 0; }
.daypass-admin-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 16px;
  margin-bottom: 12px;
}
.daypass-admin-head h3 {
  margin: 0 0 4px;
  font-size: 24px;
  letter-spacing: -0.04em;
}
.daypass-admin-head p { margin: 0; }
.rule-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0 16px;
}
.rule-pills span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 6px 10px;
  border-radius: 999px;
  background: color-mix(in srgb, var(--primary) 8%, white);
  color: var(--primary);
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
  font-size: 13px;
  font-weight: 900;
}
.daypass-edit-form {
  display: grid;
  grid-template-columns: 1.2fr 1.5fr .8fr .9fr 1fr 1fr auto;
  gap: 12px;
  align-items: end;
}
.daypass-edit-form label { font-size: 13px; color: var(--muted); }
.daypass-edit-form input,
.daypass-edit-form select { padding: 10px 12px; border-radius: 12px; }
.daypass-edit-form small { font-weight: 700; color: var(--muted); }
.toggle-form { margin-top: 12px; }
.pill.success { background: #dcfce7; color: #166534; }

@media (max-width: 1120px) {
  .daypass-edit-form { grid-template-columns: 1fr 1fr; }
  .daypass-edit-form button { grid-column: 1 / -1; }
}
@media (max-width: 760px) {
  .daypass-admin-card { grid-template-columns: 1fr; padding: 14px; border-radius: 20px; }
  .daypass-admin-media { min-height: 110px; }
  .daypass-admin-media img { max-height: 90px; }
  .daypass-admin-head { flex-direction: column; gap: 8px; }
  .daypass-edit-form { grid-template-columns: 1fr; }
  .daypass-edit-form button,
  .toggle-form button { width: 100%; }
}

/* V13: ruhigeres Admin-Design für Tageskarten */
.daypass-admin-section {
  padding: 28px;
}
.daypass-admin-grid {
  gap: 22px;
}
.daypass-admin-card {
  grid-template-columns: 190px minmax(0, 1fr);
  align-items: start;
  padding: 24px;
  border-radius: 28px;
  background: #ffffff;
  box-shadow: 0 18px 44px rgba(15, 23, 42, .07);
}
.daypass-admin-media {
  min-height: 190px;
  border-radius: 24px;
  background: linear-gradient(180deg, #ffffff, #f8fafc);
}
.daypass-admin-media img {
  max-height: 135px;
}
.daypass-admin-head {
  margin-bottom: 10px;
}
.daypass-admin-head h3 {
  font-size: 28px;
}
.rule-pills {
  margin: 12px 0 18px;
}
.clean-card-form {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(220px, 1fr));
  gap: 16px;
  align-items: stretch;
}
.form-panel {
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #f8fafc;
}
.form-panel h4 {
  margin: 0 0 12px;
  font-size: 15px;
  color: var(--text);
}
.field-grid {
  display: grid;
  gap: 12px;
}
.field-grid.two {
  grid-template-columns: 1fr 1fr;
}
.clean-card-form label {
  display: grid;
  gap: 6px;
  font-size: 13px;
  font-weight: 800;
  color: var(--muted);
}
.clean-card-form input,
.clean-card-form select {
  width: 100%;
  min-width: 0;
  padding: 11px 12px;
  border-radius: 13px;
}
.clean-card-form input[type="file"] {
  background: #fff;
  font-size: 13px;
}
.clean-card-form small {
  color: var(--muted);
  font-weight: 700;
}
.daypass-actions {
  grid-column: 1 / -1;
  display: flex;
  justify-content: flex-end;
  padding-top: 2px;
}
.daypass-actions button {
  min-width: 210px;
}
.daypass-secondary-action {
  margin-top: 10px;
  display: flex;
  justify-content: flex-start;
}
.daypass-secondary-action button {
  width: auto;
}

@media (max-width: 1180px) {
  .clean-card-form {
    grid-template-columns: 1fr;
  }
  .field-grid.two {
    grid-template-columns: 1fr 1fr;
  }
}
@media (max-width: 820px) {
  .daypass-admin-section {
    padding: 18px;
  }
  .daypass-admin-card {
    grid-template-columns: 1fr;
    padding: 18px;
  }
  .daypass-admin-media {
    min-height: 140px;
  }
  .daypass-admin-media img {
    max-height: 110px;
  }
  .field-grid.two {
    grid-template-columns: 1fr;
  }
  .daypass-actions,
  .daypass-secondary-action {
    justify-content: stretch;
  }
  .daypass-actions button,
  .daypass-secondary-action button {
    width: 100%;
    min-width: 0;
  }
}

/* V14: breite, ruhige Admin-Bearbeitung für Tageskarten */
.container {
  width: min(96vw, 1780px);
  max-width: none;
}
.wide-admin-card {
  padding: clamp(22px, 2.2vw, 34px);
}
.daypass-admin-grid-wide {
  display: grid;
  gap: 24px;
}
.daypass-admin-card-wide {
  display: block;
  padding: clamp(22px, 2.2vw, 34px);
  border: 1px solid var(--border);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(15,23,42,.07);
}
.daypass-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 22px;
}
.daypass-title-block h3 {
  margin: 0 0 4px;
  font-size: clamp(28px, 2.4vw, 42px);
  letter-spacing: -0.055em;
}
.daypass-title-block p { margin: 0; font-size: 17px; }
.daypass-card-body {
  display: grid;
  grid-template-columns: 300px minmax(0, 1fr);
  gap: 34px;
  align-items: start;
}
.daypass-admin-media-wide {
  width: 100%;
  aspect-ratio: 16 / 10;
  min-height: 0;
  padding: 20px;
  border-radius: 26px;
  background: linear-gradient(180deg, #fff, #f8fafc);
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  overflow: hidden;
}
.daypass-admin-media-wide img {
  width: 100%;
  height: 100%;
  max-height: none;
  object-fit: contain;
  display: block;
}
.daypass-editor-area { min-width: 0; }
.wide-daypass-form {
  display: block !important;
}
.wide-form-grid {
  display: grid;
  grid-template-columns: minmax(220px, .9fr) minmax(320px, 1.6fr) minmax(170px, .7fr) minmax(190px, .8fr) minmax(220px, .9fr) minmax(280px, 1.2fr);
  gap: 18px;
  align-items: start;
}
.wide-form-grid label {
  font-size: 14px;
  color: var(--muted);
}
.wide-form-grid input,
.wide-form-grid select {
  min-height: 54px;
  border-radius: 16px;
}
.wide-form-grid small {
  color: var(--muted);
  font-weight: 800;
}
.wide-actions-row {
  display: flex;
  justify-content: flex-end;
  margin-top: 22px;
}
.wide-actions-row button {
  min-width: 240px;
  min-height: 48px;
}
.daypass-secondary-action {
  margin-top: 0;
}
.daypass-secondary-action button {
  margin-top: 12px;
}

@media (max-width: 1450px) {
  .daypass-card-body { grid-template-columns: 260px minmax(0, 1fr); gap: 24px; }
  .wide-form-grid { grid-template-columns: repeat(3, minmax(220px, 1fr)); }
  .field-wide { grid-column: span 2; }
}
@media (max-width: 980px) {
  .container { width: 100%; padding: 0 14px; }
  .daypass-card-header { flex-direction: column; }
  .daypass-card-body { grid-template-columns: 1fr; }
  .daypass-admin-media-wide { max-width: 360px; }
  .wide-form-grid { grid-template-columns: 1fr 1fr; }
  .field-wide { grid-column: auto; }
}
@media (max-width: 640px) {
  .wide-admin-card, .daypass-admin-card-wide { padding: 16px; border-radius: 22px; }
  .wide-form-grid { grid-template-columns: 1fr; }
  .daypass-admin-media-wide { max-width: none; }
  .wide-actions-row button, .daypass-secondary-action button { width: 100%; min-width: 0; }
}

/* V15: klare Admin-Bearbeitung ohne horizontales Überlaufen */
.ticket-admin-shell {
  padding: clamp(22px, 2vw, 34px);
  overflow: hidden;
}
.ticket-admin-list {
  display: grid;
  gap: 24px;
}
.ticket-edit-card {
  border: 1px solid var(--border);
  border-radius: 28px;
  background: #fff;
  box-shadow: 0 18px 45px rgba(15,23,42,.07);
  padding: clamp(20px, 2vw, 30px);
}
.ticket-edit-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  margin-bottom: 24px;
}
.ticket-edit-header h3 {
  margin: 0 0 4px;
  font-size: clamp(28px, 2.3vw, 40px);
  line-height: 1;
  letter-spacing: -0.055em;
}
.compact-pills { margin-bottom: 0; }
.ticket-edit-layout {
  display: grid;
  grid-template-columns: minmax(190px, 260px) minmax(0, 1fr);
  gap: 30px;
  align-items: start;
}
.ticket-image-panel {
  display: grid;
  gap: 12px;
  align-content: start;
}
.ticket-image-preview {
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 24px;
  border: 1px solid var(--border);
  background: #fff;
  display: grid;
  place-items: center;
  padding: 18px;
  overflow: hidden;
}
.ticket-image-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.image-help {
  margin: 0;
  font-size: 13px;
  line-height: 1.35;
}
.ticket-form-panel {
  min-width: 0;
  display: grid;
  gap: 14px;
}
.ticket-edit-form {
  display: grid;
  gap: 16px;
  min-width: 0;
}
.ticket-form-section {
  border: 1px solid var(--border);
  border-radius: 20px;
  background: #f8fafc;
  padding: 18px;
}
.ticket-form-section h4 {
  margin: 0 0 14px;
  font-size: 18px;
  letter-spacing: -0.03em;
}
.ticket-form-grid {
  display: grid;
  gap: 16px;
}
.ticket-form-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.ticket-form-grid label {
  min-width: 0;
  color: var(--muted);
  font-size: 14px;
}
.ticket-form-grid input,
.ticket-form-grid select {
  min-width: 0;
  min-height: 52px;
  border-radius: 15px;
  background: #fff;
}
.ticket-form-grid input[type="file"] {
  font-size: 14px;
  max-width: 100%;
}
.ticket-action-bar {
  display: flex;
  justify-content: flex-end;
  padding-top: 4px;
}
.ticket-action-bar button {
  min-width: 240px;
  min-height: 50px;
}
.ticket-danger-row {
  display: flex;
  justify-content: flex-start;
}
.ticket-danger-row button {
  box-shadow: none;
}

@media (max-width: 1050px) {
  .ticket-edit-layout {
    grid-template-columns: 1fr;
  }
  .ticket-image-preview {
    max-width: 280px;
  }
}
@media (max-width: 700px) {
  .ticket-admin-shell,
  .ticket-edit-card {
    padding: 16px;
    border-radius: 22px;
  }
  .ticket-edit-header {
    flex-direction: column;
    gap: 12px;
  }
  .ticket-form-grid.two {
    grid-template-columns: 1fr;
  }
  .ticket-image-preview {
    max-width: none;
  }
  .ticket-action-bar,
  .ticket-danger-row {
    justify-content: stretch;
  }
  .ticket-action-bar button,
  .ticket-danger-row button {
    width: 100%;
    min-width: 0;
  }
}

/* V16: Buchungsansicht - saubere Bilddarstellung und Kapazitätsanzeige */
.selected-ticket {
  overflow: hidden;
  align-items: center;
}
.selected-ticket img {
  width: 112px !important;
  height: 112px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
  padding: 10px !important;
  border-radius: 18px !important;
  flex: 0 0 112px !important;
  box-sizing: border-box !important;
}
.availability-summary {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 10px;
}
.availability-summary span {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 999px;
  background: #fff;
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
  color: var(--primary);
  font-size: 13px;
  font-weight: 900;
}
.calendar-day.has-reservations:not(.booked) {
  background: #f0fdf4;
  border-color: #86efac;
}
.calendar-day.booked {
  background: #fff7f7;
  border-color: #fecaca;
}
.day-capacity {
  display: grid;
  gap: 4px;
  font-size: 12px;
  color: var(--muted);
  font-weight: 800;
}
.day-capacity strong {
  color: #166534;
  font-size: 13px;
}
.calendar-day.booked .day-capacity strong {
  color: var(--danger);
}
.day-button.compact { margin-top: 6px; }
@media (max-width: 760px) {
  .selected-ticket { padding: 12px; gap: 10px; }
  .selected-ticket img {
    width: 82px !important;
    height: 82px !important;
    flex-basis: 82px !important;
    padding: 8px !important;
  }
  .selected-ticket strong { font-size: 16px; }
  .selected-ticket p { font-size: 13px; line-height: 1.25; }
  .availability-summary span { font-size: 11px; padding: 5px 8px; }
  .day-capacity { font-size: 9px; line-height: 1.05; gap: 2px; }
  .day-capacity strong { font-size: 10px; }
}

/* V17: saubere Ticket-Vorschau in der Buchungsansicht */
.ticket-card {
  overflow: hidden;
}
.selected-ticket {
  display: grid !important;
  grid-template-columns: 96px minmax(0, 1fr) !important;
  gap: 16px !important;
  align-items: center !important;
  padding: 18px !important;
  border-radius: 22px !important;
  overflow: hidden !important;
}
.selected-ticket > div:last-child {
  min-width: 0 !important;
}
.selected-ticket img {
  width: 96px !important;
  height: 96px !important;
  flex: 0 0 96px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
  padding: 10px !important;
  border-radius: 20px !important;
  box-shadow: 0 10px 22px rgba(15,23,42,.10) !important;
}
.selected-ticket strong {
  display: block;
  font-size: 22px !important;
  line-height: 1.05;
  overflow-wrap: anywhere;
}
.selected-ticket p {
  margin: 7px 0 0 !important;
  line-height: 1.25 !important;
  overflow-wrap: anywhere !important;
  max-width: 100% !important;
}
.ticket-meta-grid {
  display: flex;
  flex-wrap: wrap;
  gap: 7px;
  margin-top: 12px;
}
.ticket-meta-grid span {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 9px;
  border-radius: 999px;
  background: rgba(255,255,255,.85);
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
  color: var(--primary);
  font-size: 12px;
  font-weight: 900;
  white-space: nowrap;
}
.availability-summary {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px !important;
  margin-top: 12px !important;
}
.availability-summary span {
  display: grid !important;
  gap: 1px !important;
  justify-items: center;
  min-width: 0;
  padding: 9px 8px !important;
  border-radius: 16px !important;
  background: #fff !important;
  border: 1px solid color-mix(in srgb, var(--primary) 28%, white) !important;
  color: var(--primary) !important;
  text-align: center;
  font-size: 12px !important;
  line-height: 1.1;
}
.availability-summary strong {
  font-size: 20px !important;
  line-height: 1 !important;
}
.availability-summary small {
  color: var(--muted);
  font-weight: 800;
}
@media (max-width: 980px) {
  .selected-ticket {
    grid-template-columns: 84px minmax(0, 1fr) !important;
  }
  .selected-ticket img {
    width: 84px !important;
    height: 84px !important;
    flex-basis: 84px !important;
  }
}
@media (max-width: 520px) {
  .selected-ticket {
    grid-template-columns: 1fr !important;
    text-align: center;
    justify-items: center;
  }
  .selected-ticket > div:last-child {
    width: 100%;
  }
  .selected-ticket img {
    width: 128px !important;
    height: 92px !important;
    flex-basis: auto !important;
  }
  .ticket-meta-grid {
    justify-content: center;
  }
  .ticket-meta-grid span {
    font-size: 11px;
  }
  .availability-summary {
    grid-template-columns: 1fr 1fr;
  }
}

/* V18: sauberere Admin-Reservationen und Rückgabe-Kontrolle */
.admin-reservations-clean .reservation-admin-cards,
.admin-return-dashboard .reservation-admin-cards {
  display: grid;
  gap: 12px;
}
.reservation-admin-card {
  display: grid;
  grid-template-columns: minmax(260px, 1.4fr) minmax(180px, .8fr) minmax(280px, 1fr);
  align-items: center;
  gap: 18px;
  padding: 16px 18px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: linear-gradient(135deg, rgba(255,255,255,.98), rgba(248,250,252,.96));
  box-shadow: 0 10px 24px rgba(15,23,42,.05);
}
.reservation-admin-card.overdue {
  border-color: #fbbf24;
  background: linear-gradient(135deg, #fffbeb, #ffffff);
}
.reservation-card-main {
  display: flex;
  gap: 14px;
  align-items: center;
  min-width: 0;
}
.reservation-date-big {
  min-width: 112px;
  padding: 10px 12px;
  border-radius: 14px;
  background: color-mix(in srgb, var(--primary) 8%, white);
  color: var(--primary);
  font-weight: 950;
  text-align: center;
}
.reservation-card-main strong,
.reservation-admin-card strong {
  display: block;
  font-size: 17px;
  letter-spacing: -.02em;
}
.reservation-card-main span,
.reservation-admin-card > div > span {
  display: block;
  margin-top: 3px;
  color: var(--muted);
  font-weight: 700;
}
.reservation-card-status {
  display: flex;
  gap: 8px;
  align-items: center;
  flex-wrap: wrap;
}
.reservation-card-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.reservation-card-actions form { margin: 0; }
.rules-form { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.rules-form button { justify-self: start; }
@media (max-width: 980px) {
  .reservation-admin-card { grid-template-columns: 1fr; align-items: start; }
  .reservation-card-actions { justify-content: flex-start; }
  .rules-form { grid-template-columns: 1fr; }
}
@media (max-width: 520px) {
  .reservation-card-main { align-items: flex-start; flex-direction: column; }
  .reservation-date-big { min-width: 0; width: 100%; }
  .reservation-card-actions button { width: 100%; }
  .reservation-card-actions form { width: 100%; }
}

.manual-reservation-card { border: 1px solid rgba(37,99,235,.16); }
.manual-reservation-form textarea { min-height: 84px; }
.small-info { display:block; margin-top: .25rem; font-size: .88rem; }
.reservation-admin-card .reservation-card-main > div:nth-child(2) { min-width: 0; }

/* V20: Reservationen direkt bearbeiten */
.admin-reservations-clean .reservation-admin-card {
  grid-template-columns: 1.2fr auto;
  align-items: start;
}
.admin-reservations-clean .reservation-card-main {
  grid-column: 1 / 2;
}
.admin-reservations-clean .reservation-card-status {
  grid-column: 2 / 3;
  justify-content: flex-end;
}
.reservation-period-form {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: repeat(3, minmax(170px, 1fr)) minmax(260px, 2fr) auto;
  gap: 12px;
  align-items: end;
  padding: 14px;
  border-radius: 16px;
  background: rgba(241, 245, 249, .72);
  border: 1px solid rgba(226,232,240,.95);
}
.reservation-period-form label {
  display: grid;
  gap: 6px;
  color: var(--muted);
  font-weight: 850;
  font-size: 13px;
}
.reservation-period-form input {
  width: 100%;
}
.reservation-period-form button {
  white-space: nowrap;
  min-height: 42px;
}
.admin-reservations-clean .reservation-card-actions {
  grid-column: 1 / -1;
  justify-content: flex-end;
  padding-top: 2px;
}
.manual-reservation-card { display: none; }
@media (max-width: 1200px) {
  .reservation-period-form { grid-template-columns: repeat(2, minmax(170px, 1fr)); }
  .reservation-period-form button { justify-self: start; }
}
@media (max-width: 700px) {
  .admin-reservations-clean .reservation-admin-card { grid-template-columns: 1fr; }
  .admin-reservations-clean .reservation-card-status { grid-column: 1; justify-content: flex-start; }
  .reservation-period-form { grid-template-columns: 1fr; }
  .reservation-period-form button,
  .admin-reservations-clean .reservation-card-actions button,
  .admin-reservations-clean .reservation-card-actions form { width: 100%; }
  .admin-reservations-clean .reservation-card-actions { justify-content: stretch; }
}

/* V21: geteilte Admin-Oberfläche */
.admin-tabs { display:flex; gap:10px; align-items:center; padding:12px; flex-wrap:wrap; }
.admin-tabs a { text-decoration:none; color:var(--text); font-weight:800; padding:12px 16px; border-radius:14px; background:#f4f8fd; border:1px solid #dbe7f3; }
.admin-tabs a.active { background:linear-gradient(135deg,var(--primary),var(--accent)); color:#fff; border-color:transparent; box-shadow:0 12px 26px rgba(37,99,235,.18); }
.reservation-card-v21 { grid-template-columns: 1.4fr auto; gap:16px; align-items:start; }
.reservation-card-v21 .reservation-period-form { grid-column:1 / -1; }
.reservation-card-v21 .reservation-card-actions { grid-column:1 / -1; justify-content:flex-end; }
.nice-period-form { background:#f8fbff; border:1px solid #ddeaf7; border-radius:18px; padding:14px; }
.ticket-edit-card-v21 { margin-bottom:18px; }
.ticket-admin-list-v21 { display:block; }
.ticket-form-section textarea { min-height:80px; }
@media (max-width: 800px) {
  .admin-tabs { gap:8px; }
  .admin-tabs a { width:100%; text-align:center; }
  .reservation-card-v21 { grid-template-columns:1fr; }
}

/* V23: Mobile Navigation, kompakter Kalender und bessere Reservations-Administration */
.mobile-menu { display: none; }

@media (max-width: 760px) {
  body {
    background: linear-gradient(180deg, #f8fbff 0%, #eef4ff 100%);
  }

  .topbar {
    position: sticky;
    top: 0;
    display: grid;
    grid-template-columns: 1fr auto;
    align-items: center;
    gap: 10px;
    padding: 12px 14px;
    min-height: 0;
    border-bottom: 1px solid rgba(226,232,240,.95);
  }

  .brand {
    gap: 9px;
    font-size: 20px;
    line-height: 1.05;
    letter-spacing: -.04em;
    min-width: 0;
  }

  .brand span:last-child {
    display: block;
    max-width: 185px;
    overflow: hidden;
    text-overflow: ellipsis;
  }

  .brand-logo {
    height: 34px !important;
    max-width: 128px !important;
  }

  .desktop-nav { display: none !important; }
  .mobile-menu {
    display: block;
    position: relative;
  }
  .mobile-menu summary {
    list-style: none;
    cursor: pointer;
    padding: 10px 13px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
    background: color-mix(in srgb, var(--primary) 8%, white);
    color: var(--primary);
    font-weight: 950;
    user-select: none;
  }
  .mobile-menu summary::-webkit-details-marker { display: none; }
  .mobile-menu[open] summary { background: var(--primary); color: #fff; }
  .mobile-menu nav {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: min(86vw, 320px);
    display: grid;
    gap: 6px;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: rgba(255,255,255,.98);
    box-shadow: 0 20px 45px rgba(15,23,42,.16);
    z-index: 50;
  }
  .mobile-menu nav a {
    padding: 12px 13px;
    border-radius: 13px;
    background: #f8fafc;
    font-size: 15px;
  }

  .container {
    width: 100%;
    margin: 14px auto 26px;
    padding: 0 12px;
  }

  .card {
    border-radius: 22px;
    padding: 16px;
    margin-bottom: 16px;
    box-shadow: 0 12px 30px rgba(15,23,42,.07);
  }

  .planner-layout {
    display: grid;
    gap: 16px;
  }

  .ticket-card h2 {
    font-size: 24px;
    margin-bottom: 14px;
  }

  .selected-ticket {
    grid-template-columns: 82px minmax(0, 1fr) !important;
    text-align: left !important;
    justify-items: stretch !important;
    gap: 12px !important;
    padding: 14px !important;
  }
  .selected-ticket img {
    width: 82px !important;
    height: 82px !important;
    border-radius: 18px !important;
    padding: 8px !important;
  }
  .selected-ticket strong { font-size: 18px !important; }
  .selected-ticket p {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-size: 13px;
  }
  .ticket-meta-grid {
    gap: 5px;
    margin-top: 8px;
  }
  .ticket-meta-grid span {
    min-height: 24px;
    padding: 4px 7px;
    font-size: 10.5px;
  }
  .availability-summary {
    grid-template-columns: 1fr 1fr !important;
    gap: 6px !important;
    margin-top: 8px !important;
  }
  .availability-summary span {
    padding: 7px 5px !important;
    border-radius: 13px !important;
  }
  .availability-summary strong { font-size: 17px !important; }
  .availability-summary small { font-size: 10px; }

  .legend {
    grid-template-columns: repeat(3, auto);
    justify-content: start;
    gap: 12px;
    margin-top: 14px;
    font-size: 14px;
  }
  .dot { width: 10px; height: 10px; }

  .calendar-card {
    padding: 14px 12px;
    border-radius: 22px;
    overflow: hidden;
  }
  .calendar-header {
    grid-template-columns: 40px 1fr 40px;
    gap: 8px;
    margin-bottom: 14px;
  }
  .calendar-header h2 {
    font-size: 24px;
    line-height: 1;
    text-align: center;
  }
  .calendar-header p { display: none; }
  .calendar-nav {
    width: 40px;
    height: 40px;
    border-radius: 14px;
    font-size: 28px;
  }

  .calendar-grid.weekdays,
  .month-grid {
    grid-template-columns: repeat(7, minmax(0, 1fr));
  }
  .weekdays {
    font-size: 11px;
    margin-bottom: 6px;
  }
  .weekdays div { text-align: center; padding: 0; }
  .month-grid { gap: 4px; }

  .calendar-day {
    min-height: 70px;
    padding: 5px;
    border-radius: 12px;
    overflow: hidden;
    gap: 2px;
  }
  .day-number {
    font-size: 14px;
    line-height: 1;
  }
  .day-capacity {
    display: block;
    line-height: 1.05;
    text-align: left;
    min-width: 0;
  }
  .day-capacity span {
    display: block;
    font-size: 9px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: clip;
  }
  .day-capacity span::after { content: none; }
  .day-capacity strong {
    display: block;
    font-size: 11px;
    white-space: nowrap;
  }
  .day-button,
  .day-button.compact {
    min-height: 20px;
    padding: 3px 2px;
    border-radius: 8px;
    font-size: 0 !important;
    line-height: 1;
  }
  .day-button::after,
  .day-button.compact::after {
    content: '+';
    font-size: 15px;
    line-height: 1;
  }
  .day-status {
    font-size: 0 !important;
    color: #cbd5e1;
    text-align: center;
  }
  .day-status::after {
    content: '–';
    font-size: 16px;
    line-height: 1;
  }
  .calendar-day.past .day-number { color: #94a3b8; }
}

@media (max-width: 430px) {
  .topbar { padding: 10px 12px; }
  .brand span:last-child { max-width: 158px; }
  .brand-logo { max-width: 112px !important; height: 32px !important; }
  .mobile-menu summary { padding: 9px 11px; }

  .calendar-card { padding: 12px 10px; }
  .month-grid { gap: 3px; }
  .calendar-day {
    min-height: 64px;
    padding: 4px;
    border-radius: 10px;
  }
  .day-number { font-size: 13px; }
  .day-capacity span { display: none; }
  .day-capacity strong { font-size: 10px; }
  .day-button::after,
  .day-button.compact::after { font-size: 14px; }

  .selected-ticket {
    grid-template-columns: 74px minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 12px !important;
  }
  .selected-ticket img {
    width: 74px !important;
    height: 74px !important;
  }
  .selected-ticket strong { font-size: 17px !important; }
  .ticket-meta-grid span { font-size: 10px; padding: 4px 6px; }
}

/* V23: Reservations-Admin mobil kompakter */
.period-details {
  grid-column: 1 / -1;
  border: 1px solid rgba(226,232,240,.95);
  border-radius: 16px;
  background: rgba(248,251,255,.9);
  overflow: hidden;
}
.period-details summary {
  cursor: pointer;
  padding: 12px 14px;
  font-weight: 950;
  color: var(--primary);
  user-select: none;
}
.period-details[open] summary {
  border-bottom: 1px solid rgba(226,232,240,.95);
  background: color-mix(in srgb, var(--primary) 8%, white);
}
.period-details .reservation-period-form {
  border: 0;
  border-radius: 0;
  background: transparent;
  margin: 0;
}
@media (max-width: 700px) {
  .split-admin-hero h1 { font-size: 30px; }
  .admin-tabs.card { display: none; }
  .reservation-admin-card,
  .reservation-card-v21 {
    padding: 14px;
    border-radius: 18px;
  }
  .reservation-card-main {
    gap: 10px;
  }
  .reservation-card-main strong { font-size: 16px; }
  .reservation-date-big {
    padding: 9px 10px;
    border-radius: 13px;
    width: auto;
    min-width: 98px;
  }
  .period-details summary { padding: 11px 12px; }
  .reservation-period-form {
    padding: 12px !important;
    gap: 10px;
  }
  .reservation-period-form label {
    font-size: 12px;
  }
  .reservation-period-form input {
    min-height: 46px;
    font-size: 15px;
    border-radius: 14px;
  }
  .reservation-card-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .reservation-card-actions form,
  .reservation-card-actions button {
    width: 100%;
  }
}

/* V24: Digitale Ticketdaten direkt auf Reservationsebene */
.digital-ticket-details{
  border:1px solid var(--border, #dfe8f3);
  border-radius:18px;
  padding:0;
  background:rgba(248,251,255,.96);
  margin:14px 0;
  overflow:hidden;
}
.digital-ticket-details summary{
  cursor:pointer;
  font-weight:800;
  padding:14px 18px;
  color:var(--text, #111827);
  list-style:none;
}
.digital-ticket-details summary::-webkit-details-marker{display:none;}
.digital-ticket-form{
  display:grid;
  grid-template-columns:minmax(220px, .8fr) minmax(280px, 1.2fr);
  gap:16px;
  padding:0 18px 18px;
  align-items:start;
}
.digital-ticket-form label{
  display:flex;
  flex-direction:column;
  gap:8px;
  font-weight:700;
  color:var(--muted, #64748b);
}
.digital-ticket-form textarea{
  min-height:110px;
  resize:vertical;
}
.digital-ticket-actions{
  grid-column:1 / -1;
  display:flex;
  justify-content:flex-end;
  gap:10px;
  flex-wrap:wrap;
}
@media (max-width: 720px){
  .digital-ticket-form{grid-template-columns:1fr;}
  .digital-ticket-actions{justify-content:stretch;}
  .digital-ticket-actions button{width:100%;}
}

/* V25 production helpers */
.admin-kpis{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:1rem;margin:1rem 0}.kpi{padding:1.1rem}.kpi strong{display:block;font-size:2rem;color:var(--primary)}.kpi span{color:#64748b;font-weight:700}.backup-list{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.75rem}.audit-list{display:flex;flex-direction:column;gap:.45rem;max-height:420px;overflow:auto}.audit-row{display:grid;grid-template-columns:150px 140px 180px 1fr;gap:.75rem;align-items:start;padding:.75rem;border:1px solid #e2e8f0;border-radius:14px;background:#fff}.audit-row em{font-style:normal;color:#64748b}.danger{background:#dc2626!important;color:white!important}.message.error{background:#fee2e2;color:#991b1b}.message.success{background:#dcfce7;color:#166534}
@media(max-width:800px){.admin-kpis{grid-template-columns:1fr 1fr}.audit-row{grid-template-columns:1fr}.kpi strong{font-size:1.5rem}}

/* V26: Enduser pickup/return request for physical tickets */
.pickup-return-card {
  margin-top: 1rem;
  padding: 1rem;
  border: 1px solid var(--border, #dbe4ef);
  border-radius: 1.2rem;
  background: rgba(255,255,255,.72);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.8);
}
.pickup-return-card h3 {
  margin: 0 0 .35rem 0;
  font-size: 1rem;
}
.pickup-return-card p {
  margin: 0 0 .8rem 0;
  color: var(--muted, #64748b);
  font-size: .88rem;
  line-height: 1.35;
}
.pickup-return-card label {
  display: block;
  font-weight: 700;
  color: var(--muted, #64748b);
  margin-top: .65rem;
}
.pickup-return-card input[type="date"] {
  width: 100%;
  margin-top: .25rem;
  padding: .72rem .85rem;
  border: 1px solid var(--border, #dbe4ef);
  border-radius: .8rem;
  background: #fff;
  font: inherit;
}
@media (max-width: 720px) {
  .pickup-return-card {
    padding: .85rem;
  }
  .pickup-return-card p {
    font-size: .82rem;
  }
}

/* V27: Reservation popup for pickup/return dates */
body.modal-open {
  overflow: hidden;
}
.modal-backdrop[hidden] {
  display: none !important;
}
.modal-backdrop {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 1.25rem;
  background: rgba(15, 23, 42, .54);
  backdrop-filter: blur(8px);
}
.reservation-modal {
  width: min(620px, 100%);
  max-height: min(760px, calc(100vh - 2rem));
  overflow: auto;
  border-radius: 1.6rem;
  background: var(--card, #ffffff);
  color: var(--text, #0f172a);
  box-shadow: 0 24px 80px rgba(15,23,42,.28);
  padding: 1.35rem;
  border: 1px solid rgba(226,232,240,.9);
}
.modal-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 1rem;
  margin-bottom: 1rem;
}
.modal-head h2 {
  margin: .15rem 0 0;
  font-size: clamp(1.25rem, 3vw, 1.75rem);
}
.modal-close {
  width: 2.4rem;
  height: 2.4rem;
  border: 0;
  border-radius: 999px;
  background: #f1f5f9;
  color: #334155;
  font-size: 1.45rem;
  line-height: 1;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
}
.modal-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .75rem;
  margin-bottom: 1rem;
}
.modal-summary span {
  display: block;
  padding: .9rem;
  border-radius: 1rem;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
}
.modal-summary strong,
.modal-summary small {
  display: block;
}
.modal-summary small {
  margin-top: .2rem;
  color: var(--muted, #64748b);
  font-weight: 700;
}
.modal-physical-fields,
.modal-digital-hint {
  padding: 1rem;
  border: 1px solid #dbe4ef;
  border-radius: 1.15rem;
  background: rgba(248,250,252,.75);
}
.modal-date-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: .85rem;
  margin-top: .85rem;
}
.modal-date-grid label {
  font-weight: 800;
  color: var(--muted, #64748b);
}
.modal-date-grid input[type="date"] {
  width: 100%;
  margin-top: .35rem;
  padding: .78rem .85rem;
  border: 1px solid var(--border, #dbe4ef);
  border-radius: .85rem;
  background: #fff;
  font: inherit;
}
.modal-actions {
  display: flex;
  justify-content: flex-end;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.1rem;
}
@media (max-width: 640px) {
  .modal-backdrop {
    align-items: flex-end;
    padding: .6rem;
  }
  .reservation-modal {
    border-radius: 1.35rem 1.35rem .8rem .8rem;
    padding: 1rem;
  }
  .modal-summary,
  .modal-date-grid {
    grid-template-columns: 1fr;
  }
  .modal-actions button {
    width: 100%;
  }
}

.availability-check{
  margin: 12px 0;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(15, 23, 42, .12);
  background: rgba(248, 250, 252, .95);
}
.availability-check.success{
  border-color: rgba(22, 163, 74, .28);
  background: rgba(240, 253, 244, .9);
}
.availability-check.warning{
  border-color: rgba(217, 119, 6, .3);
  background: rgba(255, 251, 235, .95);
}
.availability-check.danger{
  border-color: rgba(220, 38, 38, .32);
  background: rgba(254, 242, 242, .95);
}
.availability-head{
  display: flex;
  gap: 10px;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
}
.availability-head span{
  font-size: .92rem;
  color: var(--muted);
}
.availability-days{
  margin-top: 8px;
}
.availability-days summary{
  cursor: pointer;
  font-size: .9rem;
  color: var(--muted);
}
.availability-day-grid{
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 8px;
}
.availability-day{
  padding: 5px 8px;
  border-radius: 999px;
  font-size: .82rem;
  background: white;
  border: 1px solid rgba(15,23,42,.12);
}
.availability-day.ok{ border-color: rgba(22,163,74,.25); }
.availability-day.bad{ border-color: rgba(220,38,38,.35); background: rgba(254,226,226,.8); }

.outline-danger { background: transparent; border: 1px solid #dc2626; color: #dc2626; }
.outline-danger:hover { background: #fee2e2; }
.capacity-help { margin-top: -0.4rem; margin-bottom: 1rem; }

/* V31: Enduser Ticketkarte vereinfacht + Auswahl im Kalender aktualisiert Vorschau */
.selected-ticket {
  display: grid !important;
  grid-template-columns: 1fr !important;
  justify-items: center !important;
  text-align: center !important;
  gap: 14px !important;
  padding: 22px !important;
  border-radius: 28px !important;
  background: linear-gradient(145deg, color-mix(in srgb, var(--primary) 8%, white) 0%, #ecfeff 100%) !important;
  border: 1px solid #bae6fd !important;
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85) !important;
}
.selected-ticket > div:last-child {
  width: 100% !important;
  display: grid !important;
  justify-items: center !important;
}
.selected-ticket strong {
  font-size: 26px !important;
  line-height: 1.08 !important;
  margin: 0 !important;
}
.selected-ticket p {
  display: none !important;
}
.selected-ticket img {
  width: 150px !important;
  height: 118px !important;
  object-fit: contain !important;
  object-position: center !important;
  background: #fff !important;
  padding: 14px !important;
  border-radius: 24px !important;
  box-shadow: 0 14px 30px rgba(15,23,42,.10) !important;
}
.availability-summary {
  display: flex !important;
  justify-content: center !important;
  margin-top: 4px !important;
  width: 100% !important;
}
.availability-summary span {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 8px !important;
  min-width: 0 !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  background: #fff !important;
  border: 1px solid #bbf7d0 !important;
  color: #166534 !important;
  box-shadow: 0 8px 18px rgba(22,101,52,.08) !important;
}
.availability-summary .free-dot {
  width: 10px !important;
  height: 10px !important;
  border-radius: 999px !important;
  background: #16a34a !important;
  padding: 0 !important;
  border: 0 !important;
  box-shadow: none !important;
  flex: 0 0 10px !important;
}
.availability-summary strong {
  font-size: 22px !important;
  line-height: 1 !important;
  color: #166534 !important;
}
.availability-summary small {
  display: block !important;
  font-size: 12px !important;
  color: #64748b !important;
  font-weight: 850 !important;
}
.calendar-day.selected-for-preview {
  outline: 3px solid var(--primary);
  outline-offset: 2px;
}
@media (max-width: 760px) {
  .selected-ticket {
    padding: 18px !important;
    gap: 12px !important;
  }
  .selected-ticket img {
    width: 156px !important;
    height: 116px !important;
  }
  .selected-ticket strong {
    font-size: 24px !important;
  }
  .availability-summary span {
    flex-wrap: wrap !important;
    padding: 9px 14px !important;
    gap: 6px !important;
  }
  .availability-summary strong {
    font-size: 20px !important;
  }
  .availability-summary small {
    width: 100% !important;
    font-size: 11px !important;
  }
}
@media (max-width: 430px) {
  .selected-ticket img {
    width: 140px !important;
    height: 104px !important;
  }
  .availability-summary span {
    max-width: 100% !important;
  }
}


/* V32: iPad/tablet polish */
@media (max-width: 1180px) {
  .topbar {
    grid-template-columns: 1fr auto;
    padding: 12px 18px;
  }
  .desktop-nav { display: none !important; }
  .mobile-menu {
    display: block !important;
    position: relative;
  }
  .brand {
    font-size: 22px;
    line-height: 1.05;
  }
  .brand span:last-child {
    max-width: 260px;
    overflow: hidden;
    text-overflow: ellipsis;
  }
  .brand-logo {
    height: 40px !important;
    max-width: 150px !important;
  }
}
@media (min-width: 761px) and (max-width: 1180px) {
  .mobile-menu summary {
    list-style: none;
    cursor: pointer;
    padding: 10px 14px;
    border-radius: 14px;
    border: 1px solid color-mix(in srgb, var(--primary) 28%, white);
    background: color-mix(in srgb, var(--primary) 8%, white);
    color: var(--primary);
    font-weight: 950;
    user-select: none;
  }
  .mobile-menu summary::-webkit-details-marker { display: none; }
  .mobile-menu[open] summary { background: var(--primary); color: #fff; }
  .mobile-menu nav {
    position: absolute;
    right: 0;
    top: calc(100% + 8px);
    width: min(84vw, 360px);
    display: grid;
    gap: 6px;
    padding: 10px;
    border: 1px solid var(--border);
    border-radius: 18px;
    background: rgba(255,255,255,.98);
    box-shadow: 0 20px 45px rgba(15,23,42,.16);
    z-index: 80;
  }
  .mobile-menu nav a {
    padding: 12px 13px;
    border-radius: 13px;
    background: #f8fafc;
    font-size: 15px;
    font-weight: 850;
  }
}

/* V32: Ticket card user-facing clean layout */
.selected-ticket {
  grid-template-columns: 1fr !important;
  justify-items: center !important;
  text-align: center !important;
  padding: 22px !important;
}
.selected-ticket > div:last-child {
  width: 100% !important;
  display: grid !important;
  justify-items: center !important;
}
.selected-ticket img {
  width: 142px !important;
  height: 112px !important;
  border-radius: 22px !important;
}
.selected-ticket strong {
  margin-top: 10px !important;
  font-size: 26px !important;
}
.selected-ticket p,
.ticket-meta-grid {
  display: none !important;
}
.availability-summary {
  width: auto !important;
  display: inline-flex !important;
  grid-template-columns: none !important;
  justify-content: center !important;
}
.availability-summary span {
  display: inline-flex !important;
  align-items: center !important;
  gap: 8px !important;
  min-width: 0 !important;
  padding: 10px 16px !important;
  border-radius: 999px !important;
  color: #166534 !important;
  border-color: #bbf7d0 !important;
  background: white !important;
}
.availability-summary span::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 99px;
  background: #16a34a;
}
.availability-summary strong {
  font-size: 24px !important;
  color: #166534 !important;
}
.availability-summary small {
  color: var(--muted) !important;
  font-size: 13px !important;
}

/* V32: iPad calendar clipping improvements */
@media (min-width: 761px) and (max-width: 1180px) {
  .container { max-width: 100%; padding: 0 18px; }
  .planner-layout {
    grid-template-columns: minmax(250px, 320px) minmax(0, 1fr);
    gap: 16px;
  }
  .calendar-card { padding: 18px; }
  .month-grid { gap: 7px; }
  .calendar-day {
    min-height: 108px;
    padding: 10px;
    border-radius: 16px;
    overflow: hidden;
  }
  .day-number { font-size: 18px; }
  .day-capacity span,
  .day-capacity strong {
    font-size: 12px;
    line-height: 1.08;
  }
  .day-button {
    width: 100%;
    min-height: 28px;
    padding: 5px 6px;
    font-size: 12px;
    white-space: nowrap;
    overflow: hidden;
  }
}

/* V32: Ticket admin checkbox should look like a normal checkbox, not a big icon */
.ticket-form-grid label.checkbox-row,
.checkbox-row {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  color: var(--text) !important;
  font-size: 15px !important;
  font-weight: 850 !important;
}
.ticket-form-grid input[type="checkbox"],
input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  flex: 0 0 18px !important;
  border-radius: 5px !important;
}

/* V32: Audit log readable on iPad */
.audit-row {
  grid-template-columns: 150px 120px minmax(170px, .8fr) minmax(0, 1.4fr) !important;
  gap: 12px !important;
}
.audit-row > * {
  min-width: 0;
  overflow-wrap: anywhere;
}
.audit-row em {
  display: block;
  line-height: 1.25;
}
@media (max-width: 1180px) {
  .audit-row {
    grid-template-columns: 1fr 1fr !important;
  }
  .audit-row em {
    grid-column: 1 / -1;
  }
}
@media (max-width: 700px) {
  .audit-row {
    grid-template-columns: 1fr !important;
  }
}


/* V33 cleanup */
@media (max-width: 1400px){
  .desktop-nav{display:none!important;}
  .mobile-menu{display:block!important;position:relative;}
}

.selected-ticket p,
.availability-summary{
  display:none!important;
}

.selected-ticket{
  grid-template-columns:1fr!important;
  text-align:center!important;
  justify-items:center!important;
}

.selected-ticket img{
  width:180px!important;
  height:140px!important;
}

.day-capacity span{
  display:none!important;
}

.day-capacity strong{
  font-size:16px!important;
}

.calendar-day{
  min-height:140px!important;
}


/* V34: Reservation Admin as compact filterable worklist */
.reservation-worklist .section-title-row {
  align-items: flex-start;
}
.reservation-filter-bar {
  display: grid;
  grid-template-columns: 1.1fr 1fr 1.2fr 1fr 1fr minmax(190px, 1.5fr) auto;
  gap: 12px;
  align-items: end;
  margin: 18px 0 20px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(248, 250, 252, .88);
}
.reservation-filter-bar label {
  display: grid;
  gap: 6px;
  min-width: 0;
  color: var(--muted);
  font-size: 13px;
  font-weight: 900;
}
.reservation-filter-bar input,
.reservation-filter-bar select {
  min-width: 0;
  width: 100%;
  min-height: 42px;
  border-radius: 13px;
}
.reservation-filter-actions {
  display: flex;
  gap: 8px;
  align-items: center;
  white-space: nowrap;
}
.reservation-filter-actions .button {
  display: inline-flex;
  align-items: center;
  min-height: 38px;
  padding: 0 14px;
}
.reservation-worklist-list {
  display: grid;
  gap: 10px;
}
.reservation-workitem {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255,255,255,.96);
  overflow: hidden;
  box-shadow: 0 8px 20px rgba(15,23,42,.04);
}
.reservation-workitem summary {
  list-style: none;
  cursor: pointer;
  display: grid;
  grid-template-columns: 122px minmax(0, 1fr) auto auto;
  gap: 16px;
  align-items: center;
  padding: 12px 14px;
  user-select: none;
}
.reservation-workitem summary::-webkit-details-marker {
  display: none;
}
.reservation-workitem[open] summary {
  border-bottom: 1px solid var(--border);
  background: #f8fafc;
}
.workitem-date {
  padding: 8px 10px;
  border-radius: 13px;
  background: color-mix(in srgb, var(--primary) 8%, white);
  color: var(--primary);
  font-weight: 950;
  text-align: center;
}
.workitem-main {
  min-width: 0;
}
.workitem-main strong {
  display: block;
  font-size: 16px;
  line-height: 1.15;
}
.workitem-main span,
.workitem-main small {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.workitem-status {
  display: flex;
  justify-content: flex-end;
}
.workitem-toggle {
  color: var(--primary);
  font-weight: 900;
  font-size: 13px;
}
.reservation-workitem[open] .workitem-toggle::after {
  content: " ausblenden";
}
.workitem-details {
  display: grid;
  gap: 12px;
  padding: 14px;
}
.workitem-actions {
  justify-content: flex-end;
  border-top: 1px solid rgba(226,232,240,.75);
  padding-top: 12px;
}
@media (max-width: 1200px) {
  .reservation-filter-bar {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .reservation-filter-actions {
    grid-column: 1 / -1;
  }
}
@media (max-width: 760px) {
  .reservation-filter-bar {
    grid-template-columns: 1fr;
    gap: 10px;
  }
  .reservation-filter-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
  }
  .reservation-filter-actions button,
  .reservation-filter-actions .button {
    width: 100%;
    justify-content: center;
  }
  .reservation-workitem summary {
    grid-template-columns: 1fr auto;
    gap: 10px;
  }
  .workitem-date {
    text-align: left;
  }
  .workitem-main {
    grid-column: 1 / -1;
  }
  .workitem-status {
    justify-content: flex-start;
  }
  .workitem-toggle {
    justify-self: end;
  }
  .workitem-main span,
  .workitem-main small {
    white-space: normal;
  }
}


/* V35: verständlichere Verfügbarkeitsanzeige und saubere Details-Zeilen */
.availability-days summary,
.period-details summary,
.digital-ticket-details summary {
  display: flex !important;
  align-items: center !important;
  gap: 8px !important;
  white-space: nowrap !important;
  line-height: 1.2 !important;
}
.availability-days summary::before,
.period-details summary::before,
.digital-ticket-details summary::before {
  content: "▸";
  display: inline-flex;
  width: 16px;
  flex: 0 0 16px;
  color: var(--primary);
}
.availability-days[open] summary::before,
.period-details[open] summary::before,
.digital-ticket-details[open] summary::before {
  content: "▾";
}
.availability-day-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 8px;
}
.availability-day {
  display: grid !important;
  grid-template-columns: auto 1fr;
  gap: 2px 10px;
  align-items: center;
  padding: 10px 12px !important;
  border-radius: 14px !important;
  border: 1px solid var(--border);
  background: #fff;
}
.availability-day strong {
  grid-row: span 2;
  font-size: 15px;
  color: var(--text);
}
.availability-day em {
  font-style: normal;
  font-weight: 950;
}
.availability-day small {
  color: var(--muted);
  font-weight: 800;
}
.availability-day.ok {
  border-color: #bbf7d0 !important;
  background: #f0fdf4 !important;
}
.availability-day.ok em {
  color: #166534;
}
.availability-day.bad {
  border-color: #fecaca !important;
  background: #fef2f2 !important;
}
.availability-day.bad em {
  color: #991b1b;
}
.availability-head span {
  font-weight: 850;
}
@media (max-width: 520px) {
  .availability-days summary,
  .period-details summary,
  .digital-ticket-details summary {
    white-space: normal !important;
  }
  .availability-day-grid {
    grid-template-columns: 1fr;
  }
}


/* V36: cleaner reservation filter and today dashboard */
.reservation-filter-bar {
  align-items: end !important;
}
.reservation-filter-bar label {
  min-height: 72px;
  align-content: end;
}
.reservation-filter-bar input,
.reservation-filter-bar select,
.reservation-filter-bar button,
.reservation-filter-actions .button {
  height: 48px !important;
  min-height: 48px !important;
  line-height: 1.1 !important;
}
.reservation-filter-actions {
  align-items: end !important;
  height: 72px;
}
.reservation-filter-actions button,
.reservation-filter-actions .button {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  margin: 0 !important;
}
.today-task-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
  margin-top: 16px;
}
.today-task-box {
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #f8fafc;
  padding: 16px;
  min-width: 0;
}
.today-task-box h3 {
  margin: 0 0 12px;
  font-size: 17px;
}
.today-task-item {
  padding: 10px 0;
  border-top: 1px solid rgba(226,232,240,.9);
}
.today-task-item:first-of-type {
  border-top: 0;
  padding-top: 0;
}
.today-task-item strong {
  display: block;
  font-size: 15px;
}
.today-task-item span {
  display: block;
  color: var(--muted);
  font-weight: 750;
  margin-top: 2px;
}
@media (max-width: 1000px) {
  .today-task-grid {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 760px) {
  .reservation-filter-bar label,
  .reservation-filter-actions {
    height: auto;
    min-height: 0;
  }
}


/* V37: Benutzernamen im Kalender ausblenden */
.calendar-day .reservation-user,
.calendar-day .day-reservation-user,
.calendar-day .reservation-name,
.calendar-day .user-name {
  display: none !important;
}

/* Falls Namen als einfache Spans innerhalb der Tageszelle ausgegeben werden */
.calendar-day .day-reservations span.user,
.calendar-day .day-reservations .user {
  display: none !important;
}


/* V38: ruhigerer Kalender */
.calendar-day.past .day-status {
  display: none !important;
}
.calendar-day.past {
  background: #f8fafc !important;
  color: #94a3b8 !important;
}
.calendar-day.past .day-number {
  color: #94a3b8 !important;
}
.calendar-day {
  display: flex !important;
  flex-direction: column !important;
}
.calendar-day .day-capacity {
  margin-top: auto !important;
  margin-bottom: 10px !important;
}
.calendar-day .day-button {
  align-self: center !important;
  width: auto !important;
  min-width: 118px !important;
  max-width: 150px !important;
  padding-left: 14px !important;
  padding-right: 14px !important;
}
.calendar-day.selected,
.calendar-day.today {
  background: color-mix(in srgb, var(--primary) 8%, white) !important;
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 2px var(--primary), 0 14px 28px rgba(37,99,235,.12) !important;
}
.calendar-day:not(.past):not(.booked) .day-capacity strong {
  color: #166534 !important;
}
@media (max-width: 760px) {
  .calendar-day .day-capacity {
    margin-bottom: 5px !important;
  }
  .calendar-day .day-button {
    min-width: 0 !important;
    max-width: none !important;
    width: 100% !important;
  }
}


/* V39: Namen im Kalender endgültig entfernen */
.reserved-by { display: none !important; }


/* V40: Ticket Administration Formularlayout aufräumen */
.daypass-form {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 18px 22px !important;
  align-items: start !important;
}
.daypass-form label {
  min-width: 0 !important;
  display: grid !important;
  gap: 8px !important;
}
.daypass-form input,
.daypass-form select,
.daypass-form textarea {
  width: 100% !important;
  min-height: 50px !important;
  border-radius: 15px !important;
}
.daypass-form textarea {
  min-height: 110px !important;
}
.daypass-form .full-row,
.daypass-form button {
  grid-column: 1 / -1 !important;
}
.daypass-form button {
  justify-self: start !important;
  min-width: 220px !important;
}
.daypass-form .checkline {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  min-height: 50px !important;
  padding: 0 2px !important;
}
.daypass-form .checkline input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  flex: 0 0 18px !important;
}

/* Datei-Felder harmonischer */
input[type="file"] {
  padding: 11px 13px !important;
  background: #fff !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  font-size: 14px !important;
}

/* Bestehende Ticket-Bearbeitung: Feldgruppen schmaler und ruhiger */
.ticket-edit-layout {
  grid-template-columns: minmax(180px, 260px) minmax(0, 1fr) !important;
  gap: 26px !important;
}
.ticket-form-section {
  padding: 20px !important;
}
.ticket-form-grid.two {
  grid-template-columns: repeat(2, minmax(260px, 1fr)) !important;
}
.ticket-form-grid input,
.ticket-form-grid select,
.ticket-form-grid textarea {
  width: 100% !important;
  min-height: 50px !important;
  border-radius: 15px !important;
}
.ticket-form-grid textarea {
  min-height: 92px !important;
}
.ticket-form-grid small {
  display: block !important;
  margin-top: 6px !important;
  color: var(--muted) !important;
}

/* Checkbox in Regeln weniger dominant und sauber eingerückt */
.ticket-form-section .checkline,
.ticket-form-section label:has(input[type="checkbox"]) {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin-top: 10px !important;
  color: var(--text) !important;
  font-weight: 850 !important;
}
.ticket-form-section input[type="checkbox"] {
  width: 18px !important;
  height: 18px !important;
  min-height: 18px !important;
  flex: 0 0 18px !important;
}

/* Buttons schöner positionieren */
.ticket-action-bar {
  justify-content: flex-start !important;
}
.ticket-action-bar button {
  min-width: 260px !important;
}

/* Ticket Admin auf iPad/Desktop nicht über die ganze Breite gequetscht */
.ticket-admin-list .card,
.ticket-admin-list-v21 .card {
  max-width: 1320px !important;
}
@media (max-width: 1000px) {
  .daypass-form,
  .ticket-form-grid.two {
    grid-template-columns: 1fr !important;
  }
  .ticket-edit-layout {
    grid-template-columns: 1fr !important;
  }
  .ticket-image-preview {
    max-width: 320px !important;
  }
}
@media (max-width: 600px) {
  .daypass-form button,
  .ticket-action-bar button {
    width: 100% !important;
    min-width: 0 !important;
  }
}

.daypass-form .ticket-form-section{background:#f8fafc;border:1px solid var(--border);border-radius:18px;padding:18px}
.daypass-form h4{margin:0 0 14px}


/* V42: Ticket Administration als kompakte Liste mit Detailbearbeitung */
.ticket-admin-overview {
  margin-bottom: 14px;
}
.ticket-create-panel {
  margin-bottom: 18px;
  padding: 0 !important;
  overflow: hidden;
}
.ticket-create-panel > summary {
  cursor: pointer;
  list-style: none;
  padding: 18px 22px;
  font-size: 20px;
  font-weight: 950;
  color: var(--primary);
  user-select: none;
}
.ticket-create-panel > summary::-webkit-details-marker { display: none; }
.ticket-create-panel[open] > summary {
  border-bottom: 1px solid var(--border);
  background: #f8fafc;
}
.ticket-create-panel > form {
  padding: 20px 22px 24px;
}
.ticket-admin-compact-list {
  display: grid !important;
  gap: 12px !important;
}
.ticket-row-card {
  padding: 0 !important;
  overflow: hidden !important;
}
.ticket-row-card > summary {
  list-style: none;
  cursor: pointer;
}
.ticket-row-card > summary::-webkit-details-marker { display: none; }
.ticket-row-summary {
  display: grid;
  grid-template-columns: 90px minmax(0, 1fr) auto auto;
  gap: 16px;
  align-items: center;
  padding: 16px 18px;
  user-select: none;
}
.ticket-row-card[open] .ticket-row-summary {
  background: #f8fafc;
  border-bottom: 1px solid var(--border);
}
.ticket-row-thumb {
  width: 76px;
  height: 58px;
  border-radius: 16px;
  border: 1px solid var(--border);
  background: #fff;
  display: grid;
  place-items: center;
  padding: 8px;
  overflow: hidden;
}
.ticket-row-thumb img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.ticket-row-main {
  min-width: 0;
}
.ticket-row-main strong {
  display: block;
  font-size: 20px;
  line-height: 1.15;
}
.ticket-row-main > span {
  display: block;
  margin-top: 2px;
  color: var(--muted);
  font-weight: 750;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.ticket-row-action {
  color: var(--primary);
  font-weight: 950;
}
.ticket-row-card[open] .ticket-row-action::after {
  content: " schließen";
}
.ticket-row-card .ticket-edit-layout {
  padding: 20px;
}
.ticket-row-card .ticket-image-panel {
  display: none !important;
}
.ticket-row-card .ticket-form-panel {
  max-width: 980px;
}
.ticket-row-card .ticket-form-section {
  background: #fff;
}
@media (max-width: 820px) {
  .ticket-row-summary {
    grid-template-columns: 64px minmax(0, 1fr) auto;
    gap: 12px;
  }
  .ticket-row-thumb {
    width: 58px;
    height: 48px;
    border-radius: 14px;
  }
  .ticket-row-action {
    grid-column: 1 / -1;
    justify-self: stretch;
    text-align: center;
    padding: 10px;
    border-radius: 13px;
    background: color-mix(in srgb, var(--primary) 8%, white);
  }
}


/* V43: Customizing-Farben wirklich auf Oberfläche anwenden */
:root {
  --primary-dark: color-mix(in srgb, var(--primary) 84%, black);
}

.dashboard-hero,
button:not(.secondary):not(.danger),
.button:not(.secondary):not(.danger),
.day-button,
.ticket-action-bar button,
.ticket-create-panel button,
.daypass-form button {
  background: linear-gradient(135deg, var(--primary), var(--accent)) !important;
  color: #fff !important;
}

.brand,
nav a:hover,
.ticket-row-action,
.mobile-menu summary,
.period-details summary,
.availability-days summary,
.digital-ticket-details summary {
  color: var(--primary) !important;
}

.selected-ticket,
.calendar-nav,
.workitem-date,
.ticket-row-action,
.mobile-menu summary,
.admin-tabs a.active {
  border-color: color-mix(in srgb, var(--primary) 28%, white) !important;
}

.selected-ticket,
.calendar-nav,
.workitem-date,
.mobile-menu summary,
.ticket-row-action {
  background: color-mix(in srgb, var(--primary) 8%, white) !important;
}

.calendar-day.today,
.calendar-day.selected {
  border-color: var(--primary) !important;
  box-shadow: 0 0 0 2px var(--primary), 0 14px 28px color-mix(in srgb, var(--primary) 18%, transparent) !important;
  background: color-mix(in srgb, var(--primary) 8%, white) !important;
}

.rule-pills span,
.ticket-meta-grid span,
.availability-summary span {
  border-color: color-mix(in srgb, var(--primary) 28%, white) !important;
  color: var(--primary) !important;
}

.topbar {
  border-bottom-color: color-mix(in srgb, var(--primary) 14%, #e2e8f0) !important;
}

a.button,
button {
  transition: filter .15s ease, transform .15s ease;
}
button:hover,
a.button:hover {
  filter: brightness(.98);
  transform: translateY(-1px);
}




/* ==========================================================================
   V59 CLEAN LAYOUT
   Saubere responsive Basis für Buchung, Kalender und Reservation Admin.
   ========================================================================== */

* {
  box-sizing: border-box;
}

html, body {
  max-width: 100%;
  overflow-x: hidden;
}

.container {
  width: min(1180px, calc(100vw - 36px)) !important;
  max-width: 1180px !important;
  margin-inline: auto !important;
}

/* ---------- Buchungsseite ---------- */

.planner-layout {
  display: grid !important;
  grid-template-columns: minmax(240px, 330px) minmax(0, 1fr) !important;
  gap: 22px !important;
  align-items: start !important;
}

@media (max-width: 1250px) {
  .planner-layout {
    grid-template-columns: 1fr !important;
  }
}

.ticket-card {
  position: static !important;
  width: 100% !important;
  max-width: 420px !important;
  padding: 16px !important;
  border-radius: 20px !important;
}

@media (max-width: 1250px) {
  .ticket-card {
    max-width: 520px !important;
  }
}

.ticket-card h2 {
  font-size: 20px !important;
  line-height: 1.15 !important;
  margin: 0 0 12px !important;
}

.ticket-card label {
  display: grid !important;
  gap: 6px !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.ticket-card select {
  height: 38px !important;
  min-height: 38px !important;
  padding: 0 10px !important;
  font-size: 14px !important;
  border-radius: 10px !important;
}

.selected-ticket {
  display: grid !important;
  grid-template-columns: 70px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: center !important;
  justify-items: start !important;
  text-align: left !important;
  width: 100% !important;
  max-width: 320px !important;
  min-height: 0 !important;
  margin-top: 12px !important;
  padding: 10px 12px !important;
  border-radius: 16px !important;
}

.selected-ticket img {
  width: 62px !important;
  height: 46px !important;
  object-fit: contain !important;
  padding: 5px !important;
  border-radius: 10px !important;
}

.selected-ticket strong {
  font-size: 18px !important;
  line-height: 1.1 !important;
  margin: 0 !important;
}

.selected-ticket p,
.selected-ticket .ticket-meta-grid,
.selected-ticket .availability-summary {
  display: none !important;
}

/* ---------- Kalender ---------- */

.calendar-card {
  width: 100% !important;
  padding: 18px !important;
  border-radius: 22px !important;
  overflow: hidden !important;
}

.calendar-header {
  display: grid !important;
  grid-template-columns: 44px minmax(0, 1fr) 44px !important;
  gap: 14px !important;
  align-items: center !important;
  margin-bottom: 14px !important;
}

.calendar-header h2 {
  font-size: clamp(24px, 3vw, 34px) !important;
  line-height: 1.05 !important;
  margin: 0 !important;
}

.calendar-nav {
  width: 42px !important;
  height: 42px !important;
  border-radius: 14px !important;
}

.calendar-grid.weekdays,
.month-grid {
  display: grid !important;
  grid-template-columns: repeat(7, minmax(0, 1fr)) !important;
  gap: 8px !important;
  width: 100% !important;
  min-width: 0 !important;
}

.calendar-grid.weekdays > div {
  min-width: 0 !important;
  text-align: left !important;
  font-size: 12px !important;
  font-weight: 900 !important;
  color: var(--muted) !important;
  padding-inline: 4px !important;
}

.calendar-day {
  display: flex !important;
  flex-direction: column !important;
  min-width: 0 !important;
  min-height: 112px !important;
  padding: 8px !important;
  border-radius: 16px !important;
  overflow: hidden !important;
}

.day-number {
  font-size: 19px !important;
  line-height: 1 !important;
}

.day-capacity {
  margin-top: auto !important;
  margin-bottom: 6px !important;
}

.day-capacity span,
.reserved-by {
  display: none !important;
}

.day-capacity strong {
  display: block !important;
  color: #166534 !important;
  font-size: 14px !important;
  line-height: 1.05 !important;
  white-space: nowrap !important;
}

.calendar-day form,
.calendar-day .reservation-form {
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  margin: 0 !important;
  overflow: hidden !important;
}

.day-button,
.day-button.compact {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 100% !important;
  min-width: 0 !important;
  max-width: 100% !important;
  height: 30px !important;
  min-height: 30px !important;
  padding: 0 6px !important;
  border-radius: 10px !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: ellipsis !important;
  font-size: 13px !important;
  line-height: 1 !important;
}

/* Bei mittel/schmaler Breite konsequent +, nie überlaufender Text */
@media (max-width: 1180px) {
  .day-button,
  .day-button.compact {
    padding: 0 !important;
    font-size: 0 !important;
  }

  .day-button::after,
  .day-button.compact::after {
    content: "+" !important;
    display: block !important;
    color: #fff !important;
    font-size: 20px !important;
    line-height: 30px !important;
  }
}

/* iPhone: kein horizontaler Kalender-Scroll, kompakter 7-Spalten-Kalender */
@media (max-width: 760px) {
  .container {
    width: min(100vw - 20px, 100%) !important;
  }

  .calendar-card {
    padding: 10px !important;
    border-radius: 20px !important;
  }

  .calendar-header {
    grid-template-columns: 38px minmax(0, 1fr) 38px !important;
    gap: 8px !important;
  }

  .calendar-header h2 {
    font-size: 26px !important;
    text-align: center !important;
  }

  .calendar-nav {
    width: 38px !important;
    height: 38px !important;
  }

  .calendar-grid.weekdays,
  .month-grid {
    gap: 4px !important;
  }

  .calendar-grid.weekdays > div {
    font-size: 10px !important;
    text-align: center !important;
    padding: 0 !important;
  }

  .calendar-day {
    min-height: 72px !important;
    padding: 4px !important;
    border-radius: 11px !important;
  }

  .day-number {
    font-size: 14px !important;
  }

  .day-capacity {
    margin-bottom: 3px !important;
  }

  .day-capacity strong {
    font-size: 9px !important;
  }

  .day-button,
  .day-button.compact {
    height: 22px !important;
    min-height: 22px !important;
    border-radius: 8px !important;
    padding: 0 !important;
    font-size: 0 !important;
  }

  .day-button::after,
  .day-button.compact::after {
    content: "+" !important;
    display: block !important;
    color: #fff !important;
    font-size: 16px !important;
    line-height: 22px !important;
  }

  .ticket-card {
    max-width: 100% !important;
  }

  .selected-ticket {
    max-width: 100% !important;
  }
}

/* ---------- Reservation Admin ---------- */

.reservation-filter-bar {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 12px !important;
  align-items: end !important;
  padding: 14px !important;
  border-radius: 18px !important;
}

.reservation-filter-bar label {
  display: grid !important;
  grid-template-rows: auto 42px !important;
  gap: 6px !important;
  min-height: 0 !important;
  height: auto !important;
  margin: 0 !important;
  font-size: 13px !important;
  font-weight: 900 !important;
}

.reservation-filter-bar input,
.reservation-filter-bar select {
  width: 100% !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 0 12px !important;
  border-radius: 12px !important;
  box-sizing: border-box !important;
  font-size: 15px !important;
  line-height: normal !important;
}

.reservation-filter-actions {
  grid-column: 1 / -1 !important;
  display: flex !important;
  gap: 10px !important;
  height: auto !important;
}

.reservation-filter-actions button,
.reservation-filter-actions .button {
  height: 42px !important;
  min-height: 42px !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  border-radius: 12px !important;
}

@media (max-width: 900px) {
  .reservation-filter-bar {
    grid-template-columns: 1fr !important;
  }

  .reservation-filter-actions {
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
  }

  .reservation-filter-actions button,
  .reservation-filter-actions .button {
    width: 100% !important;
  }
}

/* ---------- Abhol/Rückgabe Details ---------- */

.period-edit-form-v49 {
  display: grid !important;
  grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  gap: 12px !important;
  padding: 14px !important;
}

.period-field-v49,
.period-note-v49 {
  display: grid !important;
  grid-template-columns: 1fr !important;
  gap: 6px !important;
  min-height: 0 !important;
}

.period-field-v49 label,
.period-note-v49 label {
  margin: 0 !important;
  font-size: 13px !important;
  line-height: 1.2 !important;
  color: var(--muted) !important;
  font-weight: 900 !important;
}

.period-field-v49 input,
.period-note-v49 input {
  width: 100% !important;
  height: 42px !important;
  min-height: 42px !important;
  max-height: 42px !important;
  padding: 0 12px !important;
  border-radius: 12px !important;
  font-size: 15px !important;
  line-height: 42px !important;
  box-sizing: border-box !important;
  background: #fff !important;
  -webkit-appearance: none !important;
  appearance: none !important;
}

.period-note-v49,
.period-actions-v49 {
  grid-column: 1 / -1 !important;
}

.period-actions-v49 button {
  height: 42px !important;
  min-height: 42px !important;
  border-radius: 12px !important;
}

@media (max-width: 760px) {
  .period-edit-form-v49 {
    grid-template-columns: 1fr !important;
  }

  .period-actions-v49 button {
    width: 100% !important;
  }
}

/* ---------- Admin Dashboard ---------- */

.dashboard-kpis,
.kpi-grid,
.admin-kpis,
.today-task-grid {
  display: grid !important;
  grid-template-columns: repeat(auto-fit, minmax(210px, 1fr)) !important;
  gap: 14px !important;
}

.dashboard-kpis > *,
.kpi-grid > *,
.admin-kpis > *,
.today-task-grid > * {
  margin: 0 !important;
  width: auto !important;
  min-width: 0 !important;
}

@media (max-width: 760px) {
  .dashboard-kpis,
  .kpi-grid,
  .admin-kpis,
  .today-task-grid {
    grid-template-columns: 1fr !important;
  }
}


/* V60: Kalenderbutton darf nie aus der Tageszelle laufen */
.month-grid,
.calendar-grid.weekdays {
  min-width: 0 !important;
}

.calendar-day {
  min-width: 0 !important;
  overflow: hidden !important;
  position: relative !important;
}

.calendar-day form,
.calendar-day .reservation-form {
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

.calendar-day .day-button,
.calendar-day .day-button.compact {
  display: flex !important;
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  box-sizing: border-box !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-overflow: clip !important;
}

/* In allen nicht sehr breiten Layouts nur + anzeigen */
@media (max-width: 1500px) {
  .calendar-day .day-button,
  .calendar-day .day-button.compact {
    font-size: 0 !important;
    padding: 0 !important;
  }

  .calendar-day .day-button::after,
  .calendar-day .day-button.compact::after {
    content: "+" !important;
    display: block !important;
    color: #fff !important;
    font-size: 20px !important;
    line-height: 1 !important;
  }
}

/* Info-Text Verwaltung */
.info-post-admin-list {
  display: grid;
  gap: 12px;
  margin: 18px 0;
}

.info-post-admin-item {
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 14px;
  background: #f8fafc;
}

.info-post-admin-item p {
  margin: 6px 0 12px;
}

.inline-delete-form {
  margin-top: 10px;
}


/* V62: Info-Texte im Technik Admin sichtbar verwalten */
.info-post-admin-list {
  margin-top: 18px !important;
}

.info-post-admin-list h2 {
  margin-top: 0 !important;
}

.info-post-admin-item {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 14px 0;
  border-top: 1px solid var(--border);
}

.info-post-admin-item:first-of-type {
  border-top: 0;
}

.info-post-admin-item p {
  margin: 6px 0;
  color: var(--muted);
}

.info-post-admin-item small {
  font-weight: 900;
  color: var(--muted);
}

.info-post-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

@media (max-width: 760px) {
  .info-post-admin-item {
    grid-template-columns: 1fr;
  }
  .info-post-actions {
    justify-content: stretch;
  }
  .info-post-actions form,
  .info-post-actions button {
    width: 100%;
  }
}

/* ==========================================================================
   V63 PUBLIC & AUTH POLISH
   ========================================================================== */

.desktop-nav a {
  padding: 9px 12px;
  border-radius: 12px;
}

.desktop-nav a.active:not(.nav-cta) {
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 8%, white);
}

.desktop-nav .nav-cta {
  color: #fff !important;
  background: var(--primary);
  box-shadow: 0 8px 18px color-mix(in srgb, var(--primary) 22%, transparent);
}

.public-hero {
  min-height: 360px;
  display: flex;
  align-items: center;
  position: relative;
  overflow: hidden;
}

.public-hero::after {
  content: "🎫";
  position: absolute;
  right: clamp(24px, 8vw, 100px);
  top: 50%;
  transform: translateY(-50%) rotate(-8deg);
  font-size: clamp(90px, 14vw, 170px);
  opacity: .13;
  filter: grayscale(1) brightness(3);
  pointer-events: none;
}

.public-hero > div {
  position: relative;
  z-index: 1;
  max-width: 760px;
}

.hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: 26px;
}

.hero-actions .button {
  min-width: 150px;
  box-shadow: none;
}

.hero-actions .hero-primary {
  background: #fff !important;
  color: var(--primary) !important;
}

.hero-actions .hero-secondary {
  background: rgba(255,255,255,.08) !important;
  color: #fff !important;
  border: 1px solid rgba(255,255,255,.5);
}

.public-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
}

.public-step {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  margin: 0;
  padding: 20px;
  border-radius: 20px;
}

.public-step > span {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  color: #fff;
  background: var(--primary);
  font-weight: 900;
}

.public-step h2 {
  margin: 1px 0 6px;
  font-size: 18px;
}

.public-step p {
  margin: 0;
  color: var(--muted);
  line-height: 1.55;
}

.auth-layout {
  min-height: min(650px, calc(100vh - 190px));
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 480px);
  gap: clamp(36px, 8vw, 100px);
  align-items: center;
  max-width: 1040px;
  margin: 0 auto;
}

.auth-intro h1 {
  margin: 8px 0 18px;
  max-width: 620px;
  font-size: clamp(36px, 5vw, 58px);
  line-height: 1.02;
  letter-spacing: -.055em;
}

.auth-intro > p:last-child {
  max-width: 560px;
  color: var(--muted);
  font-size: 18px;
  line-height: 1.65;
}

.auth-intro .eyebrow {
  color: var(--primary);
}

.auth-card {
  width: 100%;
  padding: clamp(24px, 4vw, 36px);
  margin-bottom: 0;
}

.auth-card h1,
.auth-card h2 {
  margin: 0 0 8px;
  font-size: 30px;
  letter-spacing: -.035em;
}

.auth-lead {
  margin: 0 0 24px;
}

.auth-card button {
  width: 100%;
  margin-top: 4px;
}

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

.auth-links {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 10px 18px;
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
  color: var(--muted);
  font-size: 14px;
}

.auth-links a {
  color: var(--primary);
  font-weight: 800;
}

.site-footer {
  width: min(1180px, calc(100vw - 36px));
  margin: 40px auto 22px;
  padding-top: 20px;
  border-top: 1px solid color-mix(in srgb, var(--primary) 12%, var(--border));
  display: flex;
  justify-content: space-between;
  gap: 16px;
  color: var(--muted);
  font-size: 13px;
}

.site-footer span:first-child {
  color: var(--text);
  font-weight: 800;
}

@media (max-width: 820px) {
  .public-hero {
    min-height: 0;
  }

  .public-steps {
    grid-template-columns: 1fr;
  }

  .auth-layout {
    min-height: 0;
    grid-template-columns: 1fr;
    gap: 24px;
    max-width: 560px;
  }

  .auth-intro {
    padding: 24px 8px 0;
  }

  .auth-intro h1 {
    font-size: clamp(32px, 10vw, 46px);
  }
}

@media (max-width: 760px) {
  .topbar {
    flex-direction: row !important;
    align-items: center !important;
    padding: 10px 14px !important;
  }

  .brand {
    min-width: 0;
  }

  .brand > span:last-child {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .mobile-menu summary {
    display: flex;
    align-items: center;
    gap: 7px;
  }

  .public-hero::after {
    right: 10px;
    top: 28px;
    transform: rotate(-8deg);
    font-size: 90px;
  }

  .hero-actions {
    display: grid;
    grid-template-columns: 1fr;
  }

  .hero-actions .button {
    width: 100%;
  }

  .auth-card {
    border-radius: 20px;
  }

  .site-footer {
    width: calc(100vw - 28px);
    flex-direction: column;
    margin-top: 28px;
  }
}

/* ==========================================================================
   V64 RESPONSIVE ADMIN EXPERIENCE
   Desktop, Tablet und Mobile
   ========================================================================== */

html {
  scroll-behavior: smooth;
  scroll-padding-top: 92px;
}

button,
.button,
summary,
select,
input[type="checkbox"] {
  touch-action: manipulation;
}

/* Kompakte Hauptnavigation */
.desktop-nav {
  gap: 5px;
}

.desktop-nav > a,
.admin-nav-menu > summary {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 9px 11px;
  border-radius: 12px;
  color: var(--muted);
  font-weight: 800;
  cursor: pointer;
}

.desktop-nav > a.active,
.admin-nav-menu > summary.active {
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 9%, white);
}

.nav-logout {
  width: 42px;
  justify-content: center;
  font-size: 21px;
  color: var(--muted) !important;
}

.admin-nav-menu {
  position: relative;
}

.admin-nav-menu > summary {
  list-style: none;
}

.admin-nav-menu > summary::-webkit-details-marker {
  display: none;
}

.admin-nav-menu[open] > summary {
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 9%, white);
}

.admin-nav-popover {
  position: absolute;
  z-index: 60;
  top: calc(100% + 10px);
  right: 0;
  width: 310px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: rgba(255,255,255,.98);
  box-shadow: 0 24px 60px rgba(15,23,42,.18);
  display: grid;
  gap: 4px;
}

.admin-nav-popover a {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 11px;
  align-items: center;
  padding: 10px;
  border-radius: 13px;
}

.admin-nav-popover a:hover {
  background: color-mix(in srgb, var(--primary) 7%, white);
}

.admin-nav-popover a > span:first-child {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 10%, white);
  font-size: 18px;
}

.admin-nav-popover strong,
.admin-nav-popover small {
  display: block;
}

.admin-nav-popover strong {
  color: var(--text);
  font-size: 14px;
}

.admin-nav-popover small {
  margin-top: 2px;
  color: var(--muted);
  font-size: 12px;
  font-weight: 600;
}

/* Admin-Kopf und Bereichsnavigation */
.split-admin-hero {
  min-height: 180px;
  display: flex !important;
  align-items: center;
  gap: 24px;
  padding: clamp(24px, 4vw, 40px) !important;
  overflow: hidden;
  position: relative;
  background:
    radial-gradient(circle at 92% 10%, color-mix(in srgb, var(--primary) 16%, transparent), transparent 38%),
    #fff !important;
}

.admin-hero-icon {
  width: 82px;
  height: 82px;
  flex: 0 0 82px;
  display: grid;
  place-items: center;
  border-radius: 24px;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  box-shadow: 0 18px 36px color-mix(in srgb, var(--primary) 24%, transparent);
  font-size: 32px;
}

.split-admin-hero h1 {
  margin: 4px 0 8px;
  font-size: clamp(32px, 4vw, 48px);
}

.split-admin-hero .muted {
  margin: 0;
  max-width: 680px;
  font-size: 17px;
}

.admin-tabs.card {
  position: sticky;
  top: 78px;
  z-index: 8;
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
  padding: 8px;
  border-radius: 18px;
  backdrop-filter: blur(18px);
}

.admin-tabs a {
  min-height: 46px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 12px;
  white-space: nowrap;
}

.admin-tabs a span {
  font-size: 17px;
}

/* Kennzahlen und Aufgaben */
.admin-kpis {
  grid-template-columns: repeat(4, minmax(0, 1fr)) !important;
  gap: 16px !important;
}

.admin-kpis .kpi {
  min-height: 145px;
  display: grid;
  grid-template-columns: 44px 1fr;
  grid-template-rows: auto auto;
  column-gap: 13px;
  align-items: center;
  padding: 20px !important;
  margin: 0;
}

.kpi-icon {
  width: 44px;
  height: 44px;
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  border-radius: 14px;
  font-size: 20px;
  font-weight: 900;
}

.kpi-icon.warning { color: #92400e; background: #fef3c7; }
.kpi-icon.info { color: #075985; background: #e0f2fe; }
.kpi-icon.success { color: #166534; background: #dcfce7; }
.kpi-icon.danger { color: #991b1b; background: #fee2e2; }

.admin-kpis .kpi strong {
  align-self: end;
  font-size: clamp(30px, 4vw, 44px);
  line-height: 1;
}

.admin-kpis .kpi > span:last-child {
  align-self: start;
  color: var(--muted);
  font-size: 13px;
  font-weight: 750;
}

.today-task-box {
  border: 1px solid var(--border);
  background: linear-gradient(180deg, #fff, #f8fbff);
  box-shadow: none;
}

.section-title-row h2 {
  margin-bottom: 6px;
}

/* Technik-Schnellnavigation */
.tech-jump-nav {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  padding: 10px;
}

.tech-jump-nav a {
  min-height: 54px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  border-radius: 13px;
  color: var(--text);
  background: #f6f9fc;
  border: 1px solid var(--border);
  font-weight: 800;
}

.tech-jump-nav a:hover {
  color: var(--primary);
  border-color: color-mix(in srgb, var(--primary) 28%, white);
  background: color-mix(in srgb, var(--primary) 7%, white);
}

#design,
#regeln,
#email,
#backup,
#audit {
  scroll-margin-top: 150px;
}

/* Persönlicher Bereich */
.reservation-page-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 22px;
  margin-bottom: 24px;
}

.reservation-page-head h1 {
  margin: 4px 0 8px;
}

.reservation-page-head p {
  margin-bottom: 0;
}

.reservation-page-head .eyebrow {
  color: var(--primary);
}

.reservation-count {
  width: 96px;
  height: 82px;
  flex: 0 0 96px;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 20px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 9%, white);
  border: 1px solid color-mix(in srgb, var(--primary) 22%, white);
  font-size: 30px;
  font-weight: 950;
}

.reservation-count small {
  color: var(--muted);
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.empty-state {
  padding: 36px 18px;
  text-align: center;
  border: 1px dashed color-mix(in srgb, var(--primary) 30%, var(--border));
  border-radius: 20px;
  background: color-mix(in srgb, var(--primary) 4%, white);
}

.empty-state > span,
.empty-state > strong,
.empty-state > p {
  display: block;
}

.empty-state > span { font-size: 42px; }
.empty-state > strong { margin-top: 10px; font-size: 18px; }
.empty-state > p { margin: 7px auto 18px; color: var(--muted); }

/* Tablet */
@media (max-width: 1100px) {
  .topbar {
    padding-inline: 18px;
  }

  .brand > span:last-child {
    max-width: 180px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }

  .desktop-nav > a,
  .admin-nav-menu > summary {
    padding-inline: 9px;
    font-size: 14px;
  }

  .admin-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .admin-kpis .kpi {
    min-height: 120px;
  }

  .today-task-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .today-task-box:last-child {
    grid-column: 1 / -1;
  }

  .reservation-filter-bar {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }

  .tech-jump-nav {
    grid-template-columns: repeat(5, minmax(100px, 1fr));
    overflow-x: auto;
  }
}

@media (min-width: 761px) and (max-width: 900px) {
  .brand > span:last-child {
    display: none;
  }

  .admin-tabs.card {
    grid-template-columns: repeat(4, minmax(145px, 1fr));
    overflow-x: auto;
    justify-content: start;
  }

  .admin-tabs a {
    width: auto !important;
  }

  .admin-grid {
    grid-template-columns: 1fr !important;
  }
}

/* Handy */
@media (max-width: 760px) {
  body {
    font-size: 15px;
  }

  button,
  .button,
  input,
  select,
  textarea {
    min-height: 44px;
  }

  .mobile-menu-label {
    padding: 10px 12px 4px;
    color: var(--muted);
    font-size: 11px;
    font-weight: 900;
    letter-spacing: .1em;
    text-transform: uppercase;
  }

  .mobile-menu nav a {
    min-height: 46px;
    display: flex;
    align-items: center;
  }

  .mobile-menu nav .mobile-logout {
    margin-top: 4px;
    color: #991b1b;
    background: #fff1f2;
  }

  .split-admin-hero {
    min-height: 0;
    gap: 15px;
    padding: 20px !important;
    border-radius: 20px !important;
  }

  .admin-hero-icon {
    width: 58px;
    height: 58px;
    flex-basis: 58px;
    border-radius: 17px;
    font-size: 23px;
  }

  .split-admin-hero h1 {
    font-size: 27px !important;
  }

  .split-admin-hero .muted {
    font-size: 14px;
    line-height: 1.45;
  }

  .admin-tabs.card {
    display: none !important;
  }

  .admin-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  .admin-kpis .kpi {
    min-height: 112px;
    grid-template-columns: 34px 1fr;
    column-gap: 9px;
    padding: 14px !important;
    border-radius: 18px;
  }

  .kpi-icon {
    width: 34px;
    height: 34px;
    border-radius: 11px;
    font-size: 16px;
  }

  .admin-kpis .kpi strong {
    font-size: 29px;
  }

  .admin-kpis .kpi > span:last-child {
    font-size: 11px;
    line-height: 1.3;
  }

  .today-task-grid {
    grid-template-columns: 1fr !important;
  }

  .today-task-box:last-child {
    grid-column: auto;
  }

  .section-title-row {
    align-items: stretch !important;
  }

  .section-title-row > form,
  .section-title-row > form button {
    width: 100%;
  }

  .reservation-filter-bar {
    grid-template-columns: 1fr !important;
    padding: 12px !important;
  }

  .reservation-filter-actions,
  .reservation-filter-actions > * {
    width: 100%;
  }

  .reservation-workitem summary {
    grid-template-columns: 70px minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 12px !important;
  }

  .workitem-status,
  .workitem-toggle {
    grid-column: 2;
    justify-self: start !important;
  }

  .workitem-details {
    padding: 14px !important;
  }

  .workitem-actions,
  .workitem-actions form,
  .workitem-actions button {
    width: 100%;
  }

  .tech-jump-nav {
    grid-template-columns: repeat(5, 92px);
    padding: 8px;
  }

  .tech-jump-nav a {
    min-height: 58px;
    flex-direction: column;
    gap: 3px;
    font-size: 16px;
  }

  .tech-jump-nav a span {
    font-size: 11px;
  }

  .smtp-form,
  .rules-form,
  .user-create-form,
  .ticket-form-grid.two,
  .modal-date-grid {
    grid-template-columns: 1fr !important;
  }

  /* Breite Benutzertabelle wird zu echten Karten */
  .responsive-table {
    overflow: visible !important;
  }

  .responsive-table table,
  .responsive-table tbody,
  .responsive-table tr,
  .responsive-table td {
    display: block;
    width: 100%;
  }

  .responsive-table thead {
    display: none;
  }

  .responsive-table tr {
    margin-bottom: 14px;
    padding: 14px;
    border: 1px solid var(--border);
    border-radius: 17px;
    background: #fff;
    box-shadow: 0 8px 20px rgba(15,23,42,.05);
  }

  .responsive-table td {
    min-height: 0;
    padding: 8px 0 !important;
    border: 0 !important;
    overflow-wrap: anywhere;
  }

  .responsive-table td::before {
    display: block;
    margin-bottom: 4px;
    color: var(--muted);
    font-size: 10px;
    font-weight: 900;
    letter-spacing: .08em;
    text-transform: uppercase;
  }

  .responsive-table td:nth-child(1)::before { content: "Name"; }
  .responsive-table td:nth-child(2)::before { content: "E-Mail"; }
  .responsive-table td:nth-child(3)::before { content: "Rolle"; }
  .responsive-table td:nth-child(4)::before { content: "Status"; }
  .responsive-table td:nth-child(5)::before { content: "Bearbeiten"; }
  .responsive-table td:nth-child(6)::before { content: "Aktionen"; }

  .user-edit {
    min-width: 0 !important;
    grid-template-columns: 1fr !important;
  }

  .user-edit input,
  .user-edit button,
  .actions-cell form,
  .actions-cell button {
    width: 100%;
  }

  .reservation-page-head {
    align-items: flex-start;
  }

  .reservation-page-head h1 {
    font-size: 29px;
  }

  .reservation-count {
    width: 68px;
    height: 68px;
    flex-basis: 68px;
    border-radius: 17px;
    font-size: 23px;
  }

  .reservation-count small {
    font-size: 8px;
  }

  .reservation-modal {
    width: calc(100vw - 20px) !important;
    max-height: calc(100dvh - 20px);
    overflow-y: auto;
    padding: 18px !important;
    border-radius: 20px !important;
  }

  .modal-actions {
    display: grid !important;
    grid-template-columns: 1fr;
  }

  .modal-actions button {
    width: 100%;
  }
}

@media (max-width: 430px) {
  .admin-kpis {
    grid-template-columns: 1fr 1fr !important;
  }

  .calendar-header h2 {
    font-size: 22px !important;
  }

  .calendar-day {
    min-height: 68px !important;
  }

  .day-capacity span {
    display: none !important;
  }
}
@media (min-width: 761px) {
  .reservation-list-mobile { display: none !important; }
}
.ticket-meta { margin-top: 8px; font-size: 13px; color: var(--muted); }
.day-button.compact { margin-top: 4px; padding: 5px 6px; font-size: 12px; }
.pill.pending { background: #fef3c7; color: #92400e; }
.pill.booked, .pill.sent { background: #dcfce7; color: #166534; }
@media (max-width: 760px) {
  .ticket-meta { font-size: 12px; }
  .day-button.compact { font-size: 9px; padding: 3px 1px; }
}

/* V65: Kalenderaktion mit sichtbarem Innenabstand */
.calendar-day .day-button,
.calendar-day .day-button.compact {
  height: 30px !important;
  min-height: 30px !important;
  padding: 0 10px !important;
  border-radius: 8px !important;
  font-size: 11px !important;
  font-weight: 850 !important;
  letter-spacing: -0.015em !important;
  line-height: 1 !important;
  text-overflow: clip !important;
}

/* Frühere Plus-Regeln auf Desktop und Tablet gezielt aufheben. */
@media (min-width: 761px) {
  .calendar-day .day-button::after,
  .calendar-day .day-button.compact::after {
    content: none !important;
    display: none !important;
  }
}

/* Auf sehr schmalen Handys bleibt die Aktion bewusst kompakt. */
@media (max-width: 760px) {
  .calendar-day .day-button,
  .calendar-day .day-button.compact {
    padding: 0 !important;
    font-size: 0 !important;
  }

  .calendar-day .day-button::after,
  .calendar-day .day-button.compact::after {
    content: "+" !important;
    display: block !important;
    color: #fff !important;
    font-size: 18px !important;
    line-height: 1 !important;
  }
}

/* V66: Prozesswarnung für nicht bestätigte Abholungen */
.attention-task-box {
  grid-column: 1 / -1;
  border-color: #fcd34d !important;
  background: linear-gradient(135deg, #fffbeb, #fff) !important;
}

.attention-task-heading {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 12px;
}

.attention-task-heading > span {
  width: 34px;
  height: 34px;
  flex: 0 0 34px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  color: #92400e;
  background: #fef3c7;
  font-weight: 950;
}

.attention-task-heading h3,
.attention-task-heading p {
  margin: 0;
}

.attention-task-heading p {
  margin-top: 3px;
  color: #92400e;
  font-size: 13px;
}

.attention-task-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}

.attention-task-list .today-task-item {
  border-color: #fde68a;
  background: rgba(255,255,255,.82);
}

@media (max-width: 760px) {
  .attention-task-list {
    grid-template-columns: 1fr;
  }
}

/* ==========================================================================
   V67 RUHIGE RESERVATIONSDETAILS
   ========================================================================== */

.workitem-details {
  display: grid;
  gap: 16px;
  background: #fff !important;
}

.reservation-timeline {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 34px minmax(0, 1fr) 34px minmax(0, 1fr);
  align-items: center;
  padding: 18px 20px;
  border: 1px solid var(--border);
  border-radius: 18px;
  background: #f8fafc;
}

.timeline-step {
  min-width: 0;
  display: grid;
  grid-template-columns: 38px 1fr;
  grid-template-rows: auto auto;
  column-gap: 10px;
  align-items: center;
}

.timeline-icon {
  width: 38px;
  height: 38px;
  grid-row: 1 / 3;
  display: grid;
  place-items: center;
  border-radius: 12px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 9%, white);
  font-weight: 900;
}

.timeline-step.primary .timeline-icon {
  color: #fff;
  background: var(--primary);
}

.timeline-step small {
  align-self: end;
  color: var(--muted);
  font-size: 11px;
  font-weight: 850;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.timeline-step strong {
  align-self: start;
  margin-top: 2px;
  color: var(--text);
  font-size: 15px;
  white-space: nowrap;
}

.timeline-line {
  height: 2px;
  background: color-mix(in srgb, var(--primary) 22%, var(--border));
}

.availability-check.availability-status {
  display: grid !important;
  grid-template-columns: 40px minmax(0, 1fr) !important;
  gap: 12px !important;
  align-items: center !important;
  padding: 16px !important;
  border-radius: 16px !important;
  box-shadow: none !important;
}

.availability-status.status-ok {
  border: 1px solid #86efac !important;
  background: #f0fdf4 !important;
}

.availability-status.status-error {
  border: 1px solid #fca5a5 !important;
  background: #fef2f2 !important;
}

.availability-status-icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: 13px;
  color: #166534;
  background: #dcfce7;
  font-size: 19px;
  font-weight: 950;
}

.status-error .availability-status-icon {
  color: #991b1b;
  background: #fee2e2;
}

.availability-status .availability-head {
  display: block !important;
  margin: 0 !important;
}

.availability-status .availability-head strong,
.availability-status .availability-head span {
  display: block;
}

.availability-status .availability-head strong {
  color: #166534;
  font-size: 16px;
}

.status-error .availability-head strong {
  color: #991b1b;
}

.availability-status .availability-head span {
  margin-top: 3px;
  color: var(--muted);
  font-size: 13px;
  font-weight: 650;
}

.availability-status .availability-days {
  grid-column: 1 / -1;
  margin: 4px 0 0 !important;
  border: 0 !important;
  background: transparent !important;
}

.availability-status .availability-days > summary {
  min-height: 42px;
  display: flex;
  align-items: center;
  padding: 8px 12px !important;
  border: 1px solid color-mix(in srgb, #22c55e 25%, var(--border));
  border-radius: 11px;
  color: var(--primary);
  background: rgba(255,255,255,.72) !important;
  font-size: 13px;
  font-weight: 800;
}

.availability-day-grid {
  margin-top: 8px;
}

.availability-day {
  min-height: 68px !important;
  grid-template-columns: 72px 1fr !important;
  grid-template-rows: auto auto !important;
  padding: 11px 14px !important;
  border-radius: 13px !important;
}

.availability-day > strong {
  grid-row: 1 / 3;
  align-self: center;
}

.availability-day em {
  font-style: normal;
  font-weight: 850;
}

.period-details {
  margin: 0 !important;
  border: 1px solid var(--border) !important;
  border-radius: 16px !important;
  background: #fff !important;
  overflow: hidden;
}

.period-details > summary {
  min-height: 54px;
  display: flex !important;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 16px !important;
  color: var(--text) !important;
  background: #f8fafc !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}

.period-details > summary small {
  padding: 4px 8px;
  border-radius: 999px;
  color: var(--muted);
  background: #e9eef5;
  font-size: 10px;
  letter-spacing: .06em;
  text-transform: uppercase;
}

.period-details[open] > summary {
  border-bottom: 1px solid var(--border);
}

.period-edit-form-v49 {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  gap: 14px !important;
  padding: 18px !important;
  background: #fff !important;
}

.period-field-v49 input[type="date"] {
  -webkit-appearance: auto !important;
  appearance: auto !important;
  line-height: normal !important;
}

.period-note-v49,
.period-actions-v49 {
  grid-column: 1 / -1 !important;
}

.period-actions-v49 button {
  min-width: 170px;
}

.small-info {
  margin: 0 !important;
  padding: 10px 12px;
  border-left: 3px solid var(--primary);
  border-radius: 0 10px 10px 0;
  background: color-mix(in srgb, var(--primary) 5%, white);
}

.workitem-actions {
  justify-content: flex-start !important;
  padding-top: 4px !important;
  border-top: 0 !important;
}

.workitem-actions .primary-action {
  min-height: 42px;
  padding-inline: 18px;
}

.workitem-actions .cancel-action {
  color: #991b1b !important;
  background: #fff !important;
  border: 1px solid #fecaca !important;
}

.danger-actions {
  justify-self: end;
  width: min(100%, 430px);
  margin-top: -6px;
  border-radius: 12px;
}

.danger-actions > summary {
  padding: 8px 10px;
  color: var(--muted);
  text-align: right;
  font-size: 12px;
  font-weight: 750;
}

.danger-actions > div {
  padding: 12px;
  border: 1px solid #fecaca;
  border-radius: 12px;
  background: #fff7f7;
}

.danger-actions p {
  margin: 0 0 10px;
  color: #991b1b;
  font-size: 12px;
}

@media (max-width: 900px) {
  .period-edit-form-v49 {
    grid-template-columns: 1fr 1fr !important;
  }

  .period-field-v49:nth-of-type(3) {
    grid-column: 1 / -1;
  }
}

@media (max-width: 760px) {
  .workitem-details {
    gap: 12px;
  }

  .reservation-timeline {
    grid-template-columns: minmax(0, 1fr) 12px minmax(0, 1fr) 12px minmax(0, 1fr);
    padding: 12px 8px;
  }

  .timeline-step {
    display: flex;
    flex-direction: column;
    text-align: center;
  }

  .timeline-icon {
    width: 32px;
    height: 32px;
    margin-bottom: 6px;
    border-radius: 10px;
  }

  .timeline-step small {
    font-size: 8px;
  }

  .timeline-step strong {
    font-size: 11px;
  }

  .availability-check.availability-status {
    grid-template-columns: 34px minmax(0, 1fr) !important;
    padding: 12px !important;
  }

  .availability-status-icon {
    width: 34px;
    height: 34px;
    border-radius: 10px;
  }

  .availability-day {
    grid-template-columns: 58px 1fr !important;
  }

  .period-edit-form-v49 {
    grid-template-columns: 1fr !important;
    padding: 14px !important;
  }

  .period-field-v49:nth-of-type(3),
  .period-note-v49,
  .period-actions-v49 {
    grid-column: auto !important;
  }

  .period-actions-v49 button,
  .danger-actions,
  .danger-actions form,
  .danger-actions button {
    width: 100%;
  }

  .danger-actions {
    justify-self: stretch;
  }
}

/* ==========================================================================
   V68 PASSWORTLOSES LOGIN
   ========================================================================== */

.passwordless-card {
  position: relative;
}

.auth-method-icon,
.code-mail-icon,
.approval-icon {
  width: 54px;
  height: 54px;
  display: grid;
  place-items: center;
  margin-bottom: 18px;
  border-radius: 17px;
  color: var(--primary);
  background: color-mix(in srgb, var(--primary) 10%, white);
  font-size: 24px;
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--primary) 18%, white);
}

.auth-process-note {
  display: grid;
  grid-template-columns: 26px 1fr;
  gap: 9px;
  margin-top: 18px;
  padding: 12px;
  border-radius: 13px;
  color: #166534;
  background: #f0fdf4;
  font-size: 12px;
  line-height: 1.45;
}

.auth-process-note > span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: #dcfce7;
  font-weight: 900;
}

.auth-process-note p {
  margin: 3px 0 0;
}

.auth-fallback {
  margin-top: 20px;
  padding-top: 18px;
  border-top: 1px solid var(--border);
}

.auth-fallback > summary {
  padding: 8px 0;
  color: var(--muted);
  text-align: center;
  font-size: 13px;
  font-weight: 800;
}

.auth-fallback[open] > summary {
  margin-bottom: 14px;
  color: var(--primary);
}

.auth-fallback .password-submit {
  color: var(--text) !important;
  background: #e9eef5 !important;
}

.forgot-link,
.back-link {
  display: block;
  margin-top: 14px;
  color: var(--primary);
  text-align: center;
  font-size: 13px;
  font-weight: 800;
}

.code-login-shell {
  min-height: min(680px, calc(100vh - 190px));
  display: grid;
  place-items: center;
}

.code-login-card,
.approval-wait-card {
  width: min(100%, 560px);
  padding: clamp(26px, 5vw, 46px);
  text-align: center;
}

.code-mail-icon,
.approval-icon {
  margin-inline: auto;
}

.code-login-card h1,
.approval-wait-card h1 {
  margin: 6px 0 12px;
  font-size: clamp(30px, 5vw, 42px);
  line-height: 1.05;
  letter-spacing: -.045em;
}

.code-form {
  margin-top: 26px;
  text-align: left;
}

.code-form > label {
  text-align: center;
}

.code-input {
  height: 68px !important;
  min-height: 68px !important;
  padding: 0 12px !important;
  border: 2px solid color-mix(in srgb, var(--primary) 24%, var(--border)) !important;
  border-radius: 17px !important;
  color: var(--text);
  text-align: center;
  font-size: 34px !important;
  font-weight: 900;
  letter-spacing: .28em;
  font-variant-numeric: tabular-nums;
}

.code-help {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 5px;
  margin-top: 18px;
  color: var(--muted);
  font-size: 13px;
}

.link-button {
  min-height: 0 !important;
  padding: 0 !important;
  border: 0 !important;
  color: var(--primary) !important;
  background: transparent !important;
  box-shadow: none !important;
  font-size: 13px !important;
}

.approval-icon {
  color: #92400e;
  background: #fef3c7;
}

.approval-steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin: 28px 0;
}

.approval-steps span {
  display: grid;
  justify-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 11px;
}

.approval-steps i {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 99px;
  background: #e9eef5;
  font-style: normal;
  font-weight: 900;
}

.approval-steps .done i {
  color: #166534;
  background: #dcfce7;
}

.approval-steps .current {
  color: #92400e;
}

.approval-steps .current i {
  color: #92400e;
  background: #fef3c7;
  box-shadow: 0 0 0 4px #fffbeb;
}

.tech-jump-nav {
  grid-template-columns: repeat(6, minmax(0, 1fr));
}

#login {
  scroll-margin-top: 150px;
}

.login-settings-card {
  border-color: color-mix(in srgb, var(--primary) 18%, var(--border));
}

.login-setting-badge {
  padding: 7px 11px;
  border-radius: 999px;
  color: var(--muted);
  background: #e9eef5;
  font-size: 12px;
  font-weight: 900;
}

.login-setting-badge.enabled {
  color: #166534;
  background: #dcfce7;
}

.login-settings-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  margin-top: 24px;
}

.login-setting-options,
.login-settings-form .full-row,
.login-settings-note,
.login-settings-form > button {
  grid-column: 1 / -1;
}

.login-setting-options {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.setting-toggle {
  grid-template-columns: auto 1fr;
  align-items: center;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 15px;
  background: #f8fafc;
}

.setting-toggle input {
  width: 22px;
  height: 22px;
}

.setting-toggle strong,
.setting-toggle small {
  display: block;
}

.setting-toggle small {
  margin-top: 3px;
  color: var(--muted);
  font-weight: 600;
}

.login-settings-form textarea {
  min-height: 150px;
}

.login-settings-form label > small {
  color: var(--muted);
  font-weight: 600;
}

.login-settings-note {
  display: grid;
  gap: 4px;
  padding: 14px;
  border-left: 4px solid var(--primary);
  border-radius: 0 13px 13px 0;
  background: color-mix(in srgb, var(--primary) 6%, white);
}

.login-settings-note span {
  color: var(--muted);
  font-size: 13px;
}

.login-settings-form > button {
  justify-self: start;
}

@media (max-width: 900px) {
  .tech-jump-nav {
    grid-template-columns: repeat(6, minmax(96px, 1fr));
  }
}

@media (max-width: 760px) {
  .code-login-shell {
    min-height: 0;
  }

  .code-login-card,
  .approval-wait-card {
    padding: 24px 18px;
    border-radius: 20px;
  }

  .code-input {
    font-size: 29px !important;
  }

  .approval-steps strong {
    font-size: 9px;
  }

  .login-settings-form,
  .login-setting-options {
    grid-template-columns: 1fr;
  }

  .login-setting-options,
  .login-settings-form .full-row,
  .login-settings-note,
  .login-settings-form > button {
    grid-column: auto;
  }

  .login-settings-form > button {
    width: 100%;
  }
}

/* ==========================================================================
   V69 PROFILABSCHLUSS & BENUTZER-FREIGABEWORKFLOW
   ========================================================================== */

.nav-count {
  min-width: 20px;
  height: 20px;
  display: inline-grid;
  place-items: center;
  margin-left: 4px;
  padding: 0 6px;
  border-radius: 99px;
  color: #fff;
  background: #dc2626;
  font-size: 11px;
  font-weight: 950;
  line-height: 1;
}

.profile-completion-card {
  width: min(100%, 600px);
  padding: clamp(26px, 5vw, 46px);
  text-align: center;
}

.profile-completion-card h1 {
  margin: 6px 0 10px;
  font-size: clamp(32px, 5vw, 44px);
  letter-spacing: -.05em;
}

.profile-icon {
  width: 56px;
  height: 56px;
  display: grid;
  place-items: center;
  margin: 0 auto 18px;
  border-radius: 18px;
  color: #fff;
  background: linear-gradient(135deg, var(--primary), var(--accent));
  font-size: 26px;
  box-shadow: 0 14px 30px color-mix(in srgb, var(--primary) 22%, transparent);
}

.verified-email {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 14px auto 24px;
  padding: 9px 13px;
  border-radius: 999px;
  color: #166534;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  font-size: 13px;
}

.verified-email > span {
  width: 20px;
  height: 20px;
  display: grid;
  place-items: center;
  border-radius: 99px;
  background: #dcfce7;
  font-size: 11px;
  font-weight: 900;
}

.profile-completion-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  text-align: left;
}

.profile-completion-form > button {
  grid-column: 1 / -1;
  min-height: 48px;
}

.profile-privacy-note {
  margin: 16px 0 0;
  color: var(--muted);
  font-size: 12px;
}

.pending-users-workflow {
  border-color: var(--border);
  overflow: hidden;
}

.pending-users-workflow.has-pending {
  border-color: #fcd34d;
  box-shadow: 0 18px 44px rgba(180,83,9,.09);
}

.pending-workflow-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 24px;
  margin-bottom: 20px;
}

.pending-workflow-head h2 {
  margin: 4px 0 7px;
  font-size: 27px;
}

.pending-workflow-head p {
  margin-bottom: 0;
  max-width: 760px;
}

.pending-workflow-head .eyebrow {
  color: #b45309;
}

.pending-user-kpi {
  width: 84px;
  height: 76px;
  flex: 0 0 84px;
  display: grid;
  place-items: center;
  align-content: center;
  border-radius: 19px;
  color: #92400e;
  background: #fef3c7;
  border: 1px solid #fde68a;
}

.pending-user-kpi strong {
  font-size: 28px;
  line-height: 1;
}

.pending-user-kpi small {
  margin-top: 3px;
  font-size: 10px;
  font-weight: 900;
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pending-user-list {
  display: grid;
  gap: 10px;
}

.pending-user-card {
  display: grid;
  grid-template-columns: 50px minmax(0, 1fr) auto auto;
  gap: 14px;
  align-items: center;
  padding: 14px;
  border: 1px solid #fde68a;
  border-radius: 16px;
  background: linear-gradient(135deg, #fffbeb, #fff);
}

.pending-user-avatar {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: 15px;
  color: #fff;
  background: linear-gradient(135deg, #d97706, #f59e0b);
  font-weight: 950;
}

.pending-user-identity {
  min-width: 0;
}

.pending-user-identity strong,
.pending-user-identity span,
.pending-user-identity small {
  display: block;
}

.pending-user-identity strong {
  font-size: 16px;
}

.pending-user-identity span {
  margin-top: 2px;
  color: var(--text);
  overflow-wrap: anywhere;
}

.pending-user-identity small {
  margin-top: 4px;
  color: var(--muted);
}

.pending-user-state {
  display: grid;
  justify-items: end;
  gap: 4px;
}

.pending-user-state small {
  color: #166534;
  font-size: 10px;
  font-weight: 800;
}

.pending-user-actions {
  display: flex;
  gap: 8px;
}

.pending-user-actions form,
.pending-user-actions button {
  min-width: 0;
}

.pending-user-actions .reject-user {
  color: #991b1b !important;
  background: #fff !important;
  border: 1px solid #fecaca !important;
}

.pending-empty-state {
  display: flex;
  align-items: center;
  gap: 13px;
  padding: 18px;
  border: 1px dashed #86efac;
  border-radius: 15px;
  background: #f0fdf4;
}

.pending-empty-state > span {
  width: 38px;
  height: 38px;
  flex: 0 0 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  color: #166534;
  background: #dcfce7;
  font-weight: 950;
}

.pending-empty-state strong,
.pending-empty-state p {
  display: block;
  margin: 0;
}

.pending-empty-state p {
  margin-top: 2px;
  color: var(--muted);
  font-size: 13px;
}

@media (max-width: 900px) {
  .pending-user-card {
    grid-template-columns: 50px minmax(0, 1fr) auto;
  }

  .pending-user-state {
    grid-column: 2;
    justify-items: start;
  }

  .pending-user-actions {
    grid-column: 3;
    grid-row: 1 / 3;
    flex-direction: column;
  }
}

@media (max-width: 760px) {
  .profile-completion-card {
    padding: 24px 18px;
    border-radius: 20px;
  }

  .profile-completion-form {
    grid-template-columns: 1fr;
  }

  .profile-completion-form > button {
    grid-column: auto;
  }

  .pending-workflow-head {
    align-items: flex-start;
  }

  .pending-workflow-head h2 {
    font-size: 23px;
  }

  .pending-user-kpi {
    width: 66px;
    height: 62px;
    flex-basis: 66px;
  }

  .pending-user-kpi strong {
    font-size: 23px;
  }

  .pending-user-card {
    grid-template-columns: 44px minmax(0, 1fr);
    padding: 12px;
  }

  .pending-user-avatar {
    width: 44px;
    height: 44px;
    border-radius: 13px;
  }

  .pending-user-state,
  .pending-user-actions {
    grid-column: 1 / -1;
    grid-row: auto;
  }

  .pending-user-actions {
    display: grid;
    grid-template-columns: 1fr 1fr;
    width: 100%;
  }

  .pending-user-actions form,
  .pending-user-actions button {
    width: 100%;
  }
}

/* V70: Hinweis für Security-Code AutoFill */
.code-autofill-help {
  display: block;
  margin-top: -6px;
  color: var(--muted);
  text-align: center;
  font-size: 12px;
  font-weight: 600;
  line-height: 1.4;
}
