@import url("https://fonts.googleapis.com/css2?family=Allison&family=Montserrat:wght@300;400;500;600;700&family=Poppins:wght@600&display=swap");
/*
font-family: 'Allison', cursive;
font-family: 'Montserrat', sans-serif;
font-family: 'Poppins', sans-serif;
*/

.colors-template {
	color: #225b85;
	color: #4b96d1;
}

body {
	font-family: "Montserrat", sans-serif;
	background-color: white;
}
html {
	scroll-behavior: smooth;
}
strong {
	font-weight: 700;
}
.width-limited {
	max-width: 1400px;
	margin: auto;
}
.width-limited-half-left {
	max-width: 600px;
	margin-left: auto;
	padding: 40px;
}

#o-content {
	min-height: calc(100vh - 250px);
	padding: 30px 0 50px;
}
#o-content-home {
	min-height: calc(100vh - 250px);
	padding: 0 0 50px;
}
#o-full {
	min-height: 100vh;
}

/******************/
/***** Titles *****/
/******************/

p,
a,
li {
	font-family: "Montserrat", sans-serif;
	font-size: 18px;
	line-height: 24px;
	font-weight: 300;
	color: black;
	margin: 10px;
	text-align: center;
	text-decoration: none;
}

h1 {
	font-family: "Montserrat", sans-serif;
	font-size: 24px;
	font-weight: 700;
	color: black;
	text-transform: uppercase;
	margin: 20px;
	text-align: center;
}

h2 {
	font-family: "Montserrat", sans-serif;
	font-size: 24px;
	font-weight: 500;
	color: black;
	margin: 20px;
	text-align: center;
}

h3 {
	font-size: 24px;
	font-weight: 500;
	color: black;
	margin: 20px;
	text-align: center;
}

@media (max-width: 800px) {
	h1 {
		font-size: 22px;
		margin: 10px;
	}
	h2 {
		font-size: 18px;
		margin: 10px;
	}

	h3 {
		font-size: 18px;
		margin: 10px;
	}
}

h4 {
	text-align: left;
	margin-left: 20px;
	margin-top: 10px;
}

/*********************/
/***** Utilities *****/
/*********************/

.boxzone {
	background-color: rgba(255, 255, 255, 0.6);
	padding: 20px;
	margin: 20px;
	text-align: center;
}
.fullwidth {
	width: 100%;
	max-width: 1024px;
	margin: 20px;
}
.flex-centered {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	padding: 20px;
}
.flex-centered img {
	max-width: 100%;
}
.flex-centered-page {
	padding-top: 0;
	padding-bottom: 0;
}
.flex-row {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
	padding: 20px;
	flex-wrap: wrap;
	max-width: 100%;
}
.flex-row .tsa-button {
	margin: 10px;
}
@media (max-width: 1100px) {
	.fullwidth {
		max-width: none;
		margin: 20px 0;
	}
}
@media (max-width: 700px) {
	.flex-row {
		padding: 10px;
	}
}

/******************/
/***** Header *****/
/******************/

.o-header {
	position: relative;
	width: 100%;
	height: 120px;
	background-color: #4b96d1;
	z-index: 10;
	/*box-shadow: 0 0 10px 0 black;*/
}
.header {
	position: relative;
	top: 0;
	height: 120px;
	z-index: 3;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 50px;
}
.header-logo {
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.header-logo h2 {
	color: white;
	white-space: nowrap;
	overflow: hidden;
	text-overflow: ellipsis;
	line-height: 30px;
	user-select: none;
}
.header-logo a {
	max-height: 100px;
	max-width: 50vw;
}
.header-buttons {
	position: relative;
	display: flex;
	justify-content: flex-end;
	align-items: center;
	pointer-events: none;
	margin-left: auto;
}
.header-buttons > div {
	margin-left: 20px;
}
/*
.header-buttons > * {
	width: 50px;
	padding: 8px;
	cursor: pointer;
	pointer-events: all;
}
*/
.header-buttons > * {
	cursor: pointer;
	pointer-events: all;
}

.header-logo-img {
	height: 80px;
}
.header-menu-home {
	margin-left: 50px;
}
.header-menu-home a {
	margin-left: 20px;
	text-transform: uppercase;
	color: black;
	font-size: 18px;
	font-weight: 600;
}
.header-menu-home a:hover {
	border-bottom: solid 2px black;
}
.header .tsa-button a,
.header .tsa-button-alt a {
	border-color: white;
}

.header .tsa-button a,
.header .tsa-button-alt a {
	padding: 10px 22px;
}
@media (max-width: 800px) {
	.o-header,
	.header {
		height: 80px;
		padding: 0 10px;
	}
	.header-logo-img {
		height: 50px;
	}
	.header .tsa-button a,
	.header .tsa-button-alt a {
		font-size: 10px;
		padding: 4px 8px;
	}
}
@media (max-width: 1200px) {
	.header-menu-home a {
		margin-left: 5px;
		font-size: 14px;
	}
}
@media (max-width: 1000px) {
	.header-menu-home {
		display: none;
	}
}

@media (max-width: 650px) {
	.header-buttons {
		padding: 5px;
	}
}

.header-button-account {
	font-size: 16px;
	font-weight: 600;
	color: white;
}
.header-button-account img {
	margin-left: 5px;
	width: 12px;
}
@media (max-width: 800px) {
	.header-button-account {
		font-size: 12px;
	}
	.o-header {
		padding: 0;
	}
}

/****************/
/***** Menu *****/
/****************/

#o-menu {
	display: none;
	/*display: block;*/
	position: absolute;
	width: 100%;
	z-index: 2;
}
#o-menu > div {
	position: relative;
}
.menu-content {
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	background-color: #225b85;
	width: 20vw;
	max-width: 20vw;
	min-width: 300px;
	position: absolute;
	right: 0;
	top: 0;
}

