.service-methods__board,
.service-table-wrap {
  grid-column: 1 / -1;
}

.service-distress .home-permit__media {
  grid-column: 1 / span 5;
}

.service-distress .home-permit__copy {
  grid-column: 7 / -1;
  align-content: center;
}

.service-distress .home-permit__copy h2 {
  max-width: 14ch;
}

.service-distress .home-permit__copy p {
  max-width: 50ch;
}

.service-distress__points.home-permit__steps {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: none;
  gap: 0.85rem;
}

.service-distress__point {
  grid-template-columns: auto minmax(0, 1fr);
  align-items: start;
}

.service-distress__point-copy {
  display: grid;
  gap: 0.4rem;
}

.service-distress__point-copy > span {
  color: var(--color-brand-graphite-600);
  font-size: 0.95rem;
  font-weight: 400;
  line-height: 1.5;
}

.service-methods {
  background: var(--color-paper);
}

.service-methods__board {
  display: grid;
  gap: clamp(1.25rem, 3vw, 2rem);
}

.service-methods__heading {
  margin-bottom: 0;
}

.service-methods__heading h2 {
  max-width: 18ch;
}

.service-table-wrap {
  overflow-x: auto;
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-md);
  background: var(--color-paper);
}

.s-table {
  width: 100%;
  min-width: 760px;
  border-collapse: collapse;
}

.s-table th,
.s-table td {
  border-bottom: 1px solid var(--color-brand-steel-200);
  padding: 1.05rem 1.25rem;
  text-align: left;
  vertical-align: top;
}

.s-table th {
  background: var(--color-brand-warm-50);
  color: var(--color-brand-graphite-600);
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  border-bottom: 1px solid var(--color-brand-steel-300);
}

.s-table td {
  background: var(--color-paper);
  color: var(--color-brand-graphite-700);
}

.s-table tr:last-child td {
  border-bottom: 0;
}

.s-table td:first-child {
  color: var(--color-brand-graphite-900);
  font-weight: 500;
}

.service-features .home-reasons__brief {
  min-height: clamp(22rem, 34vw, 30rem);
}

.process-section {
  overflow: hidden;
  background: var(--color-paper);
}

.process-section__header {
  grid-column: 1 / -1;
  align-items: end;
}

.process-section__header > p {
  max-width: 62ch;
  color: var(--color-brand-graphite-600);
  font-size: var(--text-lede);
}

.process-section h2 {
  max-width: 12ch;
}

.process-timeline {
  --timeline-marker-size: 3rem;
  --timeline-line-height: 100%;
  --timeline-line-top: 0px;
  --timeline-progress: 1;

  position: relative;
  display: grid;
  grid-column: 1 / -1;
  gap: clamp(3rem, 7vw, 5.5rem);
  margin: 0;
  padding: clamp(1rem, 2vw, 1.5rem) 0;
  list-style: none;
}

.process-timeline::before,
.process-timeline::after {
  position: absolute;
  top: var(--timeline-line-top);
  left: 50%;
  height: var(--timeline-line-height);
  width: 4px;
  border-radius: var(--radius-pill);
  content: "";
  transform: translateX(-50%);
}

.process-timeline::before {
  background: var(--color-brand-steel-100);
}

.process-timeline::after {
  background: var(--color-brand-orange-500);
  transform: translateX(-50%) scaleY(var(--timeline-progress));
  transform-origin: top;
}

.process-timeline--scroll-linked {
  --timeline-progress: 0;
}

.process-timeline li {
  display: grid;
  min-height: clamp(11rem, 22vw, 17rem);
  grid-template-columns: minmax(0, 1fr) clamp(4rem, 8vw, 6rem) minmax(0, 1fr);
  align-items: start;
}

.process-timeline article {
  display: grid;
  max-width: 430px;
  gap: 0.8rem;
  border: 1px solid transparent;
  border-top-color: var(--color-brand-steel-200);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  padding: 0.75rem 1rem 0.65rem;
  transition:
    background 180ms ease,
    border-color 180ms ease,
    box-shadow 180ms ease,
    opacity 260ms ease,
    transform 220ms ease;
}

