/* =====================================================
   RESET
===================================================== */

html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video { margin: 0; padding: 0; border: 0; font-size: 100%; font: inherit; vertical-align: baseline; list-style: none; text-decoration: none; quotes: none;}

article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
* {box-sizing: border-box;}







/* =====================================================
   FONTS & VARIABLES
===================================================== */



:root {
	interpolate-size: allow-keywords;

	/* COLORS	 */
	

	
	
	--c-50 : #f9f9f9;
	--c-100 : #f4f3f2;
	--c-150 : #f1ebde;
	--c-200 : #f2ebdc;
	--c-300:  #bfb8af;
	--c-350:  #9a948b;
	--c-400 : #f3df98; /* Real color */
	--c-400:  #f2c572;
	--c-500 : #f2c572;
	--c-500 : #e7b24f;
	--c-600 : #DF9000;
	--c-600 : #8F5600;
	--c-700 : #64615a;
	--c-800 : #2e2d2c;
	--c-900 : #1c1c1b;
	
	
	
	
	/* SIZE */
	
	--container-size : min(90%, 1400px);
	
	
	--fs-m: 16px;
	--fs-l: calc(var(--fs-m)*1.25);
	--fs-xl: calc(var(--fs-m)*1.5);
	--fs-xxl: calc(var(--fs-m)*1.8);
	--fs-xxxl: calc(var(--fs-m)*2.5);
	--fs-xxxxl: calc(var(--fs-m)*4);
	--fs-ms: calc(var(--fs-m)*0.9);
	--fs-s: calc(var(--fs-m)*0.85);
	--fs-ss: calc(var(--fs-m)*0.75);
	--fs-xs: calc(var(--fs-m)*0.6);
	
	/* ROUND CORNER */
	
	--radius-regular : var(--fs-s);
	--radius-big : var(--fs-l);
}




html {
	font-size: var(--fs-m);
	font-weight: 400;
	line-height: 160%;
	font-family: "Roboto", sans-serif;
	scroll-behavior: smooth;
	color: var(-c-900);
	background-color: var(--c-100);
}


/* =====================================================
   STRUCTURE
===================================================== */



.flex-col, main, .container {
	display: flex;
	flex-direction: column;
	gap: var(--fs-xl);
	justify-content: center;
	align-items: start;
}

.half {
width: 50%;
}

.container {
	margin: 0 auto;
	width: var( --container-size);
	gap: 0;
}


header {
  position: relative;
  width: 100%;
  background-color: var(--c-700);
  height: auto;
}

header img.header-bg {
  position: absolute;
  inset: 0; 
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  z-index: 0;
}



header::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(rgba(0,0,0,0.6) 25%, rgba(0,0,0,0.4) 100%);
  z-index: 1;
}

header .container {
  position: relative;
  z-index: 2;
}

 .header-edito {
	padding-top: 7%;
	padding-bottom: 12%;
	width: 60%;
}

.header-edito h1, 
.header-edito p {
	text-shadow: 0 2px 10px rgba(0, 0, 0, 0.4);
}

.header-edito p {
font-size: var(--fs-l);
font-weight: 300;
line-height: 150%;
text-wrap: balance;
}

#menu-0 header .header-bg { object-position: bottom right; }
#menu-0 .header-edito p {color: var(--c-100);
	
}

#menu-0 .header-edito .cta-discrete,
#menu-4 .header-edito .cta-discrete, 
#menu-5 .header-edito .cta-discrete {
	color: rgba(255, 255, 255, 0.7);
	background-image: url(../media/picto_d.svg);
	border: 1.5px solid rgba(255, 255, 255, 0.25);
	background-color:  rgba(0, 0, 0, 0.05);
}

#menu-4 .header-edito .cta-discrete,
#menu-5 .header-edito .cta-discrete {
	background-image: url(../media/picto_d.svg);
}


#menu-0 .header-edito .cta-discrete:hover,
#menu-4 .header-edito .cta-discrete:hover,
#menu-5 .header-edito .cta-discrete:hover {
	background-color:  rgba(0, 0, 0, 0.01);
	color: rgba(255, 255, 255, 1);
	border: 1.5px solid rgba(255, 255, 255, 0.3);
	background-position: center right 10px;
	box-shadow: 35px 10px 40px rgba(255, 154, 0, 0.2), -35px -10px 40px rgba(151, 75, 161, 0.2);

}





.temp, ul li.temp a {
	color: rgb(185, 185, 185);
}

