/*
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;
  }
  .single h1 {
    font-size: 32px !important;
  }
  .single h2 {
    font-size: 26px !important;
  }
}

/* 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 -- */

#hide-menu-loop ul {
  display: none;
}

.is-flex {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.is-flex-no-gap {
  display: flex;
  align-items: center;
}
.et_pb_menu_1_tb_header .et_pb_menu__icon.et_pb_menu__search-button,
.et_pb_menu_1_tb_header .et_pb_menu__icon.et_pb_menu__close-search-button {
  font-size: 20px;
  color: #063537;
  transform: rotate(264deg);
  font-weight: 700;
}
.et_pb_button {
  line-height: 15px !important;
}
.highlight-dark {
  color: #036a6e;
}
.highlight-light {
  color: #35e0b3;
}
.object-fit-image-hero img {
  object-fit: cover;
}

.blurb.active {
  border-left-color: rgba(53, 224, 179, 1) !important;
}

.image {
  visibility: hidden; 
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transition: opacity 0.7s ease, transform 0.7s ease;
  transform: translateX(-50px);
}

.image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.image.active {
  visibility: visible;
  opacity: 1;
  transform: translateX(0);
  position: relative;
}


.blurb:hover {
  cursor: pointer;
  background-color: rgba(6, 53, 55, 0.1);
}

.css-grid > div {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 24px;
}
.css-grid .entry-title {
  background-color: rgba(6, 53, 55, 1);
  padding: 22px 24px 26px 24px;
  position: absolute;
  bottom: 0;
  width: 100%;
}
.et_pb_image_container img,
.et_pb_post a img {
  height: 320px;
  object-fit: cover;
}
.et_pb_post {
  margin-bottom: 0px !important;
}
.ps_pagination .swiper-pagination-bullet,
#et-boc .b3testimonialgridslider_main .ps_pagination .swiper-pagination-bullet {
  width: 10px;
  height: 10px;
  background-color: rgba(3, 106, 110, 1);
  opacity: 30%;
}
.et-db
  .b3testimonialgridslider_main
  .swiper-pagination-bullet.swiper-pagination-bullet-active,
