/* Variables
--------------------------------------------- */
  
:root {
	  --main-font: var(--wp--preset--font-family--inter);
	  --alt-font: var(--wp--preset--font-family--inter);
	  --icon: "Font Awesome 6 Pro";
	  
	  --main: var(--wp--preset--color--primary);
	  --sec: var(--wp--preset--color--secondary);
	  --tri: var(--wp--preset--color--tertiary);
	  
	  --base: var(--wp--preset--color--base);
	  --contrast: var(--wp--preset--color--contrast);

	  --fs-xsm: var(--wp--preset--font-size--x-small);
	  --fs-sm: var(--wp--preset--font-size--small);
	  --fs-s-md: var(--wp--preset--font-size--s-medium);
	  --fs-md: var(--wp--preset--font-size--medium);
	  --fs-mdlg: var(--wp--preset--font-size--m-large);
	  --fs-lg: var(--wp--preset--font-size--large);
	  --fs-xlg: var(--wp--preset--font-size--x-large);
	  --fs-xxlg: var(--wp--preset--font-size--xx-large);
	  
	  --radius: 10px;
	 --shadow: rgba(0, 0, 0, 0.25) 0px 3px 8px;
}

#woo-store-vacation {
	text-align: center;
    width: 60%;
    margin: 0 auto;
}

#woo-store-vacation svg {
	display: none;
}

.wc-block-components-notice-banner__content {
    font-size: var(--fs-md);
}


.block-editor-page, .overdrive {
    background: var(--base) !important;
}

.gform-theme--foundation .gform_fields {
    gap: 10px !important;
}

.gform-theme--foundation .gform_footer {
	margin-block-start: 10px !important;
}

.gform_button {
	border-radius: var(--radius) !important;
	font-weight: 700 !important;
	text-transform: uppercase !important;
	font-size: var(--wp--preset--font-size--x-small) !important;
	padding: 10px var(--wp--preset--spacing--x-small) !important;
}

button {
	cursor: pointer;
	border: 0;
}

.wp-block-button__link,
.gform_button {
	transition: all 0.4s;
	&:hover {
		transform: scale(.9);
		box-shadow: rgba(50, 50, 93, 0.25) 0px 13px 27px -5px, rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;
	}
}

.wp-block-atbs-tabs .tabs-titles {
	background: transparent;
}

.con-no-icon .company-email::before,
.con-no-icon .company-phone::before {
	display: none;
}

.cal-details details {
    summary {
        background: var(--contrast);
        color: var(--base);
        border-radius: 10px;
        padding: 10px 20px;
        &::marker {
            font-size: 0;
        }
        &:hover {
            background: var(--main);
        }
    }
}

.cal-details details[open] {
    summary {
        background: var(--main);
    }
}

.coupon,
.woocommerce-form-coupon-toggle {
	display: none !important;
}

@media (max-width: 782px) {
	body, .has-text-align-left, .has-text-align-right {
		text-align: center;
	}
	.wp-block-buttons {
		justify-content: center;
	}
	.wp-block-list {
		padding-left: 0;
		li {
			list-style-position: inside;
		}
	}
}

/* Header */