main {
    margin: 0 auto;
    padding-block: var(--fs-xxxxl);
    width: var( --container-size);
    gap: var(--fs-xxxxl);
}

 section {
	width: 100%;
	padding-block: var(--fs-xl);
	display: flex;
	justify-content: space-between;
	gap: var(--fs-l);
	flex-wrap: wrap;
}

.col-6040 {
	display: grid;
	gap: var(--fs-xxxl);
	grid-template-columns: 2fr 1fr;
}



.mere-intro {
	background-color: transparent;
	align-items: center;
	background-size: 200px;
	background-position: top 30px left 0;
	background-repeat: no-repeat;
}


.mere-intro > :first-child {
	justify-content: space-between;
	padding-left : 200px;	
}

.mere-intro > :last-child {
	background-color: var(--c-800);
	color: white;
	padding :  var(--fs-xxl) var(--fs-xxxl);
	border-radius: var(--fs-s);
}

.mere-intro > :last-child h2 {
	font-size: var(--fs-xl);
	color: var(--c-500);
}

.mere-intro > :last-child ul  {
	width: 100%;
	
}

.mere-intro > :last-child li {
	width: 100%;
}


.mere-intro > :last-child li a {
	height: auto;
	width: 100%;
	display: block;
	font-size: var(--fs-s);
	line-height: 140%;
	position: relative;
	padding-block: 3px;
	padding-left: 15px;
	color: var(--c-200);
	transition: all ease-in-out 200ms;
}

.mere-intro > :last-child li a:hover {
	color: white;
	padding-left: 18px;
	}

.mere-intro > :last-child li a::before {
	color: var(--c-500);
	content: '•';
	font-size: var(--fs-l);
	position :absolute;
	top: 50%;
	  left: 0%;
	  transform: translateY(-50%);
}


.home-methodo {
	display: grid;
	gap: var(--fs-xl);
	align-items: flex-end;
	grid-template-columns: 1fr 1fr;
}

.home-methodo div:first-child {
	padding-right: 50px;
}


.home-methodo .cta {
	background-image: url(../media/picto_d.svg);
}

.home-methodo ul {
	display: flex;
	background-color: var(--c-800);
	color: white;
	padding :  var(--fs-xxl) var(--fs-xl);
	border-radius: var(--fs-s);
	gap: var(--fs-m);
	flex-wrap: wrap;
}

.home-methodo hr {
	border-top: 1.5px solid var(--c-900);
	border-bottom: 1px solid var(--c-700);
}

.home-methodo li {
	flex: 1 1;
	min-width: 130px;
	font-size: var(--fs-s);
	line-height: 140%;
	position: relative;
	color: var(--c-300);
}

.home-methodo li strong {
	color: white;
	width: 100%;
    display: inline-block;
	font-size: var(--fs-m);
	line-height: 130%;
	margin-bottom: 5px;
}

.home-methodo li strong::before {
	content: "› ";
	color: var(--c-500);
}


.home-methodo .mardis {
	display: flex;
	gap: 20px;
	align-items: center; 
		
	& p { font-size: var(--fs-s); 		color: var(--c-300); line-height: 150%;
		& a { color: var(--c-500); text-decoration: underline;
			&:hover {color: var(--c-400);
			}
		}
	}
	
	& span {display: block; width: 50px; aspect-ratio: 1 / 1; border-radius: 100px; background-color: var(--c-500); background-image: url(../media/portrait_2.png); background-size: 100%; border: 2px solid var(--c-700); flex-shrink: 0;
		
	}
}

.mere-main, .bothsides {
	padding: var(--fs-xl);
	border-radius: 10px;
	background-color: var(--c-100);
	justify-content: start;
	align-items: center;
	width: 100%;
}

.mere-main > div {
	width: 80%;
}

.mere-main > div span {
	display: block;
	width: clamp(25px, 4vw, 40px);
	aspect-ratio: 1 / 1;
	background-repeat: no-repeat;
	background-size: 100%;
	margin-bottom: -15px;
}

.mere-main > ul, .bothsides div:last-child {
	background-color: white;
	align-items: stretch;
	justify-content: start;
	gap : 0;
	padding :  var(--fs-xxl) var(--fs-xxxl);
	border-radius: 7px;
	border: 1px solid var(--c-neutral-400);
}



.mere-main li a {
	border-bottom: 1px solid var(--c-200);
	line-height: 140%;
	position: relative;
	display: block;
	width: 100%;
	color: var(--c-800);
	padding-block: var(--fs-m);
	padding-right: 50px;
	padding-left: 5px;
	font-size: var(--fs-ms);
	text-wrap: balance;
	transition : all ease-in-out 200ms;
}