.process-timeline li:hover article {
  transform: translateY(-0.25rem);
}

.process-timeline li:nth-child(odd) article {
  grid-column: 1;
  justify-self: end;
}

.process-timeline li:nth-child(even) article {
  grid-column: 3;
}

.process-timeline li > span {
  --number-badge-size: var(--timeline-marker-size);

  z-index: 1;
  display: inline-grid;
  place-items: center;
  width: var(--number-badge-size);
  height: var(--number-badge-size);
  grid-column: 2;
  grid-row: 1;
  justify-self: center;
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-pill);
  background: var(--color-paper);
  transition:
    background 160ms ease,
    border-color 160ms ease,
    box-shadow 160ms ease;
}

.process-timeline i {
  display: block;
  width: 1.55rem;
  height: 1.55rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-graphite-950);
  transition: background 160ms ease;
}

.process-timeline__step--active article {
  border-color: var(--color-brand-orange-300);
  border-top-color: var(--color-brand-orange-500);
  background: var(--color-brand-warm-50);
  box-shadow: var(--shadow-card);
}

.process-timeline__step--active > span {
  border-color: var(--color-brand-orange-500);
  background: var(--color-paper);
  box-shadow: var(--shadow-permit-badge);
}

.process-timeline__step--active > span i {
  background: var(--color-brand-orange-500);
}

.process-timeline strong {
  color: var(--color-brand-orange-900);
  font-size: var(--text-small);
  line-height: 1;
}

.process-timeline h3,
.service-feature-grid.reason-grid h3 {
  max-width: 16ch;
}

.process-timeline p {
  max-width: 38ch;
  color: var(--color-brand-graphite-700);
}

.service-feature-grid.reason-grid article {
  min-height: 17rem;
}

@media (prefers-reduced-motion: reduce) {
  .process-timeline::after {
    transform: translateX(-50%) scaleY(1);
  }

  .process-timeline article {
    opacity: 1;
    transform: none;
  }

  .process-timeline article {
    transition: none;
  }
}

.service-work {
  background:
    linear-gradient(180deg, var(--color-paper), var(--color-brand-warm-50) 28%, var(--color-paper)),
    var(--color-brand-warm-50);
}

.service-work__tabs {
  position: relative;
  display: grid;
  gap: clamp(1rem, 2vw, 1.35rem);
  overflow: hidden;
  border: 1px solid var(--color-brand-graphite-800);
  border-radius: var(--radius-sm);
  background: var(--color-brand-graphite-950);
  box-shadow: var(--shadow-card-dark);
  padding: clamp(1rem, 2.4vw, 1.45rem);
}

.service-work__tabs::before {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 4px;
  background: var(--color-brand-orange-500);
  content: "";
}

.service-work__tablist {
  position: relative;
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 0.45rem;
  border: 0;
  background: transparent;
  box-shadow: none;
  padding: 0.25rem 0 0.9rem;
}

.service-work__tablist::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 1px;
  background: var(--surface-on-dark-16);
  content: "";
}

.service-work__tab {
  display: grid;
  min-height: 4.1rem;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 0.7rem;
  align-items: center;
  border: 1px solid var(--surface-on-dark-16);
  border-radius: var(--radius-sm);
  background: var(--surface-on-dark-7);
  color: var(--color-paper);
  cursor: pointer;
  font: inherit;
  font-weight: 600;
  line-height: 1.2;
  padding: 0.85rem;
  text-align: left;
  transition:
    transform 0.18s,
    box-shadow 0.18s,
    border-color 0.18s,
    background 0.18s;
}

.service-work__tablist::-webkit-scrollbar {
  display: none;
}

.service-work__tab:hover {
  border-color: var(--color-brand-orange-300);
  background: var(--surface-on-dark-10);
  transform: translateY(-0.12rem);
}

.service-work__tab:focus-visible {
  outline: 3px solid var(--color-brand-orange-300);
  outline-offset: 3px;
}

