/*  
Theme Name:		hotelfiorenza.com
Author:			baga
Author URI:		http://www.bagaweb.com
*/

/************************************************/
/*** General ************************************/
/************************************************/
body, div, ul, li, h1, h2, h3, h4, h5, h6, form, fieldset, input, textarea, select, button, p, th, td, img {
	margin: 0;
	padding: 0;
	border: 0;
}
body {
	background: #fff;
    font-family: 'Oswald';
	font-weight: 300;
	font-size: 80%;
}
@media only screen and (min-width: 640px) {
body {
	font-size: 90%;
}
}
@media only screen and (min-width: 960px) {
body {
	font-size: 100%;
}
}
a {
	text-decoration: none;
}
img {
	max-width: 100%;
}
.wf-loading {
	visibility: hidden;
}
.wf-active, .wf-inactive {
	visibility: visible;
}
/************************************************/
/*** Grid ***************************************/
/************************************************/
.wrapper {
	position: relative;
	margin: 0 auto;
	padding: 0 2%;
}
@media only screen and (min-width: 1200px) {
.wrapper {
	max-width: 1200px;
	padding: 0;
}
}
.grid {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: -js-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	margin: 0 -1%;
}
.grid-cell {
	-webkit-box-flex: 0;
	-webkit-flex: 0 0 100%;
	    -ms-flex: 0 0 100%;
	        flex: 0 0 100%;
}
@media only screen and (min-width: 640px) {
.grid-cell {
	min-width:0;
	padding: 0 1%;
	-webkit-box-flex: 1;
	-webkit-flex: 1;
	    -ms-flex: 1;
	        flex: 1;
}
.col-1-4 {
	-webkit-flex-basis: 24%;
	    -ms-flex-preferred-size: 24%;
	        flex-basis: 24%;
}
.col-3-4 {
	-webkit-flex-basis: 72%;
	    -ms-flex-preferred-size: 72%;
	        flex-basis: 72%;
}
}
/************************************************/
/*** Navigation *********************************/
/************************************************/
#header {
	width: 100%;
	height: 130px;
	background: #fff;
	padding: 20px 0 0 0;
}
#header h1 a img {
	max-width: 80%;
	margin: 30px 0 0 0;
}
#header.shrink {
	top: 0;
	position: fixed;
	z-index: 12;
	height: 50px;
	border-bottom: solid 1px #333;
}
#header.shrink h1 a img {
	height: 56px;
	margin: -10px 0 0 50px;
}
#header.shrink #menu {
	margin: -5px 0 0 0;
}
#header.shrink #logos, #header.shrink #lang {
	display: none;
}
@media only screen and (min-width: 640px) {
#header {
	height: 50px;
}
#header h1 a img {
	max-width: 100%;
	margin: -10px 0 0 140px;
}
}
@media only screen and (min-width: 960px) {
#header {
	height: 130px;
}
#header h1 a img {
	margin: 50px 0 0 0;
}
#header.shrink h1 a img {
	margin: -10px 0 0 0;
}
}
@media only screen and (min-width: 1200px) {
#header {
	height: 150px;
}
}
#resp-menu-btn {
	position: absolute;
	top: 15px;
	left: 10px;
    display: block;
	width: 40px;
	height: 40px;
	color: #333;
  	cursor: pointer;
	z-index: 1000;
}
@media only screen and (min-width: 960px) {
#resp-menu-btn {
	display: none;
}
}
#resp-menu-btn span, #resp-menu-btn span:before, #resp-menu-btn span:after {
  	cursor: pointer;
  	border-radius: 1px;
 	height: 5px;
  	width: 35px;
  	background: #333;
  	position: absolute;
  	display: block;
  	content: '';
}
#resp-menu-btn span:before {
  	top: -10px; 
}
#resp-menu-btn span:after {
  	bottom: -10px;
}
#resp-menu-btn span, #resp-menu-btn span:before, #resp-menu-btn span:after {
	-webkit-transition: all 500ms ease-in-out;
	transition: all 500ms ease-in-out;
}
#resp-menu-btn.active span {
	background-color: transparent;
}
#resp-menu-btn.active span:before, #resp-menu-btn.active span:after {
	top: 0;
}
#resp-menu-btn.active span:before {
	-webkit-transform: rotate(45deg);
	        transform: rotate(45deg);
}
#resp-menu-btn.active span:after {
	-webkit-transform: rotate(-45deg);
	        transform: rotate(-45deg);
}
#menu {
	display: none;
}
@media only screen and (min-width: 960px) {
#menu {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: -js-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
	-webkit-box-pack: justify;
	    -ms-flex-pack: justify;
	        justify-content: space-between;
	margin: 75px 0 0 0;
}
#menu li {
	list-style: none;
	line-height: 20px;
    font-family: 'Oswald';
	font-weight: 400;
	font-size: 1em;
	text-transform: uppercase;
}
#menu li a {
	display: inline-block;
	color: #333;
	padding: 10px;
}
#menu li.current_page_item a {
	color: #00a4ef;
}
#menu li a:hover {
	color: #00a4ef;
	border-bottom: solid 4px #00a4ef;
}
#menu li.page-item-23 a {
	color: #fff;
	background: #00a4ef;
	border: solid 1px #00a4ef;
}
#menu li.page-item-23 a:hover {
	color: #00a4ef;
	background: #fff;
	border: solid 1px #00a4ef;
}
#menu li.page-item-25 a {
	color: #fff;
	background: #333;
	border: solid 1px #333;
}
#menu li.page-item-25 a:hover {
	color: #333;
	background: #fff;
	border: solid 1px #333;
}
}
@media only screen and (min-width: 1200px) {
#menu {
	margin: 90px 0 0 0;
}
#menu li {
	font-size: 1.25em;
}
}
/************************************************/
/*** Logos **************************************/
/************************************************/
#logos {
	position: absolute;
	top: 0;
	right: 2%;
}
#logos img {
	max-height: 20px;
	width: auto;
	padding: 0 0 0 15px;
}
@media only screen and (min-width: 640px) {
#logos img {
	max-height: 30px;
}
}
@media only screen and (min-width: 1200px) {
#logos {
	right: 0;
}
#logos img {
	max-height: 40px;
}
}
/************************************************/
/*** Lang ***************************************/
/************************************************/
#lang {
	position: absolute;
	top: 0;
	left: 60px;
}
@media only screen and (min-width: 640px) {
#lang {
	top: 5px;
}
}
@media only screen and (min-width: 960px) {
#lang {
	top: 0;
	left: 2%;
}
}
@media only screen and (min-width: 1200px) {
#lang {
	left: 0;
}
}
#lang ul {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: -js-flexbox;
	display: flex;
}
#lang ul li {
	list-style: none;
	margin: 0 10px 0 0;
    font-family: 'Oswald';
	font-weight: 400;
	font-size: 1em;
}
#lang ul li a {
	display: inline-block;
	color: #333;
}
#lang ul li a:hover {
	color: #00a4ef;
	border-bottom: solid 2px #00a4ef;
}
/************************************************/
/*** Book ***************************************/
/************************************************/
#book {
	display: none;
}
@media only screen and (min-width: 640px) {
#book {
	display: block;
	position: relative;
	margin: 0 auto;
	background: #333;
	height: 40px;
	z-index: 11;
	padding: 20px 0;
}
#book label {
	line-height: 40px;
	color: #fff;
	font-size: 1em;
}
#book input, #book select {
	width: 100%; 
	padding: 0.75%;
	height: 40px;
	border: 1px solid #fff;
	color: #fff;
	background: #333;
    font-family: 'Oswald';
	font-weight: 300;
	font-size: 1em;
    position: relative;
    z-index: 9999;
}
#book input {
	height: 35px;
	width: 98.25%; 
}
#book .button {
	width: 100%; 
	height: 40px;
	color: #fff;
	font-size: 1.25em;
	text-decoration: none;
	cursor: pointer;
	text-transform: uppercase;
}
#book .button:hover {
	background: #00a4ef;
	border: 0;
}
#book .button:active {
	top: 1px;
}
}
@media only screen and (min-width: 960px) {
#book label {
	font-size: 1.25em;
}
}
/************************************************/
/*** Content ************************************/
/************************************************/
.content {
    margin: 40px auto;
}
.content h2 {
    font-family: 'Pinyon Script', cursive;
	font-size: 4em;
	margin: 20px 0;
	color: #00a4ef;
	text-shadow: 0 0 10px #fef9c1, 0 0 20px #fef9c1, 0 0 30px #fef9c1, 0 0 40px #fef9c1, 1px 1px 2px #fef9c1;
}
.content h2 a {
	color: #00a4ef;
}
.content h3 {
    font-family: 'Pinyon Script', cursive;
	font-size: 3em;
	margin: 0 0 0.5em 0;
	color: #00a4ef;
}
.content p {
	color: #333;
	font-size: 1.25em;
	line-height: 1.25em;
	padding: 0 0 1em 0;
}
.content p a {
	color: #333;
	text-decoration: underline;
}
.content p a:hover {
	color: #00a4ef;
}
.content ul {
	padding: 0 0 0.875em 0;
}
.content li {
	color: #333;
	font-size: 1.25em;
	line-height: 1.25em;
	padding: 0 0 0 0;
	list-style: inside;
}
.content iframe {
	width: 100%;
	border: 0;
}
.content iframe#booking-form {
	min-height: 1800px;
	overflow: hidden;
}
.content iframe#skipass {
    min-height: 1210px;
    overflow: hidden;
}
.grid h4 {
    font-family: 'Oswald';
	font-weight: 400;
	font-size: 2em;
	margin: -0.125em 0 1em 0;
	color: #00a4ef;
	text-transform: uppercase;
}
.grid a h4 {
	background: #00a4ef;
	color: #fff;
	padding: 0.325em 0.5em;
}
.grid a:hover h4 {
	color: #fef9c1;
}
/************************************************/
/*** Silver stripe ******************************/
/************************************************/
.stripe {
    display: none;
}
@media only screen and (min-width: 640px) {
.stripe {
    display: block;
	background: #333;
	padding: 30px 0 50px 0;
	margin: 0 0 -20px 0;
}
.icons {
	color: #fff;
    display: block;
    text-align: center;
	padding: 30px 0;
}
.icons:hover {
	color: #00a4ef;
}
.icons p {
	margin: 0.5em 0 0 0;
    font-family: 'Oswald';
	font-weight: 400;
	font-size: 0.5em;
}
}
@media only screen and (min-width: 960px) {
.icons p {
	font-size: 0.75em;
}
}
/************************************************/
/*** Gallery ************************************/
/************************************************/
.ngg-galleryoverview {
	display: -webkit-box;
	display: -webkit-flex;
	display: -ms-flexbox;
	display: -js-flexbox;
	display: flex;
	-webkit-flex-wrap: wrap;
	    -ms-flex-wrap: wrap;
	        flex-wrap: wrap;
	margin: 0 -1%;		
}
.ngg-gallery-thumbnail-box {
	min-width: 0;
	padding: 5px 1%;
	-webkit-flex-basis: 48%;
	    -ms-flex-preferred-size: 48%;
	        flex-basis: 48%;
}
@media only screen and (min-width: 640px) {
.ngg-gallery-thumbnail-box {
	-webkit-flex-basis: 23%;
	    -ms-flex-preferred-size: 23%;
	        flex-basis: 23%;
}
}
@media only screen and (min-width: 960px) {
.ngg-gallery-thumbnail-box {
	padding: 10px 1%;
	-webkit-flex-basis: 14.666667%;
	    -ms-flex-preferred-size: 14.666667%;
	        flex-basis: 14.666667%;
}
}
.ngg-gallery-thumbnail img {
	max-width: 100%;
	height: auto;
	background: #fff;
	-webkit-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
.ngg-gallery-thumbnail img:hover {
	border-radius: 50%;
	-webkit-transform: rotate(360deg);
	transform: rotate(360deg);
}
.ngg-clear {
	clear: both;
}
/************************************************/
/*** Tables *************************************/
/************************************************/
table {
	width: 100%;
	margin: 20px 0 40px 0;
	text-align: center;
    border-collapse: collapse;
}
table.table, table.table td, table.table th {
	border: 1px solid #333;
}
table td, table th {
	padding: 0.625em;
	font-size: 1.25em;
}
table.table th {
	background: #00a4ef;
	color: #fff;
}
table.table td {
	color: #333;
}
/************************************************/
/*** Google map *********************************/
/************************************************/
#google-map {
	margin: 0 auto;
	width: 100%;
	height: 50em;
	color: #333;
}
#google-map img {
	max-width: none;
}
#info-window {
	width: 150px;
	height: 40px;
}
#google-map h3 {
    font-family: 'Oswald';
	font-weight: 400;
	font-size: 2em;
	color: #00a4ef;
}
#directions {
	margin: 20px 0 0 0;
}
#panel {
	width: 100%;
	padding: 20px 0 0 0;
}
#panel img {
	max-width: none;
}
#panel table {
	width: 100%;
	font-size: 1em;
	color: #333;
}
#panel table, #panel table td, #panel table th {
	border: 1px solid #333;
}
div.pac-item {
	color: #333;
}
table.adp-placemark, table.adp-directions {
	margin: 0;
}
table.adp-placemark, table.adp-placemark td {
	border-top: 0 !important;
}
table#adp-placemark, table#adp-placemark td {
	border: 1px solid #333 !important;
}
table.adp-placemark td {
	background: #00a4ef;
}
td.adp-text {
	background: #00a4ef;
	color: #fff;
	padding: 0 0 0 10px;
    font-weight: normal;
	font-size: 1.25em;
	text-align: left;
}
div.adp-summary {
	background: #80d2f7;
	color: #333;
	padding: 20px 10px;
	border-left: 1px solid #333;
	border-right: 1px solid #333;
    font-weight: normal;
	font-size: 1.25em;
}
td.adp-substep {
	background: #fff;
	color: #333;
	padding: 10px !important;
	border-top: 0 !important;
	font-size: 1em;
	text-align: left;
}
div.adp-legal {
	display: none !important;
}
/************************************************/
/*** Forms **************************************/
/************************************************/
.content label {
	text-transform: uppercase;
	color: #333;
}
.content label a {
	color: #333;
}
.content input, .content textarea {
	width: 98.5%; 
	padding: 0.75%;
	margin: 10px 0 20px 0;
	border: 1px solid #333;
    font-family: 'Oswald';
	font-weight: 300;
	color: #333;
	font-size: 1.25em;
}
@media only screen and (min-width: 960px) {
.content input, .content textarea {
	margin: 10px 0 30px 0;
}
}
@media only screen and (min-width: 1200px) {
.content input, .content textarea {
	margin: 10px 0 40px 0;
}
}
.content input[type="checkbox"] {
	margin: 7px 10px 40px 0;
	width: 15px; 
}
.content textarea {
	height: 140px;
	overflow: hidden;
}
.content .button {
	width: 100%; 
	padding: 0.75%;
	position: relative;
	margin: 10px 0 40px 0;
	color: #fff;
	background: #00a4ef;
	border: 0;
	font-size: 1.5em;
    font-weight: normal;
	text-decoration: none;
	cursor: pointer;
	text-transform: uppercase;
}
.content .button:hover {
	background: #333;
}
.content .button:active {
	top: 1px;
}
.content span.error {
	font-size: 1.25em;
	display: block;
	color: #ff0000;
}
#privacy {
	display: none;
	margin: 40px 0;
}
#privacy p {
	font-size: 1em;
}
/************************************************/
/*** Footer *************************************/
/************************************************/
#footer {
	background: #00a4ef;
	padding: 30px 0;
}
#footer p {
	color: #fff;
	font-size: 1.25em;
	text-align: center;
	padding: 1em 0 0 0;
}
#footer p small {
	font-size: 0.75em;
}
#footer p a {
	color: #fff;
	text-decoration: underline;
}
#footer p a:hover {
	color: #333;
}
/************************************************/
/*** Cookie bar *********************************/
/************************************************/
#cookieChoiceInfo {
	color: #fff; 
	background: #00a4ef !important; 
	height: auto; 
	min-height: 32px; 
	line-height: 32px; 
	padding: 6px 0 !important;
}
#cookieChoiceInfo a {
	color: #333; 
	background: #fff;
	padding: 3px 6px; 
	margin-left: 10px !important;
}
#cookieChoiceInfo a:hover {
	color: #fff; 
	background: #333;
}