.mere-main li a:hover {
	border-bottom: 1px solid var(--c-300);
}

.mere-main li:last-child a {
	border: none;
}

.mere-main li a:after {
	content: 'voir';
	color : white;
	padding : 3px 3px 2px 3px;
	line-height: 100%;
	background-color: var(--c-700);
	font-size: 9px;
	text-transform: uppercase;
	font-weight: 900;
	position : absolute;
	top : 50%;
	transform: translateY(-50%);
	right : 2px;
	border-radius: 3px;
	transition: all ease-in-out 150ms;
}

.mere-main li a:hover:after {
	right : 0px;
	background-color: var(--c-800);
}

.mere-main li.temp a:after { background-color: var(--c-neutral-400);}
.mere-main li.temp a:hover:after {background-color: var(--c-neutral-500); right: 2px;}


.bothsides {
	align-items: flex-end;
}

.bothsides div:first-child {
	gap: var(--fs-xxxl);
}

.bothsides div:first-child div {
	display: grid;
	  gap: 1rem;
	  width: 100%;
	  box-sizing: border-box;
	  
	
	  /* Colonnes fluides, largeur mini 250px, sinon elles s'étirent */
	  grid-template-columns: repeat(
		auto-fit,
		minmax(min(100%, max(250px, calc((100% - 1rem) / 2))), 1fr)
	  );
	  background-color: transparent;
	  padding: 0;
	  border: none;
}
.bothsides div:first-child div > :last-child {
  grid-column: 1 / -1;
  background-color: var(--c-50);
  border: 1px dashed #cdcdcd;
  box-shadow: 0 0 0 rgba(0,0,0,0);
}

.bothsides article {
	border: 1px solid white;
	padding: var(--fs-xxl) var(--fs-xl);
	border-radius: 7px;
	font-size: var(--fs-ms);
	line-height: 130%;
	background-color: var(--c-50);
	box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
}

.bothsides article h3 {
	font-size: var(--fs-l);
	margin-bottom: 10px;
	color: var(--c-700);
}

.bothsides div:last-child, .panel {
	gap : var(--fs-xl);
	background-color: white;
}

.panel {
	padding: var(--fs-xxl) var(--fs-xxxl);
	border-radius: var(--fs-s);
	align-self: flex-start;
}


.bothsides div:last-child li, .panel li {
	padding-left: 15px;
	position: relative;
	line-height: 130%;
	margin-bottom: var(--fs-xs);
	font-size: var(--fs-s);
	color: var(--c-500);
}
.panel li { color: var(--c-700);}

.bothsides div:last-child li:before, .panel li:before {
	content: '•';
	position: absolute;
	top: 0px;
    left: 0%;
}

.bothsides div:last-child p, .panel p {
	font-size: var(--fs-ms);
	line-height: 150%;
}


.conf {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: var(--fs-xxxxl);
	gap: var(--fs-ss);
}

.conf article {
	min-width: 300px;
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: space-between;
	align-items: flex-start;
	gap: var(--fs-l);
	background-color: white;
	padding: var(--fs-xl);
	border-radius: 10px;
	box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
	position: relative;
	
	&.past {
		background-color: rgba(255, 255, 255, 0.3);
		border: 2px dashed white;
			& div.author p em {text-decoration: line-through;  color: var(--c-300);}
	}
}

.conf article div.author {
	width: 100%;
	display: flex;
	justify-content: flex-start;
	gap: var(--fs-m);
	align-items: center;
	
	& p {color: var(--c-500); font-weight: 600; line-height: 130%;
		& em { color: var(--c-700); font-weight: 400;}
	}
}


.conf div.author span {
	display: block;
	width: 40px;
	aspect-ratio: 1 / 1;
	background-color: var(--c-500);
	border-radius: 200px;
	background-size: cover;
	
	&.face-1 { background-image: url(../media/portrait_1.png);}
	&.face-2 { background-image: url(../media/portrait_2.png);}
	&.face-3 { background-image: url(../media/portrait_3.png);}
	
}








.contact-box, .mardi-box {
	padding: var(--fs-xl);
	border-radius: 10px;
	align-items: center;
	grid-template-columns: 2fr 1fr;
	display: grid;
	gap: var(--fs-xxxl);
	background-image: url(../media/contact_3.jpg);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
}

.contact-box h2, .mardi-box h3 {
	color: white;
}



