/* Fonts */
@import url('https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700&family=Roboto+Condensed:ital,wght@0,100..900;1,100..900&family=Roboto:ital,wdth,wght@0,75..100,100..900;1,75..100,100..900&display=swap');

* {
	font-family: "Poppins", sans-serif;
	font-weight: 400;
}

:root {
	--color-black: #111111;
	--color-yellow: #F2AE13;
	--color-darkblue: #093147;
	--color-grey: #F5F5F5;
	--color-beige: #F6EDE5;
	--color-turquoise: #419da6;
}

/* helpers */
.yellow-text {color: var(--color-yellow) !important;}
.darkblue-text {color: var(--color-darkblue) !important}
.white-text {color: white !important;}
.bg-yellow {background-color: var(--color-yellow) !important;}
.bg-beige {background-color: var(--color-beige) !important;}
.bg-darkblue {background-color: var(--color-darkblue) !important;}
.bg-turquoise {background-color: var(--color-turquoise) !important;}
.bg-grey {background-color: var(--color-grey) !important;}
.bg-white {background-color: white !important}
.red {background-color: var(--color-orange) !important}
.underlined {text-decoration: underline !important;}

.flex {display: flex}
.flex-justify-center {justify-content: center}
.flex-justify-space-between {justify-content: space-between}
.flex-justify-space-around {justify-content: space-around}
.flex-justify-end {justify-content: flex-end}
.flex-align-end {align-items: flex-end}
.flex-align-center {align-items: center}
.flex-direction-row {flex-direction: row}
.flex-direction-column {flex-direction: column}
.flex-justify-content-space-evenly {justify-content: space-evenly}
.flex-wrap {flex-wrap: wrap}

.gap5 {gap: 5px}
.gap10 {gap: 10px}
.gap15 {gap: 15px}
.gap20 {gap: 20px}
.gap30 {gap: 30px}
.mt-1{margin-top: 1rem !important;}
.mt-2{margin-top: 2rem !important;}
.mt-3{margin-top: 3rem !important;}
.mb-0-5{margin-bottom: 0.5rem !important;}
.mb-1{margin-bottom: 1rem !important;}
.mb-1-25 {margin-bottom: 1.25rem !important}
.mb-1-5 {margin-bottom: 1.5rem !important}
.mb-2{margin-bottom: 2rem !important;}
.m-0 {margin:0 !important;}
.padding0 {padding: 0 !important;}
.padding20{padding: 20px !important;}
.boradius10 {border-radius: 10px}
.hidden, .dnone {display: none !important;}
.boxshadownone {box-shadow: none;}
.vertical-align-middle {vertical-align: middle !important;}
.v-bottom {vertical-align: text-bottom;}
/* FIN helpers*/

/* Style 'par défaut' */
html {
	font-size: 16px;
}

body {
	padding-top: 96px;
	background-color: white;
	color: var(--color-black);
}

a,
h1,
h2,
h3,
h4 {
	color: var(--color-darkblue)
}

p {
	color: var(--color-darkblue);
	font-size: 1rem;
	font-weight: 400;
	margin: 0;
}

h1 {
	font-size: 64px;
	font-weight: 600;
	font-family: "Roboto Condensed", sans-serif;
}

h2,
h3 {
	font-weight: 700;
	font-size: 1.5rem;
	font-family: "Roboto", sans-serif !important;
}

h4 {
	font-weight: 500;
	font-size: 22px;
}

h5 {
	font-size: 16px;
	font-weight: 400
}

a:hover {
	text-decoration: none !important
}

nav i {
	height: auto
}

.bold, strong {
	font-weight: 700 !important;
	color: var(--color-darkblue);
}

.row:not(.container.stats .row, .footer .row, .cards-accueil) {
	display: flow-root;
}
/* FIN Style 'par défaut' */

/* Boutons */
span.badge {
	display: inline-flex;
	justify-content: center;
	align-items: center;
	font-size: 14px;
	gap: 0.625rem;
	height: auto;
	min-width: 1.75rem;
	color: var(--color-darkblue);
	padding: 0.2rem;
	border-radius: 11rem;
	margin: 1rem 0.2rem 0 0;
	float: unset;
}
span.badge.brand {
	background-color: var(--color-yellow);
}

.btn-no-style {
	border: none !important;
	background-color: transparent !important;
	text-align: left !important;
}

.btn-no-style span:hover {
	text-decoration: none !important;
}

.btn-social {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 45px;
	width: 45px;
	border: none !important;
	border-radius: 30px;
	background-color: white !important;
	margin-right: 5px;
}

