/*
Theme Name: Divi Child
Theme URI: https://www.elegantthemes.com/gallery/divi/
Description: Divi child theme via Freshy
Author: Freshy
Author URI: https://freshysites.com/
Template: Divi
Version: 4.2.0
*/
/* Add your own styles at the bottom */

/* -- COLORS -- */

.white,
.white h1,
.white h2,
.white h3,
.white h4,
.white h5,
.white h6,
.white li,
.white a,
h1.white,
h2.white,
h3.white,
h4.white,
h5.white,
h6.white,
li.white,
a.white,
p.white {
  color: #fff;
}

.black,
.black h1,
.black h2,
.black h3,
.black h4,
.black h5,
.black h6,
.black li,
.black a,
h1.black,
h2.black,
h3.black,
h4.black,
h5.black,
h6.black,
li.black,
a.black,
p.black {
  color: #000;
}

.primary,
.primary h1,
.primary h2,
.primary h3,
.primary h4,
.primary h5,
.primary h6,
.primary li,
.primary a,
h1.primary,
h2.primary,
h3.primary,
h4.primary,
h5.primary,
h6.primary,
li.primary,
a.primary,
p.primary {
  color: #32a709;
}

.secondary,
.secondary h1,
.secondary h2,
.secondary h3,
.secondary h4,
.secondary h5,
.secondary h6,
.secondary li,
.secondary a,
h1.secondary,
h2.secondary,
h3.secondary,
h4.secondary,
h5.secondary,
h6.secondary,
li.secondary,
a.secondary,
p.secondary {
  color: #daf238;
}

.tertiary,
.tertiary h1,
.tertiary h2,
.tertiary h3,
.tertiary h4,
.tertiary h5,
.tertiary h6,
.tertiary li,
.tertiary a,
h1.tertiary,
h2.tertiary,
h3.tertiary,
h4.tertiary,
h5.tertiary,
h6.tertiary,
li.tertiary,
a.tertiary,
p.tertiary {
  color: #e4debe;
}

/* background colors */
.bg-white,
a.bg-white {
  background-color: #fff;
}
.bg-black,
a.bg-black {
  background-color: #000;
}
.bg-primary,
a.bg-primary {
  background-color: #32a709;
}
.bg-secondary,
a.bg-secondary {
  background-color: #daf238;
}
.bg-tertiary,
a.bg-tertiary {
  background-color: #e4debe;
}

/* -- END COLORS -- */

/* -- TYPOGRAPHY -- */

.text-lowercase,
.text-lowercase h1,
.text-lowercase h2,
.text-lowercase h3,
.text-lowercase h4,
.text-lowercase h5,
.text-lowercase h6,
.text-lowercase li,
.text-lowercase a {
  text-transform: lowercase !important;
}

.text-uppercase,
.text-uppercase h1,
.text-uppercase h2,
.text-uppercase h3,
.text-uppercase h4,
.text-uppercase h5,
.text-uppercase h6,
.text-uppercase li,
.text-uppercase a {
  text-transform: uppercase !important;
}

.text-capitalize,
.text-capitalize h1,
.text-capitalize h2,
.text-capitalize h3,
.text-capitalize h4,
.text-capitalize h5,
.text-capitalize h6,
.text-capitalize li,
.text-capitalize a {
  text-transform: capitalize !important;
}

.text-transform-none,
.text-transform-none h1,
.text-transform-none h2,
.text-transform-none h3,
.text-transform-none h4,
.text-transform-none h5,
.text-transform-none h6,
.text-transform-none li,
.text-transform-none a {
  text-transform: none !important;
}

.font-weight-bold,
.font-weight-bold h1,
.font-weight-bold h2,
.font-weight-bold h3,
.font-weight-bold h4,
.font-weight-bold h5,
.font-weight-bold h6,
.font-weight-bold li,
.font-weight-bold a {
  font-weight: 700;
}

.font-weight-normal,
.font-weight-normal h1,
.font-weight-normal h2,
.font-weight-normal h3,
.font-weight-normal h4,
.font-weight-normal h5,
.font-weight-normal h6,
.font-weight-normal li,
.font-weight-normal a {
  font-weight: 400;
}

.font-italic {
  font-style: italic;
}

.text-underline-none,
.text-underline-none a {
  text-decoration: none !important;
}

.text-underline,
.text-underline a {
  text-decoration: underline !important;
}

.text-nowrap,
.text-nowrap a {
  white-space: nowrap !important;
}

.text-wrap-normal,
.text-wrap-normal a {
  white-space: normal !important;
}

/* -- END TYPOGRAPHY -- */

/* -- TEMPLATE -- */

/* -- END TEMPLATE -- */

/* -- HEADER -- */

/* helps logo to not be pixelated when scaled down */
#logo {
  transform: none !important;
}

/* when mobile menu is open, change hamburger icon to x icon */
#et_mobile_nav_menu .mobile_nav.opened .mobile_menu_bar::before,
#et-boc header .mobile_nav.opened .mobile_menu_bar::before {
  content: "\4d";
}

/* makes sub sub menu icon be right arrow instead of down arrow */
#top-menu
  .menu-item-has-children
  .menu-item-has-children
  > a:first-child::after,
#et-secondary-nav
  .menu-item-has-children
  .menu-item-has-children
  > a:first-child::after,
#et-boc
  header
  .menu-item-has-children
  .menu-item-has-children
  > a:first-child::after {
  content: "5";
}

