/* commons */

* { margin: 0; padding: 0; box-sizing: border-box;}

body{ font-family: "Quicksand", sans-serif; font-size: 24px;font-weight: 400;}

h1, h2{font-family: "Abril Fatface", serif; text-transform: uppercase; font-weight: 400; font-style: normal;}

h1{font-size: 60px; text-align: left; color: #ffff;}

h2{color: #0F4698; }

.pt-0{padding: top 0!important;}
.pb-0{ padding-bottom:0!important;}

.pt-sm{padding-top:20px;}
.pb-sm{ padding-bottom:20px;}

.pt-md{padding-top:40px;}
.pb-md{ padding-bottom:40px;}

.pt-lg{padding-top:100px;}
.pb-lg{ padding-bottom:100px;}

.mt-sm{margin-top:20px;}
.mb-sm{ margin-bottom:20px;}

.mt-md{margin-top:40px;}
.mb-md{ margin-bottom:40px;}

.mt-lg{margin-top:100px;}
.mb-lg{ margin-bottom:100px;}

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

main p, main h2, main h3 {text-align: center;}

a{text-decoration: none; color: #ffff;}

.logo img {height: 70px; transition: all 0.3s ease;}

header .menu.shrink  .logo img {
    height: 50px;
    transition: all 0.3s ease;
}

.wave{max-width: 100%;}

.icon{
    width: 50px;
}

.container-lg { width: 95%; margin: auto;}
.container-md { width: 85%; margin: auto;}
.container-sm { width: 75%; margin: auto;}

.row { padding: 100px 0;}

.button-container{
    width: 100%;
    text-align: center;
}

.button{
    background-color: #FF5A60;
    border-radius: 25px;
    border: solid 2px #FF5A60;
    padding: 15px 20px;
    width: auto;
    margin: 0 auto;
    display: inline-block;
    color: #ffff !important;
    transition: transform 0.3s ease, box-shadow 0.3s ease;
    cursor: pointer;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.button:hover{
    transform: scale(1.05);
    border: solid 2px #ffff;
    box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2);
}

.card-container{ display: flex; flex-wrap: wrap; justify-content: center; align-items: center; gap:5%;}

.card { max-width: 30%; margin: 30px 0; }

span {display: flex;  align-items: center; gap: 10px;}

/* header */


header { 
     background-image: url(img/casa-vacanza-la-spezia1.webp);
     background-size: cover;
     background-position: center;
 }

header .menu {
    display: flex;
    justify-content: space-between;
    position: fixed;
    top: 0;
    width: 100%;
    margin: 0 auto;
    z-index: 10;
    padding: 0 10%;
    transition: all 0.3s ease;
}

header .menu.shrink {
    background-color: rgba(15,70,152, 0.2);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px); 
    padding: 0 10%;
    height: 80px;
    transition: all 0.3s ease;
}

.menu-desktop{
    padding: 40px 0 20px 0 ;
    transition: all 0.3s ease;
}


.menu.shrink .menu-desktop {
    padding: 30px 0 0 0;
}



header nav ul{
    list-style: none;
    display: flex;
    gap: 35px;
    font-size: 18px;
    margin: 0 0.5em;
    transition: all 0.3s ease;
}

header .menu.shrink nav ul {
    font-size: 17px;
}

header nav ul li{
    display: flex;
    flex-direction: column;
    align-items: center;
    cursor: pointer;
    padding-bottom: 17px;
}

header nav ul li a{
    text-align: right; 
}

header p{color: #ffff; text-align: left; }

header .pulsante:hover{
    background-image: url(img/menu-wave.svg);
    background-position: bottom;
    background-repeat: no-repeat;
}

#language-selector img{
    height: 24px;
}

/* hambuger */

.menu-hamburger{
    display: none;
    cursor: pointer;
    padding: 40px 0;
    transition: all 0.3s ease;
}

 .menu.shrink .menu-hamburger{
    padding: 30px 0 0 0;
    transition: all 0.3s ease;
}

#language-dropdown {
    margin-top: -32px;
    display: none;
    padding:8px;
    border-radius: 10px;
    background-color: #ffff;
  }
  
  #language-dropdown li {
    cursor: pointer;
    height: 24px;
    padding: 0;
  }

  #language-selector.open #language-dropdown {
    display: flex;
    align-items: center;
    gap: 10px;
  }
  
