@import url('https://fonts.googleapis.com/css2?family=Roboto:ital,wght@0,100;0,300;0,400;0,500;0,700;0,900;1,100;1,300;1,400;1,500;1,700;1,900&display=swap');

:root {
	--main-font-size: 17px;
    --main-line-height: 1.7;
    --main-heading-line-height: 1.25;
    --main-body-font-weight:300;
    
	--main-heading-font: "Roboto", sans-serif;
	--main-body-font: "Roboto", sans-serif;
	
	--main-text-color:var(--oraterra-dark-charcoal);
	
	--main-link-color: var( --oraterra-green);
	--main-link-hover-color: var(--oraterra-dark-green);
	
	--main-highlight-link-color:var(--oraterra-dark-charcoal);
	--main-highlight-color: var(--oraterra-dark-charcoal);
	--main-highlight-text-color: var(--oraterra-dark-charcoal);
	
	--oraterra-dark-charcoal:#151313;
	--oraterra-dark-green:#002c1e;
    --oraterra-green:#003d2b;
    --oraterra-sage: #4f644e;

    --main-text-heading-color: var(--oraterra-dark-green);
    
    --oraterra-light-background:#f7f5ee;

    --oraterra-neutral:#efede6;
    --oraterra-sand: #b6a490;
    --oraterra-burgundy: #531a2d;
    --oraterra-dark-burgundy: #38091f;
	--oraterra-golden: #b27f14;
	
	--main-banner-background-color: var( --oraterra-sand);
	--main-page-header-banner-background: var( --oraterra-sand);
	
	
	--main-button-primary-background-color: var(--oraterra-green);
	--main-button-primary-border-color:  var(--oraterra-green);
	
	
	/*club */
	--main-section-background-color: #ffffff;
    --main-wine-club-list-selection-aside-background-color: var(--oraterra-green);
    --main-wine-club-list-selection-aside-highlight-color: var(--oraterra-sand);

	
	/*header */
	--main-site-header-height:5em;
    --main-site-header-border-color: #d7d4cc;
	
	--header-menu-button-size: 2.5em;
    --header-menu-button-icon-size: 2.5em;
    --main-site-header-icon-size: 2.5em;
	--main-header-secondary-font-size: 1em;
	--main-header-secondary-font-weight: 400;
	--header-menu-button-icon-color: #fff;
    --header-menu-button-text-color: #fff;	
	/*logo */
    --main-logo-width: 145px;
	--main-logo-width-sm: 170px;
    --main-logo-width-md: 185px;
    --main-logo-width-lg: 210px;

	/*footer logo */
    --main-logo-width-sm: 170px;
    --main-logo-width-md: 190px;
    --main-logo-width-lg: 215px;

	/*banner */
    --main-banner-padding: 4.25em;
    --main-banner-description-font-size: 1.3em;
    --main-banner-title-font-size: 2em;
    --main-banner-title-font-weight: 300;
 
    --main-banner-content-width-sm: 95%;
    --main-banner-content-width-md: 55%;
    --main-banner-content-width-lg: 65%;
    --main-banner-content-width-xl: 65%;
    
    --main-site-header-navigation-container-inner-background-color: var(--oraterra-neutral);
    --main-site-header-navigation-container-footer-background-color:   var(--oraterra-neutral);

	--main-footer-background-color: var(--oraterra-dark-green);
	--main-footer-text-color: var(--oraterra-sage);
	
}

:root,
.client-theme-1 {
	--vc-dark-color: #002c1e;
	--vc-dark-contrast-color: #003d2b;
	--vc-light-color: #efede6;
	--vc-light-contrast-color: #efede6;
	--vc-accent-color: #667565;
	--vc-accent-contrast-color: #4f644e;
	--neutral-1: #e4e4e4;
	--neutral-2: #a7937c;	
}

@media (min-width: 768px) {
:root {
	    --main-site-header-height: 6.75em;
	  	--header-menu-button-size: 3em;
		--header-menu-button-icon-size: 3em;
		--main-site-header-icon-size: 3em;  
	  
	}
}
/*type adjustments */

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

body {
	font-weight:var(--main-body-font-weight);
    background:var(--oraterra-light-background);

}

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


