body {
/*	background-image: url(Fonddegrade.jpg);*/
	margin-left:auto;
	margin-right:auto;
	font-family: Baskerville, Garamond, Times ,serif;
	color: #542f13;
	background-color:#fff;
	margin-bottom: 0px;
	margin-top : 0px;
  scroll-behavior: smooth;
  font-size: 1.5rem; 
}
@media only screen and (max-width: 700px){
	.body {
  	  font-size: 0.9rem; 
	}
}

.rouge{
	color: #deaba1;
	font-size: 1.2em;
}
@media only screen and (max-width: 900px){
	.rouge {
  	  text-align: center;
	}
}

a {
	text-decoration: none;
	color: #f60;
	font-weight: bold;
}
a:visited {
	text-decoration: none;
	color: #ddd;
}
a:hover {
	text-decoration: none;
	color: #f90;
}
a:active {
	text-decoration: none;
}

img {
	border-radius: 5px; 
	width: 100%;
}

input[type="checkbox"] {
	display:none;
}

label {
  /*color: #c60;*/
  color: #f60;
  font-size: 1.2em;
}
label:hover {
  color: #F90;
}

label::before {
  /*content: '\1F5BF';  closed folder */
  /*margin-left: -20px;
  padding-right: 10px;*/
	/*content: url("images/bulletFleche2.png");*/
}

input:checked + label::before {
  /*content: '\1F5C1';  open folder */
	/*content: url("images/bulletFleche3.png");*/
}

.tobeopen {
  display: none;
  position:relative;
  /*margin-left: 0px;*/
  margin-bottom:15px;
}

input:checked ~ .tobeopen {
  display: block;
}
input:checked + label {
  position:relative;
  /*font-weight: bold;
  color: #f90;
  font-size: larger;*/
}

.disponible {
	align-self: start; 
	padding-left: 10px; 
	padding-top: 10px; 
	padding-bottom: 0px; 
	gap: 0px;
}

.occupe {
	align-self: start; 
	padding-left: 10px; 
	padding-top: 0px; 
	padding-bottom: 0px; 
	gap: 0px;
}

li{
	list-style: none;
	/*margin: 0;
	padding: 0;
	margin-left: -30px;
	padding-left: 30px;*/
	list-style-image: url("images/bulletVolute.png");
	/*background-image: url("images/bulletVoluteGrand.svg");
	background-repeat: no-repeat;
	background-position: left center;
	background-size: 20px;*/
}

li::marker {
  /*font-size: 0.5em;*/
 /* height: 2px;*/
}

.ptvolute ul li{
	list-style: none;
	list-style-image: url("images/bulletVoluteMiniB.png");
}

.langue{
	position: fixed; 
	float: right;
	right: 20px; 
	margin-top: 20px;
	width: 60px;
}
@media only screen and (max-width: 700px){
	.langue {
		width: 40px;
	}
}

.logo {
	width: 40%;
	border-radius: 5px; 
	background-color: rgba(255, 255, 255, 0.7);
	height: 100%;
}
@media only screen and (max-width: 700px){
	.logo {
		width: 80%;
	}
}

.txtPres {
	width: 45%;
	margin-top: 20px;
}
@media only screen and (max-width: 700px){
	.txtPres {
		width: 95%;
	}
}

.titre{
	background-color: rgba(255, 255, 255, 0.85); 
	margin-top: 20px;
}
.divTitre{
	width: 40%;
}
@media only screen and (max-width: 700px){
	.divTitre {
		width: 60%;
	}
}

.titreBlanc {
	background-color: rgba(64, 40, 38, 0.6);
	/*background-color: rgba(60, 38, 2, 0.6);*/
}

.divUl{
	display: flex; 
	flex-direction : column; 
	justify-content: center; 
	align-items: center; 
	width: 40%; 
	border-radius: 5px; 
	background-color: rgba(255, 255, 255, 0.7); 
	padding:20px; 
	margin-bottom: 10px
}
@media only screen and (max-width: 700px){
	.divUl {
		width: 90%;
		padding: 10px; 
	}
}

