:root {
  --pine-950: #09261d;
  --pine-900: #103328;
  --pine-800: #174535;
  --pine-700: #1d5b43;
  --cream: #f4f0e6;
  --paper: #fbfaf6;
  --ink: #16201c;
  --muted: #68726d;
  --line: #d8ddd5;
  --orange: #e96f25;
  --orange-dark: #cf5814;
  --white: #fff;
  --shadow: 0 24px 60px rgba(8, 29, 22, .16);
  --radius: 4px;
  --container: min(1180px, calc(100% - 40px));
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: 92px; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: Inter, ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif; line-height: 1.6; -webkit-font-smoothing: antialiased; }
img { display: block; max-width: 100%; }
a { color: inherit; }
button, input, select, textarea { font: inherit; }
button, a { -webkit-tap-highlight-color: transparent; }
.container { width: var(--container); margin-inline: auto; }
.skip-link { position: fixed; top: 10px; left: 10px; z-index: 200; padding: 10px 14px; color: #fff; background: var(--orange); transform: translateY(-150%); }
.skip-link:focus { transform: translateY(0); }

.topbar { color: #dbe9e2; background: var(--pine-950); font-size: .77rem; letter-spacing: .09em; text-transform: uppercase; }
.topbar-inner { height: 36px; display: flex; align-items: center; justify-content: space-between; }
.topbar p { margin: 0; display: flex; gap: 9px; align-items: center; }
.topbar a { color: #fff; font-weight: 800; text-decoration: none; }
.pulse-dot { width: 7px; height: 7px; border-radius: 50%; background: #70c287; box-shadow: 0 0 0 0 rgba(112,194,135,.7); animation: pulse 2s infinite; }

.site-header { position: sticky; top: 0; z-index: 100; background: rgba(251,250,246,.94); border-bottom: 1px solid rgba(16,51,40,.11); backdrop-filter: blur(12px); }
.nav-wrap { min-height: 76px; display: flex; align-items: center; justify-content: space-between; }
.brand { display: inline-flex; align-items: center; text-decoration: none; color: var(--pine-900); }
.brand-logo { display: block; width: 220px; height: 62px; object-fit: contain; }
.site-header .brand-logo { mix-blend-mode: multiply; }
.primary-nav { display: flex; align-items: center; gap: 31px; }
.primary-nav > a:not(.button) { position: relative; text-decoration: none; font-size: .86rem; font-weight: 800; }
.primary-nav > a:not(.button)::after { content: ""; position: absolute; right: 0; bottom: -7px; left: 0; height: 2px; background: var(--orange); transform: scaleX(0); transform-origin: left; transition: transform .22s ease; }
.primary-nav > a:hover::after, .primary-nav > a:focus-visible::after { transform: scaleX(1); }
.nav-toggle { display: none; border: 0; background: transparent; width: 44px; height: 44px; padding: 10px; }
.nav-toggle span { display: block; width: 24px; height: 2px; margin: 5px auto; background: var(--pine-900); transition: .2s ease; }

.button { min-height: 50px; display: inline-flex; align-items: center; justify-content: center; gap: 9px; padding: 14px 22px; border: 0; border-radius: var(--radius); font-size: .88rem; font-weight: 900; letter-spacing: .02em; text-decoration: none; cursor: pointer; transition: transform .2s ease, background .2s ease, box-shadow .2s ease; }
.button:hover { transform: translateY(-2px); }
.button:focus-visible, a:focus-visible, summary:focus-visible, input:focus-visible, select:focus-visible, textarea:focus-visible { outline: 3px solid rgba(233,111,37,.4); outline-offset: 3px; }
.button-small { min-height: 43px; padding: 10px 18px; color: #fff; background: var(--pine-900); }
.button-primary { color: #fff; background: var(--orange); box-shadow: 0 10px 24px rgba(233,111,37,.2); }
.button-primary:hover { background: var(--orange-dark); box-shadow: 0 14px 30px rgba(233,111,37,.26); }
.button-dark { color: #fff; background: var(--pine-900); }
.button-dark:hover { background: var(--pine-700); }
.button-outline { color: #fff; border: 1px solid rgba(255,255,255,.42); background: transparent; }
.button-outline:hover { border-color: #fff; background: rgba(255,255,255,.08); }
.button-block { width: 100%; }

.hero { position: relative; min-height: 730px; overflow: hidden; color: #fff; background: var(--pine-950); }
.hero-image, .hero-shade { position: absolute; inset: 0; width: 100%; height: 100%; }
.hero-image { object-fit: cover; object-position: center; }
.hero-shade { background: linear-gradient(90deg, rgba(5,28,20,.96) 0%, rgba(5,28,20,.82) 36%, rgba(5,28,20,.4) 63%, rgba(5,28,20,.15) 100%), linear-gradient(0deg, rgba(6,28,21,.5), transparent 50%); }
.hero-layout { position: relative; z-index: 2; min-height: 730px; display: grid; grid-template-columns: minmax(0, 1.12fr) minmax(340px, .68fr); align-items: center; gap: clamp(50px, 8vw, 110px); padding-block: 70px; }
.eyebrow { margin: 0 0 18px; display: flex; align-items: center; gap: 11px; color: var(--orange); font-size: .72rem; font-weight: 900; letter-spacing: .16em; text-transform: uppercase; }
.eyebrow > span { width: 29px; height: 2px; background: currentColor; }
.eyebrow.light { color: #f1a06e; }
.hero h1, .section h2, .work-copy h2, .final-cta h2 { margin: 0; font-family: "Arial Narrow", "Roboto Condensed", Impact, sans-serif; font-weight: 900; letter-spacing: -.045em; line-height: .91; text-transform: uppercase; }
.hero h1 { max-width: 720px; font-size: clamp(4rem, 7.2vw, 6.9rem); }
h1 em, h2 em { color: var(--orange); font-style: normal; }
.hero-lede { max-width: 620px; margin: 27px 0 0; color: #e4ebe7; font-size: clamp(1rem, 1.35vw, 1.18rem); line-height: 1.65; }
.hero-actions { margin-top: 30px; display: flex; align-items: center; gap: 28px; }
.hero-actions svg, .mobile-action-bar svg { width: 19px; fill: currentColor; }
.text-link { display: inline-flex; align-items: center; gap: 11px; font-size: .9rem; font-weight: 900; text-decoration: none; }
.text-link span { color: var(--orange); transition: transform .2s ease; }
.text-link:hover span { transform: translate(3px, 3px); }
.light-link { color: #fff; }
.hero-proof { margin: 29px 0 0; padding: 0; display: flex; flex-wrap: wrap; gap: 11px 24px; list-style: none; color: #d2dfd9; font-size: .8rem; font-weight: 750; }
.hero-proof span { margin-right: 6px; color: #8ac79b; }

.lead-card { width: 100%; max-width: 430px; justify-self: end; padding: 30px; color: var(--ink); background: rgba(251,250,246,.97); border-top: 5px solid var(--orange); border-radius: var(--radius); box-shadow: 0 28px 80px rgba(0,0,0,.3); }
.lead-card-head { margin-bottom: 20px; }
.micro-label { margin: 0 0 6px; color: var(--orange-dark); font-size: .68rem; font-weight: 900; letter-spacing: .12em; text-transform: uppercase; }
.lead-card h2 { margin: 0; font-family: "Arial Narrow", Impact, sans-serif; font-size: 2rem; line-height: 1.05; letter-spacing: -.02em; text-transform: uppercase; }
.lead-card-head > p:last-child { margin: 10px 0 0; color: var(--muted); font-size: .8rem; line-height: 1.5; }
.lead-card form { display: grid; gap: 14px; }
.field-row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
.lead-card label { display: grid; gap: 6px; color: #38433e; font-size: .7rem; font-weight: 850; letter-spacing: .035em; }
.lead-card input, .lead-card select, .lead-card textarea { width: 100%; min-width: 0; border: 1px solid #ccd3cd; border-radius: 2px; padding: 11px 12px; color: var(--ink); background: #fff; font-size: .84rem; font-weight: 500; outline: none; }
.lead-card input, .lead-card select { height: 45px; }
.lead-card textarea { resize: vertical; }
.lead-card input:focus, .lead-card select:focus, .lead-card textarea:focus { border-color: var(--pine-700); box-shadow: 0 0 0 3px rgba(29,91,67,.1); }
.form-note { margin: -2px 0 0; display: flex; align-items: center; justify-content: center; gap: 7px; color: #7b837f; font-size: .67rem; line-height: 1.35; text-align: center; }
.form-note svg { width: 14px; flex: 0 0 auto; fill: none; stroke: currentColor; stroke-width: 1.8; }

.proof-band { color: #fff; background: var(--orange); }
.proof-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.proof-grid > div { min-height: 102px; display: flex; flex-direction: column; justify-content: center; padding: 22px 28px; border-left: 1px solid rgba(255,255,255,.25); }
.proof-grid > div:last-child { border-right: 1px solid rgba(255,255,255,.25); }
.proof-grid strong { font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.55rem; letter-spacing: -.01em; line-height: 1; text-transform: uppercase; }
.proof-grid span { margin-top: 7px; color: #ffe3d1; font-size: .72rem; font-weight: 700; }

.section { padding-block: 112px; }
.services { background: var(--paper); }
.section-heading { margin-bottom: 48px; }
.section-heading h2 { font-size: clamp(3.05rem, 5.4vw, 5.25rem); }
.split-heading { display: grid; grid-template-columns: 1.05fr .8fr; align-items: end; gap: 80px; }
.split-heading > p { max-width: 510px; margin: 0 0 8px; color: var(--muted); font-size: 1rem; line-height: 1.75; }
.centered { max-width: 750px; margin-inline: auto; text-align: center; }
.centered .eyebrow { justify-content: center; }

.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); border-top: 1px solid var(--line); border-left: 1px solid var(--line); }
.service-card { position: relative; min-height: 400px; display: flex; flex-direction: column; padding: 33px 27px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); background: #fff; overflow: hidden; transition: transform .25s ease, box-shadow .25s ease; }
.service-card:hover { z-index: 2; transform: translateY(-6px); box-shadow: var(--shadow); }
.service-card.featured { color: #fff; background: var(--pine-900); }
.service-number { color: #a2aaa6; font-size: .65rem; font-weight: 900; letter-spacing: .15em; }
.featured .service-number { color: #83a395; }
.service-icon { width: 58px; height: 58px; margin: 48px 0 25px; display: grid; place-items: center; color: var(--orange); }
.service-icon svg { width: 100%; fill: none; stroke: currentColor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }
.service-card h3 { margin: 0; font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.75rem; line-height: 1; letter-spacing: -.015em; text-transform: uppercase; }
.service-card p { margin: 16px 0 27px; color: var(--muted); font-size: .85rem; line-height: 1.7; }
.featured p { color: #bad0c6; }
.service-card a { margin-top: auto; display: flex; justify-content: space-between; padding-top: 18px; border-top: 1px solid var(--line); font-size: .74rem; font-weight: 900; text-decoration: none; text-transform: uppercase; letter-spacing: .04em; }
.featured a { border-color: rgba(255,255,255,.16); }
.service-card a span { color: var(--orange); }

.story { color: #fff; background: var(--cream); }
.story-grid { display: grid; grid-template-columns: .85fr 1.15fr; min-height: 720px; }
.story-visual { position: relative; min-height: 720px; }
.story-visual > img { width: 100%; height: 100%; object-fit: cover; }
.story-stamp { position: absolute; right: -53px; bottom: 52px; width: 126px; height: 126px; display: grid; place-content: center; color: #fff; background: var(--orange); border: 4px solid #fff; border-radius: 50%; text-align: center; transform: rotate(-8deg); box-shadow: 0 10px 30px rgba(0,0,0,.18); }
.story-stamp::before { content: ""; position: absolute; inset: 7px; border: 1px solid rgba(255,255,255,.5); border-radius: inherit; }
.story-stamp strong { font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.45rem; line-height: 1; }
.story-stamp span { font-size: .55rem; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; }
.story-copy { display: flex; flex-direction: column; justify-content: center; padding: clamp(55px, 7vw, 105px); color: #fff; background: var(--pine-900); }
.story-copy h2 { font-size: clamp(3.1rem, 5vw, 5rem); }
.story-lede { margin: 27px 0 0; color: #c7d8d0; font-size: 1rem; line-height: 1.75; }
.value-list { margin: 30px 0 32px; }
.value-list > div { display: grid; grid-template-columns: 40px 1fr; gap: 15px; padding: 20px 0; border-top: 1px solid rgba(255,255,255,.14); }
.value-list > div:last-child { border-bottom: 1px solid rgba(255,255,255,.14); }
.value-index { color: var(--orange); font-size: .64rem; font-weight: 900; }
.value-list h3 { margin: 0 0 5px; font-size: .88rem; }
.value-list p { margin: 0; color: #a9c1b6; font-size: .78rem; line-height: 1.55; }
.story-copy .button { align-self: flex-start; color: var(--pine-950); background: #fff; }

.process { background: var(--paper); }
.process-grid { margin: 68px 0 0; padding: 0; display: grid; grid-template-columns: repeat(3, 1fr); list-style: none; counter-reset: process; }
.process-grid li { position: relative; min-height: 220px; padding: 0 55px 0 38px; border-left: 1px solid var(--line); }
.process-grid li:last-child { border-right: 1px solid var(--line); }
.step-number { width: 47px; height: 47px; display: grid; place-items: center; color: #fff; background: var(--orange); border-radius: 50%; font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.35rem; }
.process-grid h3 { margin: 28px 0 10px; font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.75rem; line-height: 1; text-transform: uppercase; }
.process-grid p { max-width: 270px; margin: 0; color: var(--muted); font-size: .86rem; }
.process-grid li:not(:last-child)::after { content: "→"; position: absolute; top: 7px; right: 24px; color: #a8b0ac; font-size: 1.4rem; }

.work-feature { display: grid; grid-template-columns: 1.14fr .86fr; min-height: 640px; color: #fff; background: var(--pine-950); }
.work-image img { width: 100%; height: 100%; object-fit: cover; }
.work-copy { display: flex; flex-direction: column; align-items: flex-start; justify-content: center; padding: clamp(55px, 7vw, 105px); }
.work-copy h2 { font-size: clamp(3.1rem, 5vw, 5rem); }
.work-copy > p:not(.eyebrow) { margin: 28px 0; color: #b8cbc2; line-height: 1.75; }
.work-copy ul { margin: 0 0 34px; padding: 0; display: grid; gap: 10px; list-style: none; color: #e1eae6; font-size: .85rem; font-weight: 800; }
.work-copy li span { margin-right: 9px; color: #87c89a; }

.reviews { background: var(--cream); }
.review-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid #d7d2c7; border-left: 1px solid #d7d2c7; }
.review-card { min-height: 345px; margin: 0; display: flex; flex-direction: column; padding: 33px; border-right: 1px solid #d7d2c7; border-bottom: 1px solid #d7d2c7; background: var(--paper); }
.review-card.dark { color: #fff; background: var(--pine-900); }
.review-card.orange { color: #fff; background: var(--orange); }
.quote-mark { height: 48px; color: var(--orange); font-family: Georgia, serif; font-size: 4rem; line-height: .9; }
.orange .quote-mark { color: #fff; }
.review-card blockquote { margin: 20px 0 32px; font-family: Georgia, serif; font-size: 1.03rem; line-height: 1.7; }
.review-card figcaption { margin-top: auto; display: flex; align-items: center; gap: 12px; }
.avatar { width: 38px; height: 38px; display: grid; place-items: center; color: #fff; background: var(--pine-700); border-radius: 50%; font-size: .67rem; font-weight: 900; }
.dark .avatar { color: var(--pine-900); background: var(--cream); }
.orange .avatar { color: var(--orange); background: #fff; }
.review-card figcaption div { display: grid; }
.review-card figcaption strong { font-size: .78rem; }
.review-card figcaption small { color: #828a86; font-size: .65rem; }
.dark figcaption small, .orange figcaption small { color: rgba(255,255,255,.7); }
.google-review { margin-top: 3px; display: inline-flex; align-items: center; gap: 5px; }
.google-review svg { width: 13px; height: 13px; flex: 0 0 auto; }

.areas { position: relative; overflow: hidden; color: #fff; background: var(--pine-800); }
.areas::before { content: ""; position: absolute; inset: 0; opacity: .08; background-image: radial-gradient(#fff 1px, transparent 1px); background-size: 19px 19px; }
.areas-grid { position: relative; display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 65px; }
.areas-copy h2 { font-size: clamp(3rem, 5vw, 5rem); }
.areas-copy > p:not(.eyebrow) { max-width: 470px; margin: 27px 0; color: #bed1c8; }
.areas-map { min-height: 330px; display: grid; place-items: center; }
.areas-map svg { width: 100%; overflow: visible; }
.map-road { fill: none; stroke: rgba(255,255,255,.18); stroke-width: 9; }
.map-road.thin { stroke-width: 3; stroke-dasharray: 8 8; }
.map-river { fill: none; stroke: rgba(100,174,192,.33); stroke-width: 18; }
.map-pulse { fill: rgba(233,111,37,.18); stroke: rgba(233,111,37,.45); stroke-width: 2; }
.map-pin { fill: var(--orange); }
.areas-map text { fill: #fff; font-family: "Arial Narrow", Impact, sans-serif; font-size: 18px; font-weight: 900; letter-spacing: .06em; }
.areas-map .map-state { fill: #a9c6b9; font-family: inherit; font-size: 8px; letter-spacing: .2em; }

.faq { background: var(--paper); }
.faq-grid { display: grid; grid-template-columns: .65fr 1.35fr; gap: 110px; }
.faq-intro h2 { font-size: clamp(3rem, 4.8vw, 4.8rem); }
.faq-intro > p:not(.eyebrow) { margin: 26px 0 30px; color: var(--muted); }
.faq-list { border-top: 1px solid var(--line); }
.faq-list details { border-bottom: 1px solid var(--line); }
.faq-list summary { position: relative; padding: 24px 48px 24px 0; cursor: pointer; font-family: "Arial Narrow", Impact, sans-serif; font-size: 1.35rem; font-weight: 900; line-height: 1.2; text-transform: uppercase; list-style: none; }
.faq-list summary::-webkit-details-marker { display: none; }
.faq-list summary span { position: absolute; right: 8px; color: var(--orange); font-family: sans-serif; font-size: 1.5rem; font-weight: 400; transition: transform .2s ease; }
.faq-list details[open] summary span { transform: rotate(45deg); }
.faq-list details p { margin: -6px 55px 25px 0; color: var(--muted); font-size: .9rem; line-height: 1.75; }
.faq-list details p a { color: var(--pine-700); font-weight: 900; }

.final-cta { position: relative; padding-block: 110px; overflow: hidden; color: #fff; background: var(--pine-950); }
.tree-rings { position: absolute; width: 620px; height: 620px; right: -100px; top: -130px; border: 1px solid rgba(255,255,255,.08); border-radius: 50%; }
.tree-rings::before, .tree-rings::after { content: ""; position: absolute; border: 1px solid rgba(255,255,255,.08); border-radius: 48% 52% 51% 49%; }
.tree-rings::before { inset: 70px; }
.tree-rings::after { inset: 155px; }
.final-cta-inner { position: relative; z-index: 1; text-align: center; }
.final-cta .eyebrow { justify-content: center; }
.final-cta h2 { font-size: clamp(3.8rem, 7.5vw, 7rem); }
.final-cta p:not(.eyebrow) { max-width: 630px; margin: 28px auto 32px; color: #b9cdc4; }
.cta-actions { display: flex; justify-content: center; gap: 12px; }

.site-footer { color: #b8c7c1; background: #061a14; }
.footer-main { display: grid; grid-template-columns: 1.7fr 1fr 1fr; gap: 70px; padding-block: 70px; }
.light-brand { width: fit-content; padding: 4px 9px; background: #fff; border-radius: 3px; }
.light-brand .brand-logo { width: 245px; height: 82px; }
.footer-brand p { max-width: 360px; margin: 20px 0 0; color: #8aa098; font-size: .82rem; }
.footer-main h3 { margin: 0 0 18px; color: #fff; font-size: .72rem; letter-spacing: .13em; text-transform: uppercase; }
.footer-main > div:not(.footer-brand) { display: flex; flex-direction: column; align-items: flex-start; gap: 9px; }
.footer-main > div:not(.footer-brand) a, .footer-main > div:not(.footer-brand) p { margin: 0; color: #95aaa1; font-size: .8rem; text-decoration: none; }
.footer-main a:hover { color: #fff; }
.footer-bottom { min-height: 68px; display: flex; align-items: center; justify-content: space-between; border-top: 1px solid rgba(255,255,255,.1); color: #71877e; font-size: .7rem; }
.footer-bottom a { text-decoration: none; }
.mobile-action-bar { display: none; }
.toast { position: fixed; right: 22px; bottom: 22px; z-index: 300; max-width: 360px; padding: 14px 18px; color: #fff; background: var(--pine-900); border-left: 4px solid var(--orange); border-radius: 3px; box-shadow: var(--shadow); font-size: .82rem; font-weight: 700; opacity: 0; pointer-events: none; transform: translateY(15px); transition: .25s ease; }
.toast.show { opacity: 1; transform: translateY(0); }

.reveal { opacity: 0; transform: translateY(20px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: translateY(0); }
.delay-1 { transition-delay: .1s; }
.delay-2 { transition-delay: .2s; }
.delay-3 { transition-delay: .3s; }

@keyframes pulse { 70% { box-shadow: 0 0 0 7px rgba(112,194,135,0); } 100% { box-shadow: 0 0 0 0 rgba(112,194,135,0); } }

@media (max-width: 1020px) {
  .primary-nav { gap: 20px; }
  .hero-layout { grid-template-columns: 1fr 390px; gap: 45px; }
  .service-grid { grid-template-columns: repeat(2, 1fr); }
  .service-card { min-height: 370px; }
  .story-grid { grid-template-columns: .8fr 1.2fr; }
  .story-copy { padding: 60px; }
  .work-copy { padding: 60px; }
  .faq-grid { gap: 65px; }
}

@media (max-width: 820px) {
  :root { --container: min(100% - 32px, 680px); }
  .topbar-inner p { display: none; }
  .topbar-inner { justify-content: center; }
  .nav-toggle { display: block; cursor: pointer; }
  .nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
  .nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
  .nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
  .primary-nav { position: absolute; top: 100%; right: 0; left: 0; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 12px 24px 24px; background: var(--paper); border-bottom: 1px solid var(--line); box-shadow: 0 18px 30px rgba(0,0,0,.1); }
  .primary-nav.open { display: flex; }
  .primary-nav > a:not(.button) { padding: 13px 0; border-bottom: 1px solid var(--line); }
  .primary-nav .button { margin-top: 14px; }
  .hero { min-height: auto; }
  .hero-image { height: 620px; }
  .hero-shade { background: linear-gradient(180deg, rgba(5,28,20,.47), rgba(5,28,20,.97) 600px, var(--pine-950) 760px); }
  .hero-layout { min-height: 0; grid-template-columns: 1fr; gap: 50px; padding: 100px 0 65px; }
  .hero-copy { padding-top: 0; }
  .hero h1 { max-width: 650px; }
  .hero-lede { max-width: 570px; }
  .lead-card { max-width: 570px; justify-self: start; }
  .proof-grid { grid-template-columns: repeat(2, 1fr); }
  .proof-grid > div:nth-child(3) { border-top: 1px solid rgba(255,255,255,.25); }
  .proof-grid > div:nth-child(4) { border-top: 1px solid rgba(255,255,255,.25); border-right: 1px solid rgba(255,255,255,.25); }
  .section { padding-block: 85px; }
  .split-heading { grid-template-columns: 1fr; gap: 25px; }
  .service-card { min-height: 355px; }
  .story { padding: 0; }
  .story-grid { width: 100%; grid-template-columns: 1fr; }
  .story-visual { min-height: 580px; }
  .story-visual > img { object-position: center 35%; }
  .story-stamp { right: 24px; bottom: 24px; }
  .story-copy { padding: 105px max(32px, calc((100vw - 680px)/2)) 75px; }
  .process-grid { gap: 0; }
  .process-grid li { padding: 0 30px; }
  .process-grid li:not(:last-child)::after { display: none; }
  .work-feature { grid-template-columns: 1fr; }
  .work-image { height: 510px; }
  .work-copy { padding: 75px max(32px, calc((100vw - 680px)/2)); }
  .review-grid { grid-template-columns: repeat(2, 1fr); }
  .areas-grid { grid-template-columns: 1fr; gap: 35px; }
  .faq-grid { grid-template-columns: 1fr; gap: 55px; }
  .footer-main { grid-template-columns: 1.5fr 1fr 1fr; gap: 35px; }
}

@media (max-width: 560px) {
  :root { --container: calc(100% - 28px); }
  html { scroll-padding-top: 80px; }
  body { padding-bottom: 64px; }
  .topbar { display: none; }
  .nav-wrap { min-height: 68px; }
  .brand-logo { width: 190px; height: 54px; }
  .hero-image { height: 510px; object-position: 64% center; }
  .hero-layout { padding: 80px 0 46px; gap: 40px; }
  .hero h1 { font-size: clamp(3.2rem, 16vw, 4.45rem); }
  .hero-lede { margin-top: 22px; font-size: .94rem; }
  .hero-actions { align-items: stretch; flex-direction: column; gap: 15px; }
  .hero-actions .text-link { justify-content: center; }
  .hero-proof { display: grid; grid-template-columns: 1fr 1fr; gap: 8px 15px; }
  .lead-card { padding: 24px 20px; }
  .field-row { grid-template-columns: 1fr; }
  .proof-grid > div { min-height: 90px; padding: 18px; }
  .proof-grid strong { font-size: 1.25rem; }
  .section { padding-block: 72px; }
  .section-heading h2, .story-copy h2, .work-copy h2, .areas-copy h2, .faq-intro h2 { font-size: clamp(2.8rem, 14vw, 4rem); }
  .section-heading { margin-bottom: 35px; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { min-height: 325px; padding: 28px 24px; }
  .service-icon { margin: 35px 0 20px; }
  .story-visual { min-height: 500px; }
  .story-copy { padding: 95px 24px 65px; }
  .process-grid { margin-top: 48px; grid-template-columns: 1fr; }
  .process-grid li { min-height: auto; padding: 27px 0 29px 67px; border-left: 0; border-top: 1px solid var(--line); }
  .process-grid li:last-child { border-right: 0; border-bottom: 1px solid var(--line); }
  .step-number { position: absolute; top: 26px; left: 0; }
  .process-grid h3 { margin: 0 0 8px; }
  .work-image { height: 340px; }
  .work-copy { padding: 65px 24px; }
  .review-grid { grid-template-columns: 1fr; }
  .review-card { min-height: 310px; padding: 27px; }
  .areas-map { min-height: 230px; }
  .faq-list summary { font-size: 1.1rem; }
  .faq-list details p { margin-right: 20px; }
  .final-cta { padding-block: 85px; }
  .final-cta h2 { font-size: clamp(3.25rem, 16vw, 5rem); }
  .cta-actions { flex-direction: column; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 45px 30px; padding-block: 55px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { padding: 18px 0; flex-direction: column; align-items: flex-start; justify-content: center; gap: 6px; }
  .mobile-action-bar { position: fixed; right: 0; bottom: 0; left: 0; z-index: 250; height: 64px; display: grid; grid-template-columns: 1fr 1fr; background: var(--pine-950); box-shadow: 0 -8px 30px rgba(0,0,0,.2); }
  .mobile-action-bar a { display: flex; align-items: center; justify-content: center; gap: 8px; color: #fff; font-size: .83rem; font-weight: 900; text-decoration: none; }
  .mobile-action-bar a:last-child { background: var(--orange); }
  .toast { right: 14px; bottom: 78px; left: 14px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
