/* Logo */
#cc_svg_logo {
	fill: #fff;
	width: 104px;
	margin-left: 10px;
	margin-right: 25px;
	height: 82px;
	-moz-transition: all 0.4s;
	-webkit-transition: all 0.4s;
	transition: all 0.4s;
}
#cc_text {
	fill: #fff;
}
#petales path {
	-moz-transition: all 0.5s ease;
	-webkit-transition: all 0.5s ease;
	transition: all 0.5s ease;
}
a.logo {
	display: flex;
	align-items: center;
	padding: 0;
	height: 100%;
	box-shadow: 23px 0px 0px -22px #7e043f;
	-moz-transition: all 0.4s;
	-webkit-transition: all 0.4s;
	transition: all 0.4s;
}
a.logo:hover {
	background-color: inherit;
	box-shadow: inherit;
}
a.logo:hover #cc_svg_logo {
	-moz-transform: scale(1.24);
	-webkit-transform: scale(1.24);
	transform: scale(1.24);
	-moz-transition: all 0.4s;
	-webkit-transition: all 0.4s;
	transition: all 0.4s;
}
a.logo:hover #petales path {
	animation-delay: calc(var(--order) * 220ms);
}
a.logo:hover #petale-1 {
	animation: fadeIn-1 0.5s ease forwards;
}
a.logo:hover #petale-2 {
	animation: fadeIn-2 0.5s ease forwards;
}
a.logo:hover #petale-3 {
	animation: fadeIn-3 0.5s ease forwards;
}
a.logo:hover #petale-4 {
	animation: fadeIn-4 0.5s ease forwards;
}
a.logo:hover #petale-5 {
	animation: fadeIn-5 0.5s ease forwards;
}
a.logo:hover #cc_text {
	animation: fadeIn-text 0.5s ease forwards;
	animation-delay: calc(var(--order) * 10ms);
}
@keyframes fadeOut-text {
	100% {
		fill: #fff;
   }
}
@keyframes fadeIn-text {
	100% {
		fill: #22363D;
   }
}
@keyframes fadeIn-1 {
	100% {
		fill: #7F6DC0;
   }
}
@keyframes fadeIn-2 {
	100% {
		fill: #05A885;
   }
}
@keyframes fadeIn-3 {
	100% {
		fill: #DB006A;
   }
}
@keyframes fadeIn-4 {
	100% {
		fill: #F4E42D;
   }
}
@keyframes fadeIn-5 {
	100% {
		fill: #A8E1F6;
   }
}
/*/
Logo*/
#nav ul li a#searchBtn {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 100%;
	padding-right: 0;
	padding-left: 0;
	z-index: 100;
	transition: 0.3s;
}
#nav ul li a#searchBtn:hover {
	background-color: var(--bg-color-header-activ);
}
#nav ul li a#searchBtn img {
	padding-bottom: 2px;
	padding-right: 2px;
}
#nav ul li .area-submenu{
	display:none;
	visibility:hidden;
}
#nav ul li.hover .area-submenu{
	display: inline;
	visibility: visible;
	position: absolute;
	z-index: 10;
	font-weight: normal;
	margin: 0;
	left: 24px;
	top: 82px;
	box-shadow: rgb(73 10 22 / 30%) 0px 5px 5px;
}
#nav ul li.hover ul{
	margin: 0;
	padding: 20px 0px 0 20px;
	border: 0;
	width: 976px;
	height: 128px;
	position: relative;
	background: #900448;
	line-height: 15px;
	font-size: 14px;
	font-family: var(--light-font);
	display: block;
}
#nav ul li.hover ul li {
	font-size: 13px;
	background: none;
	cursor: default;
	border-left: 1px solid #AD0054;
	height: 79px;
	margin-top: 10px;
	color: #FFFFFF;
	display:inline-block;
}
#nav ul li.hover ul li a {
	color: #FFFFFF;
	display: inline-block;
	font-size: 16px;
	height: 30px;
	overflow: hidden;
	text-decoration:none;
	font-family:var(--regular-font);
	padding-left: 40px;
	padding-right: 25px;
	margin:0;
	clear:both;
	padding-top:0;
}
#nav ul li.hover ul li a:hover{
	text-decoration:underline;
	color: #FFFFFF;
}
#nav ul li.hover ul li a {
	line-height: 20px;
}
/*nav fin*/

#loginBtn:hover {
	/* background-color: var(--bg-color-header-activ);
	color:#fff; */
	border: solid 5px var(--bg-color-header-activ);
}

.genericLoginBtn{
	color:var(--bg-color-header);
	font-size: 14px;
	font-family: var(--regular-font);
	border-radius: 35px;
    -moz-border-radius: 35px;
    -webkit-border-radius: 35px;
    height: 54px;
    width: 94px;
    background-color: #fff;
    margin-left: 5px;
	border: solid 5px var(--bg-color-header);
}

.genericLoginBtn:hover {
	
	border: solid 5px var(--bg-color-header-activ);
	cursor: pointer;
}

.loginInitials {
	font-size: 16px;
	font-family: var(--regular-font);
}

