html { scroll-behavior: smooth; }
body { margin: 0; font-family: Helvetica,Sans-Serif; font-size: 15px; background: #f4f4f4; padding: 0 0 16px 0; }
a { cursor: pointer; color: inherit; }
a:not(:hover) { text-decoration: none; }
a[name] { display: block; margin: -100px 0 100px; }
blockquote { border-left: 5px solid; text-align: center; }
.wrp { width: 1280px; margin: 0 auto; box-sizing: border-box; }
.wrp.min { width: 800px; }
.wrp.min img { max-width: 100%; }
/* Menu */
menu { margin: 0; padding: 0; background: rgba(255,255,255,0.95); position: fixed; top: 0; right: 0; left: 0; z-index: 9; }
.mnu_mnu { display: flex; align-items: center; height: 81px; }
.mnu_mnu>a, .mnu_mnu>flex>a, .mnu_top>a { text-align: center; font-weight: bold; color: inherit; text-decoration: none; display: inline-block; }
.mnu_mnu>a, .mnu_top>a { width: 120px; }
.mnu_mnu>flex>a { margin: 16px 10px 0; padding:16px 20px 32px; position: relative; }
.mnu_mnu>flex>a.sel { background: #f4f4f4; }
.mnu_mnu>flex>a.sel:after { content: ''; position: absolute; bottom: 24px; left: 20px; right: 20px; display: block; border-bottom: 4px solid #ffa500; }
.mnu_mnu>a>span { display: block; margin: 0 auto 8px; }
.mnu_mnu>a:hover, menu span[class^='ico_']:hover { color: #999; }
.mnu_sub { opacity: 0; position: fixed; top: 0; left: 0; right: 0; background: #fff; box-shadow: 0 8px 12px -8px rgba(0,0,0,0.5); transition: opacity 0.3s; pointer-events: none; z-index: 1; }
.mnu_sub .mnu_top { display: none; margin: 12px 0; position: relative; }
.mnu_sub .mnu_top .ico_clo { position: absolute; right: 48px; top: 16px; cursor: pointer; }
.mnu_sub .mnu_prt { opacity: 0; max-height: 0; line-height: 0.8; transition: line-height 0.3s; }
.mnu_sub .mnu_prt>div { display: flex; padding: 0px 48px 48px; transition: padding-top 0.3s; }
.mnu_sub .mnu_prt>div>flex, .nav_fot>flex { flex-direction: column; padding: 0 32px; }
.mnu_sub .mnu_prt h3 { margin: 0; }
.mnu_sub .mnu_prt p { margin: 32px 0; }
.mnu_sub .mnu_prt big, .nav_fot big { font-weight: bold; font-size: 1.4em; margin: 0 0 8px; }
.mnu_sub .mnu_prt a:not(.btn):not(:first-child), .nav_fot a:not(.btn) { padding: 6px 16px; position: relative; color: inherit; }
.mnu_sub .mnu_prt a:not(.btn):not(:first-child):before, .nav_fot a:before { content: '>'; position: absolute; left: 0; font-family: monospace; }
.mnu_sub .mnu_prt flex>a:not(.btn):hover { color: #ffa500; text-decoration: none; }
.mnu_sub .all { display: none; }
.mnu_sub .all .wrp, .mnu_fot { padding: 32px; position: relative; display: flex; justify-content: space-around; }
.mnu_sub .all .wrp a, .mnu_fot a { font-weight: bold; display: flex; align-items: center; }
.mnu_sub .all .wrp a img, .mnu_fot a img { margin-right: 6px; }
.mnu_sub .all .wrp:before { content: ''; position: absolute; left: 32px; right: 32px; top: 0; border-top: 1px solid #ccc; }
.mnu_sub .fnd { display: none; background: #f4f4f4; }
.mnu_sub .fnd form, form.fnd { display: flex; align-items: center; padding: 32px; position: relative; overflow: hidden; }
.mnu_sub .fnd form:after, form.fnd:after  { content: ''; position: absolute; left: 32px; right: 32px; bottom: 28px; border-bottom: 1px solid #ccc; }
.mnu_sub .fnd input, form.fnd input { flex: 1; border: none; outline: none; background: none; margin: 4px 16px 0px; padding: 0; font-size: 1.5em; }
.mnu_sub .fnd button, form.fnd button { background: none; border: none; outline: none; cursor: pointer; border-left: 1px solid #ccc; padding: 8px 16px; }
/* Variations menu */
menu.opn .mnu_sub { pointer-events: all; opacity: 1; }
menu.all .mnu_prt { opacity: 1; max-height: unset; line-height: 1.2; display: flex; }
menu.all .mnu_prt>div { flex-direction: column; flex: 1; padding: 32px; }
menu.all .mnu_prt>div>flex { flex: none; padding: 0; }
menu.all .mnu_prt big, menu.all .mnu_prt p, menu.all .mnu_prt .btn,  menu.all .mnu_prt>div>flex:last-child { display: none; }
menu.all .mnu_prt h3 { padding: 6px 16px; position: relative; }
menu.all .mnu_prt h3:before { content: '>'; position: absolute; left: 0; font-family: monospace; }
menu.prt .mnu_sub { top: 81px; background: #f4f4f4; border-bottom: 64px solid #3fa9f5; }
menu.prt .mnu_prt { opacity: 1; max-height: unset; line-height: 1.2; }
menu.prt .mnu_prt>div:not(.opn) { display: none; margin-top: -100px; }
menu.prt .mnu_prt>div.opn { padding-top: 48px; font-size: 1.2em; }
menu.prt .mnu_prt>div>flex:not(:first-child), .nav_fot>flex:not(:first-child) { border-left: 1px solid #ccc; }
menu.prt .mnu_prt h3 { font-size: 2em; }
menu.all .all { display: block; }
menu.fnd .fnd { display: block; }
menu.fnd .mnu_top { display: block; }
/* Icon menu */
.ico_mnu { display: inline-block; width: 20px; height: 10px; position: relative; border-top: 3px solid; border-bottom: 3px solid; }
.ico_mnu:after { content: ''; position: absolute; top: 4px; left: 0; right: 0; border-top: 2px solid; }
.ico_fnd { display: inline-block; width: 10px; min-width: 10px; height: 10px; position: relative; border-radius: 50%; border: 3px solid; }
.ico_fnd:after { content: ''; position: absolute; transform: rotate(45deg); width: 10px; border-bottom: 3px solid; bottom: -4px; right: -7px; }
.ico_clo { display: inline-block; width: 24px; height: 24px; position: relative; }
.ico_clo:before, .ico_clo:after { content: ''; position: absolute; width: 100%; top: 50%; left: 0; margin-top: -1px; border-top: 3px solid; }
.ico_clo:before { transform: rotate(45deg); }
.ico_clo:after  { transform: rotate(-45deg); }
.ico_nxt { display: inline-block; width: 12px; height: 12px; position: relative; border-width: 4px 4px 0 0; border-style: solid; transform: rotate(45deg); }
.ico_nxt:after { content: ''; position: absolute; transform: rotate(-45deg); width: 20px; border-bottom: 4px solid; bottom: 4px; right: -4px; }
/* Contenu */
cont { min-height: calc(100vh - 81px); display: block; padding-top: 81px; }
body:not(.acc) cont { font-size: 1.3em; }
.fil_ari { font-weight: bold; color: #555; padding: 32px 0 0; font-size: 15px; }
.fil_ari span { font-family: monospace; font-weight: normal; line-height: 16px; padding: 0 8px; }
cont h1 { margin: 64px 0 16px; color: #184880; font-size: 3em; }
cont h1+p { margin: 0; font-size: 1.2em; }
cont .min { line-height: 1.4; }
.hdr_img { height: 500px; background-size: cover; background-position: center; }
.nws_lst { flex: 1; }
.nws_lst a { display: block; margin-top: 16px; padding: 0 32px; font-size: 1.2em; }
.nws_lst a span { color: #666; display: block; margin-top: 8px; font-size: 0.7em; }
.nrj_stt { padding: 50px; }
.nrj_stt img { margin: 0 16px auto 0; }
.nrj_stt>flex:last-child { border-left: 1px solid #fff; padding-left: 32px; }
.nrj_stt h3 { margin: 0; font-size: 2.5em; }
.nrj_stt p { margin: 0; }
.nrj_stt flex>b { color: rgba(0,0,0,0.5); }
/* Footer */
footer { background-color: #6b6d6f; text-align: center; font-size: 9pt; color: #fff; padding: 24px; }
footer a { color: #fff; }

social { position: fixed; left: 15px; top: calc(50% - 100px); transition: all 0.2s; opacity: 0; }
social>a { display: block; margin: 0 0 5px; padding: 12px; background: #f4f4f4; }
social>a:hover { cursor: pointer; background: #ddd; }
.acc social { display: none; }
.soc_btn { display: inline-block; margin: 4px; color: #fff; transition: all 0.2s; font-size: 0; border-radius: 50%; }
.soc_btn:hover { background: #ffa500; transform: scale(1.05); }

flex { flex: 1; display: flex; }
.fx2 { flex: 2; }
spc_16 { display: block; width: 16px; height: 16px; }
spc_h32 { display: block; height: 32px; }
.blc_shd { box-shadow: 0 1px 2px rgba(0,0,0,0.3); color:#fff; position: relative; background-repeat: no-repeat; background-size: cover; background-position: center; }
.blc_shd:not(:last-child), .blc_mrr { margin-right: 32px; }
.blc_shd>a { flex: 1; display: flex; text-decoration: none; transition: all 0.3s; }
.blc_shd>a:hover { opacity: 0.8; }
.blc_col { flex-direction: column; }
.blc_col>.blc_shd:not(:last-child) { margin-right: 0; margin-bottom: 32px; }
.blc_msk { background: rgba(0, 0, 0, 0.15); }
.blc_ctr { align-items: center; justify-content: center; }
.blc_btm { position: absolute; left: 0; bottom: 32px; width: 100%; }
.blc_dia { position: relative; overflow: hidden; display: flex; flex: 1; max-width: 832px; }
.blc_dia a { position: relative; min-width: 100%; display: flex; text-decoration: none; }
.blc_dia a b { padding: 32px; font-size: 3em; }
.blc_dia bgi { position: absolute; width: 100%; height: 100%; left: 0; top: 0; z-index: -1; background-size: cover; background-position: center; }
.lst_acd label { cursor: pointer; }
.lst_acd input { display: none; }
.lst_acd input+div, .lst_acd input+div>* { transition: all 0.3s; overflow: hidden; }
.lst_acd input:not(:checked)+div, .lst_acd input:not(:checked)+div>* { max-height: 0; margin-top: 0; margin-bottom: 0; opacity: 0; pointer-events: none; }
.txt_shd { text-shadow: 0 0 10px #000; }
.frm_min flex>div { flex: 1; display: flex; flex-direction: column; position: relative; }
.frm_min flex>div:not(:last-child) { margin-right: 8px; }
.frm_min input, .frm_min textarea, .frm_min select { margin: 0; border: none; padding: 22px 0 6px; font-size: 15px; outline: none; border-bottom: 1px solid #ccc; }
.frm_min label { position: absolute; font-size: 15px; top: 20px; transition: all 0.3s; opacity: 0.5; pointer-events: none; }
.frm_min input.not-empty+label, .frm_min textarea.not-empty+label, .frm_min label.up { top: 6px; font-size: 11px; }
.btn { display: inline-block; padding: 16px; font-weight: bold; text-decoration: none; text-shadow: none; border: none; cursor: pointer; }
.btn:hover { filter: saturate(0.7); }
.bg_blec { background: #3FA9F5; color: #fff; }
.bg_blef { background: #184880; color: #fff; }
.bg_oran { background: #ffa500; }
.bg_marr { background: #754C24; color: #fff; }
.bg_blan { background: #fff; }
.cl_blef { color: #184880; }
.cl_blec { color: #3FA9F5; }
.cl_oran { color: #ffa500; }
.cl_marr { color: #754C24; }
.cl_grin { color: #333; }
.cl_blan { color: #fff; }
.ta_c { text-align: center; }
.ta_j { text-align: justify; }
.ta_r { text-align: right; }

@media only screen and (min-width: 900px) and (max-width: 1299px){
	.hdr_img { height: 400px; }
}
@media only screen and (max-width: 900px){
	.hdr_img { height: 300px; }
}
@media only screen and (max-width: 1300px){
	.wrp, .wrp.min { width: 94%; }
	.mnu_mnu>flex>a { display: none; }
	.mnu_mnu>a, .mnu_top>a { width: 100px; }
	.mnu_sub .wrp, .mnu_prt, cont flex:not(.fil_ari), .nav_fot, .mnu_fot { flex-direction: column; }
	.blc_shd, .blc_shd:not(:last-child), .blc_mrr { margin-right: 0; margin-bottom: 32px; min-height: 300px; }
	.blc_dia {  max-width: unset; }
	menu.prt .mnu_prt>div>flex:not(:first-child), .nav_fot>flex:not(:first-child) { border: none; }
	menu.all .mnu_prt>div { padding: 4px 32px; }
	.mnu_prt>div>flex:not(:first-child) { display: none; }
	.mnu_sub .all .wrp a:not(:last-child), .mnu_fot a:not(:last-child), .nav_fot flex:not(:last-child) { margin-bottom: 16px; }
    .nrj_stt>flex:last-child { border-left: none; border-top: 1px solid #fff; margin-top: 32px; padding: 32px 0 0; }
	.nrj_stt img { margin: 0 auto 0 0; }
	social { display: none; }
    .frm_min flex>div:not(:last-child) { margin-right: 0; }
}
@media only screen and (max-width: 600px){
	.blc_shd, .blc_shd:not(:last-child), .blc_mrr { min-height: 200px; }
}