@import url('tokens.css');

* { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; }
body { margin: 0; min-height: 100vh; }
img, svg { max-width: 100%; height: auto; display: block; }

a { color: var(--link); text-decoration: none; }
a:hover { color: var(--link-hover); text-decoration: underline; }

h1, h2, h3, h4, h5, h6 { margin: 0 0 var(--s-4); font-family: var(--font-display); font-weight: var(--fw-medium); text-transform: uppercase; letter-spacing: 0.02em; line-height: 1.05; color: var(--brand-blue-deep); }
h1 { font-size: clamp(38px, 5.5vw, 60px); line-height: 1; letter-spacing: 0.01em; font-weight: var(--fw-semi); }
h2 { font-size: clamp(28px, 3.6vw, 42px); line-height: 1.05; font-weight: var(--fw-medium); }
h3 { font-size: var(--fs-h3); font-weight: var(--fw-medium); line-height: 1.2; letter-spacing: 0.02em; }
h4 { font-size: var(--fs-h4); font-weight: var(--fw-medium); line-height: 1.2; letter-spacing: 0.02em; }
p { margin: 0 0 1em; }
ul, ol { margin: 0 0 1em; padding-left: 1.3em; }
li { margin-bottom: var(--s-2); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 var(--s-10); }

.skip-link { position: absolute; left: -9999px; top: 0; background: var(--brand-blue); color: #fff; padding: var(--s-2) var(--s-3); z-index: 1000; }
.skip-link:focus { left: var(--s-2); top: var(--s-2); }

/* NAV */
.site-header { position: sticky; top: 0; z-index: 50; background: #fff; border-bottom: 1px solid var(--hairline); transition: padding 0.16s cubic-bezier(0.2, 0, 0, 1); }
.header-inner { display: flex; align-items: center; gap: var(--s-5); padding: var(--s-3) var(--s-6); max-width: 1200px; margin: 0 auto; }
.site-branding { display: flex; align-items: center; gap: var(--s-3); flex: 0 0 auto; }
.site-branding a { display: flex; align-items: center; gap: var(--s-3); text-decoration: none; }
.site-branding a:hover { text-decoration: none; }
.logo-mark { height: 72px; width: auto; display: block; }
.wordmark-block { display: flex; flex-direction: column; line-height: 1; }
.wordmark { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); white-space: nowrap; font-family: var(--font-mono); }
.primary-nav { flex: 1; }
.nav-list { display: flex; gap: var(--s-6); list-style: none; padding: 0; margin: 0; justify-content: center; }
.nav-list li { margin: 0; }
.nav-list a { color: var(--fg); text-decoration: none; font-weight: 500; font-size: 15px; padding: var(--s-2) 0; white-space: nowrap; }
.nav-list a:hover { color: var(--brand-blue); text-decoration: none; }
.nav-list > li { position: relative; }
.nav-list > li > a.menu-item-has-children::after,
.nav-list > li.menu-item-has-children > a::after { content: " \25BE"; font-size: 0.8em; color: var(--fg-muted); margin-left: 4px; }
.nav-list .sub-menu { display: none; position: absolute; top: calc(100% + 4px); left: 0; min-width: 240px; background: #fff; border: 1px solid var(--border); border-radius: var(--radius-md); box-shadow: var(--shadow-md); padding: var(--s-2); list-style: none; margin: 0; z-index: 60; }
.nav-list > li:hover > .sub-menu,
.nav-list > li:focus-within > .sub-menu { display: block; }
.nav-list .sub-menu li { margin: 0; }
.nav-list .sub-menu a { padding: var(--s-3) var(--s-4); border-radius: var(--radius-sm); display: block; white-space: nowrap; color: var(--fg) !important; font-size: 14px; font-weight: 500; }
.nav-list .sub-menu a:hover { background: var(--bg-tint); color: var(--brand-blue) !important; }
.header-cta { display: flex; align-items: center; gap: var(--s-3); flex: 0 0 auto; }
.header-cert { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); white-space: nowrap; }
.apb-phone { display: inline-flex; flex-direction: column; align-items: flex-end; text-decoration: none; line-height: 1; }
.apb-phone .label { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.1em; text-transform: uppercase; color: var(--fg-muted); }
.apb-phone .num { font-family: var(--font-display); font-weight: var(--fw-bold); font-size: 20px; color: var(--brand-blue); letter-spacing: 0.02em; white-space: nowrap; }
.apb-phone:hover { text-decoration: none; }
.apb-phone:hover .num { color: var(--brand-blue-deep); }

/* BUTTONS */
.btn { display: inline-flex; align-items: center; gap: var(--s-2); border: 0; border-radius: var(--radius-sm); padding: 11px 20px; font-family: var(--font-body); font-weight: var(--fw-bold); font-size: 15px; cursor: pointer; letter-spacing: 0.01em; transition: background 0.16s cubic-bezier(0.2, 0, 0, 1), box-shadow 0.16s, transform 0.1s; text-decoration: none; white-space: nowrap; }
.btn:hover { text-decoration: none; }
.btn-primary { background: var(--brand-safety-red); color: #fff; }
.btn-primary:hover { background: #a42818; color: #fff; box-shadow: var(--shadow-sm); }
.btn-primary:active { background: #8a2014; transform: translateY(1px); }
.btn-dark { background: var(--brand-black); color: #fff; }
.btn-dark:hover { background: var(--ink-800); color: #fff; }
.btn-red { background: var(--brand-safety-red); color: #fff; }
.btn-red:hover { background: #a42818; color: #fff; box-shadow: var(--shadow-sm); }
.btn-red:active { background: #8a2014; transform: translateY(1px); }
.btn-secondary { background: #fff; color: var(--fg); border: 1px solid var(--border-strong); }
.btn-secondary:hover { background: var(--ink-050); color: var(--fg); }
.btn-glass { background: rgba(255,255,255,0.08); color: #fff; border: 1px solid rgba(255,255,255,0.3); backdrop-filter: blur(14px); -webkit-backdrop-filter: blur(14px); }
.btn-glass:hover { background: rgba(255,255,255,0.18); color: #fff; }
.btn-lg { padding: 14px 26px; font-size: 16px; }
.btn-outline { background: #fff; color: var(--fg); border: 1px solid var(--border-strong); }
.btn-outline:hover { background: var(--ink-050); color: var(--fg); border-color: var(--brand-blue); }
.page-section.dark .btn-outline { background: rgba(255,255,255,0.08); color: #fff; border-color: rgba(255,255,255,0.3); backdrop-filter: blur(14px); }
.page-section.dark .btn-outline:hover { background: rgba(255,255,255,0.18); color: #fff; }

/* HERO */
.hero { position: relative; padding: var(--s-10) 0 var(--s-12); overflow: hidden; background: #fff; }
.hero::before { content: ""; position: absolute; inset: 0; background: radial-gradient(ellipse at 90% 10%, rgba(6,97,168,0.10), transparent 60%), linear-gradient(180deg, #fff 0%, #f3f7fc 100%); z-index: 0; }
.hero > .container { position: relative; z-index: 1; }
.hero .wrap { display: grid; grid-template-columns: 1.1fr 0.9fr; gap: var(--s-12); align-items: center; }
.hero-single .wrap { grid-template-columns: 1fr; max-width: 820px; margin: 0 auto; text-align: left; }
.hero .eyebrow { display: inline-flex; align-items: center; gap: var(--s-2); font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand-blue); margin-bottom: var(--s-4); font-weight: 600; }
.hero .eyebrow::before { content: ""; width: 20px; height: 2px; background: var(--brand-blue); }
.hero h1 { font-family: var(--font-display); font-weight: var(--fw-semi); text-transform: uppercase; font-size: clamp(44px, 6.5vw, 78px); line-height: 0.98; letter-spacing: 0.01em; margin: 0 0 var(--s-5); color: var(--brand-blue-deep); }
.hero-display-tagline { font-family: var(--font-display); font-weight: var(--fw-black); text-transform: uppercase; font-size: clamp(56px, 9vw, 104px); line-height: 0.92; letter-spacing: 0.01em; color: var(--brand-blue-deep); margin: 0 0 var(--s-4); }
.hero-display-tagline em { font-style: normal; color: var(--brand-blue); }
.hero h1.hero-sub-h1 { font-family: var(--font-display); font-weight: var(--fw-medium); text-transform: uppercase; font-size: clamp(20px, 2.4vw, 28px); line-height: 1.25; letter-spacing: 0.04em; color: var(--fg-muted); margin: 0 0 var(--s-5); }
.hero h1 em { font-style: normal; color: var(--brand-blue); }
.hero .lead { font-size: var(--fs-lead); line-height: 1.5; color: var(--fg-muted); max-width: 540px; margin: 0 0 var(--s-8); font-family: var(--font-body); }
.hero-ctas { display: flex; gap: var(--s-3); align-items: center; flex-wrap: wrap; margin-top: var(--s-6); }
.hero .photo { position: relative; border-radius: var(--radius-xl); overflow: hidden; box-shadow: var(--shadow-lg); aspect-ratio: 4/5; }
.hero .photo img { width: 100%; height: 100%; object-fit: cover; }
.hero .photo .caption { position: absolute; left: var(--s-5); bottom: var(--s-5); right: var(--s-5); background: #fff; border-radius: var(--radius-md); padding: var(--s-4) var(--s-4); box-shadow: var(--shadow-md); }
.hero .photo .caption .k { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-muted); }
.hero .photo .caption .v { font-family: var(--font-display); font-weight: var(--fw-black); font-size: 18px; text-transform: uppercase; color: var(--fg); letter-spacing: 0.01em; margin-top: 2px; line-height: 1.1; }

/* PROOF STRIP / TRUST ROW */
.trust-row { background: #fff; border-top: 1px solid var(--hairline); border-bottom: 1px solid var(--hairline); padding: var(--s-6) 0; }
.trust-row-inner { display: flex; gap: var(--s-10); flex-wrap: wrap; justify-content: center; align-items: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: var(--fg-muted); }
.trust-row-inner strong { color: var(--brand-blue-deep); font-family: var(--font-body); font-weight: var(--fw-bold); letter-spacing: normal; text-transform: none; font-size: 14px; margin-right: var(--s-1); }

/* SECTIONS */
.page-section { padding: var(--s-12) 0; }
.page-section + .page-section { padding-top: 0; }
.page-section.alt + .page-section, .page-section + .page-section.alt, .page-section.dark + .page-section, .page-section + .page-section.dark { padding-top: var(--s-12); }
.page-section.cta-band { padding: var(--s-10) 0 var(--s-12); }
.page-section.alt { background: var(--ink-050); }
.page-section.dark { background: var(--brand-black); color: var(--fg-inverse); }
.page-section.dark h2, .page-section.dark h3 { color: #fff; }
.page-section.dark .lead, .page-section.dark p { color: rgba(255,255,255,0.82); }
.section-head { text-align: center; margin-bottom: var(--s-8); }
.section-head .eyebrow { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand-blue); font-weight: 600; margin-bottom: var(--s-3); display: block; }
.section-head h2 { margin: 0 0 var(--s-3); }
.section-head p { font-size: 18px; color: var(--fg-muted); max-width: 640px; margin: 0 auto; }

/* ICONS (Lucide inline) */
.icon-wrap { display: inline-flex; align-items: center; justify-content: center; line-height: 1; color: var(--brand-blue); }
.icon-wrap svg { display: block; }
.icon-md { width: 56px; height: 56px; border-radius: var(--radius-lg); background: var(--bg-tint); margin-bottom: var(--s-5); }
.icon-md svg { width: 28px; height: 28px; }
.icon-sm { width: 24px; height: 24px; margin-right: var(--s-2); color: var(--brand-blue); }
.icon-sm svg { width: 20px; height: 20px; }
.icon-xs { width: 20px; height: 20px; margin-right: var(--s-1); }
.icon-xs svg { width: 16px; height: 16px; }
.trust-row-inner .icon-sm + strong { vertical-align: middle; }
.trust-row-inner span { display: inline-flex; align-items: center; gap: var(--s-2); }

/* CARDS + GRIDS */
.grid-3 { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--s-6); }
.grid-2 { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: var(--s-6); }
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--s-8) var(--s-8) var(--s-6); box-shadow: var(--shadow-sm); transition: box-shadow 0.16s cubic-bezier(0.2,0,0,1), transform 0.16s; }
.card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.card h3 { margin-top: 0; margin-bottom: var(--s-3); color: var(--brand-blue-deep); font-size: 22px; }
.card h3 a { color: inherit; text-decoration: none; }
.card h3 a:hover { color: var(--brand-blue); text-decoration: none; }
.card p:last-child { margin-bottom: 0; }
.page-section.dark .card { background: rgba(255,255,255,0.04); border-color: var(--border-dark); color: var(--fg-inverse); }
.page-section.dark .card h3 { color: #fff; }

/* FIELD WORK IMAGE GRID */
.fieldwork-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--s-3); }
.fieldwork-grid img { width: 100%; height: 100%; object-fit: cover; border-radius: var(--radius-lg); aspect-ratio: 4/3; }
.fieldwork-split { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-12); align-items: center; }

/* CITY CHIPS */
.city-chips { display: flex; gap: var(--s-2); flex-wrap: wrap; list-style: none; padding: 0; margin: 0; }
.city-chips li { margin: 0; }
.city-chips a { display: inline-block; padding: var(--s-2) var(--s-4); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); font-size: 14px; font-weight: 500; color: var(--fg); text-decoration: none; background: #fff; transition: all 0.16s cubic-bezier(0.2,0,0,1); }
.city-chips a:hover { border-color: var(--brand-blue); color: var(--brand-blue); background: var(--bg-tint); text-decoration: none; }

/* FAQ BLOCK */
.faq-block { background: var(--ink-050); padding: var(--s-12) 0; }
.faq-block .container { max-width: 860px; }
.faq-block h2 { margin: 0 0 var(--s-10); text-align: center; }
.faq-item { background: #fff; border: 1px solid var(--border); border-radius: var(--radius-lg); padding: var(--s-8) var(--s-8); margin-bottom: var(--s-4); box-shadow: var(--shadow-xs); }
.faq-item h3 { margin: 0 0 var(--s-3); color: var(--brand-blue-deep); font-family: var(--font-body); font-weight: var(--fw-bold); text-transform: none; font-size: 19px; letter-spacing: 0; line-height: 1.4; }
.faq-item p { margin: 0; color: var(--fg); line-height: 1.65; }
.faq-item p:not(:last-child) { margin-bottom: 0.75em; }

/* PAGE WRAP (generic pages) */
.page-wrap { padding: var(--s-16) 0 var(--s-20); }
.page-wrap article { max-width: 820px; margin: 0 auto; }
.page-wrap .entry-title { margin-bottom: var(--s-6); }

/* CTA BAND */
.cta-band { text-align: center; }
.cta-band .container { max-width: 720px; }
.cta-band h2 { margin-bottom: var(--s-5); }
.cta-band p { font-size: 18px; color: var(--fg-muted); margin-bottom: var(--s-8); }

/* FOOTER */
.site-footer { background: var(--brand-blue-deep); color: #cbd8e6; padding: var(--s-10) 0 var(--s-5); margin-top: 0; }
.site-footer a { color: #fff; }
.site-footer a:hover { color: #fff; text-decoration: underline; }
.footer-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: var(--s-10); }
.footer-col p { margin: var(--s-1) 0; font-size: 14px; line-height: 1.5; }
.footer-title { font-family: var(--font-display); font-weight: var(--fw-black); text-transform: uppercase; letter-spacing: 0.01em; color: #fff; font-size: 14px; margin: 0 0 var(--s-3); }
.footer-cert { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.6); }
.footer-bottom { border-top: 1px solid rgba(255,255,255,0.12); margin-top: var(--s-8); padding-top: var(--s-5); text-align: center; font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.12em; text-transform: uppercase; color: rgba(255,255,255,0.55); }

/* MOBILE NAV TOGGLE (CSS-only, works without JS) */
input.nav-toggle { position: absolute !important; left: -9999px !important; top: -9999px !important; width: 1px !important; height: 1px !important; opacity: 0 !important; pointer-events: none !important; }
label.nav-toggle-label { display: none; align-items: center; gap: var(--s-2); padding: var(--s-2) var(--s-3); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); background: #fff; font-family: var(--font-body); font-size: 14px; font-weight: var(--fw-bold); cursor: pointer; user-select: none; color: var(--fg); }
.nav-toggle-label:hover { border-color: var(--brand-blue); color: var(--brand-blue); }
.nav-toggle-label .bars { display: inline-block; width: 16px; height: 2px; background: currentColor; position: relative; }
.nav-toggle-label .bars::before, .nav-toggle-label .bars::after { content: ""; position: absolute; left: 0; width: 16px; height: 2px; background: currentColor; }
.nav-toggle-label .bars::before { top: -5px; }
.nav-toggle-label .bars::after { top: 5px; }

/* BLOG ARCHIVE + SINGLE */
.blog-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(320px, 1fr)); gap: var(--s-6); }
.blog-card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; box-shadow: var(--shadow-sm); transition: box-shadow 0.16s cubic-bezier(0.2,0,0,1), transform 0.16s; display: flex; flex-direction: column; }
.blog-card:hover { box-shadow: var(--shadow-md); transform: translateY(-2px); }
.blog-card-image-link { display: block; aspect-ratio: 16/9; overflow: hidden; background: var(--ink-050); }
.blog-card-image { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform 0.3s cubic-bezier(0.2,0,0,1); }
.blog-card:hover .blog-card-image { transform: scale(1.03); }
.blog-card-image--placeholder { background: linear-gradient(135deg, var(--brand-blue-tint), var(--ink-100)); }
.blog-card-body { padding: var(--s-6) var(--s-6) var(--s-5); display: flex; flex-direction: column; flex: 1; }
.blog-card-kicker { font-family: var(--font-mono); font-size: 10px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--brand-blue); margin-bottom: var(--s-2); display: block; }
.blog-card-title { font-family: var(--font-body); font-size: 20px; line-height: 1.3; font-weight: var(--fw-bold); text-transform: none; letter-spacing: 0; margin: 0 0 var(--s-3); color: var(--brand-blue-deep); }
.blog-card-title a { color: inherit; text-decoration: none; }
.blog-card-title a:hover { color: var(--brand-blue); }
.blog-card-excerpt { font-size: 15px; line-height: 1.55; color: var(--fg-muted); margin: 0 0 var(--s-5); flex: 1; }
.blog-card-meta { display: flex; justify-content: space-between; align-items: center; font-size: 13px; color: var(--fg-subtle); font-family: var(--font-mono); text-transform: uppercase; letter-spacing: 0.08em; }
.blog-card-meta time { color: var(--fg-subtle); }
.blog-card-read-more { color: var(--brand-blue); font-weight: var(--fw-bold); text-transform: none; letter-spacing: 0; font-family: var(--font-body); text-decoration: none; }
.blog-card-read-more:hover { color: var(--brand-blue-deep); }
.blog-pagination { margin-top: var(--s-10); text-align: center; }
.blog-pagination .page-numbers { display: inline-block; padding: var(--s-2) var(--s-4); margin: 0 var(--s-1); border: 1px solid var(--border-strong); border-radius: var(--radius-sm); color: var(--fg); text-decoration: none; background: #fff; font-weight: 500; }
.blog-pagination .page-numbers.current { background: var(--brand-blue); color: #fff; border-color: var(--brand-blue); }
.blog-pagination .page-numbers:hover { border-color: var(--brand-blue); color: var(--brand-blue); }

.single-post .breadcrumb { font-family: var(--font-mono); font-size: 11px; letter-spacing: 0.14em; text-transform: uppercase; color: var(--fg-muted); margin-bottom: var(--s-4); display: block; }
.single-post .breadcrumb a { color: var(--brand-blue); text-decoration: none; }
.single-post .breadcrumb a:hover { color: var(--brand-blue-deep); }
.post-featured-image { padding: 0; margin-bottom: var(--s-8); }
.post-featured-image .container { max-width: 1100px; }
.post-featured { width: 100%; height: auto; border-radius: var(--radius-lg); box-shadow: var(--shadow-md); display: block; aspect-ratio: 16/9; object-fit: cover; }
.post-body .container { max-width: 780px; }
.post-content { font-size: 17px; line-height: 1.7; color: var(--fg); }
.post-content h2 { font-family: var(--font-display); font-weight: var(--fw-bold); text-transform: none; letter-spacing: 0; font-size: clamp(26px, 3vw, 34px); line-height: 1.2; margin: var(--s-10) 0 var(--s-4); color: var(--brand-blue-deep); }
.post-content h3 { font-family: var(--font-body); font-weight: var(--fw-bold); text-transform: none; letter-spacing: 0; font-size: 22px; line-height: 1.3; margin: var(--s-8) 0 var(--s-3); color: var(--brand-blue-deep); }
.post-content p { margin: 0 0 var(--s-5); }
.post-content ul, .post-content ol { margin: 0 0 var(--s-5); padding-left: var(--s-6); }
.post-content li { margin-bottom: var(--s-2); }
.post-content a { color: var(--brand-blue); text-decoration: underline; text-underline-offset: 2px; }
.post-content a:hover { color: var(--brand-blue-deep); }
.post-content table { width: 100%; border-collapse: collapse; margin: var(--s-6) 0; font-size: 15px; }
.post-content th, .post-content td { padding: var(--s-3) var(--s-4); text-align: left; border-bottom: 1px solid var(--border); }
.post-content th { background: var(--ink-050); font-weight: var(--fw-bold); color: var(--brand-blue-deep); }
.post-content blockquote { border-left: 4px solid var(--brand-blue); padding: var(--s-3) var(--s-5); margin: var(--s-6) 0; background: var(--bg-tint); border-radius: 0 var(--radius-md) var(--radius-md) 0; font-style: italic; color: var(--fg); }
.post-content strong { color: var(--brand-blue-deep); }

/* CONTACT FORM 7 STYLING */
.apb-form-intro { margin-bottom: var(--s-6); font-size: 16px; line-height: 1.6; color: var(--fg); }
.apb-form-intro p { margin: 0; }
.apb-form-intro a { color: var(--brand-safety-red); font-weight: var(--fw-bold); text-decoration: none; }
.apb-form-intro a:hover { text-decoration: underline; }
.apb-form-row { display: grid; grid-template-columns: 1fr 1fr; gap: var(--s-4); margin-bottom: var(--s-4); }
.apb-form-row .wpcf7-form-control-wrap { display: block; }
.wpcf7-form { font-family: var(--font-body); }
.wpcf7-form p { margin: 0 0 var(--s-4); }
.wpcf7-form label { display: block; font-size: 14px; font-weight: var(--fw-bold); color: var(--brand-blue-deep); margin-bottom: var(--s-2); letter-spacing: 0.01em; }
.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"], .wpcf7-form input[type="url"], .wpcf7-form textarea, .wpcf7-form select { width: 100%; padding: 12px 14px; font-family: var(--font-body); font-size: 16px; line-height: 1.4; color: var(--fg); background: #fff; border: 1px solid var(--border-strong); border-radius: var(--radius-sm); transition: border-color 0.16s cubic-bezier(0.2,0,0,1), box-shadow 0.16s; -webkit-appearance: none; appearance: none; }
.wpcf7-form input[type="text"]:focus, .wpcf7-form input[type="email"]:focus, .wpcf7-form input[type="tel"]:focus, .wpcf7-form textarea:focus, .wpcf7-form select:focus { outline: none; border-color: var(--brand-blue); box-shadow: 0 0 0 3px rgba(6, 97, 168, 0.15); }
.wpcf7-form input::placeholder, .wpcf7-form textarea::placeholder { color: var(--fg-subtle); opacity: 1; }
.wpcf7-form select { background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%230661a8' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; background-size: 18px; padding-right: 44px; cursor: pointer; }
.wpcf7-form textarea { min-height: 140px; resize: vertical; }
.wpcf7-form .wpcf7-not-valid-tip { color: var(--brand-safety-red); font-size: 13px; margin-top: var(--s-1); }
.wpcf7-form .wpcf7-not-valid { border-color: var(--brand-safety-red); }
.wpcf7-form .wpcf7-response-output { margin: var(--s-5) 0 0; padding: var(--s-4) var(--s-5); border-radius: var(--radius-md); border: 1px solid var(--border); background: var(--ink-050); font-size: 15px; }
.wpcf7-form.sent .wpcf7-response-output { border-color: var(--status-pass); background: #e8f5ee; color: var(--status-pass); }
.wpcf7-form.invalid .wpcf7-response-output, .wpcf7-form.failed .wpcf7-response-output { border-color: var(--brand-safety-red); background: #fcebe8; color: var(--brand-safety-red); }
.apb-form-submit { margin-top: var(--s-6) !important; }
.wpcf7-form .wpcf7-submit { display: inline-flex; align-items: center; gap: var(--s-2); border: 0; border-radius: var(--radius-sm); padding: 14px 28px; font-family: var(--font-body); font-weight: var(--fw-bold); font-size: 16px; cursor: pointer; letter-spacing: 0.01em; background: var(--brand-safety-red); color: #fff; transition: background 0.16s; }
.wpcf7-form .wpcf7-submit:hover { background: #a42818; }
.wpcf7-form .wpcf7-submit:disabled { opacity: 0.5; cursor: not-allowed; }
.wpcf7-form .wpcf7-spinner { margin-left: var(--s-2); }
.apb-form-fineprint { font-size: 13px; color: var(--fg-muted); margin-top: var(--s-4) !important; }
.wpcf7 .wpcf7-list-item { display: inline-block; margin: 0 var(--s-4) var(--s-2) 0; }
.wpcf7-form select option { padding: var(--s-2); }

/* RESPONSIVE */
@media (max-width: 720px) {
	.apb-form-row { grid-template-columns: 1fr; gap: var(--s-3); }
}
@media (max-width: 960px) {
	.hero .wrap { grid-template-columns: 1fr; gap: var(--s-8); }
	.hero .photo { aspect-ratio: 16/10; }
	.fieldwork-split { grid-template-columns: 1fr; gap: var(--s-8); }
	.trust-row-inner { gap: var(--s-4); }
	.header-inner { flex-wrap: wrap; }
	label.nav-toggle-label { display: inline-flex; order: 3; }
	.primary-nav { order: 4; width: 100%; display: none; border-top: 1px solid var(--hairline); margin: var(--s-3) calc(-1 * var(--s-6)) 0; padding: var(--s-3) var(--s-6) 0; }
	input.nav-toggle:checked ~ .primary-nav { display: block; }
	.nav-list { flex-direction: column; gap: var(--s-1); }
	.nav-list > li { position: static; }
	.nav-list a { display: block; padding: var(--s-3) 0; border-bottom: 1px solid rgba(255,255,255,0.1); }
	.nav-list .sub-menu { position: static; box-shadow: none; border: 0; background: transparent; padding: 0 0 0 var(--s-4); min-width: 0; display: block; }
	.nav-list .sub-menu a { color: rgba(255,255,255,0.75) !important; padding: var(--s-2) 0; font-size: 14px; }
	.nav-list .sub-menu a:hover { color: #ffffff !important; background: transparent; }
}
@media (max-width: 720px) {
	.container { padding: 0 var(--s-5); }
	.header-inner { gap: var(--s-3); padding: var(--s-3) var(--s-4); }
	.header-cert { display: none; }
	.apb-phone .label { display: none; }
	.wordmark-sub { display: none; }
	.logo-mark { height: 56px; }
	.header-cta { gap: var(--s-2); }
	.header-cta .apb-phone .num { font-size: 16px; }
	.page-section { padding: var(--s-10) 0; }
	.hero { padding: var(--s-8) 0 var(--s-10); }
	.faq-block { padding: var(--s-10) 0; }
	.faq-item { padding: var(--s-5) var(--s-6); }
	.card { padding: var(--s-5) var(--s-5) var(--s-4); }
	.site-footer { padding-top: var(--s-10); margin-top: var(--s-10); }
	.hero h1 { font-size: clamp(40px, 11vw, 56px); }
	h2 { font-size: clamp(26px, 7vw, 36px); }
	.btn-lg { padding: 12px 22px; font-size: 15px; }
}
