@import url('https://fonts.googleapis.com/css2?family=Arvo:ital,wght@0,400;0,700;1,400;1,700&family=Special+Elite&display=swap');


:root {
    --main-font-size: 16px;
    --main-line-height: 1.65;
    --main-heading-line-height: 1.25;
    --main-heading-font:  "Special Elite", system-ui;
    --main-body-font: "Special Elite", system-ui;
    
    
    --main-link-color: var(--hoc-green);
    --main-link-hover-color: var(--hoc-green);
	
	--main-highlight-text-color: var(--hoc-green);
	
	--main-progress-loader-color:var(--main-link-hover-color);

	--main-highlight-link-color: var(--hoc-green);
	--main-highlight-color: var(--hoc-green);

    --main-product-toggle-filter-background-active-color: var(--main-link-color);
	--main-product-toggle-filter-background-highlight-active-color: var(--main-link-hover-color);  
    
    --main-mobile-navigation-element-background-color:  var(--hoc-green);
    
    
    --hoc-green:#5f816b;
	--hoc-dark-green: #222f27;
    --hoc-dark:#231f20;
    --hoc-red:#cc2026;
    --hoc-cream:#e5d6c1;
    
    --hoc-light-green: #ebf1ed;
    
    --main-light-background-color:#ebf1ed;
    
    /*logo*/
    --main-logo-width: 100px;
    --main-logo-width-sm: 100px;
    --main-logo-width-md: 110px;
    --main-logo-width-lg: 115px;   
    
    /*mobile logo*/
    --main-mobile-logo-width: 100px;
    --main-mobile-logo-width-sm: 110px;
    --main-mobile-logo-width-md: 115px;
    --main-mobile-logo-width-lg: 130px;
    
    /* main banner */
	--main-banner-padding:4.5rem;
    --main-banner-description-font-size: 1.2em;
    --main-banner-title-font-size: 2.8em;
    --main-banner-title-font-weight: 500;
    --main-banner-content-width-lg: 55%;
    --main-banner-content-width-xl: 65%;
    --main-banner-background-position: center 25%;
    
    
	/*header */
	--main-header-secondary-region-background: var(--hoc-green);
    --main-header-secondary-region-text-color: #ffffff;
    --main-header-secondary-region-icon-color: #fff;
	
	
	--main-header-primary-region-background: #fff;
    --main-header-primary-region-background-text-color: var(--hoc-dark);
    --main-header-primary-region-background-highlight: transparent;
    --main-header-primary-region-dropdown-background-box-shadow: 0px 2px 4px 1px rgba(0, 0, 0, 0.25);
    
	--social-icon-color: #fff;
    --social-icon-border-color: rgba(255, 255, 255, .2);
	
	
	
	--main-mobile-navigation-button-border-color: rgba(255, 255, 255, 0.25);
    --main-mobile-navigation-button-background-color: transparent;
    --main-mobile-navigation-button-text-color: #fff;
    
    --header-menu-button-size: 2.25em;
    --header-menu-button-icon-size: 2.5em;
    --main-site-header-icon-size: 2.5em;
    --main-header-secondary-font: var(--main-body-font);
    --main-header-secondary-font-size: 1.1em;
    --main-header-secondary-font-weight: 400;
	--main-cart-count-background:#fff;
	--main-cart-count-text: var(--main-link-color);
	--main-site-header-height: 7.5em;



	/*footer*/
	--main-footer-background-color:var(--hoc-green);
	--main-footer-text-color: var(--hoc-dark-green);

}


:root,
.client-theme-1 {
	 --vc-dark-color: #231f20;
    --vc-dark-contrast-color: #2f2b2c;
    --vc-light-color: #ebf1ed;
    --vc-light-contrast-color: #dfe7e2;
    --vc-accent-color: #5f816b;
    --vc-accent-contrast-color: #222f27;
    --neutral-1: #cadacf;
    --neutral-2: #5e6c5e;
    --neutral-3: #94af9d;
}

