@charset "UTF-8";

/*
Theme Name: Jampaa
Theme URI: https://www.jampaa.it
Description: Jampaa theme
Author: Promoservice
Author URI: https://www.promoservice.com
Template: twentytwentyone
Version: 3.3.9
*/

/*
*   1.0 Header
*       1.1 Menu
*       1.2 Booking form
*       1.3 Widget Userway
*       1.4 Pre Header
*   2.0 Content
*       2.1 Home
*       2.2 Single room
*       2.3 404
*       2.4 All rooms
*           2.4.1 Table price
*       2.5 Internal pages
*       2.6 Single offer
*   3.0 Footer
*   4.0 Rooms list container
*   5.0 Offers list container
*   6.0 Reviews list container
*   7.0 Sliders
*   8.0 Booking form
*   9.0 Contacts
*   10.0 Comparatore
*   11.0 Services rating
*   12.0 Custom gallery
*   13.0 Gallery
*   14.0 Breadcrumbs
*   15.0 Single box
*   16.0 Sharing buttons
*   17.0 Energy saver
*   18.0 Thank you page
*   19.0 DMS AI Page
*   20.0 Keplero Chat
*   21.0 ImageMap Pro
*   22.0 Ricerca Conversazionale
*   23.0 FAQS Open Rosetta
*   24.0 Landing
*   25.0 Authors page
*   26.0 Banner Cross Channel
*/

:root {
    font-size: 10px;
    line-height: 10px;

    --responsive--alignwide-width: 100%;
    --global--font-primary: 'Reem Kufi', sans-serif;
    --global--font-secondary: 'Open Sans', sans-serif;

    --global--font-size-base: 1.6rem;
    --global--font-line-height-base: 2.6rem;
    --global--font-weight-base: normal;

    --global--letter-spacing: normal;

    --global--font-size-xs: 1.2rem;
    --global--font-size-sm: 1.4rem;
    --global--font-size-md: 1.8rem;
    --global--font-size-lg: 2.4rem;
    --global--font-size-xl: 3rem;
    --global--font-size-xxl: 4rem;
    --global--font-size-xxxl: 6rem;
    --global--font-size-page-title: var(--global--font-size-xxl);

    --heading--font-family: var(--global--font-primary);
    --heading--font-size-h6: var(--global--font-size-xs);
    --heading--font-size-h5: var(--global--font-size-sm);
    --heading--font-size-h4: var(--global--font-size-md);
    --heading--font-size-h3: var(--global--font-size-lg);
    --heading--font-size-h2: var(--global--font-size-xl);
    --heading--font-size-h1: var(--global--font-size-page-title);

    --heading--line-height-h6: 2rem;
    --heading--line-height-h5: 2.2rem;
    --heading--line-height-h4: 2.6rem;
    --heading--line-height-h3: 3rem;
    --heading--line-height-h2: 3.6rem;
    --heading--line-height-h1: 5.2rem;

    --heading--font-weight: 400;

    --heading--letter-spacing-h6: normal;
    --heading--letter-spacing-h5: 0.2rem;
    --heading--letter-spacing-h4: 0.2rem;
    --heading--letter-spacing-h3: normal;
    --heading--letter-spacing-h2: normal;
    --heading--letter-spacing-h1: normal;

    /* Line Height */
    --global--line-height-body: var(--global--font-line-height-base);

    /* Colors */
    --link-color: #6DA6D0;
    --link-color-hover: #358BC9;
    --global--color-primary: #333333;
    --booking-color: #2B71BC;
    --booking-color-hover: #17569A;

    --htv-blue: #202446;
    --htv-blue-2: #173A68;

    /* Spacing */
    --global--spacing-unit: 0;
    --global--spacing-measure: unset;
    --global--spacing-horizontal: 0;
    --global--spacing-vertical: 0;
}

:root body {
    overflow-x: hidden;
}

html,
body {
    scroll-behavior: smooth;
}

body h1,
body h2,
body h3,
body h4,
body h5,
body h6 {
    margin-bottom: 2rem;
}

body h2 {
    color: var(--htv-blue);
    text-transform: uppercase;
}

body h1.boxed,
body h2.boxed {
    text-align: center;
    background-color: #F6F7F8;
    padding: 5rem 10rem;
    margin: -4rem auto 3rem;
    justify-self: center;
    border-radius: 1rem 1rem 0 0;
    min-width: 70rem;
}

body h2.boxed {
    margin-top: -6rem;
}

body a,
body a:active,
body a:focus,
body a:visited,
body.has-background-white .site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    text-decoration: none !important;
    color: var(--link-color);
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    font-weight: bold;
    letter-spacing: 0.1rem;
    background: none;
}

body a:hover,
body .color-accent-hover:hover {
    color: var(--link-color-hover);
}

body a.link,
body a.link:active,
body a.link:focus,
body a.link:visited,
body.has-background-white .site a.link:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    margin: 1rem auto 1rem 0;
}

body a.link::after,
body a.link:active::after,
body a.link:focus::after,
body a.link:visited::after,
body.has-background-white .site a.link:focus:not(.wp-block-button__link):not(.wp-block-file__button)::after {
    content: "\f178";
    font-family: "Font Awesome 5 Pro";
    font-weight: 300;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    margin-left: 1.5rem;
}

body a.btn,
body a.btn:active,
body a.btn:focus,
body a.btn:visited,
body .entry-content a.btn,
body .entry-content a.btn:active,
body .entry-content a.btn:focus,
body .entry-content a.btn:visited,
body button:not(.toggle),
body .button,
body input[type="button"]:not(.toggle),
body input[type="reset"]:not(.toggle),
body input[type="submit"]:not(.toggle),
body.has-background-white .site a.btn:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    font-style: normal;
    font-family: var(--global--font-secondary);
    font-weight: 400;
    font-size: 1.6rem;
    text-align: center;
    background: var(--link-color);
    background-color: var(--link-color);
    color: #ffffff;
    letter-spacing: 0.1rem;
    margin: 0 auto;
    max-width: unset !important;
    width: auto !important;
    display: flex;
    align-items: center;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    text-decoration: none !important;
    border: 0.1rem solid var(--link-color);
    padding: 1rem 2rem !important;
    border-radius: 0.4rem;
    text-transform: uppercase;
    outline: none;
}

body a.btn:hover,
body .entry-content a.btn:hover,
body button:hover,
body .button:hover,
body input[type="button"]:hover,
body input[type="reset"]:hover,
body input[type="submit"]:hover {
    background: var(--link-color-hover);
    background-color: var(--link-color-hover);
    border: 0.1rem solid var(--link-color-hover);
}

body a.btn,
body .entry-content a.btn {
    margin: 1.5rem auto 1.5rem 0 !important;
}

body a.btn::after,
body .entry-content a.btn::after {
    content: "\f178";
    font-family: "Font Awesome 5 Pro";
    font-weight: 300;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    margin-left: 1.5rem;
}

body a.btn.btn-center,
body .entry-content a.btn.btn-center {
    margin-left: auto !important;
    margin-right: auto !important;
}

body li.btn-booking a,
body li.btn-booking a:active,
body li.btn-booking a:focus,
body li.btn-booking a:visited,
body a.btn-booking,
body a.btn-booking:active,
body a.btn-booking:focus,
body a.btn-booking:visited,
body .entry-content a.btn-booking,
body .entry-content a.btn-booking:active,
body .entry-content a.btn-booking:focus,
body .entry-content a.btn-booking:visited,
body.has-background-white .site a.btn-booking:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    font-style: normal;
    font-family: var(--global--font-secondary);
    font-weight: bold;
    font-size: 1.4rem;
    text-align: center;
    background: var(--booking-color);
    background-color: var(--booking-color);
    color: #ffffff;
    letter-spacing: 0.05rem;
    padding: 1rem 2rem !important;
    border-radius: 0.4rem;
    margin: 2rem auto 2rem 0;
    max-width: unset !important;
    width: auto !important;
    display: inline-flex;
    align-items: center;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
    text-decoration: none !important;
    border: 0.1rem solid var(--booking-color);
}

body a.btn-booking:hover,
body .entry-content a.btn-booking:hover {
    background: var(--booking-color-hover);
    background-color: var(--booking-color-hover);
    border-color: var(--booking-color-hover);
}

body,
body p,
body .entry-content p {
    font-size: var(--global--font-size-base);
    line-height: var(--global--font-line-height-base);
    font-weight: var(--global--font-weight-base);
}

body p,
body .entry-content p {
    margin-bottom: 1.5rem;
}

body div#page {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    grid-template-areas:
        "header header header header header header header header header header header header"
        "content content content content content content content content content content content content"
        "footer footer footer footer footer footer footer footer footer footer footer footer";
}

body .site .button:focus,
body input[type=submit]:focus,
body input[type=reset]:focus,
body .wp-block-search__button:focus,
body .wp-block-button .wp-block-button__link:focus,
body.has-background-white .site a:focus:not(.wp-block-button__link):not(.wp-block-file__button),
body .site a:focus:not(.wp-block-button__link):not(.wp-block-file__button) img,
body .site a:focus,
body input[type=checkbox]:focus,
body .swiper-button-next:focus,
.swiper-button-prev:focus {
    outline: none;
}

body .post-thumbnail,
body .entry-content .wp-audio-shortcode,
body .entry-content>*:not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.wp-block-separator):not(.woocommerce),
body *[class*=inner-container]>*:not(.entry-content):not(.alignwide):not(.alignfull):not(.alignleft):not(.alignright):not(.wp-block-separator):not(.woocommerce),
body .default-max-width {
    margin-left: unset;
    margin-right: unset;
}

hr.wp-block-separator {
    background: #8A93A7;
    height: 0.2rem;
    width: 4.2rem;
    border: 0;
    margin: 0;
    margin-bottom: 2rem;
}

body figure.full-width {
    margin: 0;
    height: 100%;
    width: 100%;
}

body figure.full-width img,
body video.full-width {
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
    max-height: -webkit-fill-available;
}

body .rooms-list-container-single-img figure.full-width img {
    height: 100%;
    width: 100%;
}

body ul {
    padding-left: 3rem;
}

/*
*   1.0 Header
*/
span.icon-plus:before, span.icon-minus:before {
    display: none;
}
header#masthead.site-header {
    position: fixed;
    top: 0;
    left: 0;
    right: 0;
    z-index: 101;
    grid-area: header;
    padding: 0;
    align-items: stretch;
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    background: transparent;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

header#masthead.site-header .site-branding {
    grid-row: 2;
    grid-column: 1;
    margin: 0;
    padding: 3.5rem;
    align-items: center;
    display: flex;
    justify-content: center;
    flex-direction: column;
    text-align: center;
    background: var(--htv-blue);
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

header#masthead.site-header.sticky .site-branding {
    padding: 1rem 2rem;
}

header#masthead.site-header .site-branding .site-logo svg {
    max-width: 18.7rem;
    margin: auto;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

header#masthead.site-header.sticky .site-branding .site-logo svg {
    max-width: 10rem;
}

header#masthead.site-header .primary-navigation {
    align-items: center;
    display: flex;
    margin-left: 0;
    padding: 0;
    margin: 0;
    grid-row: 2;
    grid-column: -1;
    justify-content: flex-end;
}

header#masthead.site-header .primary-navigation .menu-button-container {
    border-radius: 0 0 0 1rem;
    position: relative;
    display: flex;
    justify-content: center;
    align-items: center;
    padding: 4rem 3rem;
    align-self: start;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

body:not(.primary-navigation-open) header#masthead.site-header .primary-navigation .menu-button-container {
    background: var(--htv-blue);
}

header#masthead.site-header.sticky .primary-navigation .menu-button-container {
    padding: 2rem 2rem;
}

.menu-button-container #primary-mobile-menu,
.menu-button-container #primary-mobile-menu .dropdown-icon.close,
.menu-button-container #primary-mobile-menu .dropdown-icon.close svg,
.menu-button-container #primary-mobile-menu .dropdown-icon.close svg path {
    color: #fff !important;
}

.menu-button-container #primary-mobile-menu .dropdown-icon.close,
.menu-button-container #primary-mobile-menu .dropdown-icon.close svg,
.menu-button-container #primary-mobile-menu .dropdown-icon.close svg path {
    color: #333 !important;
}

.ca_review--btnDetails,
.ca_review--btnDetails:focus,
.ca_review--btnDetails:active,
.ca_review--btnDetails:visited {
    border-radius: 0px !important;
    background-color: #6dacd2 !important;
    border: none !important;
    text-transform: uppercase !important;
    font-size: 0.8em !important;
    letter-spacing: 2px !important;
    padding-top: 8px !important;
    font-weight: bold !important;
}

.ca_review--btnDetails:hover {
    background-color: #3681b0 !important;
}

.read-more+[data-readmore-toggle] {
    font-weight: bold;
}

.read-more+[data-readmore-toggle],
.read-more[data-readmore] {
    display: block;
    width: 100%;
}

.read-more[data-readmore] {
    transition: height 75ms;
    overflow: hidden;
}

body.primary-navigation-open iframe[id^=QReviewWidget] {
    display: noen !important;
    visibility: hidden !important;
}

/*
*   1.1 Menu
*/
header#masthead.site-header .primary-navigation .toggle-inner .toggle-icon {
    transform: rotate(0);
    width: 3.2rem;
    height: 2.5rem;
    position: relative;
    transition: .5s ease-in-out;
    cursor: pointer;
    display: block;
    margin-bottom: 0.5rem;
}

header#masthead.site-header .primary-navigation .toggle-inner .toggle-icon span {
    background: #ffffff;
    display: block;
    position: absolute;
    height: 0.3rem;
    width: 100%;
    border-radius: 0.9rem;
    opacity: 1;
    left: 0;
    transition: .25s ease-in-out;
}

header#masthead.site-header .primary-navigation .toggle-inner .toggle-icon span:first-child {
    transition: top .3s cubic-bezier(.47, 0, .75, .72), transform .6s ease-in-out;
    top: 0;
    width: 2.4rem;
}

header#masthead.site-header .primary-navigation .toggle-inner .toggle-icon span:nth-child(2) {
    top: 1.1rem;
}

header#masthead.site-header .primary-navigation .toggle-inner .toggle-icon span:nth-child(3) {
    top: 2.2rem;
    width: 2.4rem;
}

.primary-navigation-open .primary-navigation>.primary-menu-container {
    height: 100vh;
    overflow-x: hidden;
    overflow-y: auto;
    border: 2px solid transparent;
    padding-top: 13rem;
}

.primary-navigation>div>.menu-wrapper {
    padding-bottom: 100px;
    padding-left: 0;
}

.primary-navigation-open .primary-navigation {
    width: 100%;
    position: fixed;
}

.menu-button-container {
    display: block;
}

.primary-navigation>.primary-menu-container {
    visibility: hidden;
    opacity: 0;
    position: fixed;
    padding-top: calc(var(--button--line-height) * var(--primary-nav--font-size-button) + 42px + 5px);
    padding-left: var(--global--spacing-unit);
    padding-right: var(--global--spacing-unit);
    padding-bottom: var(--global--spacing-horizontal);
    background-color: var(--global--color-background);
    transition: all 0.15s ease-in-out;
    transform: translateY(var(--global--spacing-vertical));
}

body:not(.primary-navigation-open) #site-navigation.primary-navigation {
    position: relative;
}

body.primary-navigation-open #site-navigation.primary-navigation {
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    margin: 0;
}

body.primary-navigation-open #site-navigation.primary-navigation .menu-button-container {
    top: 0;
}

body.primary-navigation-open #site-navigation.primary-navigation #primary-mobile-menu {
    margin: 0 0 0 auto;
}

.primary-navigation>div>.menu-wrapper li,
.primary-navigation>div>.menu-wrapper li a {
    width: 100%;
}

.primary-navigation>div>.menu-wrapper li,
.primary-navigation>div>.menu-wrapper li {
    text-align: left;
}

.primary-navigation>div>.menu-wrapper li,
.primary-navigation>div>.menu-wrapper li a {
    font-size: 2rem !important;
    padding: 0.5rem 0;
}

/* START menu fix */
.primary-navigation .primary-menu-container>ul>.menu-item {
    width: 100%;
    display: block;
    margin: 0.55rem 0;
    text-align: left;
}

.primary-navigation .primary-menu-container>ul>.menu-item>a {
    display: inline !important;
}

.primary-navigation>.primary-menu-container>.menu-wrapper>li>button.sub-menu-toggle,
.primary-navigation .primary-menu-container button.sub-menu-toggle {
    margin: 0 0 0 1rem !important;
    padding: 0 !important;
    display: inline !important;
    background: #fff;
    color: var(--global--color-primary);
    border: 0 !important;
}

header#masthead.site-header .primary-navigation a {
    justify-content: center;
}

.primary-navigation>.primary-menu-container>.menu-wrapper>li>button.sub-menu-toggle:after,
.primary-navigation .primary-menu-container button.sub-menu-toggle:after {
    display: none !important;
    visibility: hidden !important;
}

.primary-navigation>.primary-menu-container ul>li .sub-menu-toggle[aria-expanded=false]~ul {
    display: none;
}

.primary-navigation>.primary-menu-container ul>li .sub-menu-toggle[aria-expanded=true]~ul {
    display: block;
}

.primary-navigation>div>.menu-wrapper>li {
    padding-top: 0.55rem !important;
    padding-bottom: 0.55rem !important;
}

.primary-navigation>div>.menu-wrapper>li>.sub-menu {
    position: relative;
    top: 0;
    border: none;
}

header#masthead.site-header .primary-navigation li.wpml-ls-menu-item.menu-item-has-children,
body.lock-scrolling .menu-button-container .menu-mobile-widget {
    display: none !important;
    visibility: hidden !important;
}

