/*
Theme Name: Achen Henderson
Theme URI: http://achenhenderson.ca/
Description: Achen Henderson Theme
Author: Alex Wong
Version: 2.0
*/

/* @import "css/utility.css"; */

.mobile {
  display: none;
}
.ie8 {
  display: none;
}

html {
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
  height: 100%;
  background: #fff;
  margin: 0;
  padding: 0 !important;
}

img {
  image-rendering: -webkit-optimize-contrast;
}

* {
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

body {
  font-family: Roboto, sans-serif;
  padding: 0;
  margin: 0 auto;
  position: relative;
  background: white;
  font-weight: 300;
  line-height: 150%;
  height: 100%;
}

#top-bar {
  background: #fff;
  z-index: 2;
  top: 0;
  bottom: auto;
  position: relative;
  left: 0;
  right: 0;
  height: 100px;
  font-size: 18px;
  font-family: Roboto, sans-serif;
  padding: 0 25px;
  box-shadow: 0 0px 10px rgba(0, 0, 0, 0.1);
}

#top-content {
  position: relative;
  max-width: 1600px;
  margin: auto;
  display: flex;
  justify-content: space-between;
}

#nav-home {
  width: auto;
  height: 100px;
  left: 0;
  top: 0;
  position: relative;
  background: white;
  display: block;
}

#logo {
  width: 320px;
  top: 15px;
  height: auto;
  position: relative;
  left: 0px;
  display: block;
  border: 0;
  margin-right: 10px;
}

#nav-top {
  padding-left: 0px;
  position: relative;
  top: 00px;
  right: 0;
  display: flex;
  align-items: center;
}

nav ul {
  margin: 0;
  padding: 0;
  list-style-type: none;
}

nav li {
  margin: 0;
  padding: 0;
  list-style-type: none;
  position: relative;
  display: inline-block;
}

nav a {
  text-decoration: none;
}

#main-menu {
  text-transform: uppercase;
  font-weight: 500;
  margin: 0;
  padding: 0;
}

#main-menu a {
  position: relative;
  display: block;
  color: #666;
  text-decoration: none;
  white-space: nowrap;
}

/* menu hover color */
#main-menu a:hover {
  color: red;
}

#main-menu > li > a {
  padding: 0 10px;
  height: 100px;
  line-height: 100px;
  background: white;
  transition: color 0.3s;
  position: relative;
  z-index: 10;
  padding-top: 3px;
  box-sizing: border-box;
  color: #666;
}

#main-menu > li > a:hover {
}

@media (max-width: 1150px) {
  #logo {
    width: 300px;
    top: 19px;
  }

  #main-menu > li > a {
    font-size: 15px;
    padding-left: 6px;
    padding-right: 6px;
  }
}

#main-menu .home {
  display: none;
}

#main-menu .sub-menu {
  text-transform: none;
  font-weight: 500;
  font-size: 17px;
  display: block;
  position: absolute;
  z-index: 5;
  top: 100%;
  background: white;
  padding: 10px 0px;
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
  box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
}

#main-menu > li:hover > .sub-menu {
  visibility: visible;
  opacity: 1;
}

#main-menu .sub-menu li {
  display: block;
}

#main-menu .sub-menu a {
  position: relative;
  display: block;
  padding: 6px 20px;
  line-height: normal;
  white-space: nowrap;
  font-weight: 300;
  box-sizing: border-box;
}

/* menu color */
#main-menu > li.current-menu-item > a,
#main-menu > li.current-menu-parent > a {
  color: red;
}

#main-menu .sub-menu .current-menu-item > a:before,
#main-menu .resources-menu .current-menu-item > a:before {
  content: "|";
  color: lightblue;
  position: absolute;
  margin-left: -12px;
  margin-top: -0.05em;
  font-weight: bold;
}

#main-menu .sub-menu-head a {
  text-transform: uppercase;
  font-weight: bold;
}

#main-menu .label > a {
  text-transform: uppercase;
  color: #999;
  cursor: default;
}

#main-menu .sidebar-menu {
  display: none;
}

#main-menu li:last-child .sub-menu {
  left: auto;
  right: 0;
}

#top-bar-contact {
  font-weight: 300;
  font-size: 0.9em;
  margin-top: 10px;
}

#top-bar-contact a {
  padding-top: 4px;
  padding-bottom: 4px;
}

#top-bar-social {
  margin-top: 4px;
  margin-left: 15px;
  font-size: 0;
}

#top-bar-social a {
  display: inline-block;
  padding: 4px;
}

