/*
	Theme Name: Signa Concept
	Theme URI: http://effigen.fr
	Description: Thème Signa Concept
	Version: 1.4.3
	Author: KOOKline (@kookline)
	Author URI: http://kookline.net
	Tags: HTML5, CSS3

	License: MIT
	License URI: http://opensource.org/licenses/mit-license.php
*/

/*------------------------------------*\
    MAIN
\*------------------------------------*/

/* global box-sizing */
*,
*:after,
*:before {
	-moz-box-sizing:border-box;
	box-sizing:border-box;
	-webkit-font-smoothing:antialiased;
	font-smoothing:antialiased;
	text-rendering:optimizeLegibility;
}
/* html element 62.5% font-size for REM use */
html {
	font-size:62.5%;
	height: 100%;
}
body {
	font:300 13px Arial, sans-serif;
	color:#444;
	background: url(img/bg.png) repeat-x top left #c8d5e7; /* Old browsers */
}
/* clear */
.clear:before,
.clear:after {
    content:' ';
    display:table;
}

.clear:after {
    clear:both;
}
.clear {
    *zoom:1;
}
img {
	max-width:100%;
	vertical-align:bottom;
}
a {
	color:#2d3c8a;
	text-decoration: none;
}
a:hover {

}
a:focus {
	outline:0;
}
a:hover,
a:active {
	outline:0;
}
input:focus {
	outline:0;
	border:1px solid #04A4CC;
}

p
{
	font-family: Arial;
	font-size: 13px;
	color: #333;
	line-height: 20px;
}

/*------------------------------------*\
    STRUCTURE
\*------------------------------------*/
.wpcf7 input[type="submit"],
.footer .newsletter input[type="submit"]
{
	transition:all 0.5s ease;
}
.wpcf7 input[type="submit"]:hover,
.footer .newsletter input[type="submit"]:hover
{
	color: white;
	background: #2d3c8a;
}
/* wrapper */
.wrapper {
	width:960px;
	margin:0 auto;
	position:relative;
}
.content-wrapper
{
	margin-top: 40px;
	padding: 5px;
	background: white;
}
.home .content-wrapper,
footer .content-wrapper
{
	background: transparent;
}
footer .content-wrapper
{
	margin-top: 10px;
	padding: 5px 0;
}
.home footer .content-wrapper
{
	padding: 5px;
}
/* sidebar */
.sidebar {

}
div.d272
{
	width: 272px;
}
div.d295
{
	width: 295px;
}
div.d363
{
	width: 363px;
}

