/* ================================================================
   CAROUSEL — Slide cards and dot navigation
   ================================================================ */

.carousel {
  overflow: hidden;
  border-radius: 28px;
}

.carousel__track {
  display: flex;
  transition: transform 600ms cubic-bezier(0.4, 0, 0.2, 1);
  will-change: transform;
}

/* ── Slide cards ─────────────────────────────────────────────── */
.slide-card {
  flex: 0 0 100%;
  /* Scales from 360px on mobile up to 520px on wide screens */
  min-height: clamp(360px, 30vw, 520px);
  padding: 20px;
  border-radius: 28px;
}

.slide-card--emerald {
  background: linear-gradient(180deg, var(--color-emerald-tint), rgba(255, 255, 255, 0.66));
}

.slide-card--amber {
  background: linear-gradient(180deg, var(--color-amber-tint), rgba(255, 255, 255, 0.66));
}

.slide-card--teal {
  background: linear-gradient(180deg, var(--color-teal-tint), rgba(255, 255, 255, 0.66));
}

.slide-card__surface {
  height: 100%;
  padding: 24px;
  border: 1px solid rgba(255, 255, 255, 0.72);
  border-radius: 24px;
  background: rgba(255, 255, 255, 0.84);
}

.slide-card__tag {
  font-size: 0.76rem;
  font-weight: 800;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-teal-deep);
}

.slide-card h3 {
  margin-top: 14px;
  font-size: 1.85rem;
}

.slide-card p {
  margin-top: 16px;
  font-size: 0.95rem;
  color: var(--color-text-muted);
  line-height: 1.7;
}

/* ── Skeleton mock UI ───────────────────────────────────────── */
.slide-card__mock {
  margin-top: 26px;
}

.slide-card__mock > span {
  display: block;
  height: 10px;
  margin-bottom: 10px;
  border-radius: var(--radius-pill);
  background: rgba(148, 163, 184, 0.28);
}

.slide-card__mock > span:first-child { width: 78%; }
.slide-card__mock > span:nth-child(2) { width: 58%; }

.mini-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 12px;
}

.mini-grid i {
  display: block;
  height: 100px;
  border-radius: 18px;
  background: rgba(148, 163, 184, 0.18);
}

/* ── Dot navigation ─────────────────────────────────────────── */
.carousel__dots {
  display: flex;
  justify-content: center;
  gap: 8px;
  margin-top: 20px;
}

.carousel__dot {
  width: 8px;
  height: 8px;
  border-radius: var(--radius-pill);
  background: rgba(19, 23, 34, 0.18);
  border: none;
  cursor: pointer;
  padding: 0;
  transition: width var(--transition), background var(--transition);
}

.carousel__dot--active {
  width: 24px;
  background: var(--color-primary);
}

.carousel__dot:hover {
  background: var(--color-teal);
}

.carousel__dot:focus-visible {
  outline: 2px solid var(--color-teal);
  outline-offset: 3px;
}