.sectionPhoto{
	display: flex; 
	flex-direction: column; 
	justify-content: center; 
	align-items: center; 
	margin-top: 20px; 
	gap: 20px; 
	background-size:cover; 
	background-position: center;
	min-height: 500px; 
	align-items: center; 
}
@media only screen and (max-width: 700px){
	.sectionPhoto {
		font-size: 0.9rem;
	}
}

.sectionBlanc {
	display: flex; 
	flex-direction: column; 
	justify-content: center; 
	align-items: center; 
	margin-top: 20px; 
	gap: 20px;
}
@media only screen and (max-width: 700px){
	.sectionBlanc {
		font-size: 0.9rem;
	}
}

.map {
	border-radius: 5px;
	width : 42%; 
	height: 480px;
	margin-bottom: 20px;
	margin-top: 0px;
}
@media only screen and (max-width: 700px){
	.map {
	height: 300px;
	width : 94%; 
	}
}


#map{ /* la carte DOIT avoir une hauteur sinon elle n'apparaît pas */
	height:400px;
	width: 100px;
}

.sectionEnv{
	background-color: rgba(255, 255, 255, 0.6);
	margin-bottom: 20px;
	border-radius: 5px;
	padding: 10px; 
	width: 50%; 
	display: flex; 
	flex-direction: column;
	gap: 10px;
	align-items: center;
}
        
.galEnv{
	display: flex; 
	justify-content: center; 
	gap: 10px;
	align-items: center;
	width: 100%;
}

@media only screen and (max-width: 700px){
	.sectionEnv {
	width : 95%; 
	flex-wrap: wrap;
	}
}
.galEnv > div {
	width: 15%;
}

.galImm{
	width: 60%;
}
@media only screen and (max-width: 700px){
	.galImm {
	width : 95%; 
	}
}

.listePortraits {
	display: flex; 
	width: 50%; 
	justify-content: space-evenly; 
	align-items: center;
	gap: 10px;
}
@media only screen and (max-width: 700px){
	.listePortraits {
		width: 95%;
		gap: 5px;
		font-size: 0.9rem;
	}
}

.column20 {
	display: flex; 
	flex-direction: 
	column; width: 20%;
}

.just70 {
	width: 70%; 
	text-align:justify;
}
@media only screen and (max-width: 700px){
	.just70 {
	text-align: left;
	}
}

.sectionContact {
	background-color: rgba(64, 40, 38, 0.6);
	display: flex; 
	flex-direction: column; 
	justify-content: center; 
	align-items: center; 
	margin-top: 20px; 
	padding-bottom: 20px;
	gap: 20px;
}

.txCtc {
	width: 50%; 
	color: #fff; 
	text-align:center; 
}
@media only screen and (max-width: 700px){
	.txCtc {
	width: 90%; 
	font-size: 0.9rem;
	}
}

.formCtc {
	width: 50%; 
	color: #fff; 
	text-align:center;
}
@media only screen and (max-width: 700px){
	.formCtc {
	width: 90%; 
	font-size: 0.9rem;
	}
}

.part {
	display: flex; 
	flex-direction: column; 
	justify-content: center; 
	align-items: center; 
	width: 80%; 
	text-align: center;
}
@media only screen and (max-width: 700px){
	.part {
	width: 95%; 
	}
}

.imgPart {
	width: 6%;
}
@media only screen and (max-width: 700px){
	.imgPart {
	width: 8%; 
	}
}

.footer {
	background-color: #402826; 
	min-height: 40px; 
	color: #fff; 
	padding-bottom: 40px; 
	margin-bottom:0px; 
	padding-top: 20px; 
	font-size: 1rem; 
	display: flex; 
	width: 100%; 
	justify-content: space-evenly; 
	align-items: center;
}
@media only screen and (max-width: 700px){
	.footer {
		font-size: 0.6rem; 
		flex-direction: column;
		gap: 10px;
	padding-bottom: 10px; 
	padding-top: 10px; 
	}
}