div.d470
{
	width: 475px;
}
.home div.d470
{
	width: 470px;
}
div.d272,
div.d363,
div.d295,
div.d470
{
	float: left;
	min-height: 10px;
}
div.d272 + div,
div.d363 + div,
div.d295 + div,
div.d470 + div
{
	margin-left: 10px;
}
.vignette
{
	position: relative;
}
.separate
{
	margin-top: 10px;
	display: block;
}
.vignette:before
{
	content: '';
	height: 0;
	position: absolute;
	width: 100%;
	bottom: 0;
	left: 0;
	background: #2d3c8a;
	background: rgba(45,60,138,0.7);
	filter: progid:DXImageTransform.Microsoft.gradient(GradientType=0,startColorstr='#462d3c8a', endColorstr='#462d3c8a');
	transition:all 0.5s ease;
}
.vignette:hover:before
{
	content: " ";
	height: 100%;
}
.vignette .texte
{
	margin: 0;
	position: absolute;
	padding: 7px 10px;
	bottom: 0;
	left: 0;
	background: #2d3c8a;
	color: white;
	font-family: 'Open sans',sans-serif;
	line-height: 20px;
	font-size: 18px;
	width: 100%;
	font-weight: 800;
	min-height: 50px;
	vertical-align: bottom;
}
.home .vignette .texte
{
	padding: 7px 0 7px 3px;
	text-transform: uppercase;
	line-height: 24px;
	font-size: 20px;
	min-height: 0;
	vertical-align: baseline;
}
.home .d363 a {
	width: calc(50% - 4.5px);
}
.home .d363 .vignette {
	height: 213px;
}
.home .d363 .vignette img {
	height: 100%;
	width: 100%;
	object-fit: cover;
	object-position: center;
}
.fleft
{
	display: block;
	float: left;
}
.fleft + .fleft
{
	margin-left: 9px;
}
.relative
{
	position: relative;
	z-index: 10;
}
/*------------------------------------*\
    HEADER
\*------------------------------------*/
.header {
	height: 182px;
}
.header-mask
{
	position: absolute;
	height: 100px;
	width: 100%;
	left: 0;
	top: 0;
	z-index: 9;
	background: #eaf6fc;
}
/* logo */
.logo {
	float: left;
	position: relative;
	z-index: 10;
}
.logo-img {

}
.bordered
{
	border: 3px solid #2d3c8a;
	background: white;
	padding: 8px;
}
/* nav */
.nav {
	float: left;
	margin-left: 4px;
	margin-top: 55px;
}
.nav ul li
{
	list-style: none;
}
.nav ul
{
	margin: 0;
	padding: 0;
}
.nav > ul > li
{
	display: block;
	float: left;
	height: 122px ;
	width: 153px ;
	position: relative;
}
.nav > ul > li > a {
	display: block;
	height: 122px;
	padding: 12px 4px;
	background: white;
	border:3px solid #feca30;
	border-radius: 4px;
	text-align: center;
	color: #2d3c8a;
	text-transform:	uppercase;
	font-family	: 'Open sans',sans-serif;
	font-weight : 800;
	font-size :	15px;
	vertical-align: bottom;
	line-height: 45px;
	position: relative;
	z-index: 10;
}
.nav > ul > li > a:hover,
.nav > ul > li.current-menu-ancestor > a,
.nav > ul > li.current-menu-item > a
 {
	border-radius: 0;
	border-top-right-radius:4px;
	border-bottom-right-radius:4px;
	background: #2d3c8a;
	border:none;
	border-left:3px solid #feca30;
	color: white;
}
/*menu images*/
.nav .menu-item a.menu-image-title-after.menu-image-not-hovered img,
.nav .menu-item a.menu-image-hovered.menu-image-title-after .menu-image-hover-wrapper
{
	padding: 0;
}
.nav > ul > li > a span.menu-image-hover-wrapper {
	display: block;
	height: 50px;
	margin: 0 auto;
	margin-bottom: 5px;
	padding: 0;
}
.nav > ul > li > a span.menu-image-hover-wrapper .helper {
	display: inline-block;
    height: 100%;
    vertical-align: middle;
}
.nav > ul > li > a span.lelien
{
	display: inline-block;
	vertical-align: middle;
	line-height: normal; 
	word-break: break-word;
}
.nav > ul > li > a span.menu-image-hover-wrapper img {
	max-height: 50px;
}
.nav > ul > li.current-menu-ancestor.menu-item a.menu-image-hovered img.hovered-image,
.nav > ul > li.current-menu-item.menu-item a.menu-image-hovered img.hovered-image
{
	opacity: 1;
	filter: alpha(opacity=100);
}
.nav > ul > li + li
{
	margin-left: 6px;
}
.nav > ul > li > ul
{
	position: absolute;
	top:0;
	left: 0;
	display: none;
	width: 100%;
	background: white;
	border: 1px solid #feca30;
	padding: 10px 0;
	border-radius: 2px;
}
.nav > ul > li:hover
{
	height: 127px;
}
.nav > ul > li:hover > ul
{
	display: block;
	z-index: 11;
	top: 127px;
}
/*Triangle au dessus du sous menu*/
.nav > ul > li:hover > ul:after,
.nav > ul > li:hover > ul:before {
	border-left: 10px solid transparent;
	border-right: 10px solid transparent;
	border-bottom: 12px solid white;
	top: -12px;
	content: '';
	left: 50%;
	margin-left: -10px;
	position: absolute;
}

/* Styling for second triangle (border) */

