:root {
  --navy: #061628;
  --navy-2: #0b2035;
  --black: #030b13;
  --paper: #f4f1ea;
  --paper-2: #e8e3d9;
  --white: #fbfaf7;
  --silver: #9da7b0;
  --muted: #687381;
  --bronze: #c1a06f;
  --bronze-2: #dfc497;
  --line-dark: rgba(255,255,255,.14);
  --line-light: rgba(6,22,40,.14);
  --serif: "Cormorant Garamond", Georgia, serif;
  --sans: "Manrope", "Segoe UI", sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; min-width: 320px; overflow-x: hidden; background: var(--paper); color: var(--navy); font-family: var(--sans); }
a { color: inherit; text-decoration: none; }
img { display: block; width: 100%; }
button, input, select, textarea { font: inherit; }
.shell { width: min(1440px, calc(100% - 72px)); margin-inline: auto; }
.section { padding: 132px 0; }
.section-number { color: #8a775b; font-size: 9px; font-weight: 700; letter-spacing: .18em; text-transform: uppercase; }
.eyebrow { display: flex; align-items: center; gap: 12px; margin: 0 0 26px; color: rgba(255,255,255,.66); font-size: 9px; font-weight: 700; letter-spacing: .19em; text-transform: uppercase; }
.eyebrow span { width: 34px; height: 1px; background: var(--bronze); }
.eyebrow.dark { color: #66717e; }
.back-to-top { position: fixed; z-index: 50; right: 20px; bottom: 20px; display: inline-flex; align-items: center; gap: 9px; min-height: 46px; padding: 0 16px; border: 1px solid rgba(255,255,255,.25); background: rgba(5,18,32,.9); backdrop-filter: blur(12px); color: white; font-family: var(--sans); font-size: 11px; font-weight: 700; cursor: pointer; opacity: 0; pointer-events: none; transform: translateY(10px); transition: opacity .2s ease,transform .2s ease,background .2s ease; }
.back-to-top.visible { opacity: 1; pointer-events: auto; transform: none; }
.back-to-top:hover { background: var(--bronze); color: var(--navy); }
.back-to-top span { font-size: 18px; line-height: 1; }
.back-to-top b { font-weight: 700; }
.mockup-switcher { position: fixed; z-index: 49; top: 50%; left: 0; display: inline-flex; align-items: center; gap: 9px; min-height: 50px; padding: 7px 14px 7px 7px; border: 1px solid rgba(255,255,255,.24); border-left: 0; background: rgba(5,18,32,.92); box-shadow: 0 14px 38px rgba(0,0,0,.2); backdrop-filter: blur(14px); color: white; font-size: 11px; font-weight: 700; 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; background: var(--bronze); color: var(--navy); font-size: 11px; }
.mockup-switcher b { font-weight: 700; white-space: nowrap; }
.mockup-switcher i { font-size: 17px; font-style: normal; transition: transform .2s ease; }
.mockup-switcher:hover { padding-right: 18px; background: var(--bronze); color: var(--navy); }
.mockup-switcher:hover span { background: var(--navy); color: white; }
.mockup-switcher:hover i { transform: translateX(4px); }

.utility-bar { position: absolute; z-index: 30; top: 0; width: 100%; color: rgba(255,255,255,.65); font-size: 8px; font-weight: 700; letter-spacing: .12em; text-transform: uppercase; }
.utility-inner { display: flex; justify-content: space-between; align-items: center; height: 38px; border-bottom: 1px solid var(--line-dark); }
.utility-inner p { display: flex; align-items: center; margin: 0; }
.utility-inner p i, .live-dot { width: 7px; height: 7px; margin-right: 9px; border-radius: 50%; background: #6ca980; box-shadow: 0 0 0 4px rgba(108,169,128,.12); }
.utility-inner div { display: flex; gap: 24px; align-items: center; }
.utility-inner a { color: white; font-size: 10px; }

.site-header { position: fixed; z-index: 29; top: 38px; width: 100%; color: white; transition: background .3s ease, box-shadow .3s ease, top .3s ease; }
.site-header.scrolled { top: 0; background: rgba(4,14,25,.94); box-shadow: 0 15px 50px rgba(0,0,0,.28); backdrop-filter: blur(18px); }
.nav { display: grid; grid-template-columns: .8fr auto .8fr; align-items: center; min-height: 84px; border-bottom: 1px solid var(--line-dark); }
.brand { display: inline-flex; align-items: center; justify-self: start; gap: 10px; }
.brand img { width: 52px; height: 52px; }
.brand > span { display: grid; line-height: 1; }
.brand strong { font-size: 22px; letter-spacing: .1em; }
.brand small { margin-top: 5px; font-size: 7px; font-weight: 700; letter-spacing: .29em; }
.nav nav { display: flex; align-items: center; gap: 27px; }
.nav nav a { position: relative; padding: 9px 0; color: rgba(255,255,255,.78); font-size: 12px; font-weight: 600; }
.nav nav a::after { position: absolute; right: 0; bottom: 0; left: 0; height: 1px; content: ""; background: var(--bronze); transform: scaleX(0); transform-origin: right; transition: transform .24s ease; }
.nav nav a:hover { color: white; }
.nav nav a:hover::after { transform: scaleX(1); transform-origin: left; }
.nav-actions { display: flex; align-items: center; justify-self: end; gap: 15px; }
.nav-phone { display: grid; gap: 3px; text-align: right; }
.nav-phone small { color: var(--bronze-2); font-size: 7px; font-weight: 700; letter-spacing: .13em; }
.nav-phone strong { font-family: var(--serif); font-size: 18px; font-weight: 600; }
.menu-toggle { display: none; }

.btn { position: relative; display: inline-flex; min-height: 58px; padding: 0 22px; align-items: center; justify-content: center; gap: 11px; overflow: hidden; border: 1px solid transparent; font-size: 13px; font-weight: 700; line-height: 1; letter-spacing: .01em; 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 22%,rgba(255,255,255,.24),transparent 72%); transform: translateX(-135%); transition: transform .55s ease; }
.btn:hover { transform: translateY(-3px); }
.btn:hover::before { transform: translateX(135%); }
.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 .22s ease; }
.btn:hover > span, .btn:hover > b { transform: translate(4px,-2px); }
.btn-gold { background: var(--bronze); color: var(--navy); box-shadow: 0 14px 36px rgba(193,160,111,.16); }
.btn-gold:hover { background: var(--bronze-2); box-shadow: 0 18px 42px rgba(193,160,111,.25); }
.btn-ghost { border-color: rgba(255,255,255,.35); color: white; background: rgba(255,255,255,.025); }
.btn-ghost:hover { background: rgba(255,255,255,.09); }
.btn-dark { background: var(--navy); color: white; }
.btn-compact { min-height: 48px; padding-inline: 18px; gap: 9px; font-size: 12px; }
.btn-compact > span, .btn-compact > b { width: 16px; height: 16px; font-size: 15px; }
.btn-phone { display: grid; min-width: 220px; align-content: center; justify-items: start; row-gap: 5px; padding-block: 10px; text-align: left; }
.btn-phone small { color: var(--bronze-2); font-size: 8px; line-height: 1; text-transform: uppercase; letter-spacing: .12em; }
.btn-phone strong { font-family: var(--serif); font-size: 18px; line-height: 1; }

.hero { position: relative; min-height: 940px; overflow: hidden; background: var(--black); color: white; }
.hero-media, .hero-overlay { position: absolute; inset: 0; }
.hero-media { background: url("../assets/titan-night-van.jpg") center/cover no-repeat; transform: scale(1.06) translateY(var(--parallax,0)); will-change: transform; }
.hero-overlay { background: linear-gradient(90deg,rgba(3,11,19,.97) 0%,rgba(3,11,19,.84) 40%,rgba(3,11,19,.18) 78%), linear-gradient(180deg,rgba(3,11,19,.16),rgba(3,11,19,.7)); }
.water-rings { position: absolute; z-index: 1; right: -7%; bottom: -8%; width: 800px; height: 300px; pointer-events: none; transform: rotate(-7deg); }
.water-rings i { position: absolute; inset: 0; border: 1px solid rgba(193,160,111,.16); border-radius: 50%; animation: ripple 12s ease-in-out infinite alternate; }
.water-rings i:nth-child(2) { inset: 35px -60px; animation-delay: -4s; }
.water-rings i:nth-child(3) { inset: 70px -120px; animation-delay: -8s; }
@keyframes ripple { to { opacity: .25; transform: translateX(50px) scale(1.07); } }
.hero-layout { position: relative; z-index: 2; display: grid; grid-template-columns: minmax(0,1.22fr) minmax(350px,.5fr); gap: 7vw; align-items: center; min-height: 830px; padding-top: 130px; }
.hero-copy { max-width: 860px; }
.hero-copy h1 { margin: 0; font-family: var(--serif); font-size: clamp(66px,6.7vw,110px); font-weight: 500; line-height: .83; letter-spacing: -.045em; }
.hero-copy h1 .line { display: block; overflow: hidden; margin-bottom: -.08em; padding-bottom: .16em; }
.hero-copy h1 .line > span { display: block; }
.hero-copy h1 .accent { color: var(--bronze-2); font-size: .72em; font-style: italic; line-height: 1.06; }
.hero-kicker { margin: 27px 0 0; font-size: 12px; font-weight: 700; letter-spacing: .14em; text-transform: uppercase; }
.hero-lead { max-width: 590px; margin: 13px 0 0; color: rgba(255,255,255,.66); font-size: 16px; line-height: 1.7; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 13px; margin-top: 35px; }
.accreditation { display: flex; flex-wrap: wrap; gap: 24px; margin-top: 30px; color: rgba(255,255,255,.68); font-size: 12px; font-weight: 600; }
.accreditation i { margin-right: 6px; color: var(--bronze-2); font-style: normal; }
.emergency-panel { position: relative; overflow: hidden; padding: 35px; border: 1px solid rgba(193,160,111,.32); border-top: 3px solid var(--bronze); background: linear-gradient(145deg,rgba(12,34,56,.96),rgba(4,17,31,.95)); box-shadow: 0 34px 100px rgba(0,0,0,.35); backdrop-filter: blur(16px); }
.emergency-panel::after { position: absolute; top: -80px; right: -80px; width: 190px; height: 190px; border: 1px solid rgba(193,160,111,.14); border-radius: 50%; content: ""; box-shadow: 0 0 0 25px rgba(193,160,111,.03),0 0 0 50px rgba(193,160,111,.018); }
.panel-head { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; margin-bottom: 30px; }
.panel-head div { display: flex; align-items: center; color: rgba(255,255,255,.6); font-size: 8px; letter-spacing: .13em; }
.panel-head b { font-family: var(--serif); color: var(--bronze-2); font-size: 25px; }
.panel-label { margin: 0; color: var(--bronze-2); font-size: 8px; font-weight: 700; letter-spacing: .18em; }
.emergency-panel h2 { margin: 10px 0 8px; font-family: var(--serif); font-size: 44px; font-weight: 500; }
.emergency-panel > p:not(.panel-label) { margin: 0; color: rgba(255,255,255,.58); font-size: 12px; line-height: 1.65; }
.emergency-panel form { display: grid; gap: 10px; margin-top: 25px; }
.emergency-panel label { display: grid; grid-template-columns: 78px 1fr; align-items: center; min-height: 56px; border: 1px solid var(--line-dark); background: rgba(255,255,255,.025); transition: border .2s ease,box-shadow .2s ease; }
.emergency-panel label:focus-within { border-color: var(--bronze); box-shadow: 0 0 0 3px rgba(193,160,111,.08); }
.emergency-panel label span { padding-left: 13px; color: rgba(255,255,255,.45); font-size: 7px; font-weight: 700; letter-spacing: .13em; }
.emergency-panel input,.emergency-panel select { width: 100%; height: 54px; border: 0; outline: 0; background: transparent; color: white; font-size: 12px; }
.emergency-panel select option { color: var(--navy); }
.emergency-panel button { display: inline-flex; align-items: center; justify-content: center; gap: 11px; min-height: 60px; padding: 0 20px; border: 0; background: var(--bronze); color: var(--navy); font-size: 13px; font-weight: 700; line-height: 1; cursor: pointer; transition: background .2s ease,transform .2s ease,box-shadow .2s ease; }
.emergency-panel button span { 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; }
.emergency-panel button:hover { background: var(--bronze-2); transform: translateY(-2px); box-shadow: 0 14px 35px rgba(193,160,111,.2); }
.emergency-panel button:hover span { transform: translateX(4px); }
.panel-notes { display: flex; justify-content: space-between; margin-top: 17px; color: rgba(255,255,255,.48); font-size: 7px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.trust-strip { position: absolute; z-index: 3; right: 0; bottom: 0; left: 0; display: grid; grid-template-columns: repeat(5,1fr); border-top: 1px solid var(--line-dark); background: rgba(3,11,19,.68); backdrop-filter: blur(14px); }
.trust-item { display: flex; align-items: baseline; gap: 15px; min-height: 112px; padding: 34px 28px; border-right: 1px solid var(--line-dark); transition: background .2s ease,transform .2s ease; }
.trust-item:first-child { padding-left: 0; }
.trust-item:last-child { border: 0; }
.trust-item:hover { background: rgba(193,160,111,.08); transform: translateY(-3px); }
.trust-item strong { font-family: var(--serif); font-size: 31px; font-weight: 500; line-height: 1; }
.trust-item span { color: rgba(255,255,255,.58); font-size: 10px; font-weight: 700; line-height: 1.35; letter-spacing: .07em; text-transform: uppercase; }

.approach { background: var(--paper); }
.approach-grid { display: grid; grid-template-columns: .25fr 1.25fr .75fr; gap: 56px; }
.approach-title h2,.section-heading h2,.why-content h2,.ppm-copy h2,.reviews-head h2,.emergency-content h2,.contact-copy h2 { margin: 0; font-family: var(--serif); font-size: clamp(54px,5.2vw,82px); font-weight: 500; line-height: .95; letter-spacing: -.04em; }
.approach-title h2 em { color: #927b5a; font-weight: 500; }
.approach-copy { padding-top: 48px; color: var(--muted); font-size: 14px; line-height: 1.8; }
.approach-copy p { margin: 0 0 20px; }
.approach-cards { grid-column: 2/4; display: grid; grid-template-columns: repeat(3,1fr); margin-top: 30px; border-top: 1px solid var(--line-light); border-left: 1px solid var(--line-light); }
.approach-cards article { min-height: 210px; padding: 32px; border-right: 1px solid var(--line-light); border-bottom: 1px solid var(--line-light); background: rgba(255,255,255,.22); transition: background .25s ease,transform .25s ease,box-shadow .25s ease,border-color .25s ease; }
.approach-cards article:hover { z-index: 1; border-color: rgba(193,160,111,.55); background: white; transform: translateY(-6px); box-shadow: 0 25px 60px rgba(6,22,40,.09); }
.approach-cards article > span { color: rgba(193,160,111,.72); font-family: var(--serif); font-size: 70px; line-height: .75; }
.approach-cards h3 { margin: 38px 0 14px; font-family: var(--serif); font-size: 44px; font-weight: 600; line-height: 1; }
.approach-cards p { max-width: 390px; margin: 0; color: #5c6775; font-size: 14px; line-height: 1.65; }

.services { background: #dad5ca; }
.section-heading { display: grid; grid-template-columns: 1fr .42fr; gap: 80px; align-items: end; margin-bottom: 55px; }
.section-heading h2 { margin-top: 19px; }
.section-heading > p { margin: 0 0 5px; color: var(--muted); font-size: 14px; line-height: 1.8; }
.service-showcase { display: grid; grid-template-columns: repeat(12,1fr); gap: 16px; }
.service-card { --image:none; position: relative; grid-column: span 6; min-height: 480px; overflow: hidden; background: var(--navy); color: white; }
.service-large { grid-column: span 8; }
.service-narrow { grid-column: span 4; }
.service-wide { grid-column: span 6; min-height: 390px; }
.service-image { position: absolute; inset: 0; background-image: linear-gradient(180deg,rgba(4,16,29,.04),rgba(4,16,29,.9)),var(--image); background-position: center; background-size: cover; transition: transform .75s cubic-bezier(.22,1,.36,1),filter .3s ease; }
.service-card:hover .service-image { transform: scale(1.065); filter: saturate(1.06); }
.service-content { position: absolute; z-index: 1; right: 0; bottom: 0; left: 0; padding: 34px; }
.service-meta { display: flex; justify-content: space-between; align-items: flex-start; margin-bottom: 21px; color: rgba(255,255,255,.7); font-size: 11px; letter-spacing: .11em; }
.service-meta > span { font-family: var(--serif); font-size: 38px; line-height: .8; letter-spacing: 0; }
.service-meta b { color: var(--bronze-2); font-size: 10px; }
.service-card h3 { max-width: 720px; margin: 0 0 15px; font-family: var(--serif); font-size: 44px; font-weight: 500; line-height: 1; }
.service-large h3 { font-size: 56px; }
.service-card p { max-width: 620px; margin: 0 0 27px; color: rgba(255,255,255,.72); font-size: 15px; line-height: 1.6; }
.service-card a { display: flex; justify-content: space-between; max-width: 210px; padding-top: 15px; border-top: 1px solid rgba(255,255,255,.48); font-size: 12px; font-weight: 700; letter-spacing: .07em; text-transform: uppercase; }
.service-card a span { transition: transform .2s ease; }
.service-card:hover a span { transform: translate(5px,-3px); }

.why { display: grid; grid-template-columns: .83fr 1.17fr; min-height: 900px; background: var(--navy); color: white; }
.why-image { position: relative; min-height: 720px; overflow: hidden; }
.why-image img { height: 100%; object-fit: cover; filter: saturate(.68) contrast(1.05); transform: scale(1.04) translateY(var(--image-parallax,0)); }
.why-image::after { position: absolute; inset: 0; content: ""; background: linear-gradient(180deg,transparent 45%,rgba(3,11,19,.8)); pointer-events: none; }
.image-caption { position: absolute; z-index: 2; right: 32px; bottom: 32px; left: 32px; display: flex; justify-content: space-between; align-items: end; padding-top: 14px; border-top: 1px solid rgba(255,255,255,.38); }
.image-caption span { color: var(--bronze-2); font-size: 8px; font-weight: 700; letter-spacing: .15em; }
.image-caption b { max-width: 280px; text-align: right; font-family: var(--serif); font-size: 20px; font-weight: 500; }
.floating-rating { position: absolute; z-index: 3; top: 35px; right: -1px; display: grid; gap: 3px; min-width: 165px; padding: 18px 22px; background: var(--paper); color: var(--navy); box-shadow: 0 20px 50px rgba(0,0,0,.2); }
.floating-rating strong { font-family: var(--serif); font-size: 28px; }
.floating-rating span { color: var(--bronze); letter-spacing: .12em; }
.floating-rating small { color: var(--muted); font-size: 7px; letter-spacing: .1em; }
.why-content { padding-inline: 8vw; background: linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px),var(--navy); background-size: 48px 48px; }
.why-content .section-number { color: rgba(255,255,255,.4); }
.why-content .eyebrow { margin-top: 46px; }
.why-content h2 { max-width: 720px; }
.why-list { margin-top: 55px; border-top: 1px solid var(--line-dark); }
.why-list article { display: grid; grid-template-columns: 70px 1fr; gap: 18px; padding: 29px 0; border-bottom: 1px solid var(--line-dark); transition: padding .2s ease,background .2s ease; }
.why-list article:hover { padding-left: 12px; background: rgba(193,160,111,.04); }
.why-list article > span { color: var(--bronze-2); font-family: var(--serif); font-size: 38px; line-height: .85; }
.why-list h3 { margin: 0 0 9px; font-family: var(--serif); font-size: 30px; font-weight: 500; line-height: 1.1; }
.why-list p { margin: 0; color: rgba(255,255,255,.62); font-size: 14px; line-height: 1.65; }
.why-stats { display: grid; grid-template-columns: repeat(3,1fr); margin-top: 35px; border: 1px solid var(--line-dark); }
.why-stats div { display: grid; gap: 7px; padding: 25px; border-right: 1px solid var(--line-dark); }
.why-stats div:last-child { border: 0; }
.why-stats strong { font-family: var(--serif); font-size: 34px; font-weight: 500; line-height: 1; }
.why-stats span { color: rgba(255,255,255,.55); font-size: 10px; text-transform: uppercase; letter-spacing: .09em; }

.ppm { position: relative; overflow: hidden; background: var(--paper); }
.ppm::after { position: absolute; right: -180px; bottom: -220px; width: 600px; height: 600px; border: 1px solid rgba(193,160,111,.16); border-radius: 50%; content: ""; box-shadow: 0 0 0 55px rgba(193,160,111,.025),0 0 0 110px rgba(193,160,111,.015); }
.ppm-grid { position: relative; z-index: 1; display: grid; grid-template-columns: .95fr 1.05fr; gap: 70px; }
.ppm-copy h2 { margin-top: 42px; }
.ppm-copy > p:not(.eyebrow) { max-width: 650px; margin: 28px 0 34px; color: var(--muted); font-size: 14px; line-height: 1.8; }
.ppm-visual { position: relative; min-height: 520px; overflow: hidden; }
.ppm-visual img { height: 100%; object-fit: cover; transition: transform .7s ease; }
.ppm-visual:hover img { transform: scale(1.05); }
.ppm-tag { position: absolute; right: 24px; bottom: 24px; left: 24px; display: flex; justify-content: space-between; align-items: end; padding: 18px; background: rgba(6,22,40,.86); backdrop-filter: blur(12px); color: white; }
.ppm-tag span { color: var(--bronze-2); font-size: 7px; letter-spacing: .14em; }
.ppm-tag b { max-width: 290px; text-align: right; font-family: var(--serif); font-size: 18px; font-weight: 500; }
.ppm-checks { grid-column: 1/3; display: grid; grid-template-columns: repeat(3,1fr); border-top: 1px solid var(--line-light); border-left: 1px solid var(--line-light); }
.ppm-checks span { position: relative; padding: 23px 24px 23px 52px; border-right: 1px solid var(--line-light); border-bottom: 1px solid var(--line-light); color: #3f4b5b; font-size: 15px; font-weight: 500; line-height: 1.4; transition: background .2s ease,padding-left .2s ease; }
.ppm-checks span::before { position: absolute; left: 23px; content: "✓"; color: #8a775b; font-size: 16px; }
.ppm-checks span:hover { padding-left: 58px; background: white; }
.sector-list { grid-column: 1/3; display: flex; flex-wrap: wrap; gap: 8px; align-items: center; }
.sector-list b { margin-right: 16px; color: #8a775b; font-size: 11px; letter-spacing: .12em; }
.sector-list span { padding: 12px 15px; border: 1px solid var(--line-light); color: #586473; font-size: 12px; font-weight: 500; transition: border .2s ease,background .2s ease; }
.sector-list span:hover { border-color: var(--bronze); background: rgba(193,160,111,.07); }

.reviews { background: var(--paper-2); }
.reviews-head { display: flex; justify-content: space-between; align-items: end; margin-bottom: 50px; }
.reviews-head h2 { max-width: 780px; margin-top: 18px; }
.review-score { display: grid; grid-template-columns: auto auto; align-items: center; gap: 0 12px; }
.review-score strong { grid-row: 1/3; font-family: var(--serif); font-size: 55px; font-weight: 500; }
.review-score span { color: var(--bronze); letter-spacing: .12em; }
.review-score small { color: var(--muted); font-size: 7px; letter-spacing: .12em; }
.review-grid { display: grid; grid-template-columns: 1.15fr .85fr .85fr; gap: 15px; }
.review-grid blockquote { display: flex; min-height: 360px; margin: 0; padding: 30px; flex-direction: column; border: 1px solid var(--line-light); background: rgba(255,255,255,.5); transition: transform .24s ease,border .24s ease,box-shadow .24s ease; }
.review-grid blockquote:hover { transform: translateY(-7px); border-color: rgba(193,160,111,.7); box-shadow: 0 25px 60px rgba(6,22,40,.08); }
.review-grid .featured-review { background: var(--navy); color: white; }
.quote { color: var(--bronze); font-family: var(--serif); font-size: 60px; line-height: .7; }
.review-grid blockquote > p { margin: 50px 0 auto; font-family: var(--serif); font-size: 22px; line-height: 1.45; }
.featured-review > p { font-size: 28px !important; }
.review-grid footer { display: grid; gap: 4px; margin-top: 30px; padding-top: 20px; border-top: 1px solid var(--line-light); background: transparent; }
.featured-review footer { border-color: var(--line-dark); }
.review-grid footer strong { font-size: 9px; letter-spacing: .1em; text-transform: uppercase; }
.review-grid footer span { color: var(--muted); font-size: 9px; }
.featured-review footer span { color: rgba(255,255,255,.45); }

.emergency-cta { position: relative; min-height: 610px; overflow: hidden; color: white; }
.emergency-bg,.emergency-shade { position: absolute; inset: 0; }
.emergency-bg { background: url("../assets/titan-night-van.jpg") center/cover no-repeat; transform: scale(1.04) translateY(var(--parallax-secondary,0)); }
.emergency-shade { background: linear-gradient(90deg,rgba(3,11,19,.96),rgba(3,11,19,.62) 58%,rgba(3,11,19,.3)),linear-gradient(180deg,transparent,rgba(3,11,19,.5)); }
.emergency-content { position: relative; z-index: 1; display: grid; grid-template-columns: 1.1fr .65fr; gap: 8vw; align-items: center; min-height: 610px; }
.emergency-content h2 { max-width: 830px; }
.emergency-content > div:first-child > p:last-child { color: rgba(255,255,255,.58); }
.emergency-actions { display: grid; gap: 15px; }
.emergency-number { display: grid; gap: 5px; padding: 22px 0; border-top: 1px solid rgba(255,255,255,.35); border-bottom: 1px solid rgba(255,255,255,.35); }
.emergency-number small { color: var(--bronze-2); font-size: 8px; letter-spacing: .14em; }
.emergency-number strong { font-family: var(--serif); font-size: 42px; font-weight: 500; }

.contact { background: #d9d3c8; }
.contact-grid { display: grid; grid-template-columns: .8fr 1.2fr; gap: 8vw; }
.contact-copy h2 { margin: 24px 0; }
.contact-copy > p { max-width: 520px; color: var(--muted); font-size: 14px; line-height: 1.8; }
.contact-copy > div { display: grid; gap: 10px; margin-top: 40px; font-family: var(--serif); font-size: 21px; }
.contact-form { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; padding: 40px; background: var(--paper); box-shadow: 0 30px 80px rgba(6,22,40,.09); }
.contact-form label { display: grid; gap: 7px; }
.contact-form label span { color: var(--muted); font-size: 8px; font-weight: 700; letter-spacing: .1em; text-transform: uppercase; }
.contact-form input,.contact-form select,.contact-form textarea { width: 100%; border: 0; border-bottom: 1px solid var(--line-light); outline: 0; background: transparent; color: var(--navy); }
.contact-form input,.contact-form select { height: 48px; }
.contact-form textarea { min-height: 100px; padding-top: 12px; resize: vertical; }
.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus { border-color: var(--bronze); box-shadow: 0 2px 0 rgba(193,160,111,.14); }
.contact-form .wide { grid-column: 1/3; }
.contact-form button { grid-column: 1/3; display: flex; justify-content: space-between; align-items: center; min-height: 58px; padding: 0 18px; border: 0; background: var(--navy); color: white; font-size: 10px; font-weight: 700; cursor: pointer; transition: background .2s ease,transform .2s ease; }
.contact-form button:hover { background: var(--navy-2); transform: translateY(-2px); }

.site-footer { position: relative; overflow: hidden; padding: 80px 0 25px; background: #030e1b; color: white; }
.footer-pattern { position: absolute; inset: 0; opacity: .5; background: radial-gradient(circle at 85% 20%,rgba(193,160,111,.1),transparent 25%),linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px); background-size: auto,50px 50px,50px 50px; }
.footer-top { position: relative; display: grid; grid-template-columns: 1.25fr .55fr .55fr .55fr .9fr; gap: 55px; }
.footer-brand p { max-width: 390px; margin: 24px 0 0; color: rgba(255,255,255,.58); font-size: 15px; line-height: 1.7; }
.footer-links { display: grid; align-content: start; gap: 15px; font-size: 14px; }
.footer-links b,.footer-emergency > span { margin-bottom: 13px; color: var(--bronze-2); font-size: 11px; letter-spacing: .12em; }
.footer-links a { color: rgba(255,255,255,.62); transition: color .2s ease,transform .2s ease; }
.footer-links a:hover { color: white; transform: translateX(4px); }
.footer-emergency { padding: 25px; border: 1px solid var(--line-dark); background: rgba(255,255,255,.025); }
.footer-emergency { display: grid; align-content: start; }
.footer-emergency > a:not(.btn) { font-family: var(--serif); font-size: 32px; }
.footer-emergency p { color: rgba(255,255,255,.55); font-size: 13px; }
.footer-emergency .btn { margin-top: 15px; }
.footer-bottom { position: relative; display: flex; justify-content: space-between; margin-top: 60px; padding-top: 24px; border-top: 1px solid var(--line-dark); color: rgba(255,255,255,.48); font-size: 11px; letter-spacing: .08em; 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(25px); transition: opacity .72s cubic-bezier(.22,1,.36,1) var(--delay,0ms),filter .72s cubic-bezier(.22,1,.36,1) var(--delay,0ms),transform .72s 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 .85s ease,transform .95s cubic-bezier(.16,1,.3,1); }
.js .hero-copy .line:nth-child(2)>span { transition-delay: .1s; }
.js .hero-copy .line:nth-child(3)>span { transition-delay: .2s; }
.js .hero-intro,.js .hero-follow { opacity: 0; transform: translateY(17px); transition: opacity .65s ease,transform .65s ease; }
.js .ready .hero-copy .line>span,.js .ready .hero-intro,.js .ready .hero-follow { opacity: 1; transform: none; }
.js .hero-follow { transition-delay: .66s; }
.js .hero-actions { transition-delay: .78s; }
.js .accreditation { transition-delay: .9s; }
.js [data-hero-panel] { opacity: 0; transform: translateX(60px); transition: opacity .9s ease .5s,transform 1s cubic-bezier(.16,1,.3,1) .5s; }
.js .ready [data-hero-panel] { opacity: 1; transform: none; }
.js .trust-item { opacity: 0; transform: translateY(18px); transition: opacity .55s ease,transform .55s ease; }
.js .ready .trust-item { opacity: 1; transform: none; }
.js .trust-item:nth-child(1){transition-delay:.85s}.js .trust-item:nth-child(2){transition-delay:.93s}.js .trust-item:nth-child(3){transition-delay:1.01s}.js .trust-item:nth-child(4){transition-delay:1.09s}.js .trust-item:nth-child(5){transition-delay:1.17s}

@media (max-width:1180px) {
  .nav { grid-template-columns: 1fr auto; }
  .nav nav,.nav-actions { display: none; }
  .menu-toggle { display: grid; gap: 7px; width: 44px; height: 44px; place-content: center; border: 1px solid var(--line-dark); background: transparent; }
  .menu-toggle i { width: 19px; height: 1px; background: white; transition: transform .2s ease; }
  .menu-toggle[aria-expanded=true] i:first-child { transform: translateY(4px) rotate(45deg); }
  .menu-toggle[aria-expanded=true] i:last-child { transform: translateY(-4px) rotate(-45deg); }
  .nav nav { position: absolute; top: 84px; right: 36px; left: 36px; display: grid; gap: 0; padding: 18px 24px; background: rgba(4,14,25,.98); opacity: 0; visibility: hidden; transform: translateY(-10px); transition: .22s ease; }
  .nav nav a { padding: 14px 0; border-bottom: 1px solid var(--line-dark); }
  .nav nav.open { opacity: 1; visibility: visible; transform: none; }
  .hero-layout { grid-template-columns: 1fr .58fr; gap: 40px; }
  .hero-copy h1 { font-size: 75px; }
  .service-card,.service-large,.service-narrow,.service-wide { grid-column: span 6; }
  .footer-top { grid-template-columns: 1.2fr .6fr .6fr .9fr; }
  .footer-links:nth-of-type(3) { display: none; }
}

@media (max-width:850px) {
  .shell { width: min(100% - 32px,720px); }
  .section { padding: 90px 0; }
  .utility-inner span { display: none; }
  .hero { min-height: 1250px; }
  .hero-media { background-position: 55% center; }
  .hero-overlay { background: linear-gradient(180deg,rgba(3,11,19,.9),rgba(3,11,19,.45) 55%,rgba(3,11,19,.96)); }
  .hero-layout { grid-template-columns: 1fr; align-content: center; padding: 170px 0 230px; }
  .hero-copy h1 { font-size: clamp(57px,12vw,82px); }
  .emergency-panel { max-width: 560px; }
  .trust-strip { grid-template-columns: repeat(2,1fr); width: 100%; }
  .trust-item { min-height: 72px; padding: 18px 20px!important; }
  .trust-item:nth-child(2n) { border-right: 0; }
  .trust-item:nth-child(-n+4) { border-bottom: 1px solid var(--line-dark); }
  .trust-item:last-child { grid-column: 1/3; }
  .approach-grid { grid-template-columns: 1fr; gap: 28px; }
  .approach-copy { padding: 0; }
  .approach-cards { grid-column: auto; grid-template-columns: 1fr; }
  .approach-cards article { min-height: 190px; }
  .section-heading { grid-template-columns: 1fr; gap: 25px; }
  .service-card,.service-large,.service-narrow,.service-wide { grid-column: span 12; min-height: 430px; }
  .why { grid-template-columns: 1fr; }
  .why-image { min-height: 570px; }
  .why-content { padding: 90px 24px; }
  .ppm-grid { grid-template-columns: 1fr; }
  .ppm-visual { min-height: 430px; }
  .ppm-checks,.sector-list { grid-column: auto; }
  .ppm-checks { grid-template-columns: 1fr 1fr; }
  .reviews-head { display: grid; gap: 30px; }
  .review-grid { grid-template-columns: 1fr; }
  .review-grid blockquote { min-height: 280px; }
  .emergency-content { grid-template-columns: 1fr; align-content: center; gap: 45px; }
  .contact-grid { grid-template-columns: 1fr; }
  .footer-top { grid-template-columns: 1fr 1fr; }
  .footer-brand,.footer-emergency { 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; }
  .utility-inner { font-size: 7px; }
  .utility-inner a { font-size: 8px; }
  .brand img { width: 45px; height: 45px; }
  .hero { min-height: 1370px; }
  .hero-layout { padding-top: 175px; }
  .hero-copy h1 { font-size: 54px; line-height: .88; }
  .hero-copy h1 .accent { font-size: .78em; }
  .hero-actions { display: grid; }
  .btn { width: 100%; min-height: 58px; padding-inline: 20px; gap: 10px; font-size: 13px; }
  .accreditation { display: grid; }
  .emergency-panel { padding: 27px 20px; }
  .panel-notes { gap: 10px; }
  .approach-title h2,.section-heading h2,.why-content h2,.ppm-copy h2,.reviews-head h2,.emergency-content h2,.contact-copy h2 { font-size: 47px; }
  .service-card { min-height: 390px; }
  .why-image { min-height: 470px; }
  .image-caption { display: grid; gap: 8px; }
  .image-caption b { text-align: left; }
  .why-stats { grid-template-columns: 1fr; }
  .why-stats div { border-right: 0; border-bottom: 1px solid var(--line-dark); }
  .ppm-checks { grid-template-columns: 1fr; }
  .ppm-tag { display: grid; gap: 8px; }
  .ppm-tag b { text-align: left; }
  .emergency-number strong { font-size: 35px; }
  .contact-form { grid-template-columns: 1fr; padding: 28px 20px; }
  .contact-form .wide,.contact-form button { grid-column: auto; }
  .footer-top { grid-template-columns: 1fr; }
  .footer-brand,.footer-emergency { 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-panel],.js .trust-item { opacity:1!important; filter:none!important; transform:none!important; }
}