/*type adjustments */

html {
    font-size: var(--main-font-size);
}

*,
*:before,
*:after {
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}

@media (min-width: 768px) {
    .header.header-003 .secondary-region {
        padding: .5rem 0;
    }
}


.header-003 .mobile-navigation-button {
	border-radius:0px;
	font-size:1em !important;
	padding: .25rem 1rem !important;
}

.header.header-003 .social-group .social-list .social-list-item:not(:last-child) {
	    margin-right: .5em !important;
}

.header.header-003 .primary-region .navigation.nav ul .nav-item>.nav-link, 
.header.header-003>.primary-region .navigation>.nav-item>.nav-link {
	font-size:1.25em;
}

.header.header-003 .secondary-region .nav-label {
    font-size: 1rem;
}


.header.header-003 .secondary-region .navbar-nav {
	gap:.5em;
}


.header.header-003 .social-group .social-list-item:hover .icon {
    color: var(--main-link-color);

    fill: var(--main-link-color);
}

.header.header-003 .social-group .icon {
    fill: var(--social-icon-color);
}

.header.header-003 .primary-region .navigation.nav .single-link li a {
    font-size: 1.1em !important;
    font-family: var(--main-body-font) !important;
    width: 100%;
}


.mobile-navigation-container .actions .cart .icon,
.mobile-navigation-container .actions .login .icon,
.mobile-navigation-container .actions .portal .icon {
    --main-header-secondary-region-icon-color: var(--hoc-green);
}

/*mobile nav */
.mobile-navigation-container .container div {
    width: 100%;
}

.mobile-navigation-container .dropdown-menu {
    left: 5px !important;
    top: -1px !important;
}


/* banners */

.main-banner-section {
	--main-banner-padding: 4.25rem;
}

@media (min-width: 768px) {
	.main-banner-section {
		--main-banner-padding: 5.75rem;
	}
	
}

.main-banner-section .banner-item {
    min-height: 600px;
}

.main-banner-section .card-type-photo .a-image img.low-res:not(.placeholder) {
	filter: blur(20px);
}

@media (min-width: 768px) {
    .main-banner-section .banner-item {
        min-height: 900px;
    }
}

@media (min-width: 992px) {
    .main-banner-section .banner-item {
        min-height: 900px;
    }
}



/* low res placeholder image smoothness */
.card-type-photo .a-image img.low-res:not(.placeholder) {
    filter: blur(30px);
}

/*image patch FF */

.a-image .full-res:not(.loaded),
.a-image .low-res:not(.loaded) {
    display: none;
}

/*product */
.top-filters .view-toggle .btn {
	border-radius:0px !important;
}
.catalog-container .filter-header h3 {
    margin: 0;
    font-size: 1.2em;
}


/*product hacks */

.product-image {
	padding:0 !important;
}

.content-list .product-item .product-image .a-image,
.products-carousel .product-item .product-image .a-image,
.product-grid .product-image .a-image {
	--product-image-aspect-ratio:var(--aspect-ratio-4-3);
    padding-top: var(--product-image-aspect-ratio, 100%);
}
.content-list .product-image .image-container,
.product-list .product-image .image-container {
	height:0;
}
.product-image .image-container {
	--product-image-aspect-ratio:var(--aspect-ratio-4-3);
	padding-bottom:var(--product-image-aspect-ratio, 100%);
}
.content-list-items .product-item .product-description,
.product-list .product-item .product-description {
    display: -webkit-box;
    -webkit-line-clamp: 5;
    -webkit-box-orient: vertical;
    overflow: hidden;
}


/* sitegate modal override */

.age-gate-content .title {
    font-size: 1.8em;
}

#modal-age-gate___BV_modal_backdrop_ {
    backdrop-filter: blur(10px);
}


.sales-modal-display.modal-image-display .sales-modal-content {
    padding: calc(var(--sales-modal-content-padding)*3) calc(var(--sales-modal-content-padding)*1.5) !important;
}