/* if parent link of child menu is a deadlink, then make it not clickable */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children > a[href="#0"],
#et-boc header .et_mobile_menu .menu-item-has-children > a[href="#0"] {
  pointer-events: none;
}

/* - mobile menu toggling elements, injected via jQuery - */

/* make menu list item be relative, to be able to position toggle within this item */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children,
#et-boc header .et_mobile_menu .menu-item-has-children {
  position: relative;
}
/* the new toggle element, which is added via jQuery */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle,
#et-boc header .et_mobile_menu .sub-menu-toggle {
  position: absolute;
  background-color: rgba(0, 0, 0, 0.03);
  z-index: 1;
  width: 36px;
  height: 36px;
  line-height: 36px;
  border-radius: 50%;
  top: 4px;
  right: 4px;
  cursor: pointer;
  text-align: center;
}
/* the new toggle element when popped */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped,
#et-boc header .et_mobile_menu .sub-menu-toggle.popped {
  background-color: rgba(0, 0, 0, 0.1);
}
/* toggle icon */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle::before,
#et-boc header .et_mobile_menu .sub-menu-toggle::before {
  font-family: "ETmodules" !important;
  font-weight: normal;
  font-style: normal;
  font-variant: normal;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  line-height: 36px;
  font-size: 24px;
  text-transform: none;
  speak: none;
  content: "\33";
}
/* toggle icon when triggered */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped::before,
#et-boc header .et_mobile_menu .sub-menu-toggle.popped::before {
  content: "\32";
}
/* hide sub menus by default */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle ~ ul.sub-menu,
#et-boc header .et_mobile_menu .sub-menu-toggle ~ ul.sub-menu {
  display: none !important;
  padding-left: 0;
}
/* show sub menu when triggered via jQuery toggle, and add slight bg color */
#main-header #mobile_menu.et_mobile_menu .sub-menu-toggle.popped ~ ul.sub-menu,
#et-boc header .et_mobile_menu .sub-menu-toggle.popped ~ ul.sub-menu {
  display: block !important;
  background-color: rgba(0, 0, 0, 0.03);
}
/* remove sub menu list item left padding, since padding will be on anchors */
#main-header #mobile_menu.et_mobile_menu li li,
#et-boc header .et_mobile_menu li li {
  padding-left: 0;
}

/* adjust mobile menu anchors side paddings */
#main-header #mobile_menu.et_mobile_menu li a,
#et-boc header .et_mobile_menu li a {
  padding-left: 20px;
  padding-right: 20px;
}
/* indent sub menu */
#main-header #mobile_menu.et_mobile_menu li li a,
#et-boc header .et_mobile_menu li li a {
  padding-left: 40px;
  padding-right: 20px;
}
/* indent sub sub menus further */
#main-header #mobile_menu.et_mobile_menu li li li a,
#et-boc header .et_mobile_menu li li li a {
  padding-left: 60px;
  padding-right: 20px;
}
/* if mobile menu anchor has toggle, make room for it to fit next to the link */
#main-header
  #mobile_menu.et_mobile_menu
  .menu-item-has-children
  .sub-menu-toggle
  + a,
#et-boc header .et_mobile_menu .menu-item-has-children .sub-menu-toggle + a {
  padding-right: 44px;
}

/* - end mobile menu toggling elements - */

/* undo Divi's default styling of mobile menu links that have children */
#main-header #mobile_menu.et_mobile_menu .menu-item-has-children > a,
#et-boc header .et_mobile_menu .menu-item-has-children > a {
  background-color: transparent;
  font-weight: inherit;
}

/* make the current page's mobile menu link be different */
#main-header #mobile_menu.et_mobile_menu li.current-menu-item > a,
#et-boc header .et_mobile_menu li.current-menu-item > a {
  font-weight: bolder;
}

/* -- END HEADER -- */

/* -- FOOTER -- */

/* - Bottom Bar - */

/* if the bottom bar has equal column height setting, then make it always be flex, and stack the columns initially (for mobile use)
 * and make the columns vertical aligned to be vertically centered too */
#fs-footer-bottom-bar > .et_pb_row.et_pb_equal_columns {
  display: flex;
  align-items: center;
}

/* copyright wrapper */
#freshy_copyright {
  display: flex;
  flex-direction: column;
  align-items: center;
  color: white;
  font-size: 13px;
  line-height: 1.25em;
}

/* vertical pipe divider */
#freshy_copyright span.copyright_via {
  width: 33.33333%;
  height: 1px;
  overflow: hidden;
  white-space: nowrap;
  text-indent: 200%;
  background: rgba(255, 255, 255, 0.25);
  vertical-align: middle;
  margin: 10px auto 15px;
  display: block;
}

/* add an FS logo via background */
#freshy_copyright a.copyright_fs {
  display: block;
  width: 68px;
  height: 20px;
  background-image: url("/wp-content/uploads/freshy_logo_WHITE.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
  margin: 4px 0 0 0;
  flex-shrink: 0;
  transition: all 0.4s ease-in-out;
}
/* FS logo link hover */
#freshy_copyright a.copyright_fs:hover {
  opacity: 0.8;
}

/* remove the bottom margin that Divi adds to the social media follow icons */
#fs-footer-bottom-bar .et_pb_social_media_follow li {
  margin-bottom: 0;
}

@media (min-width: 600px) {
  /* make the copyright elements be side by side at wider screens */
  #freshy_copyright {
    flex-direction: row;
  }
  /* change horizontal pipe divider to vertical on wider screens */
  #freshy_copyright span.copyright_via {
    width: 1px;
    height: 20px;
    margin: 0 10px;
  }
}

