:root {
  --bleu: #312783; /*Bleu*/
  --vert: #95C11F; /*Vert clair*/
  --verm: #3AAA35; /*Vert moyen*/
  --verf: #006633; /*Vert foncé*/
  --grib: #F2F2F2; /*Gris blanc*/
  --gris: #717171; /*Gris moyen*/
  --noir: #000000; /*Gris noir*/
  --blan: #fff; /*Blanc*/
}

body { margin: 0; font-family: Montserrat,Arial,Helvetica,Sans-Serif; font-size: 16px; line-height: 1.3; color: var(--noir); }

a { color: inherit; cursor: pointer; }
a:not(:hover) { text-decoration: none; }

img { max-width: 100%; }

wrp { position: relative; margin: auto; display: block; max-width: 1160px; }
cont wrp { max-width: 1020px; }

sep { min-width: 32px; min-height: 32px; display: block; }
sep[big] { min-width: 48px; min-height: 48px; }
dsh { display: inline-block; width: 112px; height: 8px; background-color: currentColor; }
flx { display: flex; flex: 1; justify-content: space-between; }
flx[col] { flex-direction: column; }
flx[lin] { flex-direction: row; }
flx[top] { align-items: start; }
flx[ctr] { align-items: center; }
flx[jst] { justify-content: start; }
flx[jct] { justify-content: center !important; }
flx[jsb] { justify-content: space-between !important; }
flx[jsa] { justify-content: space-around !important; }
flx[fl2] { flex: 2; }
flx[fln] { flex: none; }
flx[wrp] { flex-wrap: wrap; }
grd { display: grid; grid-template-columns: repeat(auto-fit, minmax(130px, 1fr)); }
grd[gd4] { grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); }
grd[gp1] { grid-gap: 1rem }
grd[gp2] { grid-gap: 2rem }
grd[gp4] { grid-gap: 4rem }
hr { margin: 0; border: 0; border-top: 1px solid; }

.soc_lst a.si- { margin-left: 12px; font-size: 20px; transition: 0.3s; }
.soc_lst a.si-:hover { color: var(--vert); text-decoration: none; }

header { position: fixed; z-index: 9; left: 0; right: 0; top: 0; padding: 32px 0; transition: 0.3s; }
header flx>.lgo { height: 72px; transition: 0.3s; }
header menu { margin: 0; padding: 0; display: flex; justify-content: space-around; align-items: center; flex: 1; }
header menu a:not(:first-child) { min-width: 100px; margin: 0 16px; overflow: hidden; font-size: 0.9em; text-align: center; text-transform: uppercase; color: var(--vert); transition: 0.3s; }
header menu a[mnu] { padding: 0 0 16px; }
header menu a:not([mnu]) { font-size: 0; }
header menu a.sel, header menu a:hover { font-weight: bold; color: var(--bleu); text-decoration: none; }
header menu a.sel { text-decoration: underline; text-decoration-thickness: 8px; text-decoration-color: var(--vert); text-underline-offset: 12px; }
header menu a .lgo { height: 72px; transition: 0.3s; }
header .lng_lst { position: relative; }
header .lng_lst>div { position: absolute; padding-top: 48px; right: 0; white-space: nowrap; }
header .lng_lst:not(:hover)>div { display: none; }
header smnu { display: block; position: relative; }
header smnu>flx { position: absolute; top: 0; left: 0; padding: 24px 60px 48px 45px; background: var(--bleu); color: var(--blan); text-align: left; transition: opacity 0.2s; opacity: 0; pointer-events: none; }
header smnu>flx.aff { opacity: 1; pointer-events: all; }
header smnu>flx>flx { padding-right: 60px; }
header smnu [fl2] { flex-direction: column; flex-wrap: wrap; max-height: 180px; }
header smnu a { margin: 1em 0 0; font-size: 1.1em; transition: 0.3s; transform-origin: left; }
header smnu a:hover { text-decoration: none; transform: scale(1.1); text-shadow: -0.3px -0.3px 0px, 0.3px -0.3px 0px, -0.3px 0.3px 0px, 0.3px 0.3px 0px; }
header mbtn, header mbtn:before, header mbtn:after { width: 32px; height: 4px; background: var(--blan); background-clip: content-box; border-radius: 4px; }
header mbtn { position: relative; margin: 0 16px 0 auto; border: solid var(--verf); border-width: 10px 0; box-shadow: 0 0 0 8px var(--verf); cursor: pointer; }
header mbtn:before, header mbtn:after { position: absolute; content: ''; transform: translateY(-10px); }
header mbtn:after { transform: translateY(10px); }

footer { display: block; background: var(--bleu); color: var(--blan); }
footer .lgo { height: 72px; }
footer .lng_lst>* { margin-right: 4px; color: var(--bleu); }
footer .mnu a { text-transform: uppercase; font-weight: bold; }
footer .mnu a:not(:last-child) { margin: 0 0 8px; }

