@import url("https://p.typekit.net/p.css?s=1&k=xza1xsu&ht=tk&f=27907.27935.27943.27948.27950.27965.27974.27978.27982.28009.28010.28041.28043.28049&a=88763028&app=typekit&e=css");

@font-face {
font-family:"serenity-semiBold";
src:url("https://use.typekit.net/af/1da4b6/00000000000000007735b462/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff2"),url("https://use.typekit.net/af/1da4b6/00000000000000007735b462/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("woff"),url("https://use.typekit.net/af/1da4b6/00000000000000007735b462/31/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n6&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:600;font-stretch:normal;
}

@font-face {
font-family:"serenity-medium";
src:url("https://use.typekit.net/af/025a0f/00000000000000007735b44c/31/l?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff2"),url("https://use.typekit.net/af/025a0f/00000000000000007735b44c/31/d?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("woff"),url("https://use.typekit.net/af/025a0f/00000000000000007735b44c/31/a?primer=7cdcb44be4a7db8877ffa5c0007b8dd865b3bbc383831fe2ea177f62257a9191&fvd=n3&v=3") format("opentype");
font-display:auto;font-style:normal;font-weight:300;font-stretch:normal;
}

@font-face {
font-family:"canela";
src: url('../fonts/canela_roman.woff2') format('truetype');
}

html {
  overflow-x: hidden;
}

body {
  /* couleurs sources */
  --color-1: #282F6B;
  --color-2: #1A6B6F;
  --color-3: #3A8D91;
  --color-4: #3C70A4;
  --color-5: #EAA636;
  --color-6: #F3EFE3;
  --color-7: #0A1616;
  --color-8: #fff;

  /* couleurs dark */
  --color-dark-1: var(--color-1);
  --color-dark-2: var(--color-2);
  --color-dark-3: var(--color-3);
  --color-dark-4: var(--color-4);
  --color-dark-5: var(--color-7);

  /* couleurs light */
  --color-light-1: var(--color-6);
  --color-light-2: var(--color-5);
  --color-light-3: var(--color-8);

  /* couleurs sémantiques */
  --color-text-on-dark: var(--color-8);
  --color-text-on-light: var(--color-7);

  /* typo */
  --font-medium: "serenity-medium";
  --font-semiBold: "serenity-semiBold";
  --font-other: "canela";


  /* UI */
  --border-radius-xs: 0.5rem;
  --border-radius-s: 1.25rem;
  --border-radius-m: 2.5rem;
  margin: 0;
}

*,
*::before,
*::after {
  box-sizing: border-box;
}

.logo_container {
  border-radius: var(--border-radius-s);
  padding: 0.5rem;
  margin-top: 1.5rem;
  background-color: var(--color-8);
}

.logo {
  height: 5rem;
}


body.nav__open {
  overflow: hidden;
}

body * {
  font-family: var(--font-medium), sans-serif;
  margin: 0;
}

body.no-scroll {
  overflow: hidden;
  height: 100vh;
}

.bg-dark-1 {
  background-color: var(--color-dark-1);
}

.bg-dark-2 {
  background-color: var(--color-dark-2);
}

.bg-dark-3 {
  background-color: var(--color-dark-3);
}

.bg-dark-4 {
  background-color: var(--color-dark-4);
}

.bg-dark-5 {
  background-color: var(--color-dark-5);
}

.bg-light-1 {
  background-color: var(--color-light-1);
}

.bg-light-2 {
  background-color: var(--color-light-2);
}

[class*="bg-light-"] :is(h1, h2, h3, label, p, a, label a, li, em) {
  color: var(--color-text-on-light);
}

[class*="bg-dark-"] :is(h1, h2, h3, label, p, a, label a, li, em),
.background-footer :is(h1, h2, h3, a, p, label, a, label a, li, em)  {
  color: var(--color-text-on-dark);
}

.color-light-2 {
  color: var(--color-light-2) !important;
}

strong,
b {
  font-family: var(--font-semiBold), sans-serif;
}

a {
  text-decoration: none;
}

a[href^="tel"] {
	color: inherit;
	text-decoration: none;
}

.font-other {
  font-family: var(--font-other);
}

.border-radius-s {
  border-radius: var(--border-radius-s);
}

.border-radius-m {
  border-radius: var(--border-radius-m);
}

.border-radius-m-top {
  border-top-left-radius: var(--border-radius-m);
  border-top-right-radius: var(--border-radius-m);
}

.border-radius-m-bottom {
  border-bottom-left-radius: var(--border-radius-m);
  border-bottom-right-radius: var(--border-radius-m);
}

.zindex3 {
  z-index: 3;
}
.zindex2 {
  z-index: 2;
}
.zindex1 {
  z-index: 1;
}
.zindex0 {
  z-index: 0;
}
.zindex-1 {
  z-index: -1;
}

.bold,
b {
  font-weight: bold;
}
.flex1 {
  flex: 1;
}
.fw-normal {
  font-weight: normal;
}

.vertical-middle {
  vertical-align: middle;
}

.fit-cover {
  -o-object-fit: cover;
  object-fit: cover;
}

.fit-contain {
  -o-object-fit: contain;
  object-fit: contain;
}

.fit-content {
  height: fit-content;
}

.display-none {
  display: none ! important;
}

.display-md,
.display-lg,
.display-l {
  display: none;
}


.position-fixed {
  position: fixed;
}

.display-mobile {
    display: none;
  }

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

.text-decoration {
  text-decoration: underline;
}

.cursor-pointer:hover {
  cursor: pointer;
}

.uppercase {
  text-transform: uppercase;
}

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

.height100vh {
  height: 100vh;
}

.height100 {
  height: 100%;
}

.break-word {
  word-break: break-word;
}

.img-vagues {
  position: relative;
  top: -6rem;
}

#alentours .img-vagues {
  top: -3rem;
}

img {
  max-width: 100%;
  height: fit-content;
}

/*------- BOUTON ASCENSEUR -------*/

#ascenseur {
  visibility: hidden;
  opacity: 0;
  transition: visibility 0.3s, opacity 0.3s;
  position: fixed;
  right: 0.6rem;
  bottom: 1.25rem;
  z-index: 10;
  border-radius: var(--border-radius-xs);
  width: 2.2rem;
  height: 2.2rem;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 4;
  background-color: var(--color-7);
}

#ascenseur a {
  color: var(--color-6);
}


/*------- TEXTES -------*/

p:not(.title-not-h3):not(.title-not-h2):not(.title-not-h1):not(.titre):not(.nav_open p):not(.menu-button p):not(header p),
label,
footer a,
input::placeholder,
textarea::placeholder,
form button {
  font-size: 1.125rem;
  line-height: 1.5rem;
}

