:root{--bg:#f4f6fb;--card:#ffffff;--text:#111827;--muted:#6b7280;--line:#e5e7eb;--brand:#2563eb;--danger:#dc2626;--ok:#16a34a;--warn:#f59e0b}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font:15px/1.45 system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}.topbar{position:sticky;top:0;z-index:20;display:flex;align-items:center;justify-content:space-between;padding:14px 24px;background:rgba(255,255,255,.92);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}.brand a{font-weight:800;color:var(--text);text-decoration:none}.topbar nav{display:flex;gap:14px;flex-wrap:wrap}.topbar nav a{color:#374151;text-decoration:none;font-weight:600}.topbar nav a:hover{color:var(--brand)}.container{max-width:1380px;margin:0 auto;padding:22px}.footer{text-align:center;color:var(--muted);padding:24px}.card{background:var(--card);border:1px solid var(--line);border-radius:18px;box-shadow:0 8px 24px rgba(15,23,42,.06);padding:22px;margin-bottom:18px}.card.narrow{max-width:460px;margin:50px auto}.card.wide{min-width:0}.card.side{height:max-content}.grid{display:grid;gap:18px}.grid.two{grid-template-columns:minmax(0,2fr) minmax(320px,1fr)}h1,h2,h3{margin:0 0 12px}p{margin:0 0 12px}.muted{color:var(--muted)}.small{font-size:13px}.form{display:grid;gap:12px}.form.compact{gap:10px}.form label{display:grid;gap:5px;font-weight:650}.form input,.form select,.form textarea,.copy,.inline input,.userrow input{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;font:inherit}.form .check{display:flex;grid-template-columns:none;align-items:center;gap:10px;font-weight:500}.form .check input{width:auto}.btn{display:inline-flex;align-items:center;justify-content:center;border:0;border-radius:11px;padding:10px 14px;background:var(--brand);color:#fff;text-decoration:none;font-weight:700;cursor:pointer}.btn:hover{filter:brightness(.95)}.btn.ghost{background:#eef2ff;color:#1f2937}.btn.danger{background:var(--danger)}.btn.small{padding:6px 10px;border-radius:9px;font-size:13px}.flash{padding:12px 14px;border-radius:12px;margin-bottom:16px;background:#eff6ff;border:1px solid #bfdbfe}.flash.success{background:#ecfdf5;border-color:#bbf7d0}.flash.error{background:#fef2f2;border-color:#fecaca}.flash.warning{background:#fffbeb;border-color:#fde68a}.split{display:flex;justify-content:space-between;gap:16px;align-items:flex-start}.legend{display:flex;gap:10px;flex-wrap:wrap;justify-content:flex-end}.legend span{display:inline-flex;align-items:center;gap:6px;background:#f9fafb;border:1px solid var(--line);border-radius:999px;padding:5px 9px}.legend i,.dot{width:11px;height:11px;border-radius:50%;display:inline-block}.table{width:100%;border-collapse:collapse}.table th,.table td{text-align:left;border-bottom:1px solid var(--line);padding:9px 8px}.table th{font-size:13px;color:var(--muted);font-weight:800}.inline{display:flex;gap:8px;align-items:end;flex-wrap:wrap}.mt{margin-top:12px}.userrow{display:grid;grid-template-columns:1.1fr 1.4fr 50px 140px 140px auto;gap:8px;align-items:center;margin-bottom:8px}.fc .fc-button{border-radius:10px!important}.fc .fc-toolbar-title{font-size:1.4rem!important}.fc-event{border-radius:8px!important;padding:2px 4px}.fc-bg-event{opacity:.45!important}@media(max-width:900px){.grid.two{grid-template-columns:1fr}.topbar{align-items:flex-start;gap:10px;flex-direction:column}.split{flex-direction:column}.legend{justify-content:flex-start}.userrow{grid-template-columns:1fr}.container{padding:14px}}
.draft-filter{margin-bottom:10px}.mt{margin-top:12px}.fc-event[style*="rgb"]{font-weight:650}.fc-event-title{font-weight:700}.legend .muted{opacity:.75}.color-preview{display:inline-flex;align-items:center;gap:8px}.color-preview input[type=color]{width:52px;padding:3px;height:38px}
.inline select,.inline textarea{border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;font:inherit}.tablewrap{overflow:auto}.table input[type=checkbox]{transform:scale(1.1)}code{background:#f3f4f6;border:1px solid var(--line);border-radius:6px;padding:1px 5px}.btn + .btn{margin-left:6px}
.user-admin-card{border:1px solid var(--line);border-radius:14px;padding:10px;margin-bottom:10px;background:#fbfdff}.delete-user-form{display:flex;gap:10px;align-items:center;flex-wrap:wrap;margin-top:8px}.delete-user-form .check{display:flex;align-items:center;gap:7px;margin:0}.delete-user-form input[type=checkbox]{width:auto}.danger-zone{border-color:#fecaca;background:#fff7f7}

.alertcard { border: 2px solid #f59e0b; background: #fffbeb; }
.swap-list { display: grid; gap: 12px; margin-top: 12px; }
.swap-card { display: flex; justify-content: space-between; align-items: center; gap: 16px; padding: 14px; border: 1px solid #f3d18a; border-radius: 16px; background: #fff; }
.swap-card .inline { flex-wrap: nowrap; }
@media (max-width: 760px) { .swap-card { align-items: stretch; flex-direction: column; } .swap-card .inline { justify-content: flex-start; } }

/* v1.7: übersichtlichere Benutzer-/Parteiverwaltung */
.users-layout{display:grid;grid-template-columns:minmax(280px,.85fr) minmax(520px,1.55fr);gap:22px;align-items:start}.user-list-panel{min-width:0}.party-card-header{display:flex;align-items:center;gap:12px;margin-bottom:12px}.party-color-dot{width:18px;height:18px;border-radius:50%;display:inline-block;box-shadow:0 0 0 3px #fff,0 0 0 4px var(--line);flex:0 0 auto}.party-title{display:grid;gap:1px;min-width:0}.party-title strong{font-size:16px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-title span{font-size:13px;color:var(--muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.party-service-count{margin-left:auto;background:#f3f4f6;border:1px solid var(--line);border-radius:999px;padding:4px 9px;color:var(--muted);font-size:13px;white-space:nowrap}.party-edit-form{display:grid;grid-template-columns:minmax(160px,1.1fr) minmax(210px,1.45fr) 78px 135px 135px auto;gap:10px;align-items:end}.party-edit-form label{display:grid;gap:4px;font-weight:650;font-size:13px;color:#374151}.party-edit-form input{width:100%;border:1px solid var(--line);border-radius:10px;padding:9px 10px;background:#fff;font:inherit}.party-edit-form input[type=color]{height:41px;padding:3px}.party-actions{display:flex;align-items:end}.user-admin-card{background:#fff;border-color:#dbe2ea;box-shadow:0 3px 14px rgba(15,23,42,.04)}@media(max-width:1100px){.users-layout{grid-template-columns:1fr}.party-edit-form{grid-template-columns:1fr 1fr}.party-actions{align-items:stretch}.party-actions .btn{width:100%}}@media(max-width:650px){.party-edit-form{grid-template-columns:1fr}.party-card-header{align-items:flex-start}.party-service-count{margin-left:0}.party-card-header{flex-wrap:wrap}}

/* Reithalle Buchung */
.hall-grid{width:100%;border-collapse:separate;border-spacing:0;border:1px solid var(--line);border-radius:16px;overflow:hidden;background:#fff}.hall-grid th{background:#f8fafc;color:#374151;font-size:13px;text-align:left;padding:10px;border-bottom:1px solid var(--line)}.hall-grid td{height:42px;border-bottom:1px solid #eef2f7;border-right:1px solid #eef2f7;padding:5px;vertical-align:top}.hall-grid tr:last-child td{border-bottom:0}.hall-grid td:last-child{border-right:0}.hall-time{width:78px;color:var(--muted);font-weight:700;font-size:13px;background:#fbfdff}.booking-chip{display:block;border-radius:10px;padding:6px 8px;font-size:13px;font-weight:750;color:#fff;min-height:30px;box-shadow:0 3px 10px rgba(15,23,42,.08)}.booking-chip .meta{display:block;font-weight:600;font-size:12px;opacity:.95}.booking-chip.block{background:#6b7280;color:#fff}.booking-chip.freejump{background:#ea580c;color:#fff}.booking-chip.empty{background:transparent;color:transparent;box-shadow:none}.booking-actions{margin-top:4px}.booking-actions button{font-size:11px;padding:4px 7px;border-radius:8px}.stat-list{display:grid;gap:8px}.stat-row{display:grid;grid-template-columns:130px minmax(0,1fr) 62px;gap:10px;align-items:center}.bar{height:12px;background:#e5e7eb;border-radius:999px;overflow:hidden}.bar span{display:block;height:100%;background:#2563eb;border-radius:999px}.season-grid{display:grid;grid-template-columns:120px repeat(3, minmax(120px,1fr));gap:8px;align-items:end}.opening-grid{display:grid;grid-template-columns:120px repeat(4, minmax(100px,1fr));gap:8px;align-items:end;margin-bottom:8px}.pill{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#f9fafb;border-radius:999px;padding:5px 9px;font-size:13px}.sep{border:0;border-top:1px solid var(--line);margin:18px 0}.mini-card{border:1px solid var(--line);border-radius:14px;padding:12px;background:#fbfdff;margin-bottom:10px}.horse-list{display:flex;gap:8px;flex-wrap:wrap}.horse-pill{display:inline-flex;gap:8px;align-items:center;border:1px solid var(--line);border-radius:999px;padding:5px 9px;background:#fff}@media(max-width:760px){.hall-grid{font-size:13px}.hall-grid td{height:52px}.hall-time{width:58px}.season-grid,.opening-grid{grid-template-columns:1fr}.stat-row{grid-template-columns:90px minmax(0,1fr) 46px}}

/* Reithalle Buchung v1.2: kompakter Klick-Kalender */
.booking-layout{align-items:start}.calendar-help{margin-top:2px;margin-bottom:14px}.hall-calendar{border:1px solid var(--line);border-radius:18px;background:#fff;overflow:hidden;box-shadow:inset 0 0 0 1px rgba(255,255,255,.4)}.calendar-head{display:grid;grid-template-columns:72px 1fr 1fr;border-bottom:1px solid var(--line);background:#f8fafc}.calendar-head>div{padding:10px 12px;font-size:13px;font-weight:800;color:#374151;border-right:1px solid var(--line)}.calendar-head>div:last-child{border-right:0}.calendar-body{display:grid;grid-template-columns:72px minmax(0,1fr);min-height:var(--calendar-height)}.calendar-times{position:relative;background:#fbfdff;border-right:1px solid var(--line);height:var(--calendar-height)}.calendar-times span{position:absolute;right:10px;transform:translateY(-50%);font-size:12px;font-weight:800;color:var(--muted);white-space:nowrap}.calendar-times span:first-child{transform:translateY(0)}.calendar-lanes{position:relative;height:var(--calendar-height);background:linear-gradient(90deg, transparent calc(50% - .5px), #eef2f7 calc(50% - .5px), #eef2f7 calc(50% + .5px), transparent calc(50% + .5px))}.calendar-hour-line{position:absolute;left:0;right:0;border-top:1px solid #e8edf5;z-index:1}.slot-hit{position:absolute;border:0;background:transparent;border-radius:10px;z-index:2;cursor:pointer}.slot-hit.lane-c{left:8px;width:calc(50% - 14px)}.slot-hit.lane-a{left:calc(50% + 6px);width:calc(50% - 14px)}.slot-hit:hover,.slot-hit:focus-visible,.slot-hit.selected{background:rgba(37,99,235,.10);outline:2px solid rgba(37,99,235,.28);outline-offset:-2px}.calendar-event{position:absolute;z-index:5;border-radius:13px;padding:7px 9px;color:#fff;box-shadow:0 8px 18px rgba(15,23,42,.16);overflow:hidden;display:flex;flex-direction:column;justify-content:center;gap:1px;min-height:28px}.calendar-event.lane-c{left:8px;width:calc(50% - 14px)}.calendar-event.lane-a{left:calc(50% + 6px);width:calc(50% - 14px)}.calendar-event.lane-both{left:8px;right:8px}.calendar-event strong{font-size:13px;line-height:1.15;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event span{font-size:12px;line-height:1.18;font-weight:650;opacity:.96;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.calendar-event.block{background:#6b7280}.calendar-event.freejump{background:#ea580c}.calendar-event .booking-actions{margin-top:4px;pointer-events:auto}.calendar-event .booking-actions .btn{font-size:11px;padding:3px 7px}.selected-slot{margin:0 0 12px;padding:10px 12px;border:1px solid #bfdbfe;background:#eff6ff;border-radius:12px;color:#1e3a8a;font-weight:750}.booking-panel.pulse{animation:panelPulse .6s ease}@keyframes panelPulse{0%{box-shadow:0 0 0 0 rgba(37,99,235,.28)}100%{box-shadow:0 0 0 12px rgba(37,99,235,0)}}@media(max-width:760px){.calendar-head{grid-template-columns:52px minmax(118px,1fr) minmax(118px,1fr)}.calendar-body{grid-template-columns:52px minmax(236px,1fr);overflow-x:auto}.calendar-times{position:sticky;left:0;z-index:6}.calendar-lanes{min-width:236px}.calendar-head>div{padding:9px 8px}.calendar-times span{right:7px;font-size:11px}.calendar-event{padding:6px 7px;border-radius:11px}.calendar-event strong{font-size:12px}.calendar-event span{font-size:11px}.slot-hit.lane-c,.calendar-event.lane-c{left:6px;width:calc(50% - 10px)}.slot-hit.lane-a,.calendar-event.lane-a{left:calc(50% + 4px);width:calc(50% - 10px)}.calendar-event.lane-both{left:6px;right:6px}}

/* Reithalle Buchung v1.4: kompakte Benutzerverwaltung */
.admin-user-tools{display:flex;align-items:end;justify-content:space-between;gap:14px;flex-wrap:wrap;margin:14px 0 16px}.user-search{display:grid;gap:5px;font-weight:700;min-width:min(100%,380px);flex:1}.user-search input{width:100%;border:1px solid var(--line);border-radius:12px;padding:11px 13px;background:#fff;font:inherit}.admin-create-user,.user-details{border:1px solid var(--line);border-radius:14px;background:#fbfdff;margin:12px 0;padding:0}.admin-create-user>summary,.user-details>summary{list-style:none;cursor:pointer;padding:11px 13px;font-weight:800;color:#1f2937;display:flex;align-items:center;justify-content:space-between;gap:10px}.admin-create-user>summary::-webkit-details-marker,.user-details>summary::-webkit-details-marker{display:none}.admin-create-user>summary:after,.user-details>summary:after{content:'öffnen';font-size:12px;font-weight:800;color:#2563eb;background:#eef2ff;border-radius:999px;padding:4px 8px}.admin-create-user[open]>summary:after,.user-details[open]>summary:after{content:'schließen'}.admin-create-user form,.user-details form,.user-details h3,.user-details .horse-list{padding-left:13px;padding-right:13px}.admin-create-user form{padding-bottom:13px}.admin-create-grid{display:grid;grid-template-columns:repeat(3,minmax(160px,1fr)) 90px 140px 110px;gap:10px;align-items:end}.admin-create-grid label{display:grid;gap:5px}.admin-create-grid input,.admin-create-grid select,.admin-create-user textarea{width:100%;border:1px solid var(--line);border-radius:10px;padding:10px 12px;background:#fff;font:inherit}.admin-create-grid input[type=color]{height:42px;padding:3px}.admin-user-list{display:grid;gap:10px}.compact-user-card{padding:12px}.compact-user-card[hidden]{display:none}.compact-user-card .party-card-header{margin-bottom:8px}.compact-horse-list{margin-top:4px}.compact-horse-list .horse-pill{font-size:13px;padding:4px 8px}.user-details{background:#fff;margin-top:10px}.user-details .horse-list{padding-bottom:4px}.user-details .inline{padding:0 13px 13px}.user-details h3{font-size:15px;margin-top:14px;margin-bottom:6px}@media(max-width:1200px){.admin-create-grid{grid-template-columns:1fr 1fr}.party-edit-form{grid-template-columns:1fr 1fr}}@media(max-width:700px){.admin-user-tools{align-items:stretch}.admin-user-tools .pill{justify-content:center}.admin-create-grid,.party-edit-form{grid-template-columns:1fr}.compact-user-card{padding:10px}.compact-user-card .party-card-header{align-items:flex-start;flex-wrap:wrap}.compact-user-card .party-service-count{margin-left:0}.user-search{min-width:100%}}

/* Reithalle Buchung v1.5: Feiertagsprüfung */
.holiday-details{border:1px solid var(--line);border-radius:14px;background:#fbfdff;margin:12px 0 16px;padding:0}.holiday-details>summary{cursor:pointer;list-style:none;padding:11px 13px;font-weight:800;color:#1f2937}.holiday-details>summary::-webkit-details-marker{display:none}.holiday-preview{display:grid;grid-template-columns:repeat(auto-fit,minmax(230px,1fr));gap:12px;padding:0 13px 13px}.holiday-year{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.holiday-year strong{display:block;margin-bottom:6px}.holiday-year ul{margin:0;padding-left:18px;color:#374151}.holiday-year li{margin:3px 0;font-size:13px}

/* Reithalle Buchung v1.6: lesbarere Kalenderblöcke, einheitliche Farben, sauberer Abschluss */
.calendar-times span:last-child{transform:translateY(-100%)}
.calendar-event{background:#2563eb!important;padding:5px 68px 5px 8px;display:block;justify-content:flex-start;line-height:1.12;overflow:hidden;min-height:30px}
.calendar-event.booking,.calendar-event.freejump{background:#2563eb!important}
.calendar-event.block{background:#374151!important}
.calendar-event .event-time{display:inline-flex;align-items:center;max-width:100%;margin:0 0 2px 0;padding:1px 6px;border-radius:999px;background:rgba(255,255,255,.18);font-size:10.5px;line-height:1.25;font-weight:850;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendar-event strong{display:block;margin:0;font-size:12.5px;line-height:1.12;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendar-event .event-sub{display:block;margin-top:1px;font-size:11.5px;line-height:1.1;font-weight:650;opacity:.96;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.calendar-event .booking-actions{position:absolute;right:6px;top:5px;margin:0;pointer-events:auto}
.calendar-event .booking-actions .btn{font-size:10.5px;line-height:1;padding:4px 7px;border-radius:999px;box-shadow:0 2px 6px rgba(0,0,0,.18)}
.calendar-event.lane-both{padding-right:76px}
@media(max-width:760px){.calendar-event{padding:5px 58px 5px 7px}.calendar-event .event-time{font-size:10px;padding:1px 5px}.calendar-event strong{font-size:12px}.calendar-event .event-sub{font-size:11px}.calendar-event .booking-actions .btn{font-size:10px;padding:3px 6px}.calendar-event.lane-both{padding-right:64px}}


/* Reithalle Buchung v1.8: deutlich auffälligere Überschneidungs-/Fehlermeldungen */
.flash.error,
.flash.conflict{
  position:sticky;
  top:76px;
  z-index:80;
  display:flex;
  align-items:flex-start;
  gap:12px;
  padding:18px 20px;
  border-width:3px;
  border-radius:18px;
  box-shadow:0 18px 44px rgba(127,29,29,.22), 0 0 0 9999px rgba(15,23,42,.04);
  font-size:17px;
  line-height:1.35;
  font-weight:850;
  animation:flashPop .28s ease-out, flashShake .42s ease-out .08s;
}
.flash.error::before,
.flash.conflict::before{
  content:'⚠️';
  flex:0 0 auto;
  font-size:28px;
  line-height:1;
}
.flash.conflict{
  color:#7c2d12;
  background:#fff7ed;
  border-color:#f97316;
}
.flash.error{
  color:#7f1d1d;
  background:#fff1f2;
  border-color:#dc2626;
}
@keyframes flashPop{
  from{opacity:0;transform:translateY(-12px) scale(.98)}
  to{opacity:1;transform:translateY(0) scale(1)}
}
@keyframes flashShake{
  0%,100%{transform:translateX(0)}
  20%{transform:translateX(-5px)}
  40%{transform:translateX(5px)}
  60%{transform:translateX(-3px)}
  80%{transform:translateX(3px)}
}
@media(max-width:760px){
  .flash.error,
  .flash.conflict{
    top:96px;
    padding:16px;
    font-size:15.5px;
    border-radius:16px;
  }
  .flash.error::before,
  .flash.conflict::before{font-size:24px}
}

/* Reithalle Buchung v1.10: Kurzbuchungen 15/30 Minuten besser lesbar */
.calendar-event.event-compact{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  grid-template-rows:minmax(0,1fr) minmax(0,1fr);
  align-items:center;
  column-gap:6px;
  row-gap:0;
  padding:3px 34px 3px 7px;
  min-height:28px;
  overflow:hidden;
}
.calendar-event.event-compact .event-time{
  grid-column:1;
  grid-row:1 / 3;
  margin:0;
  padding:1px 5px;
  font-size:9.5px;
  line-height:1.15;
  max-width:none;
}
.calendar-event.event-compact strong{
  grid-column:2;
  grid-row:1;
  display:block;
  min-width:0;
  font-size:11.8px;
  line-height:1.05;
}
.calendar-event.event-compact .event-sub{
  grid-column:2;
  grid-row:2;
  display:block;
  min-width:0;
  margin:0;
  font-size:10.6px;
  line-height:1.05;
  opacity:.98;
}
.calendar-event.event-compact .booking-actions{
  right:5px;
  top:50%;
  transform:translateY(-50%);
}
.calendar-event.event-compact .booking-actions .btn{
  width:24px;
  height:24px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:0;
  line-height:1;
  border-radius:999px;
}
.calendar-event.event-compact .booking-actions .btn::before{
  content:'×';
  font-size:17px;
  font-weight:900;
  line-height:1;
}
@media(max-width:760px){
  .calendar-event.event-compact{
    grid-template-columns:minmax(0,1fr);
    grid-template-rows:minmax(0,1fr) minmax(0,1fr);
    padding:3px 30px 3px 6px;
    column-gap:0;
    min-height:28px;
  }
  .calendar-event.event-compact .event-time{display:none}
  .calendar-event.event-compact strong{
    grid-column:1;
    grid-row:1;
    font-size:11.5px;
  }
  .calendar-event.event-compact .event-sub{
    grid-column:1;
    grid-row:2;
    font-size:10.5px;
  }
  .calendar-event.event-compact .booking-actions .btn{
    width:23px;
    height:23px;
  }
}


/* Reithalle Buchung v1.11: bessere Darstellung dichter/kurzer Termine */
.calendar-event{
  box-sizing:border-box;
  border:1px solid rgba(255,255,255,.16);
}
.calendar-event.event-compact,
.calendar-event.event-micro{
  z-index:8;
  box-shadow:0 5px 12px rgba(15,23,42,.14);
}
.calendar-event.block.event-compact,
.calendar-event.block.event-micro{
  z-index:9;
}
.calendar-event.event-micro{
  display:flex;
  align-items:center;
  justify-content:flex-start;
  gap:0;
  padding:2px 31px 2px 7px;
  min-height:20px;
  border-radius:10px;
  line-height:1;
  overflow:hidden;
}
.calendar-event.event-micro.lane-both{
  padding-right:58px;
}
.calendar-event.event-micro .event-line{
  display:block;
  min-width:0;
  width:100%;
  white-space:nowrap;
  overflow:hidden;
  text-overflow:ellipsis;
  font-size:10.7px;
  line-height:1.12;
  font-weight:850;
  color:#fff;
}
.calendar-event.event-micro .booking-actions{
  right:4px;
  top:50%;
  transform:translateY(-50%);
}
.calendar-event.event-micro .booking-actions .btn{
  width:22px;
  height:22px;
  padding:0;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  font-size:0;
  line-height:1;
  border-radius:999px;
}
.calendar-event.event-micro .booking-actions .btn::before{
  content:'×';
  font-size:16px;
  font-weight:900;
  line-height:1;
}
.calendar-event:hover,
.calendar-event:focus-within{
  z-index:30;
  outline:2px solid rgba(255,255,255,.68);
  outline-offset:-2px;
}
@media(max-width:760px){
  .calendar-event.event-micro{
    padding:2px 29px 2px 6px;
    min-height:20px;
    border-radius:9px;
  }
  .calendar-event.event-micro.lane-both{
    padding-right:50px;
  }
  .calendar-event.event-micro .event-line{
    font-size:10.2px;
    letter-spacing:-.1px;
  }
  .calendar-event.event-micro .booking-actions .btn{
    width:21px;
    height:21px;
  }
}

/* Reithalle Buchung v1.12: Außenplatz */
.card-map{margin:12px 0 16px}
.area-map{display:grid;grid-template-columns:2fr 1fr;grid-template-rows:1fr 1fr;gap:10px}
.area-map-cell{border:1px solid var(--line);background:#f8fafc;border-radius:18px;padding:18px 16px;text-align:left;cursor:pointer;transition:.18s ease;box-shadow:0 6px 16px rgba(15,23,42,.05)}
.area-map-cell strong{display:block;font-size:20px;line-height:1.1;color:#1f2937;margin-bottom:6px}
.area-map-cell span{display:block;color:#64748b;font-size:13px;font-weight:700}
.area-map-cell:hover,.area-map-cell:focus-visible,.area-map-cell.active{border-color:#93c5fd;background:#eff6ff;box-shadow:0 10px 24px rgba(37,99,235,.12)}
.area-map-a{grid-row:1 / span 2;min-height:180px;display:flex;flex-direction:column;justify-content:center}
.area-map-b,.area-map-c{min-height:85px;display:flex;flex-direction:column;justify-content:center}
.outdoor-head{grid-template-columns:72px 1.4fr 1fr 1fr}
.outdoor-body{grid-template-columns:72px minmax(0,1fr)}
.outdoor-lanes{background:
  linear-gradient(90deg,
    transparent calc(42% - .5px), #eef2f7 calc(42% - .5px), #eef2f7 calc(42% + .5px), transparent calc(42% + .5px),
    transparent calc(71% - .5px), #eef2f7 calc(71% - .5px), #eef2f7 calc(71% + .5px), transparent calc(71% + .5px)
  )}
.slot-hit.lane-out-a{left:8px;width:calc(42% - 14px)}
.slot-hit.lane-out-b{left:calc(42% + 6px);width:calc(29% - 12px)}
.slot-hit.lane-out-c{left:calc(71% + 6px);width:calc(29% - 14px)}
.calendar-event.lane-out-a{left:8px;width:calc(42% - 14px)}
.calendar-event.lane-out-b{left:calc(42% + 6px);width:calc(29% - 12px)}
.calendar-event.lane-out-c{left:calc(71% + 6px);width:calc(29% - 14px)}
@media(max-width:760px){
  .area-map{grid-template-columns:1fr 1fr;grid-template-rows:auto auto}
  .area-map-a{grid-column:1 / span 2;grid-row:auto;min-height:110px}
  .area-map-b,.area-map-c{min-height:78px}
  .area-map-cell strong{font-size:18px}
  .outdoor-head{grid-template-columns:52px minmax(130px,1.4fr) minmax(112px,1fr) minmax(112px,1fr)}
  .outdoor-body{grid-template-columns:52px minmax(354px,1fr);overflow-x:auto}
  .outdoor-lanes{min-width:354px}
  .slot-hit.lane-out-a,.calendar-event.lane-out-a{left:6px;width:calc(42% - 10px)}
  .slot-hit.lane-out-b,.calendar-event.lane-out-b{left:calc(42% + 4px);width:calc(29% - 8px)}
  .slot-hit.lane-out-c,.calendar-event.lane-out-c{left:calc(71% + 4px);width:calc(29% - 10px)}
}


/* Reithalle Buchung v1.13: Außenplatz korrigiert */
.outdoor-calendar{overflow-x:auto}
.outdoor-head{grid-template-columns:72px minmax(0,2fr) minmax(0,1fr) minmax(0,1fr)!important}
.outdoor-head>div{white-space:nowrap}
.outdoor-body{grid-template-columns:72px minmax(520px,1fr)!important}
.outdoor-lanes{min-width:520px;background:
  linear-gradient(90deg,
    transparent calc(50% - .5px), #eef2f7 calc(50% - .5px), #eef2f7 calc(50% + .5px), transparent calc(50% + .5px),
    transparent calc(75% - .5px), #eef2f7 calc(75% - .5px), #eef2f7 calc(75% + .5px), transparent calc(75% + .5px)
  )!important}
.slot-hit.lane-out-a,.calendar-event.lane-out-a{left:8px;width:calc(50% - 14px)!important}
.slot-hit.lane-out-b,.calendar-event.lane-out-b{left:calc(50% + 6px);width:calc(25% - 12px)!important}
.slot-hit.lane-out-c,.calendar-event.lane-out-c{left:calc(75% + 6px);width:calc(25% - 14px)!important}
.area-map{grid-template-columns:2fr 1fr!important;grid-template-rows:1fr 1fr!important;gap:12px!important}
.area-map-a{grid-column:1;grid-row:1 / span 2;min-height:172px!important}
.area-map-b{grid-column:2;grid-row:1}
.area-map-c{grid-column:2;grid-row:2}
.area-map-cell{padding:18px 16px!important}
.area-map-cell strong{font-size:22px!important}
.area-map-cell span{font-size:14px!important}
@media(max-width:980px){
  .outdoor-head{grid-template-columns:52px minmax(180px,2fr) minmax(110px,1fr) minmax(110px,1fr)!important}
  .outdoor-body{grid-template-columns:52px minmax(400px,1fr)!important}
  .outdoor-lanes{min-width:400px}
}
@media(max-width:760px){
  .area-map{grid-template-columns:1fr 1fr!important;grid-template-rows:auto auto!important}
  .area-map-a{grid-column:1 / span 2;grid-row:1;min-height:110px!important}
  .area-map-b{grid-column:1;grid-row:2}
  .area-map-c{grid-column:2;grid-row:2}
  .outdoor-head{grid-template-columns:52px minmax(170px,2fr) minmax(100px,1fr) minmax(100px,1fr)!important}
  .outdoor-body{grid-template-columns:52px minmax(370px,1fr)!important}
  .outdoor-lanes{min-width:370px}
  .slot-hit.lane-out-a,.calendar-event.lane-out-a{left:6px;width:calc(50% - 10px)!important}
  .slot-hit.lane-out-b,.calendar-event.lane-out-b{left:calc(50% + 4px);width:calc(25% - 8px)!important}
  .slot-hit.lane-out-c,.calendar-event.lane-out-c{left:calc(75% + 4px);width:calc(25% - 10px)!important}
}


/* Reithalle Buchung v1.14: Platzregeln Außenplatz */
.place-rules{
  margin:14px 0 18px;
  border:1px solid #bfdbfe;
  border-radius:18px;
  background:#f8fbff;
  box-shadow:0 8px 18px rgba(37,99,235,.06);
  overflow:hidden;
}
.place-rules>summary{
  cursor:pointer;
  list-style:none;
  padding:13px 15px;
  font-weight:900;
  color:#1e3a8a;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:10px;
}
.place-rules>summary::-webkit-details-marker{display:none}
.place-rules>summary:after{
  content:'anzeigen';
  font-size:12px;
  color:#2563eb;
  background:#dbeafe;
  border-radius:999px;
  padding:4px 9px;
}
.place-rules[open]>summary:after{content:'ausblenden'}
.place-rules-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  padding:0 15px 15px;
}
.place-rule{
  border:1px solid #e0ecff;
  border-radius:14px;
  background:#fff;
  padding:11px 12px;
}
.place-rule strong{
  display:block;
  color:#111827;
  font-size:14px;
  margin-bottom:4px;
}
.place-rule p{
  margin:0;
  color:#4b5563;
  font-size:13px;
  line-height:1.35;
}
@media(max-width:760px){
  .place-rules-grid{grid-template-columns:1fr;padding:0 12px 12px}
  .place-rules>summary{padding:12px}
  .place-rule{padding:10px}
}

/* Reithalle Buchung v1.16: PWA / App-Installation */
.install-app-btn{border:0;border-radius:999px;padding:7px 11px;background:#eef2ff;color:#1f2937;font:inherit;font-weight:800;cursor:pointer;box-shadow:inset 0 0 0 1px var(--line)}
.install-app-btn:hover{background:#e0e7ff;color:#1d4ed8}
@media(display-mode:standalone){.install-app-btn{display:none!important}.topbar{padding-top:max(14px,env(safe-area-inset-top))}.container{padding-left:max(14px,env(safe-area-inset-left));padding-right:max(14px,env(safe-area-inset-right));padding-bottom:max(22px,env(safe-area-inset-bottom))}}
