@import url('https://fonts.googleapis.com/css2?family=Libre+Franklin:ital,wght@0,100..900;1,100..900&display=swap');

:root {

    --main-heading-font: "Libre Franklin", sans-serif;
    --main-body-font: "Libre Franklin", sans-serif;

    --main-font-size: 16px;
    --main-line-height: 1.65;
    --main-heading-line-height: 1.25;

    --main-link-color: #a61d37;
    --main-link-hover-color: #bd3e56;


	--main-highlight-color:var(--main-link-color);
	
    --main-text-heading-color: #000;
    --main-text-color: #000;


    --main-header-primary-region-background-highlight: transparent;

    --main-page-header-banner-background: #202020;
    --main-banner-background-color: #202020;

    --main-cart-count-background: var(--main-link-color);
    --main-cart-count-text: #fff;


	--main-button-primary-background-color: var(--main-link-color);
    --main-button-primary-text-color: #ffffff;
    --main-button-primary-border-color: var(--main-link-color);

	--main-radio-checked-background-color:var(--main-link-color);
	
    /*banner */
    --main-page-header-banner-padding: 4rem;
    --main-banner-padding: 4rem;

    --main-banner-description-font-size: 1em;
    --main-banner-title-font-size: 2.1em;
    --main-banner-title-font-weight: 300;
    --main-banner-background-position: 50% 25%;

    --main-banner-content-width-sm: 75%;
    --main-banner-content-width-md: 55%;
    --main-banner-content-width-lg: 60%;
    --main-banner-content-width-xl: 70%;

    --main-logo-width: 160px;
    --main-logo-width-sm: 160px;
    --main-logo-width-md: 180px;
    --main-logo-width-lg: 240px;
    
    --main-mobile-logo-width: 210px;
    --main-mobile-logo-width-sm: 220px;
    --main-mobile-logo-width-md: 230px;
    --main-mobile-logo-width-lg: 240px;

    --main-mobile-navigation-element-background-color: var(--main-link-color);
    --main-mobile-navigation-element-background-highlight-color: var(--main-link-hover-color);
    --main-mobile-navigation-link-dropdown-background-color: #dcdcdc;

    --main-footer-background-color: #000;

}


.client-theme-1 {
    --vc-heading-font: var(--main-heading-font);
    --vc-body-font: var(--main-body-font);
    --vc-dark-color: #171616;
    --vc-dark-contrast-color: #212020;
    --vc-light-color: #efefef;
    --vc-light-contrast-color: #c9c9c9;
    --vc-accent-color: #a61d37;
    --vc-accent-contrast-color: #bd3e56;
    --neutral-1: #d8d8d8;
    --neutral-2: #4b4b4b;
    --neutral-3: #e6e6e6;
}

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

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

.h1, .h2, .h3, .h4, .h5, .h6, h1, h2, h3, h4, h5, h6 {
	font-weight:400;
}

.no-header {
    --main-header-primary-region-background-text-color: var(--main-text-color);
    --main-header-primary-region-background-highlight-text-color: var(--main-link-color);
    --main-header-primary-region-background: #fff;
    --main-header-secondary-region-background: #fff;
    --main-header-secondary-region-text-color: var(--main-text-color);
    --main-header-secondary-region-icon-color: var(--main-text-color);
}

.no-header .header.header-001 .logo-container .logo {
    display: none;
}



.no-header .header.header-001 .logo-container {
	display:flex;
}


.no-header .header.header-001 .logo-container:before {
    background: url(/dist/logos/website/logo-black.svg);
    width: var(--main-logo-width-sm);
    height: 1.5em;
    content: " ";
    object-fit: contain;
    background-repeat: no-repeat;
}

@media (min-width: 992px) {
	.no-header .header.header-001 .logo-container:before {
	  width: var(--main-logo-width-lg);
	  height:2em;
	}
}

.no-header .header.header-001 {
    box-shadow: 1px 1px 4px #e7e7e7;
}

.has-header .header.header-001 {
    position: absolute;
    width: 100%;
}

.has-header .header.header-001 {
    --main-header-secondary-region-background: rgba(0, 0, 0, .45);
    --main-header-primary-region-background: rgba(0, 0, 0, .45);
}

.has-header .header.header-001:before {
    content: " ";
    height: 16em;
    width: 100%;
    position: absolute;
    background: linear-gradient(to bottom, hsl(0, 0%, 0%) 0%, hsla(0, 0%, 0%, 0.987) 8.1%, hsla(0, 0%, 0%, 0.951) 15.5%, hsla(0, 0%, 0%, 0.896) 22.5%, hsla(0, 0%, 0%, 0.825) 29%, hsla(0, 0%, 0%, 0.741) 35.3%, hsla(0, 0%, 0%, 0.648) 41.2%, hsla(0, 0%, 0%, 0.55) 47.1%, hsla(0, 0%, 0%, 0.45) 52.9%, hsla(0, 0%, 0%, 0.352) 58.8%, hsla(0, 0%, 0%, 0.259) 64.7%, hsla(0, 0%, 0%, 0.175) 71%, hsla(0, 0%, 0%, 0.104) 77.5%, hsla(0, 0%, 0%, 0.049) 84.5%, hsla(0, 0%, 0%, 0.013) 91.9%, hsla(0, 0%, 0%, 0) 100%);
    pointer-events: none;
    top: 0;
    opacity: .75;
}

