@charset "UTF-8";
/* http://meyerweb.com/eric/tools/css/reset/ 
   v2.0 | 20110126
   License: none (public domain)
*/
@import url("https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@100;200;300;400;500;600;700;800;900&family=Bigelow+Rules&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Big+Shoulders+Display:wght@100;200;300;400;500;600;700;800;900&family=Bigelow+Rules&display=swap");
html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
footer,
header,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline;
}

b,
strong {
  font-weight: bold;
}

/* HTML5 display-role reset for older browsers */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

body {
  line-height: 1;
}

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: "";
  content: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/**
 * @license
 *
 * Font Family: Satoshi
 * Designed by: Deni Anggara
 * URL: https://www.fontshare.com/fonts/satoshi
 * © 2022 Indian Type Foundry
 *
 * Font Styles:
 * Satoshi Variable(Variable font)
 * Satoshi Variable Italic(Variable font)
 * Satoshi Light
 * Satoshi Light Italic
 * Satoshi Regular
 * Satoshi Italic
 * Satoshi Medium
 * Satoshi Medium Italic
 * Satoshi Bold
 * Satoshi Bold Italic
 * Satoshi Black
 * Satoshi Black Italic
 *
*/
/**
* This is a variable font
* You can controll variable axes as shown below:
* font-variation-settings: 'wght' 900.0;
*
* available axes:

* 'wght' (range from 300.0 to 900.0)

*/
/**
* This is a variable font
* You can controll variable axes as shown below:
* font-variation-settings: 'wght' 900.0;
*
* available axes:

* 'wght' (range from 300.0 to 900.0)

*/
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Light.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Light.woff") format("woff"), url("../fonts/satoshi/Satoshi-Light.ttf") format("truetype");
  font-weight: 300;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-LightItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-LightItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-LightItalic.ttf") format("truetype");
  font-weight: 300;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Regular.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Regular.woff") format("woff"), url("../fonts/satoshi/Satoshi-Regular.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Italic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Italic.woff") format("woff"), url("../fonts/satoshi/Satoshi-Italic.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Medium.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Medium.woff") format("woff"), url("../fonts/satoshi/Satoshi-Medium.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-MediumItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-MediumItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-MediumItalic.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Bold.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Bold.woff") format("woff"), url("../fonts/satoshi/Satoshi-Bold.ttf") format("truetype");
  font-weight: 700;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-BoldItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-BoldItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-BoldItalic.ttf") format("truetype");
  font-weight: 700;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Black.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Black.woff") format("woff"), url("../fonts/satoshi/Satoshi-Black.ttf") format("truetype");
  font-weight: 900;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-BlackItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-BlackItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-BlackItalic.ttf") format("truetype");
  font-weight: 900;
  font-display: swap;
  font-style: italic;
}
section {
  overflow: hidden;
}

body {
  font-family: "Satoshi", sans-serif;
  text-rendering: optimizeLegibility;
  font-weight: 400;
  background-color: #fff;
}

*,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
  font-family: inherit;
}

p {
  line-height: inherit;
}

em,
strong {
  font-family: inherit;
}

/* Imposto la font principale. */
.txt {
  font-family: "Satoshi", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.txt.sans {
  font-family: "Satoshi", sans-serif;
}

.txt.mono {
  font-family: "Big Shoulders Display", monospace;
}

.txt.serif {
  font-family: serif;
}

.txt.bold {
  font-weight: 700;
  font-style: normal;
}

.txt.italic {
  font-style: italic;
}

.txt.center {
  text-align: center;
}

.txt.right {
  text-align: right;
}

.txt.left {
  text-align: left;
}

.txt.caps {
  text-transform: uppercase;
}

.bordo {
  border: 1px solid #ccc;
}

.txt.blu-navy {
  color: #292c7e;
}

.txt.rosso-navy {
  color: #d2091e;
}

.txt.verde-navy {
  color: #47c6a3;
}

.txt.celeste-navy {
  color: #dbf2ff;
}

.txt.blu-scuro-navy {
  color: #1e2e42;
}

.txt.azzurro-navy {
  color: #33a8eb;
}

.txt.gold-navy {
  color: #d1a71d;
}

.txt.azzurro {
  color: #33a8eb;
}

.txt.rosso {
  color: #ff0000;
}

.txt.grigio-chiaro {
  color: #e5e5e5;
}

.txt.grigio {
  color: #959595;
}

.txt.grigio-scuro {
  color: #232324;
}

.txt.nero {
  color: #000;
}

.txt.bianco {
  color: #fff;
}

.bg-blu-navy {
  background-color: #292c7e;
}

.bg-rosso-navy {
  background-color: #d2091e;
}

.bg-verde-navy {
  background-color: #47c6a3;
}

.bg-celeste-navy {
  background-color: #dbf2ff;
}

.bg-blu-scuro-navy {
  background-color: #1e2e42;
}

.bg-azzurro-navy {
  background-color: #33a8eb;
}

.bg-gold-navy {
  background-color: #d1a71d;
}

.bg-azzurro {
  background-color: #33a8eb;
}

.bg-rosso {
  background-color: #ff0000;
}

.bg-grigio-chiaro {
  background-color: #e5e5e5;
}

.bg-grigio {
  background-color: #959595;
}

.bg-grigio-scuro {
  background-color: #232324;
}

.bg-nero {
  background-color: #000;
}

.bg-bianco {
  background-color: #fff;
}

.border-blu-navy {
  border-color: #292c7e;
}

.border-rosso-navy {
  border-color: #d2091e;
}

.border-verde-navy {
  border-color: #47c6a3;
}

.border-celeste-navy {
  border-color: #dbf2ff;
}

.border-blu-scuro-navy {
  border-color: #1e2e42;
}

.border-azzurro-navy {
  border-color: #33a8eb;
}

.border-gold-navy {
  border-color: #d1a71d;
}

.border-azzurro {
  border-color: #33a8eb;
}

.border-rosso {
  border-color: #ff0000;
}

.border-grigio-chiaro {
  border-color: #e5e5e5;
}

.border-grigio {
  border-color: #959595;
}

.border-grigio-scuro {
  border-color: #232324;
}

.border-nero {
  border-color: #000;
}

.border-bianco {
  border-color: #fff;
}

.mt-10 {
  margin-top: 10px;
}

.mb-10 {
  margin-bottom: 10px;
}

.ml-10 {
  margin-left: 10px;
}

.mr-10 {
  margin-right: 10px;
}

.pt-10 {
  padding-top: 10px;
}

.pb-10 {
  padding-bottom: 10px;
}

.pl-10 {
  padding-left: 10px;
}

.pr-10 {
  padding-right: 10px;
}

.mt-15 {
  margin-top: 15px;
}

.mb-15 {
  margin-bottom: 15px;
}

.ml-15 {
  margin-left: 15px;
}

.mr-15 {
  margin-right: 15px;
}

.pt-15 {
  padding-top: 15px;
}

.pb-15 {
  padding-bottom: 15px;
}

.pl-15 {
  padding-left: 15px;
}

.pr-15 {
  padding-right: 15px;
}

.mt-20 {
  margin-top: 20px;
}

.mb-20 {
  margin-bottom: 20px;
}

.ml-20 {
  margin-left: 20px;
}

.mr-20 {
  margin-right: 20px;
}

.pt-20 {
  padding-top: 20px;
}

.pb-20 {
  padding-bottom: 20px;
}

.pl-20 {
  padding-left: 20px;
}

.pr-20 {
  padding-right: 20px;
}

.mt-25 {
  margin-top: 25px;
}

.mb-25 {
  margin-bottom: 25px;
}

.ml-25 {
  margin-left: 25px;
}

.mr-25 {
  margin-right: 25px;
}

.pt-25 {
  padding-top: 25px;
}

.pb-25 {
  padding-bottom: 25px;
}

.pl-25 {
  padding-left: 25px;
}

.pr-25 {
  padding-right: 25px;
}

.mt-30 {
  margin-top: 30px;
}

.mb-30 {
  margin-bottom: 30px;
}

.ml-30 {
  margin-left: 30px;
}

.mr-30 {
  margin-right: 30px;
}

.pt-30 {
  padding-top: 30px;
}

.pb-30 {
  padding-bottom: 30px;
}

.pl-30 {
  padding-left: 30px;
}

.pr-30 {
  padding-right: 30px;
}

.mt-35 {
  margin-top: 35px;
}

.mb-35 {
  margin-bottom: 35px;
}

.ml-35 {
  margin-left: 35px;
}

.mr-35 {
  margin-right: 35px;
}

.pt-35 {
  padding-top: 35px;
}

.pb-35 {
  padding-bottom: 35px;
}

.pl-35 {
  padding-left: 35px;
}

.pr-35 {
  padding-right: 35px;
}

.mt-40 {
  margin-top: 40px;
}

.mb-40 {
  margin-bottom: 40px;
}

.ml-40 {
  margin-left: 40px;
}

.mr-40 {
  margin-right: 40px;
}

.pt-40 {
  padding-top: 40px;
}

.pb-40 {
  padding-bottom: 40px;
}

.pl-40 {
  padding-left: 40px;
}

.pr-40 {
  padding-right: 40px;
}

.mt-45 {
  margin-top: 45px;
}

.mb-45 {
  margin-bottom: 45px;
}

.ml-45 {
  margin-left: 45px;
}

.mr-45 {
  margin-right: 45px;
}

.pt-45 {
  padding-top: 45px;
}

.pb-45 {
  padding-bottom: 45px;
}

.pl-45 {
  padding-left: 45px;
}

.pr-45 {
  padding-right: 45px;
}

.mt-50 {
  margin-top: 50px;
}

.mb-50 {
  margin-bottom: 50px;
}

.ml-50 {
  margin-left: 50px;
}

.mr-50 {
  margin-right: 50px;
}

.pt-50 {
  padding-top: 50px;
}

.pb-50 {
  padding-bottom: 50px;
}

.pl-50 {
  padding-left: 50px;
}

.pr-50 {
  padding-right: 50px;
}

.mt-55 {
  margin-top: 55px;
}

.mb-55 {
  margin-bottom: 55px;
}

.ml-55 {
  margin-left: 55px;
}

.mr-55 {
  margin-right: 55px;
}

.pt-55 {
  padding-top: 55px;
}

.pb-55 {
  padding-bottom: 55px;
}

.pl-55 {
  padding-left: 55px;
}

.pr-55 {
  padding-right: 55px;
}

.mt-60 {
  margin-top: 60px;
}

.mb-60 {
  margin-bottom: 60px;
}

.ml-60 {
  margin-left: 60px;
}

.mr-60 {
  margin-right: 60px;
}

.pt-60 {
  padding-top: 60px;
}

.pb-60 {
  padding-bottom: 60px;
}

.pl-60 {
  padding-left: 60px;
}

.pr-60 {
  padding-right: 60px;
}

.mt-65 {
  margin-top: 65px;
}

.mb-65 {
  margin-bottom: 65px;
}

.ml-65 {
  margin-left: 65px;
}

.mr-65 {
  margin-right: 65px;
}

.pt-65 {
  padding-top: 65px;
}

.pb-65 {
  padding-bottom: 65px;
}

.pl-65 {
  padding-left: 65px;
}

.pr-65 {
  padding-right: 65px;
}

.mt-70 {
  margin-top: 70px;
}

.mb-70 {
  margin-bottom: 70px;
}

.ml-70 {
  margin-left: 70px;
}

.mr-70 {
  margin-right: 70px;
}

.pt-70 {
  padding-top: 70px;
}

.pb-70 {
  padding-bottom: 70px;
}

.pl-70 {
  padding-left: 70px;
}

.pr-70 {
  padding-right: 70px;
}

.mt-75 {
  margin-top: 75px;
}

.mb-75 {
  margin-bottom: 75px;
}

.ml-75 {
  margin-left: 75px;
}

.mr-75 {
  margin-right: 75px;
}

.pt-75 {
  padding-top: 75px;
}

.pb-75 {
  padding-bottom: 75px;
}

.pl-75 {
  padding-left: 75px;
}

.pr-75 {
  padding-right: 75px;
}

.mt-80 {
  margin-top: 80px;
}

.mb-80 {
  margin-bottom: 80px;
}

.ml-80 {
  margin-left: 80px;
}

.mr-80 {
  margin-right: 80px;
}

.pt-80 {
  padding-top: 80px;
}

.pb-80 {
  padding-bottom: 80px;
}

.pl-80 {
  padding-left: 80px;
}

.pr-80 {
  padding-right: 80px;
}

.mt-85 {
  margin-top: 85px;
}

.mb-85 {
  margin-bottom: 85px;
}

.ml-85 {
  margin-left: 85px;
}

.mr-85 {
  margin-right: 85px;
}

.pt-85 {
  padding-top: 85px;
}

.pb-85 {
  padding-bottom: 85px;
}

.pl-85 {
  padding-left: 85px;
}

.pr-85 {
  padding-right: 85px;
}

.mt-90 {
  margin-top: 90px;
}

.mb-90 {
  margin-bottom: 90px;
}

.ml-90 {
  margin-left: 90px;
}

.mr-90 {
  margin-right: 90px;
}

.pt-90 {
  padding-top: 90px;
}

.pb-90 {
  padding-bottom: 90px;
}

.pl-90 {
  padding-left: 90px;
}

.pr-90 {
  padding-right: 90px;
}

.mt-95 {
  margin-top: 95px;
}

.mb-95 {
  margin-bottom: 95px;
}

.ml-95 {
  margin-left: 95px;
}

.mr-95 {
  margin-right: 95px;
}

.pt-95 {
  padding-top: 95px;
}

.pb-95 {
  padding-bottom: 95px;
}

.pl-95 {
  padding-left: 95px;
}

.pr-95 {
  padding-right: 95px;
}

.mt-100 {
  margin-top: 100px;
}

.mb-100 {
  margin-bottom: 100px;
}

.ml-100 {
  margin-left: 100px;
}

.mr-100 {
  margin-right: 100px;
}

.pt-100 {
  padding-top: 100px;
}

.pb-100 {
  padding-bottom: 100px;
}

.pl-100 {
  padding-left: 100px;
}

.pr-100 {
  padding-right: 100px;
}

.mt-105 {
  margin-top: 105px;
}

.mb-105 {
  margin-bottom: 105px;
}

.ml-105 {
  margin-left: 105px;
}

.mr-105 {
  margin-right: 105px;
}

.pt-105 {
  padding-top: 105px;
}

.pb-105 {
  padding-bottom: 105px;
}

.pl-105 {
  padding-left: 105px;
}

.pr-105 {
  padding-right: 105px;
}

/* testi */
.txt.grande,
.txt-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 100px;
  line-height: 1.1;
}

.txt.titolo-grande,
.txt-titolo-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 80px;
  line-height: 1.1;
}

.txt.titolo,
.txt-titolo,
.header-modal #big-menu-modal a {
  font-family: "Satoshi", sans-serif;
  font-size: 60px;
  line-height: 1.2;
}

.txt.titolo-piccolo,
.txt-titolo-piccolo {
  font-family: "Satoshi", sans-serif;
  font-size: 50px;
  line-height: 1.2;
}

.txt.sottotitolo-grande,
.txt-sottotitolo-grande,
.single-offerta .punti-forza .descrizione b {
  font-family: "Satoshi", sans-serif;
  font-size: 40px;
  line-height: 1.2;
}

.txt.sottotitolo,
.txt-sottotitolo,
.iframe-modal .destinazioni .destinazione {
  font-family: "Satoshi", sans-serif;
  font-size: 30px;
  line-height: 1.25;
}

.txt.sottotitolo-piccolo,
.txt-sottotitolo-piccolo,
.air-datepicker-button,
.air-datepicker-cell,
.air-datepicker-nav--title,
.air-datepicker-nav--title i {
  font-family: "Satoshi", sans-serif;
  font-size: 20px;
  line-height: 1.2;
}

.txt.testo-grande,
.txt-testo-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 18px;
  margin-bottom: 0;
  line-height: 1.2;
}

.txt.testo,
.txt-testo,
.ss-content .ss-option,
.ss-main .ss-single,
.form-calendars-container #calendar-date-departure,
.form-calendars-container #calendar-date-return,
.banner-cta .banner-cta-content .center .btn,
.offerte-residenti .card-offerta-archivio .card-body .btn,
.content-offerte-passate .card-offerta-archivio .card-body .btn,
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
#homepage-offerte .splide__track .card .card-body .btn,
.main .secondary-menu-footer li a,
.ticket .ticket-item.calendar input,
header .header-bottom .dropdown-languages,
header .navbar li span {
  font-family: "Satoshi", sans-serif;
  font-size: 16px;
  margin-bottom: 0;
  line-height: 1.4;
}

.txt.testo-piccolo,
.txt-testo-piccolo,
.iframe-modal .required-message,
.date-picker-dettaglio p,
.air-datepicker-body--day-name,
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
.main .primary-menu-footer li a {
  font-family: "Satoshi", sans-serif;
  font-size: 14px;
  margin-bottom: 0;
  line-height: 1.2;
}

.txt.piccolo,
.txt-piccolo,
.offerte-last-minute .splide .splide__track .card-last-minute .label,
.ticket .ticket-item.passengers .total-passengers,
.ticket .ticket-item.passengers .total-vehicles,
.ticket .ticket-item.vehicles .total-passengers,
.ticket .ticket-item.vehicles .total-vehicles,
.ss-content.ticket-trip-direction .ss-list .ss-option,
.ticket .ticket-item.calendar h3 .ss-main .ss-single {
  font-family: "Satoshi", sans-serif;
  font-size: 12px;
  margin-bottom: 0;
  line-height: 1.2;
}

@media screen and (max-width: 75em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 90px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 60px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.2;
  }
}
@media screen and (max-width: 64em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 80px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 60px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 45px;
    line-height: 1.2;
  }
  .txt.titolo-piccolo,
  .txt-titolo-piccolo {
    font-family: "Satoshi", sans-serif;
    font-size: 40px;
    line-height: 1.2;
  }
  .txt.sottotitolo-grande,
  .txt-sottotitolo-grande,
  .single-offerta .punti-forza .descrizione b {
    font-family: "Satoshi", sans-serif;
    font-size: 40px;
    line-height: 1.2;
  }
  .txt.sottotitolo,
  .txt-sottotitolo,
  .iframe-modal .destinazioni .destinazione {
    font-family: "Satoshi", sans-serif;
    font-size: 28px;
    line-height: 1.25;
  }
  .txt.sottotitolo-piccolo,
  .txt-sottotitolo-piccolo,
  .air-datepicker-button,
  .air-datepicker-cell,
  .air-datepicker-nav--title,
  .air-datepicker-nav--title i {
    font-family: "Satoshi", sans-serif;
    font-size: 20px;
    line-height: 1.2;
  }
  .txt.testo-grande,
  .txt-testo-grande {
    font-size: 18px;
    margin-bottom: 0;
  }
  .txt.testo,
  .txt-testo,
  .ss-content .ss-option,
  .ss-main .ss-single,
  .form-calendars-container #calendar-date-departure,
  .form-calendars-container #calendar-date-return,
  .banner-cta .banner-cta-content .center .btn,
  .offerte-residenti .card-offerta-archivio .card-body .btn,
  .content-offerte-passate .card-offerta-archivio .card-body .btn,
  .page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
  #homepage-offerte .splide__track .card .card-body .btn,
  .main .secondary-menu-footer li a,
  .ticket .ticket-item.calendar input,
  header .header-bottom .dropdown-languages,
  header .navbar li span {
    font-size: 16px;
    margin-bottom: 0;
  }
  .txt.testo-piccolo,
  .txt-testo-piccolo,
  .iframe-modal .required-message,
  .date-picker-dettaglio p,
  .air-datepicker-body--day-name,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
  .main .primary-menu-footer li a {
    font-size: 14px;
    margin-bottom: 0;
  }
  .txt.piccolo,
  .txt-piccolo,
  .offerte-last-minute .splide .splide__track .card-last-minute .label,
  .ticket .ticket-item.passengers .total-passengers,
  .ticket .ticket-item.passengers .total-vehicles,
  .ticket .ticket-item.vehicles .total-passengers,
  .ticket .ticket-item.vehicles .total-vehicles,
  .ss-content.ticket-trip-direction .ss-list .ss-option,
  .ticket .ticket-item.calendar h3 .ss-main .ss-single {
    font-size: 12px;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 40em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1.2;
  }
  .txt.titolo-piccolo,
  .txt-titolo-piccolo {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1.2;
  }
  .txt.sottotitolo-grande,
  .txt-sottotitolo-grande,
  .single-offerta .punti-forza .descrizione b {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1;
  }
  .txt.sottotitolo,
  .txt-sottotitolo,
  .iframe-modal .destinazioni .destinazione {
    font-family: "Satoshi", sans-serif;
    font-size: 26px;
    line-height: 1.25;
  }
  .txt.sottotitolo-piccolo,
  .txt-sottotitolo-piccolo,
  .air-datepicker-button,
  .air-datepicker-cell,
  .air-datepicker-nav--title,
  .air-datepicker-nav--title i {
    font-family: "Satoshi", sans-serif;
    font-size: 16px;
    line-height: 1.2;
  }
  .txt.testo-grande,
  .txt-testo-grande {
    font-size: 18px;
    margin-bottom: 0;
  }
  .txt.testo,
  .txt-testo,
  .ss-content .ss-option,
  .ss-main .ss-single,
  .form-calendars-container #calendar-date-departure,
  .form-calendars-container #calendar-date-return,
  .banner-cta .banner-cta-content .center .btn,
  .offerte-residenti .card-offerta-archivio .card-body .btn,
  .content-offerte-passate .card-offerta-archivio .card-body .btn,
  .page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
  #homepage-offerte .splide__track .card .card-body .btn,
  .main .secondary-menu-footer li a,
  .ticket .ticket-item.calendar input,
  header .header-bottom .dropdown-languages,
  header .navbar li span {
    font-size: 16px;
    margin-bottom: 0;
  }
  .txt.testo-piccolo,
  .txt-testo-piccolo,
  .iframe-modal .required-message,
  .date-picker-dettaglio p,
  .air-datepicker-body--day-name,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
  .main .primary-menu-footer li a {
    font-size: 14px;
    margin-bottom: 0;
  }
  .txt.piccolo,
  .txt-piccolo,
  .offerte-last-minute .splide .splide__track .card-last-minute .label,
  .ticket .ticket-item.passengers .total-passengers,
  .ticket .ticket-item.passengers .total-vehicles,
  .ticket .ticket-item.vehicles .total-passengers,
  .ticket .ticket-item.vehicles .total-vehicles,
  .ss-content.ticket-trip-direction .ss-list .ss-option,
  .ticket .ticket-item.calendar h3 .ss-main .ss-single {
    font-size: 12px;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 35em) {
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 45px;
    line-height: 1.1;
  }
}
.txt.mono {
  font-family: "Big Shoulders Display", monospace;
}

.txt.b-gold {
  line-height: 1.24;
}
.txt.b-gold b {
  color: #d1a71d;
  background-color: white;
}
.txt.b-gold b span {
  padding-left: 8px;
  padding-right: 8px;
  display: inline-block;
}

.ombra {
  filter: drop-shadow(0px 10px 20px rgba(0, 0, 0, 0.25));
}

.ombra-incrocio, .banner-cta .banner-cta-content {
  filter: drop-shadow(-5px 10px 35px rgba(255, 0, 0, 0.25)) drop-shadow(-10px -5px 25px rgba(51, 168, 235, 0.5));
}

@keyframes floatheader {
  0% {
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-50%);
  }
}
header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 40px;
  transition: all ease 0.3s;
  margin-top: 0;
  z-index: 999999;
}
header.hide-header {
  margin-top: -60px;
}
header .navbar {
  background-color: #292c7e;
  padding: 11px 0;
  position: relative;
  z-index: 1000000;
  transition: all ease 0.6s;
}
@media screen and (max-width: 768px) {
  header .navbar .container {
    justify-content: flex-end;
  }
}
header .navbar.header-secondary li:hover span {
  color: #33a8eb;
}
@media screen and (max-width: 768px) {
  header .navbar.header-secondary li {
    padding: 0 10px;
  }
}
header .navbar ul {
  flex-direction: row;
}
header .navbar .navbar-nav {
  align-items: center;
}
header .navbar .navbar-nav li:hover span {
  color: #33a8eb;
}
header .navbar .nav-item .nav-link {
  padding-top: 0;
  padding-bottom: 0;
  color: white;
}
header .navbar .nav-item .nav-link.show {
  color: white;
}
header .navbar .dropdown-toggle::after {
  opacity: 0.5;
  vertical-align: 3px;
}
header .navbar li {
  padding: 0 3px;
}
header .navbar li span {
  font-weight: bold;
  color: white;
  line-height: 1 !important;
}
header .navbar li span svg {
  max-height: 20px;
  max-width: 20px;
}
header .navbar .dropdown-menu {
  padding: 0;
  border: none;
  border-radius: 0;
  margin-top: 12px;
}
header .navbar .dropdown-menu.show-click {
  display: block;
}
header .navbar .dropdown-menu li {
  padding: 0;
  border-bottom: 1px solid #dbf2ff;
}
header .navbar .dropdown-menu li:nth-last-child(1) {
  border-bottom: none;
}
header .navbar .dropdown-menu li a {
  padding: 10px;
}
header .navbar .dropdown-menu li a span {
  color: #33a8eb;
  font-weight: 500;
}

header #navbarNavDropdownSecond, header #navbarNavDropdownFirst {
  background-color: rgba(0, 0, 0, 0) !important;
}
header #navbarNavDropdownSecond a, header #navbarNavDropdownFirst a {
  transition: all ease 0.3s;
}
header #navbarNavDropdownSecond a:hover, header #navbarNavDropdownFirst a:hover {
  color: #dbf2ff;
}
header .header-notification-container {
  position: relative;
  transition: all ease 0.3s;
}
header .header-notification-container:hover svg path {
  fill: #33a8eb;
}
header .header-notification-container .header-notification {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #d2091e;
  height: 18px;
  width: 18px;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(50%, -25%);
  border-radius: 100%;
  font-size: 10px;
}

header .dropdown-item:hover {
  background-color: #33a8eb;
}
header .dropdown-item:hover span {
  color: white !important;
  font-weight: 900;
}

header .user .--user-head-menu {
  top: 94%;
  min-width: unset;
}
header .user .--user-head-menu a {
  text-decoration: none;
}
header .user .--user-head-menu a:hover .txt, header .user .--user-head-menu a .dropdown-item:hover .txt {
  color: white;
}
header .user .--user-head-menu li .dropdown-item {
  padding: 12px 20px;
  text-align: right;
  border-bottom: solid 1px #d6f0ff;
}
header .user .--user-head-menu li .dropdown-item .txt {
  text-decoration: none;
  color: #33a8eb;
  font-weight: 700;
}
header .notifiche .btn {
  border: none;
  transition: none;
}
header .notifiche .btn.show {
  border: none;
}
header .notifiche .dropdown-menu li .dropdown-item {
  background: #faeeec;
  padding: 10px;
  display: inline-block;
  border-bottom: 1px solid #292c7e;
  width: 270px;
  white-space: wrap;
}
header .notifiche .dropdown-menu li .dropdown-item .btn {
  background-color: #5296cb;
  color: white;
}
header .notifiche .dropdown-menu li .dropdown-item .btn:hover {
  background-color: white;
  color: #5296cb;
}
header .notifiche .dropdown-menu li:nth-last-child(1) .dropdown-item {
  border-bottom: none;
}

header .header-bottom {
  display: flex;
  align-items: center;
  justify-content: space-between;
  position: relative;
  z-index: 999999;
  transition: all ease 0.8s, background-color linear 0.4s;
}
header .header-bottom .logo {
  width: 150px;
  height: 35px;
  background-image: url("../images/logo-blunavy-traghetti.png");
  background-repeat: no-repeat;
  background-position: center;
  background-size: cover;
  transition: all ease 0.6s;
  transform: translateY(25%);
}
@media screen and (max-width: 768px) {
  header .header-bottom .logo {
    transform: translateY(50%);
    width: 100px;
    height: 23px;
  }
}

header .header-bottom .dropdown-languages {
  border: none;
  font-weight: 700;
  color: #292c7e;
  background-color: #ffffff;
  transition: all ease 0.3s;
  transition: background ease 0.6s, color ease 0.6s;
  transition: all ease 0.3s;
}
@media screen and (max-width: 992px) {
  header .header-bottom .dropdown-languages {
    position: relative;
    z-index: 2;
  }
}
header .header-bottom .dropdown-languages:not(.open):hover {
  transition: all ease 0.3s;
  background-color: #ececec;
}
header .header-bottom .dropdown-languages .main-language {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 50px;
  height: 50px;
  cursor: pointer;
}
header .header-bottom .dropdown-languages .menu {
  position: absolute;
  background-color: #fff;
}
header .header-bottom .dropdown-languages .menu .item {
  transition: all ease 0.6s;
  transition: font-weight ease 0s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 50px;
  height: 50px;
  color: #292c7e;
  font-weight: 400;
}
header .header-bottom .dropdown-languages .menu .item .line {
  width: 21px;
  height: 0px;
  border: 1px solid #dbf2ff;
}
header .header-bottom .dropdown-languages .menu .item:hover {
  font-weight: 900;
}

header .header-bottom .hamburger {
  background-color: #292c7e;
  height: 50px;
  width: 50px;
  transition: all ease-in-out 0.6s;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 3px;
  cursor: pointer;
}
header .header-bottom .hamburger .line {
  width: 18px;
  height: 2px;
  background-color: #ffffff;
  display: block;
  -webkit-transition: all 0.3s ease-in-out;
  -o-transition: all 0.3s ease-in-out;
  transition: all 0.3s ease-in-out;
}

/* ONE */
#hamburger-1 {
  transition: all ease 0.3s;
}
#hamburger-1:hover {
  background-color: #121554;
}

.open-header-modal #hamburger-1:hover {
  background-color: #ececec;
}

#hamburger-1.is-active .line {
  background-color: #292c7e;
}

#hamburger-1.is-active .line:nth-child(2) {
  opacity: 0;
}

#hamburger-1.is-active .line:nth-child(1) {
  -webkit-transform: translateY(5px) rotate(45deg);
  -ms-transform: translateY(5px) rotate(45deg);
  -o-transform: translateY(5px) rotate(45deg);
  transform: translateY(5px) rotate(45deg);
}

