@font-face {
	font-family: 'Geo';
	src: url('../fonts/GeosansLight.ttf') format('truetype');
	font-weight: normal;
	font-style: normal;
}
.btn,
#nav-icon div,
html.admin form input[type='submit'],
html.admin .accueil #home,
.menu-off > li .menu:before{
	-webkit-transition: all 250ms ease-in;
	-moz-transition: all 250ms ease-in;
	-o-transition: all 250ms ease-in;
	transition: all 250ms ease-in;
}
.btn,
#nav-icon,
.menu,
.close,
.contact,
html.admin form input[type='submit'],
html.admin form .suppr,
html.admin form .ajout{
	cursor: pointer;
}
html.front,
.front .wrap,
.front body,
iframe{
	height: 100%
}
.front .wrap{
	width: 100%;
	position: relative;
	overflow: hidden;
}
.front body{
	margin: 0;
	padding: 0;
	font-family: 'Geo', sans-serif;
	font-weight: 300;
}
iframe{
	width: 100%;
}
header{
	height: 70px;
	position: relative;
	margin-bottom: -70px;
}
header > *
{
	display: inline-block;
	position: absolute;
}
.wrap > header .logo,
.wrap > header h1{
	display: none;
	text-decoration: none;
}
header .logo.large{
	height: 50px;
	left: 20px;
	margin: 10px 0;
}
header .logo.large img{
	max-height: 100%;
}
header .logo.haut img{
	max-width: 100%;
}
header .logo.haut{
	width: 80px;
	margin: 30px 0;
	left: 40px;
}
header .logo.large{
	height: 50px;
	left: 20px;
	margin: 10px 0;
}
header .logo.large img{
	max-height: 100%;
}
header .logo.haut img{
	max-width: 100%;
}
header h1{
    font-size: 20px;
    font-weight: 300;
    line-height: 70px;
	letter-spacing: 3px;
    margin: auto;
    left: 0;
    right: 0;
    top: 0;
	bottom: 0;
    width: 60%;
    color: #225fb1;
    text-align: center;
}
header.mobile{
	background: none;
	height: initial;
	margin-bottom: 0;
}
header.mobile > *{
	display: block;
	position: relative;
}
header.mobile .logo.large{
	width: 100%;
	left: 0;
}
header.mobile .logo.haut{
	height: 100%;
    left: 0;
    margin: 10px auto;
}
header.mobile .logo.large img{
	width: 100%;
}
header.mobile .logo.haut img{
	width: 100%;
}
header.mobile h1{
    font-size: 18px;
    font-weight: 300;
    line-height: 24px;
    margin: auto;
    width: 100%;
    color: #fff;
    text-align: center;
    border-bottom: 1px solid #fff;
    padding-bottom: 15px;
}
#nav-icon div,
#nav-icon {
	-webkit-transform: rotate(0deg);
	-moz-transform: rotate(0deg);
	-o-transform: rotate(0deg);
	transform: rotate(0deg);
}
#nav-icon{
	background: rgba(112,112,112,0.9) none repeat scroll 0 0;
    border: medium none;
	display: block;
	position: fixed;
	border-radius: 100%;
	right: 20px;
	top: 10px;
	z-index: 350;
	width: 58px;
	height: 58px;
	opacity: 0.8;

	-webkit-transition: 500ms ease-in;
	-moz-transition: 500ms ease-in;
	-o-transition: 500ms ease-in;
	transition: 500ms ease-in;
	
}
	#nav-icon:hover
	{
		opacity: 1;
	}
	#nav-icon div{
		background: #225fb1 none repeat scroll 0 0;
		border-radius: 9px;
		display: block;
		height: 3px;
		left: 20%;
		opacity: 1;
		position: absolute;
		width: 60%;
	}
	#nav-icon div:nth-child(1)
	#nav-icon div:nth-child(2),
	#nav-icon div:nth-child(3),
	{
		-webkit-transform-origin: left center;
		-moz-transform-origin: left center;
		-o-transform-origin: left center;
		transform-origin: left center;
	}
	  
	#nav-icon div:nth-child(1) {
	  top: 16px;
	}

	#nav-icon div:nth-child(2) {
	  top: 26px;
	}

	#nav-icon div:nth-child(3) {
	  top: 36px;
	}
	#nav-icon.open div:nth-child(1),
	#nav-icon.open div:nth-child(3) {
		left: 20%;
		top: 26px;
	}
	#nav-icon.open div:nth-child(1) {
	  -webkit-transform: rotate(45deg);
	  -moz-transform: rotate(45deg);
	  -o-transform: rotate(45deg);
	  transform: rotate(45deg);
	}

	#nav-icon.open div:nth-child(2) {
	  width: 0%;
	  opacity: 0;
	}

	#nav-icon.open div:nth-child(3) {
		-webkit-transform: rotate(-45deg);
		-moz-transform: rotate(-45deg);
		-o-transform: rotate(-45deg);
		transform: rotate(-45deg);
	}