/* header */
.absolute-header.has-header .menu-closed.header.header-menu-section:before {
    background: linear-gradient(hsl(0, 0%, 0%) 0%, hsla(0, 0%, 0%, 0.738) 19%, hsla(0, 0%, 0%, 0.541) 34%, hsla(0, 0%, 0%, 0.382) 47%, hsla(0, 0%, 0%, 0.278) 56.5%, hsla(0, 0%, 0%, 0.194) 65%, hsla(0, 0%, 0%, 0.126) 73%, hsla(0, 0%, 0%, 0.075) 80.2%, hsla(0, 0%, 0%, 0.042) 86.1%, hsla(0, 0%, 0%, 0.021) 91%, hsla(0, 0%, 0%, 0.008) 95.2%, hsla(0, 0%, 0%, 0.002) 98.2%, hsla(0, 0%, 0%, 0) 100%);
    width: 100%;
    height: 16em;
    content: " ";
    position: absolute;
    top: 0;
    pointer-events: none;
    opacity: .8;
}

@media (min-width: 768px) {
	.absolute-header.has-header .menu-closed.header.header-menu-section:before {
	    height: 20em;
	}
}

.absolute-header .menu-navigation-region .link-list-title h3 {
	font-size:1.2em;
}

.absolute-header .menu-navigation-region .link-list-item .link-list-item-link {
	font-size:1em; 
}

.menu-opened {
	--main-site-header-background-color: var(--oraterra-neutral) !important; 
}

.menu-opened .mobile-navigation .social-group .social-link .icon {
	--main-footer-link-color: var(--oraterra-green) !important;
}

.absolute-header .nav-link.cart {
	    padding: 0;
}

.absolute-header .my-account-container .btn {
    padding: 0;
}

.mobile-navigation-container .main-menu-region {
    top: 0;
}
.footer-menu-region-noticebar {
	bottom:0 !important;
}

.header.header-menu-section .navbar-nav {
	align-items: center;
}

.header.header-menu-section .navigation.nav .nav-item .nav-link:after {
    margin-left: 0.5em;
    opacity: .25;
}

