/* CSS Document */

@import url('https://fonts.googleapis.com/css2?family=Barlow+Condensed:wght@300;400;500&family=Roboto:wght@300;400;500&display=swap');

html, body {
	height: 100%;
	padding: 0;
	margin: 0;
}
body {
	display: flex;
	flex-direction: column;
	font-family: 'Roboto', "sans-serif";
	font-size: 16px;
	font-weight: 300;
	background-color: #cecece;
	color: #000;
}

*:focus {
	outline: none !important;
}

img {
    max-width: 100%;
    height: auto;
    border: none;
	vertical-align: bottom !important;
}

a {
    text-decoration: none;
}

ul, li {
	list-style-type: none;
	margin: 0;
	padding: 0;
}

sup {
	vertical-align: text-top;
	font-size: 1em;
}

ul.spip {
	padding-left: 15px;
	margin: 0;
}
ul.spip li {
	list-style: disc;
	margin: 0;
	padding: 0;
}

#top {
	position: fixed;
	bottom: 100px;
	right: 22px;
	font-size: 32px;
	color: #cecece;
	text-decoration: none;
	transition: color .3s ease, padding-bottom .45s ease-in-out;
	display: none;
	cursor: pointer;
	z-index: 10;
}
#top:hover {
	color: #fff;
	padding-bottom: 20px;
}

hr {
	height: 1px;
  	margin: 1em 0;
  	padding: 0;
  	color: #154c72;
  	background-color: #154c72;
  	border: 0;
}

.wow {
	animation-delay: .5s;
	animation-duration: 1s;
}

/* cache-cache ******************************************/

.contenu-resp, .contenu-resp-int, .pdf-resp {
	display: none;
	visibility: hidden;
	opacity: 0;
}

/* fin du jeu *******************************************/

header {
	position: fixed;
	top: 0;
	width: 100%;
	height: 60px;
	background-color: #154c72;
	line-height: 60px;
	animation-delay: .5s;
	animation-duration: 1s;
	z-index: 4;
}
header h1 {
	margin: 0 0 0 60px;
	font: 400 2em 'Barlow Condensed';
	color: #fff;
	text-transform: uppercase;
	line-height: 60px;
	height: 60px;
	text-align: left;
	animation-delay: 1s;
	animation-duration: 2s;
}
header h1 strong {
	font-weight: 400;
	color: #ffd700;
}
header h1 a {
	color: #fff;
	transition: .25s ease;
}
header h1 a strong {
	color: #ffd700;
	transition: .25s ease;
}
header h1 a:hover {
	color: #fff;
}
header h1 a:hover strong {
	color: #fff;
}

.accroche {
	position: fixed;
	top: 60px;
	width: 100%;
	height: 40px;
	background-color: #444;
	text-align: left;
	display: flex;
	flex-direction: column;
	justify-content: center;
	animation-delay: .5s;
	animation-duration: 1s;
	z-index: 5;
}
.accroche p {
	margin: 0 0 0 60px;
	font-weight: 300;
	font-size: .9em;
	color: #fff;
	letter-spacing: 1px;
	animation-delay: 1s;
	animation-duration: 2s;
}
.accroche p a {
	color: #ffd700;
	font-weight: 500;
	transition: .25s ease;
}
.accroche p a:hover {
	color: #fff;
}

