:root {
  --blue: #004aad;
  --navy: #07254a;
  --ink: #0d1520;
  --muted: #5d6672;
  --line: #d9dee6;
  --paper: #f7f8fa;
  --dark: #07121d;
  --max: 1168px;
}

* { box-sizing: border-box; }

body {
  margin: 0;
  color: var(--ink);
  background: #fff;
  font-family: Arial, Helvetica, sans-serif;
  line-height: 1.45;
  overflow-x: hidden;
}

a { color: inherit; text-decoration: none; }
img { display: block; max-width: 100%; }

h1, h2, h3, .btn, .main-nav, .quote-btn {
  font-family: "Arial Narrow", Impact, Haettenschweiler, sans-serif;
  letter-spacing: .02em;
  text-transform: uppercase;
}

.site-header {
  position: sticky;
  top: 0;
  z-index: 20;
  display: grid;
  grid-template-columns: 230px 1fr 158px;
  align-items: start;
  height: 90px;
  background: #fff;
  box-shadow: 0 1px 0 rgba(0,0,0,.08);
}

.brand {
  position: relative;
  height: 120px;
  padding: 14px 0 0 44px;
  background: #fff;
  z-index: 2;
}

.brand::after {
  content: "";
  position: absolute;
  right: -53px;
  bottom: 0;
  border-style: solid;
  border-width: 53px 53px 0 0;
  border-color: #fff transparent transparent transparent;
}

.brand img { width: 95px; height: auto; }

.main-nav {
  display: flex;
  justify-content: center;
  gap: 45px;
  height: 90px;
  align-items: center;
  font-size: 16px;
}

.main-nav a {
  position: relative;
  padding: 34px 0 31px;
}

.main-nav a.active,
.main-nav a:hover { color: var(--blue); }

.main-nav a.active::after,
.main-nav a:hover::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  bottom: 22px;
  height: 2px;
  background: var(--blue);
}

.quote-btn, .btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 44px;
  padding: 0 25px;
  border: 1px solid var(--blue);
  background: var(--blue);
  color: #fff;
  font-size: 18px;
  font-weight: 800;
}

.quote-btn {
  align-self: center;
  justify-self: end;
  margin-right: 36px;
  min-width: 130px;
  height: 39px;
  font-size: 16px;
}

.btn.outline {
  background: transparent;
  border-color: rgba(255,255,255,.9);
}

.menu-toggle { display: none; }

.hero {
  position: relative;
  min-height: 438px;
  color: #fff;
  background-image: linear-gradient(90deg, rgba(0,8,14,.96), rgba(0,10,18,.75) 39%, rgba(0,15,28,.22) 70%), url("assets/hero-clean-full.png");
  background-size: cover;
  background-position: center;
}

.quote-hero {
  min-height: 394px;
  background-image: linear-gradient(90deg, rgba(0,8,14,.95), rgba(0,10,18,.68) 42%, rgba(0,0,0,.18) 72%), url("assets/quote-clean-full.png");
}

.hero-copy {
  width: min(92vw, var(--max));
  margin: 0 auto;
  padding-top: 78px;
}

.home-hero .hero-copy,
.quote-hero .hero-copy { max-width: var(--max); }

.hero h1 {
  max-width: 680px;
  margin: 0 0 22px;
  font-size: clamp(48px, 7vw, 80px);
  line-height: .98;
  font-weight: 900;
}

.hero h1 span {
  display: block;
  color: var(--blue);
}

.hero.home-hero h1 {
  max-width: 920px;
  font-size: clamp(48px, 5.2vw, 64px);
}

.hero.home-hero h1 span {
  white-space: nowrap;
}

.hero p {
  max-width: 495px;
  margin: 0 0 28px;
  font-size: 21px;
}

.button-row { display: flex; gap: 27px; flex-wrap: wrap; }