#loginSvg {
  color:var(--bg-color-header);
  width: 20px;
  height: 24px;
}

.centerContentMenuGap{
	gap: 8px;
}

.centerContentMenu{
	display: flex;
	align-items: center;
	justify-content: center;
}

.wrap-top {
	position:relative;
	display:block;
	background-color: var(--bg-color-header);
	z-index:2;
	min-width: 1044px;
}
.wrap-top-inner {
	position:relative;
   /*width:1044px;
	*/
	height:82px;
	margin:0 auto;
}
.wrap-top-inner-hp {
	height:188px;
}
.left-header {
	display: flex;
	float: left;
	height: 100%;
	align-items: center;
}
.right-header {
	float: left;
	display: flex;
	align-items: center;
	height: 100%;
	width: 23px;
}

/*nav*/
#nav {
	display:flex;
	justify-content: center;
	overflow: hidden;
}
#nav li h2 {
	font-size:16px;
}
#nav li h2 a {
	text-decoration:none;
	display:inline-block;
}

.mainMenuList {
	display: flex;
	justify-content: center;
	margin: 0 10px;
	padding: 0;
}
.mainMenuList li {
	list-style: none outside none;
}
.mainMenuList li a {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items:center;
	height: 100%;
	text-decoration: none;
	color:#fff;
	font-family:var(--light-font);
	cursor:pointer;
	transition: 0.3s;
}
.mainEntrie {
	font-size: 18px;
	padding-left: 28px;
	padding-right: 28px;
	margin:0;
}

.mainEntrie svg {
	color: #7e003c;
	margin-bottom: 8px;
	transition: 0.3s;
	display: none;
}

.mainEntrie.active svg,
.mainMenuList li:hover .mainEntrie svg {
	color: #60002e;
}

.mainMenuList li:hover .mainEntrie {
	background-color: #900448;
}
#nav ul li a.active {
	box-shadow: inset 0 -6px 0 #60002e;
}

.techMenuList{
	display:flex;
	margin: 0;
	padding: 0;
}



#nav ul li#navSearchContainer {
	display: flex;
	align-items: center;
	justify-content: flex-end;
}
#allSearchContainer {
	overflow: hidden;
	display: flex;
	justify-content: flex-end;
	border-radius: 35px;
	-moz-border-radius: 35px;
	-webkit-border-radius: 35px;
	-moz-transition: all 0.3s;
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
}
#searchBtnContainer {
	width: 44px;
	height: 44px;
	border-radius: 35px;
	-moz-border-radius: 35px;
	-webkit-border-radius: 35px;
	overflow: hidden;
	margin-right: 8px
}

.searchForm {
	display: flex;
	align-items:center;
	justify-content: space-between;
	position:absolute;
	top: 72px;
	border-radius: 35px;
	-moz-border-radius: 35px;
	-webkit-border-radius: 35px;
	padding: 4px;
	
	background-color: var(--bg-color-header-activ);
	width: 320px;
	
	z-index: 20;
	-moz-transition: all 0.5s;
	-webkit-transition: all 0.5s;
	transition: all 0.5s;
	box-shadow: rgb(0 0 0 / 20%) 0px 12px 11px 0px;
	
	opacity: 0;
}

#searchBtnForm {
	width: 44px;
	height: 44px;
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 35px;
	-moz-border-radius: 35px;
	-webkit-border-radius: 35px;
	background-color: #BB035C;
}

.navTechBtncolor{
	background-color: #BB035C;
}

.navCloseBtncolor{
	background-color: var(--bg-color-header-activ);
}

#searchBtnForm:hover{
	background-color: var(--bg-color-header);
}

#navSearchContainer .key-searched {
	line-height:40px;
	background:transparent;
	font-size:16px;
	color:#fff;
	float:left;
	border:0;
	font-family:var(--regular-font);
}

.searchCloseBtn {
	display: flex;
	width: 38px;
	height: 38px;
	align-items: center;
	justify-content: center;
	position: absolute;
	right: -13px;
	top: 22px;
	border-radius: 30px;
	-moz-border-radius: 30px;
	-webkit-border-radius: 30px;
	transition: visibility 0s, opacity 0.5s linear;
}
#searchCloseBtn:hover {
	background-color: #860041;
}
#searchCloseBtn img {
	width: 35px;
}
#searchInput::placeholder {
color: #c6c6c6;
}

#searchInput {
	margin-left: 15px;
	width: 250px;
}
.hidden {
	display: none;
}
.visuallyhidden {
	opacity: 0;
}

/* Animation à appliquer pour l'apparition */
.anim-appear {
	animation: fadeInDown 0.5s forwards;
}

/* Définition de l'animation keyframes */
@keyframes fadeInDown {
	from {
		opacity: 0;
		transform: translateY(-20px);
	}
	to {
		opacity: 1;
		transform: translateY(0);
	}
}

/* //MEGA BAN */

