/*
Theme Name:  Jampaa
Theme URI: https://www.jampaa.it/
Description:  Tema Jampaa
Author:  Jampaa
Author URI: https://www.jampaa.it/
Template:  hello-elementor
Version:  1.0.3
*/

/*
*	Root
*	1.0 SETTINGS
        *fonts
        *boxes
        *buttons
*   2.0 HEADER
*   3.0 HOME
*   4.0 CAMERE
*   5.0 FOOTER
*   6.0 REVIEWS
*   7.0 CONTATTI
*   8.0 BOOKING FORM
*   9.0 FORM NEWSLETTER
*   10.0 COSY MOODS
*/


/*
*	Root
*/
@font-face {
    font-family: 'Opificio';
    src: url('https://cosymoods.promoservicebeta.com/wp-content/themes/jampaa/fonts/Opificio.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
}

.nunito-sans-font {
  font-family: "Nunito Sans", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}

:root {
    /* Font family */
    --font-family-primary: 'Opificio', sans-serif;
    --font-family-secondary: 'Nunito Sans', sans-serif;
    --font-family-menu: 'Nunito Sans', sans-serif;
    --font-family-buttons: 'Nunito Sans', sans-serif;
    /* Colors */
    --color-black: #000000;
    --color-white: #FFFFFF;
    --color-primary: #231F20;
    --color-secondary: #F4F1EE;
    --color-tertiary: #0F7C7D;
    --color-tertiary-dark: #035F60;
    --color-menu: #fff;
    --color-menu-scroll: #231F20;
    /* H1 - 48px */
    --colore-h1: #fff;
    --font-size-h1: clamp(48px, 5vw, 64px);
    --font-weight-h1: 400;
    /* H2 - 36px */
    --colore-h2: #231F20;
    --font-size-h2: clamp(30px, 4vw, 48px);
    --font-weight-h2: 400;
    /* H3 - 28px */
    --colore-h3: #231F20;
    --font-size-h3: clamp(28px, 3.5vw, 34px);
    --font-weight-h3: 400;
    /* H4 - 24px */
    --colore-h4: #231F20;
    --font-size-h4: clamp(24px, 3vw, 24px);
    --font-weight-h4: 400;
    /* Paragraphs & Span */
    --colore-p: #231F20;
    --font-size-p-l: clamp(18px, 2vw, 21px);   /* Large */
    --font-size-p-r: clamp(16px, 2vw, 18px);    /* Regular */
    --font-size-p-s: clamp(15px, 2vw, 16px);    /* Small */
    --font-size-p-xs: clamp(13px, 2vw, 14px);    /* Extra-small */
    --font-weight-p-l: 400;
    --font-weight-p-r: 400;
    --font-weight-p-s: 400;
    --font-weight-p-xs: 400;
    --colore-span: #231F20;
    --font-size-span: clamp(15px, 1.8vw, 18px);
    --font-weight-span: 400;
    /* Link */
    --colore-a: var(--color-tertiary);
    --font-size-a: clamp(16px, 1.8vw, 18px);
    --font-weight-a: 700;
    /* Menu Desktop */
    --colore-voce-menu: var(--color-menu);
    --font-size-menu: clamp(16px, 2vw, 18px);
    --font-weight-menu: 700;
    /* Pulsanti bianco-verde */
    --colore-button-primary: var(--color-white);
    --colore-button-hover: var(--color-tertiary);
    --font-button: clamp(16px, 2vw, 18px);
    --font-weight-button: 600;
    --line-height-button: clamp(24px, 2vw, 28px);
    /* Pulsanti verde-verde scuro */
    --colore-button-primary: var(--color-tertiary);
    --colore-button-hover: var(--color-tertiary-dark);
    --font-button: clamp(16px, 2vw, 18px);
    --font-weight-button: 600;
    --line-height-button: clamp(24px, 2vw, 28px);
    /* Pulsanti bianco bordo verde - verde */
    --colore-button-primary: var(--color-white);
    --colore-button-hover: var(--color-tertiary);
    --color-border: var(--color-tertiary);
    --font-button: clamp(16px, 2vw, 18px);
    --font-weight-button: 600;
    --line-height-button: clamp(24px, 2vw, 28px);
}


/*
*	1.0 SETTINGS
*/
/*fonts*/
h1 {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h1) !important;
    font-weight: var(--font-weight-h1) !important;
    line-height: normal !important;
    color: var(--colore-h1) !important;
}