header {
	.custom-logo {
		filter: invert(1) brightness(100%);
	}
	.wp-block-button__link, .phone-button {
		&:hover {
		  transform: scale(.95);
		  box-shadow: 0px 3px 6px #00000029;		
		}
	}
	.wc-block-mini-cart__button {
		padding: 0;
		&:hover {
			.wc-block-mini-cart__quantity-badge {
				&::before {
					transform: translatex(-50%) scale(2);
				}
			}
		}
		.wc-block-mini-cart__quantity-badge {
			&::after {
				content: "\f07a";
				font-family: var(--icon);
				color: var(--base);
			}
			&::before {
			  content: "";
			  display: block;
			  position: absolute;
			  top: -3px;
			  left: 50%;
			  height: 100%;
			  background: white;
			  background: var(--contrast);
			  border: 2px solid #fff;
			  z-index: -1;
			  border-radius: 100%;
			  aspect-ratio: 1 / 1;
			  transform: translatex(-50%) scale(0);
			  transition: .3s;
			}
			svg {
				display: none;
			}
		}
	}
	@media (max-width: 1250px) {
		.custom-logo {
			width: 250px !important;
		}		
	}
	@media (max-width: 1024px) {
		.custom-logo {
			width: 200px !important;
		}		
		.wp-container-core-group-is-layout-ae3b403d {
			gap: 10px;
		}
		.wp-block-button__link, .phone-button .company-phone {
			font-size: 16px !important;
		}		
	}	
	@media (max-width: 900px) {
		.wp-container-core-group-is-layout-e088cbc5 {
			flex-direction: column;
			align-items: flex-end;
			.wp-block-buttons {
				order: 1;
			}
			.phone-button {
				order: 2;
			}
		}
	}
	@media (max-width: 660px) {
		.wp-container-core-group-is-layout-91510fe3 {
			flex-direction: column;
			.wp-container-core-group-is-layout-4a8ca3eb {
				justify-content: center;
				width: 100%;
				.wp-block-acf-menu {
					flex: 0;
				}
			}
		}
		.wp-container-core-group-is-layout-e088cbc5 {
			flex-direction: row;
			align-items: center;
			.wp-block-buttons {
				order: 2;
			}
			.phone-button {
				order: 1;
			}
		}	
		.wp-block-button__link, .phone-button .company-phone {
			font-size: 15px !important;
		}			
	}
	@media (max-width: 550px) {
		.has-primary-background-color {
			padding: 0 !important;
		}
		.wp-block-site-logo, .wp-block-site-logo a {
			width: 90% !important;
		}
		.custom-logo {
			filter: unset;
			width: 100% !important;
		}		
		.wp-container-core-group-is-layout-4a8ca3eb {
			background: var(--contrast);
			padding: 5px 0;
		}
		.wp-container-core-group-is-layout-ae3b403d {
			width: 100%;
		}		
		.wp-container-core-group-is-layout-e088cbc5 {
			flex-direction: column;
			width: 90%;
			margin: 0 auto;
			.wp-block-buttons {
				width: 100%;
				justify-content: center;
				.wp-block-button {
					flex: 1 0 48%;
				}
			}
			.phone-button {
				width: 100%;
			}
		}		
	}
	@media (max-width: 400px) {
		.wp-container-core-group-is-layout-e088cbc5 {
			.wp-block-buttons {
				.wp-block-button {
					flex: 1 0 100%;
				}
			}
		}		
	}
}

.home {
	header {
		.has-primary-background-color {
/* 			background-color: transparent !important; */
		}
	}
}

/* Hero */

.hero {
	margin-top: -172px !important;
	.wp-block-cover__inner-container {
		.wp-block-heading, .wp-block-buttons {
			text-shadow: 0px 3px 6px #00000029;
		}
	}
	@media (max-width: 1920px) {
		min-height: 1005px !important;
		padding-top: 110px !important;
	}
	@media (max-width: 1850px) {
		min-height: 905px !important;
	}	
	@media (max-width: 1550px) {
		padding-top: 125px !important;
	}
	@media (max-width: 1440px) {
		min-height: 805px !important;
		.wp-block-cover__inner-container {		
			.wp-block-button__link {
				font-size: clamp(24px, 1vw, 40px) !important;
			}
		}
	}
	@media (max-width: 1150px) {
		min-height: 755px !important;
	}	
	@media (max-width: 1024px) {
		min-height: 705px !important;
		.wp-block-cover__inner-container {			
			.wp-block-button__link {
				padding-right: 60px !important;
				padding-left: 60px !important;
			}
		}
	}	
	@media (max-width: 900px) {
		margin-top: -202px !important;
		.wp-block-cover__inner-container {		
			.wp-block-button__link {
				padding-right: 40px !important;
				padding-left: 40px !important;
			}
		}		
	}
	@media (max-width: 782px) {
		.wp-block-cover__inner-container {		
			.wp-block-heading {
				br {
					display: none;
				}
			}
		}		
	}
	@media (max-width: 660px) {
		margin-top: -246px !important;
		padding-top: 185px !important;
	}
	@media (max-width: 550px) {
		margin-top: 0px !important;
		padding-top: 0px !important;
		min-height: 555px !important;
	}
	@media (max-width: 450px) {
		min-height: 455px !important;
		.wp-block-cover__inner-container {	
			.wp-block-heading {
				margin-bottom: 10px !important;
			}
			.wp-block-button__link {
				padding: 10px 30px !important;
			}
		}		
	}	
}