.service-work__tab[aria-selected="true"] {
  border-color: var(--color-brand-orange-500);
  background: var(--color-brand-orange-500);
  color: var(--color-brand-graphite-950);
  box-shadow: var(--shadow-permit-badge);
}

.service-work__tab-label {
  min-width: 0;
}

.service-work__tab-count {
  display: inline-flex;
  min-width: 2.1rem;
  min-height: 2.1rem;
  align-items: center;
  justify-content: center;
  border: 1px solid var(--surface-on-dark-16);
  border-radius: var(--radius-pill);
  color: var(--color-brand-orange-300);
  font-size: var(--text-small);
}

.service-work__tab[aria-selected="true"] .service-work__tab-count {
  border-color: var(--color-brand-graphite-950);
  color: var(--color-brand-graphite-950);
}

.service-work__panel[hidden] {
  display: none;
}

.service-work__grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: clamp(0.9rem, 2vw, 1.25rem);
}

.service-work__grid:has(.case-study:only-child) {
  max-width: min(100%, 34rem);
  grid-template-columns: minmax(0, 1fr);
}

.service-work__grid:has(.case-study:nth-child(2):last-child) {
  max-width: min(100%, 48rem);
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.service-work__panel:not([hidden]) .service-work__grid {
  animation: service-work-panel-in 180ms ease-out;
}

.service-work .case-study {
  overflow: hidden;
  min-height: 100%;
  border-color: var(--surface-on-dark-16);
  background: var(--color-paper);
  box-shadow: var(--shadow-card);
}

.service-work .case-study::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  height: 4px;
  background: var(--color-brand-orange-500);
  content: "";
  transform: scaleX(0.22);
  transform-origin: left;
  transition: transform 0.22s ease;
}

.service-work .case-study:hover::after {
  transform: scaleX(1);
}

.service-work .case-study__media {
  aspect-ratio: 16 / 10;
  border-bottom: 0;
  background: var(--color-brand-graphite-900);
}

.service-work .case-study__media img {
  display: block;
  object-position: center;
}

.service-work .case-study__body {
  grid-template-rows: auto auto 1fr auto;
  min-height: 0;
  gap: 0.75rem;
  background: var(--color-paper);
  padding: clamp(1rem, 2vw, 1.35rem);
}

.service-work .case-study__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem 0.65rem;
  align-items: center;
  border-bottom: 1px solid var(--color-brand-steel-100);
  color: var(--color-brand-graphite-600);
  font-size: var(--text-small);
  font-weight: 600;
  padding-bottom: 0.6rem;
}

.service-work .case-study__meta span {
  color: var(--color-brand-orange-800);
  text-transform: uppercase;
}

.service-work .case-study__meta time {
  color: var(--color-brand-graphite-600);
}

.service-work .case-study strong {
  font-size: clamp(1.08rem, 1.5vw, 1.3rem);
}

.service-work .case-study__text {
  line-height: 1.55;
}

.service-work .case-study__link {
  align-self: end;
  min-height: 44px;
  align-items: center;
}

.service-work__noscript {
  margin-top: 1rem;
}

@keyframes service-work-panel-in {
  from {
    opacity: 0;
    transform: translateY(0.25rem);
  }
}

.service-areas {
  background:
    linear-gradient(180deg, var(--color-paper), var(--color-brand-steel-50) 45%, var(--color-paper)),
    var(--color-paper);
}

.service-areas__block {
  display: grid;
  grid-template-columns: minmax(18rem, 0.55fr) minmax(0, 1.45fr);
  gap: clamp(1rem, 2.5vw, 1.5rem);
  align-items: stretch;
}

.service-areas__copy {
  display: grid;
  align-content: center;
  gap: 1.35rem;
  border: 1px solid var(--surface-on-dark-16);
  border-radius: var(--radius-sm);
  background: var(--color-brand-graphite-950);
  color: var(--color-paper);
  padding: clamp(1.4rem, 3vw, 2.4rem);
}

.service-areas__copy h2 {
  max-width: 12ch;
  color: var(--color-paper);
}

