.menu{
	position: absolute;
	z-index:8;
	top:0;
	bottom:0;
	left:0;
	width:240px;
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	flex-direction: column;
	border-width: 0px 1px 0px 0px;
	border-style: solid;
	border-color: hsl(0,0%,90%);
	background-color: var(--gris-neuf);
	transition: left 0.3s ease-in-out;
	padding: 8px;
	box-sizing: border-box;
}

.menudecale{
	left:-241px;
}

.autourdudecaleur{
	position:absolute;
	top:0;
	right:-49px;
	width:48px;
	border-radius: 0px 0px 4px 0px;
	background-color: var(--bleu-neuf);
}

.decaleurdemenu{
	width:100%;
}

.menu > a{
	padding:16px;
	margin:8px;
	border: 1px solid hsl(0,0%,90%);
	border-radius: 2px;
	color:var(--bleu-arcadia);
	font-weight: 600;
	text-decoration: inherit;
	font-size: 11pt;
	display: flex;
	align-items: center;
	justify-content: center;
	background-color: hsl(0,0%,98%);
	transition: transform ease-in-out 0.1s;
}

.menu > a:hover{
	transform: scale(1.06);
}

.basdumenu{
	position: absolute;
	display: flex;
	align-items: stretch;
	justify-content: flex-start;
	flex-direction: column;
	bottom:16px;
	left:16px;
	right:16px;
	border-width:4px 0px 0px 0px;
	border-style: solid;
	border-color: var(--gris-fonce);
}

.basdumenu > a{
	color: hsl(0,0%,98%);
	border-radius: 2px;
	padding: 8px;
	margin:8px 0px;
	font-size: 11pt;
	background-color: var(--bleu-neuf);
	font-weight: 600;
	text-decoration: none;
	text-align: center;
}

.autourdubadge{
	display: flex;
	align-items: center;
	justify-content: center;
}

.badgedeconnexion{
	width:30px;
	margin:12px;
}

.nomaccueil{
	color:var(--bleu-neuf);
	font-size: 24pt;
	font-weight: 500;
	padding:24px;
	text-align: center;
	position: absolute;
	box-sizing: border-box;
	top:0;
	left:0;
	width:100%;
}

.fenetreaccueil{
	display: flex;
	align-items: stretch;
	justify-content: space-around;
	flex-direction: row;
	position: relative;
	width:calc(100% - 240px);
	height:100%;
	min-height: 100%;
	flex-grow: 1;
}

.listeaccueil{
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	padding: 54px 16px 16px 16px;
	box-sizing: border-box;
	min-height: 100%;
	flex-grow: 1;
}

.listeaccueil > a{
	display: block;
	flex-grow: 1;
	flex-shrink: 1;
	flex-basis: 0;
	margin:16px;
	min-height: 0;
}

.listeaccueil > a > img{
	display: block;
	max-height:100%;
	max-width:100%;
	width: auto;
}

.optionsaccueil{
	padding: 16px;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	min-width: 26%;
	flex-grow: 1;
}

.optionsaccueil > a{
	height:33%;
	min-width: 0;
	max-width: 300px;
}

.optionsaccueil > a > img{
	max-height: 100%;
	max-width: 100%;
}

.calendrieraccueil{
	margin:16px;
}

.chiffresaccueil{
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	padding:64px 16px;
	min-width: 30%;
	color:var(--bleu-neuf);
	text-align: center;
}

.titredechiffres{
	color:var(--gris-fonce);
	font-variant: small-caps;
	font-weight: 800;
	font-size: 24pt;
	margin:12px;
}

.unchiffreaccueil{
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	margin:12px;
}

.lechiffreaccueil{
	font-size: 20pt;
	font-weight: 700;
	margin:4px;
}

.unelegendeaccueil{
	font-size: 14pt;
	font-weight: 600;
	margin:0px;
}

.fenetredediscussion{
	display: flex;
	margin: 6px;
	min-height:300px;
	max-height:60vh;
	width:95%;
	max-width:1200px;
	align-items: stretch;
	justify-content: center;
	flex-direction: column;
	background-color: hsl(0,0%,94%);
	border-radius: 2px;
	position: relative;
}

.selectiondecours{
	font-family: "Raleway";
	border-radius: 2px;
	margin:12px;
	border: 0px solid white;
	cursor: pointer;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 4px;
	color: white;
	font-weight: 500;
	font-size: 10pt;
	background-color: var(--bleu-arcadia);
	outline: none;
}