/* main */

.bg-sticky{
    background-image: url(img/bg-sticky.png);
    position: sticky;
    bottom:0;
    z-index: 9;
}

.band-sticky{
   display: flex;
   align-items: center;
   justify-content: space-between;
   color: #0F4698;
   margin: 0 5%;
}

.band-sticky p, .bg-sticky .button-band-sticky .button a{
    font-size: 18px;
}

.band-sticky .button-band-sticky .button{
    margin: 0 0 0 20px!important;
    padding: 5px!important;
    border-radius: 15px!important;
}

.button-band-sticky{
    display: flex; 
    align-items: center;
}

.presentation-band{ background: rgb(255,255,255);
    background: linear-gradient(0deg, rgba(255,255,255,1) 35%, rgba(159,236,255,1) 100%);}

.presentation-band-p{
    margin: 0 15%;
}

.presentation-band .card{
    display: flex; flex-direction: column; align-items: center;
}

.presentation-band .card img{
    width: 50px;
    height: 50px;
}

/* gallery */

.gallery-slider .swiper-slide {
    width: 400px;
    height: 400px;
    border-radius: 25px;
}

.slide1 {
    background-image: url(img/gallery/camera1.webp);
    background-size: cover;
    object-position: center;
}

.slide2 {
    background-image: url(img/gallery/camera1.1.webp);
    background-size: cover;
    object-position: center;
}

.slide3 {
    background-image: url(img/gallery/camera1.2.webp);
    background-size: cover;
    object-position: center;
}

.slide4 {
    background-image: url(img/gallery/cucina1.webp);
    background-size: cover;
    object-position: center;
}

.slide5 {
    background-image: url(img/gallery/cucina1.1.webp);
    background-size: cover;
    object-position: center;
}

.slide6 {
    background-image: url(img/gallery/corridoio1.webp);
    background-size: cover;
    object-position: center;
}

.slide7 {
    background-image: url(img/gallery/corridoio1.1.webp);
    background-size: cover;
    object-position: center;
}

.slide8 {
    background-image: url(img/gallery/bagno1.webp);
    background-size: cover;
    object-position: center;
}

.slide9 {
    background-image: url(img/gallery/bagno1.1.webp);
    background-size: cover;
    object-position: center;
}

.swiper-button-prev::after, .swiper-button-next::after{
	color: #ff5a60 !important;
}

.gallery-slider .swiper-pagination-bullet:hover,
.gallery-slider .swiper-pagination-bullet.swiper-pagination-bullet-active{
	opacity: 1;
	border-color:#ff5a60 !important;
	background-color:#ff5a60 !important;
}

.services-band{
    background: rgb(255,255,255);
    background: linear-gradient(0deg, rgba(255,255,255,1) 0%, rgba(159,236,255,1) 50%, rgba(255,255,255,1) 100%);
}

#servizi .wave, #dove-siamo .wave, #dicono-di-noi .wave, #gallery .wave, #dove-siamo h4 {text-align: center;}

#servizi h3, #servizi p, #dove-siamo h3, #dove-siamo section p{
    text-align: start;
}

#dove-siamo .txt-center p{
    text-align: center;
    padding: 0 3em;
}

#servizi h3, #dove-siamo h3 {
    text-transform: uppercase;
    font-weight: 100;
}

#servizi p, #dove-siamo .points p {
    margin:20px 0 0 60px;

}

