
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  font-family: Arial, sans-serif;
}
:root {
  --big-fs: 5em;
}
body {
  	line-height: 1.2;
  	color: #333;
	display: flex;
	flex-direction: column;
	margin: 0 auto;
}

.container {
  width: 90%;
  max-width: 1200px;
		margin: 0 auto;
}

header {
  background: #13161f;
  color: #fff;
	font-weight: 600;
		display: flex;
	flex-direction: row;
	width: 100%;
	align-content: center;
	align-items: center;
	justify-content: center;
	padding: 0;
	filter: drop-shadow(0px 0px 10px #000);
}

header .container {
	display: flex;
	align-content: center;
	align-items: center;
	justify-content: space-between;
	width: 100%;
	padding: 0 !important;
}


#headerlogo {
	
	height: 28px;
}

header h1 {
  float: left;
  margin-left: 10px;
}

header nav {
  float: right;
  margin-right: 14px;
}

header nav ul {
  list-style: none;
	padding-bottom: 10px;
}

header nav ul li {
  display: inline-block;
  margin-left: 15px;
}

header nav ul li a {
  color: #fff;
  text-decoration: none;
	transition: 0.2s;
}

header nav ul li a:hover {
  color: #27bbFF;
}


h3 {
	font-size: 24px;
	color: #000;
	font-weight: 600;
	margin-bottom: 4px;
}

.hero {
  background: #000000aa url('images/hero.jpg') center/cover;
  padding: 60px 20px;
  text-align: center;
	height: 85vh;
  color: #fff;
background-blend-mode: overlay;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}

.hero .container {
	margin: auto 0;
}
.hero .container a {
	margin-left: 4px;
	margin-right: 4px;
}

.service-areas-hero .why-choose {
  background: rgba(255,255,255,0.0);
	padding: 0;
}

.service-areas-hero .why-choose .container {
  margin: 0 auto;
	display: flex;
	justify-content: center;
}
.service-areas-hero .why-choose ul {
	margin: 0 auto;
	display: flex;
	justify-content: center;
}
.service-areas-hero .why-choose ul li {
	
color: #333;
}
.hero h2 {
  font-size: 2rem;
}

.hero p {
  margin: 10px 0;
}