/* Buckets */

.buckets {
	.wpcp-swiper-wrapper {
		margin-bottom: 0 !important;
	}
	.wpcp-carousel-section {
		padding-top: 0 !important;
	}
	.wpcp-single-content {
		background: var(--wp--preset--color--trans-black);
		display: flex;
		flex-direction: column;
		justify-content: space-between;		
		padding: 20px;
		.slide-title {
			color: var(--base);
			font-weight: 900;
			font-size: var(--wp--preset--font-size--s-medium);
			line-height: 1;
			margin: 0;
		}
		p {
			display: none;
			a {
				font-weight: 900;
				color: var(--contrast) !important;
				font-size: var(--wp--preset--font-size--medium);		
				&:hover {
					color: var(--main) !important;
				}
			}
		}	
		&:hover {
			background: var(--wp--preset--color--trans-white) !important;
			.slide-title {
				color: var(--contrast);
			}
			p {
				display: block;
			}
		}
	}
	@media (max-width: 1650px) {
		.wpcp-single-content {
			height: 360px !important;
		}		
	}
	@media (max-width: 1440px) {
		.wpcp-single-content {
			height: 320px !important;
			.slide-title {
				font-size: 20px;
			}	
		}		
	}
	@media (max-width: 1350px) {
		.wpcp-single-content {
			.slide-title {
				font-size: var(--wp--preset--font-size--s-medium);
			}	
		}
		.wpcp-prev-button,
		.wpcp-next-button {
			border-radius: 50% !important;
			top: -55px !important;
		}
	}	
	@media (max-width: 1024px) {
		.wpcp-single-content {
			height: 280px !important;
			.slide-title {
				font-size: 20px;
			}	
			p {
				a {
					font-size: 24px;		
				}
			}			
		}		
	}
}

/* About */

.about {
	@media (max-width: 1440px) {
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				p {
					font-size: 20px !important;
				}
			}
		}
		
	}
	@media (max-width: 1150px) {
		.pdm-two-columns {
			.acf-innerblocks-container {
				gap: 0;
				justify-content: space-between;
			}
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				p {
					font-size: 18px !important;
				}
			}
		}
	}	
	@media (max-width: 1024px) {
		.pdm-two-columns {
			.acf-innerblocks-container {
				gap: 30px;
			}
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				p {
					font-size: 16px !important;
				}
			}
		}		
	}
}

/* Products */