#servizi .card .icons, #dove-siamo .icons {
    display: flex; align-items: center; gap: 10px; justify-content: start;
}

.cit-background{ 
     background-image: url(img/migliori-spiagge-cinque-terre.webp);
     background-size: cover;
     background-position: bottom;
     border-radius: 25px;
     padding: 6em;
 }

 .cit p{
    margin:0 6em;
    color: #ffff;
    line-height: 2em;
    font-weight: 400;
    font-size: 24px;
 }

.bg-gradient{
    background: rgb(255,255,255);
    background: linear-gradient(180deg, rgba(255,255,255,1) 0%, rgba(159,236,255,1) 100%);
}

/* dove siamo */

 .ds-points-container{
    background-color: antiquewhite;
    border-radius:25px;
    padding: 3em;
    width: 100%;
    margin: 0 auto;
    position: relative;
    z-index: 0;
 }

 .points-container{
    width:fit-content;
    margin: 0 auto;
 }

 .points{
    width: fit-content;
 }

 #dove-siamo .ds-points-container h3:first-child {
    font-weight: 800;
 }

 #dove-siamo .img-map{
    height: 500px;
    width: 100%;
    margin-bottom: -100px;
 }

 iframe{
    border-radius:25px;
    width: 100%;
    height: 100%;
    
 }

/* rewievs */

#dicono-di-noi{
    margin-bottom: -5%;
}

.widget-recensioni .swiper-wrapper{
	display: flex;
}

.testimonial-block_one{	background-color: #ffff; border-radius: 25px; }
.testimonial-block_one-inner{ padding: 40px 50px; overflow: hidden; }
.testimonial-block_one-text{ position: relative; margin-top: 25px; font-size: 75%;	line-height: 1.5em; color: #000 }
.testimonial-block_one-name{ color:#FF5A60; font-size: 75%; font-weight: 800; padding:20px 0}

 /* FAQ */

.bg-faq{
    background-image: url(img/bg-faq.png);
    margin-bottom: -150px;
}

.widget-faq{
    display: flex;
    justify-content: space-between;
    gap: 2em;
    padding-top: 20%;
}

.widget-faq .sx{
    width: 40%;
 }

.widget-faq .dx{
    width: 60%;
 }

main .widget-faq .sx h2, main .widget-faq .sx p {
    text-align: start!important;
} 
.accordion-box_two{
	position:relative;
}
.accordion-box_two .block{
	position: relative;
	overflow: hidden;
	margin-bottom: 15px;
}

.accordion-box_two .block:last-child{
	margin-bottom:0px;
}
.accordion-box_two .block .acc-btn{
	position:relative;
	cursor:pointer;
	font-size:1.5rem;
	font-weight:600;
	line-height:30px;
	color: #0F4698;
	padding: 30px 0px 30px 45px;
	transition:all 500ms ease;
	-ms-transition:all 500ms ease;
	-o-transition:all 500ms ease;
	-moz-transition:all 500ms ease;
	-webkit-transition:all 500ms ease;
}
.accordion-box_two .block .icon-outer{
	position:absolute;
	left: 0px;
    top: 28px;
	width: 34px;
	height: 34px;
	line-height: 30px;
	border-radius: 50px;
	transition:all 500ms ease;
	-moz-transition:all 500ms ease;
	-webkit-transition:all 500ms ease;
	-ms-transition:all 500ms ease;
	-o-transition:all 500ms ease;
}

.accordion-box_two .block .icon-outer .icon{
    position: absolute;
    left:0px;
	width: 34px;
	height: 34px;
	line-height: 30px;
	border-radius: 50px;
	-webkit-transition:all 500ms ease;
	-moz-transition:all 500ms ease;
	-ms-transition:all 500ms ease;
	-o-transition:all 500ms ease;
	transition:all 500ms ease;
}
.accordion-box_two .block .acc-btn.active .icon-outer .icon-plus{
	transform: rotate(45deg);
}

.accordion-box_two .block .acc-content{
	position:relative;
	display:none;
}

.accordion-box_two .block .acc-content.current{
	display:block;	
}

.accordion-box_two .block .content{
	position:relative;
	margin:0px 40px 35px 45px;
}
.accordion-box_two .block .content .text{
	color: #000;;
	line-height: 30px;
	font-size:17px;
	padding-top: 22px;
    text-align: left;
}


/* footer */
 footer .container-sm{
    display: flex;
    justify-content: space-between;
    align-items: center;
 }

 footer .logo img{
    height: 80px;
 }


.agency-info{
    text-align: center;
}

.agency-info p{
    padding: 5px;
}

footer a, footer p{
    font-size: 18px;
    color: #0F4698;
}

.footer-part{
    width:33%
}

footer section:last-child{
    text-align: right;
}

/*media queries*/

@media (max-width:1200px) {

    p{ font-size: 20px;}

     /* menu */
     .menu-desktop{
        display: none;
    }


   header .menu nav ul{
        flex-direction: column;
        gap: 15px;
        font-size: 24px;
        position: absolute;
        top: 0;
        right: 0;
        padding: 10%;
        width: 100%;
        margin: 116px 0;
        background-color: #ffff;
        color: #0F4698;
        transition: all 0.3s ease;
    }

    header .menu.shrink nav ul {
        margin: 80px 0;
        transition: all 0.3s ease;
    }

    header .menu nav ul a{
        color: #0F4698;
    }

    #language-selector {
        position: relative;
    }

    #language-dropdown li {
        height: 32px;
      }
    
    #language-selector.open #language-dropdown {
        margin: 0 auto;
        width: fit-content;
        position: absolute;
        top: -30%;
        left: 0;
        flex-direction: row;
    }
    
    .menu-hamburger{
        display: block;
    }

    .cit p {
        margin: 0;  
    }

    #dicono-di-noi{
        margin-bottom: -10%;
    }

    .widget-faq {
        padding-top: 30%;
    }
    
}

