﻿*, *:before, *:after { -webkit-box-sizing: border-box; -moz-box-sizing: border-box; box-sizing: border-box; }
*{ margin: 0; outline: none; -webkit-text-size-adjust: none; }

:root {
    font-family: "Montserrat", sans-serif; font-optical-sizing: auto; font-weight: normal; font-style: normal; font-size: 18px; line-height: var(--rootLineHeight) ; color: var(--black);
    --green: #BAD80A;
    --greenHover: #BAD80A;
    --darkGreen: #103A43;
    --black: #032127;
    --beige: #EDE7E1;
    --brown: #9F8F7E;
    --bs-gutter-x: 40px;
    --bs-gutter-y: 0;
    --borderColor: #838783;
    --rootLineHeight: 1.444444;
    --defaultPadding : 80px;
}

.bg-black{ background-color: var(--black); }
.bg-green{ background-color: var(--green); color: initial; }
.bg-darkgreen{ background-color: var(--darkGreen); }
.bg-beige{ background-color: var(--beige); color: initial; }


.bg-black + .bg-black,
.bg-black + article.overlapping{ padding-top: 0; }

.bg-black + article.overlapping{ margin-top: -40px; }

html { -webkit-font-smoothing: antialiased; }
html{ height: 100% !important; }

body{ background-color: var(--black); color: #fff;  }

main{ display: block; min-height: calc(100vh - 400px); }

div.container-max{ max-width: 1512px; padding: 0; margin: 0 auto; position: relative; }
div.container-max > div.row{ --bs-gutter-x: 0; }


div.container-fluid{ max-width: 1432px; }


p:empty{ display: block; min-height: 1rem; margin-top: 0!important; }

.hidden{ display: none; }
.left{ float: left; }
.right{ float: right; }
.clear{ clear: both ;}
.alignright{ text-align: right; }
.alignleft{ text-align: left; }
.cursor{ cursor: pointer; }
.center{ text-align: center; }
.abscenter{ position: absolute; top: 50%; left: 50%; -webkit-transform: translate(-50%,-50%); -ms-transform: translate(-50%,-50%); transform: translate(-50%,-50%); }
.relative{ position:relative; } 
.ucase{ text-transform: uppercase; }
.capitalize{ text-transform: capitalize; }

img, svg, iframe, picture{ vertical-align: middle; }

.flex{ display: flex; }

.object-fit-cover{ position: absolute; inset: 0; width: 100%!important; height: 100%!important; object-fit: cover; }
.object-fit-contain{ position: absolute; inset: 0; width: 100%!important; height: 100%!important; object-fit: contain; }

hr { border: none; height: 1px; width: 1760px; max-width: 100%; margin: 0 auto; background-color: var(--color2); }

ul{ list-style-type: none; margin: 0; padding: 0; }
ul li{ background: none; padding: 0; position: relative; }

figure,
div.image{ position: relative; }

figure img,
picture img,
div.media-wrapper img,
div.image img{ max-width: 100%; height: auto; }

article,section{ position: relative; z-index: 2; }

section,
footer,
article{ padding: var(--defaultPadding) 0; }

div.container-fluid.nopad{ --bs-gutter-x: 0; }

article.text-media{ padding: 0 }
article.text-media div.text{ padding: var(--defaultPadding); }

article.text-media div.text h1 + div.h4{ margin-top: 1rem; }

h1, div.h1, h2{ font-family: "Jost", sans-serif; font-optical-sizing: auto; font-weight: 600; font-style: normal; text-transform: uppercase; }

h1, div.h1{ font-size: 72px; line-height: 1.2; margin: 0; text-wrap: pretty; }
h2, .h2{ font-size: 36px; line-height: 1.2; margin: 0; text-transform: uppercase; text-wrap: pretty; }
div.h3{ font-weight: 500; line-height: 1.2; font-size: 24px; margin: 0; text-wrap: pretty; line-height: 1.1666666; }
div.h4{ font-weight: 300; line-height: 1.2; font-size: 24px; margin: 0; text-wrap: pretty; line-height: 1.1666666; }

div.text p + div.h3 { margin-top: 17px; }
div.text div.h3 + p{ margin-top: 7px; }

div.text p + p,
div.text p + p .arrow{ margin-top: 24px; }

div.text p + p .outline > a{ margin-top: 7px; }

div.text p + div.h4{ margin-top: 24px; }
div.text div.h4 + p{ margin-top: 12px; }

b,strong{ font-weight: 600; }

.hidden{ display: none; }
.center{ text-align: center; }

article :is(h1,h2) + *{ margin-top: 12px; }

a{ display: inline-block; position: relative; text-decoration: none; color: inherit; }
.underline { border-bottom: 1px solid; border-color: var(--color1); line-height: 1.2; display: inline-block;  }

.arrow{ color: var(--green); display: inline-block; font-weight: 600; }
.arrow::after{ content: ""; display: inline-block; width: 24px; height: 24px; background: url(svg/arrow_forward_green.svg) no-repeat; background-size: contain!important; vertical-align: middle; margin-left: 12px; position: relative; top: -2px; }

.bg-beige .arrow { color: initial; }
.bg-beige .arrow::after{ background: url(svg/arrow_forward.svg) no-repeat; }

button{ border: none; font-family: inherit; }
button,.button{ font-weight: 600; text-align: center; position: relative; border: unset; background-color: var(--green); color: var(--black); padding: 0 24px; line-height: 44px; border-radius: 2px; cursor: pointer; transition: .2s; }

span.outline > a,
a.outline{ display: inline-block; border: 1px solid var(--green); padding: 0 24px; line-height: 44px; border-radius: 2px; text-align: center; position: relative; cursor: pointer; transition: .2s; }

form button{ width: 100%; display: block; }

div.container.Breadcrumb{ position: relative; z-index: 2; }
ol.BreadcrumbList{ display: block; padding: 20px 0 0 0; margin: 0; list-style-type: none; font-size: 12px; opacity: 0.9; }
ol.BreadcrumbList li { display: inline-block; margin: 0 3px 0 0; padding: 0; }
ol.BreadcrumbList li:not(:first-child):before { content:">";  display: inline-block; margin-right: 4px; position: relative; top: 0; }
ol.BreadcrumbList li a{ color:  inherit;  }

header{
    --bs-gutter-x: 12px;
    --bs-gutter-y: 0px;    
    position: relative;
    z-index: 3;
    --headerHeight: 85px;
}

header a.logo{ margin-right: 24px; }

header > div.container-max{ padding: 0 20px; }
header > div.container-max > div.row{ height: var(--headerHeight); align-items: center; }
header ul.menu{ display: flex; }
header ul.menu > li > a{ border: 1px solid transparent; padding: 9px 24px 8px 24px;  }
header ul.menu li.selected > a{ color: var(--green); }
header ul.menu ul{ display: none; position: absolute; z-index: 1; top: calc(100% - 1px); border: 1px solid var(--green); left: 0; padding: 24px; background-color: var(--black); }
header ul.menu ul li + li{ margin-top: 20px; }
header ul.menu ul li a{ white-space: nowrap; }
header div.flex{ gap: 24px; align-items: center; }
header div.context-menu label{ background-color: unset; border: unset; padding: 0; padding-right: 22px; line-height: var(--rootLineHeight); }
header form { position: relative; width: 22px; height: 44px; }
header form input[type=text]{ position: absolute; border: 1px solid transparent; height: 100%; right: -12px; background-color: var(--black); width: 0; color: #fff;  }
header form svg{ position: absolute; top: 10px; }

body[data-search=open] header form input{ width: 280px; border: 1px solid var(--darkGreen); }

section.hero div.data{ text-align: center; font-size: 24px; line-height: 1.083333; margin-top: 40px; justify-content: space-between !important; }
section.hero div.data b{ display: block; color: var(--green); font-size: 36px; line-height: 1.5; margin-bottom: 7px; }
section.hero div.data > div:first-child{ text-align: left; }

section.hero.subpage{ --textWidth: 617px; }
section.hero.subpage h1 + p{ margin-top: 16px; }
section.hero.subpage{ padding: 0; overflow-y: hidden; }
section.hero.subpage div.row{ height: 668px; }
section.hero.subpage div.media-wrapper{  position: absolute; top: 0; right: 0; z-index: -1; }

/*
section.hero.subpage div.media-wrapper::before{ content: ""; display: block; position: absolute; top: 0; right: 50%; border-bottom: 668px solid var(--black); border-right: 413px solid transparent; }
*/

section.hero.subpage div.container-max div.text-mask::after{ content: ""; display: block; position: absolute; top: 0; left: var(--textWidth); border-bottom: 668px solid var(--black); border-right: 413px solid transparent; }

section.hero.subpage div.container-max div.text-mask::before{ content: ""; display: block; position: absolute; background-color: var(--black); inset: 0; width: var(--textWidth); }


section.hero.subpage div.text{ position: relative; z-index: 2; padding: var(--defaultPadding); padding-right: 0; width: var(--textWidth); max-width: 100%; }

section.hero.subpage div.text h1 + div.h3,
section.hero.subpage div.text h1 + div.h4 { margin-top: 20px; }


section.hero div.text div.h3 + p,
section.hero div.text div.h4 + p { margin-top: 15px; }

div.text div.ctas{ display: flex; gap: 20px; margin-top: 32px; }

section.hero.subpage h1.label{ border-bottom: 160px solid var(--black); border-right: 98px solid transparent; position: absolute; bottom: 0; left: 0; height: 0; padding: 0 var(--defaultPadding); }
section.hero.subpage h1.label > strong{ display: inline-block; line-height: 160px; }

article.text-media div.text img{ margin-bottom: 12px; }

article.text-media div.infos{ position: absolute; bottom: 0 ; left: 0; max-width: 765px; }
article.text-media div.info{ font-size: 24px; line-height: 1.083333; font-weight: 300;  display: inline-block; padding: 20px 129px 20px 24px; }
article.text-media div.info.bg-black{ background: url(svg/bg-info-black.svg) top right no-repeat; color: var(--green); }
article.text-media div.info.bg-green{ background: url(svg/bg-info-green.svg) top right no-repeat; }
article.text-media div.info strong{ font-family: "Jost", sans-serif; font-size: 36px; line-height: 1.444444; font-weight: 500; display: block; text-transform: uppercase; }

article.text-media div.infos div.info + div.info{ margin-top: 24px; }

article.text-text{ --bs-gutter-x: 0; }
article.text-text div.text{ padding: 0 var(--defaultPadding); }

article.overlapping + article.overlapping{ margin-top: calc(var(--defaultPadding) * -3); }

article.overlapping div.text img + h2{ margin-top: 12px; }

article.knowledge-bank{ background-color: var(--darkGreen); }
article.knowledge-bank div.row + div.row{ margin-top: 30px; }

div.media-wrapper{ position: relative; }

section.newslist h2{ margin-bottom: 40px; }

section.newslist div.row{
    --bs-gutter-x: 16px; 
    --bs-gutter-y: var(--defaultPadding);
}
section.newslist div.media-wrapper{ padding-top: 130%; background-color: var(--darkGreen); margin-bottom: 24px; }
section.newslist div.media-wrapper div.date{ position: absolute; bottom: 0; right: 0; background: url(bg-date.png) top left no-repeat; width: 183px; padding: 0 24px 0 0; line-height: 52px; font-size: 24px; font-weight: 500; text-align: right; color: initial; }

article.news div.text h1.h2{ text-transform: none!important; }

section.full-width-media h2 + div.media-wrapper{ margin-top: 40px; }

div.see-all-link{ text-align: right; margin-top: 24px; }

section.search form,
section.search ul.result{ max-width: 1000px; margin-top: 40px; position: relative; }
section.search ul.result a{ color: var(--green); }

section.search ul.result div.h3{ margin-bottom: 12px; }
section.search ul.result li p strong{ color: var(--greenHover); font-weight: normal; }

section.search ul.result > li{ padding: 24px 0; }
section.search ul.result > li + li{ border-top: 1px solid var(--darkGreen); }

section.search form input{ background-color: var(--darkGreen); color: #fff; border: 1px solid var(--darkGreen); border-radius: 5px; height: 70px; font-size: 24px; }
section.search form svg{ position: absolute; top: 11px; right: 20px; z-index: 1; cursor: pointer;}

section.persons div.row{ --bs-gutter-y: var(--defaultPadding); }
section.persons div.card{ background-color: var(--black); height: 100%;  }
section.persons div.card div.image{ border-bottom: 2px solid var(--green); }

section.persons div.card div.image img,
section.persons div.card div.image svg{ width: 100%; height: auto; }

section.persons div.card div.text{ padding: 20px; font-size: 16px; }
section.persons div.card div.text div.h3{ margin-bottom: 10px; }
section.persons h2 { margin-bottom: 40px; }

@media (max-width: 1531px){
    article.text-text div.container-max{ max-width: 1432px; }
    
    article.text-media div.text,
    article.text-text div.text { padding: 0 calc(var(--defaultPadding) / 2); }
    
}

@media (max-width: 1300px){

    header ul.burger{ display: flex; flex-wrap: wrap; width: 44px; justify-content: center; gap: 4px; cursor: pointer; padding: 15px 5px; margin-left: 12px; }
    header ul.burger li{ width: 22px; height: 2px; background-color: #ffff; transition: .2s; }
    header nav{ display: none; position: fixed; width: 100vw; height: calc(100vh - var(--headerHeight)); top: var(--headerHeight); left: 0; z-index: 1; background-color: var(--black); padding: var(--defaultPadding); }

    header nav ul.menu { flex-flow: column; gap: 0; }
    header nav ul.menu > li > a{ font-size: 24px; padding: 18px 0; border: unset; }

    header nav ul.menu > li { border-bottom: 1px solid var(--darkGreen); }
    header nav ul.menu > li span.haschild{ display: block; width: 24px; height: 24px; background-color: var(--green); position: absolute; top: 23px; right: 0; cursor: pointer; }
    header nav ul.menu > li span.haschild::after{ content: ""; display: block; position: absolute; inset: 0; background: url(haschild.svg) center center no-repeat; transition: .2s; }
    header nav ul.menu > li span.haschild.True::after{ transform: rotate(180deg); }

    header nav ul.menu > li span.haschild.True + ul{ display: block; position: static; border: unset; padding: unset; padding-bottom: 24px; }



    body[data-menu=open]{ overflow: hidden; }
    body[data-menu=open] header ul.burger li:nth-child(2){ display: none; }
    body[data-menu=open] header ul.burger li:nth-child(1){ transform: rotate(45deg); position: relative; top: 7px; }
    body[data-menu=open] header ul.burger li:nth-child(3){ transform: rotate(-45deg); }
    body[data-menu=open] header ul.burger{ position: relative; top: -4px; }
    body[data-menu=open] header nav{ display: block; }

}

@media (max-width: 1199px){

    :root { 
        --defaultPadding: 40px;
        --bs-gutter-x: 20px;
        font-size: 16px;
    }

    .bg-black + article.overlapping{ margin-top: 0; }

    article.cta div.row { 
        --bs-gutter-y: 2rem;
    }

    section.hero.subpage { --textWidth: 490px; }
    section.hero.subpage div.text { padding: var(--defaultPadding) 20px;  }

    section.hero.subpage h1.label { border-bottom: 90px solid var(--black); border-right: 90px solid transparent; padding: 0 var(--defaultPadding); }
    section.hero.subpage h1.label > strong { line-height: 90px; }


    h1{ font-size: 40px; line-height: 1.4375; }
    h2{ font-size: 24px; }
    div.h3{ font-size: 20px; }
    div.h4{ font-size: 20px; }

    article.text-media div.info{ font-size: initial; }
    article.text-media div.info strong { font-size: 24px; }    



}

@media (max-width: 991px){

    section.hero.subpage div.row { height: unset; }
    section.hero.subpage div.media-wrapper { position: relative; z-index: unset; }  
    section.hero.subpage div.media-wrapper img{ max-width: unset; width: 100%; }
    section.hero.subpage div.text-mask{ display: none; }
    section.hero.subpage div.col-auto{ flex: 0 0 auto; width: 100%; }
    section.hero.subpage div.text{ padding: var(--defaultPadding) 16px; }

    article.overlapping + article.overlapping { margin-top: calc(var(--defaultPadding) * -2);  }

    section.hero.subpage h1.label { padding: 0 16px; }
    article.text-media div.text { padding: var(--defaultPadding) 20px; }
    article.text-text div.text { padding: 0 20px; }

    article.text-media div.media-wrapper img{ max-width: unset; width: 100%; }

    article.news.text-media div.media-wrapper{ padding: 0 20px; }


    div.text div.ctas { flex-flow: column; }

    section.hero div.col-lg-6 + div.col-lg-6,
    article.text-text div.col-lg-6 + div.col-lg-6,
    article.knowledge-bank div.col-lg-6 + div.col-lg-6 { margin-top: 2rem; }

}

@media (max-width: 767px){
    
    header{ --headerHeight: 64px; }

    div.col-md-6 + div.col-md-6 { margin-top: 2rem; }
    
    article.overlapping + article.overlapping { margin-top: calc(var(--defaultPadding) * -1);}

    
    section.hero.subpage div.text { padding: var(--defaultPadding) 16px; width: unset; }
      
    section.full-width-media div.media-wrapper svg.cursor{ width: 56px; height: 56px; }


}

@media (max-width: 575px){

    :root{
        
        --bs-gutter-x: 16px;
    }

    header > div.container-max { padding: 0 16px; }
    header nav { padding: 16px; }

    header nav ul.menu > li > a{ font-size: 16px; }
    header nav ul.menu > li span.haschild{ top: 17px; }

    header a.button{ line-height: 34px; font-size: 16px; }
    header ul.burger li{ width: 16px; }
    header ul.burger { gap: 3px; width: 34px; padding: 11px 5px; }
    body[data-menu=open] header ul.burger li:nth-child(3) { top: 2px; }

    header div.flex div.adaptive{ display: none; }

    section.hero.subpage h1 + p { margin-top: 20px; }

    section.hero.subpage h1.label { position: static; border: unset; height: 70px; font-size: 34px; }
    section.hero.subpage h1.label > strong { line-height: 70px; }



    section.hero div.data { font-size: 20px; font-weight: 300; flex-wrap: wrap; margin-top: 25px; }
    section.hero div.data b { font-size: 24px; }
    section.hero div.data > div{ flex: 0 0 50%; text-align: center!important; padding: 16px 0; }

    

    article.text-media div.infos{ position: static; }


    article.text-media div.info { padding: 24px; width: 100%; }
    article.text-media div.info.bg-black { background-color: var(--black); }
    article.text-media div.info.bg-green { background-color: var(--green); }
    article.text-media div.infos div.info + div.info{ margin-top: 0; }

    section.newslist div.media-wrapper div.date { line-height: 50px; font-size: 20px; }

    article.news.text-media div.media-wrapper{ padding: 0 16px; }

    body[data-menu=open] header div.adaptive{ display: block; }
    body[data-menu=open] header div.contact-button{ display: none; }
    body[data-search=open] header form input { width: calc(100vw - 137px); }


}
