/*---------CLASS_POUR_ELEMENT_TOUTE_PAGE---------*/
body {
	margin: 0;
	background-color: black;
	font-family: Helvetica, sans-serif;
}
.btn_princp {
	background-color: rgb(255, 255, 255);
	padding: 20px;

	border-radius: 40px;
	margin-right: 20px;
	border: 1px solid white;
}

.btn_princp:hover {
	background-color: transparent;
	transition: 0.5s;
	border: 1px solid rgb(255, 255, 255);
}

.btn_princp:hover a {
	color: white;
}

.btn_princp a {
	font-size: 18px;
	text-decoration: none;
	color: black;
}

.btn_sec {
	background-color: transparent;
	padding: 20px;
	border: 1px solid white;
	border-radius: 40px;
}
.btn_sec a {
	font-size: 16px;
	text-decoration: none;
	color: rgb(255, 255, 255);
}
/*---------------------------------------------ACCEUIL---------------------------------------------------------------------*/
/*-----HEADER-----*/

header {
	position: sticky;
	background-color: black;
	z-index: 300;
	top: 0;
	display: flex;
	justify-content: space-between;
	width: 100%;
	border: 1px solid white;
}

header img {
	width: 190px;
}

header a {
	text-decoration: none;
}

#menu-btn {
	visibility: hidden;
}

.menu-icon {
	visibility: hidden;
}
.menu {
	display: flex;
	gap: 30px;
	align-items: center;
	max-width: 250px;
	margin-right: 32px;
}
.menu a {
	color: white;
}

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

.footer {
	background-color: transparent;
	display: flex;
	align-items: center;
	justify-content: center;
	gap: 80px;

	padding: 20px;
	border-top: 1px solid white;
}

.footer_logo img {
	width: 90px;
}

.footer_logo {
	display: flex;
	align-items: center;
	justify-content: start;
	gap: 20px;
}

.left_foot {
	display: flex;
	flex-direction: column;

	gap: 10px;
}

.socials {
	display: flex;
	gap: 50px;
}
.socials img {
	width: 30px;
}

.list_grid {
	padding: 0px;
	display: grid;
	grid-template-columns: repeat(6, 1fr);
	grid-template-rows: repeat(3);
	gap: 30px;
}

.list_grid li {
	list-style: none;
}

.list_grid li a {
	text-decoration: none;
	color: white;
}

/*-----MAIN------*/

/*-------SECTION_UN-------*/

.section_un {
	background-image: url(../img/fond_home.jpg);
	background-size: cover;
	padding-top: 100px;
	padding-bottom: 300px;
}

.section_un h1 {
	color: white;
	font-size: 32px;
	margin-bottom: 20px;
	margin-left: 40px;
	animation: slideUp 1s ease-out forwards;
}

.section_un p {
	color: white;
	text-align: start;
	font-size: 18px;
	margin-left: 40px;
	animation: slideUp 1s ease-out forwards;
}
.button_landing {
	display: flex;
	margin-left: 40px;
	gap: 10px;
	margin-top: 20px;
	animation: slideUp 1s ease-out forwards;
}

#landing_text_bg {
	backdrop-filter: blur(30px);
	border-radius: 20px;
	display: inline-block;
	margin-left: 20px;
	padding: 15px;
	animation: slideUp 1s ease-out forwards;
}

@keyframes slideUp {
	0% {
		opacity: 0;
		transform: translateY(50px);
	}
	100% {
		opacity: 1;
		transform: translateY(0);
	}
}

/*--------SECTION_DEUX--------*/

.section_deux {
	margin: 40px;
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	grid-template-rows: repeat(2, 300px);
	gap: 20px;
}

.section_deux article {
	border: 1px solid white;
	border-radius: 20px;
	animation: appear linear;
	animation-timeline: view();
	animation-range: entry 0%;
}

@keyframes appear {
	from {
		opacity: 0;
		scale: 0.5;
	}
	to {
		opacity: 1;
		scale: 1;
	}
}

.section_deux .un {
	grid-column: 1/3;
	text-align: center;
}
.section_deux .un h1 {
	font-size: 32px;
	color: white;
}
.section_deux .un p {
	font-size: 18px;
	color: white;
	text-align: justify;
	border-top: 1px solid white;
	padding: 40px;
}