.service-areas__copy p {
  max-width: 42ch;
  color: var(--text-on-dark-78);
}

.service-areas__copy .button {
  justify-self: start;
}

.location-detail-hero.service-hero .home-hero__copy {
  grid-column: 1 / span 5;
  max-width: 47rem;
}

.location-detail-hero .home-hero__aside {
  grid-column: 7 / -1;
}

.location-zone.home-engineer {
  padding-top: clamp(5rem, 10vw, 8rem);
}

.location-service-section {
  background: var(--location-section-bg, var(--gradient-premium-field));
}

.location-service-section--2 {
  --location-section-bg: linear-gradient(180deg, var(--color-brand-steel-50), var(--color-paper));
}

.location-service-section--3 {
  --location-section-bg: linear-gradient(180deg, var(--color-brand-warm-50), var(--color-paper));
}

.location-service-section--4 {
  --location-section-bg: var(--gradient-permit-section);
}

.location-service-section--5 {
  --location-section-bg: linear-gradient(180deg, var(--color-paper), var(--color-brand-steel-50));
}

.location-service-section__media {
  gap: 0.75rem;
}

.location-service-section__copy h2 {
  max-width: 12ch;
}

.location-service-section__copy .eyebrow {
  border-left: 3px solid var(--color-brand-orange-500);
  padding-left: 0.75rem;
}

.media-gallery__preview.home-permit__image {
  aspect-ratio: 4 / 3;
}

.location-service-section .location-point-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
  max-width: none;
}

.location-point-grid span:not(.number-badge) {
  color: var(--color-brand-graphite-600);
  line-height: 1.5;
}

.media-gallery {
  display: grid;
  grid-auto-flow: column;
  gap: 0.65rem;
  overflow-x: auto;
  padding-bottom: 0.55rem;
}

.media-gallery {
  grid-auto-columns: minmax(10.5rem, 12rem);
  margin: 0;
  padding-left: 0;
  list-style: none;
  scrollbar-color: var(--color-brand-orange-500) var(--color-brand-steel-100);
}

.media-gallery li {
  min-width: 0;
}

.media-gallery__thumb {
  display: block;
  overflow: hidden;
  width: 100%;
  border: 2px solid var(--color-brand-steel-200);
  border-radius: var(--radius-sm);
  background: var(--color-brand-steel-50);
  padding: 0;
  cursor: pointer;
  aspect-ratio: 4 / 3;
  transition:
    border-color 0.2s ease,
    box-shadow 0.2s ease,
    transform 0.2s ease;
}

.media-gallery__preview img,
.media-gallery__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.media-gallery__thumb img {
  transition: transform 0.24s ease;
}

.media-gallery__thumb:hover,
.media-gallery__thumb.is-active {
  border-color: var(--color-brand-orange-500);
  box-shadow: var(--shadow-card);
}

.media-gallery__thumb:hover {
  transform: translateY(-1px);
}

.media-gallery__thumb:hover img,
.media-gallery__thumb.is-active img {
  transform: scale(1.045);
}

.media-gallery__thumb:focus-visible {
  outline: 3px solid var(--color-brand-orange-300);
  outline-offset: 3px;
}

/* Location case studies mirror the homepage section (light, eyebrow + "See all"
   button). Locations list three projects, so use a balanced 3-up on desktop and
   let the global responsive .case-grid rules take over below. */
@media (min-width: 901px) {
  .location-projects .case-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.local-cta__panel {
  display: grid;
  grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr);
  gap: clamp(1.4rem, 4vw, 3rem);
  border-top: 0.35rem solid var(--color-brand-orange-500);
  padding: clamp(1.35rem, 4vw, 3rem);
}

.local-cta__body {
  display: grid;
  gap: 1.2rem;
  justify-items: start;
}

.local-cta__body p {
  max-width: 54ch;
  margin: 0;
  color: var(--color-brand-graphite-700);
  font-size: var(--text-lede);
}

.coverage-hero {
  position: relative;
  overflow: hidden;
  background: var(--color-surface-warm);
  color: var(--color-brand-graphite-800);
  isolation: isolate;
}

