/***** fonts et reset *****/
@import url('https://fonts.googleapis.com/css2?family=Barlow:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Playfair+Display:wght@400;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Cookie&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: 500;}
ul									{ list-style-type: none;}
body								{ font: 400 16px/30px "Barlow"; letter-spacing: 0.2px; color: #000; background: #fff; position: relative;}
body.active_overflow				{ height: 100vh; overflow: hidden;}
a									{ text-decoration: none; color: #000; position: relative;}
img									{ border: none;}
main 								{ position: relative; z-index: 10;}
#detect_scrolling					{ position: fixed; left: 0; top: 0;}
#wrapper 							{ min-width: 320px; overflow: hidden; position: relative;}
#wrapper *							{ box-sizing: border-box;}
#footer 							{ position: relative; z-index: 15;}

@media (max-width:600px) {
body								{ font-size: 14px; line-height: 24px;}
}


/***** scollbar *****/
::-webkit-scrollbar 				{ width: 6px; height: 6px; background-color: #ccc;}
::-webkit-scrollbar-thumb			{ background-color: #ec0300;}


/***** transition *****/
@media (min-width:1201px) {
.link, .slick-arrow, :before, :after, a, a span, .logo, .header, .sub { transition: all 400ms ease-in-out;}
}


/***** class *****/
.wrapper 							{ width: 90vw; max-width: 1200px; margin: 0 auto; position: relative;}
.clear								{ clear: both; display: block;}
.anchor								{ position: absolute; left: 0; top: -140px;}
.titre_main	 						{ font: 700 35px/45px "Playfair Display"; position: relative; color: #ec0300; margin-bottom: 15px;}
.sous_titre 						{ font: 500 20px/28px "Barlow"; position: relative; color: #ec0300; margin-bottom: 15px;}
.chapo		 						{ font: 400 16px/30px "Barlow"; margin-bottom: 15px;}
.chapo.red	 						{ color: #ec0300;}
.chapo span	 						{ display: block; margin-top: 15px;}
.link 								{ font: 700 13px/58px "Barlow"; text-transform: uppercase; letter-spacing: 0.6px; height: 60px; display: inline-block; color: #fff; padding: 0 30px; border-radius: 5px; background: linear-gradient(to top, #000 0% 50%, #ec0300 50% 100%); background-size: 100% 200%; background-position: 0 100%;}
.short_bloc 						{ max-width: 980px; margin: 0 auto; position: relative;}

@media (min-width:1201px) {
.link:hover 						{ background-position: 0 0; color: #fff;}
}
@media (max-width:1200px) {
.wrapper 							{ min-width: inherit;}
.titre_main	 						{ font-size: 30px; line-height: 40px;}
.sous_titre 						{ font-size: 18px; line-height: 26px;}
}
@media (max-width:1000px) {
.wrapper 							{ max-width: 750px;}
}
@media (max-width:600px) {
.wrapper 							{ width: 85vw;}
.titre_main	 						{ font-size: 22px; line-height: 30px; margin-bottom: 10px;}
.sous_titre 						{ font-size: 16px; line-height: 24px; margin-bottom: 10px;}
.chapo		 						{ font-size: 14px; line-height: 24px; margin-bottom: 10px;}
.chapo span	 						{ margin-bottom: 10px;}
.link 								{ font-size: 11px; line-height: 50px; height: 50px; padding: 0 25px;}
}


/***** header et menu *****/
.header 							{ width: 100%; font-size: 0; line-height: 0; letter-spacing: 0; position: fixed; left: 0; top: 0; z-index: 100; text-align: right; background: #fff; transition: all 400ms ease-in-out;}
.header .wrapper 					{ max-width: 1800px;}
.header .logo						{ width: 220px; position: absolute; left: 0; top: 40px; z-index: 250; transition: all 400ms ease-in-out;}
.header .logo img					{ width: 100%; height: auto; display: block;}

.header .header_top  				{ padding: 20px 0 0 0;}
.header .header_top a				{ font: 500 15px/30px "Barlow"; height: 30px; display: inline-block; vertical-align: middle; letter-spacing: 0.4px; margin-left: 30px;}
.header .header_top a.tel 			{ padding-left: 30px; background: url("../images/tel.svg") 0 50% no-repeat;}
.header .header_top a.instagram 	{ padding-left: 35px; background: url("../images/instagram.svg") 0 50% no-repeat;}
.header .header_top a.facebook 		{ padding-left: 25px; background: url("../images/facebook.svg") 0 45% no-repeat;}

/* menu */
.header .header_nav 				{ display: inline-block; position: relative;}
.header .menu>li					{ position: relative; display: inline-block; vertical-align: middle; margin-left: 35px;}
.header .menu>li>a:not(.link)		{ font: 500 15px/90px "Barlow"; height: 90px; display: block; letter-spacing: 0.4px;}
.header .menu>li .link				{ background-image: linear-gradient(to top, #ec0300 0% 50%, #000 50% 100%); width: 180px; text-align: center; padding: 0;}
.header .menu>li.active>a			{ color: #ec0300;}

.header .sub						{ width: 400px; margin-left: -200px; text-align: left; position: absolute; top: 95px; left: 50%; display: block; visibility: hidden; opacity: 0; padding: 30px 50px; background: #eee; border-radius: 5px;}
.header .sub li						{ width: 100%; margin: 0;}
.header .sub li	b					{ font-size: 16px; line-height: 30px; font-weight: 500; display: block; margin-bottom: 10px; letter-spacing: 0.4px; padding-top: 5px;}
.header .sub li a					{ display: block; font-size: 14px; letter-spacing: 0.4px; line-height: 34px; height: 36px; color: #000; background: url("../images/arrow.svg") 100% 50% no-repeat;}
.header .sub li.active a			{ color: #ec0300;}

.header .big_sub					{ width: 800px; margin-left: -400px; padding: 30px 50px;}
.header .big_sub .grid				{ display: grid; grid-template-columns: 1fr 1fr; grid-gap: 70px;}

.header .banner_menu 				{ display: none;}
.header .banner_menu img			{ width: 100%; height: 100%; object-fit: cover; display: block;}

@media (min-width:1201px) {
.menu_mobile 						{ display: none;}
.header .sub:after 					{ width: 10px; height: 10px; position: absolute; left: 50%; top: -5px; margin: 0 0 0 -5px; transform: rotate(45deg); background: #eee; content: "";}
.header .menu>li:hover .sub			{ opacity: 1; visibility: visible; z-index: 999; top: 75px;}
.header .header_top a:hover,
.header .menu>li:hover>a:not(.link),		
.header .sub li a:hover 			{ color: #ec0300;}

.sticky .header						{ top: -50px; box-shadow: 0 0 40px 0 rgba(0,0,0,10%);}
.sticky .header .logo				{ width: 140px; top: 70px;}
.sticky.scrolling_top .header		{ top: 0;}
}
@media (max-width:1600px) {
.header .logo						{ width: 200px; top: 45px;}
}
@media (max-width:1400px) {
.header .logo						{ width: 180px; top: 50px;}
.header .menu>li					{ margin-left: 30px;}
}
@media (max-width:1260px) {
.header .menu>li					{ margin-left: 25px;}
}
@media (max-width:1200px) {
.menu_mobile						{ width: 70px; height: 90px; display: inline-block; vertical-align: middle; cursor: pointer; position: relative; z-index: 250; margin: 0 -15px; transition: height 400ms ease-in-out;}
.menu_mobile div					{ width: 40px; height: 2px; background: #000; position: absolute; right: 50%; top: 50%; margin: -1px -20px 0 0;}
.menu_mobile div:before				{ width: 100%; height: 2px; background: #000; position: absolute; right: 0; top: 7px; content: "";}
.menu_mobile div:after				{ width: 100%; height: 2px; background: #000; position: absolute; right: 0; top: -7px; 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 ::-webkit-scrollbar			{ display: none;}
.header .logo						{ width: 140px; top: 22px;}

.header .header_top  				{ padding: 0; position: relative; z-index: 205;}
.header .header_top a.tel 			{ margin-right: 5vw;}

.header .header_nav 				{ width: 100%; height: 100vh; position: fixed; right: -100%; top :0; overflow-y: scroll; display: grid; z-index: 200; background: #000; border-top: 90px solid #fff; transition: right 400ms ease-in-out 600ms;}
.header .menu  						{ display: block; width: 100%; text-align: left; padding: 60px 48vw 60px 8vw; position: relative; z-index: 100; opacity: 0; transform: translateY(40px); transition: opacity 400ms ease-in-out 200ms, transform 400ms ease-in-out 200ms;}
.header .menu>li 					{ width: 100%; display: block; margin: 0;}
.header .menu>li:last-child			{ margin-top: 40px;}
.header .menu>li>a:not(.link) 		{ font-size: 22px; line-height: 48px; height: 50px; color: #fff;}
.header .menu>li>a:not(.link):after	{ width: 20px; height: 100%; position: absolute; top: 0; right: 0; background: url("../images/arrow.svg") 0 55% no-repeat; filter: invert(1); content: "";}
.header .menu>li>i					{ width: 100%; height: 50px; display: block; position: absolute; left: 0; top: 0; z-index: 5;}
.header .menu>li>i:after			{ width: 30px; height: 100%; position: absolute; top: 0; right: -5px; background: url("../images/scrolltop.svg") 50% no-repeat #000; transform: rotate(-180deg); content: "";}
.header .menu>li>i.active:after		{ transform: rotate(0);}
.header .menu>li.active>a			{ color: #ec0300;}

.header .sub 						{ width: 100%; position: relative; left: auto; top: auto; padding: 25px 40px; margin: 15px 0; border-radius: 5px; background: #fff; visibility: visible; opacity: 1; display: none; z-index: 150;}
.header .sub li  					{ width: 100%;}
.header .sub li b 					{ padding: 0; margin-bottom: 5px;}
.header .sub li a					{ line-height: 30px; height: 32px;}

.header .big_sub .grid				{ grid-template-columns: 1fr; grid-gap: 15px;}

.header .banner_menu 				{ display: block; object-fit: cover; width: 40vw; height: calc(100% - 90px); position: fixed; right: -40vw; bottom: 0; visibility: hidden; opacity: 0; transition: opacity 400ms ease-in-out 200ms, visibility 400ms ease-in-out 200ms;}

.header.active .header_nav 			{ right: 0; transition-delay: 200ms;}
.header.active .menu				{ opacity: 1; transform: translateY(0); transition-delay: 600ms;}
.header.active .banner_menu 		{ opacity: 1; visibility: visible; right: 0; transition-delay: 600ms;}

.sticky .header						{ top: 0; box-shadow: 0 0 40px 0 rgba(0,0,0,10%);}
}
@media (max-width:1000px) {
.header .menu  						{ padding: 60px 10vw;}
.header .banner_menu 				{ width: 80vw; height: 35vw; right: -100vw; position: static; align-self: end; margin: 0 0 10vw 10vw; border-radius: 5px; overflow: hidden;}
}
@media (max-width:760px) {
.header .header_top a				{ width: 54px; height: 54px; border-radius: 50%; font-size: 0; letter-spacing: 0; line-height: 0; margin-left: 10px;}
.header .header_top a:after			{ width: 100%; height: 100%; position: absolute; left: 0; top: 0; filter: grayscale(100) brightness(100); content: "";}
.header .header_top a.tel, 			 
.header .header_top a.instagram, 	 
.header .header_top a.facebook 			{ padding: 0; background: #ec0300;}
.header .header_top a.tel:after 		{ background: url("../images/tel.svg") 50% no-repeat;}
.header .header_top a.instagram:after 	{ background: url("../images/instagram.svg") 50% no-repeat;}
.header .header_top a.facebook:after 	{ background: url("../images/facebook.svg") 50% no-repeat;}
}
@media (max-width:600px) {
.menu_mobile						{ height: 70px;}
.header .logo						{ width: 100px; top: 17px;}
.header .header_top a				{ width: 40px; height: 40px; margin-left: 10px;}
.header .header_top a.tel 			{ margin-right: 7.5vw;}
.header .header_nav 				{ border-width: 70px; grid-template-rows: auto 1fr;}
.header .menu  						{ padding: 30px 7.5vw 40px 7.5vw; transform: none;}
.header .menu>li:last-child			{ margin-top: 25px;}
.header .menu>li>a:not(.link) 		{ font-size: 16px; line-height: 40px; height: 40px;}
.header .menu>li>a:not(.link):after	{ width: 20px; height: 100%; position: absolute; top: 0; right: 0; background: url("../images/arrow.svg") 0 55% no-repeat; filter: invert(1); content: "";}
.header .menu>li>a.link				{ width: 100%; text-align: center;}
.header .menu>li>i					{ height: 40px;}
.header .sub 						{ padding: 20px 25px; margin: 10px 0;}
.header .sub li b 					{ font-size: 15px; line-height: 25px;}
.header .sub li a					{ line-height: 28px; height: 30px;}
.header .banner_menu 				{ width: 85vw; height: 40vw; margin: 0 0 7.5vw 7.5vw; align-self: start;}
}
@media (max-width:400px) {
.header .header_top a.instagram, 	 
.header .header_top a.facebook 		{ display: none;}
}


/***** animal *****/
.animal 								{ position: relative;}
.animal a 								{ display: block;}
.animal .photo 							{ position: relative; overflow: hidden; border-top-left-radius: 5px; border-top-right-radius: 5px;}
.animal .photo:before 					{ width: 100%; height: 100px; position: absolute; bottom: 0; left: 0; background: linear-gradient(to top, rgba(0,0,0,0.65) 0%, rgba(0,0,0,0) 100%); z-index: 5; content: "";}
.animal .photo img 						{ display: block; width: 100%; height: auto; transition: filter 400ms ease-in-out;}
.animal .photo .name 					{ font: 400 50px/50px "Cookie"; color: #fff; padding: 20px 30px; width: 100%; position: absolute; left: 0; bottom: 0; z-index: 10; margin: 0;}
.animal .photo .video 					{ width: 26px; height: 18px; background: url("../images/youtube.svg") 50% no-repeat; position: absolute; right: 30px; bottom: 20px; z-index: 10;}
.animal .photo .reserved 				{ width: 100px; height: 40px; text-align: center; font-size: 15px; line-height: 38px; font-weight: 500; border-radius: 5px; background: #fff; color: #ec0300; position: absolute; right: 20px; top: 20px; z-index: 10;}
.animal .infos 							{ padding: 20px 30px; font-weight: 500; position: relative; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; background: #fff; box-shadow: 0 0 30px 0 rgba(0,0,0,10%); height: 130px;}
.animal .infos p						{ margin: 0; text-transform: capitalize;}
.animal .infos .arrow					{ color: #ec0300; font: 700 13px/30px "Barlow"; text-transform: uppercase; letter-spacing: 0.6px; position: absolute; right: 30px; bottom: 20px; background: url("../images/arrow.svg") right -25px center no-repeat;}

@media (min-width:1201px) {
.animal a:hover .photo img				{ filter: brightness(0.65)}
.animal a:hover .arrow					{ color: #000; padding-right: 30px; background-position: right center;}
}
@media (max-width:600px) {
.animal .photo:before 					{ height: 80px;}
.animal .photo .name 					{ font-size: 35px; line-height: 45px; padding: 15px 25px;}
.animal .photo .reserved 				{ width: 80px; height: 30px; font-size: 13px; line-height: 28px; right: 10px; top: 10px; border-radius: 3px;}
.animal .infos 							{ padding: 15px 25px; height: 110px; box-shadow: 0 0 20px 0 rgba(0,0,0,10%);}
.animal .infos .arrow					{ font-size: 11px; right: 25px;}
}


/***** actu *****/
.actu 									{ position: relative;}
.actu a 								{ display: block; text-align: center;}
.actu .photo 							{ position: relative; overflow: hidden; border-top-left-radius: 5px; border-top-right-radius: 5px;}
.actu .photo img 						{ display: block; width: 100%; height: auto; transition: filter 400ms ease-in-out;}
.actu .photo .date 						{ width: 100px; height: 39px; text-align: center; font-size: 15px; line-height: 39px; font-weight: 500; border-radius: 5px; background: #fff; position: absolute; right: 20px; top: 20px; z-index: 10;}
.actu .titre 							{ padding: 15px 30px 20px 30px; font-weight: 500; border-bottom-left-radius: 5px; border-bottom-right-radius: 5px; background: #fff; box-shadow: 0 0 30px 0 rgba(0,0,0,10%); display: grid; align-items: center; min-height: 100px; line-height: 24px; transition: color 400ms ease-in-out;}

@media (min-width:1201px) {
.actu a:hover .photo img				{ filter: brightness(0.65);}
.actu a:hover .titre 					{ color: #ec0300;}
}
@media (max-width:600px) {
.actu .photo .date 						{ width: 90px; height: 30px; font-size: 13px; line-height: 30px; right: 10px; top: 10px;}
.actu .titre 							{ padding: 10px 25px 15px 25px; line-height: 22px; min-height: 80px;}
}


/***** link icon *****/
.link_icon 								{ display: grid; grid-template-columns: 120px 1fr; align-items: center; background: #fff; box-shadow: 0 0 30px 0 rgba(0,0,0,10%); padding: 30px 40px 30px 30px; border-radius: 5px;}
.link_icon img							{ width: auto; height: 100px;}
.link_icon span							{ font-size: 15px; font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px; color: #e20502; padding-right: 40px; background: url("../images/arrow.svg") right center no-repeat;}

@media (min-width:1201px) {
.link_icon:hover						{ padding-right: 50px;}
.link_icon:hover span					{ color: #000;}
}
@media (max-width:1600px) {
.link_icon 								{ grid-template-columns: 105px 1fr; padding: 20px 30px;}
.link_icon img							{ height: 80px;}
}
@media (max-width:1000px) {
.link_icon 								{ grid-template-columns: 90px 1fr; padding: 20px 30px;}
.link_icon img							{ height: 70px;}
}
@media (max-width:600px) {
.link_icon 								{ grid-template-columns: 75px 1fr; padding: 15px 25px; box-shadow: 0 0 20px 0 rgba(0,0,0,10%);}
.link_icon img							{ height: 60px;}
.link_icon span							{ font-size: 11px; line-height: 18px;}
}


/***** footer*****/
.footer								{ position: relative; background: #151515; color: #fff; font-size: 0; letter-spacing: 0; padding-top: 100px;}
.footer .bloc_footer 				{ display: inline-block; vertical-align: top; margin-right: 100px;}
.footer .bloc_footer .titre_main	{ font-size: 20px; line-height: 45px; color: #fff;}
.footer .bloc_footer p				{ font-size: 15px; line-height: 25px; margin-top: 15px; letter-spacing: 0.4px;}
.footer .bloc_footer p a			{ color: #fff; padding-left: 30px;}
.footer .bloc_footer p a.tel		{ background: url("../images/tel.svg") 0 50% no-repeat;}
.footer .bloc_footer p a.email		{ background: url("../images/email.svg") 0 50% no-repeat;}
.footer .horaires 					{ margin-top: 58px;}
.footer .horaires p 				{ margin: 0; line-height: 30px; width: 180px;}
.footer .horaires p span 			{ float: right;}
.footer ul.bloc_footer     			{ column-count: 2; column-gap: 40px; margin-top: 55px;}
.footer ul.bloc_footer li a 		{ font-size: 15px; letter-spacing: 0.4px; line-height: 35px; padding: 5px 0 5px 20px; background: url("../images/list_red.svg") 0 55% no-repeat; color: #fff;}
.footer	.rs							{ position: absolute; right: 0; top: 0;}
.footer	.rs a						{ width: 60px; height: 60px; border-radius: 50%; background: #fff; display: inline-block; vertical-align: top; margin-right: 10px;}
.footer	.rs .scroll  				{ margin: 0;}
.footer	.rs a:after					{ width: 100%; height: 100%; position: absolute; left: 0; bottom: 0; content: "";}
.footer	.rs .scroll:after 			{ background: url("../images/scrolltop.svg") 50% 48% no-repeat;}
.footer	.rs .facebook:after			{ background: url("../images/facebook.svg") 50% no-repeat;}
.footer	.rs .instagram:after		{ background: url("../images/instagram.svg") 50% no-repeat;}
.footer_bottom   					{ padding: 20px 0; line-height: 0; margin-top: 80px;}
.footer_bottom li 					{ display: inline-block; font-size: 12px; line-height: 20px; margin-right: 25px; letter-spacing: 1px; position: relative;}
.footer_bottom li a 				{ color: #fff;}
.footer_bottom li:after				{ width: 1px; height: 8px; content: ""; position: absolute; right: -13px; top: 7px; background: #fff;}
.footer_bottom li:last-child:after 	{ display: none;}
.toponweb							{ display: block; z-index: 85; position: absolute; right: 0; bottom: 0; transition: bottom 400ms ease-in-out;}
.toponweb span						{ width: auto; height: 60px; display: block; padding: 20px; background: linear-gradient(to left, #3b3b3b 0% 50%, #151515 50% 100%); background-size: 200% 100%; background-position: 100% 0;}
.toponweb img						{ width: 76px; height: auto; display: block; margin: 0 auto; filter: invert(1); transition: all 400ms ease-in-out;}
.toponweb.show						{ bottom: 0;}

@media (min-width:1201px) {
.footer_bottom li a:hover, 			
.footer .bloc_footer li a:hover, 
.footer .bloc_footer p a:hover	 	{ color: #ec0300;}
.footer	.rs a:hover 				{ background: #585858;}
.footer	.rs a:hover:after 			{ filter: grayscale(100%) brightness(100);}
.toponweb:hover span				{ background-position: 0 0;}
}
@media (max-width:1200px) {
.footer								{ padding-top: 80px;}
.footer ul.bloc_footer     			{ display: none;}
.footer_bottom   					{ margin-top: 60px;}
}
@media (max-width:1000px) {
.footer								{ padding-top: 60px;}
.footer .bloc_footer 				{ margin-right: 80px;}
.footer .horaires 					{ margin-right: 0;}
}
@media (max-width:760px) {
.footer .bloc_footer .titre_main	{ line-height: 60px;}
.footer .bloc_footer 				{ margin-right: 0;}
.footer .horaires 					{ display: block; margin-top: 40px;}
.footer	.rs a						{ width: 54px; height: 54px;}
}
@media (max-width:600px) {
.footer								{ padding-top: 40px;}
.footer .bloc_footer 				{ width: 100%; margin: 0;}
.footer .bloc_footer .titre_main	{ line-height: 44px; margin-bottom: 10px;}
.footer .bloc_footer p				{ font-size: 14px; line-height: 24px; margin-top: 10px;}
.footer .bloc_footer p a.email		{ background-position: 0 55%;}
.footer .horaires 					{ margin-top: 30px;}
.footer .horaires p 				{ line-height: 26px; width: 60%; margin: 0;}
.footer	.rs a						{ width: 44px; height: 44px;}
.footer_bottom 	 					{ text-align: left; margin-top: 30px; padding: 0 0 20px 0;}
.footer_bottom li 					{ display: block; margin: 0; font-size: 12px; line-height: 24px;}
.footer_bottom li:after				{ display: none;}
}
@media (max-width:400px) {
.footer .bloc_footer .titre_main	{ line-height: 30px;}
.footer	.rs							{ position: static; margin: 35px auto 30px auto; text-align: center;}
}