#hamburger-1.is-active .line:nth-child(3) {
  -webkit-transform: translateY(-5px) rotate(-45deg);
  -ms-transform: translateY(-5px) rotate(-45deg);
  -o-transform: translateY(-5px) rotate(-45deg);
  transform: translateY(-5px) rotate(-45deg);
}

.header-modal {
  overflow: hidden;
  height: 100lvh;
}
.header-modal .container {
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
}
.header-modal .container::-webkit-scrollbar {
  display: none;
}
@media screen and (max-width: 992px) {
  .header-modal {
    overflow: scroll;
  }
}
.header-modal .nave-in-tempo {
  transition: all ease 0.3s;
}
.header-modal .nave-in-tempo:hover {
  transform: scale(1.05);
}
.header-modal .nave-in-tempo .radar {
  animation: rotation 2s infinite linear;
  position: absolute;
  left: 50px;
  top: 23px;
}
@media screen and (max-width: 1399px) {
  .header-modal .nave-in-tempo .radar {
    top: 23px;
    left: 34px;
  }
}
@media screen and (max-width: 1199px) {
  .header-modal .nave-in-tempo .radar {
    left: 20px;
  }
}
@media screen and (max-width: 992px) {
  .header-modal .nave-in-tempo .radar {
    animation: rotationmobile 2s infinite linear;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-48%, -46%);
    margin-left: 0;
  }
}
.header-modal .nave-in-tempo .text {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-130px, -60px) scale(0.6) rotate(-65deg);
}
@media screen and (max-width: 992px) {
  .header-modal .nave-in-tempo .text {
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%) scale(0.6) rotate(-65deg);
  }
}

@keyframes rotation {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(359deg);
  }
}
@keyframes rotationmobile {
  from {
    transform: translate(-48%, -46%) rotate(0deg);
  }
  to {
    transform: translate(-48%, -46%) rotate(359deg);
  }
}
.header-modal,
.header-modal-shadow {
  background-color: #292c7e;
  position: fixed;
  top: -150%;
  left: 0;
  height: 110%;
  width: 100%;
  transition: all ease-in-out 0.6s;
  transform: skewY(-10deg);
  z-index: 999999;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
}
@media screen and (max-width: 992px) {
  .header-modal,
  .header-modal-shadow {
    height: 110lvh;
  }
}

.header-modal {
  position: fixed;
  top: -150%;
  left: 0;
  height: 100%;
  width: 100%;
  transition: all ease-in-out 0.6s;
  transform: skewY(-10deg);
  z-index: 999999;
  display: block;
}

.header-modal-shadow {
  transition: all ease-in-out 0.8s;
  background-color: #d2091e;
  z-index: 1;
}

.open-header-modal {
  overflow: hidden;
}
.open-header-modal .navbar {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition-delay: 0.2s;
}
.open-header-modal header .logo {
  filter: grayscale(100%) brightness(1000%);
}
.open-header-modal header .header-bottom {
  margin-top: -30px;
  transition-delay: 0.2s;
}
.open-header-modal header .header-bottom .hamburger {
  background-color: white;
}
.open-header-modal header .header-bottom .hamburger svg path {
  fill: #292c7e;
}
.open-header-modal header .header-bottom .dropdown-languages {
  box-shadow: none;
  color: #292c7e;
  background-color: #ffffff;
}
.open-header-modal header .header-bottom .dropdown-languages .item {
  color: #292c7e;
}
.open-header-modal .header-modal {
  transition: all ease-in-out 0.8s;
  transform: skewY(0deg);
  top: 0%;
}
.open-header-modal .header-modal-shadow {
  transition: all ease-in-out 0.6s;
  transform: skewY(0deg);
  top: 0;
}
.open-header-modal .header-modal-shadow .header-modal-image {
  animation: floatheader 120s linear infinite alternate;
  opacity: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 200%;
  background-color: #292c7e;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
.open-header-modal .header-modal-shadow .header-modal-image.show {
  opacity: 1;
}

.hide-header .header-bottom {
  padding-top: 30px !important;
  margin-top: 0 !important;
  transition-delay: 0.2s;
}
@media screen and (max-width: 576px) {
  .hide-header .header-bottom {
    padding-top: 10px !important;
    padding-bottom: 10px;
  }
}

.link-item img {
  animation: floatheader 120s linear infinite alternate;
  opacity: 0;
  position: absolute;
  bottom: 0;
  left: 0;
  height: 100%;
  width: 200%;
  object-fit: cover;
  z-index: -1;
  pointer-events: none;
  transition: all ease 0.3s;
}
.link-item img.show {
  opacity: 0.75;
}
.link-item a {
  position: relative;
  z-index: 1;
}

@media screen and (max-width: 992px) {
  .header-modal #big-menu-modal {
    flex-direction: column;
    padding-bottom: 30px;
  }
}
@media screen and (max-width: 576px) {
  .header-modal #big-menu-modal {
    flex-direction: column;
    margin-top: 90px;
    padding-bottom: 30px;
  }
}
@media screen and (max-width: 1200px) {
  .header-modal #big-menu-modal .link-item {
    margin-bottom: 10px;
  }
}
.header-modal #big-menu-modal a {
  font-family: "Big Shoulders Display" !important;
  font-weight: 700;
  text-decoration: none;
  text-transform: uppercase;
  color: white;
  margin: 20px;
}
@media screen and (max-width: 1200px) {
  .header-modal #big-menu-modal a {
    margin: 20px;
  }
}
@media screen and (max-width: 992px) {
  .header-modal #big-menu-modal a {
    font-size: 40px !important;
  }
}
.header-modal #big-menu-modal a:hover {
  color: #33a8eb;
}
@media screen and (max-width: 992px) {
  .header-modal .menu-small-modal li a {
    margin: 0 10px;
  }
}
.header-modal .menu-small-modal li a:hover {
  color: #33a8eb;
}

.sticky-header .header-bottom {
  background-color: white;
}

.open-header-modal .sticky-header .header-bottom {
  transition: all ease 0.8s, background-color linear 0.2s;
  background-color: unset;
}

#navbarNavDropdownFirst ul ul .menu-item {
  position: relative;
}
#navbarNavDropdownFirst ul ul .sub-menu {
  padding-right: 20px;
}
#navbarNavDropdownFirst ul ul .sub-menu::after {
  display: inline-block;
  content: "";
  border-left: 0.3em solid #33a8eb;
  position: absolute;
  border-top: 0.3em solid transparent;
  border-right: 0;
  top: 50%;
  right: 0%;
  transform: translate(-150%, -50%);
  border-bottom: 0.3em solid transparent;
}
#navbarNavDropdownFirst ul ul .sub-menu:hover::after {
  display: inline-block;
  content: "";
  border-left: 0.3em solid white;
  position: absolute;
  border-top: 0.3em solid transparent;
  border-right: 0;
  top: 50%;
  right: 0%;
  transform: translate(-150%, -50%);
  border-bottom: 0.3em solid transparent;
}
#navbarNavDropdownFirst ul ul .sub-menu + .dropdown-menu {
  left: 100%;
  top: -12px;
  z-index: -1;
}

.breadcrumb {
  color: #292c7e;
  opacity: 0.5;
  text-transform: lowercase;
}
.breadcrumb .breadcrumb-arrow {
  margin-top: -2px;
}
.breadcrumb .breadcrumb-arrow .fal {
  font-size: 12px;
}
.breadcrumb a {
  text-decoration: none;
  margin: 0 4px;
  color: #292c7e;
  font-size: 12px;
}

.--landing-header.hide-header {
  margin-top: -120px;
}
.--landing-header .d-flex {
  gap: 24px;
}
@media screen and (max-width: 991px) {
  .--landing-header .d-flex {
    gap: 8px;
  }
}
.--landing-header .header-landing-link {
  text-decoration: unset;
  color: #fff;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  transition: ease 0.3s;
  opacity: 0.6;
}
.--landing-header .header-landing-link:hover {
  opacity: 1;
}
@media screen and (max-width: 991px) {
  .--landing-header .header-landing-link {
    opacity: 1;
  }
  .--landing-header .header-landing-link span {
    display: none;
  }
}
.--landing-header .header-landing-wa div {
  background-color: rgba(22, 181, 102, 0.1450980392);
  width: 45px;
  height: 45px;
  border-radius: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: ease 0.3s;
}
.--landing-header .header-landing-wa div:hover {
  background-color: #16b566;
}
.--landing-header .header-landing-booking div {
  background-color: #d2091e;
  width: 45px;
  height: 45px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: ease 0.3s;
}
.--landing-header .header-landing-booking div:hover {
  background-color: #292c7e;
}
.--landing-header .header-bottom--landing-cont {
  /* @media screen and (max-width: 991px) {
    flex-direction: column;
    .d-flex {
      flex-wrap: wrap;
    }
  } */
}
.--landing-header .header-bottom--landing-cont .header-landing-logo .logo {
  width: 150px;
  height: 35px;
  transform: unset;
}
.--landing-header.sticky-header .header-landing-link {
  color: #000;
}
.--landing-header.sticky-header .header-landing-link img {
  filter: invert(1);
}

.header-modal .btn-whatsapp {
  background-color: #bddcce;
  padding-right: 20px;
  width: 225px;
  border-radius: 100vmax;
  text-decoration: none;
  display: block;
  margin: 0 auto;
  transition: all ease 0.3s;
}
.header-modal .btn-whatsapp:hover {
  background-color: #66a58c;
  color: white;
}
.header-modal .contact-container {
  background: rgba(255, 255, 255, 0.2);
  border-radius: 20px;
  padding: 24px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 8px;
}
.header-modal .contact-container svg {
  margin-bottom: 4px;
}
.header-modal .contact-container span {
  font-weight: 700;
}
.header-modal .contact-container h3:hover {
  text-decoration: underline;
  color: white;
}
@media screen and (max-width: 992px) {
  .header-modal .menu-links-modal ul {
    flex-wrap: wrap;
  }
}
@media screen and (max-width: 992px) {
  .header-modal .menu-links-modal ul li a {
    margin: 0 10px;
  }
}
.header-modal .menu-links-modal ul li a:hover {
  color: #33a8eb;
}

.ticket {
  position: relative;
  filter: drop-shadow(0px 5px 10px rgba(255, 0, 0, 0.25)) drop-shadow(-5px 0px 10px rgba(51, 168, 235, 0.5));
  height: 62px;
}
.ticket .ticket-center {
  background-color: white;
  position: relative;
}
.ticket .ticket-center .ticket-loader {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  z-index: 999;
  background-color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all ease 0.3s;
}
.ticket .ticket-center .ticket-loader.open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.ticket .ticket-center .ticket-item {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 62px;
  padding: 0 12px;
  border-right: 1px solid #dbf2ff;
}
.ticket .ticket-center .ticket-item h3 {
  padding-bottom: 3px;
}
.ticket .ticket-center .ticket-item .trip-switch:hover span {
  text-decoration: underline;
}
.ticket .ticket-center .ticket-item .calendar-departure:hover input {
  text-decoration: underline;
}
.ticket .ticket-center .ticket-item.passengers:hover svg path {
  fill: #292C7E;
}
.ticket .ticket-center .ticket-item.vehicles:hover svg path {
  fill: #292C7E;
}
.ticket .ticket-right {
  display: flex;
  align-items: center;
  justify-content: center;
}
.ticket .ticket-right .ticket-search {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 62px;
  padding: 0 12px;
  background-color: #d2091e;
}
@media screen and (max-width: 1200px) {
  .ticket .ticket-right .ticket-search {
    padding: 0 6px;
  }
}

.ticket .trip {
  user-select: none;
  cursor: pointer;
}
.ticket .trip span:first-child {
  display: inline-block;
  width: 15px;
}
.ticket .trip .departure,
.ticket .trip .destination {
  display: inline-block;
  width: 90px;
}

.ticket .ticket-item .calendar-departure,
.ticket .ticket-item .calendar-return {
  color: rgba(51, 168, 235, 0.5);
}
.ticket .ticket-item .calendar-departure .air-datepicker,
.ticket .ticket-item .calendar-return .air-datepicker {
  transition: all ease 0.3s;
  max-width: 370px;
  background-color: white;
  padding: 20px 1rem;
  border-radius: 20px;
  top: 70px !important;
  left: 10px !important;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.ticket .ticket-item .calendar-return .air-datepicker {
  top: 60px !important;
  left: 20px !important;
  transform: translateX(100%);
}
.ticket .ticket-item .calendar-departure.open .air-datepicker,
.ticket .ticket-item .calendar-return.open .air-datepicker {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.ticket .ticket-item.vehicles, .ticket .ticket-item.passengers {
  cursor: pointer;
}
.ticket .iframe-modal {
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
}
.ticket .iframe-modal::-webkit-scrollbar {
  display: none;
}
.ticket .iframe-modal.vehicles .iframe-modal {
  padding-top: 20px;
  border-radius: 20px;
}
.ticket .iframe-modal.vehicles .iframe-modal .iframe-modal-main {
  max-height: unset !important;
  height: calc(100% - 100px);
}
.ticket .iframe-modal.vehicles,
.ticket .iframe-modal.passengers {
  width: 100%;
  max-width: 350px;
  height: auto;
  top: 70px;
  left: 100%;
  transform: translateX(-100%);
  padding: 20px 0;
  border-radius: 20px;
  transition: all ease 0.3s;
}
.ticket .iframe-modal.vehicles .iframe-modal-main,
.ticket .iframe-modal.passengers .iframe-modal-main {
  max-height: 300px;
}
.ticket .iframe-modal.vehicles .iframe-modal-header,
.ticket .iframe-modal.passengers .iframe-modal-header {
  padding-top: 0;
}
.ticket .iframe-modal.vehicles.open,
.ticket .iframe-modal.passengers.open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.ticket .ticket-item.calendar {
  min-width: 250px;
}
.ticket .ticket-item.calendar > div:first-of-type {
  min-width: 220px;
}
.ticket .ticket-item.calendar h3 .ss-main {
  border: none;
  min-width: unset;
  min-height: unset;
  margin-left: 0;
  padding: 0;
}
.ticket .ticket-item.calendar h3 .ss-main:hover {
  text-decoration: underline;
}
.ticket .ticket-item.calendar h3 .ss-main .ss-single {
  font-weight: 400;
}
.ticket .ticket-item.calendar h3 .ss-main .ss-arrow {
  transform: scale(0.75);
}
.ticket .ticket-item.calendar input {
  cursor: pointer;
  width: 100%;
  font-weight: bold;
  color: #292c7e;
  border: none;
  border: 1px solid blu;
}

.ss-content.ticket-trip-direction {
  min-width: 180px;
  width: 100%;
  z-index: 999999;
}
.ss-content.ticket-trip-direction .ss-list .ss-option {
  font-weight: 400;
}

.ticket .ticket-item.passengers,
.ticket .ticket-item.vehicles {
  position: relative;
  width: 64px;
}
.ticket .ticket-item.passengers .total-passengers,
.ticket .ticket-item.passengers .total-vehicles,
.ticket .ticket-item.vehicles .total-passengers,
.ticket .ticket-item.vehicles .total-vehicles {
  position: absolute;
  bottom: 0;
  right: 0;
  transform: translate(-100%, -100%);
  background-color: #d2091e;
  font-size: 9px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 100%;
  color: white;
  height: 14px;
  width: 14px;
  visibility: hidden;
  opacity: 0;
}
.ticket .ticket-item.passengers .total-passengers.show,
.ticket .ticket-item.passengers .total-vehicles.show,
.ticket .ticket-item.vehicles .total-passengers.show,
.ticket .ticket-item.vehicles .total-vehicles.show {
  visibility: visible;
  opacity: 1;
}

.ticket-search {
  padding-left: 16px;
  padding-right: 20px;
  cursor: pointer;
}

@media screen and (min-width: 993px) {
  .page-template-tpl-homepage .ticket, .page-template-tpl-landing-2024-04 .ticket {
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all ease 0.3s;
  }
  .page-template-tpl-homepage .sticky-header .ticket, .page-template-tpl-landing-2024-04 .sticky-header .ticket {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transition: all ease 0.3s;
  }
}
@media screen and (max-width: 992px) {
  .ticket {
    position: absolute;
    width: fit-content;
    left: 53%;
    transform: translateX(-50%);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    transition: all ease 0.6s;
    transition-delay: 0;
  }
  .open-header-modal .ticket {
    opacity: 1;
    visibility: visible;
    pointer-events: all;
    transition-delay: 0.3s;
  }
  .ticket {
    top: 90px;
    left: 50%;
    width: calc(100% - 20px);
    max-width: 720px;
  }
  .hide-header .ticket {
    top: 90px;
    left: 50%;
    width: calc(100% - 20px);
    max-width: 720px;
  }
}
@media screen and (max-width: 768px) {
  .ticket {
    top: 130px;
    left: 50%;
    width: calc(100% - 20px);
    max-width: 540px;
  }
  .hide-header .ticket {
    top: 90px;
    left: 50%;
    width: calc(100% - 20px);
    max-width: 540px;
  }
}
.modal-body {
  padding: 0 !important;
}

.main {
  background: #1e2e42;
  color: white;
  padding: 20px 0;
}
.main .primary-menu-footer a:hover, .main .secondary-menu-footer a:hover {
  color: white;
  text-decoration: underline;
}
.main .offerte-servizi a:hover {
  opacity: 1;
  color: white;
}
.main .buttons {
  gap: 20px;
}
.main .buttons a:not(.no-hover):hover {
  background-color: white;
}
.main .buttons a:not(.no-hover):hover span {
  color: #33a8eb;
}
.main .buttons a:not(.no-hover):hover svg path {
  fill: #33a8eb;
}
.main .buttons .button-purchase {
  text-decoration: none;
}
.main .buttons .button-purchase:hover {
  background-color: white;
  color: #d2091e;
}
.main .buttons .button-purchase:hover svg path {
  fill: #d2091e;
}
.main .button-contact,
.main .button-purchase {
  background-color: #33a8eb;
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 60px;
  max-height: 60px;
  cursor: pointer;
  transition: all ease 0.3s;
}
@media screen and (max-width: 992px) {
  .main .button-contact,
  .main .button-purchase {
    max-width: 100%;
  }
}
.main .button-purchase {
  background-color: #d2091e;
  border: none;
  color: white;
}
.main .primary-menu-footer {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 576px) {
  .main .primary-menu-footer {
    gap: 12px;
  }
}
.main .primary-menu-footer li a {
  color: white;
  text-decoration: none;
  font-weight: bold;
}
.main .secondary-menu-footer {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 576px) {
  .main .secondary-menu-footer {
    gap: 12px;
  }
}
.main .secondary-menu-footer li a {
  color: white;
  text-decoration: none;
}
.main .socials {
  margin-top: 35px;
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 1rem;
  flex-wrap: wrap;
}
.main .socials a {
  text-decoration: none;
  height: 45px;
  display: block;
  width: 45px;
  border-radius: 1005;
  border-radius: 100%;
  transition: all ease 0.3s;
}
.main .socials a:hover {
  background-color: rgba(219, 242, 255, 0.5);
}
.main .cosmo {
  margin-top: 30px;
}
.main .cosmo a {
  text-decoration: none;
  color: #d9dadf;
}
.main .line {
  height: 100%;
  width: 1px;
  background-color: #dbf2ff;
  opacity: 0.2;
  margin: 0 auto;
}
.main .offerte-servizi {
  margin-top: 45px;
}
.main .offerte-servizi .col-lg-4 > div {
  border-right: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-4 > div {
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.5);
  }
}
.main .offerte-servizi .col-lg-3 > div {
  border-right: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-3 > div {
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-5 > div {
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
}
.main .offerte-servizi h3 {
  margin-bottom: 20px;
}
.main .offerte-servizi li {
  margin-bottom: 8px;
}
.main .offerte-servizi li a {
  color: white;
  opacity: 0.5;
  text-decoration: none;
}
.main .btn-whatsapp {
  background-color: #bddcce;
  padding-right: 20px;
  width: 225px;
  border-radius: 100vmax;
  text-decoration: none;
  transition: all ease 0.3s;
}
.main .btn-whatsapp:hover {
  background-color: #66a58c;
  color: white !important;
}

.bn-meteo {
  background-color: #dbf2ff;
  border-radius: 20px;
  padding: 1.4rem;
  display: flex;
  gap: 16px;
  justify-content: space-evenly;
}
.bn-meteo .bn-meteo-elba {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-direction: column;
  justify-content: center;
}
.bn-meteo .bn-meteo-elba img {
  width: 120px;
}
.bn-meteo .bn-meteo-spacer {
  width: 1px;
  background-color: rgba(51, 168, 235, 0.5);
}
.bn-meteo .bn-meteo-spacer.--vertical {
  width: 100%;
  height: 1px;
  background-color: rgba(51, 168, 235, 0.2);
}
.bn-meteo .bn-meteo-lines {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* gap: 8px; */
  width: 60%;
  min-width: 160px;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: rgba(41, 44, 126, 0.5);
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single > span:nth-child(1) {
  text-transform: capitalize;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single span {
  display: flex;
  align-items: center;
  gap: 6px;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single span b {
  color: #292c7e;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single img {
  width: 36px;
}
.bn-meteo.--small {
  gap: 16px;
  padding: 1rem;
  flex-wrap: wrap;
}
.bn-meteo.--small .bn-meteo-elba img {
  width: 90px;
}
.bn-meteo.--small .bn-meteo-lines-single {
  font-size: 14px;
}

.modal-body {
  padding: 0 !important;
}

.main {
  background: #1e2e42;
  color: white;
  padding: 20px 0;
}
.main .primary-menu-footer a:hover, .main .secondary-menu-footer a:hover {
  color: white;
  text-decoration: underline;
}
.main .offerte-servizi a:hover {
  opacity: 1;
  color: white;
}
.main .buttons {
  gap: 20px;
}
.main .buttons a:not(.no-hover):hover {
  background-color: white;
}
.main .buttons a:not(.no-hover):hover span {
  color: #33a8eb;
}
.main .buttons a:not(.no-hover):hover svg path {
  fill: #33a8eb;
}
.main .buttons .button-purchase {
  text-decoration: none;
}
.main .buttons .button-purchase:hover {
  background-color: white;
  color: #d2091e;
}
.main .buttons .button-purchase:hover svg path {
  fill: #d2091e;
}
.main .button-contact,
.main .button-purchase {
  background-color: #33a8eb;
  padding: 20px 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  min-height: 60px;
  max-height: 60px;
  cursor: pointer;
  transition: all ease 0.3s;
}
@media screen and (max-width: 992px) {
  .main .button-contact,
  .main .button-purchase {
    max-width: 100%;
  }
}
.main .button-purchase {
  background-color: #d2091e;
  border: none;
  color: white;
}
.main .primary-menu-footer {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 576px) {
  .main .primary-menu-footer {
    gap: 12px;
  }
}
.main .primary-menu-footer li a {
  color: white;
  text-decoration: none;
  font-weight: bold;
}
.main .secondary-menu-footer {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  flex-wrap: wrap;
  gap: 20px;
}
@media screen and (max-width: 576px) {
  .main .secondary-menu-footer {
    gap: 12px;
  }
}
.main .secondary-menu-footer li a {
  color: white;
  text-decoration: none;
}
.main .socials {
  margin-top: 35px;
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 1rem;
  flex-wrap: wrap;
}
.main .socials a {
  text-decoration: none;
  height: 45px;
  display: block;
  width: 45px;
  border-radius: 1005;
  border-radius: 100%;
  transition: all ease 0.3s;
}
.main .socials a:hover {
  background-color: rgba(219, 242, 255, 0.5);
}
.main .cosmo {
  margin-top: 30px;
}
.main .cosmo a {
  text-decoration: none;
  color: #d9dadf;
}
.main .line {
  height: 100%;
  width: 1px;
  background-color: #dbf2ff;
  opacity: 0.2;
  margin: 0 auto;
}
.main .offerte-servizi {
  margin-top: 45px;
}
.main .offerte-servizi .col-lg-4 > div {
  border-right: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-4 > div {
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.5);
  }
}
.main .offerte-servizi .col-lg-3 > div {
  border-right: 1px solid rgba(255, 255, 255, 0.5);
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-3 > div {
    border: none;
    border-top: 1px solid rgba(255, 255, 255, 0.5);
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
}
@media screen and (max-width: 992px) {
  .main .offerte-servizi .col-lg-5 > div {
    border-bottom: 1px solid rgba(255, 255, 255, 0.5);
  }
}
.main .offerte-servizi h3 {
  margin-bottom: 20px;
}
.main .offerte-servizi li {
  margin-bottom: 8px;
}
.main .offerte-servizi li a {
  color: white;
  opacity: 0.5;
  text-decoration: none;
}
.main .btn-whatsapp {
  background-color: #bddcce;
  padding-right: 20px;
  width: 225px;
  border-radius: 100vmax;
  text-decoration: none;
  transition: all ease 0.3s;
}
.main .btn-whatsapp:hover {
  background-color: #66a58c;
  color: white !important;
}

.bn-meteo {
  background-color: #dbf2ff;
  border-radius: 20px;
  padding: 1.4rem;
  display: flex;
  gap: 16px;
  justify-content: space-evenly;
}
.bn-meteo .bn-meteo-elba {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-direction: column;
  justify-content: center;
}
.bn-meteo .bn-meteo-elba img {
  width: 120px;
}
.bn-meteo .bn-meteo-spacer {
  width: 1px;
  background-color: rgba(51, 168, 235, 0.5);
}
.bn-meteo .bn-meteo-spacer.--vertical {
  width: 100%;
  height: 1px;
  background-color: rgba(51, 168, 235, 0.2);
}
.bn-meteo .bn-meteo-lines {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  /* gap: 8px; */
  width: 60%;
  min-width: 160px;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single {
  display: flex;
  justify-content: space-between;
  align-items: center;
  color: rgba(41, 44, 126, 0.5);
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single > span:nth-child(1) {
  text-transform: capitalize;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single span {
  display: flex;
  align-items: center;
  gap: 6px;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single span b {
  color: #292c7e;
}
.bn-meteo .bn-meteo-lines .bn-meteo-lines-single img {
  width: 36px;
}
.bn-meteo.--small {
  gap: 16px;
  padding: 1rem;
  flex-wrap: wrap;
}
.bn-meteo.--small .bn-meteo-elba img {
  width: 90px;
}
.bn-meteo.--small .bn-meteo-lines-single {
  font-size: 14px;
}

.coordinates {
  background-color: #232324;
  color: #454647;
}
.coordinates .mono {
  font-family: "Big Shoulders Display";
}

.scarica-documentazione a {
  text-decoration: none;
}
.scarica-documentazione a:hover {
  opacity: 1;
  text-decoration: underline;
}
.scarica-documentazione .card-body {
  background: none;
}
.scarica-documentazione .navbar-nav {
  display: block;
  column-count: 4;
  background-color: none;
  column-gap: 40px;
}
@media screen and (max-width: 768px) {
  .scarica-documentazione .navbar-nav {
    display: flex;
    column-count: unset;
    column-gap: unset;
  }
}
.scarica-documentazione .navbar-nav .nav-item {
  font-size: 16px;
}
.scarica-documentazione .navbar-nav .nav-item a {
  color: white;
  opacity: 0.6;
  transition: all ease 0.3s;
}
.scarica-documentazione .navbar-nav .nav-item a:hover {
  opacity: 1;
  text-decoration: none;
}
.scarica-documentazione .iubenda-advertising-preferences-link {
  color: white;
  opacity: 0.6;
  transition: all ease 0.3s;
}
.scarica-documentazione .iubenda-advertising-preferences-link:hover {
  opacity: 1;
  text-decoration: none;
}

.form-newsletter {
  background-color: #292c7e;
}
.form-newsletter #my-form .hide-form > div {
  margin-bottom: 20px;
}
.form-newsletter #my-form > div {
  margin-bottom: 20px;
}
.form-newsletter #my-form > div .btn-fake,
.form-newsletter #my-form > div input[type=submit] {
  border: none;
  border-radius: 0;
  border-top-right-radius: 4px;
  border-bottom-right-radius: 4px;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  min-width: 120px;
  width: fit-content;
  margin-left: 1px;
  cursor: pointer;
  transition: all ease 0.3s;
}
.form-newsletter #my-form > div .btn-fake:hover,
.form-newsletter #my-form > div input[type=submit]:hover {
  background-color: white !important;
  color: #33a8eb !important;
}
.form-newsletter #my-form > div input.success {
  background-color: green;
}
.form-newsletter #my-form > div input.error {
  background-color: red;
}
.form-newsletter #my-form > div input[type=text],
.form-newsletter #my-form > div input[type=email] {
  color: #292c7e !important;
  outline: 1px solid white;
  border-radius: 0;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  border: 0;
  width: 400px;
  height: 40px;
  text-align: center;
  /* or, for legacy browsers */
}
@media screen and (max-width: 992px) {
  .form-newsletter #my-form > div input[type=text],
  .form-newsletter #my-form > div input[type=email] {
    width: 100%;
  }
}
.form-newsletter #my-form > div input[type=text]::placeholder,
.form-newsletter #my-form > div input[type=email]::placeholder {
  text-align: center;
}
.form-newsletter #my-form > div input[type=text]::-webkit-input-placeholder,
.form-newsletter #my-form > div input[type=email]::-webkit-input-placeholder {
  text-align: center;
}
.form-newsletter #my-form > div input[type=text]:-moz-placeholder,
.form-newsletter #my-form > div input[type=email]:-moz-placeholder {
  /* Firefox 18- */
  text-align: center;
}
.form-newsletter #my-form > div input[type=text]::-moz-placeholder,
.form-newsletter #my-form > div input[type=email]::-moz-placeholder {
  /* Firefox 19+ */
  text-align: center;
}
.form-newsletter #my-form > div input[type=text]:-ms-input-placeholder,
.form-newsletter #my-form > div input[type=email]:-ms-input-placeholder {
  text-align: center;
}
.form-newsletter #my-form > div input[type=checkbox] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  border: none;
}
.form-newsletter #my-form .ss-main {
  color: #292c7e !important;
  outline: 1px solid white;
  border-radius: 0;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  border: 0;
  width: 400px;
  height: 40px;
  text-align: center;
  margin: 0 !important;
}
@media screen and (max-width: 992px) {
  .form-newsletter #my-form .ss-main {
    width: 100%;
  }
}
.form-newsletter #my-form .ss-arrow {
  transform: scale(1.2) !important;
}