.coverage-hero__inner {
  row-gap: clamp(1.4rem, 4vw, 3rem);
  padding-block: clamp(2.25rem, 5svh, 3.75rem) clamp(2.5rem, 6svh, 4.25rem);
}

.coverage-hero__copy {
  grid-column: 1 / span 5;
  display: grid;
  max-width: 690px;
  gap: 0.85rem;
}

.coverage-hero__copy .eyebrow {
  color: var(--color-brand-graphite-800);
}

.coverage-hero__copy h1 {
  max-width: 10ch;
  color: var(--color-brand-graphite-900);
}

.coverage-hero__lede {
  max-width: 44ch;
  color: var(--color-brand-graphite-700);
  font-size: var(--text-lede);
}

.coverage-hero__aside {
  grid-column: 7 / -1;
  display: grid;
  border: 1px solid var(--surface-on-dark-16);
  border-radius: var(--radius-md);
  background: var(--color-brand-graphite-950);
  box-shadow:
    inset 0 1px 0 var(--surface-on-dark-10),
    var(--shadow-card-dark);
  padding: clamp(1rem, 2vw, 1.25rem);
}

.coverage-primary {
  display: grid;
  gap: 1rem;
  color: var(--color-paper);
}

.coverage-primary__list {
  display: grid;
  gap: 0;
  margin: 0;
  padding: 0;
  list-style: none;
}

.coverage-primary__list li {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 0.8rem;
  align-items: center;
  min-height: 4.75rem;
  border-top: 1px solid var(--surface-on-dark-18);
  padding-block: 0.75rem;
}

.coverage-primary__list .number-badge {
  background: var(--color-brand-orange-500);
  color: var(--color-brand-graphite-950);
}

.coverage-primary__list span:not(.number-badge) {
  display: grid;
  gap: 0.15rem;
  min-width: 0;
}

.coverage-primary__list a,
.coverage-primary__list strong {
  color: var(--color-paper);
  font-weight: 600;
  text-decoration: none;
}

.coverage-primary__list a:hover {
  color: var(--color-brand-orange-300);
}

.coverage-primary__list small {
  color: var(--text-on-dark-68);
  font-size: var(--text-small);
  line-height: 1.4;
}

.locations-map {
  background:
    linear-gradient(180deg, var(--color-paper), var(--color-brand-steel-50) 46%, var(--color-paper)),
    var(--color-paper);
  padding-top: clamp(3rem, 7vw, 5.5rem);
}

.locations-map__heading {
  margin-bottom: clamp(1.2rem, 3vw, 2rem);
}

.locations-map__heading > p {
  max-width: 45ch;
}

.service-area-map {
  display: grid;
  gap: clamp(0.9rem, 2vw, 1.35rem);
}

.service-area-map__visual,
.service-area-map__coverage {
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-md);
  background: var(--color-paper);
  box-shadow: var(--shadow-card);
}

.service-area-map__visual {
  display: grid;
  gap: 1rem;
  overflow: hidden;
  min-width: 0;
  padding: clamp(0.85rem, 2vw, 1.2rem);
}

.service-area-map--full .service-area-map__visual {
  gap: clamp(1rem, 2.4vw, 1.5rem);
  padding: clamp(1rem, 2.5vw, 1.45rem);
}

.service-area-map__figure {
  display: grid;
  gap: 0.65rem;
  margin: 0;
}

.service-area-map__google-wrap {
  position: relative;
  overflow: hidden;
  width: 100%;
  aspect-ratio: 16 / 10;
  min-height: 24rem;
  border: 1px solid var(--color-brand-steel-100);
  border-radius: var(--radius-sm);
  background: var(--color-brand-steel-50);
}

.service-area-map--full .service-area-map__google-wrap {
  aspect-ratio: 16 / 9;
  min-height: clamp(30rem, 54vw, 42rem);
}

.service-area-map__google-canvas,
.service-area-map__fallback {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
}

