* {
  box-sizing: border-box;
}

html {
  height: 100%;
}

body {
  margin: 0;
  padding: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  overflow: hidden;
  background: #5ab9d7;
  background: radial-gradient(ellipse at center, #5ab9d7  0%, #7b95d2 50%);
}

a {
	color: #03030366;
	text-decoration: none;
}
.cactus {
  width: 134px;
  border-radius: 100%;
  position: absolute;
  left: 18px;
  bottom: 19px;
  opacity:0;
  z-index:-1;
}
.cactus--active{
  opacity:1;
}
.mexican {
  width: 200px;
  border-radius: 100%;
  position: absolute;
  left: 93px;
  bottom: 20px;
  opacity:0;
}

.mexican--active{
  opacity:1;
}
.mexican_1 {
  width: 120px;
  border-radius: 100%;
  position: absolute;
  left: 14px;
  bottom: 15px;
  opacity:0;
}

.mexican_1--active{
  opacity:1;
}



.planet {
  width: 300px;
  height: 300px;
  border-radius: 100%;
  position: relative;
}

.path-wrapper {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 50;
}

.outline {
  fill: transparent;
  stroke: #4d3034;
  fill: #82b765;
  stroke-width: 2;
  position: relative;
  z-index: 5;
}
.outline2 {
  fill: transparent;
  stroke: #4d3034;
  fill: #82b765;
  stroke-width: 2;
  position: relative;
  z-index: 5;
}

/* ----- */
/* Cloud */
/* ----- */

.cloud-boundary {
  width: 100px;
  height: 270px;
  position: absolute;
  top: calc(-50% - 30px);
  left: 50%;
  transform: translateX(-50%);
  transform-origin: bottom center;
  z-index: -2;
  will-change: auto;
}

.cloud-boundary__marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;
}

.cloud {
  width: 100%;
  height: 50px;
  position: absolute;
  top: 0;
  left: 0;
}

.cloud-svg {
  fill: #ffffff;
}

.cloud-black-svg {
  fill: #000000;
}

/* ---- */
/* Rain */
/* ---- */

.rain {
  width: calc(100% - 20px);
  height: 100%;
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
  transition: opacity 0.3s;
  opacity: 0;
}

.rain--active {
  opacity: 0.6;
}

.rain__drops-top {
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  background: url(../img/rain.png) 0 0 no-repeat;
  background-size: 100% 100%;
  opacity: 1;
}

.rain__drops-bottom {
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  background: url(../img/rain.png) 0 0 no-repeat;
  background-size: 100% 100%;
  opacity: 1;
}

.neige {
  width: calc(100% - 20px);
  height: 100%;
  position: absolute;
  top: 40px;
  left: 50%;
  transform: translateX(-50%);
  overflow: hidden;
  transition: opacity 0.3s;
  opacity: 0;
}

.neige--active {
  opacity: 0.6;
}
.neige---active {
  opacity: 1;
}


.neige__drops-top {
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  background: url(../img/neige.png) 0 0 no-repeat;
  background-size: 100% 100%;
  opacity: 1;
}

.neige__drops-bottom {
  height: 100%;
  width: 100%;
  position: absolute;
  left: 0;
  background: url(../img/neige.png) 0 0 no-repeat;
  background-size: 100% 100%;
  opacity: 1;
}





.girl {
  position: absolute;
  top: -40px;
  left: -23px; /* girl -20px -- pere_noel -23px*/
  width: 45px; /* girl 40px -- pere_noel  45px */
  height:80px;
  z-index: -2;
  transform: rotate(0);
  will-change: auto;
}

.girl__marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;
}


#girl {
  position: relative;
}

.girl svg {
  z-index: 20;
  position: relative;
  will-change: auto;
}
/* ---- */
/* Velo */
/* ---- */

.bike {
  position: absolute;
  top: -40px;
  left: -20px;
  width: 40px;
  height: 80px;
  z-index: -2;
  transform: rotate(0);
  will-change: auto;
}

.bike__marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;
}

#bm {
  position: relative;
}

