
/* ═══════════════════════════════════════
   PAGE-SPECIFIC: Events
   ═══════════════════════════════════════ */

/* ── Hero ── */
.page-hero {
  position: relative; height: 380px; overflow: hidden;
  display: flex; align-items: flex-end; background: var(--black);
}
.page-hero-bg {
  position: absolute; inset: 0;
  background: url('https://images.unsplash.com/photo-1511578314322-379afb476865?w=1600&q=80') center/cover no-repeat;
  filter: grayscale(35%) brightness(0.3); transform: scale(1.03);
}
.page-hero-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, var(--black) 0%, rgba(8,8,8,0.55) 50%, rgba(8,8,8,0.15) 100%);
}
.page-hero::before {
  content:''; position:absolute; inset:0; z-index:1;
  background-image: linear-gradient(rgba(201,168,76,0.04) 1px,transparent 1px),
                    linear-gradient(90deg,rgba(201,168,76,0.04) 1px,transparent 1px);
  background-size:64px 64px;
}
.page-hero-content { position:relative; z-index:10; padding:0 64px 56px; width:100%; }
.breadcrumb-kbc { display:flex; align-items:center; gap:8px; margin-bottom:14px; }
.breadcrumb-kbc a { font-size:10px; letter-spacing:2px; text-transform:uppercase; color:var(--gray); text-decoration:none; transition:color .2s; }
.breadcrumb-kbc a:hover { color:var(--gold); }
.breadcrumb-kbc span { font-size:10px; color:var(--gold); letter-spacing:2px; text-transform:uppercase; }
.breadcrumb-sep { color:rgba(201,168,76,0.4); font-size:10px; }
.page-hero-title { font-family:var(--font-alt); font-size:clamp(60px,9vw,120px); color:var(--white); letter-spacing:3px; line-height:.9; }
.page-hero-title .accent { color:var(--gold); }
.hero-entry { opacity:0; transform:translateY(20px); animation:heroIn .8s var(--ease-expo) forwards; }
@keyframes heroIn { to { opacity:1; transform:translateY(0); } }

/* ── Toolbar ── */
.events-toolbar {
  background: var(--dark-2); border-bottom: 1px solid rgba(201,168,76,0.08);
  padding: 18px 64px; display: flex; align-items: center; gap: 12px; flex-wrap: wrap;
  position: sticky; top: 0; z-index: 200;
}
.search-wrap { position:relative; flex:1; max-width:360px; }
.search-input { width:100%; background:var(--dark-3); border:1px solid rgba(201,168,76,0.15); color:var(--white); font-family:var(--font-body); font-size:12px; padding:11px 40px 11px 16px; border-radius:var(--r-sm); outline:none; transition:border-color .2s; }
.search-input::placeholder { color:var(--gray); }
.search-input:focus { border-color:rgba(201,168,76,0.45); }
.search-icon { position:absolute; right:14px; top:50%; transform:translateY(-50%); color:var(--gold); font-size:14px; pointer-events:none; }
.filter-pill { padding:9px 18px; border-radius:40px; border:1px solid rgba(201,168,76,0.15); background:transparent; color:var(--gray-light); font-size:10px; font-weight:500; letter-spacing:2px; text-transform:uppercase; cursor:pointer; transition:all .2s; font-family:var(--font-body); white-space:nowrap; }
.filter-pill:hover, .filter-pill.active { border-color:var(--gold); color:var(--gold); background:var(--gold-pale); }
.event-count { font-size:11px; color:var(--gray); margin-left:auto; white-space:nowrap; }
.event-count strong { color:var(--gold); }

/* ── Featured Event ── */
.featured-section { background: var(--dark); padding: 56px 0 0; }

.featured-event {
  background: linear-gradient(135deg, var(--dark-2) 0%, rgba(201,168,76,0.04) 100%);
  border: 1px solid rgba(201,168,76,0.2); border-radius: 12px; overflow: hidden;
  display: flex; min-height: 360px;
}
.featured-event-img {
  width: 42%; flex-shrink: 0; position: relative; overflow: hidden;
}
.featured-event-img img { width:100%; height:100%; object-fit:cover; filter:grayscale(15%) brightness(0.75); transition:transform .6s var(--ease-silk); }
.featured-event:hover .featured-event-img img { transform:scale(1.05); }
.featured-event-img::after { content:''; position:absolute; inset:0; background:linear-gradient(to right, transparent 60%, rgba(8,8,8,0.6) 100%); }
.featured-event-body { padding: 44px 48px; display:flex; flex-direction:column; justify-content:center; flex:1; }
.featured-label { font-size:9px; letter-spacing:3px; text-transform:uppercase; color:var(--gold); display:flex; align-items:center; gap:8px; margin-bottom:12px; }
.featured-label::before { content:''; width:20px; height:1px; background:var(--gold); }
.featured-type-badge { display:inline-block; background:var(--gold); color:var(--black); font-size:9px; font-weight:700; letter-spacing:2px; text-transform:uppercase; padding:4px 12px; border-radius:2px; margin-bottom:14px; }
.featured-title { font-family:var(--font-display); font-size:clamp(20px,2.5vw,32px); font-weight:700; color:var(--white); line-height:1.25; margin-bottom:16px; }
.featured-meta { display:flex; flex-direction:column; gap:8px; margin-bottom:24px; }
.featured-meta-item { font-size:12px; color:var(--gray-light); display:flex; align-items:center; gap:9px; }
.featured-meta-item i { color:var(--gold); font-size:13px; width:16px; }