#et-boc
  .b3testimonialgridslider_main
  .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background-color: rgba(3, 106, 110, 1) !important;
  opacity: 100%;
}
.et_pb_b3_testimonial_grid_slider .swiper-button-next:before,
.et_pb_b3_testimonial_grid_slider .swiper-button-prev:before {
  content: "";
  background-repeat: no-repeat;
  background-color: rgba(3, 106, 110, 1);
  width: 48px;
  height: 48px;
  border-radius: 50px;
  background-position: center;
  position: absolute;
}
.swiper-button-prev:before {
  background: url(/wp-content/uploads/Arrow-left.png);
  margin-right: 32px;
}
.swiper-button-next:before {
  background: url(/wp-content/uploads/Arrow-right.png);
  margin-left: 32px;
}
.et-db .et_pb_b3_testimonial_grid_slider .b3testimonialgridslider_image img,
#et-boc .et_pb_b3_testimonial_grid_slider .b3testimonialgridslider_image img {
  position: absolute;
  border-radius: 50px;
  width: 56px;
  height: 56px;
  border-style: none;
  object-fit: cover;
  bottom: 0px;
  left: 0;
}
.et-db
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_name,
#et-boc
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_name,
.et-db
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_company_name,
#et-boc
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_company_name {
  padding-left: 76px;
  text-align: left !important;
  position: absolute;
  bottom: 13px;
}
.b3testimonialgridslider_testimonial_center.b3testimonialgridslider_grid.b3testimonialEqual {
  height: 324px !important;
}
.et-db .b3testimonialgridslider_grid article,
#et-boc .b3testimonialgridslider_grid article {
  display: flex;
  flex-direction: column;
  height: 252px;
  justify-content: flex-end;
}
.et_pb_b3_testimonial_grid_slider_0 .b3testimonialgridslider_testimonial_text,
.et_pb_b3_testimonial_grid_slider_0
  .b3testimonialgridslider_testimonial_text
  p {
  line-height: 32px !important;
}
.et-db
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_text,
#et-boc
  .et_pb_b3_testimonial_grid_slider
  .b3testimonialgridslider_testimonial_text {
  margin-bottom: 72px !important;
}
.css-grid .entry-title::after {
  content: "";
  background: url(/wp-content/uploads/Arrow-right.png);
  transition: all 0.3s ease-in-out;
  width: 15px;
  height: 15px;
  position: absolute;
  right: 24px;
  bottom: 46%;
  background-repeat: no-repeat;
}
.css-grid .entry-title:hover::after {
  margin-right: -20px;
}
.css-grid .entry-title a {
  width: 176px;
  display: block;
}
.et_pb_posts .et_pb_post {
  position: relative;
  width: 100%;
  height: 320px;
}
.et_pb_menu--style-centered .et_pb_menu__menu > nav > ul,
.et_pb_menu--style-centered .et_pb_menu__wrap {
  justify-content: flex-end;
}
#menu-primary-menu-without-button {
  display: flex;
  gap: 72px;
}
#menu-primary-menu-without-button li {
  padding-left: 0;
  padding-right: 0;
}
.et_pb_menu--style-left_aligned .et_pb_menu__logo {
  margin-right: 0;
}
.icon-left .et_pb_text_inner p::before {
  content: "";
  position: absolute;
  background-position: center;
  background-repeat: no-repeat;
  width: 24px;
  height: 24px;
  background: url("/wp-content/uploads/scroll-up.png");
  right: 90px;
}
ul#menu-footer-menu-privacy {
  display: flex;
  gap: 68px;
}
.et_pb_menu .et-menu {
  margin-left: 0px !important;
  margin-right: 0px !important;
}
.et_pb_menu__search-button:after {
  content: "U";
  transform: rotate(264deg);
  font-weight: 700;
  font-size: 24px;
}

button.et_pb_menu__icon.et_pb_menu__search-button {
  padding-top: 17px;
  padding-right: 16px;
  padding-bottom: 17px;
  padding-left: 16px;
  background-color: #eaf2f3;
  margin: 0 0 0 60px;
  height: fit-content;
  align-self: center;
}

.et_pb_menu .et_pb_menu__wrap {
  justify-content: flex-end;
}

ul#menu-primary-menu {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 60px;
}

ul#menu-primary-menu li {
  padding: 0 !important;
  margin: 18.5px 0px;
}
ul#menu-primary-menu li a {
  padding: 0;
  margin: 0;
}
@media only screen and (min-width: 980px) {
  li.et_pb_button.et_pb_button_0_tb_header.et_pb_bg_layout_light a {
    padding: 20px 24px !important;
    color: white !important;
    font-size: 15px !important;
    text-transform: uppercase !important;
    letter-spacing: 5px;
  }
  li.et_pb_button.et_pb_button_0_tb_header.et_pb_bg_layout_light a:hover {
    color: white !important;
    opacity: 1 !important;
  }
  li.et_pb_button.et_pb_button_0_tb_header.et_pb_bg_layout_light:hover {
    background-color: #024d4f !important;
    color: white !important;
  }
}
.et_pb_menu__search {
  background-color: #eaf2f3;
  margin-left: 20px;
  height: 55px;
  margin-top: 25px;
  padding-left: 20px;
}
span.et_pb_scroll_top.et-pb-icon.et-visible {
  display: none !important;
}
html {
  scroll-behavior: smooth;
}
#menu-footer-menu-privacy::after {
  content: "";
  display: inline-block;
  width: 4px;
  height: 4px;
  background-color: #063537;
  border-radius: 50%;
  margin: 0 8px;
  position: absolute;
  left: 48%;
  top: 42%;
}