.form-zendesk #my-form-zendesk-desktop .col-lg-10,
.form-zendesk #my-form-zendesk-mobile .col-lg-10 {
  display: flex;
  align-items: start;
  justify-content: start;
  gap: 20px;
}
.form-zendesk #my-form-zendesk-desktop .col-lg-10 input[type=text],
.form-zendesk #my-form-zendesk-desktop .col-lg-10 input[type=email],
.form-zendesk #my-form-zendesk-mobile .col-lg-10 input[type=text],
.form-zendesk #my-form-zendesk-mobile .col-lg-10 input[type=email] {
  width: 100%;
}
.form-zendesk #my-form-zendesk-desktop input[type=submit],
.form-zendesk #my-form-zendesk-mobile input[type=submit] {
  border: none;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  min-width: 100%;
  margin-left: 1px;
  cursor: pointer;
  border: 1px solid #33a8eb;
}
.form-zendesk #my-form-zendesk-desktop input[type=submit]:hover,
.form-zendesk #my-form-zendesk-mobile input[type=submit]:hover {
  background-color: white !important;
  color: #33a8eb !important;
}
.form-zendesk #my-form-zendesk-desktop input[type=text],
.form-zendesk #my-form-zendesk-desktop input[type=email],
.form-zendesk #my-form-zendesk-mobile input[type=text],
.form-zendesk #my-form-zendesk-mobile input[type=email] {
  color: #292c7e !important;
  outline: 1px solid white;
  border-radius: 0;
  border: 0;
  height: 40px;
  text-align: center;
  width: 400px;
  /* or, for legacy browsers */
}
@media screen and (max-width: 992px) {
  .form-zendesk #my-form-zendesk-desktop input[type=text],
  .form-zendesk #my-form-zendesk-desktop input[type=email],
  .form-zendesk #my-form-zendesk-mobile input[type=text],
  .form-zendesk #my-form-zendesk-mobile input[type=email] {
    width: 100%;
  }
}
.form-zendesk #my-form-zendesk-desktop input[type=text]::placeholder,
.form-zendesk #my-form-zendesk-desktop input[type=email]::placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=text]::placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=email]::placeholder {
  text-align: center;
}
.form-zendesk #my-form-zendesk-desktop input[type=text]::-webkit-input-placeholder,
.form-zendesk #my-form-zendesk-desktop input[type=email]::-webkit-input-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=text]::-webkit-input-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=email]::-webkit-input-placeholder {
  text-align: center;
}
.form-zendesk #my-form-zendesk-desktop input[type=text]:-moz-placeholder,
.form-zendesk #my-form-zendesk-desktop input[type=email]:-moz-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=text]:-moz-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=email]:-moz-placeholder {
  /* Firefox 18- */
  text-align: center;
}
.form-zendesk #my-form-zendesk-desktop input[type=text]::-moz-placeholder,
.form-zendesk #my-form-zendesk-desktop input[type=email]::-moz-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=text]::-moz-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=email]::-moz-placeholder {
  /* Firefox 19+ */
  text-align: center;
}
.form-zendesk #my-form-zendesk-desktop input[type=text]:-ms-input-placeholder,
.form-zendesk #my-form-zendesk-desktop input[type=email]:-ms-input-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=text]:-ms-input-placeholder,
.form-zendesk #my-form-zendesk-mobile input[type=email]:-ms-input-placeholder {
  text-align: center;
}
.form-zendesk #my-form-zendesk-desktop input[type=checkbox],
.form-zendesk #my-form-zendesk-mobile input[type=checkbox] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  border: none;
}
.form-zendesk #my-form-zendesk-desktop textarea,
.form-zendesk #my-form-zendesk-mobile textarea {
  width: 100%;
  height: 100%;
  max-height: 245px;
  padding: 12px 20px;
  box-sizing: border-box;
  border: none;
  border-radius: 0;
  background-color: #f8f8f8;
  font-size: 16px;
  resize: none;
}

.bn-form-ajax form input {
  text-transform: none !important;
}
.bn-form-ajax form .col-lg-10 {
  /* display: flex;
  align-items: start;
  justify-content: start; */
  /* gap: 20px; */
}
.bn-form-ajax form .col-lg-10 input[type=text],
.bn-form-ajax form .col-lg-10 input[type=email] {
  width: 100%;
}
.bn-form-ajax form input[type=submit] {
  border: none;
  border-radius: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 42px;
  min-width: 100%;
  margin-left: 1px;
  cursor: pointer;
  border: 1px solid #33a8eb;
}
.bn-form-ajax form input[type=submit]:hover {
  background-color: white !important;
  color: #33a8eb !important;
}
.bn-form-ajax form input[type=submit].success {
  background-color: #009688;
  border-color: #009688;
  color: white !important;
}
.bn-form-ajax form input[type=text],
.bn-form-ajax form input[type=number],
.bn-form-ajax form select,
.bn-form-ajax form input[type=datetime-local],
.bn-form-ajax form input[type=date],
.bn-form-ajax form input[type=email] {
  color: #292c7e !important;
  outline: 1px solid white;
  border-radius: 0;
  border: 0;
  height: 40px;
  text-align: center;
  width: 100%;
  /* or, for legacy browsers */
}
@media screen and (max-width: 992px) {
  .bn-form-ajax form input[type=text],
  .bn-form-ajax form input[type=number],
  .bn-form-ajax form select,
  .bn-form-ajax form input[type=datetime-local],
  .bn-form-ajax form input[type=date],
  .bn-form-ajax form input[type=email] {
    width: 100%;
  }
}
.bn-form-ajax form input[type=text]::placeholder,
.bn-form-ajax form input[type=number]::placeholder,
.bn-form-ajax form select::placeholder,
.bn-form-ajax form input[type=datetime-local]::placeholder,
.bn-form-ajax form input[type=date]::placeholder,
.bn-form-ajax form input[type=email]::placeholder {
  text-align: center;
}
.bn-form-ajax form input[type=text]::-webkit-input-placeholder,
.bn-form-ajax form input[type=number]::-webkit-input-placeholder,
.bn-form-ajax form select::-webkit-input-placeholder,
.bn-form-ajax form input[type=datetime-local]::-webkit-input-placeholder,
.bn-form-ajax form input[type=date]::-webkit-input-placeholder,
.bn-form-ajax form input[type=email]::-webkit-input-placeholder {
  text-align: center;
}
.bn-form-ajax form input[type=text]:-moz-placeholder,
.bn-form-ajax form input[type=number]:-moz-placeholder,
.bn-form-ajax form select:-moz-placeholder,
.bn-form-ajax form input[type=datetime-local]:-moz-placeholder,
.bn-form-ajax form input[type=date]:-moz-placeholder,
.bn-form-ajax form input[type=email]:-moz-placeholder {
  /* Firefox 18- */
  text-align: center;
}
.bn-form-ajax form input[type=text]::-moz-placeholder,
.bn-form-ajax form input[type=number]::-moz-placeholder,
.bn-form-ajax form select::-moz-placeholder,
.bn-form-ajax form input[type=datetime-local]::-moz-placeholder,
.bn-form-ajax form input[type=date]::-moz-placeholder,
.bn-form-ajax form input[type=email]::-moz-placeholder {
  /* Firefox 19+ */
  text-align: center;
}
.bn-form-ajax form input[type=text]:-ms-input-placeholder,
.bn-form-ajax form input[type=number]:-ms-input-placeholder,
.bn-form-ajax form select:-ms-input-placeholder,
.bn-form-ajax form input[type=datetime-local]:-ms-input-placeholder,
.bn-form-ajax form input[type=date]:-ms-input-placeholder,
.bn-form-ajax form input[type=email]:-ms-input-placeholder {
  text-align: center;
}
.bn-form-ajax form input[type=checkbox] {
  cursor: pointer;
  width: 16px;
  height: 16px;
  border: none;
}
.bn-form-ajax form textarea {
  width: 100%;
  height: 100%;
  max-height: 245px;
  padding: 12px 20px;
  box-sizing: border-box;
  border: none;
  border-radius: 0;
  background-color: #f8f8f8;
  font-size: 16px;
  resize: none;
}
.bn-form-ajax form label {
  font-size: 16px;
  color: #32a9eb;
  margin-bottom: 8px;
  font-weight: 700;
}
.bn-form-ajax .bn-form-note {
  color: #32a9eb;
}
.bn-form-ajax .date-selector {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
}
.bn-form-ajax .date-selector label {
  display: block;
  width: 100%;
}
.bn-form-ajax .date-selector input[type=date] {
  flex: 0 0 auto;
  width: calc(80% - 10px);
}
.bn-form-ajax .date-selector select {
  flex: 0 0 auto;
  width: calc(20% - 10px);
}

#homepage-hero {
  padding-top: 57px;
  min-height: 811px;
}
#homepage-hero.--layout-diagonale {
  padding-bottom: 120px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 100px), 0 100%) !important;
}
#homepage-hero.--layout-diagonale #iframe-hero {
  margin-top: -60px;
}
#homepage-hero.--layout-diagonale + #flexible-content > div:nth-child(1) {
  padding-top: 0 !important;
  margin-top: -80px;
  position: relative;
  z-index: 1;
}
@media screen and (max-width: 992px) {
  #homepage-hero .hero-landing + .container .center-card {
    overflow: visible !important;
  }
  #homepage-hero .hero-landing + .container .center-card .container-card {
    filter: drop-shadow(2px 4px 30px rgba(0, 0, 0, 0.3333333333));
  }
}
#homepage-hero .hero-landing {
  min-height: 840px;
  padding-top: 80px;
}
#homepage-hero .hero-landing .hero-landing-container .row .hero-content {
  min-height: 840px;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
}
@media screen and (max-width: 992px) {
  #homepage-hero .hero-landing .hero-landing-container .row .hero-content > * {
    text-align: center !important;
    width: 100%;
  }
}
#homepage-hero .hero-landing .hero-landing-bg-image {
  background-size: cover;
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 992px) {
  #homepage-hero .hero-landing .hero-landing-bg-image {
    height: 60%;
  }
}
#homepage-hero .hero-landing .hero-landing-overlay {
  background-color: #000;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.4;
}
@media screen and (max-width: 992px) {
  #homepage-hero .hero-landing .hero-landing-overlay {
    height: 60%;
  }
}
#homepage-hero .hero-landing video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  opacity: 0;
  transition: all ease 1s;
}
#homepage-hero .hero-landing video.active {
  opacity: 1;
}
@media screen and (max-width: 992px) {
  #homepage-hero .hero-landing video {
    height: 60%;
  }
}
@media screen and (max-width: 1199px) {
  #homepage-hero .layer-content {
    padding-left: 60px;
  }
}
@media screen and (max-width: 991px) {
  #homepage-hero .layer-content {
    padding-left: 30px;
    padding-right: 30px;
  }
}
@media screen and (max-width: 767px) {
  #homepage-hero .layer-content {
    padding-left: 15px;
    padding-right: 15px;
  }
}
#homepage-hero .bn-card-landing-cta {
  border-bottom: solid 2px #292c7e;
  padding-top: 12px;
  padding-bottom: 24px;
  margin-bottom: 24px;
  font-size: 24px;
}
#homepage-hero .bn-card-landing-cta b {
  color: #d2091e;
}
@media screen and (max-width: 992px) {
  #homepage-hero {
    clip-path: none;
    padding-top: 0;
    min-height: unset;
  }
}
#homepage-hero .splide__pagination {
  z-index: 0;
}
@media screen and (max-width: 992px) {
  #homepage-hero .splide__pagination {
    top: 50%;
  }
}
#homepage-hero .splide__pagination .splide__pagination__page {
  background: #ffffff;
  opacity: 0.5;
  width: 12px;
  height: 12px;
  border-radius: 0;
}
#homepage-hero .splide__pagination .splide__pagination__page.is-active {
  transform: scale(1);
  background-color: #d2091e;
  opacity: 1;
}
#homepage-hero .splide__arrows .splide__arrow {
  height: 50px;
  width: 50px;
  background-color: transparent;
  border-radius: 0;
  padding: 10px;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  #homepage-hero .splide__arrows .splide__arrow.splide__arrow--prev {
    left: -0.5rem;
  }
}
@media screen and (max-width: 767px) {
  #homepage-hero .splide__arrows .splide__arrow.splide__arrow--next {
    right: -0.5rem;
  }
}
#homepage-hero .splide__arrows .splide__arrow svg {
  height: 100%;
  width: 100%;
}
#homepage-hero .splide__arrows .splide__arrow svg path {
  fill: white;
}
#homepage-hero .splide__arrows .splide__arrow:hover svg path {
  fill: #d1a71d;
}
#homepage-hero .splide__slide {
  position: relative;
}
#homepage-hero .splide__slide img,
#homepage-hero .splide__slide video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
#homepage-hero .splide__slide .layer {
  height: 120%;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.4);
  position: relative;
}
@media screen and (max-width: 992px) {
  #homepage-hero .splide__slide .layer .container {
    min-height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    flex-direction: column;
    padding: 200px 1rem;
  }
}
@media screen and (max-width: 767px) {
  #homepage-hero .splide__slide .layer .container {
    padding-top: 180px;
    padding-bottom: 250px;
  }
}
#homepage-hero .splide__slide .layer .container .label {
  background-color: #d2091e;
  padding: 6px 12px;
  border-radius: 4px;
}
#homepage-hero .splide__slide .layer .container .label b {
  font-weight: bold;
}
@media screen and (max-width: 992px) {
  #homepage-hero .splide__slide .layer .container .label {
    display: block;
    margin: 0 auto;
    width: fit-content;
  }
}
#homepage-hero .splide__slide .layer .container .titolo-grande {
  font-family: "Big Shoulders Display";
  line-height: 1.2;
  margin-top: 20px;
  margin-bottom: 16px;
}
#homepage-hero .splide__slide .layer .container .titolo-grande b {
  color: #d1a71d;
  background-color: white;
  padding: 4px 10px;
  border-radius: 4px;
}
#homepage-hero .splide__slide .layer .container .button-cta {
  background-color: #33a8eb;
  border-radius: 0;
  padding: 13px 20px;
  color: white;
  margin-top: 50px;
  max-width: fit-content;
  gap: 8px;
  transition: all ease 0.3s;
}
#homepage-hero .splide__slide .layer .container .button-cta svg {
  transition: all ease 0.3s;
}
#homepage-hero .splide__slide .layer .container .button-cta svg path {
  transition: all ease 0.3s;
}
#homepage-hero .splide__slide .layer .container .button-cta:hover {
  color: #33a8eb;
  background-color: white;
}
#homepage-hero .splide__slide .layer .container .button-cta:hover svg path {
  fill: #33a8eb;
}
@media screen and (max-width: 992px) {
  #homepage-hero .splide__slide .layer .container .button-cta {
    display: flex;
    margin: 0 auto;
    margin-top: 10px;
  }
}

.bn-metodi-pagamento {
  background-color: #dbf2ff;
  align-items: center;
  justify-content: center;
  gap: 24px;
  padding: 24px 36px;
  border-radius: 50px;
  display: inline-flex;
  flex-wrap: wrap;
}
.bn-metodi-pagamento .metodo img {
  height: 34px;
}

.bn-metodi-pagamento-footer {
  background-color: rgba(255, 255, 255, 0.2);
  align-items: center;
  justify-content: center;
  gap: 16px;
  padding: 24px 36px;
  border-radius: 12px;
  flex-direction: column;
}
.bn-metodi-pagamento-footer .bn-metodi-pagamento-footer-cont {
  display: flex;
  flex-wrap: wrap;
  gap: 16px;
  gap: 12px;
  justify-content: space-around;
}
.bn-metodi-pagamento-footer .metodo img {
  height: 30px;
}

.bn-vantaggi {
  margin-top: 40px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: center;
  gap: 16px;
}
.bn-vantaggi .bn-vantaggio {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
}
.bn-vantaggi .bn-vantaggio .bn-vantaggio-icon {
  background-color: #dbf2ff;
  width: 60px;
  height: 60px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 50px;
}
.bn-vantaggi .bn-vantaggio.--has-description {
  background-color: #33a8eb;
  padding: 16px;
  border-radius: 50px;
}
.bn-vantaggi .bn-vantaggio.--has-description .bn-vantaggio-icon {
  width: 40px;
  height: 40px;
}
.bn-vantaggi .bn-vantaggio.--has-description .bn-vantaggio-descrizione {
  max-width: 200px;
  text-align: left;
  font-size: 14px;
}

#homepage-offerte {
  padding: 10px 0;
  overflow: hidden;
}
#homepage-offerte h1 {
  font-family: "Big Shoulders Display";
  font-weight: bold;
  text-transform: uppercase;
}
#homepage-offerte a {
  text-decoration: none;
}
#homepage-offerte a:hover {
  text-decoration: underline !important;
}
#homepage-offerte .splide__track {
  overflow: visible;
}
#homepage-offerte .splide__track .card {
  position: relative;
  border-top-left-radius: 0px;
  border-top-right-radius: 0px;
  min-width: 335px;
  min-height: 390px;
  border: 1px solid #33a8eb;
}
@media screen and (max-width: 576px) {
  #homepage-offerte .splide__track .card {
    min-width: 200px;
  }
}
#homepage-offerte .splide__track .card .label {
  position: absolute;
  top: -1px;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  box-shadow: 0px 10px 25px rgba(51, 58, 128, 0.55);
}
#homepage-offerte .splide__track .card img {
  width: calc(100% + 2px);
  margin-left: -1px;
  margin-top: -1px;
  min-height: 190px;
  max-height: 190px;
  object-fit: cover;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}
#homepage-offerte .splide__track .card .card-body {
  min-height: 160px;
  min-width: 100%;
  display: flex;
  align-items: flex-start;
  flex-direction: column;
  justify-content: space-between;
}
#homepage-offerte .splide__track .card .card-body .btn {
  color: #33a8eb;
  font-weight: bold;
  border: 1px solid #33a8eb;
  background-color: white;
  width: calc(100% - 10px);
  border-radius: 0;
  transition: all ease 0.3s;
}
#homepage-offerte .splide__track .card .card-body .btn:hover {
  background-color: #33a8eb;
  color: white;
  text-decoration: none !important;
}
#homepage-offerte .splide__arrows .splide__arrow {
  opacity: 0.9;
  height: 56px;
  width: 56px;
  background-color: white;
  top: 25%;
}
#homepage-offerte .splide__arrows .splide__arrow svg {
  fill: #d2091e;
}

#homepage-servizi {
  padding: 50px 0;
  padding-bottom: 100px;
  position: relative;
}
#homepage-servizi h2 {
  font-family: "Big Shoulders Display";
}
#homepage-servizi a {
  text-decoration: none;
}
#homepage-servizi a:hover {
  text-decoration: underline !important;
}
#homepage-servizi .container-full {
  background: rgba(219, 242, 255, 0.2);
  border-radius: 10px;
  padding-top: 65px;
  padding-bottom: 100px;
}
#homepage-servizi .container-full .splide__track {
  overflow: visible;
}
#homepage-servizi .container-full .splide__track .splide__slide {
  position: unset;
}
@media screen and (max-width: 576px) {
  #homepage-servizi .container-full .splide__track .splide__slide {
    width: 100%;
  }
}
#homepage-servizi .container-full .splide__track .splide__slide .card-servizi {
  background: #ffffff;
  color: #292c7e;
  border: 1px solid rgba(41, 44, 126, 0.2);
  border-radius: 8px;
  width: 100%;
  height: 100%;
  max-width: 200px;
  min-height: 100px;
  padding: 20px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  flex-direction: column;
  cursor: pointer;
}
@media screen and (max-width: 576px) {
  #homepage-servizi .container-full .splide__track .splide__slide .card-servizi {
    max-width: 100%;
  }
}
#homepage-servizi .container-full .splide__track .splide__slide .card-servizi:hover {
  cursor: pointer;
  background-color: #33a8eb;
}
#homepage-servizi .container-full .splide__track .splide__slide .card-servizi:hover a {
  color: #33a8eb;
  background-color: white;
  cursor: pointer;
}
#homepage-servizi .container-full .splide__track .splide__slide .card-servizi:hover span {
  color: #fff;
  cursor: pointer;
}
#homepage-servizi .container-full .splide__track .splide__slide .card-servizi:hover img {
  cursor: pointer;
  filter: grayscale(0) brightness(100);
}
#homepage-servizi .container-full .splide__track .splide__slide .servizi-modal {
  display: flex;
  align-items: start;
  justify-content: center;
  flex-direction: column;
  position: fixed;
  z-index: 999;
  top: 50%;
  width: 340px;
  transform: translate(-25%, -50%);
  background: white;
  padding: 20px;
  border-radius: 8px;
  box-shadow: -10px -5px 25px 0px rgba(51, 168, 235, 0.5), -5px 10px 35px 0px rgba(255, 0, 0, 0.25);
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: all ease 0.3s;
}
#homepage-servizi .container-full .splide__track .splide__slide .servizi-modal h3 {
  margin-bottom: 20px;
  pointer-events: none;
}
#homepage-servizi .container-full .splide__track .splide__slide .servizi-modal p {
  margin-bottom: 20px;
  pointer-events: none;
}
#homepage-servizi .container-full .splide__track .splide__slide .servizi-modal.is-active {
  opacity: 1;
  visibility: visible;
  pointer-events: unset;
}
@media screen and (max-width: 576px) {
  #homepage-servizi .container-full .splide__track .splide__slide .servizi-modal {
    padding: 15px;
    width: 100%;
    transform: translate(0%, -50%);
  }
}

#homepage-highlight {
  padding: 25px 0 100px;
}

#homepage-about-us .col-lg-9 {
  gap: 20px;
}
#homepage-about-us .about-us-logo {
  animation: rotation 16s infinite linear;
}
#homepage-about-us .card-about-us {
  flex-grow: 1;
  min-height: 300px;
  min-width: 300px;
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  padding: 20px;
  text-decoration: none;
  display: flex;
  align-items: flex-start;
  justify-content: flex-end;
  flex-direction: column;
  cursor: pointer;
}
#homepage-about-us .card-about-us:hover .layer {
  background-color: rgba(0, 0, 0, 0.35);
}
#homepage-about-us .card-about-us:hover img {
  transform: scale(1.1);
}
@media screen and (max-width: 992px) {
  #homepage-about-us .card-about-us {
    min-width: 100%;
  }
}
#homepage-about-us .card-about-us img,
#homepage-about-us .card-about-us .layer {
  transition: all ease 0.3s;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: 0;
}
#homepage-about-us .card-about-us .layer {
  background-color: rgba(0, 0, 0, 0.55);
  z-index: 1;
}
#homepage-about-us .card-about-us h3,
#homepage-about-us .card-about-us p {
  position: relative;
  z-index: 2;
}
#homepage-about-us .card-about-us h3 {
  font-family: "Big Shoulders Display";
}

#homepage-recensioni {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  #homepage-recensioni {
    padding: 50px 0;
  }
}
#homepage-recensioni h2 {
  font-family: "Big Shoulders Display";
}

#homepage-blog {
  background-color: #33a8eb;
  padding-top: 140px;
  padding-bottom: 180px;
}
@media screen and (max-width: 992px) {
  #homepage-blog {
    padding-top: 70px;
    padding-bottom: 90px;
  }
}
#homepage-blog h2 {
  font-family: "Big Shoulders Display";
  margin-top: 20px;
  margin-bottom: 40px;
}
@media screen and (max-width: 992px) {
  #homepage-blog h2 {
    margin-top: 10px;
    margin-bottom: 20px;
  }
}
#homepage-blog p {
  max-width: 420px;
  line-height: 1.4;
}
@media screen and (max-width: 992px) {
  #homepage-blog p {
    max-width: 100%;
  }
}
#homepage-blog a {
  margin-top: 40px;
}
#homepage-blog .container-articoli {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 20px;
  flex-wrap: wrap;
}
@media screen and (max-width: 992px) {
  #homepage-blog .container-articoli {
    margin-top: 100px;
  }
}
@media screen and (max-width: 992px) {
  #homepage-blog .container-articoli {
    flex-wrap: nowrap;
    gap: 0;
  }
}
#homepage-blog .container-articoli .card-articolo {
  padding: 20px;
  width: calc(50% - 10px);
  min-height: 475px;
  background-color: white;
  border-radius: 8px;
}
#homepage-blog .container-articoli .card-articolo:nth-child(even) {
  transform: translateY(120px);
}
@media screen and (max-width: 992px) {
  #homepage-blog .container-articoli .card-articolo:nth-child(even) {
    transform: translateY(0);
  }
}
@media screen and (max-width: 992px) {
  #homepage-blog .container-articoli .card-articolo {
    width: 100%;
    margin-top: 60px;
  }
}
#homepage-blog .container-articoli .card-articolo img {
  margin-bottom: 20px;
  width: 100%;
  height: auto;
}
#homepage-blog .container-articoli .card-articolo h3 {
  margin-bottom: 8px;
}
#homepage-blog .container-articoli .card-articolo a {
  text-decoration: none;
}
#homepage-blog .container-articoli .card-articolo a:hover {
  text-decoration: underline;
}

#homepage-hotels {
  padding: 110px 0;
}
#homepage-hotels .splide__track {
  overflow: visible;
}
#homepage-hotels h2 {
  font-family: "Big Shoulders Display";
}
#homepage-hotels a {
  text-decoration: none;
}
#homepage-hotels a:hover {
  text-decoration: underline;
}

.card-hotel {
  padding: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #dbf2ff;
  border-radius: 8px;
  min-width: 640px;
}
@media screen and (max-width: 992px) {
  .card-hotel {
    min-width: 400px;
    max-width: 100%;
    padding: 0;
  }
}
@media screen and (max-width: 420px) {
  .card-hotel {
    min-width: 100%;
    max-width: 100%;
  }
}
.card-hotel img {
  height: 200px;
  width: 200px;
  object-fit: cover;
  margin: 30px 0;
}
@media screen and (max-width: 992px) {
  .card-hotel img {
    margin: 30px auto;
    width: calc(100% - 60px);
    max-width: 300px;
    height: auto;
  }
}
@media screen and (max-width: 420px) {
  .card-hotel img {
    width: 100%;
    max-width: calc(100% - 20px);
    margin: 10px;
  }
}
.card-hotel .card-text {
  width: 100%;
  max-width: 380px;
  min-height: 220px;
  padding: 20px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  flex-direction: column;
}
@media screen and (max-width: 420px) {
  .card-hotel .card-text {
    padding-top: 0px;
  }
}
.card-hotel .card-text * {
  margin-top: 8px;
}
.card-hotel .card-text *:first-child {
  margin-top: 0;
}
.card-hotel .card-text a {
  text-decoration: none;
}

#homepage-servizio-clienti {
  padding-bottom: 100px;
}
#homepage-servizio-clienti .col-lg-10 > div {
  overflow: hidden;
  border-radius: 20px;
  border: 1px solid #33a8eb;
}
#homepage-servizio-clienti .col-lg-10 > div img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
#homepage-servizio-clienti .col-lg-10 > div p {
  max-width: 450px;
}
@media screen and (max-width: 992px) {
  #homepage-servizio-clienti .col-lg-10 > div p {
    max-width: 100%;
  }
}
#homepage-servizio-clienti .btn {
  border-radius: 0;
  border: 1px solid #33a8eb;
  padding: 6px 50px;
}
@media screen and (max-width: 992px) {
  #homepage-servizio-clienti .btn {
    width: 100%;
  }
}

#homepage-social {
  padding-bottom: 100px;
}
#homepage-social h2 {
  font-family: "Big Shoulders Display";
}
#homepage-social .btn {
  border-radius: 0;
}
#homepage-social .btn:hover {
  background-color: white;
  color: #33a8eb !important;
}

#team-compagnia {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  #team-compagnia {
    padding: 50px 0;
  }
}
#team-compagnia h2 {
  font-family: "Big Shoulders Display";
}
#team-compagnia a {
  text-decoration: none;
}
#team-compagnia a:hover {
  text-decoration: underline;
}
#team-compagnia .card-image {
  width: 310px;
  height: 390px;
  position: relative;
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0 100%);
}
#team-compagnia .card-image img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}
#team-compagnia .card-image .card-image-text {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #292c7e;
  padding: 40px 30px;
  opacity: 0;
}
#team-compagnia .card-image .card-image-text:hover {
  opacity: 1;
}

#storia-compagnia {
  padding: 100px 0;
  background-color: #292c7e;
}
#storia-compagnia h2 {
  font-family: "Big Shoulders Display";
}
#storia-compagnia .splide__track {
  overflow: visible;
}
#storia-compagnia .splide__slide {
  max-width: 640px;
}
#storia-compagnia .card {
  background-color: white;
  border: none;
  overflow: hidden;
}
#storia-compagnia .card .card-body {
  padding: 0;
}
#storia-compagnia .card .card-body img {
  max-width: 310px;
  min-height: 260px;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  #storia-compagnia .card .card-body img {
    width: 100%;
    max-width: unset;
    object-fit: cover;
  }
}
#storia-compagnia .splide__pagination {
  justify-content: space-between;
  bottom: 120%;
}
@media screen and (max-width: 992px) {
  #storia-compagnia .splide__pagination {
    display: none;
  }
}
#storia-compagnia .splide__pagination .splide__pagination__page {
  background: none;
  border: 0;
  border-radius: 0;
  display: block;
  height: unset;
  width: unset;
  position: relative;
  color: white;
}

#compagnia-banner {
  padding-top: 150px;
  padding-bottom: 110px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  overflow: hidden;
}
#compagnia-banner .compagnia-banner-img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: -1;
}
#compagnia-banner .layer {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 0;
}
#compagnia-banner h2,
#compagnia-banner a,
#compagnia-banner h3 {
  position: relative;
}
#compagnia-banner h2 {
  margin-bottom: 40px;
  font-family: "Big Shoulders Display";
}
#compagnia-banner a {
  text-decoration: none;
  color: white;
  display: block;
  width: fit-content;
  margin: 0 auto;
  cursor: pointer;
}
#compagnia-banner a:hover {
  text-decoration: underline;
}

.page-template-tpl-compagnia #compagnia-banner {
  position: relative;
  overflow: hidden;
  margin: 0 !important;
}
.page-template-tpl-compagnia #compagnia-banner .compagnia-banner-img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: -1;
}

