/* CSS RESET
================================================== */
.container {
	width: 90%;
}
body, html {
	font-family: 'Noto Sans JP', sans-serif;
	font-weight: 300;
	color: #1B1B1F;
	height: 100%;
}
body { font-size: 65%; } /* Utiliser ainsi : font-size: 14px; font-size: 1.4rem; */
h1, h2, h3, h4, h5, h6 {
	font-size  : 100%;
	font-weight: normal;
}
a {
	text-decoration: none;
	color: #20323E;
	font-weight: 700;
}
.clearer {
	clear      : both;
	visibility : hidden;
	font-size  : 0px;
	line-height: 0px;
}
.rt {
	position: absolute;
	left    : -10000px;
}
abbr {
	text-decoration: underline;
	-webkit-text-decoration: underline dotted;
	text-decoration: underline dotted;
	cursor: help;
	border-bottom: 0;
	-webkit-text-decoration-skip-ink: none;
	text-decoration-skip-ink: none;
}
/* FIN CSS RESET */
header, main, footer.hero {
border-left: 20px solid #0E3422;
}
#header {
	padding-top: 20px;
}
#nom {
	text-transform: uppercase;
	font-size: 2.4em;
	line-height: 1.1em;
}
#nom span, #coordonnees i {
	color: #0E3422;
}
#menu {
	font-size: 1.3em;
}
#menu a {
	font-weight: 300;
	text-transform: uppercase;
}
#menu .current a {
	font-weight: 700;
}
#menu a:hover:before {
	color: #efefef;
}
#menu .current a:before, #menu a:hover:before {
	content: '\25A0';
	position: absolute;
	margin-left: -1.3em;
}
#menu .current a:before, #menu .current a:hover:before {
	color: #0E3422;
}
#coordonnees {
font-size: 1.5em;
text-align: right;
}
#coordonnees a i {
font-size: 1.2em;
margin-left: 5px;
}
#coordonnees .telephone {
	font-size: 1.2em;
	font-weight: 700;
}
#coordonnees .email a {
	font-weight: 300;
	font-size: 0.9em;
}
main {
	padding-top: 30px;
}
main #main {
	font-size: 1.2em;
	line-height: 1.9em;
}
main #main p {
	margin-bottom: 10px;
}
h1 {
	text-transform: uppercase;
	font-size: 2.7em;
	line-height: 1.1em;
	text-align: center;
	color: #0E3422;
	margin-bottom: 10px;
}
h2 {
	font-size: 1.4em;
	text-align: center;
}
article h2 {
	text-align: left;
	margin-bottom: 10px;
	margin-top: 20px;
}
blockquote {
	background-color: #E5E7E8;
	border-radius: 5px;
	padding: 20px;
	text-align: center;
	font-size: 1.3em;
	font-weight: 700;
	margin: 30px auto;
	position: relative;
}
blockquote p {
	margin: 30px;
	font-size: 1.3em;
	line-height: 1.8em;
}
blockquote p:before, blockquote p:after {
	position: absolute;
	font-size: 3em;
}
blockquote p:before {
	content: "«";
	left: 20px;
	top: 15px;
}
blockquote p:after {
	content: "»";
	right: 20px;
	bottom: 1.2em;
}
blockquote footer {
	text-align: right;
	font-size: 1em;
	font-weight: 300;
}
.image img {
	border-radius: 5px;
}
.is-third, .is-half {
	width: 33%;
	float: left;
	margin: 0px 40px 15px 0px;
}
.is-half {
	width: 50%;
}
main #main h3 {
	font-size: 1.4em;
	margin-bottom: 10px;
	font-weight: 700;
	color: #0E3422;
}
main #main h3:not(:first-child) {
	margin-top: 20px;
}
main #main ul li {
	padding-left: 20px;
	margin-bottom: 5px;
}
main #main ul li:before {
	content: '\25A0';
	margin-right: 1em;
	color: #0E3422;
	font-size: 0.7em;
}
.competences {
	border-top: 1px solid #0E3422;
	margin-top: 20px;
	padding-top: 20px;
}
aside .competences {
	border-width: 0px;
	padding-top: 0px;
	margin-top: 10px;
}
.tile.is-parent article:first-child {
	border-bottom: 1px solid #0E3422;
}
article.competence h3 {
	font-size: 2.3em;
	text-transform: uppercase;
	line-height: 1.1em;
	margin-bottom: 10px;
}
article.competence p {
	line-height: 2em;
	font-size: 1.2em;
	margin-bottom: 10px;
}
article.competence p a {
	font-weight: 300;
	text-decoration: underline;
}
article.competence p a:hover {
	text-decoration: none;
}
article.competence h3 span {
	color: #97979B;
}
.space {
	margin: 20px auto;
}
.centre {
	text-align: center;
}
.tinytitle {
	text-transform: uppercase;
}
.bouton {
	text-transform: uppercase;
	padding: 3px 15px;
	border: 1px solid #1B1B1F;
	color: #1B1B1F;
	border-radius: 5px;
}
a:hover.bouton {
	background-color: #1B1B1F;
	color: #ffffff;
}
.autres {
	font-size: 2.5em;
	text-transform: uppercase;
	margin-bottom: 0;
	border-bottom: 1px solid #d9d9d9;
	color: #d9d9d9;
}
#footer {
	margin-top: 50px !important;
	padding: 30px 0;
	border-top: 1px solid #EAECEC;
	font-size: 1.2em;
}
#footer p {
	margin-bottom: 5px;
}
#footer p.legal a {
	font-weight: 300;
}
#footer p.legal a:hover {
	text-decoration: underline;
}
#footer .rs {
	font-size: 1.4em;
}
.column .image {
	margin-bottom: 20px;
}
.input, .textarea {
	font-family: 'Noto Sans JP', sans-serif;
}
.input::placeholder, .textarea::placeholder {
	text-transform: uppercase;
}
.group_errors {
background-color: rgb(246, 212, 204);
padding: 20px;
margin-bottom: 20px;
border-radius: 5px;
}
h2.error, .error {
	color: rgb(148, 38, 16);
}
.group_errors h2.error {
font-weight: 700;
margin-bottom: 15px;
text-align: left;
}
.button {
border-color: #0E3422 !important;
font-family: 'Noto Sans JP', sans-serif;
text-transform: uppercase;
font-weight: 700;
color: #0E3422 !important;
font-size: 0.8em;
}
#CcMg {
width: 100%;
}
#CcMg td:not(.label) {
width: 75%;
}