.nav > ul > li:hover > ul:before,
.nav > ul > li.hovered > ul:before {
    border-left: 11px solid transparent;
	border-right: 11px solid transparent;
	border-bottom: 12px solid;
	border-bottom-color: inherit;
	top: -13px;
	margin-left: -11px;
}
.nav > ul > li > ul > li
{
	font-family	:'Open sans',sans-serif;
	font-weight	:	800;
	font-size	:	15px;
	padding: 0 10px;
}
.nav > ul > li > ul > li + li a
{
	border-top:1px solid #2d3c8a;
}
.nav > ul > li > ul > li:hover
{
	background: #2d3c8a;
}
.nav > ul > li > ul > li:hover a
{
	color: white;
}
.nav > ul > li > ul > li a
{
	text-transform: uppercase;
	display: block;
	color: #2d3c8a;
        font-size: 14px;
	padding: 5px 0;
}
.breadcrumbs
{
	margin-top: 5px;
	border: 1px solid #ddddde;
	background: white;
	color: #888;
	padding: 5px 0 3px 40px;
	font-size: 11px;
}

/*------------------------------------*\
    PAGE d'ACCUEIL
\*------------------------------------*/
.rowaccueil
{
	margin-top: 30px;
}
div.contact
{
	height: 117px;
	padding-top: 8px;
	font-family: 'Open sans',sans-serif;
	text-align: center;
	text-transform: uppercase;
	background: white;
	transition:all 0.5s ease;

	display: flex;
	justify-content: center;
	align-items: center;
	flex-direction: column;
}
div.contact p
{
	margin: 0;
}

div.contact .jaune
{
	font-weight: 800;
	font-size: 12px;
	color: #feca30;
	line-height: 24px;
}
div.contact .texte
{
	font-weight: 600;
	font-size: 12px;
	color: #333;
	margin-bottom: 5px;
	line-height: 24px;
}
div.contact .cta
{
	display: inline-block;
	font-weight: 800;
	font-size: 22px;
	color: #333;
	line-height: 24px;
	padding-left: 32px;
	background: url(img/email.png) no-repeat left center;
}