.sales-modal-display .sales-modal-image-inner {
	flex-grow:1;
	width:20em;
}

.sales-modal-display .modal-form-display.vc-form {
	padding:0;
}

.sales-modal-display .sales-modal-content {
	    width: 100%;
}
.sales-modal-display .sales-modal-image .sales-modal-logo {
	max-width:12em;
}

.age-gate-content .title {
    font-size: 1.75em;
}

.age-gate-logo {
	margin-bottom:1em;
}

/*cta */

.cta-section .wysiwyg-content {
    max-width: 1140px;
    margin: 0 auto;
    padding: 0em 1em;
}

.cta-section.upper-cta-section >div:nth-child(2) {
    background: var(--hoc-green);
    color: #fff;
    padding: 4em 0em 3em 0em;
    text-wrap: pretty;
}

.cta-section.upper-cta-section >div:nth-child(2) .wysiwyg-content {
    max-width: 680px;
    margin: 0 auto;
    padding: 0;
}


.cta-section.upper-cta-section >div:nth-child(2) .wysiwyg-content a.btn.cta-btn-primary {
	background: transparent;
	border:2px solid  rgba(255,255,255, .25) !important;
	font-weight:500;
	font-size:1.1em;
	padding: 1em 2em;
	color: #fff;
	border-radius: 0px;
	transition:  .3s color ease-in-out, .3s border-color ease-in-out
}

.cta-section.upper-cta-section >div:nth-child(2) .wysiwyg-content a.btn.cta-btn-primary:hover, 
.cta-section.upper-cta-section >div:nth-child(2) .wysiwyg-content a.btn.cta-btn-primary:focus {
	color: var(--main-link-color);
	border: 2px solid  #fff;
	background-color:#fff;
}

.cta-section {
	padding:0;
}

.cta-section.middle-cta-section {
	padding:3em 0em;
}

.cta-section.lower-cta-section {
    background-color: var(--main-light-background-color);
    padding: 4em 0em;
}

.cta-section .highlight-element.highlight-content {
    max-width: 680px;
    margin: 0 auto;
}

.cta-section.lower-cta-section .highlight-content {
    margin-bottom: 2em;
}


.cta-section .highlight-content .highlight-title {
    margin-top: .5em;
}

.cta-section.cta-section-1 {
    padding: 4em 0em 3em 0em;
}

.cta-section.cta-section-2 {
	padding-top:0;
	padding-bottom:3em;
}

.cta-section.cta-section-1,
.cta-section.cta-section-2 {
	background:var(--hoc-cream);
}

.red-accent {
	color:var(--hoc-red);
}

/*custom adjustment for cta section order */

.content-wrap > div {
    display: flex;
    flex-direction: column;
    width: 100%;
}

section.main-banner-section {
    order: 1;
}
.cta-section.upper-cta-section {
	order:2;
}
.cta-section.middle-cta-section {
	order:3;
}

.cta-section.cta-section-4 {
	order:4;
} 

.cta-section.cta-section-5 {
	order:5;
} 

.cta-section.lower-cta-section {
	order:6;
}
.cta-section.cta-section-1 {
	order:7;
}
.cta-section.cta-section-2 {
	order:8;
}

.cta-section.cta-section-3 {
	order:9;
} 

.cta-section.cta-section-6 {
	order:10;
} 




/*buttons*/
.card-type-color .banner-action a.banner-btn-primary,
.header-content .header-links .btn-primary,
.card-type-photo .banner-btn.banner-btn-primary,
.card.card-photo .card-actions a.btn.btn-primary-cta,
.card.card-icon .card-actions a.btn.btn-primary-cta {

    --main-button-primary-border-color: rgba(255, 255, 255, .45);
    --main-button-primary-background-color: transparent;
    --main-button-primary-text-color: #fff;
    --main-button-primary-border-radius: 0px;
    border: 2px solid var(--main-button-primary-border-color) !important;
    font-family: var(--main-body-font);
    border-radius: var(--main-button-primary-border-radius);
    color: var(--main-button-primary-text-color);
    padding: .75em 1.5em;
    background-color: var(--main-button-primary-background-color);
}

