/*
palette :
- principale : #1c64ad 
- fonce : #161648 
- selectionné : #4cadab
- selectionné survol : #0095a7
- couleur texte : #353535

*/

html, body{
	width: 100%;
	height: 100%;
	font-family: "Roboto", sans-serif;
	color: #353535;
	padding: 0;
	margin: 0;
	overflow-y: hidden;	/* pour pouvoir faire la transition entre les deux pages sans afficher d'ascenceur */
	font-size: 14px;
}

button, input[type="button"], input[type="submit"], .bouton, .boutonImage{
	background-color: #1c64ad;
	text-align: center;
	border: none;
	border-radius: 5px;
	color: #ffffff;
	cursor: pointer;
	user-select: none;
}

button, input[type="button"], input[type="submit"], .bouton{
	height: 42px;
}

@media screen and (min-width: 1024px) {	/* en téléphone peut rester en survol même si pas de survol donc je préfère gérer qu'en mode PC/tablette'*/
	button:hover, input[type="button"]:hover, input[type="submit"]:hover, .bouton:hover, .boutonImage:hover{
		background-color: #161648;
	}
}

button.selectionne, input[type="button"].selectionne, input[type="submit"].selectionne, .bouton.selectionne, .boutonImage.selectionne{
	background-color: #4cadab;
}

@media screen and (min-width: 1024px) {	/* en téléphone peut rester en survol même si pas de survol donc je préfère gérer qu'en mode PC/tablette'*/
	button.selectionne:hover, input[type="button"].selectionne:hover, input[type="submit"].selectionne:hover, .bouton.selectionne:hover, .boutonImage.selectionne:hover{
		background-color: #0095a7;
	}
}

button:disabled, input[type="button"]:disabled, input[type="submit"]:disabled{
	background-color: #8b9cab;
	cursor: unset;
}

textarea{
	height: 48px;
	padding: 1px 2px;
	font-family: "Roboto", sans-serif;
}

textarea, input[type="number"], input[type="text"], input[type="email"], input[type="search"], input[type="tel"], input[type="url"], input[type="week"], select, input[type="date"], input[type="password"]{
	font-size: 14px;
	min-height: 24px;
	border-radius: 6px;
	border: 1px solid gray;
	outline: none;
    appearance: none;
	color: #555555;
}
textarea:focus, input[type="number"]:focus, input[type="text"]:focus, input[type="email"]:focus, input[type="search"]:focus, input[type="tel"]:focus, input[type="url"]:focus, input[type="week"]:focus, select:focus, input[type="date"]:focus, input[type="password"]:focus{
	box-shadow: 0 0 5px #1c64ad;
	border: 1px solid #1c64ad;
}

input[type="number"] {	/* pour désactiver flêche haut/bas sous firefox */
	-moz-appearance: textfield;
}

a{
	color: #1c64ad;
}

a:hover{
	color: #161648;
	cursor: pointer;
}

/*----------------------
	page générales
-----------------------*/

.page{
	width: 100%;
	height: 100%;
	background-color: #ecf0f1;
	display: flex;
	flex-direction: column;
}

.page.chargement{
	cursor: wait;
}

.page > .entete{
	width: 100%;
	position: relative;	/* pour forcer shadow par dessus, je n'utilise pas un zindex pour éviter le soucis avec dialogue chargement */
}

.page > .entete .principale{
	background-color: #1c64ad;
	display: flex;
	min-height: 48px;
	align-items: center;
}

.page > .entete .principale div{
	width: 48px;
	display: flex;
}

.page > .entete .principale div img{
	width: 32px; 
	margin: 8px;
}

.page > .entete .principale h1{
	flex: 1;
	text-align: center;
	font-weight: normal;
	color: #ffffff;
}

@media screen and (min-width: 1024px) {
	.page > .entete .principale h1{
		font-size: 18px;
	}
}

@media screen and (max-width: 1023px) {
	.page > .entete .principale h1{
		font-size: 16px;
	}
}

.page > .entete .secondaire{
	background-color: #dbdbdb;
	display: flex;
	min-height: 48px;
	align-items: center;
	padding: 5px;
	flex-wrap: wrap;
}