#top-bar-social a:before {
  font-size: 20px;
}

#top-bar-search {
  margin: 10px 10px 10px 15px;
}

#top-bar-search .search-field {
  width: 160px;
  padding: 4px 6px;
  border: none;
  border-bottom: 1px solid #ccc;
  background: none;
  font-size: 0.9em;
}

#top-bar-search .search-field:focus {
  border-color: lightblue;
}

#top-bar-search .icon-search {
  font-size: 14px;
  margin-left: 6px;
}

#top-bar-search .search-button {
  display: none;
}

@media (min-width: 1001px) {
  #main-menu .nav-contact a {
    background: lightblue;
    line-height: normal;
    height: auto;
    padding-top: 10px;
    padding-bottom: 10px;
    border-radius: 5px;
  }

  #main-menu .nav-contact a:hover {
    background: #08768d;
    color: white;
  }

  #main-menu .nav-contact.current-menu-item a {
    background: lightblue !important;
    color: #333 !important;
  }
}

.search-button {
  box-sizing: border-box;
  text-align: center;
}
main form.search {
  display: block;
  text-align: center;
}

main .search-field {
  width: 70%;
  width: calc(100% - 150px);
  max-width: 300px;
  margin-right: 0.5em;
}

.breadcrumbs {
  color: #999;
  text-transform: uppercase;
  font-size: 0.8em;
  letter-spacing: 0.1em;
  margin-top: 0.5em;
}

#primary {
  padding: 0 25px;
  background: white;
  height: 100%;
  max-width: 1600px;
  margin: auto;
}

main {
  flex: 1 0 auto;
  background: #ffffff;
}

#call-to-action {
  position: fixed;
  bottom: 20px;
  right: 10px;
  background: lightblue no-repeat center center;
  width: 120px;
  height: 120px;
  border-radius: 50%;
  text-align: center;
  box-shadow: 0 2px 15px rgba(0, 0, 0, 0.2);
  color: white;
  padding: 10px;
  font-size: 18px;
  line-height: 24px;
  display: block;
  display: flex;
  align-items: center;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.3);
  text-decoration: none;
  transition: background 0.3s;
  z-index: 20;
  border: 4px double white;
}
#call-to-action:hover {
  background: #26788b;
}

#call-to-action .uppercase {
  font-size: 15px;
}

.no-call-to-action #call-to-action {
  display: none;
}

article {
  font-size: 1em;
  line-height: 1.4;
}

header {
  padding-top: 40%;
  background: no-repeat top center;
  background-size: contain;
  text-align: center;
  position: relative;
  margin-bottom: 10px;
}

#resources-header {
  background-color: lightblue;
  padding: 0;
  margin: 0;
  min-height: 26vw;
  max-height: 600px;
  max-width: 1600px;
  margin: auto;
  padding: 40px;
  box-sizing: border-box;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

@media (max-width: 1000px) {
  #resources-header {
    height: 40vw;
  }
}

#header-bg {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 1;
  background-image: url(/wp-content/uploads/Resources-bg.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
}

#header-content {
  background-color: lightblue;
  width: 40%;
  margin-left: 10%;
  display: flex;
  padding: 40px;
  box-sizing: border-box;
  align-items: center;
  position: relative;
  z-index: 2;
}

#resources-header h1 {
  font-size: 60px;
  padding-bottom: 0.25em;
  font-size: min(3.5vw, 3.5em);
  max-width: 1600px;
  color: #384753;
  margin: 0;
  text-align: center;
}

@media (max-width: 1000px) {
  #header-content {
    width: 50%;
    margin-left: 20px;
    padding: 20px;
  }

  #resources-header h1 {
    font-size: 4.5vw;
  }
}

@media (max-width: 720px) {
  #resources-header {
    padding: 0;
  }

  #header-content {
    border-radius: 0;
    padding: 10px;
  }

  #resources-header h1 {
    font-size: 5vw;
    padding-bottom: 0.25em;
  }
}

@media (max-width: 540px) {
  #resources-header {
    height: auto;
    max-height: none;
  }

  #header-bg {
    position: relative;
    height: 60vw;
    background-size: 150%;
    background-position: right center;
  }

  #header-content {
    margin: auto;
    width: auto;
    padding-left: 20px;
    padding-right: 20px;
  }

  #resources-header h1 {
    font-size: 9vw;
  }
}

@media (min-height: 650px) {
  #top-bar {
    position: fixed;
  }

  #primary {
    margin-top: 100px;
  }

  :target {
    display: block;
    position: relative;
    top: -100px;
    visibility: hidden;
  }
}