.btn,
.btn:focus,
.btn.outlined,
.btn.outlined:focus {
	border-radius: 999px;
	padding: 0 1.5rem;
	width: max-content;
	cursor: pointer;
	transition: color .15s ease-in-out, background-color .15s ease-in-out, border-color .15s ease-in-out;
	text-transform: none;
	background-color: var(--color-yellow);
	color: var(--color-darkblue);
	box-shadow: none;
	font-family: "Roboto", sans-serif;
	font-weight: 500;
	border: none;
}

.btn:hover,
.btn.outlined:hover {
	background-color: var(--color-darkblue);
	color: var(--color-yellow);
	box-shadow: none;
}

.btn-invert-color {
	background-color: var(--color-darkblue);
	color: var(--color-yellow);
}

.btn-darkblue,
.btn-darkblue:focus {
	background-color: var(--color-darkblue);
	color: white;
}

.btn-darkblue:hover {
	color: var(--color-yellow);
}

.btn-icon {
	display: flex;
	align-items: center;
}

.btn-aria {
	background-color: transparent;
	border: 0;
}
/* FIN Boutons */

/* Input et multiselect */
input[type=text]:not(.browser-default) {
	height: 2.75rem;
}

.input-field.outlined input:focus:not([readonly]), 
.input-field.outlined textarea:focus:not([readonly]) {
	border: 1px solid var(--color-yellow);
}

.select2-search__field::placeholder {
	font-family: 'Poppins', sans-serif !important;
}

.select2-container--default .select2-selection--multiple .select2-selection__choice {
	background-color: var(--color-yellow);
}

.select2-container--default .select2-selection--multiple .select2-selection__choice,
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove, 
.select2-container--default .select2-selection--multiple .select2-selection__choice__remove:hover {
	color: var(--color-darkblue);
}

.filter_front .possearchv2 .select2-container--default .select2-selection--multiple, 
.filter_front .possearchv2 .select2-container--default .select2-selection--single {
	border: 1px solid var(--color-darkblue);
}

.input-field input:focus:not([readonly]), 
.input-field textarea:focus:not([readonly]),
input[type="text"]:focus:not([readonly]) {
	border-bottom: none;
	box-shadow: none;
	padding-top: 0;
}
/* FIN Input et multiselect */

/* Header */
.navbar {
	height: auto;
}

body>header>div.navbar>nav:first-child {
	line-height: 35px;
	box-shadow: none;
	border-bottom: 1px solid;
	border-color: white;
}

body .navbar button {
	color: var(--color-black);
}

.navbar2-li {
	margin-right: 5px
}

.navbar2-li button,
em:not(footer em) {
	color: var(--color-darkgray);
	font-weight: 800;
	font-size: 14px
}

.navbar2-li>button {
	font-weight: 500;
	font-size: 16px;
	text-transform: none;
	padding: 0rem;
	letter-spacing: normal;
	border-radius: 10px;
	transition-duration: 0.3s;
	padding-left: 0.75rem;
	padding-right: 0.75rem;
	font-family: "Roboto Condensed", sans-serif;
}

.currentpage,
.navbar2-li button:hover {
	background-color: var(--color-yellow) !important;
	padding-left: 0.75rem !important;
	padding-right: 0.75rem !important;
	border-radius: 0.75rem;
	color: var(--color-darkblue);
	font-weight: 500;
	cursor: pointer;
	font-family: "Roboto Condensed", sans-serif;
}

.navbar2-li:hover>button {
	background-color: unset
}

li.navbar2-li:hover+li.separateur-menu {
	display: none
}

nav#headerfixed.nav-extended>div:first-child {
	height: 64px;
	display: flex;
	align-items: center
}

.nav-extended {
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 999;
}

.nav-hidden {
  transform: translateY(-100%);
}

#navbar-spacer {
  height: 0;
}

.breadcrumbs {
	line-height: 1rem;
	margin: 10px 0 -6px;
	word-wrap: break-word !important;
	padding: 0 !important;
}

.breadcrumbs>li,
.breadcrumbs ul li {
	padding: 5px;
	display: inline-block;
	font-size: .9rem;
}

.breadcrumbs-chevron {
	font-weight: bold; 
	font-size: 1rem;
	display: inline-block;
}
/* FIN Header */

/* Page accueil */
#index-banner {
	background: url('/imggen/ademe_formation_1500_2.svg') top center no-repeat;
	display: flex;
	flex-direction: column;
	height: 410px;
	justify-content: space-between
}
/* FIN Page accueil */

/* Page Formation */
.filter_front .possearchv2 .title-card-search-front {
	margin-bottom: 10px
}

.card-panel {
	border-radius: 0.5rem;
	padding: 20px
}

.container .row {
	margin: 0
}

label {
	color: #000;
}

.recommandationrate  {
	padding: 1rem;
}

h1.title-stage {
    font-size: 2rem;
    margin-top: 10px;
}