@media (max-width: 500px) {
	.menu-content {
		width: 100vw;
		max-width: 100vw;
		min-width: 100vw;
	}
}
.menu-content a {
	height: 75px;
	display: flex;
	justify-content: center;
	align-items: center;
	width: calc(100% - 40px);
	border-bottom: 2px solid rgba(0, 0, 0, 0.2);
	font-size: 20px;
	font-weight: 500;
	color: white;
}
@media (max-width: 800px) {
	.menu-content a {
		height: 40px;
		font-size: 16px;
		line-height: 18px;
		margin-bottom: 0;
		margin-top: 0;
		padding: 30px;
	}
}
.menu-content a:nth-last-child(2) {
	border-bottom: none;
}
.menu-content a:hover {
	font-weight: 700;
}
#o-menu-bg {
	position: absolute;
	top: 0;
	left: 0;
	background-color: black;
	width: 100%;
	height: 100vh;
	z-index: 2;
	opacity: 0;
	pointer-events: none;
}

/******************/
/***** Footer *****/
/******************/

footer {
	background-color: #0b2237;
	height: 150px;
	display: grid;
	grid-template-rows: 1fr 55px;
	justify-content: center;
	align-items: center;
}

.footer-links {
	display: flex;
	justify-content: center;
	align-items: center;
}

footer a {
	color: white;
	text-decoration: none;
	margin: 20px 30px;
	font-weight: 400;
	font-size: 16px;
	text-transform: uppercase;
}
footer a:hover {
	text-decoration: underline;
}
.footer-end {
	color: #4b96d1;
	font-weight: 400;
	font-size: 16px;
	line-height: 55px;
	border-top: solid 1px #225b85;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 98vw;
}

#trace {
	background-color: white;
	padding: 10px;
}
@media (max-width: 700px) {
	.footer-links {
		flex-direction: column;
	}
	footer {
		height: auto;
		padding: 10px;
	}
	footer a {
		text-decoration: none;
		margin: 5px auto;
		font-weight: 400;
		font-size: 12px;
		text-transform: uppercase;
	}
	.footer-end {
		margin-top: 20px;
	}
}

/******************/
/***** Msgbox *****/
/******************/

#msgbox {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	z-index: 30;
}
#msgbox-bg {
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
}
#msgbox-content {
	position: relative;
	padding: 14px 10px 6px 10px;
	background-color: white;
	border-radius: 2px;
	color: white;
	text-align: center;
	max-width: 600px;
	min-height: 150px;
	min-width: 250px;
}
#msgbox h3 {
	font-size: 22px;
	line-height: 24px;
	color: white;
}
#msgbox-message > p {
	font-size: 16px;
	color: black;
	margin: 12px 10px;
}
#msgbox-message a {
	margin: 20px;
}
@media (max-width: 700px) {
	#msgbox-content {
		max-width: 90%;
	}
}
#msgbox-buttons {
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 0 20px 20px;
}
#msgbox-buttons > div {
	margin: 10px;
}
.msgbox-icon {
	width: 60px;
	height: 60px;
}
@media (max-width: 500px) {
	#msgbox-buttons {
		flex-direction: column-reverse;
	}
}

/****************/
/***** Form *****/
/****************/

.tsa-horizontal-separator {
	margin: 20px auto;
	width: 100%;
	border-top: solid 1px #999;
}

.o-formlogin {
	width: 450px;
	max-width: 100%;
	margin: auto;
}
.tsa-form-reduced {
	/*max-width: 350px;*/
}
.formlogin {
	padding: 20px;
}
@media (max-width: 500px) {
	.formlogin.boxzone {
		margin: 20px 0;
		padding: 10px;
	}
}
.tsa-form p {
	margin: 20px;
}
.tsa-form input {
	text-align: center;
}
.tsa-form input[type="text"],
.tsa-form input[type="password"],
.tsa-form textarea,
.tsa-form select,
.tsa-form textarea {
	font-family: "Montserrat", sans-serif;
	color: black;
	border: 0;
	border: solid 2px #eee;
	padding: 10px 5px;
	font-size: 1.1rem;
	border-radius: 5px;
	/*box-shadow: 0 0 15px 4px rgba(0, 0, 0, 0.06);*/
	outline: none;
	width: 90%;
	transition: all 0.5s;
	margin: 10px auto;
}

.tsa-form input[name="email"] {
	text-transform: lowercase;
}

.tsa-form input[type="text"]:hover,
.tsa-form input[type="password"]:hover {
	border: solid 2px black;
}
.tsa-form .tsa-form-bloc {
	margin: 10px;
}

.tsa-form h3 {
	margin-bottom: 0.3125em;
}
.tsa-form .error {
	font-size: 1rem;
	background-color: rgba(130, 67, 110, 0.6);
	color: white;
	padding: 10px;
	border-radius: 10px;
	margin: 10px;
}
.tsa-account {
	font-size: 1rem;
	border: solid 2px black;
	padding: 10px;
	border-radius: 10px;
	margin: 10px;
}
.tsa-form textarea {
	resize: none;
}
.tsa-form .g-recaptcha {
	margin-bottom: 20px;
}
.tsa-form .tsa-form-left {
	margin-left: 15px;
	margin-top: 0;
	text-align: left;
}
.tsa-form .tsa-form-left > *,
.tsa-form .tsa-form-left a {
	color: #666;
	font-size: 16px;
}
.tsa-form input[type="checkbox"] {
	opacity: 0.8;
	margin-right: 5px;
}
.tsa-form-right > div {
	display: flex;
	flex-direction: row;
	justify-content: flex-end;
}
.tsa-flex-bothside {
	display: flex;
	flex-direction: row;
	justify-content: space-between;
	align-items: center;
}
.tsa-form .tsa-flex-bothside * {
	margin: 0;
}
.tsa-form .tsa-form-info,
.tsa-form .tsa-form-info a,
.tsa-form option {
	font-size: 12px;
	line-height: 12px;
	margin-left: 0;
}
.tsa-form optgroup {
	font-size: 12px;
}
.tsa-form select {
	background-color: white;
	text-align: center;
}

