/*
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.0.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 {
  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 {
  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"] {
  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 {
  position: relative;
}
/* the new toggle element, which is added via jQuery */
#main-header #mobile_menu.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 {
  background-color: rgba(0, 0, 0, 0.1);
}
/* toggle icon */
#main-header #mobile_menu.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 {
  content: "\32";
}
/* hide sub menus by default */
#main-header #mobile_menu.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 {
  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 {
  padding-left: 0;
}

/* adjust mobile menu anchors side paddings */
#main-header #mobile_menu.et_mobile_menu li a {
  padding-left: 20px;
  padding-right: 20px;
}
/* indent sub menu */
#main-header #mobile_menu.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 {
  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 {
  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 {
  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 {
  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;
  line-height: 1.25em;
  line-height: 1.33em;
  letter-spacing: 0.9px;
  font-size: 18px !important;
}
@media (max-width: 980px) {
  #freshy_copyright {
    font-size: 14px !important;
  }
}

/* vertical pipe divider */
#freshy_copyright span.copyright_via {
  width: 33.33333%;
  height: 2px;
  overflow: hidden;
  white-space: nowrap;
  text-indent: 200%;
  background: #fff !important;
  vertical-align: middle;
  margin: 10px auto 15px;
  display: block;
}

/* add an FS logo via background */
#freshy_copyright a.copyright_fs {
  display: block;
  width: 36.77px;
  height: 17.37px;
  background-image: url("/wp-content/uploads/fs-lettermark-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: 2px;
    height: 17px;
    margin: 0 20px;
  }
}

@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_font_wg ul li {
  margin: 0 0 18px !important;
}
.checklist_font_wg ul li:last-child {
  margin: 0 0 0px !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 -- */

body #et-top-navigation {
  font-weight: 400;
}

/********* Common Css *********/

.align_tems_cmn {
  align-items: center;
}

/********* Row Box Sizing *********/
@media all and (min-width: 981px) {
  .margin_right_3box_row .et_pb_column {
    width: calc(33.33% - 30px + 10px) !important;
    margin-right: 30px !important;
  }
  .align_tems_end {
    align-items: end;
  }

  .margin_right_3box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }

  .for_practice_page_2box_row .et_pb_column {
    width: calc(50% - 30px + 15px) !important;
    margin-right: 30px !important;
  }
  .for_practice_page_2box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }
  .row_page_4box .et_pb_column {
    width: calc(25% - 15px + 10px) !important;
    margin-right: 15px !important;
  }
  .row_page_4box .et_pb_column:last-child {
    margin-right: 0 !important;
  }
}
@media all and (min-width: 1367px) {
  .long_page_2box_row .et_pb_column {
    width: calc(50% - 90px + 30px) !important;
    margin-right: 90px !important;
  }
  .long_page_2box_row .et_pb_column:last-child {
    margin-right: 0 !important;
  }
}
@media all and (max-width: 980px) {
  body div#et-boc .margin_right_3box_row .et_pb_column {
    margin-bottom: 30px !important;
  }

  body div#et-boc .margin_right_3box_row .et_pb_column:last-child {
    margin-bottom: 0 !important;
  }
}

/********* Column Reverse *********/
@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;
  }
}

/* -- Divi Top Scroll Icon -- */
.et_pb_scroll_top.et-pb-icon {
  background: #090afb;
  border-radius: 0;
  padding: 25px 0;
}

/*------------------------------------------------
----Common Section Padding  Styles Standard Desktop----
------------------------------------------------*/

@media only screen and (min-width: 981px) and (max-width: 1560px) {
  .cmn_section {
    padding-top: 80px !important;
    padding-bottom: 80px !important;
  }

  .cmn_section_top {
    padding-top: 80px !important;
  }

  .cmn_section_btm {
    padding-bottom: 80px !important;
  }

  div#page-container .cmn_margin {
    margin-bottom: 80px !important;
    margin-top: 80px !important;
  }

  div#page-container .cmn_margin_top {
    margin-top: 80px !important;
  }

  div#page-container .cmn_margin_btm {
    margin-bottom: 50px !important;
  }
}

/*------------------------------------------------
----Responsive Styles Large Desktop And Above----
------------------------------------------------*/
@media all and (min-width: 1405px) {
}

