body {
  margin: 0;
  overflow-x: hidden;
}

.inner {
  max-width: 100rem;
  margin: 0 auto;
}

html {
  --scroll-behavior: smooth;
  scroll-behavior: smooth;
}

@font-face {
  font-family: "NewPanamSkyline";
  src: url("font/NewPanamSkyline-Medium-WebS.woff2");
  font-style: normal;
  font-weight: 400;
}

@font-face {
  font-family: "NewPanamSkyline";
  src: url("font/NewPanamSkyline-Regular-WebS.woff2");
  font-style: normal;
  font-weight: 500;
}

img {
  width: 100%;
}

section {
  margin: 250px 0 100px 0;
}

.right {
  text-align: left;
  width: 32rem;
  margin-left: auto;
}

.right p,
.right a {
  margin-left: auto;
  text-align: left;
}

/* colors */
.light-green {
  color:#e4ebb3;
}

.dark-green {
  color:#1a3a1d;
}
/* ?????????????? FLEX */
.flex,
.flex-stay {
  display: flex;
  justify-content: space-between;
}

.invert {
  flex-direction: row-reverse;
}
/* ..................Typo */
h1,
h2,
h3,
h4 {
  font-family: "NewPanamSkyLine";
  font-weight: 100;
  text-transform: uppercase;
  margin: 0;
}

h2 {
  margin: 30px 0;
}

h4 {
  font-family: "NewPanamSkyLine";
  font-weight: 100;
}

p {
  font-size: 12pt;
  font-family: Arial, Helvetica, sans-serif ;
  max-width: 32rem;
  margin: 10px 0;
}

li {
  list-style-type: none;
  font-family: Helvetica, sans-serif;
}
a {
  text-decoration-line: none;
  font-family: Helvetica, sans-serif;
  color: #000;
}

.more {
  text-decoration-line: none;
  font-weight: bold;
  margin-top: 15px;
}


.uppercase {
  text-transform: uppercase;
}
.active {
  font-weight: 600;
}

/* ----------------------------------------header */
header {
  padding: 10px 0;
  background-color:#ffffff;
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 999;
  transition: 0.3s;
}


.burger-menu {
  display: none;
}

.menu,
.menu nav ul {
  /* display: flex;
    justify-content: space-between; */
  position: relative;
}

.menu nav ul li ul,
.menu nav ul li {
  display: block;
  padding: 0;
  justify-content: space-between;
}

.menu li {
  margin-left: 40px;
}

.menu a:hover {
  opacity: 0.5;
  transition: 0.3s;
}

.sous-menu-01 li,
.sous-menu-02 li,
.sous-menu-03 li {
  margin: 0;
  line-height: 30px;
}

.sous-menu-01,
.sous-menu-02,
.sous-menu-03 {
  position: absolute;
  top: 40px;
  opacity: 0;
  transition: 0.5s;
}

li:hover .sous-menu-01,
li:hover .sous-menu-02,
li:hover .sous-menu-03 {
  top: 20px;
  opacity: 1;
}
header li {
  transition: 0.3s;
}

.logo img {
  max-width: 150px;
  margin-top: 10px;
}

.language {
  margin-left: 60px;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 10pt;
}

/* ----------------------------------------main*/
/* (((((((((((((( SECTION 01 */
/* 


.section-01 img {
    position: absolute;
    top: 0;
}

*/

.section-01 {
  position: relative;
  top: 0;
  width: 100%;
  margin: 0;
  z-index: 1000;
}

.section-01 img {
  height: 100dvh;
  object-fit: cover;
}

.section-01 .logo-blanc img {
  position: absolute;
  bottom: 49%;
  right: 25%;
  left: 25%;
  z-index: 99;
  width: 7%;
  height: auto;
  opacity: 0;
}

.section-01 .logo-blanc .part-01 {
  right: 50%;
  left: 47%;
}

.section-01 .logo-blanc .part-02 {
  width: 34%;
  left: 25%;
  bottom: 45.5%;
}
/* (((((((((((((( SECTION 02 */

/* (((((((((((((( SECTION 03 */
.section-03{
  position: relative;
  z-index: 1000;
  background-color: #1a3a1d;
  width: 100%;
  height: 100dvh;
  display: block;
}

/* .section-03 .inner {
  position: absolute;
  top: 15%;
  right: 0;
  left: 0;

} */

.content-absolute {
  display: flex;
  justify-content: space-between;
  color: white;
  align-items:center ;
  width: 100%;
}


.content-absolute img {
  width: 40%;
  height: auto;
  text-align: right;
  margin: 12dvh 0;

}

/* (((((((((((((( SECTION 04 */
/* .news-home {
  
  height: 100%;
  transition: 0.3s;
}

.home-news {
  position: relative;
}
.news-group {
  position: absolute;
  top: 410px;
  opacity: 0;
  color: white;
  padding-left: 30px;
  transition: 0.3s;
  width: 100%;
}

.home-news:hover .news-group {
  opacity: 1;
  top: 310px;
}
.news-group a {
  color: #fff;
}


.news-home img {
  width: 95%;
  height: 500px;
  object-fit: cover;
}
*/
.news-home p,
.news-home h4, .news-group a {
  max-width: 500px;
  opacity: 0;
  margin-top: 20px;
  transition: 0.9s;
} 
.home-news:hover p,
.home-news:hover h4, .home-news:hover .news-group a {
  opacity: 1;
  margin-top: 10px;
}