@media only screen and (min-width: 980px) {
  #menu-primary-menu .current-menu-item {
    position: relative;
  }

  #menu-primary-menu .current-menu-item::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 104px;
    top: -72px;
    left: -25px;
    background: linear-gradient(180deg, #036a6e 0%, rgba(3, 106, 110, 0) 100%);
    opacity: 0.1;
    z-index: 0;
    padding: 0 25px;
  }

  #menu-primary-menu .current-menu-item::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 5px;
    top: -72px;
    left: -25px;
    background-color: #35e0b3;
    z-index: 1;
    padding: 0 25px;
  }
  #menu-primary-menu li:hover::before {
    content: "";
    position: absolute;
    width: 100%;
    height: 104px;
    top: -72px;
    left: -25px;
    background: linear-gradient(180deg, #036a6e 0%, rgba(3, 106, 110, 0) 100%);
    opacity: 0.1;
    z-index: 0;
    padding: 0 25px;
  }
  #menu-primary-menu li:hover::after {
    content: "";
    position: absolute;
    width: 100%;
    height: 5px;
    top: -72px;
    left: -25px;
    background-color: #35e0b3;
    z-index: 1;
    opacity: 0.5;
    padding: 0 25px;
  }
}
.swiper-container-horizontal > .swiper-pagination-bullets,
.swiper-pagination-custom,
.swiper-pagination-fraction {
  bottom: 0px !important;
}
.et-db .b3testimonialgridslider_main .b3testimonialgridslider .swiper-wrapper,
#et-boc .b3testimonialgridslider_main .b3testimonialgridslider .swiper-wrapper {
  margin-bottom: 48px !important;
}
@media only screen and (max-width: 690px) {
  body #page-container .et_pb_section .et_pb_button_1 {
    line-height: 1.4 !important;
  }

  .et-db .b3testimonialgridslider_grid article,
  #et-boc .b3testimonialgridslider_grid article {
    height: 300px;
  }
  .swiper-button-prev:before {
    left: 115px;
  }
  .swiper-button-next:before {
    right: 115px;
  }
  .et_pb_b3_testimonial_grid_slider .swiper-button-next:before,
  .et_pb_b3_testimonial_grid_slider .swiper-button-prev:before {
    bottom: -258px;
  }

  .et_pb_menu--style-left_aligned .et_pb_menu__logo {
    width: 200px;
  }
  button.et_pb_menu__icon.et_pb_menu__search-button {
    padding: 10px 9px;
    margin: 0;
  }
  .et_pb_menu__search-button:after {
    font-size: 18px;
  }
  .et_pb_menu .et_pb_menu__wrap {
    justify-content: flex-start;
    flex-direction: row-reverse;
  }
  .is-flex-no-gap {
    flex-direction: column;
  }
  .et_pb_image_0 .et_pb_image_wrap img,
  .et_pb_image_1 .et_pb_image_wrap img {
    height: auto !important;
  }
  .css-grid > div {
    grid-template-columns: repeat(1, 1fr);
  }
  .et_pb_posts .et_pb_post {
    width: 100%;
  }
  .et_pb_blurb_8.et_pb_blurb {
    width: 100% !important;
  }
}
@media only screen and (max-width: 980px) {
  .et_pb_menu__search {
    margin-left: 0px;
    height: auto;
    margin-top: 0px;
    padding-left: 20px;
  }
  .et_pb_menu .et_pb_menu__search-container--visible {
    padding-left: 0px !important;
    width: 100%;
  }
  .et_pb_column_0 {
    padding-top: 30px;
  }
  .et_pb_row.et_pb_row_0.is-flex-no-gap {
    flex-direction: column-reverse;
  }
  ul#menu-primary-menu-without-button a {
    padding: 10px 5px;
  }
  ul#menu-primary-menu-without-button {
    padding: 12px 0 !important;
  }
  .et-l--footer .et_pb_menu_inner_container.clearfix {
    flex-direction: column;
  }
  #menu-primary-menu-without-button {
    gap: 10px;
    justify-content: center;
  }
  #menu-footer-menu-privacy::after {
    left: 38%;
  }
  .et_pb_module.et_pb_menu.et_pb_menu_1_tb_footer.et_pb_bg_layout_light.et_pb_text_align_left.et_dropdown_animation_fade.et_pb_menu--without-logo.et_pb_menu--style-centered {
    display: flex;
    justify-content: center;
  }
  .et-l--footer .et_mobile_nav_menu {
    display: none !important;
  }
  .et-l--footer .et_pb_menu .et_pb_menu__menu {
    display: block !important;
  }
  body .et-l--header .et_pb_button {
    font-size: unset !important;
    background-color: unset !important;
    border-width: unset !important;
    border-radius: 0px;
    letter-spacing: unset !important;
    padding: 0 !important;
    border: 0px !important;
	 text-transform:none;
  }
  .mobile_menu_bar:before {
    font-size: 37px;
  }
  .et_pb_menu .et_mobile_menu {
    margin-top: 10px;
  }
  .et_pb_module .mobile_menu_bar:before {
    top: 0px;
  }
}
body #page-container .et_pb_section .et_pb_button_4 {
  line-height: 1.4 !important;
}