.cta-btn {
  display: inline-block;
  background: #27aae1;
  color: #fff;
  padding: 8px 24px;
  text-decoration: none;
  margin-top: 10px;
	border-radius: 6px;
	font-weight: 600;
	border: 1px solid #0077bb;
	filter: drop-shadow(2px 2px 6px #00000020);
	transition: .2s;
	box-sizing: border-box;
}
.cta-btn:hover {
	background: #0077bb;
	color: #fff !important;
		}
		
.cta-btn-2 {
  display: inline-block;
  background: #000000aa;
  color: #fff;
  padding: 7px 23px;
  text-decoration: none;
  margin-top: 10px;
	border-radius: 6px;
	font-weight: 600;
	border: 2px solid #27aae1;
	filter: drop-shadow(2px 2px 6px #00000020);
	transition: .2s;
	box-sizing: border-box;
}
.cta-btn-2:hover {
	background: #000000e6;
	color: #fff !important;
		}

.how-it-works,
.why-choose,
.services-snapshot {
  padding: 40px 20px;
  background: #fff;
}


.how-it-works {
	position: relative;
}

.how-it-works .steps > div strong {
	display: block;
	font-size: var(--big-fs);
	color: #27aae1;
	font-weight: 900;
	position: absolute;
	z-index: -1;
	top: calc(50% - 4px);
	left: 40px;
	opacity: 0.34;
	transform: translateY(-50%);
}
.how-it-works .steps > div h4 {
	z-index: 5;
	font-size: 22px;
	position: relative;
	margin-left: 56px;
}
.how-it-works .steps > div p {
	z-index: 5;
	position: relative;
	font-weight: 500;
	margin-left: 56px;
}

.how-it-works .steps {
  display: flex;
  padding: 0;
	margin: 0;
  list-style: none;
	flex-direction: row;
	gap: 0;
	align-items: stretch;
}


.how-it-works .steps > div {
  position: relative;
  flex: 1;
  background: #eee;
  padding: 15px 42px;
  margin-right: 0px;     
	filter: drop-shadow(4px 0 10px #00000020);
  display: flex;
  flex-direction: column;
  justify-content: center;
	align-items: center;
	overflow: visible;
	overflow-x: visible;
}

.how-it-works .steps div p, .how-it-works .steps div h4{
width: 100%;
}

.how-it-works .steps > div:first-child {
  margin-right: 0;
	z-index: 3;
	padding-left: 42px;
	border-left: 4px solid #27aae1;
	flex: 0.75;
}
.how-it-works .steps > div:first-child strong {
	margin-left: -32px;
}

.how-it-works .steps > div:nth-child(2) {
	z-index: 2;
	padding-left: 80px; 
}

.how-it-works .steps > div:last-child {
  margin-right: 0;
	z-index: 1;
	border-right: 4px solid #27aae1;
	padding-left: 80px;
}

.how-it-works .steps > div:not(:last-child)::before {
   content: "";
  position: absolute;
  top: 0;          
  height: 100%;
  background: #27aae1;
  right: -34px;        
  width: 30px;         
  clip-path: polygon( 0 0, 6px 0, calc(100% - 3px) 50%, 6px 100%, 0 100% );
  z-index: 1;
}

/* 2) the fill triangle */
.how-it-works .steps > div:not(:last-child)::after {
   content: "";
  position: absolute;
  top: 0;
  right: -26px;
  width: 26px;
  height: 100%;
  background: #eee;
  clip-path: polygon( 0 0, 6px 0, 100% 50%, 6px 100%, 0 100% );
  z-index: 2;
}

.why-choose ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  list-style: none;
  margin: 20px 0 0;
  padding: 0;
}

.why-choose ul li {
  position: relative;
  flex: 1;
  min-width: 180px;
  background: #eee;
  padding: 20px 20px 20px 56px;  /* room for 24px icon + 16px gutter */
  border-radius: 8px;
  box-shadow: 4px 0 10px rgba(0, 0, 0, 0.1);
	  font-weight: 700;    
	display: flex;
  align-items: center;
}

.why-choose ul li::before {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 16px;
  transform: translateY(-50%);
  width: 24px;
  height: 24px;
  background: #27aae1;
  color: #fff;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1em;
}


.services-snapshot .container {
	align-content: flex-end;
	align-items: flex-end;
	justify-content: flex-end;
	text-align: end;
}
.services-snapshot h3 {
	color: #fff;
	width: 100%;
	text-align: left;
}


.services-snapshot .services-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 20px;
  margin: 20px 0;
}

.services-snapshot .services-list > div {
  background: #eee;
	color: #333;
  padding: 24px 16px;
  border-radius: 8px;
  box-shadow: 4px 0 10px rgba(0, 0, 0, 0.1);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}
.services-snapshot .services-list > div h4 {
  margin: 0 0 12px;
  color: #27aae1;
  font-size: 1.1rem;
}

.services-snapshot .services-list > div p {
  flex: 1;
  margin: 0;
  font-weight: 500;
	color: #555;
}


.services-snapshot {
  background: #000000aa url('images/services.jpg') center/cover;
  background-size: cover;
  background-position: center;
  color: #fff;
  background-blend-mode: overlay;
}

.hero-services {
  background: #000000aa url('images/services.jpg') center/cover;
  padding: 60px 20px;
  text-align: center;
	height: 85vh;
  color: #fff;
background-blend-mode: overlay;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
}


.hero-services .container  .services-list {
	margin: auto 0;
	display: flex;
	flex-direction: row;
	margin-top: 42px;
}
.hero-services .container a {
	margin-left: 4px;
	margin-right: 4px;
}


.hero-services h2 {
  font-size: 2rem;
}

.hero-services p {
  margin: 10px 0;
}

.services-list {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 20px;
  margin: 40px 0;
}

.services-list > div {
  background: #eee;
  padding: 24px 16px;
  border-radius: 8px;
  box-shadow: 4px 0 10px rgba(0, 0, 0, 0.1);
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
}

.services-list > div h4 {
  margin: 0 0 12px;
  color: #27aae1;
  font-size: 1.1rem;
  font-weight: 600;
}

.services-list > div p {
  flex: 1;
  margin: 0;
  font-weight: 500;
  color: #555;
}


.hero-contact-wrapper {
  display: grid;
  /* two columns: intro | form */
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
}

.hero.contact-page {
	background: #000000aa url('images/contact-hero.jpg') center/cover;
}
.hero.tracking-page {
	background: #000000aa url('images/tracking-hero.jpg') center/cover;
}

.hero-intro h2 {
  color: #fff;
  font-size: 2rem;
  margin-bottom: 12px;
}
.hero-intro p, .hero-intro a.contact-line {
  color: #ddd;
  font-size: 1rem;
  width: 100%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
}
.hero-intro .icon {
  display: inline-flex;
  width: 24px;
  height: 24px;
  margin-right: 8px;
	flex-shrink: 0;
}
.hero-intro .icon svg,
.hero-intro .icon svg path {
  fill: #27aae1;
}

/* RIGHT COLUMN: form card */
.hero-contact {
  background: #eee;
  padding: 16px;
  border-radius: 8px;
  box-shadow: 4px 0 10px rgba(0,0,0,0.1);
}

/* Form labels */
.hero-contact form label {
  display: block;
  margin-top: 12px;
  font-weight: 600;
  color: #333;
	text-align: left !important;
}
.hero-contact form label:first-of-type {
  margin-top: 0px;
}

/* Inputs & textarea */
.hero-contact form input,
.hero-contact form textarea {
  width: 100%;
  padding: 10px;
  margin-top: 8px;
  border: 1px solid #ccc;
  border-radius: 4px;
  font-size: 0.95rem;
  box-sizing: border-box;
  color: #333;
}

/* Full-width submit button */
.hero-contact .cta-btn {
  display: block;
  width: 100%;
  text-align: center;
  margin-top: 20px;
}

/* Contact info below form */
.hero-contact p {
  margin: 20px 0 0;
  color: #555;
  font-size: 0.9rem;
}
.hero-contact form label.required::after {
  content: "*";
  color: #27aae1;
  margin-left: 4px;
	font-weight: 800;
}
.hero-tracking-wrapper {
  display: grid;
  /* two columns: intro | form */
  grid-template-columns: 1fr;
  gap: 40px;
  align-items: center;
}
.tracking-page .hero-contact-wrapper {
  grid-template-columns: 1fr;
}
.service-areas-page.why-choose ul li:nth-child(5) {
  flex: 1 1 100%;
	text-align: center;
	justify-content: center;
	align-content: center;
	align-items: center;
	padding-left: 0;
}
.service-areas-page.why-choose ul li:nth-child(5)::before {
	position: relative;
  top: auto;
  left: auto;
  transform: none;
  margin-right: 8px;
}

.service-areas-hero {
  position: relative;
	background: none;
}
.service-areas-hero .service-map {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
}
/* keep the hero’s content on top */
.service-areas-hero > .container,
.service-areas-hero .why-choose {
  position: relative;
  z-index: 2;
}
.service-areas-hero::before {
  content: "";
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: rgba(0,0,0,0.5);
  z-index: 1;
}
.service-areas-hero + .service-map #service-map {
  height: 85vh !important;
}
.about-page .hero {
  background: #000000aa url('images/about-hero.jpg') center/cover;
  background-blend-mode: overlay;
  height: 85vh;
  padding: 60px 20px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.about-page section .container ul {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  list-style: none;
  justify-content: center;
  margin-top: 16px;
}
.about-page section .container ul li {
  background: #eee;
  padding: 12px 20px 12px 44px;
  border-radius: 8px;
  position: relative;
  font-weight: 500;
  min-width: 200px;
}
.about-page section .container ul li::before {
  content: "✓";
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  background: #27aae1;
  color: #fff;
  width: 20px;
  height: 20px;
  border-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9em;
}
/* — Two-column layout on About page — */
.about-page .container.two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
	margin-top: 32px;
	margin-bottom: 32px;

}
/* left-column text stays left-aligned */
.about-page .container.two-col .col h3,
.about-page .container.two-col .col p {
  text-align: left;
}
/* right-column list → block, simple vertical flow */
.about-page .container.two-col .col ul {
  display: block;
  margin: 16px 0 0;
  padding: 0;
}
.about-page .container.two-col .col ul li {
  display: block;
  margin-bottom: 8px;
}