.page .entete .secondaire.multiLignes{
	flex-direction: column;
	align-items: unset;
}

.page .entete .secondaire.multiLignes .ligne{
	margin-top: 5px;
	display: flex;
	flex-wrap: wrap;
}

.page .entete .secondaire.multiLignes .ligne div {
	margin-right: 5px;
}

.page > .entete{
	box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
}

.page > .contenu{
	flex: 1;
	display: flex;
	overflow-y: auto;
}

.page.pageFiche .entete .secondaire, .page.pageSaisie .entete .secondaire{
	justify-content: center;
}

.page.pageFiche > .contenu, .page.pageSaisie > .contenu{
	display: unset;
}

.pageSaisie .formulaire{
	margin : 15px auto 15px auto;
	padding: 10px;
	background-color: #ffffff;
	border-radius: 10px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
}

@media screen and (min-width: 1024px) {
	.pageSaisie .formulaire{
		width: 500px;
	}
}

@media screen and (max-width: 1023px) {
	.pageSaisie .formulaire{
		width: calc(100% - 30px);
	}
}

.formulaire .ligne{
	width: 100%;
	margin-top: 5px;
}

.formulaire .ligne > .saisie{
	display: flex;
	flex-direction: column;
	width: 100%;
}

.formulaire .pied{
	display: flex;
	justify-content: flex-end;
}

.formulaire .ligne .interrupteur{
	flex-direction: row;
}

.formulaire .ligne .interrupteur input[type=checkbox]{
	margin-left: 0px;
}

.formulaire .ligne .boutonChoixOnglet{
	width: 80px;
	background-color: #1c64ad;
	text-align: center;
	color: white;
	border-radius: 4px;
}

.formulaire .ligne .boutonChoixOnglet:hover{
	width: 80px;
	background-color: #161648;
	text-align: center;
}

.formulaire .ligne .boutonChoixOnglet:not(:first-child){
	margin-left: 5px;
}

.formulaire .ligne .boutonChoixOnglet > img{
	padding: 5px;
	width: 48px;
	height: 48px;
	margin: 0px;
}

.formulaire .ligne .boutonChoixOnglet > span{
	margin: 0px;
}

.formulaire .ligne.ligneBoutons{
	justify-content: flex-end;
}

.formulaire .ligne.ligneBoutons button:last-child{
	margin-right: 0px;
}

.formulaire .ligne .saisieValeurReponse{
	font-size: 24px;
}

.formulaire .pied{
	margin-top: 5px;
}

.formulaire .pied button:not(:last-child){
	margin-right: 5px;
}

.formulaire .separateur{
	margin-top: 20px;
	text-align: center;
	font-weight: bold;
}

.page > .pied{
	margin-top: 10px;
	display: flex;
	justify-content: center;
	height: 25px;
}

/*----------------------
	page parametres avec liste
-----------------------*/
.pageParametresListe > .entete > .secondaire > div{
	text-align: center;
}

.pageParametresListe > .contenu > .liste{
	width: 100%;
}

.pageParametresListe > .contenu > .liste > .element > .conteneurTexte > .titre > .utilisateurInactif{
	margin-left: 5px;
}

/*----------------------
	dialogues
-----------------------*/

/* CSS des dialogues à revoir complètement */
.dialogue{
	display: flex;
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100%;
	height: 100%;
	background-color: rgba(51, 51, 51, 0.5);
	align-items: center;
	justify-content: center;
	z-index: 9998;
	
}

.dialogue .conteneur{		
	background-color: #ffffff;
	box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
	transition: all 0.3s cubic-bezier(.25,.8,.25,1);
}

.dialogue .entete{
	width: unset;
	padding: 20px;
	margin:0px;
	box-shadow: unset;
}


.dialogue .entete{
	padding: 20px;
	margin:0px;
}

/* En mode smartphone */
@media only screen and (max-width:1023px) {	
	.dialogue .conteneur{
		width: 80%;
	}
	
	.dialogue .entete{
		/*min-width: 250px;*/
	}
	
	.dialogue .contenu input{
		/* je force la largeur car les inputs number ne s'agrandissent pas automatiquement sous FF */ 
		width: 250px;
	}
}