.cgi {
	background-color: white; 
	padding: 5px;
	margin: 5px;
	width: 250px;
}
@media only screen and (max-width: 700px){
	.cgi {
	width: 150px;
	}
}

.styleConf{
	width: 20%; 
}
@media only screen and (max-width: 700px){
	.styleConf {
	width: 50%;
	}
}
.titreConf {
  /*color: #c60;*/
  color: #f60;
  font-size: 1.2em;
}

@media only screen and (max-width: 700px){
	.txtConf{
		justify-self: center; 
		text-align: justify;
	}
}

.copyright{
	padding: 10px; 
	font-size: small;
	color: #666;
	/*color: #999;*/
	text-align:center;
	background-color: #eee;
	/*background-color: #1c1111;*/
	/*background-color: rgba(64, 40, 38, 0.6);*/
}


/* ----- Galerie  ------------------------- -----------------  ------------------------- */
/* The Modal (background) */
.modalGalerie { /*utilisé: C4*/
  display: none; /* Hidden by default */
  grid-template-columns: 10% 1fr 10%;
  grid-template-rows: 5px 1fr;
  position: fixed; /* Stay in place */
  z-index: 100; /* Sit on top */
  padding-top: 0px; /* Location of the box */
  left: 0;
  top: 0;
  width: 100%; /* Full width */
  height: 100%; /* Full height */
  overflow: auto; /* Enable scroll if needed */
  background-color: rgb(0,0,0); /* Fallback color */
  background-color: rgba(0,0,0,0.9); /* Black w/ opacity */
  justify-items: center;
  align-items: center;
}

/* Modal Content (Image) */
.modalGalerieCont1, /*utilisé: C4*/
.modalGalerieCont { /*utilisé: C4*/
  background-color: #000;
  border:medium solid #333;
  border-radius:5px;
  animation-name: fadeGallery;
  animation-duration: 0.6s;
}

.modalGalerieCont1{ /*utilisé: C4*/
  animation-name: zoom;
  animation-duration: 0.6s;
}
/* Add Animation - Zoom in the Modal */
img.modalGalerieCont, /*utilisé: C4*/
img.modalGalerieCont1 { /*utilisé: C4*/
	padding: 30px;
	max-width: 100%;
	max-height: 95%;
  justify-self: center;
  align-self: center;
}

/* 100% Image Width on Smaller Screens */
@media only screen and (max-width: 700px){
  .modalGallery-content {
	  background-color:#099;
      width: 100%;
  }
} 

@keyframes zoom {
  from {transform:scale(0) ;}
  to {transform:scale(1));}
}

/* The Close Button */
.Close { /*utilisé: C4*/
  color: #ffffff;
  font-size: 4em;
  font-weight: bold;
  transition: 0.3s;
  justify-self: center;
  align-self:start;
}
.Close:hover {
	color: #ff9900;
  text-decoration: none;
  cursor: pointer;
}
@media only screen and (max-width: 700px){
  .Close {
	  font-size: 3em;
  }
} 

/* Next & previous buttons */
.prevGallery, .nextGallery { /*utilisé: C4*/
  cursor: pointer;
  color: white;
  font-weight: bold;
  font-size: 3em;
  justify-self:center;
  align-self:center;
}

.nextGallery { 
  /*right: 5%;*/
}
.prevGallery {
  /*left: 5%;*/
}
@media only screen and (max-width: 700px){
	.nextGallery { 
	  right: 2%;
  font-size: 1em;
	}
	.prevGallery {
	  left: 2%;
  font-size: 1em;
	}
} 

a.prevGallery:hover, a.nextGallery:hover {
	color: #ff9900;
}

 /* Style the Image Used to Trigger the Modal */
#myImg { /*utilisé: C4*/
}
.myImg {
}

/* Fading animation */
.fadeGallery {
  -webkit-animation-name: fade;
  -webkit-animation-duration: 1.5s;
  animation-name: fade;
  animation-duration: 1.5s;
}

@-webkit-keyframes fadeGallery {
  from {opacity: .4}
  to {opacity: 1}
}

