.location-page { background: var(--paper); color: var(--ink); }
.location-page .site-header { background: rgba(11,11,13,.94); color: white; }
.location-page .site-header.scrolled .brand { width: 108px; }
.location-hero { position: relative; min-height: 82svh; display: flex; align-items: flex-end; overflow: hidden; background: var(--ink); color: white; }
.location-hero > img { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; filter: saturate(.78); }
.location-hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg,rgba(5,5,7,.9),rgba(5,5,7,.25) 72%),linear-gradient(0deg,rgba(5,5,7,.82),transparent 60%); }
.location-hero-copy { position: relative; z-index: 1; width: min(1180px,100%); padding: 170px var(--pad) clamp(64px,8vw,110px); }
.location-hero-copy h1 { max-width: 1100px; margin: 0; font: 900 clamp(3.7rem,8.2vw,8.5rem)/.83 Arial,sans-serif; letter-spacing: -.055em; text-transform: uppercase; }
.location-hero-copy h1 em { color: #e1a2c3; font-style: normal; }
.location-hero-copy > p:not(.section-label) { max-width: 650px; margin: 36px 0; font-size: clamp(1rem,1.6vw,1.3rem); }
.location-cta { display: inline-flex; gap: 36px; padding: 15px 0; border-bottom: 1px solid white; font: 700 .75rem Arial,sans-serif; letter-spacing: .1em; text-transform: uppercase; }
.breadcrumbs { display: flex; gap: 11px; align-items: center; padding: 18px var(--pad); background: #e2dfd8; color: #555; font-size: .75rem; }
.breadcrumbs a { color: var(--plum); }
.location-intro,.location-local,.location-faq { display: grid; grid-template-columns: 1.05fr .95fr; gap: clamp(45px,8vw,120px); }
.location-intro h2,.location-heading h2,.location-local h2,.nearby-areas h2,.location-faq h2,.location-contact h2 { margin: 0; font: 900 clamp(2.8rem,5.4vw,6rem)/.89 Arial,sans-serif; letter-spacing: -.052em; text-transform: uppercase; }
.location-prose p,.location-local > div > p { font-size: clamp(1rem,1.3vw,1.16rem); }
.location-prose p:first-child { margin-top: 0; }
.location-services { background: var(--teal); color: white; }
.location-heading { display: grid; grid-template-columns: .75fr 1.25fr; gap: 6vw; align-items: end; margin-bottom: 65px; }
.location-service-grid { display: grid; grid-template-columns: repeat(5,1fr); border-top: 1px solid rgba(255,255,255,.35); }
.location-service-grid article { min-height: 330px; padding: 28px 22px; border-right: 1px solid rgba(255,255,255,.25); }
.location-service-grid article:last-child { border-right: 0; }
.location-service-grid span { font-size: .68rem; letter-spacing: .12em; }
.location-service-grid h3 { margin: 80px 0 22px; font-size: clamp(1.5rem,2.2vw,2.5rem); letter-spacing: -.04em; }
.location-service-grid p { margin: 0; font-size: .86rem; color: rgba(255,255,255,.82); }
.location-local { background: #dfe3e1; }
.location-local aside { align-self: start; border-top: 4px solid var(--plum); padding-top: 25px; }
.location-local aside > span { color: var(--plum); font: 700 .7rem Arial; letter-spacing: .12em; text-transform: uppercase; }
.location-local ul { list-style: none; margin: 25px 0 35px; padding: 0; }
.location-local li { padding: 14px 0; border-bottom: 1px solid rgba(0,0,0,.2); font-weight: 700; text-transform: uppercase; }
.location-local aside a { display: flex; justify-content: space-between; padding: 15px 0; border-bottom: 1px solid; font: 700 .72rem Arial; letter-spacing: .1em; text-transform: uppercase; }
.nearby-areas { background: var(--ink); color: white; }
.nearby-areas h2 { max-width: 920px; }
.area-link-grid { display: grid; grid-template-columns: repeat(5,1fr); margin-top: 65px; border-top: 1px solid rgba(255,255,255,.35); }
.area-link-grid a { min-height: 180px; display: flex; flex-direction: column; justify-content: space-between; padding: 25px 18px; border-right: 1px solid rgba(255,255,255,.25); transition: background .25s; }
.area-link-grid a:hover { background: var(--plum); }
.area-link-grid span { font: 900 clamp(1.15rem,2vw,2rem)/1 Arial; text-transform: uppercase; }
.area-link-grid b { font: 500 .62rem Arial; letter-spacing: .08em; text-transform: uppercase; }
.location-faq { background: var(--paper); }
.location-faq .faq-list { align-self: start; }
.location-contact { display: grid; grid-template-columns: 1fr 1fr; gap: 8vw; padding: var(--section-y) var(--pad); background: var(--plum); color: white; }
.location-contact > div:first-child > p:last-child { max-width: 580px; }
.location-contact > div:last-child { display: grid; align-content: end; }
.location-contact a { display: flex; justify-content: space-between; padding: 20px 0; border-bottom: 1px solid rgba(255,255,255,.55); font-weight: 700; }
.location-footer {
  background: var(--ink);
  color: white;
  border-top: 1px solid rgba(255,255,255,.12);
}
.location-footer .footer-links { border-color: rgba(255,255,255,.18); }
.location-footer small { grid-column: 1 / -1; }
@media (max-width: 980px) {
  .location-service-grid { grid-template-columns: repeat(2,1fr); }
  .location-service-grid article { min-height: 260px; border-bottom: 1px solid rgba(255,255,255,.25); }
  .location-service-grid h3 { margin-top: 45px; }
  .area-link-grid { grid-template-columns: repeat(2,1fr); }
}
@media (max-width: 700px) {
  .location-hero { min-height: 76svh; }
  .location-hero-copy { padding-top: 135px; }
  .location-intro,.location-heading,.location-local,.location-faq,.location-contact { grid-template-columns: 1fr; }
  .location-heading { gap: 24px; }
  .location-service-grid,.area-link-grid { grid-template-columns: 1fr; }
  .location-service-grid article { min-height: auto; }
  .area-link-grid a { min-height: 130px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.25); }
  .breadcrumbs { overflow-x: auto; white-space: nowrap; }
}