.formcontact {
	min-width: 800px;
}
@media (max-width: 800px) {
	.formcontact {
		min-width: 100%;
	}
}
.formcontact input {
	text-align: left;
}

/*******************/
/***** Buttons *****/
/*******************/

.tsa-button,
.tsa-button-alt,
.tsa-button-color {
	display: flex;
	justify-content: center;
	align-items: center;
}
.tsa-button a,
.tsa-button-alt a,
.tsa-button-color a,
.tsa-button input,
.tsa-button-alt input,
.tsa-button-color input {
	display: block;
	font-family: "Montserrat", sans-serif;
	font-weight: 600;
	color: white;
	font-size: 16px;
	line-height: 19px;
	margin: 4px 0;
	padding: 16px 32px;
	border: solid 2px #4b96d1;
	background-color: #4b96d1;
	text-align: center;
	text-decoration: none;
	transition: all 0.5s;
	border-radius: 6px;
	cursor: pointer;
	text-decoration: none;
	/*box-shadow: 1px 2px 5px rgba(0, 0, 0, 0.2);*/
}
@media (max-width: 800px) {
	.tsa-button a,
	.tsa-button-alt a,
	.tsa-button-color a,
	.tsa-button input,
	.tsa-button-alt input,
	.tsa-button-color input {
		padding: 10px 28px;
	}
}
.tsa-button:hover a,
.tsa-button:hover input {
	/*background-color: #225b85;*/
	background-color: white;
	color: #4b96d1;
}
.tsa-button-alt a {
	background-color: white;
	color: #4b96d1;
	border-color: #4b96d1;
}
.tsa-button-alt:hover a {
	background-color: #4b96d1;
	color: white;
}
.tsa-button-color a {
	background-color: #fbb03b;
	color: black;
	border-color: #fbb03b;
}
.tsa-button-color:hover a {
	background-color: white;
	color: #fbb03b;
}
.tsa-button img,
.tsa-button-alt img {
	height: 12px;
	margin-right: 10px;
}
.tsa-button object {
	pointer-events: none;
}
.tsa-button-home a {
	text-transform: uppercase;
	margin: 18px;
	font-size: 20px;
	background-color: #82436e;
	border-color: #82436e;
}
.tsa-button-home:hover a {
	background-color: white;
	color: #82436e;
}

.icon {
	display: inline-block;
	width: 19px;
	height: 13px;
	background-size: cover;
}
.icon-arrow-back {
	margin-left: 10px;
	background-image: url(/img/arrow-back.svg);
	transition: all 0.3s;
	/* cf https://codepen.io/sosuke/pen/Pjoqqp */
	filter: invert(100%) sepia(5%) saturate(20%) hue-rotate(185deg)
		brightness(107%) contrast(104%);
}
.tsa-button:hover .icon-arrow-back {
	filter: invert(78%) sepia(38%) saturate(242%) hue-rotate(128deg)
		brightness(94%) contrast(87%);
}

.tsa-link-simple {
	text-decoration: underline;
	margin: auto;
}
.tsa-link-simple:hover {
	color: #225b85;
	text-decoration: underline;
}

.tsa-link-color {
	font-weight: 500;
	text-decoration: none;
	color: #93cecb;
	transition: color 0.3s;
}
.tsa-link-color:hover {
	color: #82436e;
}

/****************/
/***** Form *****/
/****************/

.formfield-select {
	position: relative;
}

.formfield-select--container {
	position: relative;
	background-color: #fff;
	border: #777 1px solid;
	margin: 0 0 1.5em 0;
	overflow: hidden;
}
.formfield-select--container select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%; /* Hide native arrow */
	height: auto;
	border: 0;
	margin: 0;
	padding: 0.55em;
	border-radius: 0;
	overflow: hidden;
	text-overflow: ellipsis;
}
.formfield-select--container::after {
	content: "";
	position: absolute;
	top: 50%;
	margin-top: -3px;
	right: 0.75em;
	display: block;
	width: 0;
	height: 0;
	border-color: transparent;
	border-top-color: #444;
	border-width: 6px;
	border-style: solid;
	pointer-events: none;
}
#tsa-select-language {
	width: 120px;
	margin: auto;
}
#tsa-select-language h3 {
	margin-bottom: 5px;
}

/*****************/
/***** Pages *****/
/*****************/

.myaccount-buttons div {
	margin: 10px;
}

.myaccount-progress {
	padding: 20px 60px 30px;
	text-align: center;
	border-radius: 5px;
	border: solid 3px #adccec;
	margin: 20px;
}
.myaccount-progress h3 {
	font-size: 20px;
	font-weight: 600;
	margin-bottom: 20px;
}

.page-ressources {
	max-width: 700px;
	margin: auto;
}

/*****************/
/***** Admin *****/
/*****************/

.o-admin a {
	display: block;
}
.o-admin .crt-button {
	margin: 10px;
}

