/*
Theme Name: DentalCMO Genesis Child
Description: A Genesis child theme baed on Essence Pro, tailered to DentalCMO.
Author: StudioPress/DentalCMO

Version: 1

Template: genesis

License: GPL-2.0-or-later
License URI: http://www.gnu.org/licenses/gpl-2.0.html

Text Domain: essence-pro
Requires at least: 5.4
Requires PHP: 5.6
*/

/* HTML5 Reset
---------------------------------------------------------------------------- */

/* Baseline Normalize
--------------------------------------------- */

/* normalize.css v8.0.1 | MIT License | github.com/necolas/normalize.css
---------------------------------------------------------------------------- */
/* stylelint-disable */
html{line-height:1.15;-webkit-text-size-adjust:100%}body{margin:0}main{display:block}h1{font-size:2em;margin:.67em 0}hr{box-sizing:content-box;height:0;overflow:visible}pre{font-family:monospace,monospace;font-size:1em}a{background-color:transparent}abbr[title]{border-bottom:none;text-decoration:underline;-webkit-text-decoration:underline dotted;text-decoration:underline dotted}b,strong{font-weight:bolder}code,kbd,samp{font-family:monospace,monospace;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}img{border-style:none}button,input,optgroup,select,textarea{font-family:inherit;font-size:100%;line-height:1.15;margin:0}button,input{overflow:visible}button,select{text-transform:none}[type=button],[type=reset],[type=submit],button{-webkit-appearance:button}[type=button]::-moz-focus-inner,[type=reset]::-moz-focus-inner,[type=submit]::-moz-focus-inner,button::-moz-focus-inner{border-style:none;padding:0}[type=button]:-moz-focusring,[type=reset]:-moz-focusring,[type=submit]:-moz-focusring,button:-moz-focusring{outline:1px dotted ButtonText}fieldset{padding:.35em .75em .625em}legend{box-sizing:border-box;color:inherit;display:table;max-width:100%;padding:0;white-space:normal}progress{vertical-align:baseline}textarea{overflow:auto}[type=checkbox],[type=radio]{box-sizing:border-box;padding:0}[type=number]::-webkit-inner-spin-button,[type=number]::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}[type=search]::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}details{display:block}summary{display:list-item}[hidden],template{display:none}
/* stylelint-enable */

/* Box Sizing
--------------------------------------------- */

html,
input[type="search"] {
	box-sizing: border-box;
}

*,
*::before,
*::after {
	box-sizing: inherit;
}

/* Float Clearing
--------------------------------------------- */

.author-box::before,
.clearfix::before,
.entry::before,
.entry-content::before,
.featured-content .more-posts::before,
.footer-widgets::before,
.nav-primary::before,
.nav-secondary::before,
.pagination::before,
.site-container::before,
.site-footer::before,
.site-header::before,
.site-inner::before,
.widget::before {
	content: " ";
	display: table;
}

.author-box::after,
.clearfix::after,
.entry::after,
.entry-content::after,
.featured-content .more-posts::after,
.footer-widgets::after,
.nav-primary::after,
.nav-secondary::after,
.pagination::after,
.site-container::after,
.site-footer::after,
.site-header::after,
.site-inner::after,
.widget::after {
	clear: both;
	content: " ";
	display: table;
}


/* Defaults
---------------------------------------------------------------------------- */

/* Smooth Scroll
--------------------------------------------- */
html {
	scroll-behavior: smooth;
}

@media (prefers-reduced-motion: reduce) {

	html {
		scroll-behavior: auto;
	}

}

/* CSS Variables
--------------------------------------------- */

:root {
	--primary-color: #05324E;
	--secondary-color-1: #049EC9;
	--text-color: #000000;
	--neutral-color-1: #999;
	--neutral-color-2: #666;
	--neutral-color-3: #eee;
	--heading-font: Termina, sans-serif;
	--body-font: Montserrat, sans-serif;
}

/* Typographical Elements
--------------------------------------------- */

body {
	background-color: #fff;
	color: var(--text-color);
	font-family: var(--body-font);
	font-size: 20px;
	-webkit-font-smoothing: antialiased;
	-moz-osx-font-smoothing: grayscale;
	font-weight: 400;
	line-height: 1.625;
	margin: 0;
	overflow-x: hidden;
}

a,
button,
input:focus,
input[type="button"],
input[type="reset"],
input[type="submit"],
textarea:focus,
.button,
.gallery img {
	transition: all 0.1s ease-in-out;
}

a {
	color: var(--primary-color);
	text-decoration: none;
}

.site-container a:where(:not(.wp-element-button)) {
	text-decoration: none;
}

a:focus,
a:hover {
	color: var(--text-color);
	text-decoration: none;
}

p {
	margin: 0 0 28px;
	padding: 0;
}

ol,
ul {
	margin: 0;
	padding: 0;
}

li {
	list-style-type: none;
}

hr {
	border: 0;
	border-collapse: collapse;
	border-bottom: 1px solid currentColor;
	clear: both;
	color: var(--neutral-color-3);
	margin: 1.65em auto;
}

b,
strong {
	font-weight: 700;
}

mark {
	background-color: #ddd;
	color: #000;
}

blockquote {
	font-family: var(--body-font);
	font-size: 24px;
	font-style: normal;
}

/* Typographical Classes
--------------------------------------------- */

.intro {
	font-size: 26px;
	letter-spacing: -0.7px;
}

.small-disclaimer {
	font-size: 14px;
	font-style: italic;
}

/* Headings
--------------------------------------------- */

h1,
h2,
h3,
h4,
h5,
h6 {
	color: var(--primary-color);
	font-family: var(--heading-font);
	font-weight: 400;
	line-height: 1.2;
	margin: 0 0 10px;
	text-transform: uppercase;
}

h1 span,
h2 span,
h3 span,
h4 span,
h5 span,
h6 span {
	color: var(--secondary-color-1);
}

h1 {
	font-size: 46px;
	letter-spacing: -1.25px;
}

.internal-page h1 {
    word-break: normal;
}

h2 {
	font-size: 36px;
	letter-spacing: -1px;
}

h3 {
	font-size: 30px;
	letter-spacing: -0.75px;
}

h4 {
	font-size: 24px;
}

h5,
h6 {
	font-size: 16px;
}

.entry-content h2,
.entry-content h3,
.entry-content h4,
.entry-content h5,
.entry-content h6 {
	margin-bottom: 24px;
	margin-top: 32px;
}

.entry-content a {
	font-weight: 700;
}

/* Animations
--------------------------------------------- */

@keyframes header-down-animation {
	0% {
		top: -300px;
	}
	100% {
		top: 0;
	}
}
@keyframes header-up-animation {
	0% {
		top: 0;
	}
	100% {
		top: -300px;
	}
}

/* Objects
--------------------------------------------- */

embed,
iframe,
img,
object,
video,
.wp-caption {
	max-width: 100%;
}

img {
	height: auto;
}

figure {
	margin: 0;
}

/* Forms
--------------------------------------------- */

input,
select,
textarea {
	background-color: #fff;
	border: 1px solid #ddd;
	color: var(--text-color);
	font-size: 18px;
	font-weight: 400;
	line-height: 1.625;
	padding: 18px 24px 14px;
	width: 100%;
}

input:focus,
textarea:focus {
	border: 1px solid var(--neutral-color-1);
	outline: none;
}

input[type="checkbox"],
input[type="image"],
input[type="radio"] {
	width: auto;
}

:-ms-input-placeholder {
	color: var(--text-color);
	opacity: 1;
}

::placeholder {
	color: var(--text-color);
	opacity: 1;
}

button,
input[type="button"],
input[type="reset"],
input[type="submit"],
.gb-block-post-grid a.gb-block-post-grid-more-link,
.button,
.comment-reply-link,
.featured-content .more-from-category a,
.more-link,
.wp-block-button .wp-block-button__link,
.site-container .wp-element-button,
.site-container .wp-block-button__link
.site-container div.wpforms-container-full .wpforms-form input[type="submit"],
.site-container div.wpforms-container-full .wpforms-form button[type="submit"] {
	background-color: transparent;
    color: var(--primary-color);
    cursor: pointer;
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 2px;
    line-height: 1.2;
    padding: 0.75em 1.5em;
    text-align: center;
    text-decoration: none;
    text-transform: uppercase;
    white-space: normal;
    width: auto;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
    border-image-slice: 17;
    border-image-width: 13px;
	width: fit-content;
}

button.primary,
input[type="button"].primary,
input[type="reset"].primary,
input[type="submit"].primary,
.button.primary {
	background-color: #fff;
	border-color: #fff;
	color: var(--text-color);
}

a.button:focus,
a.button:hover,
button:focus,
button:hover,
input:focus[type="button"],
input:hover[type="button"],
input:focus[type="reset"],
input:hover[type="reset"],
input:focus[type="submit"],
input:hover[type="submit"],
.wp-block-button .wp-block-button__link:focus,
.wp-block-button .wp-block-button__link:hover,
.site-container div.wpforms-container-full .wpforms-form input[type="submit"]:focus,
.site-container div.wpforms-container-full .wpforms-form input[type="submit"]:hover,
.site-container div.wpforms-container-full .wpforms-form button[type="submit"]:focus,
.site-container div.wpforms-container-full .wpforms-form button[type="submit"]:hover {
	background-color: var(--primary-color);
    border-color: var(--primary-color);
    color: #fff;
    border-image-width: 0px;
}

