/***** banner *****/
.banner                          						{ position: relative; }
.banner img                     						{ width: 100%; height: 90vh; max-height: 1080px; object-fit: cover; display: block; filter: brightness(0.50); border-radius: 0 0 80px 80px}
.banner .txt               					    		{ position: absolute; left: 12vw; right: 12vw; top: 40%; text-align: center; color: #fff; z-index: 20;}
.banner .txt p             								{ font-size: clamp(40px, 4vw, 50px); line-height: 120%; font-weight: 500; color: #fff; text-align: center; text-transform: uppercase; letter-spacing: 2px; margin: 0;}
.banner .txt h1             							{ margin: 0; padding-top: 15px;}
.banner .txt em                                         { margin-top: 10px; font-style: normal; display: block;}

@media (max-width:1200px) {
.banner                          						{ margin-top: 90px;}
.banner img                     						{ height: 80vh; border-radius: 0}
}
@media (max-width:1000px) {
.banner img                     						{ height: 80vw;}
.banner .txt               					    		{ left: 8vw; right: 8vw; transform: translateY(-50%);}
.banner .txt p             								{ font-size: clamp(20px, 5vw, 30px);}
}
@media (max-width:700px) {
.banner                          						{ margin-top: 70px;}
.banner img                     						{ height: 100vw;}
.banner .txt               					    		{ top: 48%;}
.banner .txt p             								{ line-height: 130%;}
}


/***** intro *****/
.intro	 								                { position: relative; margin-top: -100px;}
.intro .container						                { display: grid; grid-template-columns: 1fr 1fr; align-items: start; grid-gap: clamp(20px, 5vw, 80px); text-align: left;}
.intro .atouts						                    { padding: 170px 0 100px 0;}
.intro .atouts .show_hide			                    { margin-bottom: -10px;}
.intro .cta						                    	{ background-color: #fff; padding: clamp(30px, 4vw, 60px); text-align: center; border-radius: var(--imgRadius);}
.intro .cta lord-icon			                    	{ margin: 0 auto 5px auto;}
.intro .cta	.link					                	{ text-align: center; width: 100%; display: block; margin-top: 30px;}

@media (max-width:1200px) {
.intro .cta	.link					                	{ margin-top: 25px;}
}
@media (max-width:1000px) {
.intro	 								                { margin-top: -8vw;}
.intro .container						                { grid-template-columns: 1fr; grid-gap: 0;}
.intro .atouts						                    { padding-top: 0; margin-top: var(--marginT); padding-bottom: 0;}
}
@media (max-width:700px) {
.intro .cta						                    	{ padding: 5vw;}
.intro .cta	.link					                	{ margin-top: 20px;}
.intro .atouts						                    { margin-bottom: 0;}
   
}



.card_item_v2 								{ position: relative; border-radius: 30px 30px 0 30px; overflow: hidden; text-align: left; width: 100%; display: block; background-color: #fff;}
.card_item_v2 img							{ width: 100%; height: auto; border-radius: 30px 30px 0 0; background-color: #000;}
.card_item_v2 .wrap							{ width: 100%; z-index: 5; padding: 40px 40px 80px 40px;}
.card_item_v2.middle				        { bottom: 80px}
.card_item_v2 .link_pos                    	{ position: absolute; bottom: -10px; right: -10px; padding: 10px; background: var(--bgColorLight); border-top-left-radius: 50%; z-index: 10;}
.card_item_v2 .link_pos:before             	{ position: absolute; bottom: 10px; left: -20px; background: transparent; width: 20px; height: 20px; border-bottom-right-radius: 20px; box-shadow: 10px 10px 0 10px var(--bgColorLight); transition: none; content: "";}
.card_item_v2 .link_pos:after              	{ position: absolute; top: -20px; right: 10px; background: transparent; width: 20px; height: 20px; border-bottom-right-radius: 20px; box-shadow: 10px 10px 0 10px var(--bgColorLight); transition: none; content: "";}
.card_item_v2 .link_pos .link_arrow        	{ z-index: 10;}
.card_item_v2 .link_pos .link_arrow:after   { width: 100vw; height: calc(100% + 30px); position: absolute; right: 0; bottom: 0; content: "";}

@media (min-width:1201px) {
.card_item_v2 .hover_show 					{ display: block; opacity: 0; visibility: hidden; transition: all 300ms ease-in-out;}
.card_item_v2:hover .hover_show 			{ opacity: 1; visibility: visible;}
}
@media (max-width:1200px) {
.card_item_v2 								{ border-radius: 25px 25px 0 25px;}
.card_item_v2.middle				        { bottom: 0}
.card_item_v2 .wrap							{ padding: 30px 30px 60px 30px;}
.card_item_v2 .link_pos .link_arrow:after   { height: 100vh;}
}
@media (max-width:700px) {
.card_item_v2 								{ border-radius: 20px 20px 0 20px;}
.card_item_v2 img							{ border-radius: 20px 20px 0 0;}
.card_item_v2 .wrap							{ padding: 25px 25px 50px 25px;}
.card_item_v2 .wrap :last-child				{ margin-bottom: -3px;}
.card_item_v2 .link_pos                    	{ padding: 10px;}
.card_item_v2 .link_pos:before             	{ left: -20px; width: 20px; height: 20px;}
.card_item_v2 .link_pos:after              	{ top: -20px; width: 20px; height: 20px;}
.card_item_v2 .link_pos .link_arrow        	{ width: 50px; height: 50px; background-position: 50%;}
}


/***** grid bloc *****/
.grid_bloc	 											{ position: relative;}
.grid_bloc .container									{ display: grid; grid-gap: clamp(10px, 3vw, 30px); text-align: left; grid-template-columns: repeat(3, 1fr);}
.grid_bloc.reverse .container:before					{ right: -50vw; left: 62.5%;}


@media (max-width:1200px) {
.grid_bloc .container:before							{ left: -20vw; right: -20vw; top: 15%; bottom: 15%;}
.grid_bloc.reverse .container:before					{ right: -20vw; left: -20vw;}
}
@media (max-width:1000px) {
.grid_bloc .container									{ max-width: none;}
}
@media (max-width:700px) {
.grid_bloc .container									{ grid-template-columns: 1fr;}
}

/***** mots *****/
.mot     				                { position: absolute; top: 20%; left: 60px; z-index: 20; max-width: 200px} 
.mot span                               { font: 400 52px/48px "Emmeline"; position: relative; color: #fff;}


@media (max-width: 1200px){
.mot 										{ top: 10%; left: 40px;}
}

@media (max-width: 700px){
.mot 										{ left: 30px;}
}

@media (max-width: 600px){
.mot     				                { max-width: 150px} 
.mot span   							{ font: 400 45px/48px "Emmeline";}
}

/***** about *****/
.about .container img.logo 					{ width: 200px; margin-bottom: clamp(15px, 2.2vw, 20px);}

@media (max-width: 1200px){
.about .container img.logo 					{ width: 180px;}
}
@media (max-width: 700px){
.about .container img.logo 					{ width: 160px;}
}



/***** bloc reviews *****/

.bloc_reviews                                           { position: relative; min-height: 60vh; max-height: 1000px; padding: 80px 0; display: grid; align-items: center; background-color: #000; overflow: hidden; border-radius:80px;}
.bloc_reviews .img                                      { width: 100%; height: 100%; position: absolute; left: 0; top: 0; background: url(../images/bkg.webp) 50% / cover no-repeat; background-attachment: fixed; opacity: 0.4; }
.bloc_reviews .list   									{ position: relative; max-width: 1200px; margin: 0 auto;}

.card_review 											{ position: relative; padding: 0 100px; text-align: center; color: #fff;}
.card_review p											{ font-size: 25px; line-height: 35px;}
.card_review p.author									{ font-size: 17px; line-height: 22px; font-style: italic;}

@media (max-width: 700px){
.card_review p											{ font-size: 16px; line-height: 30px;}
}

/* if slider */
.slider_reviews .slick-list 							{ overflow: hidden;}
.slider_reviews .slick-slide 							{ margin: 0;}



@media (max-width: 1200px){
.bloc_reviews .item 								    { padding: 25px; min-height: inherit; margin: 0;}
.bloc_reviews                                           { border-radius:0;}
.bloc_reviews .img                                      { background-attachment:scroll; }    
}

@media (max-width: 700px){
.bloc_reviews 												{ margin: 30px auto 20px auto;}
.card_review 											{ padding: 0 70px; text-align: center; color: #fff;}
.bloc_reviews ::-webkit-scrollbar 							{ display: none;}
.bloc_reviews .slider 										{ width: 100vw; overflow-x: auto; gap: 10px; display: flex; flex-wrap: nowrap; justify-content: start; align-items: start; padding: 0 6vw; margin: 0 -6vw;}
.bloc_reviews .item 										{ min-width: 300px; padding: 20px; margin: 0;}
.bloc_reviews .item p										{ font-size: 12px; line-height: 24px;}
.bloc_reviews .item p.author								{ font-size: 16px; line-height: 20px;}
}

@media (max-width: 400px){
.bloc_reviews .item 										{ min-width: 75vw;}
}