footer {
  background: #13161f;
  color: #fff;
  text-align: center;
  padding: 10px 0;
  margin-top: 20px;
}

#nav-toggle {
	display: none;
}


@media (max-width: 768px) {
  /* 1) Header: stack nav links vertically */
  header .container {
    position: relative;
	  display: flex;
    flex-direction: column;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
  }
  header .container nav ul {
    display: flex;
    flex-direction: column;
    gap: 8px;
    align-items: center;
  }
  header .container nav ul li {
    margin-left: 0 !important;
  }

  /* 2) “How It Works” (3 steps): stack */
  .how-it-works .steps {
    flex-direction: column;
    gap: 20px;
  }

  /* 3) About page two-col → one-col */
  .about-page .two-col {
    display: flex;
    flex-direction: column;
    gap: 20px;
  }

  /* 4) Services page 5-col → one-col */
  .services-snapshot .services-list,
  .services-list {
    grid-template-columns: 1fr !important;
  }

  /* 5) Contact us two-col → one-col & let hero grow */
  .tracking-page .hero-contact-wrapper,
  .contact-page .hero-contact-wrapper {
    grid-template-columns: 1fr !important;
  }
  .tracking-page .hero,
  .contact-page .hero {
    height: auto;
    padding-top: 2em;
    padding-bottom: 2em;
  }

  /* 6) Areas served: wrap items, full-width li, left-align text */
  .service-areas-page .why-choose ul {
    flex-wrap: wrap;
    gap: 12px;
    justify-content: center;
  }
  .service-areas-page .why-choose ul li {
    flex: 1 1 100%;
    text-align: left !important;
  }
  .service-areas-page .why-choose ul li::before {
    position: absolute;
    left: 16px;
    transform: translateY(-50%);
  }

	header {
  position: relative;
}

	#nav-toggle {
    display: block;
  }

  .contact-page .hero,
  .tracking-page .hero {
    height: auto !important;
    padding: 40px 20px;
  }


  .service-areas-page .hero.service-areas-hero {
    height: auto !important;
    padding: 40px 20px;
  }
  .service-areas-page .why-choose ul li {
    text-align: left !important;
  }

  .services-snapshot .services-list,
  .services-list,
  .hero-services .services-list {
    grid-template-columns: 1fr !important;
  }

  .about-page .two-col {
    display: flex !important;
    flex-direction: column !important;
    gap: 20px !important;
  }