a:hover div.contact
{
	background: #2d3c8a;
}
a:hover div.contact .texte,
a:hover div.contact .cta
{
	color: white;
}
.actu
{
	position: relative;
}
.actu .fa-plus
{
	position: absolute;
	right: 5px;
	bottom: 5px;
	color: white;
}
.actu p
{
	margin: 0;
}
.actu .label,
.actu .titre
{
	font-family: 'Open sans',sans-serif;
}
.actu .label
{
	font-weight: 800;
	font-size: 14px;
	color: #FECA30;
	text-transform: uppercase;
}
.actu .titre
{
	font-weight: 600;
	font-size: 18px;
	color: #333;
	text-transform: uppercase;
	line-height: 24px;
	margin: 0;
}
.home .actu .titre
{
	text-transform: none;
}
.actu img.alignleft
{
	margin-bottom: 0;
	margin-top: 0;
}
.actu:before
{
	content: "";
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 0;
	background: #2d3c8a;
	transition:all 0.5s ease;
	z-index: 0;
}
a:hover .actu:before
{
	content: " ";
	width: 100%;
}
a:hover .actu .titre,
a:hover .actu .abstract
{
	color: white;
}
/*------------------------------------*\
    PLAN DU SITE
\*------------------------------------*/
.plan-du-site article
{
	font-family: 'Open sans',sans-serif
}
.plan-du-site article ul > li:before
{
	vertical-align: baseline;
	font-size: 15px;
}
.plan-du-site article ul > li
{
	margin-bottom: 10px;
}
.plan-du-site article ul > li > a
{
	text-decoration: none;
	font-weight: 700;
	font-size: 20px;
	color: #00116c;
}
.plan-du-site article ul > li > a:hover
{
	color: white;
}
.plan-du-site article ul > li > ul
{
	padding-top: 10px;
}
.plan-du-site article ul > li > ul > li > a
{
	font-weight:600;
	font-size: 16px;
	color: #000b43;
}
.plan-du-site article ul > li > ul > li:before
{
	font-family: FontAwesome;
	content:'\f061';
	vertical-align: text-top;
}
/*------------------------------------*\
    PAGES INTERIEURES
\*------------------------------------*/
article h1,
article h2,
article h3,
article h4
{
	font-family: 'Open sans',sans-serif;
}
article h1
{
	font-weight: normal;
	font-size: 34px;
	color: #2d3c8a;
	line-height: 40px;
}
article h2
{
	font-weight: 700;
	font-size: 20px;
	color: #00116c;
	line-height: 24px;
}
article h3
{
	font-weight:600;
	font-size: 16px;
	color: #000b43;
	line-height: 20px;
	margin-top: -3px; /*Fix de la typo*/
}
article h4
{
	font-weight:800;
	font-size: 16px;
	color: #333;
	line-height: 20px;
	padding: 7px 20px;
	border: 2px solid #FECA30;
	text-align: center;
	display: inline-block;
}
article div.textcenter
{
	text-align: center;
}
article p
{
	margin: 10px auto;
}
article a
{
	display: inline-block;
	text-decoration:underline;
}
article a:hover
{
	color:#fff;
	background: #2d3c8a; 
}
article ul li
{
	list-style: none;
	position: relative;
	line-height: 20px;
}
article ul li:before
{
	content: '\0025A0';
	display: inline-block;
	color: #2d3c8a;
	vertical-align: baseline;
	margin-right: 5px;
	font-size: 15px;
}
.vignettes-row
{
	min-height: 50px;
	margin: 0 10px;
}
.vignettes-row .vignette
{
	width: 210px;
	display: inline-block;
	vertical-align: bottom;
}
.vignettes-row .vignette .texte
{
	position: relative;
}
.vignettes-row .vignette .texte span
{
	position: absolute;
	bottom: 5px;
	left: 10px;
}
.vignettes-row .vignette + .vignette
{
	margin-left: 10px;
}
.content-wrapper article
{
	padding: 0 20px;
}
.content-wrapper article table
{
	width: 100%;
	border-collapse: collapse;
	font-size: 13px;
	color: #333;
	margin-bottom: 30px;
}
.content-wrapper article table td
{
	vertical-align: top;
	line-height: 20px;
}
.content-wrapper article table td h3,
.content-wrapper article table td h4
{
	margin: 0;
}
.content-wrapper article table td > p:first-child
{
	margin-top: 0;
}
.content-wrapper article table td h3,
.content-wrapper article table td p,
.content-wrapper article table td ul
{
	text-align: left;
}
.content-wrapper article table tr > td:first-child
{
	padding-right: 10px;
}
.content-wrapper article table td.grey
{
	background: #eaebf3;
	padding: 10px 15px;
	padding-bottom: 0;
}
.content-wrapper article table img
{
	/*display: none;*/
	max-width: none;
}
/*------------------------------------*\
    PAGE CONTACT
\*------------------------------------*/
.sidebar
{
	width: 291px;
	background: #f0f1f6;
	float: right;
	padding: 5px;
}
.sidebar h2
{
	margin-left: 5px;
	margin-right: 5px;
}
.sidebar-content
{
	background: white;
	padding: 5px;
}
.sidebar-content .contact-bloc
{
	text-align: center;
}
.sidebar-content .contact-bloc + .contact-bloc
{
	border-top: 1px solid #ebb106;
}
.sidebar-content .contact-bloc .titre
{
	font-family: 'Open sans',sans-serif;
	font-weight: 600;
	font-size: 16px;
	text-transform: uppercase;
	line-height: 20px;
	color: #ebb106;
}
.sidebar-content .contact-bloc .tel
{
	font-size: 18px;
}