h1,
.title-not-h1 {
  font-size: 3.75rem;
  line-height: 100%;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--color-dark-1);
}

/*.h1-alternate {
  position: relative;
  bottom: -2rem;
}*/

.subtitle {
  display: block;
  margin-top: 1rem;
  font-size: 2.5rem;
  letter-spacing: 1px;
  line-height: 100%;
  text-transform: initial;
  color: var(--color-dark-2);
}

.titre {
  font-size: 2.5rem;
  line-height: 3rem;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--color-1);
  padding: 4rem 0 3rem;
  font-weight: 600;
}

.titre-cancel-padding-top {
  padding-top: 0;
}

h2,
.title-not-h2 {
  font-size: 2.25rem;
  line-height: 2.5rem; 
  letter-spacing: 1px;
  margin-bottom: 2.5rem;
}

header .title-not-h2 {
  margin-bottom: 0;
}

h3,
.title-not-h3 {
  font-size: 1.8rem;
  line-height: 2.5rem;
  margin-bottom: 2rem;
}

h3.h3-margin-bt-alternate {
  margin-bottom: 0 !important;
}

ul {
  list-style-type: none;
}

p>a {
  text-decoration: underline;
}




/*------- CUSTOM CONTAINER & GRID -------*/

.container-s {
  padding-left: 2rem;
  padding-right: 2rem;
}

.container {
  padding-left: 5rem;
  padding-right: 5rem;
}

.container-alternate {
  padding-left: 5rem;
  padding-right: 0;
}

.container-right {
  padding-right: 5rem;  
}

.grid {
  display: grid;
}

.grid.is-2-col {
  grid-template-columns: 1fr 1fr;
  gap: 2rem;
}

.grid.is-2-col.margin-top-m>img {
  position: relative;
  top: -6rem;
}

.grid.is-3-col {
  grid-template-columns: 1fr 1fr 1fr;
  gap: 6rem;
}

.grid.is-grid-text {
  gap: 3.75rem;
}

.is-grid-align {
  align-items: start;
}

#camping .is-grid-align {
  align-items: start;
}

.grid .item {
  gap: 3rem;
}

.gap-1 {
  gap: 1rem;
}


/*------- CUSTOM MARGIN & PADDING -------*/

.margin-top-xs {
  margin-top: 2rem;
}

.margin-bt-xs {
  margin-bottom: 2rem;
}

.margin-top-s {
  margin-top: 3rem;
}

.margin-top-m {
  margin-top: 4rem;
}

.margin-top-l {
  margin-top: 6rem;
}

.margin-bt-lg {
  margin-bottom: 6rem;
}

.padding-top-xs {
  padding-top: 2.5rem;
}

.padding-bt-xs {
  padding-bottom: 2.5rem;
}

.padding-top-s,
.padding-top-s-block-text {
  padding-top: 3rem;
}

.padding-bt-s,
.padding-bt-s-block-text {
  padding-bottom: 3rem;
}

.padding-top-m,
.padding-top-m-block-text {
  padding-top: 5rem;
}

.padding-bt-m,
.padding-bt-m-block-text {
  padding-bottom: 5rem;
}

.padding-bt-l,
.padding-bt-l-block-text {
  padding-bottom: 6rem;
}

.padding-top-l,
.padding-top-l-block-text {
  padding-top: 6rem;
}

.padding-top-xl {
  padding-top: 8rem;
}

.padding-bt-xl {
  padding-bottom: 8rem;
}

.padding-top-xxl,
.section.padding-top-xxl {
  padding-top: 10rem;
}

.padding-bt-xxl {
  padding-bottom: 10rem;
}

.padding-top-huge {
  padding-top: 12rem;
}

.padding-bt-huge {
  padding-bottom: 12rem;
}

.padding-top-xhuge {
  padding-top: 14rem;
}

.padding-bt-xhuge {
  padding-bottom: 14rem;
}

.padding-top-xxhuge {
  padding-top: 16rem;
}

.padding-bt-xxhuge {
  padding-bottom: 16rem;
}

.padding-bt-xxxhuge {
  padding-bottom: 26rem;
}

.margin-left-m {
  margin-left: 5rem;
}

.margin-bt-negatif {
  margin-bottom: -3rem;
}

.margin-bt-negatif-camping {
  margin-bottom: -5rem;
}

.margin-bt-m {
  margin-bottom: 1.5rem;
}

.margin-bt-l {
  margin-bottom: 3rem;
}



/*----- POPUP -----*/

.popup {
  padding: 2rem 3rem;
  position: fixed;
  left: 50%;
  top: 50%;
  transform: translate(-50%, -50%);
  z-index: 8;
  max-height: calc(100vh - 3rem);
  min-width: 50%;
}

.popup .close {
  position: absolute;
  top: 1rem;
  right: 2rem;
  border: none;
  background: none;
  cursor: pointer;
}

.ligne-horizontale {
  width: 100%;
  height: 1px;
  background-color: var(--color-light-3);
  margin-top: 1rem;
  margin-bottom: 0.5rem;
}


/*----- SECTION HERO -----*/

.section_hero {
  margin-bottom: 5rem;
}



/*------- SLIDER -------*/

.slider {
  position: relative;
  display: block;
  height: calc(100vh - (2 * 3rem));
}

.slider img {
  position: absolute;
  border-radius: var(--border-radius-m);
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#index .slider img:nth-child(1) {
  animation: fade-1 20s infinite;
}

#index .slider img:nth-child(2) {
  animation: fade-2 20s infinite;
}

@keyframes fade-1 {
  0%   { opacity: 1; }
  45%  { opacity: 1; }
  50%  { opacity: 0; }
  95%  { opacity: 0; }
  100% { opacity: 1; }
}

@keyframes fade-2 {
  0%   { opacity: 0; }
  45%  { opacity: 0; }
  50%  { opacity: 1; }
  95%  { opacity: 1; }
  100% { opacity: 0; }
}

.slider video {
  height: 100%;
  width: 100%;
  object-fit: cover;
}


/*------- AUTRES -------*/

#index .is-bg-img,
#camping .is-bg-img {
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  display: grid;
}

#index .is-bg-img {
  height: 780px;
}

#camping .is-bg-img {
  height: 700px;
}

#index .is-bg-img  {
  background-image: url("../images/camping-mayan-montalivet-emplacement-camping.webp");
}

#camping .is-bg-img {
  background-image: url("../images/surf-et-plage-ocean-atlantique-gironde-tourisme.webp");
}

#camping .img-vagues {
  top: -3rem;
}