.menu-off
{
	position: absolute;
	right: 0;
	background-color: #fff;
	height: 100%;
	width: 200px;
	margin: 0;
    overflow-y: scroll;
	box-sizing: border-box;
	padding-top: 60px;
	padding-left: 20px;
	padding-right: 20px;
}
.menu-off > li
{
	list-style: none;
	color: #225fb1;
	font-size: 17px;
	position: relative;
}
.menu-off > li p
{ 
	margin:5px 0;
}
.menu-off > li .menu:before{
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 0 5px 10px;
	border-color: transparent transparent #225fb1 transparent;
	left: -15px;
    position: absolute;
    top: 7px;
    -moz-transform: rotate(90deg);
	-webkit-transform: rotate(90deg);
	-o-transform: rotate(90deg);
	-ms-transform: rotate(90deg);
	transform: rotate(90deg);
}
	.menu-off > li .menu.open:before{
		-moz-transform: rotate(180deg);
		-webkit-transform: rotate(180deg);
		-o-transform: rotate(180deg);
		-ms-transform: rotate(180deg);
		transform: rotate(180deg);
	}
.menu-off > li > ul.sous-menu{
	height: 100%;
	overflow: hidden;
	display: none;
}
.menu-off > li > ul.sous-menu > li
{
	list-style: disc;
	color: rgba(34,95,177,0.8);
	font-size: 15px;
}
.contact
{
	position: absolute;
	bottom: 0;
	left: 5%;
	letter-spacing: 2px;
	background-color: rgba(255,255,255,0.9);
	border-radius: 10px 10px 0 0;
	margin: 0;
	font-size: 25px;
	color: #225fb1;
	padding: 0 10px;
	text-decoration: none;
}
.btn.open{
	text-decoration: underline;
}
h1.btn.open{
	text-decoration: none;
}
.page-contact{
	position: absolute;
	width: 50%;
	height: 50%;
	background-color: rgba(51,51,51,0.7);
	z-index: 600;
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	color: #fff;
	text-align: center;
}
.page-contact .close{
	background-color: rgba(51, 51, 51, 0.9);
	border: 2px solid #fff;
	border-radius: 100%;
	font-size: 6vw;
	height: 6vw;
	line-height: 6vw;
	padding: 1vw;
	position: absolute;
	right: -3.5vw;
	top: -3.5vw;
	width: 6vw;
}
.page-contact h2{
	font-size: 5vw;
	font-weight: 300;
}
.page-contact p{
	font-size: 4vw;
}
/*ADMIN*/
html.admin body{
	margin: 0;
	padding: 0;
	font-family: 'Geo', sans-serif;
	font-weight: 300;
	background-color: rgba(112,112,112,1);
}
html.admin .wrap{
	width: 960px;
	margin: 0 auto;
	display: block;
	overflow: hidden;
	text-align: center;
	position: relative;
}
html.admin h1{
	color: #fff;
	padding-bottom: 40px;
	border-bottom: 1px solid #fff;
}
html.admin h2{
	color: #fff;	
}
html.admin form{
	width: 100%;
	margin: 20px 0;
}
html.admin form:last-of-type{
	padding-bottom: 20px;
	border-bottom: 1px solid #fff;
}
html.admin form input,
html.admin form select{
	background-color: rgba(255, 255, 255, 0.7);
    border: 1px solid rgba(255, 255, 255, 0.8);
    border-radius: 15px;
    color: rgba(50, 50, 50, 0.8);
    font-size: 16px;
    padding: 5px 10px;
    width: 25%;
    margin: 5px 1%;
}
html.admin form select{	
    border-radius: 15px 0 0 15px;
    width: 20%;
}
html.admin form .lien{
	width: 35%;
}
html.admin form .site{
	width: 25%;
}
html.admin form input[type='submit']{
	width: 15%;
	border: none;
	background-color: rgba(255, 255, 255, 0.9);
}
	html.admin form input[type='submit']:hover{
		background-color: rgba(255, 255, 255, 1);
		-webkit-box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);
		box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);		
	}
	html.admin form input[type='submit']:active{
		background-color: rgba(255, 255, 255, 1);
		-webkit-box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
		box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
	}

