html, body, h2, h3, p, button, input, select, textarea {
	font-family: "Open Sans", sans-serif !important
}


.pb { font-size:12px !important; color:#ffffff; line-height:1.2; margin:1rem 0 }


.merci h2 {
	padding: 3rem;
}

body {
	background: #ffffff;
	min-height: 100vh;
	display: flex;
	justify-content: center;
	align-items: center;
	background-image: url(images/LPdesktop-all.jpg);
	background-size: cover;
	background-position: bottom center;
	background-repeat: no-repeat;
	padding: 0;
	margin: 0;
}

.container {
	z-index: 11;
}


.global {
	background-image: url(images/front-all.png);
	background-size: cover;
	background-position: bottom center;
	background-repeat: no-repeat;
	top: 0;
	left: 0;
	padding: 0;
	margin: 0;
	width: 100%;
	min-height: 100%;
	position: absolute;
	z-index: 1;
	/* filter: grayscale(0) brightness(0.2) blur(1); */



	/* filter: brightness(0) saturate(100%) invert(49%) sepia(100%) saturate(7410%) hue-rotate(353deg) brightness(99%) contrast(98%);
           */
	/* filter: brightness(0) saturate(100%) invert(21%) sepia(61%) saturate(332%) hue-rotate(12deg) brightness(106%) contrast(88%); */

	opacity: 1;
	animation: gradientMove__ 2s ease-in forwards;

}
.___f {


color:#000000;padding: 0; margin: 0;margin-bottom: 0px; text-align: left;line-height: 1.2;

}


 #anim_1 {
     filter: drop-shadow(50px 400px 40px rgba(210,9,30,1));
     /* padding: 0 5rem; */

}

#anim_2 {
     filter: drop-shadow(200px 200px 40px rgba(210,9,30,1));
	  opacity:0;
     /* padding: 0 5rem; */
}

 #anim_3 { opacity:0; }

 #anim_1 { width:100%; opacity:0; }

/* form { padding: 0 5rem 0 0;} */




.letter {
	display: inline-block;
	opacity: 0;
}

/* span spécial pour les espaces */
.space {
	display: inline-block;
	width: 0.3em;
	/* largeur d'un espace */
}





.bordure {
	border: 0 solid #ffffff;
    animation: borderGrow 1s forwards ease-in 1.7s;
	box-sizing: border-box;
	width: 100%;
	min-height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	z-index: 10;
}