/*------------------------------------------------
----Common Heading and text Styles Standard Desktop----
------------------------------------------------*/
@media only screen and (min-width: 981px) and (max-width: 1404px) {
  body #page-container .font_fix_res h1 {
    font-size: 45px !important;
  }
  body #page-container .font_fix_res h2 {
    font-size: 35px;
  }
  body #page-container .font_fix_res h3 {
    font-size: 30px;
  }
  .cmn_text {
    font-size: 18px;
  }
  .cmn_text p {
    font-size: 18px !important;
  }

  body #page-container .cmn_blurb p {
    font-size: 18px !important;
  }
  .checklist ul li {
    font-size: 18px !important;
  }
  .et_pb_team_member_description p {
    font-size: 18px !important;
  }
}

/** Common Button Style**/

body #page-container .et_pb_button {
  line-height: 1 !important;
  font-weight: 400 !important;
}

/*****   Accordion Icon  **** */

.accordion-icon .et_pb_toggle_title::before {
  content: "\E050";
  transition: all 0.3s ease-in-out;
  color: #000 !important;
  font-size: 20px;
}

.accordion-icon .et_pb_toggle_open .et_pb_toggle_title:before {
  content: "\E04F";
  display: block !important;
  color: #090afb !important;
}
.accordion-icon .et_pb_toggle_close {
  background-color: #fb6a0e;
  padding: 15px 20px;
}
.accordion-icon .et_pb_toggle_open {
  padding: 15px 20px;
}

/*------------------------------------------------
---------------- contact form css ---------------
------------------------------------------------*/

.gform_required_legend {
  display: none !important;
}
.gform_title {
  display: none;
}

.custom-gform .gform_wrapper .gfield_required {
  font-size: 30px;
  position: relative;
  top: 10px;
}
body
  .custom-gform
  .gform_wrapper
  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
    [type="button"]
  ):not([type="image"]):not([type="file"]) {
  background-color: #fff;
  font-size: 20px;
  color: #000;
  padding: 20px;
  border: 1px solid #00018d !important;
  border-radius: 10px;
}

body .custom-gform .gform_wrapper textarea.textarea {
  background-color: #fff;
  font-size: 20px;
  color: #000;
  padding: 20px;
  border: 1px solid #00018d !important;
  border-radius: 10px;
}
body .custom-gform .gform_wrapper .hidden_label .ginput_container > * {
  margin-top: 2px !important;
}
body .custom-gform .gform_wrapper .hidden_label textarea.textarea {
  margin: 2px !important;
  resize: none !important;
}

@media only screen and (min-width: 981px) and (max-width: 1560px) {
  body
    .custom-gform
    .gform_wrapper
    input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
      [type="button"]
    ):not([type="image"]):not([type="file"]) {
    font-size: 18px;
  }
  body .custom-gform .gform_wrapper textarea.textarea {
    font-size: 18px;
  }
  body .custom-gform .gform_wrapper .gform_footer input.button,
  body .custom-gform .gform_wrapper .gform_footer input[type="submit"] {
    font-size: 16px !important;
  }
  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
      [type="button"]
    ):not([type="image"]):not([type="file"]) {
    padding: 20px !important;
  }
  body .custom-gform .gform_wrapper textarea.textarea {
    padding: 20px !important;
  }
}

.mapWrap {
  line-height: 0px !important;
}

@media only screen and (max-width: 980px) {
  body .custom-gform .gform_wrapper .gform_footer input.button,
  body .custom-gform .gform_wrapper .gform_footer input[type="submit"] {
    font-size: 15px !important;
  }
  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
      [type="button"]
    ):not([type="image"]):not([type="file"]) {
    font-size: 16px !important;
    padding: 15px !important;
    border-radius: 10px !important;
  }
  body .custom-gform .gform_wrapper textarea.textarea {
    padding: 15px !important;
    border-radius: 10px !important;
    font-size: 16px !important;
  }
}

.custom-gform .gfield_label {
  display: none !important;
}

.custom-gform .gfield_radio {
  display: flex !important;
}

.custom-gform ::-webkit-input-placeholder {
  color: #000;
  opacity: 1 !important;
}

.custom-gform :-ms-input-placeholder {
  color: #000;
  opacity: 1 !important;
}

.custom-gform ::placeholder {
  color: #000;
  opacity: 1 !important;
}