.single-offerta .sito-hero .container {
  padding-bottom: 100px;
}
@media screen and (max-width: 992px) {
  .single-offerta .sito-hero .container {
    padding-bottom: 0;
  }
}
.single-offerta .sito-hero .col-12 {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
  color: white;
  text-align: center;
}
.single-offerta .sito-hero .col-12 .hero-sopratitolo {
  color: white;
  font-size: 16px;
  text-transform: uppercase;
  margin-bottom: 20px;
}
.single-offerta .sito-hero .col-12 .hero-label {
  background-color: #d2091e;
  padding: 8px 20px;
  border-radius: 8px;
  text-transform: uppercase;
  box-shadow: 0px 10px 25px 0px rgba(51, 58, 128, 0.5490196078);
  margin-bottom: 15px;
  font-size: 14px;
}
.single-offerta .sito-hero .col-12 .hero-label strong {
  font-weight: 700;
  margin-left: 4px;
}
.single-offerta .sito-hero .col-12 .hero-date {
  text-transform: uppercase;
  font-size: 14px;
}
.single-offerta .sito-hero .col-12 .hero-date strong {
  font-weight: 700;
}
.single-offerta .sito-hero .col-12 .hero-titolo {
  color: white;
  text-transform: uppercase;
  font-weight: bold;
  font-family: "Big Shoulders Display";
  margin-top: 20px;
  margin-bottom: 0;
}
@media screen and (min-width: 1200px) {
  .single-offerta .sito-hero .col-12 .hero-titolo {
    font-size: 90px !important;
  }
}
.single-offerta .sito-hero .col-12 .hero-descrizione {
  margin-top: 20px !important;
}
.single-offerta .sito-hero .col-12 .buttons a {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  height: 46px;
  width: 200px;
}

.single-offerta .banner-cta a:hover {
  background-color: white !important;
  color: #d2091e !important;
}

.single-offerta .punti-forza {
  margin: 100px 0;
  min-height: 110vh;
}
@media screen and (max-width: 1024px) {
  .single-offerta .punti-forza {
    margin-top: 0;
  }
}
.single-offerta .punti-forza h2 {
  margin-top: 20px;
}
.single-offerta .punti-forza .image {
  margin-top: 5vh;
}
.single-offerta .punti-forza .descrizione {
  margin-top: 15vh;
  position: relative;
  z-index: 10;
}
@media screen and (max-width: 1024px) {
  .single-offerta .punti-forza .descrizione {
    margin-top: 5vh;
  }
}
.single-offerta .punti-forza .descrizione b {
  background-color: #292c7e;
  color: white;
  text-transform: uppercase;
  font-weight: 700;
  font-family: "Big Shoulders Display" !important;
  padding: 4px 10px;
}

.single-offerta .elenco-forza {
  padding-top: 170px;
  padding-bottom: 30px;
  position: relative;
  margin-top: -200px;
}
@media screen and (max-width: 1024px) {
  .single-offerta .elenco-forza {
    margin-top: -120px;
  }
}
@media screen and (max-width: 400px) {
  .single-offerta .elenco-forza {
    margin-top: -200px;
  }
}
.single-offerta .elenco-forza::before {
  content: "";
  display: block;
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: -1;
  background-color: #DBF2FF;
  -webkit-clip-path: polygon(0 10%, 100% 0, 100% 100%, 0% 100%);
  clip-path: polygon(0 10%, 100% 0, 100% 100%, 0% 100%);
}
.single-offerta .elenco-forza .container {
  padding-top: 80px;
  padding-bottom: 50px;
  background-image: url("../images/vector.svg");
  background-size: cover;
  background-repeat: no-repeat;
  background-position: center;
}
.single-offerta .elenco-forza .items {
  border-top: 1px dashed rgba(255, 255, 255, 0.2);
}
.single-offerta .elenco-forza .items:nth-last-child(1) {
  padding-bottom: 0 !important;
}

.single-offerta .offerta-informazioni {
  padding: 100px 0;
}
.single-offerta .offerta-informazioni .card {
  border-radius: 8px;
  border: 1px solid #33a8eb;
  padding: 70px 0;
}
.single-offerta .offerta-informazioni .card h2 {
  padding: 20px 0;
}
.single-offerta .offerta-informazioni .card .btn {
  border: 1px solid #33a8eb;
  border-radius: 0;
  color: #33a8eb;
  display: flex;
  justify-content: center;
  align-items: center;
  width: 200px;
}
.single-offerta .offerta-informazioni .card .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.offerte-last-minute {
  margin-top: -100px;
  margin-bottom: 100px;
}
.offerte-last-minute .splide .splide__track {
  overflow: visible;
}
.offerte-last-minute .splide .splide__track .card-last-minute {
  background-color: white;
  border: 1px solid #33a8eb;
  width: 420px;
  min-height: 220px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  flex-direction: column;
}
@media screen and (max-width: 576px) {
  .offerte-last-minute .splide .splide__track .card-last-minute {
    width: 300px;
  }
}
@media screen and (max-width: 350px) {
  .offerte-last-minute .splide .splide__track .card-last-minute {
    width: 250px;
  }
}
.offerte-last-minute .splide .splide__track .card-last-minute p {
  line-height: 1.2;
}
.offerte-last-minute .splide .splide__track .card-last-minute .label {
  color: #d2091e;
  text-transform: uppercase !important;
  border: 1px solid #d2091e;
  border-radius: 8px;
  padding: 6px 12px;
}
.offerte-last-minute .splide .splide__track .card-last-minute .label strong {
  font-weight: 700;
}
.offerte-last-minute .splide .splide__track .card-last-minute a {
  text-decoration: none;
  transition: all ease 0.3s;
}
.offerte-last-minute .splide .splide__track .card-last-minute a:hover {
  text-decoration: underline;
}

.page-template-tpl-offerte .offerte {
  padding-bottom: 100px;
}
.page-template-tpl-offerte .offerte .card-offerta-archivio {
  gap: 10px;
  min-height: 250px;
  border: 1px solid #33a8eb;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .offerte .card-offerta-archivio {
    flex-direction: column;
    padding: 20px;
    height: fit-content;
  }
}
.page-template-tpl-offerte .offerte .card-offerta-archivio .label {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  box-shadow: 0px 10px 25px rgba(51, 58, 128, 0.55);
  text-align: center;
}
.page-template-tpl-offerte .offerte .card-offerta-archivio img {
  width: 100%;
  height: auto;
  max-width: 50%;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .offerte .card-offerta-archivio img {
    width: 100%;
    max-width: 100%;
    margin-top: -20px;
    min-height: 190px;
    object-fit: cover;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    margin-bottom: 20px;
  }
}
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body {
  display: flex;
  align-items: start;
  justify-content: space-between;
  padding-bottom: 8px;
  flex-direction: column;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .offerte .card-offerta-archivio .card-body p {
    margin-top: 8px;
    margin-bottom: 20px;
  }
}
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .label {
  position: static;
  transform: none;
  box-shadow: unset;
  width: fit-content;
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn {
  color: #33a8eb;
  font-weight: bold;
  border: 1px solid #33a8eb;
  width: calc(100% - 10px);
  border-radius: 0;
  transition: all ease 0.3s;
}
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.page-template-tpl-offerte .nativi a {
  border: 1px solid white;
}
.page-template-tpl-offerte .nativi a:hover {
  background-color: rgba(0, 0, 0, 0) !important;
  color: white !important;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .nativi .position-absolute {
    position: static !important;
  }
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .nativi .w-75 {
    width: 100% !important;
  }
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .nativi .w-50 {
    width: 100% !important;
  }
}
@media screen and (max-width: 992px) {
  .page-template-tpl-offerte .nativi .translate-middle-y {
    transform: none !important;
  }
}

@media screen and (max-width: 576px) {
  .page-template-tpl-offerte-passate .sito-hero {
    padding-top: 200px;
  }
}
.page-template-tpl-offerte-passate .sito-hero .col-12 .hero-sopratitolo {
  text-align: center;
}
.page-template-tpl-offerte-passate .sito-hero .col-12 .hero-titolo {
  text-align: center;
}

.content-offerte-passate {
  padding-bottom: 100px;
}
.content-offerte-passate .card-offerta-archivio {
  gap: 10px;
  min-height: 250px;
  border: 1px solid #33a8eb;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 992px) {
  .content-offerte-passate .card-offerta-archivio {
    flex-direction: column;
    padding: 20px;
    height: fit-content;
  }
}
.content-offerte-passate .card-offerta-archivio .label {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  box-shadow: 0px 10px 25px rgba(51, 58, 128, 0.55);
  text-align: center;
}
.content-offerte-passate .card-offerta-archivio img {
  width: 100%;
  height: auto;
  max-width: 50%;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  .content-offerte-passate .card-offerta-archivio img {
    width: 100%;
    max-width: 100%;
    margin-top: -20px;
    min-height: 190px;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    margin-bottom: 20px;
  }
}
.content-offerte-passate .card-offerta-archivio .card-body {
  display: flex;
  align-items: start;
  justify-content: space-between;
  padding-bottom: 8px;
  flex-direction: column;
}
@media screen and (max-width: 992px) {
  .content-offerte-passate .card-offerta-archivio .card-body p {
    margin-top: 8px;
    margin-bottom: 20px;
  }
}
.content-offerte-passate .card-offerta-archivio .card-body .label {
  position: static;
  transform: none;
  box-shadow: unset;
  width: fit-content;
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}
.content-offerte-passate .card-offerta-archivio .card-body .btn {
  color: #33a8eb;
  font-weight: bold;
  border: 1px solid #33a8eb;
  width: calc(100% - 10px);
  border-radius: 0;
  transition: all ease 0.3s;
}
.content-offerte-passate .card-offerta-archivio .card-body .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.page-template-tpl-offerte-passate .pagination {
  margin: 20px 0;
}
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a {
  color: #33a8eb;
  text-decoration: none;
}
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current {
  color: #292c7e;
  font-weight: bold;
}

@media screen and (max-width: 992px) {
  .page-template-tpl-offerte-nativi .sito-hero {
    padding-top: 200px;
  }
}

.offerte-residenti {
  margin-top: -10vh;
}
.offerte-residenti .card-offerta-archivio {
  gap: 10px;
  min-height: 250px;
  border: 1px solid #33a8eb;
  border-radius: 8px;
  overflow: hidden;
  position: relative;
  background-color: white;
}
@media screen and (max-width: 992px) {
  .offerte-residenti .card-offerta-archivio {
    padding: 20px;
    flex-direction: column;
    height: fit-content;
  }
}
.offerte-residenti .card-offerta-archivio .label {
  position: absolute;
  top: 0;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
  box-shadow: 0px 10px 25px rgba(51, 58, 128, 0.55);
  text-align: center;
}
.offerte-residenti .card-offerta-archivio img {
  width: 100%;
  height: auto;
  max-width: 50%;
}
@media screen and (max-width: 992px) {
  .offerte-residenti .card-offerta-archivio img {
    width: 100%;
    max-width: 100%;
    margin-top: -20px;
    min-height: 190px;
    object-fit: cover;
    border-bottom-left-radius: 8px;
    border-bottom-right-radius: 8px;
    margin-bottom: 20px;
  }
}
.offerte-residenti .card-offerta-archivio .card-body {
  display: flex;
  align-items: start;
  justify-content: space-between;
  padding-bottom: 8px;
  flex-direction: column;
}
@media screen and (max-width: 992px) {
  .offerte-residenti .card-offerta-archivio .card-body p {
    margin-top: 8px;
    margin-bottom: 20px;
  }
}
.offerte-residenti .card-offerta-archivio .card-body .label {
  position: static;
  transform: none;
  box-shadow: unset;
  width: fit-content;
  padding: 8px 20px;
  border-bottom-left-radius: 8px;
  border-bottom-right-radius: 8px;
}
.offerte-residenti .card-offerta-archivio .card-body .btn {
  color: #33a8eb;
  font-weight: bold;
  border: 1px solid #33a8eb;
  width: calc(100% - 10px);
  border-radius: 0;
  transition: all ease 0.3s;
}
.offerte-residenti .card-offerta-archivio .card-body .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.page-template-tpl-offerte-nativi .pagination {
  margin: 20px 0;
}
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 20px;
}
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a {
  color: #33a8eb;
  text-decoration: none;
}
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current {
  color: #292c7e;
  font-weight: bold;
}

.page-template-tpl-destinazioni .sito-hero .row {
  justify-content: space-between;
}
.page-template-tpl-destinazioni .sito-hero #hero-text {
  max-width: 420px;
}
.page-template-tpl-destinazioni .sito-hero #hero-text .buttons a {
  border: 1px solid white;
  background-color: white;
  color: #33a8eb;
}
.page-template-tpl-destinazioni .sito-hero #hero-text .buttons a:hover {
  background-color: rgba(0, 0, 0, 0) !important;
  color: white !important;
}
.page-template-tpl-destinazioni #flexible-content .testo-immagine .row {
  justify-content: space-between;
}
.page-template-tpl-destinazioni #flexible-content .testo-immagine .row .col-lg-6 {
  max-width: 530px;
}
.page-template-tpl-destinazioni #flexible-content .griglia .col-lg-6 .card-elemento {
  height: 430px;
  justify-content: center;
  align-items: center;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-destinazioni #flexible-content .griglia .col-lg-6 .card-elemento {
    height: 300px;
  }
}
.page-template-tpl-destinazioni #flexible-content .griglia .col-lg-6 .card-elemento img {
  opacity: 0.75;
}
.page-template-tpl-destinazioni #flexible-content .griglia .col-lg-6 .card-elemento h3 {
  color: white !important;
}
.page-template-tpl-destinazioni #flexible-content .griglia .col-lg-6 .card-elemento p {
  display: block !important;
  text-align: center !important;
}
.page-template-tpl-destinazioni #flexible-content .banner-flex .banner-text {
  padding: 60px 0;
  padding-right: 80px;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-destinazioni #flexible-content .banner-flex .banner-text {
    padding: 20px;
  }
}
.page-template-tpl-destinazioni #flexible-content .cta-grande {
  position: relative;
  overflow: hidden;
}
.page-template-tpl-destinazioni #flexible-content .cta-grande .cta-grande-img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: -1;
}
.page-template-tpl-destinazioni #flexible-content .cta-grande .container-fluid {
  padding-top: 140px;
  padding-bottom: 100px;
  background-color: rgba(0, 0, 0, 0.5);
}
.page-template-tpl-destinazioni #flexible-content .cta-grande .container-fluid h2 {
  margin-bottom: 40px;
}
.page-template-tpl-destinazioni #flexible-content .cta-grande a:hover {
  text-decoration: underline;
}
.page-template-tpl-destinazioni #flexible-content .testo-immagine-lungo h2 {
  font-family: "Big Shoulders Display";
}
.page-template-tpl-destinazioni #flexible-content .testo-immagine-lungo #contenuto-piccolo {
  padding-bottom: 20px;
}
.page-template-tpl-destinazioni #flexible-content .testo-immagine-lungo .btn:hover {
  background-color: #33a8eb;
  color: white;
}
.page-template-tpl-destinazioni #flexible-content .support h2 {
  font-family: "Big Shoulders Display";
}
.page-template-tpl-destinazioni #flexible-content .support .btn {
  transition: all ease 0s;
}
.page-template-tpl-destinazioni #flexible-content .support .btn:hover {
  background-color: #292c7e;
  color: white;
}

#pois {
  padding: 100px 0;
  background-color: rgba(219, 242, 255, 0.2);
  clip-path: polygon(0 5%, 100% 0, 100% 100%, 0% 100%);
}
@media screen and (max-width: 992px) {
  #pois {
    clip-path: polygon(0 3%, 100% 0, 100% 100%, 0% 100%);
    padding: 150px 0;
    padding-bottom: 50px;
  }
}
#pois .pois-card {
  background-color: white;
  border-radius: 8px;
  overflow: hidden;
}
#pois .pois-card img {
  width: 100%;
  height: 100%;
  max-height: 230px;
  object-fit: cover;
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%);
}
#pois .pois-card .text {
  padding: 20px;
}
#pois .pois-card .text .description {
  margin-bottom: 20px;
}
#pois .pois-card .text h3 {
  margin-bottom: 8px;
}
#pois .pois-card .text a {
  text-decoration: none;
}

.single-destinazione .corellati .splide {
  margin-bottom: 50px;
}
.single-destinazione .corellati .splide .splide__track {
  overflow: visible;
}
.single-destinazione .corellati .splide .splide__slide .bordo {
  width: 100%;
  max-width: 530px;
}
.single-destinazione .corellati .splide .splide__slide .bordo:hover {
  background-color: #dbf2ff;
}
@media screen and (max-width: 600px) {
  .single-destinazione .corellati .splide .splide__slide .bordo {
    max-width: calc(100vw - 2rem);
  }
}
.single-destinazione .corellati .splide .splide__slide .bordo span {
  display: block;
  margin-top: 20px;
  color: #33a8eb;
}
.single-destinazione .corellati .splide .splide__slide .bordo img {
  width: 200px;
  height: 200px;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  .single-destinazione .corellati .splide .splide__slide .bordo img {
    width: 100%;
    height: auto;
  }
}
.single-destinazione .informazioni p b {
  display: inline-block;
  background-color: #f9f9f9;
  border-radius: 8px;
  padding: 6px;
}

.page-template-tpl-application #form-candidatura .req {
  color: red;
  font-weight: bold;
}
.page-template-tpl-application #form-candidatura input:not([type=checkbox]), .page-template-tpl-application #form-candidatura select, .page-template-tpl-application #form-candidatura textarea {
  width: 100%;
}
.page-template-tpl-application #form-candidatura select {
  padding-right: 1rem;
}
.page-template-tpl-application #form-candidatura input[type=radio], .page-template-tpl-application #form-candidatura input[type=checkbox] {
  appearance: none;
  background-color: #fff;
  margin: 0;
  font: inherit;
  color: #323232;
  width: 1.15em;
  height: 1.15em;
  border: 0.15em solid #323232;
  border-radius: 50%;
  transform: translateY(-0.075em);
  display: grid;
  place-content: center;
  cursor: pointer;
}
.page-template-tpl-application #form-candidatura .sub-category-posizioni input[type=radio] {
  border-radius: 0;
}
.page-template-tpl-application #form-candidatura input[type=checkbox] {
  border-radius: 0;
}
.page-template-tpl-application #form-candidatura input[type=radio]::before, .page-template-tpl-application #form-candidatura input[type=checkbox]::before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  width: 1.15em;
  height: 1.15em;
  border-radius: 50%;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1.15em 1.15em #323232;
}
.page-template-tpl-application #form-candidatura .sub-category-posizioni input[type=radio]::before {
  border-radius: 0;
}
.page-template-tpl-application #form-candidatura input[type=checkbox]::before {
  border-radius: 0;
}
.page-template-tpl-application #form-candidatura input[type=radio]:checked::before {
  transform: scale(1);
}
.page-template-tpl-application #form-candidatura input[type=checkbox]:checked::before {
  transform: scale(1);
}
.page-template-tpl-application #form-candidatura input[type=text], .page-template-tpl-application #form-candidatura input[type=email], .page-template-tpl-application #form-candidatura input[type=date], .page-template-tpl-application #form-candidatura select, .page-template-tpl-application #form-candidatura textarea {
  border: none;
  border-radius: 4px;
  background-color: white;
  height: 50px;
  padding-left: 1rem;
}
.page-template-tpl-application #form-candidatura label {
  color: #232324;
  font-family: Satoshi;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 140%;
}
.page-template-tpl-application #form-candidatura .btn-primary {
  border-radius: 0;
  background-color: #33a8eb;
  border-color: #33a8eb;
  max-width: 420px;
  text-transform: uppercase;
}
.page-template-tpl-application #form-candidatura .btn-primary:hover {
  color: #33a8eb;
  background-color: white;
}
.page-template-tpl-application #form-candidatura .btn-primary.success {
  background-color: #33b86a !important;
  border-color: #33b86a !important;
}
.page-template-tpl-application #form-candidatura .btn-primary.error {
  background-color: #B80F0A !important;
  border-color: #B80F0A !important;
}
.page-template-tpl-application #form-candidatura .indietro {
  background-color: white;
  color: #33a8eb;
  border: 1px solid white;
  width: 100%;
  border-radius: 0;
  max-width: 420px;
  text-transform: uppercase;
}
.page-template-tpl-application #form-candidatura .indietro:hover {
  background-color: #33a8eb;
  color: white;
}
.page-template-tpl-application .posizione-aperta {
  border-radius: 0;
  background-color: #33a8eb;
  border: 1px solid #33a8eb;
  max-width: 420px;
  text-transform: uppercase;
}
.page-template-tpl-application .posizione-aperta:hover {
  background-color: white;
  color: #33a8eb;
}
.page-template-tpl-application .accordion {
  margin-top: 20px;
  border-radius: 0;
  --bs-accordion-border-color: none;
}
.page-template-tpl-application .accordion:focus {
  border: none;
}
.page-template-tpl-application .accordion .accordion-item {
  border-radius: 0;
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-application .accordion .accordion-item:nth-last-child(1) {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-application .accordion .accordion-item h2 {
  font-family: "Satoshi";
}
.page-template-tpl-application .accordion .accordion-item .accordion-button {
  border-radius: 0;
  background: none;
  padding-left: 0;
}
.page-template-tpl-application .accordion .accordion-item .accordion-button:not(.collapsed) {
  box-shadow: unset;
}
.page-template-tpl-application .accordion .accordion-body {
  padding-top: 0;
  padding-left: 0;
}
.page-template-tpl-application .accordion-button::after {
  background-image: url("../images/add.png");
}
.page-template-tpl-application .accordion-button:not(.collapsed)::after {
  background-image: url("../images/remove.png");
}

.form-reclamo-component .req {
  color: red;
  font-weight: bold;
}
.form-reclamo-component input:not([type=checkbox]), .form-reclamo-component select, .form-reclamo-component textarea {
  width: 100%;
}
.form-reclamo-component select {
  padding-right: 1rem;
}
.form-reclamo-component .error-message {
  display: none;
  color: red;
  font-size: 12px;
}
.form-reclamo-component input.invalid, .form-reclamo-component select.invalid, .form-reclamo-component textarea.invalid {
  border-color: red;
}
.form-reclamo-component input.invalid + .error-message, .form-reclamo-component select.invalid + .error-message, .form-reclamo-component textarea.invalid + .error-message {
  display: block;
}
.form-reclamo-component .form-group-privacy {
  display: flex;
  flex-wrap: wrap;
}
.form-reclamo-component .form-group-privacy .error-message {
  width: 100%;
  order: 2;
}
.form-reclamo-component input[type=radio], .form-reclamo-component input[type=checkbox] {
  appearance: none;
  background-color: #fff;
  margin: 0;
  font: inherit;
  color: #323232;
  width: 1.15em;
  height: 1.15em;
  border: 0.15em solid #323232;
  border-radius: 50%;
  transform: translateY(-0.075em);
  display: grid;
  place-content: center;
  cursor: pointer;
}
.form-reclamo-component input[type=checkbox] {
  border-radius: 0;
}
.form-reclamo-component input[type=radio]::before, .form-reclamo-component input[type=checkbox]::before {
  content: "";
  width: 0.65em;
  height: 0.65em;
  width: 1.15em;
  height: 1.15em;
  border-radius: 50%;
  transform: scale(0);
  transition: 120ms transform ease-in-out;
  box-shadow: inset 1.15em 1.15em #323232;
}
.form-reclamo-component input[type=checkbox]::before {
  border-radius: 0;
}
.form-reclamo-component input[type=radio]:checked::before {
  transform: scale(1);
}
.form-reclamo-component input[type=checkbox]:checked::before {
  transform: scale(1);
}
.form-reclamo-component input[type=text], .form-reclamo-component input[type=email], .form-reclamo-component input[type=date], .form-reclamo-component select, .form-reclamo-component textarea {
  border: none;
  border-radius: 4px;
  background-color: white;
  height: 50px;
  padding-left: 1rem;
}
.form-reclamo-component label {
  color: #232324;
  font-family: Satoshi;
  font-size: 16px;
  font-style: normal;
  font-weight: 700;
  line-height: 140%;
}
.form-reclamo-component .btn-primary {
  border-radius: 0;
  background-color: #33a8eb;
  border-color: #33a8eb;
  max-width: 420px;
  text-transform: uppercase;
}
.form-reclamo-component .btn-primary:hover {
  color: #33a8eb;
  background-color: white;
}
.form-reclamo-component .btn-primary.success {
  background-color: #33b86a !important;
  border-color: #33b86a !important;
}
.form-reclamo-component .btn-primary.error {
  background-color: #B80F0A !important;
  border-color: #B80F0A !important;
}
.form-reclamo-component .form-reclamo-section {
  margin-bottom: 15px;
}
.form-reclamo-component .form-reclamo-section .form-section-header {
  margin-bottom: 15px;
}
.form-reclamo-component .form-reclamo-section .form-section-body {
  margin-bottom: 45px;
}
.form-reclamo-component .form-reclamo-section .form-section-body .form-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}
.form-reclamo-component .form-reclamo-section .form-section-body .form-group label {
  display: block;
  margin-bottom: 5px;
}
.form-reclamo-component .form-reclamo-section .form-section-body .form-group input:not([type=checkbox], [type=radio]),
.form-reclamo-component .form-reclamo-section .form-section-body .form-group select,
.form-reclamo-component .form-reclamo-section .form-section-body .form-group textarea {
  width: 100%;
}
.form-reclamo-component .form-reclamo-section .form-lista-passeggeri .form-row {
  margin-bottom: 15px;
}
.form-reclamo-component .form-reclamo-section .lista-motivazioni .form-row {
  margin-bottom: 10px;
}
.form-reclamo-component .form-reclamo-section .lista-motivazioni .form-row .form-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.form-reclamo-component .form-reclamo-section .lista-motivazioni .form-row .form-group label {
  padding-left: 10px;
}
.form-reclamo-component .form-reclamo-section.section-rimborso .form-group {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
.form-reclamo-component .form-reclamo-section.section-rimborso .form-group label {
  padding-left: 10px;
}

.form-upload-reclamo .form-section-body {
  margin-top: 15px;
  margin-bottom: 15px;
  border: 1px solid #33a8eb;
  border-radius: 20px;
  padding: 15px;
  text-align: center;
}

.page-template-tpl-team .sito-hero #hero-text .hero-titolo,
.page-template-tpl-team .sito-hero #hero-text .hero-sopratitolo {
  text-align: center !important;
}
.page-template-tpl-team .sito-hero #hero-text .buttons a {
  border: 1px solid white;
  background-color: white;
  color: #33a8eb;
}
.page-template-tpl-team .sito-hero #hero-text .buttons a:hover {
  background-color: #33a8eb !important;
  color: white !important;
}
.page-template-tpl-team .page-team-content {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-team .page-team-content {
    padding: 50px 0;
  }
}
.page-template-tpl-team .page-team-content h2 {
  font-family: "Big Shoulders Display";
}
.page-template-tpl-team .page-team-content a {
  text-decoration: none;
}
.page-template-tpl-team .page-team-content .card-image {
  width: 100%;
  max-width: 310px;
  height: 390px;
  position: relative;
}
.page-template-tpl-team .page-team-content .card-image img {
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0 100%);
  position: absolute;
  top: 0;
  left: 0;
  max-width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
  width: 100%;
}
.page-template-tpl-team .page-team-content .card-image .card-image-text {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: #292c7e;
  padding: 40px 30px;
  opacity: 0;
}
.page-template-tpl-team .page-team-content .card-image .card-image-text:hover {
  opacity: 1;
}