.reinitialisationdiscussion{
	position: absolute;
	z-index: 4;
	border-radius: 2px;
	top: 6px;
	right: 6px;
	height: 32px;
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 2px;
	font-size: 9pt;
	background-color: var(--bleu-arcadia);
	color:white;
}

.discussion{
	flex-grow: 1;
	overflow-y: auto;
	padding-top:36px;
}

.unmessage{
	padding:12px;
	margin: 12px;
	font-size: 11pt;
	margin: 12px;
}

.messageetudiant{
	margin-left:20%;
	color:white;
	font-weight: 500;
	background-color: var(--bleu-lmp);
	border-radius: 8px 8px 0px 8px;
}

.messagearcadia{
	margin-right:20%;
	font-weight: 500;
	background-color: white;
	border-radius: 8px 8px 8px 0px;
}

.transcription{
	display: none;
	align-items: center;
	justify-content: space-between;
	flex-direction: row;
	margin:8px;
	background-color: white;
	padding: 8px;
	border-radius: 2px;
	font-size: 8pt;
}

.textedetranscription{
	width:80%;
	height:40px;
	overflow: hidden;
}

.contenutranscrit{
	max-height:100px;
	margin:8px;
	padding: 8px;
	font-size: 8pt;
	overflow: hidden;
	background-color: var(--gris-lmp);
	border-radius: 2px;
}

.croixdetranscription{
	background-color: var(--bleu-arcadia);
	border-radius: 50%;
	padding: 4px;
	width: 20px;
	margin: 4px;
}

.transcriptionvisible{
	display: flex;
}

.bandeaudediscussion{
	background-color: var(--gris-lmp);
	border-radius: 2px;
	padding:4px;
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: row;
}

.champdediscussion{
	margin:6px;
	border-radius: 2px;
	padding:6px;
	background-color: white;
	border: 0px solid white;
	flex-grow: 1;
	font-size: 11pt;
	outline: none;
	font-family: "Raleway";
}

.champdediscussion::placeholder{
	font-weight: 400;
	font-style: italic;
}

.unchampdephotodediscussion{
	display: none;
}

.photodediscussion{
	width:36px;
	margin:4px;
}

.envoidediscussion{
	margin:6px;
	border-radius: 2px;
	width: 50px;
}

.deschallenges{
	display: flex;
	flex-direction: row;
	align-items: center;
	justify-content: center;
	flex-wrap: wrap;
	padding: 16px;	
}

.bouton > label{
	cursor: pointer;
}

.unchallenge{
	/*background-color: var(--bleu-de-substitution);*/
	background-color: var(--bleu-arcadia);
	color:white;
	border-radius: 2px;
	padding: 6px;
	font-size: 10pt;
	font-weight: 600;
	margin: 6px;
	width: 84px;
	height: 84px;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	flex-direction: column;
}

.unchallengeindisponible{
	color:var(--gris-lmp);
	opacity: 0.6;	
}

.iconedechallenge{
	width:30px;
	padding:6px;
}

.challenge{
	z-index: 48;
	display: none;
	position: fixed;
	top:0;
	bottom:0;
	left:0;
	right:0;
	background-color: hsla(0,0%,100%,0.94);
	padding: 100px 32px 32px 32px;
	flex-direction: column;
	align-items: center;
	justify-content: space-between;
	overflow-y: scroll;
}

.challengevisible{
	display: flex;
}

.cadrechallenge{
	border-radius: 4px;
	border: 4px solid var(--bleu-lmp);
	padding: 16px;
}

.expressionmathematique{
	font-size:24pt;
	text-align: center;
	margin: 8px;
}

.verificationmathematique{
	font-size:20pt;
	text-align: center;
	margin: 8px;
}

.fermeturechallenge{
	background-color: var(--bleu-arcadia);
	border-radius: 2px;
	position: absolute;
	top:5%;
	right:5%;
	padding:8px;
	color:white;
	font-size: 12pt;
	user-select: none;
}

.nombredechallenges{
	font-size: 13pt;
	font-weight: 600;
	padding: 10px;
	border-radius: 2px;
	color:var(--bleu-lmp);
}

.autourdunouveau{
	display: flex;
	align-items: center;
	justify-content: center;
	margin: 16px;
}

.nouveauchallenge{
	display: none;
	background-color: var(--bleu-arcadia);
	border-radius: 2px;
	padding:8px;
	margin: 8px;
	color:white;
	font-size: 12pt;
	user-select: none;
}