.products {
	.pdm-two-columns {
		.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
			transition: .4s;
			width: calc(66.6% + 25px);
			.wp-block-cover {
				.wp-block-cover__inner-container {
					width: 100%;
					.wp-block-group {
						.wp-block-group__link {
							height: 500px !important;
						}
					}
				}				
				&::after {
					content: "\f08e";
					font-family: var(--icon);
					font-weight: 900;
					z-index: 1;
					position: absolute;
					bottom: 5px;
					right: 10px;
					color: #fff;
					transform: translatey(100px);
					transition: .4s;
				}
				&:hover {
					&::after {
						transform: translatey(0px);
					}
				}
			}
			&:hover {
			    transform: scale(.95);
			    box-shadow: 0px 3px 6px #0000009e;				
			}
		}
		.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
			width: 33.3%;
			.wp-block-acf-section {
				display: flex;
				flex-direction: column;
				justify-content: center;
				max-height: 500px;
			}
		}
	}
	@media (max-width: 1440px) {
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				.wp-block-cover {
					min-height: 450px !important;
					.wp-block-cover__inner-container {
						.wp-block-group {
							.wp-block-group__link {
								height: 450px !important;
							}
						}
					}				
				}
			}
			.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
				.wp-block-acf-section {
					max-height: 450px;
					.acf-innerblocks-container {
						p {
							font-size: 20px !important;
						}
					}
				}
			}
		}		
	}
	@media (max-width: 1350px) {
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
				.wp-block-acf-section {
					.acf-innerblocks-container {
						p {
							font-size: 18px !important;
						}
						.wp-block-button__link {
							font-size: 20px !important;
						}
					}
				}
			}
		}		
	}	
	@media (max-width: 1250px) {
		.acf-pdm-cards {
			.block-card-image {
				aspect-ratio: 4 / 3 !important;
			}			
		}
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
				.wp-block-acf-section {
					padding: 30px 30px !important;
				}
			}
		}		
	}
	@media (max-width: 1150px) {
		.acf-pdm-cards {
			.hover-text p {
				font-size: 16px !important;
			}
		}
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				.wp-block-cover {
					min-height: 400px !important;
					.wp-block-cover__inner-container {
						.wp-block-group {
							.wp-block-group__link {
								height: 400px !important;
							}
						}
					}				
				}
			}			
			.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
				.wp-block-acf-section {
					max-height: 400px;
					.wp-block-heading {
						font-size: clamp(24px, 2vw, 32px) !important;
					}
				}
			}
		}		
	}
	@media (max-width: 1024px) {
		.acf-pdm-cards {
			.block-card-image {
				aspect-ratio: 16 / 9 !important;
			}			
		}
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				width: 100%;
			}			
			.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
				width: 100%;
				.wp-block-acf-section {
					max-height: auto;
					.wp-block-heading {
						font-size: clamp(24px, 4vw, 32px) !important;
					}
				}
			}
		}		
	}
	@media (max-width: 782px) {
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				.wp-block-cover {
					.wp-block-cover__inner-container {
						.wp-block-group {
							justify-content: center;
						}
					}				
				}
			}			
		}		
	}
	@media (max-width: 550px) {
		.pdm-two-columns {
			.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
				.wp-block-cover {
					min-height: 350px !important;
					.wp-block-cover__inner-container {
						.wp-block-group {
							.wp-block-group__link {
								height: 350px !important;
							}
						}
					}				
				}
			}			
		}		
	}	
}

/* Compare */

.compare {
	.pdm-two-columns {
		.wp-block-image {
			img {
				width: 100%;
			}
		}
	}
}

/* Better */

.better {
	.pdm-two-columns {
		.acf-innerblocks-container> .acf-innerblocks-container:first-of-type {
			.wp-block-list {
				font-size: clamp(30px, 3vw, 50px) !important;
			}
		}
		.acf-innerblocks-container> .acf-innerblocks-container:last-of-type {
			.wp-block-image  {
				margin-bottom: 0;
				img {
					width: 100%;
				}
			}
		}		
	}
}

/* End */

.end {
	@media (max-width: 1920px) {
		padding-top: 200px !important;
		padding-bottom: 200px !important;
	}
	@media (max-width: 1024px) {
		padding-top: 150px !important;
		padding-bottom: 150px !important;
	}	
	@media (max-width: 782px) {
		padding-top: 100px !important;
		padding-bottom: 100px !important;
		.wp-block-button__link {
			padding: 10px 30px !important;
		}
	}	
}

/* Sidebar */

.sidebar {
	.wp-block-navigation__container {
		width: 100%;
		li {
			width: 100%;
			border-bottom: 2px solid var(--contrast);
			.wp-block-navigation-item__content {
				width: 100%;
				padding: 10px;
				&:hover {
					background: rgba(24, 23, 23, .5);
					color: var(--base);
				}
			}
		}
	}
}

/* Blog */

.blog {
	.wp-block-post {
		.wp-block-post-excerpt__excerpt {
			font-size: 16px;
			margin: 0;
		}
	}
}

/* City Page */