.inner-hero .hero-copy { padding-top: 76px; }
.inner-hero h1 {
  max-width: 920px;
  font-size: clamp(54px, 7vw, 78px);
  white-space: nowrap;
}
.inner-hero i, .section-head i, .hero-copy > i, .who i, .band-copy i, .focus-card i, .form-title + * { display: block; }
.inner-hero i, .section-head i, .hero-copy > i, .who i, .band-copy i, .focus-card i {
  width: 54px;
  height: 3px;
  margin: 18px 0 20px;
  background: var(--blue);
}

.quote-hero h2 {
  margin: 0;
  color: #0d68d5;
  font-size: 28px;
}

.quote-hero h1 {
  margin-top: 6px;
  max-width: 640px;
  color: #fff;
  font-family: Arial, Helvetica, sans-serif;
  font-size: clamp(48px, 5.4vw, 64px);
  font-weight: 800;
  line-height: 1.04;
  letter-spacing: 0;
  text-transform: none;
  white-space: nowrap;
}

.service-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  width: min(100%, var(--max));
  margin: 0 auto;
  padding: 29px 0 27px;
}

.service-strip article {
  min-height: 260px;
  padding: 0 42px;
  text-align: center;
  border-right: 1px solid var(--line);
}

.service-strip article:last-child { border-right: 0; }

.icon, .round-icon, .mini, .line-icon, .target {
  display: inline-block;
  width: 64px;
  height: 64px;
  color: var(--blue);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
}