.section_deux .deux {
	grid-column: 3/4;
	grid-row: 1/3;
	text-align: center;
}

.section_deux .deux h1 {
	font-size: 32px;
	color: white;
	padding-bottom: 30px;
	border-bottom: 1px solid white;
}

.section_deux .deux p {
	margin: 30px;
	font-size: 18px;
	color: white;
	text-align: left;
}

.section_deux .deux ul li {
	margin-left: 30px;
	font-size: 18px;
	color: white;
	text-align: left;
	list-style: none;
}
#lieu::before {
	content: url(../img/map.svg);
	margin-right: 15px;
}

#date::before {
	content: url(../img/date.svg);
	margin-right: 15px;
}
#info_pratique::before {
	content: url(../img/info.svg);
	margin-right: 15px;
}

.section_deux .deux ul {
	padding: 0px;
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.section_deux .trois {
	grid-column: 4/5;
	grid-row: 1/3;
	text-align: center;
}

.section_deux .trois h1 {
	display: block;
	font-size: 32px;
	color: white;
	margin-bottom: 55px;
	padding-bottom: 30px;
	border-bottom: 1px solid white;
}

.section_deux .trois ul {
	display: flex;
	flex-direction: column;
	gap: 50px;
	padding: 0px;
}

.section_deux .trois ul li img:hover {
	transform: rotate(360deg);
	transition: 0.5s;
}

.section_deux .quatre {
	grid-column: 1/3;
	text-align: center;
}

.section_deux .quatre h1 {
	font-size: 32px;
	color: white;
}

.section_deux .quatre p {
	font-size: 18px;
	color: white;
	text-align: justify;
	border-top: 1px solid white;
	padding: 40px;
}

@media (max-width: 867px) {
	/*-----HEADER-----*/
	header img {
		width: 150px;
	}

	/*-----MAIN------*/

	/*-------SECTION_UN-------*/

	.section_un {
		background-image: url(../img/fond_home.jpg);
		background-size: cover;
		background-position: 100%;
		padding-top: 100px;
		padding-bottom: 150px;
		display: flex;
		justify-content: center;
	}

	.section_un h1 {
		color: white;
		font-size: 32px;
		margin-bottom: 20px;
		margin-left: 40px;
	}

	.section_un p {
		color: white;
		text-align: start;
		font-size: 18px;
		margin-left: 40px;
	}
	.button_landing {
		display: flex;
		margin-left: 40px;
		gap: 10px;
		margin-top: 20px;
	}

	.button_princp {
		background-color: white;
		margin-bottom: 20px;
		padding: 20px;
		border: none;
		border-radius: 40px;
	}

	.btn_princp a {
		font-size: 16px;
		color: black;
	}

	.btn_sec {
		background-color: transparent;
		padding: 20px;
		border: 1px solid white;
		border-radius: 40px;
	}
	.btn_sec a {
		font-size: 18px;
		color: rgb(255, 255, 255);
	}

	#landing_text_bg {
		margin-top: 300px;
		-webkit-backdrop-filter: blur(30px);
		border-radius: 20px;
		display: inline-block;
		margin-left: 0px;

		padding: 15px;
	}

	/*------SECTION_DEUX------*/
	.section_deux {
		margin: 40px;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(6 300px);
		gap: 20px;
	}

	.section_deux article {
		border: 1px solid white;
		border-radius: 20px;
	}

	.section_deux .un {
		grid-column: 1/3;
		text-align: center;
	}
	.section_deux .un h1 {
		font-size: 24px;
		color: white;
	}
	.section_deux .un p {
		font-size: 18px;
		color: white;
		text-align: justify;
		border-top: 1px solid white;
		padding: 40px;
	}

	.section_deux .deux {
		grid-column: 1/3;
		grid-row: 1/3;
		text-align: center;
	}

	.section_deux .deux h1 {
		font-size: 24px;
		color: white;
		padding-bottom: 30px;
		border-bottom: 1px solid white;
	}

	.section_deux .deux p {
		margin: 30px;
		font-size: 18px;
		color: white;
		text-align: left;
	}

	.section_deux .deux ul {
		margin-bottom: 30px;
		padding: 0px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 20px;
	}

	#list_un {
		margin-top: 100px;
	}
	.section_deux .deux ul li {
		margin-left: 30px;
		font-size: 18px;
		color: white;
		text-align: left;
		list-style: none;
	}

	.section_deux .trois {
		grid-column: 1/3;
		grid-row: 5/6;
		text-align: center;
	}

	.section_deux .img {
		width: 40px;
	}

	.section_deux .trois h1 {
		display: block;
		font-size: 24px;
		color: white;
		margin-bottom: 30px;
		padding-bottom: 30px;
		border-bottom: 1px solid white;
	}

	.section_deux .trois ul {
		display: flex;
		flex-direction: column;
		gap: 50px;
		padding: 0px;
	}

	.section_deux .quatre {
		grid-column: 1/3;
		text-align: center;
	}

	.section_deux .quatre h1 {
		font-size: 24px;
		color: white;
	}

	.section_deux .quatre p {
		font-size: 18px;
		color: white;
		text-align: justify;
		border-top: 1px solid white;
		padding: 40px;
	}

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

	.footer {
		background-color: transparent;
		display: flex;
		align-items: center;
		justify-content: center;
		gap: 50px;

		padding: 20px;
		border-top: 1px solid white;
	}

	.footer_logo img {
		width: 90px;
	}

	.footer_logo {
		display: flex;
		align-items: center;
		justify-content: start;
		gap: 20px;
	}

	.socials {
		display: flex;
		gap: 50px;
	}
	.socials img {
		width: 25px;
	}

	.left_foot {
		display: flex;
		flex-direction: column;
		margin-bottom: 20px;
		gap: 20px;
	}
	.list_grid {
		padding: 0px;
		display: grid;
		grid-template-columns: repeat(5, 1fr);
		grid-template-rows: repeat(4);
		gap: 30px;
	}

	.list_grid li {
		list-style: none;
	}

	.list_grid li a {
		text-decoration: none;
		color: white;
	}
}