.tools {
	position: fixed;
	top: 0px;
	right: 0px;
	width: 30px;
	min-height: 100vh;
	padding: 20px;
	text-align: center;
	background-color: #154c72;
	animation-delay: 1.5s;
	animation-duration: 1s;
	z-index: 5;
}
.tools i {
	position: relative;
	font-size: 30px;
	color: #cecece;
	transition: .25s ease;
	z-index: 6;
}
.tools a {
	color: #cecece;
}
.tools i:hover {
	color: #FFF;
}
.tools span {
	display: block;
	width: 30px;
	height: 20px;
}
.tools i:hover:after, .tools i:focus:after, .top-right button i:hover:after, .top-right button i:focus:after, .tools #styleswitcher img:hover:after, .tools #styleswitcher img:focus:after {
	content: attr(aria-label);
	position: absolute;
	top: 2px;
	right: 40px;
	z-index: 8;
	white-space: nowrap;
	padding: 5px 10px 6px;
	background-color: #000;
	color: #fff;
	font-size: 15px;
	font-weight: 400;
	font-family: 'Barlow Condensed';
	text-transform: uppercase;
	border-radius: .2em;
}
[aria-label]:focus {
  outline: none;
}
/*.tools #styleswitcher {
	display: inline-block;
	width: 100%;
	margin-top: 40px;
}
.tools #styleswitcher img {
	position: relative;
	width: 30px;
	margin-bottom: 15px;
	transition: .25s ease;
	z-index: 6;
}*/


/* donne moi ta main camarade ********************************************************************************/
main {
	display: inline-block;
	width: auto;
	margin: 140px 90px 40px 60px;
	animation-delay: 2s;
	animation-duration: 3s;
}
.contenu {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-column-gap: 50px;
	width: 100%;
	text-align: center;
}
.portrait {
	grid-area: 1 / 1 / 2 / 2;
	display: inline-block;
	animation-delay: 2.5s;
	animation-duration: 3s;
}
.portrait img.spip_logo {
	width: 100%;
}
.portrait .pdf {
	display: inline-block;
	width: 100%;
	margin: 20px 0 6px;
}
.portrait .pdf img {
	width: 25%;
	transition: .2s linear;
}
.portrait .pdf:hover img {
	transform: rotateY(180deg);
	transform-origin: center;
}
.portrait small {
	display: inline-block;
	width: 100%;
	text-align: center;
	font: 400 1em 'Barlow Condensed';
}
.txt-intro {
	display: inline-block;
	width: 100%;
	padding: 15px 0 0;
	text-align: left;
	line-height: 1.3;
}
.txt-intro a {
	color: #154c72;
	transition: .3s ease;
}
.txt-intro a:hover {
	color: #444;
}
.txt-intro p {
	margin: .5em 0 0;
}
.txt-intro a button {
	display: inline-block;
	width: 100%;
	margin-top: 1em;
	padding: 10px 5px 15px;
	background-color: #154c72;
	border-radius: .2em;
	border: none;
	color: #ffd700;
	font: 400 1.4em 'Barlow Condensed';
	text-transform: uppercase;
	transition: .3s ease;
	cursor: pointer;
}
.txt-intro a:hover button, .txt-intro a.on button, .portrait-int a:hover button, .portrait-int a.on button {
	background-color: #333;
	color: #fff;
}
.txt-intro a button small {
	font: 400 .8em 'Barlow Condensed';
}