@media (max-width:1024px) {

    #language-selector img{
        height: 32px;
    }

    .desktop-only{
        display: none;
    }
    .row{padding: 50px 0;}

    .presentation-band-p{
        margin: 0;
    }

    #dove-siamo .txt-center p {
        text-align: center;
        padding: 0;
    }

    .widget-faq {
        padding-top: 20%;
    }

    .band-sticky{
        justify-content: center;
     }

     .band-sticky p{
        text-align:left;
     }

}

@media (max-width:768px){
    h1{font-size: 40px;}

    .card { max-width: 100%; }

    .ds-points-container { padding: 1.5em;}

   .presentation-band .card-container, #servizi .card-container{
        width: 80%;
        margin: 0 auto;
    }

    #servizi p{
        margin-top: 20px;
    }

    #servizi p{
        margin-left: 0;
    }

    .cit-background {
        padding: 3em 1.5em;
    }

    #dove-siamo .img-map {
        margin-bottom: 40px;
    }

    #dicono-di-noi{
        margin-bottom: -15%;
    }

    .widget-faq {flex-direction: column; padding-top: 40%;}

    .widget-faq .sx, .widget-faq .dx, .widget-faq .button a {
        width: fit-content;
        margin: 0 auto;
    }
    main .widget-faq .sx h2, main .widget-faq .sx p{
        text-align: center !important;
    }

    .faq-button-container{
        text-align: center;
    }

    footer .container-sm{
        flex-direction: column;
     }

     .footer-part{
        width:100%;
        text-align:center!important;
        padding-bottom: 20px;
    }
}

@media (max-width:480px){
    .logo img {
        height: 70px;
    }

    .pb-lg{ padding-bottom:0;}

    #dicono-di-noi{
        margin-bottom: -20%;
    }

    .band-sticky{
        flex-direction: column;
     }

     .band-sticky p{
       padding-bottom: 20px;
     }
}