/*Hero header*/
header.hero h1,
header.hero .hero-text {
  position: relative;
  top: 100%;
  display: block;
  left: 0;
  right: 0;
  line-height: 1;
  margin: 0;
  font-family: "EB Garamond", serif;
}

h1.secondary {
  font-size: 2.5em;
}

header.hero .line1 {
  display: block;
  left: 0;
  right: 0;
  text-shadow: 0 0 15px rgba(0, 0, 0, 0.5);
}

header.hero .line1 {
  position: absolute;
  bottom: 100%;
  z-index: 1;
  color: white;
  display: block;
  line-height: 100%;
  font-size: 90px;
  font-size: 9vw;
}

header.hero .line1.large {
  font-size: 12vw;
}

header.hero .line1.small {
  font-size: 50px;
  font-size: 8vw;
}

header.hero .line2 {
  display: block;
  color: #666;
  font-size: 80px;
  font-size: 5vw;
  position: relative;
  top: 0;
  left: 0;
  right: 0;
  line-height: 1;
  z-index: 2;
}
header.hero .line2.large {
  font-size: 6vw;
}

@media (min-width: 1600px) {
  header.hero .line1 {
    font-size: 150px !important;
  }

  header.hero .line2 {
    font-size: 80px !important;
  }
}

@media (max-width: 1000px) {
  header.hero .line1 {
    font-size: 12vw;
  }
  header.hero .line1.large {
    font-size: 15vw;
  }

  header.hero h1 .line2 {
    font-size: 7vw;
  }
  header.hero h1 .line2.large {
    font-size: 8.5vw;
  }
}

@media (max-width: 600px) {
  header.hero .line2 {
    line-height: 1.2;
    margin: auto;
  }
}

.section {
  position: relative;
  margin: auto;
}

.content {
  padding: 30px 5% 30px 5%;
  max-width: 1200px;
  margin: auto;
}

.section.intro .content {
  padding-top: 4%;
  padding-bottom: 4%;
}

.separator {
  position: relative;
}

div.separator:after {
  content: "";
  display: block;
  width: 300px;
  max-width: 50%;
  height: 1px;
  border-bottom: 2px solid lightblue;
  position: absolute;
  left: 0;
  right: 0;
  margin: auto;
  bottom: 0;
}

.section.separator:after {
  bottom: 1em;
}
.block.separator:after {
  bottom: -0.5em;
}

hr {
  border: none;
  background: none;
  padding: 0;
  position: relative;
  display: block;
  clear: both;
  margin: 1.5em auto 2em auto !important;
  width: 300px;
  max-width: 50%;
  height: 1px;
  border-bottom: 2px solid lightblue;
}
hr.compact {
  margin: 0.8em auto 1em auto;
}

/*Formatting*/

.lead {
  font-family: Roboto, sans-serif;
  font-weight: 300;
  font-size: 1.4em;
}

.lead.align-right,
.column.align-right {
  text-align: right;
}

.serif {
  font-family: "EB Garamond", serif;
}

.number-icon .elementor-widget-container {
  width: 80px;
  margin: auto;
  height: 80px;
  display: inline-flex;
  font-size: 50px;
  font-family: "EB Garamond", serif;
  flex-direction: column;
  justify-content: center;
}

.highlight {
  background: lightblue;
  outline: 0.25em solid lightblue;
  padding: 0.2em 0.4em 0.2em 0.4em;
  margin: 0 0.25em;
  font-weight: 500;
  letter-spacing: 0.05em;
  text-transform: uppercase;
}
@supports (box-decoration-break: clone) or (-webkit-box-decoration-break: clone) {
  .highlight {
    -webkit-box-decoration-break: clone;
    box-decoration-break: clone;
    margin: 0;
    border-radius: 4px;
    outline: none;
  }
}

.highlight-search {
  background: #ffe682;
  background: rgba(255, 205, 0, 0.3);
  outline: 4px solid rgba(255, 205, 0, 0.3);
  position: relative;
}

.lead .highlight {
  font-size: 0.85em;
}

.lead-callout {
  width: 90%;
  margin: auto;
  max-width: 900px;
}

@media (min-width: 1400px) {
  .lead-callout {
    width: 80%;
  }
}

.lead-callout span.lead {
  display: inline-block;
  width: 50%;
  text-align: left;
  margin: -0.2em 4% 0.5em -5%;
  float: left;
  box-sizing: border-box;
}

.slate-bg .highlight {
  color: #384753;
}