.is-acces {
  background: url("../images/carte-mer-aquitaine2.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
}

.is-alentours-text {
  margin-bottom: -1rem;
  z-index: 2;
  display: flex;
  padding: 0 5rem;
}

.is-text-above {
  position: relative;
  z-index: 2;
  display: flex;
  margin-top: -7rem;
}

.img-decorative {
  margin-top: -21rem;
  z-index: 1;
}

.img-2pins {
  margin-top: -23rem;
  margin-bottom: 0.5rem;
  pointer-events: none;
}

.img-2pins img {
  max-width: 880px;
  width: 100%;
}

.img-1pin {
  margin-top: -27rem;
  margin-bottom: 0.5rem;
  pointer-events: none;
}

.img-1pin img {
  max-width: 406px !important;
  width: 100%;
}

.u-h-medium {
  height: 575px;
}

.bloc-img-goeland {
  padding-top: 3rem;
}

.bloc-img-zoom {
  width: fit-content;
  height: fit-content;
  overflow: hidden;
}

.bloc-img-zoom img {
  transition: transform 0.4s ease;
  position: relative;
  z-index: 0;
}

.bloc-img-zoom img:hover {
  transform: scale(1.05);
  z-index: 0;
}

.bloc-img-zoom:has(.img-absolute-bt-right) {
  position: absolute;
  right: 2rem;
  bottom: 3rem;
  z-index: 3;
  width: 40%;
}

.section-top {
  height: 3rem;
}

#camping .is-2-col.align-items-center .collage-img {
  margin-top: 0;
}

#camping .is-bg-img>div {
  margin-top: -10rem;
}

#camping .is-2-col .bloc-img-collage img,
#alentours .is-2-col .bloc-img-collage img {
  width: calc(100% + 5rem);
  max-width: 930px;
}

#camping .grid.is-2-col h1 {
  margin-bottom: 5rem;
}

#camping .is-guitare .bloc-img-zoom {
  width: 66.666667%;
}

#emplacements .position-relative.is-text {
  top: -5rem;
}

.bloc-1-img .inner {
  position: relative;
  bottom: -2.5rem;
}

.inner img {
  position: relative;
}

.inner.is-bottom {
  margin-bottom: -5rem;
}

#emplacements .inner.is-top {
  margin-top: -15rem;
}

#emplacements .bloc-img-zoom {
  width: 100%;
}

#emplacements .padding-bt-xhuge {
  padding-bottom: 14rem;
}

#locatifs .locatif_img {
  padding-right: 2.5rem;
  height: fit-content;
}

.locatif_img img {
  border-radius: var(--border-radius-m);
  width: 100%;
  height: 100%;
  object-fit: cover;
}

#locatifs .locatif_descriptif {
  padding-left: 2.5rem;
}

.bloc-locatif {
  position: relative;
  top: -8rem;
}

.presentation-locatifs .bloc-img-zoom {
  width: 93%;
}

.presentation-locatifs .bloc-img-zoom,
.presentation-locatifs .bloc-img-zoom img {
  height: 100% !important;
}

.presentation-locatifs .bloc-img-zoom img {
  width: fit-content;
  object-fit: cover;
}

.img-goeland-volant {
  right: 5rem;
  width: 45%;
}

#alentours .last-section {
  top: -15rem;
  margin-bottom: 8rem;
}

.img-phare {
  position: relative;
  bottom: -2rem;
}

#alentours .padding-bt-xxl {
  padding-bottom: 9rem;
}

#alentours .img-vagues-bottom {
  position: absolute;
  bottom: -2rem;
  width: 100%;
}

#alentours .img-vagues-second {
  position: absolute;
}

#alentours .img-vagues-relative-top {
  position: relative;
  top: -6rem;
}

#alentours .margin-top-huge {
  margin-top: 22rem;
}

#alentours .bloc-img-zoom.position-relative {
  position: relative;
  top: -5rem;
}

#alentours .position-relative.is-text {
    transform: translateY(-50%);
}

#alentours .inner.is-bottom {
  position: relative;
  bottom: -5rem;
}

#alentours .inner.is-top {
  position: relative;
  top: -10rem;
}

#alentours .inner.is-top2 {
  position: relative;
  top: 0;
}

#alentours .inner.is-bottom2 {
  position: relative;
  top: 15rem;
}

#alentours .height-fixed {
  height: 20rem;
}

#alentours .img-mouette {
  position: absolute;
  bottom: 5rem;
  z-index: 2;
}



/*-------- SWIPER --------*/

.swiper {
  width: 100%;
  height: fit-content;
}

.swiper.img {
  height: 100%;
  width: 100% !important;
  object-fit: cover;
}

.swiper-pagination-bullet {
  background: var(--color-light-1) !important;
  opacity: 1 !important;
  width: 0.5rem !important;
  height: 0.5rem !important;
}

.swiper-pagination-bullet-active {
  background: var(--color-dark-5) !important;
}

.button-swiper.swiper-button-next,
.button-swiper.swiper-button-prev {
  width: 2.5rem;
  height: 2.5rem;
  background: var(--color-light-1) !important;
  border-radius: 50%;
}

.button-swiper i {
  color: var(--color-dark-5) !important;
  font-size: 1.7rem;
}

.button-swiper::after {
  display: none;
}



/*-------- FORMULAIRES --------*/


#contact iframe {
  width: 100%;
  height: 778px;
  border-radius: var(--border-radius-m);
  border: 0;
}

.is-form {
  padding-left: 0;
}

form {
  padding: 2rem;
}

input,
textarea,
form button {
  border-radius: 0.5rem;
  border: 0;
}

input,
textarea {
  padding: 1rem;
  font-weight: bold;
}

input {
  margin-bottom: 2rem;
  box-sizing: border-box;
}

textarea {
  height: 6rem;
}

label,
input::placeholder,
textarea::placeholder {
  font-weight: bold;
}

label {
  margin-bottom: 0.5rem;
  color: var(--color-5);
}

.label-input-div .is-right {
  padding-left: 18%;
}

.label-input-div .is-left {
  padding-right: 18%;
}

input::placeholder,
textarea::placeholder {
  color: var(--color-dark-5);
}

form button {
  background: var(--color-dark-1);
  color: var(--color-light-3);
  padding: 0.6rem 3.75rem;
  font-weight: bold;
  margin-top: 2rem;
  cursor: pointer;
}

/*-------- ANIMATION DES FORMULAIRES --------*/