@media (max-width: 980px) {
  /* make sure the row has columns going side by side instead of stacked */
  #fs-footer-bottom-bar > .et_pb_row.et_pb_equal_columns {
    flex-direction: column;
  }
  /* when stacked, adjust the gap between stacked columns */
  #fs-footer-bottom-bar > .et_pb_row.et_pb_equal_columns > .et_pb_column {
    margin-bottom: 1rem;
  }
  /* swap the order of columns when stacked, to the first column is the last one 
	 * and give no bottom margin to the first column, since we re-ordered it to the bottom */
  #fs-footer-bottom-bar
    > .et_pb_row.et_pb_equal_columns
    > .et_pb_column:first-child {
    order: 1;
    margin-bottom: 0;
  }
  /* center the copyright stuff when columns are stacked */
  #freshy_copyright {
    justify-content: center;
  }
  /* remove left margin on first social icon in regular Divi footer (when not using Theme Builder) when stacked */
  #footer-bottom .et-social-icons li:first-child {
    margin-left: 0;
  }
}

/* -- END FOOTER -- */

/* -- RESPONSIVE -- */

/* do for mobile */
@media screen and (max-width: 767px) {
  /* hide on mobile */
  .hide-mobile {
    display: none;
  }
}

/* do for desktop */
@media screen and (min-width: 768px) {
  /* hide on desktop */
  .hide-desktop {
    display: none;
  }
}

/* -- END RESPONSIVE -- */

/* -- CHECKLIST -- */

.checklist ul {
  margin: 0;
  padding: 0 !important;
  list-style: none;
}

.checklist ul li {
  position: relative;
  padding-left: 30px;
  margin: 0 0 6px !important;
}

.checklist-columns-2 ul li,
.checklist-columns-3 ul li,
.checklist-columns-4 ul li {
  margin-bottom: 30px !important;
}

@media (max-width: 638px) {
  .checklist-columns-2 ul li,
  .checklist-columns-3 ul li,
  .checklist-columns-4 ul li {
    margin-bottom: 20px !important;
  }
  .checklist-columns-2 ul li:last-child,
  .checklist-columns-3 ul li:last-child,
  .checklist-columns-4 ul li:last-child {
    margin-bottom: 0 !important;
  }
}

/* create columns of list items with this class */
@media (min-width: 639px) {
  .checklist-columns-2 ul::after,
  .checklist-columns-3 ul::after,
  .checklist-columns-4 ul::after {
    content: "";
    clear: both;
    display: table;
  }
  .checklist-columns-2 ul li,
  .checklist-columns-3 ul li,
  .checklist-columns-4 ul li {
    float: left;
    width: 50%;
    padding-right: 30px;
  }
  .checklist-columns-2 ul li:nth-child(odd),
  .checklist-columns-3 ul li:nth-child(odd),
  .checklist-columns-4 ul li:nth-child(odd) {
    clear: both;
  }
  .checklist-columns-2-alt > ul,
  .checklist-columns-3-alt > ul,
  .checklist-columns-4-alt > ul {
    column-count: 2;
    column-gap: 20px;
  }
  .checklist-columns-2-alt ul li,
  .checklist-columns-3-alt ul li,
  .checklist-columns-4-alt ul li {
    break-inside: avoid-column;
  }
}
@media (min-width: 981px) {
  .checklist-columns-3 ul li,
  .checklist-columns-4 ul li {
    float: left;
    width: 33.333333%;
  }
  .checklist-columns-3 ul li:nth-child(odd),
  .checklist-columns-4 ul li:nth-child(odd) {
    clear: none;
  }
  .checklist-columns-3 ul li:nth-child(3n + 1),
  .checklist-columns-4 ul li:nth-child(3n + 1) {
    clear: both;
  }
  .checklist-columns-3-alt ul,
  .checklist-columns-4-alt ul {
    column-count: 3;
  }
}
@media (min-width: 1199px) {
  .checklist-columns-4 ul li {
    float: left;
    width: 25%;
  }
  .checklist-columns-4 ul li:nth-child(odd) {
    clear: none;
  }
  .checklist-columns-4 ul li:nth-child(3n + 1) {
    clear: none;
  }
  .checklist-columns-4 ul li:nth-child(4n + 1) {
    clear: both;
  }
  .checklist-columns-4-alt ul {
    column-count: 4;
  }
}

.checklist ul li::before {
  font-family: "ETModules";
  content: "\4e";
  width: 20px;
  margin: 0;
  display: inline-block;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
  color: #32a709;
  /* set font size helps make icon sharper */
  font-size: 22px;
  font-weight: normal;
}
.pluslist ul li::before {
  content: "\e050";
}
.externallist ul li::before {
  content: "\e906";
}

/* -- END CHECKLIST -- */

/* -- DIVI HACKS -- */

/* make parallax image be centered at the start */
.et_parallax_bg {
  background-position: center center;
}

/* Divi was turning off bottom padding on last paragraphs, when it should be only if it's the last child */
p:last-of-type,
p:not(.has-background):last-of-type {
  padding-bottom: 1em;
}
p:last-child,
p:not(.has-background):last-child {
  padding-bottom: 0;
}

/* if there are more than one paragraphin the Fullwidth Header module, they should have padding */
.et_pb_fullwidth_header p:not(:last-child) {
  padding-bottom: 1em;
}

