/***** fonts et reset *****/
@font-face { font-family: 'gr book italic'; src: url('../fonts/gr-Bookitalic.woff2') format('woff2'), url('../fonts/gr-Bookitalic.woff') format('woff'); font-weight: normal; font-style: italic; font-display: swap;}
@font-face { font-family: 'gr book'; src: url('../fonts/gr-Book.woff2') format('woff2'), url('../fonts/gr-Book.woff') format('woff'); font-weight: normal; font-style: normal; font-display: swap;}
@font-face { font-family: 'gr bold italic'; src: url('../fonts/gr-Bolditalic.woff2') format('woff2'),        url('../fonts/gr-Bolditalic.woff') format('woff'); font-weight: bold; font-style: italic; font-display: swap;}
@font-face { font-family: 'gr bold'; src: url('../fonts/gr-Bold.woff2') format('woff2'), url('../fonts/gr-Bold.woff') format('woff'); font-weight: bold; font-style: normal; font-display: swap;}
@font-face { font-family: 'gr medium italic'; src: url('../fonts/gr-Mediumitalic.woff2') format('woff2'), url('../fonts/gr-Mediumitalic.woff') format('woff'); font-weight: 500; font-style: italic; font-display: swap;}
@font-face { font-family: 'gr light'; src: url('../fonts/gr-Light.woff2') format('woff2'), url('../fonts/gr-Light.woff') format('woff'); font-weight: 300; font-style: normal; font-display: swap;}
@font-face { font-family: 'gr medium'; src: url('../fonts/gr-Medium.woff2') format('woff2'), url('../fonts/gr-Medium.woff') format('woff'); font-weight: 500; font-style: normal; font-display: swap;}
@font-face { font-family: 'gr light italic'; src: url('../fonts/gr-Lightitalic.woff2') format('woff2'), url('../fonts/gr-Lightitalic.woff') format('woff'); font-weight: 300; font-style: italic; font-display: swap;}