.header.header-001 .mobile-navigation-button {
	border-radius: 0px;
    padding: .5em 1em;
    font-size: 1em;    
}

.header.header-001 .primary-region .navigation.nav ul .nav-item>.nav-link,
.header.header-001>.primary-region .navigation>.nav-item>.nav-link {
    padding: 1em 0em .25em 0em;
    font-size: .95em;
    text-transform: uppercase;
    margin: 0em .5em;
}

.has-header .header-001 .primary-region .navigation.nav ul .nav-item>.nav-link,
.has-header .header-001>.primary-region .navigation>.nav-item>.nav-link {
	text-shadow: 0px 2px 4px rgba(0, 0, 0, .5);
}

.header.header-001 .primary-region .navigation.nav ul .nav-item>.nav-link:hover,
.header.header-001>.primary-region .navigation>.nav-item>.nav-link:hover {
	box-shadow:0px 2px 0px rgba(255, 255, 255, 0.5);
}


@media (min-width: 992px) {

    .header.header-001 .secondary-region .nav-link.cart .icon,
    .header.header-001 .secondary-region .nav-link.login .icon,
    .header.header-001 .secondary-region .nav-link.logout .icon,
    .header.header-001 .secondary-region .nav-link.portal .icon {
        width: 2.25em;
        height: 2.25em;
    }
}

.header.header-001 .secondary-region .nav-link {
    padding: 0em;
    z-index: 3;
}

.header.header-001>.primary-region .navigation {
    width: auto;
    margin: 0 auto;
}

.header.header-001>.primary-region .navbar {
    padding: 0 0 .5em 0;
}


.no-header .header.header-001 {
	--main-mobile-navigation-button-border-color: var(--main-border-color);
	--main-mobile-navigation-button-hover-border-color:var(--main-link-color);
}

.header.header-001 .secondary-region .nav-link.cart .icon-container, 
.header.header-001 .secondary-region .nav-link.login .icon-container, 
.header.header-001 .secondary-region .nav-link.logout .icon-container, 
.header.header-001 .secondary-region .nav-link.portal .icon-container {
    margin-right: .5em;
}

.header.header-001 .primary-region .navigation.nav .nav-item .dropdown-menu a {
    font-size: 1em;
}

@media (max-width: 767.98px) {
    .header.header-001 .secondary-region {
        padding: 1em 0em;
    }
}

@media (min-width: 768px) {
    .header.header-001 .secondary-region {
        padding-top: 1em;
        padding-bottom: .5em;
    }
}

.header.header-001 .secondary-region {
    position: relative;
    z-index: 3;
}

.header.header-001 .secondary-region a,
.header.header-001 .secondary-region .nav-link .nav-link-button-inner .nav-label {
    font-size: .9em;
}

.header.header-001 .secondary-region .nav-link.portal .btn-link {
	padding:0;
}
.header-001 .secondary-nav .navbar-nav >li:not(:last-child) {
    margin-right: 1em;
}

.header-001 .secondary-nav .navbar-nav {
	z-index:3;
}
@media (min-width: 992px) {
    .header.header-001 .secondary-region a.logo-container {
        position: absolute;
        display: flex;
        justify-content: center;
        align-items: center;
        width: 100%;
        z-index: 0;
    }
}

.header.header-001 .secondary-region .nav-link.cart.has-items {
	padding-right:0;
}

.header-001 .cart-count {
	margin-left: 0.75em;
}

.header.header-001 .secondary-region .nav-link.cart .icon, 
.header.header-001 .secondary-region .nav-link.login .icon, 
.header.header-001 .secondary-region .nav-link.logout .icon, 
.header.header-001 .secondary-region .nav-link.portal .icon {
	width: 2em;
    height: 2em;
}

.header-region.has-image .header-content-position {
    display: flex;
    align-items: flex-end;
}

.header-region.has-image .header-content-position,
.header-carousel .banner-item {
    min-height: 600px;
}


.mobile-navigation-container {
	    --main-header-secondary-region-icon-color:#000;

}

/*fixes chrome issue with backdop filter and menu combination */


.has-header .header.header-001 .primary-region {
    background: transparent;

}

.has-header .header.header-001 .secondary-region {
    background: transparent;
}


.header-region.has-image .a-image.cover img {
    object-position: 50% 40%;
}

/*mobilr nav*/

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

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

