
/* Eventbricks Single Template – clean, erweiterbar */
.eb-wrap{max-width:1120px;margin:0 auto;padding:24px 16px;font-family:system-ui,-apple-system,Segoe UI,Roboto,Arial}
.eb-h1{font-size:34px;letter-spacing:-.02em;margin:0 0 8px}
.eb-h2{font-size:26px;margin:0 0 8px}
.eb-h3{font-size:16px;margin:0}
.eb-muted{color:#667085;font-size:14px;line-height:1.45}
.eb-small{font-size:12px}
.eb-notice{background:#fff3cd;border:1px solid #ffe69c;padding:12px 14px;border-radius:12px;margin:12px 0}
.eb-notice--ok{background:#ecfdf3;border-color:#abefc6}
.eb-divider{height:1px;background:#eaecf0;margin:12px 0}

.eb-hero{display:grid;grid-template-columns:1.1fr .9fr;gap:18px;align-items:start;margin-bottom:18px}
@media(max-width:980px){.eb-hero{grid-template-columns:1fr}}
.eb-hero__left{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:14px;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.eb-hero__right{border-radius:20px;overflow:hidden;border:1px solid #e5e7eb;background:#f2f4f7;box-shadow:0 4px 18px rgba(0,0,0,.04);aspect-ratio:16/9}
.eb-hero__img{width:100%;height:100%;min-height:0;object-fit:contain;display:block;background:#111827}
.eb-hero__placeholder{height:100%;min-height:280px;background:linear-gradient(135deg,#f2f4f7,#eaecf0)}
.eb-hero__slogan{font-size:15px;color:#475467;margin:0 0 10px}
.eb-hero__meta{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px;margin-top:10px}
@media(max-width:980px){.eb-hero__meta{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:640px){.eb-hero__meta{grid-template-columns:1fr}}
.eb-metaitem{background:#f9fafb;border:1px solid #eaecf0;border-radius:14px;padding:10px}
.eb-metaitem__k{display:block;font-size:11px;color:#667085;text-transform:uppercase;letter-spacing:.06em}
.eb-metaitem__v{display:block;margin-top:2px;font-size:14px;color:#111827;font-weight:650}
.eb-hero__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.eb-btn{display:inline-block;padding:9px 12px;border-radius:12px;border:1px solid #d0d5dd;background:#111827;color:#fff;text-decoration:none;font-size:13px;cursor:pointer}
.eb-btn--ghost{background:#fff;color:#111827}

.eb-gridlayout{display:grid;grid-template-columns:1fr 340px;gap:18px}
@media(max-width:980px){.eb-gridlayout{grid-template-columns:1fr}}
.eb-col{display:grid;gap:14px}
.eb-col--side{align-content:start}
.eb-sticky{position:sticky;top:14px;align-self:start}
@media(max-width:980px){.eb-sticky{position:relative;top:auto}}

.eb-box{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:14px;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.eb-box__head{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px}

.eb-sectionlabel{margin-top:10px;font-size:12px;font-weight:700;color:#111827}
.eb-chips{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.eb-chip{display:inline-flex;align-items:center;font-size:11px;background:#f2f4f7;border:1px solid #eaecf0;color:#344054;padding:4px 8px;border-radius:999px}

.eb-rich :where(p,ul,ol){margin:0 0 10px}
.eb-rich :where(h2,h3){margin:12px 0 8px}

.eb-gallery{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:10px}
@media(max-width:980px){.eb-gallery{grid-template-columns:repeat(3,minmax(0,1fr))}}
@media(max-width:640px){.eb-gallery{grid-template-columns:repeat(2,minmax(0,1fr))}}
.eb-figure{margin:0}
.eb-figure__img{width:100%;height:150px;object-fit:cover;border-radius:14px;display:block}
.eb-figure__cap{font-size:12px;color:#667085;margin-top:6px}

.eb-videos{display:grid;grid-template-columns:1fr;gap:12px}
.eb-video iframe{width:100% !important;max-width:100% !important;border-radius:14px}

.eb-audio__row{display:grid;gap:6px;margin-bottom:10px}

.eb-upsell__title{font-weight:700;color:#111827;margin-bottom:4px}

/* Inquiry Form */
.eb-inquiry__tabs{display:flex;gap:8px;margin-bottom:10px;flex-wrap:wrap}
.eb-tabbtn{padding:8px 10px;border-radius:999px;border:1px solid #eaecf0;background:#fff;color:#111827;font-size:13px;cursor:pointer}
.eb-tabbtn.is-active{background:#111827;color:#fff;border-color:#111827}
.eb-hidden{display:none}

/* === Navigation row (contextual, only when coming from search results) === */
.eb-navrow{display:flex;align-items:center;gap:12px;flex-wrap:wrap;margin:12px 0 0;padding:10px 12px;border:1px solid #eaecf0;border-radius:14px;background:rgba(255,255,255,.92);backdrop-filter:blur(8px)}
.eb-navrow--sticky{position:sticky;top:0;z-index:50}
.admin-bar .eb-navrow--sticky{top:32px}

.eb-navbtn{display:inline-flex;align-items:center;gap:8px;border:1px solid #eaecf0;background:#fff;border-radius:999px;padding:8px 10px;font-size:13px;color:#111827;text-decoration:none;cursor:pointer;user-select:none}
.eb-navbtn:hover{background:#f9fafb}
.eb-navbtn.is-disabled{opacity:.45;pointer-events:none}
.eb-navicon{font-size:18px;line-height:1}
.eb-navmeta{font-size:12px;color:#667085;flex:1;min-width:180px}

@media(max-width:640px){
  .eb-navrow{gap:8px}
  .eb-navlabel{display:none}
  .eb-navmeta{flex-basis:100%;min-width:0}
  .eb-navicon{font-size:20px}
}

/* Swipe hint toast */
.eb-swipehint{position:fixed;left:12px;right:12px;bottom:14px;z-index:9999;border:1px solid #eaecf0;border-radius:16px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);padding:12px 12px;display:flex;gap:10px;align-items:flex-start;box-shadow:0 10px 30px rgba(16,24,40,.12)}
.eb-swipehint__txt{font-size:13px;color:#111827;line-height:1.35}
.eb-swipehint__x{margin-left:auto;border:0;background:transparent;font-size:20px;line-height:1;color:#667085;cursor:pointer;padding:2px 6px}
.eb-swipehint.is-hide{opacity:0;transform:translateY(10px);transition:all .2s ease}

.eb-form{display:grid;gap:12px}
.eb-grid2{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
@media(max-width:640px){.eb-grid2{grid-template-columns:1fr}}
.eb-field label{display:block;font-size:12px;color:#111827;font-weight:700;margin-bottom:6px}
.eb-field input,.eb-field textarea,.eb-field select{width:100%;padding:10px 12px;border-radius:12px;border:1px solid #d0d5dd;font-size:14px;background:#fff}
.eb-field--wide{grid-column:1 / -1}
.eb-actions{display:flex;justify-content:space-between;align-items:center;gap:12px;flex-wrap:wrap}

/* Owner Inquiry List */
.eb-inq-list{display:grid;gap:12px;margin-top:12px}
.eb-inq-item__top{display:flex;justify-content:space-between;align-items:flex-start;gap:10px}
.eb-inq-item__title{font-size:14px;font-weight:750;color:#111827;margin-bottom:4px}
.eb-inq-item__msg{margin-top:10px;font-size:13px;color:#111827;line-height:1.45}
.eb-inq-item__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}


/* --- Grouped taxonomy chips --- */
.eb-tax-group__title{font-weight:700;margin:12px 0 6px 0}
.eb-chips{display:flex;flex-wrap:wrap;gap:8px}
.eb-chip{display:inline-flex;padding:6px 10px;border-radius:999px;border:1px solid rgba(0,0,0,.14);background:#fff;font-size:13px}

/* --- Normalized media sizing (contain, may show margins) --- */
.eb-hero__right{display:flex;align-items:center;justify-content:center}
.eb-hero__img{width:100%;max-height:30px;object-fit:contain;background:#111;border-radius:18px}
.eb-gallery__item{aspect-ratio: 4 / 3; display:flex; align-items:center; justify-content:center; background:#111}
.eb-gallery__item img.eb-fit{width:100%;height:100%;object-fit:contain}
.eb-video{position:relative;aspect-ratio:16/9;border-radius:16px;overflow:hidden;background:#111;border:1px solid rgba(0,0,0,.12)}
.eb-video iframe{position:absolute;inset:0;width:100%;height:100%}
.eb-mapwrap{background:#111}
.eb-map{height:260px}
.eb-origin{margin-top:8px;color:rgba(0,0,0,.65);font-size:14px}

/* --- Compact video grid --- */
.eb-videos{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(max-width:700px){.eb-videos{grid-template-columns:repeat(1,minmax(0,1fr))}}
.eb-video{aspect-ratio:16/9}

/* --- Sticky hero header --- */
.eb-hero{position:sticky;top:0;z-index:50;background:#fff;box-shadow:0 6px 18px rgba(0,0,0,.06);padding-top:10px}

/* --- Lightbox --- */
.eb-lightbox{cursor:zoom-in;text-decoration:none;color:inherit}
.eb-lb{position:fixed;inset:0;background:rgba(0,0,0,.88);display:none;align-items:center;justify-content:center;z-index:9999;padding:24px}
.eb-lb.is-open{display:flex}
.eb-lb__img{max-width:min(1100px,95vw);max-height:90vh;object-fit:contain;border-radius:16px;background:#111}
.eb-lb__btn{position:absolute;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);color:#fff;border-radius:12px;padding:10px 12px;cursor:pointer}
.eb-lb__close{right:18px;top:18px}
.eb-lb__prev{left:18px;top:50%;transform:translateY(-50%)}
.eb-lb__next{right:18px;top:50%;transform:translateY(-50%)}
.eb-origin--side{margin:0 0 10px 0;font-size:14px;color:rgba(0,0,0,.75)}

/* --- Audio grid --- */
.eb-audios{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(max-width:700px){.eb-audios{grid-template-columns:repeat(1,minmax(0,1fr))}}
.eb-audio audio{width:100%}

/* --- Merkmale compact blocks --- */
.eb-box--compact .eb-box__body{display:grid;gap:14px}
.eb-taxblock__h{font-weight:800;margin-bottom:6px}
.eb-taxblock .eb-tax-groups{display:grid;gap:10px}
.eb-tax-group__title{margin-top:0}

/* --- Mobile sticky header: keep text+button, let image scroll --- */
@media(max-width:800px){
  .eb-hero{position:static;box-shadow:none}
  .eb-hero__left{position:sticky;top:0;z-index:60;background:#fff;padding:10px 0;box-shadow:0 6px 18px rgba(0,0,0,.06)}
  .eb-hero__right{margin-top:10px}
}

/* --- Compact layout tweaks --- */
.eb-title{font-size:28px;line-height:1.15;margin:0}
.eb-slogan{font-size:14px;margin-top:6px}
.eb-btn{padding:10px 14px;font-size:14px}
.eb-box__head h2{font-size:18px}
.eb-prose{font-size:15px}
.eb-chip{padding:5px 8px;font-size:12px}
.eb-taxblock__h{font-size:14px}

/* --- Audio/Videos single player --- */
.eb-audio-playerall{display:grid;gap:12px}
.eb-audio-tracks{display:flex;flex-wrap:wrap;gap:10px}
.eb-audio-track{padding:8px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.14);background:#fff;cursor:pointer;font-size:13px}
.eb-audio-track.is-active{background:rgba(0,0,0,.06)}

.eb-video-playerall{display:grid;gap:12px}
.eb-video-main{position:relative;aspect-ratio:16/9;border-radius:16px;overflow:hidden;background:#111;border:1px solid rgba(0,0,0,.12)}
.eb-video-main iframe{position:absolute;inset:0;width:100%;height:100%}
.eb-video-list{display:flex;flex-wrap:wrap;gap:10px}
.eb-video-item{padding:8px 12px;border-radius:999px;border:1px solid rgba(0,0,0,.14);background:#fff;cursor:pointer;font-size:13px}
.eb-video-item.is-active{background:rgba(0,0,0,.06)}

/* tighter hero */
.eb-hero{padding-top:6px}

.eb-hero__img{max-height:30px}

/* --- Videos grid (same vibe as gallery) --- */
.eb-videos-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(max-width:700px){.eb-videos-grid{grid-template-columns:repeat(1,minmax(0,1fr))}}
.eb-video-tile{position:relative;aspect-ratio:4/3;border-radius:16px;overflow:hidden;background:#111;border:1px solid rgba(0,0,0,.12)}
.eb-video-tile iframe{position:absolute;inset:0;width:100%;height:100%}

/* --- Audio grid 4-up on desktop --- */
.eb-audio-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}
@media(max-width:1000px){.eb-audio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
@media(max-width:700px){.eb-audio-grid{grid-template-columns:repeat(1,minmax(0,1fr))}}
.eb-audio-tile audio{width:100%}

/* audio: max 2 per row */
.eb-audio-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
@media(max-width:700px){.eb-audio-grid{grid-template-columns:repeat(1,minmax(0,1fr))}}

/* disable sticky hero */
.eb-hero{position:static!important;top:auto!important}

.eb-tabpanel{display:none}

.eb-tabbtn.is-active{opacity:1}

.eb-tabpanel[data-eb-tab="booking"]{display:block}

/* --- Lightbox (popup gallery) --- */
#eb-lightbox{position:fixed;inset:0;display:none;z-index:99999}
#eb-lightbox.is-open{display:block}
#eb-lightbox .eb-lb__backdrop{position:absolute;inset:0;background:rgba(0,0,0,.75)}
#eb-lightbox .eb-lb__content{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;gap:12px;padding:24px}
#eb-lightbox .eb-lb__img{max-width:92vw;max-height:92vh;border-radius:14px;box-shadow:0 20px 60px rgba(0,0,0,.45);background:#111;object-fit:contain}
#eb-lightbox button{border:0;background:rgba(255,255,255,.15);color:#fff;width:44px;height:44px;border-radius:999px;font-size:28px;cursor:pointer;line-height:44px}
#eb-lightbox .eb-lb__close{position:absolute;top:16px;right:16px}
#eb-lightbox .eb-lb__prev{position:absolute;left:16px}
#eb-lightbox .eb-lb__next{position:absolute;right:16px}

/* --- Hero in same 2-col layout as details --- */
.eb-hero-grid{margin-bottom:14px}
.eb-hero-box .eb-box__body{padding:0}
.eb-hero-media{background:#fff;border:1px solid #e5e7eb;border-radius:20px;padding:14px;box-shadow:0 4px 18px rgba(0,0,0,.04)}
.eb-hero-media .eb-hero__imglink img{width:100%;height:100%;object-fit:contain;display:block}
.eb-hero-media .eb-hero__placeholder{height:180px;display:flex;align-items:center;justify-content:center;border-radius:16px;background:#f3f4f6;color:#6b7280}
@media(max-width:980px){
  .eb-hero-media .eb-hero__imglink img{width:100%;height:100%;object-fit:contain;display:block}
}

/* Header row: left (title/slogan/type/buttons) + right (map) same height */
.eb-headrow{display:flex;flex-wrap:nowrap;gap:14px;align-items:stretch}
.eb-headleft{flex:3 1 0;min-width:0}
.eb-headright{flex:1 1 0;min-width:240px;display:flex}
@media(max-width:980px){.eb-headrow{flex-wrap:wrap}.eb-headright{min-width:0;width:100%}}
.eb-headmeta{display:flex;flex-wrap:wrap;gap:8px;margin:8px 0 10px}
.eb-chip{display:inline-flex;align-items:center;padding:6px 10px;border-radius:999px;font-size:13px;line-height:1;border:1px solid #eaecf0;background:#fff;color:#111827}
.eb-chip--muted{color:#475467;background:#f8fafc}
.eb-btn--ghost{background:#fff;color:#111827;border:1px solid #eaecf0}
.eb-headmapwrap{position:relative;flex:1;height:100%;border-radius:14px;overflow:hidden;border:1px solid #eaecf0;background:#111827}
.eb-headmap{position:absolute;inset:0;width:100%;height:100%;border:0;display:block}
.eb-headmaplabel{position:absolute;top:8px;left:8px;right:8px;z-index:2;font-size:12px;line-height:1.2;color:#fff;background:rgba(0,0,0,.45);padding:6px 8px;border-radius:10px;backdrop-filter:blur(4px);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}

/* === FIX: Formular-Felder laufen rechts nicht mehr raus === */
.eb-inquiry,
.eb-inquiry * {
  box-sizing: border-box;
}

.eb-inquiry form,
.eb-inquiry .eb-grid,
.eb-inquiry .eb-grid2,
.eb-inquiry .eb-field,
.eb-inquiry .eb-field--wide {
  max-width: 100%;
}

.eb-inquiry input,
.eb-inquiry select,
.eb-inquiry textarea {
  width: 100%;
  max-width: 100%;
}

.eb-col--side .eb-box {
  overflow: hidden;
}

/* === Lightbox (Modal) === */
.eb-lightbox-modal{
  position:fixed;
  inset:0;
  background:rgba(0,0,0,.9);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:99999;
}
.eb-lightbox-modal.is-open{ display:flex; }
.eb-lightbox-modal img{
  max-width:90vw;
  max-height:90vh;
}
.eb-lightbox-modal__nav{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  font-size:44px;
  color:#fff;
  cursor:pointer;
  user-select:none;
  padding:18px;
}
.eb-lightbox-modal__prev{ left:0; }
.eb-lightbox-modal__next{ right:0; }


/* Map: ensure enough minimum size so tiles render */
.eb-map{
  min-height: 180px;
  height: 180px;
}
@media(max-width:980px){
  .eb-map{
    min-height: 220px;
    height: 220px;
  }
}

/* Map container positioning */
.eb-mapwrap{ position:relative; }

/* Header map (Google embed) – same height as left header block */
.eb-headmapwrap{
  position:relative;
  flex:1;
  height:100%;
  min-height:180px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid #eaecf0;
  background:#0b1220;
}
@media(max-width:980px){
  .eb-headmapwrap{ min-height:220px; }
}
.eb-headmap{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* === Hero split: Titelbild + Map nebeneinander (nur Hero, Rest unverändert) === */
.eb-hero--split{
  border-radius:18px;
  overflow:hidden;
  background:#0b1220;
}
.eb-hero__grid{
  display:grid;
  grid-template-columns: 3fr 1fr;
  gap:12px;
  padding:12px;
  align-items:stretch;
}
@media(max-width:980px){
  .eb-hero__grid{ grid-template-columns:1fr; }
}
.eb-hero__left,
.eb-hero__right{ min-width:0; }

.eb-hero__img{
  width:100%;
  height:100%;
  max-height:380px;
  object-fit:contain;
  display:block;
  border-radius:14px;
  background:#111827;
}
@media(max-width:980px){
  .eb-hero__img{ max-height:320px; }
}

.eb-hero__mapwrap{
  position:relative;
  height:100%;
  min-height:220px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid rgba(255,255,255,.08);
  background:#111827;
}
.eb-hero__map{
  position:absolute;
  inset:0;
  width:100%;
  height:100%;
  border:0;
  display:block;
}

/* Sidebar map under image, above sticky form (not sticky) */
.eb-side-mapwrap{
  width:100%;
  height:200px;
  border-radius:14px;
  overflow:hidden;
  border:1px solid #eaecf0;
  background:#0b1220;
}
@media(max-width:980px){
  .eb-side-mapwrap{ height:220px; }
}
.eb-side-mapframe{
  width:100%;
  height:100%;
  border:0;
  display:block;
}

}

/* Mobile: only ONE inquiry form (main content). Hide sidebar sticky form. */
@media(max-width:980px){
  #eb-inquiry-sticky{ display:none !important; }
}

/* Blurred background fill for images (like search cards) */
.eb-imgfill{position:relative;overflow:hidden;border-radius:18px}
.eb-imgfill::before{content:"";position:absolute;inset:-18px;background-image:var(--ebbg);background-size:cover;background-position:center;filter:blur(22px);transform:scale(1.15);opacity:.65}
.eb-imgfill > *{position:relative;z-index:1}
.eb-imgfill img{width:100%;height:100%;object-fit:contain;display:block}
.eb-imgfill--hero{aspect-ratio:4/3;max-height:360px}
.eb-imgfill--gallery{border-radius:14px}


/* Blur-fill sizing fixes */
.eb-hero-media .eb-imgfill{width:100%;aspect-ratio:4/3;max-height:360px}
.eb-hero-media .eb-imgfill img{height:100%;object-fit:contain}
.eb-gallery .eb-imgfill{width:100%;aspect-ratio:1/1}
.eb-gallery .eb-imgfill img{height:100%;object-fit:contain}
/* Media tiles should not look like black frames */
.eb-video-tile{background:#f3f4f6;border:1px solid #e5e7eb}



/* --- Fix spacing issues (override messy legacy rules) --- */
.eb-hero-box .eb-box__body{padding:14px!important}
.eb-hero-media .eb-imgfill{max-height:360px!important}
.eb-hero__img{max-height:360px!important}
.eb-title{margin:0 0 6px!important}
.eb-slogan{margin:0 0 10px!important}
.eb-description{margin-top:0!important}

/* --- External profile icons under sticky inquiry --- */
.eb-exticons{display:flex;gap:10px;align-items:center;justify-content:flex-start;margin-top:10px;opacity:.75}
.eb-exticon{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;border:1px solid #e5e7eb;border-radius:12px;text-decoration:none;line-height:1;font-size:16px;background:#fff}
.eb-exticon:hover{opacity:1}
.eb-exticon--disabled{cursor:default;opacity:.5}

/* Compact radios (Ernsthaftigkeit) */
.eb-radio--compact{display:flex;flex-direction:column;gap:8px;width:100%;padding:10px 12px;border:1px solid rgba(0,0,0,.12);border-radius:12px;background:#fff;box-sizing:border-box}





/* === Fix: Commitment radios should NOT wrap per character === */
  overflow-wrap: normal !important; /* override 'anywhere' */
  word-break: normal !important;
  white-space: normal !important;
  hyphens: auto;
}

/* Ensure label takes full row width inside grids */
  width: 100%;
  max-width: 100%;
}

/* Fieldset styling */
  border: 1px solid #d0d0d0;
  padding: 14px 16px;
  margin: 0;
}
  font-weight: 600;
  padding: 0 6px;
}


/* === FINAL OVERRIDE (fix16): prevent per-character wrapping === */


  /* ensure columns don't collapse to min-content */
  grid-template-columns: minmax(0,1fr) minmax(0,1fr);
}

.eb-inquiry .eb-grid2 > .eb-field.eb-field--wide{
  grid-column: 1 / -1 !important;
  min-width: 0 !important;
}

.eb-inquiry .eb-field.eb-field--wide .eb-radio--compact,
.eb-inquiry .eb-field.eb-field--wide .eb-radio__row,
.eb-inquiry .eb-field.eb-field--wide .eb-radio__label{
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
}



/* === FIX21: align commitment radios left and on neat rows === */
.eb-inquiry .eb-field--wide { text-align: left !important; }

.eb-inquiry .eb-radio--compact{
  display: flex !important;
  flex-direction: column !important;
  align-items: flex-start !important;
  gap: 8px;
}

.eb-inquiry .eb-radio--compact .eb-radio__row{
  width: 100% !important;
}

.eb-inquiry .eb-radio--compact .eb-radio__label{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 10px;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.eb-inquiry .eb-radio--compact .eb-radio__txt{
  flex: 1 1 auto !important;
  min-width: 0 !important;
  text-align: left !important;
}


/* === FIX22: left aligned, non-bold, text directly after radio === */
.eb-inquiry .eb-radio--compact{
  align-items: flex-start !important;
}

.eb-inquiry .eb-radio--compact .eb-radio__label{
  justify-content: flex-start !important;
  align-items: center !important;
  font-weight: 400 !important;
  text-align: left !important;
}

.eb-inquiry .eb-radio--compact input[type="radio"]{
  margin: 0 6px 0 0 !important;
}

.eb-inquiry .eb-radio--compact .eb-radio__txt{
  font-weight: 400 !important;
  margin-left: 0 !important;
}


/* === FIX23: force left alignment against grid === */
.eb-inquiry .eb-field--wide{
  justify-self: start !important;
  align-self: start !important;
}

.eb-inquiry .eb-radio--compact{
  margin-left: 0 !important;
  padding-left: 0 !important;
}

.eb-inquiry .eb-radio__row{
  display: block !important;
  text-align: left !important;
}


/* === FIX24: make the seriousness block full width and align radios perfectly === */
.eb-inquiry .eb-booking-seriousness{
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio--compact{
  width: 100% !important;
  max-width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__row{
  display: block !important;
  width: 100% !important;
  margin: 0 0 8px 0 !important;
  padding: 0 !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  gap: 8px !important;
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
  font-weight: 400 !important;
  text-align: left !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label input[type="radio"]{
  flex: 0 0 auto !important;
  margin: 0 !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__txt{
  display: inline !important;
  margin: 0 !important;
  padding: 0 !important;
  font-weight: 400 !important;
  line-height: 1.35 !important;
}


/* === FIX25: full-width seriousness field + perfectly aligned rows === */
.eb-inquiry .eb-field.eb-field--wide{
  justify-self: stretch !important;
  width: 100% !important;
  max-width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness{
  width: 100% !important;
  max-width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio--compact{
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important; /* IMPORTANT: prevent shrink */
  width: 100% !important;
  max-width: 100% !important;
  gap: 8px !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__row{
  width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label{
  display: flex !important;
  flex-direction: row !important;
  align-items: center !important;
  justify-content: flex-start !important;
  width: 100% !important;
  max-width: 100% !important;
  font-weight: 400 !important;
  text-align: left !important;
  gap: 8px !important;
  margin: 0 !important;
  padding: 0 !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label input[type="radio"]{
  margin: 0 !important;
  flex: 0 0 auto !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__txt{
  display: inline-block !important;
  margin: 0 !important;
  padding: 0 !important;
  font-weight: 400 !important;
  text-align: left !important;
}


/* === FIX26: force left alignment (some parent rule makes it right/auto) === */
.eb-inquiry .eb-booking-seriousness,
.eb-inquiry .eb-booking-seriousness *,
.eb-inquiry .eb-booking-seriousness .eb-radio--compact{
  text-align: left !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label{
  justify-content: flex-start !important;
  gap: 8px !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__txt{
  display: inline !important;
  width: auto !important;
  max-width: none !important;
  margin-left: 0 !important;
  margin-right: 0 !important;
  padding-left: 0 !important;
  padding-right: 0 !important;
}

/* Neutralize common "push to right" patterns */
.eb-inquiry .eb-booking-seriousness .eb-radio__txt,
.eb-inquiry .eb-booking-seriousness .eb-radio__label{
  margin-inline-start: 0 !important;
  margin-inline-end: 0 !important;
}


/* === FIX27: keep each radio+text as a tight left-aligned pair === */
.eb-inquiry .eb-booking-seriousness .eb-radio--compact{
  align-items: flex-start !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__row{
  display: flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
  width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__label{
  display: inline-flex !important;
  justify-content: flex-start !important;
  align-items: center !important;
  width: auto !important;          /* IMPORTANT */
  max-width: 100% !important;
}

.eb-inquiry .eb-booking-seriousness .eb-radio__txt{
  margin-left: 0 !important;
  margin-right: 0 !important;
}


/* === FIX28: clean radio layout after markup fix === */
.eb-inquiry .eb-radio {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 400;
}

.eb-inquiry .eb-radio span {
  font-weight: 400;
}


/* === FIX28: seriousness radios rebuilt with fieldset/labels (no flex tricks) === */
.eb-inquiry .eb-booking-seriousness{
  width: 100%;
  max-width: 100%;
  border: 1px solid rgba(0,0,0,.12);
  border-radius: 12px;
  padding: 12px 14px;
  margin: 0;
}

.eb-inquiry .eb-booking-seriousness legend{
  font-weight: 600;
  padding: 0 6px;
}

.eb-inquiry .eb-booking-seriousness label{
  display: block;
  font-weight: 400;
  margin: 8px 0 0 0;
}

.eb-inquiry .eb-booking-seriousness input[type="radio"]{
  margin-right: 8px;
}


/* === FIX29: override theme form styling that pushes radios away === */
.eb-inquiry fieldset.eb-booking-seriousness label{
  display: inline-flex !important;
  align-items: center !important;
  justify-content: flex-start !important;
  text-align: left !important;
  width: 100% !important;
}

.eb-inquiry fieldset.eb-booking-seriousness input[type="radio"]{
  float: none !important;
  margin: 0 8px 0 0 !important;
}


/* === FIX30: seriousness as buttons (avoid theme radio styling) === */
.eb-inquiry .eb-commitment__value{
  position: absolute !important;
  left: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  overflow: hidden !important;
  opacity: 0 !important;
  pointer-events: none !important;
}

.eb-inquiry .eb-commitment__buttons{
  display: block;
}

.eb-inquiry .eb-commitment__btn{
  display: inline-block;
  padding: 10px 12px;
  border: 1px solid rgba(0,0,0,.16);
  border-radius: 10px;
  background: #fff;
  cursor: pointer;
  font-weight: 400;
  line-height: 1.2;
  text-align: left;
}

.eb-inquiry .eb-commitment__btn.is-active{
  border-color: rgba(0,0,0,.45);
  box-shadow: 0 0 0 2px rgba(0,0,0,.08) inset;
}

.eb-inquiry .eb-commitment__btn:focus{
  outline: none;
  box-shadow: 0 0 0 2px rgba(0,0,0,.20);
}


/* === FIX31: dropdowns for budget + seriousness (theme-safe) === */
.eb-inquiry .eb-booking-seriousness select,
.eb-inquiry select[name="budget"]{
  width: 100% !important;
  max-width: 100% !important;
}


/* === FIX32: Budget + Commitment side by side === */
.eb-inquiry .eb-grid2 .eb-field select{
  width: 100%;
}


/* === FIX34: allow side-by-side selects without overflow === */
.eb-inquiry .eb-grid2 > .eb-field{ min-width:0; }
.eb-inquiry select{ min-width:0 !important; max-width:100%; width:100%; }

.eb-form select{width:100%;padding:10px 12px;border:1px solid var(--base);border-radius:12px;background:var(--base-2);color:inherit;line-height:1.2;height:auto;}

.eb-field select{min-width:0;}


/* === Top navigation bar (Prev/Next) === */
:root{--eb-topnav-gap:6px;}
.eb-topnavwrap{
  position: sticky;
  /* Top offset is computed in JS (admin bar + sticky header + optional gap). */
  top: var(--eb-sticky-top, 0px);
  /* Must sit above the theme header (header should be visually "behind" the nav) */
  z-index: 10050;
  /* full-bleed under the site header */
  margin-left: calc(50% - 50vw);
  margin-right: calc(50% - 50vw);
  width: 100vw;
  border-top: 1px solid rgba(0,0,0,0.08);
  border-bottom: 1px solid rgba(0,0,0,0.08);
  /* Solid background to avoid "see-through" gaps when header disappears */
  background: #fff;
  /* subtle separation from header/content */
  box-shadow: 0 1px 0 rgba(16,24,40,.06);
}
.eb-topnav{
  max-width: 1100px;
  margin: 0 auto;
  padding: 10px 12px;
  display:grid;
  /* 20% / 60% / 20% */
  grid-template-columns: 1fr 3fr 1fr;
  align-items:center;
  gap:10px;
}
.eb-topnavcenter{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  min-width: 0;
}
.eb-topnavcenter .eb-navmeta{
  min-width: 0;
  max-width: 100%;
  font-size: 13px;
  opacity: .85;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* Ensure left/right buttons align to edges while center stays centered */
.eb-topnav .eb-navbtn--prev{justify-self:start;}
.eb-topnav .eb-navbtn--next{justify-self:end;}
.eb-topnavcenter{justify-self:center;}
@media (max-width: 640px){
  .eb-topnav .eb-navlabel{display:none;}
  .eb-topnavcenter{justify-content:center;}
}

/* Prev/Next Nav – keep 20/60/20 even if only "Zurück" exists */
.eb-topnavwrap.eb-only-back .eb-navbtn--prev,
.eb-topnavwrap.eb-only-back .eb-navbtn--next{
  visibility:hidden;
  pointer-events:none;
}

/* Desktop keyboard hint (Arrow keys) */
.eb-keyshint{position:fixed;right:18px;bottom:18px;z-index:9999;max-width:460px;border:1px solid #eaecf0;border-radius:16px;background:rgba(255,255,255,.96);backdrop-filter:blur(8px);padding:12px 12px;box-shadow:0 10px 30px rgba(16,24,40,.12)}
.eb-keyshint__inner{display:flex;gap:10px;align-items:flex-start}
.eb-keyshint__text{font-size:13px;color:#111827;line-height:1.35}
.eb-keyshint__close{margin-left:auto;border:0;background:transparent;font-size:20px;line-height:1;color:#667085;cursor:pointer;padding:2px 6px}

