.bcm-ruimtes { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 16px; }
@media (max-width: 1024px) {
  .bcm-ruimtes { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 640px) {
  .bcm-ruimtes { grid-template-columns: 1fr; }
}
.bcm-ruimte-filters { display:flex; gap:8px; flex-wrap:wrap; margin:8px 0 12px; }
.bcm-chip-filter { padding:6px 10px; border:1px solid #00A7A0; border-radius:999px; background:#fff; color:#00A7A0; cursor:pointer; }
.bcm-chip-filter.active { background:#00A7A0; color:#fff; }
.bcm-ruimte-card { border: 1px solid #e5e7eb; border-radius: 10px; overflow:hidden; background: #fff; }
.bcm-ruimte-media { position:relative; }
.bcm-ruimte-thumb { width: 100%; height: 200px; object-fit: cover; border-radius:0; border:0 !important; box-shadow:none !important; outline:none; display:block; }
/* Detailpagina: hoofdfoto weer normaal, volledige hoogte proportioneel */
.bcm-ruimte-single .bcm-ruimte-thumb { height: auto; object-fit: initial; border-radius: 6px; }
.bcm-ruimte-overlay { position:absolute; left:0; right:0; top:0; padding:20px 12px 12px 20px; color:#fff; text-shadow:0 1px 2px rgba(0,0,0,0.5); }
.bcm-ruimte-title { margin:0; font-size:1.25rem; font-weight:800; color:#fff; }
.bcm-ruimte-cap-ov { font-size:1rem; font-weight:600; padding-bottom:12px; }
.bcm-ruimte-cta { position:absolute; left:0; right:0; bottom:0; }
.bcm-ruimte-cta .bcm-btn-cta { display:block; width:100%; padding:10px 14px; background:#00A7A0; color:#fff; text-decoration:none; text-align:center; font-weight:700; border-radius:0 0 10px 10px; }
.bcm-ruimte-info { padding: 10px 12px 12px; }
.bcm-ruimte-list { margin:0; padding:0 0 0 16px; color:#374151; }
.bcm-galerij { margin-top: 12px; overflow-x: auto; }
.bcm-galerij-track { display:flex; gap:8px; }
.bcm-galerij-item img { height: 140px; width: auto; border-radius:6px; border:1px solid #e5e7eb; }
.bcm-ruimte-titel { margin: 8px 0; font-size: 1.1rem; }
.bcm-ruimte-meta, .bcm-ruimte-prijs { color: #374151; margin: 4px 0; }
.bcm-ruimte-voorzieningen { margin: 8px 0 0; padding: 0 0 0 18px; }

/* Single ruimte */
.bcm-ruimte-single .bcm-container { max-width: 1200px; margin: 0 auto; padding: 24px 16px; }
.bcm-ruimte-header { margin-bottom: 12px; }
.bcm-ruimte-header .bcm-ruimte-titel { margin: 0 0 8px; }
.bcm-chip { display: inline-block; padding: 2px 8px; border-radius: 999px; background: #f3f4f6; color: #111827; font-size: 12px; margin-right: 6px; }
.bcm-ruimte-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 24px; align-items: start; }
.bcm-ruimte-grid.bcm-60-40 { grid-template-columns: 3fr 2fr; }
.bcm-prijzen { display: flex; gap: 16px; margin-bottom: 8px; }
.bcm-prijs strong { font-size: 1.25rem; }
.bcm-acties { display: flex; gap: 12px; margin: 12px 0; }
.bcm-btn.boeken { padding: 8px 12px; background: #111827; color: #fff; border-radius: 6px; text-decoration: none; }
.bcm-link { color: #111827; text-decoration: underline; }
.bcm-ruimte-content { margin-top: 16px; }
.bcm-voorzieningen { padding-top:20px; }
.bcm-reserveren { position: sticky; top: 16px; align-self: start; }
.bcm-reserveren-inner { border:1px solid #e5e7eb; border-radius:8px; padding:12px; background:#fff; }
.bcm-summary-card { border:1px solid #e5e7eb; border-radius:8px; padding:12px; background:#fff; margin-bottom:12px; }
.bcm-summary-head { display:flex; gap:10px; align-items:center; }
.bcm-thumb-sm { width:56px; height:56px; object-fit:cover; border-radius:6px; }
.bcm-summary-title { font-weight:700; }
.bcm-summary-title-lg { font-size: 1.6rem; line-height:1.2; }
.bcm-badge { display:inline-block; padding:2px 8px; border-radius:999px; background:#f3f4f6; font-size:12px; }
.bcm-cap { display:inline-flex; gap:4px; align-items:center; color:#374151; font-size:12px; margin-left:6px; }
.bcm-prijzen-grid { display:grid; grid-template-columns: repeat(4, 1fr); gap:6px; margin-top:10px; }
.bcm-price-chip { background:#00A7A0; color:#fff; border-radius:8px; padding:8px; text-align:center; }
.bcm-price-chip .lbl { font-size:14px; font-weight:700; opacity:0.95; }
.bcm-price-chip .val { font-size:18px; font-weight:700; }
.bcm-grid-2 { display:grid; grid-template-columns:1fr 1fr; gap:10px; }
.bcm-addons .bcm-addon-row { display:flex; justify-content:space-between; align-items:center; padding:6px 0; border-bottom:1px dashed #eee; }
.bcm-datetime { margin:8px 0 12px; }
.bcm-datetime-row { display:grid; grid-template-columns: repeat(3, 1fr); gap:8px; align-items:center; }
.bcm-datetime-row .dt-cell { position:relative; display:flex; align-items:center; }
.bcm-datetime-row .dt-cell .sep-pill { position:absolute; right:-12px; top:50%; transform:translateY(-50%); background:transparent; color:#6b7280; border-radius:6px; padding:2px 6px; font-size:14px; pointer-events:none; }
.bcm-datetime .time-pair { display:flex; align-items:center; gap:6px; }
.bcm-datetime .time-pair .sep { color:#6b7280; }
.bcm-availability-bar { margin-top:8px; border:1px solid #e5e7eb; border-radius:6px; padding:10px; background:#ecfdf5; display:grid; grid-template-columns: repeat(3, 1fr); gap:8px; }
.bcm-availability-bar .seg { display:flex; flex-direction:column; align-items:flex-start; gap:6px; color:#065f46; }
.bcm-availability-bar .lbl { font-size:15px; font-weight:700; color:#065f46; }
.bcm-availability-bar .dots { display:flex; flex-wrap:wrap; gap:3px; }
.bcm-availability-bar .dot { width:12px; height:12px; border-radius:2px; background:#e5e7eb; }
.bcm-availability-bar .dot.ok { background:#10b981; }
.bcm-availability-bar .seg .lbl { font-size:12px; color:#065f46; }
/* Grotere inputs in datum/tijd selectie */
.bcm-datetime-row input[type="date"],
.bcm-datetime-row select { height:44px; font-size:16px; padding:8px 10px; border:1px solid #e5e7eb; border-radius:6px; width:100%; }
.bcm-mode-chips { display:flex; gap:8px; margin:10px 0; }
.mode-chip { padding:6px 10px; border:1px solid #00A7A0; border-radius:999px; background:#00A7A0; color:#fff; }
.mode-chip.active, .mode-chip:hover { background:#111827; color:#fff; border-color:#111827; }
.mode-chip.disabled { opacity:0.4; pointer-events:none; }
.bcm-availability-banner { display:flex; align-items:center; gap:8px; background:#ecfdf5; border:1px solid #10b981; color:#065f46; padding:8px; border-radius:6px; margin-bottom:8px; }
.bcm-availability-banner .bars { display:flex; gap:2px; }
.bcm-availability-banner .bar { width:12px; height:12px; border-radius:2px; background:#e5e7eb; }
.bcm-availability-banner .bar.ok { background:#10b981; }
.bcm-slots .bcm-slotpick { padding:6px 10px; border:1px solid #00A7A0; border-radius:6px; background:#00A7A0; color:#fff; }
.bcm-slots .bcm-slotpick:hover { background:#111827; color:#fff; border-color:#111827; }
.bcm-slots .bcm-slotpick[disabled] { opacity:0.4; pointer-events:none; background:#f3f4f6; border-color:#e5e7eb; color:#9ca3af; }
.bcm-kalender { border:1px solid #e5e7eb; border-radius:8px; }
.bcm-kalender-head { display:flex; justify-content:space-between; align-items:center; padding:8px; border-bottom:1px solid #e5e7eb; }
.bcm-kalender-grid { padding:8px; }
.bcm-kalender-legenda { display:flex; gap:12px; align-items:center; padding:8px; color:#374151; font-size:12px; }
.bcm-kalender-legenda .lg { width:12px; height:12px; display:inline-block; border-radius:3px; margin-right:4px; vertical-align:middle; }
.bcm-kalender-legenda .lg-open { background:#ecfdf5; border:1px solid #10b981; }
.bcm-kalender-legenda .lg-partial { background:#fffbeb; border:1px solid #f59e0b; }
.bcm-kalender-legenda .lg-closed { background:#f3f4f6; border:1px solid #e5e7eb; }
.bcm-kalender-grid .bcm-weekdays { display:grid; grid-template-columns: repeat(7, 1fr); text-align:center; color:#6b7280; gap:4px; }
.bcm-kalender-grid .bcm-days { display:grid; grid-template-columns: repeat(7, 1fr); gap:4px; }
.bcm-kalender-grid .day { padding:8px 4px; border:1px solid #e5e7eb; border-radius:6px; background:#fff; color:#111827; }
.bcm-kalender-grid .day.open { background:#ecfdf5; border-color:#10b981; color:#111827; }
.bcm-kalender-grid .day.partial { background:#fffbeb; border-color:#f59e0b; color:#111827; }
.bcm-kalender-grid .day.closed { background:#f3f4f6; color:#9ca3af; }
.bcm-kalender-grid .day.sel { outline:2px solid #111827; }
.bcm-samenvatting { margin-top:12px; border-top:1px solid #e5e7eb; padding-top:8px; }
.bcm-samenvatting .rows { color:#374151; font-size:14px; margin-bottom:6px; }
.bcm-boeking-form { margin-top:10px; }
.bcm-boeking-form p { margin:0 0 10px; }
/* Specifieke styling voor submitknop in rechterkolom */
#bcm-submit { width:100%; background:#00A7A0; border:1px solid #00A7A0; color:#fff; border-radius:6px; padding:10px 14px; margin-top:10px; font-size:14px; font-weight:700; display:block; }
#bcm-submit:hover { filter:brightness(0.95); }

/* Extra diensten – nette, onopvallende uitlijning */
.bcm-addons { border:0; padding:0; margin-top:6px; }
.bcm-addons legend { font-weight:700; margin-bottom:6px; }
.bcm-addons-table { width:100%; border-collapse:collapse; border:0; }
.bcm-addons-table td { border:0; padding:4px 6px 6px 0; vertical-align:middle; font: inherit; color: inherit; }
.bcm-addons-table .col-check { width:28px; padding-right:8px; }
.bcm-addons-table .col-ttl { font-weight:500; }
.bcm-addons-table .col-prc { text-align:left; white-space:nowrap; padding-left:8px; }
.bcm-addons-table .col-unit { color:#6b7280; padding-left:6px; white-space:nowrap; }
.bcm-cta-lunch { margin-top:8px; }
.bcm-btn.bcm-lunch-btn { background:#10b981; color:#fff; border-radius:6px; padding:6px 10px; border:1px solid #10b981; }

@media (max-width: 900px) {
  .bcm-ruimte-grid { grid-template-columns: 1fr; }
  .bcm-ruimte-grid.bcm-60-40 { grid-template-columns: 1fr; }
}

/* Agenda/beschikbaarheid */
.bcm-agenda { border:1px solid #e5e7eb; border-radius:8px; }
.bcm-agenda-toolbar { display:flex; gap:8px; align-items:center; margin:12px 0; }
.bcm-agenda-header { display:grid; grid-template-columns: repeat(7, 1fr); gap:8px; padding:8px; border-bottom:1px solid #e5e7eb; background:#f9fafb; }
.bcm-agenda-colhead { text-align:center; font-weight:600; }
.bcm-agenda-grid { display:grid; grid-template-columns: repeat(7, 1fr); gap:8px; padding:8px; }
.bcm-agenda-col { min-height: 180px; border-left:1px dashed #eee; padding:4px; }
.bcm-slot { border:1px solid #e5e7eb; border-radius:6px; padding:6px; margin-bottom:6px; }
.bcm-slot-time { font-weight:600; }
.bcm-slot-free { font-size:12px; color:#374151; margin:4px 0; }
.bcm-btn.bcm-book { display:inline-block; padding:6px 10px; background:#111827; color:#fff; border-radius:6px; text-decoration:none; }
.bcm-btn[disabled], .bcm-btn-disabled { opacity:0.4; pointer-events:none; }
.bcm-empty { color:#6b7280; font-style:italic; text-align:center; margin-top:8px; }

/* Lightbox */
.bcm-ruimte-media a.bcm-lightbox-link { outline:none; border:0; }
.bcm-lightbox { position:fixed; inset:0; background:rgba(0,0,0,0.85); display:none; align-items:center; justify-content:center; z-index:999999; }
.bcm-lightbox .lb-img { max-width:90vw; max-height:90vh; border-radius:8px; display:block; }
.bcm-lightbox .lb-close, .bcm-lightbox .lb-prev, .bcm-lightbox .lb-next { position:absolute; border:0 !important; outline:none; display:flex; align-items:center; justify-content:center; width:44px; height:44px; padding:0; margin:0; cursor:pointer; background:rgba(17,24,39,0.85) !important; color:#fff !important; border-radius:50%; box-shadow:none !important; }
.bcm-lightbox .lb-close { top:16px; right:16px; font-size:22px; line-height:1; }
.bcm-lightbox .lb-prev { left:16px; top:50%; transform:translateY(-50%); font-size:28px; }
.bcm-lightbox .lb-next { right:16px; top:50%; transform:translateY(-50%); font-size:28px; }
.bcm-noscroll { overflow:hidden; }

/* Carousel */
.bcm-carousel { overflow:hidden; position:relative; }
.bcm-carousel-track { display:flex; gap:0; will-change:transform; }
/* animatie wordt via JS (requestAnimationFrame) gedaan voor naadloze loop */
.bcm-slide { min-width: 280px; max-width: 360px; flex:0 0 auto; border-radius:10px; overflow:hidden; border:1px solid #e5e7eb; background:#fff; position:relative; }
.bcm-slide + .bcm-slide { margin-left:12px; }
.bcm-slide-media img { display:block; width:100%; height:200px; object-fit:cover; }
.bcm-slide-overlay { position:absolute; left:0; right:0; top:0; padding:20px 12px 12px 20px; color:#fff !important; text-shadow:0 1px 2px rgba(0,0,0,0.5); pointer-events:none; }
.bcm-slide-title { margin:0; font-size:1.35rem; font-weight:800; color:#fff !important; }
.bcm-slide-cap { font-size:1.05rem; padding-bottom:14px; font-weight:600; }
/* CTA over de afbeelding, volledige breedte onderaan */
.bcm-slide-cta { position:absolute; left:0; right:0; bottom:0; padding:0; display:block; }
.bcm-btn-cta { display:block; width:100%; padding:10px 14px; background:#00A7A0; color:#fff !important; border-radius:0 0 10px 10px; text-decoration:none !important; text-align:center; font-weight:700; }