body, ul, li, ol, form, h1, h2, h3, h4, h5, h6, div, span, p { padding:0; margin:0; border:0; -webkit-text-size-adjust: none; -moz-text-size-adjust: none; text-size-adjust: none;}
article, aside, dialog ,figcaption, figure, footer, header, hgroup, main, nav, section { display: block;}  
input, textarea						{ -webkit-appearance: none; -ms-appearance: none; appearance: none; -moz-appearance: none; -o-appearance: none; border-radius: 0;}
*          							{ outline: none;}
strong, b							{ font-weight: 700;}
ul									{ list-style-type: none;}
body								{ font: 16px/30px "gr light"; letter-spacing: 0.4px; color: #000000; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #000000; position: relative;}
img									{ border: none;}
main 								{ position: relative; z-index: 10;}
#wrapper 							{ min-width: 320px; overflow: hidden; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}
/***** scollbar *****/
::-webkit-scrollbar 				{ width: 8px; height: 8px; background-color: #eee;}
::-webkit-scrollbar-thumb			{ background-color: #c59570;}
/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .sub { transition: all 400ms ease-in-out;}
}
/***** class *****/
.wrapper 							{ width: 90vw; min-width: 1080px; max-width: 1200px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.titre_main	 						{ font: 28px/34px "gr medium";text-transform: uppercase; position: relative;color: #c59570;}
.titre                              { font: 28px/34px "gr medium"; display: block;color: #000000; margin-bottom: 15px; }
.sous_titre 						{ font: 28px/40px "gr medium"; position: relative; margin-bottom: 10px; color: #c59570;}
.chapo		 						{ font: 18px/32px "gr medium";}
.link 								{ font: 13px/60px "gr bold"; letter-spacing: 1px; text-transform: uppercase; height: 60px; border: none;border-radius: 5px; display: inline-block; vertical-align: middle; color: #fff; padding: 0 30px; background: linear-gradient(to top, #c59570 0%, #c59570 50%, #efcf9f 50%, #efcf9f 100%); background-size: 100% 200%; background-position: 0 100%; cursor: pointer;}
.tel 								{ font: 16px/60px "gr medium"; letter-spacing: 0.4px; text-transform: uppercase; height: 60px; border: none; display: inline-block; vertical-align: middle; color: #fff; padding: 0 35px 0 70px; background-image: linear-gradient(to top, #c59570 0%, #c59570 50%, #efcf9f 50%, #efcf9f 100%);position: relative;}
.tel::after                         { content:"";background: url("../images/tel.svg") no-repeat;width: 26px;height: 26px;position: absolute;top: 16px;left: 30px; line-height: 0;}
.link_plus							{ display: block; width: 60px; height: 60px; border-radius: 50%; background: url("../images/plus.svg") 50% no-repeat #c59570;}
@media (min-width:1201px) {
.tel:hover,
.link:hover 						{ background-position: 0 0;}
.link_plus:hover					{ background-color: #efcf9f;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width:750px;}
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.titre_main                         { font-size: 22px; }
.titre                              { margin-bottom: 10px; font-size: 20px; }  
.sous_titre							{ font-size: 20px; line-height: 30px;}
body                                { font-size: 15px; }
.link                               { font-size: 12px; }
.tel                                { font-size: 15px; }
.chapo                              { font-size: 16px; }
}
/***** header et menu *****/
.header 							{ width: 100%; background: #fff; font-size: 0; line-height: 0; text-align: right; position: fixed; left: 0; top: 0; z-index: 100; transition: all 400ms ease-in-out;}
.header .logo						{ position: absolute; left: 5vw; top: 50%; transform: translateY(-50%); z-index: 90;}
.header .logo img					{ width: 100%; height: auto;}
.header_right 						{ display: inline-block; vertical-align: middle; position: relative; z-index: 120; margin-left: 30px; padding-right: 5vw;}
.header_nav							{ display: inline-block; vertical-align: middle; z-index: 50;}
.header_nav .menu					{ position: relative;}	
.header_nav .menu li				{ display: inline-block; vertical-align: middle; position: relative; margin-left: 35px;}	
.header_nav .menu li a				{ font: 16px/100px "gr medium"; text-transform: none;height: 100px; display: block; transition-property: all;}
.header_nav .menu>li.active>a 		{ color: #c59570;}
.header_nav .sub					{ width: 355px; text-align: center; position: absolute; top: 120%; left: 50%; margin-left: -175px; display: block; visibility: hidden; opacity: 0; background: #222; padding: 30px 0 25px;}
.header_nav .sub.sized				{ width: 280px; margin-left: -140px;}
.header_nav .sub li					{ width: 100%; margin: 0;}
.header_nav .sub li a				{ width: 100%; font: 16px/38px "gr medium"; text-transform: inherit; letter-spacing: 0.4px; height: 40px; color: #fff;}
.header_nav .menu li:hover .sub		{ opacity: 1; visibility: visible; z-index: 999; top: 100%;}
.header_nav .menu .sub li.active a	{ color: #c59570;}
.sticky .header 					{ box-shadow: 0 0 30px 0 rgb(0 0 0 / 10%);}
@media (min-width:1201px) {
.header_nav .menu .vue_mobile,
.menu_mobile 						{ display: none;}
.header_nav .sub 					{ display: block !important;}
.header_nav .sub:after 				{ width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: #222; content: "";}
.header_nav .menu>li:hover>a,
.header_nav .sub li a:hover			{ color: #c59570;}
.sticky .header_nav .menu>li>a		{ line-height: 90px; height: 90px;}
}
@media (max-width:1450px) {
.header .logo                       { max-width: 200px; }
.header_nav .menu>li                { margin-left: 20px; }
.header_nav .menu>li a              { font-size: 14px; }
.header_right                       { margin-left: 20px; }
}
@media (max-width:1200px) {
.menu_mobile						{ width: 60px; height: 60px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; margin: 20px -15px; transition: margin 400ms ease-in-out;}
.menu_mobile div					{ width: 30px; height: 2px; background: #000; position: absolute; right: 50%; top: 50%; margin: -1px -15px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #000; position: absolute; right: 0; top: 8px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #000; position: absolute; right: 0; top: -8px; content: "";}
.menu_mobile.active div				{ height: 0;}
.menu_mobile.active div:before		{ top: 0; transform: rotate(45deg);}
.menu_mobile.active div:after		{ top: 0; transform: rotate(-45deg);}
.header 							{ height: 100px; transition: box-shadow 400ms ease-in-out, height 400ms ease-in-out 400ms;}
.header .logo						{ top: 25px; transform: none;z-index: 120;}
.header_right 						{ margin: 0;}
.header_right .link					{ margin-right: 5vw;}
.header_nav 	  					{ width: 100%; height: 100vh; padding: 0; position: fixed; right: 100%; top :0; overflow-y: scroll; display: grid; z-index: 100; padding-top: 80px; transition: 0ms ease-in-out 400ms;}
.header_nav::-webkit-scrollbar		{ display: none;}
.header_nav .menu  					{ width: 100%; text-align: center; padding: 5vw; position: relative; z-index: 100;  align-self: center; opacity: 0; transform: translateY(40px); transition: all 400ms ease-in-out 0ms;}
.header_nav .menu li 				{ width: 100%; display: block; margin: 0;}
.header_nav .menu li a				{ font-size: 16px; line-height: 54px; ; height: 50px;}
.header_nav .menu li i				{ width: 100%; height: 50px; position: absolute; left: 0; top: 0;}
.header_nav .menu li i:after		{ width: 10px; height: 10px; transform: rotate(45deg); position: absolute; left: 50%; bottom: -22px; margin-left: -5px; opacity: 0; transition: all 300ms ease-in-out; background: #222; content: "";}
.header_nav .menu li i.active:after	{ opacity: 1;}
.header_nav .menu .sub 				{ width: auto; visibility: visible; position: relative; left: auto; top: auto; padding: 25px 0; margin: 15px 0; opacity: 1; display: none;}
.header_nav .menu .sub li a			{ font-size: 16px; line-height: 42px; height: 40px;}
/* active menu mobile */
.header.active 						{ height: 100vh; transition-delay: 0ms;}
.header_nav.active					{ right: 0; transition-delay: 0ms;}
.header_nav.active .menu			{ opacity: 1; transform: translateY(0); transition-delay: 400ms;}
}
@media (max-width:600px) {
.header 							{ height: 80px;}
.header .logo						{ width: 180px; left: 7.5vw; top: 20px;}
.header_right 						{ padding-right: 7.5vw;}
.header_right .link					{ width: 50px; height: 50px;border-radius: 50%; font-size: 0; background: url("../images/tel_mobile.svg") 50% #c59570 no-repeat;padding: 0; margin-right: 30px;}
.header_right .tel::after           { display: 	none; }
.menu_mobile						{ margin: 10px -15px;}
.header_nav .menu  					{ padding: 7.5vw;}
.header_nav .menu>li>a				{ font-size: 15px; line-height: 48px; ; height: 44px;}
.header_nav .menu li i				{ height: 44px;}
}
@media (max-width:380px) {
.header .logo						{ width: 150px;}
}
/***** bandeau téléphone *****/
.tel_banner .content                { background: #f9f9f9; margin: 90px 0; }
.tel_banner p 						{ font: 24px/40px "gr medium"; color: #000000; display: block; text-align: center; padding: 55px 40px; }
.tel_banner a                       { color: #c59570;border-bottom: 1px solid transparent; padding-bottom: 2px; }
@media (min-width:1201px) {
.tel_banner a:hover					{ border-color: #efcf9f;}
}
@media (max-width:1000px) {
.tel_banner                         { background: #f9f9f9; }
.tel_banner .content                { background: none; margin: 50px 0 60px; }
}
@media (max-width:600px) {
.tel_banner p                       { padding: 35px 20px;font-size: 20px;line-height: 32px; }
}
/***** Atouts *****/
.atouts                             { background:#f9f9f9 ;margin: 100px 0 0; }
.atouts .content                    { padding: 65px 0 60px; display: grid;grid-template-columns: 1fr 1fr 1fr;align-items: center;justify-content: center;text-align: center;}
.atouts .content .item              { padding: 10px 20px;border-right: 1px solid #d8d8d8;}
.atouts .content .item p            { font-size: 18px; }
.atouts .content .item:last-child   { border: none; }
.atouts img                         { width: auto;height: auto; margin: auto; }    
@media (max-width:1000px) {
.atouts                             { margin: 80px 0; }
.atouts .content                    { grid-template-columns: 1fr;text-align: left;padding: 30px 0; }
.atouts .content .item              { display: grid;grid-template-columns: 80px auto;align-items: center;justify-content: flex-start;padding:20px 0;border-bottom: 1px solid #d8d8d8;border-right: none;margin-bottom: 0; }
.atouts .content .item img          { max-width: 60px;margin: 0; }
.atouts .content .item p br         { display: none; }
}
@media (max-width:600px) {
.atouts                             { margin: 50px 0; }
.atouts .content .item p            { font-size: 16px; }
}
/***** Produits *****/
.produits                           { background: #f9f9f9;margin: 100px 0 90px;padding: 85px 0 100px; }
.produits .content                  { padding: 25px 0 0;margin: 0 -40px;}
.produits .slick-slide img          { width: 100%;height: 100%; border: 1px solid #ededed; }
.produits .nav_slider               { position: absolute;top: -15px;right: 0; }
.produits .slick-arrow              { width: 55px;height: 55px;background-color: #000000;border-radius: 50%; }
.produits .slick-next               { margin-left: 10px; }
.produits .item                     { position: relative; margin: 0 40px; }
.produits .item .promo              { font: 13px/32px "gr bold";color: #ffffff;text-transform: uppercase; position: absolute;top: 15px;right: 15px;width: 75px;height: 75px;background: #c59570;border-radius: 50%;display: grid;align-items: center;justify-content: center; }
.produits .item .content_titre      { display: grid;grid-template-columns: 2fr 1fr;grid-gap: 10px; border-bottom: 1px solid #e6e6e6;padding: 20px 0 10px;margin-bottom: 10px; }
.produits .titre                    { line-height: 32px; }
.produits .item .sous_titre         { font: 20px/32px "gr medium";color: #c59570;}
.produits .item span                { font: 30px/32px "gr medium";color: #000000;text-align: right; white-space: nowrap; }
.produits .item .group_link         { margin-top: 20px;display: grid;grid-template-columns: max-content max-content;grid-gap: 20px; }
@media (min-width:1200px) {
.produits .slick-arrow:not(.slick-disabled):hover   { background-color: #c59570; }
.produits .slick-next:not(.slick-disabled):hover    { background: url("../images/arrow_next.svg") 50% no-repeat #c59570; }
.produits .slick-prev:not(.slick-disabled):hover    { background: url("../images/arrow_prev.svg") 50% no-repeat #c59570; }
}
@media (max-width:1200px) {
.produits .content                  { margin: 0 -20px;}
.produits .item                     { margin: 0 20px; }
}
@media (max-width:1000px) {
.produits                           { margin: 80px 0 75px; padding: 75px 0 80px;}
.produits .content                  { margin: 0 -20px; }
.produits .item                     { margin: 0 20px; }
.produits .item .group_link         { grid-gap: 10px; }
.produits .item .group_link .link   { padding: 0 20px; }
}
@media (max-width:600px) {
.produits                           { position: relative; text-align: center;margin: 50px 0 40px;padding: 35px 0 150px;}
.produits .titre                    { font-size: 28px; }
.produits .nav_slider               { top: inherit;right: inherit;bottom: -100px; left: 50%;transform: translateX(-50%); }
.produits .content                  { padding: 15px 0 0;max-width: 350px;margin: auto; }
.produits .item .sous_titre         { text-align: left;margin-bottom: 0; }
.produits .item .content_titre      { padding: 20px 0; }
.produits .item span                { text-align: right;font-size: 26px;line-height: 30px; }
.produits .item .group_link         { justify-content: center;grid-gap: 15px; }
.produits .item .group_link .link   { min-width: 135px;padding: 0 30px; }
}
/***** footer*****/
.footer								{ width: 100%; position: relative; padding-top: 85px; background: #100c08; color: #fff; font-size: 0;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 85px; line-height: 30px;}
.footer .logo                       { font: 20px/30px "gr medium";text-transform: uppercase;color: #c59570; }
.footer .tel:before                 { display: none;}
.footer .bloc_footer.last			{ margin-right: 0;}
.footer .bloc_footer p				{ font-size: 16px; margin-top: 10px;}
.footer .bloc_footer p:first-of-type{ margin-top: 5px; }
.footer .bloc_footer p:last-child   { margin-top:30px}
.footer .bloc_footer p b			{ display: block; font: 400 18px/24px "Poppins"; color:#c59570; margin-bottom: 5px;}
.footer .bloc_footer p a			{ color: #c59570;}
.footer .bloc_footer p .tel         { color: #ffffff;}
.footer .bloc_footer p span			{ display: inline-block;}
.footer .bloc_footer ul				{ margin-top: -5px; display: inline-block;vertical-align: top; margin-right: 50px;}
.footer .bloc_footer li a			{ font-size: 16px; color: #fff; margin-top: 0; background:url(../images/list.svg) 0 14px no-repeat; padding: 5px 0 5px 20px; display: inline-block;}
.footer	.rs							{ position: absolute; right: 0; top: -10px;}
.footer	.rs a						{ width: 50px; height: 50px; display: inline-block; vertical-align: top; border-radius: 50%; margin-right: 10px;}
.footer	.rs .facebook			    { background: url(../images/facebook.svg) 50% no-repeat #c59570;}
.footer	.rs .tiktok			        { background: url(../images/tiktok.svg) 50% no-repeat #c59570;}
.footer	.rs .instagram				{ background: url(../images/instagram.svg) 50% no-repeat #c59570;}
.footer	.rs .scroll					{ background: url(../images/scrolltop.svg) 50% no-repeat #353535; margin: 0;}
.footer_bottom   					{ padding: 10px 0 10px; line-height: 0; margin-top: 70px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 28px; margin-right: 30px; letter-spacing: 0.6px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 9px; content: ""; position: absolute; right: -16px; top: 11px; background: #c59570;}
.footer_bottom li:last-child:after 	{ display: none;}
.toponweb							{ display: block; z-index: 85; position: fixed; right: 0; bottom: -65px; transition: bottom 400ms ease-in-out;}
.toponweb span						{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, #c59570 0%, #c59570 50%, #efcf9f 50%, #efcf9f 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 74px; height: auto; display: block; margin: 0 auto;}
.toponweb.show						{ bottom: 0;}
@media (min-width:1201px) {
.footer .bloc_footer p a:hover,
.footer .bloc_footer li a:hover,
.footer_bottom li a:hover			{ color: #efcf9f;}
.footer .bloc_footer p .tel:hover   { color: #ffffff; }
.footer	.rs .facebook:hover,.footer	.rs .tiktok:hover,
.footer	.rs .instagram:hover        { background-color: #efcf9f; }
.footer	.rs .scroll:hover			{ background-color: #c59570;}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .bloc_footer.last			{ display: none;}
.toponweb                           { position: absolute;}
}
@media (max-width:1000px) {
.footer .bloc_footer 				{ display: block; margin: 0;}
.footer .bloc_footer p              { margin: 0 0 10px;}
.footer_bottom   					{ margin-top: 80px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 40px;}
.footer .logo						{ margin-bottom: 0;}
.footer .bloc_footer 				{ margin: 0;}
.footer .bloc_footer p:last-child   { margin-top: 25px; }
.footer .bloc_footer p              { font-size: 14px; }
.footer .bloc_footer p b			{ font-size: 18px; line-height: 20px; margin-bottom: 20px;}
.footer	.rs							{ position: static; margin-top: 40px;}
.footer_bottom 	 					{ text-align: left; margin-top: 30px; padding: 0 0 40px 0;}
.footer_bottom li 					{ display: block; margin-right: 0; line-height: 28px;}
.footer_bottom li:after				{ display: none;}
}