.custom-gform .large {
  background-color: #fff;
  color: #000 !important;
  font-size: 20px !important;
  border: 1px solid #00018d;
  border-radius: 10px;
  padding: 20px !important;
}

body .custom-gform .gform_wrapper select {
  height: 66px !important;
}

@media only screen and (min-width: 981px) and (max-width: 1560px) {
  .custom-gform .large {
    font-size: 18px !important;
    padding: 20px;
  }
  body .custom-gform .gform_wrapper select {
    height: 64px !important;
  }
  body .custom-gform .textarea {
    height: 170px !important;
  }
  body .custom-gform .gform_button {
    padding: 10px 50px !important;
    margin: 0px !important;
    font-size: 16px !important;
  }
}

@media only screen and (max-width: 980px) {
  .custom-gform .large {
    font-size: 16px !important;
    padding: 15px !important;
  }
  body .custom-gform .gform_wrapper select {
    height: 51px !important;
  }
  body .custom-gform .textarea {
    height: 150px !important;
  }
  body .custom-gform .gform_button {
    padding: 10px 42px !important;
    margin: 0px !important;
    font-size: 15px !important;
  }
}

body .custom-gform .gf_placeholder {
  padding: 0px !important;
}

.custom-gform .textarea {
  height: 190px !important;
}

body .custom-gform .gform_button {
  padding: 13px 55px !important;
  margin: 0px !important;
}
body .custom-gform .gform_button {
  background-color: #00018d !important;
  color: #fff !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
  border-width: 0px !important;
  font-size: 20px !important;
}
body .et_password_protected_form .et_submit_button {
  margin: 20px auto 0;
  background-color: #00018d !important;
  color: #fff !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
  border-width: 0px !important;
  font-size: 20px !important;
  display: inline-block;
  padding: 16px 40px !important;
  border-radius: 30px !important;
}
body .et_password_protected_form .et_submit_button:hover {
  background-color: #000 !important;
  color: #fff !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
  display: inline-block;
  padding: 16px 40px !important;
}
body .custom-gform .gform_button:hover {
  background-color: #000 !important;
  color: #fff !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
}

body #page-container .gform_wrapper.gravity-theme .gfield-choice-input + label {
  max-width: calc(100% - 20px) !important;
}
body #page-container .gform_wrapper.gravity-theme .gfield_checkbox label,
.gform_wrapper.gravity-theme .gfield_radio label {
  font-size: 18px;
}
@media only screen and (max-width: 980px) {
  body .custom-gform .gform_button {
    font-size: 18px !important;
  }
  body #page-container .gform_wrapper.gravity-theme .gfield_checkbox label,
  .gform_wrapper.gravity-theme .gfield_radio label {
    display: inline-block;
    font-size: 16px;
  }
}
.maps_code {
  line-height: 0 !important;
}
/*------------------------------------------------
---------------- Header ---------------
------------------------------------------------*/

body #page-container header#main-header #et-top-navigation .contact_us a {
  background: #090afb;
  color: #ffffff !important;
  padding-top: 23px !important;
  padding-right: 40.5px !important;
  padding-bottom: 23px !important;
  padding-left: 40.5px !important;
  border-radius: 30px;
  font-size: 20px !important;
}
body #page-container header#main-header #et-top-navigation .contact_us a:hover {
  background: #000000 !important;
  opacity: 1 !important;
}
body #page-container .container {
  width: 90%;
}
body #page-container #top-menu li {
  padding-right: 50px;
}
body #page-container #top-menu li:last-child {
  padding-right: 0px !important;
}
@media only screen and (min-width: 981px) and (max-width: 1270px) {
  body #page-container #top-menu li {
    padding-right: 20px;
  }
  #top-menu li a {
    font-size: 18px;
  }
  body #page-container header#main-header #et-top-navigation .contact_us a {
    font-size: 18px !important;
  }
}
body #page-container #top-menu .current-menu-item a {
  font-weight: bold !important;
}
@media only screen and (min-width: 981px) {
  #top-menu li a {
    position: relative;
    padding-bottom: 10px !important;
  }
  #top-menu li a::before {
    position: absolute;
    content: "";
    width: 0%;
    height: 2px;
    background: #000;
    left: 0;
    bottom: 0;
    transition: 0.3s ease-in;
  }
  #top-menu li.contact_us a::before {
    position: relative !important;
  }
  #top-menu li li a:before {
    left: 0;
  }
  #top-menu li li a:before {
    background: #fff !important;
  }

  #top-menu li.menu-item-has-children li a:before {
    width: 0%;
  }

  #top-menu li.menu-item-has-children a:before {
    width: 0px;
  }

  #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_btn a:before {
    height: 0;
  }
  ul#top-menu li a:hover {
    background: transparent;
  }
  body #page-container #et-top-navigation {
    padding: 30px 0 !important;
  }
}