.city-hero {
	.wp-block-acf-section {
		.acf-innerblocks-container {
			padding: 0;
		}
	}
}

/* Footer */

footer {
	.wp-block-latest-posts__list {
		margin: 0;
		padding-left: 21px;
		li {
			list-style: disc;
			margin: 0 0 5px;
			.wp-block-latest-posts__post-title {
				font-weight: normal;
			}
		}
	}
	@media (max-width: 1440px) {
		.pdm-columns>.acf-innerblocks-container {
			gap: 5% !important;
			.acf-innerblocks-container {
				width: 30%;
			}
		}
	}
	@media (max-width: 1250px) {
		.pdm-columns>.acf-innerblocks-container {
			gap: 3% !important;
			.acf-innerblocks-container {
				width: 31%;
			}
		}
	}	
	@media (max-width: 1024px) {
		.pdm-columns>.acf-innerblocks-container {
			gap: 30px 0 !important;
			.acf-innerblocks-container {
				width: 100%;
			}
		}
	}	
	@media (max-width: 782px) {
		.wp-block-latest-posts__list {
			padding-left: 0px;
			li {
				list-style-position: inside !important;
			}
		}		
	}
}

/* Shop */

.woocommerce-account .wp-block-post-title,.woocommerce-account main .woocommerce,.woocommerce-cart .wp-block-post-title,.woocommerce-cart main .woocommerce,.woocommerce-checkout .wp-block-post-title,.woocommerce-checkout main .woocommerce {
    max-width: 100% !important;
}

/* auto icons */
.auto-icons .wp-block-button__link[href^="mailto:"]::before, 
.auto-icons .company-email[href^="mailto:"]::before{
	content: "\f0e0";
	font-family: var(--icon);
	font-weight: 900;
	margin-right: 10px;
}

.auto-icons .wp-block-button__link[href^="tel:"]::before,
.auto-icons .company-phone[href^="tel:"]::before {
	content: "\f095";
	font-family: var(--icon);
	font-weight: 900;
	margin-right: 10px;
}

.auto-icons .wp-block-button__link[href^="sms:"]::before {
	content: "\f27a";
	font-family: var(--icon);
	font-weight: 900;
	margin-right: 10px;
}

.auto-icons .wp-block-button__link[href$="contact/"]::before, 
.auto-icons .wp-block-button__link[href$="contact-us/"]::before {
	content: "\f27a";
	font-family: var(--icon);
	font-weight: 900;
	margin-right: 10px;
}

.phone-button {
	transition: all 0.4s;
	.company-phone {
		line-height: 1;
	}
}

/* backgrounds */

.octane-background, .overdrive-bg {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}

.octane-background img, .overdrive-bg img {
    object-fit: cover;
    width: 100%;
    height: 100%;
}

.octane-content, .overdrive-content {
    position: relative;
    height: 100%;
}

.octane-position, .overdrive-rel {
    position: relative;
}

.line-after-title::after {
	content: "";
	display:block;
	max-width: 300px;
	width: 100%;
	height: 5px;
	background: var(--main);
	border-radius: calc(var(--radius) / 3);
	margin-top: 10px;
}

.has-text-align-center.line-after-title::after {
	margin-inline: auto;
}

/* alignment */

* {
	box-sizing: border-box!important;
}



/* new innerblocks wrapper frontend */

.wp-block-acf-section:not([class*="wp-container-acf-section-is-layout-"]) > .acf-innerblocks-container {
    max-width: var(--wp--style--global--content-size);
    margin-inline: auto !important;
}

.wp-block-acf-section.is-layout-flow:not(.layout-constrained) > .acf-innerblocks-container {
	max-width: 100%;
}

.block-editor [class*="wp-container-acf-section-is-layout-"] {
	max-width: 100%;
}



/* core columns block */

@media(max-width: 1024px) {
    .wp-block-columns {
        flex-wrap: wrap!important;
		justify-content: center;
    }

	.wp-block-columns:not(.is-not-stacked-on-mobile)>.wp-block-column {
		flex-basis: 100%!important;
	}
}


/* anchor links scrolling */