.nouveauchallengevisible{
	display: flex;
}

.autourdereponse{
	display: none;
	align-items: center;
	justify-content: center;
	flex-direction: column;
	padding:0px 0px;
	margin:0px 0px;
	width: 100%;
}

.actionsdereponse{
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: row;
	padding:16px 0px;
}

.resultatsmathematiques{
	display: flex;
	align-items: center;
	justify-content: center;
	flex-direction: row;
}

.resultatmathematique{
	display: none;
	padding:6px;
	font-size: 28pt;
	font-family: 'Nothing You Could Do';
	animation: saute 4s ease-in-out;
}

@keyframes saute{
	0%,100%{
		transform: scale(1.0);
	}
	25%{
		transform: scale(1.6);
	}
}

#leresultat0{
	color: var(--rouge-lmp);
}

#leresultat1{
	color: var(--vert-correct);
}

.microdereponse, .photodereponse, .crayondereponse{
	background-color: var(--bleu-arcadia);
	display: flex;
	align-items: center;
	justify-content: center;
	border-radius: 50%;
	width:48px;
	height:48px;
	margin: 6px;
}

.microdereponse > img,.photodereponse > img{
	width: 60%;
}

.crayondereponse > img{
	width: 80%;
}

.microvalide, .photovalide, .crayonvalide{
	background-color: var(--gris-lmp);
	pointer-events: none;
}

.microinvalide, .photoinvalide, .crayoninvalide{
	display: none;
}

.enenregistrement{
	animation: enenregistrement 2s ease-in-out infinite;
}

@keyframes enenregistrement{
	0%{
		background-color: rgba(200,200,200,0.8);
		transform: scale(1.0);
	}
	50%{
		background-color: rgba(255,60,50,0.8);
		transform: scale(1.4);
	}
	100%{
		background-color: rgba(200,200,200,0.8);
		transform: scale(1.0);
	}
}

.unecritdereponse{
	display: none;
	width: 100%;
	margin: 16px;
	max-width: 400px;
	height:100px;
	min-height:100px;
	padding:12px;
	font-family: "Raleway";
	font-size: 11pt;
	font-weight: 600;
	color: white;
	background-color: var(--bleu-arcadia);
	font-style: italic;
	box-sizing: border-box;
	border-radius: 2px;
	border: 1px solid hsl(0,0%,90%);
}

.unecritdereponsevisible{
	display: block;
}

.optionsdereponse{
	display: none;
	background-color: var(--bleu-lmp);
	border-radius: 2px;
	width:160px;
	align-items: center;
	flex-direction: row;
	justify-content: space-around;
}

.optionsvisibles{
	display: flex;
}

.imageoptionreponse{
	padding:0px;
	width:32px;
	border-radius: 50%;
	margin: 6px;
	background-color: var(--bleu-arcadia);
}

.unephotodereponse{
	display: none;
}

.autourdugraphedechallenge{
	margin: 32px 0px;
	width:320px;
}

.avertissementia{
	font-size: 9pt;
	text-align: center;
	font-style: italic;
	margin: 0px;
	color: var(--bleu-arcadia);
}

.receptacle{
	display: none;
	align-items: center;
	justify-content: center;
	text-align: center;
	flex-direction: column;
	font-size:10pt;
	font-weight: 600;
	background-color: white;
	border-radius: 4px;
	padding: 16px;
	margin: 64px 0px;
	color: var(--bleu-arcadia);
}

.receptaclevisible{
	display: flex;
}

.analyseencours{
	margin:16px;
}

.barretotale{
	width: 300px;
	background-color: var(--gris-lmp);
	height:12px;
	border-radius: 2px;
	margin:16px 0px;
	position: relative;
}

.barreanalysee{
	position: absolute;
	top:0;
	bottom:0;
	left:0;
	border-radius: 2px;
	background-color: var(--bleu-arcadia);
}

@media screen and (max-width: 720px) {
	.fenetreaccueil{
		flex-direction: column;
	}
	.listeaccueil{
		height: calc(100vh - 100px);
	}
}

@media screen and (max-width: 960px) {
	.fenetreaccueil{
		width: auto;
	}
	.menu{
		height:calc(100vh -  100px);
	}
}

@media screen and (min-width: 960px) {
	.menu{
		left: 0px;
	}
	.autourdudecaleur{
		display: none;
	}
	.fenetreaccueil{
		padding-left: 240px;
	}
}