/*
Theme Name: Deviation Road
Theme URI: https://wordpress.org/themes/twentytwentyone/
Template: twentytwentyone
Author: Moller and Romeo
Author URI: https://mollerandromeo.com/
Description: Child theme for twenty twenty-one WordPress theme
Version: 2.4.1741759749
Updated: 2025-03-12 06:06:08

*/


/* GENERAL - WEBSITE */

.site .button:not(:hover):not(:active):not(.has-background), button:not(:hover):not(:active):not(.has-background), input[type="submit"]:not(:hover):not(:active):not(.has-background), input[type="reset"]:not(:hover):not(:active):not(.has-background), .wp-block-search .wp-block-search__button:not(:hover):not(:active):not(.has-background), .wp-block-button .wp-block-button__link:not(:hover):not(:active):not(.has-background), .wp-block-file a.wp-block-file__button:not(:hover):not(:active):not(.has-background) {
  background-color: #000;
}

.page-template-page-deviation-light-header {
	background:#fff;
}
.page-template-page-deviation-dark-header {
	background:#fff;
}
.page-template-page-home {
	background:#fff;
} 

.site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    outline: none;
    text-decoration: none;
    text-decoration-skip-ink: none;
    background: transparent;
}
.site .button:focus, button:focus, input[type="submit"]:focus, input[type="reset"]:focus, .wp-block-search .wp-block-search__button:focus, .wp-block-button .wp-block-button__link:focus, .wp-block-file a.wp-block-file__button:focus {
  outline-offset: -6px;
  outline: none;
}
a {
	color:#cdbf8a;
}
.c7-side-cart a {
	color:#000;
}
.site-main {
	padding-top:0px;
	padding-bottom:0px;
}

.elementor-widget-button .elementor-button {
	background-color:#000;
	border-radius:0px;
}




/* HEADER & NAVIGATION */

.header-nav {
    display: flex;
    justify-content: center; 
    width: 100%;
}
.header-top-wrapper {
	border-bottom: 1px solid #cba158;
	height: 50px;
}
.header-bottom-wrapper {
	height: 52px;
}
.header-top {
	width: 1200px;
  	margin: auto;
  	max-width: 96%;
    display: flex;
    align-items: center;
    justify-content: space-between;
}
.header-bottom {
	width: 1200px;
  	margin: auto;
  	max-width: 96%;
    display: flex;
    align-items: center;
    justify-content: center;
	padding-top: 3px;
	padding-bottom:3px;
}
.header-cart-wrapper {
    display: flex;
    align-items: center;
    gap: 15px; 
    margin-left: auto;
	z-index: 1000;
}
header button:not(:hover):not(:active):not(.has-background) {
	background: transparent;
    color: #fff;
}
.header-logo img {
	width:200px;
	vertical-align: unset;
    padding-top: 8px;
}


#c7-cart {
    display: flex;
    align-items: center;
}
#c7-account {
	display: flex;
    align-items: center;
	border-left:1px solid #cba158;
	border-right:1px solid #cba158;
}
.c7-user-nav__account {
    position: relative;
    padding-right: 20px;
    padding-left: 20px;
    padding-top: 8px;
    padding-bottom: 8px;
}
.c7-user-nav__account a {
	font-family: "Playfair Display", sans-serif;
	font-size: 15px;
	font-weight: 400;
}
.c7-user-nav__cart button {
	padding-bottom:0px;
	padding-top:0px;
	font-family: "Playfair Display", sans-serif;
	font-size: 15px;
	font-weight: 400;
}
.c7-user-nav__cart__title svg {
    display: none;
}
.c7-user-nav__cart__title span {
	clip: rect(0 0 0 0);
    clip-path: unset;
    overflow: hidden;
    position: unset;
    white-space: nowrap;
	padding-right: 12px;
}


.nav-menu {
    list-style: none; 
    padding: 0;
    margin: 0;
    display: flex; 
    gap: 20px; 
}
.nav-menu li {
    display: inline-block;
}
.nav-menu a {
    text-decoration: none;
    color: #fff;
    padding: 10px 15px;
    display: block;
    font-weight: 500; 
    transition: color 0.3s ease-in-out;
	font-family: "Playfair Display", sans-serif;
	font-size:17px;
}
.nav-menu .current-menu-item a,
.nav-menu .current_page_item a {
    color: #cba158; 
}
.nav-menu a:hover {
    color: #cba158;
}

