/* Bela Module Events — Frontend styles */

/* ─── Filters ─── */
.bela-event-filters { display:flex; flex-wrap:wrap; gap:8px; margin-bottom:24px; }
.bela-event-filters__item { padding:6px 16px; border-radius:20px; font-size:13px; font-weight:500; color:var(--bela-text-secondary); background:var(--bela-bg-alt); text-decoration:none; transition:all .15s; }
.bela-event-filters__item:hover, .bela-event-filters__item--active { background:var(--bela-primary); color:#fff; text-decoration:none; }

/* ─── Event list ─── */
.bela-event-list { display:flex; flex-direction:column; gap:12px; margin-bottom:32px; }

/* ─── Card ─── */
.bela-event-card { display:flex; align-items:flex-start; gap:16px; padding:16px 20px; background:var(--bela-surface); border:1px solid var(--bela-border); border-radius:12px; transition:box-shadow .15s; }
.bela-event-card:hover { box-shadow:0 4px 16px rgba(0,0,0,.06); }
.bela-event-card--featured { border-left:3px solid var(--bela-accent); }
.bela-event-card--cancelled { opacity:.65; }
.bela-event-card--cancelled .bela-event-card__title a { text-decoration:line-through; }

.bela-event-card__date-block { text-align:center; min-width:52px; flex-shrink:0; background:var(--bela-primary); color:#fff; border-radius:10px; padding:8px 6px; }
.bela-event-card__day { display:block; font-size:22px; font-weight:800; font-family:var(--bela-font-heading); line-height:1; }
.bela-event-card__month { display:block; font-size:11px; text-transform:uppercase; letter-spacing:.05em; }
.bela-event-card__weekday { display:block; font-size:10px; opacity:.8; }

.bela-event-card__thumb { flex-shrink:0; width:80px; height:80px; border-radius:8px; overflow:hidden; }
.bela-event-card__thumb img { width:100%; height:100%; object-fit:cover; }

.bela-event-card__body { flex:1; min-width:0; }
.bela-event-card__top { display:flex; gap:8px; align-items:center; margin-bottom:4px; }
.bela-event-card__cat { font-size:11px; font-weight:600; text-transform:uppercase; color:var(--bela-secondary); }
.bela-event-card__star { font-size:14px; }

.bela-event-card__title { font-size:16px; font-weight:600; margin-bottom:6px; }
.bela-event-card__title a { color:var(--bela-text); text-decoration:none; }
.bela-event-card__title a:hover { color:var(--bela-primary); text-decoration:underline; }

.bela-event-card__meta { display:flex; flex-wrap:wrap; gap:12px; font-size:12px; color:var(--bela-text-muted); margin-bottom:6px; }
.bela-event-card__footer { display:flex; gap:10px; align-items:center; }
.bela-event-card__org { font-size:12px; color:var(--bela-text-secondary); }

/* ─── Badges ─── */
.bela-event-badge { display:inline-block; padding:3px 10px; border-radius:4px; font-size:11px; font-weight:700; }
.bela-event-badge--free { background:var(--bela-secondary); color:#fff; }
.bela-event-badge--price { background:var(--bela-bg-alt); color:var(--bela-text); border:1px solid var(--bela-border); }
.bela-event-badge--cancelled { background:var(--bela-danger); color:#fff; }
.bela-event-badge--featured { background:var(--bela-accent); color:#fff; }

/* ─── Tags ─── */
.bela-event-tag { display:inline-block; padding:4px 12px; border-radius:20px; font-size:12px; background:var(--bela-bg-alt); color:var(--bela-text-secondary); text-decoration:none; margin:2px; }
.bela-event-tag:hover { background:var(--bela-primary); color:#fff; text-decoration:none; }
.bela-event-single__tags { margin-top:24px; padding-top:16px; border-top:1px solid var(--bela-border); }

/* ─── Single ─── */
.bela-event-single__header { margin-bottom:20px; }
.bela-event-single--cancelled .bela-event-single__title { text-decoration:line-through; opacity:.6; }
.bela-event-single__title { font-size:clamp(24px,4vw,36px); margin-top:10px; }
.bela-event-single__date { font-size:16px; color:var(--bela-text-secondary); margin-top:4px; }
.bela-event-single__poster { margin:20px 0; border-radius:12px; overflow:hidden; }
.bela-event-single__poster img { width:100%; height:auto; display:block; }
.bela-event-single__content { font-size:16px; line-height:1.7; margin:24px 0; }
.bela-event-single__content p { margin-bottom:12px; }

/* ─── Meta ─── */
.bela-event-meta { display:grid; grid-template-columns:auto 1fr; gap:6px 16px; font-size:14px; margin:16px 0 24px; padding:16px; background:var(--bela-bg-alt); border-radius:8px; }
.bela-event-meta dt { font-weight:600; color:var(--bela-primary); }
.bela-event-meta dd { margin:0; }
.bela-event-meta a { color:var(--bela-secondary); }

/* ─── Program ─── */
.bela-event-program { margin:24px 0; }
.bela-event-program h3 { font-size:18px; margin-bottom:14px; }
.bela-event-program__list { display:flex; flex-direction:column; gap:0; border-left:3px solid var(--bela-primary); padding-left:20px; }
.bela-event-program__item { display:flex; gap:12px; align-items:baseline; padding:8px 0; border-bottom:1px solid var(--bela-border); position:relative; }
.bela-event-program__item::before { content:''; position:absolute; left:-25px; top:14px; width:10px; height:10px; border-radius:50%; background:var(--bela-primary); }
.bela-event-program__time { font-weight:700; font-family:var(--bela-font-mono); font-size:14px; color:var(--bela-primary); min-width:50px; flex-shrink:0; }
.bela-event-program__title { font-size:15px; font-weight:500; }
.bela-event-program__note { font-size:13px; color:var(--bela-text-muted); }

/* ─── Gallery ─── */
.bela-event-gallery { margin:24px 0; }
.bela-event-gallery h3 { font-size:16px; margin-bottom:12px; }
.bela-event-gallery__grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(150px,1fr)); gap:8px; }
.bela-event-gallery__item { display:block; border-radius:8px; overflow:hidden; aspect-ratio:4/3; }
.bela-event-gallery__item img { width:100%; height:100%; object-fit:cover; transition:transform .2s; }
.bela-event-gallery__item:hover img { transform:scale(1.05); }

/* ─── Empty ─── */
.bela-event-empty { text-align:center; padding:48px 20px; color:var(--bela-text-muted); }

/* ─── Responsive ─── */
@media(max-width:768px) {
    .bela-event-card { flex-direction:column; gap:10px; }
    .bela-event-card__date-block { flex-direction:row; display:flex; gap:6px; align-items:center; border-radius:8px; padding:6px 14px; }
    .bela-event-card__thumb { width:100%; height:160px; }
    .bela-event-gallery__grid { grid-template-columns:repeat(2,1fr); }
    .bela-event-program__item { flex-direction:column; gap:2px; }
}
