@import url(https://fonts.googleapis.com/css2?family=Inter:wght@100;200;300;400;500;600;700;800;900&display=swap);
@import url(https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;1,100;1,200;1,300;1,400;1,500;1,600&display=swap);

a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, summary, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
    border: none;
    font: inherit;
    font-size: 100%;
    margin: 0;
    padding: 0;
    vertical-align: baseline
}

html {
    -webkit-box-sizing: border-box;
    box-sizing: border-box
}

*, :after, :before {
    -webkit-box-sizing: inherit;
    box-sizing: inherit
}

article, aside, details, figcaption, figure, footer, header, hgroup, main, nav, section, summary {
    display: block
}

audio, canvas, video {
    display: inline-block
}

body {
    margin: 0
}

ul {
    list-style-type: none
}

a {
    background: transparent;
    text-decoration: none
}

button, input {
    line-height: normal
}

input[type=search] {
    -webkit-appearance: textfield
}

input[type=search]::-webkit-search-cancel-button, input[type=search]::-webkit-search-decoration {
    -webkit-appearance: none
}

button::-moz-focus-inner, input::-moz-focus-inner {
    border: 0;
    padding: 0
}

textarea {
    overflow: auto;
    vertical-align: top
}

img {
    display: block;
    height: auto;
    max-width: 100%
}

input:focus, textarea:focus {
    outline: 0
}

input {
    -webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    margin: 0;
    padding: 0
}

@media print {
    @page {
        margin: 1cm
    }

    body {
        background: #fff;
        color: #000
    }

    a, blockquote, pre, table {
        page-break-inside: avoid
    }

    dl, ol, ul {
        page-break-before: avoid
    }
}

::-moz-selection {
    background: rgba(200, 158, 92, .7);
    color: #fff
}

::selection {
    background: rgba(200, 158, 92, .7);
    color: #fff
}

a.anchor {
    display: block;
    position: relative;
    top: -10rem
}

html {
    font-size: 16px
}

h2 {
    font-size: .83rem;
    font-weight: 400;
    letter-spacing: .075em;
    margin-bottom: 1rem;
    padding-bottom: 1.2rem;
    position: relative;
    text-transform: uppercase
}

h2.white {
    color: #fff
}

h2:after {
    background-color: #c89e5c;
    bottom: 0;
    content: "";
    display: block;
    height: 1px;
    left: 0;
    position: absolute;
    width: 2.5rem
}

h3 {
    color: #174377;
    font-family: Lora;
    font-size: 1.33rem;
    line-height: 1.7rem;
    margin-bottom: .5rem
}

p {
    line-height: 1.3rem
}

p a {
    color: #252c35;
    font-weight: 500;
    opacity: .75;
    text-decoration: underline
}

p a:hover {
    opacity: 1
}

body {
    background: #fff;
    color: #252c35;
    font-family: Inter, arial, serif;
    font-size: 1.3em;
    font-weight: 400
}

header {
    background-color: #fff;
    border-bottom: 1px solid rgba(37, 44, 53, .1);
    height: 5rem;
    position: fixed;
    top: 0;
    width: 100%;
    z-index: 10
}

.wrapper {
    margin: 0 auto;
    max-width: 77rem
}

.wrapper.small {
    max-width: 38rem
}

@media (max-width: 920px) {
    .wrapper.small {
        padding: 0 3rem
    }
}

.wrapper.padded {
    padding: 1.5rem
}