.domande-nave {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .domande-nave {
    padding: 50px 0;
  }
}
.domande-nave * {
  box-shadow: none !important;
}
.domande-nave h2 {
  font-family: "Big Shoulders Display";
}
.domande-nave .accordion {
  margin-top: 20px;
  border-radius: 0;
  --bs-accordion-border-color: none;
}
.domande-nave .accordion:focus {
  border: none;
}
.domande-nave .accordion .accordion-item {
  border-radius: 0;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.domande-nave .accordion .accordion-item h2 {
  font-family: "Satoshi";
}
.domande-nave .accordion .accordion-item .accordion-button {
  border-radius: 0;
  background: none;
  padding-left: 0;
}
.domande-nave .accordion .accordion-item .accordion-button:not(.collapsed) {
  box-shadow: unset;
}
.domande-nave .accordion .accordion-body {
  padding-top: 0;
  padding-left: 0;
}

.accordion-button::after {
  background-image: url("../images/add.png");
}

.accordion-button:not(.collapsed)::after {
  background-image: url("../images/remove.png");
}

@media screen and (max-width: 992px) {
  .page-template-tpl-servizi .accordion-body {
    padding: 0 !important;
  }
}
@media screen and (max-width: 992px) {
  .page-template-tpl-servizi img {
    pointer-events: none;
  }
}
.page-template-tpl-servizi .card-servizi {
  background: #ffffff;
  color: #292c7e;
  border: 1px solid rgba(41, 44, 126, 0.2);
  border-radius: 8px;
  width: 100%;
  height: 100%;
  max-width: 200px;
  min-height: 100px;
  padding: 20px;
  display: flex;
  align-items: start;
  justify-content: space-between;
  flex-direction: column;
  cursor: pointer;
}
@media screen and (max-width: 576px) {
  .page-template-tpl-servizi .card-servizi {
    max-width: 100%;
  }
}
.page-template-tpl-servizi .card-servizi:hover {
  background-color: #33a8eb;
}
.page-template-tpl-servizi .card-servizi:hover a {
  color: #33a8eb;
  background-color: white;
}
.page-template-tpl-servizi .card-servizi:hover span {
  color: #fff;
}
.page-template-tpl-servizi .card-servizi:hover img {
  filter: grayscale(0) brightness(100);
}
.page-template-tpl-servizi * {
  box-shadow: none !important;
}
.page-template-tpl-servizi h2 {
  font-family: "Big Shoulders Display";
}
.page-template-tpl-servizi .accordion {
  margin-top: 20px;
  border-radius: 0;
  --bs-accordion-border-color: none;
}
.page-template-tpl-servizi .accordion:focus {
  border: none;
}
.page-template-tpl-servizi .accordion .accordion-item {
  border-radius: 0;
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-servizi .accordion .accordion-item:nth-last-child(1) {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-servizi .accordion .accordion-item h2 {
  font-family: "Satoshi";
}
.page-template-tpl-servizi .accordion .accordion-item .accordion-button {
  border-radius: 0;
  background: none;
  padding-left: 0;
}
.page-template-tpl-servizi .accordion .accordion-item .accordion-button:not(.collapsed) {
  box-shadow: unset;
}
.page-template-tpl-servizi .accordion .accordion-body {
  padding-top: 0;
  padding-left: 0;
}

.image-fixed-container-servizio {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 1000000;
  display: flex;
  align-items: center;
  justify-content: center;
}
.image-fixed-container-servizio .layer {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
}
.image-fixed-container-servizio img {
  position: relative;
  width: 75%;
  height: auto;
}

.page-template-tpl-faq .btn-card-contatti {
  display: flex;
  width: 100%;
  max-width: 200px;
  border: 1px solid #33a8eb;
  color: #33a8eb;
  font-weight: bold;
  font-size: 14px;
  text-decoration: none;
  align-items: center;
  justify-content: center;
  height: 33px;
}
.page-template-tpl-faq .input-search-container {
  width: 100%;
  max-width: 420px;
  height: 48px;
  position: relative;
}
.page-template-tpl-faq .input-search-container #search-faq {
  border: 1px solid #33a8eb;
  margin: 0 auto;
  text-align: center;
  width: 100%;
  height: 100%;
  color: #292c7e;
  font-weight: bold;
}
.page-template-tpl-faq .input-search-container .place-holder {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-template-tpl-faq .input-search-container .place-holder span {
  font-weight: bold;
  color: #33a8eb;
  opacity: 0.5;
  text-transform: uppercase;
}
.page-template-tpl-faq .faq-category {
  cursor: pointer;
}
.page-template-tpl-faq .faq-category.active {
  background-color: #292c7e;
  color: white;
}
.page-template-tpl-faq .faq-category.active:hover {
  color: white;
}
.page-template-tpl-faq * {
  box-shadow: none !important;
}
.page-template-tpl-faq h2 {
  font-family: "Big Shoulders Display";
}
.page-template-tpl-faq .accordion {
  margin-top: 20px;
  border-radius: 0;
  --bs-accordion-border-color: none;
}
.page-template-tpl-faq .accordion:focus {
  border: none;
}
.page-template-tpl-faq .accordion .accordion-item {
  border-radius: 0;
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-faq .accordion .accordion-item:nth-last-child(1) {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.page-template-tpl-faq .accordion .accordion-item h2 {
  font-family: "Satoshi";
}
.page-template-tpl-faq .accordion .accordion-item .accordion-button {
  border-radius: 0;
  background: none;
  padding-left: 0;
}
.page-template-tpl-faq .accordion .accordion-item .accordion-button:not(.collapsed) {
  box-shadow: unset;
}
.page-template-tpl-faq .accordion .accordion-body {
  padding-top: 0;
  padding-left: 0;
}

.accordion-button::after {
  background-image: url("../images/add.png");
}

.accordion-button:not(.collapsed)::after {
  background-image: url("../images/remove.png");
}

.page-template-tpl-scrollspy,
.page-template-tpl-whistleblowing,
.page-template-tpl-thankyou {
  /* navigation */
  /* trigger sample */
}
.page-template-tpl-scrollspy main,
.page-template-tpl-whistleblowing main,
.page-template-tpl-thankyou main {
  background-color: unset !important;
  color: black;
}
.page-template-tpl-scrollspy .hero-sopratitolo,
.page-template-tpl-whistleblowing .hero-sopratitolo,
.page-template-tpl-thankyou .hero-sopratitolo {
  color: #292c7e !important;
}
.page-template-tpl-scrollspy .sito-hero,
.page-template-tpl-whistleblowing .sito-hero,
.page-template-tpl-thankyou .sito-hero {
  text-align: center !important;
}
.page-template-tpl-scrollspy .container-sections,
.page-template-tpl-whistleblowing .container-sections,
.page-template-tpl-thankyou .container-sections {
  width: 75%;
  margin-left: 25%;
}
.page-template-tpl-scrollspy .container-sections section:nth-last-child(1),
.page-template-tpl-whistleblowing .container-sections section:nth-last-child(1),
.page-template-tpl-thankyou .container-sections section:nth-last-child(1) {
  margin-bottom: 0 !important;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-scrollspy .container-sections,
  .page-template-tpl-whistleblowing .container-sections,
  .page-template-tpl-thankyou .container-sections {
    width: 100%;
    margin-left: 0;
  }
}
.page-template-tpl-scrollspy .navigation,
.page-template-tpl-whistleblowing .navigation,
.page-template-tpl-thankyou .navigation {
  position: sticky;
  float: left;
  width: 20%;
  top: 20%;
}
.page-template-tpl-scrollspy .navigation ul,
.page-template-tpl-whistleblowing .navigation ul,
.page-template-tpl-thankyou .navigation ul {
  -ms-overflow-style: none; /* IE and Edge */
  scrollbar-width: none; /* Firefox */
  max-height: 400px;
  overflow-y: scroll;
  padding: 20px 0;
  display: flex;
  flex-direction: column;
  list-style: none;
  background-color: #fff;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  border-radius: 4px;
}
.page-template-tpl-scrollspy .navigation ul::-webkit-scrollbar,
.page-template-tpl-whistleblowing .navigation ul::-webkit-scrollbar,
.page-template-tpl-thankyou .navigation ul::-webkit-scrollbar {
  display: none;
}
.page-template-tpl-scrollspy .navigation ul li,
.page-template-tpl-whistleblowing .navigation ul li,
.page-template-tpl-thankyou .navigation ul li {
  border-bottom: 1px solid #d2d2d2;
  border-top: 1px solid #33a8eb;
}
.page-template-tpl-scrollspy .navigation ul li:nth-last-child(1),
.page-template-tpl-whistleblowing .navigation ul li:nth-last-child(1),
.page-template-tpl-thankyou .navigation ul li:nth-last-child(1) {
  border-bottom: none;
}
.page-template-tpl-scrollspy .navigation ul li:nth-child(1),
.page-template-tpl-whistleblowing .navigation ul li:nth-child(1),
.page-template-tpl-thankyou .navigation ul li:nth-child(1) {
  border-top: none;
}
.page-template-tpl-scrollspy .navigation li.active a,
.page-template-tpl-whistleblowing .navigation li.active a,
.page-template-tpl-thankyou .navigation li.active a {
  background-color: #33a8eb;
  color: #fff;
}
.page-template-tpl-scrollspy .navigation a,
.page-template-tpl-whistleblowing .navigation a,
.page-template-tpl-thankyou .navigation a {
  display: block;
  padding: 10px 10px;
  color: #33a8eb;
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
}
.page-template-tpl-scrollspy .navigation a:hover,
.page-template-tpl-whistleblowing .navigation a:hover,
.page-template-tpl-thankyou .navigation a:hover {
  background-color: #fafafa;
}
.page-template-tpl-scrollspy .section01,
.page-template-tpl-whistleblowing .section01,
.page-template-tpl-thankyou .section01 {
  background: #fff9f9;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  font-weight: 900;
  font-size: 50px;
}
.page-template-tpl-scrollspy .section02,
.page-template-tpl-whistleblowing .section02,
.page-template-tpl-thankyou .section02 {
  background: #fff0d9;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  font-weight: 900;
  font-size: 50px;
}
.page-template-tpl-scrollspy .section03,
.page-template-tpl-whistleblowing .section03,
.page-template-tpl-thankyou .section03 {
  background: #ffffd9;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  font-weight: 900;
  font-size: 50px;
}
.page-template-tpl-scrollspy .section04,
.page-template-tpl-whistleblowing .section04,
.page-template-tpl-thankyou .section04 {
  background: #d9ffd9;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  font-weight: 900;
  font-size: 50px;
}
.page-template-tpl-scrollspy .section05,
.page-template-tpl-whistleblowing .section05,
.page-template-tpl-thankyou .section05 {
  background: #d9d9ff;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 100vh;
  font-weight: 900;
  font-size: 50px;
}
.page-template-tpl-scrollspy .trigger,
.page-template-tpl-whistleblowing .trigger,
.page-template-tpl-thankyou .trigger {
  position: fixed;
  top: 0;
  bottom: 0;
  margin: auto 0;
  height: 1px;
  width: 100%;
}
.page-template-tpl-scrollspy .trigger:after,
.page-template-tpl-whistleblowing .trigger:after,
.page-template-tpl-thankyou .trigger:after {
  content: "";
  position: absolute;
  bottom: 100%;
  right: 0;
  color: #fff;
  font-size: 13px;
  padding: 2px 5px;
}

.page-template-tpl-thankyou .sito-hero {
  clip-path: none;
}

.page-template-tpl-blog .input-search-container-article {
  width: 100%;
  max-width: 420px;
  height: 48px;
  position: relative;
}
.page-template-tpl-blog .input-search-container-article #search_blog {
  border: 1px solid #33a8eb;
  margin: 0 auto;
  text-align: center;
  width: 100%;
  height: 100%;
  color: #292c7e;
  font-weight: bold;
}
.page-template-tpl-blog .input-search-container-article .place-holder {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-template-tpl-blog .input-search-container-article .place-holder span {
  font-weight: bold;
  color: #33a8eb;
  opacity: 0.5;
  text-transform: uppercase;
}
.page-template-tpl-blog .btn-category-blog {
  color: #292c7e;
  text-decoration: none;
}
.page-template-tpl-blog .btn-category-blog:hover {
  color: white;
  background-color: #292c7e;
}
.page-template-tpl-blog .card-hero-blog {
  padding: 5px 0;
  border-radius: 10px;
}
.page-template-tpl-blog .card-hero-blog:hover {
  background-color: #dbf2ff;
}
.page-template-tpl-blog .col-lg-6 > div:hover {
  background-color: #dbf2ff;
}
.page-template-tpl-blog .image-article-container {
  position: relative;
  overflow: hidden;
}
.page-template-tpl-blog .image-article-container .gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  background: rgb(51, 58, 128);
  background: linear-gradient(180deg, rgba(51, 58, 128, 0.55) 0%, rgba(51, 58, 128, 0) 37.5%, rgba(51, 58, 128, 0.05) 40%);
}
.page-template-tpl-blog .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 25px 0;
}
.page-template-tpl-blog .page-numbers li a {
  text-decoration: none;
  color: #292c7e;
}
.page-template-tpl-blog .page-numbers li a:hover {
  text-decoration: underline;
}
.page-template-tpl-blog .page-numbers .current {
  color: #292c7e;
  font-weight: bold;
}
.page-template-tpl-blog .splide__track {
  overflow: visible;
}
.page-template-tpl-blog .splide__track .splide__slide a {
  display: block;
  width: fit-content;
}

.page-template-tpl-news .input-search-container-article {
  width: 100%;
  max-width: 420px;
  height: 48px;
  position: relative;
}
.page-template-tpl-news .input-search-container-article #search_news {
  border: 1px solid #33a8eb;
  margin: 0 auto;
  text-align: center;
  width: 100%;
  height: 100%;
  color: #292c7e;
  font-weight: bold;
}
.page-template-tpl-news .input-search-container-article .place-holder {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 1;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-template-tpl-news .input-search-container-article .place-holder span {
  font-weight: bold;
  color: #33a8eb;
  opacity: 0.5;
  text-transform: uppercase;
}
.page-template-tpl-news .btn-category-news {
  color: #292c7e;
  text-decoration: none;
}
.page-template-tpl-news .btn-category-news:hover {
  color: white;
  background-color: #292c7e;
}
.page-template-tpl-news .col-lg-6 > div:hover {
  background-color: #dbf2ff;
}
.page-template-tpl-news .image-article-container {
  position: relative;
  overflow: hidden;
}
.page-template-tpl-news .image-article-container .gradient {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  pointer-events: none;
  background: rgb(51, 58, 128);
  background: linear-gradient(180deg, rgba(51, 58, 128, 0.55) 0%, rgba(51, 58, 128, 0) 37.5%, rgba(51, 58, 128, 0.05) 40%);
}
.page-template-tpl-news .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  margin: 25px 0;
}
.page-template-tpl-news .page-numbers li a {
  text-decoration: none;
  color: #33a8eb;
}
.page-template-tpl-news .page-numbers .current {
  color: #292c7e;
  font-weight: bold;
}
.page-template-tpl-news .splide__track {
  overflow: visible;
}
.page-template-tpl-news .splide__track .splide__slide a {
  display: block;
  width: fit-content;
}

.category .archivio-hero {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50vh;
  padding-top: 100px;
  margin-bottom: 50px;
  background-image: linear-gradient(360deg, #33a8eb 0%, rgba(51, 168, 235, 0) 100%);
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%);
}

.tag .archivio-hero {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 50vh;
  padding-top: 100px;
  margin-bottom: 50px;
  background-image: linear-gradient(360deg, #33a8eb 0%, rgba(51, 168, 235, 0) 100%);
  clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%);
}

.page-template-tpl-sitemap .sitemap-container .my-row {
  columns: 3;
  column-gap: 40px;
}
@media screen and (max-width: 768px) {
  .page-template-tpl-sitemap .sitemap-container .my-row {
    columns: unset;
    column-gap: unset;
  }
}
.page-template-tpl-sitemap .sitemap-container h3 {
  font-size: 40px;
  font-weight: bold;
  color: #292c7e;
  margin-bottom: 20px;
}
.page-template-tpl-sitemap .sitemap-container ul li {
  margin: 10px 0;
  padding-left: 40px;
}
.page-template-tpl-sitemap .sitemap-container ul li a {
  text-decoration: none;
  color: #292c7e;
}
.page-template-tpl-sitemap .sitemap-container ul li a:hover {
  text-decoration: underline;
}

.single-post {
  /*=====================================
  Comment Template CSS
  ========================================*/
}
.single-post .sito-hero {
  padding-top: 200px;
  padding-bottom: 150px;
}
@media screen and (max-width: 992px) {
  .single-post .sito-hero {
    padding-bottom: 100px;
  }
}
.single-post .sito-hero .immagine-singola {
  position: relative;
  height: 420px;
  width: 100%;
}
@media screen and (max-width: 992px) {
  .single-post .sito-hero .immagine-singola {
    position: relative;
    left: 50%;
    width: 80vw;
    height: auto;
    margin-bottom: 20px;
    transform: translateY(25%) translateX(-50%);
  }
}
.single-post .content .wp-block-heading {
  font-size: 50px;
  line-height: 1.2;
  color: #292c7e;
  font-weight: bold;
  margin-bottom: 40px;
}
@media screen and (max-width: 64em) {
  .single-post .content .wp-block-heading {
    font-size: 40px;
  }
}
@media screen and (max-width: 40em) {
  .single-post .content .wp-block-heading {
    font-size: 30px;
  }
}
.single-post .content .cosmo-block--paragraph p {
  font-size: 20px;
  line-height: 1.4;
  margin-bottom: 36px;
}
@media screen and (max-width: 64em) {
  .single-post .content .cosmo-block--paragraph p {
    font-size: 18px;
  }
}
.single-post .content .cosmo-block--quote {
  margin-bottom: 70px;
}
.single-post .content .cosmo-block--quote .quote {
  font-size: 40px;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: bold;
  font-family: "Big Shoulders Display";
  color: #d1a71d;
  margin-left: 150px;
  position: relative;
}
.single-post .content .cosmo-block--quote .quote::before {
  content: "";
  position: absolute;
  height: 68px;
  width: 68px;
  top: 0;
  left: -110px;
  transform: translateX(-50%);
  background-image: url("../images/quote.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 64em) {
  .single-post .content .cosmo-block--quote .quote {
    font-size: 30px;
  }
}
@media screen and (max-width: 40em) {
  .single-post .content .cosmo-block--quote .quote {
    font-size: 25px;
    margin-left: 0;
  }
  .single-post .content .cosmo-block--quote .quote::before {
    display: none;
  }
}
.single-post .content .cosmo-block--banner .banner {
  margin-bottom: 70px;
}
.single-post .content .cosmo-block--banner .banner img {
  /*height: 100%;
  width: 100%;
  object-fit: cover;*/
}
.single-post .content .cosmo-block--galleria {
  margin-bottom: 50px;
}
.single-post .content .cosmo-block--galleria > div {
  min-height: 280px;
  margin-bottom: 20px;
}
.single-post .content .cosmo-block--galleria > div img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.single-post .splide {
  margin-bottom: 50px;
}
.single-post .splide .splide__track {
  overflow: visible;
}
.single-post .splide .splide__slide .bordo {
  width: 100%;
  max-width: 530px;
}
.single-post .splide .splide__slide .bordo:hover {
  background-color: #dbf2ff;
}
@media screen and (max-width: 600px) {
  .single-post .splide .splide__slide .bordo {
    max-width: calc(100vw - 2rem);
  }
}
.single-post .splide .splide__slide .bordo span {
  display: block;
  margin-top: 20px;
  color: #33a8eb;
}
.single-post .splide .splide__slide .bordo img {
  width: 200px;
  height: 200px;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  .single-post .splide .splide__slide .bordo img {
    width: 100%;
    height: auto;
  }
}
.single-post .content {
  overflow: visible;
  position: relative;
}
.single-post .content .side-menu-articolo {
  position: sticky;
  top: 175px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  z-index: 99;
  margin-bottom: -200px;
}
@media screen and (max-width: 992px) {
  .single-post .content .side-menu-articolo {
    position: static;
    margin: 50px 0;
  }
}
.single-post .content .side-menu-articolo p a {
  background-color: #f9f9f9;
  font-size: 14px;
  font-weight: bold;
  color: #33a8eb;
  display: block;
  text-decoration: none;
  padding: 10px 0;
  padding-left: 1rem;
  border-top: 1px solid #33a8eb;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.single-post .content .side-menu-articolo p a svg {
  margin-right: 0.5rem;
}
.single-post .content .side-menu-articolo p a:hover {
  background-color: #d2091e;
  color: white;
}
.single-post .content .side-menu-articolo p a:hover svg {
  margin-right: 0.5rem;
}
.single-post .content .side-menu-articolo p a:hover svg path {
  fill: white;
}
.single-post .content .side-menu-articolo p:nth-last-child(1) a {
  border-bottom: 1px solid #33a8eb;
}
.single-post h3#comments {
  display: none;
}
.single-post .comment-body {
  padding: 20px 0;
  border-bottom: solid 2px #33a8eb;
}
.single-post .comment-body .comment-content {
  line-height: 1.5;
  font-size: 18px;
}
.single-post .comment-author {
  padding-left: 0px;
}
.single-post .comment-author img {
  display: none;
}
.single-post .comment-metadata {
  margin-left: 0;
}
.single-post .comments-area {
  margin-top: 40px;
}
.single-post .comments-area h2.comments-title {
  font-size: 25px;
  margin-bottom: 20px;
}
.single-post input {
  text-transform: unset !important;
}
.single-post .comment-list {
  margin: 0;
  padding: 0;
  list-style: none;
}
.single-post .comment-meta {
  margin-bottom: 20px;
}
.single-post .comment-meta a {
  color: #333;
}
.single-post .comment-author.vcard {
  position: relative;
}
.single-post .comment-author.vcard img {
  position: absolute;
  left: 0;
  top: 5px;
}
.single-post .comment-edit-link, .single-post .comment-reply-link {
  display: none !important;
}
.single-post .comments-area table {
  border-left: 1px solid rgba(221, 221, 221, 0.8666666667);
  border-bottom: 1px solid #ddd;
  margin-bottom: 20px;
}
.single-post .comments-area table td,
.single-post .comments-area table th {
  border-right: 1px solid #ddd;
  border-top: 1px solid #ddd;
  padding: 10px;
}
.single-post .comments-area th {
  background: #278cc1;
  color: #fff;
}
.single-post .comments-area dd {
  margin-bottom: 15px;
}
.single-post .comments-area .comments-content ul,
.single-post .comments-area .comments-content ol {
  padding-left: 15px;
}
.single-post .comments-area .comment-content ul,
.single-post .comments-area .comment-content ol {
  padding-left: 15px;
}
.single-post .comment-reply-title {
  font-family: "Big Shoulders Display", monospace;
  font-size: 40px;
  line-height: 1.2;
  color: #d1a71d;
  font-weight: 700;
  font-style: normal;
  text-transform: uppercase;
}
.single-post .comment-reply-link {
  background: #1e71f9;
  display: inline-block;
  padding: 5px 20px;
  color: #fff;
  border-radius: 5px;
}
.single-post .comment-list li.comment {
  margin-bottom: 30px;
  border-bottom: 1px solid #ddd;
  padding-bottom: 30px;
}
.single-post .comment-metadata {
  font-size: 80%;
}
.single-post .comment-reply-link {
  margin-top: 10px;
}
.single-post .comment-list li ol.children {
  padding-left: 50px;
  margin: 0;
  list-style: none;
  margin-top: 25px;
}
.single-post .comment-list li ol.children ol.children {
  padding-left: 20px;
}
.single-post .comment-list li.comment:last-child {
  border-bottom: 0px solid;
  padding-bottom: 0;
  margin-bottom: 0;
}
.single-post .comment-respond {
  margin-top: 50px;
}
.single-post .comment-notes {
  font-size: 90%;
  margin-bottom: 40px;
}
.single-post .comment-form label {
  display: block;
  margin-bottom: 10px;
}
.single-post .comment-form .form-submit [type=submit] {
  width: 100%;
  background-color: #292c7e;
  border: none;
  padding: 12px;
  color: #fff;
  font-weight: 700;
  border-radius: 6px;
  transition: ease 0.5s;
}
.single-post .comment-form .form-submit [type=submit]:hover {
  background-color: #34a8eb;
}
.single-post .logged-in-as {
  display: none;
}
.single-post .comment-form input,
.single-post .comment-form textarea {
  width: 100%;
  margin-bottom: 6px;
}
.single-post .comment-form input[type=submit] {
  width: auto;
}
.single-post .comment-form-comment label {
  font-size: 14px;
  font-weight: bold;
  color: #33a8eb;
  text-decoration: none;
}
.single-post .comment-form-comment textarea {
  border: 2px solid rgb(51, 168, 235);
  font-size: 20px;
  height: 100px;
  background-color: rgba(241, 241, 241, 0.48);
  border-radius: 10px;
  padding: 12px;
}

.single-poi .sito-hero {
  padding-top: 200px;
  padding-bottom: 100px;
}
.single-poi .sito-hero .immagine-singola {
  position: relative;
  height: 420px;
  width: 100%;
}
@media screen and (max-width: 992px) {
  .single-poi .sito-hero .immagine-singola {
    position: relative;
    left: 50%;
    width: 80vw;
    height: auto;
    transform: translateY(25%) translateX(-50%);
  }
}
.single-poi .content .wp-block-heading {
  font-size: 50px;
  line-height: 1.2;
  color: #292c7e;
  font-weight: bold;
  margin-bottom: 40px;
}
@media screen and (max-width: 64em) {
  .single-poi .content .wp-block-heading {
    font-size: 40px;
  }
}
@media screen and (max-width: 40em) {
  .single-poi .content .wp-block-heading {
    font-size: 30px;
  }
}
.single-poi .content .cosmo-block--paragraph p {
  font-size: 20px;
  line-height: 1.4;
  margin-bottom: 60px;
}
@media screen and (max-width: 64em) {
  .single-poi .content .cosmo-block--paragraph p {
    font-size: 18px;
  }
}
.single-poi .content .cosmo-block--quote {
  margin-bottom: 70px;
}
.single-poi .content .cosmo-block--quote .quote {
  font-size: 40px;
  line-height: 1.2;
  text-transform: uppercase;
  font-weight: bold;
  font-family: "Big Shoulders Display";
  color: #d1a71d;
  margin-left: 150px;
  position: relative;
}
.single-poi .content .cosmo-block--quote .quote::before {
  content: "";
  position: absolute;
  height: 68px;
  width: 68px;
  top: 0;
  left: -110px;
  transform: translateX(-50%);
  background-image: url("../images/quote.png");
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
}
@media screen and (max-width: 64em) {
  .single-poi .content .cosmo-block--quote .quote {
    font-size: 30px;
  }
}
@media screen and (max-width: 40em) {
  .single-poi .content .cosmo-block--quote .quote {
    font-size: 25px;
    margin-left: 0;
  }
  .single-poi .content .cosmo-block--quote .quote::before {
    display: none;
  }
}
.single-poi .content .cosmo-block--banner .banner {
  height: 350px;
  margin-bottom: 70px;
}
.single-poi .content .cosmo-block--banner .banner img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.single-poi .content .cosmo-block--galleria {
  margin-bottom: 50px;
}
.single-poi .content .cosmo-block--galleria > div {
  height: 280px;
  margin-bottom: 20px;
}
.single-poi .content .cosmo-block--galleria > div img {
  height: 100%;
  width: 100%;
  object-fit: cover;
}
.single-poi .splide {
  margin-bottom: 50px;
}
.single-poi .splide .splide__track {
  overflow: visible;
}
.single-poi .splide .splide__slide .bordo {
  width: 100%;
  max-width: 530px;
}
.single-poi .splide .splide__slide .bordo:hover {
  background-color: #dbf2ff;
}
@media screen and (max-width: 600px) {
  .single-poi .splide .splide__slide .bordo {
    max-width: calc(100vw - 2rem);
  }
}
.single-poi .splide .splide__slide .bordo span {
  display: block;
  margin-top: 20px;
  color: #33a8eb;
}
.single-poi .splide .splide__slide .bordo img {
  width: 200px;
  height: 200px;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  .single-poi .splide .splide__slide .bordo img {
    width: 100%;
    height: auto;
  }
}
.single-poi .content {
  overflow: visible;
  position: relative;
}
.single-poi .content .side-menu-articolo {
  position: sticky;
  top: 175px;
  display: flex;
  align-items: center;
  justify-content: flex-end;
  z-index: 99;
  margin-bottom: -200px;
}
@media screen and (max-width: 992px) {
  .single-poi .content .side-menu-articolo {
    position: static;
    margin: 50px 0;
  }
}
.single-poi .content .side-menu-articolo p a {
  background-color: #f9f9f9;
  font-size: 14px;
  font-weight: bold;
  color: #33a8eb;
  display: block;
  text-decoration: none;
  padding: 10px 0;
  padding-left: 1rem;
  border-top: 1px solid #33a8eb;
  display: flex;
  align-items: center;
  justify-content: flex-start;
}
.single-poi .content .side-menu-articolo p a svg {
  margin-right: 0.5rem;
}
.single-poi .content .side-menu-articolo p a:hover {
  background-color: #d2091e;
  color: white;
}
.single-poi .content .side-menu-articolo p a:hover svg {
  margin-right: 0.5rem;
}
.single-poi .content .side-menu-articolo p a:hover svg path {
  fill: white;
}
.single-poi .content .side-menu-articolo p:nth-last-child(1) a {
  border-bottom: 1px solid #33a8eb;
}

.single-hotel .sito-hero {
  padding-bottom: 100px;
}
@media screen and (max-width: 992px) {
  .single-hotel .sito-hero {
    padding-bottom: 50px;
  }
}
@media screen and (max-width: 992px) {
  .single-hotel .hero-descrizione {
    margin-top: 1rem;
  }
}

.page-template-tpl-hotels .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 25px;
  color: #292c7e;
}
.page-template-tpl-hotels .page-numbers a {
  text-decoration: none;
}
.page-template-tpl-hotels .page-numbers a:hover {
  text-decoration: underline;
}
.page-template-tpl-hotels .archive-hotels .btn-category {
  text-decoration: none;
  color: #292c7e;
}
.page-template-tpl-hotels .archive-hotels .btn-category:hover {
  color: white;
  background-color: #292c7e;
}
.page-template-tpl-hotels .archive-hotels .card-hotel:hover {
  background-color: #dbf2ff;
}

.page-template-tpl-pois .page-numbers {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  margin-bottom: 25px;
  color: #292c7e;
}
.page-template-tpl-pois .page-numbers a {
  text-decoration: none;
}
.page-template-tpl-pois .page-numbers a:hover {
  text-decoration: underline;
}
.page-template-tpl-pois .btn-pois {
  text-decoration: none;
  color: #292c7e;
}
.page-template-tpl-pois .btn-pois:hover {
  color: white;
  background-color: #292c7e;
}
.page-template-tpl-pois .card-poi:hover {
  background-color: #dbf2ff;
}

.coupon-page-body {
  padding-top: 5rem;
  padding-bottom: 5rem;
}
.coupon-page-body .customer-details-list {
  display: flex;
  flex-direction: column;
}
.coupon-page-body .customer-details-list .customer-details-item {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 0.5rem;
}
.coupon-page-body .customer-details-list .customer-details-item .customer-details-label {
  font-weight: 700;
}
.coupon-page-body .form-send-coupon-component {
  background-color: #292c7e;
  border-radius: var(--bs-border-radius-xl) !important;
  padding: 2rem;
}
.coupon-page-body .form-send-coupon-component .error-message {
  display: none;
  color: red;
  font-size: 12px;
}
.coupon-page-body .form-send-coupon-component input.invalid {
  border-color: red;
}
.coupon-page-body .form-send-coupon-component input.invalid + .error-message {
  display: block;
}
.coupon-page-body .form-send-coupon-component .btn-primary {
  border-radius: 0;
  background-color: #d2091e;
  border-color: #d2091e;
  width: 100%;
  text-transform: uppercase;
}
.coupon-page-body .form-send-coupon-component .btn-primary:hover {
  color: #d2091e;
  background-color: white;
}
.coupon-page-body .form-send-coupon-component .form-section-body {
  margin-bottom: 15px;
}
.coupon-page-body .form-send-coupon-component .form-section-body .form-group {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
  margin-bottom: 10px;
}
.coupon-page-body .form-send-coupon-component .form-section-body .form-group label {
  display: block;
  margin-bottom: 5px;
}
.coupon-page-body .form-send-coupon-component .form-section-body .form-group input {
  width: 100%;
}
.coupon-page-body .form-send-coupon-component .form-section-body .form-group input[type=text],
.coupon-page-body .form-send-coupon-component .form-section-body .form-group input[type=email] {
  color: #292c7e !important;
  outline: 1px solid white;
  border-radius: 0;
  border: 0;
  width: 100%;
  height: 40px;
  text-align: center;
}
.coupon-page-body .form-notification {
  display: none;
  color: white;
  text-align: center;
  padding: 15px;
}
.coupon-page-body .form-notification.show {
  display: block;
}
.coupon-page-body .form-notification.success {
  background-color: #47c6a3;
}
.coupon-page-body .form-notification.error {
  background-color: red;
}

.influencer-component {
  padding-top: 90px;
  padding-bottom: 90px;
}
.influencer-component .component-title {
  color: #1e2e42;
  font-family: "Big Shoulders Display";
  font-size: 40px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  margin-bottom: 50px;
}
@media screen and (max-width: 767px) {
  .influencer-component .component-title {
    font-size: 30px;
  }
}
.influencer-component .influencer-card {
  display: flex;
  flex-direction: column;
  height: calc(100% - 20px);
  gap: 25px;
  background-color: #FFF;
  margin-bottom: 45px;
  border-radius: 8px;
  padding: 20px;
  box-shadow: -5px 10px 10px 0px rgba(255, 0, 0, 0.15), -10px -5px 10px 0px rgba(51, 168, 235, 0.25);
}
.influencer-component .influencer-card .influencer-header {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 20px;
}
.influencer-component .influencer-card .influencer-header .influencer-thumb {
  flex: 0 0 auto;
  width: 100px;
  height: 100px;
  border-radius: 50%;
  overflow: hidden;
}
.influencer-component .influencer-card .influencer-header .influencer-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.influencer-component .influencer-card .influencer-header .influencer-details {
  flex: 0 0 auto;
  width: calc(100% - 120px);
}
.influencer-component .influencer-card .influencer-header .influencer-details .influencer-name {
  color: #292c7e;
  font-family: "Satoshi";
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.2;
  margin-bottom: 20px;
}
.influencer-component .influencer-card .influencer-header .influencer-details .influencer-social {
  display: flex;
  gap: 10px;
  list-style: none;
  padding: 0;
  margin: 0;
}
.influencer-component .influencer-card .influencer-header .influencer-details .influencer-social > li {
  display: block;
}
.influencer-component .influencer-card .influencer-header .influencer-details .influencer-social > li a {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  width: 25px;
  height: 25px;
  font-size: 16px;
  color: #292c7e;
  text-decoration: none;
  border-radius: 50%;
  background-color: rgba(41, 44, 126, 0.1);
}
.influencer-component .influencer-card .influencer-body .influencer-post svg {
  margin-bottom: 10px;
}
.influencer-component .influencer-card .influencer-body .influencer-post .post-content {
  color: #000;
  font-family: "Satoshi";
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}
.influencer-component .influencer-card .influencer-footer .influencer-link {
  display: inline-flex;
  align-items: center;
  color: #33a8eb;
  font-family: "Satoshi";
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
}

.rassegna-stampa-component {
  background-color: #dbf2ff;
  padding-top: 70px;
  padding-bottom: 70px;
  overflow: hidden;
}
.rassegna-stampa-component .component-header {
  margin-bottom: 70px;
}
.rassegna-stampa-component .component-header .component-title {
  color: #292c7e;
  font-family: "Big Shoulders Display";
  font-size: 40px;
  font-style: normal;
  font-weight: 700;
  line-height: 1;
  text-transform: uppercase;
  margin-bottom: 10px;
}
@media screen and (max-width: 767px) {
  .rassegna-stampa-component .component-header .component-title {
    font-size: 30px;
  }
}
.rassegna-stampa-component .component-header .component-description {
  color: #232324;
  font-family: "Satoshi";
  font-size: 18px;
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: -0.18px;
}
.rassegna-stampa-component .component-header .splide {
  margin-top: 70px;
}
.rassegna-stampa-component .component-header .splide .splide__track {
  overflow: visible;
}
.rassegna-stampa-component .component-header .splide img {
  filter: grayscale(100%); /* Standard */
  -webkit-filter: grayscale(100%); /* Webkit */
  filter: url("data:image/svg+xml;utf8,<svg version='1.1' xmlns='http://www.w3.org/2000/svg' height='0'><filter id='greyscale'><feColorMatrix type='matrix' values='0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0.3333 0.3333 0.3333 0 0 0 0 0 1 0' /></filter></svg>#greyscale"); /* Firefox4-34*/
  filter: gray; /* IE6-9 */
  -webkit-filter: grayscale(1); /* Old WebKit */
}
.rassegna-stampa-component .component-body .press-card {
  display: flex;
  flex-wrap: wrap;
  height: calc(100% - 20px);
  border-radius: 8px;
  background: #F6F6F6;
  margin-bottom: 20px;
  padding: 20px;
}
.rassegna-stampa-component .component-body .press-card .press-header {
  width: 100%;
  margin-bottom: 40px;
}
.rassegna-stampa-component .component-body .press-card .press-body {
  flex: 1;
}
.rassegna-stampa-component .component-body .press-card .press-body .press-title {
  color: #292c7e;
  font-family: "Satoshi";
  font-size: 20px;
  font-style: normal;
  font-weight: 700;
  line-height: 1.4;
  text-transform: uppercase;
  margin-bottom: 8px;
}
.rassegna-stampa-component .component-body .press-card .press-body .press-excerpt {
  font-family: "Satoshi";
  font-size: 16px;
  font-weight: 400;
  line-height: 1.4;
}
.rassegna-stampa-component .component-body .press-card .press-thumb {
  flex: 0 0 auto;
  width: 200px;
  height: 190px;
  border-radius: 8px;
  overflow: hidden;
  margin-left: 15px;
}
@media screen and (max-width: 991px) {
  .rassegna-stampa-component .component-body .press-card .press-thumb {
    width: 100%;
    margin-left: 0;
    margin-top: 15px;
    margin-bottom: 15px;
  }
}
.rassegna-stampa-component .component-body .press-card .press-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}
.rassegna-stampa-component .component-body .press-card .press-footer {
  width: 100%;
}
.rassegna-stampa-component .component-body .press-card .press-footer .press-link {
  display: inline-flex;
  align-items: center;
  color: #33a8eb;
  font-family: "Satoshi";
  font-size: 14px;
  font-weight: 700;
  text-decoration: none;
}

