/* ── About Page ───────────────────────────────────────────────────── */
.section.about-hero {
  background: var(--color-surface-100);
  overflow: hidden;
  padding: var(--space-3xl) 0 0;
  margin-bottom: 0;
}

.about-hero__inner,
.about-story__grid,
.about-local__grid {
	display: grid;
	grid-template-columns: 1fr;
	gap: var(--space-xl);
	align-items: center;
}

.about-local__content {
	display: flex;
	flex-direction: column;
	gap: var(--space-xl);
}

.about-hero__content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: var(--space-xl);
	text-align: center;
	max-width: 860px;
	margin: 0 auto;
}

.about-hero__title {
  font-family: var(--font-family-heading);
  font-size: var(--text-5xl);
  font-weight: 900;
  line-height: 1.08;
  letter-spacing: 0;
	color: var(--color-text-dark);
	margin: 0 auto;
	max-width: 760px;
}

.about-hero__copy,
.about-story__copy p,
.about-local__content p {
	color: var(--color-muted);
	font-size: var(--text-base);
	line-height: var(--leading-relaxed);
	margin: 0;
	max-width: 640px;
}

.about-hero__copy {
	margin: 0 auto;
}

.about-hero .hero__ctas,
.about-hero .hero__pills {
	justify-content: center;
}

.about-hero__media {
	display: flex;
	align-items: flex-end;
	justify-content: center;
	margin-top: 0;
}

.about-hero__img {
	display: block;
	width: min(100%, 560px);
	height: auto;
	max-width: none;
	margin-bottom: 0;
}

/* team-grid styles live in style.css (shared with service page heroes) */

.about-support {
  background: var(--color-white);
  border-top: 1px solid var(--color-border);
  border-bottom: 1px solid var(--color-border);
  padding: 0;
}

.about-support .page-container {
  box-sizing: border-box;
  padding: var(--space-md) 0;
}

.about-support p {
  color: var(--color-text-dark);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  line-height: var(--leading-relaxed);
  text-align: center;
  max-width: 860px;
  margin: 0 auto;
}

.about-review__card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-2xl);
  max-width: 880px;
  margin: 0 auto;
  text-align: center;
}

.about-review__stars {
  color: var(--color-star);
  font-size: var(--text-xl);
  letter-spacing: 2px;
  margin-bottom: var(--space-md);
}

.about-review__card h2 {
  font-size: var(--text-4xl);
  font-weight: 900;
  letter-spacing: -0.025em;
  color: var(--color-text-dark);
  margin: 0 0 var(--space-sm);
}

.about-review__card p {
  color: var(--color-muted);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  margin: 0 auto;
  max-width: 620px;
}

.about-review__meta {
  display: inline-flex;
  margin-top: var(--space-md);
  padding: 6px 12px;
  border-radius: var(--radius-full);
  background: rgba(10, 57, 138, 0.06);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}

.about-team__frame {
  max-width: 820px;
  margin: 0 auto;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  background: var(--color-surface-100);
  overflow: hidden;
  display: flex;
  justify-content: center;
  padding: var(--space-md) var(--space-md) 0;
}

.about-team__img {
  display: block;
  width: 100%;
  max-width: 720px;
  height: auto;
}

.about-story__copy {
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.about-proof-card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-md);
  padding: var(--space-xl);
}

.about-proof-card__top {
  display: flex;
  align-items: center;
  gap: var(--space-md);
  padding-bottom: var(--space-lg);
  border-bottom: 1px solid var(--color-border);
}

.about-proof-card__top strong,
.about-proof-card__stats strong {
  display: block;
  font-family: var(--font-family-heading);
  font-weight: 900;
  color: var(--color-text-dark);
}

.about-proof-card__top span,
.about-proof-card__stats span {
  display: block;
  color: var(--color-muted);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}

.about-proof-card__stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-sm);
  padding-top: var(--space-lg);
}

.about-proof-card__stats > span {
  background: var(--color-surface-100);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: var(--space-md);
}

.about-process__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

.about-values__grid,
.about-way__grid,
.about-help__grid,
.about-contact-flow__grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-md);
}

.about-process__card {
  background: var(--color-white);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-xl);
  display: flex;
  flex-direction: column;
  gap: var(--space-md);
}

.about-process__card .icon {
  color: var(--color-primary);
}

.about-help__card {
  align-items: center;
  text-align: center;
}