/* En mode tablette/PC */
@media only screen and (min-width:1024px) {
	.dialogue .conteneur{
		max-width: 500px;
	}
	
	.dialogue .entete{
		/*min-width: 350px;*/
	}
	
	.dialogue .contenu input{
		/* je force la largeur car les inputs number ne s'agrandissent pas automatiquement sous FF */ 
		width: 350px;
	}
}

.dialogue .contenu{
    font-weight: normal;
	overflow-y: auto;
	padding: 0px 20px 0px 20px;
}

.dialogue .contenu .progression{
	display:flex;
	overflow:hidden;
}

.dialogue .contenu .progression .cercleIndefini{
	border: 8px solid #666666;
    border-top: 8px solid #0000FF; 
    border-radius: 50%;
    width: 32px;
    height: 32px;
    animation: spin 2s linear infinite;
	margin-left: auto;
	margin-right: auto;
}

@keyframes spin {
    0% { transform: rotate(0deg); }
    100% { transform: rotate(360deg); }
}

.dialogue .contenu .progression .description{
	flex: 1;
	padding: 14px 0px 0px 14px;
}

/* En mode smartphone */
@media only screen and (max-height:600px) {
	.dialogue .contenu{
		max-height: 375px;	/* j'utilise un nombre non multiple de 32 pour voir le scroll sur mobile (dernier input coupé) */ 
	}
}


/* En mode PC avec petit ecran */ 
@media only screen and (min-height:601px) and (max-height:799px) {
	.dialogue .contenu{
		max-height: 450px;
	}
}

/* En mode PC avec grand ecran */ 
@media only screen and (min-height:800px){
	.dialogue .contenu{
		max-height: 750px;
	}
}

.dialogue .pied{
	display:flex;
	padding: 20px;
}

.dialogue .pied button{
	margin: 0px;
	flex:1;
}

.dialogue .pied input:not(:first-child), .dialogue .pied button:not(:first-child){
	margin-left: 5px;
}

/*----------------------
	Dialogue chargement
-----------------------*/

/* demande de Rémi pour supprimer clignotement */

#dialogueChargement{
	background-color: transparent;
	cursor: wait;
}

#dialogueChargement .conteneur{
	display: none;	
}

/*----------------------
	Conteneur volant utilisateur
-----------------------*/

.entete .conteneurVolantUtilisateur{
	right: 5px;
	box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23);
}

.entete .conteneurVolantUtilisateur .avatar{
	text-align: center;
}

.entete .conteneurVolantUtilisateur .avatar img{
	width: 92px;
}

.entete .conteneurVolantUtilisateur .utilisateur{
	text-align: center;
	font-weight: bold;
}

.entete .conteneurVolantUtilisateur .infoUtilisateur{
	text-align: center;
	margin-top: 5px;
	font-size: 14px;
}

.entete .conteneurVolantUtilisateur .actions{
	margin-top: 10px;
	border-top: solid 2px #e4e4e4;
	display: flex;
	flex-direction: column;
}

.entete .conteneurVolantUtilisateur .actions a{
	margin-top: 15px;
	color: #353535;
}

.entete .conteneurVolantUtilisateur .actions a:hover{
	margin-top: 15px;
	color: #1c64ad;
}

/*----------------------
	Conteneur plusieurs boutons
-----------------------*/

.actions{
	display: flex;	/* pour éviter le soucis des espaces automatiques */
	flex-wrap: wrap;
	align-items: center;
}

.actions > button{
	margin-top: 5px;
}

.actions > button:not(:last-child){
	margin-right: 5px;
}

/*----------------------
    mosaique photo
----------------------*/

.mosaiquePhotos{
	margin: 15px auto 15px auto;
	padding: 10px;
}

.mosaiquePhotos .champUpload{
	text-align: center;
}

.mosaiquePhotos label:first-child {
	background-color: #1c64ad;
	border-radius: 5px;
	padding: 15px; /* Pas d'autre choix pour garder un aspect bouton assez gros sur le label, attention au margin bottom de la grille photo si modification */
	color: white;
}

