/*
	Theme Name: Villa Rey
	Theme URI: https:/www.villarey.eu
	Description: 
	Version: 1.0.0
	Author: Dhynet (@dhynet)
	Author URI: https://www.dhynet.com
	Tags: 

	License: 
	License URI: 
*/

/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*, *:after, *:before { -moz-box-sizing:border-box; box-sizing:border-box; -webkit-font-smoothing:antialiased; font-smoothing:antialiased; text-rendering:optimizeLegibility;}


/* clear */
.clear:before, .clear:after {content:' '; display:table;}
.clear:after {clear:both;}
.clear {*zoom:1;}
img {max-width:100%; vertical-align: middle;}


html, body {width:100%; margin:0; padding:0;}
html {scroll-behavior: smooth; overflow-x: hidden; scroll-padding-top: 120px;}
body { 
	
	background:var(--background);  
	color:var(--text-color);
	font-size:16px;
	line-height: 1.5;
	letter-spacing:1px;
	font-weight:normal;
	font-family: "Source Sans 3", sans-serif;

}

a {color:#444; text-decoration:none; transition: 0.3s ease;}
a:hover {color:#444; transition: 0.3s ease;}
a:focus {outline:0;}
a:hover, a:active {outline:0;}
input:focus {outline:0; border:1px solid #04A4CC;}

ul, ol {margin:0; padding:0; list-style-type:none;}

/* Hide Scrollbar */
::-webkit-scrollbar {display: none;} /* Chrome, Edge, Safari */
html {scrollbar-width: none;} /* Firefox */
html {-ms-overflow-style: none;} /* IE/Edge vecchio */


/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/

main {width:100%; margin:0; padding:0;}

/* wrapper */
.wrapper 		{width: 100%; max-width:1024px; margin:0 auto; padding-inline:var(--gutter);}
.wrapper-big 	{width: 100%; max-width:1480px; margin:0 auto; padding-inline:var(--gutter);}
.wrapper-medium {width: 100%; max-width:1280px; margin:0 auto; padding-inline:var(--gutter);}
.wrapper-small 	{width: 100%; max-width: 960px; margin:0 auto; padding-inline:var(--gutter);}



/* header */
.header {position:fixed; top:0; left:0; width:100%; margin:0; padding:0; z-index:9999; background:var(--background);}
.header_inner {height:135px; display:flex; align-items: center; justify-content: space-between; column-gap:var(--gutter); transition: 0.6s ease; border-inline:1px solid var(--alt-color-light);}
.sticky .header_inner {height:80px; transition: 0.6s ease;}
.header_left, .header_right {display:flex; align-items: center; justify-content: space-between;}

.logo {position:relative; flex:1; text-align:center; padding-block:0.5rem; border-top:2px solid var(--main-color); transition: 0.6s ease; /*border-inline:1px solid var(--alt-color-light);*/
background:var(--background);
}
.sticky .logo {margin-top:-34px; transition: 0.6s ease;}
.logo-img {width: 100%;  max-width: 7rem; height:auto;}
.logo:after {content:''; position:absolute; bottom:-25px; left:0; width:100%; height:135px; z-index:-1; background:url(img/pick.svg) center center no-repeat; background-size: auto 100%;}

.get-in-touch {display:flex; gap:calc(var(--gutter) / 2); align-items: center;}
.get-in-touch a {display:flex; border:1px solid var(--alt-color-light); border-radius:50px; padding-inline: 1rem; height:34px; background:var(--background);}
.get-in-touch a:hover {background:var(--alt-color-light);}
.get-in-touch svg {width:1.2rem; height:auto;}

.languages {display:flex; justify-content: space-between; column-gap:var(--gutter); align-items: center; border:1px solid var(--alt-color-light); border-radius:50px; padding:0.3rem 1rem; background:var(--background);}
.languages ul {display:flex; gap:var(--gutter);}
.languages a:hover {opacity:0.6;}
.languages img {width:20px !important; height:auto !important;}
.languages .current-lang {opacity:0.2;}

.book-now {min-width:var(--col); text-transform: uppercase; font-size:0.875rem; font-weight:700;}
.book-now a {display:inline-block; width:100%; background: var(--alt-color); padding:1rem 2rem; color:white; text-align:center; border-radius:4px;}

/* nav */
.nav {display:none; margin:0; padding:0;}
.nav ul {margin:0; padding:0; list-style:none;}
.nav ul li {margin:0; padding:0;}
.nav ul li a {}
.nav ul li a:hover {}


/* Hamburgher Menù */
*{-webkit-tap-highlight-color: rgba(0,0,0,0); -webkit-tap-highlight-color: transparent; /* For some Androids */}

.mobilenav-hidden {overflow:hidden;}

.top-animate {background:  var(--second-color) !important; top: 13px !important; -webkit-transform: rotate(45deg); transform: rotate(45deg);}
.mid-animate {opacity: 0;}
.bottom-animate {background:  var(--second-color) !important; top: 13px !important; -webkit-transform: rotate(-225deg); transform: rotate(-225deg);}

.top-menu {top: 5px; width: 2rem; height: 2px; border-radius: 0px; background-color:  var(--second-color);}
.mid-menu {top: 13px; width: 1.5rem; height: 2px; border-radius: 0px; background-color: var(--second-color);}
.bottom-menu {top: 21px; width: 2rem; height: 2px; border-radius: 0px; background-color:  var(--second-color);}

.icon {width:2rem; height:2rem; padding:0; margin:0;}
.menui {position: absolute; transition: 0.6s ease; transition-timing-function: cubic-bezier(.75, 0, .29, 1.01);}
.hamburger {position:relative; display:block; height:2rem;}

.mobilenav {display:none; position:fixed; top: 0; left:0; z-index: 9; width:100%; height:auto; overflow-x: hidden; overflow-y: auto; background:var(--alt-color-dark);}
.mobilenav .mobilenav-inner {position:relative; width:100%; height:auto; padding:135px 0 0 0; margin:0;}
.mobilenav ul {position:relative; display:flex; gap:1rem; border-bottom:3px solid var(--main-color); border-top:1px solid rgba(255,255,255,0.2); margin:0; padding:3rem 0; list-style:none; font-family: "Prata", serif; text-transform: uppercase; font-size:1.25rem;}
.mobilenav li {flex:1; padding:0; margin:0; text-align:center;}
.mobilenav li a {color:var(--background);}
.mobilenav li a:hover {opacity: 0.4;}
.mobilenav .current_page_item a, .mobilenav .current-page-ancestor a {color:var(--main-color);}


.mobilenav ul:before {content:'★ ★ ★ ★'; position:absolute; left:50%; top:0; color:var(--main-color); font-size:0.75rem; translate: -50% -100%;}






/* footer */
.footer {padding-top:calc(var(--col) / 2); background:var(--alt-color); color:white; font-size:1rem;}
.footer a {color:white;}
.footer a:hover {opacity:0.5;}
.footer .logo-img {max-width:var(--col);}
.footer h6 {color:white; text-transform: uppercase; font-weight:700;}
.icon-list {display:flex; align-items: center; gap:1rem;}

.footer_inner {display:flex; gap:var(--gutter); flex-wrap: wrap;}
.footer_inner .col {/*display:flex; flex-direction:*/ column; flex:1;}

.colophon {width:100%; margin:0; padding:0; font-size:0.75rem;}
.colophon_top {border-bottom:1px solid white; padding-block:2rem; text-align:center;}
.colophon_bottom {display:flex; justify-content: space-between; gap:var(--gutter); text-transform: uppercase; padding-block:2rem; font-size:0.75rem;}
.colophon_bottom div {display:flex; gap:var(--gutter);}
.colophon_bottom a {font-weight:700;}

span.wppro_avg_b6s6a {color:white !important;}













/*------------------------------------*\
    PAGES
\*------------------------------------*/







/*------------------------------------*\
    LIBRARY
\*------------------------------------*/

:root {

	--screen:1480px;
	--gutter: 1rem;
	--cols: 12;
  	--col: calc(1448px / var(--cols) - var(--gutter));

	/* Colors Palette */
	--background: #efece4 /*#FFFAED*/ /*#f5f4f1*/;
	--text-color: #201d1c;
	--title-color: #AE9A63;

	--main-color: #AE9A63;
	--second-color: #1D1D1B;

	--alt-color:#5F514B;
	--alt-color-light: #e5e0d0 /*#fbf3df*/ /*#efece4*/;
	--alt-color-dark:#3f3632;

}


.row-margin {margin-block:8rem !important;}
.row-margin-inline {margin-inline:1rem;}
.row-padding-inline {padding-inline:1rem;}
.cell-padding {padding:calc(var(--col) / 2);}
.cell-padding-small {padding:calc(var(--col) / 4);}
.cell-padding-big {padding:calc(var(--col) + var(--gutter) );}
.cell-padding-inline {padding-inline:calc(var(--col) / 2);}
.cell-padding-block {padding-block:calc(var(--col) / 2);}
.extra-left-padding {padding-left: calc((100vw - 1480px) / 2);}
.parallax {will-change: transform; transform: translate3d(0,0,0);}
.text-clamp {
	display: -webkit-box !important;
	-webkit-box-orient: vertical !important;
	-webkit-line-clamp: 3 !important;
	overflow: hidden !important;
  }

.main-title {color:var(--main-color); margin:0 0 2rem 0;}
.cell-radius {border-radius:0.5rem; overflow:hidden;}
.img-radius img {border-radius:0.5rem; overflow:hidden;}
.txt-2-col {column-count: 2; column-gap: 3rem;}
.eyebrow {position:relative; font-size:0.75rem; text-transform: uppercase; color:var(--main-color); margin:0 0 2rem 0; padding:0 0 0 calc(var(--col) / 2 + var(--gutter)); font-weight:700; line-height:1;}
.eyebrow:before {content:''; position:absolute; top:0.75rem; left:0; width:calc(var(--col) / 2); height:1px; background:var(--second-color);}
.eyebrow-light {position:relative; font-size:0.75rem; text-transform: uppercase; color:var(--background); margin:0 0 2rem 0; padding:0 0 0 calc(var(--col) / 2 + var(--gutter)); font-weight:700; line-height:1;}
.eyebrow-light:before {content:''; position:absolute; top:0.75rem; left:0; width:calc(var(--col) / 2); height:1px; background:var(--main-color);}


.test {border:1px solid red;}
.hidden {display:none !important;}
.flex {display:flex;}
.flex-col {flex-direction: column;}
.flex-end {justify-content: flex-end;}
.flex-space-between {justify-content: space-between;}
.flex-1 {flex:1;}
.grid {display:grid;}
.relative {position:relative;}
.absolute {position:absolute;}

.swiper-button-next.swiper-button-disabled, 
.swiper-button-prev.swiper-button-disabled {opacity:0;}











/* Columns --------- */
.col-1, .col-2, .col-3, .col-4, .col-5, .col-6 {/*border:1px solid red;*/}
/*
.col-2 { grid-column: span 2; }
.col-3 { grid-column: span 3; }
.col-4 { grid-column: span 4; }
.col-5 { grid-column: span 5; }
.col-6 { grid-column: span 6; }
.col-7 { grid-column: span 7; }
.col-8 { grid-column: span 8; }
.col-9 { grid-column: span 9; }
.col-10 { grid-column: span 10; }
.col-11 { grid-column: span 11; }
.col-12 { grid-column: span 12; }
*/

.col-1 {width:var(--col);}
.col-2 {width:calc(var(--col) * 2 + var(--gutter));}
.col-3 {width:calc(var(--col) * 3 + var(--gutter) * 2);}
.col-4 {width:calc(var(--col) * 4 + var(--gutter) * 3);}
.col-5 {width:calc(var(--col) * 5 + var(--gutter) * 4);}
.col-6 {width:calc(var(--col) * 6 + var(--gutter) * 5);}






#system-grid {position: fixed; inset: 0; z-index: 9999; display: none; pointer-events: none;}
.grid-container {display: grid; grid-template-columns: repeat(12, 1fr); max-width:1480px; gap:var(--gutter); width: 100%; height: 100%; margin:0 auto; padding-inline:var(--gutter);}
.grid-col {/*border: 1px solid blue;*/ background: rgba(255, 0, 0, 0.3); box-sizing: border-box;}


/* Typography
--------------------------------------------- */

p {margin:0 0 1rem 0;}

p b, p strong {font-weight:600;}

h1, h2, h3, h4, h5, h6 {
	font-family: "Prata", serif;
	color:var(--title-color); 
	font-weight:normal; 
	margin:0 0 1rem 0; 
	padding:0;
	line-height:1.3;
}

h1 {font-size:3rem;}
h2 {font-size:2.5rem;}
h3 {font-size:1.875rem;}
h4 {font-size:1.5rem;}
h5 {font-size:1.25rem;}
h6 {font-size:1rem;}

small, .text-small {font-size: 0.75rem; line-height:1;}




/* Booking Engine
--------------------------------------------- */

.booking-engine div {display:none;}

#btn-booking-mobile{display: none; margin: auto; width: 100% !important;}

#booking{}
#booking-form{}
#booking-form > div {height: 100%; margin: 0;}
#booking-form form {display: flex; gap:1.75rem; justify-content: center; align-items: center;}
#booking-form form div {display:flex; align-items: center; justify-content: flex-end; gap:0.5rem;}
#booking-form label {font-size:1rem; line-height:1rem; margin:0;}
#booking-form .date-picker-control{background-image: url(img/calendar.svg); background-position: center; background-size: 24px auto;}
#booking-form input,
#booking-form select,
#booking-form button{margin:0; padding:0.75rem; border: none; border-radius: 3px; background-color:white; text-align:center;}
#booking-form input{width: 100%;}
#booking-form select{text-align:left; font-size:1rem; padding: 0.75rem; min-width: 3.5rem; appearance:none; background:white url(img/arrow-down.svg) center right 0.25rem no-repeat; background-size: 14px auto;
	-webkit-appearance:none;
	-moz-appearance:none;
	-ms-appearance:none;	
}
/* #booking-form form input::placeholder{font-weight: 400; color: #0453AE;} */
#booking-form button {background: var(--alt-color); padding: 1rem 2rem; color: white; text-align: center; border-radius: 4px; font-weight:600;}

#ITH_Pax_div, #ITH_Extra_div {flex:0;}





/* Forms
--------------------------------------------- */
form .flex {gap:1rem; align-items: center; width:100%; margin-bottom:0.5rem;}
form .flex * {flex:1;}
form label {display:block; margin-bottom:0.5rem;}
.wpcf7-checkbox {display:flex; flex-wrap: wrap; gap:1rem; row-gap:0.5rem;}
.wpcf7-list-item {margin:0; flex: 0 0 calc(25% - 1rem);}
.wpcf7-list-item label {margin-bottom:0;}

form input[type="checkbox"] {width:1rem; height:1rem;}

button,
input[type="button"],
input[type="reset"],
input[type="submit"] {
	border: 0px solid;
	border-radius: 3px;
	background: var(--main-color);
	color: white;
	line-height: 1;
	font-size:1rem;
	text-transform: uppercase;
	padding: 1rem;
}

button:hover,
input[type="button"]:hover,
input[type="reset"]:hover,
input[type="submit"]:hover {
	border-color: #ccc #bbb #aaa;
}

button:active,
button:focus,
input[type="button"]:active,
input[type="button"]:focus,
input[type="reset"]:active,
input[type="reset"]:focus,
input[type="submit"]:active,
input[type="submit"]:focus {
	border-color: #aaa #bbb #bbb;
}

input[type="text"],
input[type="email"],
input[type="url"],
input[type="password"],
input[type="search"],
input[type="number"],
input[type="tel"],
input[type="range"],
input[type="date"],
input[type="month"],
input[type="week"],
input[type="time"],
input[type="datetime"],
input[type="datetime-local"],
input[type="color"],
textarea {
	width:100%;
	color: var(--text-color);
	background:var(--background);
	border: 0px solid #ccc;
	border-radius: 0;
	padding: 1rem;
	margin-bottom:0.5rem;
	border-bottom:1px solid var(--second-color);
	font-size:1rem;
}

input[type="text"]:focus,
input[type="email"]:focus,
input[type="url"]:focus,
input[type="password"]:focus,
input[type="search"]:focus,
input[type="number"]:focus,
input[type="tel"]:focus,
input[type="range"]:focus,
input[type="date"]:focus,
input[type="month"]:focus,
input[type="week"]:focus,
input[type="time"]:focus,
input[type="datetime"]:focus,
input[type="datetime-local"]:focus,
input[type="color"]:focus,
textarea:focus {
	color: #111;
}

select {
	border: 1px solid #ccc;
}

textarea {
	width: 100%;
}








/*------------------------------------*\
    ANIMATIONS
\*------------------------------------*/


/* Fade-in */

@keyframes fadeIn {
	0% {
		opacity: 0;
	}
	100% {
		opacity: 1;
	}
}
  
.fade-in {animation: fadeIn 1s ease-in-out 1s forwards;}


/* Fade-up */

@keyframes fadeUp {
	0% {
		opacity: 0;
		transform: translateY(20px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

.fade-up {animation: fadeUp 1s ease-out 1s forwards;} 
  
  
/* Ritardi progressivi */
.fade-up:nth-child(1) {animation-delay: 0s;}
.fade-up:nth-child(2) {animation-delay: 0.2s;}
.fade-up:nth-child(3) {animation-delay: 0.4s;}
.fade-up:nth-child(4) {animation-delay: 0.6s;}
.fade-up:nth-child(5) {animation-delay: 0.8s;}
.fade-up:nth-child(6) {animation-delay: 1s;}  





/*------------------------------------*\
    MISC
\*------------------------------------

::selection {background:yellow; color:black; text-shadow:none;}
::-webkit-selection {background:yellow; color:black; text-shadow:none;}
::-moz-selection {background:yellow; color:black; text-shadow:none;}

*/

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

/* Galleries
--------------------------------------------- */
.gallery {margin-bottom: 1.5em; display: grid; grid-gap: 1.5em;}
.gallery-item {display: inline-block; text-align: center; width: 100%;}
.gallery-columns-2 {grid-template-columns: repeat(2, 1fr);}
.gallery-columns-3 {grid-template-columns: repeat(3, 1fr);}
.gallery-columns-4 {grid-template-columns: repeat(4, 1fr);}
.gallery-columns-5 {grid-template-columns: repeat(5, 1fr);}
.gallery-columns-6 {grid-template-columns: repeat(6, 1fr);}
.gallery-columns-7 {grid-template-columns: repeat(7, 1fr);}
.gallery-columns-8 {grid-template-columns: repeat(8, 1fr);}
.gallery-columns-9 {grid-template-columns: repeat(9, 1fr);}
.gallery-caption {display: block;}

/* Alignments
--------------------------------------------- */
.alignnone {margin:1.5em;}
.alignleft {float: left; margin-right: 1.5em; margin-bottom: 1.5em;}
.alignright {float: right; margin-left: 1.5em; margin-bottom: 1.5em;}
.aligncenter {clear: both; display: block; margin-left: auto; margin-right: auto; margin-bottom: 1.5em;}

a img.alignright {float:right; margin:5px 0 20px 20px;}
a img.alignnone {margin:5px 20px 20px 0;}
a img.alignleft {float:left; margin:5px 20px 20px 0;}
a img.aligncenter {display:block; margin-left:auto; margin-right:auto;}

.wp-caption {background:#FFF; border:1px solid #F0F0F0; max-width:96%; padding:5px 3px 10px; text-align:center;}
.wp-caption.alignnone {margin:5px 20px 20px 0;}
.wp-caption.alignleft {margin:5px 20px 20px 0;}
.wp-caption.alignright {margin:5px 0 20px 20px;}
.wp-caption img {border:0 none; height:auto; margin:0; max-width:98.5%; padding:0; width:auto;}
.wp-caption .wp-caption-text, .gallery-caption {font-size:11px; line-height:17px; margin:0; padding:0 4px 5px;}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {background:transparent !important; color:#000 !important; box-shadow:none !important; text-shadow:none !important;}
	a, a:visited {text-decoration:underline;}
	a[href]:after {content:" (" attr(href) ")";}
	abbr[title]:after {content:" (" attr(title) ")";}
	.ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after {content:"";}
	pre,blockquote {border:1px solid #999; page-break-inside:avoid;}
	thead {display:table-header-group;}
	tr,img {page-break-inside:avoid;}
	img {max-width:100% !important;}
	@page {margin:0.5cm;}
	p, h2, h3 {orphans:3; widows:3;}
	h2, h3 {page-break-after:avoid;}
}






/*------------------------------------*\
    RESPONSIVE
\*------------------------------------*/

@media only screen
    and (max-width: 767px)
    and (orientation: portrait) {
		body {overflow-x: hidden;}
		h1 {font-size:2.5rem;}
		h2 {font-size:1.875rem;}
		h3 {font-size:1.5rem;}
		h4 {font-size:1.25rem;}

		.cell-padding {padding: calc(var(--col) / 4);}
		#booking-form form, form .flex {flex-direction: column;}
		.wpcf7-list-item {flex: 0 0 calc(100% - 1rem);}

		.get-in-touch {display:none;}
		.book-now {position:fixed; bottom:0; left:0; width:100%; z-index:9999;}
		.book-now a {background:var(--alt-color-dark);}
		.logo {padding-inline: 1rem;}
		.logo-img {width:100px;}
		.header_right {justify-content: flex-end;}
		.languages {padding:0; border:0px solid white;}
		.languages ul {gap:1rem;}
		.mobilenav ul {flex-direction: column;}

		.footer_inner {flex-direction: column; text-align:center; gap: calc(var(--gutter) * 2);}
		.icon-list {justify-content: center;}
		.colophon {text-align:center;}
		.colophon_bottom {flex-direction: column; align-items: center;}
	}	


@media only screen
    and (max-width: 1023px)
    and (orientation: landscape) {
		body {overflow-x: hidden;}
		.col-4 {width: calc(var(--col)* 2 + var(--gutter)* 3);}
	}	


@media only screen
	and (min-width: 768px)
	and (max-width: 1023px)
	and (orientation: portrait) {
		body {overflow-x: hidden;}
		h1 {font-size:2.5rem;}
		h2 {font-size:1.875rem;}
		h3 {font-size:1.5rem;}
		h4 {font-size:1.25rem;}

		.col-4 {width: calc(var(--col)* 2 + var(--gutter)* 3);}
		.cell-padding {padding: calc(var(--col) / 4);}
		#booking-form form, form .flex {flex-direction: column;}
		.wpcf7-list-item {flex: 0 0 calc(100% - 1rem);}

		.mobilenav ul {font-size: 0.9rem;}
		.book-now a {padding:1rem;}
	}

@media only screen
	and (min-width: 1024px)
	and (max-width: 1179px)
	and (orientation: landscape) {
		body {overflow-x: hidden;}
		.col-4 {width: calc(var(--col)* 3 + var(--gutter)* 3);}
	}	