@media only screen and (max-width: 980px) {
  body #page-container header#main-header #et-top-navigation .contact_us a {
    padding: 15px !important;
    font-size: 16px !important;
    text-align: center !important;
  }
}
@media only screen and (min-width: 981px) {
  body
    #page-container
    .et_header_style_left
    .et-fixed-header
    #et-top-navigation
    nav
    > ul
    > li
    > a {
    padding-bottom: 50px !important;
  }
}

/*------------------------------------------------
---------------- Footer ---------------
------------------------------------------------*/
h1,
h2,
h3,
h4,
h5,
h6 {
  padding-bottom: 0;
}
body {
  font-weight: 400;
}
.footer_sideber .et_pb_widget ol li,
.et_pb_widget ul li {
  margin-bottom: 15px !important;
}
.footer_sideber .et_pb_widget ol li,
.et_pb_widget ul li:last-child {
  margin-bottom: 0px !important;
}
.footer_sideber .et_pb_widget {
  margin-bottom: 0px !important;
}
.footer_email {
  color: #fff;
}
.footer_email:hover {
  color: #FB0930 ;
}
@media only screen and (max-width: 980px) {
  body
    #page-container
    .footer_section
    .footer_menu_row
    .et_pb_column
    .et_pb_widget {
    width: 100% !important;
  }
  .footer_sideber .et_pb_widget ol li,
  .et_pb_widget ul li {
    margin-bottom: 10px !important;
  }
}

/*------------------------------------------------
---------------- All banner ---------------
------------------------------------------------*/

body #page-container .banner_section .header-content {
  width: 100%;
  max-width: 1015px;
  margin: 0px auto !important;
  padding: 0px !important;
}
.banner_section .header-content h1 span {
  display: inline-block !important;
  width: 100%;
}

.inner_banner h1 span {
  display: inline-block !important;
  width: 100%;
}
.banner_section .header-content .et_pb_fullwidth_header_subhead span {
  display: inline-block !important;
  width: 100%;
}
.banner_section .header-content h1 {
  margin-bottom: 15px !important;
}
.banner_section .header-content a.et_pb_button {
  margin-top: 85px !important;
}
@media only screen and (min-width: 981px) and (max-width: 1560px) {
  .banner_section .header-content a.et_pb_button {
    margin-top: 50px !important;
  }
  .image_small {
    width: 70% !important;
  }
}
@media only screen and (max-width: 980px) {
  .banner_section .header-content a.et_pb_button {
    margin-top: 30px !important;
  }
}
@media only screen and (min-width: 981px) and (max-width: 1250px) {
  .banner_section .header-content h1 {
    font-size: 50px !important;
  }
  body #page-container .curved_shape {
    margin-top: -90px !important;
  }
  .banner_section .header-content .et_pb_fullwidth_header_subhead {
    font-size: 25px !important;
  }
  body #page-container .banner_section {
    padding-top: 100px !important;
    padding-bottom: 120px !important;
  }
  body #page-container .service_blurb p {
    font-size: 16px !important;
  }
}
@media only screen and (min-width: 1251px) and (max-width: 1560px) {
  .banner_section .header-content h1 {
    font-size: 60px !important;
  }
  .banner_section .header-content .et_pb_fullwidth_header_subhead {
    font-size: 30px !important;
  }
  body #page-container .banner_section {
    padding-top: 150px !important;
    padding-bottom: 170px !important;
  }
  body #page-container .service_blurb p {
    font-size: 18px !important;
  }
}
@media only screen and (min-width: 1367px) and (max-width: 1560px) {
  body #page-container .banner_section {
    padding-top: 180px !important;
    padding-bottom: 200px !important;
  }
}
body
  #page-container
  .banner_section.et_pb_fullwidth_header
  .et_pb_fullwidth_header_container {
  width: 90%;
}
body #page-container .top_text p {
  padding-bottom: 5px !important;
}
.service_blurb h3 span {
  display: inline-block !important;
  width: 100%;
}
.service_blurb h2 span {
  display: inline-block !important;
  width: 100%;
}
.service_blurb h3 {
  margin-bottom: 20px !important;
  padding-bottom: 0px !important;
}
.service_blurb h2 {
  margin-bottom: 20px !important;
  padding-bottom: 0px !important;
}
body #page-container .service_blurb .et_pb_main_blurb_image {
  margin-bottom: 15px;
}
.service_row .et_pb_column:hover .et-pb-icon {
  color: #fff !important;
}

