/* =============================================================================
   CINESTAR EVENTS — Upcoming Events Page Styles
   theme/cinestar-child/assets/css/events.css
   Depends on: assets/css/main.css (design tokens + layout utilities + components)
   Sections:
     1. #main-content overflow guard
     3. Page Hero  (.ce-pg-hero)
     4. Countdown Strip  (.ce-events-cd)
     5. Filter Bar  (.ce-events-filter-bar)
     6. Events Grid  (.ce-events-grid)
     7. Event Card  (.ce-event-card)
     8. Empty State
     9. Reduced Motion
   ============================================================================= */


/* .ce-skip-link — defined globally in main.css */


/* =============================================================================
   2. MAIN CONTENT OVERFLOW GUARD
   ============================================================================= */

#main-content {
  width: 100%;
  min-width: 0;
  /* overflow-x: hidden omitted — it clips sticky filter bar pills and breaks sticky positioning */
}


/* =============================================================================
   3. PAGE HERO  (.ce-pg-hero)
   Concert-lights radial gradient overlay, ~50vh on desktop.
   .ce-hero class triggers header.js transparent→solid behaviour.
   ============================================================================= */

.ce-pg-hero {
  position: relative;
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  overflow: hidden;
  /* padding-top = header height + breathing room so eyebrow never sits behind nav */
  padding-block: calc(var(--ce-header-h) + 3rem) 3rem;
}

/* Radial stage-lighting gradient */
.ce-pg-hero__bg {
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 15% 0%,  rgba(123, 47, 190, 0.28) 0%, transparent 60%),
    radial-gradient(ellipse 60% 50% at 85% 0%,  rgba(255, 20, 147, 0.18) 0%, transparent 55%),
    radial-gradient(ellipse 100% 80% at 50% 0%, rgba(255, 215, 0, 0.08)  0%, transparent 55%),
    var(--ce-bg);
  z-index: 0;
}

/* Bottom gradient fade into page bg — smooth transition into countdown strip */
.ce-pg-hero__fade {
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 6rem;
  background: linear-gradient(to bottom, transparent, var(--ce-bg));
  z-index: 1;
  pointer-events: none;
}

.ce-pg-hero__content {
  position: relative;
  z-index: 2;
}

.ce-pg-hero__eyebrow {
  font-family: var(--ce-font-heading);
  font-size: var(--ce-text-sm);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--ce-gold);
  margin-block: 0 0.875rem;
}

.ce-pg-hero__headline {
  font-family: var(--ce-font-heading);
  font-size: clamp(2.5rem, 6vw, 4.5rem);
  font-weight: 900;
  line-height: 1.05;
  color: var(--ce-text);
  margin-block: 0 1rem;
}

.ce-pg-hero__sub {
  font-family: var(--ce-font-body);
  font-size: clamp(var(--ce-text-base), 2vw, var(--ce-text-lg));
  color: var(--ce-text-muted);
  line-height: 1.6;
  max-width: 44ch;
  margin-inline: auto;
  margin-block: 0;
}

@media (min-width: 768px) {
  .ce-pg-hero {
    padding-block: calc(var(--ce-header-h) + 4rem) 5rem;
  }
}


/* =============================================================================
   4. COUNTDOWN STRIP  (.ce-events-cd)
   Single-line text: "Next Event: [name] — X days X hrs X mins"
   ============================================================================= */

.ce-events-cd {
  background-color: var(--ce-bg-raised);
  border-block: 1px solid var(--ce-border);
  padding-block: 0.875rem;
}

.ce-events-cd__text {
  margin: 0;
  font-family: var(--ce-font-body);
  font-size: var(--ce-text-sm);
  color: var(--ce-text-muted);
  text-align: center;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 0.375rem;
}

.ce-events-cd__label {
  font-family: var(--ce-font-heading);
  font-size: var(--ce-text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ce-text-faint);
}

.ce-events-cd__name {
  font-family: var(--ce-font-heading);
  font-weight: 700;
  color: var(--ce-text);
}

.ce-events-cd__sep {
  color: var(--ce-border-gold);
}

/* The live-updating inline numbers */
.ce-events-cd__inline {
  font-family: var(--ce-font-heading);
  font-weight: 700;
  color: var(--ce-gold);
  letter-spacing: 0.02em;
}

/* Static date shown as fallback when JS is off */
.ce-events-cd__date-fallback {
  display: none; /* JS will show countdown; leave this hidden */
}

.no-js .ce-events-cd__inline {
  display: none;
}

.no-js .ce-events-cd__date-fallback {
  display: inline;
}


/* =============================================================================
   5. FILTER BAR  (.ce-events-filter-bar)
   Sticky under header; two rows on mobile/tablet, one row on 1024px+.
   City pills scroll horizontally on mobile via .ce-filter-scroll wrapper.
   ============================================================================= */