.feature,
.feature.column {
  position: relative;
  background: white;
  border-radius: 16px;
  padding: 20px 30px !important;
  box-shadow: 0 2px 20px rgba(0, 0, 0, 0.3);
  box-sizing: border-box;
  margin: 3% 0 3% 0;
  width: 50%;
  max-width: 500px;
}

.feature.right {
  margin-left: 50%;
}

.feature.center {
  margin-left: auto;
  margin-right: auto;
}

.feature.column.right {
  margin-left: 2%;
  width: 48%;
}

.feature.left {
  width: 50%;
}

.feature h2 {
  text-align: center;
}

.feature.action-section {
  border-bottom-left-radius: 18px;
  border-bottom-right-radius: 18px;
}

.feature .action p {
  margin: 0;
}

.feature .action {
  margin: 0 -30px -20px -30px;
}

.feature .action a {
  display: block;
  background: lightblue;
  color: #384753;
  text-decoration: none;
  text-align: center;
  border-radius: 0 0 16px 16px;
  padding: 0.8em 4%;
  line-height: normal;
}

.feature .action a:hover {
  background: #26788b;
  color: white;
}

.feature .action a:before {
  content: "\00BB";
  vertical-align: middle;
  margin-right: 0.25em;
  font-size: 1.5em;
  display: inline-block;
  margin-bottom: 0.1em;
}

.logo-accent:before {
  content: url(images/logo-accent.svgz);
  display: block;
  position: absolute;
  left: 50%;
  top: -20px;
  margin-left: -30px;
  text-align: center;
  z-index: 1;
  line-height: 0;
}

.feature.logo-accent {
  padding-top: 35px !important;
}

.feature.logo-accent h2 {
  position: relative;
  z-index: 1;
}

.feature-section {
  background-repeat: no-repeat;
  background-position: top center;
  background-size: cover;
}

.callout {
  background: lightblue;
  border-radius: 8px;
}

.text-highlight {
  font-size: 1.3em;
  font-weight: 500;
  color: #f2c100;
}

.row-info {
  position: relative;
  display: inline-block;
  width: 26%;
  padding-right: 4%;
  vertical-align: top;
  font-size: 0.9em;
  font-style: normal;
  text-align: right;
  text-transform: uppercase;
  line-height: 1.5;
  color: #8c7c73;
  letter-spacing: 0.05em;
}

.row-info:after {
  content: "";
  display: block;
  width: 50%;
  height: 1px;
  border-bottom: 2px solid lightblue;
  position: relative;
  margin: 1em 0 0 auto;
}

.row-main {
  display: inline-block;
  width: 69%;
  vertical-align: top;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  margin-top: 0;
  margin-bottom: 0.5em;
  line-height: 1;
}

h1,
h2 {
  font-family: "EB Garamond", serif;
}

.alt-text {
  display: none;
}

h1 {
  font-weight: 300;
  font-size: 3.5em;
}

@media (max-width: 1336px) {
  h1 {
    font-size: 2.5em;
  }
}

h1 em,
h2 em,
.hero em {
  font-family: "EB Garamond", serif;
  font-style: italic;
  font-size: 0.8em;
}

.ampersand {
  font-family: "EB Garamond", serif;
  font-size: 0.65em;
  font-style: italic;
}

h1 strong,
h2 strong,
.hero strong {
  font-family: Roboto;
  text-transform: uppercase;
  font-size: 0.58em;
  font-weight: 500;
  letter-spacing: 0.1em;
}

h2 {
  font-weight: 300;
  font-size: 2.5em;
}

.resources-content h2,
.resources-content h3 {
  padding: 0.5em 1em;
  background: lightblue;
  text-transform: uppercase;
  font-size: 1em;
  letter-spacing: 0.05em;
  margin: 1em 0 1em 0;
  display: inline-block;
  font-family: Roboto, sans-serif;
  font-weight: 500;
  line-height: 1.3;
}

.resources-content h2 a {
  display: block;
  padding: 0.5em 1em;
  margin: -0.5em -1em;
  text-decoration: none;
  color: black;
}
.resources-content h2 a:hover {
  background: #26788b;
  color: #fff;
}

.resources-content hr + h2 {
  margin-top: 0;
}

.resource-heading {
  margin-bottom: 20px;
}
.resource-heading .elementor-container {
  height: 200px;
}
.resource-heading .elementor-widget-wrap {
  align-content: flex-end;
  align-items: flex-end;
}

.resource-heading h2 {
  display: inline-block;
  border-bottom: 10px solid lightblue;
  width: auto;
  padding: 0 0 15px 0;
  margin: 0 0 -15px 10px !important;
}

