/* ============================================================
   TOP ATTRACTIONS — sections/attractions.css
   ============================================================ */

.attractions {
  background: var(--clr-white);
  padding-block: var(--section-py);
}

/* ---- 2-column layout ---- */
.attractions__grid {
  display: grid;
  grid-template-columns: 290px 1fr;
  gap: 56px;
  align-items: start;
}

/* ---- Left side text ---- */
.attractions__left {
  position: sticky;
  top: 110px;
}

.attractions__left .section-title {
  font-family: 'Nomiyola', 'Normiyola', 'Normiyola VIP', var(--ff-display);
  font-size: clamp(2.9rem, 5.8vw, 4.8rem);
  letter-spacing: 0.035em;
  line-height: 0.95;
  margin-bottom: var(--sp-4);
}

.attractions__left .section-title > span {
  display: block;
}

.attractions__left .section-title .section-title__top {
  font-size: 1.54em;
  line-height: 0.88;
}

.attractions__left .text-muted {
  margin-bottom: var(--sp-6);
  line-height: var(--lh-relaxed);
}

/* ---- Right: cards grid ---- */
.attractions__cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}

/* Card sizing */
.attractions__cards .attraction-card {
  border-radius: var(--r-lg);
}

.attractions__cards .attraction-card__image {
  height: 144px;
}

/* Make cards in first row slightly taller */
.attractions__cards .attraction-card:nth-child(-n+3) .attraction-card__image {
  height: 160px;
}