cont { display: block; min-height: calc(100vh - 48px - 169px - 47px); }
cont elm { position: relative; display: block; }
cont p, footer p { margin-top: 0; }
cont p:last-child { margin-bottom: 0; }

cont input, cont textarea { border: none; border-bottom: 1px solid var(--bleu); outline: none; background: transparent; padding: 8px 0; margin: 0; min-width: 0; flex: 1; font: inherit; transition: 0.3s; }
cont input:focus, cont textarea:focus { border-bottom: 1px solid var(--vert); }
cont input::placeholder, cont form textarea::placeholder { color: var(--gris); }

plx { position: absolute; width: 100%; z-index: -1; pointer-events: none; }
plx>img { width: 100%; }

.btn { display: inline-block; padding: 0.9em 3em; outline: none; border: 2px solid transparent; background-color: var(--vert); color: var(--bleu); font-weight: bold; transition: 0.3s; cursor: pointer; transition: 0.3s; }
.btn:hover { text-decoration: none; }

.btc { padding: 56px 0; }

.tsc h3 { padding: 1em 0; margin: 0; font-size: 2em; font-weight: 900; }

.col lin { min-width: 1px; min-height: 1px; background: var(--gris); }

.bl1 .img { position: relative; width: 300px; height: 300px; flex: none; margin: 0 32px 0 18px; background: center/cover var(--gris); border: 1px solid var(--vert); border-radius: 6px; }
.bl1 .img:after { content: ''; position: absolute; left: -8px; top: 20%; width: 16px; height: 60%; background: var(--vert); border-radius: 8px; transition: 0.25s; }
.bl1:hover .img:after { top: 10%; height: 80%; }