@media only screen and (min-device-width: 768px) and (max-device-width: 1200px) and (orientation: landscape) {
  .et_pb_menu__logo {
    width: 270px;
  }
  .et_pb_row {
    width: 95% !important;
  }
  .css-grid > div {
    grid-template-columns: repeat(2, 1fr);
  }
  .et_pb_posts .et_pb_post {
    width: 100%;
  }
  #menu-primary-menu-without-button {
    gap: 50px;
  }
  ul#menu-primary-menu {
    gap: 30px;
  }
  button.et_pb_menu__icon.et_pb_menu__search-button {
    margin-left: 30px;
  }
  .swiper-button-prev:before {
    left: 450px;
  }
  .swiper-button-next:before {
    right: 450px;
  }
  .et_pb_b3_testimonial_grid_slider .swiper-button-next:before,
  .et_pb_b3_testimonial_grid_slider .swiper-button-prev:before {
    bottom: -250px;
  }
}

@media only screen and (min-device-width: 768px) and (max-device-width: 1024px) and (orientation: portrait) {
  button.et_pb_menu__icon.et_pb_menu__search-button {
    padding: 10px 9px;
    margin: 0;
  }
  .et_pb_menu .et_pb_menu__wrap {
    justify-content: flex-start;
    flex-direction: row-reverse;
  }
  .et-l--footer .et_pb_module.et_pb_text_align_left {
    text-align: center !important;
  }

  .et_pb_blurb_9 .et_pb_blurb_content {
    max-width: unset;
  }
  .css-grid > div {
    grid-template-columns: repeat(2, 1fr);
  }
  .et_pb_posts .et_pb_post {
    width: 100%;
  }
  .is-flex-no-gap {
    flex-direction: column;
  }
  .swiper-button-prev:before {
    left: 300px;
  }
  .swiper-button-next:before {
    right: 300px;
  }
  .et_pb_b3_testimonial_grid_slider .swiper-button-next:before,
  .et_pb_b3_testimonial_grid_slider .swiper-button-prev:before {
    bottom: -254px;
  }

}
.et_pb_image_0 .et_pb_image_wrap img {
  object-fit: cover;
}
.caligraphy {
  font-family: "Caveat", serif;
  font-size: 44px;
  font-weight: 400;
  line-height: 66px;
}
li.et_pb_button.et_pb_button_0_tb_header.et_pb_bg_layout_light.et_pb_menu_page_id-514.menu-item.menu-item-type-custom.menu-item-object-custom.current-menu-item.menu-item-514
  a {
  color: white !important;
}