.page-template-tpl-whistleblowing .modal-segnalazione {
  position: fixed;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 9999999;
  backdrop-filter: blur(5px);
  display: flex;
  align-items: center;
  justify-content: center;
}
.page-template-tpl-whistleblowing .modal-segnalazione .card {
  border: none;
  border-radius: 20px;
  box-shadow: 0px 10px 20px 0px rgba(0, 0, 0, 0.25);
  padding: 60px 40px;
}
.page-template-tpl-whistleblowing .modal-segnalazione .card .button {
  padding: 12px 20px;
  width: fit-content;
  margin: 0 auto;
  cursor: pointer;
  border: 1px solid #d2091e;
  transition: all ease 0.3s;
  margin-top: 40px;
  margin-bottom: 20px;
}
.page-template-tpl-whistleblowing .modal-segnalazione .card .button.disabled {
  pointer-events: none;
  opacity: 0.5;
}
.page-template-tpl-whistleblowing .modal-segnalazione .card .button:hover {
  color: #d2091e;
  background-color: white;
}
.page-template-tpl-whistleblowing .card-segnalazione {
  background-color: #e5e5e5;
  border-radius: 8px;
  padding: 1.2rem;
  margin-bottom: 20px;
}
.page-template-tpl-whistleblowing .card-segnalazione .titolo-segnalazione {
  border-bottom: 1px dashed #959595;
  padding-bottom: 8px;
  margin-bottom: 8px;
}
.page-template-tpl-whistleblowing .card-segnalazione .button {
  display: block;
  width: fit-content;
  border: 1px solid #d2091e;
  text-decoration: none;
  padding: 0.8rem 1.2rem;
  transition: all ease 0.3s;
}
.page-template-tpl-whistleblowing .card-segnalazione .button:hover {
  color: white;
  background-color: #d2091e;
}
.page-template-tpl-whistleblowing .informativa-whistleblowing-button {
  transition: all ease 0.3s;
  border: 1px solid #33a8eb;
  color: #fff;
}
.page-template-tpl-whistleblowing .informativa-whistleblowing-button:hover {
  color: #33a8eb;
  background-color: white;
}

#not-found {
  min-height: 50vh;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
  width: 100%;
}
#not-found .space {
  min-height: 30vh;
  max-height: 300px;
}
#not-found .container {
  margin-bottom: 50px;
}
#not-found h1 {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
#not-found .safe {
  animation: float 6s ease-in-out infinite;
  margin: 0 -100px;
  width: 30vw;
  max-width: 300px;
  height: auto;
}
@media screen and (max-width: 768px) {
  #not-found .safe {
    margin: 0 -10vw;
  }
}
#not-found .four-logo {
  width: 25vw;
  max-width: 300px;
  height: auto;
}
#not-found .waves {
  width: 100%;
  height: 25vw;
  position: relative;
}
#not-found .waves .wave {
  position: absolute;
  width: 100vw;
  height: 25vw;
  top: 0;
  left: 0;
}
#not-found .waves .one {
  background-image: url("../images/waves/one.svg");
  background-size: 100%;
  background-repeat: repeat-x;
  background-position: 0% 101%;
  z-index: 10;
}
#not-found .waves .two {
  background-image: url("../images/waves/two.svg");
  background-size: 100%;
  background-repeat: repeat-x;
  background-position: 0% 0%;
  z-index: 9;
}
#not-found .waves .three {
  background-image: url("../images/waves/three.svg");
  background-size: 100%;
  background-repeat: repeat-x;
  background-position: 0% 0%;
  z-index: 8;
}
#not-found .waves .four {
  background-image: url("../images/waves/four.svg");
  background-size: 100%;
  background-repeat: repeat-x;
  background-position: 0% 0%;
  z-index: 7;
}

@keyframes float {
  0% {
    transform: translatey(0px);
  }
  50% {
    transform: translatey(-20px);
  }
  100% {
    transform: translatey(0px);
  }
}
@keyframes floatx {
  0% {
    background-position: 0% 101%;
  }
  50% {
    background-position: 50% 101%;
  }
  100% {
    background-position: 0% 101%;
  }
}
@keyframes floatxbig {
  0% {
    background-position: 0% 101%;
  }
  50% {
    background-position: 50% 101%;
  }
  100% {
    background-position: 0% 101%;
  }
}
.page-template-tpl-homepage #homepage-hero, .page-template-tpl-landing-2024-04 #homepage-hero {
  overflow: hidden;
  position: relative;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-homepage #homepage-hero, .page-template-tpl-landing-2024-04 #homepage-hero {
    min-height: 100vh;
    clip-path: unset;
  }
}
.page-template-tpl-homepage #homepage-hero .splide__slide, .page-template-tpl-landing-2024-04 #homepage-hero .splide__slide {
  padding-bottom: 120px;
}
.page-template-tpl-homepage #homepage-hero #iframe-hero, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero {
  position: absolute;
  top: 50%;
  right: calc((100% - 1300px) / 2);
  transform: translate(0%, -50%);
}
@media screen and (max-width: 1400px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero {
    right: calc((100% - 1200px) / 2);
  }
}
@media screen and (max-width: 1300px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero {
    right: calc((100% - 1140px) / 2);
  }
}
@media screen and (max-width: 1200px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero {
    right: calc((100% - 840px) / 2);
  }
}
.page-template-tpl-homepage #homepage-hero #iframe-hero .card-center, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-center {
  min-width: 375px;
}
@media screen and (max-width: 992px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero {
    top: unset;
    right: unset;
    position: relative;
    transform: unset;
    margin-top: -120px;
  }
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-center, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-center {
    min-width: 300px;
  }
}
@media screen and (max-width: 450px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-center, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-center {
    min-width: 100%;
    border-radius: 8px;
    padding: 20px 10px;
    overflow: hidden;
  }
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-center .iframe-modal, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-center .iframe-modal {
    padding: 20px 10px;
  }
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-left,
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-right, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-left,
  .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-right {
    display: none;
  }
}
@media screen and (min-width: 300px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero .card-center, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .card-center {
    padding: 20px 10px !important;
  }
}
@media screen and (max-width: 450px) {
  .page-template-tpl-homepage #homepage-hero #iframe-hero .air-datepicker .air-datepicker--navigation, .page-template-tpl-landing-2024-04 #homepage-hero #iframe-hero .air-datepicker .air-datepicker--navigation {
    padding: 0 1rem;
  }
}

#sb_instagram {
  transform: rotate(-4deg);
}
@media screen and (max-width: 992px) {
  #sb_instagram {
    transform: none;
  }
}
#sb_instagram .sbi_photo_wrap {
  border-radius: 4px;
  overflow: hidden;
}

@keyframes rotation {
  from {
    transform: rotate(0deg);
  }
  to {
    transform: rotate(359deg);
  }
}
@keyframes scale {
  from {
    transform: scale(1);
  }
  to {
    transform: scale(0.85);
  }
}
.sito-map #acciarello svg:nth-child(2), .sito-map #tremestieri svg:nth-child(2), .sito-map #vesta svg:nth-child(2),
.sito-map .bn-map-single-nave svg:nth-child(2) {
  animation: scale 1.5s infinite linear alternate;
}
.sito-map #acciarello circle, .sito-map #tremestieri circle, .sito-map #vesta circle,
.sito-map .bn-map-single-nave circle {
  margin-left: -2px;
  transform-origin: center;
  animation: rotation 7s infinite linear;
}
.sito-map .container-map {
  padding-top: 64.86%;
  overflow: hidden;
  position: relative;
  min-height: 100%;
  max-height: 992px;
}
@media screen and (max-width: 768px) {
  .sito-map .container-map {
    padding-top: 129.72%;
  }
}
.sito-map .container-map .map-link {
  text-decoration: none;
}
.sito-map .container-map .map-link:hover {
  text-decoration: underline;
}
.sito-map .container-map .container-image {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 768px) {
  .sito-map .container-map .container-image {
    width: 200%;
    margin-left: -50%;
  }
}
.sito-map .container-map .container-image img {
  position: relative;
  width: 100%;
  height: auto;
}
.sito-map .container-map .container-image .container {
  position: absolute;
  top: 25%;
  left: 50%;
  width: 100%;
  max-width: 1320px;
  z-index: 2;
  transform: translateX(-50%);
}
@media screen and (max-width: 768px) {
  .sito-map .container-map .container-image .container {
    top: 5%;
    transform: translateX(-15%);
  }
}
.sito-map .container-map .destinazione-mappa a {
  text-decoration: none;
  color: white;
  border: 2px solid #292c7e;
  background: rgba(219, 242, 255, 0.8);
  padding: 8px 14px;
  border-radius: 100vmax;
  transition: all ease 0.3s;
}
@media screen and (max-width: 768px) {
  .sito-map .container-map .destinazione-mappa a {
    padding: 2px 4px;
  }
}
.sito-map .container-map .destinazione-mappa a:hover {
  background: #33a8eb;
}
.sito-map .container-map .destinazione-mappa.piombino {
  position: absolute;
  bottom: 70%;
  left: 62%;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .sito-map .container-map .destinazione-mappa.piombino {
    bottom: 74%;
    left: 62%;
  }
}
@media screen and (max-width: 350px) {
  .sito-map .container-map .destinazione-mappa.piombino {
    left: 60%;
  }
}
.sito-map .container-map .destinazione-mappa.portoferraio {
  position: absolute;
  bottom: 38%;
  left: 33%;
  z-index: 3;
}
@media screen and (max-width: 768px) {
  .sito-map .container-map .destinazione-mappa.portoferraio {
    bottom: 30%;
    left: 38%;
  }
}
.sito-map .container-map #acciarello a, .sito-map .container-map #tremestieri a, .sito-map .container-map #vesta a,
.sito-map .container-map .bn-map-single-nave a {
  transition: all ease 0.3s;
}
.sito-map .container-map #acciarello a:hover, .sito-map .container-map #tremestieri a:hover, .sito-map .container-map #vesta a:hover,
.sito-map .container-map .bn-map-single-nave a:hover {
  background-color: white;
  color: #292c7e;
}

.map-timer {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background-color: white;
  border-radius: 4px;
  padding: 5px;
}

.sito-hero {
  overflow: hidden;
  padding-top: 260px;
  padding-bottom: 100px;
  background: rgb(51, 168, 235);
  background: linear-gradient(180deg, rgba(51, 168, 235, 0) 20%, rgb(51, 168, 235) 100%);
  clip-path: polygon(0 0, 100% 0, 100% 85%, 0% 100%);
  position: relative;
}
.sito-hero.immagini {
  padding-bottom: 0px;
}
@media screen and (max-width: 992px) {
  .sito-hero {
    padding-bottom: 100px;
    clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%);
  }
  .sito-hero.immagini {
    padding-bottom: 100px;
  }
}
.sito-hero .overlay-hero {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  background: rgb(255, 255, 255);
  background: linear-gradient(180deg, rgba(255, 255, 255, 0) 0%, rgba(0, 0, 0, 0.8) 100%);
}
@media screen and (max-width: 576px) {
  .sito-hero {
    clip-path: polygon(0 0, 100% 0, 100% 95%, 0% 100%);
    padding-top: 200px;
    padding-bottom: 125px;
  }
  .sito-hero.immagini {
    padding-bottom: 125px;
  }
  .sito-hero p,
  .sito-hero h2 {
    text-align: center;
    color: white;
  }
  .sito-hero h2 {
    font-size: 50px !important;
  }
}
.sito-hero.immagine_sfondo p,
.sito-hero.immagine_sfondo h2 {
  text-align: center;
  color: white;
}
@media screen and (max-width: 992px) {
  .sito-hero.immagine_sfondo {
    clip-path: polygon(0 0, 100% 0, 100% 90%, 0% 100%);
  }
}
.sito-hero .buttons {
  display: flex;
  align-items: center;
  justify-content: start;
  gap: 20px;
}
@media screen and (max-width: 576px) {
  .sito-hero .buttons {
    flex-direction: column;
    align-items: center;
    justify-content: center;
  }
}
.sito-hero img {
  box-shadow: -10px -5px 25px 0px rgba(51, 168, 235, 0.5019607843), -5px 10px 35px 0px rgba(255, 0, 0, 0.2509803922);
  border-radius: 8px;
}
.sito-hero .immagine-background {
  box-shadow: unset;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: 0;
}
.sito-hero h2 {
  font-family: "Big Shoulders Display";
}
.sito-hero .btn {
  padding: 12px 40px;
}
.sito-hero .immagine-singola-mobile img {
  width: 100%;
  height: auto;
  object-fit: cover;
  margin-bottom: 20px;
}
.sito-hero .immagine-doppia {
  position: relative;
  height: 530px;
}
@media screen and (max-width: 992px) {
  .sito-hero .immagine-doppia {
    height: fit-content;
  }
}
.sito-hero .immagine-doppia .immagine-principale {
  height: 220px;
  width: 350px;
  position: absolute;
  z-index: 1;
  transform: translate(-35%);
}
@media screen and (max-width: 1300px) {
  .sito-hero .immagine-doppia .immagine-principale {
    height: 189px;
    width: 310px;
  }
}
@media screen and (max-width: 1025px) {
  .sito-hero .immagine-doppia .immagine-principale {
    height: 175px;
    width: 290px;
  }
}
@media screen and (max-width: 992px) {
  .sito-hero .immagine-doppia .immagine-principale {
    width: 50%;
    height: auto;
    position: relative;
    transform: unset;
  }
}
.sito-hero .immagine-doppia .immagine-secondaria {
  height: 300px;
  width: 520px;
  position: absolute;
  transform: translate(0%, 25%);
}
@media screen and (max-width: 1300px) {
  .sito-hero .immagine-doppia .immagine-secondaria {
    height: 256px;
    width: 420px;
  }
}
@media screen and (max-width: 1025px) {
  .sito-hero .immagine-doppia .immagine-secondaria {
    height: 245px;
    width: 400px;
  }
}
@media screen and (max-width: 992px) {
  .sito-hero .immagine-doppia .immagine-secondaria {
    width: 80%;
    height: auto;
    position: relative;
    transform: unset;
    margin-top: -10%;
    margin-left: 20%;
    margin-bottom: 50px;
  }
}
.sito-hero .immagine-singola {
  position: relative;
  height: 530px;
  width: 100%;
}
@media screen and (max-width: 576px) {
  .sito-hero .immagine-singola {
    height: 265px;
  }
}
.sito-hero .immagine-singola img, .sito-hero .immagine-singola .immagine-principale, .sito-hero .immagine-singola .immagine-secondaria {
  height: auto;
  width: 100%;
  position: absolute;
  z-index: 1;
  transform: translateY(10%);
}
@media screen and (max-width: 992px) {
  .sito-hero .immagine-singola img, .sito-hero .immagine-singola .immagine-principale, .sito-hero .immagine-singola .immagine-secondaria {
    position: relative;
    left: 50%;
    width: 80vw;
    height: auto;
    transform: translateY(25%) translateX(-50%);
  }
}

.card-scaduta {
  position: relative;
  overflow: hidden;
  box-shadow: 0px 10px 20px 0px rgba(0, 0, 0, 0.25);
}
.card-scaduta .bg-image {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  z-index: 0;
  background-position: bottom;
  background-size: cover;
  background-repeat: no-repeat;
  opacity: 0.5;
}
.card-scaduta h2,
.card-scaduta p,
.card-scaduta a {
  position: relative;
}
.card-scaduta .btn {
  color: #33a8eb;
  background-color: white;
  border-radius: 0;
  margin-top: 20px;
  font-weight: bold !important;
}

@media screen and (max-width: 576px) {
  .single-hotel .sito-hero {
    clip-path: polygon(0 0, 100% 0, 100% 95%, 0% 100%);
    padding-top: 200px;
    padding-bottom: 100px;
  }
  .single-hotel .sito-hero p,
  .single-hotel .sito-hero h2 {
    text-align: start;
    color: #232324;
  }
  .single-hotel .sito-hero h2 {
    font-size: 50px !important;
  }
}

.testo-immagine {
  padding: 50px 0;
}
@media screen and (max-width: 992px) {
  .testo-immagine {
    padding: 50px 0;
  }
}
.testo-immagine img {
  width: 100%;
  height: auto;
  border-radius: 8px;
}
.testo-immagine #contenuto em {
  color: #292c7e;
  padding: 4px 12px;
  background-color: #f2f2f2;
  border-radius: 8px;
  font-weight: bold;
}
.testo-immagine #contenuto a {
  text-decoration: none;
}
.testo-immagine .links-list li {
  padding: 20px;
  background-color: #f2f2f2;
  border-radius: 8px;
  gap: 20px;
}
.testo-immagine .links-list li a {
  text-decoration: none;
}
.testo-immagine a {
  color: #292c7e;
  font-size: 16px;
  background-color: #F9F9F9;
  border-radius: 8px;
  padding: 4px 12px;
  margin-top: 10px;
  display: block;
  max-width: fit-content;
}
.testo-immagine a:hover {
  background-color: #292c7e;
  color: white;
}
.testo-immagine .whatsapp {
  color: #292c7e;
  font-size: 16px;
  font-weight: bold;
  border-radius: 100vmax;
  background-color: #BDDCCE;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  padding-left: 50px;
  padding-right: 20px;
  height: 45px;
  overflow: hidden;
}
.testo-immagine .whatsapp::after {
  content: url("../images/whatsapp.svg"); /* with class ModalCarrot ??*/
  position: absolute;
  top: 50%;
  left: 0.75rem;
  transform: translateY(-45%);
}
.testo-immagine .whatsapp:hover {
  background-color: #66a58c;
  color: white;
}

.testo-immagine-lungo {
  padding: 50px 0;
}
@media screen and (max-width: 992px) {
  .testo-immagine-lungo {
    padding: 50px 0;
  }
}
.testo-immagine-lungo img {
  border-radius: 8px;
}
.testo-immagine-lungo h2 {
  font-family: "Big Shoulders Display";
}
.testo-immagine-lungo h3 {
  margin-bottom: 20px;
  text-transform: uppercase;
}
.testo-immagine-lungo #contenuto-piccolo p {
  font-size: 18px;
}
.testo-immagine-lungo #contenuto-grande p {
  font-size: 20px;
}
.testo-immagine-lungo .contenuto ul {
  list-style: disc;
  margin-left: 16px;
}
.testo-immagine-lungo .contenuto ul li {
  margin-top: 6px;
}
.testo-immagine-lungo .btn {
  border: 2px solid #33a8eb;
  border-radius: 0;
  background-color: white;
  color: #33a8eb;
  padding: 6px 100px;
  font-weight: bold;
  margin: 16px 0;
}
@media screen and (max-width: 992px) {
  .testo-immagine-lungo .btn {
    padding: 10px;
  }
}
.testo-immagine-lungo .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.ombra {
  filter: drop-shadow(0px 10px 20px rgba(0, 0, 0, 0.25));
}

.ombra-incrocio, .banner-cta .banner-cta-content {
  filter: drop-shadow(-5px 10px 35px rgba(255, 0, 0, 0.25)) drop-shadow(-10px -5px 25px rgba(51, 168, 235, 0.5));
}

.banner-cta {
  margin: 50px 0;
  position: relative;
}
@media screen and (max-width: 992px) {
  .banner-cta {
    margin: 25px 0;
  }
}
.banner-cta h3 {
  font-family: "Big Shoulders Display";
  margin-top: 12px;
}
.banner-cta .divisore {
  height: 1px;
  width: 80%;
  border: 1px dashed rgba(41, 44, 126, 0.2);
}
.banner-cta .col-lg-10 {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  padding-top: 50px;
  padding-bottom: 50px;
}
.banner-cta .banner-cta-background {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 0;
}
.banner-cta .banner-cta-content {
  position: relative;
  border-radius: 8px;
  width: 100%;
  max-width: 860px;
  display: flex;
  align-items: stretch;
  justify-content: center;
}
.banner-cta .banner-cta-content .center {
  padding: 80px 80px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  background-color: white;
}
@media screen and (max-width: 992px) {
  .banner-cta .banner-cta-content .center {
    padding: 20px;
    text-align: center;
  }
}
.banner-cta .banner-cta-content .center .btn {
  font-weight: bold;
  border-radius: 0;
  padding: 10px 100px;
  margin-top: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all ease 0.3s;
}
@media screen and (max-width: 992px) {
  .banner-cta .banner-cta-content .center .btn {
    padding: 5px 50px;
  }
}
.banner-cta .banner-cta-content .center .btn.bg-rosso-navy {
  border: 1px solid #D2091E;
  color: white;
}
.banner-cta .banner-cta-content .center .btn.bg-rosso-navy:hover {
  color: #D2091E;
  background-color: white;
}
.banner-cta .banner-cta-content .center .btn:not(.bg-rosso-navy):hover {
  opacity: 0.5;
}
.banner-cta .banner-cta-content .center .btn img {
  height: 24px;
  width: 24px;
  object-fit: cover;
}
.banner-cta .card-left,
.banner-cta .card-right {
  margin-top: 0px;
  min-width: 22px;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
}
.banner-cta .card-left .fill-space,
.banner-cta .card-right .fill-space {
  min-width: 22px;
  height: 100%;
  background-color: white;
  flex-grow: 1;
  margin-top: -1px;
  margin-bottom: -1px;
}
.banner-cta .card-left svg,
.banner-cta .card-right svg {
  min-width: 22px;
  min-height: 44px;
}
.banner-cta .card-left .corner-top-left,
.banner-cta .card-left .corner-bottom-left {
  min-height: 22px;
  min-width: 22px;
  background-color: white;
}
.banner-cta .card-left .corner-top-left {
  border-top-left-radius: 100%;
}
.banner-cta .card-left .corner-bottom-left {
  border-bottom-left-radius: 100%;
}
.banner-cta .card-right .corner-top-right,
.banner-cta .card-right .corner-bottom-right {
  min-height: 22px;
  min-width: 22px;
  background-color: white;
}
.banner-cta .card-right .corner-top-right {
  border-top-right-radius: 100%;
}
.banner-cta .card-right .corner-bottom-right {
  border-bottom-right-radius: 100%;
}

.faqs-flex {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .faqs-flex {
    padding: 50px 0;
  }
}
.faqs-flex * {
  box-shadow: none !important;
}
.faqs-flex h2 {
  font-family: "Big Shoulders Display";
}
.faqs-flex .accordion {
  background-color: rgba(0, 0, 0, 0);
  margin-top: 20px;
  border-radius: 0;
  --bs-accordion-border-color: none;
}
.faqs-flex .accordion:focus {
  border: none;
}
.faqs-flex .accordion .accordion-item {
  border-radius: 0;
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
}
.faqs-flex .accordion .accordion-item:nth-last-child(1) {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.faqs-flex .accordion .accordion-item h2 {
  font-family: "Satoshi";
}
.faqs-flex .accordion .accordion-item .accordion-button {
  border-radius: 0;
  background: none;
  padding-left: 0;
}
.faqs-flex .accordion .accordion-item .accordion-button:not(.collapsed) {
  box-shadow: unset;
}
.faqs-flex .accordion .accordion-body {
  padding-top: 0;
  padding-left: 0;
}

.accordion-button::after {
  background-image: url("../images/add.png");
}

.accordion-button:not(.collapsed)::after {
  background-image: url("../images/remove.png");
}

#faqs .ticket {
  position: static;
  filter: none;
  height: unset;
}

.support {
  background-color: #dbf2ff;
  padding: 70px 0;
}
.support h2 {
  font-family: "Big Shoulders Display";
  margin: 20px 0;
}
.support p {
  margin-bottom: 20px;
}
.support .row {
  gap: 20px;
}
.support .contact-card {
  border: 1px solid #33a8eb;
  border-radius: 8px;
  padding-top: 14px;
  padding-bottom: 14px;
}
.support .contact-card .btn {
  margin-top: 8px;
  background-color: #f9f9f9;
}

.banner-flex {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .banner-flex {
    padding: 50px 0;
  }
}
.banner-flex .banner-card {
  border: 1px solid #dbf2ff;
  gap: 100px;
  display: flex;
  align-items: stretch;
  justify-content: start;
  border-radius: 20px;
  overflow: hidden;
}
@media screen and (max-width: 992px) {
  .banner-flex .banner-card {
    flex-direction: column;
    gap: 20px;
  }
}
.banner-flex .banner-card img {
  max-width: 360px;
  object-fit: cover;
}
@media screen and (max-width: 992px) {
  .banner-flex .banner-card img {
    max-width: 100%;
  }
}
.banner-flex .banner-card .banner-text {
  padding: 40px 0;
  padding-right: 40px;
}
@media screen and (max-width: 992px) {
  .banner-flex .banner-card .banner-text {
    padding: 10px;
  }
}
.banner-flex .banner-card .banner-text .descrizione-banner b {
  font-weight: bold;
}
.banner-flex .banner-card .banner-text .btn {
  width: 100%;
  background-color: #33a8eb;
  margin-top: 30px;
  border-radius: 0;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all ease 0.3s;
}
.banner-flex .banner-card .banner-text .btn:hover {
  opacity: 0.5;
}

