.hsbw-events-list.columns{display:flex;flex-direction:column;gap:14px}
.hsbw-event-row{display:grid;grid-template-columns:180px 1px 150px 1px minmax(300px,1fr) 1px 140px 1px 180px;gap:12px;align-items:stretch;background:#fff;border-radius:10px;box-shadow:0 2px 10px rgba(0,0,0,.05);padding:14px;border-left:6px solid var(--event-color,#5BB98B)}
.hsbw-colorbar{grid-column:1/2;border-radius:8px;background:var(--event-color,#5BB98B);width:6px;min-height:100%;align-self:stretch;display:block}
.divider{width:1px;background:rgba(0,0,0,.12);align-self:stretch;display:block;opacity:.6}
.col{display:flex;flex-direction:column}
.col.date,.col.price,.col.capacity,.col.cta{align-items:center;justify-content:flex-start;text-align:center}
.col.content{align-items:flex-start;justify-content:flex-start;text-align:left}
.col.date .dm{font-size:18px;font-weight:700;line-height:1.1}
.col.date .year{font-size:12px;opacity:.8;margin-top:2px}
.col.date .t{font-size:12px;opacity:.9;margin-top:4px}
.col.price .label,.col.capacity .label{font-size:12px;opacity:.7;margin-bottom:2px}
.col.price .value{font-weight:700}
.col.content .title{margin:0 0 4px;font-size:18px;font-weight:700}
.col.content .desc{font-size:14px;color:#444}
.col.capacity .value{font-size:18px;font-weight:800}
.col.cta .btn{display:inline-block;padding:10px 16px;border-radius:999px;font-weight:700;text-decoration:none}
.col.cta .btn.bookable{background:#1fb976;color:#fff}
.col.cta .btn.soldout{background:#e06464;color:#fff} /* red when sold out */
.col.cta .btn.waitlist{background:#f8d486;color:#6b4b00}

@media(max-width:980px){
  .hsbw-event-row{grid-template-columns:140px 1px 120px 1px 1fr;grid-auto-rows:auto;border-left:6px solid var(--event-color,#5BB98B)}
  .col.capacity,.col.cta{grid-column:2/-1;align-items:flex-start;text-align:left}
  .hsbw-event-row > .divider:nth-of-type(n+7){display:none}
}

/* Modal */
.hsbw-modal{position:fixed;inset:0;display:none;z-index:9999}
.hsbw-modal.open{display:block}
.hsbw-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.4)}
.hsbw-modal-dialog{
  /* Center the dialog in the viewport */
  position:absolute;
  top:50%;
  left:50%;
  transform:translate(-50%, -50%);
  max-width:520px;
  width:90%;
  background:#fff;
  border-radius:12px;
  box-shadow:0 10px 30px rgba(0,0,0,.2);
  padding:16px;
}
.hsbw-modal-close{position:absolute;top:6px;right:8px;border:0;background:transparent;font-size:20px;line-height:1;cursor:pointer}
.hsbw-modal-title{margin:0 0 10px;font-size:18px;font-weight:700}

/* Registration form */
.hsbw-reg-form{margin-top:8px}
.hsbw-reg-form .row{margin-bottom:6px}
.hsbw-reg-form input{width:100%;padding:8px;border:1px solid #ddd;border-radius:6px}
.hsbw-reg-msg{margin-top:6px;font-size:12px}
.hsbw-reg-msg.ok{color:#1b8a5a}
.hsbw-reg-msg.err{color:#b00020}

/* --- Clickability Hotfix (1.5.8) --- */
.hsbw-event-row{position:relative}
.hsbw-event-row .divider,
.hsbw-event-row .hsbw-colorbar{pointer-events:none;z-index:0}
.hsbw-event-row .col{position:relative;z-index:1}
.hsbw-event-row .col.cta{z-index:10}
.hsbw-event-row .col.cta .btn{position:relative;z-index:11;display:inline-block}
/* Sometimes builders wrap rows with overlays; ensure our CTA wins */
.hsbw-event-row *{pointer-events:auto}