.mosaiquePhotos label:hover{
	background-color: #161648;
}

.mosaiquePhotos .grillePhotos{
	margin-bottom: 25px;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
}

.mosaiquePhotos .bouton{
	display: flex;
	height: 130px;
	padding: 8px;
	background-color: #ffffff;
	box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
	transition: all 0.3s cubic-bezier(.25,.8,.25,1);
	flex-direction: column;
	align-items: center;
	color: #353535;
}

.mosaiquePhotos .bouton img{
	height: 90px;
}

.mosaiquePhotos .bouton .description{
	display: flex;
	flex-direction: column;
	margin-top: 5px;
	align-items: center;
}	

.mosaiquePhotos .champUpload{
	margin: 0 auto;
}

@media only screen and (max-width: 1023px){
	.mosaiquePhotos .champUpload{
		width: calc(100% - 30px);
	}
	
	.mosaiquePhotos .bouton{
		width: calc(100% - 20px);
		margin-top: 10px;
	}
}

@media only screen and (min-width: 1024px){
	.mosaiquePhotos .champUpload{
		width: 500px;
	}
	
	.mosaiquePhotos .bouton {
		width: 250px;
		margin: 5px;
	}
}

/*----------------------
	Champ upload
-----------------------*/
.champUpload > label{
	color: #1c64ad;
}

/*----------------------
	Champ Onglet
-----------------------*/

.champOnglet{
	background-color: #dbdbdb;
	display: flex;
	justify-content: center;
	border-bottom: 1px solid rgba(0,0,0,0.15);
}

.champOnglet > .entete{
	display: flex;
}

.champOnglet > .entete > .bouton{
	flex: 1;
	background-color: transparent;
	height: 32px;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 0px;
	font-weight: bold;
	color: rgba(0,0,0,0.30);
	box-sizing: border-box;
	margin-bottom: -1px;
	/* Permet de fusionner les deux bordures (grise et couleur)*/
}

.champOnglet > .entete > .bouton.selectionne{
	border-bottom: 3px solid #1c64ad;
	color: #1c64ad;
}

.champOnglet > .entete > .bouton.selectionne:hover{
	background-color: transparent;
	color: #1c64ad;
}

.champOnglet > .entete > .bouton:hover{
	background-color: #1c64ad;
	color: #FFFFFF;
}

@media screen and (min-width: 1024px) {
	.pageSaisieOnglet .champOnglet > .entete{
		width: 500px;
	}
}

@media screen and (max-width: 1023px) {
	.pageSaisieOnglet .champOnglet > .entete{
		width: calc(100% - 30px);
	}
}

/*----------------------
	page saisie avec onglet 
-----------------------*/
.pageSaisieOnglet .entete .secondaire, .pageSaisieOnglet .contenu .sousEntete{
	flex-direction: column;
	/*text-align: center;*/
}

.pageSaisieOnglet .contenu .sousEntete hr{
	width: 100%;
	margin-top: 5px;
	margin-bottom: 5px;
	border: none;
	border-top: 1px solid #1c64ad;
}
	
.pageSaisieOnglet .contenu .sousEntete .descriptionDemande{
	display: flex;
	align-items: center;
}

.pageSaisieOnglet .contenu .sousEntete .descriptionDemande .imageDemande{
	display: flex;
	flex-direction: column;
	align-items: center;
	margin-right: 5px;
}

.pageSaisieOnglet .contenu .sousEntete .descriptionDemande .imageDemande span{
	margin-top: 5px;
}
.pageSaisieOnglet .contenu .sousEntete .descriptionDemande .informationDemande{
	margin-left: 5px;
}


.pageSaisieOnglet .contenu .sousEntete .descriptionDemande .informationDemande .titreDemande{
	margin-top: 5px;
}

/*.pageSaisieOnglet .entete .secondaire .entete .titreDemande, .pageSaisieOnglet .contenu .sousEntete .titreDemande{
	display: flex;
	align-items: center;
	justify-content: center;
 }
*/