@media (max-width: 1024px) {
	
}

@media (min-width: 769px) {
	.tmenu {
		display: none;
	}
}
@media (max-width: 768px) {
	.tmenu {
		top: 20px;
		font-size: 2em;
		position: absolute;
		left: calc( 100% - 40px );
		transition: ease-in-out 0.4s;
	}
	.tmenu.open {
		left: calc( 50% - 30px );
	}
	#menu nav ul, #ssheader nav ul {
		display: inline;
	}
	#header.container {
		position: unset;
	}
	#menunav {
		position: fixed;
		top: 0;
		right: -50%;
		height: 100%;
		width: 50%;
		background-color: white;
		padding: 30px;
		z-index: 99;
		transition: ease-in-out 0.4s;
	}
	#menunav.open {
		right: 0;
		box-shadow: 0 0 30px rgba(0,0,0,0.2);
	}
	#menu nav ul li:not(:first-child) a, #ssheader nav ul li:not(:first-child) a {
		margin-left: 0px;
	}
	#menu nav ul li a, #ssheader nav ul li a {
		font-size: 1.6em;
		line-height: 2.5em;
	}
	#menu nav ul li.current a:not(.contact):after, #menu nav ul li.active a:not(.contact):after {
		background-color: transparent;
	}
	#rs {
		margin-top: 20px;
	}
}
@media (max-width: 479px) {
	.tmenu.open {
		right: unset;
		left: 30px;
		z-index: 999;
	}
	#menu nav {
		width: 100%;
		right: -100%;
		padding-top: 80px;
	}
}