@keyframes fadeGallery {
  from {opacity: .4}
  to {opacity: 1}
}	

/* slidein animation */
.slide {
  -webkit-animation-name: slide;
  -webkit-animation-duration: 1.5s;
  animation-name: slide;
  animation-duration: 1.5s;
}

@-webkit-keyframes slide {
  from {
		margin-left: 100%;
		}
  to {
		margin-left: 0%;
	  }
}

@keyframes slide {
  from {
		margin-left: 100%;
		}
  to {
		margin-left: 0%;
	  }
}	
.row2col1 { /*utilisé: L1, C4*/
	grid-column: 1 ;
	grid-row: 2; 
	z-index: 100;
}
.row2col2 { /*utilisé: L1, C4*/
	grid-column: 2 ;
	grid-row: 2; 
}
.row2col3 { /*utilisé: C4*/
	grid-column: 3 ;
	grid-row: 2; 
	z-index: 100;
}


/* formulaire et grille spécifique  -------------------------------------------------------*/
.grid4 { 
	display: grid;
	grid-template-columns: 1fr 2fr 1fr 2fr;
	margin-left:auto;
	margin-right:auto;
	grid-gap: 5px;
}
@media only screen and (max-device-width: 900px) {
	.grid4 { 
		grid-template-columns: 10% 1fr;
	}
}
.box1 { 
	grid-column: 1 ;
	grid-row: 1;   
}
@media only screen and (max-device-width: 900px) {
	.box1 { 
		grid-column: 1 / span 2;
		grid-row: 1;   
	}
}
.box2 { 
	grid-column: 2 ;
	grid-row: 1;   
}
@media only screen and (max-device-width: 900px) {
	.box2 { 
		grid-column: 1 / span 2;
		grid-row: 2;   
	}
}
.box3 { 
	grid-column: 3 ;
	grid-row: 1;   
}
@media only screen and (max-device-width: 900px) {
	.box3 { 
		grid-column: 1 / span 2;
		grid-row: 3;   
	}
}
.box4 { 
	grid-column: 4 ;
	grid-row: 1;   
}
@media only screen and (max-device-width: 900px) {
	.box4 { 
		grid-column: 1 / span 2;
		grid-row: 4;   
	}
}
.box1R2 { 
	grid-column: 1 ;
	grid-row: 2;   
}
@media only screen and (max-device-width: 900px) {
	.box1R2 { 
		grid-column: 1 / span 2;
		grid-row: 5;   
	}
}
.box2R2 { 
	grid-column: 2 ;
	grid-row: 2;   
}
@media only screen and (max-device-width: 900px) {
	.box2R2 { 
		grid-column: 1 / span 2;
		grid-row: 6;   
	}
}
.box3R2 { 
	grid-column: 3 ;
	grid-row: 2;   
}
@media only screen and (max-device-width: 900px) {
	.box3R2 { 
		grid-column: 1 / span 2;
		grid-row: 7;   
	}
}
.box4R2 { 
	grid-column: 4 ;
	grid-row: 2;   
}
@media only screen and (max-device-width: 900px) {
	.box4R2 { 
		grid-column: 1 / span 2;
		grid-row: 8;   
	}
}
.span4 { 
	grid-column: 1 / span 4 ;
	grid-row: 3 ; 
}
@media only screen and (max-device-width: 900px) {
	.span4 { 
		grid-column: 1 ;
		grid-row: 9;   
	}
}
.span4R4 { 
	grid-column: 1 / span 4 ;
	grid-row: 4 ; 
}
@media only screen and (max-device-width: 900px) {
	.span4R4 { 
		grid-column: 1 / span 2;
		grid-row: 10;   
	}
}
.box1R5 { 
	grid-column: 1 ;
	grid-row: 5;   
	align-self: center;
	justify-self: right;
	padding-right: 5px;
	padding-top: 10px;
}
@media only screen and (max-device-width: 900px) {
	.box1R5 { 
		grid-column: 1 ;
		grid-row: 11;   
		justify-self: center;
		padding-right: 0px;
	}
}
.span3R5 { 
	grid-column: 2 / span 3 ;
	grid-row: 5 ; 
	padding-top: 10px;
}
@media only screen and (max-device-width: 900px) {
		.span3R5 { 
			grid-column: 2 ;
			grid-row: 11;   
		}
}
.span4R6 { 
	grid-column: 1 / span 4 ;
	grid-row: 6 ; 
	justify-self: center;
	padding-top: 5px;
	padding-bottom: 5px;
}
@media only screen and (max-device-width: 900px) {
	.span4R6 { 
		grid-column: 1 / span 2;
		grid-row: 12;   
	}
}
.span4R7 { 
	grid-column: 1 / span 4 ;
	grid-row: 7 ; 
}
@media only screen and (max-device-width: 900px) {
	.span4R7 { 
		grid-column: 1 / span 2;
		grid-row: 13;   
	}
}