.how-it-works .steps {
  flex-direction: column;
  gap: 0;
}

.how-it-works .steps > div {

  border: none !important;
  overflow: visible !important;
}
.how-it-works .steps > div h4,
.how-it-works .steps > div p {
  margin-left: 0 !important;
  text-align: left !important;
  width: auto;
}


.how-it-works .steps > div:first-child {
  border-top: 4px solid #27aae1 !important;
}
.how-it-works .steps > div:last-child {
  border-bottom: 4px solid #27aae1 !important;
}


.how-it-works .steps > div::before,
.how-it-works .steps > div::after {
  display: none !important;
}

.how-it-works .steps > div {
  display: flex !important;
  flex-direction: column;
  align-items: flex-start !important;
  justify-content: flex-start !important;
  padding: 20px 16px !important;
}

.how-it-works .steps > div {
  padding: 20px 16px 20px 80px !important;
}

.how-it-works .steps > div strong {
  position: absolute !important;
  top: 50% !important;
  left: 16px !important;
  transform: translateY(-50%) !important;
  font-size: var(--big-fs) !important;
  z-index: 2 !important;
  margin: 0 !important;
}

.how-it-works .steps > div h4,
.how-it-works .steps > div p {
  margin-left: 0 !important;
}
.services-snapshot .services-list,
.services-list {
  grid-template-columns: 1fr !important;
}
	
	.service-areas-page .why-choose ul {
  justify-content: center !important;
  flex-wrap: wrap !important;
  gap: 12px !important;
}