.parcours {
	grid-area: 1 / 2 / 2 / 6;
	animation-duration: 2s;
}
.parcours h2, .parcours-int h2 {
	font: 500 1.6em 'Barlow Condensed';
	color: #154c72;
	margin: 0 0 .5em;
	text-transform: uppercase;
}
.item {
	position: relative;
	background-color: #fff;
	color: #000;
	border-radius: .2em;
	width: 100%;
	height: 100%;
	transition: .3s ease;
}
.item:hover {
	background-color: rgba(255,255,255,0.8);
}
.item h3 {
	margin: 0 !important;
	font: 500 1.4em 'Roboto';
	background-color: #154c72;
	color: #ffd700;
	padding: 10px 0;
	border-radius: .2em .2em 0 0;
	transition: .3s ease;
}
.item:hover h3 {
	background-color: #444;
	color: #fff;
}
.item small {
	display: inline-block;
	width: 100%;
	background-color: #cecece;
	color: #154c72;
	font: 400 1.1em 'Barlow Condensed';
	padding: 6px 0;
}
a .item12 {
	display: flex;
	flex-direction: column;
	justify-content: center;
	position: relative;
	background-color: #154c72;
	color: #fff !important;
	border-radius: .2em;
	width: 100%;
	height: 100%;
	/*padding: 20px 0;*/
	transition: .3s ease;
}
a .item12 h4 {
	color: #ffd700;
	font: 500 1.2em 'Barlow Condensed';
	margin: 0 15px .5em;
}
a:hover .item12 {
	background-color: #333;
}
.txt-12 {
	display: inline-block;
	padding: 0 15px;
	font-size: .9em;
}
.desc {
	display: inline-block;
	padding: 10px 15px;
	/*text-align: left;*/
	color: #000;
	font-size: .8em;
	font-weight: 400;
	line-height: 1.3;
}
.desc strong {
	display: inline-block;
	width: 100%;
	text-align: center;
	font: 500 1.4em 'Barlow Condensed';
	color: #154c72;
	text-transform: uppercase;
}
.desc i {
	display: inline-block;
	width: 100%;
	text-align: center;
	font: 500 1.1em 'Barlow Condensed';
	color: #154c72;
	padding: 0 0 5px;
	margin-bottom: 5px;
	border-bottom: 1px dotted #154c72;
}
.date {
	display: inline-block;
	width: 100%;
	text-align: center;
	font-weight: 400;
	font-size: .95em;
	color: #154c72;
	border-top: 1px dotted #154c72;
	padding: 5px 0;
	margin-top: 5px;
}
.zoom {
	display: inline-block;
	width: 100%;
	background-color: #154c72;
	color: #ffd700;
	font: 500 1.3em 'Barlow Condensed';
	padding: 6px 0;
	margin-bottom: 10px;
	transition: .25s linear;
}
.item:hover .zoom {
	background-color: #444;
	color: #fff;
}

/* le footer est en bas et le grenier en haut **********************************************/

footer {
	margin-top: auto;
	width: auto;
	display: block;
	padding: 30px 60px;
	background-color: #154c72;
	color: #fff;
	text-align: center;
}
footer a {
	color: #ffd700;
	transition: .25s ease;
}
footer a:hover, footer a.on {
	color: #fff;
}
footer .rappel {
	text-align: left;
	line-height: 1.4;
}
footer .rappel a.items {
	font-size: .9em;
}
footer .rappel h4 {
	font: 400 1.1em 'Roboto';
	margin: 0 0 .5em;
}

/* intérieur *******************************************************************************/

main.interieur {
	display: inline-block;
	width: auto;
	margin: 140px 90px 40px 60px;
	animation-delay: .5s;
	animation-duration: 2s;
}

.contenu-int {
	display: grid;
	grid-template-columns: repeat(5, 1fr);
	grid-column-gap: 40px;
	width: 100%;
	text-align: center;
}
.portrait-int {
	grid-area: 1 / 1 / 2 / 2;
	display: inline-block;
}
.parcours-int {
	grid-area: 1 / 2 / 2 / 6;
	animation-duration: 2s;
}
.txt-intro.int a button {
	margin: 0 0 .5em!important;
}

.pdf-resp-rub {
	width: 100%;
	text-align: center;
}
.pdf-resp-rub {
	margin-bottom: 20px;
}

.parcours-int h2 a {
	font-size: .85em;
	color: #333;
	transition: .25s ease;
}
.parcours-int h2 a:hover {
	color: #000;
}
.parcours-int h2 strong {
    font-weight: 500;
}