h2 {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h2) !important;
    font-weight: var(--font-weight-h2) !important;
    line-height: normal !important;
    color: var(--colore-h2) !important;
}

.font-h1 h2 {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h2) !important;
    font-weight: var(--font-weight-h2) !important;
    line-height: normal !important;
    color: var(--colore-h2) !important;
}

h3 {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h3) !important;
    font-weight: var(--font-weight-h3) !important;
    line-height: normal !important;
    color: var(--colore-h3) !important;
}

h4 {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h4) !important;
    font-weight: var(--font-weight-h4) !important;
    line-height: normal !important;
    color: var(--colore-h4) !important;
}

p {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-r) !important;
    font-weight: var(--font-weight-p-r) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

p.paragraph-l {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-l) !important;
    font-weight: var(--font-weight-p-l) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

p.paragraph-r {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-r) !important;
    font-weight: var(--font-weight-p-r) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

p.paragraph-s {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-s) !important;
    font-weight: var(--font-weight-p-s) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

p.paragraph-xs {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-xs) !important;
    font-weight: var(--font-weight-p-xs) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

.pre-titolo p {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-r) !important;
    font-weight: var(--font-weight-p-r) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
    letter-spacing: 0.5px;
}

span {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-span) !important;
    font-weight: var(--font-weight-span) !important;
    line-height: 1.6 !important;
    color: var(--colore-span) !important;
}

a {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-a) !important;
    font-weight: var(--font-weight-a) !important;
    line-height: 1.6 !important;
    color: var(--colore-a) !important;
    text-decoration: none !important;
}

a.js-wpml-ls-item-toggle.wpml-ls-item-toggle span {
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-l) !important;
    font-weight: var(--font-weight-menu) !important;
    line-height: 1.75 !important;
    color: var(--colore-p) !important;
}

#menu-principale a {
    font-family: var(--font-family-menu) !important;
    font-size: var(--font-size-menu) !important;
    font-weight: var(--font-weight-menu) !important;
    line-height: 1.6 !important;
    /*color: var(--colore-voce-menu) !important;*/
    text-decoration: none !important;
    text-transform: uppercase;
    background: transparent !important;
}

p.iubenda-cs-preferences-link {
    margin: 0px;
    font-family: var(--font-family-secondary) !important;
    font-size: var(--font-size-p-m) !important;
    font-weight: var(--font-weight-p-l) !important;
    line-height: 1.75 !important;
    color: var(--colore-a) !important;
}

.sottotitolo-home span {
    font-size: clamp(24px, 5vw, 32px) !important;
    color: var(--color-white) !important;
}

.post-footer span, .post-footer a {
    font-size: var(--font-size-p-m) !important;
}

.testo-troncato-4 p {
    display: -webkit-box;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 4; /* Limita a 4 righe */
    overflow: hidden;
    text-overflow: ellipsis;
}

.font-primary h1, .font-primary h2, .font-primary h3, .font-primary h4, .font-primary h5, .font-primary p, .font-primary span, .font-primary a {
    font-family: var(--font-family-primary) !important;
}

.titolo-tabs-camere a {
    font-size: var(--font-size-h3) !important;
    font-weight: 400 !important;
}

/*boxes*/
div#full-width-box {
    max-width: 2100px !important;
    margin: auto !important;
}

/*color classes*/
.black {
    color: var(--color-black);
}
.white, .white h1, .white h2, .white h3, .white h4, .white h5, .white p, .white span, .white a {
    color: var(--color-white) !important;
}
.color-primary {
    color: var(--color-primary);
}
.color-secondary {
    color: var(--color-secondary);
}
.color-tertiary, .color-tertiary h1, .color-tertiary h2, .color-tertiary h3, .color-tertiary h4, .color-tertiary h5, .color-tertiary p, .color-tertiary span, .color-tertiary a {
    color: var(--color-tertiary) !important;
}
.color-tertiary-dark {
    color: var(--color-tertiary-dark);
}

/*buttons*/
.button-white a {
    background: var(--color-white) !important;
    border-radius: 0px 30px 0px 0px;
    padding: 15px 40px;
}
.button-white a span {
    font-weight: 700 !important;
    color: var(--color-tertiary) !important;
}
.button-white:hover a {
    background: var(--color-tertiary) !important;
    border-radius: 0px 30px 0px 0px;
}
.button-white:hover a span {
    font-weight: 700 !important;
    color: var(--color-white) !important;
}