@media (max-width: 452px) {
	header {
		display: grid;
		grid-template-areas:
			"title   title   hamburger"
			"nav     nav     nav";
	}
	header img {
		width: 150px;
	}

	.menu a {
		text-decoration: none;
		color: black;
	}
	.menu-btn {
		display: none;
	}
	.menu-icon {
		grid-area: hamburger;
		cursor: pointer;
		display: flex;
		justify-content: flex-end;
		align-items: baseline;
		padding: 30px 20px 30px 0;
		position: relative;
		user-select: none;
		visibility: visible;
	}
	.navicon {
		background: #ffffff;
		display: block;
		height: 2px;
		width: 18px;
		position: relative;
	}
	.navicon:before {
		top: 5px;
	}
	.navicon:after {
		top: -5px;
	}
	.navicon:before,
	.navicon:after {
		background: #ffffff;
		display: block;
		width: 100%;
		height: 100%;
		content: "";
		position: absolute;
		transition: all 0.2s ease-out;
	}
	.menu {
		grid-area: nav;
		max-width: unset;
		max-height: 0;
		transition: max-height 0.2s ease-out;
		overflow: hidden;
		margin: 0;
		padding: 0;
		background-color: #000000;
		display: flex;
		flex-direction: column;
	}
	.menu a {
		padding: 20px 20px;
		border: 1px solid white;
		color: white;
		background-color: #000000;
		width: 100%;
		text-align: center;
	}
	.menu-btn:checked ~ .menu {
		max-height: 240px;
	}
	.menu-btn:checked ~ .menu-icon .navicon {
		background: transparent;
	}
	.menu-btn:checked ~ .menu-icon .navicon:before {
		transform: rotate(-45deg);
	}
	.menu-btn:checked ~ .menu-icon .navicon:after {
		transform: rotate(45deg);
	}
	.menu-btn:checked ~ .menu-icon .navicon:before,
	.menu-btn:checked ~ .menu-icon .navicon:after {
		top: 0;
	}

	/*-----MAIN------*/

	/*-------SECTION_UN-------*/

	.section_un {
		background-image: url(../img/fond_home.jpg);
		background-size: cover;
		background-position: 90%;
		padding-top: 100px;
		padding-bottom: 150px;
		display: flex;
		justify-content: center;
	}

	.section_un h1 {
		color: white;
		text-align: center;
		font-size: 32px;
		margin-bottom: 20px;
		margin-left: 0px;
	}

	.section_un p {
		color: white;
		text-align: center;
		font-size: 16px;
		margin-left: 0px;
	}
	.button_landing {
		display: flex;
		align-items: center;
		margin: 0px;
		gap: 10px;
		margin-top: 20px;
	}

	.btn_sec {
		background-color: transparent;
		padding: 15px;
		border: 1px solid white;
		border-radius: 40px;
	}
	.btn_sec a {
		font-size: 16px;
		color: rgb(255, 255, 255);
	}

	#landing_text_bg {
		display: flex;
		flex-direction: column;
		align-items: center;
		margin-top: 300px;
		-webkit-backdrop-filter: blur(30px);
		border-radius: 20px;
		margin-left: 0px;
		padding: 15px;
	}

	/*------SECTION_DEUX------*/
	.section_deux {
		margin: 40px;
		display: grid;
		grid-template-columns: repeat(2, 1fr);
		grid-template-rows: repeat(6 300px);
		gap: 20px;
	}

	.section_deux article {
		border: 1px solid white;
		border-radius: 20px;
	}

	.section_deux .un {
		grid-column: 1/3;
		text-align: center;
	}
	.section_deux .un h1 {
		font-size: 24px;
		color: white;
	}
	.section_deux .un p {
		font-size: 16px;
		color: white;
		text-align: justify;
		border-top: 1px solid white;
		padding: 40px;
	}

	.section_deux .deux {
		grid-column: 1/3;
		grid-row: 1/3;
		text-align: center;
	}

	.section_deux .deux h1 {
		font-size: 24px;
		color: white;
		padding-bottom: 30px;
		border-bottom: 1px solid white;
	}

	.section_deux .deux p {
		margin: 30px;
		font-size: 18px;
		color: white;
		text-align: left;
	}

	.section_deux .deux ul {
		margin-bottom: 30px;
		padding: 0px;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 20px;
	}

	#list_un {
		margin-top: 100px;
	}
	.section_deux .deux ul li {
		margin-left: 30px;
		font-size: 16px;
		color: white;
		text-align: left;
		list-style: none;
	}

	.section_deux .trois {
		grid-column: 1/3;
		grid-row: 5/6;
		text-align: center;
	}

	.section_deux .img {
		width: 40px;
	}

	.section_deux .trois h1 {
		display: block;
		font-size: 24px;
		color: white;
		margin-bottom: 30px;
		padding-bottom: 30px;
		border-bottom: 1px solid white;
	}

	.section_deux .trois ul {
		display: flex;
		flex-direction: column;
		gap: 50px;
		padding: 0px;
	}

	.section_deux .quatre {
		grid-column: 1/3;
		text-align: center;
	}

	.section_deux .quatre h1 {
		font-size: 24px;
		color: white;
	}

	.section_deux .quatre p {
		font-size: 16px;
		color: white;
		text-align: justify;
		border-top: 1px solid white;
		padding: 40px;
	}

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

	.footer {
		background-color: transparent;
		display: flex;
		flex-direction: column;
		align-items: center;
		justify-content: center;
		gap: 50px;
		padding: 20px;
		border-top: 1px solid white;
	}

	.footer_logo img {
		width: 90px;
	}

	.footer_logo {
		display: flex;
		align-items: center;
		justify-content: start;
		gap: 20px;
	}

	.socials {
		display: flex;
		gap: 50px;
	}
	.socials img {
		width: 25px;
	}

	.left_foot {
		display: flex;
		flex-direction: column;
		margin-bottom: 20px;
		gap: 20px;
	}
	.list_grid {
		padding: 0px;
		display: grid;
		grid-template-columns: repeat(3, 1fr);
		grid-template-rows: repeat(5);
		gap: 30px;
	}

	.list_grid li {
		list-style: none;
	}

	.list_grid li a {
		text-decoration: none;
		color: white;
	}
}