.service-areas-page .why-choose ul li {
  flex: 1 1 100% !important;
  text-align: left !important;
}

.service-areas-page .why-choose ul li::before {
  left: 16px !important;
  position: absolute !important;
  transform: translateY(-50%) !important;
}

.hero-services .services-list {
  display: grid !important;
  grid-template-columns: 1fr !important;
}

.service-areas-page ul {
  display: flex !important;
  flex-wrap: wrap !important;
  justify-content: center !important;
  gap: 12px !important;
}
.service-areas-page ul li {
  flex: 1 1 100% !important;
  text-align: left !important;
  padding-left: 56px !important; /* restore space for checkbox */
}
.service-areas-page ul li::before {
  left: 16px !important;
  position: absolute !important;
  transform: translateY(-50%) !important;
}


.hero,
.hero-services,
.service-areas-hero,
.tracking-page .hero {
  height: auto !important;
  padding-top: 40px !important;
  padding-bottom: 40px !important;
}


.hero-services .services-list > div {
  margin-bottom: 20px;
}


.service-areas-page ul li {
  margin-bottom: 12px;
}


.tracking-page .hero-contact {
  margin-bottom: 20px;
}

#nav-toggle {
  display: block;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
}
#nav-toggle .bar {
  display: block;
  width: 24px;
  height: 3px;
  margin: 4px 0;
  background: #fff; 
  transition: background .3s;
}


header nav {
  position: absolute;
  top: 100%;
  left: 20;
  right: 20;
  background: #13161f;
  max-height: 0;
  overflow: hidden;
  transition: max-height .3s ease-out;
	margin-right: 0;
}


header.nav-open nav {
 position: absolute;
  top: 100%;
  left: 20;
  right: 20;
  max-height: 500px;
	}


header nav ul {
  flex-direction: column;
  gap: 12px;
  padding: 12px;
	align-items: center;
}
header nav ul li {
  margin-left: 0;
	margin-right: 0;
}
/* — hide hamburger on desktop — */
#nav-toggle {
  display: none;
}

/* — show & position on mobile — */

  #nav-toggle {
    display: block;
  }

  /* ensure the dropdown sits flush with your container edges */
  .mobile-nav {
    position: absolute;
    top: 100%;
    left: 20px;   /* ← same as your container’s horizontal padding */
    right: 20px;  /* ← ditto */
    background: #13161f;
    border-radius: 4px;
    overflow: hidden;
  }

  .mobile-nav ul {
    list-style: none;
    margin: 0;
    padding: 0;
  }

  .mobile-nav li + li {
    border-top: 1px solid rgba(255,255,255,0.1);
  }

  .mobile-nav a {
    display: block;
    padding: 12px 16px;
    color: #fff;
    text-decoration: none;
  
}

	
}

.contact-page .success {
  color: #27aae1;
  margin-top: 16px;
  font-weight: bold;
}
.contact-page .error {
  color: red;
  margin-top: 16px;
  font-weight: bold;
}
/* hide until we actually submit */
.success,
.error {
  display: none;
}
.contact-page .error a {
	text-decoration: underline;
}
/* only show once <body class="submitted"> */
body.submitted .success,
body.submitted .error {
  display: block;
  margin-top: 1em;   /* or whatever spacing you like */
}