.card-type-color .banner-action a.banner-btn-primary:hover,
.header-content .header-links .btn-primary:hover,
.card-type-photo .banner-btn.banner-btn-primary:hover,
.card.card-photo .card-actions a.btn.btn-primary-cta:hover,
.card.card-icon .card-actions a.btn.btn-primary-cta:hover {
    --main-button-primary-highlight-background-color: var(--main-link-color);
    --main-button-primary-highlight-border-color: var(--main-link-color);
    --main-button-primary-highlight-text-color: #fff;
    background-color: var(--main-button-primary-highlight-background-color);
    color: var(--main-button-primary-highlight-text-color);
    border: 2px solid var(--main-button-primary-highlight-border-color) !important;
}

.header-content .header-links .btn-secondary,
.card-type-photo .banner-btn.banner-btn-secondary,
.card.card-photo .card-actions a.btn.btn-secondary-cta,
.card.card-icon .card-actions a.btn.btn-secondary-cta {
    --main-button-secondary-border-color: var(--main-link-color);
    --main-button-secondary-background-color: var(--main-link-color);
    --main-button-secondary-text-color: #fff;
    --main-button-secondary-border-radius: 0px;
    background: var(--main-button-secondary-background-color);
    border: 2px solid var(--main-button-secondary-border-color) !important;
    font-family: var(--main-body-font);
    border-radius: var(--main-button-secondary-border-radius);
    color: var(--main-button-secondary-text-color);
    padding: .75em 1.5em;
}

.header-content .header-links .btn-secondary:hover,
.card-type-photo .banner-btn.banner-btn-secondary:hover,
.card.card-photo .card-actions a.btn.btn-secondary-cta:hover,
.card.card-icon .card-actions a.btn.btn-secondary-cta:hover {
    --main-button-secondary-highlight-background-color: #ffff;
    --main-button-secondary-background-color: #fff;
    --main-button-secondary-highlight-text-color: var(--main-link-color);
    --main-button-secondary-border-color: #fff;
    background-color: var(--main-button-secondary-background-color);
    color: var(--main-button-secondary-highlight-text-color);
    border-color: var(--main-button-secondary-border-color);
}


/* footer */
.footer-section .lower-footer-region, 
.footer-section .middle-footer-region, 
.footer-section .upper-footer-region {
    margin-bottom: 1em !important;
}

.footer-section .middle-footer-region .footer-region-divider {
    border: none !important;
}

@media (min-width: 768px) {
    .footer-section .middle-footer-region .row [class*="col-"]:not(:last-child) {
        border-right:3px solid rgba(255,255,255, .25);
    }
}

.link-list-item .link-list-item-link {
	    padding: 0.5em 0;
}

.footer-section .social-group .social-link .icon {
    color: var(--main-footer-link-color);
    fill: var(--main-footer-link-color);
}

.footer-section .social-group .social-link:hover .icon,
.footer-section .social-group .social-link:focus .icon {
	color: var(--main-link-color);
	fill: var(--main-link-color);
}

.footer .link-list .link-list-item .link-list-item-link {
	font-size:1em;
} 

.footer-section .middle-footer-region .link-list-title h3 {
    font-weight: 600;
}

/* table overrides */
.table thead th,
.table th,
.table td,
table .cart-view-table {
    border-color: var(--main-border-color) !important;
}

.table td, .table th {
	border-top: 1px solid var(--main-border-color) !important;
}

.table thead th {
	border-bottom: 2px solid var(--main-border-color) !important;
}
.table tbody+tbody {
    border-top-color: var(--main-border-color) !important;
}

.teaser-list-item {
    border-color: var(--main-border-color) !important;
}
	