/* Nav Sub Menu */

.sub-menu-toggle {
    display: none !important;
}

.sub-menu {
    display: none; 
    position: absolute;
    background: white;
    color: black;
    list-style: none;
    margin: 0;
    min-width: 150px; 
	margin-top: 2px;
	padding-inline-start: 0px;
}

@media (min-width: 751px) {
	.sub-menu {
		z-index:9999;	
	}
}
.sub-menu li {
    white-space: nowrap; 
	width:100%;
	display:block;
}
.sub-menu li a {
    color: black;
    text-decoration: none;
    display: block;
    transition: background 0.3s ease-in-out;
}
.sub-menu li a:hover {
    background: #f2f2f2;
}
.menu-item-has-children:hover > .sub-menu {
    display: block;
}
.menu-item-has-children {
    position: relative;
}
.sub-menu li a {
    color: #000 !important;
}

@media (min-width: 751px) {
	.menu-item-has-children {
    position: relative; /* Ensures submenu is positioned relative to the parent */
}

.sub-menu {
    position: absolute;
    top: 100%;
    left: 0;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease-in-out, visibility 0.2s ease-in-out;
    z-index: 1000; /* Ensures it's above other elements */
	margin-top: 0px;
}

.menu-item-has-children:hover .sub-menu {
    opacity: 1;
    visibility: visible;
}

}



/* HOME PAGE HEADER & DARK HEADER */

header.home-header {
	background:#000;
}
header.home-header .c7-user-nav__account a, header.home-header .c7-user-nav__cart button {
	color: #fff;
	top: -3px;
    position: relative;
}
header.home-header .c7-user-nav__cart__count {
	background: #464646;
	min-width: 25px;
    height: 25px;
    padding-bottom: 2px;
	font-size: 15px;
	top: 3px;
    position: relative;
    font-weight: 400;
}
header.home-header .nav-menu ul li a {
	color: #fff;  
}

@media (min-width: 751px) {
	
	header.home-header .sub-menu {
		background: #000 !important;
		z-index:9999;
	}
	header.home-header .sub-menu li a {
		color:#fff !important;
		background: #000;
	}
	header.home-header .sub-menu li a:hover {
		color:#cba158 !important;
		background: #000;
	}	
	.sub-menu {
		margin-top: -1px;
		pointer-events: auto;
	}
	
}


/* LIGHT HEADER */

header.light-header {
	background:#e7e7e7;
}
header.light-header .c7-user-nav__account a, header.light-header .c7-user-nav__cart button {
	color: #000;
	top: -3px;
    position: relative;
}
header.light-header .c7-user-nav__cart__count {
	background: #464646;
	min-width: 25px;
    height: 25px;
    padding-bottom: 2px;
	font-size: 15px;
	top: 3px;
    position: relative;
    font-weight: 400;
}

header.light-header button:not(:hover):not(:active):not(.has-background) {
	background: transparent;
	color: #000;
}



@media (min-width: 751px) {
	header.light-header .nav-menu a {
		color: #000;  
	}
	header.light-header .sub-menu {
		background: #e7e7e7;
	}		
	.header-logo-mobile {
		display:none;
	}
	.header-logo {
		display:block;
	}
	header.light-header .nav-menu a:hover {
		color: #cba158;
	}
	header.light-header .sub-menu li:hover a {
	  	background: #E7E7E7;
		color:#cba158 !important;
	}
}









/* FOOTER */