.service-area-map__google-canvas {
  background: var(--color-brand-steel-50);
}

.service-area-map__fallback {
  display: grid;
  place-items: center;
  background:
    radial-gradient(130% 120% at 0% 0%, var(--color-brand-warm-50), transparent 58%),
    var(--color-brand-steel-50);
  padding: clamp(1.25rem, 3vw, 2.25rem);
}

.service-area-map__fallback-inner {
  display: grid;
  justify-items: center;
  max-width: 46ch;
  gap: 1rem;
  text-align: center;
}

.service-area-map__fallback-title {
  max-width: 30ch;
  color: var(--color-brand-graphite-800);
  font-size: var(--text-lede);
  font-weight: 600;
}

.service-area-map__fallback-hubs {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(8.5rem, 1fr));
  gap: 0.5rem 1.25rem;
  width: 100%;
  margin: 0;
  padding: 0;
  list-style: none;
  text-align: left;
}

.service-area-map__fallback-hubs li {
  display: flex;
  gap: 0.55rem;
  align-items: center;
  color: var(--color-brand-graphite-800);
  font-weight: 600;
}

.service-area-map__loading,
.service-area-map__google-canvas--error {
  color: var(--color-brand-graphite-700);
}

.service-area-map__loading,
.service-area-map__google-canvas--error {
  display: grid;
  height: 100%;
  place-items: center;
  padding: 1rem;
  text-align: center;
}

.service-area-map__figure figcaption {
  color: var(--color-brand-graphite-600);
  font-size: var(--text-small);
  line-height: 1.45;
}

.service-area-map__coverage {
  display: grid;
  gap: clamp(0.85rem, 2vw, 1.2rem);
  padding: clamp(1rem, 2vw, 1.25rem);
}

.service-area-map__coverage-head {
  display: flex;
  flex-wrap: wrap;
  gap: 0.35rem 1rem;
  align-items: end;
  justify-content: space-between;
  border-bottom: 1px solid var(--color-brand-steel-100);
  padding-bottom: 0.85rem;
}

.service-area-map__coverage-head h3 {
  color: var(--color-brand-graphite-950);
  font-size: clamp(1.05rem, 1.5vw, 1.25rem);
}

.service-area-map__coverage-list {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: clamp(0.85rem, 2vw, 1.15rem);
}

.service-coverage-group {
  display: grid;
  gap: 0.65rem;
  min-width: 0;
}

.service-coverage-group h4 {
  color: var(--color-brand-graphite-950);
  font-size: 1rem;
}

.service-coverage-group ul {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  margin: 0;
  padding: 0;
  list-style: none;
}

.service-coverage-group li {
  min-width: 0;
}

.service-coverage-group a,
.service-coverage-group span {
  display: inline-flex;
  min-height: 2.35rem;
  align-items: center;
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-pill);
  background: var(--color-brand-steel-50);
  color: var(--color-brand-graphite-950);
  padding: 0.45rem 0.7rem;
  font-size: var(--text-small);
  font-weight: 600;
  line-height: 1.2;
  text-decoration: none;
}

.service-coverage-group a {
  min-height: 44px;
}

.service-coverage-group a:hover {
  border-color: var(--color-brand-orange-300);
  background: var(--color-brand-warm-50);
}

.service-coverage-group a:focus-visible,
.service-area-map a:focus-visible {
  outline: 3px solid var(--color-brand-orange-300);
  outline-offset: 3px;
}

.faq-section {
  background:
    linear-gradient(180deg, var(--color-paper), var(--color-brand-steel-50) 55%, var(--color-paper)),
    var(--color-paper);
}

.faq-section__grid {
  align-items: start;
  row-gap: clamp(1.6rem, 4vw, 3rem);
}

.faq-section__intro {
  position: sticky;
  top: 7rem;
  grid-column: 1 / span 5;
  max-width: 38rem;
}

.faq-section__intro h1,
.faq-section__intro h2 {
  max-width: 10ch;
  font-size: var(--text-h2);
}