/*------------------------------------*\
    FORMULAIRES DE CONTACT
\*------------------------------------*/
.wpcf7 label
{
	width: 240px;
	float: left;
	font-weight: 700;
	color: #2d3c8a;
	text-align: right;
	font-size: 16px;
	font-weight: 800;
	margin-right: 10px;
	line-height: 24px;
	font-family: 'Open sans',sans-serif;
	min-height: 1px;
}
span.mandatory
{
	color: #333;
}
.wpcf7 input[type=text],
.wpcf7 input[type=email],
.wpcf7 input[type=tel],
.wpcf7 textarea,
.wpcf7 select
{
	border:2px solid #FECA30;
	border-radius: 2px;
	min-height: 24px;
	width: 220px;
}
.wpcf7 input[type=text][name=cp]
{
	width: 110px;
}
.wpcf7 input[type=text].wpcf7-captchar
{
	width: 145px;
}
.wpcf7 input[type=submit]
{
	background: white;
	color: #2d3c8a;
	border:1px solid #2d3c8a;
	width: 220px;
	line-height: 30px;
	font-family: 'Open sans',sans-serif;
	font-size: 16px;
	font-weight: 800;
}
.wpcf7 .wpcf7-not-valid-tip
{
	text-align: right;
	width: 470px;
}
/*------------------------------------*\
    Pages articles
\*------------------------------------*/
div.article img.alignleft
{
	margin-bottom: 0;
}
div.article
{
	padding-bottom: 20px;
	margin-bottom: 20px;
	position: relative;
}
div.article + .article
{
	padding-top: 20px;
	border-top: 2px solid #c8d5e7;
}
div.article .postuler
{
	position: absolute;
	right: 0;
	bottom: 0px;
	display: inline-block;
	padding: 5px 10px;
	color: #2d3c8a;
	text-decoration: none;
	transition:all 0.5s ease;
	font-size: 13px;
	font-weight: 700;
}
div.article .postuler i
{
	vertical-align: middle;
}
div.article .postuler:hover
{
	color: white;
	background: #2d3c8a;
}
div.navigation
{
	text-align: center;
}
div.navigation .wp-paginate span.current,
div.navigation .wp-paginate li span.gap,
div.navigation .wp-paginate li a
{
	display: inline-block;
	border: 2px solid  #2d3c8a;
	line-height: 20px;
	height: 30px;
	width: 30px;
}
div.navigation .wp-paginate span.current,
div.navigation .wp-paginate li a:hover
{
	background: #2d3c8a;
	color: white;
}
div.navigation .wp-paginate li a
{
	background: white;
	color: #2d3c8a;
}
div.navigation .wp-paginate li span.gap
{
  background: #f2f2f2;
  border: 2px solid #f2f2f2;
  color: #2d3c8a;
}
/*------------------------------------*\
    SINGLE ARTICLE
\*------------------------------------*/
article#single h1 span
{
	display: inline-block;
	padding: 8px 20px;
	border:1px solid #2d3c8a;
	color:#FECA30;
	margin-right: 10px;
	font-size: 13px;
	line-height: 100%;
	vertical-align: middle;
	font-weight: bold;
}
article#single .navigation
{
	border-top:2px solid #c8d5e7;
	padding: 10px 0;
	font-weight: bold;
}
article#single .navigation a
{
	text-decoration: none;
}
/*------------------------------------*\
    FOOTER
\*------------------------------------*/
.footer .recrutement
{
	text-align: center;
	position: relative;
}
.footer .recrutement:before
{
	content: "";
	position: absolute;
	right: 0;
	top: 0;
	height: 100%;
	width: 0;
	background: #2d3c8a;
	transition:all 0.5s ease;
	z-index: 0;
}
.footer a:hover .recrutement:before
{
	content: " ";
	width: 100%;
}
.footer a:hover .recrutement .titre,
.footer a:hover .recrutement .texte
{
	color: white
}
.footer a:hover .recrutement .titre
{
	background: url(img/user-hover.png) no-repeat left center;
}
.footer .recrutement .titre{
	font-family: 'Open sans',sans-serif;
	font-size: 30px;
	display: inline-block;
	padding-left: 33px;
	color: #2d3c8a;
	line-height: 24px;
	text-transform: uppercase;
	background: url(img/user.png) no-repeat left center;
	margin-top: 0;
	margin-bottom: 14px;
	font-weight: 800;
}
.footer .recrutement p
{
	margin: 0;
}
.footer .recrutement p.texte
{
	text-align: left;
}