.header.header-menu-section .dropdown-menu:before {
	z-index:-2 !important;
}
.header.header-menu-section .dropdown-menu { 
   filter: drop-shadow(1px 2px 3px #5555);
}

.header.header-menu-section .header-navigation-region .mini-main-navigation .navigation.nav>li, 
.header.header-menu-section .header-navigation-region .mini-main-navigation .navigation.nav>ul {
    margin-left: 1.2em !important;
}
@media (min-width: 1200px) {
.header.header-menu-section .header-navigation-region .mini-main-navigation .navigation.nav>li, 
.header.header-menu-section .header-navigation-region .mini-main-navigation .navigation.nav>ul {
    margin-left: 1.25em !important;
}
}

.absolute-header .user-actions .navbar-nav .dropdown-menu {
	position: absolute !important;
}

/*hide unused nav region */

.header .secondary-region .mini-main-navigation {
    display: none;
}

/* banners */

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

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

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


.main-banner-section .banner-title {
	display:none;
}

.banner-description {
    line-height: 1.6;
    font-weight: 300;
}

.main-banner-section .banner-content .banner-content-inner {
	position: relative;
}


.main-banner-section .banner-content .banner-content-inner:before {
    background: url(/dist/images/banner-text-display.svg);
    content: " ";
    width: 240px;
    height: 85px;
    object-fit: contain;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: 2;
    display: flex;
    left: 0;
    right: 0;
    margin: 3em auto;
}

@media (min-width: 992px) {

.main-banner-section .banner-content .banner-content-inner:before {
    width: 500px;
    height: 180px;
    margin:0em auto 3em auto;
    
}
}

@media (min-width: 768px) {
    .banner-content-position-bottom {
        padding-top: calc(var(--main-banner-padding)* 3);
        padding-bottom: calc(var(--main-banner-padding)* .75) !important;
    }
}

@media (min-width: 992px) {
    .banner-content-position-bottom {
        padding-top: calc(var(--main-banner-padding)* 4);
        padding-bottom: calc(var(--main-banner-padding)* .75) !important;
    }
}


.header-region .header-content h1 {
    font-weight: 400;
}

/*cta sections */

.cta-section {
	    --main-banner-padding: 6.25em;
}

.cta-section .banner-content .col {
    max-width: 520px;
}

.cta-section .banner-title h1,
.slice .banner-title h1 {
	font-size: 1.6em;
}

@media (min-width: 576px) {
	 .banner-title h1 {
        font-size: 2em;
    }
}

.cta-section .banner-title h1,
.slice .banner-title h1 {
	font-size: 1.6em;
}

@media (min-width: 576px) {
	.cta-section .banner-title h1,
	.slice .banner-title h1 {
		font-size: 1.4em;
	}
}


.cta-section .banner-title,
.slice .banner-title {
    margin-bottom: 1.25em;
}


.cta-section-2 .image-background{
	--main-banner-background-position: 50% 35%;
}

.cta-section.lower-cta-section .image-background{
	--main-banner-background-position: 50% 45%;
}

.cta-section.lower-cta-section .banner-content-position-top.banner-content-gradient {
	background-image:none;
}


.cta-section.lower-cta-section .banner-item .banner-content:before {
    content: "MARTINBOROUGH";
    POSITION: absolute;
    bottom: 0;
    width: 100%;
    max-width: 1140px;
    padding-left: 15px;
    left:0;
    right:0;
    text-align: left;
}


.cta-section.lower-cta-section  .banner-item .banner-content:after {

    content: "NEW ZEALAND";
    POSITION: absolute;
    bottom: 0;
    width: 100%;
    max-width: 1140px;
    padding-right: 15px;
    left: 0;
    right: 0;
    text-align: right;
    }

.cta-section.lower-cta-section .banner-item .banner-content:before,
.cta-section.lower-cta-section  .banner-item .banner-content:after {
	font-size:.9rem;
    padding-bottom: 40px;
	letter-spacing: 2px;
    margin:0 auto;
}

@media (min-width: 768px) {
.cta-section.lower-cta-section .banner-item .banner-content:before,
.cta-section.lower-cta-section  .banner-item .banner-content:after {
	font-size:1.2rem;
    padding-bottom: 80px;

}
}



/*cta 50-50 hacks*/

.cta-section.upper-cta-section,
.cta-section.cta-section-1 {
    --main-banner-padding: 3.5em;
}

.cta-section.upper-cta-section .swiper-container,
.cta-section.cta-section-1  .swiper-container {
    padding: 3em 1.5em;
}

@media (min-width: 768px) {
	.cta-section.upper-cta-section .swiper-container,
	.cta-section.cta-section-1  .swiper-container {
	    padding: 5em 0em;
	}
}

@media (min-width: 768px) {
	.cta-section cta-section-1 .card-type-photo .image-overlay,
	.cta-section.upper-cta-section .card-type-photo .image-overlay {
		display: none !important;
	} 
}

.cta-section cta-section-1 .card-type-photo .banner-content-gradient,
.cta-section.upper-cta-section .card-type-photo .banner-content-gradient {
	background: none;
}

/*left*/

.cta-section .banner-title h1 {
    letter-spacing: 3px;
}

.cta-section.upper-cta-section .card-type-photo {
    --main-banner-padding: 3rem;
}

.cta-section.upper-cta-section .card-type-photo .banner-btn.banner-btn-secondary {
	color: #fff;
}


.cta-section.upper-cta-section .card-type-photo .banner-btn.banner-btn-secondary:hover {
	    --main-button-secondary-border-color: rgba(0,0,0, .25);
}

@media (min-width: 768px) {

.cta-section.upper-cta-section .banner-item .banner-content .col {
    width: 100%;
    display: flex;
    justify-content: flex-end;
    max-width: 100%;
}

.cta-section.upper-cta-section .image-background {
    width: 50% !important;
}

.cta-section .banner-content-inner .banner-title h1 {
	font-size:2.8rem;
}

.cta-section.upper-cta-section .banner-content-inner {
    width: 50%;
    display: flex;
    justify-content: flex-end;
    flex-direction: column;
    align-items: flex-start;
    padding-left:6em;
}
}
.banner-content .banner-action {
    margin-top: 1.5em;
}


@media (max-width: 767.98px) {
    .banner-content .banner-action {
        justify-content: center;
    }
}

@media (min-width: 576px) {
    .banner-text-left .banner-action .btn {
        margin-right: 0em !important;
    }
}
.banner-action .banner-btn {
	margin-bottom: 0em !important;
}

.banner-content .banner-action {
    gap: 1em;
    display: flex;
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
}

/*right */


@media (min-width: 768px) {
	.cta-section.cta-section-1  .banner-content-gradient {
		background-image: none !important;
	}
}
@media (min-width: 768px) {
   	.cta-section.cta-section-1 .banner-item .banner-content .col{
	    width: 100%;
	    display: flex;
	    justify-content: flex-start;
	    max-width: 100%;
	}
	.cta-section.cta-section-1 .image-background {
	    WIDTH: 50% !important;
	    right: 0;
	}
	.cta-section.cta-section-1 .image-background {
	    WIDTH: 50% !important;
	    right: 0;
	}
	
	.cta-section.cta-section-1 .banner-content-inner{
	    width: 50%;
	    display: flex;
	    justify-content: flex-start;
	    flex-direction: column;
	    align-items: flex-start;
	    padding-right:6em;
	    color: var(--oraterra-green);
	}
}


/*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: 1px 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: .6em 1.5em;
    background-color: var(--main-button-primary-background-color);
    letter-spacing: 3px;

}
.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: #fff;
    --main-button-primary-highlight-border-color: #fff;
    --main-button-primary-highlight-text-color: var(--main-link-color);
    background-color: var(--main-button-primary-highlight-background-color);
    color: var(--main-button-primary-highlight-text-color);
    border: 1px 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: 1px 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: .6em 1.5em;
    letter-spacing: 3px;

}

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

div[name^="page-blob-bottom--node-"]:before,
div[name^="page-blob-bottom--node-"]:after  {
    content: " ";
    background-color: var(--oraterra-green);
    position: absolute;
    height: 100%;
    width: 100vw;
    z-index: -1;
    top:3em;
}

div[nid^="49"] div[name^="page-blob-bottom--node-"]:before,
div[nid^="49"]  div[name^="page-blob-bottom--node-"]:after  {
	    background-color: var(--oraterra-sand);
}

div[name^="page-blob-bottom--node-"]:before {
    left: -50vw;
}
div[name^="page-blob-bottom--node-"]:after  {
    right: -50vw;
}

div[name^="page-blob-bottom--node-"] .a-carousel {
    margin-top: 4em;
}

div[name^="page-blob-bottom--node-"] {
	    --main-banner-padding: 3em;
	    padding-top:3em;
}

div[name^="page-blob-bottom--node-"] .banner-content .banner-content-inner {
	padding:2em;
}

div[name^="page-blob-bottom--node-"] .banner-content .col {
    max-width: 600px;
}

div[name^="page-blob-bottom--node-"]  .featured-swiper .swiper-slide {
	    min-height: 450px;
}

div[name^="page-blob-bottom-"][class*="wysiwyg-content"] {
	color:#fff;
}

div[name^="page-blob-bottom-"][class*="wysiwyg-content"] a{
    color: #b4c7c1;
    text-decoration-color: #b4c7c1;
    text-decoration: underline;
}

div[nid^="49"] .slice:nth-child(1){
	background-color: var(--oraterra-dark-burgundy);	
	color:#fff;
	--main-text-color:#fff;
    padding-top: 6em;
    padding-bottom: 0;
}

div[nid^="49"] .slice:nth-child(2){
	background-color: var(--oraterra-burgundy);	
	--main-text-heading-color:#fff;
	color:#fff;
	--main-text-color:#fff;
	padding:4em 0;
}
div[nid^="49"] .slice:nth-child(3) {
	padding-top:3em;
	padding-bottom:0;
} 

div[nid^="49"] .slice:nth-child(3) .advanced-wysiwyg-content-region {
	max-width:550px;
}

div[nid^="49"] .header-region .header-content .header-title h1 {
	display: none;
}

div[nid^="49"] .header-region .header-content .header-title::before {
    background: url(/dist/images/the-fold-logo.svg);
    content: " ";
    width: 260px;
    height: 95px;
    object-fit: contain;
    background-size: contain;
    background-repeat: no-repeat;
    z-index: 2;
    display: flex;
    left: 0;
    right: 0;
    margin: 3em auto 5em auto;
}

.slice form {
    padding: 0;
}

.slice .form-renderer-wrapper .form-buttons  .btn-secondary{
	display: none;
}



div[nid^="44"]  .page-body,
div[nid^="45"]  .page-body,
div[nid^="33"]  .page-body {
	--main-highlight-color: var(--oraterra-burgundy);
}

/*cta sections */

.cta-section {
	padding:0;
}
.cta-section.upper-cta-section  {
	background-color: var(--oraterra-dark-charcoal);
}

.cta-section.cta-section-1 {
		background-color: var(--oraterra-neutral);

}
@media (min-width: 768px) {
.cta-section.cta-section-1 .card-type-photo .banner-btn.banner-btn-primary {
	 --main-button-primary-border-color: var(--oraterra-green);
    --main-button-primary-background-color:transparent;
    --main-button-primary-text-color:  var(--oraterra-green);
}
}


/*wine club */
.product-cards .product-card .product-info .product-title h3{
	font-weight:400;
}

#somnambulist-ui.wineclub-ui,
#somnambulist-ui {
    --main-text-color: var(--oraterra-dark-charcoal);
}


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


/*page*/

.page .header-region {
	margin-bottom:0;
}

/* slices */

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



.slice {
    padding: 1em 0em;
}

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

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

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

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

.banner-content-inner.banner-text-center .banner-actions {
    display: flex;
    justify-content: center;
    align-items: center;
}

@media (min-width: 576px) {
   .slice .highlight-image {
        margin-bottom: 0;
        width: auto;
        min-width: 45%;
        max-width: 45%;
    }
}

/* footer */
.footer-section .lower-footer-region, 
.footer-section .middle-footer-region, 
.footer-section .upper-footer-region {
    margin-bottom: 1.5em !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:2px 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;
} 


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