.contact-box ul, .contact-form ul {
	
	background-color: rgba(30, 23, 23, 0.15);
	backdrop-filter: blur(17px);
	padding :  var(--fs-s) var(--fs-xxxl);
	border-radius: 7px;
	gap: 0;
	flex-wrap: wrap;
	border-top: 1px solid rgba(255, 255, 255, 0.2);
	border-bottom: 1px solid rgba(37, 27, 19, 0.2);
	min-width: 250px;
	transition: all linear 200ms;
}
.contact-box li {
	width: 100%;
}

.contact-box ul:has(li a:hover) {
	background-color: rgba(30, 23, 23, 0.40);
	backdrop-filter: blur(20px);
	border-top: 1px solid rgba(255, 255, 255, 0.3);
	border-bottom: 1px solid rgba(37, 27, 19, 0.15);
}

.contact-box li:first-child {
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
.contact-box li:last-child {
	border-top: 1px solid rgba(255, 255, 255, 0.25);
}

.contact-box li a {
	font-size: var(--fs-m);
	font-weight: 500;
	color: var(--c-500);
	line-height: 130%;
	display: block;
	height: auto;
	width: 100%;
	padding: var(--fs-m);
	padding-left: 0;
	border-radius: 5px;
	transition: all ease-in-out 200ms;
	font-weight: 800;
}

.contact-box li a:hover {
	color: var(--c-400);
}


.contact-box li a p {
	line-height: 180%;
	font-weight: 400;
	color: var(--c-100);
	width: 100%;	
}

.contact-form {
	grid-template-columns: 1fr 1fr;
	background-image: none;
	padding: 0;
	overflow: hidden;
	gap: 0;
	background-color: var(--c-800);
}

.contact-form .contactlink {
	background-image: url(../media/contact4.jpg);
	background-size: cover;
	background-position: center center;
	background-repeat: no-repeat;
	padding: var(--fs-xl);
	justify-content: space-between;
	height: 100%;
	align-items: stretch;
}

.contact-form2 .contactlink {
	background-image: url(../media/contact4b.jpg);
}



.contact-form .contactlink li:first-child, .contact-form .contactlink li:nth-child(2) {
	border-bottom: 1px solid rgba(0, 0, 0, 0.15);
}
.contact-box li:last-child, .contact-form .contactlink li:nth-child(2){
	border-top: 1px solid rgba(255, 255, 255, 0.25);
}

.mail {
	align-items: center;
	justify-content: center;
	color: var(--c-300);
	text-align: center;
	padding: var(--fs-l);
}

.mail a { color: var(--c-500);}

.mail img {
width: 150px;}

.contact-form #contactForm {
	background-color: var(--c-8blur00);
}


.mardi-box {
	padding: var(--fs-xxl) var(--fs-xl);
	grid-template-columns:  2fr 1fr;
	background-image: url(../media/mardi.jpg);
	color: white;
	width: 100%;
}



.fille-main {
	background-color: white;
	padding: 0;
	border-radius: var(--fs-s);
	overflow: hidden;
	box-shadow: 0px 2px 6px rgba(0, 0, 0, 0.2);
}



 .fille-main > :first-child {
	padding : var(--fs-xxxl);
 }
 
 .fille-main > :first-child p {
	/* margin-bottom: 20px; */
  }
  
ul.classic
  
  .fille-main > :first-child ul , ul.classic {
	  list-style-position: outside;
	  padding-left: 15px;
   }
   .fille-main > :first-child ul li , ul.classic li {
   list-style-type: disc;
   line-height: 150%;
   margin-bottom: 10px;
   color: var(--c-800);
   }
   
   .fille-main > :first-child ul li:last-child {
	   margin-bottom: 0;
   }
   
   .fille-main > :first-child ul li::marker {
	   color: var(--c-500);
   } 
   

 .fille-main > :last-child {
	background-color: var(--c-neutral-100);
	border-left: 1px solid var(--c-neutral-400);
 }
 
 .fille-main > :last-child div {
	padding : var(--fs-xxxl) var(--fs-xxl);
  }
  
  .fille-main > :last-child div:last-child {
	border-top: 1px solid var(--c-neutral-400);
  }
 
 .fille-main > :last-child h3 {
	color: var(--c-600);
	font-size: var(--fs-l);
 }
 
 .fille-main > :last-child ul {
	
 }
 
 .fille-main > :last-child li {
	font-size: var(--fs-s);
	color: var(--c-neutral-700);
	padding-left: 40px;
	background-image: url(../media/picto_check.svg);
	background-repeat: no-repeat;
	background-position: left -2px;
	background-size: 30px;
	line-height: 150%;
	margin-bottom: var(--fs-s);
	padding-block: 3px; 
  }






