/* ---------- Hero ---------- */
.hero {
  padding-block: var(--space-10) var(--space-12);
  overflow: hidden;
}
.hero-inner {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}
.hero-copy h1 {
  font-size: clamp(2.4rem, 5vw, 4rem);
  margin-top: var(--space-4);
}
.hero-copy h1 em {
  font-style: italic;
  color: var(--color-primary);
}
.hero-lead {
  margin-top: var(--space-5);
  font-size: 1.15rem;
  color: var(--color-text-muted);
  max-width: 46ch;
}
.hero-ctas {
  display: flex;
  gap: var(--space-4);
  margin-top: var(--space-8);
  flex-wrap: wrap;
}
.hero-trust {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-8);
  font-size: 0.9rem;
  color: var(--color-text-muted);
}
.hero-trust .stars {
  color: var(--color-primary);
  letter-spacing: 2px;
}
.hero-media {
  border-radius: var(--radius-lg);
  overflow: hidden;
  box-shadow: var(--shadow-lg);
  aspect-ratio: 4/5;
}
.hero-media img {
  width: 100%; height: 100%;
  object-fit: cover;
}

@media (max-width: 900px) {
  .hero-inner { grid-template-columns: 1fr; }
  .hero-media { aspect-ratio: 16/10; order: -1; }
}

/* ---------- Offers ---------- */
.offers-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 900px) {
  .offers-grid { grid-template-columns: 1fr; }
}

/* ---------- Categories ---------- */
.category-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
.category-tile {
  background: var(--color-white);
  border-radius: var(--radius-md);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  transition: transform var(--duration) var(--ease), box-shadow var(--duration) var(--ease);
}
.category-tile:hover {
  transform: translateY(-6px);
  box-shadow: var(--shadow-lg);
}
.category-tile svg { color: var(--color-primary); }
.category-tile h3 { margin-top: var(--space-4); font-size: 1.2rem; }
.category-tile p { margin-top: var(--space-2); color: var(--color-text-muted); font-size: 0.92rem; }
.category-tile-cta {
  background: var(--color-ink);
  color: var(--color-cream);
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.category-tile-cta h3 { color: var(--color-white); }
.category-tile-cta p { color: rgba(250,246,241,0.7); }
.category-tile-cta .btn { margin-top: var(--space-5); align-self: flex-start; }

@media (max-width: 900px) {
  .category-grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .category-grid { grid-template-columns: 1fr; }
}

/* ---------- About / Stats ---------- */
.about-grid {
  display: grid;
  grid-template-columns: 1.1fr 1fr;
  gap: var(--space-10);
  align-items: center;
}
.about-copy h2 { margin-top: var(--space-3); font-size: clamp(1.9rem, 3.2vw, 2.6rem); }
.about-copy p { margin-top: var(--space-4); color: var(--color-text-muted); }
.about-copy .btn { margin-top: var(--space-6); }
.about-stats .stat-grid {
  grid-template-columns: repeat(2, 1fr);
  background: var(--color-white);
  padding: var(--space-8);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
@media (max-width: 900px) {
  .about-grid { grid-template-columns: 1fr; }
}

/* ---------- Locations teaser ---------- */
.locations-strip {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-4);
  margin-bottom: var(--space-8);
}
.locations-strip span {
  padding: var(--space-3) var(--space-6);
  background: var(--color-white);
  border-radius: var(--radius-full);
  font-weight: 600;
  font-size: 0.92rem;
  box-shadow: var(--shadow-sm);
}
.center-cta { text-align: center; }

/* ---------- Blog teaser ---------- */
.blog-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}
@media (max-width: 900px) {
  .blog-grid { grid-template-columns: 1fr; }
}

/* ---------- Final CTA ---------- */
.final-cta {
  background: linear-gradient(135deg, var(--color-ink) 0%, var(--color-ink-soft) 100%);
  color: var(--color-white);
  text-align: center;
}
.final-cta h2 {
  color: var(--color-white);
  font-size: clamp(2rem, 3.5vw, 2.8rem);
}
.final-cta p {
  margin-top: var(--space-4);
  color: rgba(250,246,241,0.75);
  max-width: 520px;
  margin-inline: auto;
}
.final-cta .btn { margin-top: var(--space-8); }