@media (max-width: 760px) {
  .resource-heading h2 {
    font-size: 2em;
  }
}

h3 {
  font-size: 1.2em;
  font-weight: 500;
  line-height: 1.2;
}

h3.highlight {
  padding: 0.3em 0.4em;
  display: inline-block;
  margin-bottom: 0.5em;
}

h4 {
  font-size: 1.1em;
}

h5 {
  font-size: 1em;
}

.yellow-background {
  background: #ffc900;
}

.teal-background {
  background: #08768d;
}

.slate-background {
  background: #304553;
}

.simple header,
header.simple {
  padding-top: 15%;
  padding-left: 5%;
  padding-right: 5%;
  background-color: lightblue;
  background-size: 10% auto;
  background-position: 50% 20%;
  text-align: center;
  margin-bottom: 1.5em;
}

.simple header h1,
header.simple h1 {
  display: inline-block;
  padding-bottom: 0.5em;
  font-size: 80px;
  font-size: 5.5vw;
  color: white;
  margin: 0;
  border-bottom: 20px solid #384753;
  margin-bottom: -10px;
}

@media (min-width: 1600px) {
  .simple header h1,
  header.simple h1 {
    font-size: 90px;
  }
}
@media (max-width: 1000px) {
  .simple header h1,
  header.simple h1 {
    font-size: 8vw;
    border-bottom-width: 3vw;
    margin-bottom: -1.5vw;
  }
}

@media (max-width: 480px) {
  .simple header,
  header.simple {
    padding-left: 15px;
    padding-right: 15px;
  }
}

.simple h2 {
  font-size: 1.1em;
  font-family: Roboto, Sans-serif;
  display: inline-block;
  text-transform: uppercase;
  font-weight: 500;
  letter-spacing: 0.05em;
  line-height: 1.3;
  margin-bottom: 0.25em;
}

.simple h3 {
  font-size: 1em;
  font-family: Roboto, Sans-serif;
  display: inline-block;
  font-weight: 500;
  line-height: 1.3;
}

article p {
  margin-top: 0;
  margin-bottom: 1em;
  font-weight: 300;
}

p:last-child {
}
.elementor-section-wrap :last-child {
  margin-bottom: 0;
}
.last-item-margin-none :last-child {
  margin-bottom: 0;
}

p:empty {
  display: none;
}

.watch-video {
  font-style: italic;
  text-decoration: none;
  font-family: "EB Garamond", serif;
}

.watch-video:before {
  content: "\e810";
  font-style: normal;
  font-family: "icons";
  display: inline-block;
  margin-right: 0.25em;
}

article a.button {
  display: inline-block;
  background: lightblue;
  padding: 0.5em 1em;
  text-align: center;
  color: black;
  text-decoration: none !important;
  font-weight: 500;
  border-radius: 8px;
  border: 4px double white;
}

article a.button:hover {
  background: #faa900;
  color: black;
}

.elementor-button.elementor-size-xs {
  font-size: 0.85em !important;
  padding: 8px 10px !important;
}

em {
  font-family: sans-serif;
}

strong em,
em strong {
  font-weight: 500;
}

sup,
sub {
  height: 0;
  line-height: 1;
  position: relative;
  _position: static;
  font-size: 0.6em;
}
sup {
  top: 0.1em;
}
sub {
  bottom: -0.5em;
}

.small {
  font-size: 0.8em;
}

.teal-bg {
  background: #1f7a8c;
  color: white;
}
.slate-bg {
  background: #384753;
  color: white;
}
.yellow-bg {
  background: lightblue;
}

.uppercase {
  text-transform: uppercase;
}

.column {
  width: 49.5%;
  display: inline-block;
  vertical-align: top;
  box-sizing: border-box;
}

.column.left {
  padding-right: 2.5%;
}
.column.right {
  padding-left: 2.5%;
  margin-left: -1px;
}

a {
  -webkit-transition: 0.3s;
  transition: color 0.3s, background 0.3s;
}

article a {
  color: #26788b;
  font-weight: 500;
}

article em a,
article a em {
}

article strong {
  font-weight: 500;
}

article a:hover {
  color: #dda704;
}

article .white-text a {
  color: lightblue;
}
article .white-text a:hover {
  color: white;
}

article ul,
article ol {
  margin-top: 0;
  margin-left: 0;
  padding: 0;
  margin-bottom: 1em;
}

article ul {
  list-style-type: square;
}

