/* =========================================================
   SM EVENTOS — EVENTS ARCHIVE PAGE
   CSS específico de composición.
   Requiere sm-global.css
========================================================= */

/* =========================================================
   1. PAGE WRAPPER
========================================================= */

.sm-events-archive-page {
  background: var(--sm-black);
  color: var(--sm-white);
  overflow: hidden;
}

/* =========================================================
   2. HERO
========================================================= */

.sm-events-archive-hero {
  min-height: clamp(420px, 54vh, 620px);
  display: flex;
  align-items: center;
  padding-top: clamp(110px, 9vw, 160px);
  padding-bottom: clamp(70px, 7vw, 120px);

  background:
    radial-gradient(circle at 82% 18%, rgba(255,45,149,.15), transparent 28%),
    radial-gradient(circle at 12% 72%, rgba(123,44,191,.18), transparent 34%),
    linear-gradient(180deg, #08080d 0%, #0b0b12 62%, #08080d 100%);
}

.sm-events-archive-hero__inner {
  position: relative;
  z-index: 2;
}

.sm-events-archive-hero__title,
.sm-events-archive-hero__title .elementor-heading-title {
  max-width: 920px;
  margin-top: 18px;
  margin-bottom: 0;
}

.sm-events-archive-hero__intro,
.sm-events-archive-hero__intro p {
  max-width: 720px;
  margin-top: 20px;
  color: var(--sm-text) !important;
}

/* =========================================================
   3. EVENTS SECTIONS
========================================================= */

.sm-events-archive-events {
  padding-top: clamp(42px, 5vw, 76px);
  padding-bottom: clamp(70px, 8vw, 120px);
  background:
    radial-gradient(circle at 16% 24%, rgba(123,44,191,.16), transparent 30%),
    radial-gradient(circle at 88% 68%, rgba(255,45,149,.10), transparent 30%),
    var(--sm-black);
}

.sm-events-archive-events__inner {
  position: relative;
  z-index: 2;
}

.sm-events-block {
  width: 100%;
}

.sm-events-block + .sm-events-block {
  margin-top: clamp(58px, 7vw, 96px);
}

.sm-events-block__title,
.sm-events-block__title .elementor-heading-title {
  margin: 0 0 clamp(28px, 4vw, 44px);
  text-align: center;
  font-size: clamp(42px, 4.2vw, 68px);
}

/* Loop Grid */
.sm-events-block__loop {
  width: 100%;
}

/* Centra los cards cuando hay pocos */
.sm-events-block__loop .elementor-loop-container {
  justify-content: center;
  align-items: stretch;
  gap: clamp(28px, 3.2vw, 42px);
}

/* Cards con ancho controlado */
.sm-events-block__loop .e-loop-item {
  overflow: visible;
}

/* Si Elementor deja el loop muy estrecho o raro */
.sm-events-block__loop .sm-media-card {
  max-width: 340px;
  margin-inline: auto;
}

/* Eventos pasados algo más discretos */
.sm-events-block--past {
  opacity: .96;
}

.sm-events-block--past .sm-events-block__title,
.sm-events-block--past .sm-events-block__title .elementor-heading-title {
  color: rgba(255,255,255,.88) !important;
}

/* =========================================================
   4. FEATURES / SEO PANEL
========================================================= */

.sm-events-archive-features {
  padding-top: clamp(70px, 7vw, 110px);
  padding-bottom: clamp(54px, 6vw, 88px);
  background:
    radial-gradient(circle at 8% 50%, rgba(255,45,149,.08), transparent 26%),
    radial-gradient(circle at 90% 50%, rgba(123,44,191,.11), transparent 30%),
    var(--sm-black);
}

.sm-events-archive-features__panel {
  position: relative;
  z-index: 2;

  display: grid;
  grid-template-columns: minmax(0, 1.08fr) minmax(420px, .92fr);
  align-items: center;
  gap: clamp(34px, 5vw, 72px);
}

.sm-events-archive-features__content {
  min-width: 0;
}

.sm-events-archive-features__title,
.sm-events-archive-features__title .elementor-heading-title {
  margin: 0 0 18px;
  font-size: clamp(38px, 4vw, 62px);
}

.sm-events-archive-features__text,
.sm-events-archive-features__text p {
  color: var(--sm-text) !important;
}

.sm-events-archive-features__text p + p {
  margin-top: 14px;
}

.sm-events-archive-features__icons {
  min-width: 0;
}

/* Ajuste fino del componente global de iconos dentro de este panel */
.sm-events-archive-features .sm-feature-icons {
  min-height: 140px;
}

.sm-events-archive-features .sm-feature-icons__title {
  font-size: clamp(24px, 1.8vw, 32px);
}

/* =========================================================
   5. FINAL CTA SECTION
   No toca el componente .sm-action-cta, solo su sección.
========================================================= */

.sm-events-archive-final-cta {
  padding-top: clamp(44px, 5vw, 72px);
  padding-bottom: clamp(80px, 8vw, 120px);
  background:
    radial-gradient(circle at 50% 0%, rgba(255,45,149,.08), transparent 30%),
    var(--sm-black);
}

/* =========================================================
   6. RESPONSIVE
========================================================= */

@media (max-width: 1024px) {
  .sm-events-archive-hero {
    min-height: auto;
    padding-top: 110px;
  }

  .sm-events-archive-features__panel {
    grid-template-columns: 1fr;
    gap: 36px;
  }

  .sm-events-archive-features__icons {
    width: 100%;
  }
}

@media (max-width: 767px) {
  .sm-events-archive-hero {
    padding-top: 92px;
    padding-bottom: 64px;
  }

  .sm-events-archive-hero__title,
  .sm-events-archive-hero__title .elementor-heading-title {
    font-size: 72px;
  }

  .sm-events-archive-hero__intro,
  .sm-events-archive-hero__intro p {
    font-size: 15px;
  }

  .sm-events-block__title,
  .sm-events-block__title .elementor-heading-title {
    font-size: 42px;
    margin-bottom: 28px;
  }

  .sm-events-block + .sm-events-block {
    margin-top: 56px;
  }

  .sm-events-block__loop .sm-media-card {
    max-width: 360px;
  }

  .sm-events-archive-features__panel {
    padding: 24px;
  }

  .sm-events-archive-features__title,
  .sm-events-archive-features__title .elementor-heading-title {
    font-size: 42px;
  }
}

@media (max-width: 420px) {
  .sm-events-block__loop .sm-media-card {
    max-width: 100%;
  }
}