.site-footer {
	background: #000;
	max-width:100%;
}
.footer-wrapper {
	width: 1200px;
  	margin: auto;
  	max-width: 96%;
	padding-top:50px;
}
.footer-wrapper h5 {
	color:#fff;
	text-align:center;
	font-family: "Playfair Display", sans-serif;
	margin-bottom:25px;
}
.footer-wrapper-top {
    display: flex;
    justify-content: space-between;
    gap: 0px;
}
.footer-col-1, .footer-col-2, .footer-col-3, .footer-col-4 {
    flex: 1;
	padding-left: 5px;
    padding-right: 5px;
}
.footer-col-1, .footer-col-2, .footer-col-3 {
	border-right: 1px solid #cba158;
}
.footer-navigation-wrapper {
    list-style: none;  
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
}
.footer-navigation-wrapper li {
    margin-bottom: 10px;
    width: 100%; 
    text-align: center;
	display: inline;
    line-height: 1.5;
}
.footer-navigation-wrapper li a {
    text-decoration: none;
    color: white;
}
.footer-navigation-wrapper li a:link, .footer-navigation-wrapper li a:visited, .footer-navigation-wrapper li a:active {
    color: #fff;
}
.footer-wrapper-logo {
	text-align:center;
	width:100%;
	margin-bottom: 50px;
}
.footer-wrapper-logo img{
	width:300px;
}
.footer-navigation {
	margin-top:25px;
}
.footer-navigation-wrapper li a:link {
	font-family:"Playfair Display", sans-serif;
	font-size: 15px;
}
.footer-wrapper-top p {
	font-family:"Playfair Display", sans-serif;
	color:#fff;
	font-size:15px;
	text-align:center;
	line-height: 20px;
	margin-bottom:17px;
}
.footer-wrapper.row2 {
	border-top: 1px solid #cba158;
	width: 100%;
    max-width: 100%;
	margin-top: 50px;
}
.footer-site-info {
	text-align:center;
}
.footer-site-info p {
	font-family:"Playfair Display", sans-serif;
	color:#fff;
	font-size:15px;
}

@media (max-width: 980px) {
    .footer-wrapper-top {
        display: flex;
        flex-wrap: wrap; 
    }

    .footer-col-1,
    .footer-col-2 {
        flex: 1 1 50%;
		margin-bottom:50px;
		padding-left: 25px;
    	padding-right: 25px;
    }

    .footer-col-3,
    .footer-col-4 {
        flex: 1 1 50%; 
		padding-left: 25px;
    	padding-right: 25px;
    }
	.footer-col-2 {
		border-right: 0px solid #cba158;
	}
}

@media (max-width: 580px) {
    .footer-col-1,
    .footer-col-2,
    .footer-col-3,
    .footer-col-4 {
        flex: 1 1 100%; /* Each takes full width */
		border-right: 0px solid #cba158;
    }
	.footer-col-4 {
		margin-top:50px;
	}
}



@media (min-width: 751px) {
	button.menu-toggle {
		display:none;
	}
	.submenu-toggle-icon {
		display:none;
	}
	.menu-item-has-children:hover > .sub-menu {
		display: block;
	}
 
}


/* MOBILE HEADER & MENU */