.admin-table {
	line-height: 1.8rem;
	margin: auto;
}
.admin-table thead {
	font-size: 1.2rem;
	font-weight: 700;
}
.admin-table td,
.admin-table th {
	padding: 10px;
	text-align: center;
}
.admin-table tr {
	padding: 5px;
}
.admin-table thead tr:first-child {
	background: rgba(0, 0, 0, 0);
}
.admin-table tr:nth-child(even) {
	background: rgba(147, 206, 203, 0.1);
}
.admin-table tr:nth-child(odd) {
	background: rgba(147, 206, 203, 0.3);
}

.admin-table a {
	color: rgba(0, 0, 0, 0.7);
	transition: color 0.3s;
}
.admin-table a:hover {
	color: rgba(0, 0, 0, 1);
}
.pager {
	margin: 10px;
}
.pager a {
	color: grey;
}

/*********************/
/***** Simplebar *****/
/*********************/

.simplebar-vertical {
	transform: scale(0.9) translateX(-10px);
}

.simplebar-scrollbar::before {
	border-radius: 0 !important;
}
.simplebar-track.simplebar-vertical {
	/*background-color: rgba(0, 0, 0, 0.7);*/
	background-color: rgba(0, 0, 0, 0.1);
	width: 2px !important;
	cursor: pointer;
	pointer-events: all;
}
.simplebar-scrollbar::before {
	/*background-color: rgba(255, 255, 255, 1) !important;*/
	background-color: rgba(0, 0, 0, 1) !important;
	left: 0px !important;
	right: 0px !important;
}
.simplebar-scrollbar.simplebar-visible::before {
	opacity: 1 !important;
}
::-webkit-scrollbar {
	width: 0; /* Remove scrollbar space */
	background: transparent; /* Optional: just make scrollbar invisible */
}
/* Optional: show position indicator in red */
::-webkit-scrollbar-thumb {
	background: rgba(0, 0, 0, 0);
}

/****************/
/***** Game *****/
/****************/

.grid-list-game {
	display: grid;
	grid-template-columns: 100px 300px 150px;
	align-items: center;
}
.grid-list-game > div {
	padding: 10px;
	text-align: center;
}

@media (max-width: 750px) {
	.grid-list-game {
		display: grid;
		grid-template-columns: 1fr 1fr;
	}
	.grid-list-game > div:nth-child(3n) {
		grid-column-start: 1;
		grid-column-end: 3;
		border-bottom: solid 1px grey;
	}
}

/***** Game popup *****/

#game {
	display: none;
	position: fixed;
	top: 0;
	left: 0;
	width: 100vw;
	height: 100vh;
	z-index: 30;
}
#game-bg {
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: rgba(0, 0, 0, 0.8);
}
#game-zone {
	position: relative;
	background-color: white;
	width: 90%;
	max-width: 1200px;
	max-height: 100%;
}
@media (max-width: 600px) {
	#game {
		padding: 0;
	}
	#game-zone {
		padding: 6px;
		border-radius: 0;
		width: 100%;
		height: 100%;
	}
}

/***** Game Header *****/

.game-header {
	position: relative;
	height: 160px;
	background-color: #4b96d1;
	display: flex;
	flex-direction: row;
	justify-content: flex-start;
	align-items: center;
	overflow: hidden;
}
.game-header-situations {
	position: relative;
	margin-left: auto;
	width: 240px;
	height: 100%;
	background-color: #225b85;
}
.game-header-close {
	width: 160px;
	height: 160px;
	display: flex;
	justify-content: center;
	align-items: center;
	background-color: rgba(0, 0, 0, 0);
	cursor: pointer;
	z-index: 2;
}
.game-header-close-img {
	width: 30px;
	height: 30px;
	background-image: url("/img/game-close.svg");
}
.game-header-close:hover .game-header-close-img {
	background-image: url("/img/game-close-hover.svg");
}

.game-header-title {
	padding: 20px;
}
.game-header-title-sub {
	font-family: "Allison", cursive;
	font-weight: 400;
	color: black;
	text-transform: lowercase;
	font-size: 50px;
}
.game-header-title-main {
	font-family: "Montserrat", sans-serif;
	font-weight: 700;
	color: white;
	text-transform: uppercase;
	font-size: 30px;
	line-height: 30px;
	padding-bottom: 25px;
}

/***** Game Header Situations *****/

.game-header-situations-title {
	font-family: "Montserrat", sans-serif;
	font-weight: 600;
	color: white;
	font-size: 18px;
	line-height: 26px;
}
.game-header-situations-list {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.game-header-situations-list > div {
	width: 19px;
	height: 19px;
	border-radius: 50%;
	border: solid 1px #4b96d1;
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 4px;
}
.game-header-situations-inside {
	width: 9px;
	height: 9px;
	border-radius: 50%;
	background-color: #4b96d1;
}
.game-header-situations-active {
	background-color: white;
}

/***** Header Mobile *****/

@media (max-width: 600px) {
	.game-header {
		height: 120px;
	}
	.game-header-close {
		width: 60px;
		height: 120px;
	}
	.game-header-close-img {
		width: 20px;
		height: 20px;
	}
	.game-header-title {
		padding: 5px;
	}
	.game-header-title-sub {
		font-size: 35px;
	}
	.game-header-title-main {
		font-size: 20px;
		padding-bottom: 10px;
	}
	.game-header-situations {
		width: 120px;
		padding: 10px;
	}
	.game-header-situations-title {
		font-size: 14px;
		line-height: 30px;
	}
	.game-header-situations-list > div {
		width: 15px;
		height: 15px;
		margin: 2px;
	}
	.game-header-situations-inside {
		width: 7px;
		height: 7px;
	}
}

/***** Game Score *****/

.game-score {
	height: 90px;
	background-color: #adccec;
	display: flex;
	justify-content: space-around;
	align-items: center;
	flex-direction: row;
	padding: 0 40px;
}
@media (max-width: 850px) {
	.game-score {
		height: 90px;
		flex-direction: column;
		padding: 0 40px;
		justify-content: center;
	}
	.o-progressbar {
		height: 35px;
	}
}

/***** Game Comment *****/

.game-comment {
	display: none;
	overflow: hidden;
	background-color: #ccc;
}
.game-comment p {
	padding: 20px 40px;
	max-width: 800px;
	margin: auto;
	font-size: 16px;
	line-height: 20px;
	font-style: italic;
	text-align: justify;
}
@media (max-width: 850px) {
	.game-comment p {
		font-size: 14px;
		line-height: 18px;
	}
}

/***** Game Content *****/

#game-content {
	width: 100%;
	/*
	Force height (removed)
	height: calc(100% - 160px - 90px);
	position: absolute;
	*/
	/*display: grid;*/
	padding: 0;
	/*
	top: 250px;
	height: calc(100% - 160px - 90px);
	position: absolute;
	*/
}