/* case à cocher pour formulaire contact */
input[type="checkbox"].checkbox { 
  display: none;
}
input[type="checkbox"].checkbox + label::before {
  /*content:'';*/
  /*border: 3px solid #00B7E8;*/
  /*border-radius: 2px;
  padding: 0 0.6rem;
  padding-right: 1rem;
  padding-left: 1rem;
  margin-right: 0.6rem;*/
  width: 50px;
  height: 50px;
  background-image: url("/images/ckbox_empty_w.png");
  background-size:contain;
  background-color: #fff;
}
input[type="checkbox"].checkbox:checked + label::before {
  background-color: #00B7E8;
  width: 50px;
  height: 50px;
}

@media only screen and (max-device-width: 900px) {
	input[type="checkbox"].checkbox + label::before {
	  padding-right: 0.6rem;
	  padding-left: 0.6rem;
	}
}

.tocheck img{
  width: 30px;
  height: 30px;
}

.submitctc{
	/*width: 30%; */
	font-family: Baskerville, Garamond, Times ,serif;
	font-size: 1.3rem;
	font-stretch:expanded; 
	padding: 5px; 
	padding-left: 10px; 
	padding-right: 10px;
	min-width: 20%;
}
@media only screen and (max-device-width: 900px) {
	.submitctc{
		/*width: 100%;*/ 
	font-size: 1rem;
	}
}
textarea {
	width:100%; 
	height:200px;
}
@media only screen and (max-device-width: 900px) {
	textarea {
	}
}

/*--- Animations -----------  ---------- --------------- ------------ ----------- ------------ */

.reduction{ /*utilisé: H2, H3, H4, P1, P2, P3, P4, P5, P7, P9, P10, P11, P12, L1, L9, E1*/
	-webkit-transition: all 0.6s ease-in-out;
	-moz-transition: all 0.6s ease-in-out;
	-o-transition: all 0.6s ease-in-out;
	-ms-transition: all 0.6s ease-in-out;
	transition: all 0.6s ease-in-out;
}

.reduction:hover{
	-webkit-transform: scale(0.95);
	-moz-transform: scale(0.95);
	-o-transform: scale(0.95);
	transform: scale(0.95);
}




#my_osm_widget_map3 { /*carte pour les infras */
	position:relative;
	width: 100%; /* important! if you need full width display */
	height: 300px;
	margin: 0;
	border-radius: 5px;
	z-index:1;
}
@media only screen and (min-device-width: 1600px) {
	#my_osm_widget_map3,
	.sectionCarteInfra{
		height: 500px;
	}
}
@media only screen and (max-device-width: 1200px) {
	#my_osm_widget_map3,
	.sectionCarteInfra{
		height: 300px;
	}
}
@media only screen and (max-device-width: 800px) {
	#my_osm_widget_map3,
	.sectionCarteInfra{
		height: 300px;
	}
}

.mapOSM {
	width: 45%; 
	margin-top: 0px; 
	padding-top: 0px;
}

@media only screen and (max-device-width: 900px) {
	.mapOSM {
		width: 95%;
	}
}