@keyframes borderGrow {
    from { border-width: 0; border-color: #d2091e;}
    to   { border-width: 20px; border-color: white; }
}








.light-effect {

	z-index: 1;
	--x: 100%;
	--y: 20%;
	--alpha: 0.85;

	opacity: 1;
	position: absolute;
	bottom: 0;
	right: 0;
	width: 100%;
	min-height: 100%;
	background: radial-gradient(circle at var(--x) var(--y), rgba(21, 3, 3, var(--alpha)) 0%, rgb(0, 0, 0) 100%);
	/* mix-blend-mode: hard-light; */
	/* filter: brightness(1); */
	animation: gradientMove 2s ease-in forwards;

	/* border: 20px solid #ffffff; */
	box-sizing: border-box;

}

.light-effect-2 {
	/* position: absolute;*/
	bottom: 0;
	right: 0;
	width: 100%;
	min-height: 100vh;
	box-sizing: border-box;
	position: relative;
	height: 100%;
    overflow: hidden;
}


@keyframes gradientMove {
	0% {
		opacity: 1;
	}

	100% {
		opacity: 0;
	}
}

@keyframes gradientMove__ {
	0% {
		opacity: 1;
	}

	100% {
		opacity: 0;
	}
}

.form-control {
    background-color: rgba(255,255,255,1);
	  border-radius: 0;
	  border-color: #ffffff;
}


input[type=text]:focus, input[type=file]:focus, textarea:focus, select:focus {
box-shadow: 0 0 0 #000 !important;
  border-color: #fff !important;
  transition: all 0.3s ease-in-out;
}

.form-floating>label, .form-floating>.form-control:focus~label {
   font-weight: bold;
   color:#000000 !important
}

.btn {
    height: 58px;
       background-color: #d2091e;
        border: #d2091e;
		font-weight: bold;
		text-transform: uppercase;
		border-radius: 0;
		  /* box-shadow: 0px 4px 15px #918a8a; */
}

.btn:hover {
    height: 58px;
       color: #d2091e;
	   background-color: #ffffff;


}



.titreh2 {
   background-color: #d2091e;
   padding:0.5rem;
}


h2 {
	font-size: 50px;
    text-align: center;
    line-height: 1.15;
	border:1px solid #ffffff;
	padding: 0 2rem 0.6rem 2rem;
	color: #ffffff;
	text-transform: uppercase;
	font-weight: 400;
	display: block;
	overflow: hidden;
    margin: 0;
}

h2 span {
	font-size: 32px;
}


.v_reglement {
color: #fff;
  font-weight: bold;

  padding: 1rem 0;
}

.v_reglement:hover {

  color:rgb(210, 9, 30);

}


h3 {
	text-transform: uppercase;
  font-weight: 400;
  background-color: #d2091e;
  font-size: 24px !important;
  line-height: 1.15;
  border: 20px solid #ffffff;
  transform: rotate(4deg);
  width: 100%;
}

h3 .date {
   font-size: 16px;
  background-color: #000000;
  padding: 0.2rem 0.6rem;
  font-weight: bold;
  margin: 0.5rem 0 0 0;
  display: block;
}

sup { font-size: 16px;}

.date sup {
	font-size: 10px;
}



.content {
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 2rem;
	margin: 0 0 2rem;
}


.container {
    padding:2rem 0 8rem 0;
     
     margin:0;
}

/* FORM */

.invalid-feedback {
    margin-top: .45rem;
    color: #ffffff;
    background-color: #000000;
    padding: 0.2rem 0.5rem;
	font-size: 13px;

}

.was-validated :invalid ~ .invalid-feedback {
	display: inline-block;
	width: auto;
}





.container, .content {
	position: relative;
	z-index: 11;
   
}

.form-floating>label {
	left: inherit !important
}

.reve {
	max-width: 340px;
	height: auto;
	width: 100%;
}

.conn_ {
	min-height: 100vh;
}



.logo-container {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 12;
	padding: 3rem
}

.passeport_ .passeport_content {
	background-color: #ffffff;
	min-height: calc(3.5rem + calc(var(--bs-border-width) * 2));
	display: flex;
	align-items: start;
	flex-direction: column;
	padding: 0.2rem 0.6rem;
}

.passeport_ p { 
font-weight: bold;
  font-size: 16px;
  transform: scale(.85);
  transform-origin: left;
}

.passeport_ .form-check {
			display: flex;
  align-content: center;
  align-items: center;
  gap: 0.2rem;

}

.passeport_ label { font-size:14px;   cursor: pointer;}

.form-check-input:checked {
  background-color: rgba(210, 9, 30, 0.5);
  border-color: #d2091e;
}
.form-check-input {
	border: 1px solid #000000;   cursor: pointer;
	width: 14px;
  height: 14px;

}
.form-check-input:focus {

  outline: 0;
  box-shadow: none;
}


.offre_ {
	font-size:12px; color:#ffffff; width:80%; line-height: 1.2;
	text-align: justify; width:70%; margin:1rem 0 0 0
}

.offre_ a { color:#ffffff;}
.offre_ a:hover { color:rgb(210, 9, 30);}

.off_des { display:block; }

.off_mob { display:none; }

@media (min-width: 1200px) {
	.container {
		max-width: 1040px !important;
		width: 96%;
	}

}


.etape_2 { display:none;}



    @media (max-width: 1200px) {


.reve {
  padding: 8rem 0 0 0;
}

.logo-container {
  left: 50%;
  transform: translate(-50%);
}
    }

 @media (max-width: 576px) {

	.off_des { display:none; }

	.off_mob { display:block; 
	
	width: 80%;
  margin: 0 auto;

}

.off_mob .v_reglement {
	margin:0 0 3rem;
	display: block;
}

.off_mob .offre_ { width:100%}


	.merci .titreh2 {
    width: 80%;
    margin: 0 auto;
	}

	.merci .img-right {
		display: block;
  width: fit-content;
  margin-left: auto;

	}

	#anim_2 {
		align-items: end;
	}



	#anim_2.hidden, #anim_1.hidden {
		display: none !important;
	}

	.conn_ {
		justify-content: start !important;
	}

	.etape_2 { 
		margin:3rem auto 5rem;
    background-color: #fff;
    color: #d2091e;
    padding: 0.5rem 2rem;
    text-transform: uppercase;
    display: inline-block;
    width: auto;
    text-decoration: none;
    font-size: 18px;
    font-weight: bold;
    box-shadow: 0px 4px 15px #918a8a;
	}

	.etape_2::after {
   content: "➪";              /* la flèche */
    margin-left: 0.5rem;       /* espace entre le texte et la flèche */
    font-size: 20px;
    display: inline-block;
}



	.container { padding:0; }
	 .content {
    
    gap: 0rem;
	  margin: 0rem;
	 }

	.logo-container {
		padding: 1.5rem;
		left: 0;
    transform: none;
	}

	.logo {
		width: 124px;
	}

	  .reve {
margin: 0 0 0 auto;
    width: 200px;
	padding: 1.5rem;
  }



 
 .titreh2 {
  width: 80%;
}


h2 {
	font-size:24px;
	padding: 0 1rem 0.6rem 1rem;
   
}

h2 span {
	font-size: 18px;
}

h3 {
	text-transform: uppercase;
  font-weight: 400;
  background-color: #d2091e;
  font-size: 18px !important;
  line-height: 1.15;
  border: 0.5rem solid #ffffff;
  transform: rotate(0);
  width: 90%;
}

#anim_3 { display: none;
}

#anim_3 form { width:80%; margin:2rem auto}

#anim_3 p { color: #fff;
  font-weight: bold;
  text-align: center;
  margin: 2rem 0 0;
  font-size: 18px;}

@keyframes borderGrow {
    from { border-width: 0; border-color: #d2091e;}
    to   { border-width: 0.5rem; border-color: white; }
}
	} 