section.getmore {
	width: 100%;
	gap :var(--fs-xxxl);
	background-size: 200px;
	background-position: top right;
	background-repeat: no-repeat;
}

section.getmore > div {
	min-height: 160px;
	padding-right: 30%;
}

.sub-1 section.getmore, .sub-1 .mere-intro {background-image: url(../media/illu_theme_1.png);}
.sub-2 section.getmore, .sub-2 .mere-intro {background-image: url(../media/illu_theme_2.png);}
.sub-3 section.getmore, .sub-3 .mere-intro {background-image: url(../media/illu_theme_3.png);}
.sub-4 section.getmore, .sub-4 .mere-intro {background-image: url(../media/illu_theme_4.png);}
.sub-5 section.getmore, .sub-5 .mere-intro {background-image: url(../media/illu_theme_5.png);}
.sub-6 section.getmore, .sub-6 .mere-intro {background-image: url(../media/illu_theme_6.png);}




.getmore ul {
	width: 100%;
	display: grid;
	grid-template-columns: 
		repeat(auto-fill, minmax(280px, 1fr));
	gap: 15px;
	width: 100%;
	grid-auto-rows: auto;
	align-items: stretch;
}


.getmore ul a {
 width: 100%;
 height: 100%;
  display : inline-block;
  overflow: hidden;
  padding-bottom: var(--fs-xxl);
  background-color: white;
  border-radius: var(--fs-s);
  position: relative;
  transition: all ease-in-out 0.2s;
  box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
 }

.getmore ul a:hover {
	box-shadow: 0 3px 10px rgba(0, 0, 0, 0.3) ;
}

.getmore article {
	width: 100%;
	gap: 5px;
}

.getmore article p, .getmore article h3 {
	width: 100%;
	padding-inline: var(--fs-l);
	
}
.getmore article p {
	color: var(--c-800);
	font-size: var(--fs-ss);
	font-weight: 500;
	transition: color ease-in-out 250ms;
}
.getmore article h3 {
	font-size: var(--fs-m);
}

span.cover {
	width: 100%;
	aspect-ratio:  2 / 1;
	margin-bottom: var(--fs-m);
	background-size: cover;
	background-position: center center;
	opacity: 0.95;
	transition: opacity ease-in-out 200ms;
}

.getmore a:hover span.cover {
	opacity: 1;
}

.getmore a:hover article p {
	color: var(--c-600);
}

.etapes {
  display: grid;
  padding-block: var(--fs-xxxl);
  gap: var(--fs-m);
  width: 100%;
  box-sizing: border-box;
  grid-template-columns: repeat(	auto-fit, minmax( min(100%, max(350px, calc((100% - 2 * 1.25rem) / 3))), 1fr	));
}

.etapes > div {
	justify-content: flex-start;
	padding-right: 30px;
}



/* cercle disque disc rond jaune */

body{
background-image: url(../media/disque.svg);
background-repeat: no-repeat;

}

#menu-0 { background-size: 35%; background-position: top 170vh right -10%; }
#menu-4 { background-size: 40%; background-position: top 15vh right -30%; }
body:has(section.mere-intro) {background-color: var(--c-50); background-size: 35%; background-position: top 25vh right -10%;  }
body:has(section.fille-main) { background-size: 35%; background-position: top 55vh right 10px; }
#menu-3 { background-size: 40%; background-position: top 15vh right -30%; }



#menu-0 .etapes {
	gap: var(--fs-ss);
}
#menu-0 .etapes > div {
	justify-content: space-between;
	padding: var(--fs-xl);
	padding-right: 50px;
	background-position: bottom -20px right -20px;
	background-size: 140px;
	background-repeat: no-repeat;
	gap: var(--fs-xxxl);
	align-items: flex-start;
	background-color: white;
	border-radius: 10px;
	box-shadow: 0 2px 3px rgba(0, 0, 0, 0.1);
}

#menu-0 .etapes > div p { font-size: var(--fs-s);  line-height: 150%;}

#menu-0 .etapes > div:nth-child(1) { background-image: url(../media/illu_theme_1.png); }
#menu-0 .etapes > div:nth-child(2) { background-image: url(../media/illu_theme_2.png);}
#menu-0 .etapes > div:nth-child(3) { background-image: url(../media/illu_theme_3.png);}
#menu-0 .etapes > div:nth-child(4) { background-image: url(../media/illu_theme_4.png);}
#menu-0 .etapes > div:nth-child(5) { background-image: url(../media/illu_theme_5.png);}
#menu-0 .etapes > div:nth-child(6) { background-image: url(../media/illu_theme_6.png); background-position: bottom -30px right -25px; 
	background-color: var(--c-150);
	box-shadow: 0 2px 3px rgba(0, 0, 0, 0.25);}


