/* ===== Services Listing Page ===== */

body.page-inner {
  background: var(--color-white);
}

.page-banner-image {
  background: var(--color-white);
}

.services-page {
  padding: var(--section-pad) var(--container-side);
  background: var(--color-white);
}

.services-page-intro {
  text-align: center;
  max-width: 640px;
  margin: 0 auto 72px;
}

.services-page-intro + .branch-notice {
  margin-bottom: 56px;
}

.services-page-intro p {
  font-size: var(--font-size-lead);
  font-weight: var(--font-weight-lead);
  line-height: 1.8;
  color: var(--color-text-lead);
}

.services-page-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 48px;
  max-width: var(--container-wide);
  margin: 0 auto;
}

.services-page-card {
  display: flex;
  flex-direction: column;
}

.services-page-card-image {
  display: block;
  aspect-ratio: 4 / 3;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-white);
  border: 1px solid var(--color-line);
}

.services-page-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  transition: transform 0.4s ease;
}

.services-page-card-image:hover img {
  transform: scale(1.04);
}

.services-page-card-title {
  font-size: 13px;
  font-weight: var(--font-weight-heading);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-accent);
  margin: 28px 0 16px;
}

.services-page-card-desc {
  font-size: 14px;
  font-weight: var(--font-weight-lead);
  line-height: 1.8;
  color: var(--color-text-lead);
  margin-bottom: 28px;
  flex: 1;
}

.services-page-card-btn {
  align-self: flex-start;
}

@media (max-width: 1024px) {
  .services-page-grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 40px;
  }

  .services-page-grid .services-page-card:last-child:nth-child(odd) {
    grid-column: 1 / -1;
    max-width: 560px;
    margin: 0 auto;
    width: 100%;
  }
}

@media (max-width: 600px) {
  .services-page-grid {
    grid-template-columns: 1fr;
    gap: 48px;
  }

  .services-page-grid .services-page-card:last-child:nth-child(odd) {
    grid-column: auto;
    max-width: none;
  }
}