.bike svg {
  z-index: 20;
  position: relative;
  will-change: auto;
}

.umbrella-animation {
  position: absolute;
  top: -12px;
  left: calc(50% + 2px);
  transform: translateX(-50%);
  width: 100%;
  z-index: 10;
}

.light {
  position: absolute;
  top: 18px;
  left: 30px;
  width: 0;
  z-index: 10;
  height: 10px;
  background: url(../img/light.png) 0 0 no-repeat;
  background-size: 22px 10px;
  transition: width 0s 0.3s, opacity 0.3s;
  transform-origin: center left;
  opacity: 0;
}

.light--active {
  width: 22px;
  transition: width 0.2s, opacity 0s;
  opacity: 0.6;
}

.bulle {
  position: absolute;
  top: -88px;
  left: -70px;
  width: 100px;
  z-index: 10;
  height: 100px;
  transition: width 0s 0.3s, opacity 0.3s;
  transform-origin: center left;
  opacity: 0;
}

.bulle--active {
  width: 100px;
  transition: width 0.2s, opacity 0s;
  opacity: 1;
}


.tower {
  width: 70px;
  position: absolute;
  top: 155px;
  left: -56px;
  transform: rotate(-111deg);
  z-index: -3;
  fill: #373b37;
}

.pise {
  width: 45px;
  position: absolute;
  top: -23px;
  left: 32px;
  transform: rotate(-29deg);
  z-index: -3;
  fill: #373b37;
}

.liberte{
  width: 45px;
  position: absolute;
  top: 120px;
  left: 238px;
  transform: rotate(90deg);
  z-index: -3;
  fill: #373b37;
}

/* ------- */
/* Scenery */
/* ------- */

.tree-01 {
  width: 40px;
  position: absolute;
  top: 5px;
  left: -5px;
  transform: rotate(-41deg);
  z-index: -3;
  fill: #1f6219;
}

.tree-02 {
  width: 30px;
  position: absolute;
  top: 6px;
  left: 16px;
  transform: rotate(-41deg);
  z-index: -1;
  fill: #1a5215;
}

.tree-03 {
  width: 40px;
  position: absolute;
  top: 225px;
  left: 75px;
  transform: rotate(-161deg);
  z-index: -3;
  fill: #1f6219;
}

.tree-04 {
  width: 30px;
  position: absolute;
  top: 225px;
  left: 98px;
  transform: rotate(-169deg);
  z-index: -1;
  fill: #1a5215;
}

.tree-05 {
  width: 30px;
  position: absolute;
  top: 24px;
  left: 225px;
  transform: rotate(-304deg);
  z-index: -1;
  fill: #1a5215;
}

.mountain-1 {
  fill: #97b45c;
  position: absolute;
  top: -18px;
  left: 80px;
  transform: rotate(40deg);
  width: 60px;
  z-index: -5;
}

.mountain-2 {
  fill: #97b45c;
  position: absolute;
  top: -5px;
  left: 119px;
  transform: rotate(56deg);
  width: 60px;
  z-index: -5;
}

.mountain-4 {
  fill: #97b45c;
position: absolute;
top: 156px;
left: 182px;
transform: rotate(77deg);
width: 60px;
z-index: -5;
}

.mountain-5 {
  fill: #97b45c;
  position: absolute;
  top: 180px;
  left: 159px;
  transform: rotate(10deg);
  width: 60px;
  z-index: -5;
}

.rock-1 {
  position: absolute;
top: 127px;
left: -8px;
width: 20px;
transform: rotate(-90deg);
z-index: -1;
fill: #6a6a6a;
}

.rock-2 {
  position: absolute;
  top: 199px;
  left: 198px;
  width: 20px;
  transform: rotate(-206deg);
  z-index: -1;
  fill: #6a6a6a;
}

.rotating-fog {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  fill: #fff;
  opacity: 0.05;
  width: 92%;
  height: 92%;
  animation: spin;
  animation-duration: 40s;
  animation-timing-function: linear;
  animation-iteration-count: infinite;
  z-index: -10;
}