.button-white-border a {
    background: var(--color-white) !important;
    border-radius: 0px 30px 0px 0px;
    padding: 15px 40px;
    border-style: solid;
    border-color: var(--color-tertiary);
}
.button-white-border a span {
    font-weight: 700 !important;
    color: var(--color-tertiary) !important;
}
.button-white-border:hover a {
    background: var(--color-tertiary) !important;
    border-radius: 0px 30px 0px 0px;
    border-color: var(--color-tertiary);   
}
.button-white-border:hover a span {
    font-weight: 700 !important;
    color: var(--color-white) !important;
}

.button-green a {
    background: var(--color-tertiary) !important;
    border-radius: 0px 30px 0px 0px;
    padding: 15px 40px;
}
.button-green a span {
    font-weight: 700 !important;
    color: var(--color-white) !important;
}
.button-green:hover a {
    background: var(--color-tertiary-dark) !important;
    border-radius: 0px 30px 0px 0px;
}
.button-green:hover a span {
    font-weight: 700 !important;
    color: var(--color-white) !important;
}

button#button-form span {
    color: white !important;
    font-weight: 700 !important;
}


/*
*	2.0 HEADER
*/
.wpml-elementor-ls {
    width: 70px;
}

div#menu-principale a:after {
    background-color: white;
    height: 2px;
    width: 100%;
}

div#menu-principale a {
    padding: 0px 0px 3px 0px;
    text-transform: capitalize;
}

#menu-principale ul {
    gap: 30px;
}

.hide {
    display: none;
}

#slide-3 {
    background-color: #F4F1EE;
}

#header-desktop #menu-principale .elementor-item {
  color: #fff !important;
  transition: color .25s ease;
}

#header-desktop.menu-dark #menu-principale .elementor-item {
  color: #231F20 !important;
}

.menu-dark #menu-principale a:after {
    background-color: #231F20;
    height: 2px;
    width: 100%;
}

#header-desktop {
  background-color: transparent;
  transition: background-color .3s ease, color .3s ease;
}

#header-desktop.scrolled {
  background-color: #F4F1EE;
}

#header-desktop.scrolled #menu-principale .elementor-item {
  color: #231F20 !important;
}

#header-desktop.scrolled div#menu-principale a:after {
    background-color: #231F20;
    height: 2px;
    width: 100%;
}

body:not(.home) .scrolled img {
    width: 100px !important;
}


/*
*   3.0 HOME
*/
.scroll-section {
  position: relative !important;
  height: calc(100svh - var(--header-h, 0px)) !important;
  height: calc(100vh - var(--header-h, 0px)) !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}

.scroll-section .img-sfondo { 
  position: absolute !important; 
  inset: 0 !important; 
  z-index: 0 !important;
}

.scroll-section .img-sfondo img {
  width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center !important;
  display: block !important;
}

.scroll-section > :not(.img-sfondo) {
  position: relative !important;
  z-index: 1 !important;
}

.scroll-section > *:not(.img-sfondo) {
  position: relative !important;
  z-index: 1;
}

body.home footer#site-footer {
    display: none;
}

div#slide-6 {
    gap: 40px;
    display: flex !important;
    justify-content: center !important;
    flex-direction: column;
    align-items: center !important;
}

div#slide-7 {
    display: none !important;
}

div#slide-8 {
    display: none !important;
}

div#slide-10 {
    display: none !important;
}

.carosello-img img {
    height: 620px !important;
    width: 100%;
    object-fit: cover;
    object-position: center;
}

.container-punteggio-home {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    width: 100%;
}

.container-punteggio-home i {
    font-size: 30px;
    color: #009598B2;
    margin-right: 20px;
}

span.span-posizione {
    font-size: 50px !important;
    font-weight: 400 !important;
    color: #009598B2 !important;
    margin-right: 5px;
    font-family: var(--font-family-primary) !important;
}

span.span-punteggio-posizione {
    font-size: 63px !important;
    margin-bottom: 15px;
    color: #009598B2 !important;
    font-family: var(--font-family-primary) !important;
}