/* -- END DIVI HACKS -- */

/* -- PASSWORD PROTECTED -- */

/* set a max width to make it only as wide as most content */
.post-password-required .et_password_protected_form {
  width: 80%;
  margin: 10% auto;
  max-width: 1140px;
}

/* give the input a border */
.post-password-required .et_password_protected_form p input {
  border: 1px solid !important;
}

/* remove the arrow on hover of the submit button */
.post-password-required .et_password_protected_form .et_submit_button::after {
  display: none;
}

/* -- END PASSWORD PROTECTED -- */

/* -- TESTIMONIALS PLUGIN -- */

/* flip quote so it's an opening quote icon for grid and slider versions */
.b3_archive_testimonials_grid article .b3_quote.grid_quote::before,
.et_pb_module.et_pb_testimonial_slider .et_pb_slides_testi::before {
  transform: scale(-1, -1);
}

/* -- END TESTIMONIALS PLUGIN -- */

/* -- GRAVITY FORMS -- */

/* confirmation (success) message */
.gform_confirmation_wrapper .gform_confirmation_message {
  font-size: 1.2rem;
  line-height: 1.5em;
  padding: 2rem;
  background: rgba(90, 90, 90, 0.1);
  text-align: center;
}

/* -- END GRAVITY FORMS -- */

/* -- HELPERS -- */

/* use the "fullwidth-section" class on a SECTION to make a "standard" SECTION truly be fullwidth 
(NOTE: the SECTION needs THIS class) */
.fullwidth-section.et_pb_section {
  padding: 0;
}
.fullwidth-section.et_pb_section > .et_pb_row {
  width: 100% !important;
  max-width: 100% !important;
  padding: 0;
}

/* use the "fullwidth-row" class on a SECTION to make a "full width" ROW truly be fullwidth 
(NOTE: the ROW module settings needs to be Gutter Width 1, and the SECTION needs THIS class,
and unlike the class above, THIS class will auto-add padding to the columns) */
.fullwidth-row.et_pb_section {
  padding: 0;
}
.fullwidth-row.et_pb_section .et_pb_row {
  width: 100% !important;
  max-width: 100% !important;
  margin: 0 !important;
  padding: 0 !important;
}
/* helps add padding to each column */
.fullwidth-row.et_pb_section .et_pb_row > .et_pb_column {
  padding: 50px 10%;
}
@media (min-width: 767px) {
  .fullwidth-row.et_pb_section .et_pb_row > .et_pb_column {
    padding: 80px 6%;
  }
}
/* for some reason Divi removes bottom margin from modules if in column with no gutters, 
so we need to add margins back */
.fullwidth-row.et_pb_section
  .et_pb_row.et_pb_gutters1
  > .et_pb_column
  .et_pb_module:not(:last-child) {
  margin-bottom: 30px;
}
@media (min-width: 981px) {
  .fullwidth-row.et_pb_section
    .et_pb_row.et_pb_gutters1
    > .et_pb_column_2_3
    .et_pb_module:not(:last-child) {
    margin-bottom: 4.242%;
  }
  .fullwidth-row.et_pb_section
    .et_pb_row.et_pb_gutters1
    > .et_pb_column_1_3
    .et_pb_module:not(:last-child) {
    margin-bottom: 9.27%;
  }
}
/* reduce gap between toggles if in fullwidth row */
.fullwidth-row.et_pb_section
  .et_pb_row.et_pb_gutters1
  > .et_pb_column
  .et_pb_module.et_pb_toggle:not(:last-child) {
  margin-bottom: 3px;
}

@media (max-width: 980px) {
  /* use the "stacked-flex" class on a ROW to make it be flexbox when stacked, to help with adjusting order of stacked columns */
  .stacked-flex {
    display: flex;
    flex-wrap: wrap;
  }
  /* add the desired class to COLUMNS to designate their order when stacked within a "stacked-flex" ROW */
  .stacked-order-negative-4 {
    order: -4;
  }
  .stacked-order-negative-3 {
    order: -3;
  }
  .stacked-order-negative-2 {
    order: -2;
  }
  .stacked-order-negative-1 {
    order: -1;
  }
  .stacked-order-1 {
    order: 1;
  }
  .stacked-order-2 {
    order: 2;
  }
  .stacked-order-3 {
    order: 3;
  }
  .stacked-order-4 {
    order: 4;
  }
  /* adds margin to former "last" column that otherwise wouldn't have it */
  .stacked-flex:last-child .et_pb_column:last-child {
    margin-bottom: 30px;
  }
}

/* -- END HELPERS -- */

/* -- BLOG -- */

/* sidebar recent posts */
.et_pb_widget.widget_recent_entries ul li {
  margin-bottom: 1em;
}

/* sidebar recent posts dates */
.et_pb_widget.widget_recent_entries ul li span.post-date {
  display: table;
  font-size: 0.85em;
}

/* -- END BLOG -- */

.align_tems_cmn {
  align-items: center;
}
.align_tems_end {
  align-items: end;
}
.column-items-center {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-items: center;
}