article ol ol,
article ul ul {
  margin-bottom: 0;
}

article li {
  position: relative;
  margin-left: 1em;
}

article ul li::marker {
  color: lightblue;
}

article ol li::marker {
}

article ul ul {
  padding-left: 1em;
}
article ol ol {
  padding-left: 2em;
}

article ol:not([type]) {
  counter-reset: li;
  list-style-type: none;
  position: relative;
  padding: 0;
}

article ol:not([type]) > li {
  padding: 0.2em 0 0.2em 34px;
  list-style-type: none;
  margin-left: 0;
}

article ol:not([type]) > li:before {
  content: counter(li);
  counter-increment: li;
  background: white;
  color: #53534b;
  border: 2px solid lightblue;
  border-radius: 50%;
  display: inline-block;
  position: absolute;
  left: 0;
  top: 0.2em;
  font-family: "EB Garamond", serif;
  font-size: 16px;
  line-height: 16px;
  width: 20px;
  height: 20px;
  text-align: center;
}
article ol:not([type]) li[data-counter]:before {
  content: attr(data-counter);
}

ol.columns,
ul.columns,
.columns-2,
.columns-3 {
  -moz-column-gap: 50px;
  -webkit-column-gap: 50px;
  column-gap: 40px;
  margin-left: 0;
  break-inside: avoid-column;
  -webkit-column-break-inside: avoid;
}

.columns li,
.columns-2 li,
.columns-3 li {
  -webkit-column-break-inside: avoid;
  page-break-inside: avoid;
  break-inside: avoid;
}

.columns.all {
  -moz-column-count: 2;
  -webkit-column-count: 2;
  column-count: 2;
}

@media (min-width: 640px) {
  ol.columns,
  ul.columns,
  .columns-2 {
    -moz-column-count: 2;
    -webkit-column-count: 2;
    column-count: 2;
  }
}

@media (min-width: 1600px) {
  ol.columns,
  ul.columns,
  .columns.all {
    -moz-column-count: 3;
    -webkit-column-count: 3;
    column-count: 3;
  }
}

@media (min-width: 1200px) {
  .columns-3 {
    -moz-column-count: 3;
    -webkit-column-count: 3;
    column-count: 3;
  }
}

.no-break {
  white-space: nowrap;
}

.social-media {
  margin: 0;
  padding: 0;
  list-style: none;
}

.social-media li {
  display: inline;
}

.social-media a {
  display: inline-block;
  padding: 4px;
}

.social-media a:before {
  font-size: 20px;
}

footer {
  background: #384753;
  padding: 8px;
  text-align: center;
  font-size: 11px;
  line-height: 18px;
  margin-top: 0;
  color: #bdc9d2;
  font-weight: 300;
  position: relative;
}

#footer-logos {
  margin: 0 160px;
}

#footer-logos img {
  height: 50px;
  width: auto;
  display: inline-block;
  vertical-align: bottom;
  margin: 20px 20px 30px 20px;
}

footer nav,
footer ul,
footer li {
  display: inline-block;
}

footer a {
  padding: 0 0.75em;
  display: inline-block;
  color: #bdc9d2;
  text-decoration: none;
}

footer a:hover {
  color: white;
}

#footer-contact {
  font-weight: 300;
  font-size: 16px;
  padding-top: 10px;
  padding-bottom: 10px;
  margin-bottom: 10px;
  border-bottom: 1px solid #556c80;
  display: inline-block;
}

#footer-contact a {
  padding-top: 8px;
  padding-bottom: 8px;
}

#footer-social {
  margin-top: 4px;
  font-size: 0;
  display: inline-block;
}

::-webkit-input-placeholder {
  font-style: italic;
  font-family: sans-serif;
}
::-moz-placeholder {
  font-style: italic;
  font-family: sans-serif;
}
:-ms-input-placeholder {
  font-style: italic;
  font-family: sans-serif;
}
:-moz-placeholder {
  font-style: italic;
  font-family: sans-serif;
}

input[type="submit"],
button {
  background: #fcc800;
  color: black;
  border: none;
  cursor: pointer;
  padding: 8px 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
  -webkit-transition: 0.3s;
  transition: 0.3s;
  border-radius: 6px;
  font-size: 1em;
  font-family: Roboto, sans-serif;
  border: 3px double white;
}
input[type="submit"]:hover,
button:hover {
  background: #1f7a8c;
  color: white;
}

input[type="text"],
textarea,
select {
  padding: 0.3em;
  border: 1px solid #ccc;
  border-radius: 3px;
  font-family: sans-serif;
  font-size: 1em;
  box-sizing: border-box;
}