.etapes ul {
	width: 80%;
	display: flex;
	gap: 6px;
	flex-wrap: wrap;
}

.etapes ul li {
	color: var(--c-800);
	background-color:  var(--c-150);
	font-size: var(--fs-ss);
	border-radius: 4px;
	padding: 4px 5px;
	line-height: 100%;
}

.etapes .cta {	background-image: url(../media/picto_cta_read.svg); 	 }
.etapes .cta:hover { 	background-image: url(../media/picto_cta_read2.svg); }



.people {
	display: grid;
	/* grid-template-columns: repeat(	auto-fit, minmax( min(100%, max(350px, calc((100% - 2 * 1.25rem) / 2))), 1fr	)); */
	grid-template-columns: 1fr;
	gap: 2rem;
	align-items: start;
	width: 100%;
}

.people div:first-child {
	gap: var(--fs-xxxl);
	max-width: 500px;
}

.people ul {
	width: 100%;
  list-style: none;
  margin: 0;
  padding: 0;
  border-radius: 10px;
  display: grid;
  gap: 1px;
  overflow: hidden;

  grid-template-columns: repeat(4, 1fr);

}
.people ul li {
	border-radius: 5px;
	overflow: hidden;
	aspect-ratio: 1 / 1.2; 
	position: relative;
	background-color: rgb(192, 192, 192);
	}
	
	

.people ul li div {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	background-color: rgba(0, 0, 0, 0.65);
	color: white;
	font-size: var(--fs-s);
	line-height: 140%;
	padding: var(--fs-xs);
}


.people ul li:hover div {
	background-color: rgba(0, 0, 0, 0.8);
}


.people ul li div span {
	display: block;
	width: 100%;
	height: 0;
	overflow: hidden;
	transition: height ease-in-out 200ms, color ease-in-out 600ms ;
	font-size: var(--fs-ss);
	margin-top : 0px;
	color: transparent;
	overflow-y: auto;    /* scroll vertical si besoin */
	overflow-x: hidden;
	
	
}

.people ul li:hover div span {
	height: auto;
	margin-top :10px;
	color: var(--c-400);
}


.people ul li img {
	width: 100%;
	opacity: 0.92;
	transition: opacity ease-in-out 600ms;
}

.people ul li:hover img {
	opacity: 0.7;
}








.readmore-details > summary {
  list-style: none;    
  cursor: pointer;
}

.readmore-details > summary::-webkit-details-marker {
  display: none;
}

.readmore-toggle {
  display: inline-flex;
  align-items: center;
  gap: 0.35rem;

  margin-top: 0.5rem;
  padding: 0.35rem 0;
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--c-600);
}

/* Le + visuel */
.readmore-toggle::after {
  content: "+";
  font-size: 1.1rem;
  display: inline-block;
  transition: transform .25s ease;
  transform-origin: center;
  line-height: 0; /* bien centré */
}

/* Quand c’est ouvert → on pivote le + en × */
.readmore-details[open] .readmore-toggle::after {
  transform: rotate(45deg);
}

/* Zone dépliée */
.readmore-content {
  margin-top: .75rem;
  line-height: 150%;
  display: flex; 
  flex-direction: column;
  gap: var(--fs-m);
}
















.fulltext {
	width: 90%;
	gap : var(--fs-xxxl);
}

.fulltext a {
	color: var(--c-500);
	text-decoration: underline;
}

.fulltext ul.liste-cookies ul  {
	margin-block: 10px;
}

.fulltext ul.liste-cookies strong {
	font-weight: 800;
}


.fulltext ul.liste-cookies ul strong {
	font-weight: 400;
	color: var(--c-500);
}

.access  strong {
	font-weight: 800;
}

.access ul ul li {list-style-type: disc; list-style: inside;}
.access ul { margin-bottom: 15px;}

.nopad {
	padding: 0;
}

.pad-xl {
	padding: var(--fs-xl);
}

hr {
	border: none;
	border-top : 1px solid var(--c-neutral-500);
	width: 100%;
	height: 1px;
}




	


h1, h2, h3 {
	font-family: "Playfair Display", serif;
	  font-optical-sizing: auto;
	  font-weight: 400;
	  font-style: normal;
	  font-variation-settings:"wdth" 100;
	font-size: var(--fs-xxxxl);
	color : white;
	line-height: 110%; 
	text-wrap: balance;
}