body
  .gform_wrapper
  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
    [type="button"]
  ):not([type="image"]):not([type="file"]),
body .gform_wrapper textarea.textarea,
body
  div.form_saved_message
  div.form_saved_message_emailform
  form
  input[type="text"] {
  background-color: rgba(3, 106, 110, 0.05);
  color: rgba(38, 41, 41, 1);
}
body .gform_wrapper #field_submit input,
body .gform_wrapper .gform_footer input.button,
body .gform_wrapper .gform_page_footer input.button,
body
  div.form_saved_message
  div.form_saved_message_emailform
  form
  input[type="submit"] {
  background-color: #036a6e;
  color: #ffffff;
  border-radius: 0px;
  font-family: "Poppins", Helvetica, Arial, Lucida, sans-serif;
  font-size: 15px;
  letter-spacing: 5px !important;
  text-transform: uppercase;
  padding: 20px 24px !important;
  font-weight: 600;
  border: 1px;
  transition: border 0.3s ease-in-out;
  border: 0px solid transparent;
}
body .gform_wrapper #field_submit input:hover,
body .gform_wrapper .gform_footer input.button:hover,
body .gform_wrapper .gform_page_footer input.button:hover,
body
  div.form_saved_message
  div.form_saved_message_emailform
  form
  input[type="submit"]:hover {
  background-color: #024d4f !important;
  color: white !important;
  border-radius: 0px !important;
  border: 2px solid transparent;
}
/* Hide the entry title */
.grid-masonry .entry-title {
  display: none;
}

/* Masonry Grid Container */
.grid-masonry > div {
  column-count: 2; /* 2 columns */
  column-gap: 20px; /* Spacing between columns */
}

/* Masonry Grid Items */
.grid-masonry .et_pb_post {
  position: relative;
  display: inline-block; /* Ensure items don't break across columns */
  width: 100%; /* Full width */
  padding: 40px !important;
  background-color: white;
  break-inside: avoid; /* Prevent items from breaking across columns */
  margin-bottom: 20px !important; /* Spacing between items */
  height: auto;
}