.cards-flex {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .cards-flex {
    padding: 50px 0;
  }
}
.cards-flex h2 {
  margin-bottom: 8px;
}
.cards-flex .row {
  gap: 20px;
}
.cards-flex .col-12:nth-last-child(1) {
  gap: 20px;
}
@media screen and (max-width: 992px) {
  .cards-flex .col-12:nth-last-child(1) {
    flex-wrap: wrap;
  }
}
.cards-flex .col-12:nth-last-child(1) .card {
  width: 100%;
  padding: 1rem;
  background-color: #f9f9f9;
}
.cards-flex .col-12:nth-last-child(1) .card img {
  height: 200px;
  width: 200px;
  object-fit: cover;
}
.cards-flex .col-12:nth-last-child(1) .card img.tonda {
  border-radius: 100%;
}
.cards-flex .col-12:nth-last-child(1) .card img.rettangolare {
  border-radius: 8px;
}
@media screen and (max-width: 992px) {
  .cards-flex .col-12:nth-last-child(1) .card img {
    display: block;
    margin: 0 auto;
  }
}
.cards-flex .col-12:nth-last-child(1) .card .esplora {
  text-decoration: none;
  font-size: 14px;
  font-weight: bold;
  color: #33a8eb;
  margin: 10px 0;
}
.cards-flex .col-12:nth-last-child(1) .card ul {
  margin-top: 8px;
}
.cards-flex .col-12:nth-last-child(1) .card ul li {
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
  padding: 10px 0;
  line-height: 2.2;
}
.cards-flex .col-12:nth-last-child(1) .card ul li p {
  margin: 0.75rem 0;
}
.cards-flex .col-12:nth-last-child(1) .card ul li a {
  background-color: white;
  color: #292c7e;
  text-decoration: none;
  padding: 4px 12px;
  border-radius: 8px;
  transition: all ease 0.3s;
}
.cards-flex .col-12:nth-last-child(1) .card ul li a:hover {
  background-color: #292c7e;
  color: white;
}

.simple-card {
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .simple-card {
    padding: 50px 0;
  }
}
.simple-card .card {
  padding: 20px;
  border: 1px solid #33a8eb;
}
.simple-card .card .text {
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
}
.simple-card .card .text h3,
.simple-card .card .text p {
  padding-top: 12px;
}
.simple-card .card .link {
  margin-top: 12px;
  border-top: 1px dashed rgba(41, 44, 126, 0.2);
  text-align: center;
}
.simple-card .card .link .btn {
  margin-top: 12px;
  margin-bottom: 12px;
  border: 1px solid #33a8eb;
  border-radius: 0;
  font-size: 14px;
  font-weight: bold;
  color: #33a8eb;
}
.simple-card .card .link .btn:hover {
  background-color: #33a8eb;
  color: white;
}

.griglia h2,
.griglia h3 {
  font-family: "Big Shoulders Display" !important;
}
.griglia .col-lg-6 .card-elemento {
  position: relative;
  height: 300px;
  border-radius: 8px;
  display: flex;
  align-items: start;
  justify-content: flex-end;
  flex-direction: column;
  text-decoration: none;
  overflow: hidden;
  padding: 20px;
  background-color: black;
}
.griglia .col-lg-6 .card-elemento img {
  opacity: 0.5;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  min-height: 100%;
  z-index: 0;
  object-fit: cover;
  transition: all ease 0.3s;
}
.griglia .col-lg-6 .card-elemento p,
.griglia .col-lg-6 .card-elemento h3 {
  position: relative;
  z-index: 1;
}
.griglia .col-lg-6 .card-elemento:hover img {
  transform-origin: center;
  transform: scale(1.25);
  opacity: 0.75;
}

.orari {
  overflow: hidden;
  padding: 100px 0;
}
@media screen and (max-width: 992px) {
  .orari {
    padding: 50px 0;
  }
}
.orari .prossima-partenza b {
  color: #d1a71d;
}
.orari .prossima-partenza svg {
  animation: rotationclessidra 3s infinite ease-in-out alternate;
}
.orari .---prossima-partenza svg {
  animation: rotationclessidra 3s infinite ease-in-out alternate;
}
.orari .col-lg-6 h2 {
  font-family: "Big Shoulders Display" !important;
  font-weight: bold !important;
}
.orari .ss-single {
  font-size: 40px !important;
  font-weight: bold !important;
  color: #d1a71d !important;
  font-family: "Big Shoulders Display" !important;
  text-transform: uppercase;
}
.orari .am > div,
.orari .pm > div {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  width: 100%;
  border-bottom: 1px solid rgba(41, 44, 126, 0.2);
}
.orari .splide {
  width: 100%;
}
.orari .splide .splide__track {
  overflow: visible;
}
.orari .splide .splide__slide {
  width: 180px;
}
@media screen and (max-width: 992px) {
  .orari .splide .splide__slide {
    width: 120px;
  }
}
.orari .am,
.orari .pm {
  margin-top: 40px;
}
.orari .pm > div:nth-last-child(1) {
  border-bottom: none;
}
.orari .week {
  gap: 4px;
  margin-top: 100px;
  width: 100%;
}
.orari .day {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-direction: column;
  padding: 20px 0;
  border-radius: 8px;
}
.orari .day:nth-child(even) {
  background-color: rgba(219, 242, 255, 0.5);
}
.orari .day:nth-child(odd) {
  background-color: #dbf2ff;
}
.orari .table-grid {
  margin-top: 3rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 2rem;
}
@media screen and (max-width: 500px) {
  .orari .table-grid {
    gap: 1rem;
  }
}
.orari .table-grid tbody {
  display: flex;
  width: 250px;
}
.orari .table-grid tbody tr {
  display: flex;
  flex-direction: column;
  gap: 4px;
  position: relative;
  padding-left: 50px;
}
.orari .table-grid tbody tr th {
  font-weight: bold;
}
.orari .table-grid tbody tr .td-icon {
  position: absolute;
  top: 50%;
  left: 0;
  width: 40px;
  text-align: center;
  transform: translateY(-50%);
  color: #33a8eb;
  font-size: 2rem;
}

@keyframes rotationclessidra {
  0% {
    transform: rotate(0deg);
  }
  75% {
    transform: rotate(360deg);
  }
  100% {
    transform: rotate(360deg);
  }
}
.ss-text-blu,
.ss-text-oro {
  margin-right: 4px;
}

.orari-v2 .ss-text-blu {
  color: #292c7e;
  margin-right: 8px;
}
.orari-v2 .ss-text-oro {
  color: #d1a71d;
  margin-right: 8px;
}
@media screen and (max-width: 992px) {
  .orari-v2 .ss-single {
    font-size: 36px !important;
  }
  .orari-v2 .ss-text-blu,
  .orari-v2 .ss-text-oro {
    margin-right: 6px;
  }
}
@media screen and (max-width: 640px) {
  .orari-v2 .ss-single {
    font-size: 30px !important;
    display: block !important;
  }
  .orari-v2 .ss-text-blu,
  .orari-v2 .ss-text-oro {
    margin-right: 4px;
  }
}
.orari-v2 .---prossima-partenza b {
  color: #d1a71d;
}
.orari-v2 #bn-orari-calendar-container {
  position: relative;
  border: solid 1px #33a8eb;
  border-radius: 8px;
  overflow: hidden;
  width: 860px;
  max-width: 100%;
  padding-right: 0px;
  transition: ease 0.5s;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar {
  padding: 2rem;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar .air-datepicker {
  position: relative !important;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day {
  background-color: #dbf2ff;
  width: 280px;
  height: 100%;
  top: 0;
  right: -280px;
  position: absolute;
  transition: ease 0.5s;
  z-index: 100;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day-inner {
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  gap: 12px;
  padding: 40px 16px;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--date {
  font-weight: 700;
  color: #1e2e42;
  margin-bottom: 12px;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--message {
  font-size: 14px;
  text-transform: uppercase;
  font-weight: 700;
  color: #33a8eb;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--message.error {
  color: #d2091e;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--orari {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  justify-content: center;
  gap: 8px;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--orari a {
  text-decoration: none;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--orari .bn-orari-calendar-day--orario {
  padding: 8px 16px;
  border: solid 1px #33a8eb;
  border-radius: 4px;
  text-decoration: none;
  color: #1e2e42;
  transition: ease 0.5s;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--orari .bn-orari-calendar-day--orario:hover {
  background-color: #33a8eb;
  color: #fff;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--loader {
  position: absolute;
  height: 20px;
  width: 20px;
  top: calc(50% - 10px);
  left: calc(50% - 10px);
  border: solid 3px #33a8eb;
  border-top-color: transparent;
  border-radius: 100px;
  animation: rotation 1s infinite linear;
  opacity: 0;
  visibility: hidden;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day-inner > * {
  transition: ease 0.2s;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day #bn-orari-calendar-day--closer {
  position: absolute;
  top: 6px;
  left: 6px;
  background-color: #33a8eb;
  width: 30px;
  height: 30px;
  border-radius: 30px;
  display: flex;
  align-items: center;
  justify-content: center;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day.loading #bn-orari-calendar-day-inner > * {
  opacity: 0;
  visibility: hidden;
}
.orari-v2 #bn-orari-calendar-container #bn-orari-calendar-day.loading #bn-orari-calendar-day--loader {
  opacity: 1;
  visibility: visible;
}
@media screen and (min-width: 768px) {
  .orari-v2 #bn-orari-calendar-container.open {
    padding-right: 280px;
  }
}
.orari-v2 #bn-orari-calendar-container.open #bn-orari-calendar-day {
  right: 0;
}

.btn-informazioni-orari {
  color: #fff;
  background-color: #33a8eb;
  border-radius: 0;
}
.btn-informazioni-orari:hover {
  background-color: #292c7e;
  color: #fff;
}

#homepage-evidenza {
  padding: 50px 0;
}
#homepage-evidenza .col-12 > div {
  border: 1px solid #33a8eb;
  padding: 40px 20px 40px 40px;
  border-radius: 8px;
}
@media screen and (max-width: 992px) {
  #homepage-evidenza .col-12 > div {
    padding: 0px;
  }
}
#homepage-evidenza .col-12 > div .cta-button {
  border: 1px solid #33a8eb;
  background: none;
  color: #33a8eb;
  border-radius: 0;
}
@media screen and (max-width: 992px) {
  #homepage-evidenza .col-12 > div .cta-button {
    display: block;
    width: 100%;
  }
}
#homepage-evidenza .col-12 > div img {
  width: 500px;
  height: 250px;
  object-fit: cover;
  border-radius: 8px;
}
@media screen and (max-width: 992px) {
  #homepage-evidenza .col-12 > div img {
    width: 100%;
    height: auto;
  }
}
@media screen and (max-width: 992px) {
  #homepage-evidenza .splide__slide {
    padding: 20px;
    padding-top: 40px;
  }
}
#homepage-evidenza .splide__pagination {
  bottom: 100%;
  padding: 0;
  right: 100%;
  width: 100px;
  justify-content: start;
  z-index: 0;
}
@media screen and (max-width: 992px) {
  #homepage-evidenza .splide__pagination {
    bottom: calc(100% - 30px);
    left: 20px;
  }
}
#homepage-evidenza .splide__pagination .splide__pagination__page {
  background: #dedede;
  opacity: 0.7;
  width: 8px;
  height: 8px;
  border-radius: 0;
}
#homepage-evidenza .splide__pagination .splide__pagination__page.is-active {
  transform: scale(1);
  background-color: #d2091e;
  opacity: 1;
}

#banner-full {
  padding-top: 150px;
  padding-bottom: 110px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  overflow: hidden;
}
#banner-full .banner-full-img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
}
#banner-full .layer {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: 0;
}
#banner-full h2,
#banner-full a,
#banner-full h3 {
  position: relative;
}
#banner-full h2 {
  margin-bottom: 40px;
  font-family: "Big Shoulders Display";
}
#banner-full a {
  text-decoration: none;
  color: white;
  width: fit-content;
  display: block;
  margin: 0 auto;
}
#banner-full a:hover {
  text-decoration: underline;
}

.cta-grande {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  position: relative;
  overflow: hidden;
}
.cta-grande .cta-grande-img {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  object-fit: cover;
  z-index: -1;
}
.cta-grande a:hover {
  text-decoration: underline;
}

.flexible--video {
  margin-top: 100px;
  overflow: visible;
}
.flexible--video .container {
  position: relative;
}
.flexible--video .video--text {
  padding-top: 3rem;
  padding-bottom: 3rem;
}
.flexible--video .video--video .video--video--play {
  width: 100%;
  margin-top: -30px;
  overflow: hidden;
  margin-bottom: -2px;
  cursor: pointer;
  position: relative;
  max-width: 300px;
}
.flexible--video .video--video .video--video--play > img, .flexible--video .video--video .video--video--play > video {
  border-radius: 20px 20px 0 0;
  width: 100%;
  max-height: 500px;
  max-width: 300px;
  object-fit: cover;
}
.flexible--video .video--video .video--video--play .video--video--play-icon {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100px;
  height: 100px;
  transform: translate(-50%, -50%);
  background-color: #33a8eb;
  border: solid 5px #fff;
  border-radius: 100px;
  cursor: pointer;
  transition: ease 0.5s;
}
.flexible--video .video--video .video--video--play .video--video--play-icon:after {
  transition: ease 0.5s;
  content: "";
  position: absolute;
  border-left: solid 26px #fff;
  border-top: solid 16px transparent;
  border-bottom: solid 16px transparent;
  top: 50%;
  left: 50%;
  transform: translate(-10px, -50%);
}
.flexible--video .video--video .video--video--play .video--video--play-icon:hover {
  background-color: #fff;
}
.flexible--video .video--video .video--video--play .video--video--play-icon:hover:after {
  border-left: solid 26px #33a8eb;
}
.flexible--video .iframe-yt-video-cont {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.8);
  z-index: 9999999;
  opacity: 0;
  visibility: hidden;
}
.flexible--video .iframe-yt-video-cont.active {
  opacity: 1;
  visibility: visible;
}
.flexible--video .iframe-yt-video-cont .iframe-yt-video-cont-closer {
  color: #fff;
  position: absolute;
  top: 10px;
  right: 20px;
  font-size: 50px;
  cursor: pointer;
  transform: rotate(45deg);
}
.flexible--video .iframe-yt-video-cont .iframe-yt-video {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 90%;
  max-height: 90%;
  width: 1200px;
}

.bg-images {
  position: relative;
}
.bg-images .bg-cover-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-size: cover;
}
.bg-images .bg-cover-image.--desktop {
  display: none;
}
@media screen and (min-width: 1024px) {
  .bg-images .bg-cover-image.--desktop {
    display: block;
  }
}
.bg-images .bg-cover-image.--mobile {
  display: none;
}
@media screen and (max-width: 1023px) {
  .bg-images .bg-cover-image.--mobile {
    display: block;
  }
}
.bg-images .bg-cover-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.bg-images .bg-cover-overlay.--dark {
  background-color: rgba(0, 0, 0, 0.6);
}
.bg-images .bg-cover-overlay.--light {
  background-color: rgba(255, 255, 255, 0.6);
}
.bg-images .bg-cover-overlay.--gradient {
  background: linear-gradient(270deg, #33A8EB 10%, rgba(0, 0, 0, 0) 100%);
}

.bn-button {
  background-color: #fff;
  display: inline-block;
  color: #33a8eb;
  border: solid 1px #33a8eb;
  padding: 12px 20px;
  text-align: center;
  min-width: 200px;
  cursor: pointer;
  font-weight: 700;
  transition: ease 0.5s;
}
.bn-button:hover {
  background-color: #33a8eb;
  color: #fff;
}

.section-video {
  min-height: 470px;
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  margin-top: 100px;
}
.section-video .wysiwyg {
  margin-top: 30px;
  margin-bottom: 30px;
}
.section-video .section-video-content {
  padding-top: 60px;
  padding-bottom: 60px;
}
.section-video .landscape-video-wrapper {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 110%;
  margin-top: -30px;
  border-top-left-radius: 20px;
  border-top-right-radius: 20px;
  overflow: hidden;
}
@media screen and (max-width: 991px) {
  .section-video .landscape-video-wrapper {
    height: 300px;
    border-radius: 20px;
  }
}
.section-video .landscape-video-wrapper .play-button {
  position: absolute;
  z-index: 100;
  background-color: transparent;
  border: none;
  transition: all 0.3s ease;
}
.section-video .landscape-video-wrapper .play-button:hover {
  cursor: pointer;
  transform: scale(1.2);
  transition: all 0.3s ease;
}
.section-video .landscape-video-wrapper video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
}

/* ==================================================================================================================================================================================== */
.container-card {
  display: flex;
  align-items: stretch;
  justify-content: center;
  min-width: fit-content;
  height: fit-content;
  min-height: 450px;
}
.container-card .card-center {
  background-color: white;
  width: 100%;
  max-width: 376px;
  padding: 40px 20px;
  position: relative;
}
.container-card .card-center form {
  display: flex;
  align-items: flex-start;
  justify-content: center;
  flex-direction: column;
}
.container-card .card-left,
.container-card .card-right {
  margin-top: 0px;
  min-width: 22px;
  display: flex;
  align-items: stretch;
  justify-content: space-between;
  flex-direction: column;
}
.container-card .card-left .fill-space,
.container-card .card-right .fill-space {
  min-width: 22px;
  height: 100%;
  background-color: white;
  flex-grow: 1;
  margin-top: -1px;
  margin-bottom: -1px;
}
.container-card .card-left svg,
.container-card .card-right svg {
  min-width: 22px;
  min-height: 44px;
}
.container-card .card-left .corner-top-left,
.container-card .card-left .corner-bottom-left {
  min-height: 22px;
  min-width: 22px;
  background-color: white;
}
.container-card .card-left .corner-top-left {
  border-top-left-radius: 100%;
}
.container-card .card-left .corner-bottom-left {
  border-bottom-left-radius: 100%;
}
.container-card .card-right .corner-top-right,
.container-card .card-right .corner-bottom-right {
  min-height: 22px;
  min-width: 22px;
  background-color: white;
}
.container-card .card-right .corner-top-right {
  border-top-right-radius: 100%;
}
.container-card .card-right .corner-bottom-right {
  border-bottom-right-radius: 100%;
}

.card-center-loader {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  display: flex;
  align-items: center;
  justify-content: center;
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
  width: 100%;
  background-color: white;
  z-index: 99;
  transition: all ease 0.3s;
}

.card-center-loader.open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}

.modal-control-passengers,
.modal-control-vehicles {
  width: 100%;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
  cursor: pointer;
}
.modal-control-passengers svg,
.modal-control-vehicles svg {
  min-width: 14px;
  min-height: 14px;
  max-width: 14px;
  max-height: 14px;
  object-fit: contain;
}
.modal-control-passengers span,
.modal-control-vehicles span {
  opacity: 0.1;
}
.modal-control-passengers span:nth-last-child(1),
.modal-control-vehicles span:nth-last-child(1) {
  opacity: 1;
}

.hotel-logo {
  width: 100%;
  height: 100%;
  max-width: 300px;
  height: 80px;
  margin: 0 auto;
  display: block;
  object-fit: contain;
}

.switch-destinations {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 50px;
  margin: -25px 0;
  transition: all ease 0.3s;
}
.switch-destinations.rotate {
  transform: rotate(180deg);
}
.switch-destinations svg {
  cursor: pointer;
}
.switch-destinations svg:hover path {
  stroke: #fff;
}
.switch-destinations svg:hover circle {
  fill: #292c7e;
}

.form-departure,
.iframe-tratta-fine {
  width: 100%;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}

.form-button-search {
  margin-top: 30px;
  width: 100%;
  text-align: center;
  background-color: #d2091e;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  height: 50px;
  border: 1px solid #d2091e;
  background: #d2091e;
  border-radius: 8px;
  font-family: "Satoshi";
  font-style: normal;
  font-weight: 700;
  font-size: 14px;
  line-height: 19px;
  color: #ffffff;
  cursor: pointer;
}
.form-button-search svg {
  transition: all ease 0.3s;
}
.form-button-search svg path {
  transition: all ease 0.3s;
}
.form-button-search:hover {
  background-color: #ffffff;
  color: #d2091e;
}
.form-button-search:hover svg path {
  fill: #d2091e;
}

.summary ul li {
  font-family: "Satoshi";
  font-style: normal;
  font-weight: 700;
  font-size: 16px;
  line-height: 22px;
  color: #292c7e;
  padding: 15px 0;
  border-bottom: 1px solid #dbf2ff;
  display: flex;
  align-items: center;
  justify-content: space-between;
  width: 100%;
}
.summary ul li svg {
  min-width: 14px;
  min-height: 14px;
  max-width: 14px;
  max-height: 14px;
  object-fit: contain;
}

.number-select {
  display: flex;
  flex-direction: row;
  justify-content: space-between;
  align-items: center;
  padding: 4px 8px;
  max-width: 100px;
  min-width: 100px;
  width: 100px;
  border: 1px solid #33a8eb;
  height: 35px;
}

.footer-subfields {
  font-family: "Satoshi";
  font-style: normal;
  font-weight: 400;
  font-size: 14px;
  line-height: 19px;
  display: block;
  margin: 10px 0;
  letter-spacing: 0.02em;
  color: #292c7e;
}

.number-select-container,
.passenger {
  padding: 20px 0;
  border-bottom: 1px solid #dbf2ff;
}

.center-card.in-iframe {
  height: 100%;
  width: 100%;
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
}
.center-card.in-iframe .container-card {
  display: flex;
  align-items: stretch;
  justify-content: center;
  width: 100% !important;
  height: 100%;
  max-height: unset;
  position: fixed;
  filter: none !important;
}
.center-card.in-iframe .container-card .center {
  background-color: white;
  width: 100%;
  height: 100%;
  max-width: calc(100% - 44px);
  padding: 40px 20px;
  position: relative;
}

input {
  text-transform: uppercase;
}

/* ==================================================================================================================================================================================== */
@media screen and (max-width: 379px) {
  .card-center {
    padding: 22px 0 !important;
  }
  .card-left svg,
  .card-right svg {
    display: none !important;
  }
  .iframe-modal-header,
  .iframe-modal-main,
  .moda-footer,
  .form-departure,
  .iframe-tratta-fine,
  .form-trip-direction-select,
  .form-calendars-container,
  .form-coupon-container,
  .modal-control-passengers,
  .modal-control-vehicles,
  .modal-control-coupons {
    padding-left: 0 !important;
    padding-right: 0 !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
.modal-control-coupons {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 0;
  left: auto;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  width: auto;
  font-size: 12px;
  background-color: white;
}
.modal-control-coupons .modal-control-label {
  color: #292c7e;
  font-weight: 700;
  padding: 2px;
}
.modal-control-coupons .modal-control-action {
  color: white;
  font-weight: 700;
  background-color: #d2091e;
  border-radius: 4px;
  padding: 2px 5px;
  cursor: pointer;
}

.iframe-modal.coupons .form-coupon-details-notify {
  display: none;
  color: white;
  text-align: center;
  margin-top: 15px;
  padding: 15px;
  border-radius: 4px;
}
.iframe-modal.coupons .form-coupon-details-notify.show {
  display: block;
}
.iframe-modal.coupons .form-coupon-details-notify.success {
  background-color: #47c6a3;
}
.iframe-modal.coupons .form-coupon-details-notify.error {
  background-color: red;
}

.form-calendars-container {
  width: 100%;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
  padding-bottom: 1rem;
}
.form-calendars-container .calendar {
  width: 50%;
}
.form-calendars-container .calendar .calendar-svg {
  min-width: 18px;
  min-height: 18px;
  max-width: 18px;
  max-height: 18px;
  object-fit: contain;
}
.form-calendars-container .calendar:nth-last-child(1) {
  border-left: 1px solid rgba(41, 44, 126, 0.2);
}
.form-calendars-container #calendar-date-departure,
.form-calendars-container #calendar-date-return {
  width: 100%;
  margin-top: 2px;
  border: none;
  cursor: pointer;
  font-style: normal;
  font-weight: 700;
  color: #292c7e;
}
@media screen and (max-width: 40em) {
  .form-calendars-container #calendar-date-departure,
  .form-calendars-container #calendar-date-return {
    font-size: 14px !important;
  }
}
.form-calendars-container #calendar-date-departure.disable,
.form-calendars-container #calendar-date-return.disable {
  cursor: no-drop;
  opacity: 0.2;
  pointer-events: none;
}
.form-calendars-container #calendar-date-departure::placeholder,
.form-calendars-container #calendar-date-return::placeholder {
  /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #292c7e;
  opacity: 0.2; /* Firefox */
}
.form-calendars-container #calendar-date-departure:-ms-input-placeholder,
.form-calendars-container #calendar-date-return:-ms-input-placeholder {
  /* Internet Explorer 10-11 */
  color: #292c7e;
  opacity: 0.2;
}
.form-calendars-container #calendar-date-departure::-ms-input-placeholder,
.form-calendars-container #calendar-date-return::-ms-input-placeholder {
  /* Microsoft Edge */
  color: #292c7e;
  opacity: 0.2;
}
.form-calendars-container #calendar-date-departure:focus-visible,
.form-calendars-container #calendar-date-return:focus-visible {
  outline: none !important;
  border: none !important;
  border-radius: 6px;
}

.air-datepicker-body--day-name {
  color: #292c7e;
  opacity: 0.5;
  text-transform: lowercase;
}

.air-datepicker {
  position: absolute !important;
  top: 0 !important;
  left: 0 !important;
  width: 100% !important;
  min-height: 100% !important;
}

.air-datepicker-nav--title,
.air-datepicker-nav--title i {
  font-style: normal;
  font-weight: 700;
  color: #292c7e;
  text-transform: lowercase;
}

.air-datepicker-body--day-name {
  font-style: normal;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.02em;
  color: #292c7e;
  opacity: 0.5;
}

.air-datepicker-body--cells.-days- {
  min-height: 270px;
  grid-template-columns: repeat(7, var(--adp-day-cell-width));
  grid-auto-rows: auto;
}

.air-datepicker-cell {
  font-style: normal;
  font-weight: 400;
  text-align: center;
  letter-spacing: 0.02em;
  color: #1e2e42;
}

.air-datepicker-nav {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}

.air-datepicker-nav,
.air-datepicker,
.air-datepicker--buttons {
  border: none !important;
}

.air-datepicker-button {
  border-radius: 0;
  display: flex;
  flex-direction: row;
  justify-content: center;
  align-items: center;
  width: 100%;
  height: 45px;
  background: #dbf2ff;
  font-style: normal;
  font-weight: 700;
  color: #292c7e;
  line-height: 1.4;
}
.air-datepicker-button:hover {
  color: #dbf2ff;
  background-color: #292c7e;
  font-weight: 900;
}

.air-datepicker-cell.-day-.-selected- {
  background-color: rgba(41, 44, 126, 0.2);
}

.air-datepicker-buttons {
  display: flex;
  align-items: center;
  justify-content: center;
}

.date-picker-dettaglio {
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
  padding-top: 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.date-picker-dettaglio svg {
  cursor: pointer;
}
.date-picker-dettaglio p {
  letter-spacing: 0.02em;
  color: #292c7e;
  padding: 5px 0;
}

.air-datepicker-cell.-current- {
  color: #33a8eb;
}

.form-coupon-container {
  position: relative;
  width: 100%;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
  padding-bottom: 1rem;
}
.form-coupon-container input {
  text-transform: unset;
  font-weight: 700;
  color: #2a2c7e;
  border: none;
  box-shadow: none;
  outline: none;
}
.form-coupon-container input::placeholder {
  color: #e9eaf2;
  opacity: 1;
}

.form-coupon-details-container {
  width: 100%;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
  padding-bottom: 1rem;
}
.form-coupon-details-container .req {
  color: red;
  font-weight: bold;
}
.form-coupon-details-container input {
  text-transform: unset;
  font-weight: 700;
  color: #2a2c7e;
  border: none;
  box-shadow: none;
  outline: none;
}
.form-coupon-details-container input::placeholder {
  color: #e9eaf2;
  opacity: 1;
}

.ss-main {
  border: none;
  width: fit-content;
  min-width: 150px;
  margin-left: 20px;
  padding: 0;
}
.ss-main:focus {
  box-shadow: none;
}
.ss-main .ss-single {
  line-height: 1;
  margin: 0;
  margin-top: 14px;
  color: #292c7e;
}
.ss-main .ss-arrow {
  transform: scale(2);
  margin-left: 10px;
}
.ss-main .ss-arrow path {
  stroke: #292c7e;
}

.ss-content {
  border: 1px solid #292c7e !important;
  border-radius: 2px !important;
  transition: opacity ease 0.3s !important;
}
.ss-content .ss-option {
  line-height: 1;
  margin: 0;
  color: #292c7e !important;
}
.ss-content .ss-option:hover {
  background-color: #292c7e !important;
  color: #fff !important;
}
.ss-content.ss-open-below {
  border-bottom-right-radius: 2px !important;
  border-bottom-left-radius: 2px !important;
  border-radius: 2px !important;
  padding: 0px !important;
}

.iframe-modal {
  background-color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.iframe-modal.open {
  opacity: 1;
  visibility: visible;
  pointer-events: all;
}
.iframe-modal .iframe-modal-header {
  margin: 0 1rem;
  padding-top: 45px;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.iframe-modal .summary-footer {
  padding-top: 20px;
  padding-bottom: 12px;
  border-bottom: 1px dashed rgba(41, 44, 126, 0.2);
}
.iframe-modal .iframe-modal-main {
  overflow: scroll;
  height: calc(100% - 200px);
  margin-bottom: 10px;
}
.iframe-modal .moda-footer {
  padding: 0 1rem;
}
.iframe-modal svg:hover {
  cursor: pointer;
}
.iframe-modal .vehicle {
  border-bottom: 1px solid #dbf2ff;
  cursor: pointer;
}
.iframe-modal .vehicle.disable {
  opacity: 0.5;
  pointer-events: none;
  cursor: no-drop;
}
.iframe-modal #select-adulti .disable {
  color: red;
  font-weight: 900;
  pointer-events: none;
  cursor: no-drop;
}
.iframe-modal .errore-passengers {
  width: 100%;
  text-align: center;
  padding: 1rem;
  padding-top: 0;
  color: #d2091e;
}
.iframe-modal .button-footer-modal {
  background-color: #dbf2ff;
  padding: 8px;
}
.iframe-modal .button-footer-modal:hover {
  cursor: pointer;
  color: #dbf2ff;
  background-color: white;
}
.iframe-modal .destinazioni {
  width: 100%;
}
.iframe-modal .destinazioni .destinazione {
  color: #292c7e;
  text-align: center;
  padding: 12px;
}
.iframe-modal .destinazioni .destinazione:nth-child(1) {
  margin-top: 12px;
}
.iframe-modal .destinazioni .destinazione:nth-last-child(1) {
  margin-bottom: 12px;
}
.iframe-modal .destinazioni .destinazione:hover, .iframe-modal .destinazioni .destinazione.active {
  background-color: #f9f9f9;
  color: #33a8eb;
  cursor: pointer;
}
.iframe-modal .add-number .input-hidden {
  display: none;
}
.iframe-modal .add-number .add,
.iframe-modal .add-number .sub,
.iframe-modal .add-number .number {
  height: 25px;
  width: 25px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: "Satoshi";
  font-style: normal;
  font-weight: 700;
  font-size: 20px;
  line-height: 27px;
  color: #292c7e;
  user-select: none;
  -moz-user-select: none;
  -khtml-user-select: none;
  -webkit-user-select: none;
  -o-user-select: none;
}
.iframe-modal .add-number .add,
.iframe-modal .add-number .sub {
  cursor: pointer;
  color: #33a8eb;
}
.iframe-modal .add-number .add svg,
.iframe-modal .add-number .sub svg {
  min-width: 14px;
  min-height: 14px;
  max-width: 14px;
  max-height: 14px;
}
.iframe-modal .error-required {
  border: 2px solid #d2091e;
}
.iframe-modal .required-message {
  margin-top: -5px;
  margin-bottom: 15px;
  color: red;
  text-align: end;
}

.single-hotel #hero-text .breadcrumb a {
  background-color: rgba(0, 0, 0, 0);
  color: black;
  border: none;
  text-decoration: none;
}
.single-hotel #hero-text .breadcrumb a:hover {
  color: black;
  text-decoration: underline;
}
.single-hotel #hero-text .hotel-telefono {
  background-color: rgba(0, 0, 0, 0);
  color: black;
  border: none;
  text-decoration: none;
}
.single-hotel #hero-text .hotel-telefono:hover {
  color: black;
  text-decoration: underline;
}
.single-hotel #hero-text a {
  background-color: white;
  border: 1px solid white;
  color: #33A8EB;
}
.single-hotel #hero-text a:hover {
  color: white;
  background-color: rgba(0, 0, 0, 0);
}