.news-home img {
  width: 500px;
  height: 700px;
  object-fit: cover;
  transition: 0.4s;
}

.home-news:hover img {
  height: 500px;
}

/* (((((((((((((( SECTION 05 */
/* swiper */


/* .swiper-slide {
    display: flex;
    justify-content: space-between;
  } */

.swiper-slide img {
  width: 50%;
  object-fit: cover;
}

.pensionnaire-text {
  max-width: 600px;
}

/* ----------------------------------------pages*/
/* °°°°°°°°°°°°°°°°° infos */
.big {
  width: 500px;
  height: 300px;
  object-fit: cover;
  transition: 0.3s;
}

.big:hover {
  width: 510px;
  height: 310px;
  object-fit: cover;
}

.ancre {
  height: 1px;
  margin: 0;
  padding: 0;
}

.restau-img {
  width: 30%;
}


.contact {
  background-color: #1a3a1d;
  height: 50dvh;
  margin-bottom: 0;
}

.contact .inner {
  align-items: center;
  padding-top: 17dvh;
}

.section-info {
  background-color: #f2ece1;
  height: 50dvh;
}

.section-info h4 {
  margin-bottom: 20px;
}
.section-info  p {
  margin: 0;
}

.section-info .inner {
  padding-top: 15dvh;
}

.section-info h3 {
  margin: 20px 0;
}

.down {
  margin-bottom: 30px;
}

/* info form */
/* Ajoutez votre style CSS pour le formulaire de réservation ici */
#reservation-form {
  border: 1px solid #ccc;
  padding: 20px;
  margin-top: 20px;
}

#reservation-form h4 {
  margin-top: 0;
  text-transform: uppercase;
}

#reservation-form label {
  display: block;
  margin-bottom: 5px;
}

#reservation-form input[type="number"],
#reservation-form select {
  width: 88%;
  padding: 5px;
  margin-bottom: 10px;
}

#reservation-form button {
  background-color: #000000;
  color: #fff;
  border: none;
  padding: 10px 20px;
  cursor: pointer;
}

#reservation-form button:hover {
  background-color: #3f3f3f;
}

/* °°°°°°°°°°°°°°°°°° activite */
.activite-img {
  width: 500px;
  height: 300px;
object-fit: cover;
}

/* °°°°°°°°°°°°°°° pensio */

.pensionnaire img {
  width: 700px;
  height: 500px;
  object-fit: cover;
}

/* °°°°°°°°°°°°°°° shop */
.shop-img img {
  width: 700px;
  height: 900px;
  object-fit: cover;
}

.group-text p {
  margin: 0;
}

.img-shop-hover {
  position: relative;
  transition: 0.3s;
}
.img-shop-hover .on {
  transition: 0.3s;
  opacity: 1;
  display: block;
  z-index: -3;
}
.off {
  position: absolute;
  top: 0;
  z-index: -4;
}

.img-shop-hover:hover .on {
  opacity: 0;
}

.section-relative {
  position: relative;
}

/* Styles pour le formulaire de commande */
#order-form,
#reservation-form {
  /* Styles de positionnement et arrière-plan */
  background-color: rgba(255, 255, 255, 0.8); /* Blanc semi-transparent */
  width: 400px;
  height: auto;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  padding: 20px;
  border-radius: 10px;
  box-shadow: 0 0 10px rgba(0, 0, 0, 0.2);
  text-align: center;
  font-family: Arial, Helvetica, sans-serif;
}

.specific-color-area {
  background-color: rgb(155, 138, 138);
}

/* Style pour les étiquettes */
label {
  display: block;
  margin-bottom: 10px;
  text-align: left;
  margin-left: 20px;
}

/* Style pour les champs de formulaire */
input[type="text"],
select {
  width: 90%;
  padding: 10px;
  margin-bottom: 20px;
  border: 1px solid #ccc;
  border-radius: 5px;
}

/* Style pour le bouton */
button[type="submit"] {
  background-color: #000000; /* Couleur de fond bleue */
  color: #fff; /* Couleur du texte blanc */
  padding: 10px 20px;
  border: none;
  border-radius: 5px;
  cursor: pointer;
  transition: background-color 0.3s ease;
}

button[type="submit"]:hover {
  background-color: #505860; /* Couleur de fond bleue plus foncée au survol */
}

#close-btn {
  padding: 10px;
}

/* actu */
.actu {
  position: relative;
}

.actu img {
  width: 770px;
  height: 500px;
  object-fit: cover;
}

.actu p, .actu h4 {
  max-width: 500px;
}

.actu h4 {
  /* position: absolute; */
  bottom: 180px;
  /* padding-left: 20px; */
  padding-top: 20px;
  color: #000000;
}