h1,
h2,
h3,
h4,
h5,
h6 {
  padding-bottom: 0;
}
body {
  font-weight: 400;
}
#page-container strong {
  font-weight: 600;
}
@media all and (min-width: 981px) {
  .margin_right_3box_row .et_pb_column {
    width: calc(33.33% - 40px + 10px) !important;
    margin-right: 40px !important;
  }
  .margin_right_3box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }
  .margin_right_2box_row .et_pb_column {
    width: calc(50% - 40px + 20px) !important;
    margin-right: 40px !important;
  }
  .margin_right_2box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }
  .margin_right_page_4box_row .et_pb_column {
    width: calc(25% - 24px + 5px) !important;
    margin-right: 24px !important;
  }
  .margin_right_page_4box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }
}
@media only screen and (min-width: 981px) and (max-width: 1250px) {
  #page-container .cmn_section {
    padding-top: 70px;
    padding-bottom: 70px;
  }
  #page-container .cmn_section_top {
    padding-top: 70px;
  }
  #page-container .cmn_section_btm {
    padding-bottom: 70px;
  }
  #page-container .banner_title h1 {
    font-size: 60px !important;
  }
  #page-container .inner_banner h1 {
    font-size: 50px !important;
  }
  #page-container .font_fix h2 {
    font-size: 36px !important;
  }
  #page-container .font_fix h3 {
    font-size: 22px !important;
  }
  #page-container .font_fix {
    font-size: 17px;
  }
  .font_fix .et_pb_text_inner {
    font-size: 17px;
  }

  #page-container .font_fix p {
    font-size: 17px;
  }
  #page-container .big_txt {
    font-size: 20px;
  }
  #page-container .big_txt .et_pb_text_inner {
    font-size: 20px;
  }
  #page-container .big_txt p {
    font-size: 20px;
  }
  #page-container .checklist ul li {
    font-size: 17px;
  }
  #page-container .et_pb_button {
    font-size: 15px;
  }
}
@media only screen and (min-width: 1251px) and (max-width: 1440px) {
  #page-container .cmn_section {
    padding-top: 80px;
    padding-bottom: 80px;
  }
  #page-container .cmn_section_top {
    padding-top: 80px;
  }
  #page-container .cmn_section_btm {
    padding-bottom: 80px;
  }
  #page-container .banner_title h1 {
    font-size: 70px !important;
  }
  #page-container .inner_banner h1 {
    font-size: 55px !important;
  }
  #page-container .font_fix h2 {
    font-size: 40px !important;
  }
  #page-container .font_fix h3 {
    font-size: 25px !important;
  }
  #page-container .font_fix {
    font-size: 18px;
  }
  #page-container .font_fix .et_pb_text_inner {
    font-size: 18px;
  }
  #page-container .big_txt {
    font-size: 22px;
  }
  #page-container .big_txt .et_pb_text_inner {
    font-size: 22px;
  }
  #page-container .big_txt p {
    font-size: 22px;
  }
  #page-container .font_fix p {
    font-size: 18px;
  }
  #page-container .big_txt p {
    font-size: 22px;
  }
  #page-container .checklist ul li {
    font-size: 18px;
  }
  #page-container .et_pb_button {
    font-size: 16px;
  }
}
@media all and (max-width: 980px) {
  .column-reverse {
    display: flex;
    flex-direction: column-reverse;
  }
  .column-reverse .et_pb_column:first-child {
    margin-bottom: 0;
  }
  .column-reverse .et_pb_column:last-child {
    margin-bottom: 30px !important;
  }
  .reverse_margin .et_pb_column:last-child {
    margin-bottom: 0px !important;
  }
}

.et_pb_scroll_top.et-pb-icon {
  background: #0056c4;
  border-radius: 0;
  padding: 20px 0;
}
body div#page-container .et_pb_button {
  transition: all 0.4s ease-in-out !important;
  line-height: 1 !important;
  font-weight: 600;
  box-shadow: 0px 4px 40px 0px rgba(25, 22, 14, 0.04);
}
/*------------------------------------------------
---------------- Header ---------------
------------------------------------------------*/

#top-menu li {
  display: inline-block;
  padding-right: 75px;
}
body #page-container header#main-header #et-top-navigation .contact_us a {
  padding-top: 20px;
  padding-right: 24px;
  padding-bottom: 20px !important;
  padding-left: 24px;
  background: #0056c4;
  color: #fff !important;
  line-height: 1 !important;
  font-size: 18px !important;
  font-weight: 600;
  border-radius: 100px;
  margin-left: 60px;
}

body #main-header .container {
  width: 90% !important;
}
body #page-container header#main-header #et-top-navigation .contact_us a:hover {
  background: #fb4f14;
}

