/* --------------- Text attributes ---------------------- */
body, p, label { color: #000; font-size: 23px; font-family: 'latoregular'; }
p { font-weight: bold; margin-bottom: 1.2rem; }

/* --------------- Headings ----------------------------- */
h1, 
.path-frontpage main h2 { font-family: 'latoblack'; font-size: 75px; color: #18453b; line-height: 1; margin-bottom: 1.5rem; }
.path-frontpage h1,
.path-frontpage main h2 { text-align: center; }
.path-frontpage h1::before { content: 'Welcome to'; }
.path-frontpage h1::before,
.path-frontpage main h2::before { color: #000; font-size: 40px; display: block;  }
.path-frontpage h1::after,
.path-frontpage main h2::after { content: url('../images/square.png'); display: block; line-height: 0.4; }
h2 { font-family: 'latoblack'; font-size: 50px; color: #18453b; line-height: 1; margin-bottom: 1.5rem; }
h3 { font-family: 'latoblack'; font-size: 32px; color: #18453b; line-height: 1; margin-bottom: 1.5rem; }

/* --------------- Header ------------------------------- */
header { background-color: #282828; }
header * { color: #fff; }
.region-header { background-image: url('../images/header.jpg'); background-size: cover; background-repeat: no-repeat; padding: 6vw 48.5vw 21.8vw 3vw; }

/* --------------- Navigation --------------------------- */
ul.menu { justify-content: space-around; max-width: 110rem; display: flex; margin: auto; }
.menu a { font-family: 'latoblack'; font-size: 19px; display: block; padding: 30px 2vw; }
.menu a:hover { background-color: #18453b; color: inherit; }

a.black.button { background-color: #000; font-family: 'latoblack'; font-size: 26px; padding: 10px 45px; border: 1px solid #000;  border-radius: 10px; margin: 30px auto; display: table; }
a.black.button:hover { background-color: #fff; color: #000; }

/* --------------- Main --------------------------------- */
.row { max-width: 67.5rem; }
.wide.row { max-width: 97.5rem; }
.nopadding-left { padding-left: 0; }
.nopadding-right { padding-right: 0; }
main { padding: 75px 0 0; }
.node__content { margin-bottom: 50px; }
.path-frontpage .node__content p { text-align: justify; }
.node__content img { margin: 10px 5px; }
.field__label { font-weight: bold; }
.field__label::after { content: ": "; }
.field--label-inline .field__label { float: left; margin-right: 10px; }
.description { font-size: 12px; }
.tabs { border: none; }
.tabs.primary { background-color: #fff; border: none; }
.tabs.primary li { display: inline-block; margin: 0 5px; }
.tabs.primary li.is-active { background-color: #e6e6e6; }
.tabs.primary>li>a { padding: 5px;  }
.tabs.primary>li>a:hover { color: #fff; background-color: #18453b; }
.button { background-color: #18453b; }


/* --------------- Secondary content regions ------------ */
.region-secondary-content, .region-tertiary-content { margin: 50px 0; }

/* --------------- Find us block ------------------------ */
#block-findus h2::before { content: "It's Easy to"; }
#block-findus p:first-of-type { color: #fff; text-align: center; font-family: 'latoblack'; font-size: 29px; background-color: #18453b; margin-bottom: 5px; padding: 10px 0; }
#block-findus img.small { display: none; }

/* --------------- Bottom Content region ---------------- */
.region-content-bottom { background-color: #3aa8e6; background-image: url('../images/street.png'); background-repeat: no-repeat; background-position-x: right; background-position-y: center; }

/* --------------- Specializing block ------------------- */
#block-specializing { padding: 75px 250px; }
#block-specializing p { color: #fff; font-family: 'latoblack'; font-size: 60px; line-height: 1; text-shadow: 5px 5px 7px #095c8a; }
#block-specializing a { color: #fff; }
#block-specializing span.second-line { margin-left: 35px; }
#block-specializing span.third-line { margin-left: 70px; }
#block-specializing p:nth-of-type(2) { text-indent: 105px; }

/* --------------- Your Perfect Car Hauler -------------- */
#block-yourperfectcarhauler-2 h2::before { content: "Let's Get Started Finding"; }
#block-yourperfectcarhauler-2 p { text-align: justify; }

/* --------------- Footer ------------------------------- */
.region-footer-1, .region-footer-2, .region-footer-3, .region-footer-4 { margin-bottom: 20px; }
footer { background-color: #18453b; padding-bottom: 20px; }
footer * { color: #fff; }
footer h2 { font-family: 'latoblack'; color: #fff; font-size: 25px; margin: 1.5rem 0; }
footer h2::after { display: none; }
footer p { font-size: 18px; margin-bottom: 0; }

/* --------------- Footer menu -------------------------- */
footer ul.menu { margin: 0 -40px; }
footer .menu a { padding: 30px 0.8vw; }

/* --------------- Social Media Icons ------------------- */
.view-social-media-icons { text-align: right; padding-top: 1.5rem; }
.view-social-media-icons .views-row { display: inline-block; margin-right: 5px; }

/* --------------- Footer Bottom Blocks ----------------- */
.region-footer-btm-lft, .region-footer-btm-rght { margin: 30px 0 10px;  }
.region-footer-btm-lft p, .region-footer-btm-rght p { font-size: 11px; }
.region-footer-btm-lft p { text-align: left; }
.region-footer-btm-rght p { text-align: right; }

/* --------------- Contact page ------------------------ */
.node--type-webform .columns p { margin-bottom: 0; }

/* --------------- Mobile Navigation ------------------- */
a[data-toggle="offCanvas"] { position: fixed; top: 10px; right: 10px; background-color: #fff; opacity: 0.8; border-radius: 5px; padding: 20px 10px; }
a[data-toggle="offCanvas"].button:hover { background-color: #fff; }
.mobile-nav-toggle a.button { margin: 0; }
.mobile-nav-toggle a.button span,
.mobile-nav-toggle a.button span::before,
.mobile-nav-toggle a.button span::after { content: ""; display: block; height: 5px; width: 35px; border-radius: 3px; background-color: #18453b; }
.mobile-nav-toggle a.button span::before { position: relative; top: -10px; }
.mobile-nav-toggle a.button span::after { position: relative; top: 5px; }

.off-canvas { background-color: #18453b; }
.region-mobile-nav ul.menu { display: block; }
.region-mobile-nav ul.menu a { text-align: center; color: #fff; padding: 20px 0; }
.region-mobile-nav ul.menu a:hover { background-color: none; }

/* --------------- MEDIA QUERIES ----------------------- */
@media only screen and (max-width: 1600px) {
  .menu a { font-size: 16px; padding: 30px 0.5vw; }
  #block-specializing { padding: 75px 7vw; }
  footer ul.menu { margin: 0; }
}
@media only screen and (max-width: 1080px) {
  .node__content, main .block-block-content { padding: 0 15px; }
  main .region-secondary-content .block-block-content { padding: 0; }
  #block-findus p:first-of-type { font-size: 2.75vw; }
}
@media only screen and (max-width: 1024px) {
  h1, .path-frontpage main h2 { font-size: 68px; }
  h2 { font-size: 45px; }
  h3 { font-size: 29px; }
  body, p, label { font-size: 21px; }
  a.black.button { font-size: 22px; }
}
@media only screen and (max-width: 800px) {
  h1, .path-frontpage main h2 { font-size: 61px; }
  h2 { font-size: 40px; }
  h3 { font-size: 26px; }
  body, p, label { font-size: 19px; }
  #block-specializing p { font-size: 40px; }
  a.black.button { font-size: 20px; }
  footer h2 { font-size: 20px; margin-top: 1.2rem; }
  footer p { font-size: 14px; }
}
@media only screen and (max-width: 640px) {
  main { padding: 50px 0; }
  .node__content { margin-bottom: 25px; }
  h1, .path-frontpage main h2 { font-size: 62px; }
  h2 { font-size: 36px; }
  h3 { font-size: 23px; }
  body, p, label { font-size: 17px; }
  a.black.button { display: block; width: 90%; padding: 10px 0; font-size: 18px; }
  .region-secondary-content, .region-tertiary-content { margin: 25px 0; }
  #block-findus img.small { display: block; }
  #block-findus img.large { display: none; }
  #block-specializing { padding: 50px 0 50px 2vw; }
  #block-specializing p { font-size: 30px; }
  #block-specializing span.second-line { margin-left: 3vw; }
  #block-specializing span.third-line { margin-left: 6vw; }
  #block-specializing p:nth-of-type(2) { text-indent: 9vw; }
  .view-social-media-icons { text-align: center; }
  footer h2 { font-size: 17px; }
  .region-footer-btm-lft, .region-footer-btm-rght { margin: 5px 10px; }
  .region-footer-btm-lft p, .region-footer-btm-rght p { text-align: center; }
}
@media only screen and (max-width: 480px) {
	h1, .path-frontpage main h2 { font-size: 56px; }
	h2 { font-size: 32px; }
	h3 { font-size: 21px; }
	body, p, label { font-size: 15px; }
	a.black.button { font-size: 16px; }
	#block-specializing p { font-size: 20px; }
}