.pageSaisieOnglet .entete .secondaire .entete .titreDemande .libelleDemande, .pageSaisieOnglet .contenu .sousEntete .titreDemande .libelleDemande{
	font-weight: bold;
}

.pageSaisieOnglet .entete .secondaire .entete .titreDemande .libelleElement, .pageSaisieOnglet .contenu .sousEntete .titreDemande .libelleElement{
	font-weight: bold;
	margin-left: 0px;
}

.pageSaisieOnglet .entete .secondaire .corps .detail, .pageSaisieOnglet .contenu .sousEntete .detail{
	color: #626262;
}

.pageSaisieOnglet .contenu .sousEntete .informationDemande div{
	margin-top: 5px;
}
	
.pageSaisieOnglet .contenu .sousEntete{
	background-color: #dbdbdb;
	display: flex;
	min-height: 48px;
	align-items: center;
	padding: 5px;
	justify-content: center;
}

.pageSaisieOnglet .titreOnglet{
	margin-top: 15px;
	display: flex;
	align-items: center;
	justify-content: center;
}

.pageSaisieOnglet .titreOnglet h4{
	margin-top: 0;
	margin-bottom: 0;
	margin-left: 5px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons{
	display: flex;
	margin-top: 3px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet{
	width: 80px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet:hover{
	width: 80px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet:not(:first-child){
	margin-left: 5px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet.selectionne{
	background-color: #4cadab;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet.selectionne:hover{
	background-color: #0095a7;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet > img{
	padding: 5px;
	width: 48px;
	height: 48px;
	margin: 0px;
}

.pageSaisieOnglet .contenu .sousEntete .boutons .boutonChoixOnglet > span{
	margin: 0px;
}

.pageSaisieOnglet .contenu .listeHistorique{
	display: flex;
	flex-direction: column;
	align-items: center;
}

.pageSaisieOnglet .contenu h4{
	font-size: 12px;
	text-align: center;
}

.pageSaisieOnglet .ligne.reponseAvecInput > .saisie > input{
	margin-bottom: 5px;
}

.pageSaisieOnglet .formulaire .ligne label{
	width: 75px; /* Dimensions choisi pour pouvoir afficher deux boutons réponses sur petit écran */
	min-width: 0;
}

.pageSaisieOnglet .conteneurOngletHistorique{
	text-align: center;
}

.pageSaisieOnglet .conteneurOngletHistorique .bouton{
	width: 110px;
	height: 48px;
	margin-top: 15px;
}

.pageSaisieOnglet .contenu .listeHistorique .historiqueVide{
	margin-top: 7px;
	color: #626262;
}

.pageSaisieOnglet .contenu .listeHistorique div{
	margin-top: 7px;
}

.pageSaisieOnglet .contenu .listeHistorique > div{
	padding: 10px;
	background-color: #ffffff;
	border-radius: 10px;
	box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24);
	text-align: left;
}

@media screen and (min-width: 1024px) {
	.pageSaisieOnglet .contenu .listeHistorique > div{
		width: 500px;
	}
}

@media screen and (max-width: 1023px) {
	.pageSaisieOnglet .contenu .listeHistorique > div{
		width: calc(100% - 30px);
	}
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligne > .libelleEquipe, .pageSaisieOnglet .contenu .listeHistorique > div > .ligne.ligneObservation > div{
	margin-left: 21px; /* pour aligner avec icone gravité */
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligne.ligneObservation > span{
	color: #595959;
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligne.ligneIcone{
	display: flex;
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligne.ligneIcone > span, .pageSaisieOnglet .contenu .listeHistorique > div > .ligne > .libelleEquipe{
	font-weight: bold;
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligne > .libelleDateHeure{
	margin-left: 5px;
	color: #595959;
}

.pageSaisieOnglet .contenu .listeHistorique > div > .ligneIcone > span{
	margin-left: 5px;
}

.pageSaisieOnglet .contenu .liste > div > .ligne:first-child > span:not(:first-child){
	font-weight: bold;
}

.pageSaisieOnglet .conteneurOngletPhotos .indication.erreur{
	text-align: center;
	display: block;
}