@keyframes spin {
  0% {transform: translate(-50%, -50%) rotate(360deg);}
  100% {transform: translate(-50%, -50%) rotate(0deg);}
}

.grass-1 {
  position: absolute;
  top: 100px;
  left: -4px;
  transform: rotate(-86deg);
  width: 10px;
  height: 20px;
  fill: #4d3034;
  z-index: -10;
}

.grass-2 {
  position: absolute;
  top: 209px;
  left: 46px;
  transform: rotate(-156deg);
  width: 10px;
  height: 20px;
  fill: #4d3034;
  z-index: -10;
}

.grass-3 {
  position: absolute;
  top: 109px;
  left: 235px;
  transform: rotate(-266deg);
  width: 10px;
  height: 20px;
  fill: #4d3034;
  z-index: -10;
}

.cop{
 position: absolute;	
 bottom:0;
 left: 0;
 font-family: 'Source Sans Pro', sans-serif;
 color:#ffffff;
 font-size: 14px;
 padding: 10px 10px 10px 20px;
}


/* ------------ */
/* Instructions */
/* ------------ */

.instructions {
  position: absolute;
  top: 0;
  left: 0;
  padding: 20px;
  z-index:51;
}

.instructions__new {
  font-family: 'Source Sans Pro', sans-serif;
  color: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  padding: 4px 10px;
  display: inline-block;
  margin-top: 10px;
  font-size: 14px;
  width: 290px;
  color: #fff;
  white-space: pre-wrap;
}

.instructions__item {
  font-family: 'Source Sans Pro', sans-serif;
  color: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  padding: 4px 10px;
  display: inline-block;
  margin-top: 10px;
  font-size: 14px;
  width: 290px;
  color: #fff;

}

.instructions__item:first-child {
  margin-top: 0;
}
#new_item{

  font-family: 'Source Sans Pro', sans-serif;
  color: rgba(0, 0, 0, 0.3);
  border: 1px solid rgba(0, 0, 0, 0.2);
  border-radius: 3px;
  padding: 4px 10px;
  display: none;
  margin-top: 10px;
  font-size: 14px;
  width: 290px;
  color: #fff;
}
.noel {
	 background-size: auto 100%;
position:absolute;
z-index:1000;
	
}

.bird {
	 background-image: url(../img/bird.svg);
	 background-size: auto 100%;
	 width: 88px;
	 height: 125px;
	 will-change: background-position;
	 animation-name: fly-cycle;
	 animation-timing-function: steps(10);
	 animation-iteration-count: infinite;
	 z-index: 2;
}
 .bird--one {
	 animation-duration: 1s;
	 animation-delay: -0.5s;
}
 .bird--two {
	 animation-duration: 0.9s;
	 animation-delay: -0.75s;
}
 .bird--three {
	 animation-duration: 1.25s;
	 animation-delay: -0.25s;
}
 .bird--four {
	 animation-duration: 1.1s;
	 animation-delay: -0.5s;
}
 .bird--six {
	 animation-duration: 1.3s;
	 animation-delay: -0.45s;
}

 .bird-container {
	 position: absolute;
	 top: 17%;
	 left: -10%;
	 transform: scale(0) translateX(-10vw);
	 will-change: transform;
	 animation-name: fly-right-one;
	 animation-timing-function: linear;
	 animation-iteration-count: infinite;
	 z-index: 52;
}
 .bird-container--one {
	 animation-duration: 15s;
	 animation-delay: 0;
}
 .bird-container--two {
	 animation-duration: 16s;
	 animation-delay: 1s;
}
 .bird-container--three {
	 animation-duration: 14.6s;
	 animation-delay: 9.5s;
}
 .bird-container--four {
	 animation-duration: 16s;
	 animation-delay: 10.25s;
}
 .bird-container--six {
	 animation-duration: 13s;
	 animation-delay: 19.25s;
}

 @keyframes fly-cycle {
	 100% {
		 background-position: -900px 0;
	}
}
 @keyframes fly-right-one {
	 0% {
		 transform: scale(0.3) translateX(-10vw);
	}
	 10% {
		 transform: translateY(2vh) translateX(10vw) scale(0.4);
	}
	 20% {
		 transform: translateY(0vh) translateX(30vw) scale(0.5);
	}
	 30% {
		 transform: translateY(4vh) translateX(50vw) scale(0.6);
	}
	 40% {
		 transform: translateY(2vh) translateX(70vw) scale(0.6);
	}
	 50% {
		 transform: translateY(0vh) translateX(90vw) scale(0.6);
	}
	 60% {
		 transform: translateY(0vh) translateX(110vw) scale(0.6);
	}
	 100% {
		 transform: translateY(0vh) translateX(110vw) scale(0.6);
	}
}
 @keyframes fly-right-two {
	 0% {
		 transform: translateY(-2vh) translateX(-10vw) scale(0.5);
	}
	 10% {
		 transform: translateY(0vh) translateX(10vw) scale(0.4);
	}
	 20% {
		 transform: translateY(-4vh) translateX(30vw) scale(0.6);
	}
	 30% {
		 transform: translateY(1vh) translateX(50vw) scale(0.45);
	}
	 40% {
		 transform: translateY(-2.5vh) translateX(70vw) scale(0.5);
	}
	 50% {
		 transform: translateY(0vh) translateX(90vw) scale(0.45);
	}
	 51% {
		 transform: translateY(0vh) translateX(110vw) scale(0.45);
	}
	 100% {
		 transform: translateY(0vh) translateX(110vw) scale(0.45);
	}
}