.title-ss-stage {
	font-size: 1rem; 
	font-style: italic;
}
/* FIN Page Formation */

/* Page FAQ */
.faq-begin form>div {
	position: relative;
	width: 24%;
	margin: 0 auto
}

.faq-begin form input {
	border-radius: 10px 0 0 10px !important;
	padding: 0 0 0 10px;
	border: 1px solid #dedede;
	height: 40px;
	border-bottom: 1px solid #a4a4a4;
}

.faq-begin form button {
	background-color: var(--color-yellow);
	border: none;
	border-radius: 0 10px 10px 0;
}

.faq-begin form button span {
	color: #fff
}

.faq ul.collapsible {
	border: none;
	box-shadow: none
}

.faq ul li {
	border-bottom: 1px solid lightgray;
}

.faq ul li:hover {
	background-color: var(--color-grey);
}

.faq ul li button {
	padding: 20px 0;
	font-weight: 500;
}

.card-answer {
    border-radius: 0.75rem;
    padding: 1rem 2rem;
}
/* FIN Page FAQ */

/* FOOTER */
.container_inscription {
	padding: 40px 0px;
	background-color: var(--color-yellow);
}

.separateur-menu {
    position: relative;
	width: 2px;
    height: auto;
	left: 1px;
    top: 12px;
	margin: 0 30px 0 30px;
	list-style-type: none;
}

.footer_link {
	color: var(--color-yellow);
	font-weight: 500;
	text-decoration: underline;
}

.footer_h4 {
	margin-top: 3rem;
	margin-bottom: 0;
}

.footer a {
	color: var(--color-yellow);
	font-size: 1rem;
	cursor: pointer;
}

footer.page-footer {
	padding-bottom: 13px
}

.container.stats {
	padding:100px 0px;
	display: flex;
	justify-content: center;
}

.footer_stat {
	display: flex;
	flex-direction: column;
	justify-content: center;
	height: 220px;
	border-radius: 25px;
	margin-bottom: 1rem;
	margin-right : auto;
}

.footer_stat.bg-beige {
	width: 430px;
	height: 265px;
}

.footer_stat .desc {
	background-color: white;
	border-radius: 30px;
	padding: 15px;
	font-size: 1.5rem;
	font-family: 'Roboto Condensed', sans-serif !important;
	font-weight: 600;
	line-height: 1.5rem;
	margin: 0;
}

.footer_stat .stat {
	font-weight: 600 !important;
	font-size: 4rem !important;
	font-family: 'Roboto Condensed', sans-serif !important;
	margin: 0;
}

@media screen and (max-width: 600px) {
	.footer .col.l6.s12 {
		margin-top: 3rem;
		order: 1;
	}

	.footer_all_links {
		margin-top: 1rem;
	}

	.footer_all_links .footer_link {
		margin: 0 !important;
		padding: 0;
	}

	.footer_all_links .footer_link ul {
		margin: 0;
		line-height: 2rem;
	}

	.barStg {
		top: 57px !important;
	}
}

@media screen and (min-width: 601px) and (max-width: 1099px) {
	.footer_part_one {
		display: flex;
		flex-direction: column-reverse;
		order: 1;
	}

	.footer_part_two {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	.footer_h4 {
		margin: 1.14rem 0 0.912rem 0;
	}

	.footer_all_links {
		margin-bottom: 1rem;
	}
}
/* FIN FOOTER */

/* Formation page d'accueil */
.formation h2 {
	font-size: 3rem;
	font-weight: 700;
	font-family: 'Roboto Condensed', sans-serif !important;
}

.formation h3 {
	background-color: white;
	width: fit-content;
	padding: 10px;
	border-radius: 10px;
}

.formation a:not(.btn) {
	font-family: 'Roboto Condensed', sans-serif !important;
	font-weight: 500;
	text-decoration: underline;
	cursor: pointer;
}

.formation .formation-card p {
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 6;
	overflow: hidden;
	font-size: 1rem;
	color: var(--color-black);
}

.formation .formation-card {
	display: flex;
	flex-direction: column;
	gap: 1rem;
	background-color: var(--color-beige);
	border-radius: 20px;
	padding: 2rem;
	margin: 0 !important;
}

.formation .formation-card:not(.static) {
	height: 295px;
}

@media only screen and (min-width: 993px) {
    .formation-card {
        width: 23.5% !important;
    }

    .right.formation-card {
        width: fit-content!important;
		margin-right: 0;
    }

    .formation-card:nth-of-type(4n),
	.formation-card:last-child {
        margin-right: 0; 
    }
}
/* FIN Formation page d'accueil */

/** PAGE PLAN DU SITE **/
.map {
	font-weight: 500;
}

.sub-map {
	font-weight: 500;
	cursor: pointer;
}
/** FIN PAGE PLAN DU SITE **/

.input-rg2a {
	border: 1px solid var(--color-darkblue) !important;
	height: 38px !important;
	padding-left: 10px !important;
	margin-bottom: 10px;
	display: block;
}

select.input-rg2a {
	width: 100% !important;
}

.input-rg2a.valid,
.input-rg2a.invalid {
	width: calc(100% - 30px) !important;
}

input.valid~span.iconvalid,
select.valid~span.iconvalid {
	display: block !important;
}

input.invalid~span.iconnovalid,
select.invalid~span.iconnovalid {
	display: block !important;
}

input.valid~span.iconvalid,
input.invalid~span.iconnovalid,
select.valid~span.iconvalid,
select.invalid~span.iconnovalid {
	font-size: 32px !important;
}

span.icon_style {
	background-color: var(--color-yellow);
	padding: 5px;
	border-radius: 30px;
	color: white;
}

.barStg {
	position: sticky !important;
	top: 0px;
}

.barStg div>ul>li:last-child {
	display: inherit
}

.barStgSticky {
	top: 97px !important; 
}


@media (max-width: 1100px) {
	#logo_ademe-mob {
		height: 50px;
	}
}


