:root {
  --navy: #061b38;
  --navy-2: #0b2848;
  --ink: #071a33;
  --paper: #f4f5f4;
  --white: #ffffff;
  --silver: #dfe3e5;
  --silver-2: #b9c1c7;
  --muted: #637083;
  --champagne: #c6a879;
  --champagne-2: #e2ccaa;
  --line: rgba(7,26,51,.13);
  --sans: "Manrope", "Segoe UI", sans-serif;
  --serif: "Newsreader", Georgia, serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; overflow-x: hidden; background: var(--paper); color: var(--ink); font-family: var(--sans); }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button,input,select { font: inherit; }
.shell { width: min(1480px,calc(100% - 56px)); margin-inline: auto; }
.section { padding: 120px 0; }
.kicker,.eyebrow { display: block; margin: 0 0 18px; color: #77664c; font-size: 10px; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.back-to-top { position: fixed; z-index: 60; right: 20px; bottom: 20px; display: inline-flex; align-items: center; gap: 9px; min-height: 46px; padding: 0 16px; border: 1px solid rgba(7,26,51,.15); border-radius: 99px; background: rgba(255,255,255,.92); box-shadow: 0 12px 35px rgba(7,26,51,.12); backdrop-filter: blur(12px); color: var(--navy); font-family: var(--sans); font-size: 11px; font-weight: 800; cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .2s ease,transform .2s ease,background .2s ease,color .2s ease; }
.back-to-top.visible { opacity: 1; pointer-events: auto; transform: none; }
.back-to-top:hover { background: var(--navy); color: white; }
.back-to-top span { font-size: 18px; line-height: 1; }
.back-to-top b { font-weight: 800; }
.mockup-switcher { position: fixed; z-index: 59; top: 50%; left: 0; display: inline-flex; align-items: center; gap: 9px; min-height: 50px; padding: 7px 14px 7px 7px; border: 1px solid rgba(7,26,51,.16); border-left: 0; border-radius: 0 8px 8px 0; background: rgba(255,255,255,.94); box-shadow: 0 14px 38px rgba(7,26,51,.14); backdrop-filter: blur(14px); color: var(--navy); font-size: 11px; font-weight: 800; transform: translateY(-50%); transition: background .2s ease,color .2s ease,padding .2s ease; }
.mockup-switcher span { display: grid; width: 35px; height: 35px; place-items: center; border-radius: 5px; background: var(--navy); color: white; font-size: 11px; }
.mockup-switcher b { font-weight: 800; white-space: nowrap; }
.mockup-switcher i { font-size: 17px; font-style: normal; transition: transform .2s ease; }
.mockup-switcher:hover { padding-right: 18px; background: var(--navy); color: white; }
.mockup-switcher:hover span { background: var(--champagne); color: var(--navy); }
.mockup-switcher:hover i { transform: translateX(-4px); }

.response-ribbon { background: var(--navy); color: white; }
.response-ribbon .shell { display: flex; align-items: center; justify-content: space-between; min-height: 42px; font-size: 10px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; }
.response-ribbon p,.response-ribbon div { display: flex; align-items: center; gap: 20px; margin: 0; }
.response-ribbon p i { width: 7px; height: 7px; border-radius: 50%; background: #6eae82; box-shadow: 0 0 0 4px rgba(110,174,130,.13); }
.response-ribbon p span,.response-ribbon div > span { color: rgba(255,255,255,.48); }
.response-ribbon a { color: var(--champagne-2); }

.site-header { position: sticky; z-index: 40; top: 0; background: rgba(244,245,244,.91); border-bottom: 1px solid var(--line); backdrop-filter: blur(17px); transition: background .28s ease,box-shadow .28s ease; }
.site-header.scrolled { background: rgba(255,255,255,.96); box-shadow: 0 14px 45px rgba(7,26,51,.08); }
.nav { display: grid; grid-template-columns: .8fr auto .8fr; align-items: center; min-height: 86px; }
.brand { display: inline-flex; align-items: center; justify-self: start; gap: 9px; }
.brand img { width: 50px; height: 50px; }
.brand > span { display: grid; line-height: 1; }
.brand strong { font-size: 22px; letter-spacing: .1em; }
.brand small { margin-top: 5px; font-size: 8px; font-weight: 800; letter-spacing: .25em; }
.nav nav { display: flex; gap: 25px; }
.nav nav a { position: relative; padding: 10px 0; font-size: 12px; font-weight: 700; }
.nav nav a::after { position: absolute; right: 0; bottom: 0; left: 0; height: 2px; border-radius: 99px; content: ""; background: var(--champagne); transform: scaleX(0); transform-origin: right; transition: transform .22s ease; }
.nav nav a:hover::after { transform: scaleX(1); transform-origin: left; }
.nav-actions { display: flex; align-items: center; justify-self: end; gap: 15px; }
.phone-link { display: grid; gap: 3px; text-align: right; }
.phone-link small { color: #806d50; font-size: 9px; font-weight: 800; letter-spacing: .11em; }
.phone-link strong { font-size: 17px; }
.menu-toggle { display: none; }

.btn { position: relative; display: inline-flex; align-items: center; justify-content: center; gap: 11px; min-height: 58px; padding: 0 22px; overflow: hidden; border: 1px solid transparent; border-radius: 6px; font-size: 13px; font-weight: 800; line-height: 1; white-space: nowrap; transition: transform .22s ease,background .22s ease,color .22s ease,box-shadow .22s ease; }
.btn::before { position: absolute; inset: 0; content: ""; background: linear-gradient(105deg,transparent 20%,rgba(255,255,255,.23),transparent 70%); transform: translateX(-140%); transition: transform .55s ease; }
.btn:hover { transform: translateY(-3px); }
.btn:hover::before { transform: translateX(140%); }
.btn > span,.btn > b { display: inline-flex; flex: 0 0 auto; align-items: center; justify-content: center; width: 18px; height: 18px; font-size: 17px; font-weight: 500; line-height: 1; transition: transform .2s ease; }
.btn:hover > span,.btn:hover > b { transform: translateX(4px); }
.btn-primary { background: var(--navy); color: white; box-shadow: 0 14px 34px rgba(7,26,51,.16); }
.btn-primary:hover { background: var(--navy-2); box-shadow: 0 18px 40px rgba(7,26,51,.23); }
.btn-outline { border-color: var(--line); background: rgba(255,255,255,.7); }
.btn-light { background: white; color: var(--navy); }
.btn-champagne { background: var(--champagne); color: var(--navy); }
.btn-small { min-height: 48px; padding-inline: 18px; gap: 9px; font-size: 12px; }
.btn-small > span,.btn-small > b { width: 16px; height: 16px; font-size: 15px; }
.phone-button { display: grid; min-width: 230px; gap: 3px; text-align: left; }
.phone-button small { color: #806d50; font-size: 9px; text-transform: uppercase; letter-spacing: .11em; }
.phone-button strong { font-size: 18px; }

.hero { position: relative; overflow: hidden; padding: 75px 0 64px; background: var(--paper); }
.hero-grid-bg { position: absolute; inset: 0; background: linear-gradient(rgba(7,26,51,.035) 1px,transparent 1px),linear-gradient(90deg,rgba(7,26,51,.035) 1px,transparent 1px); background-size: 48px 48px; mask-image: linear-gradient(180deg,#000,transparent 80%); pointer-events: none; }
.hero-grid-bg::after { position: absolute; top: -20%; left: -15%; width: 650px; height: 650px; border-radius: 50%; content: ""; background: radial-gradient(circle,rgba(198,168,121,.13),transparent 67%); }
.hero-layout { position: relative; display: grid; grid-template-columns: .95fr 1.05fr; gap: 5vw; align-items: center; min-height: 650px; }
.hero-copy { position: relative; z-index: 1; }
.location-pill { display: inline-flex; align-items: center; gap: 14px; padding: 8px 15px 8px 8px; border: 1px solid var(--line); border-radius: 99px; background: rgba(255,255,255,.7); color: var(--muted); font-size: 11px; font-weight: 600; }
.location-pill span { padding: 7px 10px; border-radius: 99px; background: var(--navy); color: white; font-size: 9px; letter-spacing: .09em; }
.hero-copy .eyebrow { margin-top: 38px; color: #7b684b; }
.hero-copy h1 { margin: 0; font-size: clamp(66px,6.1vw,99px); line-height: .9; letter-spacing: -.065em; }
.hero-copy h1 .line { display: block; overflow: hidden; padding-bottom: .04em; }
.hero-copy h1 .line > span { display: block; }
.mobile-break { font: inherit; }
.hero-copy h1 .accent { color: var(--navy-2); font-family: var(--serif); font-style: italic; font-weight: 500; letter-spacing: -.045em; }
.engineered { max-width: 690px; margin: 25px 0 0; color: var(--navy); font-size: 12px; font-weight: 800; letter-spacing: .1em; line-height: 1.55; text-transform: uppercase; }
.lead { max-width: 590px; margin: 14px 0 0; color: var(--muted); font-size: 15px; line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; margin-top: 31px; }
.hero-trust { display: grid; grid-template-columns: repeat(5,1fr); margin-top: 43px; padding-top: 20px; border-top: 1px solid var(--line); }
.trust-item { display: grid; gap: 3px; padding: 0 15px; border-right: 1px solid var(--line); transition: transform .2s ease,background .2s ease; }
.trust-item:first-child { padding-left: 0; }
.trust-item:last-child { border: 0; }
.trust-item:hover { transform: translateY(-3px); }
.trust-item b { font-size: 17px; }
.trust-item span { color: var(--muted); font-size: 9px; font-weight: 700; text-transform: uppercase; letter-spacing: .06em; }
.hero-visual { position: relative; min-height: 565px; }
.hero-image { position: absolute; inset: 0; overflow: hidden; border-radius: 18px; box-shadow: 0 35px 100px rgba(7,26,51,.16); }
.hero-image img { height: 100%; object-fit: cover; object-position: 45% center; filter: saturate(.65) contrast(1.04); transform: scale(1.04) translateY(var(--image-parallax,0)); transition: transform .7s cubic-bezier(.22,1,.36,1),filter .3s ease; }
.hero-image:hover img { transform: scale(1.085) translateY(var(--image-parallax,0)); filter: saturate(.82); }
.hero-image::after { position: absolute; inset: 0; content: ""; border: 1px solid rgba(255,255,255,.32); border-radius: 18px; box-shadow: inset 0 -140px 120px rgba(6,27,56,.32); }
.visual-caption { position: absolute; z-index: 2; right: 25px; bottom: 25px; left: 25px; display: flex; justify-content: space-between; align-items: end; padding: 17px 19px; border: 1px solid rgba(255,255,255,.2); border-radius: 8px; background: rgba(6,27,56,.88); backdrop-filter: blur(12px); color: white; }
.visual-caption span { color: var(--champagne-2); font-size: 9px; font-weight: 800; letter-spacing: .12em; }
.visual-caption strong { max-width: 330px; text-align: right; font-size: 12px; line-height: 1.4; }
.visual-badge { position: absolute; z-index: 3; display: flex; align-items: center; gap: 12px; padding: 13px 15px; border: 1px solid var(--line); border-radius: 8px; background: white; box-shadow: 0 14px 35px rgba(7,26,51,.13); }
.visual-badge i { width: 9px; height: 9px; border-radius: 50%; background: #6eae82; box-shadow: 0 0 0 4px rgba(110,174,130,.12); }
.visual-badge span { display: grid; gap: 3px; font-size: 12px; font-weight: 700; }
.visual-badge small { color: #806d50; font-size: 9px; letter-spacing: .09em; }
.visual-badge b { font-family: var(--serif); font-size: 23px; }
.badge-top { top: 27px; left: -32px; }
.badge-bottom { right: -24px; bottom: 105px; }
.response-checker { position: relative; z-index: 5; display: grid; grid-template-columns: minmax(220px,.72fr) minmax(240px,1fr) minmax(280px,1.12fr) minmax(190px,.55fr); gap: 14px; align-items: stretch; min-height: 142px; margin-top: 48px; padding: 22px; border: 1px solid rgba(255,255,255,.08); border-radius: 16px; background: linear-gradient(115deg,#061b38,#092442); box-shadow: 0 28px 70px rgba(7,26,51,.2); color: white; }
.checker-title { display: flex; flex-direction: column; justify-content: center; padding: 0 20px; }
.checker-title span,.response-checker label > span { color: var(--champagne-2); font-size: 10px; font-weight: 800; letter-spacing: .1em; }
.checker-title h2 { margin: 9px 0 0; font-size: 25px; line-height: 1.2; letter-spacing: -.025em; }
.response-checker label { display: grid; align-content: center; gap: 9px; min-width: 0; padding: 17px 19px; border: 1px solid rgba(255,255,255,.18); border-radius: 9px; background: rgba(255,255,255,.025); transition: border .2s ease,background .2s ease,box-shadow .2s ease; }
.response-checker label:focus-within { border-color: var(--champagne); box-shadow: 0 0 0 3px rgba(198,168,121,.08); }
.response-checker label:focus-within { background: rgba(255,255,255,.05); }
.response-checker input,.response-checker select { width: 100%; min-width: 0; height: 34px; padding: 0; border: 0; outline: 0; background: transparent; color: white; font-size: 14px; font-weight: 500; }
.response-checker input::placeholder { color: rgba(255,255,255,.65); }
.response-checker option { color: var(--navy); }
.response-checker button { display: inline-flex; justify-content: center; align-items: center; align-self: stretch; gap: 11px; min-width: 190px; min-height: 76px; padding: 0 22px; border: 0; border-radius: 9px; background: var(--champagne); color: var(--navy); font-size: 13px; font-weight: 800; line-height: 1; cursor: pointer; transition: background .2s ease,transform .2s ease,box-shadow .2s ease; }
.response-checker button span { white-space: nowrap; }
.response-checker button b { display: inline-flex; flex: 0 0 auto; align-items: center; justify-content: center; width: 18px; height: 18px; font-size: 17px; font-weight: 500; line-height: 1; transition: transform .2s ease; }
.response-checker button:hover { background: var(--champagne-2); transform: translateY(-2px); box-shadow: 0 14px 30px rgba(198,168,121,.18); }
.response-checker button:hover b { transform: translateX(4px); }

.service-intro { padding-top: 120px; }
.heading-row { display: grid; grid-template-columns: 1fr .42fr; gap: 70px; align-items: end; margin-bottom: 52px; }
.heading-row h2,.process-heading h2,.why-copy h2,.ppm-content h2,.price-inner h2,.emergency-inner h2 { margin: 0; font-size: clamp(52px,4.8vw,76px); line-height: .98; letter-spacing: -.055em; }
.heading-row p { margin: 0 0 5px; color: var(--muted); font-size: 13px; line-height: 1.75; }
.services-grid { display: grid; grid-template-columns: repeat(12,1fr); gap: 15px; }
.service-card { position: relative; grid-column: span 4; min-height: 440px; overflow: hidden; border-radius: 12px; background: var(--navy); color: white; box-shadow: 0 10px 35px rgba(7,26,51,.06); }
.emergency-card { grid-column: span 8; min-height: 400px; }
.ppm-card { grid-column: span 4; min-height: 400px; }
.commercial-card { grid-column: span 12; min-height: 400px; }
.service-card img { position: absolute; inset: 0; height: 100%; object-fit: cover; filter: saturate(.68); transition: transform .75s cubic-bezier(.22,1,.36,1),filter .3s ease; }
.service-card:hover img { transform: scale(1.075); filter: saturate(.9); }
.image-shade { position: absolute; inset: 0; background: linear-gradient(180deg,rgba(6,27,56,.02),rgba(6,27,56,.93)); transition: background .3s ease; }
.service-card:hover .image-shade { background: linear-gradient(180deg,rgba(6,27,56,.08),rgba(6,27,56,.96)); }
.service-copy { position: absolute; z-index: 1; right: 0; bottom: 0; left: 0; padding: 27px; }
.service-copy > span { color: var(--champagne-2); font-size: 9px; font-weight: 800; letter-spacing: .11em; }
.service-copy h3 { margin: 10px 0; font-size: clamp(27px,2.4vw,38px); line-height: 1.03; letter-spacing: -.04em; }
.service-copy p { max-width: 500px; margin: 0 0 23px; color: rgba(255,255,255,.68); font-size: 13px; line-height: 1.65; }
.service-copy a { display: flex; justify-content: space-between; max-width: 190px; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.35); font-size: 11px; font-weight: 800; letter-spacing: .07em; text-transform: uppercase; }
.service-copy a b { transition: transform .2s ease; }
.service-card:hover .service-copy a b { transform: translate(5px,-3px); }

.process { background: #e5e8e9; }
.process-grid { display: grid; grid-template-columns: .72fr 1.28fr; gap: 8vw; }
.process-heading { align-self: start; position: sticky; top: 125px; }
.process-heading p { max-width: 490px; color: var(--muted); line-height: 1.75; }
.process-steps { border-top: 1px solid var(--line); }
.process-steps article { position: relative; display: grid; grid-template-columns: 45px 35px 1fr; align-items: start; gap: 15px; padding: 30px 10px; border-bottom: 1px solid var(--line); transition: padding .2s ease,background .2s ease; }
.process-steps article::before { position: absolute; top: 0; bottom: 0; left: 0; width: 3px; content: ""; background: var(--champagne); transform: scaleY(0); transform-origin: bottom; transition: transform .22s ease; }
.process-steps article:hover { padding-left: 22px; background: rgba(255,255,255,.55); }
.process-steps article:hover::before { transform: scaleY(1); }
.process-steps article > span { color: #806d50; font-size: 11px; font-weight: 800; }
.process-steps article > i { width: 24px; height: 24px; border: 1px solid #9ca5ac; border-radius: 50%; transition: background .2s ease,border .2s ease; }
.process-steps article:hover > i { border-color: var(--champagne); background: var(--champagne); }
.process-steps h3 { margin: 0 0 8px; font-size: 24px; letter-spacing: -.03em; }
.process-steps p { max-width: 550px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.65; }

.why { padding: 120px 0 0; background: var(--navy); color: white; }
.why-grid { display: grid; grid-template-columns: 1.08fr .92fr; gap: 7vw; align-items: stretch; }
.why-copy { padding-bottom: 85px; }
.why-copy .kicker { color: var(--champagne-2); }
.why-copy > p { max-width: 650px; color: rgba(255,255,255,.57); line-height: 1.75; }
.why-cards { display: grid; grid-template-columns: repeat(3,1fr); margin-top: 50px; border-top: 1px solid rgba(255,255,255,.15); border-left: 1px solid rgba(255,255,255,.15); }
.why-cards article { min-height: 250px; padding: 25px; border-right: 1px solid rgba(255,255,255,.15); border-bottom: 1px solid rgba(255,255,255,.15); transition: background .2s ease,transform .2s ease; }
.why-cards article:hover { background: rgba(198,168,121,.07); transform: translateY(-5px); }
.why-cards b { color: var(--champagne-2); font-size: 11px; }
.why-cards h3 { margin: 68px 0 10px; font-size: 19px; line-height: 1.2; }
.why-cards p { margin: 0; color: rgba(255,255,255,.55); font-size: 13px; line-height: 1.6; }
.why-visual { position: relative; overflow: hidden; min-height: 650px; }
.why-visual img { height: 100%; object-fit: cover; filter: saturate(.63); transition: transform .7s ease; }
.why-visual:hover img { transform: scale(1.05); }
.why-visual::after { position: absolute; inset: 0; content: ""; background: linear-gradient(180deg,transparent 45%,rgba(6,27,56,.75)); }
.why-image-label { position: absolute; z-index: 1; right: 25px; bottom: 25px; left: 25px; display: flex; justify-content: space-between; align-items: end; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.38); }
.why-image-label span { color: var(--champagne-2); font-size: 9px; letter-spacing: .11em; }
.why-image-label b { font-family: var(--serif); font-size: 22px; font-weight: 500; }
.stats-band { display: grid; grid-template-columns: repeat(5,1fr); border-top: 1px solid rgba(255,255,255,.15); }
.stats-band div { display: grid; gap: 4px; padding: 27px; border-right: 1px solid rgba(255,255,255,.15); transition: background .2s ease; }
.stats-band div:hover { background: rgba(198,168,121,.07); }
.stats-band div:last-child { border: 0; }
.stats-band strong { font-family: var(--serif); font-size: 27px; font-weight: 500; }
.stats-band span { color: rgba(255,255,255,.5); font-size: 9px; font-weight: 700; letter-spacing: .08em; text-transform: uppercase; }

.ppm { background: var(--paper); }
.ppm-shell { display: grid; grid-template-columns: .9fr 1.1fr; gap: 0; overflow: hidden; border: 1px solid var(--line); border-radius: 17px; background: var(--navy); color: white; box-shadow: 0 30px 80px rgba(7,26,51,.12); }
.ppm-image { position: relative; min-height: 700px; overflow: hidden; }
.ppm-image img { height: 100%; object-fit: cover; transition: transform .75s ease; }
.ppm-image:hover img { transform: scale(1.055); }
.ppm-image::after { position: absolute; inset: 0; content: ""; background: linear-gradient(180deg,transparent 50%,rgba(6,27,56,.85)); }
.ppm-image-tag { position: absolute; z-index: 1; right: 27px; bottom: 27px; left: 27px; display: grid; gap: 7px; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.4); }
.ppm-image-tag span { color: var(--champagne-2); font-size: 9px; letter-spacing: .11em; }
.ppm-image-tag b { font-family: var(--serif); font-size: 23px; font-weight: 500; }
.ppm-content { padding: 65px; }
.ppm-content .kicker { color: var(--champagne-2); }
.ppm-content h2 { font-size: clamp(47px,4.3vw,69px); }
.ppm-content > p { margin: 25px 0; color: rgba(255,255,255,.57); font-size: 13px; line-height: 1.8; }
.ppm-list { display: grid; grid-template-columns: 1fr 1fr; border-top: 1px solid rgba(255,255,255,.14); }
.ppm-list span { position: relative; padding: 16px 10px 16px 23px; border-bottom: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.75); font-size: 12px; transition: color .2s ease,padding-left .2s ease; }
.ppm-list span::before { position: absolute; left: 0; content: "—"; color: var(--champagne-2); }
.ppm-list span:hover { padding-left: 29px; color: white; }
.ppm-content .btn { margin-top: 30px; }
.sector-strip { grid-column: 1/3; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; padding: 20px 28px; border-top: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.025); }
.sector-strip b { margin-right: 12px; color: var(--champagne-2); font-size: 9px; letter-spacing: .11em; }
.sector-strip span { padding: 9px 12px; border: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.58); font-size: 10px; transition: color .2s ease,border .2s ease; }
.sector-strip span:hover { border-color: var(--champagne); color: white; }

.reviews { background: #e5e8e9; }
.reviews-heading { align-items: center; }
.rating { display: grid; grid-template-columns: auto auto; gap: 2px 12px; align-items: center; }
.rating strong { grid-row: 1/3; font-family: var(--serif); font-size: 50px; font-weight: 500; }
.rating span { color: #9b8057; letter-spacing: .12em; }
.rating small { color: var(--muted); font-size: 9px; letter-spacing: .09em; }
.testimonials { display: grid; grid-template-columns: 1.15fr .85fr .85fr; gap: 15px; }
.testimonials blockquote { display: flex; min-height: 350px; margin: 0; padding: 28px; flex-direction: column; border: 1px solid var(--line); border-radius: 10px; background: rgba(255,255,255,.58); transition: transform .22s ease,border .22s ease,box-shadow .22s ease; }
.testimonials blockquote:hover { transform: translateY(-7px); border-color: rgba(198,168,121,.65); box-shadow: 0 23px 55px rgba(7,26,51,.09); }
.testimonials .testimonial-featured { background: var(--navy); color: white; }
.testimonials blockquote > span { color: var(--champagne); font-family: var(--serif); font-size: 55px; line-height: .7; }
.testimonials blockquote > p { margin: 47px 0 auto; font-size: 18px; line-height: 1.55; }
.testimonial-featured > p { font-family: var(--serif); font-size: 27px!important; }
.testimonials footer { display: grid; gap: 4px; margin-top: 30px; padding-top: 18px; border-top: 1px solid var(--line); background: transparent; }
.testimonial-featured footer { border-color: rgba(255,255,255,.14); }
.testimonials footer strong { font-size: 10px; letter-spacing: .08em; text-transform: uppercase; }
.testimonials footer small { color: var(--muted); font-size: 10px; }
.testimonial-featured footer small { color: rgba(255,255,255,.42); }

.price-cta { padding: 80px 0; background: var(--silver); }
.price-inner { display: grid; grid-template-columns: 1fr .55fr; gap: 8vw; align-items: end; }
.price-inner .kicker { color: #806d50; }
.price-inner h2 { font-family: var(--serif); font-weight: 500; }
.price-inner > div:last-child p { margin: 0 0 24px; color: var(--muted); line-height: 1.75; }

.emergency-cta { position: relative; min-height: 580px; overflow: hidden; color: white; }
.emergency-image,.emergency-overlay { position: absolute; inset: 0; }
.emergency-image { background: url("../assets/titan-night-van.jpg") center/cover no-repeat; transition: transform 1s ease; }
.emergency-cta:hover .emergency-image { transform: scale(1.025); }
.emergency-overlay { background: linear-gradient(90deg,rgba(4,15,28,.95),rgba(4,15,28,.63) 60%,rgba(4,15,28,.3)); }
.emergency-inner { position: relative; z-index: 1; display: grid; grid-template-columns: 1.05fr .65fr; gap: 8vw; align-items: center; min-height: 580px; }
.emergency-inner .kicker { color: var(--champagne-2); }
.emergency-inner p { max-width: 610px; color: rgba(255,255,255,.6); line-height: 1.7; }
.emergency-actions { display: grid; gap: 15px; }
.phone-cta { display: grid; gap: 5px; padding: 20px 0; border-top: 1px solid rgba(255,255,255,.32); border-bottom: 1px solid rgba(255,255,255,.32); }
.phone-cta small { color: var(--champagne-2); font-size: 9px; letter-spacing: .11em; }
.phone-cta strong { font-family: var(--serif); font-size: 38px; font-weight: 500; }

.site-footer { position: relative; overflow: hidden; padding: 78px 0 24px; background: #030f20; color: white; }
.footer-glow { position: absolute; inset: 0; background: radial-gradient(circle at 88% 15%,rgba(198,168,121,.13),transparent 25%),linear-gradient(rgba(255,255,255,.018) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.018) 1px,transparent 1px); background-size: auto,50px 50px,50px 50px; }
.footer-grid { position: relative; display: grid; grid-template-columns: 1.2fr .55fr .55fr .55fr .9fr; gap: 50px; }
.footer-brand p { max-width: 350px; color: rgba(255,255,255,.48); font-size: 12px; line-height: 1.7; }
.footer-contact { display: grid; gap: 9px; margin-top: 25px; font-size: 12px; }
.footer-contact a:first-child { font-family: var(--serif); font-size: 22px; }
.footer-links { display: grid; align-content: start; gap: 13px; font-size: 12px; }
.footer-links b,.footer-cta > span { margin-bottom: 12px; color: var(--champagne-2); font-size: 9px; letter-spacing: .11em; }
.footer-links a { color: rgba(255,255,255,.57); transition: color .2s ease,transform .2s ease; }
.footer-links a:hover { color: white; transform: translateX(4px); }
.footer-cta { display: grid; align-content: start; padding: 24px; border: 1px solid rgba(255,255,255,.14); background: rgba(255,255,255,.025); }
.footer-cta strong { font-size: 20px; }
.footer-cta p { color: rgba(255,255,255,.5); font-size: 12px; line-height: 1.6; }
.footer-cta .btn { margin-top: 13px; }
.footer-bottom { position: relative; display: flex; justify-content: space-between; margin-top: 55px; padding-top: 21px; border-top: 1px solid rgba(255,255,255,.14); color: rgba(255,255,255,.4); font-size: 10px; letter-spacing: .07em; text-transform: uppercase; }
.footer-bottom a { color: inherit; text-decoration: none; }
.footer-bottom a:hover { color: white; }

.js [data-reveal],.js [data-footer]>* { opacity:0; filter:blur(7px); transform:translateY(24px); transition:opacity .7s cubic-bezier(.22,1,.36,1) var(--delay,0ms),filter .7s cubic-bezier(.22,1,.36,1) var(--delay,0ms),transform .7s cubic-bezier(.22,1,.36,1) var(--delay,0ms); }
.js [data-reveal].visible,.js [data-footer].visible>* { opacity:1; filter:none; transform:none; }
.js .hero-copy .line>span { opacity:0; transform:translateY(110%); transition:opacity .82s ease,transform .92s cubic-bezier(.16,1,.3,1); }
.js .hero-copy .line:nth-child(2)>span { transition-delay:.12s; }
.js .hero-intro,.js .hero-follow { opacity:0; transform:translateY(17px); transition:opacity .62s ease,transform .62s ease; }
.js .ready .hero-copy .line>span,.js .ready .hero-intro,.js .ready .hero-follow { opacity:1; transform:none; }
.js .hero-follow { transition-delay:.55s; }
.js .hero-actions { transition-delay:.68s; }
.js [data-hero-visual] { opacity:0; transform:translateX(42px) scale(.98); transition:opacity .85s ease .35s,transform .9s cubic-bezier(.16,1,.3,1) .35s; }
.js .ready [data-hero-visual] { opacity:1; transform:none; }
.js [data-hero-panel] { opacity:0; transform:translateY(35px); transition:opacity .75s ease .7s,transform .85s cubic-bezier(.16,1,.3,1) .7s; }
.js .ready [data-hero-panel] { opacity:1; transform:none; }
.js .trust-item { opacity:0; transform:translateY(15px); transition:opacity .5s ease,transform .5s ease; }
.js .ready .trust-item { opacity:1; transform:none; }
.js .trust-item:nth-child(1){transition-delay:.72s}.js .trust-item:nth-child(2){transition-delay:.79s}.js .trust-item:nth-child(3){transition-delay:.86s}.js .trust-item:nth-child(4){transition-delay:.93s}.js .trust-item:nth-child(5){transition-delay:1s}

@media (max-width:1200px) {
  .nav { grid-template-columns: 1fr auto; }
  .nav nav,.nav-actions { display:none; }
  .menu-toggle { display:grid; gap:4px; width:43px; height:43px; place-content:center; border:1px solid var(--line); border-radius:6px; background:white; }
  .menu-toggle i { width:18px; height:2px; background:var(--navy); transition:.2s ease; }
  .menu-toggle[aria-expanded=true] i:first-child { transform:translateY(6px) rotate(45deg); }
  .menu-toggle[aria-expanded=true] i:nth-child(2) { opacity:0; }
  .menu-toggle[aria-expanded=true] i:last-child { transform:translateY(-6px) rotate(-45deg); }
  .nav nav { position:absolute; top:86px; right:28px; left:28px; display:grid; padding:15px 22px; border:1px solid var(--line); border-radius:0 0 10px 10px; background:rgba(255,255,255,.98); box-shadow:0 25px 55px rgba(7,26,51,.12); opacity:0; visibility:hidden; transform:translateY(-10px); transition:.22s ease; }
  .nav nav a { padding:13px 0; border-bottom:1px solid var(--line); }
  .nav nav.open { opacity:1; visibility:visible; transform:none; }
  .hero-copy h1 { font-size:70px; }
  .hero-trust { grid-template-columns:repeat(3,1fr); gap:13px 0; }
  .service-card { grid-column:span 6; }
  .emergency-card,.ppm-card { grid-column:span 6; }
  .commercial-card { grid-column:span 12; }
  .why-cards { grid-template-columns:1fr; }
  .why-cards article { min-height:170px; }
  .why-cards h3 { margin-top:35px; }
  .footer-grid { grid-template-columns:1.2fr .55fr .55fr .9fr; }
  .footer-links:nth-of-type(3) { display:none; }
}

@media (max-width:850px) {
  .shell { width:min(100% - 28px,720px); }
  .section { padding:90px 0; }
  .response-ribbon p span,.response-ribbon div>span { display:none; }
  .hero { padding-top:55px; }
  .hero-layout { grid-template-columns:1fr; gap:55px; }
  .hero-copy h1 { font-size:clamp(55px,13vw,78px); }
  .hero-visual { min-height:520px; }
  .response-checker { grid-template-columns:1fr; margin-top:45px; padding:18px; }
  .checker-title { padding:10px 5px 14px; }
  .response-checker button { min-height:64px; }
  .service-intro { padding-top:100px; }
  .heading-row { grid-template-columns:1fr; gap:25px; }
  .service-card,.emergency-card,.ppm-card,.commercial-card { grid-column:span 12; min-height:430px; }
  .process-grid,.why-grid { grid-template-columns:1fr; }
  .process-heading { position:static; }
  .why { padding-top:90px; }
  .why-visual { min-height:540px; }
  .stats-band { grid-template-columns:1fr 1fr; }
  .stats-band div:nth-child(2n) { border-right:0; }
  .stats-band div:last-child { grid-column:1/3; }
  .ppm-shell { grid-template-columns:1fr; }
  .ppm-image { min-height:500px; }
  .ppm-content { padding:45px 30px; }
  .sector-strip { grid-column:auto; }
  .testimonials { grid-template-columns:1fr; }
  .testimonials blockquote { min-height:280px; }
  .price-inner,.emergency-inner { grid-template-columns:1fr; gap:40px; }
  .footer-grid { grid-template-columns:1fr 1fr; }
  .footer-brand,.footer-cta { grid-column:1/3; }
}

@media (max-width:560px) {
  .mockup-switcher { top: auto; bottom: 78px; min-height: 44px; padding: 5px 11px 5px 5px; font-size: 10px; transform: none; }
  .mockup-switcher span { width: 33px; height: 33px; }
  .mockup-switcher b { display: none; }
  .response-ribbon .shell { font-size:7px; }
  .response-ribbon a { font-size:0; }
  .response-ribbon a::after { content:"CALL"; font-size:8px; }
  .hero-copy h1 { font-size:52px; }
  .mobile-break { display:block; }
  .engineered { font-size:8px; line-height:1.6; }
  .hero-actions { display:grid; }
  .btn { width:100%; min-height:58px; padding-inline:20px; gap:10px; font-size:13px; }
  .response-checker button { width:100%; min-height:64px; font-size:13px; }
  .service-copy a { font-size:11px; }
  .hero-trust { grid-template-columns:1fr 1fr; }
  .trust-item { padding:12px 8px!important; border-bottom:1px solid var(--line); }
  .hero-visual { min-height:430px; }
  .badge-bottom { display:none; }
  .badge-top { top:20px; left:20px; }
  .visual-caption { display:grid; gap:7px; }
  .visual-caption strong { text-align:left; }
  .heading-row h2,.process-heading h2,.why-copy h2,.ppm-content h2,.price-inner h2,.emergency-inner h2 { font-size:44px; }
  .service-card { min-height:390px; }
  .process-steps article { grid-template-columns:35px 25px 1fr; gap:9px; }
  .why-visual { min-height:450px; }
  .stats-band { grid-template-columns:1fr; }
  .stats-band div,.stats-band div:nth-child(2n) { border-right:0; border-bottom:1px solid rgba(255,255,255,.15); }
  .stats-band div:last-child { grid-column:auto; }
  .ppm-image { min-height:430px; }
  .ppm-list { grid-template-columns:1fr; }
  .sector-strip { padding:20px; }
  .phone-cta strong { font-size:33px; }
  .footer-grid { grid-template-columns:1fr; }
  .footer-brand,.footer-cta { grid-column:auto; }
  .footer-bottom { display:grid; gap:8px; }
}

@media (prefers-reduced-motion:reduce) {
  html { scroll-behavior:auto; }
  *,*::before,*::after { animation-duration:.01ms!important; animation-iteration-count:1!important; transition-duration:.01ms!important; }
  .js [data-reveal],.js [data-footer]>*,
  .js .hero-copy .line>span,.js .hero-intro,.js .hero-follow,.js [data-hero-visual],.js [data-hero-panel],.js .trust-item { opacity:1!important; filter:none!important; transform:none!important; }
}