@media (min-width: 1200px) {

  .form-animated input {
    transition: transform 0.3s ease, width 0.3s ease, border-radius 0.3s ease;
  }

  .form-animated .label-input-div:focus-within label,
  .form-animated .label-texteare-div:focus-within label {
    color: var(--color-light-1);
  }

  .form-animated .is-left input:focus,
  .form-animated .is-right input:focus,
  .form-animated textarea:focus {
    border-radius: 0;
  }

  .form-animated .is-left input:focus {
    transform: translate(1.25rem, 1rem) scaleX(1.15);
  }

  .form-animated .is-right input:focus {
    transform: translate(-1.25rem, 1rem) scaleX(1.15);
  }

  .form-animated textarea {
    transition: transform 0.3s ease, border-radius 0.3s ease;
  }

  .form-animated textarea:focus {
    transform: translateY(1rem);
  }

  .form-animated input::-webkit-input-placeholder {
    transition: font-weight 0.3s ease;
  }

  .form-animated input:focus::-webkit-input-placeholder,
  .form-animated textarea:focus::-webkit-input-placeholder {
    color: grey;
  }
}


/*------- RGPD -------*/

.rgpds-main {
  padding-bottom: 5rem;
}

.section-rgpds {
  padding: 10rem 0;
}

.rgpds-main h1 {
  margin-top: 5rem;
  margin-bottom: 2rem;
}

.rgpds-main h2,
.rgpds-main h3 {
  margin-top: 2rem;
  margin-bottom: 1rem;
}





/*------- HEADER --------*/

header {
  position: absolute;
  padding-top : 3rem;
}

.header_col {
  width: 33.3333333333%;
}

.header_col:last-child {
    justify-content: center;
  }

.sidebar-right {
  position: fixed;
  background: var(--color-8);
  right: 0;
  top: 0;
  display: flex;
  color: var(--color-7);
  flex-direction: column;
  align-items: center;
  width: auto;
  z-index: 2;
  margin-top: 3rem;
}

.btn-reservation,
.lang-switcher a,
header i.fas {
  font-family: var(--font-other);
  color: var(--color-7);
  font-size: 1.5rem;
  line-height: 1.25rem;
  text-transform: uppercase;
}

.btn-reservation {
  background: var(--color-5);
  padding: 1.2rem;
  writing-mode: vertical-rl;
  transform: rotate(180deg);
  text-align: center;
}

.lang-switcher {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 2px;
  padding: 1rem 0;
  width: 100%;
}

.lang-switcher .lang-active {
  color: var(--color-7);
  font-weight: 700;
}

.sidebar-icons {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  width: 100%;
  padding-bottom: 0.5rem;
}

.sidebar-icons a {
  color: var(--color-7);
  font-size: 1.5rem;
  padding: 0.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}


/*------- FOOTER -------*/

.background-footer {
  background: url("../images/fond-surf-gironde-tourisme.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  padding-bottom: 1rem;
  color: var(--color-light-3);
}

footer a {
  text-decoration: underline;
}

footer .footer-copy {
  border-top: 0.5px solid var(--color-text-on-dark);
  padding-top: 2rem;
}

footer .footer-copy div {
  color: var(--color-text-on-dark);
}


/*------- FOOTER MOBILE -------*/

.footer__xs {
  display: none;
}


/*------- NAV MOBILE -------*/

.navbar {
  display: flex;
  padding: 1.5rem 0rem 1.5rem 7rem;
  transition: transform 0.3s ease;
}

.navbar.hidden {
  transform: translateY(-1rem);
}

.navbar a {
  z-index: 4;
}

.nav_open .logo_container {
  height: fit-content;
  width: fit-content;
  position: absolute;
  right: 1rem;
  padding-left: 0.5rem;
}

.menu-button {
  cursor: pointer;
  gap: 0.5rem;
  z-index: 7;
}

.menu-button p {
  color: var(--color-light-1);
  text-transform: uppercase;
  text-shadow: 2px 2px 4px var(--color-7);
  font-size: 1.2rem;
}

.nav-icon {
  width: 1.5rem;
  height: 1.2rem;
  position: relative;
  margin-left: 0.625rem;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .5s ease-in-out;
  -moz-transition: .5s ease-in-out;
  -o-transition: .5s ease-in-out;
  transition: .5s ease-in-out;
}

.nav-icon:hover {
  transform: rotate(90deg);
}

.nav-icon span {
  display: block;
  position: absolute;
  width: 100%;
  height: 3px;
  background: var(--color-light-1);
  border-radius: 9px;
  opacity: 1;
  left: 0;
  -webkit-transform: rotate(0deg);
  -moz-transform: rotate(0deg);
  -o-transform: rotate(0deg);
  transform: rotate(0deg);
  -webkit-transition: .25s ease-in-out;
  -moz-transition: .25s ease-in-out;
  -o-transition: .25s ease-in-out;
  transition: .25s ease-in-out;
  box-shadow: 2px 2px 10px var(--color-7);
}

.nav-icon span:nth-child(1) {
  top: 0px;
}

.nav-icon span:nth-child(2),
.nav-icon span:nth-child(3) {
  top: 8px;
  width: 80%;
}

.nav-icon span:nth-child(4) {
  top: 16px;
}

.nav-icon.open span:nth-child(1) {
  top: 6px;
  width: 0%;
  left: 50%;
}

.nav-icon.open span:nth-child(2) {
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
}

.nav-icon.open span:nth-child(3) {
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

nav .nav-icon.open span:nth-child(4) {
  top: 6px;
  width: 0%;
  left: 50%;
}

.nav_open {
  position: absolute;
  padding-left: 5rem;
  padding-right: 5rem;
  top: -110vh;
  width: 100%;
  transition: top 0.3s ease-in-out;
  z-index: 6;
}

.nav_open .display-desktop,
.nav_open .display-mobile {
  position: absolute;
  top: 2rem;
  left: 3rem;;
}

.nav_open.active {
  top: 0rem;
}

.nav_open .nav-liens {
  position: relative;
  border-radius: var(--border-radius-m);
  background: url("../images/surf-et-plage-ocean-atlantique-gironde-tourisme.webp");
  background-size: cover;
  background-position: center;
  background-repeat: no-repeat;
  height: calc(100vh - (2 * 3rem));
  display: grid;
}

.bg-transparent {
  background: rgba(10, 22, 22, 0.3);
  border-radius: var(--border-radius-m);
  position: absolute;
  width: 100%;
  height: 100%;
}

.nav_open .grid {
  padding: 2rem 15rem;
  display: grid;
  grid-template-columns: 2fr 4fr;
  align-self: center;
  gap: 2rem;
  z-index: 7;
}

.nav_open .nav-liens a {
  color: var(--color-8);
  text-transform: uppercase;
  padding-left: 0;
  text-shadow: 2px 2px 5px var(--color-7);
  transition: all 0.2s ease, transform 0.2s ease;
}

header .title-not-h2 {
  padding-top: 1rem;
  padding-bottom: 1rem;
}

.nav_open .nav-liens a:hover,
.nav_open .nav-liens a.active {
  color: var(--color-5);
  padding-left: 2rem;
}

.menu_images {
  position: relative;
  overflow: hidden;
}

.menu_image {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  border-radius: var(--border-radius-m);
  opacity: 0;
  transition: opacity 0.3s ease, transform 0.4s ease;
}

.menu_image.is-active {
  opacity: 1;
}





/*------- BREAKPOINTS -------*/

@media (max-width: 1699px) {

  .display-none-xl {
    display: none;
  }

  .container,
  .nav_open  {
    padding-left: 4rem;
    padding-right: 4rem;
  }

  .container-alternate {
    padding-left: 4rem;
    padding-right: 0;
  }

  .padding-bt-xhuge {
    padding-bottom: 4rem;
  }

  .nav_open .grid {
    padding: 2rem 12rem;
  }

  .grid.is-3-col { 
    gap: 4rem;
  }

  .bloc.padding-top-xxl {
    padding-top: 5rem;
  }

  .popup {
    padding: 1rem 1.5rem;
    max-height: calc(100vh - 2rem);
    min-width: 70%;
  }

  .popup p {
    font-size: 0.8rem !important;
    line-height: 130% !important;
  }

  #contact iframe {
    height: 650px;
  }

  #contact .is-intro {
    margin-bottom: 2rem;
  }

  .padding-bt-xxxhuge {
    padding-bottom: 14rem;
  }

  .is-form {
    padding: 0 !important;
  }

  #camping .img-vagues {
    margin-bottom: 3rem;
  }

  #camping .is-2-col .bloc-img-collage img,
  #alentours .is-2-col .bloc-img-collage img {
    width: 100%;
  }

  #camping .titre,
  #emplacements .titre.cancel-padding-top,
  #locatifs .titre.cancel-padding-top {
    width: 100% !important;
    padding-top: 0;
  }

  #camping .grid.is-2-col h1 {
    margin-bottom: 0rem;
  }

  .img-1pin .titre {
    padding-bottom: 2rem !important;
  }

  .img-1pin {
    margin-top: -21rem;
  }

  #locatifs .locatif_img {
    padding-right: 1.5rem;
  }

  #locatifs .locatif_descriptif {
    padding-left: 1.5rem;
  }

  .img-goeland-volant {
    width: 25%;
  }

  #alentours .padding-bt-xxl {
    padding-bottom: 5rem;
  }

  #alentours .margin-top-huge {
    margin-top: 10rem;
  }

  #alentours .add-margin-bottom-1699 {
    margin-bottom: 5rem;
  }

  #camping .img-vagues {
    margin-bottom: 0;
  }

  #camping .is-bg-img  {
    height: 640px;
  }

  
}