.grid-home {
    display: grid;
    grid-template-columns: repeat(8, 1fr);
    grid-template-rows: repeat(8, 1fr);
    gap: 10px;
    height: 550px;
}

img.cell-1 {
    height: 100% !important;
    object-fit: cover;
    object-position: center;
    width: 100% !important;
    grid-column-start: 2;
    grid-column-end: 5;
    grid-row-start: 1;
    grid-row-end: 4;
}

img.cell-2 {
    grid-column-start: 5;
    grid-column-end: 9;
    grid-row-start: 1;
    grid-row-end: 6;
    height: 100% !important;
    object-fit: cover;
    object-position: center;
}

img.cell-3 {
    object-fit: cover;
    object-position: center;
    grid-column-start: 1;
    grid-column-end: 5;
    grid-row-start: 4;
    grid-row-end: 9 !important;
    height: 100% !important;
}

img.cell-4 {
    object-fit: cover;
    object-position: center;
    grid-column-start: 5;
    grid-column-end: 8;
    grid-row-start: 6;
    grid-row-end: 9;
    height: 100% !important;
    width: 100% !important;
}

.grid-home img {
    width: 100%;
}

.carosello-home-1 {
    width: 80% !important;
}

i.fa-solid.fa-star.stella-valutazione-rec {
    margin-left: 5px;
}

.link-camera-hover {
    position: absolute !important;
    bottom: 180px;
    display: none;
}

.swiper-slide:hover .link-camera-hover, .apartments:hover .link-camera-hover {
    display: block;
}

.link-camera-hover a {
    color: white !important;
    font-weight: 400 !important;
    text-decoration: underline !important;
    text-underline-offset: 6px;
}

.recensione .e-con-inner {
    display: flex;
    justify-content: center !important;
}


/*
*   4.0 CAMERE
*/
.label-brown.label-rooms {
    background: #553D24;
    color: white;
    padding: 10px 10px;
    gap: 10px;
}

.label-red.label-rooms {
    background: #A83C2E;
    color: white;
    padding: 10px 10px;
    gap: 10px;
}

.label-green.label-rooms {
    background: #3A4935 !important;
    color: white;
    padding: 10px 10px;
    gap: 10px;
}

.label-blue.label-rooms {
    background: #0A2F44;
    color: white;
    padding: 10px 10px;
    gap: 10px;
}

.container-orari-apertura span {
    text-align: right;
}

.icona-tab i{
    color: #231F20 !important;
}

.carosello-img-room img {
    width: 100% !important;
    height: 450px !important;
    object-fit: cover;
    object-position: center;
}

.evidenza div, .evidenza i, .evidenza p, .evidenza li {
    color: var(--color-tertiary) !important;
    font-weight: 600 !important;
}

li.item-servizio {
    display: flex;
    align-items: center;
    gap: 10px;
}

.full-link h3 a, .full-link h3, .full-link {
    font-family: var(--font-family-primary) !important;
    font-size: var(--font-size-h3) !important;
    font-weight: var(--font-weight-h3) !important;
    width: 100% !important;
    height: 100%;
    display: flex;
    justify-content: center;
    align-content: center;
    align-items: center;
}

.img-preview-room a {
    width: 100% !important;
}

/*
*   5.0 FOOTER
*/
.elementor-field-type-acceptance {
    display: flex !important;
    flex-direction: column-reverse;
    align-items: flex-start !important;
    align-content: flex-start !important;
    flex-wrap: nowrap !important;
}

.bottom-bar a {
    justify-content: center !important;
}

.whatsapp-button a {
    font-size: 40px !important;
}


/*
*   8.0 BOOKING FORM
*/
.by-beddy-bar-ui__container {
    background-color: transparent !important;
}

div#sb-container_sb__form {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: 1fr;
    column-gap: 15px;
    align-items: center;
}

.sb__dates {
    grid-column-start: 1;
    grid-column-end: 3;
    width: 100% !important;
    display: flex;
    gap: 15px;
}

.sb__footer-actions {
    display: flex;
    flex-direction: row;
}

.sb__guests-rooms {
    width: 100% !important;
    padding: 0px !important;
}

input#sb-container_sb__form-field--checkavailability {
    width: 100% !important;
}

a#bfPreventivo {
    width: 100%;
    height: 100% !important;
    vertical-align: middle;
    display: flex;
    align-content: center;
    align-items: center;
    color: #0F7C7D !important;
    border-style: solid;
    border-width: 2px;
    justify-content: center;
    text-transform: uppercase;
    font-weight: 800 !important;
}