#game-content-inside {
	padding: 0;
	/*min-height: 50%;*/
}

.game-2-cols {
	display: grid;
	grid-template-columns: 1fr 1fr;
}

/***** Game intro *****/

.game-intro {
	margin: 40px 20px;
	max-width: 600px;
	max-width: 100%;
}
.game-intro h2 {
	font-weight: 700;
	font-size: 22px;
	line-height: 30px;
	text-transform: uppercase;
	display: flex;
	justify-content: center;
	align-items: center;
}
.game-intro p {
	font-weight: 400;
	font-size: 18px;
	line-height: 26px;
	max-width: 600px;
	margin: 10px auto;
}
.game-tuto {
	display: grid;
	grid-template-columns: 1fr 1fr;
	margin: auto;
	margin: 40px;
}
.game-tuto > * {
	padding: 10px;
}
.game-tuto h2 {
	font-weight: 700;
	font-size: 14px;
	line-height: 20px;
	margin: 0;
}
.game-tuto p {
	font-weight: 600;
}
.game-intro a {
	text-align: center;
	margin: 40px 20px;
}
@media (max-width: 800px) {
	.game-tuto {
		margin: 10px;
	}
	.game-intro p {
		font-size: 14px;
		line-height: 18px;
		margin: 0 0 15 px;
	}
	.game-tuto > * {
		padding: 5px;
	}
}

.game-won-img {
	width: 80px;
}

/***** Situations *****/

.o-situation {
	padding: 20px;
}
.situation-image {
	position: relative;
	background-image: url("/img/situations/situation_1.jpg");
	width: 100%;
	height: 100%;
	background-position: center;
	background-size: cover;
	display: flex;
	justify-content: center;
	align-items: center;
}
.situation-image-shadow {
	position: absolute;
	width: 100%;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.7);
	pointer-events: none;
	opacity: 0;
	transition: opacity 1s;
}
#situation-button-next {
	z-index: 1;
}
.situation-question {
	margin: 40px 20px 0;
}
.situation-question p {
	color: #225b85;
	font-weight: 500;
	font-size: 16px;
	line-height: 22px;
	text-transform: uppercase;
	text-align: left;
}
.situation-answers {
}
.situation-answer {
	position: relative;
	width: 100%;
	padding: 14px 20px;
	background-color: #f4f4f4;
	color: #333333;
	font-weight: 300;
	font-size: 16px;
	line-height: 22px;
	transition: all 0.3s;
	text-align: left;
}
.situation-answer:hover {
	background-color: #adccec;
}
.situation-answer-selected {
	background-color: #adccec;
}

@media (max-width: 1100px) {
	.game-2-cols {
		grid-template-columns: 0.7fr 1fr;
	}
}
@media (max-width: 900px) {
	.game-2-cols {
		grid-template-columns: 1fr;
	}
	.situation-image {
		height: 300px;
	}
	.situation-question {
		margin: 0;
	}
	.situation-answers {
		padding: 0;
	}
}

/***** Infoscore *****/

.infoscore {
	position: absolute;
	border-radius: 50%;
	width: 60px;
	height: 60px;
	border: solid 3px white;
	color: white;
	font-weight: 700;
	top: 0;
	left: 0;
	font-size: 20px;
	line-height: 20px;
	text-align: center;
	display: flex;
	justify-content: center;
	align-items: center;
	box-shadow: 1px 1px 5px black;
	z-index: 1;
}
.infoscore-stress {
	background-color: red;
}
.infoscore-satisfaction {
	background-color: green;
}

/***** Gameover *****/

.gameover {
	min-height: 40vh;
}

/************************/
/***** Progress Bar *****/
/************************/

.o-progressbar {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: row;
}
.progressbar-title {
	font-family: "Montserrat", sans-serif;
	font-weight: 600;
	color: black;
	font-size: 14px;
	line-height: 16px;
	text-transform: uppercase;
	margin-right: 20px;
}
.progressbar-bar {
	position: relative;
	transform-origin: left;
	width: 221px;
	height: 47px;
}
.progressbar-bar > div {
	position: absolute;
	width: 221px;
	height: 47px;
	top: 0;
	left: 0;
}
.progressbar-color {
	transition: all 3s;
	clip-path: polygon(0 0, 0 100%, 0 100%, 0 0);
}
@media (max-width: 850px) {
	.o-progressbar {
		display: grid;
		grid-template-columns: 0.8fr 1fr;
		width: 100%;
	}
	.progressbar-title {
		text-align: right;
	}
	.game-tuto .o-progressbar {
		display: flex;
	}
}

/*******************/
/***** Harfang *****/
/*******************/