@media (max-width: 750px) {
	.header-logo-mobile {
		display:block;
	}
	.header-logo-mobile img {
		width:220px;
		margin-top:5px;
	}
	.header-bottom-wrapper {
	  	height: 57px;
	}
	.header-logo {
		display:none;
	}
    .header-nav {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100vh;
        background: rgba(0, 0, 0, 1);
        display: flex;
        flex-direction: column;
        align-items: flex-start; 
        justify-content: center;
        transform: translateX(-100%);
        transition: transform 0.3s ease-in-out;
        z-index: 1000;
    }
    .header-nav.active {
        transform: translateX(0);
    }
    .nav-menu {
        list-style: none;
        padding-left: 0;
        text-align: left;
        margin-left: 0px;
        margin-top: 50px;
        display: flex;
        flex-direction: column;
        align-items: center;
        gap: 10px;
        position: fixed;
        top: 50px;
        left: 0;
        right: 0;
    }
    .nav-menu li {
        width: 100%;
        text-align: left;
    }
    .nav-menu a {
        color: white;
        text-decoration: none;
        font-size: 1.5rem;
        transition: color 0.3s;
        display: block;
        padding: 10px;
    }
    .nav-menu a:hover {
        color: #cba158;
    }
    .menu-toggle {
        background: none;
        border: none;
        cursor: pointer;
        display: block;
        padding: 10px;
        position: absolute;
        left: 15px;
        top: 15px;
        z-index: 1001;
    }
    .menu-toggle.active {
        position: fixed;
    }  
    .menu-item-has-children:hover > .sub-menu {
        display: none !important;
    }
    .submenu-toggle-icon {
        font-weight: bold;
        cursor: pointer;
        display: inline-block;
        margin-left: 5px;
        font-size: 20px;
        padding-right: 20px;
        color: white;
    }   
    .menu-item {
        display: flex;
        align-items: center;
        justify-content: space-between;
        padding: 10px;
        transition: height 0.3s ease-out;
    }  
    .sub-menu {
        display: none;
        list-style: none;
        padding-left: 20px;
        text-align: left;
        transition: height 0.3s ease-out;
    }
    .submenu-open .sub-menu {
        display: block;
    }
    .menu-item-has-children .sub-menu-toggle {
        background: none;
        border: none;
        color: white;
        cursor: pointer;
        font-size: 1.2rem;
        padding: 5px;
        margin-top: 5px;
    }
    .menu-item-has-children .sub-menu li {
        margin: 5px 0;
    }
    .menu-item-has-children .sub-menu a {
        font-size: 1.2rem;
    }  
    .hamburger {
        display: block;
        width: 30px;
        height: 3px;
        background: white;
        position: relative;
        transition: all 0.3s ease-in-out;
    }
    .hamburger::before,
    .hamburger::after {
        content: '';
        width: 30px;
        height: 3px;
        background: white;
        position: absolute;
        left: 0;
        transition: all 0.3s ease-in-out;
    }	
	.light-header .hamburger {
        background: black;
    }
    .light-header .hamburger::before {
        content: '';
        background: black;
    }
    .light-header .hamburger::after {
        content: '';
        background: black;
    }	
	.light-header .menu-toggle.active .hamburger::before {
		background:white;
	}
	.light-header .menu-toggle.active .hamburger::after {
		background:white;
	}
    .hamburger::before {
        top: -10px;
    }

    .hamburger::after {
        top: 10px;
    }
    .menu-toggle.active .hamburger {
        background: transparent;
    }
    .menu-toggle.active .hamburger::before {
        transform: rotate(45deg);
        top: 0;
    }
    .menu-toggle.active .hamburger::after {
        transform: rotate(-45deg);
        top: 0;
    }
	.header-nav .menu-item {
        padding: 0px;
    }	
    .header-nav .nav-menu {
        display: flex;
        flex-direction: column;
    }
    .header-nav .nav-menu li {
        width: 100%;
        position: relative;
        display: flex;
        flex-direction: column; 
        align-items: flex-start; 
		font-size:1.2rem;
		border-bottom: 1px solid #cba158;
		padding-left: 20px;
    }	
	.header-nav .nav-menu li a{
		font-size:1.3rem;
		padding-top:0px;
    }
    .header-nav .nav-menu li.menu-item-has-children > a {
        width: 100%;
        display: flex;
        justify-content: space-between; 
        align-items: center;
    }
    .submenu-toggle-icon {
        font-weight: bold;
        cursor: pointer;
        display: inline-block;
        margin-left: 5px;
        font-size: 20px;
        color: white;
    }
    .header-nav .sub-menu {
        width: 100%;
        display: none;
        list-style: none;
        padding-left: 20px;
		background:transparent;
    }	
	.header-nav .sub-menu li {
		border-bottom:0px solid #000;
	}	
	.header-nav .sub-menu li a {
		font-size:1.2rem;
		color: white !important;
		
	}
	.sub-menu li a:hover {
	  	background: transparent;
		color:#cba158;
	}
    .header-nav .sub-menu.active {
        display: block;
    }
    .header-nav .sub-menu.active li {
        display: block;
    }

    /* Ensure the parent li expands in height when submenu is active */
    .header-nav .sub-menu.active {
        position: relative;
		padding-bottom: 10px;
    }

    /* Disable hover effect when submenu is active */
    .header-nav .nav-menu li.submenu-expanded:hover > .sub-menu {
        display: block !important;
    }
	
}





/* ELEMENTOR CONTAINER */

.e-con-full {
	
}
.e-con-boxed .e-con-inner {
	width:1140px !important;
	max-width:90% !important;
}




/* TYPOGRAPHY START */

#content h1 {
	font-size: 40px;
	color: #050505;
	font-family:"Playfair Display", sans-serif;
	line-height: 55px;
	font-weight: 500;
}
#content h2 {
	font-size: 32px;
	color: #050505;
	font-family:"Playfair Display", sans-serif;
}
#content h3 {
	font-size: 23px;
	color: #050505;
	font-family:"Playfair Display", sans-serif;
}
#content p {
	font-size: 16px;
	color: #050505;
	font-family: "Roboto", sans-serif;
	margin-bottom:18px;
}
#content .awards-text p {
	font-size: 20px;
	color: #050505;
	font-family:"Playfair Display", sans-serif;
	margin-bottom:18px;
}
#content ul li {
	font-size: 16px;
	color: #050505;
	font-family: "Roboto", sans-serif;
	margin-bottom: 7px;
    margin-top: 7px;
}

