/* ==========================================================================
   SEO Content Blocks - Styling for SEO text sections across pages
   ========================================================================== */

.seo-content {
  padding: var(--section-padding-desktop);
  margin-bottom: var(--spacing-md);
  line-height: var(--line-height-body);
  color: var(--color-text);
}

.seo-content h2 {
  font-size: var(--font-size-2xl);
  line-height: var(--line-height-heading);
  margin-bottom: var(--spacing-sm);
}

.seo-content h3 {
  font-size: var(--font-size-xl);
  line-height: var(--line-height-heading);
  margin-top: var(--spacing-md);
  margin-bottom: var(--spacing-xs);
}

.seo-content p {
  margin-bottom: var(--spacing-sm);
  color: var(--color-text-muted);
  font-size: var(--font-size-base);
}

.seo-content ul {
  list-style: none;
  padding: 0;
  margin-bottom: var(--spacing-sm);
}

.seo-content ul li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: var(--spacing-xs);
  color: var(--color-text-muted);
}

.seo-content ul li::before {
  content: "—";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 700;
}

.seo-content ul li strong {
  color: var(--color-text);
}

.seo-content a {
  color: var(--color-primary);
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color var(--transition-fast);
}

.seo-content a:hover {
  color: var(--color-primary-hover);
}

/* Programs CTA grid inside SEO content */
.programs-cta__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: var(--spacing-sm);
  margin-top: var(--spacing-sm);
}

.programs-cta__card {
  display: block;
  padding: var(--spacing-sm);
  text-decoration: none;
  transition: transform var(--transition-fast), box-shadow var(--transition-fast);
}

.programs-cta__card:hover {
  transform: translateY(-2px);
  box-shadow: 0 12px 40px rgba(0, 0, 0, 0.3);
}

.programs-cta__card h3 {
  font-size: var(--font-size-lg);
  color: var(--color-text);
  margin: 0 0 var(--spacing-xs) 0;
}

.programs-cta__card p {
  font-size: var(--font-size-sm);
  color: var(--color-text-muted);
  margin: 0;
}

/* City/School page specifics */
.city-page,
.school-location-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}

.city-hero,
.school-hero {
  text-align: center;
  padding: var(--section-padding-desktop);
}

.city-hero h1,
.school-hero h1 {
  font-size: var(--font-size-3xl);
}

.city-content,
.school-content,
.city-achievements,
.city-locations,
.school-online,
.school-testimonials,
.city-cta,
.school-cta {
  padding: var(--section-padding-desktop);
  margin-bottom: var(--spacing-md);
}

.city-achievements__list,
.city-locations__list,
.school-online__list {
  list-style: none;
  padding: 0;
}

.city-achievements__list li,
.city-locations__list li,
.school-online__list li {
  position: relative;
  padding-left: 1.5em;
  margin-bottom: var(--spacing-xs);
}

.city-achievements__list li::before,
.school-online__list li::before {
  content: "✓";
  position: absolute;
  left: 0;
  color: var(--color-primary);
  font-weight: 700;
}

.city-locations__list li::before {
  content: "→";
  position: absolute;
  left: 0;
  color: var(--color-primary);
}

.city-cta,
.school-cta {
  text-align: center;
}

/* Testing page SEO content */
.testing-seo-content {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: var(--spacing-md) auto 0;
  padding: 0 0 var(--spacing-md);
}

/* Kids learning page */
.kids-learning-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
  position: relative;
  z-index: var(--z-content);
}

.kids-hero {
  text-align: center;
  padding: var(--section-padding-desktop);
}

.kids-hero h1 {
  font-size: var(--font-size-3xl);
}

.kids-hero__subtitle {
  font-size: var(--font-size-lg);
  color: var(--color-text-muted);
  margin-bottom: var(--spacing-sm);
}

.kids-cta {
  text-align: center;
  padding: var(--section-padding-desktop);
}

/* Job page */
.job-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}

/* Shares page */
.shares-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}

/* About page */
.about-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}

/* Feedback page */
.feedback-page {
  width: var(--content-width-desktop);
  max-width: var(--content-max-width);
  margin: 0 auto;
  padding: var(--spacing-md) 0;
}

@media (width <= 767px) {
  .city-page,
  .school-location-page,
  .kids-learning-page,
  .job-page,
  .shares-page,
  .about-page,
  .feedback-page,
  .testing-seo-content {
    width: var(--content-width-mobile);
  }

  .city-hero,
  .school-hero {
    padding: var(--section-padding-mobile);
  }

  .city-hero h1,
  .school-hero h1 {
    font-size: var(--font-size-2xl);
  }

  .seo-content {
    padding: var(--section-padding-mobile);
  }

  .kids-hero,
  .kids-cta {
    padding: var(--section-padding-mobile);
  }

  .kids-hero h1 {
    font-size: var(--font-size-2xl);
  }

  .programs-cta__grid {
    grid-template-columns: 1fr;
  }
}