.harfang {
	margin: auto;
	width: 120px;
}
.harfang img {
	width: 100%;
}
@media (max-width: 500px) {
	.harfang {
		width: 80px;
	}
}

/****************/
/***** Home *****/
/****************/

.home-hero {
	background-image: url("/img/home-hero.jpg");
	background-position: top center;
	background-size: cover;
	height: 650px;
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.home-hero > div:first-child {
	background-color: rgba(0, 0, 0, 0.4);
}
.home-hero-text {
	height: 100%;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
.home-hero-text h3 {
	color: white;
	font-weight: 700;
	font-size: 32px;
	line-height: 40px;
	text-align: left;
	margin-right: auto;
}
.home-hero-text p {
	color: white;
	font-size: 21px;
	line-height: 28px;
	text-align: left;
	margin-right: auto;
}
@media (max-width: 800px) {
	.home-hero {
		height: 400px;
		grid-template-columns: 1fr;
	}
	.home-hero > div:last-child {
		display: none;
	}
	.home-hero-text h3 {
		font-size: 26px;
		line-height: 30px;
	}
	.home-hero-text p {
		font-size: 17px;
		line-height: 20px;
	}
}

.home-invite {
	width: 660px;
	margin-left: auto;
}
.home-invite p {
	margin: 60px 0;
	font-size: 18px;
	line-height: 24px;
	font-weight: 700;
	text-align: right;
}
@media (max-width: 800px) {
	.home-invite {
		width: 100%;
	}
	.home-invite p {
		margin: 30px 10px;
		font-size: 14px;
		text-align: center;
	}
}

.home-video {
	display: grid;
	grid-template-columns: 1fr 1fr;
	justify-content: center;
	align-items: start;
	margin: 40px auto;
}
.home-video-video {
	height: 360px;
}
.home-video-text {
	margin-left: 80px;
}
.home-video-text p {
	text-align: left;
	margin-bottom: 30px;
	max-width: 480px;
}
.home-video-deco {
	width: 35px;
	border-top: solid 3px black;
	margin: 10px;
}
@media (max-width: 1200px) {
	.home-video-text {
		margin-left: 20px;
	}
}
@media (max-width: 900px) {
	.home-video {
		grid-template-columns: 1fr;
		justify-content: center;
		align-items: start;
	}
	.home-video-text {
		margin: 20px;
	}
}
@media (max-width: 450px) {
	.home-video-video {
		height: 200px;
	}
}

.home-account {
	background-color: #dfecf5;
}
.home-account-blocks {
	display: flex;
	justify-content: space-around;
	align-items: center;
	flex-direction: row;
	padding: 80px 0 40px;
}
.home-account-blocks > div {
	width: 500px;
	height: 380px;
	background-color: white;
	display: flex;
	justify-content: space-around;
	align-items: center;
	flex-direction: column;
	padding: 40px 20px;
}
.home-account h3 {
	font-size: 22px;
	line-height: 28px;
	font-weight: 600;
}
.home-account p {
	margin-bottom: 20px;
}
.home-account-login {
	display: flex;
	justify-content: center;
	align-items: center;
	padding-bottom: 40px;
}
@media (max-width: 1100px) {
	.home-account-blocks > div {
		width: 40%;
		height: auto;
	}
}
@media (max-width: 800px) {
	.home-account h3 {
		font-size: 18px;
		line-height: 22px;
	}
	.home-account-blocks > div {
		width: 45%;
	}
}
@media (max-width: 700px) {
	.home-account-blocks {
		flex-direction: column;
		padding: 40px 0 20px;
	}
	.home-account-blocks > div {
		width: 90%;
		max-width: 500px;
		height: auto;
		margin: 20px;
	}
}

.home-about-line {
	display: grid;
	grid-template-columns: 1fr 1fr;
	height: 600px;
}
.home-about-line > div {
	min-height: 400px;
}
.home-about-img1 {
	background-image: url("/img/home-projet.jpg");
	background-position: center;
	background-size: cover;
}
.home-about-right .home-about-text {
	background-color: #225b85;
}
.home-about-img2 {
	background-image: url("/img/home-dispositif.jpg");
	background-position: center;
	background-size: cover;
}
.home-about-left .home-about-text {
	background-color: #adccec;
}
.home-about-text {
	width: 700px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	padding: 120px 40px;
	height: 100%;
	max-width: 600px;
}
.home-about-text h3 {
	font-size: 35px;
	font-weight: 700;
	text-transform: uppercase;
	margin-bottom: 60px;
}
.home-about-text p {
	font-size: 16px;
	line-height: 20px;
	margin-bottom: 25px;
}
.home-about-right .home-about-text h3,
.home-about-right .home-about-text p {
	color: white;
}
.home-about-left .home-about-text h3,
.home-about-left .home-about-text p {
	color: black;
}
.home-about-left .home-about-text {
	margin-left: auto;
}
@media (max-width: 1400px) {
	.home-about-text {
		width: 100%;
		padding: 40px 20px;
	}
}
@media (max-width: 800px) {
	.home-about-line {
		grid-template-columns: 1fr;
		height: auto;
	}
	.home-about-right .home-about-text {
		margin-left: auto;
		margin-right: auto;
	}
	.home-about-left .home-about-text {
		margin-right: auto;
	}
	.home-about-img2 {
		grid-row-start: 1;
	}
}
@media (max-width: 800px) {
	.home-about-text h3 {
		font-size: 30px;
		margin-bottom: 40px;
	}
	.home-about-text p {
		font-size: 14px;
		line-height: 18px;
		margin-bottom: 15px;
	}
}

.home-ambassadors {
	background-color: #4b96d1;
	height: 600px;
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
.home-ambassadors h2 {
	font-size: 35px;
	font-weight: 700;
	text-transform: uppercase;
	color: white;
	margin-bottom: 80px;
}
.home-ambassadors-portrait {
	width: 210px;
	height: 230px;
	border-radius: 5px;
}
.home-ambassadors-portrait1 {
	background-image: url("/img/ambassador-example.jpg");
	background-position: center;
	background-size: cover;
}
.home-ambassadors-container {
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0;
}
.home-ambassadors-card {
	margin: 20px;
}
.home-ambassadors-card p {
	font-weight: 600;
	font-size: 19px;
	margin-top: 15px;
	color: white;
}
@media (max-width: 1100px) {
	.home-ambassadors {
		height: 400px;
	}
	.home-ambassadors h2 {
		font-size: 30px;
		margin-bottom: 20px;
	}
	.home-ambassadors-portrait {
		width: 147px;
		height: 160px;
		border-radius: 5px;
	}
}
@media (max-width: 800px) {
	.home-ambassadors {
		height: auto;
	}
	.home-ambassadors h2 {
		font-size: 26px;
		margin-top: 40px;
	}
	.home-ambassadors-container {
		flex-wrap: wrap;
	}
	.home-ambassadors-card {
		margin: 10px;
	}
	.home-ambassadors-card p {
		font-size: 17px;
		margin-top: 10px;
	}
}

.home-partners a {
	margin: 0;
}
.home-partners h2 {
	font-size: 35px;
	font-weight: 700;
	text-transform: uppercase;
	margin-top: 80px;
	margin-bottom: 60px;
}
.home-partners-big,
.home-partners-small {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-wrap: wrap;
	margin: 20px;
}
.home-partners-big img {
	width: 135px;
	/*height: 140px;*/
	margin: 30px;
}
.home-partners-small img {
	width: 110px;
	/*height: 110px;*/
	margin: 15px;
}
@media (max-width: 800px) {
	.home-partners h2 {
		margin-top: 60px;
		margin-bottom: 20px;
		font-size: 26px;
		margin-top: 40px;
	}
	.home-partners-big img {
		width: 100px;
		/*height: 100px;*/
		margin: 10px;
	}
	.home-partners-small img {
		width: 80px;
		/*height: 80px;*/
		margin: 10px;
	}
}

/********************/
/***** Parcours *****/
/********************/

.parcours-home {
	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
	max-width: 700px;
	margin: auto;
}
.parcours-home h1 {
	padding: 20px;
}
.parcours-home-steps {
	margin-top: 20px;
}
.parcours-home-step {
	width: 500px;
	height: 80px;
	border-radius: 5px;
	display: grid;
	grid-template-columns: 40px 1fr;
	justify-content: center;
	align-items: center;
	background-color: #dfecf5;
	border: solid 3px #dfecf5;
	padding: 10px;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: -0.4px;
	margin: 15px;
	pointer-events: none;
	transition: border 0.3s;
}
.parcours-home-step-cur,
.parcours-home-step-done {
	background-color: #76c1ff;
	border: solid 3px #76c1ff;
	pointer-events: all;
	cursor: pointer;
}
.parcours-home-step:hover {
	border: solid 3px #225b85;
}
.parcours-home-step-label {
	text-align: left;
	margin-left: 20px;
}
.parcours-home-step-bullet {
	width: 40px;
	height: 40px;
	border-radius: 50%;
	background-color: rgba(204, 204, 204, 0.3);
	border: solid 1px rgba(153, 153, 153, 0.3);
}
.parcours-home-step-bullet img {
	width: 170%;
	transform: translate(-10px, -20px);
}

.parcours-home-step-cur .parcours-home-step-bullet {
	background-color: #ffcc03;
	border: solid 3px #a28400;
}

.parcours-home-step-done .parcours-home-step-bullet {
	background-color: #76c1ff;
	border: solid 3px #225b85;
}

.parcours-home-footer {
	height: 165px;
	background-color: #76c1ff;
	display: flex;
	justify-content: center;
	align-items: center;
}
.parcours-home-footer > div {
	margin: 20px;
}
.parcours-home-footer a {
	border: none;
}

@media (max-width: 600px) {
	.parcours-home-step {
		width: 90%;
		height: 80px;
	}
}

@media (max-width: 800px) {
	.parcours-home-footer {
		height: auto;
		display: flex;
		flex-direction: column;
		background-color: #4b96d1;
	}
	.parcours-home-footer > div {
		position: relative;
		border-top: solid 1px white;
		width: 100%;
		margin: 0;
		height: 60px;
	}
	.parcours-home-footer > div a {
		position: relative;
		border: solid 1px yellow;
		width: 100%;
		border: none;
		margin: 0;
		border-radius: 0;
		background-color: #4b96d1;
		color: white;
		text-align: left;
		padding-left: 50px;
	}
	.parcours-home-footer > div:hover a {
		color: #0b2237;
	}
	.parcours-home-footer > div a:after {
		content: ">";
		position: absolute;
		right: 60px;
	}
}

/*** Page parcours ***/

.parcours-title h1 {
	margin-top: 100px;
}
.parcours-title h1:after {
	display: block;
	content: url("/img/title-deco.svg");
	width: 500px;
	max-width: 40%;
	margin: auto;
}
.parcours-layout {
	display: grid;
	grid-template-columns: 450px 1fr;
	padding: 50px;
	gap: 100px;
}

.parcours-text {
	padding: 0;
	margin: 0;
}
.parcours-text-limited {
	max-width: 700px;
	margin: 60px auto;
	padding: 20px;
}
.parcours-text p {
	padding: 0;
	margin: 0 0 30px 0;
	font-size: 18px;
	line-height: 28px;
	font-weight: 400;
}
@media (max-width: 800px) {
	.parcours-text p {
		padding: 0;
		margin: 0 0 20px 0;
		font-size: 15px;
		line-height: 21px;
		font-weight: 400;
	}
}
.parcours-text a {
	font-weight: 400;
}
.parcours-text ul {
	margin-bottom: 20px;
}
.parcours-text li {
	list-style: disc;
	text-align: left;
	margin-left: 30px;
	font-weight: 400;
}

.parcours-chapo p {
	text-align: left;
}

.parcours-video {
	position: relative;
}

.parcours-content {
	margin-top: 60px;
}
.parcours-content p {
	text-align: justify;
}

.parcours-memo-header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.parcours-memo-container {
	padding: 20px 10px;
	background-color: #f1f1f1;
	border: solid 3px #4b96d1;
}
.parcours-memo h2 {
	font-size: 24px;
	color: #4b96d1;
	font-weight: 700;
}
.parcours-memo h3 {
	font-size: 16px;
	line-height: 20px;
	margin-top: 20px;
	text-align: left;
	font-weight: 600;
	text-transform: uppercase;
}
.parcours-memo li {
	font-size: 16px;
	line-height: 20px;
	list-style: disc;
	text-align: left;
	margin-left: 30px;
}
.parcours-memo li:first-letter {
	text-transform: uppercase;
}
.parcours-memo .tsa-button-alt a {
	border-color: #c8c8c8;
	color: black;
	padding: 6px 10px;
	font-size: 12px;
	line-height: 18px;
}
.parcours-memo .tsa-button-alt a img {
	margin: 0 2px 0 8px;
	height: 15px;
	transform: translateY(3px);
}
.parcours-memo .tsa-button-alt:hover a {
	border-color: #4b96d1;
	background-color: white;
}

.parcours-ressources {
	margin-top: 60px;
	padding: 20px 10px 40px;
	border: solid 3px #4b96d1;
	display: flex;
	justify-content: center;
	align-items: flex-start;
	flex-direction: column;
}
.parcours-ressources h2 {
	font-size: 22px;
	font-weight: bold;
	margin: 0 auto 30px;
	padding: 30px 0;
	border-bottom: solid 3px #4b96d1;
}
.parcours-ressources p {
	text-align: left;
	margin: 20px 30px;
}
.parcours-ressources-line {
	margin: 5px 20px;
}
.parcours-ressources-line a {
	font-size: 14px;
	font-weight: 600;
	text-transform: uppercase;
}
.parcours-ressources-line a:hover {
	text-decoration: underline;
}
.parcours-ressources-line span {
	font-weight: 300;
}
.parcours-ressources-line img {
	width: 15px;
	margin-left: 5px;
	transform: translateY(2px);
}
.parcours-memo-mobile {
	display: none;
}
@media (max-width: 1100px) {
	.parcours-memo-mobile {
		display: block;
	}
	.parcours-memo-desktop {
		display: none;
	}
	.parcours-layout {
		grid-template-columns: 1fr 2fr;
		padding: 30px;
		gap: 30px;
	}
	.parcours-title h1 {
		margin-top: 30px;
	}
	.parcours-layout {
		grid-template-columns: 1fr;
	}
	.parcours-chapo {
		width: 90%;
		text-align: center;
		margin: auto;
	}
	.parcours-chapo p {
		text-align: center;
	}
	.parcours-memo {
		width: 100%;
	}
	.parcours-ressources h2 {
		margin-bottom: 20px;
	}
}
@media (max-width: 700px) {
	.parcours-layout {
		padding: 20px;
	}
	.parcours-memo {
		padding: 20px;
	}
	.parcours-ressources {
		padding: 10px 0;
		margin: 20px;
	}
}
.parcours-start-game {
	position: relative;
	background-color: #76c1ff;
	display: flex;
	justify-content: center;
	align-items: center;
	padding: 135px 0 40px 0;
	margin-top: 70px;
}
.parcours-start-game .tsa-button-color a {
	margin: 0;
}
.parcours-start-game .game-start-arrow {
	position: absolute;
	top: -2px;
	width: 100%;
	width: 940px;
}
.parcours-start-game .game-start-invite {
	position: absolute;
	top: -120px;
}
.parcours-start-game .game-start-invite p {
	color: #666666;
	font-size: 19px;
	font-weight: 500;
	margin: 0;
}
.parcours-start-game .harfang {
	margin-bottom: 10px;
	width: 100px;
}
@media (max-width: 1000px) {
	.parcours-start-game .game-start-arrow {
		width: 100%;
	}
}
@media (max-width: 800px) {
	.parcours-start-game {
		padding-top: 110px;
	}
	.parcours-start-game .game-start-invite {
		top: -160px;
	}
	.parcours-start-game {
		margin-top: 120px;
	}
}
@media (max-width: 600px) {
	.parcours-start-game {
		padding-top: 70px;
	}
	.parcours-start-game .game-start-invite {
		top: -160px;
	}
	.parcours-start-game {
		margin-top: 100px;
	}
}

.parcours-video-double {
	display: grid;
	grid-template-columns: 1fr 1fr;
}
.parcours-video-double > div {
	padding: 20px;
}
@media (max-width: 800px) {
	.parcours-text-limited {
		margin: 20px auto;
	}
	.parcours-video-double {
		grid-template-columns: 1fr;
	}
}

/******************/
/***** Badges *****/
/******************/

.badge-won {
	width: 120px;
	margin: 20px auto 40px;
}
.list-badges {
	display: flex;
	flex-wrap: wrap;
	margin-bottom: 40px;
}
.list-badges > img {
	width: 150px;
	margin: 20px;
}
