:root {
  --black: #161616;
  --ink: #242424;
  --muted: #656565;
  --paper: #f6f2ea;
  --white: #ffffff;
  --red: #c8102e;
  --gold: #c99a45;
  --steel: #d9e1e4;
  --line: rgba(22, 22, 22, .16);
}

* {
  box-sizing: border-box;
}

body {
  margin: 0;
  background: var(--paper);
  color: var(--ink);
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.5;
  overflow-x: hidden;
}

html {
  overflow-x: hidden;
}

img {
  display: block;
  max-width: 100%;
}

a {
  color: inherit;
}

.grid-container,
.grid-container-full {
  width: 100%;
  margin: 0 auto;
  position: relative;
}

.grid-container {
  max-width: 77rem;
  padding: 0 2.25rem;
}

.grid-offset {
  margin-left: -.75rem;
  margin-right: -.75rem;
}

.grid-33,
.grid-40,
.grid-45,
.grid-50,
.grid-55,
.grid-60,
.grid-100,
.tablet-grid-100,
.mobile-grid-100 {
  float: left;
  min-height: 1px;
  padding-left: .75rem;
  padding-right: .75rem;
}

.grid-33 { width: 33.333%; }
.grid-40 { width: 40%; }
.grid-45 { width: 45%; }
.grid-50 { width: 50%; }
.grid-55 { width: 55%; }
.grid-60 { width: 60%; }
.grid-100 { width: 100%; }

.grid-container:after,
.grid-container-full:after,
.grid-offset:after {
  content: "";
  display: table;
  clear: both;
}

.display-flex {
  display: flex;
  align-items: center;
}

.flex-wrap-wrap {
  flex-wrap: wrap;
}

.justify-content-space-between {
  justify-content: space-between;
}

.align-items-stretch {
  align-items: stretch;
}

.padding-global-2x {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

.padding-global-4x {
  padding-top: 5rem;
  padding-bottom: 5rem;
}

.site-header {
  padding: 1rem 0;
  background: var(--white);
  border-bottom: 1px solid var(--line);
}

.brand-logo {
  width: 11rem;
}

.header-actions {
  gap: .75rem;
  justify-content: flex-end;
}

.small-link {
  color: var(--muted);
  font-size: .875rem;
  text-decoration: none;
}

.button {
  display: inline-flex;
  align-items: center;
  min-height: 2.75rem;
  padding: .75rem 1rem;
  border: 1px solid var(--black);
  background: var(--black);
  color: var(--white);
  font-weight: 700;
  text-decoration: none;
  border-radius: 4px;
}

.button.secondary {
  background: var(--white);
  color: var(--black);
}

.hero {
  background: linear-gradient(90deg, var(--white) 0 58%, var(--steel) 58% 100%);
  border-bottom: 1px solid var(--line);
}

.eyebrow {
  margin: 0 0 1rem;
  color: var(--red);
  font-size: .8125rem;
  font-weight: 800;
  letter-spacing: .14em;
  text-transform: uppercase;
}

h1,
h2,
h3,
p {
  margin-top: 0;
}

h1 {
  max-width: 12ch;
  margin-bottom: 1rem;
  color: var(--black);
  font-size: 4.7rem;
  line-height: .95;
  letter-spacing: 0;
}

h2 {
  max-width: 14ch;
  font-size: 2.25rem;
  line-height: 1.05;
  letter-spacing: 0;
}

h3 {
  margin-bottom: .5rem;
  font-size: 1.1rem;
}

.lead {
  max-width: 38rem;
  color: var(--muted);
  font-size: 1.15rem;
}

.hero-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: .75rem;
  margin-top: 1.75rem;
}

.hero-photo {
  height: 33rem;
  width: 100%;
  object-fit: cover;
  object-position: 54% center;
  border-left: 1px solid var(--line);
}

.service-strip {
  background: var(--black);
  color: var(--white);
}

.strip-item {
  min-height: 8rem;
  padding-top: 1.5rem;
  padding-bottom: 1.5rem;
  border-right: 1px solid rgba(255,255,255,.18);
}

.strip-item:last-child {
  border-right: 0;
}

.strip-item p {
  margin-bottom: 0;
  color: rgba(255,255,255,.72);
}

.section-intro {
  max-width: 40rem;
}

.service-card {
  height: 100%;
  padding: 1.5rem;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.service-card:before {
  content: "";
  display: block;
  width: 2.5rem;
  height: .25rem;
  margin-bottom: 1.25rem;
  background: var(--red);
}

.service-card p,
.area-list,
.contact-panel p {
  color: var(--muted);
}

.area-list {
  columns: 2;
  margin: 1rem 0 0;
  padding-left: 1.2rem;
}

.contact-panel {
  padding: 2rem;
  background: var(--white);
  border: 1px solid var(--line);
  border-radius: 6px;
}

.contact-row {
  display: block;
  padding: .75rem 0;
  border-bottom: 1px solid var(--line);
  color: var(--black);
  font-weight: 700;
  text-decoration: none;
}

.contact-row:last-child {
  border-bottom: 0;
}

.verse {
  color: var(--gold);
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
}

.site-footer {
  padding: 1.5rem 0;
  background: var(--black);
  color: rgba(255,255,255,.75);
  font-size: .875rem;
}

.site-footer strong {
  color: var(--white);
}

@media (max-width: 64rem) {
  .tablet-grid-100 {
    width: 100%;
  }

  h1 {
    font-size: 3.8rem;
  }

  .hero {
    background: var(--white);
  }

  .hero-photo {
    height: 26rem;
    border-left: 0;
    border-top: 1px solid var(--line);
  }
}

@media (max-width: 47.9375rem) {
  .mobile-grid-100 {
    width: 100%;
  }

  .grid-container {
    padding: 0 1.25rem;
  }

  .padding-global-4x {
    padding-top: 2.75rem;
    padding-bottom: 2.75rem;
  }

  .site-header .display-flex,
  .header-actions {
    align-items: flex-start;
    flex-direction: column;
  }

  h1 {
    font-size: 3rem;
  }

  h2 {
    font-size: 1.9rem;
  }

  .hero-photo {
    height: 22rem;
  }

  .strip-item {
    border-right: 0;
    border-bottom: 1px solid rgba(255,255,255,.18);
  }

  .area-list {
    columns: 1;
  }
}
