:root {
--color-black: #080808;
--color-ink: #171717;
--color-muted: #5f5f5f;
--color-text-soft: #3f3f3f;
--color-text-strong: #252525;
--color-footer: #fbfaf8;
--color-line: #dedad2;
--color-surface: #f7f4ef;
--color-white: #ffffff;
--focus-ring: 2px solid var(--color-black);
--focus-offset: 4px;
--font-display: "Cormorant Garamond", Georgia, serif;
--font-body: "Inter", Arial, sans-serif;
--container: 1180px;
--page-gutter: clamp(1rem, 4vw, 3rem);
--radius-none: 0;
--shadow-soft: 0 18px 45px rgba(0, 0, 0, 0.08);
}
@font-face {
font-family: "Inter";
font-style: normal;
font-weight: 400 800;
font-display: swap;
src: url("fonts/inter-latin.woff2") format("woff2");
}
@font-face {
font-family: "Cormorant Garamond";
font-style: normal;
font-weight: 500 700;
font-display: swap;
src: url("fonts/cormorant-garamond-latin.woff2") format("woff2");
}
*, *::before, *::after { box-sizing: border-box; }
html {
scroll-behavior: smooth;
scroll-padding-top: 7rem;
overflow-x: clip;
}
body {
margin: 0;
overflow-x: clip;
color: var(--color-black);
background: var(--color-white);
font-family: var(--font-body);
font-size: 1rem;
line-height: 1.5;
text-rendering: optimizeLegibility;
-webkit-font-smoothing: antialiased;
}
img, svg { display: block; max-width: 100%; }
a { color: inherit; text-decoration: none; }
button, input, textarea, select { font: inherit; }
:focus-visible {
outline: var(--focus-ring);
outline-offset: var(--focus-offset);
}
.skip-link {
position: absolute;
top: 0.75rem;
left: 0.75rem;
z-index: 999;
transform: translateY(-150%);
background: var(--color-black);
color: var(--color-white);
padding: 0.75rem 1rem;
font-size: 0.85rem;
font-weight: 800;
letter-spacing: 0.06em;
text-transform: uppercase;
transition: transform 180ms ease;
}
.skip-link:focus { transform: translateY(0); }
.container {
width: min(var(--container), calc(100% - (var(--page-gutter) * 2)));
margin-inline: auto;
}
.section { padding-block: clamp(2.75rem, 6vw, 5rem); }
.section--compact { padding-block: clamp(2rem, 4vw, 3.5rem); }
.eyebrow {
margin: 0 0 0.75rem;
font-size: 0.72rem;
font-weight: 800;
letter-spacing: 0.12em;
text-transform: uppercase;
}
.heading {
margin: 0;
font-family: var(--font-display);
font-weight: 600;
line-height: 1.05;
letter-spacing: -0.045em;
color: var(--color-black);
}
.heading--xl { font-size: clamp(3.35rem, 7vw, 5.95rem); }
.heading--lg { font-size: clamp(2.6rem, 5vw, 4.25rem); }
.text-muted { color: var(--color-muted); }
.button {
display: inline-flex;
min-height: 3rem;
align-items: center;
justify-content: center;
border: 1px solid var(--color-black);
padding-inline: 1.6rem;
font-size: 0.75rem;
font-weight: 800;
letter-spacing: 0.09em;
text-transform: uppercase;
transition: transform 180ms ease, box-shadow 180ms ease, background-color 180ms ease, color 180ms ease;
}
.button:hover, .button:focus-visible {
transform: translateY(-2px);
box-shadow: var(--shadow-soft);
}
.button--dark { background: var(--color-black); color: var(--color-white); }
.button--light { background: transparent; color: var(--color-black); }
.sr-only {
position: absolute;
width: 1px;
height: 1px;
padding: 0;
margin: -1px;
overflow: hidden;
clip: rect(0, 0, 0, 0);
white-space: nowrap;
border: 0;
}
.site-header {
position: sticky;
top: 0;
z-index: 20;
border-bottom: 1px solid rgba(0, 0, 0, 0.07);
background: rgba(255, 255, 255, 0.94);
backdrop-filter: blur(16px);
}
.header-inner {
display: grid;
grid-template-columns: 11.5rem 1fr auto;
min-height: 6.75rem;
align-items: center;
gap: 2rem;
}
.brand { display: inline-flex; align-items: center; width: 8.75rem; }
.brand__logo {
width: 8.5rem;
height: auto;
object-fit: contain;
}
.primary-nav__list {
display: flex;
align-items: center;
justify-content: center;
gap: clamp(1.2rem, 3vw, 2.7rem);
margin: 0;
padding: 0;
list-style: none;
}
.primary-nav__link {
position: relative;
display: inline-block;
padding-block: 0.5rem;
font-size: 0.74rem;
font-weight: 700;
letter-spacing: 0.075em;
text-transform: uppercase;
}
.primary-nav__link::after {
content: "";
position: absolute;
right: 0;
bottom: 0;
left: 0;
height: 1px;
transform: scaleX(0);
transform-origin: center;
background: currentColor;
transition: transform 180ms ease;
}
.primary-nav__link:hover::after,
.primary-nav__link:focus-visible::after,
.primary-nav__link[aria-current="page"]::after { transform: scaleX(1); }
.header-actions {
display: flex;
align-items: center;
gap: 1.35rem;
white-space: nowrap;
}
.phone-link {
display: inline-flex;
align-items: center;
gap: 0.55rem;
font-size: 0.86rem;
font-weight: 600;
}
.menu-button {
display: none;
width: 2.75rem;
height: 2.75rem;
border: 1px solid var(--color-line);
background: var(--color-white);
color: var(--color-black);
cursor: pointer;
}
.menu-button__line {
display: block;
width: 1.2rem;
height: 1px;
margin: 0.28rem auto;
background: currentColor;
}
.hero { overflow: hidden; }
.hero__grid {
display: grid;
grid-template-columns: minmax(23rem, 0.95fr) minmax(0, 1.15fr);
align-items: stretch;
min-height: clamp(34rem, 58vw, 43rem);
}
.hero__content {
display: flex;
flex-direction: column;
justify-content: center;
padding-block: 4rem;
padding-right: clamp(2rem, 5vw, 4.25rem);
}
.hero__rule {
width: 3rem;
height: 1px;
margin: 2rem 0 1.25rem;
background: var(--color-black);
}
.hero__copy {
max-width: 29rem;
margin: 0 0 1.9rem;
color: var(--color-text-strong);
font-size: clamp(1rem, 1.4vw, 1.12rem);
}
.hero__actions { display: flex; flex-wrap: wrap; gap: 1rem; }
.hero__media {
position: relative;
min-height: 100%;
margin-right: calc((100vw - min(var(--container), calc(100vw - (var(--page-gutter) * 2)))) / -2);
overflow: hidden;
background: var(--color-white);
box-shadow: none;
isolation: isolate;
}
.hero__content {
position: relative;
z-index: 2;
min-width: 0;
background: var(--color-white);
}
.hero .heading--xl {
max-width: 9.4ch;
overflow-wrap: normal;
}
.hero__media {
z-index: 0;
}
.hero__media::before {
z-index: 1;
}
.hero__image {
width: 100%;
height: 100%;
min-height: 34rem;
object-fit: cover;
object-position: center;
box-shadow: none;
filter: none;
transform: translateZ(0);
}
.hero__media::before {
content: "";
position: absolute;
inset: 0;
background: linear-gradient(90deg, #fff 0%, rgba(255,255,255,0.74) 9%, rgba(255,255,255,0.04) 32%);
pointer-events: none;
}
.section-header {
max-width: 52rem;
margin: 0 auto clamp(1.75rem, 4vw, 3rem);
text-align: center;
}
.services-grid {
display: grid;
grid-template-columns: repeat(5, minmax(0, 1fr));
gap: 1.25rem;
}
.service-card {
display: flex;
min-height: 19.75rem;
flex-direction: column;
border: 1px solid var(--color-line);
background: var(--color-white);
}
.service-card__image {
width: 100%;
height: 9.7rem;
object-fit: cover;
object-position: center;
filter: saturate(0.88) contrast(1.02);
}
.service-card__body {
display: flex;
flex: 1;
flex-direction: column;
align-items: center;
padding: 1.35rem 1rem 1.1rem;
text-align: center;
}
.card-title {
margin: 0 0 0.75rem;
font-size: 0.78rem;
font-weight: 800;
line-height: 1.25;
letter-spacing: 0.075em;
text-transform: uppercase;
}
.service-card__copy {
max-width: 13.5rem;
margin: 0;
color: var(--color-text-soft);
font-size: 0.94rem;
line-height: 1.6;
}
.service-card__arrow {
margin-top: auto;
padding-top: 1rem;
font-size: 1.6rem;
line-height: 1;
}
.difference {
display: grid;
grid-template-columns: minmax(15rem, 18rem) 1fr;
gap: clamp(2rem, 5vw, 4rem);
align-items: start;
}
.difference__intro .heading { text-align: left; }
.difference__rule {
width: 3rem;
height: 1px;
margin: 1.25rem 0;
background: var(--color-black);
}
.features-grid {
display: grid;
grid-template-columns: repeat(5, minmax(0, 1fr));
}
.feature {
padding: 0 1.25rem;
border-right: 1px solid var(--color-line);
text-align: center;
}
.feature:last-child { border-right: 0; }
.feature__icon {
width: 2.35rem;
height: 2.35rem;
margin: 0 auto 0.85rem;
stroke: var(--color-black);
stroke-width: 1.4;
fill: none;
stroke-linecap: round;
stroke-linejoin: round;
}
.feature__copy {
margin: 0.6rem 0 0;
color: var(--color-text-soft);
font-size: 0.94rem;
line-height: 1.55;
}
.pricing-grid {
display: grid;
grid-template-columns: repeat(4, minmax(0, 1fr));
border: 1px solid var(--color-line);
background: var(--color-white);
}
.price-card {
display: flex;
min-height: 14rem;
flex-direction: column;
align-items: center;
justify-content: center;
padding: 1.9rem 1.35rem;
border-right: 1px solid var(--color-line);
text-align: center;
}
.price-card:last-child { border-right: 0; }
.price-card__icon {
width: 2.35rem;
height: 2.35rem;
margin-bottom: 0.85rem;
stroke: var(--color-black);
stroke-width: 1.4;
fill: none;
stroke-linecap: round;
stroke-linejoin: round;
}
.price-card__label {
margin: 0.2rem 0 0;
color: var(--color-muted);
font-size: 0.78rem;
}
.price-card__amount {
margin: 0.1rem 0 0.75rem;
font-family: var(--font-display);
font-size: clamp(2.6rem, 4vw, 3.25rem);
font-weight: 600;
line-height: 1;
letter-spacing: -0.04em;
}
.price-card__quote {
margin: 0.1rem 0 0.75rem;
font-family: var(--font-display);
font-size: clamp(2.6rem, 4vw, 3.25rem);
font-weight: 600;
line-height: 1;
letter-spacing: -0.04em;
}
.price-card__copy {
max-width: 16rem;
margin: 0;
color: var(--color-text-soft);
font-size: 0.94rem;
line-height: 1.55;
}
.price-card__cta { margin-top: 1.25rem; }
.reviews-grid {
display: grid;
grid-template-columns: repeat(auto-fit, minmax(min(100%, 22rem), 1fr));
gap: 1.75rem;
align-items: stretch;
}
.review {
display: flex;
min-height: 100%;
margin: 0;
flex-direction: column;
justify-content: center;
border: 1px solid var(--color-line);
padding: clamp(1.5rem, 3vw, 2.25rem);
text-align: center;
}
.review__quote {
margin: 0 0 0.9rem;
font-family: var(--font-display);
font-size: clamp(1.15rem, 2vw, 1.35rem);
font-style: italic;
line-height: 1.35;
}
.review__name {
display: block;
font-size: 0.72rem;
font-weight: 800;
letter-spacing: 0.13em;
text-transform: uppercase;
}
.review__area {
display: block;
margin-top: 0.15rem;
color: var(--color-muted);
font-size: 0.78rem;
letter-spacing: 0.14em;
text-transform: uppercase;
}
.review__source {
display: inline-block;
margin-top: 0.65rem;
border-bottom: 1px solid currentColor;
font-size: 0.72rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.review__source[hidden] { display: none; }
.review-cta {
display: flex;
justify-content: center;
margin-top: 1.75rem;
}
.site-footer {
border-top: 1px solid var(--color-line);
background: var(--color-footer);
padding-block: 2.4rem 1.7rem;
}
.footer-grid {
display: grid;
grid-template-columns: 10rem 1.35fr 0.75fr 1.1fr 0.8fr;
gap: clamp(1.5rem, 4vw, 3rem);
align-items: start;
}
.footer-logo { width: 7.25rem; }
.footer-title {
margin: 0 0 0.9rem;
font-size: 0.75rem;
font-weight: 800;
letter-spacing: 0.11em;
text-transform: uppercase;
}
.footer-text { margin: 0; color: var(--color-text-soft); font-size: 0.86rem; }
.footer-list {
display: grid;
gap: 0.45rem;
margin: 0;
padding: 0;
list-style: none;
color: var(--color-text-soft);
font-size: 0.86rem;
}
.social-list {
display: flex;
gap: 0.8rem;
margin: 0;
padding: 0;
list-style: none;
}
.social-list a {
display: grid;
width: 2.25rem;
height: 2.25rem;
place-items: center;
border: 1px solid var(--color-line);
border-radius: 50%;
font-weight: 800;
}
.footer-bottom {
display: flex;
flex-wrap: wrap;
justify-content: space-between;
gap: 1rem;
margin-top: 2rem;
color: var(--color-muted);
font-size: 0.78rem;
}
.legal-links { display: flex; gap: 1.5rem; }
.review__stars {
display: flex;
justify-content: center;
gap: 0.15rem;
margin-bottom: 0.85rem;
color: var(--color-black);
font-size: 0.95rem;
letter-spacing: 0.08em;
}
.contact-section {
border-top: 1px solid var(--color-line);
border-bottom: 1px solid var(--color-line);
background: var(--color-surface);
}
.contact-grid {
display: grid;
grid-template-columns: minmax(0, 0.85fr) minmax(20rem, 1fr);
gap: clamp(2rem, 5vw, 4rem);
align-items: start;
}
.contact-list-clean {
display: grid;
gap: 0.85rem;
margin: 1.5rem 0 0;
padding: 0;
list-style: none;
color: var(--color-text-soft);
font-size: 0.98rem;
}
.contact-form {
display: grid;
gap: 1rem;
padding: clamp(1.25rem, 3vw, 2rem);
border: 1px solid var(--color-line);
background: var(--color-white);
}
.form-row {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1rem;
}
.field {
display: grid;
gap: 0.45rem;
}
.field label {
font-size: 0.76rem;
font-weight: 800;
letter-spacing: 0.09em;
text-transform: uppercase;
}
.field input,
.field select,
.field textarea {
width: 100%;
border: 1px solid var(--color-line);
border-radius: 0;
background: var(--color-white);
color: var(--color-black);
padding: 0.85rem 0.9rem;
font-size: 1rem;
}
.field textarea {
min-height: 7rem;
resize: vertical;
}
.form-note {
margin: 0;
color: var(--color-muted);
font-size: 0.88rem;
}
.form-status {
margin: 0;
border: 1px solid var(--color-line);
padding: 0.85rem 1rem;
font-size: 0.9rem;
line-height: 1.5;
}
.form-status--success {
border-color: #66806a;
background: #f1f6f1;
color: #29452e;
}
.form-status--error {
border-color: #a46767;
background: #fff4f4;
color: #702c2c;
}
.final-cta {
background: var(--color-black);
color: var(--color-white);
text-align: center;
}
.final-cta .heading { color: var(--color-white); }
.final-cta__copy {
max-width: 40rem;
margin: 1rem auto 1.75rem;
color: rgba(255, 255, 255, 0.78);
font-size: 1.05rem;
line-height: 1.65;
}
.final-cta .button {
border-color: var(--color-white);
background: var(--color-white);
color: var(--color-black);
}
.social-list svg {
width: 1.05rem;
height: 1.05rem;
fill: currentColor;
}
@media (max-width: 1100px) {
.header-inner { grid-template-columns: 9rem 1fr auto; gap: 1.1rem; }
.brand__logo { width: 7.75rem; }
.primary-nav__list { gap: 1.15rem; }
.services-grid { grid-template-columns: repeat(3, 1fr); }
.difference { grid-template-columns: 1fr; }
.features-grid { grid-template-columns: repeat(3, 1fr); row-gap: 2rem; }
.feature:nth-child(3) { border-right: 0; }
.pricing-grid { grid-template-columns: repeat(2, 1fr); }
.price-card:nth-child(2) { border-right: 0; }
.price-card:nth-child(-n+2) { border-bottom: 1px solid var(--color-line); }
.footer-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 860px) {
.header-inner {
display: flex;
min-height: 5.25rem;
justify-content: space-between;
}
.brand__logo { width: 6.8rem; }
.primary-nav { display: none; }
.header-actions .button, .phone-link { display: none; }
.menu-button { display: block; }
.primary-nav.is-open {
position: absolute;
top: 100%;
right: 0;
left: 0;
display: block;
border-top: 1px solid var(--color-line);
background: var(--color-white);
padding: 1rem var(--page-gutter) 1.4rem;
}
.primary-nav.is-open .primary-nav__list {
flex-direction: column;
align-items: flex-start;
gap: 0.5rem;
}
.hero__grid { grid-template-columns: 1fr; min-height: auto; }
.hero__media { order: -1; margin-inline: calc(var(--page-gutter) * -1); }
.hero__image { min-height: 23rem; max-height: 30rem; }
.hero__media::before {
inset: auto 0 0 0;
width: auto;
height: 7rem;
background: linear-gradient(0deg, var(--color-white) 0%, rgba(255,255,255,0) 100%);
}
.hero__content { padding: 2.6rem 0 1rem; }
.services-grid, .features-grid, .pricing-grid, .reviews-grid, .footer-grid, .contact-grid, .form-row { grid-template-columns: 1fr; }
.feature, .review, .price-card { border-right: 0; }
.feature { border-bottom: 1px solid var(--color-line); padding: 1.35rem 0; }
.feature:last-child { border-bottom: 0; }
.price-card { border-bottom: 1px solid var(--color-line); }
.price-card:last-child { border-bottom: 0; }
.review { min-height: 0; }
.footer-bottom { flex-direction: column; }
}
.hero {
overflow: hidden;
background: var(--color-white);
}
.hero__grid {
display: grid;
grid-template-columns: minmax(0, 0.72fr) minmax(0, 1.28fr);
gap: clamp(1.75rem, 4vw, 4rem);
align-items: center;
min-height: auto;
padding-block: clamp(3.75rem, 6vw, 5.75rem);
}
.hero__content {
position: relative;
z-index: 3;
display: flex;
flex-direction: column;
justify-content: center;
max-width: 34rem;
padding: 0;
background: var(--color-white);
}
.hero .heading--xl {
max-width: 10.5ch;
line-height: 1.02;
overflow: visible;
}
.hero__media {
position: relative;
z-index: 1;
min-height: 0;
margin: 0;
overflow: hidden;
background: var(--color-white);
box-shadow: none;
isolation: isolate;
}
.hero__media::before {
content: "";
position: absolute;
inset: 0 auto 0 0;
display: block;
width: clamp(8rem, 17vw, 15rem);
background: linear-gradient(
90deg,
var(--color-white) 0%,
rgba(255, 255, 255, 0.92) 18%,
rgba(255, 255, 255, 0.58) 48%,
rgba(255, 255, 255, 0.18) 78%,
rgba(255, 255, 255, 0) 100%
);
pointer-events: none;
z-index: 2;
}
.hero__image {
display: block;
width: 100%;
height: clamp(31rem, 42vw, 40rem);
min-height: 0;
object-fit: cover;
object-position: center;
filter: none;
box-shadow: none;
transform: none;
}
@media (min-width: 1280px) {
.hero__grid {
grid-template-columns: minmax(0, 0.68fr) minmax(0, 1.32fr);
}
}
@media (max-width: 860px) {
.hero__grid {
grid-template-columns: 1fr;
gap: 0;
padding-block: 0 2.75rem;
}
.hero__media {
order: -1;
margin-inline: calc(var(--page-gutter) * -1);
}
.hero__media::before {
inset: auto 0 0 0;
width: auto;
height: 7rem;
background: linear-gradient(
0deg,
var(--color-white) 0%,
rgba(255, 255, 255, 0.72) 34%,
rgba(255, 255, 255, 0) 100%
);
}
.hero__image {
height: clamp(22rem, 68vw, 30rem);
}
.hero .heading--xl {
max-width: 11ch;
}
.hero__content {
padding-top: 2.35rem;
}
}
#about {
padding-block: clamp(3rem, 5vw, 4.5rem);
}
#about .difference {
display: grid;
grid-template-columns: 18rem minmax(0, 1fr);
gap: clamp(3rem, 6vw, 5rem);
align-items: start;
}
#about .difference__intro {
padding-top: 0;
}
#about .difference__intro .heading {
margin: 0;
line-height: 1.04;
letter-spacing: -0.045em;
}
#about .features-grid {
display: grid;
grid-template-columns: repeat(5, minmax(8.5rem, 1fr));
align-items: start;
padding-top: 0.22rem;
}
#about .feature {
display: flex;
min-height: 11.5rem;
flex-direction: column;
align-items: center;
justify-content: flex-start;
padding: 0 1.45rem;
border-right: 1px solid var(--color-line);
text-align: center;
}
#about .feature:last-child {
border-right: 0;
}
#about .feature__icon {
display: block;
width: 2.25rem;
height: 2.25rem;
flex: 0 0 2.25rem;
margin: 0 0 0.8rem;
stroke: var(--color-black);
stroke-width: 1.45;
}
#about .feature .card-title {
display: flex;
min-height: 3.25rem;
align-items: flex-start;
justify-content: center;
margin: 0;
line-height: 1.18;
text-align: center;
}
#about .feature__copy {
max-width: 10rem;
margin: 1rem auto 0;
line-height: 1.5;
text-align: center;
}
@media (max-width: 1100px) {
#about .difference {
grid-template-columns: 1fr;
gap: 2.25rem;
}
#about .features-grid {
grid-template-columns: repeat(3, minmax(0, 1fr));
}
#about .feature:nth-child(3) {
border-right: 0;
}
}
@media (max-width: 860px) {
#about .features-grid {
grid-template-columns: 1fr;
padding-top: 0;
}
#about .feature {
min-height: 0;
padding: 1.35rem 0;
border-right: 0;
border-bottom: 1px solid var(--color-line);
}
#about .feature:last-child {
border-bottom: 0;
}
#about .feature .card-title {
min-height: 0;
}
}
.fieldset {
min-width: 0;
margin: 0;
border: 0;
padding: 0;
}
.fieldset legend {
padding: 0;
font-size: 0.76rem;
font-weight: 800;
letter-spacing: 0.09em;
text-transform: uppercase;
}
.radio-group {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 0.75rem;
}
.radio-option {
display: flex;
min-height: 3.05rem;
align-items: center;
gap: 0.6rem;
border: 1px solid var(--color-line);
background: var(--color-white);
padding: 0.75rem 0.9rem;
cursor: pointer;
}
.radio-option input {
width: 1rem;
height: 1rem;
accent-color: var(--color-black);
}
.field label span,
.fieldset legend span {
color: var(--color-black);
}
.hero__image,
.service-card__image {
image-rendering: auto;
backface-visibility: hidden;
-webkit-backface-visibility: hidden;
}
@media (max-width: 860px) {
.hero__image {
width: 100%;
height: auto;
min-height: 0;
aspect-ratio: 4 / 3;
object-fit: cover;
object-position: center;
}
.service-card__image {
height: auto;
aspect-ratio: 16 / 10;
object-fit: cover;
object-position: center;
}
}
.hero__image,
.service-card__image {
filter: none !important;
transform: none !important;
backface-visibility: visible !important;
-webkit-backface-visibility: visible !important;
image-rendering: auto;
}
.service-card__image {
background: var(--color-surface);
}
@media (max-width: 860px) {
.hero__image {
width: 100%;
height: auto !important;
min-height: 0 !important;
max-height: none !important;
aspect-ratio: 4 / 3;
object-fit: cover;
object-position: center;
}
.service-card__image {
width: 100%;
height: auto !important;
min-height: 0 !important;
aspect-ratio: 4 / 3;
object-fit: cover;
object-position: center;
}
}
.brand,
.footer-brand {
display: inline-flex;
align-items: center;
cursor: default;
user-select: none;
}
.brand__logo,
.footer-logo {
display: block;
height: auto !important;
object-fit: contain;
pointer-events: none;
}
.footer-brand { width: fit-content; }
@media (min-width: 861px) {
.hero__actions {
display: flex;
flex-wrap: nowrap;
align-items: center;
gap: 1rem;
}
.hero__actions .button {
flex: 0 0 auto;
white-space: nowrap;
}
}
@media (max-width: 860px) {
.hero__actions {
display: grid;
grid-template-columns: 1fr;
gap: 0.75rem;
width: 100%;
}
.hero__actions .button {
width: 100%;
min-width: 0;
padding-inline: 1rem;
white-space: normal;
text-align: center;
}
}
.mobile-cta-bar {
display: none;
}
@media (max-width: 860px) {
body {
padding-bottom: calc(4.25rem + env(safe-area-inset-bottom));
}
.mobile-cta-bar {
position: fixed;
right: 0;
bottom: 0;
left: 0;
z-index: 40;
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
border-top: 1px solid var(--color-line);
background: var(--color-black);
box-shadow: 0 -12px 30px rgba(0, 0, 0, 0.12);
padding-bottom: env(safe-area-inset-bottom);
}
.mobile-cta-bar__link {
display: inline-flex;
min-height: 4.25rem;
align-items: center;
justify-content: center;
padding: 0 1rem;
border: 0;
background: var(--color-black);
color: var(--color-white);
font-size: 0.76rem;
font-weight: 800;
letter-spacing: 0.1em;
line-height: 1.1;
text-align: center;
text-transform: uppercase;
white-space: nowrap;
}
.mobile-cta-bar__link + .mobile-cta-bar__link {
border-left: 1px solid rgba(255, 255, 255, 0.24);
}
.mobile-cta-bar__link:focus-visible {
outline-color: var(--color-white);
outline-offset: -6px;
}
}
@media (max-width: 860px) {
.mobile-cta-bar {
background: var(--color-white);
}
.mobile-cta-bar__link {
border-top: 0;
}
.mobile-cta-bar__link--light {
background: var(--color-white);
color: var(--color-black);
}
.mobile-cta-bar__link + .mobile-cta-bar__link {
border-left: 1px solid var(--color-line);
}
.mobile-cta-bar__link--light:focus-visible {
outline-color: var(--color-black);
}
}
.checkbox-field {
display: grid;
grid-template-columns: auto 1fr;
gap: 0.7rem;
align-items: start;
border: 1px solid var(--color-line);
background: var(--color-white);
padding: 0.9rem;
}
.checkbox-field input {
width: 1.05rem;
height: 1.05rem;
margin-top: 0.18rem;
accent-color: var(--color-black);
}
.checkbox-field label {
color: var(--color-text-soft);
font-size: 0.84rem;
font-weight: 500;
letter-spacing: 0;
line-height: 1.55;
text-transform: none;
}
.checkbox-field a,
.form-note a,
.legal-links a {
text-decoration: underline;
text-underline-offset: 0.18em;
}
.honeypot-field {
position: absolute;
left: -10000px;
width: 1px;
height: 1px;
overflow: hidden;
}
.honeypot-field input {
position: absolute;
left: -10000px;
}
.hero__slogan {
margin: 0.55rem 0 0;
font-family: var(--font-display);
font-size: clamp(1.35rem, 2.3vw, 1.95rem);
line-height: 1.15;
color: var(--color-text-strong);
}
.text-link {
display: inline-flex;
width: fit-content;
border-bottom: 1px solid currentColor;
font-size: 0.78rem;
font-weight: 800;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.text-link:hover,
.text-link:focus-visible {
color: var(--color-muted);
}
.service-card__link {
margin-top: 1rem;
}
.seo-section {
background: var(--color-footer);
border-block: 1px solid rgba(0, 0, 0, 0.06);
}
.seo-grid {
display: grid;
grid-template-columns: minmax(0, 1.35fr) minmax(18rem, 0.65fr);
gap: clamp(2rem, 5vw, 4rem);
align-items: start;
}
.seo-actions {
display: flex;
flex-wrap: wrap;
gap: 0.85rem;
margin-top: 1.5rem;
}
.local-link-card,
.faq-item,
.content-card {
border: 1px solid var(--color-line);
background: var(--color-white);
padding: clamp(1.25rem, 3vw, 2rem);
}
.local-link-grid,
.check-list,
.faq-list {
display: grid;
gap: 0.8rem;
margin: 1rem 0 0;
padding: 0;
list-style: none;
}
.local-link-grid a,
.faq-list a {
display: inline-flex;
border-bottom: 1px solid currentColor;
font-weight: 700;
}
.faq-grid {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 1rem;
}
.faq-item p,
.content-card p {
color: var(--color-text-soft);
}
.page-hero {
padding-block: clamp(3rem, 7vw, 6rem);
border-bottom: 1px solid rgba(0, 0, 0, 0.07);
background: var(--color-footer);
}
.page-hero__inner {
max-width: 880px;
}
.breadcrumb {
margin: 0 0 1rem;
color: var(--color-muted);
font-size: 0.78rem;
font-weight: 700;
letter-spacing: 0.08em;
text-transform: uppercase;
}
.breadcrumb a {
border-bottom: 1px solid currentColor;
}
.page-intro {
max-width: 780px;
margin-top: 1rem;
color: var(--color-text-soft);
font-size: clamp(1rem, 2vw, 1.2rem);
}
.content-grid {
display: grid;
grid-template-columns: minmax(0, 1fr) minmax(18rem, 0.42fr);
gap: clamp(1.5rem, 5vw, 3rem);
align-items: start;
}
.content-card + .content-card {
margin-top: 1rem;
}
.service-nav-list {
display: grid;
gap: 0.75rem;
margin: 1rem 0 0;
padding: 0;
list-style: none;
}
.service-nav-list a {
font-weight: 700;
border-bottom: 1px solid currentColor;
}
@media (max-width: 860px) {
.seo-grid,
.content-grid,
.faq-grid {
grid-template-columns: 1fr;
}
}
.hero .heading--xl {
max-width: 13ch;
font-size: clamp(2.75rem, 4.85vw, 4.25rem);
line-height: 1.04;
}
.hero__slogan {
max-width: 28rem;
font-size: clamp(1.08rem, 1.45vw, 1.35rem);
line-height: 1.25;
}
.hero__copy {
max-width: 31rem;
}
.hero__image {
display: block;
width: 100%;
height: clamp(31rem, 42vw, 40rem) !important;
min-height: 0 !important;
max-height: none !important;
aspect-ratio: auto !important;
object-fit: cover;
object-position: center;
filter: none !important;
transform: none !important;
}
.service-card__image {
display: block;
width: 100%;
height: clamp(9.8rem, 11vw, 11.5rem) !important;
min-height: 0 !important;
max-height: none !important;
aspect-ratio: auto !important;
object-fit: cover;
object-position: center;
filter: none !important;
transform: none !important;
}
@media (min-width: 1280px) {
.hero .heading--xl {
font-size: clamp(3.1rem, 4.15vw, 4.35rem);
}
}
@media (max-width: 860px) {
.hero .heading--xl {
max-width: 12.5ch;
font-size: clamp(2.1rem, 8.6vw, 2.85rem);
line-height: 1.05;
}
.hero__slogan {
max-width: 22rem;
font-size: clamp(1rem, 4.2vw, 1.22rem);
}
.hero__copy {
max-width: 34rem;
font-size: 1rem;
}
.hero__image {
height: clamp(20rem, 64vw, 28rem) !important;
object-position: center;
}
.service-card__image {
height: clamp(14.5rem, 62vw, 22rem) !important;
object-position: center;
}
}
@media (max-width: 420px) {
.hero .heading--xl {
max-width: 11.8ch;
font-size: clamp(2rem, 8.8vw, 2.45rem);
}
.hero__image {
height: clamp(18.5rem, 72vw, 23rem) !important;
}
}
.content-card__image {
display: block;
width: 100%;
height: auto;
max-width: 100%;
border: 0;
object-fit: cover;
object-position: center;
filter: none !important;
transform: none !important;
image-rendering: auto;
background: var(--color-surface);
}
.content-card > .content-card__image:first-child {
margin: calc(clamp(1.25rem, 3vw, 2rem) * -1) calc(clamp(1.25rem, 3vw, 2rem) * -1) 1.5rem;
width: calc(100% + (clamp(1.25rem, 3vw, 2rem) * 2));
max-width: none;
}
.content-card > .content-card__image:first-child + .heading {
margin-top: 0 !important;
}
@media (max-width: 860px) {
.content-card > .content-card__image:first-child {
margin-inline: calc(clamp(1.25rem, 3vw, 2rem) * -1);
width: calc(100% + (clamp(1.25rem, 3vw, 2rem) * 2));
}
}
.service-card__link {
margin-top: auto;
padding-top: 1rem;
}
.service-card__arrow {
margin-top: 0.35rem;
padding-top: 0;
}
.service-card__image,
.content-card__image {
image-rendering: auto;
filter: none !important;
transform: none !important;
}
.content-card > .content-card__image:first-child {
aspect-ratio: 16 / 10;
height: auto !important;
object-fit: cover;
object-position: center;
}
.service-card__image,
.content-card__image {
image-rendering: auto;
filter: none !important;
transform: none !important;
background: var(--color-surface);
}
.service-card__image {
aspect-ratio: 16 / 10;
height: auto !important;
object-fit: cover;
object-position: center;
}
.content-card > .content-card__image:first-child {
aspect-ratio: 16 / 10;
width: 100%;
height: auto !important;
object-fit: cover;
object-position: center;
}
@media (max-width: 860px) {
.service-card__image,
.content-card > .content-card__image:first-child {
aspect-ratio: 4 / 3;
height: auto !important;
object-fit: cover;
object-position: center;
}
}
.pricing-note {
max-width: 48rem;
margin: 1rem auto 0;
color: var(--color-muted);
font-size: 0.88rem;
line-height: 1.6;
text-align: center;
}
.form-help {
margin: -0.2rem 0 0;
color: var(--color-muted);
font-size: 0.78rem;
line-height: 1.45;
text-transform: none;
letter-spacing: normal;
}
.u-mt-md { margin-top: 1rem; }
.u-mt-lg { margin-top: 1.5rem; }
.u-copy-left {
color: var(--color-text-soft);
margin-inline: 0;
}
.header-actions .button,
.mobile-cta-bar__link,
.hero__actions .button,
.price-card__cta .button,
.final-cta .button {
text-align: center;
}
.features-grid,
.pricing-grid,
.faq-grid {
align-items: stretch;
}
.feature,
.price-card,
.faq-item,
.content-card,
.local-link-card {
height: 100%;
}
.price-card {
display: flex;
flex-direction: column;
}
.price-card__cta {
margin-top: auto;
}
.checkbox-field {
align-items: flex-start;
}
.checkbox-field label {
padding-top: 0.05rem;
}
@media (max-width: 640px) {
.pricing-note { text-align: left; }
.header-actions { gap: 0.85rem; }
}
.pricing-grid {
max-width: 1080px;
margin-inline: auto;
}
.price-card {
min-height: 12.25rem;
padding: 1.45rem 1.1rem;
}
.price-card__amount,
.price-card__quote {
font-size: clamp(2.25rem, 3.35vw, 2.85rem);
}
.price-card__copy {
font-size: 0.9rem;
}
.price-card__cta .button {
min-height: 2.7rem;
padding-inline: 1.25rem;
}
.contact-section .contact-grid {
align-items: center;
}
.contact-section .heading--lg {
font-size: clamp(2.15rem, 4vw, 3.35rem);
line-height: 1.08;
}
.contact-section .final-cta__copy.u-copy-left,
.booking-quote-copy .final-cta__copy {
max-width: 33rem;
margin: 0.85rem 0 1.25rem;
color: var(--color-text-soft);
font-size: 0.98rem;
line-height: 1.65;
}
.contact-section .contact-form {
width: 100%;
max-width: 640px;
justify-self: end;
gap: 0.78rem;
padding: clamp(1rem, 2vw, 1.45rem);
}
.contact-section .form-row {
gap: 0.78rem;
}
.contact-section .field {
gap: 0.34rem;
}
.contact-section .field label {
font-size: 0.7rem;
letter-spacing: 0.085em;
}
.contact-section .field input,
.contact-section .field select,
.contact-section .field textarea {
padding: 0.68rem 0.78rem;
font-size: 0.95rem;
}
.contact-section .field textarea {
min-height: 5.8rem;
}
.contact-section .form-help,
.contact-section .form-note {
font-size: 0.76rem;
line-height: 1.45;
}
.contact-section .checkbox-field {
display: grid;
grid-template-columns: auto minmax(0, 1fr);
gap: 0.62rem;
align-items: start;
}
.contact-section .checkbox-field input {
margin-top: 0.2rem;
}
.contact-section .checkbox-field label {
font-size: 0.76rem;
line-height: 1.5;
}
.contact-section .contact-form .button {
min-height: 2.85rem;
justify-self: start;
padding-inline: 1.35rem;
}
.final-cta--compact,
.final-cta {
padding-block: clamp(2rem, 4vw, 3.25rem);
}
.final-cta .heading--lg {
font-size: clamp(2rem, 4vw, 3.25rem);
}
.final-cta__copy {
margin: 0.75rem auto 1.25rem;
font-size: 0.98rem;
}
.final-cta .button {
min-height: 2.8rem;
}
.booking-page-hero {
background: var(--color-footer);
padding-block: clamp(2.4rem, 5vw, 4.4rem);
}
.booking-page-hero__inner {
max-width: 760px;
}
.booking-page-hero .heading--xl {
max-width: 690px;
font-size: clamp(2.35rem, 4.9vw, 4rem);
line-height: 1.07;
}
.booking-page-hero .page-intro {
max-width: 620px;
font-size: clamp(0.98rem, 1.35vw, 1.08rem);
line-height: 1.7;
}
.booking-quote-section {
background: var(--color-surface);
}
.booking-quote-grid {
grid-template-columns: minmax(0, 0.82fr) minmax(22rem, 1fr);
gap: clamp(1.5rem, 4vw, 3.25rem);
}
.booking-quote-copy {
align-self: start;
}
.booking-process-list li {
border-top: 1px solid var(--color-line);
padding-top: 0.72rem;
}
.quote-contact-card {
margin-top: 1.25rem;
border: 1px solid var(--color-line);
background: var(--color-white);
padding: 1rem;
}
.quote-contact-card p {
margin: 0.35rem 0 0;
color: var(--color-text-soft);
font-size: 0.92rem;
}
.quote-contact-card .eyebrow {
margin: 0 0 0.45rem;
color: var(--color-black);
}
.booking-form-card--light {
border: 1px solid var(--color-line);
background: var(--color-white);
padding: clamp(1rem, 2vw, 1.45rem);
}
.booking-form-card--light .heading--lg {
font-size: clamp(1.8rem, 3vw, 2.55rem);
}
.quote-form-intro {
margin: 0.65rem 0 1rem;
color: var(--color-text-soft);
font-size: 0.94rem;
line-height: 1.6;
}
.booking-form-card--light .contact-form {
border: 0;
background: transparent;
padding: 0;
}
@media (max-width: 980px) {
.booking-quote-grid {
grid-template-columns: 1fr;
}
.contact-section .contact-form {
max-width: none;
justify-self: stretch;
}
}
@media (max-width: 860px) {
.price-card {
min-height: 0;
}
}
@media (max-width: 640px) {
.contact-section .contact-form .button {
justify-self: stretch;
width: 100%;
}
.contact-section .checkbox-field label {
font-size: 0.72rem;
}
}
.hero__slogan {
display: flex;
width: min(100%, 30rem);
align-items: center;
gap: 0.85rem;
margin: 1.15rem 0 1.35rem;
color: var(--color-text-strong);
font-family: var(--font-body);
font-size: clamp(0.76rem, 1vw, 0.88rem);
font-weight: 700;
letter-spacing: 0.13em;
line-height: 1.4;
text-transform: uppercase;
white-space: nowrap;
}
.hero__slogan::before,
.hero__slogan::after {
content: "";
height: 1px;
flex: 1;
background: var(--color-black);
}
.hero__copy {
margin-bottom: 1.65rem;
}
@media (max-width: 420px) {
.hero__slogan {
gap: 0.55rem;
font-size: 0.68rem;
letter-spacing: 0.09em;
}
.booking-quote-grid > *,
.booking-quote-copy,
.booking-form-card,
.content-grid > *,
.content-card {
min-width: 0;
width: 100%;
}
.page-hero .heading--xl {
overflow-wrap: anywhere;
word-break: normal;
}
}
.hero .heading--xl {
max-width: 16ch;
font-size: clamp(2.35rem, 3.65vw, 3.55rem);
line-height: 1.08;
}
@media (min-width: 1280px) {
.hero .heading--xl {
font-size: clamp(2.75rem, 3.45vw, 3.75rem);
}
}
@media (max-width: 860px) {
.hero .heading--xl {
max-width: 14.5ch;
font-size: clamp(1.95rem, 7.25vw, 2.45rem);
line-height: 1.08;
}
}
@media (max-width: 420px) {
.hero .heading--xl {
max-width: 14ch;
font-size: clamp(1.85rem, 7.8vw, 2.18rem);
}
}
#about .difference,
#about .features-grid {
align-items: center;
}
#about .feature {
justify-content: center;
}
#about .difference__intro {
align-self: center;
}
.local-areas__inner {
display: flex;
flex-direction: column;
align-items: center;
text-align: center;
}
.local-areas__header {
max-width: 760px;
margin-inline: auto;
}
.local-areas__header .text-muted {
max-width: 700px;
margin-inline: auto;
}
.local-areas__button-row {
justify-content: center;
gap: 0.75rem;
margin-top: clamp(1.15rem, 2.8vw, 1.7rem);
}
.local-areas__button {
min-height: 2.8rem;
min-width: min(100%, 12.75rem);
padding-inline: 1.25rem;
letter-spacing: 0.08em;
}
.local-areas__button--primary {
background: var(--color-black);
color: var(--color-white);
}
.local-areas__button--secondary {
background: var(--color-white);
color: var(--color-black);
}
.local-areas__links {
width: 100%;
max-width: 900px;
margin-top: clamp(1.55rem, 4vw, 2.6rem);
padding-top: clamp(1rem, 3vw, 1.35rem);
border-top: 1px solid var(--color-line);
}
.local-areas__links-title {
margin: 0;
font-family: var(--font-serif);
font-size: clamp(1.15rem, 2vw, 1.45rem);
font-weight: 600;
}
.local-areas__links .local-link-grid {
grid-template-columns: repeat(5, minmax(0, 1fr));
gap: 0.75rem;
margin-top: 1rem;
}
.local-areas__links .local-link-grid a {
display: flex;
min-height: 3.05rem;
align-items: center;
justify-content: space-between;
gap: 0.75rem;
width: 100%;
border: 1px solid var(--color-line);
padding: 0.72rem 0.85rem;
background: var(--color-white);
color: var(--color-black);
font-size: 0.72rem;
font-weight: 800;
letter-spacing: 0.08em;
line-height: 1.2;
text-align: left;
text-decoration: none;
text-transform: uppercase;
transition: background-color 180ms ease, border-color 180ms ease, color 180ms ease, transform 180ms ease;
}
.local-areas__links .local-link-grid a:hover,
.local-areas__links .local-link-grid a:focus-visible {
border-color: var(--color-black);
background: var(--color-black);
color: var(--color-white);
transform: translateY(-2px);
}
.local-area-arrow {
flex: 0 0 auto;
font-size: 0.9rem;
line-height: 1;
}
@media (max-width: 980px) {
.local-areas__links .local-link-grid {
grid-template-columns: repeat(2, minmax(0, 1fr));
}
}
@media (max-width: 560px) {
.local-areas__button-row {
display: flex;
flex-wrap: nowrap;
width: 100%;
max-width: 25rem;
gap: 0.55rem;
}
.local-areas__button {
flex: 1 1 0;
min-width: 0;
padding-inline: 0.7rem;
font-size: 0.65rem;
white-space: nowrap;
}
.local-areas__links .local-link-grid {
grid-template-columns: 1fr;
}
}
.local-areas .local-areas__actions.local-areas__button-row {
display: grid;
grid-template-columns: repeat(2, minmax(0, 13rem));
justify-content: center;
align-items: stretch;
width: min(100%, 28rem);
margin-inline: auto;
gap: 0.75rem;
}
.local-areas .local-areas__actions.local-areas__button-row .local-areas__button {
width: 100%;
min-width: 0;
margin: 0;
}
@media (max-width: 380px) {
.local-areas .local-areas__actions.local-areas__button-row {
gap: 0.45rem;
}
.local-areas .local-areas__actions.local-areas__button-row .local-areas__button {
padding-inline: 0.45rem;
font-size: 0.58rem;
letter-spacing: 0.06em;
}
}