.service_row .et_pb_column:hover h3.et_pb_module_header {
  color: #fff !important;
}
.service_row .et_pb_column:hover h2.et_pb_module_header {
  color: #fff !important;
}
.service_row .et_pb_column:hover p {
  color: #fff !important;
}
.service_row .et_pb_column:hover ul li {
  color: #fff !important;
}
body #page-container .service_row .read_more_icon:hover::after {
  content: Url(/wp-content/uploads/right-arrow.svg) !important;
  margin-left: 10px !important;
  margin-top: -2px;
}
body div#page-container .service_row .et_pb_column:hover .read_more_icon {
  color: #fff !important;
}
@media only screen and (min-width: 981px) {
  body #page-container .service_blurb {
    padding-bottom: 85px !important;
  }
  body #page-container .service_blurb_inner {
    padding-bottom: 40px !important;
  }
}
@media only screen and (min-width: 768px) and (max-width: 980px) {
  body #page-container .service_blurb {
    padding-bottom: 55px !important;
  }
  body #page-container .service_blurb_inner {
    padding-bottom: 30px !important;
  }
}
@media only screen and (max-width: 767px) {
  body #page-container .service_blurb {
    padding-bottom: 5px !important;
  }
  body #page-container .service_blurb_inner {
    padding-bottom: 30px !important;
  }
}
@media only screen and (max-width: 980px) {
  body #page-container .service_row .read_more_icon:hover::after {
    margin-top: 0px;
  }
  body #page-container .service_row .et_pb_column .et_pb_module {
    margin-bottom: 20px;
  }
}
@media only screen and (min-width: 981px) and (max-width: 1366px) {
  body #page-container .service_blurb {
    padding: 30px 20px 0px !important;
    margin-bottom: 20px !important;
  }
  body #page-container .service_row .et_pb_button_module_wrapper {
    margin-left: 20px !important;
    margin-bottom: 40px !important;
  }
  body #page-container .service_blurb {
    padding-bottom: 65px !important;
  }
  body #page-container .service_blurb_inner {
    padding-bottom: 40px !important;
  }
}
@media only screen and (min-width: 1367px) and (max-width: 1560px) {
  body #page-container .service_blurb {
    padding: 30px 30px 0px !important;
    margin-bottom: 85px !important;
  }
  body #page-container .service_row .et_pb_button_module_wrapper {
    margin-left: 30px !important;
    margin-bottom: 40px !important;
  }
}
@media only screen and (min-width: 981px) {
  #page-container .quality_row .et_pb_column:nth-child(1) {
    width: 53.8%;
  }
  #page-container .quality_row .et_pb_column:nth-child(2) {
    width: 40.7%;
  }
}
@media only screen and (min-width: 981px) and (max-width: 1440px) {
  #page-container .quality_row .et_pb_column:nth-child(1) {
    width: 50.8%;
  }
  #page-container .quality_row .et_pb_column:nth-child(2) {
    width: 43.7%;
  }
}
#page-container .testimonials-section .et_pb_slide_description {
  padding-left: 0px !important;
  padding-right: 0px !important;
}
#page-container .testimonials-section .et_pb_slide {
  padding: 0 0% !important;
}
#page-container .testimonials-section .et-pb-controllers a {
  border-radius: 17px !important;
  width: 17px !important;
  height: 17px !important;
  margin-right: 18px !important;
}
#page-container
  .testimonials-section
  .et-pb-controllers
  a.et-pb-active-control {
  border-radius: 22px !important;
  width: 22px !important;
  height: 22px !important;
  background: #ffffff !important;
}
#page-container .testimonials-section .et-pb-controllers {
  display: flex;
  align-items: center;
  justify-content: center;
  bottom: 10px !important;
}
.checklist ul li::before {
  content: "";
  margin: 0 !important;
  display: inline-block;
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  background: url("/wp-content/uploads/Icon-awesome-check.svg") !important;
  height: 15px !important;
  width: 20px !important;
  background-repeat: no-repeat !important;
  background-size: contain !important;
  margin-top: 5px !important;
}
@media only screen and (max-width: 980px) {
  #page-container
    .testimonials-section
    .et-pb-controllers
    a.et-pb-active-control {
    border-radius: 19px !important;
    width: 19px !important;
    height: 19px !important;
  }
  #page-container .testimonials-section .et-pb-controllers a {
    border-radius: 16px !important;
    width: 16px !important;
    height: 16px !important;
  }
  .et_header_style_left #logo {
    height: 85% !important;
    max-height: 85% !important;
  }
}
/*apply style to the active top level menu item*/