/* ----------------------------------------footer */
footer {
  background-color: #f2ece1;
  color: #fff;
  padding: 50px 0;
}

/* footer .inner, .footer-content{
    display: flex;
    justify-items:baseline;
    justify-content: space-between;
    align-items:normal;
} */

.footer-content {
  width: 100%;
}

footer img {
  margin: 21.28px 70px 0 0;
}
footer p {
  font-size: 11pt;
  margin: 0;
}

footer img {
  width: 60px;
}
 footer h4 {
  margin-bottom: 10px;
 }
/* ----------------------------------------------------RESPONSIVE MEDIA QUERY */

@media screen and (max-width: 1800px) {

  .inner {
    max-width: 60rem;
    margin: 0 auto;
  }
/* typo */
p {
  font-size: 12pt;
  font-family: Arial, Helvetica, sans-serif ;
  max-width: 25rem;
  margin: 10px 0;
}

/* ``````````````````````======================= Header */
.menu li {
  margin-left: 20px;
}
.menu a {
  font-size: 11pt;
}

.sous-menu-01,
.sous-menu-02,
.sous-menu-03 {
  display: none;
}

/* ``````````````````````======================= Main */
/* (((((((((((((( SECTION 03 */
.content-absolute img {
  width: 40%;
  height: auto;
  text-align: right;
  margin: 25dvh 0;

}

/* section 04 */

.news-home img {
  width: 300px;
  height: 500px;
  object-fit:cover;
  transition: 0.4s;
}

/* ----------------------------------------pages*/
/* °°°°°°°°°°°°°°°°° activite */
.activite-img {
  width: 400px;
  height: 500px;
object-fit: cover;
}
/* °°°°°°°°°°°°°°°°° pensio */
.pensionnaire img {
  width: 500px;
  height: 250px;
  object-fit: cover;
}

/* °°°°°°°°°°°°°°°°° actu */
.actu img {
  width: 450px;
  height: 250px;
  object-fit: cover;
}

.actu p, .actu h4 {
  max-width: 400px;
}

/* °°°°°°°°°°°°°°° shop */
.shop-img img {
  width: 400px;
  height: 500px;
  object-fit: cover;
}



}


@media screen and (max-width: 900px) {
  .inner {
    max-width: 20rem;
    margin: 0 auto;
  }
  /* ?????????????? FLEX */
  .flex {
    display: block;
  }

  .responsive-flex {
    display: flex;
    justify-content: space-between;
  }

  /* ..................Typo */
  .right {
    text-align: left;
    width: 100%;
  }

  .right p,
  .right a {
    margin-left: auto;
  }

  .menu > nav {
    display: none;
  }

  /* HEADER */
  .responsive-flex {
    display: flex;
    justify-content: space-between;
  }

  .menu li {
    margin-left: 0;
    margin-top: 10px;
  }

  .show .flex {
    padding: 0;
  }

  .burger-menu {
    display: block;
  }

.language {
  margin: 40px 0;
  text-transform: uppercase;
  font-weight: bold;
  font-size: 10pt;
}
  .burger {
    width: 30px;
    height: 3px;
    background-color: #333;
    margin: 6px 0;
    transition: 0.4s;
  }
  
  .burger-menu {
    z-index: 1004;
    cursor: pointer;
  }
  
  /* Animation lorsque le menu burger est ouvert */
  
  .menu > nav.show {
    display: block;
  }
  
  .burger-menu.open .burger:nth-child(1) {
    transform: rotate(-45deg) translate(-5px, 5px);
  }
  
  .burger-menu.open .burger:nth-child(2) {
    opacity: 0;
  }
  
  .burger-menu.open .burger:nth-child(3) {
    transform: rotate(45deg) translate(-5px, -5px);
  }
  

  /* ======================================= MAIN */

  /* (((((((((((((( SECTION 03 */
  .content-absolute {
    display:block;
    justify-content: space-between;
    color: white;
    align-items:center ;
    width: 100%;
    padding-top: 35%;
  }
.content-absolute img {
display: none;

}

/* (((((((((((((( SECTION 04 */ 

.news-home p,
.news-home h4, .news-group a {
  max-width: 300px;
  opacity: 1;
  margin-top: 20px;
  transition: 0.9s;

} 


.home-news {
  margin-bottom: 40px;
}

.news-home img {
  width: 300px;
  height: 200px;
  object-fit: cover;
  transition: 0.4s;
}

/* (((((((((((((( SECTION 05 */

.swiper-slide img {
  width: 100%;
  object-fit: cover;
  margin-bottom: 20px;
}

/* =====================================Pages */
.big {
  width: 200px;
  height: 200px;
  object-fit: cover;
  transition: 0.3s;
}

.big:hover {
  width: 200px;
  height: 200px;
  object-fit: cover;
}

.section-info {
  background-color: #f2ece1;
  height: 130dvh;
}

/* info */



/* =====================================footer */
footer img {
  margin-bottom: 20px;
}
.footer-group-01, .footer-group-02, .footer-group-03 {
  margin-bottom: 20px;
}


}
