/* ==========================================================================
   Personalise Page Styles
   ========================================================================== */

/* ---------- Hero ---------- */
.personalise-hero {
  position: relative;
  padding-block: var(--space-4xl);
  padding-inline: var(--space-lg);
  background: linear-gradient(135deg, var(--color-hero-gradient-start), var(--color-hero-gradient-end));
  color: var(--color-text-white);
  text-align: center;
  overflow: hidden;
  isolation: isolate;
}

.personalise-hero__watermark {
  position: absolute;
  inset-inline-end: -4rem;
  inset-block-end: -4rem;
  inline-size: 480px;
  max-inline-size: 60%;
  block-size: auto;
  opacity: 0.08;
  pointer-events: none;
  z-index: 0;
  user-select: none;
}

.personalise-hero__inner {
  position: relative;
  z-index: 1;
  max-inline-size: 720px;
  margin-inline: auto;
}

.personalise-hero__heading {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  margin-block-end: var(--space-md);
}

.personalise-hero__subtitle {
  font-size: var(--font-size-lg);
  opacity: 0.95;
  margin-block-end: var(--space-xl);
}

.personalise-hero__cta {
  margin-inline: auto;
}

/* ---------- Shared Section Shell ---------- */
.personalise-steps,
.personalise-showcase,
.personalise-tips {
  padding-block: var(--space-3xl);
  padding-inline: var(--container-padding);
}

.personalise-steps__inner,
.personalise-showcase__inner,
.personalise-tips__inner {
  max-inline-size: var(--container-max);
  margin-inline: auto;
}

.personalise-steps__header,
.personalise-showcase__header,
.personalise-tips__header {
  text-align: center;
  margin-block-end: var(--space-2xl);
}

.personalise-steps__heading,
.personalise-showcase__heading,
.personalise-tips__heading {
  font-size: var(--font-size-3xl);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-dark);
  margin-block-end: var(--space-sm);
}

.personalise-steps__lede,
.personalise-showcase__lede,
.personalise-tips__lede {
  color: var(--color-text-muted);
  font-size: var(--font-size-md);
  margin: 0;
}

/* ---------- Steps Grid ---------- */
.personalise-steps {
  background: var(--color-bg-light);
}

.personalise-steps__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-xl);
}

/* ---------- Step Card ---------- */
.step-card {
  position: relative;
  background: var(--color-bg-white);
  border-radius: var(--radius-lg);
  padding: var(--space-2xl) var(--space-lg) var(--space-lg);
  text-align: center;
  box-shadow: var(--shadow-card);
  border: 1px solid var(--color-border);
  transition: var(--transition-base);
}

.step-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card-hover);
}

.step-card__number {
  position: absolute;
  inset-block-start: -22px;
  inset-inline-start: 50%;
  transform: translateX(-50%);
  inline-size: 44px;
  block-size: 44px;
  border-radius: var(--radius-circle);
  background: var(--color-primary);
  color: var(--color-text-white);
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-shadow: var(--shadow-sm);
}

.step-card__icon {
  inline-size: 64px;
  block-size: 64px;
  margin-inline: auto;
  margin-block-end: var(--space-md);
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.step-card__icon svg {
  inline-size: 40px;
  block-size: 40px;
}

.step-card__title {
  font-size: var(--font-size-lg);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-dark);
  margin-block-end: var(--space-sm);
}

.step-card__text {
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  margin: 0;
}

/* ---------- Showcase Grid ---------- */
.personalise-showcase__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.showcase-item {
  position: relative;
  margin: 0;
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-card);
  transition: var(--transition-base);
  aspect-ratio: 1 / 1;
}

.showcase-item:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card-hover);
}

.showcase-item img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  display: block;
  transition: transform var(--transition-slow);
}

.showcase-item:hover img {
  transform: scale(1.05);
}

.showcase-item__caption {
  position: absolute;
  inset-inline: 0;
  inset-block-end: 0;
  padding: var(--space-md);
  background: linear-gradient(to top, hsla(240, 33%, 14%, 0.85), transparent);
  color: var(--color-text-white);
  font-weight: var(--font-weight-semibold);
  font-size: var(--font-size-base);
  text-align: start;
}

/* ---------- Tips Grid ---------- */
.personalise-tips {
  background: var(--color-bg-light);
}

.personalise-tips__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-lg);
}

.tip-card {
  background: var(--color-bg-white);
  border-radius: var(--radius-lg);
  padding: var(--space-xl) var(--space-lg);
  text-align: center;
  border: 1px solid var(--color-border);
  box-shadow: var(--shadow-card);
  transition: var(--transition-base);
}

.tip-card:hover {
  transform: translateY(-4px);
  box-shadow: var(--shadow-card-hover);
}

.tip-card__icon {
  inline-size: 56px;
  block-size: 56px;
  margin-inline: auto;
  margin-block-end: var(--space-md);
  border-radius: var(--radius-circle);
  background: var(--color-primary-light);
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.tip-card__icon svg {
  inline-size: 28px;
  block-size: 28px;
}

.tip-card__title {
  font-size: var(--font-size-md);
  font-weight: var(--font-weight-bold);
  color: var(--color-text-dark);
  margin-block-end: var(--space-sm);
}

.tip-card__text {
  color: var(--color-text-muted);
  font-size: var(--font-size-sm);
  line-height: var(--line-height-base);
  margin: 0;
}

/* ---------- CTA Banner ---------- */
.personalise-cta {
  padding-block: var(--space-4xl);
  padding-inline: var(--space-lg);
  background: linear-gradient(135deg, var(--color-hero-gradient-start), var(--color-hero-gradient-end));
  color: var(--color-text-white);
  text-align: center;
}

.personalise-cta__inner {
  max-inline-size: 720px;
  margin-inline: auto;
}

.personalise-cta__heading {
  font-size: var(--font-size-4xl);
  font-weight: var(--font-weight-bold);
  line-height: var(--line-height-tight);
  margin-block-end: var(--space-md);
}

.personalise-cta__lede {
  font-size: var(--font-size-lg);
  opacity: 0.95;
  margin-block-end: var(--space-xl);
}

.personalise-cta__actions {
  display: flex;
  justify-content: center;
  gap: var(--space-md);
  flex-wrap: wrap;
}

.personalise-cta__btn-outline {
  background: transparent;
  color: var(--color-text-white);
  border: 2px solid var(--color-text-white);
}

.personalise-cta__btn-outline:hover,
.personalise-cta__btn-outline:focus-visible {
  background: var(--color-text-white);
  color: var(--color-primary);
}

/* ---------- Responsive ---------- */
@media (max-width: 960px) {
  .personalise-steps__grid,
  .personalise-showcase__grid,
  .personalise-tips__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 640px) {
  .personalise-hero {
    padding-block: var(--space-3xl);
  }

  .personalise-hero__heading,
  .personalise-cta__heading {
    font-size: var(--font-size-3xl);
  }

  .personalise-steps__heading,
  .personalise-showcase__heading,
  .personalise-tips__heading {
    font-size: var(--font-size-2xl);
  }

  .personalise-steps__grid,
  .personalise-showcase__grid,
  .personalise-tips__grid {
    grid-template-columns: 1fr;
    gap: var(--space-xl);
  }

  .personalise-cta__actions {
    flex-direction: column;
    align-items: stretch;
  }
}