/* Forms */

label {
	font-family: "Roboto", sans-serif;
}

.c7-btn {
	border-radius: 0px;
	font-family:"Playfair Display", sans-serif;
}

.c7-form input[type="text"], .c7-form input[type="email"], .c7-form input[type="number"], .c7-form input[type="tel"], .c7-form input[type="username"], .c7-form input[type="password"], .c7-form textarea, .c7-form--stripe, .c7-order-item input, .c7-form select, .c7-order-item select {
	border-radius: 0px;
	margin-left: 0px;
}

.c7-btn--primary {
	font-family:"Playfair Display", sans-serif;
	color:#fff !important;
}
.c7-btn--primary:not([disabled]):hover {
	background-color:#393939;
	color:#fff !important;
}
button:not(:hover):not(:active):not(.has-text-color) {
	color:#fff;
}

.c7-link {
	font-family: "Roboto", sans-serif;
	font-size: inherit;
}

/* PRODUCT LIST PAGE */

.c7-product-collection .c7-product__title, .c7-product-allocation .c7-product__title, .c7-club-product__details__title {
	font-family:"Playfair Display", sans-serif;
	font-weight: 500;
  	font-size: 28px;
  	margin-bottom: 15px;
}

.c7-product__teaser {
  	margin-bottom: 30px;
}
#content .c7-product__teaser {
  	/*font-family:"Playfair Display", sans-serif;*/
	display:none;
}

.c7-product__subtitle {
	/*display:none;*/
	font-family: "Roboto", sans-serif;
	color: #050505;
}
.c7-product__add-to-cart__price {
	/*font-family:"Playfair Display", sans-serif;*/
	font-size: 26px;
}
.c7-product-collection__product-list .c7-product__add-to-cart__form__quantity {
	display:none;
}
.c7-product-collection__product-list .c7-btn--primary {
	width:100%;
}

@media screen and (min-width: 769px) {
  .c7-product-collection .c7-product, .c7-product-allocation .c7-product, .c7-product-detail .c7-product {
    display: block;
	background: #e7e7e7;
    padding: 30px;
  }
}

.c7-product-collection .c7-product, .c7-product-allocation .c7-product, .c7-product-detail .c7-product {
    display: block;
	background: #e7e7e7;
    padding: 30px;
  }
.c7-radio__label {
	font-family: "Roboto", sans-serif;
	font-weight:400;
}

.c7-product-collection .c7-product {
    display: flex;
    flex-direction: column;
    height: 100%; /* Ensures it takes full height */
}
.c7-product-content-wrapper {
	flex-grow: 1;
}
input[type="radio"] {
    accent-color: black !important; /* Change this to your desired color */
}
.c7-checkbox input[type="checkbox"]:focus + .c7-checkbox__control, .c7-radio input[type="radio"]:checked + .c7-radio__control, .c7-radio--box input[type="radio"]:checked + .c7-radio__control + .c7-radio__label::after, .c7-radio--box input[type="radio"]:checked + .c7-radio__control + .c7-card-type + .c7-radio__label::after {
	border-color: black !important;
}

.c7-radio input[type="radio"]:checked + .c7-radio__control::after {
	background:#000;
	accent-color: black !important;
}


/* Newsletter plugin */
.newsletter-block {
    display: flex;
    justify-content: center; 
	background:#cdbf8a;
	padding-top: 15px;
    padding-bottom: 15px;
}

.newsletter-block-wrapper {
    display: flex;
    justify-content: center;
    width: 100%; 
}

.newsletter-block-content {
    display: flex;
    align-items: center; 
    justify-content: center; 
    gap: 10px; 
    text-align: center; 
}

.newsletter-block-form label {
	display:none !important;
}
.newsletter-block-form .c7-form input[type="email"] {
	margin-top:25px;
	border: 0px solid;
}
.newsletter-block-form .c7-form__field {
	width:380px;
	margin-left:35px;
}