div#page-container #top-menu-nav > ul > li > a:hover {
  opacity: 1 !important;
  color: #fb4f14 !important;
}
div#page-container #top-menu a {
  font-weight: 600;
}
@media only screen and (min-width: 981px) {
  body #page-container #et-top-navigation {
    padding: 55px 0px !important;
  }
  body #page-container .et-fixed-header #et-top-navigation {
    padding: 25px 0px !important;
  }
  #top-menu li a {
    position: relative;
    padding-bottom: 12px !important;
    font-size: 18px !important;
  }
  #top-menu li a::before {
    position: absolute;
    content: "";
    width: 0%;
    height: 4px;
    background: #fb4f14;
    left: 0;
    bottom: 0;
    transition: 0.3s ease-in;
    border-radius: 100px;
  }

  body #et-top-navigation ul ul li a::before {
    position: relative !important;
  }
  #top-menu li.contact_us a::before {
    position: relative !important;
  }
  #top-menu li li a:before {
    left: 0;
  }
  #top-menu li.menu-item-has-children li a:before {
    width: 0%;
  }
  #top-menu li.menu-item-has-children a:before {
    width: 0;
  }
  #top-menu li:hover a:before,
  #top-menu .current_page_item a:before,
  #top-menu li.menu-item-has-children.current_page_item a:before {
    width: 100%;
  }
  #top-menu li.menu-item-has-children:hover a:before {
    width: 0%;
  }
  #top-menu li li:hover a:before,
  #top-menu li ul.sub-menu .current_page_item a:before,
  #top-menu li ul.sub-menu li:hover a:before {
    width: 95%;
  }
  #top-menu li.contact_us a:before {
    height: 0;
  }
}
#et-top-navigation {
  font-weight: 600 !important;
}
body #top-menu li:last-child {
  padding-right: 0px !important;
}
body div#page-container .et_pb_button {
  line-height: 1 !important;
}
@media only screen and (max-width: 980px) {
  body #page-container header#main-header #et-top-navigation .contact_us a {
    text-align: center;
    width: 100%;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    font-size: 14px !important;
    margin-left: 0px;
  }
}
/*------------------------------------------------
---------------- Footer ---------------
------------------------------------------------*/
.footer_menu .et-menu > li {
  padding-left: 0px;
  padding-right: 79px;
}
.footer_menu .et-menu > li:last-child {
  padding-right: 11px;
}
body #page-container .footer_menu .copy-right a {
  color: #2c2c2c !important;
  font-weight: 300 !important;
}
body #page-container .footer_menu .copy-right a:hover {
  color: #2c2c2c !important;
}
/*------------------------------------------------
----------------Form ---------------
------------------------------------------------*/
.contact_form textarea {
  resize: none;
}
.contact_form .gform_heading {
  display: none;
}
body #page-container #et-boc .contact_form .gform_fields {
  grid-column-gap: 8px;
  grid-row-gap: 8px;
}
body
  #page-container
  #et-boc
  .gform_wrapper.gravity-theme
  .gfield
  textarea.medium {
  height: 101px;
}
body #page-container #et-boc .contact_form .gform_confirmation_message {
  color: #fff;
}

#page-container #et-boc .contact_form div.gform_footer.top_label {
  padding: 0;
  margin-top: 12px;
}
body #page-container .contact_form .gform_wrapper .ginput_container textarea,
body #page-container .contact_form .gform_wrapper .ginput_container input {
  margin-top: 0 !important;
  background: #fff !important;
  padding: 12px 20px !important;
  color: #020404;
  font-size: 19px !important;
  border-radius: 5px;
}
body #page-container .footer_form .gform_wrapper .ginput_container textarea,
body #page-container .footer_form .gform_wrapper .ginput_container input {
  border: none;
}
body .contact_form .gform_wrapper label {
  font-size: 19px;
  font-weight: 400;
  color: #020404;
}
body .contact_form textarea::-webkit-input-placeholder,
body .contact_form input::-webkit-input-placeholder {
  opacity: 1 !important;
  color: rgba(2, 4, 4, 0.4) !important;
}
body .contact_form textarea::-moz-placeholder,
body .contact_form input::-moz-placeholder {
  opacity: 1 !important;
  color: rgba(2, 4, 4, 0.4) !important;
}
body .contact_form textarea:-ms-input-placeholder,
body .contact_form input:-ms-input-placeholder {
  opacity: 1 !important;
  color: rgba(2, 4, 4, 0.4) !important;
}
body .contact_form div.gform_footer.top_label input {
  padding: 18.9px 24px !important;
  cursor: pointer;
  line-height: 1 !important;
  margin-top: 0;
  width: 100%;
  font-weight: 600;
}
body .contact_form div.gform_footer.top_label {
  text-align: center;
}

@media (min-width: 981px) and (max-width: 1450px) {
  body #page-container .contact_form .gform_wrapper label,
  body #page-container .contact_form textarea::-webkit-input-placeholder,
  body #page-container .contact_form input::-webkit-input-placeholder,
  body #page-container .contact_form .gform_wrapper .ginput_container input,
  body #page-container .contact_form .gform_wrapper .ginput_container textarea,
  body #page-container .contact_form .gform_wrapper label {
    font-size: 18px !important;
  }
  body .contact_form div.gform_footer.top_label input {
    font-size: 17px;
  }
  body .contact_form div.gform_footer.top_label input {
    padding: 15px 20px !important;
  }
}
@media (min-width: 981px) and (max-width: 1366px) {
  body #page-container .contact_form .gform_wrapper label,
  body #page-container .contact_form textarea::-webkit-input-placeholder,
  body #page-container .contact_form input::-webkit-input-placeholder,
  body #page-container .contact_form .gform_wrapper .ginput_container input,
  body #page-container .contact_form .gform_wrapper .ginput_container textarea,
  body #page-container .contact_form .gform_wrapper label {
    font-size: 17px !important;
  }
  body .contact_form div.gform_footer.top_label input {
    font-size: 16px;
  }
  body .contact_form div.gform_footer.top_label input {
    padding: 15px 20px !important;
  }
}
@media (min-width: 768px) and (max-width: 980px) {
  body #page-container .contact_form .gform_wrapper label,
  body #page-container .contact_form textarea::-webkit-input-placeholder,
  body #page-container .contact_form input::-webkit-input-placeholder,
  body #page-container .contact_form .gform_wrapper .ginput_container input,
  body #page-container .contact_form .gform_wrapper .ginput_container textarea,
  body #page-container .contact_form .gform_wrapper label {
    font-size: 17px !important;
  }
  body .contact_form div.gform_footer.top_label input {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  body .contact_form div.gform_footer.top_label input,
  body #page-container .contact_form .gform_wrapper label,
  body #page-container .contact_form textarea::-webkit-input-placeholder,
  body #page-container .contact_form input::-webkit-input-placeholder,
  body #page-container .contact_form .gform_wrapper .ginput_container input,
  body #page-container .contact_form .gform_wrapper .ginput_container textarea,
  body #page-container .contact_form .gform_wrapper label {
    font-size: 16px !important;
  }
}
/*------------------------------------------------
----------------Home Page ---------------
------------------------------------------------*/
body #page-container .home_banner .et_pb_container.clearfix {
  height: auto !important;
  min-height: auto !important;
}
body #page-container .home_banner .et_pb_slide {
  padding-top: 0 !important;
}
body #page-container .home_banner .et_pb_slide_description {
  padding: 0;
  padding-top: 14vw;
  padding-bottom: 14vw;
  max-width: 980px;
}

