/**
 * CECCM - Homepage Styles
 *
 * Dedicated styles for the homepage (index.php).
 * Contains ONLY homepage-specific overrides not found in landing.css.
 * All shared styles (hero, features, live, events, CTA, responsive) come from landing.css.
 *
 * @version 2.0.0
 * @date 2026-03-24
 */

/* ============================================
   SECTION HEADER OVERRIDES
   Homepage removes max-width constraint and ensures centering
   ============================================ */
.section-header {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: none !important;
  text-align: center;
}

.section-header .heading-display,
.section-header .heading-2,
.section-header h2,
#features-heading,
#live-heading,
#events-heading {
  text-align: center !important;
  width: 100%;
}

/* ============================================
   EVENT TIME (Homepage-specific)
   Separate from .event-location which is defined in landing.css
   ============================================ */
.event-time {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: #d1d5db;
  font-size: var(--text-sm);
  margin-bottom: var(--space-4);
}

.event-time-icon {
  color: var(--color-accent-violet);
  font-size: var(--text-base);
}

/* ============================================
   EVENT CARD (Homepage-specific consistency fixes)
   ============================================ */
.events-section .event-card {
  display: flex;
  flex-direction: column;
  padding: var(--space-6);
  position: relative;
  overflow: hidden;
}

.events-section .event-card .event-title {
  color: #ffffff;
  font-size: var(--text-xl);
  font-weight: var(--font-weight-semibold);
  margin: var(--space-4) 0 var(--space-2);
  line-height: 1.3;
}

.events-section .event-card .event-location {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  color: #d1d5db;
  font-size: var(--text-sm);
  margin-bottom: var(--space-2);
}

.events-section .event-card .event-location-icon {
  color: var(--color-accent-cyan);
  font-size: var(--text-base);
  flex-shrink: 0;
}

.events-section .event-card .event-info {
  color: #9ca3af;
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  margin-bottom: var(--space-6);
  flex-grow: 1;
}

.events-section .event-card .btn {
  align-self: flex-start;
  margin-top: auto;
}

.events-section .event-card .event-date-badge {
  background: linear-gradient(
    135deg,
    var(--color-accent-cyan),
    var(--color-accent-violet)
  );
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-lg);
  text-align: center;
  display: inline-block;
  width: fit-content;
}

.events-section .event-card .event-date-day {
  font-size: 2rem;
  font-weight: var(--font-weight-bold);
  display: block;
  line-height: var(--leading-none);
  color: #0a0e1a;
}

.events-section .event-card .event-date-month {
  font-size: var(--text-xs);
  text-transform: uppercase;
  letter-spacing: var(--tracking-wide);
  color: #0a0e1a;
}

/* ============================================
   EVENT FALLBACK INDICATOR (Homepage-specific)
   ============================================ */
.event-fallback {
  border-color: rgba(251, 191, 36, 0.3);
}

.event-fallback:hover {
  border-color: rgba(251, 191, 36, 0.5);
}

/* ============================================
   NO RESULTS EMPTY STATE (Homepage-specific)
   ============================================ */
.no-results-modern {
  text-align: center;
  padding: var(--space-12) var(--space-6);
  background: linear-gradient(
    135deg,
    rgba(255, 255, 255, 0.05) 0%,
    rgba(255, 255, 255, 0.02) 100%
  );
  border: 1px dashed rgba(255, 255, 255, 0.15);
  border-radius: var(--radius-xl);
  grid-column: 1 / -1;
}

.no-results-modern .no-results-icon {
  font-size: 3rem;
  color: var(--color-accent-cyan);
  margin-bottom: var(--space-4);
  opacity: 0.6;
}

.no-results-modern h3 {
  color: #ffffff;
  font-size: var(--text-xl);
  margin-bottom: var(--space-2);
}

.no-results-modern p {
  color: #9ca3af;
  margin-bottom: var(--space-6);
}

/* ============================================
   BENTO IMAGE ERROR FALLBACK
   Shows a gradient background when images fail to load
   ============================================ */
.bento-image-wrapper {
  background: linear-gradient(
    135deg,
    rgba(6, 182, 212, 0.1),
    rgba(139, 92, 246, 0.1)
  );
}

.bento-image-wrapper img {
  /* Ensure broken images don't collapse */
  min-height: 100%;
  min-width: 100%;
  object-fit: cover;
}
