/* News-style event card grid.
 *
 * Used wherever an event listing should render as photo-on-top cards
 * with a kicker meta line beneath. Today: the homepage upcoming section
 * and experiences.html's Experiences catalog. The renderer that outputs the
 * matching HTML is renderUpcomingGrid / renderCatalog in events-render.js.
 */

.upcoming-section {
  padding: 5rem 1.5rem 4rem;
}
.upcoming-section header {
  text-align: center;
  margin-bottom: 3rem;
}
.upcoming-section header h2 {
  font-family: "Archia";
  font-weight: 400;
  font-size: clamp(2rem, 5vw, 3rem);
  line-height: 1.05;
  letter-spacing: -0.02em;
  text-transform: none;
  margin: 0 0 0.5rem;
}
.upcoming-section header p {
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
  font-size: 1rem;
}

.upcoming-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 2.5rem;
  max-width: 68rem;
  margin: 0 auto;
}

.upcoming-card {
  display: block;
  text-decoration: none;
  color: #fff;
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
.upcoming-card:hover {
  transform: translateY(-4px);
  color: #fff;
}

/* Per-category accent. The renderer adds .upcoming-card--experience or
   .upcoming-card--trackday to each card; the variable cascades into the
   gradient layer's inset glow, the badge color, and the title hover. */
.upcoming-card--experience { --accent-color: #74d3ff; }
.upcoming-card--trackday   { --accent-color: #5d31ff; }

.upcoming-card-image {
  position: relative;
  aspect-ratio: 3 / 2;
  overflow: hidden;
  /* Echoes the rounded pill silhouette of .media-banner on experiences.html. */
  border-radius: 4rem;
  margin-bottom: 1.25rem;
  background: #000;
}
.upcoming-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
  transition: transform 0.7s cubic-bezier(0.22, 1, 0.36, 1);
}
.upcoming-card:hover .upcoming-card-image img {
  transform: scale(1.05);
}

/* Reuse the global .gradient-layer rule from style.css for the accent
   inset glow. The hover blur from the menu-grid era is killed here —
   on these cards we want the photo crisp, not blurred. */
.upcoming-card-image .gradient-layer {
  pointer-events: none;
}
.upcoming-card:hover .gradient-layer,
.upcoming-card .gradient-layer {
  backdrop-filter: none;
  -webkit-backdrop-filter: none;
}

/* Info block sits inside the rounded card visual envelope; horizontal
   padding pulls the copy in so it lines up close to where the image's
   border-radius curves rather than floating at the rectangular edge. */
.upcoming-card-info {
  padding: 0 1.75rem;
}

.upcoming-card-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.85rem;
  margin-bottom: 0.65rem;
  flex-wrap: wrap;
}
.upcoming-card-meta time {
  font-family: "Montserrat", sans-serif;
  font-size: 0.7rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.55);
}
/* Right-side cluster: category badge + country flag. */
.upcoming-card-tags {
  display: inline-flex;
  align-items: center;
  gap: 0.6rem;
}
.upcoming-card-tags .fi {
  width: 1.4em;
  font-size: 0.95rem;
  border-radius: 2px;
  /* box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.18); */
  background-size: cover;
}
.upcoming-card-badge {
  font-family: "Montserrat", sans-serif;
  font-size: 0.65rem;
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  border-radius: 999px;
  color: var(--accent-color);
  background: color-mix(in srgb, var(--accent-color) 6%, transparent);
}

.upcoming-card h3 {
  font-family: "Archia";
  font-weight: 400;
  font-size: 1.4rem;
  line-height: 1.2;
  letter-spacing: -0.015em;
  text-transform: none;
  margin: 0 0 0.65rem;
  text-align: left;
  transition: color 0.25s ease;
}
.upcoming-card:hover h3 {
  color: var(--accent-color);
}

.upcoming-card p {
  font-family: "Montserrat", sans-serif;
  font-size: 0.95rem;
  font-weight: 300;
  line-height: 1.45;
  color: rgba(255, 255, 255, 0.7);
  margin: 0;
  text-align: left;
  max-width: 38ch;
}

/* Price line — only rendered when event.price is set in events.js.
   Subtle by default: muted white instead of the accent color, modest
   size, "per person" as a small uppercase footnote. */
.upcoming-card-price {
  display: flex;
  align-items: baseline;
  justify-content: flex-start;
  gap: 0.5rem;
  margin-top: 0.85rem;
  font-family: "Archia";
  font-size: 0.95rem;
  letter-spacing: 0.01em;
  color: rgba(255, 255, 255, 0.7);
  text-align: left;
}
.upcoming-card-price small {
  font-family: "Montserrat", sans-serif;
  font-size: 0.6rem;
  font-weight: 400;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4);
}

.upcoming-cta {
  text-align: center;
  margin-top: 3rem;
}

/* Two columns from 720px up; three on very wide screens if you ever
   want more density — change to repeat(3, 1fr) above 1200px. */
@media (min-width: 720px) {
  .upcoming-grid {
    grid-template-columns: 1fr 1fr;
    gap: 3rem 2rem;
  }
  .upcoming-card h3 {
    font-size: 1.6rem;
  }
}
