/*google fonts */

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

:root {
    --main-font-size: 17px;
    --main-line-height: 1.7;
    --main-heading-line-height: 1.25;
    --main-heading-font: "Montserrat", sans-serif;
	--main-body-font: "Noto Sans", sans-serif;
	   
	--kimbolton-blue:#113053;
	--kimbolton-blue-accent:#174068;
	
	--kimbolton-blue-slate:#22374f;
	
	--main-text-heading-color: #1f2b36;
    --main-text-color: #1f2b36;
	
	--main-link-color:var(--kimbolton-blue);
	--main-link-hover-color:var(--kimbolton-blue-accent);

	--main-dark-background-color:var(--kimbolton-blue-slate);
	--main-progress-loader-color: var(--kimbolton-blue-accent);


    --main-page-header-banner-background: var(--main-dark-background-color);
    --main-banner-background-color:  var(--main-dark-background-color);


    --main-input-label-color: var(--main-link-color);
    --main-input-border-color: var(--main-border-color);
    --main-cart-continue-btn-background-color: #8e978f;

    --main-radio-checked-background-color: var(--main-link-color);

    --main-product-toggle-filter-background-highlight-active-color: var(--main-link-hover-color);
    --main-product-toggle-filter-background-active-color: var(--main-link-color);
    --main-product-toggle-filter-background-color: #bbc3d3;


    --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: var(--main-link-color);
    
	--main-mobile-navigation-link-dropdown-background-color: #f0f5fa;
    --main-mobile-navigation-link-dropdown-background-highlight-color: #d8e3ec;

    --main-mobile-navigation-button-background-color: var(--main-link-color);
    --main-mobile-navigation-button-hover-background-color: var(--main-link-hover-color);
    --main-mobile-navigation-button-text-color: white;
    --main-mobile-navigation-button-hover-text-color: #fff;

    --main-logo-width: 130px;
    --main-logo-width-sm: 140px;
    --main-logo-width-md: 140px;
    --main-logo-width-lg: 150px;


    --main-mobile-logo-width: 140px;
    --main-mobile-logo-width-sm: 150px;
    --main-mobile-logo-width-md: 170px;
    --main-mobile-logo-width-lg: 190px;
    
    --main-header-primary-region-background: #eef2f9;

    --main-header-primary-region-background-text-color: var(--main-link-color);
    --main-header-primary-region-background-highlight: var(--main-link-color);
    --main-header-primary-region-background-highlight-text-color: #fff;


    --main-header-secondary-region-background: #eef2f9;
    --main-header-secondary-region-text-color: var(--main-link-color);
    --main-header-secondary-region-icon-color: var(--main-link-color);

    --main-cart-count-background: var(--main-link-color);
    --main-cart-count-text: #fff;
    
	--main-cart-continue-btn-background-color: #4c6784;
    --main-cart-clear-btn-background-color: #dfe4e9;
  
    --age-gate-logo-size:135px;
    
	/* banner */
    --main-banner-padding: 4em;
    --main-banner-description-font-size: 1.1em;
    --main-banner-title-font-size: 2.3em;
	--main-banner-title-font-weight: 700;
    --main-banner-background-position: 50% 30%;
    
    /*footer*/  
    --main-footer-background-color: var(--kimbolton-blue);
    --main-footer-text-color:#617e9e;
    --main-footer-link-color:#fff;
    
}

:root, 
.client-theme-1 {
	--vc-dark-color: #08182b;
    --vc-dark-contrast-color: #285181;
    --vc-light-color: #e5f1fa;
    --vc-light-contrast-color: #dbeffe;
    --vc-accent-color: #113053;
    --vc-accent-contrast-color: #224a77;
    --neutral-1: #bacddc;
    --neutral-2: #2e4f6b;
    --neutral-3: #447795;
}


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

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


.header.header-001 .primary-region .navigation.nav ul .nav-item>.nav-link,
.header.header-001>.primary-region .navigation>.nav-item>.nav-link {
    font-weight: 500;
    font-size: 1em;
}

/*header */
.header.header-001 .secondary-region {
    padding: 1rem 0;
}

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

.header.header-001 .secondary-region .nav-label {
	font-size:.867em;
    font-weight: 400;
}

.header.header-001>.primary-region .navigation {
    justify-content: center;
}

.header.header-001>.primary-region .navigation>.nav-item {
    flex: none;
    padding: 0em .5em;
}

.header.header-001 .primary-region .navigation.nav ul,
.header.header-001 .primary-region .navigation.nav > li {
    flex: none;
    padding: 0em .2em;
}

@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 .primary-region .navigation.nav ul .nav-item>.nav-link,
.header.header-001>.primary-region .navigation>.nav-item>.nav-link {
    font-size: .9em;
    font-weight: 500;
    padding: .8em 1em;
}

.header.header-001>.secondary-region .secondary-nav {
    z-index: 2;
}

@media (min-width: 768px) {
    .header.header-001>.secondary-region .navbar {
        min-height: 4em;
    }
}

.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.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: 0.25em !important;
}

.header.header-001 .secondary-region .navbar-nav .nav-item {
    margin-left: 1em;
}

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

.header.header-001 .secondary-region .mobile-navigation .nav-link.cart.has-items,
.header.header-001 .secondary-region .mobile-navigation .nav-link {
    padding: 1rem;
}

.header.header-001 .secondary-region .nav-link.portal .btn-link {
    padding: 0em;
}