.ce-events-filter-bar {
  border-bottom: 1px solid var(--ce-border);
  padding-block: 1.125rem;
  position: sticky;
  top: var(--ce-header-h);
  z-index: 100;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  background-color: rgba(10, 10, 10, 0.95);
}

/* WP admin bar offset */
body.admin-bar .ce-events-filter-bar {
  top: calc(var(--ce-header-h) + 32px);
}

@media screen and (max-width: 782px) {
  body.admin-bar .ce-events-filter-bar {
    top: calc(var(--ce-header-h) + 46px);
  }
}

/* Two rows (column) on mobile/tablet — one row on 1024px+ */
.ce-events-filter {
  display: flex;
  flex-direction: column;
  gap: 0.625rem;
}

@media (min-width: 1024px) {
  .ce-events-filter {
    flex-direction: row;
    align-items: center;
    gap: 1.5rem;
  }
}

.ce-events-filter__group {
  display: flex;
  align-items: center;
  gap: 0.625rem;
  min-width: 0;
}

.ce-events-filter__label {
  font-family: var(--ce-font-heading);
  font-size: var(--ce-text-xs);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--ce-text-faint);
  white-space: nowrap;
  flex-shrink: 0;
}

/* Scroll wrapper — provides local overflow clip + left/right fade indicators */
.ce-filter-scroll {
  position: relative;
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden; /* local clip — does NOT affect sticky or outer layout */
}

/* Right fade — always visible (hints scrollable content) */
.ce-filter-scroll::after {
  content: '';
  position: absolute;
  right: 0;
  top: 0;
  bottom: 0;
  width: 2.5rem;
  background: linear-gradient(to left, rgba(10, 10, 10, 0.9), transparent);
  pointer-events: none;
  z-index: 1;
  opacity: 1;
  transition: opacity 0.2s ease;
}

/* Left fade — hidden until JS adds .has-scrolled */
.ce-filter-scroll::before {
  content: '';
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  width: 2.5rem;
  background: linear-gradient(to right, rgba(10, 10, 10, 0.9), transparent);
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  transition: opacity 0.2s ease;
}

.ce-filter-scroll.has-scrolled::before {
  opacity: 1;
}

.ce-filter-scroll.is-at-end::after {
  opacity: 0;
}

/* At 1024px+ all pills fit in one line — no clipping or fades needed */
@media (min-width: 1024px) {
  .ce-filter-scroll {
    overflow: visible;
  }

  .ce-filter-scroll::before,
  .ce-filter-scroll::after {
    display: none;
  }
}

/* Pill row — scrolls horizontally on mobile */
.ce-events-filter__pills {
  display: flex;
  gap: 0.375rem;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  padding-block: 2px; /* prevents focus-ring clipping */
}

.ce-events-filter__pills::-webkit-scrollbar {
  display: none;
}

/* Individual pill */
.ce-filter-pill {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  white-space: nowrap;
  flex-shrink: 0;
  min-height: 44px; /* WCAG 2.5.5 touch target */
  padding: 0.25rem 0.625rem;
  font-family: var(--ce-font-heading);
  font-size: 0.6875rem; /* 11px — fits all pills at tablet without scrolling */
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--ce-text-muted);
  background-color: transparent;
  border: 1px solid var(--ce-border);
  border-radius: 100px;
  cursor: pointer;
  transition:
    color var(--ce-transition),
    background-color var(--ce-transition),
    border-color var(--ce-transition),
    box-shadow var(--ce-transition);
}

.ce-filter-pill:hover,
.ce-filter-pill:focus-visible {
  color: var(--ce-gold);
  border-color: var(--ce-border-gold);
  outline: none;
}

.ce-filter-pill:focus-visible {
  box-shadow: 0 0 0 2px var(--ce-gold);
}

.ce-filter-pill.is-active {
  color: #0A0A0A;
  background-color: var(--ce-gold);
  border-color: var(--ce-gold);
}

.ce-filter-pill.is-active:hover {
  background-color: var(--ce-gold-hover);
  border-color: var(--ce-gold-hover);
}

/* 1024px+ pointer device: reduce touch target size (mouse, not touch) */
@media (min-width: 1024px) {
  .ce-filter-pill {
    min-height: 36px; /* pointer device — font/padding already compact globally */
  }
}


/* =============================================================================
   6. EVENTS GRID  (.ce-events-grid)
   1 col mobile → 2 cols tablet → 3 cols desktop.
   JS toggles .ce-event-card--hidden on filtered-out cards.
   ============================================================================= */

.ce-events-section {
  min-height: 40vh; /* prevents layout jump when all cards hidden */
}

.ce-events-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 1.5rem;
}