.faq-section__lede {
  max-width: 32rem;
  margin: 0;
  color: var(--color-brand-graphite-700);
  font-size: var(--text-lede);
}

.faq-section__list {
  grid-column: 7 / -1;
  display: grid;
  gap: 0.65rem;
}

.faq-section__item {
  overflow: hidden;
  border-color: var(--color-brand-steel-200);
  background: var(--color-paper);
  box-shadow: var(--shadow-card-inset);
  transition:
    border-color 180ms ease,
    box-shadow 180ms ease,
    transform 180ms ease;
}

.faq-section__item:hover,
.faq-section__item:focus-within,
.faq-section__item[open] {
  border-color: var(--color-brand-orange-300);
  box-shadow: var(--shadow-card);
}

.faq-section summary {
  display: grid;
  grid-template-columns: 2.6rem minmax(0, 1fr) 2rem;
  gap: clamp(0.75rem, 1.6vw, 1rem);
  align-items: center;
  min-height: 4.75rem;
  cursor: pointer;
  color: var(--color-brand-graphite-950);
  font-weight: 500;
  line-height: 1.35;
  padding: clamp(0.95rem, 1.7vw, 1.2rem);
}

.faq-section summary::after {
  display: inline-grid;
  width: 2rem;
  height: 2rem;
  place-items: center;
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-pill);
  color: var(--color-brand-graphite-800);
  content: "+";
  font-size: 1.2rem;
  font-weight: 700;
  line-height: 1;
  transition:
    background 160ms ease,
    border-color 160ms ease,
    color 160ms ease,
    transform 160ms ease;
}

.faq-section summary::marker,
.faq-section summary::-webkit-details-marker {
  display: none;
}

.faq-section summary:focus-visible {
  outline: 3px solid var(--color-brand-orange-300);
  outline-offset: -3px;
}

.faq-section__index {
  display: inline-grid;
  min-width: 2.35rem;
  min-height: 2.35rem;
  place-items: center;
  border: 1px solid var(--color-brand-steel-200);
  border-radius: var(--radius-pill);
  background: var(--color-brand-steel-50);
  color: var(--color-brand-orange-900);
  font-size: var(--text-small);
  font-weight: 600;
}

.faq-section__item[open] summary::after {
  border-color: var(--color-brand-orange-500);
  background: var(--color-brand-orange-500);
  color: var(--color-brand-graphite-950);
  transform: rotate(45deg);
}

.faq-section__item[open] .faq-section__index {
  border-color: var(--color-brand-orange-500);
  background: var(--color-brand-orange-500);
  color: var(--color-brand-graphite-950);
}

.faq-section__item p {
  margin: 0;
  border-top: 1px solid var(--color-brand-steel-100);
  background:
    linear-gradient(90deg, var(--color-brand-warm-50), var(--color-paper)),
    var(--color-brand-warm-50);
  color: var(--color-brand-graphite-700);
  line-height: 1.65;
  padding: clamp(1rem, 2vw, 1.25rem) clamp(1rem, 2vw, 1.2rem) clamp(1.05rem, 2vw, 1.35rem)
    clamp(4.65rem, 5vw, 5rem);
}