.newsletter-block-form .c7-form__group .c7-form__field + button {
  margin-top: 25px;
  margin-left: 0px;
}
.no-widgets .site-footer {
  margin-top: 0px;
}
@media screen and (max-width: 900px) {
	.newsletter-block-content {
        flex-direction: column; 
        gap: 5px; 
		padding-top: 20px;
    }
	.newsletter-block-form .c7-form__field {
		margin-left:0px;
	}
	
}

@media screen and (max-width: 580px) {
	.newsletter-block-form .c7-form__group {
		flex-direction: column;
	}
	.newsletter-block-form .c7-form__group .c7-form__field + button {
		margin-top:0px;
		margin-bottom:35px;
		width:100%;
	}
	.newsletter-block-form .c7-form__field {
	  	width: 380px;
	  	max-width: 100%;
    	margin: auto;
    	margin-bottom: 20px;
	}
}


/* PRODUCT DETAIL */

.c7-product-detail .c7-product {
  	display: flex;
  	align-items: flex-start;
  	gap: 20px; 
	padding:0px;
	background:#fff;
}

.c7-product .c7-product__image {
  	flex-shrink: 0; 
}

.c7-product .c7-product__details {
  	flex-grow: 1; 
}

.c7-product-detail .c7-product__image {
	flex: 0 0 500px;
	margin-right: 40px;
	background:#e7e7e7;
	padding:40px;
}

.product-detail-vintage-wrapper {
  	width: 100%;
  	display: flex;
  	justify-content: flex-start; 
  	align-items: center; 
  	gap: 30px; 
  	padding: 10px 0; 
	font-size: 15px;
  	color: #050505;
  	font-family: "Roboto", sans-serif;
	margin-top:30px;
}

.product-vintage,
.product-varietal,
.product-appellation {
  	white-space: nowrap; 
  	text-align: left; 
	padding-right:30px;
	border-right:1px solid #000;
}

.product-varietal {
  	max-width: 40%; 
  	word-wrap: break-word; 
}

.product-detail-vintage-wrapper > div:last-child {
  	border-right: none; 
}

@media screen and (max-width: 1080px) { 
	
	.c7-product-detail .c7-product__image {
		flex: 0 0 380px;
		margin-right: 40px;
		background:#e7e7e7;
		padding:40px;
	}
	
}

@media screen and (max-width: 960px) { 
	
	.c7-product-detail .c7-product__image {
		flex: 0 0 300px;
		margin-right: 40px;
		background:#e7e7e7;
		padding:40px;
	}
	
}

@media screen and (max-width: 860px) { 
	
	.c7-product-detail .c7-product {
     flex-direction: column; 
     align-items: center; 
     gap: 20px;
     width: 100%;
   }

   .c7-product-detail .c7-product__image {
     flex: none; 
     width: 100%; 
     margin-right: 0; 
     padding: 20px; 
   }

   .c7-product .c7-product__details {
     width: 100%;
   }
	
}

/* CART */

.c7-btn--primary, .c7-btn--primary--small {
	background: #000;
}
ul, ol {
  	color: #050505;
  	font-family: "Roboto", sans-serif;
}
.c7-side-cart__header h1.c7-h1 {
	font-family:"Playfair Display", sans-serif;
}

.c7-cart__content button.c7-link {
	background-color: transparent !important;
	color:#000 !important;
}
.c7-form--coupon-code-container button.c7-link {
	background-color: transparent !important;
	color:#000 !important;
}
.c7-order-items__title .c7-link {
	color:#000;
}
aside .c7-cart__summary-container {
	color: #050505;
  	font-family: "Roboto", sans-serif;
}
#c7-side-cart__summary__proceed:active {
	background:#000;
}
#c7-side-cart__summary__proceed:focus {
	background:#000;
}
.c7-order-item__details button.c7-link {
	color:#000 !important;
	color: #050505;
  	font-family: "Roboto", sans-serif;
}
.c7-order-item__title a {
	text-decoration:underline !important;
	color:#000;
}
.c7-callout:not(.c7-callout--club)::before {
	top:-4px;
}
.c7-checkout-logo {
	max-width: 240px !important;
}

/* ACCORDION */

.elementor-widget-n-accordion .e-n-accordion-item-title {
	background: #e7e7e7;
	border-bottom: 0px solid !important;
}