@media only screen and (min-width: 1550px) {
  body #page-container .home_banner .et_pb_slide_description {
    padding-top: 11.1vw;
    padding-bottom: 11.1vw;
  }
}
body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-prev,
body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-next {
  opacity: 1 !important;
}
body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-prev {
  left: 74px;
}
body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-next {
  right: 74px;
}
body #page-container .home_banner .et-pb-arrow-next,
body #page-container .home_banner .et-pb-arrow-prev {
  font-size: 36px;
  background: #0056c4;
  width: 48px;
  height: 48px;
  border-radius: 100% !important;
  line-height: 36px !important;
  box-shadow: 0px 4px 40px 0px rgba(25, 22, 14, 0.04);
}
body #page-container .home_banner .et-pb-arrow-next:hover,
body #page-container .home_banner .et-pb-arrow-prev:hover {
  background: #fb4f14;
}
body #page-container .home_banner .et-pb-arrow-next::before {
  content: url(/wp-content/uploads/Hero-Arrow-Right.png);
  padding-left: 14px;
}
body #page-container .home_banner .et-pb-arrow-prev::before {
  content: url(/wp-content/uploads/Hero-Arrow-Left.png);
  padding-left: 14px;
}
.et_pb_bg_layout_dark .et_pb_slide_description {
  text-shadow: none !important;
}
body #page-container .home_banner .et-pb-controllers a {
  background-color: #fff;
  border-radius: 12px;
  width: 12px;
  height: 12px;
  padding: 0;
  opacity: 0.2;
  box-shadow: 0px 4px 40px 0px rgba(25, 22, 14, 0.04);
}
body #page-container .home_banner .et-pb-controllers .et-pb-active-control {
  background-color: #0056c4;
  width: 24px;
  opacity: 1;
}
.demo-email {
  display: flex;
  align-items: center;
  margin: auto;
}
.demo-email img {
  margin-right: 12px;
  padding: 0px;
  transition: margin 300ms;
}
body #page-container .custom_media li a.icon::before {
  font-size: 15px;
}

/*------------------------------------------------
----------------Responsive ---------------
------------------------------------------------*/
body #page-container .home_banner .et_pb_more_button {
  margin-top: 40px;
}
/*style the Divi blog link text as a button*/

.et_pb_post a.more-link {
  padding-top: 20px;
  padding-right: 24px;
  padding-bottom: 20px !important;
  padding-left: 24px;
  background: #0056c4;
  color: #fff !important;
  line-height: 1 !important;
  font-weight: 600;
  border-radius: 100px;
  display: inline-block;
  transition: all 0.3s ease-in-out;
  margin-top: 20px;
  text-transform: uppercase;
}
.pa-blog-equal-height .post-content-inner {
  margin-top: 20px;
}

/*style the Divi blog link text as a button on hover*/