.primary-navigation>div>.menu-wrapper>li {
    padding-left: 3rem;
}

.primary-navigation>div>.menu-wrapper ul {
    padding-top: 1rem;
    padding-left: 1.5rem;
}

/* FINISH menu fix */
.primary-navigation>div>.menu-wrapper>li>.sub-menu:before,
.primary-navigation>div>.menu-wrapper>li>.sub-menu:after {
    display: none !important;
    visibility: hidden !important;
}

.primary-navigation>div>.menu-wrapper .sub-menu-toggle:focus {
    outline: none !important;
}

/* START language menu selector */
.menu-mobile-widget {
    right: 8rem;
    align-items: center;
    display: flex
}

.menu-mobile-widget .wpml-ls-legacy-dropdown {
    width: auto
}

.menu-mobile-widget .wpml-ls-legacy-dropdown a {
    background-color: transparent;
    border: 0;
    color: #fff !important;
    font-weight: 700;
    font-size: 1.4rem
}

.menu-mobile-widget .wpml-ls-legacy-dropdown a:hover,
.menu-mobile-widget .wpml-ls-legacy-dropdown a:focus,
.menu-mobile-widget .wpml-ls-legacy-dropdown a:active {
    color: #fff !important
}

.menu-mobile-widget .wpml-ls-legacy-dropdown a.wpml-ls-item-toggle:after {
    content: "\f0d7";
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    border: 0;
    top: unset;
    right: 1rem
}

header#masthead.site-header .primary-navigation .wpml-ls a {
    padding: 1rem 2.5rem
}

.menu-mobile-widget .wpml-ls-legacy-dropdown .wpml-ls-sub-menu a {
    padding-top: 15px;
    padding-bottom: 5px;
    background: var(--htv-blue) !important
}

.menu-mobile-widget .wpml-ls-legacy-dropdown .wpml-ls-sub-menu {
    border: 0
}

.menu-mobile-widget .wpml-ls-legacy-dropdown .wpml-ls-sub-menu span {
    white-space: nowrap !important;
}

.menu-mobile-widget {
    border-right: 1px solid #fff
}

.wpml-ls-legacy-dropdown .wpml-ls-current-language:hover>a,
.wpml-ls-legacy-dropdown a:focus,
.wpml-ls-legacy-dropdown a:hover {
    background: var(--htv-blue) !important;
}

/* FINISH language menu selector */


/* Menù highlighted voice */
.highlighted-menu a {
    background: #358bc9;
    color: white !important;
}

.highlighted-menu a:active {
    background: #2b71bc;
}

.highlighted-menu a:focus {
    background: #2b71bc !important;
}

/*
*   1.2 Booking form
*/
header#masthead.site-header .site-booking-form {
    grid-row: 2;
    grid-column: 2 / -2;
    font-size: 1.4rem;
    font-weight: 600;
    line-height: 1.9rem;
    max-width: 100rem;
}

header#masthead.site-header .site-booking-form i {
    margin-right: 0.5rem;
}

header#masthead.site-header .site-booking-form .site-booking-form-pre {
    padding: 1.4rem;
    background-color: #F5BC41;
}

header#masthead.site-header .site-booking-form .site-booking-form-post {
    background-color: #ffffff;
    padding: 1.4rem;
    display: inline-flex;
    width: 100%;
    gap: 5rem;
    border-radius: 0 0 1rem 0;
}

header#masthead.site-header .site-booking-form .site-booking-form-post a,
header#masthead.site-header .site-booking-form .site-booking-form-post a:active,
header#masthead.site-header .site-booking-form .site-booking-form-post a:focus,
header#masthead.site-header .site-booking-form .site-booking-form-post a:visited {
    color: #27AE60;
}

header#masthead.site-header .site-booking-form .site-booking-form-post a:hover {
    color: #27AE60;
}

header#masthead.site-header .site-booking-form .booking-form {
    background-color: #F5BC41;
}

header#masthead.site-header .site-booking-form .booking-form div.sb {
    box-shadow: none;
    padding: 0 0.5rem 1rem !important;
}

header#masthead.site-header .site-booking-form .booking-form #sb-container_sb__form-field--checkin span.sb__form-field-label,
header#masthead.site-header .site-booking-form .booking-form #sb-container_sb__form-field--checkout span.sb__form-field-label {
    display: none;
}

#booking-form div.sb__form div.sb__dates>* {
    margin-top: 0 !important;
}

#booking-form div.sb__form div.sb__guests-rooms {
    margin-top: 0 !important;
}

#booking-form .sb__guests-rooms .sb__form-field .sb__guests {
    width: auto !important;
}

#booking-form .sb__guests-rooms .sb__form-field .sb__guests button.sb__guests-add-room {
    padding: 0 1rem 0 2.5rem !important;
    margin-left: 2rem;
}

#booking-form .sb__guests-rooms .sb__panel-actions {
    display: flex;
    gap: 1rem;
    justify-content: center;
    align-items: center;
}

#booking-form .sb__guests-rooms .sb__panel-actions button {
    padding: 1rem 1.5rem !important;
    line-height: 1.5rem;
}

@media (max-width: 1380px) {

    .sb__form-field-weekday,
    .sb__form-field-date-wrapper .sb__form-field-weekday,
    .sb-screen-s .sb__form-field-weekday {
        display: none !important;
        visibility: hidden !important;
    }

    .sb__form-field-icon,
    .sb-screen-s .sb__form-field-icon {
        display: none !important;
        visibility: hidden !important;
    }
}

/*
* 1.3 Widget Userway
*/
.userway_buttons_wrapper {
    top: 50% !important;
}

/*
*   1.4 Pre Header
*/

header.site-header .pre-header {
    background-color: #173A68;
    color: #ffffff;
    font-size: 13px;
    line-height: 24px;
    padding: 10px 30px;
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 3rem;
    grid-column-start: 1;
    grid-column-end: inherit;
    grid-row-start: 1;
    grid-row-end: 1;
}

header.site-header .pre-header>a,
header.site-header .pre-header>a:active,
header.site-header .pre-header>a:focus,
header.site-header .pre-header>a:visited {
    color: var(--booking-color);
}

header.site-header .pre-header>a:hover {
    color: var(--booking-color-hover);
}

header.site-header .pre-header .pre-header-start-chat {
    display: flex;
    justify-content: flex-end;
    align-items: stretch;
    width: unset;
    max-width: 80rem;
    position: relative;
}

header.site-header .pre-header .pre-header-start-chat i.fa-search {
    position: absolute;
    color: #888888;
    top: 11px;
    left: 12px;
    z-index: 1;
    bottom: auto;
    font-size: 18px;
}

header.site-header .pre-header .pre-header-start-chat input#start-chat-input {
    padding: 10px 200px 10px 40px;
    border-radius: 70px 70px 70px 70px;
    border: none;
    outline: none;
}

header.site-header .pre-header .pre-header-start-chat button#start-chat-button {
    margin: 0;
    padding: 8px 15px;
    border-radius: 70px 70px 70px 70px;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: nowrap;
    text-wrap-mode: nowrap;
    gap: 5px;
    position: absolute;
    top: 0;
    bottom: 0;
    height: 100%;
    right: -1px;
    left: auto;
    background-color: #6DA6D0;
    border:none;
}

header.site-header .pre-header .pre-header-start-chat button#start-chat-button svg {
    width: 25px;
}
header.site-header .pre-header .pre-header-start-chat button#start-chat-button svg path{
    fill:#F5BC41;
}

header.site-header .pre-header .pre-header-contacts {
    text-align: right;
}

body.showing-menu-modal header.site-header .pre-header,
header.site-header.sticky .pre-header {
    display: none;
}


@media (max-width: 767px) {
    header.site-header {
        flex-direction: column-reverse;
        display: flex;
    }

    header.site-header .pre-header {
        text-align: center;
        padding: 10px;
    }

    header.site-header .pre-header .pre-header-contacts {
        display: none;
    }
    
    
}

/*
*   2.0 Content
*/
body div#page>div.site-content,
body div#page :not(.pricecomparison-section-bkg)>div.site-content {
    grid-area: content;
    min-height: 80vh;
}

body.singular .entry-header {
    padding: 0;
    border: 0;
    height: 55rem;
    position: relative;
}

body.singular .entry-header.entry-header-custom {
    height: auto;
}

body.singular .entry-header img {
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
}

body .entry-content .entry-content-title {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    background-color: #F6F7F8;
}

body .entry-content .entry-content-title h1 {
    grid-column: 2 / -2;
    padding-bottom: 2rem;
    text-transform: uppercase;
    color: var(--htv-blue);
    z-index: 5;
}

body .entry-content .entry-content-title h2 {
    grid-column: 2 / -2;
    text-align: center;
}

.entry-content .grids-section .grids-s-w_i {
    padding-top: 2rem;
    padding-bottom: 2rem;
}


.image-boxed-blue h2,
.image-boxed-blue p {
    color: #ffffff;
}

.image-boxed-blue hr {
    margin-left: auto;
    margin-right: auto;
    background: #ffffff;
}

.entry-content .image-boxed-blue.grids-section>.grids-s-w_i {
    color: #ffffff;
    padding: 7rem 0;
}

.image-boxed-blue>.grids-s-w_i::after {
    content: "";
    display: block;
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    background-repeat: no-repeat;
    background-position-x: 50%;
    background-position-y: 50%;
    background-size: auto;
    background-attachment: scroll;
    background: rgba(23, 58, 104, 0.7);
    backdrop-filter: blur(5px);
}

.image-boxed-blue>.grids-s-w_i .grids-area {
    z-index: 1;
}

.three-anchors-wrapper>.grids-s-w_i,
.four-anchors-wrapper>.grids-s-w_i {
    display: grid !important;
    grid-template-columns: repeat(3, 1fr) !important;
    grid-template-rows: auto !important;
    gap: 5rem !important;
}

.four-anchors-wrapper>.grids-s-w_i {
    grid-template-columns: repeat(4, 1fr) !important;
}

.three-anchors-wrapper.inline-boxes>.grids-s-w_i,
.four-anchors-wrapper.inline-boxes>.grids-s-w_i {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    grid-template-rows: auto !important;
    gap: 5rem !important;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper {
    grid-column: auto !important;
    grid-row: 1 !important;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure {
    max-height: 30rem;
    margin: 0;
    height: 100%;
    width: 100%;
}

.three-anchors-wrapper.ingr-indiv>.grids-s-w_i>.single-anchor-wrapper figure {
    max-height: unset;
    margin: 0;
    height: 100%;
    width: 100%;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure a,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure a {
    display: unset;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure img,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper figure img {
    border-radius: 1rem;
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
    max-height: -webkit-fill-available;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3 {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(0deg, rgba(32, 36, 70, 0.6) 0%, rgba(32, 36, 70, 0) 100%);
    margin: 0;
    padding: 3rem;
    color: #ffffff;
    border-radius: 0 0 1rem 1rem;
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3::before,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3::before {
    content: "";
    position: absolute;
    height: 2px;
    border-bottom: 2px solid white;
    top: -7px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3::after,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3::after {
    content: "";
    position: absolute;
    height: 2px;
    bottom: 0px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    background-color: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -o-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -moz-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -webkit-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -ms-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
}

.three-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3 a,
.four-anchors-wrapper>.grids-s-w_i>.single-anchor-wrapper h3 a {
    color: #FFF !important;
}

.grids-area.single-anchor-wrapper.below {
    grid-row: inherit !important;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i {
    display: grid !important;
    grid-template-columns: repeat(4, 1fr) !important;
    grid-template-rows: auto !important;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.left {
    padding-right: 1rem;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.right {
    padding-left: 1rem;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .description-card-onhover-expand {
    padding: 3rem !important;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .image-card-onhover-expand {
    z-index: 1;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .description-card-onhover-expand {
    z-index: 2;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.left>.grids-s-w_i .image-card-onhover-expand {
    grid-column: 3/5;
    grid-row: 1;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.left>.grids-s-w_i .description-card-onhover-expand {
    grid-column: 2/5;
    grid-row: 1;
    -webkit-transition: 1s ease-in-out;
    -moz-transition: 1s ease-in-out;
    -o-transition: 1s ease-in-out;
    transition: 1s ease-in-out;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.right>.grids-s-w_i .image-card-onhover-expand {
    grid-column: 1/3;
    grid-row: 1;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand.right>.grids-s-w_i .description-card-onhover-expand {
    grid-column: 1/4;
    grid-row: 1;
    -webkit-transition: 1s ease-in-out;
    -moz-transition: 1s ease-in-out;
    -o-transition: 1s ease-in-out;
    transition: 1s ease-in-out;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .image-card-onhover-expand .wp-block-image,
.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .image-card-onhover-expand .wp-block-image figure {
    margin: 0 !important;
    padding: 0 !important;
}

.cards-wrapper-onhover-expand .single-card-onhover-expand>.grids-s-w_i .image-card-onhover-expand img {
    max-height: 45rem;
    min-height: 45rem;
    width: auto;
    opacity: 0.3;
    -webkit-transition: 1s ease-in-out;
    -moz-transition: 1s ease-in-out;
    -o-transition: 1s ease-in-out;
    transition: 1s ease-in-out;
}

.btn.btn-newsletter,
.btn.btn-newsletter:active,
.btn.btn-newsletter:visited {
    background: var(--link-color) !important;
    background-color: var(--link-color) !important;
}

.btn.btn-newsletter:hover,
.btn.btn-newsletter:focus {
    background: var(--link-color-hover) !important;
    background-color: var(--link-color-hover) !important;
}

form.form-bonus-terme input[type=text],
form.form-bonus-terme input[type=email],
form.form-bonus-terme input[type=number],
form.form-bonus-terme input[type=text],
form.form-bonus-terme input[type=url],
form.form-bonus-terme select {
    background: transparent !important;
    border: 2px solid rgba(51, 51, 51, 0.5) !important;
    margin-left: 0 !important;
    outline: none !important;
}

ul.rientro-elenco,
ol.rientro-elenco {
    padding-inline-start: 6rem !important;
}

.mx-auto,
.btn.mx-auto,
.entry-content .mx-auto,
.entry-content .btn.mx-auto,
body .entry-content .mx-auto,
body .entry-content .btn.mx-auto {
    margin-left: auto !important;
    margin-right: auto !important;
}

span.label {
    display: flex;
    flex-flow: row;
    align-items: center;
    gap: 1rem;
}

/*
*   2.1 Home
*/
#slider-home {
    min-height: 40rem;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    position: relative;
}

body.home #esperienza-benessere {
    padding: 5rem 0;
}

body.home #esperienza-benessere>.grids-s-w_i {
    gap: 0 5rem;
}

body.home #esperienza-benessere .services ul {
    list-style: none;
}

body.home #esperienza-benessere .services:not(.services-blue) ul {
    columns: 2;
}

body.home #esperienza-benessere .services ul li {
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
}

body.home #esperienza-benessere .services ul li i {
    margin-right: 1rem;
    font-size: 2rem;
    width: 3rem;
    text-align: center;
}

body.home #esperienza-benessere .services:not(.services-blue) ul li i {
    color: #8A93A7;
}

body.home #esperienza-benessere .services.services-blue ul li a {
    width: 100%;
    max-width: 15.5rem;
    display: flex;
    align-items: center;
}

body.home #esperienza-benessere .services.services-blue ul li a i.fa-long-arrow-right {
    margin: 0 0 0 auto;
}

body.home #piscina-cibo {
    padding: 5rem 5rem;
}

body.home #piscina-cibo>.grids-s-w_i {
    gap: 0 2rem;
}

body.home #piscina-cibo>.grids-s-w_i>.grids-area {
    position: relative;
    filter: drop-shadow(0px 2px 20px rgba(138, 147, 167, 0.3));
}

body.home #piscina-cibo>.grids-s-w_i>.grids-area .content {
    position: absolute;
    bottom: 0;
    top: auto;
    left: 0;
    right: 0;
    height: 10.5rem;
    overflow: hidden;

    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

body.home #piscina-cibo>.grids-s-w_i>.grids-area:hover .content {
    height: 60%;
}

body.home #piscina-cibo>.grids-s-w_i>.grids-area .content>.grids-s-w_i {
    background: rgba(255, 255, 255, 0.8);
    backdrop-filter: blur(0.4rem);
    border-radius: 1rem 1rem 0 0;
    padding: 2rem;
    min-height: 440px;
}

@media (max-width: 1600px) {
    body.home #piscina-cibo>.grids-s-w_i>.grids-area .content>.grids-s-w_i {
        min-height: 350px !important;
    }

    body.home #piscina-cibo>.grids-s-w_i>.grids-area:hover .content {
        height: 80% !important;
    }
}

body.home #piscina-cibo h2,
body.home #piscina-cibo h2 a {
    color: var(--htv-blue) !important;
}

body.home #row-camere {
    padding: 5rem 10rem;
    overflow: hidden;
    max-width: 100vw;
}

body.home #row-trattamenti {
    padding: 5rem 10rem;
}

body.home #row-trattamenti>.grids-s-w_i {
    gap: 2rem 2rem;
}

body.home #row-trattamenti .treatment-column div.title {
    position: relative;
}

body.home #row-trattamenti .treatment-column div.title figure {
    /*max-height: 40rem;*/
}

body.home #row-trattamenti .treatment-column div.title figure img {
    border-radius: 1rem;
}

body.home #row-trattamenti .treatment-column div.title h3 {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(0deg, rgba(32, 36, 70, 0.6) 0%, rgba(32, 36, 70, 0) 100%);
    margin: 0;
    padding: 3rem;
    color: #ffffff;
    border-radius: 0 0 1rem 1rem;
}