.fiche {
	background-color: rgba(255,255,255,0.6);
	padding: 20px 0 0;
	border-radius: .2em;
}
.structure {
	font: 400 1.4em 'Barlow Condensed';
}
.structure strong {
    font-weight: 500;
}
.structure small {
	line-height: 1.25 !important;
}
.descriptif {
	display: inline-block;
	margin: .5em 0 0;
	font-size: 1.1em;
	width: 100%;
}
.date-int {
	display: inline-block;
	width: 100%;
	margin: 15px 0;
	font: 400 1.1em 'Barlow Condensed';
}
.date-int strong {
	font-weight: 400;
	color: #154c72;
}
.mission {
	display: inline-block;
	margin-top: 10px;
	background-color: #fff;
	padding: 20px 30px;
	text-align: left;
	font-weight: 400;
	line-height: 1.3;
	border-radius: 0 0 .2em .2em;
}
.mission strong, .complement strong {
	font-weight: 500;
}
.mission p, .complement p {
	margin: 0 0 1em;
}
.mission ul.spip li i {
	font-style: normal;
	font-weight: 500;
}
.mission ul.spip {
	margin-bottom: .5em;
}
.mission ul.spip li ul.spip li {
	list-style-type: circle;
	font-size: .9em;
}
.mission a {
	color: #154c72;
	font-weight: 500;
	transition: .25s ease;
}
.mission a:hover {
	color: #000;
}
.mission h2.spip {
	font-weight: 400;
	margin: .5em 0;
	font-size: 1em;
}
.mission h2.spip strong {
	font-weight: 500;
	font-size: 1.2em;
}
.mission h2.spip .niveau {
	display: inline-block;
	width: 100%;
	height: 30px;
	margin: .25em 0 0 0;
	background-color: rgba(255,208,0,0.5);
	border-radius: .2em;
	text-align: left;
}
.n90 {
	display: inline-block;
	float: left;
	width: 90%;
	height: 30px;
	background-color: #154c72;
	border-radius: .2em;
	animation: niveau9 2.5s linear -1s;
}
.n80 {
	display: inline-block;
	float: left;
	width: 80%;
	height: 30px;
	background-color: #154c72;
	border-radius: .2em;
	animation: niveau8 2.5s linear -1s;
}
.n70 {
	display: inline-block;
	float: left;
	width: 70%;
	height: 30px;
	background-color: #154c72;
	border-radius: .2em;
	animation: niveau7 2.5s linear -1s;
}
.n60 {
	display: inline-block;
	float: left;
	width: 60%;
	height: 30px;
	background-color: #154c72;
	border-radius: .2em;
	animation: niveau6 2.5s linear -1s;
}
@keyframes niveau9 {
  from { 
	  opacity: 0;
	  width: 0;
	}
  to   {
	  opacity: 1;
	  width: 90%;
	}
}
@keyframes niveau8 {
  from { 
	  opacity: 0;
	  width: 0;
	}
  to   {
	  opacity: 1;
	  width: 80%;
	}
}
@keyframes niveau7 {
  from { 
	  opacity: 0;
	  width: 0;
	}
  to   {
	  opacity: 1;
	  width: 70%;
	}
}
@keyframes niveau6 {
  from { 
	  opacity: 0;
	  width: 0;
	}
  to   {
	  opacity: 1;
	  width: 60%;
	}
}

.complement {
	display: inline-block;
	margin-top: 10px;
	background-color: #EBEBEB;
	padding: 20px 30px;
	text-align: left;
	font-weight: 400;
	border-radius: .2em;
}

h3 {
	margin: 1em 0 .25em;
	font: 400 1.4em 'Barlow Condensed';
	color: #154c72;
}
h3 strong {
	font-weight: 500;
}
.enavant {
	display: inline-block;
	width: auto;
	background-color: #154c72;
	padding: 20px;
	border-radius: .2em;
	color: #fff;
	font-size: 1.05em;
	font-weight: 500;
	margin-bottom: 25px;
}
.enavant h2.spip {
	color: #EBEBEB;
	font-size: 1.2em;
	font-weight: 500;
	margin: 0 0 .25em;
}
.enavant strong {
	font-weight: 500;
}
.enavant p {
	margin-bottom: 0;
}
.color {
	display: inline-block;
	background-color: #154c72;
	color: #fff;
	font-weight: 500;
	padding: 6px 15px;
	margin: 0 0 1em;
	border-radius: .2em;
}