.sb__btn--verify {
    font-size: 16px !important;
    height: 56px !important;
    padding: 16px 8px !important;
}

.sb__form-field-input {
    padding: 16px !important;
    height: 56px !important;
}

.sb__footer-actions {
    width: 100% !important;
    float: right !important;
    gap: 10px;
}

.sb__footer-promo-wrapper {
    float: left !important;
    position: relative !important;
    width: auto !important;
}

.sb__footer-link--promo {
    float: left;
    text-align: left;
}

.sb__footer-link--edit {
    float: right;
    text-align: left;
    width: fit-content !important;
}

.sb__footer-link {
    width: 100%;
    text-align: center;
    font-size: 11px;
    text-decoration: none;
    margin-top: 16px;
    float: left;
    clear: both;
    text-align: left !important;
}

.sb__form-field-input {
    height: fit-content !important;
}

span.sb__form-field-weekday {
    display: none !important;
}

.sb__form-field-date-wrapper {
    display: flex;
    gap: 40px;
}

#sb-container_sb__form-field--guests span.sb__form-field-date-number {
    position: absolute;
    left: 90px;
}

.sb__footer {
    display: none;
}

input#sb-container_sb__form-field--checkavailability {
    background: #0F7C7D !important;
    color: white !important;
    text-transform: uppercase;
    font-weight: 700 !important;
}

#sb-container .sb-custom-bg-color {
    border-radius: 10px;
    box-shadow: 0 0 8px 0px #000000b3;
}

div#booking-form span {
    font-weight: 800 !important;
    font-size: 17px;
}

div#booking-form span.sb__form-field-label.sb-custom-label-color {
    font-weight: 400 !important;
    margin-bottom: 0px;
    margin-left: 15px;
    font-size: 15px !important;
}

.sb__guests-rooms {
    margin-top: 0px !important;
}

input#sb-container_sb__form-field--checkavailability {
    margin: 0px;
}

.sb.sb-custom-color.sb-custom-bg-color.sb-direction-ltr {
    padding-top: 10px !important;
    padding-bottom: 8px !important;
    padding-left: 30px;
    padding-right: 30px;
}

body #booking-form input#sb-container_sb__form-field--checkavailability {
    color: white !important;
    height: 100% !important;
    border-radius: 0px;
}

body .booking-form-container .site-booking-form.sticky #booking-form input#sb-container_sb__form-field--checkavailability {
    color: #0F7C7D !important;
}

body .booking-form-container .site-booking-form.sticky #booking-form .sb-custom-button-color {
    color: #0F7C7D !important;
    border-radius: 0px !important;
    height: 100% !important;
    min-height: 50px;
    background: white !important;
}

.sb__form-field-input {
    padding: 5px 15px !important;
}

.sb__guests-rooms {
    margin-top: 0px !important;
}

body .booking-form-container .site-booking-form.sticky #booking-form .sb.sb-custom-color.sb-custom-bg-color.sb-direction-ltr {
    background-color: #009598 !important;
}


/*
*   9.0 FORM NEWSLETTER
*/
.gform_heading h2 {
    display: none !important;
}

div#gform_fields_1 {
    gap: 20px;
}

form#gform_1 {
    display: flex;
    align-items: center;
    width: 100% !important;
    justify-content: center;
}

form#gform_1 .gform-footer.gform_footer.top_label {
    margin: 0px;
}

form#gform_1 {
    display: flex;
    align-items: flex-start;
    width: 100% !important;
    justify-content: center;
    gap: 15px;
    flex-direction: row;
}

input#gform_submit_button_1 {
    width: 200px;
    height: 50px;
    font-size: 20px;
    text-transform: uppercase;
    background: var(--color-tertiary);
    font-weight: 600;
}

.ginput_container.ginput_container_email input {
    height: 50px !important;
    font-size: 16px !important;
    color: #4A4A4A !important;
    width: 100% !important;
}

span#psnewsShort {
    font-size: 14px !important;
}

h2.gform_submission_error.hide_summary {
    font-size: 18px !important;
}

/*
*   10.0 COSY MOODS
*/
.vertical-slider-1 img.slide-image:nth-child(2) {
    object-fit: cover;
    object-position: bottom;
}