.footer .newsletter
{
	height: 100px;
	background: #FECA30;
	padding: 2px 12px 8px 12px;
}
.home .footer .newsletter
{
	padding: 8px 12px;
}
.footer .newsletter h3
{
	margin: 0;
	font-family: 'Open sans',sans-serif;
}
.footer .newsletter h3.texte
{
	display: none;
	font-size: 16px;
	font-weight: 600;
	color: #2d3c8a;
	line-height: 20px;
	margin-bottom: 10px;
}
.footer .newsletter h3.titre
{
	color: white;
	font-weight: normal;
	font-size: 30px;
	text-align: center;
	text-transform: uppercase;
	margin-bottom: 10px;
}
.footer .newsletter h3.titre span
{
	font-weight: 800;
}
.home .footer .newsletter h3.titre
{
	display: none;
}
.home .footer .newsletter h3.texte
{
	display: block;
}
.footer .newsletter input
{
	height: 33px;
	font-family: 'Open sans',sans-serif;
}
.footer .newsletter input[type=text]
{
	border: 1px solid #d18502;
	padding-left: 10px;
	width: 320px;
}
.footer .newsletter input[type=submit]
{
	background: white;
	border: 1px solid #2d3c8a;
	width: 120px;
	text-align: center;
	font-weight: 800;
	font-size: 16px;
	color: #2d3c8a;
	vertical-align: bottom;
}
.footer .copyright p
{
	margin: 0;
}
.footer .copyright
{
	background: #2d3c8a;
	color: white;
	padding: 3px;
	text-align: center;
	margin-top: 29px;
}
.footer .copyright a
{
	color: #FECA30;
	text-decoration: none;
}
.footer .copyright a:hover
{
	color: white;
}
.footer .copyright ul
{
	padding: 0;
	margin: 0;
	display: inline-block;
}
.footer .copyright ul li
{
	list-style: none;
	display: inline-block;
	margin-right: 5px;
	padding-right: 5px;
	border-right:1px solid white;
	text-transform: uppercase;
}

#cookie-notice a
{
	color: #FECA30;
}

/*------------------------------------*\
    MISC
\*------------------------------------*/

::selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-webkit-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}
::-moz-selection {
	background:#04A4CC;
	color:#FFF;
	text-shadow:none;
}

/*------------------------------------*\
    WORDPRESS CORE
\*------------------------------------*/

.alignnone {
	margin:0;
}
.aligncenter,
div.aligncenter {
	display:block;
	margin:5px auto 5px auto;
}
.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.alignright {
	float:right;
	margin:5px 0 20px 20px;
}
a img.alignnone {
	margin:5px 20px 20px 0;
}
a img.alignleft {
	float:left;
	margin:5px 20px 20px 0;
}
a img.aligncenter {
	display:block;
	margin-left:auto;
	margin-right:auto;
}
.wp-caption {
	background:#FFF;
	border:1px solid #F0F0F0;
	max-width:96%;
	padding:5px 3px 10px;
	text-align:center;
}
.wp-caption.alignnone {
	margin:5px 20px 20px 0;
}
.wp-caption.alignleft {
	margin:5px 20px 20px 0;
}
.wp-caption.alignright {
	margin:5px 0 20px 20px;
}
.wp-caption img {
	border:0 none;
	height:auto;
	margin:0;
	max-width:98.5%;
	padding:0;
	width:auto;
}
.wp-caption .wp-caption-text,
.gallery-caption {
	font-size:11px;
	line-height:17px;
	margin:0;
	padding:0 4px 5px;
}
.sticky {

}
.bypostauthor {

}

/*------------------------------------*\
    PRINT
\*------------------------------------*/

@media print {
	* {
		background:transparent !important;
		color:#000 !important;
		box-shadow:none !important;
		text-shadow:none !important;
	}
	pre,blockquote {
		border:1px solid #999;
		page-break-inside:avoid;
	}
	thead {
		display:table-header-group;
	}
	tr,img {
		page-break-inside:avoid;
	}
	img {
		max-width:100% !important;
	}
	@page {
		margin:0.5cm;
	}
	p,
	h2,
	h3 {
		orphans:3;
		widows:3;
	}
	h2,
	h3 {
		page-break-after:avoid;
	}
}