.mobile-navigation-wrapper .mobile-navigation .mobile-navigation-container .primary a {
	z-index: 1;
}

/*banner */
.banner-content .banner-description {
    font-weight: 300;
}

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

/*

.banner-item .col {
    max-width: var(--main-banner-content-width-sm);
}

@media (min-width: 768px) {
    .banner-item .col {
        max-width: var(--main-banner-content-width-md);
    }
}

@media (min-width: 992px) {
    .banner-item .col {
        max-width: var(--main-banner-content-width-lg);
    }
}


@media (min-width: 1200px) {
    .banner-item .col {
        max-width: var(--main-banner-content-width-xl);
    }
}
*/


/*wysiwyg */

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

.cta-section.upper-cta-section {
    padding-bottom: 2em;
}

.cta-section .highlight-element.highlight-content {
    margin-bottom: 1em;
}

.cta-section.cta-section-2 {
    padding: 3em 0em;
}
.cta-section.cta-section-2 .highlight-title {
	margin:0;
	font-size:1.2em;
}

.highlight-content {
    --highlight-content-icon-size: 4em !important;
}


.cta-section.cta-section-1  {
	padding-top:0;
}

.cta-section.cta-section-1 .wysiwyg-content {
    margin-bottom: 0;
    padding-bottom:0;
}

/*custom map section */

.shirvington-map-display {
    background: url(/dist/images/map/shirvington-map.jpg);
    background-size:cover;
    background-position: 30% 50%;
    padding:3em 0em 6em 0em;
    position: relative;
}

.shirvington-map-display:before {
    background: rgba(0, 0, 0, .05);
    content: " ";
    width: 100%;
    height: 100%;
    z-index: 0;
    position: absolute;
    top: 0;
    left: 0;
}

@media (min-width: 992px) {
	.shirvington-map-display {
		    padding:3em 0em;
	}
}
.shirvington-map-display .content-box {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
	background:#fff;
	padding:2em;
	box-shadow:0px 3px 8px 0px rgba(0, 0, 0, .20);
}

.shirvington-map-display  .content-box .directions-button {
	background: var(--main-link-color);
    color: white;
    padding: .5em 1em;
    text-decoration: none;
}



/* sitegate modal override */
#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.5) 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: 15em;
}

/*sales bar*/

.sales-bar {
    --sales-bar-vertical-padding: 0.25em !important;
    --sales-bar-font-size: .925em !important;

}

@media (max-width: 991.98px) {
    .sales-highlight-text-element:not(:last-child) {
        margin-bottom: .25em !important
    }
}

/*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: var(--main-link-color);
    --main-button-primary-background-color: var(--main-link-color);
    --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);
    font-weight: 500;
    font-size: 1.15em;
}

.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-hover-color);
    --main-button-primary-highlight-border-color: var(--main-link-hover-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,
.card-type-color .banner-action a.btn.banner-btn-secondary {
    --main-button-secondary-border-color: rgba(255, 255, 255, .75);
    --main-button-secondary-background-color: transparent;
    --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;
    font-weight: 500;
    font-size: 1.15em;
}


.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,
.card-type-color .banner-action a.btn.banner-btn-secondary:hover {
    --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);
}

/*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;
}
@media (min-width: 576px) {
   .product-list .product-item .product-image{
        width: 30%;
    }
}

/*slices */

.slice {
    padding: 1em 0em;
}

.slice .grid-item .icon-cta-item-content>div {
    width: 100%;
}

.slice .icon-cta-ghost .highlight-text .highlight-text-inner {
    background: transparent;
    padding: 1em;
}

.slice .feature-highlights .col {
    padding: 0;
}

.slice .highlight-item > div {
    padding: 0em !important;
    border: none !important;
    align-items: flex-start;
}

.slice .highlights .highlight-item:not(:first-child) {
    padding-top: 2em;
}

.slice .acarousel.navigation-carousel {
    display: none;
}

.slice form {
    padding: 0;
}

.slice .form-buttons button{
	margin: 1em 1em 1em 0em;
}

.catalog-container .top-filters .category-filter {
    z-index: 10;
}

.top-filters .view-toggle .btn {
	border-radius:0px;
}

/*footer */
.footer-section {
    position: relative;
}

.footer-section:before {
    background: url(/dist/images/pimpernel-background-footer.jpg);
    content: " ";
    width: 100%;
    height: 100%;
    z-index: 0;
    position: absolute;
    background-size: cover;
    opacity: .4;
    top: 0;
    left: 0;
}

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

.footer-section .middle-footer-region .link-list-title h3 {
    font-size: 1.6em !important;
    font-weight: 400;
}

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

.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-section .middle-footer-region .footer-region-divider {
    border: none !important;
}

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

/* table overrides */
.table thead th,
.table th,
.table td,
table .cart-view-table {
    border-color: 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;
}