/* === FONT ========================================================== */
@import url('https://fonts.googleapis.com/css?family=Montserrat&display=swap');
@import url('https://fonts.googleapis.com/css?family=Roboto&display=swap');
@font-face {
    font-family: 'fontello';
    src: url('font/fontello.eot');
    src: url('font/fontello.eot') format('embedded-opentype'),
        url('font/fontello.woff2') format('woff2'),
        url('font/fontello.woff') format('woff'),
        url('font/fontello.ttf') format('truetype'),
        url('font/fontello.svg') format('svg');
    font-weight: normal;
    font-style: normal;
}

/* ===  GENERAL HTML ========================================================= */
body {
    font-family: 'Roboto', Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";
    font-size: 1em;
    margin: 0 0 2em;
    color:#004f94;
}

hr {
    border-color: #004f94 -moz-use-text-color -moz-use-text-color;
    border-style: dotted none none;
    border-width: 4px medium medium;
    margin: 0.7cm 0;
}

q:before,
q::after {
    content: none;
}

p.txt_p {
    margin: 2px 0 5px 0;
    line-height: 1.3;
}

table.txt_tb,
div.img_ex {
    margin: 10px 0;
}

table.txt_tb,
table.txt_tb td,
table.txt_tb th {
    border-collapse: collapse;
    border: 1px solid #d2d2d2;
}

table.txt_tb .cellCenter_tbtd {
    text-align: center;
}

table.txt_tb .cellEmp_tbtd {
    font-weight: bold;
}

table p {
    margin: 1px 0;
}

.binCap {
    text-align: center;
}

.binCap_ti {
    font-style: italic;
}

/* ===  TITRE ========================================================= */
h1, h2, h3, h4{
    font-family: 'Montserrat', Arial, sans-serif;
}
h1 {
    margin: 0;
}
h1.training_ti,
h1.job_ti {
    text-align: center;
    text-transform: uppercase;
    position: relative;
    margin-bottom: 1.5em;
}

h1.training_ti::after,
h1.job_ti::after {
    background-color: #d9d9d9;
    bottom: -0.5em;
    content: "";
    height: 4pt;
    left: 35%;
    position: absolute;
    width: 30%;
}

h3 {
    font-style: italic;
    margin: 0.2cm 0;
    font-weight: normal;
    line-height: 1;
}

h1.block_ti {
    text-transform: uppercase;
    font-size: 1.8em;
    margin-bottom: 0.8em;
}


/* === CONTENT ============================================================ */
.content {
    margin: 1em auto;
    max-width: 1200px;
    background-color: #fff;
    padding: 0.5em 2em 2em;
    border: 1px solid #eaeaea;
}

.modCd,
.trainCd {
    font-style: italic;
}

.header {
    display: flex;
    justify-content: flex-end;
    min-height: 110px;
    background: url("img/logo.png") no-repeat left center / 150px auto;
}

.header.noLogo {
    background-image: none;
}


.header .ref {
    align-self: center;
    flex: 2 1 auto;
    font-size: 0.9em;
    text-align: right;
}

.header .rome::after {
    content: ", ";
}

.header .rome:last-child::after,
.header .rome:only-child::after {
    content: "";
}


.training_co {
    display: flex;
}

/* ===  METAS ========================================================= */
.meta {
    background-color: #004F94;
    flex: 0 0 300px;
    position: relative;
    color: #fff;
    margin-right: 2em;
    align-self: flex-start;
    padding: 0 1em;
}

.metaBk {
    padding: 1em 0;
    border-bottom: 1px solid #fff;
}

.metaBk:last-child,
.metaBk:only-child {
    border-bottom: none;
}

.metaBk_ti {
    font-weight: bold;
    text-transform: uppercase;
    margin-bottom: 0.5em;
}

.download_ul {
    list-style-type: none;
    padding: 0;
}

.download_ul li {
    margin: 5px 0;
}

.meta a {
    color: #fff;
    text-decoration: none;
}

.meta a:hover {
    text-decoration: underline;
}

a.pdf_lnk {
    background: url("img/pdf.png") no-repeat 3px center;
    padding-left: 26px;
}

a.registrationLnk::before {
    font-family: "fontello";
    content: "\f291";
    margin-right: 0.5em;
    display: inline-block;
}

.meta .mailto_lnk a::before {
    font-family: "fontello";
    content: "\e802";
    margin-right: 5px;
}

.meta .session {
    padding: 0.5em 1.5em;
    position: relative;
}