body.home #row-trattamenti .treatment-column div.title h3 a,
body.home #row-trattamenti .treatment-column div.title h3 a:active,
body.home #row-trattamenti .treatment-column div.title h3 a:focus,
body.home #row-trattamenti .treatment-column div.title h3 a:visited {
    color: #ffffff;
    font-weight: 400;
}

body.home #row-trattamenti .treatment-column div.title h3 a:hover {
    color: var(--link-color-hover);
}

body.home #row-trattamenti .treatment-column div.title h3:before {
    content: "";
    position: absolute;
    height: 2px;
    border-bottom: 2px solid white;
    top: -7px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

body.home #row-trattamenti .treatment-column div.title h3:after {
    content: "";
    position: absolute;
    height: 2px;
    bottom: 0px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    background-color: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -o-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -moz-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -webkit-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -ms-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
}

body.home #row-trattamenti .treatment-column div.content {
    margin-top: 4rem;
}

body.home #staff {
    padding: 5rem 10rem;
}

body.home #staff h2,
body.home #staff h3 {
    color: var(--htv-blue-2) !important;
}

body.home #staff>.grids-s-w_i {
    gap: 0 2rem;
}

body.home #staff .riccardo-panzarini figure {
    max-height: 66rem;
}

body.home #staff .riccardo-panzarini figure img {
    border-radius: 0 0 15rem;
}

body.home #staff .single-staff-member figure {
    margin-bottom: 0 !important;
    height: 100px !important;
    width: 100px !important;
    display: flex;
    align-self: center;
}

/* Start viaggi green */
.viaggi-green-banner {
    padding: 2rem;
    border: 2px solid #000;
    box-sizing: border-box;
    border-radius: 10px;
    display: flex;
    gap: 5rem;
    margin: 4rem auto;
}

.viaggi-green-banner .icon-green img {
    max-height: 120px;
    width: auto;
}

.content-green h3.title-green {
    font-size: 24px;
    line-height: 130%;
    text-transform: uppercase;
    color: #288836;
    margin-bottom: 1rem;
}

.content-green .wrapper-content {
    font-weight: normal;
    font-size: 18px;
    line-height: 28px;
}

.content-green a.btn-readmore-green {
    font-weight: bold;
    font-size: 16px;
    line-height: 130%;
    letter-spacing: 1px;
    text-transform: uppercase;
    color: #288836;
    width: fit-content;
    margin-left: auto;
    margin-right: 0;
}

.content-green a.btn-readmore-green:hover,
.content-green a.btn-readmore-green:active,
.content-green a.btn-readmore-green:focus {
    color: #288836;
}

.viaggi-green-banner .content-green {
    display: flex;
    flex-flow: column;
    width: 100%;
}

/* Finish viaggi green */
i.volume-icon {
    font-family: "Font Awesome 5 Pro" !important;
    font-weight: 900 !important;
    font-size: 30px;
    line-height: 30px;
    font-style: normal !important;
    cursor: pointer !important;
    background: #fff;
    color: var(--booking-color) !important;
    padding: 10px;
    border-radius: 100px;
}

i.volume-icon::before {
    content: "\f6a8" !important;
}

div.grids-section.box-activities>.grids-s-w_i {
    max-width: 100rem;
    width: 100%;
    border-radius: 10px;
    border: 1px solid #C4C4C4;
    background: #FFF;
    box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.25);
    margin: 5rem auto;
    text-align: center;
    padding: 2.5rem;
}

div.grids-section.box-activities>.grids-s-w_i i.icon {
    font-size: 2.5rem;
    color: #8A93A7;
    margin-bottom: 1rem;
}

div.grids-section.box-activities>.grids-s-w_i h2::after {
    content: "";
    width: 4.2rem;
    height: 0.2rem;
    background: #878A8F;
    display: block;
    margin: 2.5rem auto 0;
}

div.grids-section.box-activities>.grids-s-w_i h3 {
    margin-bottom: 1.5rem;
}

div.grids-section.box-activities>.grids-s-w_i div.wp-block-columns:has(:nth-child(3))>div.wp-block-column:nth-child(2) {
    padding-top: 5rem;
}

div.grids-section.box-activities>.grids-s-w_i div.wp-block-columns:has(:nth-child(4))>div.wp-block-column:nth-child(2),
div.grids-section.box-activities>.grids-s-w_i div.wp-block-columns:has(:nth-child(4))>div.wp-block-column:nth-child(3) {
    padding-top: 5rem;
}

.grids-section.hotel-services-list>.grids-s-w_i>.grids-area>.grids-section {
    width: 100%
}

.hotel-services-list div.grids-area {
    text-align: center
}

.hotel-services-list div.grids-area>h3 {
    text-align: center !important
}

.hotel-services-list div.grids-area>i {
    color: var(--link-color);
    font-size: 50px;
    margin-bottom: 15px
}

.hotel-services-list div.grids-area>ul {
    list-style: none;
    padding: 0;
    margin: 0
}

/*
*   2.2 Single room
*/
body.single-room .entry-content {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(12, 1fr);
    gap: 2.5rem 1rem;
    margin-top: 30rem;
}

body.single-room .entry-content hr {
    margin-bottom: 4rem;
    border-color: #AEAEAE;
}

body.single-room .entry-content .single-room-title {
    grid-row: 1;
    grid-column: 2 / -2;
    display: flex;
    align-items: center;
}

body.single-room .entry-content .single-room-title h1 {
    margin: 0;
}

body.single-room .entry-content .single-room-title .single-room-title-message {
    background: #5D7CFB;
    color: #ffffff;
    box-shadow: 0px 0.2rem 2rem rgba(138, 147, 167, 0.3);
    letter-spacing: 0.2rem;
    padding: 0.5rem 2rem;
    text-transform: uppercase;
    border-radius: 3rem;
    display: flex;
    align-items: center;
    margin-left: 4rem;
}

body.single-room .entry-content .single-room-title .single-room-title-message i {
    margin-right: 0.6rem;
    font-size: 1.5rem;
}

body.single-room .entry-content .single-room-title .single-room-title-price {
    margin: 0 0 0 auto;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 0 1rem rgba(138, 147, 167, 0.3);
    border-radius: 1rem;
    padding: 2rem 2rem;
    font-size: 1.4rem;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
    color: var(--htv-blue);
    display: flex;
    align-items: center;
}

body.single-room .entry-content .single-room-title .single-room-title-price span.price {
    margin-left: 1rem;
    font-family: var(--global--font-primary);
    font-size: 3.4rem;
    color: #27AE60;
    align-items: center;
    display: flex;
}

body.single-room .entry-content .single-room-title .single-room-title-price span.price i.fa-spinner {
    font-size: 1.6rem;
    color: #8A93A7;
}

body.single-room .entry-content .single-room-features {
    grid-row: 2;
    grid-column: 2 / -2;
    display: flex;
    padding: 0;
    margin: 0 !important;
    color: #8A93A7;
    align-items: center;
    border-bottom: 0.1rem solid #DCDFE5;
    gap: 0;
    padding-bottom: 2.5rem;
}

body.single-room .entry-content .single-room-features .feature-box {
    padding: 0 1.5rem;
    border-right: 0.1rem solid #DCDFE5;
    height: 100%;
}

body.single-room .entry-content .single-room-features .feature-box:first-of-type {
    padding-left: 0;
}

body.single-room .entry-content .single-room-features .feature-box:last-of-type {
    border-right: none;
}

body.single-room .entry-content .single-room-features .feature-box.feature-box-occupancy {
    display: flex;
    gap: 0 0.3rem;
    justify-content: center;
    align-items: center;
}

body.single-room .entry-content .single-room-features-evidence {
    grid-row: 3;
    grid-column: 2 / -2;
    display: flex;
    gap: 0;
    list-style: none;
    padding: 0;
    margin: 0;
}

body.single-room .entry-content .single-room-features-evidence li {
    display: flex;
    align-items: center;
    border-right: 0.1rem solid #DCDFE5;
    padding: 0 2rem;
}

body.single-room .entry-content .single-room-features-evidence li:first-of-type {
    padding-left: 0;
}

body.single-room .entry-content .single-room-features-evidence li:last-of-type {
    border-right: none;
}

body.single-room .entry-content .single-room-features-evidence li span.material-icons {
    color: #8A93A7;
    margin-right: 1rem;
}

body.single-room .entry-content .single-room-gallery {
    grid-row: 4;
    grid-column: 2 / -2;
    display: grid;
    grid-template-rows: repeat(2, 1fr);
    grid-template-columns: repeat(4, 1fr);
    grid-gap: 1.5rem;
    padding-bottom: 2rem;
    position: relative;
}

body.single-room .entry-content .single-room-gallery .single-room-gallery-single {
    cursor: pointer;
}

body.single-room .entry-content .single-room-gallery .single-room-gallery-single.single-room-gallery-single-0 {
    grid-column: 1 / 3;
    grid-row: 1 / 3;
}

body.single-room .entry-content .single-room-description {
    grid-row: 5;
    grid-column-start: 2;
    grid-column-end: 7;
    margin: 0;
}

body.single-room .entry-content .single-room-services {
    grid-row: 6;
    grid-column-start: 2;
    grid-column-end: 7;
}

body.single-room .entry-content .single-room-services ul {
    margin: 1em 0 0;
    list-style: none;
    column-count: 2;
    padding: 0;
}

body.single-room .entry-content .single-room-services ul li {
    margin: 0;
    display: flex;
    align-items: center;
    margin-bottom: 0.5em;
    justify-content: start;
    break-inside: avoid-column;
}

body.single-room .entry-content .single-room-services ul li.highlight-service {
    font-weight: bold !important;
    color: var(--booking-color) !important;
}

body.single-room .entry-content .single-room-services li span.material-icons {
    margin-right: 1rem;
    width: 3rem;
    text-align: center;
}


body.single-room .entry-content .single-room-booking {
    grid-row-start: 5;
    grid-row-end: 7;
    grid-column-start: 7;
    grid-column-end: 12;
}

body.single-room .entry-content .single-room-booking .single-room-booking-warning {
    border-radius: 1rem;
    background-color: #ECF3FE;
    max-width: 46rem;
    margin: 0 auto 2rem;
    padding: 2rem;
    color: #5D7CFB;
    font-weight: bold;
    font-style: italic;
    display: flex;
    justify-content: center;
    align-items: center;
}