#top-menu-nav.et-menu-nav > ul > li.current-menu-item > a {
  border-bottom: 2px solid #090afb !important;
}
@media only screen and (min-width: 1251px) and (max-width: 1366px) {
  body #page-container .curved_shape {
    margin-top: -100px !important;
  }
}
@media only screen and (min-width: 1367px) and (max-width: 1660px) {
  body #page-container .curved_shape {
    margin-top: -125px !important;
  }
}

/* =========== Start Careers page css ========== */
.form_title_center {
  text-align: center;
  margin-bottom: 2vw;
  margin-top: 2vw;
}
.top_title1 {
  color: #090afb;
}
.top_title2 {
  color: #00018d;
}
.careers_form
  .gform_wrapper
  input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
    [type="button"]
  ):not([type="image"]):not([type="file"]) {
  background-color: #fff;
  border: 1px solid #00018d;
  font-size: 18px;
  color: #000;
  padding: 20px;
  border-radius: 10px;
}
.careers_form .gform_wrapper .datepicker {
  width: 330px !important;
}
.careers_form .gchoice {
  display: inline;
  margin-right: 15px;
}
.careers_form .gform_wrapper.gravity-theme .ginput_complex select {
  background: #fff;
  font-size: 18px;
  color: #000;
  border: 1px solid #00018d;
  border-radius: 10px;
  height: 66px;
}
.careers_form .gform_wrapper.gravity-theme .gfield select.large {
  background: #fff;
  font-size: 18px;
  color: #000 !important;
  border: 1px solid #00018d;
  border-radius: 10px;
  height: 65px;
}
.careers_form .gform_wrapper.gravity-theme .gfield_label {
  font-size: 20px;
  font-weight: 500;
}
.careers_form .gform_wrapper.gravity-theme .ginput_complex label {
  font-size: 20px;
  font-weight: 500;
  padding-bottom: 8px;
}
.careers_form .gform_wrapper.gravity-theme .ginput_full:not(:last-of-type) {
  margin-bottom: 0px;
}
.signature_top_spacing {
  margin-top: 20px;
}
.careers_form .gform_wrapper .gform_footer input.button {
  background-color: #00018d;
  color: #ffffff;
  border-width: 0px;
  border-color: #090afb;
  border-radius: 30px;
  font-family: "Roboto", Helvetica, Arial, Lucida, sans-serif;
  font-size: 20px;
  letter-spacing: 0px;
  padding: 10px 50px;
}
.careers_form .gform_button:hover {
  background-color: #000 !important;
  color: #fff !important;
  border-radius: 30px !important;
  transition: all 0.3s ease-in-out !important;
}
body #page-container .careers_form .name_first {
  padding-right: 0px;
}
.careers_form .gform_wrapper.gravity-theme .ginput_container_address span {
  padding-right: 0.5%;
  padding-left: 0.5%;
}
.careers_form .gform_wrapper.gravity-theme .gform_fields {
  grid-column-gap: 1%;
  grid-row-gap: 16px;
  display: grid;
  grid-template-columns: repeat(12, fr);
  grid-template-rows: repeat(auto-fill, auto);
  width: 100%;
}
.careers_form .gform_wrapper.gravity-theme .gfield_required {
  color: #090afb;
}
.careers_form .date_picker1 .datepicker {
  width: 900px !important;
}
.careers_form .gform_wrapper.gravity-theme .gfield textarea.large {
  height: 150px;
}
body .careers_form .gform_wrapper textarea.textarea {
  background-color: #fff;
  border: 1px solid #000;
  font-size: 20px;
  color: #000;
  padding: 20px;
  line-height: initial;
  height: initial;
  resize: none;
  border-radius: 10px;
}
@media only screen and (min-width: 981px) and (max-width: 1600px) {
  .top_title1 {
    font-size: 30px;
  }
  .top_title2 {
    font-size: 25px;
  }
  .top_title3 {
    font-size: 20px;
  }
  .color_title3 {
    font-size: 18px;
  }
  .top_title4 {
    font-size: 16px;
  }
  .form_txt_fix {
    font-size: 18px;
  }
}
@media only screen and (max-width: 1280px) {
  .careers_form .gform_wrapper.gravity-theme .gfield_label {
    font-size: 16px;
  }
  .careers_form .gform_wrapper.gravity-theme .ginput_complex label {
    font-size: 16px;
  }
  .careers_form
    .gform_wrapper
    input:not([type="radio"]):not([type="checkbox"]):not([type="submit"]):not(
      [type="button"]
    ):not([type="image"]):not([type="file"]) {
    font-size: 16px;
  }
  .careers_form .gform_wrapper.gravity-theme .ginput_complex select {
    height: 62px;
  }
  .careers_form .gform_wrapper.gravity-theme .gfield select.large {
    height: 62px;
    font-size: 16px;
  }
  #page-container
    .careers_form
    .gform_wrapper.gravity-theme
    .gfield_checkbox
    label {
    font-size: 16px;
  }
}
@media only screen and (max-width: 980px) {
  .careers_form .gform_wrapper.gravity-theme .ginput_complex select {
    height: 50px;
  }
  .careers_form .gform_wrapper.gravity-theme .gfield select.large {
    height: 50px;
  }
  .careers_form .gform_wrapper.gravity-theme .gfield_label {
    line-height: 1.5em;
  }
  .top_title1 {
    font-size: 26px;
  }
  .top_title2 {
    font-size: 22px;
  }
  .top_title3 {
    font-size: 18px;
  }
  .color_title3 {
    font-size: 16px;
  }
  .top_title4 {
    font-size: 15px;
  }
  .form_txt_fix {
    font-size: 16px;
  }
}
@media only screen and (max-width: 767px) {
  .careers_form .gform_wrapper.gravity-theme .ginput_complex select {
    height: 52px;
  }
  .careers_form .gform_wrapper.gravity-theme .gfield select.large {
    height: 52px;
  }
  body
    #page-container
    .careers_form
    .gform_wrapper.gravity-theme
    .gfield_checkbox
    label {
    font-size: 13px;
  }
  .top_title1 {
    font-size: 20px;
    margin-bottom: 5px;
  }
  .top_title2 {
    font-size: 18px;
    margin-bottom: 5px;
  }
  .top_title3 {
    font-size: 18px;
    margin-bottom: 5px;
  }
  .color_title3 {
    font-size: 14px;
    margin-bottom: 5px;
  }
  .top_title4 {
    font-size: 14px;
    line-height: 1.5em;
  }
  .form_txt_fix {
    font-size: 16px;
    line-height: 1.5em;
  }
  .careers_form .gform_wrapper .gform_footer input.button {
    padding: 6px 50px;
  }
}
@media only screen and (max-width: 640px) {
  .careers_form .gform_wrapper .datepicker {
    width: 576px !important;
  }
}
@media only screen and (max-width: 480px) {
  .top_title1 {
    margin-bottom: 10px;
  }
  .top_title2 {
    margin-bottom: 10px;
  }
  .top_title3 {
    margin-bottom: 10px;
  }
  .color_title3 {
    margin-bottom: 10px;
  }
  .top_title4 {
    margin-bottom: 10px;
  }
  .careers_form .gform_wrapper.gravity-theme .gfield textarea.large {
    height: 130px;
  }
}

/* =========== End Careers page css ========== */

/* Final rev css */
.wp-image-978 {
  position: relative;
  top: 6px;
}
.copyright_spaceing {
  margin-left: 10px;
  margin-right: 10px;
}