h2 {
	color: var(--c-800);
	font-size: var(--fs-xxxl);
	font-weight: 500;
	line-height: 130%; 
	letter-spacing: -0.8px;
}

h3 {
	font-size : var(--fs-xxl);
	line-height: 130%; 
	color: var(--c-700);
}

 h4{
	  font-weight: 600;
	  font-size: var(--fs-l);
	  color: var(--c-800);
  }


.intro {
	font-family: "Robot", sans-serif;
	font-size: var(--fs-xl);
	font-weight: 300;
	line-height: 145%;
	color: var(--c-700);
	text-wrap: pretty;
}

p strong, li strong {
	font-weight: 700;
}

p.legende {
	font-size: var(--fs-s);
	font-weight: 400;
	line-height: 150%;
	color: var(--c-neutral-700);
	text-wrap: pretty;
}


a.cta {
	background-color: var(--c-400);
	color: var(--c-950);
	border : 1px solid var(--c-300);
	padding: var(--fs-ss);
	padding-right: 60px;
	
	border-radius: 5px;
	background-image: url(../media/picto_chat.svg);
	background-size: 30px;
	background-repeat: no-repeat;
	background-position: right 10px center ;
	transition : all ease-in-out 250ms;
	line-height: 120%;
	font-weight: 600;
}


  
a.cta:hover {
	background-color: var(--c-500);
}

a.cta-discrete {
	background-color: transparent;
	color: var(--c-800);
	background-image: url(../media/picto_download.svg);
	cursor: pointer;
}

a.cta-mail {
	background-image: url(../media/picto_mail.svg);
}

a.cta-discrete:hover {
	background-color: white;
	border : 1px solid var(--c-500);
}

a.link {
	color: var(--c-600);
	transition: all ease-in-out 200ms;
}

a.link:hover {
	color: var(--c-700);
	text-decoration: underline;
}

span.tag {
	display: inline;
	background-color: var(--c-500);
	color: var(--c-900);
	line-height: 100%;
	padding : 9px 14px 9px 14px;
	/* text-shadow: 0 1px 2px rgba(5, 48, 35, 0.4); */
	background-repeat: no-repeat;
	background-size: 25px;
	background-position: left 8px center;
	border-radius: 3px;
	font-size: var(--fs-s);
	font-weight: 700;
}

span.tag-picto {
	padding-left : 40px;
}

.tag-1  { background-image: url(../media/picto_cat_1.svg); }
.tag-2  { background-image: url(../media/picto_cat_2.svg); }
.tag-3  { background-image: url(../media/picto_cat_3.svg); }
.tag-4  { background-image: url(../media/picto_cat_4.svg); }
.tag-5  { background-image: url(../media/picto_cat_5.svg); }
.tag-6  { background-image: url(../media/picto_cat_6.svg); }
.tag-7  { background-image: url(../media/picto_cat_7.svg); }
.tag-8  { background-image: url(../media/picto_cat_8.svg); }
.tag-9  { background-image: url(../media/picto_cat_9.svg); }
.tag-10 { background-image: url(../media/picto_cat_10.svg); }
.tag-11 { background-image: url(../media/picto_cat_11.svg); }
.tag-12 { background-image: url(../media/picto_cat_12.svg); }
.tag-13 { background-image: url(../media/picto_cat_13.svg); }
.tag-14 { background-image: url(../media/picto_cat_14.svg); }
.tag-15 { background-image: url(../media/picto_cat_15.svg); }
.tag-16 { background-image: url(../media/picto_cat_16.svg); }
.tag-17 { background-image: url(../media/picto_cat_17.svg); }
.tag-18 { background-image: url(../media/picto_cat_18.svg); }
.tag-19 { background-image: url(../media/picto_cat_19.svg); }


/* › › › › › › › › › › › › › › ›  A R I A N E */


.ariane {
	display: flex;
	width: 100%;
	flex-wrap: wrap;
	line-height: 120%;
	margin-bottom: -20px;
}

.ariane li::after {
	content: '›';
	margin-inline: 5px;	
	font-size: 12px;
	color: var(--c-100);
	opacity: 0.5;
}

.ariane li:last-child::after {
	content: none;
	margin: 0;
}

.ariane li a  {
	display: inline;
	line-height: 100%;
	color: var(--c-100);
	font-size: var(--fs-s);
	font-weight: 500;
	opacity: 0.5;
	transition: all ease-out 0.2s;
}

.ariane li:last-child a {
	opacity: 0.8;
}

.ariane li a:hover  {
	opacity: 1;
	font-size: 600;
}