body.single-room .entry-content .single-room-booking .single-room-booking-warning i {
    margin-right: 1.2rem;
    font-size: 2.6rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box {
    box-shadow: 0 0.2rem 2rem rgba(138, 147, 167, 0.3);
    border-radius: 1rem;
    background-color: #F5BC41;
    max-width: 46rem;
    margin: 0 auto;
    padding: 2rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-open {
    display: none;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-open i {
    margin-left: 1.5rem;
    font-size: 2.2rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content h2 {
    margin: 0 0 1.5rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-checkin-checkout {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(2, 1fr);
    margin-bottom: 1.5rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-checkin span.time,
body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-checkout span.time {
    font-weight: bold;
    margin-left: 1.5rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-checkout span.our-site {
    display: block;
    font-size: 1rem;
    line-height: 2rem;
    letter-spacing: 0.1rem;
    color: #2B71BC;
    font-weight: bold;
    text-transform: uppercase;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content hr {
    border-color: #ffffff;
    width: 100%;
    margin: 0 0 1.5rem;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-price {
    border-radius: 1rem;
    background-color: #ffffff;
    padding: 2rem;
    margin-bottom: 1.5rem;
    display: flex;
    align-items: center;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-price span.text {
    font-size: 1.4rem;
    letter-spacing: 0.1rem;
    text-transform: uppercase;
    color: var(--htv-blue);
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-price span.price {
    margin: 0 0 0 auto;
    font-family: var(--global--font-primary);
    font-size: 3.4rem;
    color: #27AE60;
    display: flex;
    align-items: center;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .single-room-booking-box-content-price span.price i.fa-spinner {
    font-size: 1.6rem;
    color: #8A93A7;
}

body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .btn-booking,
body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .btn-booking:active,
body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .btn-booking:focus,
body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .btn-booking:visited,
body.single-room .entry-content .single-room-booking .single-room-booking-box .single-room-booking-box-content .btn-booking:hover {
    margin: 0;
    width: 100% !important;
    justify-content: center;
}

body.single-room .entry-content .single-room-gallery figure.single-room-gallery-single,
body.single-room .entry-content .single-room-gallery figure.single-room-gallery-single img {
    border-radius: 1rem;
}

body.single-room .entry-content .single-room-gallery .single-rooms-gallery-wrapper-show-all {
    position: absolute;
    bottom: 1.5rem;
    right: 1.5rem;
    z-index: 10;
}

body.single-room .single-room-more {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(12, 1fr);
    gap: 4rem 1rem;
    margin-top: 4rem;
    padding: 4rem 0 4rem;
    background: #F8F8F8;
}

body.single-room .single-room-more h2 {
    grid-row: 1;
    grid-column-start: 2;
    grid-column-end: 12;
    margin: 0;
}

body.single-room .single-room-more .single-room-more-wrapper {
    grid-row: 3;
    grid-column-start: 2;
    grid-column-end: 12;
}

body.single-room .single-room-more .rooms-list-navigation {
    grid-row: 2;
    grid-column-start: 2;
    grid-column-end: 12;
    display: flex;
    justify-content: flex-end;
}

.single-icon i {
    font-size: 2.5rem;
    margin-right: 1rem;
}

.single-icon {
    padding: 1rem 0;
}

.single-pages-more {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(12, 1fr);
    gap: 4rem 1rem;
    padding: 4rem 0 4rem;
    background: #F8F8F8;
}

.single-pages-more h2 {
    grid-row: 1;
    grid-column-start: 2;
    grid-column-end: 12;
    margin: 0;
}

.single-pages-more .single-pages-more-wrapper {
    grid-row: 2;
    grid-column-start: 2;
    grid-column-end: 12;
}

.pages-list-container {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.pages-list-container.swiper-container-horizontal {
    overflow: hidden;
    padding: 2rem 3rem 5rem;
}

.pages-list-container:not(.swiper-container-horizontal) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(var(--pages-list-container-columns), 1fr);
    gap: 2rem;
}

.pages-list-container .pages-list-container-single {
    grid-column: auto;
    grid-row: auto;
}

.pages-list-container.swiper-container-horizontal .pages-list-container-single {
    max-width: 22rem;
    margin: 0 3rem 0 0;
}

.pages-list-container .pages-list-container-single .single-page-title {
    position: relative;
}

.pages-list-container .pages-list-container-single .single-page-title a figure,
.pages-list-container .pages-list-container-single .single-page-title a img {
    border-radius: 1rem;
}

.pages-list-container .pages-list-container-single .single-page-title a img {
    max-height: 30rem !important;
    min-height: 30rem !important;
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
}

.pages-list-container .pages-list-container-single .single-page-title h3 {
    position: absolute;
    bottom: 0;
    left: 0;
    right: 0;
    background: linear-gradient(0deg, rgba(32, 36, 70, 0.6) 0%, rgba(32, 36, 70, 0) 100%);
    margin: 0;
    padding: 3rem;
    border-radius: 0 0 1rem 1rem;
    text-transform: uppercase;
    color: #ffffff !important;
}

.pages-list-container .pages-list-container-single .single-page-title h3 a {
    color: #ffffff !important;
}

.pages-list-container .pages-list-container-single .single-page-title h3::before {
    content: "";
    position: absolute;
    height: 2px;
    border-bottom: 2px solid white;
    top: -7px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
}

.pages-list-container .pages-list-container-single .single-page-title h3::after {
    content: "";
    position: absolute;
    height: 2px;
    bottom: 0px;
    width: 50px;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    background-color: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -o-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -moz-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -webkit-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
    background-image: -ms-linear-gradient(left, #ffffff 50%, #4a4a4a 50%);
}

.pages-list-container .pages-list-container-single .single-page-content {
    padding: 2rem 0;
}


/*
*   2.3 404
*/
body.error404 .site-content .entry-content .content {
    margin-bottom: 2.5rem;
    background-color: #e4e4e4;
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 15rem 15rem 3rem;
}

body.error404 .site-content .entry-content .content .text {
    max-width: 62rem;
}

body.error404 .site-content .entry-content .content .text h1 {
    text-transform: uppercase;
}

body.error404 .site-content .entry-content .content .text a.btn {
    margin-right: auto !important;
    display: inline-flex !important;
}

body.error404 .site-content .entry-content .content .image img {
    max-height: 90rem;
    height: 100%;
    width: auto;
}

body.error404 .site-content .single-pages-more {
    background-color: transparent;
}

body.error404 .site-content .single-pages-more h2 {
    text-align: center;
}

/*
*   2.4 All rooms
*/
body .extra-services {
    background-color: var(--htv-blue-2);
    border-radius: 1rem;
    color: #ffffff;
    padding: 3rem !important;
}

body .extra-services h2 {
    color: #ffffff;
}

body .extra-services ul {
    list-style: none;
    -webkit-columns: 2;
    -moz-columns: 2;
    columns: 2;
    padding: 0;

    list-style-position: inside;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}

body .extra-services ul li {
    list-style-position: inside;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    margin-bottom: 2rem;
}

body .extra-services ul li i {
    margin-right: 1rem;
    display: inline-block;
    height: 100%;
}

body .extra-services ul li span.little {
    display: block;
    font-size: 1.4rem;
    line-height: 2.4rem;
    color: #8A93A7;
}

body .extra-services ul li span.little a,
body .extra-services ul li span.little a:active,
body .extra-services ul li span.little a:focus,
body .extra-services ul li span.little a:visited,
body .extra-services ul li span.little a:hover {
    letter-spacing: normal !important;
}

/*  */
body ul.servizi-extra {
    list-style: none;
    -webkit-columns: 3;
    -moz-columns: 3;
    columns: 3;

    list-style-position: inside;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
}

body ul.servizi-extra li {
    list-style-position: inside;
    -webkit-column-break-inside: avoid;
    page-break-inside: avoid;
    break-inside: avoid;
    margin-bottom: 2rem;
}

body ul.servizi-extra li i {
    margin-right: 1rem;
    display: inline-block;
    height: 100%;
    font-size: 2rem;
}

body ul.servizi-extra li span.little {
    display: block;
    font-size: 1.4rem;
    line-height: 2.4rem;
    color: #8A93A7;
}

body ul.servizi-extra li span.little a,
body ul.servizi-extra li span.little a:active,
body ul.servizi-extra li span.little a:focus,
body ul.servizi-extra li span.little a:visited,
body ul.servizi-extra li span.little a:hover {
    letter-spacing: normal !important;
}


/*
*   2.4.1 Table price
*/
/* 10.0 Table */
.table caption,
.table th,
.table td {
    font-weight: normal;
    text-align: left;
}

.table td {
    border: 1px solid #d7d7d7;
    padding: 6px 10px 6px 10px;
}

.table>thead>tr>th,
.table>tbody>tr>th,
.table>tfoot>tr>th,
.table>thead>tr>td,
.table>tbody>tr>td,
.table>tfoot>tr>td {
    padding: 8px;
    line-height: 1.428571429;
    vertical-align: top;
    border-top: 1px solid #ddd;
}

.table>thead>tr>.active,
.table>tbody>tr>.active,
.table>tfoot>tr>.active,
.table>thead>.active>td,
.table>tbody>.active>td,
.table>tfoot>.active>td,
.table>thead>.active>th,
.table>tbody>.active>th,
.table>tfoot>.active>th {
    background-color: #f5f5f5;
}

.table .col_price,
.table .col_minutes {
    width: 10% !important;
    text-align: center !important;
}

.table .col_title {
    width: 20% !important;
    height: 97px !important;
}

.table .row_color {
    background: #eeeeee !important;
}

.table .btn-gold,
.table .btn-gold:focus,
.table .btn-gold:visited,
.table .btn-gold:active {
    background-color: #6dacd2 !important;
    color: #fff !important;
    font-size: 14px !important;
    line-height: 20px !important;
    padding: 15px 50px !important;
    cursor: pointer !important;
    font-family: 'Montserrat', sans-serif !important;
    letter-spacing: 2px !important;
    transition: all 0.5s ease !important;
    text-decoration: none !important;
    display: inline-table;
    text-align: center;
    text-shadow: none !important;
    outline: 0px !important;
}

.table .btn-gold:hover {
    background-color: #3681b0 !important;
    color: #fff !important;
    text-decoration: none !important;
    cursor: pointer !important;
}

.table .btn-gold a,
.table .btn-gold a:hover,
.table .btn-gold a:focus,
.table .btn-gold a:visited,
.table .btn-gold a:active {
    color: #fff !important;
    text-decoration: none !important;
    transition: all 0.5s ease !important;
}

.table .btn-table,
.table .btn-table:active,
.table .btn-table:hover,
.table .btn-table:focus,
.table .btn-table:visited {
    width: 100px !important;
    line-height: 34px !important;
    border-radius: 3px !important;
}

.table .tab-comp_intestazione {
    background: var(--htv-blue) !important;
}

table.table {
    width: 100% !important;
    padding: 6px 10px 6px 0 !important;
    margin-top: 6rem;
    margin-bottom: 6rem;
}

.table .col_full {
    text-align: center;
}

.table th a {
    font-weight: normal !important;
}

.col-md-12 {
    overflow: hidden;
    overflow-x: scroll;
}

.table tr>th:first-child,
.table tr>td:first-child {
    position: -webkit-sticky !important;
    position: sticky !important;
    top: 0;
    left: 0;
    z-index: 4;
}

.table tr>td:first-child {
    background: #ffff;
}

.table tr>th:first-child {
    background: var(--htv-blue);
}

a.btn-gold.btn-table.btn-table-1 {
    width: fit-content !important;
    line-height: 20px !important;
    min-height: 50px;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    padding: 0px 10px !important;
}

a.btn-gold.btn-table.btn-table-1:hover {
    width: fit-content !important;
    line-height: 20px !important;
    min-height: 50px;
    display: flex;
    align-content: center;
    flex-wrap: wrap;
    padding: 0px 10px !important;
}


/*
*   2.5 Internal pages
*/
.error-404>.page-content {
    display: grid !important;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    row-gap: 2rem;
}

.error-404>.page-content>* {
    grid-column: 2/-2;
    grid-row: auto;
}

.swiper-slide>.featured-video-info {
    display: flex;
    flex-flow: row;
    justify-content: space-between;
}

.swiper-slide .video-rate i {
    color: #F2C94C !important;
    font-size: 2rem !important;
}

.swiper-slide>.video-title {
    font-weight: bold !important;
    font-size: 2.4rem !important;
    line-height: 3.112rem !important;
    color: #484B5C !important;
}

.swiper-slide>.video-content,
.swiper-slide>.video-content p {
    font-size: 1.6rem;
    line-height: 2.6rem;
    color: #8A93A7 !important;
}

.emotional_newsletter_wrapper {
    display: grid !important;
    grid-template-rows: repeat(2, 1fr);
    grid-template-columns: repeat(3, auto);
    column-gap: 1rem;
    position: relative;
    align-items: center;
    max-width: 80rem !important;
    border: 0.1rem solid #BDBDBD;
    border-radius: 3rem;
    padding: 0.5rem;
    margin: 2rem auto !important;
    width: 100%;
    background: #fff;
}

img.emotional_newsletter_icon {
    grid-column: 1;
    grid-row: 1/3;
    max-width: 16rem;
}

span.emotional_newsletter_close {
    grid-column: 2;
    grid-row: 1;
    position: absolute;
    right: 2rem;
    top: 1rem;
    font-size: 3rem;
    z-index: 8;
}

.emotional_newsletter_wrapper h2.emotional_newsletter_title {
    grid-column: 2/4;
    grid-row: 1;
    text-align: left;
}

.emotional_newsletter_wrapper p.emotional_newsletter_subtitle {
    grid-column: 2/4;
    grid-row: 1;
    padding-top: 9rem;
    margin-bottom: 0px;
    text-align: left;
}

.emotional_newsletter_wrapper section.yikes-mailchimp-container {
    grid-column: 2/4;
    grid-row: 2;
}

.emotional_newsletter_wrapper form {
    display: grid;
    width: 100%;
    grid-template-rows: 1fr;
    grid-template-columns: repeat(3, 1fr);
}

.emotional_newsletter_wrapper button.yikes-easy-mc-submit-button {
    grid-row: 1;
    grid-column: 3;
}

.emotional_newsletter_wrapper label.EMAIL-label {
    height: 5.2rem !important;
    grid-row: 1;
    grid-column: 1/3;
}

.emotional_newsletter_wrapper label.EMAIL-label>input {
    height: 4rem !important;
    padding: 0.5rem !important;
    outline: none !important;
}

.emotional_newsletter_wrapper button.yikes-easy-mc-submit-button {
    margin: 0 auto 0 0 !important;
    background-color: #45B3B8 !important;
    height: 4rem !important;
    border-radius: 0 !important;
    border: 0 !important;
    font-style: normal;
    font-weight: 700;
    font-size: 1.3rem;
    line-height: 3rem !important;
    letter-spacing: 0rem;
    text-align: center;
    color: #fff;
    text-transform: uppercase;
    padding: 0.5rem 1.5rem;
    max-width: unset !important;
    width: auto !important;
    display: inline-flex;
    text-decoration: none !important;
    transition: 0.5s all ease;
}

.emotional_newsletter_wrapper button.yikes-easy-mc-submit-button span {
    line-height: 1 !important;
    align-self: center;
}

.emotional_newsletter_wrapper button.yikes-easy-mc-submit-button:hover,
.emotional_newsletter_wrapper button.yikes-easy-mc-submit-button:focus {
    background-color: #2484AD;
    border: 0 !important;
}

.emotional_newsletter_wrapper label.EMAIL-label:focus {
    outline: none !important;
    border-color: #dbdbdb !important;
}

.hidden_newsletter,
.emotional_newsletter_wrapper span.EMAIL-label {
    display: none !important;
    visibility: hidden !important;
}

@media (max-width:699px) {
    .emotional_newsletter_wrapper h2.emotional_newsletter_title {
        font-size: 2.2rem;
        line-height: 2.5rem;
        letter-spacing: 0.1rem;
    }

    .emotional_newsletter_wrapper p.emotional_newsletter_subtitle {
        font-size: 1.2rem;
    }

    img.emotional_newsletter_icon {
        display: none !important;
        visibility: hidden !important;
    }
}

@media(max-width:500px) {
    .emotional_newsletter_wrapper:not(.hidden_newsletter) {
        display: flex !important;
        flex-flow: column;
    }

    img.emotional_newsletter_icon:not(.hidden_newsletter) {
        display: block !important;
        visibility: visible !important;
    }

    .emotional_newsletter_wrapper p.emotional_newsletter_subtitle {
        padding: 1.8rem 0 !important;
    }

    .emotional_newsletter_wrapper h2.emotional_newsletter_title {
        margin-bottom: 0 !important;
    }
}

.grid-info {
    border-top: 1px solid #C2C8E2;
    border-bottom: 1px solid #C2C8E2;
    padding: 1rem 0;
    margin: 2rem 0;
    display: flex;
    width: fit-content;
}

.single-info {
    padding: 0 1rem;
    display: flex;
    align-items: baseline;
}

.single-info>i {
    color: #C2C8E2 !important;
    padding-right: 0.5rem;
}

.single-info:not(:first-child) {
    border-left: 1px solid #C2C8E2;
}

span.gallery-label-floating {
    background: #5D7CFB;
    box-shadow: 0px 2px 20px rgba(138, 147, 167, 0.3);
    border-radius: 30px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
    padding: 6px 20px;

    font-weight: 600;
    font-size: 1.6rem;
    line-height: 2.6rem;
    letter-spacing: 0.2rem;
    text-transform: uppercase;
    color: #FFFFFF;
    width: fit-content !important;
    position: absolute;

    top: 6rem;
    left: 0;
}

.reviews-list-container-single {
    background: #FFFFFF;
    box-shadow: 0 0.2rem 2rem rgba(138, 147, 167, 0.3);
    border-radius: 1rem;
    max-width: 46rem;
    margin: 2rem auto;
}

.reviews-list-container-single .review-single-info {
    display: flex;
    flex-flow: row;
    background: #A3CDCB;
    border-radius: 1rem;
    padding: 1rem 2rem;
}

.reviews-list-container-single .review-single-content {
    padding: 2rem;
    font-size: 1.6rem;
    line-height: 2.6rem;
}

.reviews-list-container-single .review-single-info .review-single-platform {
    margin-right: 1rem;
}

.reviews-list-container-single .review-single-info .review-single-platform i {
    font-family: "Font Awesome 5 Brands";
}

.reviews-list-container-single .review-single-info .review-single-rate {
    margin-left: auto;
    margin-right: 1rem;
}

.reviews-list-container-single .review-single-info .review-single-rate i {
    font-size: 1.4rem;
    color: #FDC60A;
}


/*
*   2.6 Single offer
*/
article.offer>.entry-content {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    gap: 2rem;
}

article.offer>.entry-content>div {
    grid-column: 2/-2;
    grid-row: auto;
}

article.offer>.entry-content>div.entry-content-title {
    grid-column: 1/-1;
    grid-row: auto;
}

article.offer .offer-whats-included ul.offer-list-features {
    list-style: none;
    display: flex;
    gap: 0;
    align-items: center;
    padding: 0;
}

article.offer .offer-whats-included ul.offer-list-features li {
    display: flex;
    justify-content: center;
    padding: 0 1rem 0;
    /* border-right: 0.1rem solid #DCDFE5; */
}

article.offer>.entry-content>.offer-book-buttons>a.btn,
article.offer>.entry-content>.offer-book-buttons>a.btn:hover,
article.offer>.entry-content>.offer-book-buttons>a.btn:focus,
article.offer>.entry-content>.offer-book-buttons>a.btn:active {
    width: fit-content !important;
}

article.offer .offer-content form {
    display: grid;
    grid-template-columns: auto;
    grid-template-rows: auto;
    gap: 1.5rem;
    width: fit-content;
    margin-top: 4rem;
}

article.offer .offer-content form select {
    padding: 0.5rem 1.8rem;
    border: 0.1rem solid black;
    background-position-x: 19.5rem;
    background-position-y: 1.5rem;
}

article.offer .offer-content form select:focus {
    outline: none !important;
}

article.offer .entry-content .offer-content h3,
article.offer .entry-content .offer-content h2 {
    margin-top: 4rem;
}

/* NEW OFFER */
.single-offer-wrapper {
    grid-column: 2/-2;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: auto;
    gap: 1rem;
}

.single-offer-container {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
}

.single-offer-wrapper .offer-title {
    grid-column: 1/-1;
    text-align: center;
}

.single-offer-wrapper .offer-title h1 {
    margin: 6rem 0;
    color: #464861;
}

.single-offer-wrapper .offer-content {
    grid-column: 1/3;
}

.single-offer-wrapper .offer-extra-info {
    grid-column: 3;
    display: flex;
    flex-flow: column;
    justify-content: start;
    gap: 4rem;
}

.single-offer-wrapper .services-onrequest {
    grid-column: 1/-1;
}

.single-offer-wrapper .booking-button {
    grid-column: 1/-1;
    margin: 5rem 0;
    text-align: center;
}

.offer-services ul.offers-list-services {
    list-style: none;
    display: flex;
    flex-flow: row;
    flex-wrap: wrap;
    padding: 0 !important;
}

.offer-services ul.offers-list-services li span {
    font-size: 3rem !important;
    padding: 1rem 0.5rem;
}

.offer-extra-services ul.offers-list-extra-services {
    padding: 0 !important;
    list-style: none !important;
}

.offer-extra-services ul.offers-list-extra-services li.evidence {
    color: #B129A4 !important;
}

.offer-extra-services ul.offers-list-extra-services li {
    display: flex;
    align-items: center;
    font-weight: normal;
    font-size: 18px;
    line-height: 30px;
    margin-bottom: 1rem;
}

.offer-extra-services ul.offers-list-extra-services li :first-child {
    margin-right: 1rem;
}

.single-offer-wrapper .offer-extra-info .offer-price {
    display: flex;
    flex-flow: column;
    align-items: center;
    width: fit-content;
    margin: auto auto 0;
    padding: 1.5rem 4rem;
    background: #202544;
    color: #fff;
    border-radius: 0.4rem;
}

.single-offer-wrapper .offer-extra-info .offer-price span.price-text {
    font-weight: normal;
    font-size: 35px;
    line-height: 35px;
}

.single-offer-wrapper .offer-extra-info .offer-price span.price {
    font-weight: 700;
    font-size: 65px;
    line-height: 65px;
}

.single-offer-wrapper .offer-extra-info .offer-price span.price:after {
    content: '€';
}

body .booking-button a.btn.booking-btn-offers,
body .booking-button a.btn.booking-btn-offers:hover,
body .booking-button a.btn.booking-btn-offers:active,
body .booking-button a.btn.booking-btn-offers:focus,
body .booking-button a.btn.booking-btn-offers:visited,
body.has-background-white .site .booking-button a.btn.booking-btn-offers:focus:not(.wp-block-button__link):not(.wp-block-file__button) {
    width: fit-content !important;
    margin-left: auto !important;
    margin-right: auto !important;
}

.booking-button a.btn.booking-btn-offers::after {
    display: none !important;
    visibility: hidden !important;
}

.services-onrequest {
    border-top: 1px solid #c4c4c4;
}

.services-onrequest h2 {
    text-align: center;
    color: #000000;
    margin-top: 6rem;
    margin-bottom: 5rem;
}

.services-onrequest ul.services-listing {
    list-style: none !important;
    padding: 0 !important;
}

.services-onrequest ul.services-listing li::before {
    content: '-';
    margin-right: 1rem;
}

.services-onrequest ul.services-listing li {
    padding-bottom: 1.5rem;
}

.offer-content ul.check-icon {
    list-style: none !important;
    padding: 0 !important;
}

.offer-content ul.check-icon li::before {
    content: '\f00c';
    font-family: "Font Awesome 5 Pro";
    font-weight: 900;
    margin-right: 1rem;
}

.offer-content ul.check-icon li {
    padding-bottom: 1.5rem;
}


/*
*   3.0 Footer
*/
.border-rounded {
    border-radius: 1rem;
}

.single-review-footer {
    border-radius: 40px 40px 40px 0px;
    background: #A3CDCB;
    padding: 2rem 3rem;
    display: flex;
    flex-flow: column;
    text-align: center;
    width: fit-content;
    margin: auto;
}

.single-review-footer span.title {
    color: #fff;
    font-weight: bold;
    letter-spacing: 0.1rem;
}

.single-review-footer span.reviews-info {
    color: #8c94a7;
}

.single-review-footer span.rate i {
    color: #F5BC41;
}

.bottom-bar {
    position: fixed;
    bottom: 0;
    left: 0;
    right: 0;
    padding: 2rem 4rem;
    display: flex;
    flex-flow: row;
    justify-content: space-between;
    background: var(--htv-blue-2);
    z-index: 20;
}

.bottom-bar a,
.bottom-bar a i,
.bottom-bar a span {
    text-align: center !important;
}

.bottom-bar a,
.bottom-bar a i,
.bottom-bar a span,
.bottom-bar a:active,
.bottom-bar a:active i,
.bottom-bar a:active span,
.bottom-bar a:visited,
.bottom-bar a:visited i,
.bottom-bar a:visited span {
    color: #FFFFFF !important;
}

.bottom-bar a {
    display: flex;
    flex-flow: column;
}

.bottom-bar a i {
    font-size: 2.2rem !important;
    line-height: 2.2rem !important;
}

.bottom-bar a span {
    font-weight: normal !important;
    font-size: 1rem !important;
    line-height: 1.4rem !important;
    letter-spacing: 0.2rem !important;
    text-transform: uppercase !important;
    margin-top: 1rem;
}

.bottom-bar a:hover,
.bottom-bar a:hover i,
.bottom-bar a:hover span,
.bottom-bar a:focus,
.bottom-bar a:focus i,
.bottom-bar a:focus span {
    color: #F5BC41 !important;
}

body.single-room .bottom-bar {
    display: none !important;
    visibility: hidden !important;
}




/*
*   3.0 Footer
*/
footer.site-footer {
    grid-area: footer;
    background: var(--htv-blue-2);
    color: #ffffff;
    width: 100%;
    font-size: 1.3rem;
    line-height: 2.4rem;
    margin-top: 6rem !important;
}

footer.site-footer::before {
    display: none;
}

footer.site-footer .row-reviews {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    background-color: #F6F7F8;
    color: #333333;
    padding: 2rem 0 5rem;
    gap: 1rem 3rem;
    font-size: 1.6rem;
    line-height: 2.6rem;
}

footer.site-footer .row-reviews h2 {
    grid-column: 2 / -2;
    text-align: center;
    background-color: #F6F7F8;
}

footer.site-footer .row-reviews .row-reviews-widget {
    grid-column: 2 / 4;
}

footer.site-footer .row-reviews .row-reviews-review {
    grid-column: 4 / 7;
    display: flex;
    flex-direction: column;
}

footer.site-footer .row-reviews .row-reviews-stats {
    grid-column: 7 / 12;
}

footer.site-footer .row-newsletter {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    padding: 5rem 0;
    position: relative;
    color: #333333;
}

body:not(.home) footer.site-footer {
    margin-top: 3rem;
}

footer.site-footer .row-newsletter:before {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    top: 0;
    bottom: 0;
    background: #ffffff;
    opacity: .8;
}

footer.site-footer .row-newsletter h2 {
    color: var(--htv-blue-2);
}

footer.site-footer .row-newsletter .row-newsletter-subscribe {
    grid-column: 2 / 6;
    z-index: 1;
}

.row-newsletter-subscribe form.yikes-easy-mc-form {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    row-gap: 3rem;
}

.row-newsletter-subscribe form.yikes-easy-mc-form>* {
    grid-column: 1/-1;
    grid-row: auto;
}

.row-newsletter-subscribe form.yikes-easy-mc-form label.EMAIL-label {
    grid-column: 1/8;
    grid-row: 1;
    display: flex;
    margin: 0 !important;
}

.row-newsletter-subscribe form.yikes-easy-mc-form label.EMAIL-label input {
    outline: none !important;
    margin: 0 !important;
    height: 100% !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.row-newsletter-subscribe form.yikes-easy-mc-form button.yikes-easy-mc-submit-button {
    grid-column: 7/13;
    grid-row: 1;

    margin: 0 !important;
    background: var(--link-color) !important;
    border-radius: 0.4rem !important;
    padding: 1rem !important;
}

.row-newsletter-subscribe form.yikes-easy-mc-form button.yikes-easy-mc-submit-button:hover,
.row-newsletter-subscribe form.yikes-easy-mc-form button.yikes-easy-mc-submit-button:focus {
    background: var(--link-color-hover) !important;
}

.row-newsletter-subscribe form.yikes-easy-mc-form label.yikes-mailchimp-eu-compliance-label>input,
form.yikes-easy-mc-form label.yikes-mailchimp-eu-compliance-label>input {
    border: 1px solid black;
    width: 1.5rem;
    height: 1.5rem;
}

.row-newsletter-subscribe form.yikes-easy-mc-form button.yikes-easy-mc-submit-button::after {
    content: "\f178";
    font-family: "Font Awesome 5 Pro";
    font-weight: 300;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    margin-left: 1.5rem;
}

footer.site-footer .row-newsletter .row-newsletter-socials {
    grid-column: 8 / 12;
    z-index: 1;
}

footer.site-footer .row-newsletter .row-newsletter-socials .socials a {
    display: inline-block;
}

footer.site-footer .row-newsletter .row-newsletter-socials .socials i {
    font-size: 4rem;
    padding: 1rem;
}

footer.site-footer .row-site {
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    grid-template-rows: auto;
    gap: 4rem;
    justify-content: center;
    align-items: start;
    padding: 3rem 2rem;
}

footer.site-footer .row-site span.title {
    font-weight: 700;
    display: block;
    font-size: 1.5rem;
    margin-bottom: 1rem;
}

footer.site-footer .row-site .site-logo svg {
    max-width: 21.5rem !important;
    height: auto !important;
    margin-bottom: 2rem;
}

footer.site-footer .row-site .row-site-contacts a {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
}

footer.site-footer .row-site .row-site-contacts a i,
footer.site-footer .row-site .row-site-contacts a:active i,
footer.site-footer .row-site .row-site-contacts a:focus i,
footer.site-footer .row-site .row-site-contacts a:visited i {
    color: #ffffff;
    margin-right: 1rem;
    font-size: 2.2rem;
    padding: 0.5rem 0;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

footer.site-footer .row-site .row-site-contacts a:hover i {
    color: var(--link-color-hover);
}

footer.site-footer .row-site .row-site-socials a {
    display: inline-block;
    margin-right: 2rem;
}

footer.site-footer .row-site .row-site-socials a i {
    font-size: 3rem;
}

footer.site-footer .row-credits {
    margin: 0 0;
    padding: 1rem 2rem;
    background: #E1E6E9;
    width: 100%;
    color: #000000;
    text-align: center;
}

/*
*   4.0 Rooms list container
*/
.rooms-list-container {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.rooms-list-container.swiper-container-horizontal {
    overflow: hidden;
    padding: 2rem 3rem 5rem;
}

.rooms-list-container:not(.swiper-container-horizontal) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(var(--rooms-list-container-columns), 1fr);
    gap: 2rem;
}

.rooms-list-container .rooms-list-container-single {
    grid-column: auto;
    grid-row: auto;
    background-color: #ffffff;
    display: grid;
    grid-template-rows: auto;
    -webkit-box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    transition: 0.5s all ease;
    position: relative;
    padding: 0 2rem 2rem;
    border-radius: 1rem;
    color: #8A93A7;
    gap: 1.5rem 0rem;
}

.rooms-list-container .rooms-list-container-single:hover {
    -webkit-box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
}

.rooms-list-container.swiper-container-horizontal .rooms-list-container-single {
    max-width: 28rem;
    margin: 0 3rem 0 0;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-message {
    position: absolute;
    background: #5D7CFB;
    -webkit-box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    color: #ffffff;
    padding: 0.5rem 2rem;
    left: -1rem;
    top: 2rem;
    font-size: 1.6rem;
    letter-spacing: 0.2rem;
    font-weight: 600;
    text-transform: uppercase;
    z-index: 2;
    border-radius: 3rem;
    display: flex;
    align-items: center;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-message i {
    margin-right: 0.6rem;
    font-size: 1.5rem;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-img {
    margin: 0 -2rem;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-img figure {
    height: 28rem;
    width: 100%;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-img figure,
.rooms-list-container .rooms-list-container-single .rooms-list-container-single-img figure img {
    border-radius: 1rem 1rem 0 0;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title {
    position: relative;
    display: flex;
    gap: 0 0.5rem;
    margin-bottom: 1rem;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title h3 {
    margin: -2rem 0 1.2rem 0;
    color: var(--global--color-primary);
    position: relative;
    padding: 2.5rem 0 2rem;
    text-transform: uppercase;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title h3::before {
    content: "";
    position: absolute;
    height: 0.2rem;
    top: -1.4rem;
    width: 5rem;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    background-color: linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -o-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -moz-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -webkit-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -ms-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title h3:after {
    content: "";
    position: absolute;
    height: 0;
    bottom: 0;
    width: 2.5rem;
    top: auto;
    left: 1.25rem;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    border-bottom: 0.2rem solid var(--htv-blue);
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title .rooms-list-container-single-price {
    margin: -3rem 0 0 auto;
    background: rgba(255, 255, 255, 0.8);
    box-shadow: 0 0 1rem rgb(138 147 167 / 30%);
    border-radius: 1rem;
    padding: 2rem 2rem;
    color: var(--htv-blue);
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title .rooms-list-container-single-price span.price {
    font-size: 3.4rem;
    display: block;
    color: #27AE60;
    margin-top: 1rem;
    font-family: var(--heading--font-family);
    font-weight: normal;
    white-space: nowrap;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-title .rooms-list-container-single-price span.price i.fa-spinner {
    font-size: 1.6rem;
    color: #8A93A7;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-short-description,
.rooms-list-container .rooms-list-container-single .rooms-list-container-single-short-description p {
    margin: 0;
}

.rooms-list-container .rooms-list-container-single hr {
    background: #8A93A7 !important;
    border: 0;
    width: 100%;
    margin: 0 auto;
    height: 0.1rem;
    opacity: 0.3;
}

.rooms-list-container .rooms-list-container-single hr::before,
.rooms-list-container .rooms-list-container-single hr::after {
    display: none !important;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features {
    margin: 0;
    display: flex;
    padding: 0;
    color: #8A93A7;
    align-items: center;
    gap: 0;

}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .feature-box {
    padding: 0 1.5rem;
    border-right: 0.1rem solid #DCDFE5;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .feature-box:first-of-type {
    white-space: nowrap;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .feature-box.feature-box.feature-box-occupancy {
    gap: 0 0.3rem;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .feature-box:first-of-type {
    padding-left: 0;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .feature-box:last-of-type {
    border-right: none;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .rooms-list-container-single-features-evidence {
    list-style: none;
    display: flex;
    gap: 0 1rem;
    align-items: center;
    margin: 0 0 0 auto;
    padding: 0;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-features .rooms-list-container-single-features-evidence li {
    display: flex;
    justify-content: center;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-button {
    margin: auto 0 0 !important;
}

.rooms-list-container .rooms-list-container-single .rooms-list-container-single-button::after {
    margin: 0 0 0 auto !important;
}

/*
*   5.0 Offers list container
*/

@media screen and (max-width: 450px) {
    .desktop-excerpt {
        display: none;
    }
}

.offers-list-container {
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.offers-list-container.swiper-container-horizontal {
    overflow: hidden;
    padding: 2rem 3rem 5rem;
}

.offers-list-container:not(.swiper-container-horizontal) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(var(--offers-list-container-columns), 1fr);
    gap: 2rem;
}

.offers-list-container .offers-list-container-single {
    grid-column: auto;
    grid-row: auto;
    background-color: #ffffff;
    display: grid;
    grid-template-rows: auto;
    -webkit-box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 4px 20px 0px rgba(0, 0, 0, 0.25);
    transition: 0.5s all ease;
    position: relative;
    padding: 0 2rem 2rem;
    border-radius: 1rem;
    color: #8A93A7;
    gap: 1.5rem 0rem;
}

.offers-list-container .offers-list-container-single:hover {
    -webkit-box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
    box-shadow: 0px 4px 30px 0px rgba(0, 0, 0, 0.25);
}

.offers-list-container.swiper-container-horizontal .offers-list-container-single {
    max-width: 28rem;
    margin: 0 3rem 0 0;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead {
    grid-column: 1 / 3;
    padding: 0;
    display: grid;
    grid-template-columns: 2fr 3fr;
    grid-template-rows: auto;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-message {
    left: 25%;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead figure,
.offers-list-container .offers-list-container-single.offers-list-container-single-lead figure img {
    border-radius: 1rem;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content {
    padding: 8rem 2rem 2rem;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content h3 {
    position: relative;
    color: var(--htv-blue);
    padding-bottom: 2rem;
    margin-bottom: 3rem;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content h3::after {
    content: "";
    position: absolute;
    height: 0;
    bottom: 0;
    width: 2.5rem;
    top: auto;
    left: 4rem;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    border-bottom: 0.2rem solid var(--htv-blue);
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content hr {
    margin: 1rem 0;
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content .offers-list-container-single-lead-content-blurred span.blurred {
    color: transparent;
    text-shadow: 0 0 5px rgb(0 0 0 / 50%);
}

.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content a.offers-list-container-single-button,
.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content a.offers-list-container-single-button:hover,
.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content a.offers-list-container-single-button:active,
.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content a.offers-list-container-single-button:focus,
.offers-list-container .offers-list-container-single.offers-list-container-single-lead .offers-list-container-single-lead-content a.offers-list-container-single-button:visited {
    cursor: not-allowed !important;
    background: #C7D3ED;
    background-color: #C7D3ED;
    border-color: #C7D3ED;
    display: none !important;
    visibility: hidden !important;
}

body .offers-list-container-single-services-preview a.offers-list-container-single-button {
    display: none;
}

.offers-list-container-single-lead-content-blurred {
    display: none !important;
    visibility: hidden !important;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-message {
    position: absolute;
    background: #5D7CFB;
    -webkit-box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    -moz-box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    box-shadow: 0 0.4rem 0.4rem rgba(0, 0, 0, 0.25);
    color: #ffffff;
    padding: 0.5rem 2rem;
    left: -1rem;
    top: 2rem;
    font-size: 1.6rem;
    letter-spacing: 0.2rem;
    font-weight: 600;
    text-transform: uppercase;
    z-index: 2;
    border-radius: 3rem;
    display: flex;
    align-items: center;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-message i {
    margin-right: 0.6rem;
    font-size: 1.5rem;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-img {
    margin: 0 -2rem;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-img figure {
    height: 28rem;
    width: 100%;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-img figure,
.offers-list-container .offers-list-container-single .offers-list-container-single-img figure img {
    border-radius: 1rem 1rem 0 0;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-title {
    position: relative;
    display: flex;
    gap: 0 0.5rem;
    margin-bottom: 1rem;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-title h3 {
    margin: -2rem 0 1.2rem 0;
    color: var(--global--color-primary);
    position: relative;
    padding: 2.5rem 0 2rem;
    text-transform: uppercase;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-title h3::before {
    content: "";
    position: absolute;
    height: 0.2rem;
    top: -1rem;
    width: 5rem;
    left: 0;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    background-color: linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -o-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -moz-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -webkit-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
    background-image: -ms-linear-gradient(left, #ffffff 80%, #4a4a4a 20%);
}

.offers-list-container .offers-list-container-single .offers-list-container-single-title h3:after {
    content: "";
    position: absolute;
    height: 0;
    bottom: 0;
    width: 2.5rem;
    top: auto;
    left: 1.25rem;
    -ms-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
    border-bottom: 0.2rem solid var(--htv-blue);
}

.offers-list-container .offers-list-container-single .offers-list-container-single-title .offers-list-container-single-title-percentage {
    background: #F5BC41;
    box-shadow: 0 0.2rem 2rem rgb(138 147 167 / 30%);
    border-radius: 3rem;
    color: #333333;
    font-weight: 800;
    font-size: 1.6rem;
    line-height: 2.6;
    letter-spacing: 0.2rem;
    text-transform: uppercase;
    padding: 0rem 1rem;
    align-self: start;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-short-description,
.offers-list-container .offers-list-container-single .offers-list-container-single-short-description p {
    margin: 0;
}

.offers-list-container .offers-list-container-single hr {
    background: #8A93A7 !important;
    border: 0;
    width: 100%;
    margin: 0 auto;
    height: 0.1rem;
    opacity: 0.3;
}

.offers-list-container .offers-list-container-single hr::before,
.offers-list-container .offers-list-container-single hr::after {
    display: none !important;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-features {
    margin: 0;
    display: flex;
    padding: 0;
    color: #8A93A7;
    align-items: center;
    gap: 0;

}

.offers-list-container .offers-list-container-single .offers-list-container-single-features .feature-box {
    padding: 0 1rem 0 0;
    border-right: 0.1rem solid #DCDFE5;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-features .feature-box.feature-box-text {
    color: #27AE60;
    font-weight: bold;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-features .offers-list-container-single-features-evidence {
    list-style: none;
    display: flex;
    gap: 0;
    align-items: center;
    padding: 0;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-features .offers-list-container-single-features-evidence li {
    display: flex;
    justify-content: center;
    padding: 0 1rem 0;
    border-right: 0.1rem solid #DCDFE5;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-features .offers-list-container-single-features-evidence li:last-of-type {
    border-right: 0;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-button {
    margin: auto 0 0 !important;
}

.offers-list-container .offers-list-container-single .offers-list-container-single-button::after {
    margin: 0 0 0 auto !important;
}

.newsletter-block,
.offers-list-container-single-features {
    margin-bottom: 2rem !important;
}

.newsletter-block form.newsletter-grid-form {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    grid-template-rows: auto;
    row-gap: 3rem;
}

.newsletter-block form.newsletter-grid-form>* {
    grid-column: 1/-1;
    grid-row: auto;
}

.newsletter-block form.newsletter-grid-form label.EMAIL-label {
    grid-column: 1/8;
    grid-row: 1;
    display: flex;
    margin: 0 !important;
}

.newsletter-block form.newsletter-grid-form label.EMAIL-label input {
    outline: none !important;
    margin: 0 !important;
    height: 100% !important;
    border-top-right-radius: 0 !important;
    border-bottom-right-radius: 0 !important;
}

.newsletter-block form.newsletter-grid-form button.yikes-easy-mc-submit-button {
    grid-column: 7 / 13;
    grid-row: 1;

    margin: 0 !important;
    background: var(--link-color) !important;
    border-radius: 0.4rem !important;
    padding: 1rem !important;
}

.newsletter-block form.newsletter-grid-form button.yikes-easy-mc-submit-button span {
    font-size: 1.5rem;
}

.newsletter-block form.newsletter-grid-form button.yikes-easy-mc-submit-button:hover,
.newsletter-block form.newsletter-grid-form button.yikes-easy-mc-submit-button:focus {
    background: var(--link-color-hover) !important;
}

.newsletter-block form.newsletter-grid-form label.yikes-mailchimp-eu-compliance-label>input {
    border: 1px solid black;
    width: 1.5rem;
    height: 1.5rem;
}

.newsletter-block form.newsletter-grid-form button.yikes-easy-mc-submit-button::after {
    content: "\f178";
    font-family: "Font Awesome 5 Pro";
    font-weight: 300;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    margin-left: 1.5rem;
}

/*
*   6.0 Reviews list container
*/
.reviews-list-container.swiper-container-horizontal {
    overflow: hidden;
    padding: 2rem 0 5rem;
}

.reviews-list-container:not(.swiper-container-horizontal) {
    display: grid;
    grid-template-rows: auto;
    grid-template-columns: repeat(var(--reviews-list-container-columns), 1fr);
    gap: 2em;
}

.reviews-list-container .reviews-list-container-single {
    grid-column: auto;
    grid-row: auto;
    color: var(--color);
    display: grid;
    grid-template-rows: auto;
    row-gap: 0.1rem;
    transition: 0.5s all ease;
    position: relative;
    padding: 0;
    font-size: 1.6rem;
}

.reviews-list-container.swiper-container-horizontal .reviews-list-container-single {
    max-width: 46rem;
    padding: 0 2rem 0 0;
    margin: 0 3rem 0 0;
}

.reviews-list-container.swiper-container-horizontal .reviews-list-container-single .reviews-list-container-single-head {
    display: grid;
    grid-template-columns: 6rem auto;
    grid-template-rows: 2.5rem 2.5rem;
    gap: 0.5rem;
    align-items: center;
    margin-bottom: 1.5rem;
}

.reviews-list-container.swiper-container-horizontal .reviews-list-container-single .reviews-list-container-single-photo {
    background: #4CC9DC;
    box-shadow: 0 0 1rem rgba(0, 0, 0, 0.25);
    color: #ffffff;
    border-radius: 100%;
    width: 5rem;
    height: 5rem;
    display: flex;
    justify-content: center;
    align-items: center;
    font-weight: 900;
    line-height: 0;
    grid-column: 1;
    grid-row: 1 / 3;
}

.reviews-list-container .reviews-list-container-single .reviews-list-container-single-author {
    font-weight: bold;
    grid-column: 2;
    grid-row: 1;
    height: 60%;
}

.reviews-list-container .reviews-list-container-single .reviews-list-container-single-date-platform {
    grid-column: 2;
    grid-row: 2;
    color: #AEAEAE;
    font-size: 1.4rem;
}

.reviews-list-container .reviews-list-container-single .reviews-list-container-single-date-platform .reviews-list-container-single-date-platform-divider {
    margin: 0 1rem;
    width: 0.1rem;
    border-left: 0.1rem solid #AEAEAE;
}

.reviews-list-container .reviews-list-container-single .reviews-list-container-single-short-description,
.reviews-list-container .reviews-list-container-single .reviews-list-container-single-short-description p {
    margin: 0;
    font-size: 1.4rem;
}

.reviews-list-navigation {
    display: inline-flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: row-reverse;
}

/*
*   7.0 Sliders
*/
body .slider-list-navigation {
    display: inline-flex;
    justify-content: flex-start;
    align-items: center;
    flex-direction: row-reverse;
}

body .swiper-button-next,
body .swiper-button-prev {
    position: relative;
    top: auto;
    bottom: auto;
    left: auto;
    right: auto;
    margin: 0 0 0 1rem;
    width: 3.4rem;
    height: 3.4rem;
    padding: 1rem;
    border-radius: 100%;
    border: 0.1rem solid #DFDFDF;
}

body .swiper-button-next::after,
body .swiper-button-prev::after {
    font-size: 2.5rem;
    font-family: 'Font Awesome 5 Pro';
    font-weight: 300;
    -moz-osx-font-smoothing: grayscale;
    -webkit-font-smoothing: antialiased;
    display: inline-block;
    font-style: normal;
    font-variant: normal;
    text-rendering: auto;
    line-height: 1;
    color: var(--global--color-primary);
}

body .swiper-button-next::after {
    content: "\f105";
}

body .swiper-button-prev::after {
    content: "\f104";
}

/*
*   8.0 Booking form
*/
body a.booking-form-mobile {
    display: none;
}

#booking-form div.sb {
    box-shadow: 0 0.8rem 4rem rgba(0, 0, 0, 0.08);
    border-radius: 0.4rem;
    padding: 1rem !important;
}

#booking-form div.sb__form {
    display: grid;
    grid-template-columns: repeat(7, 1fr);
    grid-template-rows: auto;
    gap: 0 0.5rem;
}

#booking-form div.sb__form div.sb__dates {
    grid-row: 1;
    grid-column: 1 / 5;
    width: 100%;
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: 1;
    gap: 0 0.5rem;
}

#booking-form div.sb__form div.sb__dates div.sb__form-field--checkin,
#booking-form div.sb__form div.sb__dates div.sb__form-field--checkout {
    width: 100%;
    display: flex;
    align-items: center;
}

#booking-form div.sb__form div.sb__guests-rooms {
    grid-row: 1;
    grid-column: 5;
    width: 100%;
    padding: 0;
}

#booking-form div.sb__form div.sb__guests-rooms span.sb__form-field-label {
    display: none;
}

#booking-form div.sb__form input.sb__btn--verify,
#booking-form div.sb__form input.sb__btn--verify:focus,
#booking-form div.sb__form input.sb__btn--verify:visited,
#booking-form div.sb__form input.sb__btn--verify:active {
    grid-row: 1 / 3;
    grid-column: 6 / -1;
    width: 100% !important;
    background: var(--booking-color) !important;
    border-color: var(--booking-color) !important;
    margin: 0;
    height: 100%;
    justify-content: center;
    color:#fff!important
}

#booking-form div.sb__form input.sb__btn--verify:hover {
    background: var(--booking-color-hover) !important;
    border-color: var(--booking-color-hover) !important;
}

#booking-form div.sb__form div.sb__footer {
    grid-row: 2;
    grid-column: 1 / -3;
    width: 100%;
    display: flex;
    align-items: center;
    padding-top: 1rem;
}

#booking-form div.sb__form div.sb__footer div.sb__footer-actions {
    float: unset;
    display: flex;
    align-items: center;
}

#booking-form div.sb__form div.sb__footer div.sb__footer-actions div.sb__footer-promo-wrapper {
    float: unset;
    margin-right: 7rem !important;
}

.sb__panel-actions button {
    margin: 0.5rem 0 !important;
}

#sb-container .sb__panel-actions .sb__btn.sb__btn--secondary:hover {
    color: #000000 !important;
}

#booking-form div.sb__form div.sb__footer div.sb__footer-actions a,
#booking-form div.sb__form div.sb__footer div.sb__footer-actions a:active,
#booking-form div.sb__form div.sb__footer div.sb__footer-actions a:focus,
#booking-form div.sb__form div.sb__footer div.sb__footer-actions a:visited {
    float: unset;
    margin: 0;
    padding: 0;
    color: var(--booking-color) !important;
    font-weight: normal;
    font-size: 1.2rem;
    text-transform: uppercase;
}

#booking-form div.sb__form div.sb__footer div.sb__footer-actions a:hover {
    color: var(--booking-color-hover) !important;
}

#booking-form div.sb__form div.sb__footer div.sb__footer-actions a svg {
    display: none;
}

#booking-form div.sb__form .sb__calendar-btn-icon {
    line-height: 0 !important;
}

#booking-form div.sb__form button.sb__guests-add-room.sb-custom-icon-color.sb-custom-add-room-box-shadow-color {
    font-size: 1.2rem !important;
}

#booking-form div.sb__form button.sb__calendar-btn.sb__calendar-btn--next,
#booking-form div.sb__form button.sb__calendar-btn.sb__calendar-btn--prev {
    padding: 0.4rem 0.8rem !important;
    background: none;
}

#booking-form div.sb__form button.sb__guests-add-room.sb-custom-icon-color.sb-custom-add-room-box-shadow-color {
    background: none;
}

/*
*   9.0 Contacts
*/
/*
.form-contacts {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    grid-template-rows: auto;
    gap: 1rem;
}
.form-contacts .content-column {
    grid-column: 1 / -1;
    grid-row: auto;
    display: inline-flex;
    align-items: center;
}
.form-contacts .content-column.one_half {
    grid-column: span 1;
}*/
.form-contacts .content-column.one_half input {
    max-width: 25rem;
}

.form-contacts .content-column input,
.form-contacts .content-column select,
.form-contacts textarea,
.form-contacts div.privacy span.wpcf7-list-item input {
    border: 0.1rem solid #000000;
    padding: 0 0.7rem;
    margin-left: 1rem;
}

.form-contacts .content-column select {
    padding-right: 2rem;
    background-position: right 0.5rem top 60%;
}

.form-contacts .content-column input:focus,
.form-contacts .content-column select:focus,
.form-contacts .content-column textarea:focus {
    outline: 0 !important;
}

.form-contacts .content-column .your-message,
.form-contacts .content-column .your-message textarea {
    width: 100%;
    margin: 0;
}

.form-contacts div.privacy span.wpcf7-list-item,
.form-contacts div.privacy span.wpcf7-list-item input {
    margin-left: 0;
}

.form-contacts div.privacy span.wpcf7-list-item input {
    margin-right: 1rem;
}

/*
*   10.0 Comparatore
*/
#pc_maincontainer h2.pc_title {
    z-index: 10;
    position: relative;
    background: #F6F7F8;
    width: auto;
    margin: -6rem auto 0;
    display: table;
    padding: 4rem 8rem 1rem;
    border-radius: 1rem 1rem 0 0;
}

.resident-manager-image {
    max-width: 100px !important;
}

/*
*   11.0 Services rating
*/
.services-rating {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    align-items: end;
}

.services-rating .single-service-rating .single-service-rating-description {
    display: flex;
    align-items: center;
    margin-bottom: 0.5rem;
}

.services-rating .single-service-rating .single-service-rating-description .single-service-rating-description-name {
    font-size: 1.8rem;
}

.services-rating .single-service-rating .single-service-rating-description .single-service-rating-description-value {
    color: #8A93A7;
    margin: 0 0 0 auto;
}

.services-rating .single-service-rating .single-service-rating-description i {
    margin-left: 1rem;
    color: rgba(33, 150, 83, 1);
}

.services-rating .single-service-rating .single-service-rating-chart {
    height: 1.4rem;
    background: rgba(163, 205, 203, 0.6);
    display: flex;
    flex-flow: column;
}

.services-rating .single-service-rating .single-service-rating-chart .single-service-rating-chart-loading {
    height: 100% !important;
    background: rgba(163, 205, 203, 1);
}

.services-rating .single-service-rating.evidence .single-service-rating-chart {
    background: rgba(33, 150, 83, 0.6);
}

.services-rating .single-service-rating.evidence .single-service-rating-chart .single-service-rating-chart-loading {
    background: rgba(33, 150, 83, 1);
}

/*
*   12.0 Custom gallery
*/
.custom-gallery-wrapper {
    padding: 2rem;
    display: grid;
    grid-template-columns: 3fr 2fr;
    grid-template-rows: repeat(2, 1fr);
    gap: 2rem;
}

.custom-gallery-wrapper .enable-fullscreen {
    position: absolute;
    max-width: 6rem;
    height: auto;
    right: 3rem;
    bottom: 6rem;
    cursor: pointer;
}

.custom-gallery-wrapper .gallery-wrapper-image-single:not(.gallery-wrapper-image-video) {
    cursor: pointer;
}

.custom-gallery-wrapper .gallery-wrapper-image-single:first-of-type {
    grid-column: 1;
    grid-row: 1 / 3;
}

.custom-gallery-wrapper .gallery-wrapper-image-single video,
.custom-gallery-wrapper .gallery-wrapper-image-single figure,
.custom-gallery-wrapper .gallery-wrapper-image-single figure img {
    border-radius: 1rem;
}

.custom-gallery-wrapper .gallery-wrapper-image-single.gallery-wrapper-image-0 {
    max-height: 42rem;
}

.custom-gallery-wrapper .gallery-wrapper-image-single:not(.gallery-wrapper-image-0) {
    max-height: 20rem;
}

.filters-gallery-list-navigation {
    display: flex;
    flex-flow: row;
    justify-content: flex-end;
}

.gallery-container-wrapper .enable-slide {
    overflow: hidden;
    position: relative;
}

.gallery-container-wrapper-category.enable-slide .swiper-button-prev,
.gallery-container-wrapper-category.enable-slide .swiper-button-next {
    position: absolute;
    top: 50%;
    background: #fff;
    z-index: 1;
    margin: 0 !important;
}

.gallery-container-wrapper-category.enable-slide .swiper-button-prev {
    left: 0;
}

.gallery-container-wrapper-category.enable-slide .swiper-button-next {
    right: 0;
}

.custom-gallery-wrapper .custom-gallery-label {
    position: absolute;
    left: 0;
    top: 5rem;
    background: #5D7CFB;
    color: #FFFFFF !important;
    box-shadow: 0px 2px 20px rgba(138, 147, 167, 0.3);
    border-radius: 3rem;
    font-weight: bold;
    font-size: 1.4rem;
    padding: 0 1.5rem;
    line-height: 3.5rem;
}

/*
*   13.0 Gallery
*/
.standard-gallery-wrapper {
    display: flex;
    flex-flow: column;
    gap: 50px;
    margin: 50px 0;
}

.standard-gallery-wrapper .gallery-filters {
    display: flex !important;
    flex-flow: row;
    flex-wrap: wrap;
    gap: 10px;
}

.standard-gallery-wrapper .gallery-filters button:not(:hover):not(:active):not(.has-background),
.standard-gallery-wrapper .gallery-filters button,
.standard-gallery-wrapper .gallery-filters button:active,
.standard-gallery-wrapper .gallery-filters button:focus,
.standard-gallery-wrapper .gallery-filters button:visited {
    margin: 0;
    background: transparent;
    color: var(--link-color);
    border: 1px solid var(--link-color);
}

.standard-gallery-wrapper .gallery-filters button.active:not(:hover):not(:active):not(.has-background),
.standard-gallery-wrapper .gallery-filters button.active,
.standard-gallery-wrapper .gallery-filters button:hover {
    background: var(--link-color);
    color: #ffffff;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category:not(:last-of-type) {
    padding-bottom: 50px;
    border-bottom: 1px solid rgba(138, 147, 167, 0.3);
}

.standard-gallery-wrapper .standard-gallery-wrapper-category img {
    /* border-radius: 10px; */
    cursor: pointer;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide {
    max-width: 480px;
    margin: 0 30px 0 0;
}

.standard-gallery-wrapper.gallery-container-image .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide {
    max-height: 380px;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category .swiper-slide h3 {
    margin: 10px 0;
}

.standard-gallery-wrapper hr {
    background: #8A93A7;
    opacity: 0.3;
    width: 100%;
}

.standard-gallery-wrapper-category.image {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    grid-template-rows: minmax(40px, 1fr);
    gap: 15px;
}

.standard-gallery-wrapper-category.image h2 {
    grid-column: 1/-1;
}

.standard-gallery-wrapper-category.image .single-image {
    position: relative;
    max-height: 300px;
}

.standard-gallery-wrapper-category.image .single-image span.panorama-widget {
    position: absolute;
    z-index: 1;
    right: 1.5rem;
    top: 1.5rem;
    width: 4rem;
    height: 4rem;
    background-color: var(--link-color);
    padding: 0.8rem;
    border-radius: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

.standard-gallery-wrapper-category.image .single-image span.panorama-widget:hover {
    background-color: var(--link-color-hover);
}

.standard-gallery-wrapper-category.image .single-image span.panorama-widget svg {
    fill: #ffffff;
}

.standard-gallery-wrapper-category.image .single-image:nth-of-type(1n+16) {
    display: none;
}

.standard-gallery-wrapper-category.image .single-image figure {
    margin: 0;
    height: 100%;
    width: 100%;
}

.standard-gallery-wrapper-category.image .single-image figure img {
    object-fit: cover;
    object-position: center;
    height: 100%;
    width: 100%;
    max-height: -webkit-fill-available;
}

.standard-gallery-wrapper-category.image span.description {
    position: absolute;
    right: 12px;
    left: auto;
    bottom: 12px;
    top: auto;
    z-index: 1;
    background: var(--link-color);
    color: #ffffff;
    padding: 10px 12px;
    margin-left: 12px;
    border-radius: 5px;
    cursor: pointer;
    font-size: 15px;
    line-height: 15px;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

.standard-gallery-wrapper-category.image span.description>i {
    font-size: 18px;
}

.standard-gallery-wrapper-category.image span.description.active>i {
    display: none;
}

.standard-gallery-wrapper-category.image span.description:not(.active)>span.text {
    display: none;
}


.standard-gallery-wrapper-category.image figure.cta img {
    filter: blur(5px);
    -webkit-filter: blur(5px);
    z-index: 2;
}

.standard-gallery-wrapper-category.image figure figcaption {
    display: none;
}

.standard-gallery-wrapper-category.image .overlay-cta {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    flex-flow: column;
    z-index: 3;
    cursor: pointer;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
}

.standard-gallery-wrapper-category.image .overlay-cta span {
    margin: auto;
    width: auto;
    padding: 10px 20px;
    text-align: center;
    justify-content: center;
    color: #ffffff;
    cursor: pointer;
    background: var(--link-color);
    text-transform: uppercase;
    -webkit-transition: all 0.5s ease;
    -moz-transition: all 0.5s ease;
    -ms-transition: all 0.5s ease;
    -o-transition: all 0.5s ease;
    transition: all 0.5s ease;
}

.standard-gallery-wrapper-category.image .overlay-cta:hover span {
    background: var(--link-color-hover);
}

.standard-gallery-wrapper-category.image .overlay-cta.overlay-cta-play {
    color: #fff;
    font-size: 7rem;
    justify-content: center;
    align-items: center;
    background-color: rgba(0, 0, 0, 0.3);
}

.lead-generation-slide {
    width: 100%;
    height: 100%;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    padding: 0 40px;

    background-image: url('/wp-content/uploads/2021/11/last-image-gallery-message.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.lead-generation-content-description {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 100px 50px;
}

.lead-generation-content-description .lead-generation-icon {
    font-size: 80px;
    margin-bottom: 40px;
    text-align: center;
}

.standard-gallery-wrapper-category.image figure.cta .overlay-cta a.btn::after {
    display: none !important;
    visibility: hidden !important;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide iframe {
    height: 300px !important;
    margin-bottom: 10px;
}

.rll-youtube-player .play {
    width: 100% !important;
}

.swiper-slide .video-rate i {
    font-size: 20px !important;
}

.swiper-slide>.video-title {
    font-weight: bold !important;
    font-size: 24px !important;
    line-height: 31px !important;
    color: #484B5C !important;
}

.standard-gallery-wrapper-category.enable-slide .swiper-button-prev,
.standard-gallery-wrapper-category.enable-slide .swiper-button-next {
    position: absolute;
    top: 50%;
    background: #fff;
    z-index: 1;
    margin: 0 !important;
}

.standard-gallery-wrapper-category.enable-slide .swiper-button-next {
    right: 0;
}

.standard-gallery-wrapper-category.enable-slide .swiper-button-prev {
    left: 0;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category {
    overflow: hidden;
    position: relative;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide {
    max-width: 480px;
    margin: 0 30px 0 0;
}

.standard-gallery-wrapper .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide iframe {
    height: 300px !important;
    margin-bottom: 10px;
}

.standard-gallery-wrapper.gallery-container-image .standard-gallery-wrapper-category.swiper-horizontal .swiper-slide {
    max-height: 380px;
}

@media (max-width: 600px) {
    .standard-gallery-wrapper-category.image {
        gap: 5px !important;
        grid-template-columns: repeat(2, 1fr);
    }

    .standard-gallery-wrapper-category.image span.description {
        -webkit-transition: none;
        -moz-transition: none;
        -ms-transition: none;
        -o-transition: none;
        transition: none;
        right: 5px;
        bottom: 5px;
    }

    .standard-gallery-wrapper-category.image span.description.active {
        width: 100%;
        height: 100%;
        left: 0;
        right: 0;
        bottom: 0;
        top: 0;
        margin: 0;
        border-radius: 0;
        display: flex;
        justify-content: center;
        align-items: center;
        text-align: center;
    }

    .standard-gallery-wrapper .standard-gallery-wrapper-category.swiper-container-horizontal .swiper-slide {
        max-width: 290px;
        max-height: unset;
    }
}

.overlay-cta {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    flex-flow: column;
    z-index: 3;
    cursor: pointer;
}

.gallery-container-wrapper-category.image figure.cta .overlay-cta a.btn {
    margin: auto !important;
    width: fit-content !important;
}

.lead-generation-slide {
    width: 100%;
    height: 100%;
    display: flex;
    flex-flow: column;
    justify-content: center;
    align-items: center;
    padding: 0 4rem;

    background-image: url('/wp-content/uploads/2021/11/last-image-gallery-message.jpg');
    background-repeat: no-repeat;
    background-size: cover;
    background-position: center;
}

.lead-generation-content-description {
    background-color: rgba(255, 255, 255, 0.8);
    padding: 10rem 5rem;
}

.lead-generation-content-description .lead-generation-icon {
    font-size: 8rem;
    margin-bottom: 4rem;
    text-align: center;
}

.gallery-container-wrapper-category.image figure.cta .overlay-cta a.btn::after {
    /* margin-left: 0.5rem; */
    display: none !important;
    visibility: hidden !important;
}

.gallery-container-wrapper .gallery-container-wrapper-category.swiper-container-horizontal .swiper-slide iframe {
    height: 30rem !important;
    margin-bottom: 1rem;
}

.rll-youtube-player .play {
    width: 100% !important;
}

body button.pswp__button {
    border: none !important;
    margin: 0 !important;
    background: transparent !important;
}

body button.pswp__button.pswp__button--close,
body button.pswp__button.pswp__button--zoom {
    margin: 0 20px 0 0 !important;
}

body .pswp__custom-caption {
    background-color: rgba(255, 255, 255, .9);
    width: 100%;
    max-width: 500px;
    padding: 2px 10px;
    position: absolute;
    left: 50%;
    bottom: 10px;
    transform: translateX(-50%);
    color: #000;
    font-size: 14px;
    border-radius: 1px;
}

.pswp__360-image-container {
    position: relative;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.pswp__360-image-container iframe {
    background: #444;
    width: 100%;
    height: 100%;
    max-width: calc(100vw - 20rem);
    max-height: 100vh;
    pointer-events: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    border: none !important;
}

.pswp__video-container {
    position: relative;
    width: 100%;
    height: 100%;
    pointer-events: none;
}

.pswp__video-container video {
    width: 100%;
    height: 100%;
    max-width: calc(100vw - 20rem);
    max-height: 100vh;
    pointer-events: auto;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}


.rotate-device {
    position: fixed;
    background-color: #000000;
    width: 100%;
    height: 100%;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    z-index: 99999;
    display: none;
    justify-content: center;
    align-items: center;
    flex-direction: column;
    gap: 4rem;
    color: #fff;
}

.rotate-device.show {
    display: flex;
}

.rotate-device .phone {
    height: 5rem;
    width: 10rem;
    border: 0.3rem solid white;
    border-radius: 1rem;
    animation: rotate-device 4s ease-in-out infinite;
}

.rotate-device a,
.rotate-device a:active,
.rotate-device a:focus,
.rotate-device a:visited,
.rotate-device a:hover {
    color: #fff;
    letter-spacing: normal;
    padding: 10px 30px;
}

@keyframes rotate-device {
    0% {
        transform: rotate(-90deg)
    }

    70% {
        transform: rotate(0deg)
    }

    100% {
        transform: rotate(-90deg)
    }
}

/*
*   14.0 Breadcrumbs
*/
p#breadcrumbs {
    padding: 2rem 2rem 2rem 4rem;
    grid-column: -2 / 2;
    grid-row: 1;
    z-index: 9;
    position: relative;
}

body.single-room p#breadcrumbs {
    padding-left: 0;
    top: -35px !important;
}

p#breadcrumbs,
p#breadcrumbs a,
p#breadcrumbs a:active,
p#breadcrumbs a:focus,
p#breadcrumbs a:visited {
    color: #8A93A7;
    font-size: 1.1rem;
    line-height: 1.5rem;
    font-weight: 400;
}

p#breadcrumbs>span {
    gap: 1rem;
    display: flex;
    align-items: center;
}

p#breadcrumbs>span>span {
    max-width: 20rem;
}

p#breadcrumbs>span i.fa-home {
    font-size: 1.5rem;
}

p#breadcrumbs span span:not(.breadcrumb_last):hover,
p#breadcrumbs span span:not(.breadcrumb_last):hover a {
    text-decoration: underline;
    text-underline-offset: 3px;
    color: var(--link-color);
}

p#breadcrumbs span.divider {
    font-size: 2rem;
}

p#breadcrumbs span.breadcrumb_last {
    font-weight: 800;
    text-decoration: none !important;
}

/*
*   15.0 Single box
*/
.single-box {
    display: grid;
    grid-template-columns: 3fr 2fr;
    grid-template-rows: auto;

    border-radius: 10px;
    border: 1px solid #C4C4C4;
    background: #FFF;
    box-shadow: 0px 4px 10px 0px rgba(0, 0, 0, 0.25);
    max-width: 100rem;
    width: 100%;
    margin: 3rem auto;
    padding: 5rem;
    gap: 5rem;
}

.single-box.single-box-offer {
    grid-template-columns: 2fr 3fr;
}

.single-box figure,
.single-box figure img {
    border-radius: 1rem;
    min-height: 31rem;
}

.single-box.single-box-room figure {
    grid-column: 2;
}

.single-box.single-box-room .content {
    grid-column: 1;
    grid-row: 1;
}

.single-box .content h2 {
    margin-bottom: 2.5rem;
}

.single-box .content h2 i {
    margin-right: 1.5rem;
}

.single-box .content h2::after {
    content: "";
    width: 4.2rem;
    height: 0.2rem;
    background: #878A8F;
    display: block;
    margin-top: 2.5rem;
}

.single-box .content ul.features-list {
    padding: 0;
    display: flex;
    flex-flow: wrap;
    -ms-flex-flow: wrap;
    gap: 1.5rem;
    list-style: none;
    margin-bottom: 2.5rem;
    color: #8A93A7;
    align-items: center;
}

.single-box .content ul.features-list li:not(:last-of-type) {
    padding-right: 1.5rem;
    border-right: 0.1rem solid #DCDFE5;
}

.single-box .content ul.features-list li {
    display: flex;
    justify-content: center;
    align-items: center;
}

.single-box .content ul.features-list li.feature-box-text {
    color: #27AE60;
    font-weight: 700;
}

.single-box .content a.btn,
.single-box .content a.btn:active,
.single-box .content a.btn:focus,
.single-box .content a.btn:visited,
.single-box .content a.btn:hover {
    display: inline-block !important;
}

/*
*   16.0 Sharing buttons
*/
body a.btn-share,
body a.btn-share:visited,
body a.btn-share:focus,
body a.btn-share:active {
    display: inline-flex !important;
    gap: 1rem !important;
    justify-content: center !important;
    align-items: center !important;
    margin: 0 auto !important;
    background: #F6F7F8 !important;
    box-shadow: 0 0.4rem 1rem 0 rgba(0, 0, 0, 0.25) !important;
    color: var(--link-color) !important;
}

body a.btn-share:hover {
    color: #ffffff !important;
    background: var(--link-color-hover) !important;
}

body a.btn-share::after {
    display: none !important;
}

body a.btn-share.sharing-button {
    position: fixed !important;
    top: 30rem !important;
    right: 4rem !important;
    width: 4.5rem !important;
    height: 4.5rem !important;
    border-radius: 100% !important;
    border: 0.1rem solid var(--link-color);
    z-index: 99;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #ffffff;
}

div.sharing-buttons-content {
    position: fixed;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, .9);
    z-index: 9999999999;
    display: flex;
    justify-content: center;
    align-items: center;
}

div.sharing-buttons-content:not(.active) {
    display: none !important;
}

div.sharing-buttons-content .content {
    max-width: 41rem;
    border-radius: 1rem;
    background-color: #fff;
    box-shadow: 0 0.4rem 1rem 0 rgba(0, 0, 0, 0.25);
    width: 100%;
    padding: 3rem;
    margin: auto;
    position: relative;
    text-align: center;
    max-height: 90vh;
    overflow-x: auto;

    display: flex;
    gap: 1rem;
    flex-direction: column;
    justify-content: center;
    align-items: flex-start;
}

div.sharing-buttons-content .content>span.close {
    position: absolute;
    right: 1.5rem;
    top: 1rem;
    font-size: 2rem;
    cursor: pointer;
}

div.sharing-buttons-content .content>a.btn-share-social,
div.sharing-buttons-content .content>a.btn-share-social:active,
div.sharing-buttons-content .content>a.btn-share-social:focus,
div.sharing-buttons-content .content>a.btn-share-social:visited {
    border: 0.06rem solid var(--htv-blue);
    background: #FFF !important;
    width: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    color: var(--htv-blue) !important;
    padding: 0.5rem 1rem;
    font-size: 1.4rem !important;
    font-weight: 400 !important;
    line-height: 2.6rem !important;
    border-radius: 1rem;
    margin: 0;
}

div.sharing-buttons-content .content>a.btn-share-social:hover {
    background: var(--htv-blue) !important;
    color: #ffffff !important;
}

/*
*   17.0 Energy saver
*/
:root body.energy-saver-lock {
    overflow: hidden !important;
}

#energy-saver {
    position: fixed;
    z-index: 9999999999999;
    top: 0;
    bottom: 0;
    left: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 1);
    display: none;

    justify-content: center;
    align-items: center;
    padding: 3rem;
    text-align: center;
    overflow-x: auto;
    color: #ffffff;
    max-height: 100vh;
}

#energy-saver.active {
    display: flex;
}

#energy-saver .energy-saver-content {
    max-width: 90rem;
}

#energy-saver .energy-saver-content img.energy-saver-logo {
    max-width: 25rem;
    height: auto;
    width: 100%;
    margin-bottom: 2rem;
}

#energy-saver .energy-saver-content .title {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 1rem;
    margin: 3rem auto;
    font-family: var(--global--font-primary);
    font-weight: 600;
    font-size: var(--heading--font-size-h2);
    letter-spacing: var(--heading--letter-spacing-h2);
    line-height: var(--heading--line-height-h2);
    color: #ffffff;
}

#energy-saver .energy-saver-content a.btn,
#energy-saver .energy-saver-content a.btn:active,
#energy-saver .energy-saver-content a.btn:focus,
#energy-saver .energy-saver-content a.btn:visited {
    color: #ffffff;
}

#energy-saver .energy-saver-content a.btn,
#energy-saver .energy-saver-content a.btn:active,
#energy-saver .energy-saver-content a.btn:focus,
#energy-saver .energy-saver-content a.btn:visited,
#energy-saver .energy-saver-content a.btn:hover {
    margin-top: 1.5rem !important;
    display: inline-block !important;
}

#energy-saver #pc_maincontainer .pc_title,
#energy-saver #pc_maincontainer .pc_stayLegend {
    color: #ffffff;
}

#energy-saver #pc_maincontainer .pc_title {
    margin-top: 0;
    background: transparent;
}


/*
*   18.0 Thank you page
*/
body .button-thankyou-page a.btn {
    margin: 0 !important;
}

.button-thankyou-page {
    margin-top: 30px;
    margin-bottom: 30px;
}

.box-thankyou {
    border-radius: 30px;
}





/* ACCORDION SERVIZI CAMERE*/
.list-services-accordion li {
    flex: 1 1 50%;
}

@media(max-width: 768px) {
    .list-services-accordion li {
        flex: 1 1 50%;
        display: none;
    }

    .list-services-accordion li:nth-of-type(-n+6) {
        display: flex !important;
    }
}

.list-services-accordion li.show-more span {
    color: var(--link-color) !important;
    font-weight: 800 !important;
}

.list-services-accordion li.show-more.show span:not(.text) {
    transform: rotate(180deg);
}

/*
* 19.0 DMS AI PAGE
*/

.column-1-3-dms {
    /*width: 30%;*/
}

.row-dms {
    width: 100%;
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    column-gap: 3%;
    margin-bottom: 20px;
}

.single-item-dms {
    transition: 0.2s ease-out;
    box-shadow: 0px 2px 4px -1px rgba(0, 0, 0, 0.2), 0px 4px 5px 0px rgba(0, 0, 0, 0.14), 0px 1px 10px 0px rgba(0, 0, 0, 0.12);
    border-radius: 1rem;
    overflow: hidden;
    margin: 0 auto;
    display: block;
    font-size: 15px;
    height: 55vh;
    display: flex;
    flex-direction: column;
}

.dms-bottom-excerpt h3 {
    font-family: 'Open Sans' !important;
    font-size: 15px !important;
    line-height: 1.8rem !important;
}

.dms-bottom-excerpt {
    font-family: 'Open Sans' !important;
    font-size: 15px !important;
    line-height: 1.8rem !important;
    font-weight: normal;
}

.row-single-upper {
    height: 40%;
    position: relative;
    width: 100%;
}

.row-single-bottom.second {
    height: 40%;
    padding: 2rem;
}

.row-single-bottom.third {
    height: 20%;
    padding-left: 2rem;
    padding-right: 2rem;
    padding-top: 0px;
    display: flex;
    flex-direction: row;
    justify-content: center;
    align-items: center;
}

.dms-bottom-title {
    text-align: left;
    color: black;
}

.dms-bottom-title h3 {
    font-family: 'Reem Kufi' !important;
    text-transform: uppercase;
    font-size: 18px !important;
    line-height: 1.75rem !important;
}

.dms-bottom-excerpt {
    color: black;
}

.dms-bottom-excerpt p {
    font-family: 'Open Sans' !important;
    font-size: 15px !important;
    line-height: 1.5rem !important;
}

.dms-bottom-button .btn.offers-list-container-single-button.mobile-action {
    margin-bottom: 0px !important;
    margin-top: 0px !important;
}

.post-dms-container {
    display: flex;
    flex-direction: row;
    column-gap: 3%;
    min-height: 1000px;
    align-items: flex-start;
}

.column-left-dms {
    width: 30%;
    position: sticky;
    top: 200px;
    /* Distanza dalla parte superiore della pagina */
    z-index: 100;
    /* Assicurati che rimanga sopra altri elementi */
}

.column-right-dms {
    width: 60%;
}

.row-single-upper img {
    display: block;
    width: 100%;
    height: auto;
}

.column-1-3-dms .linksinglepost {
    height: 100%;
}

.img-category {
    position: absolute;
    top: 5px;
    left: 5px;
    width: 30px !important;
    background: white;
    padding: 5px;
    z-index: 10;
    /* Metti un valore più alto per sovrapporre */
}

.category-filter {
    background-color: #f5f5f5;
    border: 1px solid #ddd;
    padding: 10px;
    border-radius: 10px;
    width: 250px;
    font-family: 'Arial', sans-serif;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
    margin: auto;
}

.category-list {
    list-style: none;
    padding: 0;
    margin: 0;
    display: none;
    /* Nasconde la lista delle categorie inizialmente */
}

.category-list li {
    display: flex;
    align-items: center;
    padding: 8px 0;
    cursor: pointer;
    transition: background-color 0.3s;
}

.category-list li:hover {
    background-color: #eee;
}

.category-list img {
    width: 24px;
    height: 24px;
    margin-right: 10px;
}

.category-list span {
    font-size: 14px;
    color: #555;
}

.category-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 14px;
    font-weight: bold;
    color: #333;
    cursor: pointer;
    padding-bottom: 10px;
}

.toggle-icon {
    font-size: 12px;
    transition: transform 0.3s ease;
}

.category-filter.open .toggle-icon {
    transform: rotate(180deg);
    /* Ruota l'icona quando la lista è aperta */
}

.featured-image-single {
    width: -webkit-fill-available !important;
    height: -webkit-fill-available !important;
    object-fit: cover !important;
}

#load-more-posts {
    display: inline-block;
    padding: 10px 20px;
    background-color: #333;
    color: #fff;
    border: none;
    cursor: pointer;
    margin-top: 20px;
    font-size: 16px;
    border-radius: 4px;
}

#load-more-posts:hover {
    background-color: #555;
}

.button-load-more-dms {
    text-align: center;
}

/*
 * Single Post
 */
.single-post-container {
    display: flex;
    flex-direction: row;
    padding: 5vh;
    column-gap: 5vw;
}

.single-post-header .breadcrumb_last {
    max-width: unset !important;
}

.single-post-half-column {
    width: 50%;
}

.single-post-img img {
    max-width: 100% !important;
}

.booking-button-single-post {
    margin: auto;
    text-align: center;
}

.single-post-img {
    text-align: center;
    margin: auto;
}


/*
* 20.0 Keplero Chat
*/
.chatbot-keplero {
    width: 100dvw;
    height: calc(100dvh - 86px);
    position: fixed;
    top: 0;
    left: 0;
    z-index: 500;
}

.chatbot-keplero-hidden {
    display: none;
}

.chatbot-keplero-visible {
    display: block;
}

#chat-text-open {
    display: block;
}

#chat-text-close {
    display: none;
}

@media screen and (min-width: 1044px) {
    .chatbot-keplero {
        /*display: none !important;*/
    }
}

@media screen and (max-width: 1044px) {
    #chatbot-keplero-desktop {
        display: none !important;
    }
}

/* fix booking quote form */
#simplebookingQuote>iframe {
    max-height: unset !important;
}

/*
*   21.0 ImageMap Pro
*/
.imagemapro-image {
    max-width: 15rem;
}

/* 22.0 Ricerca conversazionale*/

.chat-container {
    background-color: #fff;
    width: 60vw;
    border-radius: 10px;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    min-height: 500px;
    margin: auto !important;
}

.chat-header {
    padding: 20px;
    text-align: center;
    font-size: 18px;
    font-size: 36px;
    font-weight: bold;
}

.sub-chat-header {
    background: linear-gradient(to right, #3a5bdb, #7a53ce, #ff6090);
    -webkit-background-clip: text;
    color: transparent;
}

.sub-chat-header-colorless {
    color: #202446;
}

.entry-chats-wrapper {
    display: flex;
    justify-content: space-around;
    padding: 10px;

}

.entry-chat {
    background-color: #dbe6f6;
    padding: 30px;
    border-radius: 5px;
    cursor: pointer;
    text-align: center;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    min-height: 250px;
    width: 250px;
}

.entry-chat-icon {
    height: 20px;
    align-self: flex-end;
    background-color: white;

}

.entry-chat-icon-wrap {
    align-self: flex-end;
    padding: 10px;
    border-radius: 40px;
    background: white;
}

.chat-box {
    flex-grow: 1;
    padding: 20px;
    overflow-y: auto;
    border-top: 1px solid #ccc;
}

.input-area-conver {
    display: flex;
    align-items: center;
    background-color: #eef5ff;
    border-radius: 30px;
    padding: 10px;
    width: 100%;
    margin: 20px auto;
    box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.1);
}

#user-input-conver {
    flex-grow: 1;
    border: none;
    background-color: transparent;
    font-size: 16px;
    padding: 10px;
    outline: none;
    color: #202446;
    margin-right: 10px;
}

#send-btn-conver {
    background-color: #1e407c;
    border: none;
    border-radius: 50%;
    width: 40px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items: center;
    cursor: pointer;
    position: relative;
}

#send-btn-conver img {
    width: 20px;
    height: 20px;
    object-fit: contain;
    position: absolute;
}

#send-btn-conver:hover {
    background-color: #143055;
}

/* Messaggi della chat */
.chat-message {
    margin-bottom: 15px;
    display: flex;
}

.chat-message.user {
    justify-content: flex-end;
}

.chat-message.system {
    justify-content: flex-start;
}

.chat-message .message-content {
    max-width: 60%;
    padding: 10px;
    border-radius: 10px;
}

.chat-message.user .message-content {
    background-color: #007bff;
    color: white;
    text-align: right;
}

.chat-message.system .message-content {
    background-color: #e9ecef;
}

/* Pallini di caricamento */
.loading {
    display: flex;
    justify-content: flex-start;
    padding: 10px;
}

.dot {
    height: 10px;
    width: 10px;
    margin: 5px;
    border-radius: 50%;
    background-color: #007bff;
    animation: bounce 1.2s infinite;
}

.dot:nth-child(2) {
    animation-delay: 0.2s;
}

.dot:nth-child(3) {
    animation-delay: 0.4s;
}

@keyframes bounce {

    0%,
    20%,
    50%,
    80%,
    100% {
        transform: translateY(0);
    }

    40% {
        transform: translateY(-10px);
    }

    60% {
        transform: translateY(-5px);
    }
}

/* Classe per nascondere l'elemento */
.hidden {
    display: none;
}

/* Stile per l'icona invio */
.arrow-sending-conver {
    width: 20px;
    height: 20px;
}

#chat-text-open {
    display: block;
}

#chat-text-close {
    display: none;
}

/*
* A/B test
*/
.booking-button-menu a {
    background-color: #2a71bc !important;
    padding: 15px 20px !important;
    border-radius: 10px;
    text-transform: uppercase;
    font-weight: 700 !important;
    color: white !important;
}

.primary-navigation>div>.menu-wrapper li,
.primary-navigation>div>.menu-wrapper li.booking-button-menu a {
    font-size: 15px !important;
}

.booking-button-menu {
    margin-top: 30px !important;
}

.h3-conversazionale {
    font-size: 20px !important;
    margin-bottom: 0px !important;
}

/* 23.0 FAQS OPEN ROSETTA*/

.faq-container {
    display: flex;
    flex-wrap: wrap;
    gap: 20px;
}

.faq-category-or {
    width: calc(50% - 20px);
    /* Due colonne */
    margin-bottom: 20px;
}

.faq-category-title-or {
    font-size: 18px;
    margin-bottom: 10px;
}

.accordion-or {
    border: 1px solid #ccc;
    /* Bordino attorno all'accordion */
    border-radius: 2px;
    margin-bottom: 10px;
    overflow: hidden;
}

.accordion-header-or {
    display: flex;
    justify-content: space-between;
    align-items: center;
    padding: 10px;
    background-color: #ffffff;
    cursor: pointer;
}

.accordion-question-or {
    text-align: left;
    flex-grow: 1;
    /* Occupa tutto lo spazio disponibile */
    line-height: 1.8;
    font-size: 1.2em;
    font-family: 'Reem Kufi', sans-serif !important;
    color: #39414D !important;
}

.accordion-icon-or {
    font-size: 12px;
    margin-left: 10px;
    transform: rotate(0);
    transition: transform 0.3s;
}

.accordion-or.active .accordion-icon-or {
    transform: rotate(180deg);
    /* Ruota l'icona quando attivo */
}

.accordion-content-or {
    padding: 10px;
    display: none;
    border-top: 1px solid #ccc;
    /* Bordino tra domanda e risposta */
}










form#newsletterForm {
    max-width: 700px;
    display: grid;
    grid-template-rows: 2fr 1fr;
    row-gap: 12px;
}

.news-cont-1 {
    display: grid;
    grid-template-columns: 1.8fr 1fr;
    grid-template-rows: 1fr 1.6fr;
    column-gap: 10px;
}

.news-cont-1 button {
    grid-column: 2;
    grid-row: 2 / 3;
    min-width: 100%;
    display: grid !important;
    justify-items: center;
    justify-content: center;
    align-items: center;
    align-content: center;
}

.news-cont-1 input#email {
    grid-column: 1;
    border-width: 1px;
    margin: 0px;
    border-radius: 5px;
    border-color: grey;
}

span#psnewsShort,
span#psnewsShort a {
    font-size: 12px;
    line-height: 12px !important;
}

form#newsletterForm button {
    background: #6DA6D0 !important;
    border-radius: 5px;
}

input#privacy {
    width: 20px;
    height: 20px;
    border-width: 2px;
}

label.label-email {
    font-weight: 700;
    font-size: 18px;
    color: #173A68;
}

.news-cont-2 {
    display: flex;
    justify-content: flex-start;
    align-items: center;
    gap: 10px;
}

h1#result {
    font-size: 20px;
    color: green;
}

/*
*   24.0 Landing
*/
body.page-template-template-landing div.entry-content div.grids-section.landing-header>.grids-s-w_i {
    min-height: 70rem;
}

body.page-template-template-landing div.entry-content div.grids-section.landing-header>.grids-s-w_i .grids-area {
    background-color: rgba(0, 0, 0, 0.7);
    border-radius: 10px;
    padding: 40px;
    height: auto;
    margin: auto auto 0;
    max-width: 660px;
}

body.page-template-template-landing div.entry-content div.grids-section.landing-header>.grids-s-w_i .grids-area p.header-title {
    font-family: var(--global--font-primary);
    font-size: 40px;
    font-weight: 400;
    line-height: 50px;
}

body.page-template-template-landing div.entry-content div.grids-section.landing-header .wp-block-button:not(.is-style-outline) .wp-block-button__link:hover,
body.page-template-template-landing div.entry-content div.grids-section.landing-header .wp-block-button:not(.is-style-outline) .wp-block-button__link:active {
    color: #fff !important;
    background-color: #6DA6D0 !important;
    border-color: #6DA6D0 !important;
}


.primary-navigation-open .menu-button-container {
	width: fit-content;
	z-index: 500;
	background-color: var(--global--color-background);
}

/* 25.0 Authors Page */

/* Layout generale */
.template-autore-container {
    max-width: 1200px;
    margin: 0 auto;
    padding: 25% 20px 10% 20px;
}

@media screen and (max-width: 768px){
    .template-autore-container {
        padding: 40% 20px 10% 20px;
    }
}


/* Header autore */
.autore-header {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    margin-bottom: 60px;
}

.autore-info {
    flex: 1 1 60%;
    padding-right: 20px;
}

.autore-logo {
    flex: 1 1 35%;
    text-align: center;
}

.autore-logo img {
    max-width: 160px;
    height: auto;
}

/* Link autore */
.autore-link a {
    display: inline-block;
    margin: 5px 10px 5px 0;
    color: var(--colore-a);
    font-weight: var(--font-weight-a);
}

/* Titolo sezione articoli */
.lista-articoli-autore h2 {
    text-align: center;
    margin-bottom: 40px;
    font-size: var(--font-size-h2);
}

/* Griglia articoli */
.griglia-articoli {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 30px;
}

/* Card articolo */
.card-articolo {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0px 6px 20px rgba(0,0,0,0.50);
    overflow: hidden;
    display: flex;
    flex-direction: column;
}

.card-thumb img {
    width: 100% !important;
    max-width: 100% !important;
    height: 150px !important;
    object-fit: cover !important;
    display: block;
    border-bottom: 1px solid #eee;
}

.card-content {
    padding: 20px;
    display: flex;
    flex-direction: column;
    justify-content: space-between;
    height: 100%;
}

.card-content h3 {
    font-size: 20px;
    margin-bottom: 10px;
    font-family: var(--font-family-secondary);
}

.card-content .data-pubblicazione {
    font-size: 14px;
    color: #888;
    display: block;
    margin-bottom: 10px;
}

.card-content p {
    font-size: var(--font-size-p-m);
    margin-bottom: 15px;
}

a.btn-azzurro {
    display: inline-flex;
    align-items: center;
    justify-content: space-between;
    padding: 16px 24px;
    background-color: #72ADD6 !important; /* Colore azzurro dal bottone */
    color: white !important;
    font-family: var(--font-family-buttons);
    font-weight: 600 !important;
    font-size: 16px;
    line-height: 1.4;
    text-decoration: none;
    text-transform: uppercase;
    border-radius: 8px;
    min-width: 250px;
    transition: background-color 0.3s ease;
    gap: 10px;
}

a.btn-azzurro:hover {
    background-color: #5A97C2; /* tonalità più scura */
    color: white !important;
}

a.btn-azzurro .freccia {
    font-size: 18px;
}


/* Responsive */
@media screen and (max-width: 768px) {
    .autore-header {
        flex-direction: column;
        text-align: center;
    }

    .autore-info, .autore-logo {
        flex: 1 1 100%;
        padding: 0;
    }

    .autore-logo {
        margin-top: 20px;
    }
}

.paginazione-articoli {
    margin-top: 40px;
    text-align: center;
}

.paginazione-articoli ul.page-numbers {
    display: inline-flex;
    gap: 8px;
    list-style: none;
    padding: 0;
    margin: 0 auto;
}

.paginazione-articoli ul.page-numbers li a,
.paginazione-articoli ul.page-numbers li span {
    display: inline-block;
    padding: 10px 16px;
    background-color: #F5F5F5;
    color: #333;
    border: 1px solid #ddd;
    border-radius: 6px;
    text-decoration: none;
    font-weight: 500;
    transition: all 0.3s ease;
}

.paginazione-articoli ul.page-numbers li a:hover {
    background-color: #72ADD6;
    color: #fff;
    border-color: #72ADD6;
}

.paginazione-articoli ul.page-numbers li .current {
    background-color: #72ADD6;
    color: #fff;
    font-weight: bold;
    border-color: #72ADD6;
    pointer-events: none;
}

/* 26.0 Banner Cross Channel */

.banner-crosschannel .font-lazydog{
    color: white;
    font-weight: 700;
    font-size: 40px;
    font-family: "Shantell Sans", cursive;
    line-height: normal;
}

.banner-crosschannel .grids-area{
    display: flex;
    justify-content: flex-end;
    row-gap: 20px;
    padding-bottom: 20px;
}

.banner-crosschannel .sfondo-azzurro{
    font-family: 'Open Sans';
    font-size: 70px;
    font-weight: 700;
    background: #97e1e4;
    width: fit-content;
    padding: 25px;
    line-height: normal;
}

.banner-crosschannel .sfondo-giallo {
    font-family: 'Open Sans';
    font-size: 70px;
    font-weight: 700;
    background: #FFFF04;
    width: fit-content;
    padding: 25px;
    line-height: normal;
}

.banner-crosschannel .sfondo-bianco-natale {
    font-family: 'Open Sans';
    font-size: 40px;
    font-weight: 700;
    background: white;
    width: fit-content;
    padding: 25px;
    line-height: normal;
    color: #045087;
    font-family: "Shantell Sans", cursive;
}

.banner-crosschannel .grids-s-w_i::before{
    background: linear-gradient(90deg, #3d8489, rgba(92, 109, 109, 0.7), rgba(0, 0, 0, 0), rgba(0, 0, 0, 0)), var(--_gs-bg, var(--_gs-bg-desktop, none));
    background-position-y: 27%;
}

.banner-crosschannel .pulsante-offerta a{
    background-color: #6da6d0 !important;
}

.pulsante-offerta.wp-block-button:not(.is-style-outline) .wp-block-button__link:hover{
    background-color: white !important;
    border-color: #6da6d0 !important;
    color: #6da6d0 !important;
}

@media screen and (max-width: 875px) {

    .banner-crosschannel .grids-area{
        row-gap: 10px !important;;
    }

    .banner-crosschannel .grids-s-w_i{
        justify-content: flex-end !important;
        min-height: 500px !important;
    }
    .banner-crosschannel .sfondo-azzurro{
        font-size: 25px !important;
        line-height: 25px !important;
        padding:15px !important
    }

    .banner-crosschannel .sfondo-giallo{
        font-size: 25px !important;
        line-height: 25px !important;
        padding:15px !important
    }

    .banner-crosschannel .sfondo-bianco-natale{
        font-size: 25px !important;
        line-height: 25px !important;
        padding:15px !important
    }

    .banner-crosschannel .font-lazydog{
        line-height: 20px !important;
        font-size: 20px !important;
    }
    .banner-crosschannel .pulsante-offerta a{
        padding:14px !important;
    }
}