.icon.cube, .mini.cube { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 4 57 18v28L32 60 7 46V18L32 4Z'/%3E%3Cpath d='M7 18l25 14 25-14M32 32v28'/%3E%3C/svg%3E"); }
.icon.bolt, .round-icon.bolt { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 8h24l8 18-20 30L12 26 20 8Z'/%3E%3Ccircle cx='32' cy='28' r='8'/%3E%3C/svg%3E"); }
.icon.gear, .round-icon.gear, .line-icon.gear { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='32' cy='32' r='10'/%3E%3Cpath d='M32 4v10M32 50v10M4 32h10M50 32h10M12 12l7 7M45 45l7 7M52 12l-7 7M19 45l-7 7M24 6l4 8M40 6l-4 8M24 58l4-8M40 58l-4-8'/%3E%3C/svg%3E"); }
.icon.tools, .mini.tools { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' stroke-linecap='round' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 10l40 40M46 6l12 12-8 8-12-12 8-8ZM18 58 6 46l14-14 12 12-14 14Z'/%3E%3C/svg%3E"); }

.service-strip h2,
.capability-cards h2,
.values h3,
.core-grid h3 {
  margin: 16px 0 9px;
  color: #073a85;
  font-size: 20px;
  line-height: 1.18;
}

.service-strip i,
.capability-cards i,
.values i {
  display: block;
  width: 31px;
  height: 2px;
  margin: 0 auto 18px;
  background: var(--blue);
}

.service-strip p,
.capability-cards p,
.values p,
.core-grid p { margin: 0; font-size: 14px; }

.service-strip a,
.capability-cards a {
  display: inline-block;
  margin-top: 26px;
  color: #073a85;
  font-family: "Arial Narrow", Impact, sans-serif;
  font-size: 16px;
  font-weight: 900;
  text-transform: uppercase;
}

.split-band {
  display: grid;
  grid-template-columns: 1fr 1fr;
  min-height: 262px;
}

.band-image.gold {
  background: url("assets/gold-parts.png") center/cover no-repeat;
}

.band-copy {
  padding: 42px 64px;
  color: #fff;
}

.band-copy.blue {
  background: linear-gradient(115deg, #05337a, #0056c8 58%, #003579);
}

.band-copy h2 {
  margin: 0;
  font-size: 31px;
  line-height: 1.08;
}

.band-copy h2 span { display: block; }

.band-copy p {
  max-width: 480px;
  margin: 0 0 24px;
  font-size: 16px;
}

.industries-choice {
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: center;
  background: var(--paper);
}

.industries, .why {
  padding: 30px 54px;
}

.industries h2, .why h2 {
  margin: 0 0 20px;
  color: #073a85;
  font-size: 24px;
}

.mini-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}

.mini-grid article {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-start;
  min-height: 86px;
  padding: 0 12px;
  text-align: center;
  border-right: 1px solid var(--line);
}

.mini-grid article:last-child { border-right: 0; }

.mini { width: 42px; height: 42px; margin: 0 auto 8px; }
.mini.food { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 26h40v26H12zM18 26c0-9 6-15 14-15s14 6 14 15M8 52h48'/%3E%3C/svg%3E"); }
.mini.helmet { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 34C12 18 22 8 36 10c10 1 18 10 18 22v16H10V34Z'/%3E%3Cpath d='M33 11c-2 8-3 22 6 37'/%3E%3C/svg%3E"); }
.mini.factory { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 54h48V22L39 34V22L22 34V16H8v38Z'/%3E%3Cpath d='M18 44h6M31 44h6M44 44h6'/%3E%3C/svg%3E"); }
.mini.cnc { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M10 12h44v36H10zM18 20h18v20H18zM42 20h6v8h-6zM8 52h48'/%3E%3C/svg%3E"); }
.mini.press { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M16 12h32M20 48h24M32 12v18M24 30h16v8H24zM18 54h28'/%3E%3C/svg%3E"); }
.mini.inspect { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M18 44 46 16M16 22l10-10 8 8-10 10zM30 48l12-12 8 8-12 12z'/%3E%3C/svg%3E"); }
.mini.truck { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M8 18h34v28H8zM42 28h10l6 8v10H42z'/%3E%3Ccircle cx='20' cy='48' r='5'/%3E%3Ccircle cx='49' cy='48' r='5'/%3E%3C/svg%3E"); }

.mini-grid b {
  display: block;
  width: 100%;
  color: #07121d;
  font-size: 12px;
  line-height: 1.25;
  text-align: center;
  text-transform: uppercase;
}

.why li {
  list-style: none;
  margin: 8px 0;
  font-size: 15px;
}

.why li::before {
  content: "✓";
  display: inline-grid;
  place-items: center;
  width: 18px;
  height: 18px;
  margin-right: 11px;
  border-radius: 50%;
  background: var(--blue);
  color: #fff;
  font-size: 12px;
}

.site-footer {
  color: #fff;
  background: linear-gradient(90deg, #07121d, #102435);
}

.footer-main {
  position: relative;
  display: grid;
  grid-template-columns: 220px 230px 1fr;
  gap: 30px;
  width: min(100%, var(--max));
  margin: 0 auto;
  padding: 31px 48px;
}

.footer-main.four {
  grid-template-columns: 1.1fr 1.2fr 1fr 1.1fr;
}

.footer-main section {
  min-height: 145px;
  padding-right: 28px;
  border-right: 1px solid rgba(255,255,255,.24);
}

.footer-main section:last-of-type { border-right: 0; }

.footer-brand img { width: 116px; margin-bottom: 12px; }
.footer-main h2 {
  margin: 0 0 17px;
  color: #0068d9;
  font-size: 22px;
}

.footer-main p { margin: 0 0 8px; font-size: 16px; }
.footer-main a { color: #fff; }
.contact-line::before, .contact-dot::before {
  display: inline-grid;
  place-items: center;
  margin-right: 13px;
  color: #fff;
}
.phone::before { content: "☎"; }
.mail::before { content: "✉"; }
.pin::before { content: "●"; }
.footer-parts {
  position: absolute;
  right: 48px;
  bottom: 0;
  width: 235px;
}

.footer-bottom {
  display: flex;
  justify-content: center;
  gap: 50px;
  padding: 14px 24px;
  background: #004aad;
  font-size: 15px;
}

.footer-bottom p { margin: 0; }

.section-head {
  width: min(92vw, var(--max));
  margin: 0 auto;
  padding: 24px 0 20px;
  text-align: center;
}

.section-head h2 {
  margin: 0;
  color: #073a85;
  font-size: 39px;
}

.section-head i { margin: 5px auto 10px; }
.section-head p { margin: 0; font-size: 17px; }
.section-head.compact { padding-bottom: 5px; }

.capability-cards {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 14px;
  width: min(92vw, var(--max));
  margin: 0 auto 22px;
}

.capability-cards article {
  position: relative;
  min-height: 369px;
  overflow: hidden;
  border: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: 0 2px 12px rgba(0,0,0,.08);
  text-align: center;
}

.capability-cards img { width: 100%; height: 144px; object-fit: cover; }
.round-icon {
  position: relative;
  width: 67px;
  height: 67px;
  margin-top: -36px;
  border: 4px solid #fff;
  border-radius: 50%;
  background-color: #073a85;
  background-size: 36px;
}
.round-icon.cube { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23ffffff' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 4 57 18v28L32 60 7 46V18L32 4Z'/%3E%3Cpath d='M7 18l25 14 25-14M32 32v28'/%3E%3C/svg%3E"); }
.round-icon.bolt { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23ffffff' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M20 8h24l8 18-20 30L12 26 20 8Z'/%3E%3Ccircle cx='32' cy='28' r='8'/%3E%3C/svg%3E"); }
.round-icon.gear { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23ffffff' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='32' cy='32' r='10'/%3E%3Cpath d='M32 4v10M32 50v10M4 32h10M50 32h10M12 12l7 7M45 45l7 7M52 12l-7 7M19 45l-7 7M24 6l4 8M40 6l-4 8M24 58l4-8M40 58l-4-8'/%3E%3C/svg%3E"); }
.round-icon.tools { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23ffffff' stroke-width='3' stroke-linecap='round' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 10l40 40M46 6l12 12-8 8-12-12 8-8ZM18 58 6 46l14-14 12 12-14 14Z'/%3E%3C/svg%3E"); }
.capability-cards h2, .capability-cards p { padding: 0 24px; }

.core-grid {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  width: min(92vw, var(--max));
  margin: 0 auto 32px;
  text-align: center;
}

.core-grid article {
  min-height: 145px;
  padding: 0 26px;
  border-right: 1px solid var(--line);
}

.core-grid article:last-child { border-right: 0; }
.core-grid .mini { width: 54px; height: 54px; margin-bottom: 4px; }
.core-grid h3 { font-size: 16px; margin: 0 0 4px; }

.cta-image {
  min-height: 167px;
  color: #fff;
  background-image: linear-gradient(90deg, rgba(5,18,31,.95), rgba(7,24,37,.7) 35%, rgba(8,15,22,.2)), url("assets/mission-parts.png");
  background-size: cover;
  background-position: center right;
}

.cta-image div {
  width: min(92vw, var(--max));
  margin: 0 auto;
  padding: 27px 12px;
}

.cta-image h2 {
  margin: 0 0 7px;
  font-size: 32px;
}

.cta-image p { max-width: 390px; margin: 0 0 17px; }

.about-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 360px;
  align-items: center;
  gap: 40px;
  padding: 34px calc((100% - min(92vw, var(--max))) / 2) 30px;
}

.about-hero .hero-copy {
  width: auto;
  margin: 0;
  padding-top: 0;
}

.about-hero h1 {
  line-height: 1.05;
}

.about-hero h1 span {
  margin-top: 14px;
  font-size: clamp(38px, 4vw, 45px);
  line-height: 1.14;
  letter-spacing: 0;
  text-transform: none;
}

.focus-card {
  padding: 25px 34px;
  border: 1px solid var(--blue);
  border-radius: 4px;
  background: rgba(5,20,34,.86);
}

.focus-card h2 { margin: 0; font-size: 26px; }
.focus-card p { margin: 18px 0 0; font-size: 14px; }

.who {
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  gap: 66px;
  width: min(92vw, var(--max));
  margin: 0 auto;
  padding: 29px 0;
}

.who h2, .build-row h2 {
  margin: 0;
  color: #073a85;
  font-size: 38px;
}

.who p { max-width: 430px; font-size: 17px; }
.who img, .build-row img { border-radius: 4px; }

.values {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  width: min(92vw, var(--max));
  margin: 0 auto 24px;
}

.values article {
  min-height: 224px;
  padding: 24px 20px;
  border: 1px solid var(--line);
  border-radius: 4px;
  box-shadow: 0 2px 10px rgba(0,0,0,.08);
  text-align: center;
}

.line-icon.badge { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='32' cy='25' r='16'/%3E%3Cpath d='m22 39-5 18 15-8 15 8-5-18'/%3E%3C/svg%3E"); }
.line-icon.flex { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 8v48M32 8 20 22M32 8l12 14M14 18c8 7 13 14 14 25M50 18c-8 7-13 14-14 25'/%3E%3C/svg%3E"); }
.line-icon.chat { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12 16h40v28H28L14 54V44h-2V16Z'/%3E%3Cpath d='M23 29h18'/%3E%3C/svg%3E"); }
.line-icon.pin { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 58S14 39 14 25a18 18 0 0 1 36 0c0 14-18 33-18 33Z'/%3E%3Ccircle cx='32' cy='25' r='7'/%3E%3C/svg%3E"); }
.line-icon.headset { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M14 36v-7a18 18 0 0 1 36 0v7M14 36h8v14h-8zM42 36h8v14h-8zM42 56h-8'/%3E%3C/svg%3E"); }
.line-icon.shield { background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='3' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M32 6 52 14v15c0 15-8 24-20 29-12-5-20-14-20-29V14L32 6Z'/%3E%3Cpath d='m22 31 7 7 14-16'/%3E%3C/svg%3E"); }

.mission {
  display: grid;
  grid-template-columns: 92px 1fr;
  align-items: center;
  min-height: 176px;
  padding-left: calc((100% - min(92vw, var(--max))) / 2);
  color: #fff;
  background-image: linear-gradient(90deg, rgba(0,63,135,.9), rgba(0,73,168,.78) 46%, rgba(0,0,0,.25)), url("assets/mission-parts.png");
  background-size: cover;
  background-position: center right;
}

.target {
  width: 78px;
  height: 78px;
  filter: brightness(0) invert(1);
  background-image: url("data:image/svg+xml,%3Csvg fill='none' stroke='%23004aad' stroke-width='4' viewBox='0 0 64 64' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='32' cy='32' r='25'/%3E%3Ccircle cx='32' cy='32' r='15'/%3E%3Ccircle cx='32' cy='32' r='5'/%3E%3Cpath d='M32 2v10M32 52v10M2 32h10M52 32h10'/%3E%3C/svg%3E");
}

.mission h2 { margin: 0; font-size: 29px; }
.mission i { display: block; width: 42px; height: 2px; margin: 5px 0 10px; background: #fff; }
.mission p { margin: 0; max-width: 540px; font-family: "Arial Narrow", Impact, sans-serif; font-size: 34px; font-weight: 900; line-height: 1.12; }

.build-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 44px;
  width: min(92vw, var(--max));
  margin: 0 auto;
  padding: 12px 0;
  align-items: center;
}

.build-row p { margin: 9px 0 18px; }

.quote-layout {
  display: grid;
  grid-template-columns: minmax(0, 2fr) 340px;
  width: min(100%, var(--max));
  margin: 0 auto;
  background: #fff;
}

.quote-form {
  padding: 44px 48px 28px;
}

.form-title {
  display: flex;
  gap: 20px;
  align-items: center;
  padding-bottom: 22px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 24px;
}

.form-title .icon { width: 48px; height: 48px; }
.form-title h2, .help-panel h2 {
  margin: 0;
  color: #073a85;
  font-size: 28px;
}
.form-title p { margin: 3px 0 0; }

.form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 17px 32px;
}

label {
  display: block;
  color: #111;
  font-size: 14px;
  font-weight: 700;
}

label b { color: #d93434; }
input, select, textarea {
  width: 100%;
  min-height: 41px;
  margin-top: 8px;
  padding: 0 14px;
  border: 1px solid #ccd2d9;
  border-radius: 3px;
  background: #fff;
  color: var(--ink);
  font: inherit;
  font-weight: 400;
}

textarea {
  min-height: 99px;
  padding-top: 12px;
  resize: vertical;
}

.wide { margin-top: 17px; }
small { color: #697480; font-size: 12px; font-weight: 400; }

.upload {
  margin-top: 16px;
}

.upload span {
  display: block;
  margin-top: 8px;
  padding: 22px;
  border: 1px dashed #ccd2d9;
  border-radius: 3px;
  text-align: center;
  color: #073a85;
  font-weight: 400;
}

.upload b { font-size: 34px; color: var(--blue); }
.upload input { display: none; }
.secure { color: #697480; font-size: 12px; }
.submit-btn { border-radius: 2px; }

.help-panel {
  padding: 49px 45px;
  background: #f2f4f7;
}

.contact-dot {
  display: grid;
  grid-template-columns: 38px 1fr;
  gap: 12px;
  align-items: center;
  margin: 20px 0;
  font-size: 17px;
}

.contact-dot::before {
  width: 35px;
  height: 35px;
  margin: 0;
  border-radius: 50%;
  background: #073a85;
}

.help-panel hr {
  border: 0;
  border-top: 1px solid var(--line);
  margin: 38px 0;
}

.help-panel article {
  display: grid;
  grid-template-columns: 56px 1fr;
  gap: 18px;
  margin: 24px 0;
}

.help-panel .line-icon { width: 56px; height: 56px; }
.help-panel p { font-size: 15px; }

@media (max-width: 900px) {
  .site-header {
    grid-template-columns: 150px 1fr 110px;
    height: 78px;
  }

  .brand { height: 78px; padding-left: 20px; }
  .brand::after { display: none; }
  .brand img { width: 78px; }

  .menu-toggle {
    display: block;
    justify-self: center;
    align-self: center;
    border: 1px solid var(--line);
    background: #fff;
    color: var(--navy);
    font-weight: 800;
  }

  .main-nav {
    position: absolute;
    left: 0;
    right: 0;
    top: 78px;
    display: none;
    height: auto;
    padding: 10px 22px 20px;
    background: #fff;
    box-shadow: 0 10px 20px rgba(0,0,0,.12);
  }

  .main-nav.open { display: grid; gap: 0; }
  .main-nav a { padding: 12px 0; }
  .main-nav a.active::after, .main-nav a:hover::after { bottom: 7px; }
  .quote-btn { min-width: 100px; margin-right: 12px; padding: 0 10px; font-size: 14px; }
  .hero.home-hero h1 span { white-space: normal; }

  .service-strip,
  .capability-cards,
  .values,
  .core-grid,
  .industries-choice,
  .split-band,
  .who,
  .build-row,
  .quote-layout,
  .about-hero {
    grid-template-columns: 1fr;
  }

  .service-strip article,
  .core-grid article,
  .mini-grid article,
  .footer-main section { border-right: 0; }

  .service-strip article { border-bottom: 1px solid var(--line); padding: 28px; }
  .mini-grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
  .band-image.gold { min-height: 250px; }
  .about-hero { padding: 50px 4vw; }
  .focus-card { width: 100%; }
  .mission { padding: 30px 4vw; grid-template-columns: 80px 1fr; }
  .quote-form, .help-panel { padding: 34px 24px; }
  .form-grid { grid-template-columns: 1fr; }
  .footer-main, .footer-main.four { grid-template-columns: 1fr; padding: 30px 24px; }
  .footer-parts { display: none; }
}

@media (max-width: 560px) {
  .site-header { grid-template-columns: 110px 1fr; }
  .quote-btn { display: none; }
  .hero-copy { padding-top: 48px; }
  .hero h1 { font-size: 46px; }
  .inner-hero h1,
  .quote-hero h1,
  .home-hero h1 span { white-space: normal; }
  .hero p { font-size: 18px; }
  .button-row .btn { width: 100%; }
  .footer-bottom { display: grid; gap: 8px; text-align: center; }
}