/* mon responsive est plus beau que le tien ************************************************/

@media only screen and (max-width: 1042px) {
	
	.txt-intro {
		padding: 15px 0 0;
		font-size: .85em;
	}
	
}

@media only screen and (max-width: 920px) {
	
	header h1 {
		margin: 12px 0 0 30px;
		font: 400 1.8em 'Barlow Condensed';
		letter-spacing: normal;
	}
	.accroche p {
		margin: 0 0 0 30px;
		font: 400 1em 'Barlow Condensed';
		letter-spacing: normal;
	}
	main, main.interieur {
		margin: 140px 90px 40px 30px;
	}
	.contenu, .contenu-int {
		grid-column-gap: 30px;
	}
	.item {
		height: auto;
		margin-bottom: 20px;
	}
	.item h3 {
		padding: 6px 0;
	}
	a .item12 {
		height: auto;
		padding: 20px 0;
	}
	footer {
		padding: 30px 80px 30px 30px;
	}
	footer .rappel a.items {
		font-family: 'Barlow Condensed';
		font-size: 1em;
	}
	
}

@media only screen and (max-width: 760px) {
	
	.contenu-int {
		display: none;
		visibility: hidden;
		opacity: 0;
	}
	.contenu-resp-int {
		display: inline-block;
		visibility: visible;
		opacity: 1;
		width: 100%;
		text-align: center;
	}
	.portrait-int {
		grid-area: none;
		display: inline-block;
		width: 100%;
		margin-bottom: 30px;
		animation-delay: 2.5s;
		animation-duration: 3s;
	}
	.portrait-int a button {
		display: inline-block;
		margin: 0 10px 10px 0;
		padding: 6px 10px;
		background-color: #154c72;
		border-radius: .2em;
		border: none;
		color: #fff;
		font: 400 1.3em 'Barlow Condensed';
		transition: .3s ease;
		cursor: pointer;
	}
	.fiche {
		text-align: center;
	}
	
}

@media only screen and (max-width: 560px) {
	
	header h1 {
		margin: 12px 0 0 20px;
		font: 400 1.7em 'Barlow Condensed';
	}
	.accroche p {
		margin: 0 0 0 20px;
	}
	main, main.interieur {
		margin: 140px 90px 40px 20px;
	}
	footer {
		padding: 30px 80px 30px 20px;
	}
	.accroche p .temp {
		display: none;
		visibility: hidden;
		opacity: 0;
	}
	.accroche p {
		font: 400 1.2em 'Barlow Condensed';
	}
	.txt-intro a button {
		font: 500 1.5em 'Barlow Condensed';
		letter-spacing: 1px;
		padding: 8px 0;
	}
	
	.contenu {
		display: none;
		visibility: hidden;
		opacity: 0;
	}
	.contenu-resp, .pdf-resp {
		display: inline-block;
		visibility: visible;
		opacity: 1;
		width: 100%;
		text-align: center;
	}
	.pdf-resp {
		margin-bottom: 20px;
	}
	.portrait {
		grid-area: none;
		display: inline-block;
		width: 100%;
		margin-bottom: 30px;
		animation-delay: 2.5s;
		animation-duration: 3s;
	}
	.portrait img {
		width: 70%;
		margin: 0 auto 15px auto;
	}
	.txt-intro {
		display: inline-block;
		padding: 0;
		text-align: left;
		line-height: 1.3;
	}
	footer .rappel a.items {
		font-size: 1.2em;
	}
	.descriptif {
		font-size: 1em;
	}
	.portrait-int {
		margin: 20px 0;
	}
	.portrait-int a button {
		margin: 0 0 10px 0;
		width: 90%;
	}
	.structure {
		padding: 0 15px;
		line-height: 1.2;
	}
	.date-int {
		width: 90%;
		margin: 15px 0;
		padding: 0 5%;
	}
	.contenu-resp-int {
		margin-bottom: 20px !important;
	}
}