.meta .session::before {
    font-family: "fontello";
    content: "\e800";
    position: absolute;
    top: 0.5em;
    left: 0;
}

.meta .lang span {
    margin: 0 5px;
    vertical-align: middle;
    display: inline-block;
    height: 16px;
    width: 16px;
}

.meta .FR {
    background-image: url("img/flag/fr.png");
    background-size: 100% auto;
}

.meta .DE {
    background-image: url("img/flag/de.png");
    background-size: 100% auto;
}

.meta .EN {
    background-image: url("img/flag/en.png");
    background-size: 100% auto;
}

.meta .PT {
    background-image: url("img/flag/pt.png");
    background-size: 100% auto;
}

/* ===  BODY ========================================================= */
.listMod_ul,
.condition_ul,
.date_ul {
    list-style-type: none;
    margin: 0;
}

.listMod_ul {
    padding-left: 1em;
}

.condition_ul,
.date_ul {
    padding-left: 0;
}

.condition_li {
    margin: 0.5em 0;
}

.condition_li p.txt_p {
    margin: 0;
}

.listMod_li {
    margin: 1em 0;
    page-break-inside: avoid;
}

.modTitle {
    text-transform: uppercase;
    font-weight: bold;
}

.training_co .body {
    flex: 2 1 auto;
}

.specificObj_ul,
.trainingMethod_ul,
.activity_ul,
.pedagCo ul {
    list-style-type: none;
}

.specificObj_li,
.trainingMethod_li,
.activity_li,
.pedagCo li {
    margin: 0.2cm 0;
    position: relative;
}

.specificObj_li::before,
.trainingMethod_li::before,
.activity_li::before,
.pedagCo li::before {
    font-family: "fontello";
    position: absolute;
    top: 0;
    left: -20px;
    content: "\e801";
}

.specificObj_li:empty,
.trainingMethod_li:empty,
.activity_li:empty,
.pedagCo li:empty {
    display: none;
}

.jobFed img {
    margin: 0.5em;
}

.listMod_li .lang span {
    margin: 0 5px;
    vertical-align: middle;
    display: inline-block;
    height: 16px;
    width: 16px;
}

.listMod_li .FR {
    background-image: url("img/flag/fr.png");
    background-size: 100% auto;
}

.listMod_li .DE {
    background-image: url("img/flag/de.png");
    background-size: 100% auto;
}

.listMod_li .EN {
    background-image: url("img/flag/en.png");
    background-size: 100% auto;
}

.listMod_li .PT {
    background-image: url("img/flag/pt.png");
    background-size: 100% auto;
}

/* ===  HEADER ========================================================= */
#header {
    display: flex;
    flex-direction: column;
}

#header .banner img {
    max-width: 100%;
    height: auto;
    vertical-align: middle;
}

#header #navigation {
    display: flex;
    background-color: #75AE63;
}

.nav_stuck_yes #header #navigation {
    position: fixed;
    left: 0;
    right: 0;
    top: 0;
    z-index: 1;
}

#header #navigation a {
    color: #fff;
    text-decoration: none;
    line-height: 32px;
    padding: 0 16px;
    font-size: 15px;
    margin: .2em;
}

.home header #navigation div.displayLangBtns > a.currentLang:hover, div.displayLangBtns > a.currentLang{
    background-color:#004F94 !important;
    border-radius: 5px;
}

#header #navigation a:hover {
    color: #EABC0C;
}

#header .rootCatLnk {
    flex: 2 1 auto;
    text-align: center;
    font-size: 2em;
    font-weight: bold;
    text-transform: uppercase;
}

/* === HOME - MAIN ======================================================= */
/* .is_loading::before {
    content: "loading ...";
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    text-align: center;
} */

.is_loading #main {
    display: none;
}

.home #main {
    margin: 0 auto;
    max-width: 1200px;
    padding: 1em;
}

.home #main #menu {
    flex: 0 0 21.5em;
    border-right: 1px solid #ececec;
}

.home #main #content[tabindex] {
    display: flex;
}
.home.searchHome #main #content {
    display: block;
}

.schResBkCo {
    flex: 2 1 auto;
    width: 100%;
    padding: 1em;
}

.schCmds {
    flex: 0 0 auto;
    width: 290px;
}

.home.searchHome .schCmds {
    width: auto;
}

/* === HOME - MENU ======================================================= */
ul.mnu {
    margin: 0;
    padding: 0;
    list-style: none;
    margin: 0 2em 2em;
}

li.dpt_0 {
    border-bottom: 1px solid #ececec;
    padding: 0.5em 0;
}