form.infusion-form {
  display: block;
  margin: auto;
  max-width: 600px;
  position: relative;
  overflow: hidden;
  z-index: 2;
}

@media (min-width: 1200px) {
  .feature.youtube form {
    width: 90%;
  }
}

form.infusion-form::after {
  content: "";
  display: block;
  clear: both;
}

.infusion-field {
  margin-bottom: 1em;
}

.infusion-field label {
  display: block;
}

.infusion-radio label {
  display: inline;
}

.infusion-radio .infusion-option {
  padding-right: 1.5em;
  white-space: nowrap;
}

.infusion-field textarea,
.infusion-field-input,
.infusion-field input[type="text"],
select {
  width: 100%;
}

@media (min-width: 1400px) {
  .infusion-field.label-beside label {
    display: inline-block;
    width: 30%;
    margin-right: 2%;
    vertical-align: middle;
    text-align: right;
  }

  .infusion-field.label-beside textarea,
  .infusion-field.label-beside .infusion-field-input {
    display: inline-block;
    width: 66%;
    vertical-align: middle;
  }

  .infusion-field.label-beside textarea {
    vertical-align: top;
  }

  form.label-beside button,
  form.label-beside p.required {
    margin-left: 33%;
  }
}

.required {
  color: #e8b900;
  font-size: 0.8em;
}

.infusion-submit {
  padding-bottom: 20px;
  position: relative;
}

.grecaptcha-badge {
  box-shadow: none !important;
  position: absolute !important;
  bottom: -0px !important;
}

article img {
  max-width: 100%;
  height: auto;
}

img.alignright {
  float: right;
  margin: 0 0 0 16px;
  max-width: 50%;
}

img.alignleft {
  float: left;
  margin: 0 16px 0 0;
  max-width: 50%;
}

img.aligncenter {
  display: block;
  margin: auto;
}

a img {
  border: none;
}

p + ul,
p + ol {
  margin-top: -0.5em;
}

table {
  width: 100%;
  border-collapse: collapse;
  border-top: 2px solid lightblue;
  margin-bottom: 1.5em;
}

td.checked {
  background: #fff9e1;
  font-size: 30px;
}

th {
  text-align: left;
  background: #fff9e1;
  border-bottom: 2px solid #fef1bd;
  padding: 0.3em 0.5em;
  color: #666;
}

th p,
td p:last-child {
  margin-bottom: 0;
}

td {
  border-bottom: 1px solid #ddd;
  padding: 0.2em 0.5em;
}

.embed {
  position: relative;
  display: block;
  margin-bottom: 2em;
}

.embed iframe {
  display: block;
  margin: auto;
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  border: 6px solid white;
}

.feature .embed {
  margin: 0;
  height: 0;
  padding-bottom: 56.25%;
}

.feature .embed iframe {
  box-shadow: none;
  border: none;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.feature.youtube {
  padding: 16px !important;
}

@media (max-width: 600px) {
  .embed {
    height: 0;
    margin-left: 0 auto 1em auto;
    width: 100%;
    padding-bottom: 56.25%;
  }

  .embed iframe {
    box-sizing: border-box;
    position: absolute;
    width: 100%;
    height: 100%;
    top: 0;
    left: 0;
  }
}

top-bar .post-edit-link {
  font-size: 14px;
  display: block;
  margin-top: 20px;
  font-weight: 300;
}

/*Pagination*/

.pagination {
  text-align: center;
  margin-top: 1em;
}

.pagination ul,
.pagination li {
  margin: 0;
  padding: 0;
  display: inline-block;
}

.pagination li:before {
  content: none;
}

.pagination a.page-numbers,
.pagination .current {
  min-width: 24px;
  min-height: 24px;
  line-height: 24px;
  font-size: 16px;
  display: inline-block;
  vertical-align: middle;
  margin-right: 0.5em;
  text-align: center;
  padding: 0.25em !important;
  text-decoration: none;
}

.pagination .current {
  background: #ffe066;
  border-radius: 4px;
  text-align: center;
}

/*Pages*/

#terms-of-use header {
  background-image: url(images/info-icon.svgz);
}

#privacy-policy header {
  background-image: url(images/privacy-icon.svgz);
}

#header-sitemap {
  padding-top: 35%;
  background-image: url(images/sitemap-header.jpg);
}

#article-404 header {
  padding-top: 35%;
  background-image: url(images/404-header.jpg);
  margin-bottom: 0;
}

#article-404 h2 {
  text-align: center;
}

