/* ============================================
   State Index / Landing Page Styles
   Shared layout for the 20 state index pages:
   /{service}/{state}/index.html

   A light directory layout that aggregates the
   built city pages for a service in one state,
   plus cross-links to the state's other services.

   Loaded AFTER service-hub.css (reuses the
   .hero--service-hub treatment for the compact header).
   Desktop-first; fills the viewport on large screens.
   ============================================ */

/* ============================================
   Compact hero header
   The state index reuses .hero--service-hub but
   carries less content (badge + title + subtitle),
   so we tighten the vertical rhythm.
   ============================================ */

.hero--state-index .hero__content {
  padding-top: calc(var(--space-10) + var(--space-6));
  padding-bottom: var(--space-10);
}

.hero--state-index .hero__title {
  max-width: 720px;
}

.hero--state-index .hero__subtitle {
  max-width: 640px;
  margin-bottom: 0;
}

/* ============================================
   Intro section
   Unique ~100-150 word state + service context.
   Desktop-first editorial two-column layout that
   FILLS the container width (no narrow centered
   measure / mobile-style side margins on desktop).
   ============================================ */

.state-intro {
  display: grid;
  grid-template-columns: minmax(240px, 0.75fr) 1.6fr;
  gap: var(--space-6) var(--space-12);
  align-items: start;
}

.state-intro__lead .section-label {
  margin-bottom: var(--space-3);
}

.state-intro__lead h2 {
  margin: 0;
}

.state-intro__body p {
  font-size: var(--fs-md);
  line-height: 1.7;
  color: var(--color-text);
}

.state-intro__body p + p {
  margin-top: var(--space-4);
}

/* ============================================
   City directory grid
   The 4 built cities for this state + service.
   ============================================ */

.state-cities__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-5);
  margin-top: var(--space-8);
}

.state-city-card {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-6);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  text-decoration: none;
  color: inherit;
  transition: transform 0.2s ease, box-shadow 0.2s ease, border-color 0.2s ease;
}

.state-city-card:hover,
.state-city-card:focus-visible {
  transform: translateY(-3px);
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
}

.state-city-card__name {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  font-size: var(--fs-lg);
  font-weight: 600;
  color: var(--color-text);
}

.state-city-card__name svg {
  width: 18px;
  height: 18px;
  color: var(--color-primary);
  flex-shrink: 0;
}

.state-city-card__text {
  font-size: var(--fs-sm);
  color: var(--color-text-muted);
  line-height: 1.5;
}

/* ============================================
   Cross-service links
   The state's other 4 services.
   ============================================ */

.state-services__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-4);
  margin-top: var(--space-8);
}

.state-service-card {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-4) var(--space-5);
  background-color: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-decoration: none;
  font-weight: 600;
  color: var(--color-text);
  transition: border-color 0.2s ease, color 0.2s ease, background-color 0.2s ease;
}

.state-service-card:hover,
.state-service-card:focus-visible {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background-color: var(--color-bg-alt);
}

.state-service-card svg {
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

/* ============================================
   Responsive
   ============================================ */

@media (max-width: 900px) {
  .state-intro {
    grid-template-columns: 1fr;
    gap: var(--space-4);
  }
  .state-cities__grid {
    grid-template-columns: repeat(2, 1fr);
  }
  .state-services__grid {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 560px) {
  .state-cities__grid,
  .state-services__grid {
    grid-template-columns: 1fr;
  }
  .state-intro__body p {
    font-size: var(--fs-base);
  }
}