/* date block */
.featured-date {
  display:flex; gap:12px; align-items:center; margin-bottom:28px;
  background:rgba(201,168,76,0.07); border:1px solid rgba(201,168,76,0.15);
  border-radius:var(--r-sm); padding:14px 18px; width:fit-content;
}
.date-big { font-family:var(--font-alt); font-size:44px; color:var(--gold); line-height:1; }
.date-info { display:flex; flex-direction:column; }
.date-month { font-size:12px; font-weight:700; letter-spacing:2px; color:var(--white); text-transform:uppercase; }
.date-year  { font-size:10px; color:var(--gray); letter-spacing:1px; }

.btn-register-featured {
  display:inline-flex; align-items:center; gap:10px;
  background:var(--gold); color:var(--black); border:none;
  padding:13px 28px; font-size:11px; font-weight:700;
  letter-spacing:2.5px; text-transform:uppercase;
  border-radius:var(--r-sm); text-decoration:none;
  transition:all .25s; cursor:pointer;
}
.btn-register-featured:hover { background:var(--gold-light); transform:translateY(-2px); box-shadow:0 10px 28px rgba(201,168,76,0.25); color:var(--black); }

/* ── Events Grid ── */
.events-section { background: var(--dark); padding: 48px 0 80px; }

.event-card {
  background: var(--dark-2); border: 1px solid rgba(201,168,76,0.07);
  border-radius: var(--r); overflow: hidden;
  transition: all .35s var(--ease-silk); height:100%; display:flex; flex-direction:column;
}
.event-card:hover { border-color:rgba(201,168,76,0.32); transform:translateY(-7px); box-shadow:0 24px 52px rgba(0,0,0,0.45); }

.event-cover { position:relative; height:190px; overflow:hidden; flex-shrink:0; }
.event-cover img { width:100%; height:100%; object-fit:cover; filter:grayscale(20%) brightness(0.72); transition:all .55s var(--ease-silk); }
.event-card:hover .event-cover img { transform:scale(1.07); filter:grayscale(0%) brightness(0.78); }
.event-cover::after { content:''; position:absolute; inset:0; background:linear-gradient(to top, rgba(22,22,22,0.92) 0%, rgba(22,22,22,0.25) 55%, transparent 100%); }

.event-type-tag { position:absolute; top:13px; left:13px; z-index:2; font-size:9px; letter-spacing:2px; text-transform:uppercase; color:var(--black); background:var(--gold); padding:4px 10px; border-radius:2px; font-weight:700; }
.event-city-tag { position:absolute; top:13px; right:13px; z-index:2; font-size:9px; letter-spacing:1.5px; text-transform:uppercase; color:var(--white); background:rgba(8,8,8,0.75); padding:4px 10px; border-radius:2px; backdrop-filter:blur(4px); }

.event-date-block { position:absolute; bottom:0; left:16px; z-index:2; background:var(--gold); color:var(--black); padding:8px 14px; border-radius:var(--r-sm) var(--r-sm) 0 0; text-align:center; min-width:52px; }
.date-day   { font-family:var(--font-alt); font-size:28px; line-height:1; display:block; }
.date-month { font-size:9px; font-weight:700; letter-spacing:1px; display:block; }
.date-year  { font-size:8px; opacity:.65; letter-spacing:1px; display:block; }

.event-body { padding:18px 20px 22px; flex:1; display:flex; flex-direction:column; }
.event-title { font-size:13px; font-weight:600; color:var(--white); line-height:1.45; margin-bottom:12px; flex:1; }
.event-meta-row { display:flex; flex-direction:column; gap:7px; margin-bottom:16px; }
.event-meta-item { font-size:11px; color:var(--gray); display:flex; align-items:center; gap:7px; }
.event-meta-item i { color:var(--gold); font-size:11px; flex-shrink:0; }

.btn-register {
  display:inline-flex; align-items:center; gap:8px;
  padding:9px 20px; background:transparent; color:var(--gold);
  border:1px solid rgba(201,168,76,0.35); font-size:10px; font-weight:700;
  letter-spacing:2px; text-transform:uppercase; text-decoration:none;
  border-radius:var(--r-sm); transition:all .22s; width:fit-content;
}
.btn-register:hover { background:var(--gold); color:var(--black); border-color:var(--gold); }

/* ── Pagination ── */
.pagination-wrap { display:flex; align-items:center; justify-content:center; gap:6px; padding:48px 0 0; }
.page-btn { width:38px; height:38px; display:flex; align-items:center; justify-content:center; border-radius:var(--r-sm); border:1px solid rgba(201,168,76,0.12); background:transparent; color:var(--gray); font-size:12px; cursor:pointer; transition:all .2s; font-family:var(--font-body); }
.page-btn:hover { border-color:rgba(201,168,76,0.35); color:var(--gold); }
.page-btn.active { background:var(--gold); color:var(--black); border-color:var(--gold); font-weight:700; }
.page-btn:disabled { opacity:.3; cursor:default; pointer-events:none; }

/* ── No results ── */
.empty-state { text-align:center; padding:72px 20px; }
.empty-state i { font-size:48px; color:rgba(201,168,76,0.2); display:block; margin-bottom:16px; }
.empty-state p { font-size:13px; color:var(--gray); }

/* responsive */
@media (max-width:991.98px) {
  .page-hero-content { padding:0 32px 48px; }
  .events-toolbar { padding:16px 24px; }
  .featured-event { flex-direction:column; }
  .featured-event-img { width:100%; height:240px; }
  .featured-event-body { padding:28px 24px; }
}
@media (max-width:575.98px) {
  .page-hero-content { padding:0 20px 36px; }
  .events-toolbar { flex-wrap:wrap; }
  .search-wrap { max-width:100%; width:100%; }
}