.button {
    border-image: url(https://torrey.dental/wp-content/uploads/2024/01/Request-Appointment-Button.svg);
    border-image-slice: 17;
    border-image-width: 13px;
    padding: 0.75em 1.5em;
    background-color: transparent;
    transition: all ease-in-out 0.2s;
    background: transparent;
}

.button:hover {
	border-image-width: 0px;
	background-color: #049EC9;
	color: #fff;
}

.entry-content .button:focus,
.entry-content .button:hover {
	color: #fff;
}

button.secondary,
input[type="button"].secondary,
input[type="reset"].secondary,
input[type="submit"].secondary,
.comment-reply-link,
.button.secondary,
.featured-content .more-from-category a {
	background-color: transparent;
	border-color: var(--neutral-color-1);
	color: var(--neutral-color-2);
}

button.secondary:focus,
button.secondary:hover,
input[type="button"].secondary:focus,
input[type="button"].secondary:hover,
input[type="reset"].secondary:focus,
input[type="reset"].secondary:hover,
input[type="submit"].secondary:focus,
input[type="submit"].secondary:hover,
.comment-reply-link:focus,
.comment-reply-link:hover,
.button.secondary:focus,
.button.secondary:hover,
.featured-content .more-from-category a:focus,
.featured-content .more-from-category a:hover {
	background-color: transparent;
	border-color: var(--neutral-color-2);
	color: var(--text-color);
}

a.button.small,
button.small,
input[type="button"].small,
input[type="reset"].small,
input[type="submit"].small,
.comment-reply-link {
	font-size: 13px;
	padding: 10px 12px 8px;
}

a.button.large,
button.large,
input[type="button"].large,
input[type="reset"].large,
input[type="submit"].large {
	font-size: 20px;
	padding: 26px 36px 22px;
}

button.text,
input[type="button"].text,
input[type="reset"].text,
input[type="submit"].text,
a.button.text,
a.more-link.button.text,
.gb-block-post-grid a.gb-block-post-grid-more-link,
.more-link {
	background-color: transparent;
	box-shadow: none;
	border-bottom: 2px solid var(--primary-color);
	border-left: 0;
	border-right: 0;
	border-radius: 0;
	border-top: 0;
	color: var(--primary-color);
	font-weight: 700;
	letter-spacing: 2px;
	padding: 16px 0 6px 0;
}

button.text:focus,
button.text:hover,
input[type="button"].text:focus,
input[type="button"].text:hover,
input[type="reset"].text:focus,
input[type="reset"].text:hover,
input[type="submit"].text:focus,
input[type="submit"].text:hover,
.button.text:focus,
.button.text:hover,
a.more-link.button.text:focus,
a.more-link.button.text:hover,
.gb-block-post-grid a.gb-block-post-grid-more-link:focus,
.gb-block-post-grid a.gb-block-post-grid-more-link:hover,
.more-link:focus,
.more-link:hover {
	background-color: transparent;
	box-shadow: none;
	border-bottom: 2px solid var(--neutral-color-2);
	color: var(--text-color);
	padding: 16px 0 6px 0;
	text-decoration: none;
}

.entry-container a.more-link {
	display: inline-block;
	margin-bottom: 28px;
}

a.more-link.button.text {
	margin-bottom: 0;
}

.buttonAlt {
	text-transform: uppercase;
	color: #fff;
	padding: 0.75em 1.5em;
	background-color: #06314D;
	transition: all ease-in-out 0.2s;
	width: fit-content;
}

.buttonAlt:hover {
	background-color: #049EC9;
	color: #fff;
}

.buttonAlt1 {
    border-image: url(/wp-content/uploads/2024/01/Learn-More-Button.svg);
    border-image-slice: 17;
    border-image-width: 13px;
	padding: 0.75em 1.5em;
	color: #fff;
	background-color: transparent;
	transition: all ease-in-out 0.2s;
}

.buttonAlt1:hover {
	background-color: #049EC9;
    border-image-width: 0px;
	color: #fff;
}

.contact-link {
	display: inline-flex;
	align-items: center;
	gap: 5px;
	line-height: 1.2;
	text-align: left;
}
.contact-link svg path {
	fill: var(--primary-color);
}

.site-container button:disabled,
.site-container button:disabled:hover,
.site-container input:disabled,
.site-container input:disabled:hover,
.site-container input[type="button"]:disabled,
.site-container input[type="button"]:disabled:hover,
.site-container input[type="reset"]:disabled,
.site-container input[type="reset"]:disabled:hover,
.site-container input[type="submit"]:disabled,
.site-container input[type="submit"]:disabled:hover {
	background-color: var(--neutral-color-3);
	border-width: 0;
	color: var(--neutral-color-2);
	cursor: not-allowed;
}

input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-results-button {
	display: none;
}

/* Tables
--------------------------------------------- */

table {
	border-collapse: collapse;
	border-spacing: 0;
	margin-bottom: 40px;
	width: 100%;
	word-break: break-all;
}

tbody {
	border-bottom: 1px solid var(--neutral-color-3);
}

td,
th {
	line-height: 2;
	text-align: left;
	vertical-align: top;
}

td {
	padding: 0.5em;
}

tr {
	border-top: 1px solid var(--neutral-color-3);
}

th {
	font-weight: 700;
	padding: 0.5em;
}

/* Screen Reader Text
--------------------------------------------- */

.screen-reader-shortcut,
.screen-reader-text,
.screen-reader-text span {
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	overflow: hidden;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.genesis-nav-menu .search input[type="submit"]:focus,
.screen-reader-shortcut:focus,
.screen-reader-text:focus,
.widget_search input[type="submit"]:focus {
	background-color: #fff;
	box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
	clip: auto !important;
	color: var(--text-color);
	display: block;
	font-size: 1em;
	font-weight: 700;
	height: auto;
	padding: 15px 23px 14px;
	text-decoration: none;
	width: auto;
	z-index: 100000; /* Above WP toolbar. */
}


/* Structure and Layout
---------------------------------------------------------------------------- */

/* Site Containers
--------------------------------------------- */

.site-inner,
.wrap {
	margin: 0 auto;
	max-width: 1300px;
}

.site-inner {
	clear: both;
	position: relative;
	z-index: 1;
}

body:not(.home) .hero-wrapper {
	background-image: none !important;
	background-color: #fff;
}

body:not(.home) .hero-page-title {
	margin-top: 204px;
}

body:not(.home).page-template-blocks .hero-page-title {
	display: none;
}

body:not(.home).page.page-template-blocks .site-inner {
	margin-top: 204px !important;
}

.landing-page .site-inner {
	margin-bottom: 100px;
}

.page-template-blocks .site-inner, .page-template-full-width .site-inner {
	max-width: 100%;
}

/* Column Widths and Positions
--------------------------------------------- */

/* Content */

.content {
	background-color: transparent;
	float: right;
	width: 660px;
}

.content-sidebar .content {
	float: left;
}

.content-sidebar .content,
.sidebar-content .content {
	background-color: #fff;
	width: 75%;
}

.error404.content-sidebar .content,
.error404.sidebar-content .content,
.page.content-sidebar .content,
.page.sidebar-content .content,
.single.content-sidebar .content,
.single.sidebar-content .content {
	padding: 60px 80px;
}

.archive.sidebar-content .content,
.archive.content-sidebar .content,
.page-template-page_blog.sidebar-content .content,
.page-template-page_blog.content-sidebar .content {
	background-color: transparent;
	box-shadow: none;
	padding: 0;
}

.full-width-content .content {
	float: none;
	padding: 60px 80px;
	max-width: 100%;
	width: 1300px;
}

.page-template-blocks .content, .page-template-full-width .content {
	padding: 0;
	max-width: 100%;
	width: 100%;
	margin: 0;
}

.half-width-entries .content {
	display: flex;
	flex-wrap: wrap;
	max-width: none;
	width: 100%;
}

/* Primary Sidebar */

.sidebar-primary {
	float: right;
	width: 25%;
}

.sidebar-content .sidebar-primary {
	float: left;
}

/* Grid/Flex Classes
--------------------------------------------- */

.d-grid {
	display: grid;
	grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
}

.d-flex {
	display: flex;
}

.flex {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -webkit-justify-content: space-between;
    -moz-justify-content: space-between;
    justify-content: space-between;
}

.gap-10 {
	gap: 10px;
}
.gap-20 {
	gap: 20px;
}
.gap-30 {
	gap: 30px;
}
.gap-40 {
	gap: 40px;
}
.gap-50 {
	gap: 50px;
}

/* Common Classes
---------------------------------------------------------------------------- */

.membership-popup {
    text-align: center;
}

.membership-popup > * {
    margin: 0 0 16px;
    line-height: 1;
}

.membership-popup h3 {
    font-size: 20px;
}

.membership-popup p {
    font-size: 16px;
}

.membership-popup p:last-child {
    margin: 0;
}

.membership-popup .button {
    font-size: 16px;
}

.seo-cta-main {
    display: flex;
    flex-direction: column;
    gap: 25px;
}

/* Banner Promo */

.banner-promo h2 {
    margin-bottom: 8px;
    font-weight: 700;
}

.banner-promo h3 {
    font-size: 26px;
}

.banner-promo .p1 {
    font-size: 26px;
}

.banner-promo .p2 a {
    color: var(--secondary-color-1);
}

.banner-promo .p2 a:hover {
	color: #fff;
}

.banner-promo .p2 {
	font-size: 28px;
}

/* Banner Promo END */

.no-margin-top {
	margin-top: 0 !important;
}

.no-margin-bottom {
	margin-bottom: 0 !important;
}

.copy {
	padding: 0 25px;
}

.text-align-center {
	text-align: center !important;
}

.grid-buttons .gb-block-layout-column-inner {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.contact-us .form {
	display: flex;
	flex-direction: column;
	gap: 10px;
}
.contact-us .form .frm_forms {
    min-width: 300px;
}
.contact-us {
    display: flex;
    gap: 100px;
}
.contact-us h2 {
	margin-top: 0;
}
.video-container {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden;
    margin-bottom: 10px;
}
.video-container iframe, .video-container object, .video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}
#Copyright-logo-SVG {
    height: 1.1em;
    width: auto;
    overflow: visible;
    vertical-align: text-top;
}
.left {
	text-align: left;
}
.center {
	text-align: center;
}
.right {
	text-align: right;
}

.site-container ul.dcmo-social-links {
	display: inline-flex;
	align-items: center;
	gap: 30px;
	justify-content: center;
	margin-bottom: 50px;
}
.site-container ul.dcmo-social-links svg path {
	fill: #fff;
}

.no-overflow {
	overflow: hidden;
}

/* Avatar
--------------------------------------------- */

.avatar {
	border-radius: 50%;
	float: left;
}

.author-box .avatar,
.alignleft .avatar {
	margin-right: 24px;
}

.alignright .avatar {
	margin-left: 24px;
}

.comment .avatar {
	margin: -12px 16px 24px 0;
}

/* Genesis
--------------------------------------------- */

.breadcrumb {
	color: #ccc;
	font-size: 16px;
	padding: 10px 0;
	text-align: center;
}

.breadcrumb a {
	color: #ccc;
}

.after-entry,
.author-box {
	font-size: 18px;
	margin-bottom: 40px;
}

.after-entry {
	padding: 60px 0;
}

.author-box {
	background-color: #f5f5f5;
	color: var(--text-color);
	padding: 60px;
	text-align: center;
}

.full-width-content .author-box {
	margin: 0 -140px;
}

.archive.full-width-content .author-box {
	margin: 140px 0 0 0;
}

.author-box .avatar {
	float: none;
	margin: 0 auto 20px auto;
}

.archive-description,
.archive-description a,
.archive-description p {
	color: #ccc;
}

.archive-description p:last-child,
.author-box p:last-child {
	margin-bottom: 0;
}

/* Search Form
--------------------------------------------- */

.search-form {
	overflow: hidden;
	position: relative;
}

.entry-content .search-form {
	margin-bottom: 40px;
	width: 50%;
}

.post-password-form input[type="submit"],
.search-form input[type="submit"] {
	margin-top: 10px;
}

.genesis-nav-menu .search input[type="submit"],
.widget_search input[type="submit"] {
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	margin: -1px;
	padding: 0;
	position: absolute;
	width: 1px;
}

/* Titles
--------------------------------------------- */

.archive-title,
.author-box-title {
	font-size: 28px;
}

.entry-title {
	font-size: 36px;
}

.entry-title a,
.sidebar .widget-title a {
	color: #111;
	text-decoration: none;
}

.entry-title a:focus,
.entry-title a:hover {
	color: var(--primary-color);
}

.featured-content .widget-title .more-posts-title,
.widget-title {
	font-family: var(--heading-font);
	font-size: 18px;
	font-weight: 700;
	letter-spacing: 1px;
	margin-bottom: 20px;
	text-transform: uppercase;
}

.sidebar .featured-content .entry {
	box-shadow: none;
}

.sidebar .featured-content .widget-title {
	text-align: left;
}

/* WordPress
--------------------------------------------- */

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

a.alignnone {
	display: inline-block;
}

.alignleft {
	float: left;
	text-align: left;
}

.alignright {
	float: right;
	text-align: right;
}

a.alignleft,
a.alignnone,
a.alignright {
	max-width: 100%;
}

img.centered,
.aligncenter {
	display: block;
	margin: 0 auto 24px;
}

img.alignnone,
.alignnone {
	margin-bottom: 12px;
}

a.alignleft,
img.alignleft,
.wp-caption.alignleft,
.wp-block-image.alignleft
{
	margin: 0 24px 24px 0;
}

a.alignright,
img.alignright,
.wp-caption.alignright,
.wp-block-image.alignright
{
	margin: 0 0 24px 24px;
}

figcaption,
.gallery-caption,
.wp-caption-text {
	font-size: 16px;
	font-style: italic;
	font-weight: 700;
	margin-top: 0.5em;
	margin-bottom: 1em;
	text-align: center;
}

.entry-content p.wp-caption-text {
	margin-bottom: 0;
}

.entry-content .wp-audio-shortcode,
.entry-content .wp-playlist,
.entry-content .wp-video {
	margin: 0 0 28px;
}


/* Widgets
---------------------------------------------------------------------------- */

.widget {
	margin-bottom: 40px;
	word-wrap: break-word;
}

.widget p:last-child,
.widget ul > li:last-of-type,
.widget-area .widget:last-of-type {
	margin-bottom: 0;
}

.widget ul > li {
	margin-bottom: 10px;
	padding-bottom: 10px;
}

.widget ul > li:last-of-type {
	padding-bottom: 0;
}

.widget ol > li {
	list-style-position: inside;
	list-style-type: decimal;
	padding-left: 20px;
	text-indent: -20px;
}

.widget li li {
	border: 0;
	margin: 0 0 0 30px;
	padding: 0;
}

.widget_calendar table {
	width: 100%;
}

.widget_calendar td,
.widget_calendar th {
	text-align: center;
}

/* Flexible Widgets
--------------------------------------------- */

.flexible-widgets .widget,
.flexible-widgets .widget:last-of-type {
	background-color: #fff;
	float: left;
	margin-bottom: 40px;
	padding: 40px;
}

.flexible-widgets.widget-full .widget,
.flexible-widgets.widget-halves.uneven .widget:last-of-type {
	width: 100%;
}

.flexible-widgets.widget-fourths .widget {
	margin-left: 4%;
	width: 22%;
}

.flexible-widgets.widget-halves .widget {
	margin-left: 4%;
	width: 48%;
}

.flexible-widgets.widget-thirds .widget {
	margin-left: 3.5%;
	width: 31%;
}

.flexible-widgets.widget-halves .widget:nth-of-type(odd),
.flexible-widgets.widget-thirds .widget:nth-of-type(3n+1),
.flexible-widgets.widget-fourths .widget:nth-child(4n+1) {
	clear: left;
	margin-left: 0;
}

.flexible-widgets.widget-thirds .widget:nth-of-type(3n) {
	float: right;
	margin-left: 0;
}

.flexible-widgets .featured-content .entry-title {
	font-size: 26px;
	letter-spacing: -1px;
	text-decoration: none;
}

.flexible-widgets .featured-content .entry-content,
.flexible-widgets .featured-content .entry-title {
	padding: 15px 40px 0 40px;
}

.flexible-widgets .featuredpage .entry-content {
	padding-bottom: 20px;
}

.flexible-widgets .featuredpost .entry-meta {
	padding-left: 40px;
	padding-right: 40px;
}

.flexible-widgets.widget-full .featuredpost .entry,
.flexible-widgets.widget-halves.uneven .featuredpost.widget:last-of-type .entry {
	float: left;
	margin-left: 3.5%;
	width: 31%;
}

.flexible-widgets.widget-full .featuredpost .entry:nth-of-type(3n+1),
.flexible-widgets.widget-halves.uneven .featuredpost.widget:last-of-type .entry:nth-of-type(3n+1) {
	clear: left;
	margin-left: 0;
}

.flexible-widgets .featured-content .more-posts-title {
	padding: 30px 0;
}

.flexible-widgets .featured-content .more-posts {
	text-align: center;
}

.flexible-widgets.widget-full .featured-content .more-posts,
.flexible-widgets.widget-halves.uneven .featured-content:last-of-type .more-posts {
	clear: both;
	column-count: 3;
	flex-basis: 100%;
	padding-bottom: 30px;
}

.flexible-widgets .featured-content .more-from-category,
.flexible-widgets .featured-content .widget-title {
	flex-basis: 100%;
}

.flexible-widgets .featured-content .more-from-category {
	margin-bottom: 55px;
}

.flexible-widgets .featured-content .more-link {
	display: inline-block;
	margin-bottom: 28px;
}

.flexible-widgets .featuredpost,
.flexible-widgets .featuredpost:last-of-type {
	background-color: transparent;
	box-shadow: none;
	padding: 0;
}

.flexible-widgets .featuredpage,
.flexible-widgets .featuredpage:last-of-type {
	box-shadow: 0 25px 60px 0 rgba(0, 0, 0, 0.05);
	display: flex;
	padding: 0;
	text-align: center;
}

.flexible-widgets .featuredpage .entry {
	box-shadow: none;
}

.flexible-widgets .featuredpage .widget-title {
	margin-top: 20px;
}

.flexible-widgets .featuredpost .widget-wrap {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}

.flexible-widgets .featuredpost.widget .entry,
.flexible-widgets .featuredpost.widget .entry:last-of-type {
	background-color: #fff;
	box-shadow: 0 25px 60px 0 rgba(0, 0, 0, 0.05);
	margin-bottom: 40px;
	text-align: center;
}

/* Plugins/Addons
---------------------------------------------------------------------------- */

/* Slick */

.site-container ul.slick-dots {
	margin-bottom: 0;
	padding-left: 0;
}
.site-container .slick-dots li button {
	width: 10px;
	height: 10px;
	background-color: transparent;
	border: 2px solid var(--primary-color);
	border-radius: 50%;
}
.site-container .slick-dots li.slick-active button {
	background-color: var(--primary-color);
}
.site-container .slick-dots li button:before {
	display: none;
}

.site-container .slick-prev:hover,
.site-container .slick-prev:focus,
.site-container .slick-next:hover,
.site-container .slick-next:focus {
	background: #fff;
}

/* Formidable Forms*/

.frm_forms .frm_submit {
	text-align: center;
}
.frm_forms .button {
	margin-top: 20px;
	color: #fff;
}

/* Shortcodes Ultimate */

.su-lightbox {
	cursor: pointer;
}

/* Skip Links
---------------------------------------------------------------------------- */

.genesis-skip-link {
	font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen-Sans, Ubuntu, Cantarell, "Helvetica Neue", sans-serif;
	font-size: 14px;
	margin: 0;
}

.genesis-skip-link li {
	height: 0;
	width: 0;
	list-style: none;
}

/* Display outline on focus */
:focus {
	color: var(--text-color);
	outline: #ccc solid 1px;
}


/* Site Header
---------------------------------------------------------------------------- */

.site-header {
	color: var(--text-color);
    background-color: transparent;
    position: fixed;
    width: 100%;
	z-index: 9;
	transition: all ease-in-out 0.2s;
}

.internal-page .site-header {
	background-color: #fff;
}

.scrolldown .site-header {
	background-color: #fff;
	border-bottom: 1px solid #CCC;
	box-shadow: 0px 0px 5px;
}

.site-header > .wrap {
	padding: 10px 2.5%;
	display: grid;
	justify-content: space-between;
	align-items: center;
	grid-template-areas: "left center right";
	grid-template-columns: 1fr 1fr 1fr;
	max-width: 1800px;
}

.js.header-menu .nav-primary {
	clear: both;
	display: none;
}

.header-menu button.off-screen-item {
	display: none;
}

.off-screen-menu .genesis-nav-menu a {
	margin-bottom: 0;
	padding: 10px;
}

.genesis-responsive-menu .wrap {
	padding: 0;
}

.genesis-skip-link .skip-link-hidden {
	display: none;
	visibility: hidden;
}

.menu-toggle {
	display: none;
}

/* Animated Hamburger Menu */
.hamburger-label {
	display: none;
}

.header-menu .hamburger {
	visibility: visible;
	padding: 10px 0;
	display: block;
	cursor: pointer;
	transition-property: opacity, filter;
	transition-duration: 0.15s;
	transition-timing-function: linear;
	color: var(--primary-color);
	text-transform: none;
	background-color: transparent;
	border: 0;
	margin: 0 auto 0 0;
	overflow: visible;
	grid-area: left;
	z-index: 9;
}

@media all and (max-width: 1022px) {
	.header-menu .hamburger {
		transform: translate(-50px);
	}
}

.hamburger:hover {
	opacity: 0.7;
	outline: none;
}

.hamburger.activated:hover {
	opacity: 0.7;
	outline: none;
}

.hamburger.activated .hamburger-inner,
.hamburger.activated .hamburger-inner::before,
.hamburger.activated .hamburger-inner::after {
	background-color: var(--primary-color);
}

.hamburger-box {
	width: 70px;
	height: 36px;
	display: inline-block;
	position: relative;
}

.hamburger-inner {
	display: block;
	top: 50%;
	margin-top: -2px;
	transform: skew(-60deg, 0deg) translate(20px, 0px);
}

.hamburger-inner,
.hamburger-inner::before,
.hamburger-inner::after {
	width: 60px;
	height: 6px;
	background-color: var(--primary-color);
	position: absolute;
	transition-property: transform;
	transition-duration: 0.15s;
	transition-timing-function: ease;
}

.hamburger-inner::before,
.hamburger-inner::after {
	content: "";
	display: block;
}

.hamburger-inner::before {
	top: -12px;
	transform: skew(0deg, 0deg) translate(-30px, 0px);
}

.hamburger-inner::after {
	bottom: -12px;
	transform: skew(0deg, 0deg) translate(-10px, 0px);
}

/* Title Area
--------------------------------------------- */

.title-area {
	padding: 10px 0;
	text-align: center;
	grid-area: center;
}

.custom-logo {
	transition: all ease-in-out 0.2s;
}

.scrolldown .custom-logo {
	width: 150px;
}

.site-title {
	font-family: var(--body-font);
	font-size: 20px;
	font-weight: 700;
	line-height: 1.2;
	letter-spacing: 10px;
	text-indent: 10px;
	text-transform: uppercase;
}

.site-title a,
.site-title a:focus,
.site-title a:hover {
	color: var(--text-color);
	text-decoration: none;
}

.site-description {
	font-size: 16px;
	font-weight: 400;
	line-height: 1.5;
	border: 0;
	clip: rect(0, 0, 0, 0);
	height: 1px;
	overflow: hidden;
	position: absolute !important;
	width: 1px;
	word-wrap: normal !important;
}

.site-description,
.site-title {
	margin-bottom: 0;
}

.no-off-screen-menu.wp-custom-logo .site-description,
.no-off-screen-menu.wp-custom-logo .site-title,
.wp-custom-logo .site-description,
.wp-custom-logo .site-title {
	display: block;
	text-indent: -9999px;
	font-size: 0;
}

.header-left {
	grid-area: left;
	text-align: right;
}

.header-left a {
	text-transform: uppercase;
}

.header-left a:nth-of-type(1) {
	margin-right: 20px;
}

@media all and (max-width: 1379px) {
	.header-left a {
		font-size: 14px;
	}
}

.header-right {
	grid-area: right;
	text-align: right;
}

/* Header Hero
--------------------------------------------- */

.header-hero {
	background-color: #111;
	color: #fff;
	display: flex;
	flex-direction: column;
}

.home .header-hero {
	min-height: 100vh;
}

.hero-page-title {
	padding: 8vw 180px 0 180px;
	text-align: center;
	z-index: 8;
}

.internal-page .hero-page-title  {
	padding: 0;
}

.internal-page .hero-page-title h1 {
	margin-bottom: 0;
}

.internal-page.header-image .hero-page-title,
.internal-page.has-featured-image .hero-page-title
{
	padding: 8vw 2.5% 50px 2.5%;
}

.hero-wrapper {
	flex-grow: 1;
	background-position: center;
	background-size: cover;
	background-repeat: no-repeat;
}

.home .hero-wrapper {
	display: flex;
    justify-content: center;
    align-items: center;
	position: relative;
}

.home .hero-wrapper:before {
    content: ' ';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(255,255,255,.8);
    z-index: 1;
	pointer-events: none;
}

.home .hero-wrapper:after {
    content: ' ';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: auto;
    aspect-ratio: 1981/391;
    background-image: url(/wp-content/uploads/2024/01/BlueHeroShape.svg);
	pointer-events: none;
	z-index: 1;
}

.hero-page-title h1,
.hero-page-title .entry-title {
	color: var(--primary-color);
	font-size: 48px;
	font-weight: 700;
}

.home .hero-page-title .entry-title {
	display: none;
}

.hero-page-title .entry-meta {
	display: inline-block;
}

.hero-ctas {
	display: flex;
    justify-content: center;
    flex-direction: column;
    align-items: center;
}

.hero-ctas a {
	width: fit-content;
}

/* Site Navigation
---------------------------------------------------------------------------- */

.genesis-nav-menu {
	clear: both;
    font-size: 16px;
    font-weight: 600;
    line-height: 1;
    width: 100%;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    margin: auto;
    position: absolute;
    top: 0;
    bottom: 0;
}

.genesis-nav-menu .menu-item {
	display: inline-block;
	margin-bottom: 0;
	padding-bottom: 0;
	text-align: left;
}

.genesis-nav-menu a {
	color: var(--text-color);
	display: inline-block;
	letter-spacing: 2px;
	outline-offset: -1px;
	padding: 20px 15px;
	text-transform: uppercase;
	text-decoration: none;
	font-family: 'Termina';
	font-weight: 400;
}

.genesis-nav-menu .sub-menu-toggle {
	background-color: transparent;
	padding: 5px;
}

.genesis-nav-menu .sub-menu {
	background: #000;
	left: -400%;
	top: -10000px;
	margin-top: -1px;
	opacity: 0;
	position: absolute;
	transition: opacity 0.4s ease-in-out;
	width: 200px;
	z-index: 99;
}

.genesis-nav-menu .sub-menu a {
	background-color: var(--primary-color);
	border-top: 0;
	font-size: 11px;
	padding: 15px 20px;
	position: relative;
	width: 200px;
	word-wrap: break-word;
}

.genesis-nav-menu .sub-menu .current-menu-item > a {
	background-color: #fff;
	color: var(--primary-color);
}

.genesis-nav-menu .sub-menu a:hover {
	background-color: #fff;
	color: var(--primary-color);
}

.genesis-nav-menu .sub-menu .sub-menu {
	border-top-width: 0;
	margin: -52px 0 0 200px;
}

.genesis-nav-menu .menu-item:hover {
	position: static;
}

.genesis-nav-menu .menu-item:hover > .sub-menu {
	display: block;
	left: auto;
	opacity: 1;
}

/* Accessible Menu
--------------------------------------------- */

.menu .menu-item:focus {
	position: static;
}

.menu .menu-item > a:focus + ul.sub-menu,
.menu .menu-item.sfHover > ul.sub-menu {
	left: 100%;
	top: 0;
	opacity: 1;
}

/* Primary Navigation
--------------------------------------------- */

.nav-primary {
	text-align: center;
    position: fixed;
    left: 0;
    width: 500px;
    height: 100%;
    top: 0;
	background-color: #fff;
}

.nav-primary .genesis-nav-menu a {
	color: var(--text-color);
}

.nav-primary .genesis-nav-menu .current-menu-item > a,
.nav-primary .genesis-nav-menu .current-menu-ancestor > a
{
	color: var(--primary-color);
}

.nav-primary .menu-item:hover {
	position: relative;
}

.nav-primary ul.sub-menu {
    width: auto;
    display: flex;
    flex-direction: column;
}

.nav-primary .sub-menu a {
	color: #fff;
	width: 100%;
    min-width: 300px;
}

.nav-primary .sub-menu .sub-menu {
    top: 0;
    margin: 0;
}

.nav-primary .menu-item:hover>.sub-menu .sub-menu {
    left: 100%;
 }

/* Off Screen Navigation
--------------------------------------------- */

.off-screen-content {
	text-align: center;
}

.off-screen-menu .genesis-nav-menu .menu-item {
	display: block;
	text-align: center;
}

.off-screen-menu .genesis-nav-menu a {
	color: #fff;
	font-family: var(--body-font);
	font-size: 32px;
	font-weight: 400;
	letter-spacing: normal;
	margin-bottom: 25px;
	padding: 20px;
	text-transform: none;
}

.off-screen-menu .genesis-nav-menu a:focus,
.off-screen-menu .genesis-nav-menu a:hover {
	color: var(--primary-color);
}

button.off-screen-item {
	background-color: transparent;
	color: #fff;
}

.no-off-screen-menu .site-title,
.no-off-screen-menu .site-description {
	text-align: left;
	text-indent: 0;
}

/* Footer Navigation
--------------------------------------------- */

.site-footer .genesis-nav-menu {
	padding-bottom: 20px;
}

.site-footer .genesis-nav-menu a {
	color: var(--text-color);
	text-align: center;
}

.site-footer .genesis-nav-menu a:focus,
.site-footer .genesis-nav-menu a:hover {
	color: var(--primary-color);
}


/* Content Area
---------------------------------------------------------------------------- */

/* Entries
--------------------------------------------- */

.entry {
	background-color: #fff;
	margin-bottom: 40px;
}

.page-template-full-width .entry, .page-template-blocks .entry {
	margin: 0;
}

.error404 .content .entry,
.single .content .entry,
.page:not(.page-template-page_blog) .content > .entry {
	background-color: transparent;
	box-shadow: none;
}

.search.search-no-results .content .entry,
.archive.archive-no-results .content .entry {
	padding: 60px 20px 40px;
	text-align: center;
	width: 100%;
}

.half-width-entries .content .entry {
	float: left;
	margin-left: 4%;
	text-align: center;
	width: 48%;
}

.half-width-entries .content .entry:nth-of-type(odd) {
	clear: left;
	margin-left: 0;
}

.entry-container {
	padding: 40px 80px 40px;
}

.entry-content ol,
.entry-content ul {
	margin-bottom: 28px;
	padding-left: 40px;
}

.entry-content ol > li {
	list-style-type: decimal;
}

.entry-content ul > li {
	list-style-type: disc;
}

.entry-content ol ul > li,
.entry-content ul ul > li {
	list-style-type: circle;
}

.entry-content ol ol,
.entry-content ul ul {
	margin-bottom: 0;
}

.entry-content code {
	background-color: var(--text-color);
	color: var(--neutral-color-3);
}

/* Entry Meta
--------------------------------------------- */

p.entry-meta {
	color: #707070;
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 3px;
	margin-bottom: 0;
	text-transform: uppercase;
}

.entry-meta a {
	color: #707070;
	text-decoration: none;
}

.entry-meta em {
	font-weight: 400;
	letter-spacing: normal;
}

.hero-page-title p.entry-meta,
.hero-page-title .entry-meta a {
	color: #ccc;
}

.hero-page-title .entry-meta a:focus,
.hero-page-title .entry-meta a:hover {
	text-decoration: underline;
}

.entry-header .entry-meta {
	margin-bottom: 24px;
	margin-top: 24px;
}

.sidebar .entry-header .entry-meta {
	margin-top: 4px;
}

.byline {
	text-transform: initial;
}

.hero-video {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	overflow: hidden;
}

.hero-video video {
	position: absolute;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

/* Pagination
--------------------------------------------- */

.pagination {
	clear: both;
	flex-basis: 100%;
	margin: 40px 0;
	position: relative;
	text-align: center;
	z-index: 3;
}

.archive-pagination.pagination::before {
	background-color: #dedede;
	content: "";
	display: block;
	height: 2px;
	position: absolute;
	top: 50%;
	width: 100%;
	z-index: 1;
}

.archive-pagination ul,
.pagination-next,
.pagination-previous {
	background-color: #f4f4f4;
	display: inline-block;
	padding: 0 30px;
	position: relative;
	z-index: 9;
}

.adjacent-entry-pagination {
	margin-bottom: 0;
}

.archive-pagination li {
	display: inline;
}

.pagination a {
	background-color: transparent;
	border: 2px solid var(--neutral-color-2);
	color: var(--neutral-color-2);
	cursor: pointer;
	display: inline-block;
	font-size: 14px;
	font-weight: 600;
	margin: 0 3px;
	padding: 7px 15px;
	text-decoration: none;
}

.pagination a:focus,
.pagination a:hover,
.pagination .active a {
	border-color: var(--primary-color);
	color: var(--primary-color);
}

/* Comments
--------------------------------------------- */

.comment-respond,
.entry-comments,
.entry-pings {
	background-color: #fff;
	font-size: 16px;
	margin-bottom: 40px;
}

.comment-respond,
.entry-pings {
	padding: 60px 0 32px;
}

.entry-comments {
	padding: 60px 0;
}

.entry-comments::before {
	background-color: #e8e8e8;
	content: "";
	display: block;
	height: 40px;
	margin: 0 auto 80px auto;
	width: 2px;
}

.comment-notes {
	text-align: center;
}

.entry-comments h3,
.comment-respond h3 {
	font-size: 36px;
	margin-bottom: 40px;
	text-align: center;
}

.comment-list li {
	padding-left: 30px;
	margin-top: 60px;
}

.comment-list .depth-1 {
	padding-left: 0;
}

.comment-list .comment:not(.depth-1) article {
	border-left: 2px solid #e8e8e8;
	padding: 0 0 10px 50px;
}

.comment-header {
	margin-bottom: 20px;
}

.comment-header .comment-author-link {
	color: #111;
	font-size: 16px;
	font-weight: 700;
	letter-spacing: 2px;
	text-decoration: none;
	text-transform: uppercase;
}

.comment-meta .comment-time-link {
	color: var(--neutral-color-1);
	font-size: 13px;
	font-weight: 700;
	letter-spacing: 2px;
	text-decoration: none;
	text-transform: uppercase;
}

.comment-content {
	clear: both;
}

.comment-content ul > li {
	list-style-type: disc;
}

.comment-respond input[type="email"],
.comment-respond input[type="text"],
.comment-respond input[type="url"] {
	width: 50%;
}

.comment-respond label {
	display: block;
	margin-right: 12px;
}

.comment-header p {
	margin-bottom: 0;
	line-height: 1;
}

.comment-form-cookies-consent label {
	display: inline;
	padding-left: 10px;
}

.entry-pings .reply {
	display: none;
}


/* Sidebar
---------------------------------------------------------------------------- */

.sidebar {
	font-size: 16px;
	margin-bottom: 40px;
}

.sidebar .widget {
	background-color: #fff;
	padding: 40px;
}

/* Off-screen Content
---------------------------------------------------------------------------- */

.no-scroll {
	overflow: hidden;
}

.off-screen-item,
.off-screen-container .close {
	display: none;
}

.off-screen-item {
	display: initial;
}

.off-screen-content {
	background-color: rgba(0, 0, 0, 0.9);
	display: none;
	height: 100vh;
	left: 0;
	overflow-y: scroll;
	padding: 0;
	position: fixed;
	text-align: center;
	top: 0;
	width: 100%;
	z-index: 9998;
}

.off-screen-container {
	display: table;
	height: 100vh;
	overflow: hidden;
	table-layout: fixed;
	text-align: center;
	width: 100%;
}

.off-screen-wrapper {
	display: table-cell;
	padding-bottom: 20px;
	vertical-align: middle;
	width: 100%;
}

.off-screen-container .close {
	background-color: #000;
	color: #fff;
	display: initial;
	font-size: 20px;
	position: absolute;
	top: 20px;
	right: 40px;
}

.admin-bar .off-screen-container .close {
	top: 52px;
}

.off-screen-content .wrap {
	margin-left: auto;
	margin-right: auto;
	max-width: 720px;
}

.before-after-col {
	margin-bottom: 5%;
}
.site-container .wp-block-icb-image-compare .icbImageCompare {
	padding: 45px;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider {
	position: relative;
	overflow: visible;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider::before {
	content: '';
	display: block;
	background-image: url('/wp-content/uploads/2024/02/top-left-shape.svg');
	background-size: cover;
	background-repeat: no-repeat;
	width: 90%;
	height: auto;
	aspect-ratio: 439.1/66.76;
	position: absolute;
	top: -35px;
	left: -35px;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider::after {
	content: '';
	display: block;
	background-image: url('/wp-content/uploads/2024/02/bottom-right-shape.svg');
	background-size: cover;
	background-repeat: no-repeat;
	width: 90%;
	height: auto;
	aspect-ratio: 439.1/66.76;
	position: absolute;
	bottom: -35px;
	right: -35px;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider .divider {
	background-image: linear-gradient(to bottom, var(--secondary-color-1) 50%, var(--primary-color) 50%);
	width: 6px;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider .divider::before {
	background-image: url('/wp-content/uploads/2024/02/expander-icon.svg');
	background-size: cover;
	background-repeat: no-repeat;
	background-color: transparent;
	transform: translate(-50%,-50%) rotate(0deg);
	width: 98.99px;
	height: 98.99px;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider .resize .beforeImg {
    height: 100%;
}
.site-container .wp-block-icb-image-compare .icbImageCompare .caption {
	font-size: 16px!important;
	font-weight: 600!important;
	margin-top: 45px;
}

/* Site Footer
---------------------------------------------------------------------------- */

.site-footer {
	font-size: 16px;
	line-height: 1;
	padding: 60px 0;
	text-align: center;
}

.site-footer p {
	margin-bottom: 0;
}

.site-footer a {
	color: #707070;
}

/* Media Queries
---------------------------------------------------------------------------- */

/* Min Widths
---------------------------------------------------------------------------- */ 

@media only screen and (min-width: 769px) {
	.flex>.half {
		width: calc(50% - 10px/2);
	}
	.serviceHighlights .dcmo-slick-block-slider {
	    display: grid;
    	grid-template-columns: repeat(4, 1fr);
	}
	.serviceHighlightsMobile {
		display: none !important;
	}
}

@media only screen and (min-width: 1024px) {
	.mobile-only {
		display: none !important;
	}
	.videoTestimonials {
		display: grid;
	}
	.serviceHighlights .slick-next {
    	background-color: #fff;
	}
	.writtenTestimonial .gb-3-col-widecenter>.gb-layout-column-wrap {
		grid-template-columns: 1fr 2fr 3fr;
	}
	.genesis-nav-menu .sub-menu-toggle {
		display: none;
	}

	.menu-item.menu-item-has-children > a > span {
		display: flex;
		align-items: center;
		justify-content: space-between;
		gap: 5px;
	}
	
	.menu-item.menu-item-has-children > a > span::after {
		width: 6px;
		height: 6px;
		border-top: 2px solid;
		border-right: 2px solid;
		content: "";
		transform: rotate(135deg);
		margin-bottom: 5px;
	}
	
	.sub-menu .menu-item.menu-item-has-children > a > span::after {
		transform: rotate(45deg);
	}

	.nav-primary .genesis-nav-menu .sub-menu .current-menu-ancestor > a {
		color: var(--primary-color);
		background-color: #fff;
	}
}


/* Max Widths
---------------------------------------------------------------------------- */

@media only screen and (max-width: 1360px) {

	.site-inner,
	.wrap {
		max-width: 1140px;
	}

	.content {
		width: 800px;
	}

	.hero-page-title h1,
	.hero-page-title .entry-title {
		font-size: 60px;
	}

	.entry-container {
		padding: 30px 60px 20px 60px;
	}

}

@media only screen and (max-width: 1200px) {

	.site-inner,
	.wrap {
		max-width: 960px;
	}

	.hero-page-title {
		padding-left: 140px;
		padding-right: 140px;
	}

	.hero-page-title h1,
	.hero-page-title .entry-title,
	.footer-cta .widget-title {
		font-size: 48px;
	}

	.entry-title {
		font-size: 30px;
	}

	.half-width-entries .flexible-widgets .featured-content .entry-title,
	.flexible-widgets .featured-content .entry-title {
		font-size: 20px;
		padding: 15px 20px 0 20px;
	}

	.footer-cta .widget {
		padding: 10% 7% 7% 7%;
	}

	.author-box {
		margin: 0 -70px;
	}
	
	.header-left {
		font-size: 14px;
	}
	
	.header-right .button {
		font-size: 14px;
		padding: 20px 25px;
	}

}

@media all and (max-width: 1039px) {
	.header-left,
	.header-right {
		display: none;
	}
}

@media only screen and (max-width: 1023px) {
	.desktop-only {
		display: none !important;
	}
	.dcmo-slick-block.serviceHighlights {
		background-size: 400% auto;
    	background-position: bottom;
	}
	.site-header {
		background-color: #fff;
	}
	.welcome-links {
		align-items: center;
	}
	.flexible-widgets .wrap,
	.site-inner,
	.wrap {
		max-width: 800px;
	}

	.content,
	.content-sidebar .content,
	.sidebar-content .content,
	.genesis-responsive-menu .genesis-nav-menu .sub-menu a,
	.genesis-responsive-menu .genesis-nav-menu .sub-menu,
	.sidebar-primary,
	.site-header .nav-primary {
		max-width: 100%;
		width: 100%;
	}

	.sidebar {
		margin-top: 40px;
	}

	.site-header {
		position: relative;
		z-index: 99999;
	}

	.site-header .wrap {
		padding-left: 5%;
		padding-right: 5%;
	}

	.site-title {
		text-indent: 0;
	}

	.title-area {
		text-align: left;
	}

	.genesis-nav-menu li,
	.site-header ul.genesis-nav-menu {
		float: none;
	}

	.entry {
		margin-bottom: 5%;
	}

	.half-width-entries .content .entry {
		float: none;
		margin-left: 0;
		width: 100%;
	}

	.author-box,
	.full-width-content .author-box {
		margin: 0;
	}

	.flexible-widgets.widget-fourths .widget {
		margin-left: 4%;
		width: 48%;
	}

	.flexible-widgets.widget-fourths .widget:nth-of-type(2n+1) {
		clear: left;
		margin-left: 0;
	}

	.footer-cta {
		margin: 40px 0;
	}

	.footer-cta::before {
		display: none;
	}

	.footer-cta.widget-title {
		font-size: 36px;
	}

	.front-page-featured blockquote {
		padding: 30px 0;
	}

	
	
	/* Slider Effect (see https://github.com/jonsuh/hamburgers/blob/master/dist/hamburgers.css) */
	/* Don't want to use this effect right now
	.hamburger--slider .hamburger-inner {
		top: 2px;
	}
	
	.hamburger--slider .hamburger-inner::before {
		top: 10px;
		transition-property: transform, opacity;
		transition-timing-function: ease;
		transition-duration: 0.15s;
	}
	
	.hamburger--slider .hamburger-inner::after {
		top: 20px;
	}
	
	.hamburger--slider.activated .hamburger-inner {
		transform: translate3d(0, 10px, 0) rotate(45deg);
	}
	
	.hamburger--slider.activated .hamburger-inner::before {
		transform: rotate(-45deg) translate3d(-5.71429px, -6px, 0);
		opacity: 0;
	}
	
	.hamburger--slider.activated .hamburger-inner::after {
		transform: translate3d(0, -20px, 0) rotate(-90deg);
	}
	*/

	.sub-menu-toggle {
		border-width: 0;
		background-color: transparent;
		color: #fff;
		display: block;
		margin: 0 auto;
		overflow: hidden;
		text-align: center;
		visibility: visible;
		float: right;
		padding: 11px 10px;
		position: absolute;
		right: 0;
		top: 0;
		z-index: 100;
	}

	.sub-menu-toggle::before {
		width: 6px;
		height: 6px;
		border-top: 2px solid;
		border-right: 2px solid;
		content: "";
		transform: rotate(135deg);
		display: inline-block;
		text-rendering: auto;
		transition: transform 0.25s ease-in-out;
	}

	.sub-menu-toggle.activated::before {
		transform: rotate(-45deg);
	}

	.genesis-responsive-menu .genesis-nav-menu {
		background-color: var(--primary-color);
	}

	.genesis-responsive-menu.nav-primary .genesis-nav-menu .menu-item {
		display: block;
		float: none;
		position: relative;
		text-align: left;
	}

	.genesis-responsive-menu .genesis-nav-menu .menu-item:focus,
	.genesis-responsive-menu .genesis-nav-menu .menu-item:hover {
		position: relative;
	}

	.genesis-responsive-menu .genesis-nav-menu .menu-item:hover > .sub-menu {
		display: none;
	}

	.genesis-responsive-menu .genesis-nav-menu a:focus,
	.genesis-responsive-menu .genesis-nav-menu a:hover {
		color: var(--primary-color);
	}

	.genesis-responsive-menu .genesis-nav-menu .menu-item a {
		color: #fff;
		border-width: 0;
		padding: 15px 20px;
		width: 100%;
	}

	.genesis-responsive-menu .genesis-nav-menu .menu-item.current-menu-item a {
		color: #fff;
	}

	.genesis-responsive-menu .genesis-nav-menu .sub-menu {
		border-width: 0;
	}

	.genesis-responsive-menu .genesis-nav-menu .menu-item > a:focus ul.sub-menu,
	.genesis-responsive-menu .genesis-nav-menu .menu-item > a:focus ul.sub-menu .sub-menu {
		left: 0;
		margin-left: 0;
	}

	.genesis-responsive-menu .genesis-nav-menu .sub-menu {
		clear: both;
		display: none;
		margin: 0;
		opacity: 1;
		position: static;
		width: 100%;
	}

	.genesis-nav-menu .sub-menu .current-menu-item > a {
		background-color: var(--primary-color);
	}

	.genesis-responsive-menu .genesis-nav-menu .sub-menu .menu-item a {
		padding-left: 30px;
	}

	.genesis-responsive-menu .genesis-nav-menu .sub-menu .sub-menu {
		margin: 0;
	}

}

@media only screen and (max-width: 860px) {

	body {
		font-size: 18px;
	}

	.error404 .content,
	.error404.content-sidebar .content,
	.error404.sidebar-content .content,
	.page:not(.page-template-page_blog) .site-inner,
	.page:not(.page-template-page_blog).content-sidebar .content,
	.page:not(.page-template-page_blog).sidebar-content .content,
	.single .site-inner,
	.single.content-sidebar .content,
	.single.sidebar-content .content {
		padding: 7%;
	}

	.page.page-template-full-width .site-inner, .page.page-template-blocks .site-inner {
		padding: 0;
	}

	.full-width-content .content {
		padding: 0;
	}

	.page.content-sidebar .site-inner,
	.page.sidebar-content .site-inner,
	.single.content-sidebar .site-inner,
	.single.sidebar-content .site-inner {
		padding: 0;
	}

	.wrap {
		padding-left: 5%;
		padding-right: 5%;
	}

	.error404 .site-inner::before,
	.page .site-inner::before,
	.single .site-inner::before {
		display: none;
	}

	figure.alignleft, 
	img.alignleft, 
	figure.alignright, 
	img.alignright,
	.wp-block-image.alignleft,
	.wp-block-image.alignright
	{
		float: none;
		display: block;
		margin-left: auto;
		margin-right: auto;
    }

	.after-entry,
	.author-box,
	.sidebar .widget {
		padding: 7%;
		margin-bottom: 5%;
	}

	.comment-respond,
	.entry-comments,
	.entry-pings {
		margin-bottom: 5%;
		padding: 0;
	}

	.entry-comments::before {
		margin: 40px auto;
	}

	.comment-respond {
		margin-top: 40px;
		padding-bottom: 0;
	}

	.hero-page-title h1,
	.hero-page-title .entry-title {
		font-size: 36px;
	}

	.half-width-entries .entry .entry-title {
		font-size: 28px;
	}

	.entry-container {
		padding: 7%;
	}

	.sidebar {
		margin-bottom: 5%;
	}

	.pagination {
		margin: 5% auto;
	}

	.archive-pagination ul {
		background-color: transparent;
		padding: 0;
	}

	.archive-pagination.pagination::before {
		display: none;
	}

	.featured-content .more-from-category {
		overflow: hidden;
	}

	.featured-content .more-from-category a::after,
	.featured-content .more-from-category a::before {
		width: 20px;
	}

	.featured-content .more-from-category a::after {
		right: -22px;
	}

	.featured-content .more-from-category a::before {
		left: -22px;
	}

	.archive-pagination li a {
		margin-bottom: 4px;
	}

	.flexible-widgets .wrap {
		padding-left: 0;
		padding-right: 0;
	}

	.flexible-widgets.widget-fourths .widget,
	.flexible-widgets.widget-halves .widget,
	.flexible-widgets.widget-thirds .widget,
	.flexible-widgets.widget-thirds .widget:nth-of-type(3n) {
		float: none;
		margin-left: 0;
		width: 100%;
	}

	.flexible-widgets.widget-full .widget .entry,
	.flexible-widgets.widget-halves.uneven .widget:last-of-type .entry {
		margin-left: 0;
		width: 100%;
	}

	.flexible-widgets .entry:last-of-type {
		margin-bottom: 40px;
	}

	.flexible-widgets .featured-content .entry-title,
	.half-width-entries .flexible-widgets .featured-content .entry-title,
	.flexible-widgets.widget-full .entry-title,
	.flexible-widgets.widget-halves.uneven .widget:last-of-type .entry-title {
		font-size: 28px;
	}

	.flexible-widgets.widget-full .featured-content .more-posts,
	.flexible-widgets.widget-halves.uneven .featured-content:last-of-type .more-posts {
		column-count: 1;
	}

	.after-content-featured .featuredpage .entry {
		margin-bottom: 0;
	}

	.after-content-featured,
	.footer-cta,
	.front-page-featured {
		margin-left: auto;
		margin-right: auto;
		width: 90%;
	}

	.front-page-featured {
		margin-top: 40px;
	}

	.front-page-featured blockquote {
		font-size: 24px;
		padding: 0;
	}

	.footer-cta .wrap {
		padding-left: 0;
		padding-right: 0;
	}

}

@media only screen and (min-width: 601px) and (max-width: 768px) {
	h2 {
		font-size: 26px;
	}
	h3 {
		font-size: 22px;
	}
	.serviceHighlights .dcmo-slick-block-slider {
		display: grid;
    	grid-template-columns: repeat(2, 1fr);
	}
}

@media only screen and (max-width: 768px) {
	body:not(.home).page.page-template-blocks .site-inner {
		margin-top: 0 !important;
	}
	.internal-page h1 {
		font-size: 30px;
	}
	.internal-page h2 {
    	font-size: 26px;
	}
	.internal-page h3 {
    	font-size: 24px;
	}
	.innerSection3 > .gb-layout-column-wrap {
    	grid-gap: 50px;
	}
	figure.quote img {
    	object-fit: cover;
	    height: auto !important;
    	width: auto;
	}
	div.testimonialInsides div.gb-layout-column-wrap {
	    grid-template-columns: 1fr 3fr 1fr !important;
    	grid-template-areas: 'col1 col2 col3' !important;
		grid-gap: 5px;
	}
	.serviceHighlights .service-slider {
		display: grid;
		grid-template-areas:
			'slider slider'
			'prev next';
		grid-template-rows: 1fr auto;
	}
	
	.serviceHighlights .slick-list {
		grid-area: slider;
	}
	
	.serviceHighlights .slick-prev {
		grid-area: prev;
    	position: relative;
    	bottom: 0;
    	left: unset !important;
    	justify-self: end;
    	padding-right: 25px;
    	width: 100% !important;
    	display: flex;
    	justify-content: end;
    	background-color: #fff;
	    padding-top: 25px;
	}
	
	.serviceHighlights .slick-next {
		grid-area: next;
    	position: relative;
    	right: unset !important;
    	padding-left: 25px;
		background-color: #fff;
	    padding-top: 25px;
	}
	.serviceHighlightsMobile {
    	min-height: 300px;
		max-width: 100%;
    	width: auto;
    	background-color: #0f0;
    	position: relative;
    	overflow: hidden;
    	aspect-ratio: 1/1;
	}

	.serviceHighlightsMobile:before {
    	content: '';
	    background-color: #333;
    	height: 100%;
	    width: 100%;
    	z-index: 1;
	    position: absolute;
    	transform: rotate(45deg) scale(.8);
	    transform-origin: center;
	}
	.home .hero-wrapper:after {
		background: var(--secondary-color-1);
    	height: 50px;
	}
	.site-container .videoTestimonials {
		display: grid;
		grid-template-areas:
			'slider slider slider'
			'prev dots next';
	}
	.videoTestimonials .slick-prev,
	.videoTestimonials .slick-next,
	.videoTestimonials .slick-dots {
		position: relative;
	}
	div.videoTestimonials button.slick-prev.slick-arrow {
		grid-area: prev;
	    margin-left: 40px;
		width: 40px;
		justify-self: end;
		left: unset;
	}
	div.videoTestimonials button.slick-next.slick-arrow {
		grid-area: next;
		margin-right: 40px;
		width: 40px;
		justify-self: start;
		right: unset;
	}
	.videoTestimonials .slick-dots {
		grid-area: dots;
		align-self: center;
	}
	.videoTestimonials .slick-list {
		grid-area: slider;
		padding: 0 !important;
	}
	.contact-us {
		flex-direction: column;
	}
	.flex {
		-webkit-flex-direction: column;
		-moz-flex-direction: column;
		flex-direction: column;
	}
	.flex>.half {
		max-width: 540px;
		width: 100%;
	}
	.flex>:not(:last-child) {
		margin: 0 auto 20px;
	}
	.footer-menu-wrap {
    	flex-direction: column !important;
    	justify-content: center;
    	align-items: center;
    	gap: 25px;
	}
	div.footer-menu {
		width: 100%;
	}
	.footer-logo {
		order: -1;
	}
}

@media only screen and (max-width: 749px) {
	.contact-section > div:nth-of-type(1),
	.contact-section > div:nth-of-type(2) {
		width: 100%;
	}
	.contact-section {
		flex-direction: column-reverse;
	}
	.contact-section > div:nth-of-type(2) {
		min-height: 700px;
	}
	div.contact-section > div:nth-of-type(1) {
		min-width: unset;
	}
}

@media only screen and (max-width: 600px) {

	.site-container .wp-block-icb-image-compare .icbImageCompare {
		padding: 22.5px;
	}
	.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider::before {
		top: -17.5px;
		left: -17.5px;
	}
	.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider::after {
		bottom: -17.5px;
		right: -17.5px;
	}
	.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider .divider {
		width: 3px;
	}
	.site-container .wp-block-icb-image-compare .icbImageCompare .comparison-slider .divider::before {
		width: 49.495px;
		height: 49.495px;
	}

	.site-footer {
		padding: 30px 0;
	}

	.site-footer .genesis-nav-menu a {
		padding: 10px;
	}
	.hero-page-title {
		padding-left: 2%;
		padding-right: 2%;
	}
}

/* Print Styles
---------------------------------------------------------------------------- */

@media print {

	*,
	*::before,
	*::after {
		background: transparent !important;
		box-shadow: none !important;
		color: #000 !important;
		text-shadow: none !important;
	}

	a,
	a:visited {
		text-decoration: underline;
	}

	a[href]::after {
		content: " (" attr(href) ")";
	}

	abbr[title]::after {
		content: " (" attr(title) ")";
	}

	a[href^="javascript:"]::after,
	a[href^="#"]::after,
	.site-title > a::after {
		content: "";
	}

	thead {
		display: table-header-group;
	}

	img,
	tr {
		page-break-inside: avoid;
	}

	img {
		max-width: 100% !important;
	}

	@page {
		margin: 2cm 0.5cm;
	}

	p,
	h2,
	h3 {
		orphans: 3;
		widows: 3;
	}

	blockquote,
	pre {
		border: 1px solid var(--neutral-color-1);
		page-break-inside: avoid;
	}

	.content,
	.content-sidebar {
		width: 100%;
	}

	button,
	input,
	select,
	textarea,
	.breadcrumb,
	.comment-edit-link,
	.comment-form,
	.comment-list .reply a,
	.comment-reply-title,
	.edit-link,
	.entry-comments-link,
	.entry-footer,
	.genesis-box,
	.hidden-print,
	.home-top,
	.nav-primary,
	.nav-secondary,
	.post-edit-link,
	.sidebar {
		display: none !important;
	}

	.title-area {
		text-align: center;
		width: 100%;
	}

	.site-title > a {
		margin: 0;
		text-decoration: none;
		text-indent: 0;
	}

	.author-box {
		margin-bottom: 0;
	}

	h1,
	h2,
	h3,
	h4,
	h5,
	h6 {
		orphans: 3;
		page-break-after: avoid;
		page-break-inside: avoid;
		widows: 3;
	}

	img {
		page-break-after: avoid;
		page-break-inside: avoid;
	}

	blockquote,
	pre,
	table {
		page-break-inside: avoid;
	}

	dl,
	ol,
	ul {
		page-break-before: avoid;
	}

}

.sectionWelcome:before,
.innerSection2:before {
    content: ' ';
    display: block;
    position: absolute;
    left: 0;
    top: 0;
	bottom: 0;
    height: 100%;
    width: auto;
    aspect-ratio: 321/637;
    background-image: url(/wp-content/uploads/2024/01/Left-Main-Logomark.svg);
    background-size: cover;
    background-position: right;
    opacity: .2;
	pointer-events: none;
	max-width: 50%;
    max-height: 520px;
    margin: auto;
}

.sectionWelcome:after {
    content: ' ';
    display: block;
    position: absolute;
    right: 0;
    top: 0;
	bottom: 0;
    height: 100%;
    width: auto;
    aspect-ratio: 321/637;
    background-image: url(/wp-content/uploads/2024/01/Right-Main-Logomark.svg);
    background-size: cover;
    background-position: left;
    opacity: .2;
	pointer-events: none;
	max-width: 50%;
    max-height: 520px;
    margin: auto;
}

.videoTestimonials figure {
    margin-bottom: 0;
    mask-image: url(/wp-content/uploads/2024/01/Video-Mask-Image.svg);
    mask-size: 100%;
    mask-repeat: no-repeat;
	position: relative;
}

.videoTestimonials figure:before {
    content: ' ';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
    width: 100%;
    background-color: rgba(6, 49, 77, 0.6);
	transition: all ease-in-out 0.2s;
}

.videoTestimonials .slick-center figure:before {
	background-color: rgba(255, 255, 255, 0.55);
}

.videoTestimonials figure img {
    object-fit: cover;
    aspect-ratio: 1/1;
}

.videoTestimonials .wp-block-group {
    position: relative;
}

.videoTestimonials .wp-block-group .su-lightbox {
    position: absolute;
    top: 0;
    left: 0;
    bottom: 0;
    right: 0;
    margin: auto;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
	opacity: 0;
	pointer-events: none;
	transition: all ease-in-out 0.2s;
}

.videoTestimonials .slick-center.wp-block-group .su-lightbox {
	pointer-events: all;
	opacity: 1;
}

.videoTestimonials .slick-track {
	padding-bottom: 50px;
}

.videoTestimonials .slick-slide {
	transition: all ease-in-out 0.2s;
	opacity: 1;
}

.videoTestimonials .slick-slide:has( + .slick-center) {
    transform: skew(15deg, -15deg) translate(150px, 100px);
}

.videoTestimonials .slick-center {
	transform: skew(0deg, 0deg) translate(0px, 0px);
}

.videoTestimonials .slick-center + .slick-slide {
    transform: skew(-15deg, 15deg) translate(-150px, 100px);
    z-index: -1;
}

.videoTestimonials .slick-slide:not(.slick-active) {
    opacity: 0;
}

.videoTestimonials .wp-block-group .su-lightbox svg {
    transition: all ease-in-out 0.2s;
}
.videoTestimonials .wp-block-group .su-lightbox:hover svg {
    transform: scale(1.1);
}

.videoTestimonials .wp-block-group .su-lightbox svg path {
    transition: all ease-in-out 0.2s;
}
.videoTestimonials .wp-block-group .su-lightbox:hover svg path {
    fill: #00A1CA;
}

.videoTestimonials.slick-initialized.slick-slider.slick-dotted {
    margin-bottom: 50px;
}

.videoTestimonials button.slick-prev.slick-arrow {
    left: 40%;
}

.videoTestimonials button.slick-next.slick-arrow {
    right: 40%;
}

@media all and (max-width: 1079px) and (min-width: 768px) {
	.videoTestimonials .slick-prev,
	.videoTestimonials .slick-next{
		bottom: -40px !important;
	}
}

.serviceHighlights {
	background-image: url(/wp-content/uploads/2024/01/Services-Image-Background.jpg);
	background-position: 50% 100%;
	background-size: cover;
	background-repeat: no-repeat;
}

.serviceHighlights .gb-block-layout-column {
    min-height: 513px;
    position: relative;
}

.serviceHighlights .dcmo-service-highlight:before {
    content: ' ';
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    height: 50px;
    width: 100%;
    border-bottom: 50px solid transparent;
    border-left: 8vw solid #fff;
    border-right: 8vw solid #fff;
}

.serviceHighlights .dcmo-service-highlight:after {
    content: ' ';
    display: block;
    position: absolute;
    bottom: 0;
    left: 0;
    height: 50px;
    width: 100%;
    border-top: 50px solid transparent;
    border-left: 8vw solid #fff;
    border-right: 8vw solid #fff;
    z-index: 9;
}

@media all and (max-width: 1440px) {
	.serviceHighlights h3 {
		font-size: 18px;
	}
}

@media all and (max-width: 977px) {
	.serviceHighlights .dcmo-service-highlight:hover .dcmo-service-text,
	.serviceHighlights .dcmo-service-highlight:focus .dcmo-service-text {
		padding: 20px;
	}
}

@media all and (max-width: 817px) {
	.serviceHighlights h3 {
		font-size: 16px;
	}
}

.koisPicture > div,
.innerSection3 > div:nth-of-type(1) > div > div {
	height: 100%;
}

.koisPicture figure,
.innerSection3 figure {
    height: 100%;
}

.koisPicture figure:before,
.innerSection3 figure:before {
    content: ' ';
    display: block;
    position: absolute;
    bottom: 100%;
    height: 50px;
    width: 100%;
    border-bottom: 50px solid transparent;
    border-left: 8vw solid #fff;
    border-right: 8vw solid #fff;
}

.koisPicture figure:after,
.innerSection3 figure:after  {
    content: ' ';
    display: block;
    position: absolute;
    top: 100%;
    height: 50px;
    width: 100%;
    border-top: 50px solid transparent;
    border-left: 8vw solid #fff;
    border-right: 8vw solid #fff;
}

.koisPicture .wp-block-image img,
.innerSection3 .wp-block-image img {
    margin-top: -50px;
    object-fit: cover;
    height: calc(100% + 100px);
	width: 100%;
    mask-size: cover;
    mask-repeat: no-repeat;
    mask-position: center;
}

.innerSection3 h2,
.innerSection3 h3,
.innerSection3 p,
.innerSection3 ol,
.innerSection3 ul {
	color: #fff;
}

.koisFlex > div {
    display: flex;
    flex-direction: column;
    height: 100%;
    place-content: center;
}

.meetTheDoctor .gb-block-layout-column:nth-child(1) .gb-block-layout-column-inner {
	height: 70%;
    display: flex;
    flex-direction: column;
    justify-content: space-evenly;
    margin: auto;
}

.writtenTestimonial:before {
    content: ' ';
    display: block;
    position: absolute;
    bottom: 0;
    right: 0;
    width: 100%;
    height: calc(100% + 60px);
    background-image: url(/wp-content/uploads/2024/06/Doctor-Blue-Shape.png);
    background-size: 100% 100%;
    background-position: right;
    background-repeat: no-repeat;
}

@media all and (max-width: 1699px) {
	.writtenTestimonial:before {
		aspect-ratio: 1993/580;
	}
}

@media all and (max-width: 1514px) {
	.writtenTestimonial:before {
		aspect-ratio: 1993/740;
	}
}

@media all and (max-width: 1340px) {
	.writtenTestimonial:before {
		aspect-ratio: 1993/846;
	}
}

@media all and (max-width: 1256px) {
	.writtenTestimonial {
		border-top: 30px solid #049EC9;
		padding-top: 30px;
	}
	.writtenTestimonial:before {
		display: none;
	}
	.writtenTestimonial > div {
		grid-template-areas: "col1" !important;
		grid-template-columns: 3fr !important;
		grid-gap: 0 !important;
	}
}

.testimonialInsides img {
	height: 118px !important;
    width: 151px;
    object-fit: none;
    object-position: 67% 34.5%;
    position: absolute;
    right: 0;
}

.testimonialInsides .gb-block-layout-column:nth-child(3) .gb-block-layout-column-inner {
	display: flex;
    height: 100%;
    align-items: self-end;
}

.testimonialInsides .gb-block-layout-column:nth-child(3) .gb-block-layout-column-inner svg {
	width: 130px;
	height: 130px;
}

.testimonialInsides .gb-block-layout-column:nth-child(3) .gb-block-layout-column-inner svg path {
	fill: #06314D;
	opacity: 0.05;
}

.footer-menu-wrap {
	display: flex;
	flex-direction: row;
	width: 90%;
	max-width: 1400px;
	margin: auto;
	margin-top: 50px;
	justify-content: space-around;
}
.footer-menu {
	width: 33%;
	text-align: center;
}

.contact-section {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
}

.contact-section iframe {
    width: 100%;
    height: 100%;
}

.contact-section > div:nth-of-type(1) {
	width: 60%;
	min-width: 400px;
	background-image: url(/wp-content/uploads/2024/01/Map-Location-Group.svg);
    background-position: center;
    background-size: cover;
}

.contact-section > div:nth-of-type(2) {
	width: 40%;
    min-width: 300px;
    display: flex;
    flex-direction: column;
	color: #fff;
	background-color: #06314D;
}

.contact-section > div:nth-of-type(2) h2 {
	font-weight: 700;
	text-align: center;
	color: #fff;
	margin: 50px 0;
}

@media all and (max-width: 700px) {
	.contact-section > div {
		width: 100% !important;
		min-height: 500px;
	}
}

.flexHours {
	display: flex;
	flex-direction: row;
	flex-wrap: wrap;
	justify-content: space-evenly;
}

.flexHours > div {
	width: 50%;
	min-width: 270px;
}

.flexHours h5 {
	color: #fff;
	text-align: center;
}

.flexHours table tbody {
	border-bottom: none;
}

.flexHours table tr {
	border: none;
}

.flexHours table tr td {
	padding: 0px 5px;
}

.flexHours table tr td:nth-of-type(1) {
	text-align: right;
}

.contact-section a,
.contact-section p {
    color: #fff;
	width: fit-content;
	text-align: center;
	margin: auto;
	margin-bottom: 30px;
}

.contact-section a svg, .contact-section p svg {
    vertical-align: middle;
    line-height: 2em;
    height: 30px;
    width: 30px;
}

.contact-section a svg path {
    fill: #fff;
}

.contact-section p svg path {
    fill: #fff;
}

.flex {
	display: flex;
}

/* Hiding until I find a better way.
.innerWelcome > div {
	margin-top: -20vw;
}
*/

.innerWelcome figure.wp-block-media-text__media {
    position: relative;
}

.framed-image figure {
    aspect-ratio: 1 / 1;
}

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

.framed-image figure:before {
    content: ' ';
    display: block;
    position: absolute;
    bottom: -1px;
    left: 0;
    background-image: url(/wp-content/uploads/2024/06/First-Section-Shape.png);
    width: 100%;
    height: 100%;
    z-index: 0;
    background-size: 100% 100%;
}

.innerWelcome figure,
.framed-image {
	overflow: hidden;
}

.innerWelcome figure:before {
    content: ' ';
    display: block;
    position: absolute;
    bottom: -10px;
    left: 0;
    background-image: url(/wp-content/uploads/2024/06/First-Section-Shape.png);
    width: 100%;
    height: calc(100% + 10px);
    z-index: 0;
    background-size: 100% 100%;
}

.innerWelcome .wp-block-media-text__media img,
.innerWelcome .wp-block-media-text__media video {
    height: 99%;
    width: 100%;
    object-fit: cover;
}

.innerWelcome .su-lightbox {
	position: absolute;
    right: 0;
    width: 50%;
    top: 0px;
    height: auto;
    aspect-ratio: 960/960;
    z-index: 9;
	display: flex;
	justify-content: center;
}

.innerWelcome .su-lightbox svg {
	width: 8vw;
	height: auto;
}

.innerWelcome .su-lightbox svg path {
	transition: all ease-in-out 0.2s;
}

.innerWelcome .su-lightbox:hover svg path {
	fill: #049ec9;
}

/* Hiding until I find a better way
.innerSection2 {
	margin-top: -10vw;
}
*/

@media all and (max-width: 1023px) {
	#menu-header-menu .sub-menu > .menu-item > .sub-menu > .menu-item > a {
		padding-left: 13%;
	}
	.service > .wp-block-genesis-blocks-gb-container > .gb-container-inside, .service > .wp-block-genesis-blocks-gb-container, .service > .wp-block-genesis-blocks-gb-container > .gb-container-inside > .gb-container-content {
    	height: 100%;
	}
	.page.page-template-blocks .site-inner {
		margin-top: 0 !important;
	}
	.nav-primary {
	    position: relative;
    	grid-area: nav;
	    width: 100%;
	}
	.site-header > .wrap {
	    padding: 0;
		grid-template-areas:
			"left center right"
			"nav nav nav";
	}
	.site-header .wrap {
		padding: 0;
	}
	.menu-toggle {
	    position: absolute;
    	right: -15px;
	    top: 25px;
	}
	.nav-primary #menu-header-menu {
	    left: 0;
	    position: relative;
	}
}

.playWithSound {
	display: flex;
	align-items: center;
	margin-top: 10px;
	color: var(--primary-color);
	transition: all ease-in-out 0.2s;
}

.playWithSound svg {
	margin-left: 5px;
}

.playWithSound svg path {
	transition: all ease-in-out 0.2s;
}

.playWithSound:hover {
	color: #049ec9;
}

.playWithSound:hover svg path {
	fill: #049ec9;
}

.clear {
	clear: both !important;
}

.menu-item-has-children:hover > .sub-menu {
    top: 0 !important;
    left: 100% !important;
	z-index: 999 !important;
}

.alignright,
.alignleft {
	max-width: 50%;
}