/* Responsive Adjustments */
@media (max-width: 768px) {
  .grid-masonry > div {
    column-count: 1; /* 1 column on tablets and mobile */
  }
}
@media only screen and (min-width: 980px) and (max-width: 1400px) {
  .is-flex-no-gap {
    display: flex;
    flex-direction: row;
  }
  .et_pb_row {
    padding: 0 20px;
  }
}
@media only screen and (min-width: 980px) and (max-width: 1073px) {
  .et_pb_b3_testimonial_grid_slider_0
    .b3testimonialgridslider_grid
    article
    .b3testimonialgridslider_quote.b3testimonialgridslider_grid_quote:before {
    top: -15px;
  }
}
@media only screen and (min-width: 1200px) and (max-width: 1310px) {
  .et_pb_menu__logo {
    width: 270px;
  }

  #menu-primary-menu-without-button {
    gap: 50px;
  }
  ul#menu-primary-menu {
    gap: 30px;
  }
  button.et_pb_menu__icon.et_pb_menu__search-button {
    margin-left: 30px;
  }
}
@media only screen and (min-width: 1050px) and (max-width: 1192px) {
  ul#menu-primary-menu {
    gap: 30px;
  }
  button.et_pb_menu__icon.et_pb_menu__search-button {
    margin-left: 30px;
  }
  .et_pb_menu__logo {
    width: 230px;
  }
}
@media only screen and (min-width: 981px) and (max-width: 1050px) {
  ul#menu-primary-menu {
    gap: 20px;
  }
  button.et_pb_menu__icon.et_pb_menu__search-button {
    margin-left: 20px;
  }
  .et_pb_menu__logo {
    width: 220px;
  }
  ul#menu-primary-menu li a {
    font-size: 16px;
  }
  .et_pb_menu .et_pb_menu__wrap {
    justify-content: flex-end;
    flex-direction: row;
  }
  #menu-primary-menu-without-button {
    gap: 40px;
  }
}
.single h1 {
  font-size: 66px;
  font-weight: 600;
  line-height: 1.2;
}
.single h2 {
  font-size: 48px;
  font-weight: 600;
  line-height: 1.2;
}
.single .entry-content {
  display: flex;
  flex-direction: column;
  gap: 25px;
}
.single .container {
  max-width: 1352px;
  width: 100%;
  padding-top: 0 !important;
}
.single .et_post_meta_wrapper img {
  width: 100%;
}
@media only screen and (max-width: 1370px) {
  .single .container {
    padding: 0 20px;
  }
  .search-results .container {
    padding: 0 20px;
  }
}
.search-results div#sidebar {
  display: none;
}
.search-results #main-content .container:before {
  display: none;
}
.search-results div#left-area {
  width: 100%;
  padding: 0 !important;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.search-results .container {
  padding-top: 0px !important;
  width: 100%;
  max-width: 1352px;
  padding-left: 20px;
  padding-right: 20px;
}
.search-results .entry-featured-image-url img {
  width: 100%;
  height: 500px;
}
ul#menu-primary-menu-without-button li a {
  font-weight: 400;
}
.page-id-42
  .et_pb_with_border.et_pb_module.et_pb_text.et_pb_text_0.et_pb_text_align_left.et_pb_bg_layout_light {
  width: fit-content;
}
@media only screen and (min-width: 691px) and (max-width: 767px) {
  .css-grid > div {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
  .swiper-button-prev:before {
    left: 300px;
  }
  .swiper-button-next:before {
    right: 300px;
  }
  .et_pb_b3_testimonial_grid_slider .swiper-button-next:before,
  .et_pb_b3_testimonial_grid_slider .swiper-button-prev:before {
    bottom: -254px;
  }
	.is-flex-no-gap {
    display: flex;
    align-items: center;
	flex-direction:column;
}
}

@media only screen and (min-width: 1025px) and (max-width: 1192px) {
  .css-grid > div {
    grid-template-columns: repeat(2, 1fr);
    gap: 12px;
  }
}
@media only screen and (min-width: 1201px) and (max-width: 1388px) {
  .et_pb_posts .et_pb_post {
    width: 100%;
  }
}
.et_pb_text {
    font-weight: 400;
}
.et_pb_b3_testimonial_grid_slider_0 .b3testimonialgridslider_testimonial_text, .et_pb_b3_testimonial_grid_slider_0 .b3testimonialgridslider_testimonial_text p{
    font-weight: 400;
}
.et_pb_blurb_description{
    font-weight: 400;
}
.home .et_pb_module.et_pb_text.et_pb_text_1 {
    font-weight: 400;
}
#left{
width:49%;
float:left;
text-align: center;
margin-bottom: 10px;
}
#right{
width:49%;
float:right;
text-align: center;
margin-bottom: 10px;
}
@media only screen and (max-width: 690px) {
    .page-id-634 #page-container .et_pb_section .et_pb_button_1 {
        line-height:15px !important;
    }
}
.error404 h1:before {
    content: "404";
    position: absolute;
    top: 50%;
    left: 50%;
    color: #f1f1f1;
    font-weight: 700;
    font-size: 5em;
    line-height: 1;
    transform: translate(-50%, -50%);
  	background-repeat:no-repeat;
  	z-index:-1;
}
.et-db #et-boc .et-l .et_pb_menu_0_tb_header.et_pb_menu ul li.et_pb_button.et_pb_button_0_tb_header.et_pb_bg_layout_light a {
    color: white !important;
}
@media only screen and (max-width:375px){
#left {
    width: 100%;
     margin-bottom: 5px; 
}
	#right{
    width: 100%;
    margin-bottom: 5px; 
}

}

.grecaptcha-badge{
z-index:2;
}

.page-id-658 sub{
top:0;
font-size:1rem;
}