.et_pb_post a.more-link:hover {
  background: #fb4f14;
  color: #fff;
  transition: all 0.3s ease-in-out;
}
body div#page-container .inner_banner {
  padding-top: 100px !important;
  padding-bottom: 100px !important;
}
.et_pb_fullwidth_header .header-content {
  padding: 0px !important;
}
.et_pb_fullwidth_header
  .et_pb_fullwidth_header_container.center
  .header-content {
  margin: 0px auto !important;
  width: 90% !important;
}
body #page-container .footer_menu {
  margin-bottom: 0px !important;
}
@media (min-width: 981px) and (max-width: 1150px) {
  #logo {
    height: 75% !important;
  }
  body #page-container #et-top-navigation {
    padding: 35px 0px !important;
  }
  body #page-container .et-fixed-header #et-top-navigation {
    padding: 20px 0px !important;
  }
  #top-menu li a {
    font-size: 15px !important;
  }
  #top-menu li {
    display: inline-block;
    padding-right: 60px;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    font-size: 15px !important;
    margin-left: 30px;
  }
  div#page-container .home_banner .et_pb_slide_title {
    font-size: 55px !important;
  }
  body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-prev {
    left: 30px;
  }
  body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-next {
    right: 30px;
  }
  .et_pb_module.et_pb_divider.divider_line {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
  body #page-container .home_banner .et_pb_more_button {
    margin-top: 20px;
  }
  .footer_menu .et-menu > li {
    padding-right: 60px;
  }
  .footer_menu ul li a {
    font-size: 15px !important;
  }
  body div#page-container .inner_banner {
    padding-top: 70px !important;
    padding-bottom: 70px !important;
  }
  div#page-container .inner_banner .et_pb_module_header {
    font-size: 45px !important;
  }
}
@media (min-width: 1151px) and (max-width: 1366px) {
  #logo {
    height: 75% !important;
  }
  body #page-container #et-top-navigation {
    padding: 40px 0px !important;
  }
  body #page-container .et-fixed-header #et-top-navigation {
    padding: 25px 0px !important;
  }
  #top-menu li a {
    font-size: 16px !important;
  }
  #top-menu li {
    display: inline-block;
    padding-right: 70px;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    font-size: 16px !important;
    margin-left: 50px;
  }
  .et_pb_module.et_pb_divider.divider_line {
    margin-top: 25px !important;
    margin-bottom: 25px !important;
  }
  body #page-container .home_banner .et_pb_more_button {
    margin-top: 24px;
  }
  div#page-container .home_banner .et_pb_slide_title {
    font-size: 60px !important;
  }
  body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-prev {
    left: 40px;
  }
  body #page-container .home_banner .et-pb-slider-arrows a.et-pb-arrow-next {
    right: 40px;
  }
  div#page-container .inner_banner .et_pb_module_header {
    font-size: 50px !important;
  }
  body div#page-container .inner_banner {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }
}
@media (max-width: 980px) {
  .tab_menu .et_pb_widget {
    margin: 0px !important;
    width: 100% !important;
  }
  body #page-container .tab_menu .copy-right a {
    color: #2c2c2c !important;
    font-weight: 300 !important;
  }
  body #page-container .tab_menu .et_pb_widget ul li {
    margin-bottom: 12px;
  }
  body #page-container .tab_menu .et_pb_widget ul li:last-child {
    margin-bottom: 0px;
  }
  .demo-email {
    justify-content: center;
  }
  body #page-container .et_pb_module.et_pb_divider.divider_line {
    margin-top: 20px !important;
    margin-bottom: 20px !important;
  }
  body div#page-container .inner_banner {
    padding-top: 60px !important;
    padding-bottom: 60px !important;
  }
}
.entry-featured-image-url {
  position: relative;
  overflow: hidden;
}

.entry-featured-image-url:after {
  content: "";
  position: absolute;
  width: 200%;
  height: 0%;
  left: 50%;
  top: 50%;
  background-color: rgba(255, 255, 255, 0.3);
  transform: translate(-50%, -50%) rotate(-45deg);
  z-index: 1;
}

.entry-featured-image-url:hover:after {
  height: 250%;
  transition: all 600ms linear;
  background-color: transparent;
}

/* Video Icon */

.gform_confirmation_wrapper .gform_confirmation_message {
  font-size: 18px;
  line-height: 1.52em;
}
body #page-container .custom-video .et_pb_video_play::before {
  content: url("/wp-content/uploads/video-icon-up.png") !important;
}
@media (min-width: 981px) and (max-width: 1366px) {
  body #page-container .custom-video .et_pb_video_play::before {
    content: url("/wp-content/uploads/video-icon-tab.png") !important;
  }
}
@media all and (max-width: 980px) {
  #logo {
    height: 90% !important;
    min-height: 90% !important;
  }
  #mobile_menu li a {
    text-transform: uppercase !important;
  }
  body #page-container .home_banner .et_pb_slide_description {
    padding-top: 120px;
    padding-bottom: 120px;
  }
  body #page-container .home_banner .et_pb_more_button {
    margin-top: 20px;
  }
  body #page-container .contact_form .gform_wrapper .ginput_container textarea,
  body #page-container .contact_form .gform_wrapper .ginput_container input {
    padding: 10px 20px !important;
  }
  body .contact_form div.gform_footer.top_label input {
    padding: 13.9px 24px !important;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    padding-top: 16px;
    padding-bottom: 16px !important;
  }
  .gform_confirmation_wrapper .gform_confirmation_message {
    font-size: 16px;
  }
  body #page-container .custom-video .et_pb_video_play::before {
    content: url("/wp-content/uploads/video-icon-tab.png") !important;
  }
}
@media all and (max-width: 767px) {
  body #page-container .home_banner .et_pb_slide_description {
    padding-top: 100px;
    padding-bottom: 100px;
  }
  body #page-container .home_banner .et-pb-controllers a {
    border-radius: 8px;
    width: 8px;
    height: 8px;
  }
  body #page-container .home_banner .et-pb-controllers .et-pb-active-control {
    width: 16px;
  }
  body .contact_form div.gform_footer.top_label input {
    padding: 12.9px 24px !important;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    padding-top: 15px;
    padding-bottom: 15px !important;
  }
  body #page-container .custom-video .et_pb_video_play::before {
    content: url("/wp-content/uploads/video-icon-phone.png") !important;
  }
}
.wp-pagenavi a, .wp-pagenavi span {
	border: 1px solid #0056c4;
}
.wp-pagenavi a:hover, .wp-pagenavi span.current {
	border-color: #fb4f14 !important;
}
@media all and (max-width: 480px) {
  body #page-container .et_pb_module.et_pb_divider.divider_line {
    margin-top: 16px !important;
    margin-bottom: 16px !important;
  }
  body #page-container .home_banner .et_pb_slide_description {
    padding-top: 90px;
    padding-bottom: 90px;
  }
  body div#page-container .inner_banner {
    padding-top: 50px !important;
    padding-bottom: 50px !important;
  }
}
@media all and (max-width: 400px) {
  div#page-container .home_banner .et_pb_slide_title {
    font-size: 28px !important;
  }
}
