
.login {
	display: flex;
	align-items: center;
	position: absolute;
	height: 100%;
	width: 100%;
	overflow: auto;
	.erreur {
		padding: .5em;
		border: solid 1px var(--couleur_erreur_texte);
	}
	.form {
		color: var(--couleur_texte);
		background-color: var(--couleur_fond);
		border: dotted 1px var(--couleur_accent);
		text-align: left;
		display: block;
		margin: auto;
		padding: 0 1rem 1rem 1rem;
	}
	footer {
		margin-top: 1rem;
		text-align: right;
	}
}

@keyframes fondu-toast {
	from {
		opacity: 1;
		scale: 1;
	}
	25% {
		opacity: 0;
		scale: .8;
	}
	to {
		opacity: 0;
		scale: .8;
		position: absolute;
	}
}

#toasts {
	position: absolute;
	top: .5rem;
	left: 0;
	width: 100%;
	padding: 0 3rem;
	z-index: 11;
	overflow: hidden;
	max-height: calc(100% - 50px);
	pointer-events: none;
	> div {
		position: relative;
		margin: .5rem auto;
		left:0;
		width: 100%;
		max-width: 600px;
		padding: .5rem 2rem .5rem 1rem;
		border-radius: 1rem;
		cursor: pointer;
		border: solid 2px var(--couleur_fond);
		color: var(--couleur_fond);
		background-color: var(--couleur_accent);
		pointer-events: all;
		box-shadow: var(--couleur_texte) 0px 0px 6px 1px;
	}
	> div::before {
		position: absolute;
		right: 1rem;
		content: "×";
	}
	> div.erreur {
		color: var(--couleur_erreur_texte);
		background-color: var(--couleur_erreur_fond);
		border-color: var(--couleur_erreur_texte);
	}
	.hide {
		animation-name: fondu-toast ;
		animation-timing-function: linear;
		animation-duration: 1s;
		animation-iteration-count: 1;
		animation-fill-mode: forwards;
	}
	strong {
		font-size: 200%;
	}
}

#home {
	position: absolute;
	top: 0;
	left: 0;
	height: 100%;
	width: 100%;
	display: grid;
	grid-template-columns: 1fr;
	grid-template-rows: auto 1fr;

	#erreur {
		position: fixed;
		top: 1rem;
		left: calc( min(10rem, 20%) + 1rem );
		width: calc(100% - min(10rem, 20%) - 2rem);
		z-index: 99;
		border: 2px dotted var(--couleur_erreur_texte);
		outline: 3px solid var(--couleur_erreur_fond);
		box-shadow: 0 0 15px 5px var(--couleur_erreur_fond);
		padding: 1rem;
		cursor: pointer;
		border-radius: 1rem;
		small {
			display: block;
			text-align: right;
		}
	}

	#topBar {
		display: flex;
		align-items: center;
		justify-content: space-between;
		padding: .5em;
		font-size: 75%;
	}

	#content {
		padding: 1rem;
		overflow: auto;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}

	> nav {
		padding: 1rem;
		margin: auto;
	}
}

.cadre {
	background-color: color-mix(in srgb, var(--couleur_accent) 10%, var(--couleur_fond));
	border-width: 1px;
	border-style: solid;
	border-color: color-mix(in srgb, var(--couleur_accent) 60%, var(--couleur_fond));
	border-radius: 1rem;
	padding: .5rem 1rem;
	margin: .5rem auto;
	> header {
		margin-top: 0;
	}
}
.cadre.centre {
	max-width: 800px;
	margin-left: auto;
	margin-right: auto;
}