/* Media Queries */
/* debut Media Queries - min-width */
@media screen and (min-width:330px) {
	.imarginright {
		margin-right: 10px !important
	}
}

@media screen and (min-width:400px) {
	#login-page {
		width: 400px !important
	}
}

@media screen and (min-width:601px) {
	.small-only {
		display: none
	}

	.ariane-m {
		left: 50px !important;
		padding: 10px 30px 10px 15px !important
	}

	.padding-m {
		padding: 15px 0 10px !important
	}

	.newicon {
		height: 100% !important;
		padding: 50px !important
	}

	.medium-large {
		font-size: 6rem
	}

	footer.page-footer {
		padding-top: 40px;
	}

	.currentfooter {
		width: fit-content;
	}
}

@media screen and (min-width:991px) {
	.container {
		width: 95% !important;
	}
}

@media screen and (min-width:1100px) {
	.barStg {
		line-height: 55px;
		font-size: 1.2rem
	}

    .displaysearchv2 {
		display: inline-block;
		overflow-y: initial !important;
		will-change: initial !important
	}

    .possearchv2 {
		position: relative !important;
        box-shadow: none !important;
	}
}

@media screen and (min-width:1150px) {
	.container-large {
		width: 95%;
		margin: 0 auto
	}
}
/* fin Media Queries - min-width */

/* debut Media Queries - max-width */
@media screen and (max-width:320px) {
	.btn,
	.btn-large,
	.btn-small {
		font-size: .8rem !important
	}
}

@media screen and (max-width:400px) {
	.card-panel {
		background-color: transparent;
		box-shadow: none
	}
}

@media screen and (max-width:500px) {
	.footer_part_one img {
		height: 60px !important;
	}
}

@media screen and (max-width:600px) {
	.small-only {
		display: block
	}
}

@media screen and (max-width:990px) {
	.container {
		width: 98% !important
	}

	.container-large {
		width: 100%;
		margin: 0 auto
	}

	.btn-navbar {
		line-height: 35px !important
	}

	.btn {
		padding: 0 .5rem !important
	}
}

@media screen and (max-width:1099px) {
	.bar-divider {
		top: 55px !important
	}

	#index-banner-mob {
		background-image: url('/imggen/ademe_formation_1500_1.svg');
		background-repeat: no-repeat;
		position: relative;
		width: 100%;
		filter: opacity(.5);
		height: 350px
	}

	.btn-nav {
		height: 40px;
		width: 32px
	}

	.bloc-titre {
		flex-direction: column;
		gap: 2.5rem;
	}

	.container-large.container {
		display: flex;
		justify-content: center;
		padding: 1rem;
	}

	body {
		padding-top: 0;
	}
}
/* fin Media Queries - max-width */

/* debut Media Queries - min-width and max-width */
@media screen and (min-width:321px) and (max-width:360px) {
	.btn,
	.btn-large,
	.btn-small {
		font-size: .7rem !important
	}
}

@media screen and (min-width:361px) and (max-width:699px) {
	.btn,
	.btn-large,
	.btn-small {
		font-size: .8rem !important
	}
}

@media screen and (min-width: 601px) and (max-width:769px) {
	.bloc-entete {
		width: 80% !important;
	}
}

@media screen and (min-width: 601px) and (max-width:1099px) {
	.barStg {
		line-height: 35px;
		font-size: 1rem;
		top: 64px !important;
	}
}
/* fin Media Queries - min-width and max-width */