li.dpt_0:last-child,
li.dpt_1:last-child {
    border-bottom: none;
}

li.dpt_1 {
    border-bottom: 1px solid #ececec;
    padding: 0.2em 0;
}

li.dpt_0 a {
    text-transform: uppercase;
    text-decoration: none;
    color: #000000;
    padding: 1em;
    border-left: 5px solid #004f94;
    display: block;
}

li.dpt_0:nth-child(2n+1) a {
    border-left: 5px solid #CA4C3B;
}

li.dpt_0>div>a {
    font-weight: bold;
}

li.dpt_0 a.tgle_o {
    border-width: 15px;
}

li.dpt_0 a:hover {
    color: #004f94;
}

li.dpt_0:nth-child(2n+1) a:hover {
    color: #CA4C3B;
}

ul.sub {
    list-style: none;
    padding: 0;
    margin: 1.3em 1em 0.5em;
}

li.subArea.dpt_1 {
    padding: 0.1em 0;
}

li.dpt_1 a {
    text-transform: none;
    text-decoration: none;
    color: #000000;
    display: inline-block;
    border-left: none !important;
    padding: 0;
}

li.dpt_1 a:before {
    padding-right: 0.2em;
}

/* === SEARCH ============================================================ */
.subArea .schCmds {
    border-bottom: 1px solid #ececec;
}

.searchBk {
    padding-top: 3em;
}

.searchBk_ti {
    font-size: 240%;
    font-weight: bold;
    padding: 0 0 0.2em 0.4em;
    margin: 0;
}

.schResLbl {
    font-weight: bold;
}

.schForm {
    margin: 0 auto;
}

body.searchHome .schForm {
    display:flex;
	align-items:center;
	justify-content:space-between;
}

body.searchHome .schInputBk,
body.searchHome .schFilterCategoryBk {
    flex: 0 0 calc(50% - 1em);
	margin:0.5em;
}

.schLabel {
    color: #738DCB;
    text-transform: uppercase;
    font-weight: bold;
    padding: 1em;
    float: left;
    display: none;
}

.schInputDiv {
    position: relative;
    display: flex;
}

.schInput {
    flex: 2 1 auto;
    background-color: #fafafa;
    border: 1px solid #ccc;
    color: #666;
    box-shadow: none;
    font-size: 1em;
    padding: 0.5em 2.5em 0.5em 0.5em;
}

.schInput:focus {
    background-color: #fff;
}

.schBtnLaunchBk,
.schBtnResetBk {
    position: absolute;
    right: 0;
}

.schBtnLaunchBk .schBtnLaunch {
    padding: 2px 0.5em;
}
.schBtnResetBk .schBtnReset {
    padding: 10px;
}

.hiddenBtn {
    display: none;
}

.schInfoBk {
    background-color: #fff;
}

.schInfoBkTxt {
    font-size: 2em;
    color: #194f7e;
    margin-bottom: 1em;
}

.subArea .schInfoBkTxt {
    -webkit-transform: rotate(-90deg) translate(-5.7em, 0.8em);
    -moz-transform: rotate(-90deg) translate(-5.7em, 0.8em);
    -ms-transform: rotate(-90deg) translate(-5.7em, 0.8em);
    -o-transform: rotate(-90deg) translate(-5.7em, 0.8em);
    transform: rotate(-90deg) translate(-5.7em, 0.8em);
}

.schInputBk {
    position: relative;
    width: inherit;
}

div.schPropose a:hover {
    text-decoration: none;
}

.schBtnPropose:hover,
.schBtnPropose:focus {
    background-color: #F6F6F6;
}

.schPropose {
    position: absolute;
    top: 45px;
    left: 128px;
    width: 437px;
    padding: 5px 2px;
    border-top: 0;
    background-color: white;
    z-index: 100;
    font-size: 85%;
    box-shadow: 0px 2px 2px #666;
}

.schBtnPropose {
    display: block;
    text-decoration: none;
    color: #000000;
    font-style: italic;
    padding: 0 2px;
    margin: 1px;
}

.schBtnPropose:hover,
.schBtnPropose:active,
.schBtnPropose:focus {
    outline: none;
    text-decoration: none;
    background-color: #434e52;
    color: #ffffff;
    border-radius: 2px;
}

.schProposeExceeded {
    display: block;
    color: #434e52;
    font-style: italic;
    padding: 2px 3px;
}

div.schProp_no {
    display: none;
}

fieldset.schFilter {
    border: 1px solid #dddddd;
    font-size: 75%;
    font-weight: bold;
	background-color: #fafafa;
}