.header.header-001 .primary-region .navigation.nav .dropdown-menu {
    width: 100%;
    padding: 0;
}

.header.header-001 .primary-region .navigation.nav .dropdown-menu:before {
    width: 1.5em;
    height: 0.75rem;
    background: #fff;
    -webkit-clip-path: polygon(50% 0, 0 100%, 100% 100%);
    clip-path: polygon(50% 0, 0 100%, 100% 100%);
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    z-index: 1;
    transform: translate(0, 0);
    transition: translate, .3s;
    content: " ";
    top: -0.75rem;
    margin-left: auto;
    margin-right: auto;
}

.header.header-001 .primary-region .navigation.nav .dropdown-menu ul {
    padding: 0em;
}

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

.header.header-001 .primary-region .navigation.nav .nav-item .dropdown-menu a.router-link-exact-active {
    background: var(--main-link-color);
    color: white;
}


.header.header-001 .secondary-region .dropdown-menu:before {
    z-index: -1;
}

.header.header-001 .dropdown-menu:before {
    z-index: -2 !important;
    margin-top: 2px;
}

.header.header-001 .dropdown-menu {
    filter: drop-shadow(1px 2px 3px #5555);
}

.header.header-001 .secondary-region .nav-link.portal .btn-link {
    color: var(--main-header-secondary-region-text-color);
}

.cta-section .wysiwyg-content {
    max-width: 720px;
    margin: 0 auto;
    padding: 0em 1em;
	text-wrap: pretty;
}

@media (min-width: 768px) {
	.cta-section .wysiwyg-content {
	    max-width: 720px;
	}
}
@media (min-width: 992px) {
	.cta-section .wysiwyg-content {
	    max-width: 1140px;
	}
}

/*mobile nav */

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

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


/* banner section */
.main-banner-section .featured-swiper .swiper-slide {
	min-height:500px;
}
@media (min-width: 768px) {
.main-banner-section .featured-swiper .swiper-slide {
	min-height:500px;
}
}
@media (min-width: 992px){

	.main-banner-section .featured-swiper .swiper-slide {
		min-height:550px;
	}
}
@media (min-width: 1200px){
	.main-banner-section .featured-swiper .swiper-slide {
		min-height:650px;
	}
}



#modal-age-gate-temp .age-gate-content-element:first-of-type:before {
    content: " ";
    background-image: url(/dist/images/sitegates/age-gate/grapes-for-good-web-page-header-2025.jpg);
    width: 100%;
    height: 10em;
    display: flex;
    background-repeat: no-repeat;
    background-size: contain;
}


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




/*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);
}

.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 {
    --main-button-secondary-border-color: rgba(255, 255, 255, .45);
    --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;
}

.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);
}


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

/*cta sections */
.cta-section.upper-cta-section >div:nth-child(2){
    margin: 2em 0em 1.5em 0em;
}

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

.cta-section-2 .featured-swiper{
 --main-banner-background-position: 50% 60%;
}

.cta-section.upper-cta-section .home-intro-content {
    padding: 1.5em 0em;
    background: #eef2f9;
}

@media (min-width: 768px) {
	.cta-section.upper-cta-section .home-intro-content {
	    padding: 3em 0em;
	 }
}
.award-grid {
    --grid-size:3;
    display: grid;
    grid-template-columns: repeat(var(--grid-size), 1fr);
    grid-gap: .75em;
    width: 100%;
}

@media (min-width: 768px) {
	.award-grid {
		--grid-size:6;
	}
}

.award-grid-item img {
    width: 100%;
    height: auto;
}

.award-grid-item {
    justify-content: center;
    display: flex;
    align-items: center;
    padding: 1em 2em;
    background:#fff;
    border-radius:6px;
}

@media (min-width: 768px) {
	.award-grid {
	    grid-gap: 1em;
	}
	
	.award-grid-item {
	 padding: 1em;
	}
}

@media (min-width: 992px) {
	.award-grid {
	    grid-gap: 1.5em;
	}
	
	.award-grid-item {
	 padding:1em 2em;
	}
}

/*checkout*/

@media (min-width: 992px) {
    .cart-side-2 {
	top: 1em;
	}
}	  

/*page */

.slice .advanced-wysiwyg-content-region a.cta-button-link {
    border: 2px solid var(--main-link-color);
    margin: 1em 0;
    padding: .75em 1.25em;
    display: inline-flex;
    text-decoration: none;
    color: #fff;
    background-color:var(--main-link-color);
    transition: background-color .3s ease-in-out, color .3s ease-in-out;
}

.slice .advanced-wysiwyg-content-region a.cta-button-link:hover {
    background: var(--main-link-hover-color);
    border-color: var(--main-link-hover-color);
}

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

.slice .a-carousel.featured-swiper {
    aspect-ratio: 16 / 9;
    height: 100%;
    min-height: 100%;
    padding: 0 15px;
}

.slice .a-carousel .swiper-container {
	height:100%;
}


.inset-image {
    width: 800px;
    margin: 2em auto;
    left: auto;
    right: auto;
    display: flex;
}

/*catalouge */

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

/*footer*/

.footer-navigation.footer-software-provider {
    opacity: .5;
}

.footer-section .disclaimer-footer-region {
    font-size: .867em;
}

.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, .1);
    }
}

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

.country-acknowledgement {
    display: flex;
    flex-direction: column;
    font-size:.867em;
    margin-bottom: 1em;
    text-align: center;
}

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