button.c7-link:hover {
	background:transparent;
}
.c7-side-cart__header button:active, .c7-side-cart__header button:hover, .c7-side-cart__header button:focus:not(:focus-visible) {
  outline: 0;
  background: transparent;
}


/* RESERVATION WIDGET */

.reservation-wrapper {
    display: flex;
    width: 100%;
	align-items: stretch;
}

.reservation-wrapper .left-side-image, .reservation-wrapper .right-side-info {
    flex: 1; 
}

.reservation-wrapper .left-side-image {
    width: 50%;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    min-height: 100%; 
}

.reservation-wrapper .right-side-info {
    width: 50%;
    padding: 20px;
	background: #e7e7e7;
	padding: 45px;
	padding-bottom:45px;
	border-top:1px solid #cacaca;
	border-right:1px solid #cacaca;
	border-bottom:1px solid #cacaca;
}

.reservation-wrapper .right-side-info h3 {
	margin-bottom:25px;
	font-size: 22px;
  	color: #050505;
  	font-family: "Playfair Display", sans-serif;
	font-weight: 600;
}
.reservation-wrapper .reservation-text {
	margin-bottom:20px;
}
.reservation-wrapper .c7-btn {
	margin-left:0px !important;
}

@media screen and (max-width: 1160px) {
	
	.reservation-wrapper .c7-btn {
		margin-left:10px !important;
		margin-top:39px !important;
	}
	
}

@media screen and (max-width: 999px) {
	
	.reservation-wrapper .left-side-image {
		display:none;
	}
	.reservation-wrapper .right-side-info {
    	width: 100%;
		border-left:1px solid #cacaca;
	}
}

@media screen and (max-width: 768px) {
  .reservation-wrapper .c7-btn {
    margin-left: 0px !important;
  }
}

#left-image-right-text.reservation-wrapper .reservation-text {
	margin-bottom:50px;
}

.elementor-button {
	padding-top: 17px !important;
	padding-bottom: 17px !important;
	padding-left:29px !important;
	padding-right:29px !important;
}

.home-banner-logo {
	top: 45% !important;
    left: 50% !important;
    transform: translate(-50%, -45%);
}
@media screen and (max-width: 700px) {
.elementor-15 .elementor-element.elementor-element-c983312 {
  --container-widget-width: 59% !important;
	}
}

.home-content h1 {
	font-size: 42px !important;
}


.home-column-block {
    max-width: 700px;
    width: 100%;
    position: relative;
}

.home-column-block .image-container {
    width: 100%;
}

.home-column-block .image-container img {
    width: 100%;
    height: auto;
    display: block;
}

.home-column-block .bottom-bar {
    position: absolute;
    bottom: 40px;
    left: 50%;
    transform: translateX(-50%);
    width: 90%;
    color: white;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 26px;
    border-top: 1px solid #fff;
    padding-top: 20px;
}

.home-column-block .bottom-bar span {
    font-size: 28px;
	font-family: "Playfair Display", sans-serif;
	font-weight: 500;
}
.home-column-block .bottom-bar svg {
	top: 5px;
  	position: relative;
}


/* SABRE CLUB PAGE */

.sabre-club-info .e-con-inner{
	width:1200px !important;
	max-width:90% !important;
	
}

#sabre-wrapper h1 {
	color:#fff;
}

#content .sabre-club-info .e-con-inner p {
	color:#fff !important;
}
#content .sabre-club-info .e-con-inner h2 {
	color:#fff !important;
}
#content .sabre-club-info .e-con-inner h3 {
	color:#fff !important;
}
#content .sabre-club-info .e-con-inner ul {
	padding-left:15px;
}
#content .sabre-club-info .e-con-inner ul li {
	color:#fff !important;
	padding-left: 6px;
}



/* Review Quotes Block */
.testimonial-slider {
    width: 100%;
    background: #e7e7e7;
    padding: 30px;
    position: relative;
    text-align: center;
    border: 1px solid #ccc;
}

.testimonial-slider .testimonial-container {
    position: relative;
    overflow: hidden;
    min-height: 100px;
    width: 75%;
    margin: auto;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
}

.testimonial-slider .testimonial {
    display: none;
    opacity: 0;
    font-size: 18px;
    font-style: italic;
    color: #333;
    transition: opacity 1s ease-in-out;
}
 
.testimonial-slider .testimonial.active {
    display: block;
    opacity: 1;
}