.schFilter.schFilterLangFieldSet,
.schFilter.schFilterCECFieldSet {
    padding: 0.5em;
}

fieldset.schFilter .schFilterInputBk {
    text-transform: uppercase;
}

legend.schFilter {
    color: #738dcb;
    font-size: 120%;
}

legend.schFilterBranchLegend,
legend.schFilterAreaLegend {
    float: none;
}

span.schFilter.schFilterBranchSpan {
    padding-right: 0.5em;
}

label.schFilter {
    color: #7e7e7f;
    position: relative;
    margin: 0.5em;
    padding-left: 1.4em;
    display: block;
    cursor: pointer;
}

label.schFilter.schFilterCategoryLabel {
    color: #738dcb;
    font-size: 1.1em;
}

div.schFilter {
    margin: 0.5em 0;
}

.schFilterCECFieldSet label {
    float: left;
}

.schFilterCategoryBk {
    text-align: center;
}

label.schFilterLangLabel[for="fr"] {
    background: rgba(0, 0, 0, 0) url("img/flag/fr.png") no-repeat scroll left center;
    padding-left: 20px;
    display: inline-block;
    height: 16px;
}

label.schFilterLangLabel[for="de"] {
    background: rgba(0, 0, 0, 0) url("img/flag/de.png") no-repeat scroll left center;
    padding-left: 20px;
    display: inline-block;
    height: 16px;
}

input.schFilter[type="checkbox"]:not(:checked), 
input.schFilter[type="checkbox"]:checked, 
input.schFilter[type="radio"]:checked, 
input.schFilter[type="radio"]:not(:checked) {
  position: absolute;
  left: -9999px;
} 

label.schFilter [type="checkbox"] + span::before,
label.schFilter [type="radio"] + span::before {
    position: absolute;
    font-size: 1.2em;
    font-weight: normal;
    left: 0;
    top: 1px;
    font-family: "fontello";
}

label.schFilter [type="checkbox"]:not(:checked) + span::before,
label.schFilter [type="radio"]:not(:checked) + span::before {
    content: '\e826';
}

label.schFilter [type="checkbox"]:checked + span::before,
label.schFilter [type="radio"]:checked + span::before {
    content: '\e82c';
}

label.schFilter [type="checkbox"]:disabled + span,
label.schFilter [type="radio"]:disabled + span {
    opacity: 0.2;
    cursor: default;
}

label.schFilterAreaLabel {
    top: 6px;
    display: inline-block;
    height: 4em;
    margin: 0;
    left: 0;
    width: 4.5em;
}

span.schFilterAreaSpan {
    position: absolute;
    top: 4.5em;
    color: #ffffff;
    background-color: #ececec;
    padding: 0.5em 1em;
    width: 10em;
}

[type="checkbox"]:not(:checked)+label.schFilterAreaLabel:before,
[type="checkbox"]:checked+label.schFilterAreaLabel:before,
[type="radio"]:not(:checked)+label.schFilterAreaLabel:before,
[type="radio"]:checked+label.schFilterAreaLabel:before {
    font-size: 4em;
    position: absolute;
    z-index: 0;
    width: auto;
    height: auto;
    border: none;
    top: 0;
    left: 0;
    background: none;
    color: #999999;
}

[type="checkbox"]:not(:checked)+label.schFilterAreaLabel:after,
[type="checkbox"]:checked+label.schFilterAreaLabel:after,
[type="radio"]:not(:checked)+label.schFilterAreaLabel:after,
[type="radio"]:checked+label.schFilterAreaLabel:after {
    position: absolute;
    font-size: 4em;
    z-index: 0;
    width: auto;
    height: auto;
    border: none;
    top: 0;
    left: 0;
    background: none;
    color: #999999;
    transition: none;

}

.schFilter.schFilterInputBk {
    margin: 0;
    display: inline-block;
}

.vis_no {
    display: none;
}

a.modLnk {
    text-decoration: none;
    display: inline-block;
    font-weight: bold;
    color: #738dcb;
    margin-bottom: 0.3em;
}

.result_ul {
    margin: 0;
    padding: 0;
}

.result_li {
    padding: 0.8em;
    border-bottom: 1px solid #ececec;
    list-style: none;
}

.result_li:last-child {
    border-bottom: none;
}


a.resultLnk {
    color: #004f94;
    text-decoration: none;
}

a.resultLnk:hover {
    border-bottom: 1px dashed;
}

a.resultLnk::before {
    font-family: "fontello";
    margin-right: 5px;
}

.trainingLnk::before {
    content: "\f114";
}