html.admin form .newlien{
	background-color: rgba(200, 255, 200, 0.8);	
	margin: 5px;
}

html.admin form .suppr{
	background-color: rgba(200, 120, 120, 0.9);
    border-radius: 100%;
    color: #fff;
    display: inline-block;
    font-size: 25px;
    line-height: 30px;
    text-decoration: none;
    width: 30px;
}
	html.admin form .suppr:hover{
		background-color: rgba(200, 120, 120,1);
		-webkit-box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);
		box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);		
	}
	html.admin form .suppr:active{
		background-color: rgba(200, 120, 120,1);
		-webkit-box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
		box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
	}
html.admin form .ajout{
	background-color: rgba(120, 200, 120, 0.9);
    border-radius: 100%;
    color: #fff;
    display: inline-block;
    font-size: 20px;
    line-height: 30px;
    border: none;
    text-decoration: none;
    width: 30px;
}
	html.admin form .ajout:hover{
		background-color: rgba(120, 200, 120,1);
		-webkit-box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);
		box-shadow: 0 0 10px 0 rgba(0,0,0,0.3);		
	}
	html.admin form .ajout:active{
		background-color: rgba(120, 200, 120,1);
		-webkit-box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
		box-shadow:inset 0 0 7px 0 rgba(0,0,0,0.3);
	}
html.admin .accueil{
	position: absolute;
	right: 10px;
    top: 20px;
}
html.admin .accueil #home{
	opacity: 0.8;
	width: 50px;
	height: 50px;
}
	html.admin .accueil #home:hover{
		opacity: 1;
	}
	html.admin .titres h3{
		display: inline-block;
		color: #fff;
		text-align: center;
		margin: 1%;
	}
		html.admin .titres h3:nth-of-type(1),		
		html.admin .titres h3:nth-of-type(3){
			width: 25%;
		}
		html.admin .titres h3:nth-of-type(2){
			width: 35%;
		}
small.sous-titre{
	text-decoration: none;
	pointer-events: none;
	color: #225fb1;
	font-size: 18px;
	text-align: center;
}
.entete{
	position: absolute;
	top: 10px;
	height: 56px;
	line-height: 56px;
	left: 0;
	padding-left: 10%;
	padding-right: 10px;
	background-color: rgba(255,255,255,01); 
}
/*FIN ADMIN*/
@media only screen and (min-width: 769px) {
	header.mobile{
		display: none;
	}
	.entete{
		position: absolute;
		top: 120px;
		padding-left: 5%;
	}
	.wrap > header{
		background-color: rgba(255,255,255,0.9);
		height: 100px;
		margin-bottom: -100px;
		display: block;
	}
	.wrap > header .logo,
	.wrap > header small.sous-titre,
	.wrap > header h1{
		display: inline-block;
	}
		.wrap > header .logo.haut{
			margin: 10px 0 0 0;
			max-height: 80px;
			width: 150px;
		}
			.wrap > header .logo.haut img{
				max-height: 80px;
			}
		.wrap > header .logo.large{
			height: 80px;
			margin: 20px 0 0 0;
		}
	.wrap > header small.sous-titre,
	.wrap > header .logo{
		float: left;
	}
	.wrap > header small.sous-titre{
		line-height: 90px;
		margin-left: 2vh;
	}
	.wrap > header h1{
	    font-size: 34px;
	    line-height: 100px;
	}
	.menu-off
	{
		right: 0;
		width: 400px;
		padding-top: 130px;
		padding-left: 50px;
	}
		.menu-off > li
		{
			font-size: 27px;
		}
		.menu-off > li > ul.sous-menu > li
		{
			font-size: 24px;
		}
		.menu-off > li p
		{
			margin:15px 0;
		}
	#nav-icon{
		right: 25px;
		top: 25px;
		background: none ;
		border-radius: 0;
	}
	.contact
	{
		left: 5%;
		letter-spacing: 5px;
		font-size: 34px;
		padding: 0 20px;
	}
	.page-contact{
		width: 50%;
		height: 50%;
	}
}
@media only screen and (min-width: 1100px) {
	.page-contact h2{
		font-size: 60px;
	}
	.wrap > header small.sous-titre{
		font-size: 3vh;
	}
	.page-contact p{
		font-size: 50px;
	}
	.page-contact .close{
		font-size: 40px;
    	height: 50px;
    	line-height: 50px;
    	padding: 5px;
    	right: -30px;
    	top: -30px;
    	width: 50px;
	}
	.menu-off > li .menu:before{
		left: -25px;
    	top: 10px;
	}	
}