/*------ BURGER -------*/
.burger span:before, .burger span:after, .burger:after, .mobile-header * {
	-webkit-transition: all 0.3s;
	transition: all 0.3s;
	box-sizing: border-box;
}
.burger-check {
	display: none;
}
/* Sets the actionable area for the burger including a label for usability */
.burger {
	position: relative;
	float: right;
	margin-right: 10px;
	margin-bottom: 0;
	width: 60px;
	height: 60px;
	cursor: pointer;
}
.burger:after {
	content: 'Menu';
	color: #fff;
	position: absolute;
	bottom: 7px;
	left: 0px;
	width: 100%;
	text-align: center;
	font-size: 13px;
}
/* Creates the look of the burger icon using the inner span and pseudo-elements*/
.burger span, .burger span:before, .burger span:after {
	position: absolute;
    left: 15px;
    top: 23px;
    width: 30px;
    height: 2px;
    background: #fff;
    border-radius: 0.2em;
}
/* Reset the left and create the pseudo-element */
.burger span:before, .burger span:after {
	content: '';
	left: 0;
}
/* Top bar position */
.burger span:before {
	top: -8px;
}
/* Bottom bar position */
.burger span:after {
	top: 8px;
}
/* Get rid of more on action (IE9 or higher) */
.burger-check:checked + .burger:after {
	content: '';
}
/* Get rid of the middle bar on action (IE9 or higher) */
.burger-check:checked + .burger span {
	height: 0;
	width: 0;
}
/* Moves the top and bottom bars to the middle on action (IE9 or higher) */
.burger-check:checked + .burger span:before, .burger-check:checked + .burger span:after {
	top: 6px;
}
/* Rotates the top bar on action with full browser support (IE9 or higher) */
.burger-check:checked + .burger span:before {
	-webkit-transform: rotate(225deg);
	-ms-transform: rotate(225deg);
	transform: rotate(225deg);
}
/* Rotates the bottom bar on action with full browser support (IE9 or higher) */
.burger-check:checked + .burger span:after {
	-webkit-transform: rotate(-225deg);
	-ms-transform: rotate(225deg);
	transform: rotate(-225deg);
}
/* Simple reveal (IE9 or higher) */
span.boo {
	width: auto;
	margin-top: 0;
	line-height: 60px;
	height: 0;
	overflow: hidden;
}
/* Reveals Boo! (IE9 or higher) */
#main-nav-test:checked ~ .boo {
	height: 50px;
}
/* Simple mobile menu opening and closing (IE9 or higher) */
.mobile-header {
	display: none;
	position: relative;
	width: 100%;
	margin: 0;
	min-height: 50px;
	background: #AD0054;
	overflow: hidden;
	z-index: 2;
}
.mobile-header ul {
	position: relative;
	float: left;
	width: 100%;
	list-style: none;
	margin: 0;
	padding: 0;
	background-color: #DB006A;
}
.mobile-header ul li a, .mobile-header ul li form {
	position: relative;
	float: left;
	width: 100%;
	height: 0;
	line-height: 50px;
	padding: 0 15px;
	text-decoration: none;
	overflow: hidden;
	color: #fff;
	text-align: left;
	font-size: 22px;
}
.mobile-header ul a:hover, .mobile-header ul a:active, .mobile-header ul a:focus, .mobile-header ul a:visited {
	background: #AD0054;
}
/* Animate height of 'a' element in order to reveal the menu on check (IE9 or higher) */
#main-nav:checked ~ ul a {
	height: 50px;
}
#main-nav:checked ~ ul form {
	height: 80px;
	background-color: #AD0054;
}
.mobile-logo {
	position: relative;
	display: inline-block;
	width: 104px;
	height: 50px;
	margin-top: 10px;
	margin-left: 10px;
}
.mobile-logo img {
	width: 100%;
}


/*------------
User btn
-------------*/
.loginBtnContent {
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-direction: column;
	width: 100%;
	height: 100%;
	padding-bottom: 7px;
    padding-top: 12px;
}


.mobile-loginBtn {
	display: inline-block;
	/* display: none; */
    position: absolute;
    height: 60px;
    right: 90px;
    width: 80px;
    font-size: 13px;
    text-decoration: none;
    color: white;
    font-family: var(--regular-font);
}
/*------------ Search form -------------*/
.searchMobileContainer {
	text-align: center;
	margin-top: 15px;
	font-size: 0;
	border: none;
}
.searchMobileContainer input {
	font-family: var(--regular-font);
	line-height: normal;
}
.searchMobile {
	padding: 0 30px;
	font-size: 18px;
	width: 65%;
	max-width: 400px;
	height: 46px;
	border: none;
	border-radius: 25px 0 0 25px;
}
.searchMobileSubmit {
	-webkit-appearance: none;
	border: none;
	border-left: 2px solid #AD0054;
	border-radius: 0 25px 25px 0;
	display: inline-block;
	width: 20%;
	max-width: 100px;
	height: 46px;
	background-color: #fff;
	color: #AD0054;
	font-size: 18px;
}


@media only screen and (max-width: 1300px) {
	.mainMenuList{
		margin: 0 4px;
	}
	
	.mainEntrie{
		font-size: 16px;
		padding: 0 20px;
	}
}

@media only screen and (max-width: 1074px) {
	.wrap-top {
		display: none;
   }
	.mobile-header{
		display: block;
   }
}