.testimonial-slider .quote {
    font-size: 20px;
    font-style: italic;
    color: #333;
	font-family: "Roboto", sans-serif;
}

.testimonial-slider .quoter {
    font-size: 16px;
    font-weight: bold;
    color: #555;
    margin-top: 10px;
	font-family: "Roboto", sans-serif;
	font-style: normal;
}

.testimonial-slider button {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: none;
    border: none;
    font-size: 24px;
    cursor: pointer;
    padding: 10px;
    color: #333;
    transition: 0.3s;
}

.testimonial-slider button:not(:hover):not(:active):not(.has-background) {
	background-color: transparent;
}

.testimonial-slider button:hover {
    color: #007bff;
}

.testimonial-slider .prev {
    left: 10px;
}

.testimonial-slider .next {
    right: 10px;
}

@media screen and (max-width: 600px) {
	.testimonial-slider .prev {
		left: 0px;
	}
	.testimonial-slider .next {
		right: 0px;
	}	
	.testimonial-slider .testimonial-container {
		width: 85%;
	}
}



/* Sabre club */

.elementor-27 .elementor-element.elementor-element-e1f27a5:not(.elementor-motion-effects-element-type-background) {
  	background-position: calc(50% + 80px) calc(5% + 10px);
}
p.join-the-club  {
	margin-bottom:0px !important;
}
.c7-club-join-button .c7-btn--primary {
	font-family: "Roboto", sans-serif;
	font-style: normal;
	background:#cdbf8a !important;
	color: #000 !important;
	text-decoration:none !important;
	width:190px;
	margin-bottom:20px;
}
.c7-club-join-button  .c7-btn--primary:not([disabled]):hover {
  background:#c9b567 !important;
  color: #000 !important;
}

.elementor-27 .elementor-element.elementor-element-4318908::before {
	background-color: #000 !important;
	opacity: 0.8 !important;
}
.elementor-27 .elementor-element.elementor-element-4318908 {
	/*opacity: 0.7 !important;*/
}

/* Club Checkout */

.c7-club-summary__selection svg {
	margin-top:-18px;
}



/* Events */
.elementor-192 .reservation-button {
	display: inline-block;
    padding: 10px 20px;
    background-color: #000;
    color: #ffffff;
    text-decoration: none;
    margin-top: 10px;
	font-family: "Playfair Display", sans-serif;
	font-size: 15px;
	font-weight: 600;
}


.footer-col-4 a {
	color: #fff;
	text-decoration:none;
}
.footer-col-4 a:hover {
	color: #fff;
	text-decoration:underline;
	text-decoration-style: dotted;
  	text-decoration-skip-ink: none;
}

@media screen and (max-width: 600px) {
	.c7-side-cart__header h1.c7-h1 {
	  font-family: "Playfair Display", sans-serif;
	  padding-left: 50px;
	  margin-top: -15px;
	}
}



/* LIVE UPDATES */

header.light-header .c7-user-nav__account a.c7-user-nav__account__name {
	padding:4px;
}
header.home-header .c7-user-nav__account a.c7-user-nav__account__name {
	padding:4px;
}
header.home-header .c7-user-nav__account__name svg {
	stroke:#fff !important;
}
header.home-header .c7-user-nav__account__dropdown__header a {
	color:#000;
}
header.home-header .c7-user-nav__account__dropdown li a {
	color:#000;
}
header.home-header .c7-user-nav__account__dropdown__logout {
	color:#000 !important;
}

.c7-account-block__actions button {
	padding: 10px;
    font-family: "Playfair Display", serif;
    font-size: 14px;
    letter-spacing: 1px;
    padding-top: 4px;
    padding-bottom: 4px;
}
.c7-account__menu .c7-active a {
	border-bottom-color: #cba158; 
}


/********* UPDATES **********************/

.c7-filters .c7-form__field {
  margin-left: auto;
}
.visit-grid .elementor-button.elementor-button-link.elementor-size-sm {
	width:190px !important;
}
@media (max-width: 1200px) {
  .elementor-23 .elementor-element.elementor-element-2169654 {
    --e-con-grid-template-columns: repeat(1, 1fr) !important;
    --grid-auto-flow: row !important;
  }
}
.c7-product__add-to-cart__giftcard .c7-expand-link {
	padding: 8px;
  	font-size: 14px;
}