@media (max-width: 1399px) {

  .display-none-l {
    display: none;
  }

  .display-l {
    display: flex;
  }

  #camping .titre {
    padding-top: 2rem;
  }

  .sidebar-right {
    margin-top: 1.5rem;
  }

  .btn-reservation,
  .lang-switcher a,
  header i.fas {
    font-size: 1.2rem;
    line-height: 1rem;
  }

  .btn-reservation {
    padding: 1rem;
  }

  .sidebar-icons a {
    font-size: 1rem;
  }

  header {
    padding-top : 1.5rem;
    z-index: 5;
  }

  .navbar {
    padding: 1.5rem 0rem 1.5rem 4rem;
  }

  .nav_open .grid {
    padding: 2rem 10rem;
    grid-template-columns: 2fr 3fr;
  }

  .nav_open .nav-liens {
    height: calc(100vh - (2 * 1.5rem));
  }

  .container,
  .nav_open  {
    padding-left: 3.2rem;
    padding-right: 3.2rem;
  }

  .container-alternate {
    padding-left: 3.2rem;
  }

  .padding-top-s {
    padding-top: 1.5rem;
  }

  .padding-bt-s {
    padding-bottom: 1.5rem;
  }

  .padding-top-s-block-text,
  .padding-top-m,
  .padding-top-m-block-text,
  .padding-top-l-block-text {
    padding-top: 3rem;
  }

  .padding-bt-s-block-text,
  .padding-bt-m,
  .padding-bt-m-block-text,
  .padding-bt-l-block-text {
    padding-bottom: 3rem;
  }

  .padding-bt-xxl {
    padding-bottom: 7rem;
  }

  .slider {
    height: 75vh;
  }

  p:not(.title-not-h3):not(.title-not-h2):not(.title-not-h1):not(.titre):not(.nav_open p):not(.menu-button p):not(header p),
  label,
  footer a,
  input::placeholder,
  textarea::placeholder,
  form button {
    font-size: 1rem;
    line-height: 1.5rem;
  }

  h1,
  .title-not-h1 {
    font-size: 2.5rem;
  }

  .subtitle {
    font-size: 2.25rem;
  }

  h2,
  .title-not-h2 {
    font-size: 1.7rem;
    line-height: 1.9rem; 
  }

  h3,
  .title-not-h3 {
    font-size: 1.3rem;
    line-height: 1.5rem;
  }

  .titre {
    font-size: 2rem;
    line-height: 2.5rem;
  }

  #camping .titre {
    width: 60% !important;
    margin: auto;
  }

  .section_hero {
    margin-bottom: 4rem;
  }

  .img-vagues {
    top: -4rem;
  }

  .u-h-medium {
    height: 475px;
  }

  #index .is-bg-img {
    height: 680px;
  }

  #camping .is-bg-img {
    height: 540px;
  }

  .img-decorative {
    width: 50%;
    margin-top: -12rem;
  }

  .bloc-2-img-absolute>div:first-child {
    margin-right: 6rem;
  }

  #contact iframe {
    height: 550px;
  }

  .is-text.padding-top-xl {
    padding-top: 2rem;
  }

  .is-text.padding-bt-xl {
    padding-bottom: 2rem;
  }

  #emplacements .padding-bt-xhuge {
    padding-bottom: 8rem;
  }

  #emplacements .inner.is-top {
    margin-top: -8rem;
  }

  .bloc-1-img .inner {
    position: relative;
    bottom: -1.5rem;
  }

  .inner.is-bottom {
    margin-bottom: -3rem;
  }

  .img-1pin {
    margin-top: -18rem;
  }

  .img-1pin .titre {
    padding-bottom: 1rem !important;
  }

  .presentation-locatifs .bloc-img-zoom {
    width: 100%;
  }

  #locatifs .locatif_img {
    padding-right: 1rem;
  }

  #locatifs .locatif_descriptif {
    padding-left: 1rem;
  }

  .descriptif-details {
    display: flex;
    gap: 2.5rem;
  }

  .descriptif-details>div:first-child,
  .descriptif-details>div:nth-child(2) {
    width: 50%;
  }

  .bloc-locatif {
    top: -5rem;
  }

  #alentours .img-vagues-bottom {
    bottom: -1rem;
  }

  #alentours .last-section {
    top: -13rem;
  }

  #alentours .inner.is-bottom {
    bottom: -3rem;
  }

  #alentours .inner.is-bottom2 {
    top: 13rem;
  }

  #alentours .img-mouette {
    width: 50%;
    bottom: 6rem;
  }

  #alentours .img-vagues-second {
    top: 5rem;
  }

}