.moduleLnk::before {
    content: "\f0f6";
}

.schFilterCECLegend>a:visited {
    color: inherit;
}

.schFiltersLabel {
    padding: 0.5em 0.5em 0;
    color: #738dcb;
}

/*=== START SELECTOR =================================================== */
.schFilterCategorySelectRoot{
	margin:.5em 0;
	width: 100%;
}
.schFilterCategorySelectRoot select{
	font-size: inherit;
	padding: 0.5em;
	cursor:pointer;
	background-color:#fafafa;
	color:#666;
	width: 100%;
}
.schFilterCategorySelectRoot select option:hover{
	box-shadow: 20px 20px #666 inset;
}

@supports (pointer-events: none) and ((-webkit-appearance: none) or (-moz-appearance: none) or (appearance: none)) {
	.schFilterCategorySelectRoot {
		position: relative;
		display: inline-block;
		vertical-align: middle;
	}

	.schFilterCategorySelectRoot select  {
		padding-right: 2.5em;
		border: 1px solid #ccc;
		-webkit-appearance: none;
		-moz-appearance: none;
		appearance: none;	
	}

	.schFilterCategorySelectRoot::after{
		content: "";
		position: absolute;
		pointer-events: none;
	}

	.schFilterCategorySelectRoot::after	{
		content: "\e80f";
		font-family:"fontello";
		height: 1em;
		line-height: 1;
		right: 0.7em;
		top: 50%; margin-top: -.5em;
		color: #555;
	}

	.schFilterCategorySelectRoot select[disabled] {
		color: rgba(0,0,0,.3);
	}
}
/*=== END SELECTOR =================================================== */


/* === HOME SEARCH =============================================================== */
.schHomeResTitle {
    margin-left: 0.5em;
    margin-bottom: 1em;
    font-size: 125%;
}

.schHomeResContent {
    display: flex;
    flex-flow: row wrap;
}

.homeCardBk {
    background-color: #ececec;
    margin: 0.5em;
    padding: 0.5em;
    width: calc(50% - 2em);
}

.homeCardBk a {
    background-color: transparent;
    color: #75AE63;
    text-decoration: none;
    font-size: 18px
}

/* === EQF =============================================================== */

.jobArea_co {
    counter-reset: proArea;
}

.proArea {
    counter-increment: proArea;
}

.jobArea .subSec_co {
    margin-left: 0.6em;
    padding-left: 1em;
    border-left: 1px dotted #d9d9d9;
}

.actArea .subSec_co {
    margin-left: 0.45em;
}

.jobArea a {
    text-decoration: none;
    color: #000;
}

.actArea>a {
    margin: 0.5em 0;
}

.proArea>a {
    font-size: 1.2em;
    font-weight: bold;
    margin: 1em 0 0.5em;
}

.proArea>a .subSec_ti::before {
    content: counter(proArea, decimal) ". ";
}

.jobArea .subSec_open::before {
    font-family: "fontello";
    content: "\e80f";
    margin-right: 5px;
}

.jobArea .subSec_closed::before {
    font-family: "fontello";
    content: "\e810";
    margin-right: 5px;
}

.listAct_ul {
    margin: 0;
    padding: 0 1.5em;
}

/* === CERT TABLE ======================================================== */

.certTable {
    border-collapse: collapse;
    margin: 0 auto;
}

.certTable th {
    background-color: #f2f2f2;
}

.certTable td,
.certTable th {
    border: 1px solid #d9d9d9;
    padding: 0.5em;
}

/* ===  JOB COLLECTION ================================================ */
div.trainingOfferLink a {
    color: #004f94;
    text-decoration: none;
}

div.trainingOfferLink a:hover {
    border-bottom: 1px dashed;
}

div.trainingOfferLink a::before {
    font-family: "fontello";
    margin-right: 5px;
    content: "\f114";
}

/* ===  RESPONSIVE DESIGN ================================================ */
@media (max-width: 1050px) {
    body {
        margin: 0;
    }

    .home #main {
        flex-direction: column;
    }

    .home #main #menu {
        flex: 0 0 auto;
        border-right: none;
    }

    .content {
        padding: 0.5em 1em 1em;
        margin: 0;
        border: none;
    }

    h1.training_ti {
        font-size: 1.5em;
    }

    .training_co {
        flex-direction: column;
    }

    .meta {
        margin: 0;
    }

    .metaBk {
        border-bottom: medium none;
        display: inline-block;
        padding: 0.5em;
        vertical-align: top;
        width: 45%;
    }
}