.wrapper .row {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media (max-width: 920px) {
    .wrapper .row {
        display: block
    }
}

.wrapper .col-2 {
    -webkit-box-flex: 50%;
    -ms-flex: 50%;
    flex: 50%;
    padding: 3rem
}

@media (max-width: 920px) {
    .wrapper .col-2 {
        display: block;
        width: 100%
    }
}

.wrapper .col-2.picture {
    padding: 0;
    position: relative
}

.wrapper .col-2.picture.left {
    left: -3rem
}

@media (max-width: 920px) {
    .wrapper .col-2.picture.left {
        left: 0
    }
}

.wrapper .col-2.picture.right {
    right: -3rem
}

@media (max-width: 920px) {
    .wrapper .col-2.picture.right {
        right: 0
    }
}

.wrapper .col-2.center {
    text-align: center
}

.wrapper .col-3 {
    -webkit-box-flex: 33%;
    -ms-flex: 33%;
    flex: 33%;
    padding: 0 1.5rem
}

nav {
    -webkit-box-align: center;
    -ms-flex-align: center;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    align-items: center;
    height: 100%;
    justify-content: center
}

nav, nav ul {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

nav ul {
    list-style: none;
    margin: 0;
    padding: 0
}

nav ul .logo {
    margin: 0 3rem
}

nav ul .logo a img {
    max-width: 3.125rem
}

nav ul li {
    margin: 0 3rem
}

nav ul li a {
    color: #252c35;
    font-size: .83rem;
    line-height: 3.125rem;
    opacity: .75;
    text-decoration: none;
    text-transform: uppercase
}

nav ul li a:hover {
    opacity: 1
}

.logo-mobile {
    display: none;
    max-width: 3.125rem
}

.menu-toggle.btn {
    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwAgMAAAAqbBEUAAAACVBMVEUGMGf///8GMGfDHWVXAAAAAnRSTlMAAHaTzTgAAAAlSURBVCjPYwhFAgyDjRO1CgpWEs8JYIACRjItRTFgaLpg8MYpAGZu10mT1LQSAAAAAElFTkSuQmCC);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: 1.5rem;
    cursor: pointer;
    display: none;
    height: 5rem;
    position: absolute;
    right: 0;
    top: 0;
    width: 5rem
}

.menu-toggle.btn.open {
    background-image: url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAADAAAAAwBAMAAAClLOS0AAAAJ1BMVEUGMGf///8GMGcGMGcGMGcGMGcGMGcGMGcGMGcGMGcGMGcGMGcGMGcoPWQQAAAADHRSTlMAAANbXJaXpaaoqfymMRwKAAAA8UlEQVQ4y8XUMRaCMAyA4Wr1AB6B0U3nLjhzBI/gpM/Rxd3bwMjqoPRQJE3SJk94jrD+73uQvhS3m3nc0mF9d+bxtxWF/VCbED4VhUfsDOjjlUITDQlxOFHY9JoA6PgdzhAAtQRNEDgJmiAooZAESigkARWEEFBBCAEdiDDQgQgDE4C0AkxAcpZvMwFIlGlMAJLnt2Eb49tNhQDiMBE8vqOdCDDDRYgOOAPO8hPS0A0TFWhoISrwKTEpQU6JSQlyrExyyMfKJIdQtiQRCV7tVSISgt5EJBy82V0kHILddiBHCi97P4A8Z27Ut/pzBxf7M4yXUqxuDUPQXAAAAABJRU5ErkJggg==)
}

@media (max-width: 920px) {
    .logo {
        display: none
    }

    .logo-mobile, .menu-toggle.btn {
        display: block
    }

    nav ul {
        -webkit-box-orient: vertical;
        -webkit-box-direction: normal;
        -webkit-overflow-scrolling: touch;
        background-color: #fff;
        display: none;
        -ms-flex-direction: column;
        flex-direction: column;
        height: calc(100vh - 5rem);
        left: 0;
        overflow: auto;
        position: absolute;
        top: 5rem;
        width: 100%
    }

    nav ul.active {
        display: block
    }

    nav ul li {
        border-top: 1px solid #ccc;
        margin: 0
    }

    nav ul li a {
        display: block;
        padding: 1rem
    }
}

section.headline {
    background-color: #0e3c6e;
    background-image: url(../images/design/headline.ce81fa.jpg);
    background-position-x: center;
    background-position-y: 0;
    background-repeat: no-repeat;
    background-size: cover;
    margin-bottom: 0;
    padding-bottom: 7.5rem;
    padding-top: 12.5rem
}

@media (max-width: 580px) {
    section.headline {
        padding-bottom: 4rem;
        padding-top: 9rem
    }
}

section.headline ul li {
    color: #fff;
    display: inline-block;
    font-family: Lora;
    font-size: 2rem;
    font-weight: 100;
    line-height: 3rem
}

@media (max-width: 580px) {
    section.headline ul li {
        font-size: 1.2rem;
        line-height: 2rem
    }
}

section.headline ul li:after {
    background-color: #c89e5c;
    border-radius: 50%;
    content: "";
    display: inline-block;
    height: .4rem;
    margin-left: .5rem;
    position: relative;
    top: -.25rem;
    width: .4rem
}

@media (max-width: 580px) {
    section.headline ul li:after {
        height: .3rem;
        width: .3rem
    }
}

section.headline ul li:last-of-type:after, section.headline ul li:nth-of-type(3):after {
    display: none
}

@media (max-width: 920px) {
    section.headline ul li:nth-of-type(3):after {
        display: inline-block
    }
}

section.headline a.affiliated {
    border-bottom: 1px solid #fff;
    color: #fff;
    display: inline-block;
    font-size: .83rem;
    font-weight: 400;
    letter-spacing: .075em;
    margin-top: 1rem;
    opacity: .75;
    position: relative;
    text-transform: uppercase
}

section.headline a.affiliated:hover {
    opacity: 1
}

section.headline a.affiliated img {
    display: inline-block;
    max-height: .8rem
}

section {
    margin-bottom: 2rem
}

section p {
    font-size: .9167rem;
    font-weight: 200;
    margin-bottom: 2rem;
    text-align: justify
}

section p strong {
    font-weight: 400
}

section p.headline {
    font-family: Lora;
    font-size: 1.1667rem;
    line-height: 1.7rem;
    margin: 2rem 0
}

section p.headline strong {
    font-weight: 600
}

section.mission .col-2.picture {
    background-image: url(../images/design/mission.81c5ff.jpg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover
}

@media (max-width: 920px) {
    section.mission .col-2.picture {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: contain
    }
}

@media (max-width: 580px) {
    section.mission .col-2.picture {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: cover
    }
}

section.mission .col-2.picture:after {
    content: "";
    display: block;
    padding-bottom: 100%
}

@media (max-width: 920px) {
    section.mission .col-2.picture:after {
        padding-bottom: 60%
    }
}

@media (max-width: 580px) {
    section.mission .col-2.picture:after {
        padding-bottom: 100%
    }
}

section.societe ul p {
    margin-bottom: 0;
    display: inline-block;
}
section.societe ul  {
    margin-bottom: 1rem;
}

section.societe li .sep {
    color: #c89e5c;
    font-size: .8rem;
    margin: 0 1.5rem;
    text-align: center;
    display: inline-block;
}

section.societe ul.team {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    padding-top: 1rem
}

section.societe ul.team li {
    -webkit-box-flex: 33.333%;
    -ms-flex: 33.333%;
    flex: 33.333%;
    text-align: center
}

section.societe ul.team li h4 {
    font-family: Lora;
    font-size: .9417rem;
    margin-bottom: .4rem
}

section.societe ul.team li .title {
    display: block;
    font-size: .75rem;
    font-weight: 200
}

section.societe ul.team li img.avatar {
    border: 1px solid #c89e5c;
    border-radius: 50%;
    display: inline-block;
    margin-bottom: .8rem;
    max-width: 80%
}

.linkedin-link {
    color: #252c35;
    display: inline-block;
    font-size: .83rem;
    margin-top: 1rem;
    opacity: .75
}

.linkedin-img {
    display: inline-block;
    margin-left: 2px;
    max-height: 1rem;
    position: relative;
    top: 3px
}

section.societe .director-content {
    display: inline-block;
    text-align: center
}

section.societe .director-content img {
    display: inline-block;
    max-width: 17.5rem
}

section.societe .director-content img.oarg {
    margin-bottom: .5rem;
    max-width: 8rem
}

section.societe .director-content h3 {
    display: block;
    font-size: 1.6667rem;
    margin-top: 1rem
}

section.societe .director-content p {
    margin-bottom: 0;
    max-width: 17.5rem;
    text-align: center
}

section.societe .director-content .sep {
    color: #c89e5c;
    font-size: .8rem;
    margin: 1.5rem 0;
    text-align: center
}

section.services {
    background-color: hsla(200, 7%, 84%, .2);
    margin-bottom: 0;
    padding: 3rem 0
}

section.services p {
    margin-bottom: 0;
    margin-top: 1rem
}

section.contact p.headline {
    margin: 1rem 0
}

section.contact .col-2.picture {
    background-image: url(../images/design/contact.1b1b6d.jpg);
    background-position: 50%;
    background-repeat: no-repeat;
    background-size: cover
}

@media (max-width: 920px) {
    section.contact .col-2.picture {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: contain;
        margin-top: 3rem
    }
}

@media (max-width: 580px) {
    section.contact .col-2.picture {
        background-position: 50%;
        background-repeat: no-repeat;
        background-size: cover;
        margin-top: 0
    }
}

section.contact .col-2.picture:after {
    content: "";
    display: block;
    padding-bottom: 100%
}

@media (max-width: 920px) {
    section.contact .col-2.picture:after {
        padding-bottom: 60%
    }
}

@media (max-width: 580px) {
    section.contact .col-2.picture:after {
        padding-bottom: 100%
    }
}

section.contact .col-2 {
    padding-bottom: 0
}

section.contact .address {
    display: block;
    padding: .5rem 0;
    text-align: center
}

section.contact .address img {
    display: inline-block;
    max-width: 3rem
}

section.contact .address h3 {
    display: block;
    font-size: 1.5rem;
    font-weight: 600;
    margin-top: .2rem
}

section.contact .address p {
    margin-bottom: .8rem;
    text-align: center
}

section.contact .address p a {
    border-bottom: 1px solid #fff;
    display: inline-block;
    font-size: .75rem;
    font-weight: 400;
    letter-spacing: .075em;
    margin-top: .4rem;
    opacity: .75;
    position: relative;
    text-transform: uppercase
}

section.contact .address p a:hover {
    opacity: 1
}

section.contact .address ul.tel li {
    font-size: .75rem;
    font-weight: 200;
    margin-bottom: .4rem
}

section.contact .address ul.tel li label {
    font-family: Lora;
    font-size: .75rem;
    margin-right: 1.3rem
}

section.contact ul.mails {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    margin-bottom: 1.2rem;
    margin-top: 1.2rem
}

@media (max-width: 580px) {
    section.contact ul.mails {
        display: block
    }
}

section.contact ul.mails li {
    -webkit-box-flex: 50%;
    -ms-flex: 50%;
    flex: 50%
}

@media (max-width: 580px) {
    section.contact ul.mails li {
        display: block;
        margin-bottom: 2rem;
        text-align: center;
        width: 100%
    }
}

section.contact ul.mails li label {
    display: block;
    font-size: .75rem;
    font-weight: 400;
    letter-spacing: .075em;
    line-height: .5rem;
    text-transform: uppercase
}

section.contact ul.mails li a {
    border-bottom: 1px solid #174377;
    color: #174377;
    font-size: .83rem;
    font-weight: 400;
    letter-spacing: .075em;
    opacity: .75
}

section.contact ul.mails li a:hover {
    opacity: 1
}

footer .affiliated {
    padding: 0 3rem
}

footer .affiliated .affiliated-content {
    border-bottom: 1px solid rgba(37, 44, 53, .2);
    padding-bottom: 1rem
}

footer .affiliated .affiliated-content span {
    display: block;
    font-size: .65rem;
    text-transform: uppercase
}

footer .affiliated .affiliated-content span.legend {
    color: #856f4f;
    font-size: .85rem
}

footer .affiliated .affiliated-content img {
    margin: .25rem 0;
    max-width: 18rem;
    width: 100%
}

@media (max-width: 580px) {
    footer .affiliated .affiliated-content span.legend {
        font-size: .75rem;
        text-align: center;
        width: 100%
    }

    footer .affiliated .affiliated-content img {
        max-width: 100%
    }
}

footer .footer-content {
    margin-bottom: 0
}

footer .footer-content .col-2 {
    padding-top: 1.5rem
}

footer .footer-content .subrow {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex
}

@media (max-width: 580px) {
    footer .footer-content .subrow {
        display: block
    }
}

footer .footer-content .subrow > div {
    -webkit-box-flex: 50%;
    -ms-flex: 50%;
    flex: 50%
}

@media (max-width: 580px) {
    footer .footer-content .subrow > div {
        display: block;
        text-align: center
    }
}

footer .footer-content p {
    font-weight: 300;
    margin-bottom: .5rem
}

footer .footer-content p.cookies {
    color: #856f4f;
    font-size: .65rem;
    font-weight: 300
}

footer .footer-content .info-group {
    margin-bottom: 1.2rem
}

footer .footer-content .info-group label {
    color: #856f4f;
    display: block;
    font-size: .85rem;
    font-weight: 400
}

footer .footer-content .info-group span {
    font-size: .9167rem;
    font-weight: 300;
    text-align: justify
}

footer .footer-content .info-group a {
    color: #252c35;
    font-weight: 500;
    opacity: .75;
    text-decoration: underline
}

footer .footer-content .info-group a:hover {
    opacity: 1
}