@media (max-width: 1199px) {
  
  .container-alternate-right,
  .presentation-locatifs .container-alternate {
    padding-right: 3.2rem;
  }

  .display-none-lg {
    display: none;
  }

  .display-lg {
    display: flex;
  }

  #locatifs .padding-bt-huge {
    padding-bottom: 0;
  }

  .locatif_content>div.padding-bt-l {
    padding-bottom :3rem;
  }

  .bloc.padding-top-xxl {
    padding-top: 1.5rem;
  }

  .section-top {
    height: 2rem;
  }

  .padding-top-s-block-text,
  .padding-top-m,
  .padding-top-m-block-text,
  .padding-top-l-block-text,
  #camping .padding-top-l,
  #emplacements .padding-top-l,
  #locatifs .bg-light-1.padding-top-l,
  #alentours .bg-light-1.padding-top-l,
  #alentours .bg-light-1>div>div.padding-top-l {
    padding-top: 2rem;
  }

  .padding-bt-s-block-text,
  .padding-bt-m,
  .padding-bt-m-block-text,
  .padding-bt-l-block-text,
  .padding-bt-xxl,
  #camping .padding-bt-l,
  #emplacements .padding-bt-l,
  #locatifs .bg-light-1.padding-bt-l,
  #alentours .bg-light-1.padding-bt-l,
  #alentours .padding-bt-xxl {
    padding-bottom: 2rem;
  }

  .margin-bt-negatif {
    margin-bottom: 0; 
  }

  .bloc-2-img-absolute {
    padding-bottom: 1.5rem;
  }

  .img-decorative {
    width: 80%;
    margin-top: -18rem;
  }

  .nav_open .grid {
    padding: 2rem 6rem;
    grid-template-columns: 2fr 3fr;
  }

  .is-alentours-text {
    margin-bottom: 2rem;
    padding: 0rem;
  }

  .padding-bt-xxl {
    padding-bottom: 3rem;
  }

  .cancel-container-lg {
    padding-right: 0 !important;
  }

  #contact .cancel-container-lg {
    padding-left: 0 !important;
  }

  .grid.is-3-col {
    grid-template-columns: 1fr 1fr;
  }

  .grid.is-3-col .text {
    grid-column: 1 / -1;
  }

  .u-h-medium {
    height: 400px;
  }

  #index .is-bg-img {
    height: 580px;
  }

  #camping .is-bg-img {
    height: 440px;
  }

  .bloc-2-img-absolute>div:first-child {
    width: 65%;
    margin-bottom: 14rem;
  }

  .bloc-img-goeland {
    padding-top: 0;
  }

  .is-form {
    margin-bottom: 2rem; 
  }

  #contact iframe {
    height: 450px;
  }

  .padding-bt-xxxhuge {
    padding-bottom: 10rem;
  }

  .label-input-div .is-right {
    padding-left: 10%;
  }

  .label-input-div .is-left {
    padding-right: 10%;
  }

  .inner.is-bottom {
    margin-bottom: -2rem;
  }

  #emplacements .padding-bt-xhuge {
    padding-bottom: 9rem;
  }

  #emplacements .img-offset-top {
    margin-top: 2rem;
  }

  .bloc-1-img .inner {
    bottom: -1rem;
  }

  .grid.is-2-col.margin-top-m>img {
    top: 0;
  }

  .presentation-locatifs .bloc-img-zoom img {
    width: 100%;
  }

  .img-1pin {
    margin-top: -14rem;
  }

  #locatifs .locatif_img {
    padding-right: 0;
  }

  #locatifs .locatif_descriptif {
    padding-left: 0;
  }

  .bloc-locatif {
      top: 0;
      margin-top: 2rem;
  }

  #locatifs .locatif_content.last-section,
  #alentours .last-section {
    margin-bottom: 4rem;
  }

  .locatif_content.is-first {
    padding-top: 2rem;
    padding-bottom: 2rem;
  }

  .section-intro .intro-bloc-text.margin-top-m {
    margin-top: 0;
  }

  #alentours h1 {
    text-align: center;
    padding: 0 !important;
  }

  .img-goeland-volant {
    display: none;
  }

  #alentours .margin-bt-lg {
    margin-bottom: 2rem;
  }

  #alentours .add-margin-negative-1199 {
    margin-top: -3rem;
  }

  #alentours .inner.is-top {
    top: -2rem;
  }

  #alentours .inner.is-bottom {
    bottom: -2rem;
  }

  #alentours .inner.is-bottom2 {
    bottom: 14rem;
  }

  #alentours .inner.is-top2 {
    top: 10rem;
  }

  .padding-bt-xxxhuge {
    padding-bottom: 4rem;
  }

  #alentours .add-margin-bottom-1699 {
    margin-bottom: -5rem;
  }

  #alentours .bloc-img-zoom.position-relative {
    top: -4rem;
  }

  .add-container-1199 {
    padding-left: 3.2rem;
    padding-right: 3.2rem;
  }

  #alentours .img-vagues-second {
    top: 7rem;
  }

  #camping .img-vagues {
    margin-bottom: 1rem;
  }

  #contact .padding-bt-xxxhuge {
    padding-bottom: 8rem;
  }

  #alentours .bg-light-1.cancel-border-radius-top {
    border-top-left-radius: var(--border-radius-m);
    border-top-right-radius: var(--border-radius-m);
  }

}

