/* =====================================================================
   KBZ geteilte Frontend-Komponenten (Kosh, 2026-06-21)
   Wird von ArtHotel + ExoMind ueber partial kbz/components.html geladen.
   Enthaelt: Galerie + Lightbox (kbz-gallery / kbz-zoom-all) und Event-Ticker/-Liste.
   Farb-Variablen mit Fallback, damit es auf jeder Site funktioniert.
   ===================================================================== */

/* ---------- Galerie ---------- */
.kbz-gallery{display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:34px;}
.kbz-gallery.g4{grid-template-columns:repeat(4,1fr);}
.kbz-gallery>*{position:relative;display:block;border-radius:6px;overflow:hidden;cursor:zoom-in;
  box-shadow:0 6px 18px rgba(20,20,30,.16);transition:transform .22s ease;background:#e9e4db center/cover no-repeat;aspect-ratio:4/3;}
.kbz-gallery>*:hover{transform:scale(1.03);}
.kbz-gallery>img,.kbz-gallery>a>img{width:100%;height:100%;object-fit:cover;display:block;}
.kbz-gallery>.tall{grid-row:span 2;aspect-ratio:auto;height:100%;}
.kbz-zoom-all img{cursor:zoom-in;}
@media(max-width:820px){.kbz-gallery,.kbz-gallery.g4{grid-template-columns:repeat(2,1fr);}}
@media(max-width:520px){.kbz-gallery,.kbz-gallery.g4{grid-template-columns:1fr;}.kbz-gallery>.tall{grid-row:auto;aspect-ratio:4/3;}}

/* ---------- Lightbox ---------- */
body.kbz-lb-open{overflow:hidden;}
.kbz-lb{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;background:rgba(10,9,12,.94);}
.kbz-lb.open{display:flex;}
.kbz-lb-stage{margin:0;max-width:92vw;max-height:88vh;display:flex;flex-direction:column;align-items:center;gap:12px;}
.kbz-lb-stage img{max-width:92vw;max-height:82vh;object-fit:contain;border-radius:4px;box-shadow:0 18px 60px rgba(0,0,0,.6);}
.kbz-lb-cap{color:#e8e8ef;font-size:.9rem;letter-spacing:.02em;text-align:center;max-width:70ch;}
.kbz-lb-close{position:absolute;top:14px;right:22px;background:none;border:none;color:#fff;font-size:2.5rem;line-height:1;cursor:pointer;opacity:.85;}
.kbz-lb-close:hover{opacity:1;}
.kbz-lb-nav{position:absolute;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;border:none;
  background:rgba(255,255,255,.14);color:#fff;font-size:2rem;line-height:1;cursor:pointer;transition:.2s;}
.kbz-lb-nav:hover{background:rgba(255,255,255,.30);}
.kbz-lb-prev{left:18px;}.kbz-lb-next{right:18px;}
.kbz-lb-count{position:absolute;bottom:18px;left:0;right:0;text-align:center;color:#fff;font-size:.82rem;letter-spacing:.06em;opacity:.85;}
@media(max-width:560px){.kbz-lb-nav{width:44px;height:44px;font-size:1.6rem;}.kbz-lb-prev{left:8px;}.kbz-lb-next{right:8px;}.kbz-lb-close{font-size:2.1rem;right:14px;}}

/* ---------- Formulare: globale Tech-Styles (Honeypot + Rueckmeldung) ---------- */
.kbz-hp{position:absolute;left:-9999px;width:1px;height:1px;overflow:hidden;}
.kbz-form-msg{display:none;padding:12px 14px;border-radius:5px;margin-bottom:14px;font-size:.95rem;}
.kbz-form-msg.show{display:block;}
.kbz-form-msg.ok{background:#e7f4ea;border:1px solid #b6dcc0;color:#1d6b35;}
.kbz-form-msg.err{background:#fdecec;border:1px solid #f3c2c2;color:#a12020;}

/* ---------- Event-Ticker (Startseite) — fix am unteren Fensterrand ---------- */
.kbz-ticker{position:fixed;left:0;right:0;bottom:0;z-index:1200;display:flex;align-items:stretch;
  background:var(--burgundy,#A50022);color:#fff;overflow:hidden;box-shadow:0 -4px 18px rgba(0,0,0,.22);}
.kbz-ticker[hidden]{display:none;}
.kbz-ticker .tk-label{flex:none;display:flex;align-items:center;background:var(--burgundy-dark,#7d001a);font-weight:700;
  text-transform:uppercase;letter-spacing:.1em;font-size:.72rem;padding:0 20px;white-space:nowrap;}
.kbz-ticker .tk-vp{flex:1;overflow:hidden;}
.kbz-ticker .tk-track{display:inline-flex;align-items:center;white-space:nowrap;will-change:transform;animation:kbzticker 40s linear infinite;}
.kbz-ticker:hover .tk-track{animation-play-state:paused;}
.kbz-ticker .tk-item{display:inline-flex;align-items:center;color:#fff;padding:11px 0;font-size:.92rem;}
.kbz-ticker a.tk-item:hover .tk-title{text-decoration:underline;text-underline-offset:3px;}
.kbz-ticker .tk-badge{font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.08em;padding:2px 8px;border-radius:4px;margin-right:9px;}
.kbz-ticker .tk-badge.today{background:#fff;color:var(--burgundy,#A50022);}
.kbz-ticker .tk-badge.now{background:#ffd84d;color:#5a3a00;}
.kbz-ticker .tk-date{font-weight:700;margin-right:9px;opacity:.95;}
.kbz-ticker .tk-place{opacity:.8;}
.kbz-ticker .sep{opacity:.5;padding:0 20px;}
@keyframes kbzticker{from{transform:translateX(0)}to{transform:translateX(-50%)}}
@media(max-width:560px){.kbz-ticker .tk-label{display:none;}}
@media(prefers-reduced-motion:reduce){.kbz-ticker .tk-track{animation:none;}.kbz-ticker .tk-vp{overflow-x:auto;}}

/* ---------- Event-Liste (z.B. /erleben/) – Badges fuer laufende Events ---------- */
#kbz-eventlist[hidden]{display:none;}
#kbz-eventlist .ev{scroll-margin-top:110px;}                 /* Anker landet nicht unter dem Sticky-Header */
#kbz-eventlist .ev.ev-flash{animation:evflash 2.2s ease;}    /* kurz hervorheben, wenn aus dem Ticker angesprungen */
@keyframes evflash{0%,100%{background:transparent}12%,42%{background:rgba(255,216,77,.40)}}

/* Datumsspalte: Laufzeit "von … bis …" + Dauerlaeufer */
.ev-range,.ev-when{display:block;font-family:var(--serif,Georgia,serif);color:var(--burgundy,#A50022);font-size:.98rem;line-height:1.3;margin-top:3px;}

/* Unsere eigenen Events prominent */
#kbz-eventlist .ev.ev-own{background:rgba(165,0,34,.05);border-left:3px solid var(--burgundy,#A50022);padding-left:16px;}
.ev-own-tag{display:inline-block;background:var(--burgundy,#A50022);color:#fff;font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:2px 8px;border-radius:3px;margin-bottom:7px;}
/* zweites Tag: Ort/Marke (KunstQuartier · Restaurant Schmokenberg) — outline statt fill, ordnet sich dem ArtHotel-Tag unter */
.ev-venue-tag{display:inline-block;background:transparent;color:var(--burgundy,#A50022);border:1px solid var(--burgundy,#A50022);font-size:.6rem;letter-spacing:.12em;text-transform:uppercase;font-weight:700;padding:1px 7px;border-radius:3px;margin-bottom:7px;margin-left:6px;}
/* Quelle/Veranstalter unter dem Event-Text */
.ev-src{font-size:.78rem;color:var(--muted,#6b6b6b);margin-top:6px;font-style:italic;}
/* Externes-Link-Symbol im CTA */
.ext-ico{display:inline-block;vertical-align:-1px;margin-left:5px;}
/* Screenreader-only (a11y) */
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0;}

/* Filter-Leiste: Veranstalter-Umschalter + Reisedaten */
.evfilter{display:flex;flex-direction:column;align-items:center;gap:14px;margin:0 0 30px;padding:18px;background:var(--cream-2,#faf7f1);border:1px solid var(--line,#e7e0d4);border-radius:10px;}
.evf-scope{display:inline-flex;align-self:center;border:1px solid var(--burgundy,#A50022);border-radius:8px;overflow:hidden;}
.evf-seg{font:inherit;font-size:.85rem;font-weight:600;padding:9px 16px;border:none;background:#fff;color:var(--burgundy,#A50022);cursor:pointer;transition:.15s;}
.evf-seg + .evf-seg{border-left:1px solid var(--burgundy,#A50022);}
.evf-seg.is-on{background:var(--burgundy,#A50022);color:#fff;}
.evf-dates{display:flex;flex-wrap:wrap;align-items:flex-end;justify-content:center;gap:12px;}
.evf-label{font-weight:700;color:var(--burgundy,#A50022);text-transform:uppercase;letter-spacing:.08em;font-size:.74rem;align-self:center;}
.evf-field{display:inline-flex;flex-direction:column;font-size:.64rem;color:var(--muted,#6b6b6b);text-transform:uppercase;letter-spacing:.06em;gap:3px;}
.evfilter input[type=date]{font:inherit;font-size:.92rem;padding:7px 10px;border:1px solid var(--line,#e7e0d4);border-radius:6px;background:#fff;color:var(--ink,#1e2020);}
.evf-dash{color:var(--muted,#6b6b6b);padding-bottom:8px;}
.evf-clear{font:inherit;font-size:.84rem;color:var(--burgundy,#A50022);background:none;border:none;cursor:pointer;text-decoration:underline;text-underline-offset:2px;}
.evf-count{flex-basis:100%;text-align:center;margin:0;color:var(--muted,#6b6b6b);font-size:.86rem;}
@media(max-width:560px){.evf-scope{width:100%;}.evf-seg{flex:1;}.evf-count{margin-left:0;}}
.ev-badge{display:inline-block;font-weight:700;text-transform:uppercase;font-size:.7rem;letter-spacing:.06em;padding:3px 9px;border-radius:4px;}
.ev-badge.today{background:var(--burgundy,#A50022);color:#fff;}
.ev-badge.now{background:#ffd84d;color:#5a3a00;}
.ev-sub{display:block;font-size:.8rem;color:var(--muted,#6b6b6b);margin-top:5px;}

/* ===== KBZ Buchungs-Suchmaske (booking.js / partial kbz/searchmask) ===== */
.kbzs{display:flex;flex-wrap:wrap;align-items:flex-end;gap:0;max-width:920px;margin:0 auto;
  background:#fff;border-radius:28px;box-shadow:0 18px 48px rgba(20,16,14,.22);padding:10px;}
.kbzs-field{display:flex;flex-direction:column;gap:5px;padding:10px 18px;flex:1 1 150px;min-width:0;position:relative;}
.kbzs-field + .kbzs-field{border-left:1px solid var(--line,#e7dccb);}
.kbzs-field label{font-size:.7rem;letter-spacing:.12em;text-transform:uppercase;color:var(--muted,#8a7f73);}
.kbzs-field input[type=date],.kbzs-field select,.kbzs-guests-toggle{
  border:0;background:none;font-family:inherit;font-size:1.05rem;color:var(--ink,#3b3530);
  padding:2px 0;cursor:pointer;width:100%;}
.kbzs-field select{appearance:none;-webkit-appearance:none;}
.kbzs-guests-toggle{display:flex;align-items:center;justify-content:space-between;gap:8px;text-align:left;}
.kbzs-caret{color:var(--muted,#8a7f73);font-size:.8rem;}
.kbzs-guests-pop{position:absolute;top:100%;left:10px;z-index:30;min-width:240px;margin-top:8px;
  background:#fff;border:1px solid var(--line,#e7dccb);border-radius:12px;box-shadow:0 16px 40px rgba(20,16,14,.2);
  padding:14px 16px;display:none;}
.kbzs-guests-pop.open{display:block;}
.kbzs-row{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:6px 0;color:var(--ink,#3b3530);}
.kbzs-stepper{display:inline-flex;align-items:center;gap:10px;}
.kbzs-step{width:34px;height:34px;border-radius:9px;border:1px solid var(--line,#e7dccb);background:#fff;
  font-size:1.2rem;line-height:1;color:var(--burgundy,#a50022);cursor:pointer;}
.kbzs-step:hover{background:var(--cream,#f6f0e6);}
.kbzs-stepper input{width:28px;text-align:center;border:0;background:none;font-size:1.05rem;color:var(--ink,#3b3530);-moz-appearance:textfield;}
.kbzs-stepper input::-webkit-outer-spin-button,.kbzs-stepper input::-webkit-inner-spin-button{-webkit-appearance:none;margin:0;}
.kbzs-submit{flex:0 0 auto;margin:6px;padding:16px 30px;border:0;border-radius:20px;cursor:pointer;
  background:var(--burgundy,#c4ab7a);color:#131925;font-family:inherit;font-size:.82rem;font-weight:600;
  letter-spacing:.08em;text-transform:uppercase;transition:background .15s;}
.kbzs-submit:hover{background:var(--burgundy-dark,#a08a5d);}
@media(max-width:720px){
  .kbzs{flex-direction:column;align-items:stretch;}
  .kbzs-field + .kbzs-field{border-left:0;border-top:1px solid var(--line,#e7dccb);}
  .kbzs-submit{width:auto;}
}
/* Suchmaske-Band auf der Startseite: ragt leicht in den Hero hinein */
.kbzs-band{position:relative;z-index:5;margin:26px 0 6px;}
@media(max-width:720px){.kbzs-band{margin-top:8px;}}

/* ===== KBZ Gästebewertungen (partial kbz/reviews) ===== */
.kbz-reviews{background:var(--cream-2,#f4ede0);padding:64px 0;text-align:center;}
.kbz-reviews .eyebrow{justify-content:center;}
.kbz-rev-fallback{max-width:60ch;margin:18px auto 0;}
.kbz-rev-fallback p{color:var(--muted);font-size:1.08rem;line-height:1.6;margin:0 0 22px;}
.kbz-reviews iframe{width:100%;border:0;border-radius:12px;box-shadow:0 12px 34px rgba(51,45,40,.10);background:#fff;min-height:360px;}
.kbz-reviews .kbz-iiq{max-width:820px;margin:0 auto;text-align:center;}
.kbz-reviews .kbz-iiq>div{margin:0 auto;}

/* ---------- Event-Detail-Foldout (eigene Events, aufklappbar auf /erleben/) ---------- */
#kbz-eventlist .ev-toggle{display:inline-flex;align-items:center;gap:7px;cursor:pointer;}
#kbz-eventlist .ev-toggle .ev-caret{font-size:.85em;transition:transform .2s ease;}
#kbz-eventlist .ev-toggle.is-open .ev-caret{transform:rotate(180deg);}
#kbz-eventlist .ev-foldout{grid-column:1 / -1;margin-top:14px;padding:22px 24px;border-radius:10px;
  background:var(--cream-2,#f4f0ea);border:1px solid var(--line,#e4ded4);animation:evdin .25s ease;}
@keyframes evdin{from{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:none}}
/* Oben: Bild + Faktenblock nebeneinander */
#kbz-eventlist .evd-top{display:grid;grid-template-columns:minmax(0,300px) 1fr;gap:26px;align-items:start;}
#kbz-eventlist .evd-top.nomedia{grid-template-columns:1fr;}
#kbz-eventlist .evd-media img{width:100%;height:auto;max-height:300px;object-fit:cover;border-radius:8px;display:block;}
#kbz-eventlist .evd-facts{display:grid;gap:7px;margin:2px 0 0;}
#kbz-eventlist .evd-facts>div{display:grid;grid-template-columns:96px 1fr;gap:12px;font-size:.95rem;line-height:1.45;}
#kbz-eventlist .evd-facts dt{margin:0;color:var(--muted,#6b6b6b);}
#kbz-eventlist .evd-facts dd{margin:0;font-weight:600;}
/* Text voll breit darunter (nutzt die ganze Foldout-Breite, kein leerer Rand mehr) */
#kbz-eventlist .evd-text{margin-top:18px;}
#kbz-eventlist .evd-text>p{margin:0 0 11px;line-height:1.65;}
#kbz-eventlist .evd-text>p:first-child{font-size:1.04rem;color:var(--ink,inherit);}
/* Aktionen voll breit, mit Trennlinie abgesetzt */
#kbz-eventlist .evd-actions{margin-top:20px;padding-top:18px;border-top:1px solid var(--line,#e4ded4);}
#kbz-eventlist .evd-btns{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;}
#kbz-eventlist .evd-btns .btn{width:100%;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.25;}
#kbz-eventlist .evd-btns .evd-tk{display:inline-block;}
#kbz-eventlist .evd-cal{display:flex;justify-content:flex-end;align-items:center;gap:10px;font-size:.85rem;color:var(--muted,#6b6b6b);margin-top:14px;}
#kbz-eventlist .evd-cal a{color:var(--burgundy,#A50022);text-decoration:underline;text-underline-offset:2px;}
@media(max-width:680px){#kbz-eventlist .evd-top{grid-template-columns:1fr;}#kbz-eventlist .evd-cal{justify-content:flex-start;}}
/* Sticky-Suchband: angedockt am unteren Rand (über dem Event-Ticker) */
.kbzs-band.kbzs-stuck{position:fixed;bottom:var(--kbzs-bottom,0);z-index:40;margin:0;box-sizing:border-box;filter:drop-shadow(0 -8px 22px rgba(0,0,0,.18));}
.kbzs-spacer{pointer-events:none;}
/* DIRS21-Quickbook: Squircle-Rahmen ums Widget (Felix-Wunsch) */
.kbz-quickbook{width:min(1080px,calc(100% - 40px));margin:0 auto;}
.kbz-quickbook .d21-quickbook{width:100%;border-radius:18px;}
/* Sanftes Andocken des Sticky-Suchbands (statt hartem Sprung): gleitet von unten herein */
@keyframes kbzs-dock{from{transform:translateY(115%);opacity:.35}to{transform:translateY(0);opacity:1}}
.kbzs-band.kbzs-stuck{animation:kbzs-dock .30s cubic-bezier(.22,.61,.36,1) both;}
@media(prefers-reduced-motion:reduce){.kbzs-band.kbzs-stuck{animation:none;}}
/* DIRS21-Quickbook „Suchen"-Button auf CI-Gold (Vollthemung sonst im DIRS21-Backend) */
.kbz-quickbook .d21-button.d21-primary{background:var(--burgundy)!important;border-color:var(--burgundy)!important;}
.kbz-quickbook .d21-button.d21-primary:hover{background:var(--burgundy-dark)!important;border-color:var(--burgundy-dark)!important;}
.kbz-quickbook .d21-button.d21-primary span{color:#131925!important;}