#loading {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100;
  width: 100vw;
  height: 100vh;
  background-image: url("../img/4532.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: 400px;
}

#pages   { 
visibility: hidden;}

.unsupported-browser {
    display: none;
    position: fixed;
    z-index: 99999;
    top: 16px;
    left: 16px;
    right: 16px;
    background: #cf6a87;
    color: #ffffff;
    padding: 24px 16px;
    text-align: center;
    border-radius: 3px;
    box-shadow: 0 0 48px rgba(0, 0, 0, 0.25);
}
.image-container {
  position: absolute;
  top: 39px;
  z-index:-2;
  left: -39px

}
.image-container img {
            width: 146px;  
            height: auto;  
            display: block;

}	
 .message {
      font-size: 14px;
      line-height: 1.5;
      white-space: pre-wrap;
    }

    .word {
      display: inline-block;
      white-space: nowrap; /* Ne pas couper les mots */
    }

    .letter {
      display: inline-block;
      opacity: 0;
      transform: translateY(20px);
      font-size: 14px;
    }		
	
	    .bold {
      font-weight: bold;
    }
	
	input, textarea {
  width: 100%;
  padding: 0.45rem;
  margin-bottom: 1rem;
  border: 1px solid #ccc;
  border-radius: 5px;
}

button {
  background: #007BFF;
  color: white;
  padding: 0.45rem 2rem;
  border: none;
  border-radius: 5px;
  cursor: pointer;
}
.avion_ligne {
  width: 115px;
  position: absolute;
  bottom: 10px;
  left: -110px;
  font-size: 40px;
  z-index: 50;
}
.avion {
  position: absolute;
  bottom: -250px;
  left: -1000px; /* girl -20px -- pere_noel -23px*/
  width: 115px; /* girl 40px -- pere_noel  45px */
  height:80px;
  z-index: -4;
  transform: rotate(0);
  will-change: auto;
}

.avion__marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;
}


#avion {
  position: relative;
}

.avion svg {
  z-index: 30;
  position: relative;
  will-change: auto;
}
.pecheur {
  position: absolute;
  top: -78px;
  z-index: 2;
  left: -80px;
  width: 200px;
}

.sun{
  position: absolute;
  top: -140px;
  left: -131px; /* girl -20px -- pere_noel -23px*/
  width: 256px; /* girl 40px -- pere_noel  45px */
  height:256px;
  z-index: -6;
  transform: rotate(0) translateX(0) translateY(0);
  will-change: auto;
  opacity: 0;
}

.sun__marker {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 1px;
  height: 1px;