@media (max-width: 991px) {

  .display-md {
    display: flex;
  }

  .display-none-md {
    display: none;
  }

  .nav_open .nav-liens a:hover {
    color: var(--color-8);
    padding-left: 0;
  }

  header .title-not-h2 {
    padding-top: 1rem;
    padding-bottom: 1rem;
  }

  .container,
  .container-alternate,
  .nav_open,
  .presentation-locatifs .container-alternate,
  .add-container-1199,
  .add-container-991  {
    padding-left: 2rem;
    padding-right: 2rem;
  }

  .grid.grid-reverse>img {
    grid-area: item1;
  }

  .grid.grid-reverse>div {
    grid-area: item2;
    gap: 2rem;
  }

  .grid.grid-reverse {
    grid-template-areas:"item2" "item1";
  }

  .container-alternate-right {
    padding-right: 0;
  }

  .slider {
    height: 358px;
  }

  .section_hero {
    margin-bottom: 1.5rem;
  }

  .grid .item {
    gap: 0;
  }

  .grid.is-2-col h1,
  #camping .grid.is-2-col h1 {
    margin-bottom: 1.5rem;
  }

  .grid.is-2-col {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }

  .collage-img {
    margin-top: 0;
    margin-bottom: 1.5rem;
  }

  h2,
  .title-not-h2,
  h3,
  .title-not-h3 {
    margin-bottom: 1.5rem; 
  }

  .titre {
    padding: 1rem;
  }

 .is-acces {
    background: transparent;
  }

  .margin-bt-l {
    margin-bottom: 0;
  }

  .padding-bt-l {
    padding-bottom: 4rem;
  }

  .img-vagues {
    top: -2.5rem;
  }

  .grid.is-3-col {
    gap: 2rem;
  }

  .img-2pins {
    margin-top: -20rem;
  }

  .u-h-medium {
    height: 300px;
  }

  #index .is-bg-img {
    height: 400px;
  }

  #camping .is-bg-img {
    height: 320px;
  }

  #camping .titre {
    width: 90% !important;
    padding-top: 0;
  }

  body:not(#alentours) .is-alternate-padding.padding-bt-m {
    padding-top: 2rem !important;
    padding-bottom: 0 !important;
  }

  .padding-bt-xxhuge {
    padding-bottom: 10rem;
  }

  #camping .is-3-col {
    padding-top: 0;
  }

  .padding-top-xxl,
  .section.padding-top-xxl,
  #camping .padding-top-l,
  #emplacements .padding-top-l,
  #locatifs .bg-light-1.padding-top-l,
  #alentours .bg-light-1.padding-top-l {
    padding-top: 2rem;
  }

  #camping .padding-bt-l,
  #camping .is-guitare,
  #emplacements .padding-bt-l,
  #locatifs .bg-light-1.padding-bt-l,
  #alentours .bg-light-1.padding-bt-l,
  #alentours .padding-bt-l  {
    padding-bottom: 2rem;
  }

  footer {
    margin-bottom: 5rem;
  }

  .footer__xs
  {
    display: flex;
    position: fixed;
    bottom: 0;
    height: 5rem;
  }

  .footer__xs div:first-child {
    border-top: 0.5px solid var(--color-7);
    border-bottom: 0.5px solid var(--color-7);
  }

  .footer__xs>div:first-child {
    color: var(--color-light-1);
    font-size: 2rem;
    letter-spacing: 2px;
  }

  .footer__xs a {
    width: 100%;
    text-align: center;
  }

  .footer__xs i {
    color: var(--color-light-1);
  }

  .footer__xs div {
    height: 2.5rem;
  }  

  #ascenseur {
    bottom: 5.5rem;
  }

  .bloc-2-img-absolute>div:first-child {
    margin-bottom: 6rem;
  }

  .bloc-img-zoom:has(.img-absolute-bt-right) {
    bottom: 1.5rem;
  }

  .img-decorative {
    margin-top: -12rem;
  }

  .padding-bt-xhuge {
    padding-bottom: 2rem;
  }

  .popup {
    max-height: calc(100vh - 1rem);
    min-width: 90%;
  }

  #contact iframe {
    height: 350px;
  }

  .padding-bt-xxxhuge {
    padding-bottom: 8rem;
  }

  .is-form {
    margin-bottom: 1.5rem; 
  }

  .is-text-above {
    margin-top: 2rem;
  }

  #camping .padding-bt-xl {
    padding-bottom: 3.5rem;
  }

  #camping .is-2-col.align-items-center .collage-img {
    margin-bottom: 0;
  }

  #camping .is-guitare .bloc-img-zoom {
    width: 100%;
  }

  #camping .padding-top-huge {
    padding-top: 0.5rem;
  }

  #camping .padding-top-huge>div:first-child {
    margin-bottom: 2rem;
  }

  #emplacements .padding-bt-m {
    padding-bottom: 4rem;
  }

  #emplacements .padding-bt-xhuge {
    padding-bottom: 4rem;
  }

  #emplacements .img-offset-top {
    margin-top: 0;
  }

  .bg-light-1.add-border-radius-top {
    border-radius: var(--border-radius-m);
  }

  .cancel-padding-top-m {
    padding-top: 0;
  }

  .img-1pin {
    margin-top: -20rem;
    margin-bottom: 2rem;
  }

  .img-1pin>div:last-child {
    padding-right: 2rem;
  }

  .bloc-locatif {
    margin-top: 1.5rem;
  }

  .locatif_content>div.padding-bt-l {
    padding-bottom :2rem;
  }

  #locatifs .locatif_content.last-section,
  #alentours .last-section {
    margin-bottom: 3rem;
  }

  #alentours .is-2-col.u-h-medium {
    grid-template-columns: 1fr 1fr;
  }

  #alentours .last-section {
    margin-bottom: 3.5rem;
  }

  #alentours .collage-img {
    margin-bottom: 0;
  }

  #alentours .add-margin-negative-1199 {
    margin-top: 0.5rem;
  }

  #alentours .add-container-991 {
    margin-top: 2rem;
  }

  #alentours .is-relative-991 {
    position: relative !important;
    margin-bottom: 2rem;
    width: 100%;
  }

  #alentours .is-relative-991 img {
    width: 100%;
  }

  #alentours .bloc-img-zoom.position-relative {
    margin-top: 2rem;
    top: 0rem;
  }

  #alentours .margin-top-huge {
    margin-top: 0;
  }

  #alentours .modify-margin-top-l-991 {
    margin-top: 2rem;
    padding-bottom: 4rem;
  }

  #alentours .inner.is-top {
    top: -6rem;
  }

  #alentours .inner.is-bottom {
    bottom: 6rem;
  }

  #alentours .inner.is-top2,
  #alentours .inner.is-bottom2 {
    top: 6.5rem;
  }

  #alentours .last-section {
    margin-bottom: 0;
  }

  #alentours .bloc-img-zoom {
    width: 100%;
  }

 
}