.bl3 { position: relative; display: flex; flex-direction: column; flex: 1; padding: 6px; border-radius: 8px; text-align: center; background: linear-gradient(151deg, var(--vert), transparent); transition: 0.3s; }
.bl3:hover { text-decoration: none; box-shadow: 0 3px 6px #00000055; }
.bl3>* { padding: 12px; margin: 0; }
.bl3 flx { background: var(--blan); border-radius: 6px; }
.bl3 i { position: relative; background: center/cover var(--gris); margin-bottom: 12px; padding-top: 100%; border-radius: 6px; transition: 0.3s; }
.bl3 i:before { content: ''; position: absolute; left: 0; right: 0; top: 0; bottom: 0; background: center/200%; opacity: 0.5; filter: blur(3px); transition: 0.3s; }
.bl3:hover i:before { background-size: 100%; }
.bl3 p { font-size: 1.2em; color: var(--blan); }

.acd input { display: none; }
.acd input+label { display: flex; align-items: center; padding: 16px 6px; cursor: pointer; }
.acd input+label:hover, .acd input:checked+label, .acd input:checked+label+div { background: var(--grib); }
.acd input+label:before { content: '+'; flex: none; width: 24px; height: 24px; margin: 0 12px; background: var(--blan); border-radius: 50%; display: flex; align-content: center; justify-content: center; font-family: monospace; font-size: 1.5em; line-height: 0.95; }
.acd input:checked+label:before { content: '-'; }
.acd input+label+div { max-height: 999px; margin: 0 0 4px; overflow: hidden; transition: 0.3s; }
.acd input:not(:checked)+label+div { max-height: 0; }
.acd input+label+div>div { margin: 16px; padding: 16px; background: var(--blan); }
.acd div>div img { vertical-align: middle; }

.tab { display: flex; flex-wrap: wrap; }
.tab input { display: none; }
.tab input+label { display: flex; align-items: center; justify-content: center; flex: 1; padding: 16px 6px; cursor: pointer; transition: 0.3s; }
.tab input+label:not(:first-of-type) { border-left: 1px solid var(--gris); }
.tab input+label:hover { background: var(--grib); }
.tab input+label:hover, .tab input:checked+label { flex: 1.2; }
.tab input:not(:checked)+label:not(:hover) { filter: grayscale(1); opacity: 0.5; }
.tab input+label+div { min-width: 100%; order: 1; }
.tab input:not(:checked)+label+div { display: none; }

.ban { height: 100px; background-image: linear-gradient(to right, var(--blan) 3px, transparent 1px), linear-gradient(to right, var(--blan) 3px, transparent 1px), linear-gradient(to right, var(--blan) 3px, transparent 1px); background-size: 140px 20%, 140px 50%, 140px 100%; background-repeat: repeat-x; background-position-y: bottom; }

.art_hdr { padding: 12% 0 8%; background: var(--grib) center/cover; }
.art_hdr h1 { margin: 0.2em 0; }
.art_shr { padding: 64px; text-align: center; }
.art_shr a { margin: 8px; font-size: 2em; color: var(--bleu); }
.art_shr a:hover { text-decoration: none; color: var(--bleu); }

.art, .art>i { display:flex; flex-direction: column; }
.art>i { overflow: hidden; border-radius: 4px; }
.art>i>i { padding-top: 100%; background: center/cover; transition: 0.3s; }
.art>flx { position: relative; margin: -56px 24px 0; padding: 32px 16px 24px; background: var(--blan); box-shadow: 0px 3px 6px #00000029; overflow: hidden; transition: 0.3s; }
.art>flx:before { content: ''; position: absolute; left: 0; right: 0; top: -90%; height: 100%; background: linear-gradient(122deg, var(--vert), var(--bleu)); transition: 0.3s; }
.art>flx>b { position: relative; font-size: 1.2em; text-align: center; transition: 0.3s; }
.art:hover { text-decoration: none; }
.art:hover>i>i { transform: scale(1.02); }
.art:hover>flx { transform: translateY(12px); }
.art:hover>flx:before { top: 10%; }
.art:hover>flx>b { color: var(--blan); }

.hda { position: relative; display: block; padding: 32px 0 48px; background: center/cover, linear-gradient(var(--vert), var(--bleu)); background-blend-mode: soft-light; }
.hda .txt { max-width: 364px; }
.hda .txt p { text-shadow: 0 0 1px; }
.hda .big { font-size: 9em; white-space: nowrap; z-index: 1; }
.hda .img { padding-top: calc(20% + 256px); background: center/cover; border-bottom: 12px solid var(--blan); box-shadow: 0px -5px 6px #a1cb3a9f; }

.hdv { min-height: clamp(600px, 32vw, 800px); display: flex; }
.hdv>div { position: absolute; inset: 0; background: center/cover; }
.hdv>div video { position: absolute; width: 100%; height: 100%; object-fit: cover; }
.hdv>div msk { position: absolute; width: 100%; height: 100%; background: var(--gris); mix-blend-mode: multiply; }

.mis { background: linear-gradient(180deg, var(--noir), var(--bleu)); }
.mis_ico { height: 36px; margin: 0 0 16px; background: center/contain no-repeat; }
.mis_man { position: relative; }

.ecv { position: relative; display: flex; flex-direction: column; min-height: 400px; }
.ecv>plx>img { transform: translateY(-20%) scale(0.9, 0.8); }
.ecv>div { filter: drop-shadow(0px 2px 2px rgba(0, 0, 0, 0.5)); }
.ecv>div>flx { width: 100%; height: 100%; padding: 10% 20%; box-sizing: border-box; background: linear-gradient(200deg, var(--vert), var(--bleu)); color: var(--blan); clip-path: url(#ecv_msk); }
.ecv>figure { padding: 16px; box-sizing: border-box; border: 8px solid var(--vert); border-radius: 16px; font-size: 0; }
.ecv>figure>video { position: relative; width: 100%; border-radius: 8px; z-index: 1; }
.ecv>figure>video:not(.act) { cursor: pointer; }
.ecv>figure>svg { position: absolute; width: 100px; height: 100px; left: 50%; top: 50%; margin: -50px 0 0 -50px; z-index: 2; fill: var(--vert); stroke: var(--vert); pointer-events: none; opacity: 0.9; transition: 0.3s; }
.ecv>figure>video.act+svg { opacity: 0; transform: scale(2); }
.ecv>svg { position: absolute; width: 0; height: 0; }

.bpt { position: relative; background: no-repeat 85px bottom / auto 480px, 0; }
.bpt.lin:after { position: absolute; content: ''; inset: auto 85px 0; height: 8px; background: var(--gris); }
.bpt_tit { padding: 128px 32px 232px 440px; }

.eqp>flx>i { padding-top: 100%; background: center/cover; }
.eqp>flx>div { text-align: center; padding: 8px; margin: -24px 32px 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.eqp>flx>hr { margin: 0 16px 8px; color: var(--bleu); }
.eqp>flx>flx>a { color: var(--bleu); }

.eq1 pho { position: relative; padding-top: 100%; background: center/cover; border-radius: 8px; }
.eq1 pho:before { content: ''; position: absolute; left: -8px; top: 20%; width: 16px; height: 60%; background: var(--vert); border-radius: 8px; }
.eq1 pho+div { padding: 16px; margin: 0 0 auto; }

.mbr>a { padding-top: 100%; background: center/contain no-repeat; }

.mes>flx[col] { max-width: 320px; margin: auto; }


@media only screen and (max-width: 1024px){
    body { font-size: 14px; }
    wrp, .fmt>div { padding-left: 16px; padding-right: 16px; }
    wrp wrp { padding-left: 0; padding-right: 0; }
    flx[rsp], flx[wrp], footer>wrp { flex-direction: column; }
    body.scr header flx>.lgo { opacity: 0; transform: translateY(-16px); }
    header menu a .lgo { height: 64px; }
    header menu a:not(:first-child) { color: var(--blan); font-size: 1.3em; }
    header menu { position: fixed; box-sizing: border-box; width: 100%; right: -100%; top: 0; height: 100vh; padding: 20vh 32px; flex-direction: column; background: var(--bleu); transition: 0.2s ease; }
    body.mnu header menu { right: 0; }
    header menu a { color: var(--blan); }
    header menu a:not([mnu]) { order: -1; margin: 0 0 16px; }
    header smnu { display: none; }
    .hid_sml { display: none; }
    .bl1 .img { margin: 0 0 16px; }
    .bl1 .txt>div { text-align: center; }
    .hda .big, .art_hdr .big { font-size: 4em; }
    .ecv>img.lgo { margin: 48px auto 24px; max-width: 240px; }
    .ecv>plx { display: none; }
    .ecv>div, .ecv>figure { position: relative; margin: -8px 0; transform: none !important; }
    .ecv>div { order: 2; font-size: 0.9em; }
    .bpt { background: no-repeat center bottom / auto 315px, 0; }
    .bpt.lin:after { inset: auto 16px 0; }
    .bpt_tit { padding: 64px 16px 400px; }
}
@media only screen and (min-width: 1025px){
    flx[wrp] { flex-wrap: wrap; justify-content: start; }
    wrp[nrw] { max-width: 850px; }
    wrp[nr2] { max-width: 700px; }
    header { background: rgba(255,255,255,0.9); backdrop-filter: blur(16px); }
    header flx>.lgo { display: none; }
    header menu .lng_lst:not(:hover) .lng { margin-right: 0; letter-spacing: -1ch; opacity: 0; }
    body.scr header { padding-top: 16px; padding-bottom: 16px; box-shadow: 0 0 16px rgba(0,0,0,0.2); }
    body.scr header menu a .lgo { height: 64px; }
    header mbtn { display: none; }
    cont { padding: 136px 0 0; }
    .bl1 .img, .bl1.inv .txt { order: 1; }
    .bl1 .txt, .bl1.inv .img { order: 2; }
    .bl1 .txt>div { margin: 0 0 0 32px; }
    .bl1.inv .img { margin: 0 18px 0 32px; }
    .bl1.inv .txt>div { margin: 0 32px 0 0; align-self: flex-end; text-align: right; }
    .mis_man:before { position: absolute; content: ''; width: 40%; height: calc(100% + 64px); left: 30%; top: -32px; border: 1px solid var(--vert); }
    .ecv>img.lgo { position: absolute; left: 12%; top: 20%; width: 174px; }
    .ecv>div { position: absolute; width: 46%; height: 50%; left: -4%; top: 45%; }
    .ecv>figure { position: relative; width: 64%; margin: 5% 0 10% 36%; }
    .ecv>figure>video { min-height: 390px; }
}

.bg_bleu { background-color: var(--bleu); color: var(--blan); }
.bg_vert { background-color: var(--vert); color: var(--blan); }
.bg_verm { background-color: var(--verm); color: var(--blan); }
.bg_verf { background-color: var(--verf); color: var(--blan); }
.bg_grib { background-color: var(--grib); }
.bg_gris { background-color: var(--gris); }
.bg_noir { background-color: var(--noir); color: var(--blan); }
.bg_blan { background-color: var(--blan); }

.cl_bleu { color: var(--bleu); }
.cl_vert { color: var(--vert); }
.cl_verm { color: var(--verm); }
.cl_verf { color: var(--verf); }
.cl_grib { color: var(--grib); }
.cl_gris { color: var(--gris); }
.cl_noir { color: var(--noir); }
.cl_blan { color: var(--blan); }

.fsz_080 { font-size: 0.8em; }
.fsz_130 { font-size: 1.3em; } /* 20pt */
.fsz_160 { font-size: 1.6em; } /* 25pt */
.fsz_200 { font-size: 2.0em; } /* 30pt */
.fsz_230 { font-size: 2.3em; } /* 35pt */
.fsz_260 { font-size: 2.6em; } /* 40pt */

.ftb { font-weight: bold; }
.tac { text-align: center; }
.ttu { text-transform: uppercase; }
.txo { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tsh { text-shadow: 3px 3px 6px var(--noir); }
.tdn { text-decoration: none; }

.br6 { border-radius: 6px; }
.bo1 { border: 1px solid; }
.bb1 { border-bottom: 1px solid; }
.bo_bleu { border: 1px solid var(--bleu); }

.bsh { box-shadow: 0px 3px 6px #00000029; }

.frm_snt [snt-hid], form:not(.frm_snt) [snt-shw] { display: none; }