#article-404 h2 .line1 {
  display: block;
  padding-right: 2em;
}

#article-404 h2 .line1 .large {
  font-size: 1.3em;
}

#article-404 h2 .line2 {
  display: block;
  padding-left: 2em;
}

@media (max-width: 720px) {
  #page-404 #intro-404 {
    font-size: 2em;
  }
}

@media (max-width: 420px) {
  #page-404 #intro-404 {
    font-size: 1.6em;
  }
}

a.summary {
  text-decoration: none;
  color: #000;
  display: block;
  border-radius: 8px;
  padding: 0.8em;
}

a.summary:hover {
  background: #fff9e1;
  color: black;
}

.mfp-close {
  background: none !important;
}

/*Industry pages*/
@media (max-width: 760px) {
  .industry-intro .elementor-column-wrap {
    background: lightblue !important;
  }

  .mobile-solid-yellow-bg .elementor-column-wrap {
    background: lightblue !important;
  }
}

/*hexagons*/
.hexagons {
  margin: auto;
}

@media (max-width: 1300px) {
  .hexagons {
    max-width: 900px;
  }
}

@media (max-width: 1350px) {
  .header-separator .elementor-container {
    max-width: none !important;
  }
}

.hexagons .offset-half-row {
  margin-top: 14%;
}
.hexagons .offset-one-row {
  margin-top: 28%;
}
.hexagons .offset-one-half-row {
  margin-top: 42%;
}

.hexagons .elementor-widget-container {
  width: 125%;
  padding-bottom: 112%;
  height: 0;
  color: white;
  position: relative;
}

.hexagons .elementor-widget-text-editor .elementor-widget-container {
  background: url(images/Hexagon-teal.svg) no-repeat center center;
  background-size: contain;
}

.hexagons .elementor-widget-text-editor.slate .elementor-widget-container {
  background: url(images/Hexagon-slate.svg) no-repeat center center;
  background-size: contain;
}

.hexagons .elementor-widget-image .elementor-widget-container {
  background: url(images/Hexagon-yellow.svg) no-repeat center center;
  background-size: contain;
}

.hexagons .elementor-widget-text-editor.yellow .elementor-widget-container {
  background: url(images/Hexagon-yellow.svg) no-repeat center center;
  background-size: contain;
}

.hexagons .elementor-widget-image.yellow-outline .elementor-widget-container {
  background: url(images/Hexagon-yellow-outline.svg) no-repeat center center;
  background-size: contain;
}

.hexagons .elementor-text-editor,
.hexagons .elementor-image {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  text-align: center;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: 0 18%;
}

.hexagons .elementor-image img {
  display: block;
  margin: auto;
  width: 60% !important;
}

.hexagons .elementor-widget-image.yellow-outline img {
  width: 100% !important;
}

.hexagons .elementor-widget-image .elementor-widget-container:before {
  content: "";
  display: block;
  border: 3px solid white;
  border-radius: 100%;
  width: 70%;
  padding-bottom: 70%;
  position: absolute;
  left: 0;
  right: 0;
  top: 10%;
  margin: auto;
}

@media (max-width: 1000px) {
  .hexagons {
    max-width: 570px;
  }

  .hexagons .elementor-column {
    width: 44% !important;
  }

  .hexagons .elementor-row {
    justify-content: center;
  }

  .hexagons .offset-half-row {
    margin-top: 24%;
  }

  .hexagons .offset-tablet-none {
    margin-top: 0;
  }

  .hexagons .offset-tablet-negative-half {
    margin-top: -24%;
  }
}

@media (max-width: 720px) {
  .hexagons .elementor-column {
    width: 300px !important;
    margin: 0 auto !important;
  }

  .hexagons .elementor-widget-container {
    width: 100%;
    padding-bottom: 0;
    height: 250px;
  }

  .hexagons .elementor-text-editor,
  .hexagons .elementor-image {
    width: auto;
  }
}

/*Ribbons*/
.ribbons .elementor-column {
  display: block;
  margin-left: auto;
  margin-right: auto;
  margin-bottom: 1em;
}

.ribbons .elementor-column-wrap {
  padding-bottom: 60px !important;
  background-image: url(images/Ribbon-bottom.svg);
  background-repeat: no-repeat;
  background-position: bottom center;
  background-size: 100% 25px;
}

main .wprs_unslider-arrow.next {
  right: 0;
}

main .wprs_unslider-arrow.prev {
  left: 0;
}

#nav-top .mega-menu-wrap-main-menu {
  width: 100%;
}