@media (max-width: 767px) {

  .display-none-sm {
    display: none;
  }

  .margin-top-m,
  #alentours .modify-margin-top-l-991,
  #alentours .bloc-img-zoom.position-relative {
    margin-top: 1.5rem;
  }

  .popup {
    min-width: 95%;
  }

  .menu_images {
    display: none;
  }

  .nav_open {
    padding-left: 0;
    padding-right: 0;
  }

  .nav_open.active {
    padding-top: 0;
    padding-left: 0;
    padding-right: 0;
  }

  .nav_open .nav-liens {
    height: 100svh;
  }

  .nav_open .grid {
    padding: 2rem;
    grid-template-columns: 1fr;
  }

  header {
    padding-top : 0;
  }

  header .title-not-h2 {
    font-size: 2.25rem;
    line-height: 100%;
    margin-top: 0.5rem;
    margin-bottom: 0.5rem;
  }

  .header_col {
    width: 50%;
  }

  .header_col:last-child {
    justify-content: flex-end;
    padding-right: 2rem;
  }

  .navbar {
    padding: 1.5rem 0rem 1.5rem 2rem;
  }

  .slider {
    height: 158px;
  }

  p:not(.title-not-h3):not(.title-not-h2):not(.title-not-h1):not(.titre):not(.nav_open p):not(.menu-button p):not(header p),
  label,
  footer a,
  input::placeholder,
  textarea::placeholder,
  form button {
    font-size: 0.875rem;
    line-height: 1.25rem;
  }

  h1,
  .title-not-h1 {
    font-size: 1.5rem;
  }

  .subtitle {
    font-size: 1.25rem;
  }

  .titre {
    display: none;
  }

  h2,
  .title-not-h2 {
    font-size: 1.125rem;
    line-height: 1.25rem; 
  }

  h3,
  .title-not-h3 {
    font-size: 1rem;
    line-height: 1.2rem;
  }

  .container,
  .container-s,
  .container-alternate,
  .presentation-locatifs .container-alternate,
  .add-container-991,
  .add-container-1199 {
    padding-left: 1rem;
    padding-right: 1rem;
  }

  .padding-top-s {
    padding-top: 0.5rem;
  }

  .padding-bt-s {
    padding-bottom: 0.5rem;
  }

  form {
    padding: 1.5rem 1rem;
  }

  .img-vagues,
  #alentours .img-vagues {
    top: -1.2rem;
  }

  .img-2pins {
    margin-top: -15rem;
  }

  .padding-top-s-block-text,
  .padding-top-m,
  .padding-top-m-block-text,
  .padding-top-l-block-text
  .padding-top-xxl,
  .section.padding-top-xxl,
  #camping .padding-top-l,
  #locatifs .bg-light-1.padding-top-l,
  #alentours .bg-light-1.padding-top-l {
    padding-top: 1.5rem;
  }

  .padding-bt-s-block-text,
  .padding-bt-m,
  .padding-bt-m-block-text,
  .padding-bt-l-block-text,
  .padding-bt-xxl,
  #camping .padding-bt-l,
  #camping .is-guitare,
  #locatifs .bg-light-1.padding-bt-l,
  #alentours .bg-light-1.padding-bt-l,
  #alentours .padding-bt-l {
    padding-bottom: 1.5rem;
  }

  .is-alternate-padding.padding-bt-m {
    padding-top: 1.5rem !important;
  }

  .is-alentours-text,
  #alentours .margin-bt-lg {
    margin-bottom: 1.5rem;
  }

  #alentours .add-margin-negative-1199 {
    margin-top: -0.5rem;
  }

  #alentours .add-container-991 {
    margin-top: 1.5rem;
  }

  .u-h-medium {
    height: 120px;
  }

  #index .is-bg-img {
    height: 170px;
  }

  #camping .img-vagues {
    margin-bottom: 2rem;
  }

  #index .is-bg-img.padding-top-xxhuge {
    padding-top: 0;
  }

  .padding-bt-xxhuge {
    padding-bottom: 5rem;
  }

  .padding-bt-xl {
    padding-bottom: 4rem;
  }

  #footer-copy {
    gap: 0;
  }

  .bloc-2-img-absolute {
    padding-top: 1.5rem;
  }

  .bloc-img-zoom:has(.img-absolute-bt-right) {
    right: 1rem;
  }

  .img-decorative {
    width: 100%;
    margin-top: -6rem;
  }

  .bloc-img-goeland {
    padding-top: 1.5rem;
    align-items: flex-start !important;
  }

  .bloc-img-goeland img {
    max-height: calc(120px - 3rem);
    width: fit-content;
  }

  .padding-bt-xxxhuge {
    padding-bottom: 18rem;
  }

  #contact .is-intro {
    margin-bottom: 0;
  }
  
  .label-input-div .is-right {
    padding-left: 0;
  }

  .label-input-div .is-left {
    padding-right: 0;
  }

  input {
    margin-bottom: 1rem;
  }

  .is-text-above,
  .margin-top-xs {
    margin-top: 1.5rem;
  }

  #camping .padding-bt-xl {
    padding-bottom: 3rem;
  }

  .section-top {
    height: 1.5rem;
  }

  #camping .padding-top-huge {
    padding-top: 0rem;
  }

  #camping .padding-top-huge>div:first-child,
  .margin-bt-xs {
    margin-bottom:1.5rem;
  }

  #emplacements .padding-bt-xhuge {
    padding-bottom: 2.3rem;
  }

  #emplacements .padding-bt-xxxhuge {
    padding-bottom: 8rem;
  }

  #emplacements .padding-bt-m {
    padding-bottom: 3.3rem;
  }

  .bloc-1-img .inner {
    bottom: -0.5rem;
  }

  .cancel-padding-top-m {
    padding-top: 0;
  }

  .grid.grid-reverse>div {
    gap: 1.5rem;
  }

  .img-1pin {
    margin-bottom: 1.5rem;
  }

  .img-1pin>div:last-child {
    padding-right: 1rem;
  }

  .locatif_content>div.padding-bt-l {
    padding-bottom :1.5rem;
  }

  .descriptif-details {
    display: flex;
    flex-direction: column;
    gap: 0;
  }

  .descriptif-details>div:first-child,
  .descriptif-details>div:nth-child(2) {
    width: 100%;
  }

  .locatif_content.is-first {
    padding-top: 0;
    padding-bottom: 1.5rem;
  }

  #alentours .img-vagues-bottom {
    bottom: 0;
  }

  #alentours .img-vagues-relative-top {
    top: -2.5rem;
  }

  #alentours .add-margin-bottom-1699 {
    margin-bottom: -3rem;
  }

  #alentours .padding-bt-xxxhuge {
    padding-bottom: 7.5rem;
  }

  #alentours .inner.is-top2, #alentours .inner.is-bottom2 {
    top: 7.4rem;
  }

  #alentours .last-section {
    margin-bottom: -2rem;
  }

  #contact .padding-bt-xxxhuge {
    padding-bottom: 18rem;
  }

  
}


@media (min-width: 450px) and (max-width: 767px) {
  #alentours .add-margin-bottom {
  margin-bottom: 1.5rem;
}
}


@media (max-width: 575px) {
  .img-2pins,
  .img-1pin {
    margin-top: -10rem;
    padding-left: 16.66667%;
  }

  #alentours .img-vagues-bottom {
    bottom: 1rem;
  }

  #alentours .margin-top-xs {
    margin-top: 0;
  }
}