.grecaptcha-badge {
  width: 70px !important;
  overflow: hidden !important;
  transition: all 0.3s ease !important;
  right: 0px !important;
  bottom : 70px!important;
}

.grecaptcha-badge:hover {
  width: 256px !important;
}




@media only screen and (max-width: 1000px) {
	
	
	span.tag {display:none;}
	
	:root {
		--container-size : 92%;
		--fs-m: 18px;
		--fs-l: calc(var(--fs-m)*1.10);
		--fs-xl: calc(var(--fs-m)*1.35);
		--fs-xxl: calc(var(--fs-m)*1.6);
		--fs-xxxl: calc(var(--fs-m)*1.8);
		--fs-xxxxl: calc(var(--fs-m)*2.5);	
	}
	
	html {line-height: 140%;}
	h1 { font-size: 36px;}
	h2 { font-size: 28px;}
	h3 { font-size: 22px;}
	
	header .header-edito {  padding-inline: calc( calc(100% - var(--container-size)) / 2);  width: 90%;  }
	header .header-edito {padding-top: 10%; padding-bottom: 20%;} 
	#menu-0 header .header-bg { object-position: 90% center; }
	
	.ariane { margin-bottom: -10px; }
	
	/* header .header-edito {flex-direction: column-reverse; padding-block: 20%;  padding-inline: calc( calc(100% - var(--container-size)) / 2);  gap: 0; background-image: linear-gradient(rgba(0, 0, 0, 0.0) 25%, rgba(0, 0, 0, 0.3) 50% );}
	#menu-0 header {background-position: bottom right -100px;	}
	#menu-0 header .header-edito {flex-direction: column; gap: var(--fs-l); background-image: linear-gradient( rgba(0, 0, 0,0) 0%, rgba(0, 0, 0, 0.6) 60%); }
	#menu-0 header .header-edito .cta, .home-methodo ul {display: none;}
	#menu-0  .header-edito p, #menu-3  .header-edito p {	font-size: var(--fs-m); width: 90%; }
 */
	
	.home-edito, .fulltext, .half { width: 100%; }
	.intro {line-height: 140%; font-weight: 200; font-size: var(--fs-l); }
	a.cta { padding: var(--fs-m) var(--fs-ss); padding-right: 50px;}
	.mobile-hide {display: none;}
	
	.col-6040, .contact-box, .mardi-box, .home-methodo { gap: var(--fs-xxxl); grid-template-columns: 1fr;  }
	.contact-form {gap:0;}
	
	.mere-intro > div:first-child {padding-left: 0; }
	.mere-intro > :last-child li a { padding-block: 10px; font-size: var(--fs-m);}

	.mere-main > div {width: 100%; font-size: var(--fs-s);}
	.mere-main > ul {padding :  var(--fs-xs) var(--fs-m); border-radius: 10px;}
	.mere-main > ul a {font-size: var(--fs-m); }
	.mere-main li a:after {content: '›'; font-size: var(--fs-xl); font-weight: 700; padding: 0px 8px 2px 8px; border-radius: 7px;}
	
	.fille-main > :first-child,  .fille-main > :last-child div {padding : var(--fs-xxxl)  var(--fs-xl); }
	.fille-main > :last-child {border:none; border-top: 1px solid var(--c-neutral-400); }
	
	.mere-intro,
	section.getmore  { padding-right: 0; padding-left: 0; padding-top : 250px; background-size: 200px; background-position: center top;  }
	
	section.getmore div {min-height: auto;}
		
	.getmore ul {gap: var(--fs-l); }
	.getmore ul a { padding-bottom: var(--fs-l);}
	.getmore ul a article { gap: 0;}
	.getmore ul a h3 { font-size: var(--fs-l); }
	section.getmore > div {padding-right: 0%; }
	span.cover {aspect-ratio:  2.5 / 1;}
	
	.people ul {  grid-template-columns: repeat(2, 1fr);}
	
	.etapes > div .cta { padding-block: var(--fs-ss) ;}
	
	#menu-4 .etapes {padding: 0; }
	#menu-4 .etapes div {padding: 0; background-color: transparent; box-shadow: none; }
	
	
	body:has(section.fille-main) { 	background-size: 90%; 	background-position: top 300px right -100px; 	}
	body:has(section.mere-intro) { background-size: 50%; background-position: top 25vh right -15%;  }
	#menu-0 { background-size: 75%; background-position: top 290vh right -80%; }
	#menu-4 { background-size: 60%; background-position: top 25vh right -30%; }
	
}