.about-help__icon {
  width: 56px;
  height: 56px;
  border-radius: var(--radius-full);
  background: rgba(10, 57, 138, 0.06);
  color: var(--color-primary);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.about-help__icon-img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.about-process__card h3 {
  font-size: var(--text-xl);
  font-weight: 900;
  color: var(--color-text-dark);
  margin: 0;
}

.about-process__card p {
  color: var(--color-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  margin: 0;
}

.about-way__num {
  width: 34px;
  height: 34px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: var(--color-white);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-family-heading);
  font-size: var(--text-sm);
  font-weight: 900;
}

.about-way__cta {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: var(--space-md);
  margin-top: var(--space-xl);
}

.about-local__photo {
  position: relative;
  margin: 0;
  border-radius: var(--radius-2xl);
  overflow: hidden;
  min-height: 320px;
  background: var(--color-surface-200);
}

.about-local__img {
  display: block;
  width: 100%;
  height: 100%;
  min-height: 320px;
  object-fit: cover;
}

.about-local__cap {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  padding: var(--space-lg) var(--space-md) var(--space-md);
  background: linear-gradient(to top, rgba(8, 39, 96, 0.85), rgba(8, 39, 96, 0));
  color: var(--color-white);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}

.about-local__areas {
  margin-bottom: 0;
}

.about-local__areas .service-areas__card {
  padding: var(--space-md);
}

.about-local__areas .service-areas__name {
  font-size: var(--text-sm);
}

.about-final {
  padding-top: 0;
}

.about-final__title {
  color: var(--color-white);
  font-size: var(--text-3xl);
  font-weight: 900;
  letter-spacing: 0;
  margin: var(--space-xs) 0 var(--space-sm);
}

.about-final__actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-sm);
}

@media (min-width: 768px) {
	.about-hero__inner {
		grid-template-columns: minmax(0, 1fr);
		justify-items: center;
	}

  .about-story__grid,
  .about-local__grid {
    grid-template-columns: 1fr 1fr;
  }

  .about-process__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .about-values__grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .about-help__grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .about-way__grid {
    grid-template-columns: repeat(5, 1fr);
  }

  .about-contact-flow__grid {
    grid-template-columns: repeat(3, 1fr);
  }

  .about-local__areas {
    grid-template-columns: repeat(2, 1fr);
  }

  .about-final__actions {
    flex-direction: column;
    flex-shrink: 0;
    align-items: stretch;
  }

  .about-final__actions .btn {
    text-align: center;
    white-space: nowrap;
  }
}

@media (max-width: 767px) {
  .about-hero {
    padding-bottom: 0;
  }

  .about-hero__inner {
    gap: var(--space-lg);
  }

  .about-hero__img {
    width: min(100%, 360px);
    margin-bottom: 0;
  }

  .about-hero__media {
    align-items: flex-start;
  }

  .about-values__grid,
  .about-way__grid,
  .about-help__grid,
  .about-contact-flow__grid {
    grid-template-columns: 1fr;
  }

  .about-hero__title {
    font-size: var(--text-4xl);
  }

  /* team-grid mobile overrides live in style.css */
}

/* ── Help-card line icons ── */
.about-help__icon svg {
	width: 26px;
	height: 26px;
}

/* ── Real-photo review band ── */
.about-band {
	padding: var(--space-2xl) 0;
}

.about-band__inner {
	margin: 0;
	display: grid;
	grid-template-columns: 1fr;
	overflow: hidden;
	background: var(--color-primary-dark);
}

.about-band__img {
	width: 100%;
	height: auto;
	/* Source photo is 1003x1568; this ratio shows exactly the top 60%
	   (bottom 40% cropped). Recompute width/(height*0.6) if the photo changes. */
	aspect-ratio: 1003 / 941;
	object-fit: cover;
	object-position: center top;
	display: block;
}

.about-band__quote {
	display: flex;
	flex-direction: column;
	justify-content: center;
	gap: var(--space-sm);
	padding: var(--space-xl);
	color: var(--color-white);
}

.about-band__stars {
	color: #fbbf24;
	letter-spacing: 2px;
	font-size: var(--text-lg);
}

.about-band__shot {
	display: block;
	width: 100%;
	max-width: 420px;
	height: auto;
	border-radius: var(--radius-lg);
	box-shadow: var(--shadow-md);
}

.about-band__quote blockquote {
	margin: 0;
	font-family: var(--font-family-heading);
	font-size: var(--text-2xl);
	font-weight: 800;
	line-height: var(--leading-tight);
}

.about-band__cite {
	color: rgba(186, 230, 253, 0.9);
	font-size: var(--text-sm);
	font-weight: var(--font-bold);
	text-decoration: none;
}

.about-band__cite:hover {
	color: var(--color-white);
}

/* ── Process as a connected timeline ── */
.about-contact-flow .about-process__card {
	background: transparent;
	border: 0;
	text-align: center;
	align-items: center;
	padding: 0 var(--space-md);
}

.about-contact-flow .about-way__num {
	width: 48px;
	height: 48px;
	font-size: var(--text-lg);
	box-shadow: 0 0 0 6px var(--color-surface-100);
}

@media (min-width: 768px) {
	.about-band__inner {
		grid-template-columns: 1fr 1fr;
		align-items: center;
	}

	.about-contact-flow__grid {
		position: relative;
	}

	.about-contact-flow__grid::before {
		content: "";
		position: absolute;
		top: 24px;
		left: 16%;
		right: 16%;
		height: 2px;
		background: var(--color-border);
		z-index: 0;
	}

	.about-contact-flow .about-process__card {
		position: relative;
		z-index: 1;
	}
}