@media (min-width: 640px) {
  .ce-events-grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (min-width: 1024px) {
  .ce-events-grid {
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
  }
}

.ce-event-card--hidden {
  display: none;
}


/* =============================================================================
   7. EVENT CARD  (.ce-event-card)
   Dark card with poster image (+ gradient fallback), status badge top-right,
   artist name, date/location meta, full-width CTA button.
   Hover: scale(1.02) + gold glow.
   ============================================================================= */

.ce-event-card {
  display: flex;
  flex-direction: column;
  background-color: var(--ce-bg-card);
  border: 1px solid var(--ce-border);
  border-radius: var(--ce-radius-lg, 12px);
  overflow: hidden;
  transition:
    transform 0.25s ease,
    box-shadow 0.25s ease,
    border-color 0.25s ease;
}

/* Only apply card lift on pointer devices — prevents sticky hover on mobile tap */
@media (hover: hover) {
  .ce-event-card:hover {
    transform: translateY(-4px) scale(1.02);
    box-shadow: var(--ce-glow-gold);
    border-color: var(--ce-border-gold);
  }
}

/* ── Poster area ── */
.ce-event-card__poster {
  position: relative;
  width: 100%;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  background-color: #111;
}

.ce-event-card__img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.35s ease;
}

@media (hover: hover) {
  .ce-event-card:hover .ce-event-card__img {
    transform: scale(1.05);
  }
}

/* Gradient placeholder fills poster area */
.ce-event-card__img--gradient {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}


/* Bottom gradient on poster for body transition */
.ce-event-card__poster::after {
  content: '';
  position: absolute;
  inset: auto 0 0 0;
  height: 40%;
  background: linear-gradient(to bottom, transparent, rgba(10, 10, 10, 0.85));
  pointer-events: none;
}

/* ── Status badge — top-right of poster ── */
.ce-event-card__badge {
  position: absolute;
  top: 0.75rem;
  right: 0.75rem;
  z-index: 2;
  padding: 0.25rem 0.625rem;
  font-family: var(--ce-font-heading);
  font-size: 0.65rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  border-radius: 100px;
  white-space: nowrap;
}

/* Green = On Sale */
.ce-event-card__badge--on-sale {
  background-color: #16a34a;
  color: #ffffff;
}

/* Gold = Coming Soon */
.ce-event-card__badge--coming-soon {
  background-color: var(--ce-gold);
  color: #0A0A0A;
}

/* Red = Sold Out */
.ce-event-card__badge--sold-out {
  background-color: #dc2626;
  color: #ffffff;
}

/* ── Card body ── */
.ce-event-card__body {
  display: flex;
  flex-direction: column;
  flex: 1;
  padding: 1.25rem 1.25rem 0;
}

.ce-event-card__artist {
  font-family: var(--ce-font-heading);
  font-size: var(--ce-text-lg);
  font-weight: 800;
  color: var(--ce-text);
  margin-block: 0 0.375rem;
  line-height: 1.2;
}

.ce-event-card__meta {
  font-family: var(--ce-font-body);
  font-size: var(--ce-text-sm);
  color: var(--ce-gold);
  margin-block: 0 1rem;
  line-height: 1.4;
}

/* ── Full-width CTA button at card bottom ── */
.ce-event-card__cta {
  margin-top: auto;
  padding: 1rem 1.25rem 1.25rem;
}

.ce-event-card__btn {
  display: block;
  width: 100%;
  text-align: center;
}


/* =============================================================================
   7b. FEATURED EVENT CARD (single event, centred layout)
   Used when only one event is listed — wider card, centred on page.
   ============================================================================= */

.ce-events-featured {
  display: flex;
  justify-content: center;
}

.ce-event-card--featured {
  max-width: 650px;
  width: 100%;
}

.ce-event-card--featured .ce-event-card__poster {
  aspect-ratio: auto;
}

.ce-event-card--featured .ce-event-card__img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: center top;
}

@media (min-width: 768px) {
  .ce-event-card--featured .ce-event-card__artist {
    font-size: var(--ce-text-xl);
  }

  .ce-event-card--featured .ce-event-card__meta {
    font-size: var(--ce-text-base);
  }
}


/* =============================================================================
   8. EMPTY STATE
   Shown by JS when all cards are filtered out. Hidden by default.
   ============================================================================= */

.ce-events-empty {
  text-align: center;
  padding-block: var(--ce-space-xl);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1.5rem;
}

.ce-events-empty[hidden] {
  display: none;
}

.ce-events-empty p {
  font-family: var(--ce-font-body);
  font-size: var(--ce-text-lg);
  color: var(--ce-text-muted);
  margin: 0;
}


/* =============================================================================
   9. REDUCED MOTION
   ============================================================================= */

@media (prefers-reduced-motion: reduce) {
  .ce-event-card,
  .ce-event-card__img,
  .ce-pg-hero__bg {
    transition: none;
    animation: none;
  }
  @media (hover: hover) {
    .ce-event-card:hover {
      transform: none;
    }
  }
}