@media (max-width: 1100px) {
  .service-areas__block {
    grid-template-columns: 1fr;
  }

  .coverage-hero__copy,
  .coverage-hero__aside,
  .location-detail-hero.service-hero .home-hero__copy,
  .location-detail-hero .home-hero__aside,
  .location-service-section__media,
  .location-service-section__copy {
    grid-column: 1 / -1;
  }

  .location-service-section__copy {
    order: -1;
  }

  .service-area-map__coverage-list {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .service-distress .home-permit__media,
  .service-distress .home-permit__copy,
  .faq-section__intro,
  .faq-section__list {
    grid-column: 1 / -1;
  }

  .local-cta__panel {
    grid-template-columns: 1fr;
  }

  .faq-section__intro {
    position: static;
  }

  .service-features .home-reasons__brief {
    min-height: auto;
  }

  .process-timeline li {
    grid-template-columns: 1fr;
  }

  .process-timeline li:nth-child(n) article {
    grid-column: 1 / -1;
  }

  .process-section h2 {
    max-width: none;
  }

  .process-timeline {
    gap: 2rem;
    padding-left: 4rem;
  }

  .process-timeline::before,
  .process-timeline::after {
    left: 1.5rem;
  }

  .process-timeline li > span {
    grid-column: 1;
    justify-self: start;
    transform: translateX(-4rem);
  }

  .service-work__tablist {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-work__grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }

  .service-work__grid:has(.case-study:nth-child(2):last-child) {
    max-width: none;
  }

  .service-area-map__google-wrap {
    min-height: 22rem;
  }

  .service-area-map--full .service-area-map__google-wrap {
    min-height: 28rem;
  }
}

@media (max-width: 720px) {
  .service-distress__points.home-permit__steps,
  .location-service-section .location-point-grid,
  .service-area-map__coverage-list {
    grid-template-columns: 1fr;
  }

  .media-gallery {
    grid-auto-columns: minmax(10.5rem, 58vw);
  }

  .faq-section__intro h1,
  .faq-section__intro h2 {
    max-width: 9ch;
  }

  .faq-section summary {
    grid-template-columns: 2.35rem minmax(0, 1fr) 1.85rem;
    min-height: 4.25rem;
  }

  .faq-section summary::after {
    width: 1.85rem;
    height: 1.85rem;
  }

  .faq-section__item p {
    padding: 1rem;
  }

  .service-areas__copy {
    min-height: 22rem;
  }

  .service-areas__copy h2,
  .coverage-hero__copy h1 {
    max-width: 9ch;
  }

  .service-area-map__visual {
    padding: 0.85rem;
  }

  .service-area-map__google-wrap {
    aspect-ratio: 4 / 3;
    min-height: 18rem;
  }

  .service-area-map--full .service-area-map__google-wrap {
    aspect-ratio: 1 / 1;
    min-height: 25rem;
  }

  .service-work__tablist {
    display: grid;
    grid-auto-columns: minmax(13rem, 72vw);
    grid-auto-flow: column;
    grid-template-columns: none;
    margin-inline: 0;
    overflow-x: auto;
    overscroll-behavior-inline: contain;
    padding-inline: 0;
    scroll-padding-inline: 0;
    scroll-snap-type: inline proximity;
    scrollbar-width: none;
  }

  .service-work__tablist::after {
    right: 0;
    left: 0;
  }

  .service-work__tab {
    scroll-snap-align: start;
  }

  .service-work__grid,
  .service-work__grid:has(.case-study:only-child),
  .service-work__grid:has(.case-study:nth-child(2):last-child) {
    max-width: none;
    grid-template-columns: 1fr;
  }

  .s-table,
  .s-table tbody,
  .s-table tr,
  .s-table td {
    display: block;
  }

  .s-table {
    min-width: 0;
  }

  .s-table thead {
    display: none;
  }

  .s-table tbody {
    display: grid;
    gap: 0.75rem;
  }

  .s-table tr {
    border: 1px solid var(--color-brand-steel-200);
    border-radius: var(--radius-md);
    overflow: hidden;
  }

  .s-table td {
    display: grid;
    grid-template-columns: minmax(7.5rem, 0.42fr) minmax(0, 1fr);
    gap: 0.75rem;
  }

  .s-table td:last-child {
    border-bottom: 0;
  }

  .s-table td::before {
    color: var(--color-brand-graphite-900);
    content: attr(data-label);
    font-weight: 700;
  }
}

@media (max-width: 460px) {
  .s-table td {
    grid-template-columns: 1fr;
    gap: 0.35rem;
  }
}

@media (prefers-reduced-motion: reduce) {
  .media-gallery__thumb,
  .media-gallery__thumb img,
  .service-work__tab,
  .service-work__panel:not([hidden]) .service-work__grid {
    animation: none;
    transition: none;
  }

  .media-gallery__thumb:hover,
  .media-gallery__thumb:hover img,
  .media-gallery__thumb.is-active img {
    transform: none;
  }
}