/**
 * @license
 *
 * Font Family: Satoshi
 * Designed by: Deni Anggara
 * URL: https://www.fontshare.com/fonts/satoshi
 * © 2022 Indian Type Foundry
 *
 * Font Styles:
 * Satoshi Variable(Variable font)
 * Satoshi Variable Italic(Variable font)
 * Satoshi Light
 * Satoshi Light Italic
 * Satoshi Regular
 * Satoshi Italic
 * Satoshi Medium
 * Satoshi Medium Italic
 * Satoshi Bold
 * Satoshi Bold Italic
 * Satoshi Black
 * Satoshi Black Italic
 *
*/
/**
* This is a variable font
* You can controll variable axes as shown below:
* font-variation-settings: 'wght' 900.0;
*
* available axes:

* 'wght' (range from 300.0 to 900.0)

*/
/**
* This is a variable font
* You can controll variable axes as shown below:
* font-variation-settings: 'wght' 900.0;
*
* available axes:

* 'wght' (range from 300.0 to 900.0)

*/
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Light.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Light.woff") format("woff"), url("../fonts/satoshi/Satoshi-Light.ttf") format("truetype");
  font-weight: 300;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-LightItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-LightItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-LightItalic.ttf") format("truetype");
  font-weight: 300;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Regular.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Regular.woff") format("woff"), url("../fonts/satoshi/Satoshi-Regular.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Italic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Italic.woff") format("woff"), url("../fonts/satoshi/Satoshi-Italic.ttf") format("truetype");
  font-weight: 400;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Medium.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Medium.woff") format("woff"), url("../fonts/satoshi/Satoshi-Medium.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-MediumItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-MediumItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-MediumItalic.ttf") format("truetype");
  font-weight: 500;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Bold.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Bold.woff") format("woff"), url("../fonts/satoshi/Satoshi-Bold.ttf") format("truetype");
  font-weight: 700;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-BoldItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-BoldItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-BoldItalic.ttf") format("truetype");
  font-weight: 700;
  font-display: swap;
  font-style: italic;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-Black.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-Black.woff") format("woff"), url("../fonts/satoshi/Satoshi-Black.ttf") format("truetype");
  font-weight: 900;
  font-display: swap;
  font-style: normal;
}
@font-face {
  font-family: "Satoshi";
  src: url("../fonts/satoshi/Satoshi-BlackItalic.woff2") format("woff2"), url("../fonts/satoshi/Satoshi-BlackItalic.woff") format("woff"), url("../fonts/satoshi/Satoshi-BlackItalic.ttf") format("truetype");
  font-weight: 900;
  font-display: swap;
  font-style: italic;
}
section {
  overflow: hidden;
}

body {
  font-family: "Satoshi", sans-serif;
  text-rendering: optimizeLegibility;
  font-weight: 400;
  background-color: #fff;
}

*,
h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: inherit;
  font-family: inherit;
}

p {
  line-height: inherit;
}

em,
strong {
  font-family: inherit;
}

/* Imposto la font principale. */
.txt {
  font-family: "Satoshi", sans-serif;
  font-weight: 400;
  font-style: normal;
}

.txt.sans {
  font-family: "Satoshi", sans-serif;
}

.txt.mono {
  font-family: "Big Shoulders Display", monospace;
}

.txt.serif {
  font-family: serif;
}

.txt.bold {
  font-weight: 700;
  font-style: normal;
}

.txt.italic {
  font-style: italic;
}

.txt.center {
  text-align: center;
}

.txt.right {
  text-align: right;
}

.txt.left {
  text-align: left;
}

.txt.caps {
  text-transform: uppercase;
}

.bordo {
  border: 1px solid #ccc;
}

.txt.blu-navy {
  color: #292c7e;
}

.txt.rosso-navy {
  color: #d2091e;
}

.txt.verde-navy {
  color: #47c6a3;
}

.txt.celeste-navy {
  color: #dbf2ff;
}

.txt.blu-scuro-navy {
  color: #1e2e42;
}

.txt.azzurro-navy {
  color: #33a8eb;
}

.txt.gold-navy {
  color: #d1a71d;
}

.txt.azzurro {
  color: #33a8eb;
}

.txt.rosso {
  color: #ff0000;
}

.txt.grigio-chiaro {
  color: #e5e5e5;
}

.txt.grigio {
  color: #959595;
}

.txt.grigio-scuro {
  color: #232324;
}

.txt.nero {
  color: #000;
}

.txt.bianco {
  color: #fff;
}

.bg-blu-navy {
  background-color: #292c7e;
}

.bg-rosso-navy {
  background-color: #d2091e;
}

.bg-verde-navy {
  background-color: #47c6a3;
}

.bg-celeste-navy {
  background-color: #dbf2ff;
}

.bg-blu-scuro-navy {
  background-color: #1e2e42;
}

.bg-azzurro-navy {
  background-color: #33a8eb;
}

.bg-gold-navy {
  background-color: #d1a71d;
}

.bg-azzurro {
  background-color: #33a8eb;
}

.bg-rosso {
  background-color: #ff0000;
}

.bg-grigio-chiaro {
  background-color: #e5e5e5;
}

.bg-grigio {
  background-color: #959595;
}

.bg-grigio-scuro {
  background-color: #232324;
}

.bg-nero {
  background-color: #000;
}

.bg-bianco {
  background-color: #fff;
}

.border-blu-navy {
  border-color: #292c7e;
}

.border-rosso-navy {
  border-color: #d2091e;
}

.border-verde-navy {
  border-color: #47c6a3;
}

.border-celeste-navy {
  border-color: #dbf2ff;
}

.border-blu-scuro-navy {
  border-color: #1e2e42;
}

.border-azzurro-navy {
  border-color: #33a8eb;
}

.border-gold-navy {
  border-color: #d1a71d;
}

.border-azzurro {
  border-color: #33a8eb;
}

.border-rosso {
  border-color: #ff0000;
}

.border-grigio-chiaro {
  border-color: #e5e5e5;
}

.border-grigio {
  border-color: #959595;
}

.border-grigio-scuro {
  border-color: #232324;
}

.border-nero {
  border-color: #000;
}

.border-bianco {
  border-color: #fff;
}

.mt-10 {
  margin-top: 10px;
}

.mb-10 {
  margin-bottom: 10px;
}

.ml-10 {
  margin-left: 10px;
}

.mr-10 {
  margin-right: 10px;
}

.pt-10 {
  padding-top: 10px;
}

.pb-10 {
  padding-bottom: 10px;
}

.pl-10 {
  padding-left: 10px;
}

.pr-10 {
  padding-right: 10px;
}

.mt-15 {
  margin-top: 15px;
}

.mb-15 {
  margin-bottom: 15px;
}

.ml-15 {
  margin-left: 15px;
}

.mr-15 {
  margin-right: 15px;
}

.pt-15 {
  padding-top: 15px;
}

.pb-15 {
  padding-bottom: 15px;
}

.pl-15 {
  padding-left: 15px;
}

.pr-15 {
  padding-right: 15px;
}

.mt-20 {
  margin-top: 20px;
}

.mb-20 {
  margin-bottom: 20px;
}

.ml-20 {
  margin-left: 20px;
}

.mr-20 {
  margin-right: 20px;
}

.pt-20 {
  padding-top: 20px;
}

.pb-20 {
  padding-bottom: 20px;
}

.pl-20 {
  padding-left: 20px;
}

.pr-20 {
  padding-right: 20px;
}

.mt-25 {
  margin-top: 25px;
}

.mb-25 {
  margin-bottom: 25px;
}

.ml-25 {
  margin-left: 25px;
}

.mr-25 {
  margin-right: 25px;
}

.pt-25 {
  padding-top: 25px;
}

.pb-25 {
  padding-bottom: 25px;
}

.pl-25 {
  padding-left: 25px;
}

.pr-25 {
  padding-right: 25px;
}

.mt-30 {
  margin-top: 30px;
}

.mb-30 {
  margin-bottom: 30px;
}

.ml-30 {
  margin-left: 30px;
}

.mr-30 {
  margin-right: 30px;
}

.pt-30 {
  padding-top: 30px;
}

.pb-30 {
  padding-bottom: 30px;
}

.pl-30 {
  padding-left: 30px;
}

.pr-30 {
  padding-right: 30px;
}

.mt-35 {
  margin-top: 35px;
}

.mb-35 {
  margin-bottom: 35px;
}

.ml-35 {
  margin-left: 35px;
}

.mr-35 {
  margin-right: 35px;
}

.pt-35 {
  padding-top: 35px;
}

.pb-35 {
  padding-bottom: 35px;
}

.pl-35 {
  padding-left: 35px;
}

.pr-35 {
  padding-right: 35px;
}

.mt-40 {
  margin-top: 40px;
}

.mb-40 {
  margin-bottom: 40px;
}

.ml-40 {
  margin-left: 40px;
}

.mr-40 {
  margin-right: 40px;
}

.pt-40 {
  padding-top: 40px;
}

.pb-40 {
  padding-bottom: 40px;
}

.pl-40 {
  padding-left: 40px;
}

.pr-40 {
  padding-right: 40px;
}

.mt-45 {
  margin-top: 45px;
}

.mb-45 {
  margin-bottom: 45px;
}

.ml-45 {
  margin-left: 45px;
}

.mr-45 {
  margin-right: 45px;
}

.pt-45 {
  padding-top: 45px;
}

.pb-45 {
  padding-bottom: 45px;
}

.pl-45 {
  padding-left: 45px;
}

.pr-45 {
  padding-right: 45px;
}

.mt-50 {
  margin-top: 50px;
}

.mb-50 {
  margin-bottom: 50px;
}

.ml-50 {
  margin-left: 50px;
}

.mr-50 {
  margin-right: 50px;
}

.pt-50 {
  padding-top: 50px;
}

.pb-50 {
  padding-bottom: 50px;
}

.pl-50 {
  padding-left: 50px;
}

.pr-50 {
  padding-right: 50px;
}

.mt-55 {
  margin-top: 55px;
}

.mb-55 {
  margin-bottom: 55px;
}

.ml-55 {
  margin-left: 55px;
}

.mr-55 {
  margin-right: 55px;
}

.pt-55 {
  padding-top: 55px;
}

.pb-55 {
  padding-bottom: 55px;
}

.pl-55 {
  padding-left: 55px;
}

.pr-55 {
  padding-right: 55px;
}

.mt-60 {
  margin-top: 60px;
}

.mb-60 {
  margin-bottom: 60px;
}

.ml-60 {
  margin-left: 60px;
}

.mr-60 {
  margin-right: 60px;
}

.pt-60 {
  padding-top: 60px;
}

.pb-60 {
  padding-bottom: 60px;
}

.pl-60 {
  padding-left: 60px;
}

.pr-60 {
  padding-right: 60px;
}

.mt-65 {
  margin-top: 65px;
}

.mb-65 {
  margin-bottom: 65px;
}

.ml-65 {
  margin-left: 65px;
}

.mr-65 {
  margin-right: 65px;
}

.pt-65 {
  padding-top: 65px;
}

.pb-65 {
  padding-bottom: 65px;
}

.pl-65 {
  padding-left: 65px;
}

.pr-65 {
  padding-right: 65px;
}

.mt-70 {
  margin-top: 70px;
}

.mb-70 {
  margin-bottom: 70px;
}

.ml-70 {
  margin-left: 70px;
}

.mr-70 {
  margin-right: 70px;
}

.pt-70 {
  padding-top: 70px;
}

.pb-70 {
  padding-bottom: 70px;
}

.pl-70 {
  padding-left: 70px;
}

.pr-70 {
  padding-right: 70px;
}

.mt-75 {
  margin-top: 75px;
}

.mb-75 {
  margin-bottom: 75px;
}

.ml-75 {
  margin-left: 75px;
}

.mr-75 {
  margin-right: 75px;
}

.pt-75 {
  padding-top: 75px;
}

.pb-75 {
  padding-bottom: 75px;
}

.pl-75 {
  padding-left: 75px;
}

.pr-75 {
  padding-right: 75px;
}

.mt-80 {
  margin-top: 80px;
}

.mb-80 {
  margin-bottom: 80px;
}

.ml-80 {
  margin-left: 80px;
}

.mr-80 {
  margin-right: 80px;
}

.pt-80 {
  padding-top: 80px;
}

.pb-80 {
  padding-bottom: 80px;
}

.pl-80 {
  padding-left: 80px;
}

.pr-80 {
  padding-right: 80px;
}

.mt-85 {
  margin-top: 85px;
}

.mb-85 {
  margin-bottom: 85px;
}

.ml-85 {
  margin-left: 85px;
}

.mr-85 {
  margin-right: 85px;
}

.pt-85 {
  padding-top: 85px;
}

.pb-85 {
  padding-bottom: 85px;
}

.pl-85 {
  padding-left: 85px;
}

.pr-85 {
  padding-right: 85px;
}

.mt-90 {
  margin-top: 90px;
}

.mb-90 {
  margin-bottom: 90px;
}

.ml-90 {
  margin-left: 90px;
}

.mr-90 {
  margin-right: 90px;
}

.pt-90 {
  padding-top: 90px;
}

.pb-90 {
  padding-bottom: 90px;
}

.pl-90 {
  padding-left: 90px;
}

.pr-90 {
  padding-right: 90px;
}

.mt-95 {
  margin-top: 95px;
}

.mb-95 {
  margin-bottom: 95px;
}

.ml-95 {
  margin-left: 95px;
}

.mr-95 {
  margin-right: 95px;
}

.pt-95 {
  padding-top: 95px;
}

.pb-95 {
  padding-bottom: 95px;
}

.pl-95 {
  padding-left: 95px;
}

.pr-95 {
  padding-right: 95px;
}

.mt-100 {
  margin-top: 100px;
}

.mb-100 {
  margin-bottom: 100px;
}

.ml-100 {
  margin-left: 100px;
}

.mr-100 {
  margin-right: 100px;
}

.pt-100 {
  padding-top: 100px;
}

.pb-100 {
  padding-bottom: 100px;
}

.pl-100 {
  padding-left: 100px;
}

.pr-100 {
  padding-right: 100px;
}

.mt-105 {
  margin-top: 105px;
}

.mb-105 {
  margin-bottom: 105px;
}

.ml-105 {
  margin-left: 105px;
}

.mr-105 {
  margin-right: 105px;
}

.pt-105 {
  padding-top: 105px;
}

.pb-105 {
  padding-bottom: 105px;
}

.pl-105 {
  padding-left: 105px;
}

.pr-105 {
  padding-right: 105px;
}

/* testi */
.txt.grande,
.txt-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 100px;
  line-height: 1.1;
}

.txt.titolo-grande,
.txt-titolo-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 80px;
  line-height: 1.1;
}

.txt.titolo,
.txt-titolo,
.header-modal #big-menu-modal a {
  font-family: "Satoshi", sans-serif;
  font-size: 60px;
  line-height: 1.2;
}

.txt.titolo-piccolo,
.txt-titolo-piccolo {
  font-family: "Satoshi", sans-serif;
  font-size: 50px;
  line-height: 1.2;
}

.txt.sottotitolo-grande,
.txt-sottotitolo-grande,
.single-offerta .punti-forza .descrizione b {
  font-family: "Satoshi", sans-serif;
  font-size: 40px;
  line-height: 1.2;
}

.txt.sottotitolo,
.txt-sottotitolo,
.iframe-modal .destinazioni .destinazione {
  font-family: "Satoshi", sans-serif;
  font-size: 30px;
  line-height: 1.25;
}

.txt.sottotitolo-piccolo,
.txt-sottotitolo-piccolo,
.air-datepicker-nav--title,
.air-datepicker-nav--title i,
.air-datepicker-cell,
.air-datepicker-button {
  font-family: "Satoshi", sans-serif;
  font-size: 20px;
  line-height: 1.2;
}

.txt.testo-grande,
.txt-testo-grande {
  font-family: "Satoshi", sans-serif;
  font-size: 18px;
  margin-bottom: 0;
  line-height: 1.2;
}

.txt.testo,
.txt-testo,
header .navbar li span,
header .header-bottom .dropdown-languages,
.ticket .ticket-item.calendar input,
.main .secondary-menu-footer li a,
#homepage-offerte .splide__track .card .card-body .btn,
.page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
.content-offerte-passate .card-offerta-archivio .card-body .btn,
.offerte-residenti .card-offerta-archivio .card-body .btn,
.banner-cta .banner-cta-content .center .btn,
.form-calendars-container #calendar-date-departure,
.form-calendars-container #calendar-date-return,
.ss-main .ss-single,
.ss-content .ss-option {
  font-family: "Satoshi", sans-serif;
  font-size: 16px;
  margin-bottom: 0;
  line-height: 1.4;
}

.txt.testo-piccolo,
.txt-testo-piccolo,
.main .primary-menu-footer li a,
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
.page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
.page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
.air-datepicker-body--day-name,
.date-picker-dettaglio p,
.iframe-modal .required-message {
  font-family: "Satoshi", sans-serif;
  font-size: 14px;
  margin-bottom: 0;
  line-height: 1.2;
}

.txt.piccolo,
.txt-piccolo,
.ticket .ticket-item.calendar h3 .ss-main .ss-single,
.ss-content.ticket-trip-direction .ss-list .ss-option,
.ticket .ticket-item.passengers .total-passengers,
.ticket .ticket-item.passengers .total-vehicles,
.ticket .ticket-item.vehicles .total-passengers,
.ticket .ticket-item.vehicles .total-vehicles,
.offerte-last-minute .splide .splide__track .card-last-minute .label {
  font-family: "Satoshi", sans-serif;
  font-size: 12px;
  margin-bottom: 0;
  line-height: 1.2;
}

@media screen and (max-width: 75em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 90px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 60px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.2;
  }
}
@media screen and (max-width: 64em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 80px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 60px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 45px;
    line-height: 1.2;
  }
  .txt.titolo-piccolo,
  .txt-titolo-piccolo {
    font-family: "Satoshi", sans-serif;
    font-size: 40px;
    line-height: 1.2;
  }
  .txt.sottotitolo-grande,
  .txt-sottotitolo-grande,
  .single-offerta .punti-forza .descrizione b {
    font-family: "Satoshi", sans-serif;
    font-size: 40px;
    line-height: 1.2;
  }
  .txt.sottotitolo,
  .txt-sottotitolo,
  .iframe-modal .destinazioni .destinazione {
    font-family: "Satoshi", sans-serif;
    font-size: 28px;
    line-height: 1.25;
  }
  .txt.sottotitolo-piccolo,
  .txt-sottotitolo-piccolo,
  .air-datepicker-nav--title,
  .air-datepicker-nav--title i,
  .air-datepicker-cell,
  .air-datepicker-button {
    font-family: "Satoshi", sans-serif;
    font-size: 20px;
    line-height: 1.2;
  }
  .txt.testo-grande,
  .txt-testo-grande {
    font-size: 18px;
    margin-bottom: 0;
  }
  .txt.testo,
  .txt-testo,
  header .navbar li span,
  header .header-bottom .dropdown-languages,
  .ticket .ticket-item.calendar input,
  .main .secondary-menu-footer li a,
  #homepage-offerte .splide__track .card .card-body .btn,
  .page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
  .content-offerte-passate .card-offerta-archivio .card-body .btn,
  .offerte-residenti .card-offerta-archivio .card-body .btn,
  .banner-cta .banner-cta-content .center .btn,
  .form-calendars-container #calendar-date-departure,
  .form-calendars-container #calendar-date-return,
  .ss-main .ss-single,
  .ss-content .ss-option {
    font-size: 16px;
    margin-bottom: 0;
  }
  .txt.testo-piccolo,
  .txt-testo-piccolo,
  .main .primary-menu-footer li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
  .air-datepicker-body--day-name,
  .date-picker-dettaglio p,
  .iframe-modal .required-message {
    font-size: 14px;
    margin-bottom: 0;
  }
  .txt.piccolo,
  .txt-piccolo,
  .ticket .ticket-item.calendar h3 .ss-main .ss-single,
  .ss-content.ticket-trip-direction .ss-list .ss-option,
  .ticket .ticket-item.passengers .total-passengers,
  .ticket .ticket-item.passengers .total-vehicles,
  .ticket .ticket-item.vehicles .total-passengers,
  .ticket .ticket-item.vehicles .total-vehicles,
  .offerte-last-minute .splide .splide__track .card-last-minute .label {
    font-size: 12px;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 40em) {
  .txt.grande,
  .txt-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.1;
  }
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 50px;
    line-height: 1.1;
  }
  .txt.titolo,
  .txt-titolo,
  .header-modal #big-menu-modal a {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1.2;
  }
  .txt.titolo-piccolo,
  .txt-titolo-piccolo {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1.2;
  }
  .txt.sottotitolo-grande,
  .txt-sottotitolo-grande,
  .single-offerta .punti-forza .descrizione b {
    font-family: "Satoshi", sans-serif;
    font-size: 30px;
    line-height: 1;
  }
  .txt.sottotitolo,
  .txt-sottotitolo,
  .iframe-modal .destinazioni .destinazione {
    font-family: "Satoshi", sans-serif;
    font-size: 26px;
    line-height: 1.25;
  }
  .txt.sottotitolo-piccolo,
  .txt-sottotitolo-piccolo,
  .air-datepicker-nav--title,
  .air-datepicker-nav--title i,
  .air-datepicker-cell,
  .air-datepicker-button {
    font-family: "Satoshi", sans-serif;
    font-size: 16px;
    line-height: 1.2;
  }
  .txt.testo-grande,
  .txt-testo-grande {
    font-size: 18px;
    margin-bottom: 0;
  }
  .txt.testo,
  .txt-testo,
  header .navbar li span,
  header .header-bottom .dropdown-languages,
  .ticket .ticket-item.calendar input,
  .main .secondary-menu-footer li a,
  #homepage-offerte .splide__track .card .card-body .btn,
  .page-template-tpl-offerte .offerte .card-offerta-archivio .card-body .btn,
  .content-offerte-passate .card-offerta-archivio .card-body .btn,
  .offerte-residenti .card-offerta-archivio .card-body .btn,
  .banner-cta .banner-cta-content .center .btn,
  .form-calendars-container #calendar-date-departure,
  .form-calendars-container #calendar-date-return,
  .ss-main .ss-single,
  .ss-content .ss-option {
    font-size: 16px;
    margin-bottom: 0;
  }
  .txt.testo-piccolo,
  .txt-testo-piccolo,
  .main .primary-menu-footer li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-passate .pagination .page-navigation .page-numbers li .current,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li a,
  .page-template-tpl-offerte-nativi .pagination .page-navigation .page-numbers li .current,
  .air-datepicker-body--day-name,
  .date-picker-dettaglio p,
  .iframe-modal .required-message {
    font-size: 14px;
    margin-bottom: 0;
  }
  .txt.piccolo,
  .txt-piccolo,
  .ticket .ticket-item.calendar h3 .ss-main .ss-single,
  .ss-content.ticket-trip-direction .ss-list .ss-option,
  .ticket .ticket-item.passengers .total-passengers,
  .ticket .ticket-item.passengers .total-vehicles,
  .ticket .ticket-item.vehicles .total-passengers,
  .ticket .ticket-item.vehicles .total-vehicles,
  .offerte-last-minute .splide .splide__track .card-last-minute .label {
    font-size: 12px;
    margin-bottom: 0;
  }
}
@media screen and (max-width: 35em) {
  .txt.titolo-grande,
  .txt-titolo-grande {
    font-family: "Satoshi", sans-serif;
    font-size: 45px;
    line-height: 1.1;
  }
}
.txt.mono {
  font-family: "Big Shoulders Display", monospace;
}

.txt.b-gold {
  line-height: 1.24;
}
.txt.b-gold b {
  color: #d1a71d;
  background-color: white;
}
.txt.b-gold b span {
  padding-left: 8px;
  padding-right: 8px;
  display: inline-block;
}

@media screen and (max-width: 410px) {
  #banner-iframe .col-12 {
    padding: 0;
  }
}
#banner-iframe .banner {
  background-position: center;
  background-repeat: no-repeat;
  background-size: cover;
  border-radius: 20px;
  padding: 100px 65px 130px;
}
@media screen and (max-width: 1200px) {
  #banner-iframe .banner {
    padding: 50px 25px;
  }
}
@media screen and (max-width: 992px) {
  #banner-iframe .banner {
    padding: 25px 5px;
  }
}
@media screen and (max-width: 330px) {
  #banner-iframe .banner {
    padding: 25px 0;
  }
}
#banner-iframe .banner h1 {
  font-family: "Big Shoulders Display";
  line-height: 1.2;
}
#banner-iframe .banner h1 strong {
  color: #d1a71d;
  background-color: white;
  padding: 4px 10px;
}

.wysiwyg {
  margin-bottom: 16px;
}
.wysiwyg p {
  font-size: 18px;
  line-height: 1.4 !important;
}
.wysiwyg ol, .wysiwyg ul {
  padding-left: 20px;
  margin-bottom: 16px;
  margin-top: 16px;
  list-style: auto;
}
.wysiwyg ol li, .wysiwyg ul li {
  line-height: 1.4;
  margin-bottom: 4px;
}

.red-hover:hover {
  transition: all ease 0.3s !important;
  background-color: #d2091e !important;
  color: white !important;
}

.azzurro-hover:hover {
  transition: all ease 0.3s !important;
  background-color: #33a8eb !important;
  color: white !important;
}

.azzurro-hover-border:hover {
  transition: all ease 0.3s !important;
  background-color: #33a8eb !important;
  color: white !important;
  border: 1px solid white !important;
}

.bianco-hover-border:hover {
  transition: all ease 0.3s !important;
  background-color: white !important;
  color: #33a8eb !important;
  border: 1px solid #33a8eb !important;
}

.center-card .ss-main {
  padding-right: 4px;
  border: 1px solid white;
}
.center-card .ss-main:hover {
  transition: all ease 0.3s !important;
  border: 1px solid #292c7e !important;
}
.center-card .calendar {
  border: 1px solid white;
  padding: 4px;
}
.center-card .calendar:hover {
  transition: all ease 0.3s !important;
  border: 1px solid #292c7e;
}
.center-card .modal-control-passengers, .center-card .modal-control-vehicles {
  padding-right: 20px !important;
  border-top: 1px solid transparent;
  border-left: 1px solid transparent;
  border-right: 1px solid transparent;
}
.center-card .modal-control-passengers:hover, .center-card .modal-control-vehicles:hover {
  transition: all ease 0.3s !important;
  border: 1px solid #292c7e;
}

.form-button-search {
  transition: all ease 0.3s !important;
}

.form-button-search:hover {
  opacity: 1 !important;
}

.center-card {
  overflow: hidden;
}

.btn-whatsapp:hover {
  background-color: #66a58c;
  color: white !important;
}

.archive.category .card-category:hover {
  background-color: #dbf2ff;
}

.archive.tag .card-tag span {
  padding-top: 5px;
}
.archive.tag .card-tag:hover {
  background-color: #dbf2ff;
}

a.iubenda-tp-btn.iubenda-cs-preferences-link {
  display: none !important;
}

#flexible-content > .sito-map:nth-child(2) {
  margin-top: -200px;
  position: relative;
  z-index: -1;
}
@media screen and (max-width: 1200px) {
  #flexible-content > .sito-map:nth-child(2) {
    margin-top: -100px;
  }
}
@media screen and (max-width: 992px) {
  #flexible-content > .sito-map:nth-child(2) {
    margin-top: 0;
    position: static;
  }
}

#flexible-content > .banner-cta:nth-last-child(1) {
  margin-bottom: 0;
}

.iframe-modal .vehicle:hover {
  text-decoration: underline;
}

#hero-text .buttons a {
  border: 1px solid white;
  background-color: white;
  color: #33a8eb;
}
#hero-text .buttons a:hover {
  background-color: rgba(0, 0, 0, 0) !important;
  color: white !important;
}

.single-destinazione #hero-text .buttons a {
  border: 1px solid white;
  background-color: white;
  color: #33a8eb;
}
.single-destinazione #hero-text .buttons a:hover {
  background-color: rgba(0, 0, 0, 0) !important;
  color: white !important;
}

div[data-message-details] {
  color: white;
}

.accordion-button:hover {
  background-color: #f5f5f5 !important;
}

.form-scheda-thank {
  height: 0px;
}

.disabled .real-submit {
  pointer-events: none;
}

.no-decoration {
  text-decoration: none;
}

.bn-global-btn {
  font-weight: bold;
  border-radius: 0;
  padding: 16px;
  margin-top: 20px;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  transition: all ease 0.3s;
  background-color: #d2091e;
  color: white;
  text-decoration: none;
}
.bn-global-btn:hover {
  background-color: #292c7e;
  color: white;
}