html, body {
	scroll-behavior: smooth;
}

/* ======= blog posts page */

/* make post full height */
.blog .post>div {
	height: 100%!important;
}

.wp-block-post-excerpt {
	flex-grow: 1!important;
}

.blog .wp-block-post-featured-image img {
	aspect-ratio: 16 / 9;
	width: 100%;
	height: auto;
}

.blog-featured-image img {
	max-height: 40vh;
}

/* fix image alignment */
@media only screen and (min-width : 768px) {
	img.alignright { float: right; margin: 0 0 1em 1em; }
	img.alignleft { float: left; margin: 0 1em 1em 0; }
	img.aligncenter { display: block; margin-left: auto; margin-right: auto; }
	.alignright { float: right; margin: 0 0 1em 1em; }
	.alignleft { float: left; margin: 0 1em 1em 0; }
	.aligncenter { display: block; margin-left: auto; margin-right: auto; }
}


/* breadcrumbs */
.breadcrumbs-bar p {
	margin: 0;
}

/* fix block editor default html margin? */
html {
	margin: 0px!important;
	overflow-x: hidden;
}

/* headers */

header:has(.menu-slideout) {
	z-index: 99;
	position: relative;
}

/* inline header */



@media(max-width: 1500px) {
	.inline-header .is-layout-flex {
		display: grid;
		gap: 0;
		grid-template-columns: 30% 70%;
		grid-template-areas:
		    "site-logo header-btns"
		    "nav-primary nav-primary";
		align-items: center;
	}

	.inline-header .wp-block-site-logo {
		grid-area: site-logo;
	}

	.inline-header .wp-block-buttons {
		grid-area: header-btns;
		display: flex;
		justify-content: flex-end;
		gap: 10px;
	}

	.inline-header .wp-block-acf-menu {
		grid-area: nav-primary;
	}

	.inline-header .wp-block-acf-menu {
		width: 100%;
		margin-inline: auto;
	}
}

@media(max-width: 1024px) {
	.inline-header .is-layout-flex {
		display: grid;
		gap: 0;
		grid-template-columns: 30% 70%;
		grid-template-areas:
		    "site-logo header-btns"
		    "nav-primary nav-primary";
		align-items: center;
	}

	.inline-header .wp-block-site-logo {
		grid-area: site-logo;
	}

	.inline-header .wp-block-buttons {
		grid-area: header-btns;
		display: flex;
		justify-content: flex-end;
	}

	.inline-header .wp-block-acf-menu {
		grid-area: nav-primary;
	}

	.inline-header .wp-block-acf-menu {
		width: 100%;
	}

}

@media(max-width: 550px) {
	.inline-header .is-layout-flex {
		display: flex;
		flex-direction: column;
		gap: 10px;
	}

	.inline-header .wp-block-buttons {
		order: 2;
	}

	.inline-header .wp-block-acf-menu {
		order: 3;
	}

	.inline-header .wp-block-site-logo {
		max-width: 200px;
	}
}


/* wp carousel fix */
.block-editor [data-title="WP Carousel Pro"] {
	height: fit-content;
}

/* toc */
/* TOC container */
.table-of-contents-container {
    border-radius: var(--radius);
    padding: 20px;
    margin-bottom: 20px;
    background-color: #eeeeee;
}

/* reset counters  */
.table-of-contents {
    counter-reset: h2-counter h3-counter;
    padding-left: 0;
}

.table-of-contents li {
	margin-bottom: 5px;
	list-style: none;
}

/* h2 list items */
.table-of-contents li.toc-level-2 {
    counter-increment: h2-counter;
}

.table-of-contents li.toc-level-2::before {
    content: counter(h2-counter) ". ";
    font-weight: bold;
}

/* h3 list items */
.table-of-contents li.toc-level-3 {
    counter-increment: h3-counter;
}

.table-of-contents li.toc-level-3::before {
    content: counter(h2-counter) "." counter(h3-counter) " ";
    font-weight: bold;
}

.table-of-contents ul {
    padding-left: 20px;
}