/*
Theme Name: ExoCore
Theme URI: http://underscores.me/
Author: Exo B2B
Author URI: https://exob2b.com
Description: ExoB2B
Version: 4.0.0
License: GNU General Public License v2 or later
Text Domain: exocore
*/
/*--------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Titillium+Web:wght@400;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Open+Sans:ital,wght@0,300..800;1,300..800&display=swap");
html {
  font-family: sans-serif;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%; }

body {
  margin: 0; }

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

audio,
canvas,
progress,
video {
  display: inline-block;
  vertical-align: baseline; }

audio:not([controls]) {
  display: none;
  height: 0; }

[hidden],
template {
  display: none; }

a {
  background-color: transparent; }

a:active,
a:hover {
  outline: 0; }

abbr[title] {
  border-bottom: 1px dotted; }

b,
strong {
  font-weight: bold; }

dfn {
  font-style: italic; }

h1 {
  font-size: 2em;
  margin: 0.67em 0; }

mark {
  background: #ff0;
  color: #000; }

small {
  font-size: 80%; }

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

img {
  border: 0; }

svg:not(:root) {
  overflow: hidden; }

figure {
  margin: 1em 40px; }

hr {
  box-sizing: content-box;
  height: 0; }

pre {
  overflow: auto; }

code,
kbd,
pre,
samp {
  font-family: monospace, monospace;
  font-size: 1em; }

button,
input,
optgroup,
select,
textarea {
  color: inherit;
  font: inherit;
  margin: 0; }

button {
  overflow: visible; }

button,
select {
  text-transform: none; }

button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  cursor: pointer; }

button[disabled],
html input[disabled] {
  cursor: default; }

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

input {
  line-height: normal; }

input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  padding: 0; }

input[type="number"]::-webkit-inner-spin-button,
input[type="number"]::-webkit-outer-spin-button {
  height: auto; }

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

fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

legend {
  border: 0;
  padding: 0; }

textarea {
  overflow: auto; }

optgroup {
  font-weight: bold; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

td,
th {
  padding: 0; }

html {
  font-size: 62.5%; }
  @media only screen and (min-width: 2100px) {
    html {
      font-size: 68%; } }
  @media only screen and (max-width: 1400px) {
    html {
      font-size: 62.5%; } }

.ecol-1 {
  width: 8.33%; }

.ecol-2 {
  width: 16.66%; }

.ecol-3 {
  width: 25%; }

.ecol-4 {
  width: 33.33%; }

.ecol-5 {
  width: 41.66%; }

.ecol-6 {
  width: 50%; }

.ecol-7 {
  width: 58.33%; }

.ecol-8 {
  width: 66.66%; }

.ecol-9 {
  width: 75%; }

.ecol-10 {
  width: 83.33%; }

.ecol-11 {
  width: 91.66%; }

.ecol-12 {
  width: 100%; }

[class*="ecol-"] {
  float: left;
  padding: 50px; }

.erow::after {
  content: "";
  clear: both;
  display: table; }

@media only screen and (min-width: 2100px) {
  [class*="ecol-"] {
    padding: 50px; } }

@media only screen and (max-width: 1500px) {
  [class*="ecol-"] {
    padding: 0; } }

@media only screen and (max-width: 800px) {
  [class*="ecol-"] {
    width: 100%; } }

* {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box; }

html {
  -webkit-overflow-scrolling: touch;
  overflow-x: hidden; }

body {
  overflow-x: hidden; }

.full_w {
  width: 100%; }

.deskOnly {
  display: block; }
  @media only screen and (max-width: 800px) {
    .deskOnly {
      display: none; } }

.mobOnly {
  display: none; }
  @media only screen and (max-width: 800px) {
    .mobOnly {
      display: block; } }

strong, a strong {
  font-weight: 700; }

.clear {
  clear: both; }

@media only screen and (max-width: 1100px) {
  .hide-mob {
    display: none; } }

.hidden {
  display: none; }

.right {
  float: right; }

.left {
  float: left; }

.center {
  text-align: center; }

.alri {
  text-align: right; }
  @media only screen and (max-width: 800px) {
    .alri {
      text-align: center; } }

.inline {
  display: inline-block !important; }

.mt10 {
  margin-top: 10px; }

.mt20 {
  margin-top: 20px; }

.mt30 {
  margin-top: 30px; }

.mt40 {
  margin-top: 40px; }

.mt80 {
  margin-top: 80px; }

.mr20 {
  margin-right: 20px; }

.ml30 {
  margin-left: 30px; }

.ml50 {
  margin-left: 50px; }

.mb20 {
  margin-bottom: 20px; }

.mb30 {
  margin-bottom: 30px; }

.mb80 {
  margin-bottom: 80px; }

.pt20 {
  padding-top: 20px; }

.pt40 {
  padding-top: 40px; }

.nopad {
  padding: 0; }

::-webkit-input-placeholder {
  color: #999999;
  font: 300 13px/14px "Titillium Web", sans-serif; }

::-moz-placeholder {
  color: #999999;
  font: 300 13px/14px "Titillium Web", sans-serif; }

:-ms-input-placeholder {
  color: #999999;
  font: 300 13px/14px "Titillium Web", sans-serif; }

:-moz-placeholder {
  color: #999999;
  font: 300 13px/14px "Titillium Web", sans-serif; }

.search-field::-webkit-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
  font: 300 3rem/3rem "Titillium Web", sans-serif; }

.search-field::placeholder {
  color: rgba(255, 255, 255, 0.5);
  font: 300 3rem/3rem "Titillium Web", sans-serif;
  /* Firefox */ }

.search-field::-ms-input-placeholder {
  color: rgba(255, 255, 255, 0.5);
  font: 300 3rem/3rem "Titillium Web", sans-serif;
  /* Microsoft Edge */ }

.close {
  position: absolute;
  right: 25px;
  top: 50%;
  margin-top: -13px;
  height: 25px;
  width: 25px;
  cursor: pointer;
  -webkit-transition: .2s ease-in-out;
  -moz-transition: .2s ease-in-out;
  -o-transition: .2s ease-in-out;
  transition: .2s ease-in-out; }
  .close:hover {
    opacity: 0.7; }

/*
img {// Prevent image drag & Drop
	-moz-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
	-webkit-user-drag: none;
	user-drag: none;
	-webkit-touch-callout: none;
}
*/
hr {
  background-color: #ccc;
  border: 0;
  height: 1px;
  margin-bottom: 1em; }

img {
  height: auto;
  /* Make sure images are scaled correctly. */
  max-width: 100%;
  /* Adhere to container width. */ }

figure {
  margin: 1em 0;
  /* Extra wide images within figure tags don't overflow the content area. */ }

body,
button,
input,
select,
optgroup,
textarea {
  color: #121212;
  font-family: "Titillium Web", sans-serif;
  font-size: 16px;
  font-size: 1rem;
  line-height: 1.5; }

h1, h2, h3, h4, h5, h6 {
  clear: both; }

dfn, cite, em, i {
  font-style: italic; }

blockquote {
  margin: 0 1em; }

address {
  margin: 0 0 1em; }

pre {
  background: #eee;
  font-family: "Courier 10 Pitch", Courier, monospace;
  font-size: 15px;
  font-size: 0.9375rem;
  line-height: 1.6;
  margin-bottom: 1.6em;
  max-width: 100%;
  overflow: auto;
  padding: 1.6em; }

code, kbd, tt, var {
  font-family: Monaco, Consolas, "Andale Mono", "DejaVu Sans Mono", monospace;
  font-size: 15px;
  font-size: 0.9375rem; }

abbr, acronym {
  border-bottom: 1px dotted #666;
  cursor: help; }

mark, ins {
  background: #fff9c0;
  text-decoration: none; }

big {
  font-size: 125%; }

/*--------------------------------------------------------------
## Others
--------------------------------------------------------------*/
table {
  width: 100%; }

/* Alignement */
.alignleft {
  display: inline;
  float: left;
  margin-right: 1em; }

.alignright {
  display: inline;
  float: right;
  margin-left: 1em; }

.aligncenter {
  clear: both;
  display: block;
  margin-left: auto;
  margin-right: auto; }

/* Text meant only for screen readers. */
.screen-reader-text {
  border: 0;
  clip: rect(1px, 1px, 1px, 1px);
  clip-path: inset(50%);
  height: 1px;
  margin: -1px;
  overflow: hidden;
  padding: 0;
  position: absolute !important;
  width: 1px;
  word-wrap: normal !important;
  /* Many screen reader and browser combinations announce broken words as they would appear visually. */ }
  .screen-reader-text:focus {
    background-color: #f1f1f1;
    border-radius: 3px;
    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.6);
    clip: auto !important;
    clip-path: none;
    color: #21759b;
    display: block;
    font-size: 14px;
    font-size: 0.875rem;
    font-weight: bold;
    height: auto;
    left: 5px;
    line-height: normal;
    padding: 15px 23px 14px;
    text-decoration: none;
    top: 5px;
    width: auto;
    z-index: 100000;
    /* Above WP toolbar. */ }

/* Do not show the outline on the skip link target. */
#content[tabindex="-1"]:focus {
  outline: 0; }

/* Clear */
.clear:before,
.clear:after,
.entry-content:before,
.entry-content:after,
.comment-content:before,
.comment-content:after,
.site-header:before,
.site-header:after,
.site-content:before,
.site-content:after,
.site-footer:before,
.site-footer:after {
  content: "";
  display: table;
  table-layout: fixed; }

.clear:after,
.entry-content:after,
.comment-content:after,
.site-header:after,
.site-content:after,
.site-footer:after {
  clear: both; }

/* Globally hidden elements when Infinite Scroll is supported and in use. */
.infinite-scroll .posts-navigation, .infinite-scroll.neverending .site-footer {
  /* Theme Footer (when set to scrolling) */
  display: none; }

/* When Infinite Scroll has reached its end we need to re-display elements that were hidden (via .neverending) before. */
.infinity-end.neverending .site-footer {
  display: block; }

/*--------------------------------------------------------------
## Media
--------------------------------------------------------------*/
.page-content .wp-smiley,
.entry-content .wp-smiley,
.comment-content .wp-smiley {
  border: none;
  margin-bottom: 0;
  margin-top: 0;
  padding: 0; }

/* Make sure embeds and iframes fit their containers. */
embed,
iframe,
object {
  max-width: 100%; }

/* Make sure logo link wraps around logo image. */
.custom-logo-link {
  display: inline-block; }

/*--------------------------------------------------------------
## Captions
--------------------------------------------------------------*/
.wp-caption {
  margin-bottom: 1.5em;
  max-width: 100%; }
  .wp-caption img[class*="wp-image-"] {
    display: block;
    margin-left: auto;
    margin-right: auto; }
  .wp-caption .wp-caption-text {
    margin: 0.8075em 0; }

.wp-caption-text {
  text-align: center; }

/*--------------------------------------------------------------
## Galleries
--------------------------------------------------------------*/
.gallery {
  margin-bottom: 1.5em; }

.gallery-item {
  display: inline-block;
  text-align: center;
  vertical-align: top;
  width: 100%; }

.gallery-caption {
  display: block; }

.site-header .menu {
  /* Don't display menus further than 3 deep in ul tree */ }
  .site-header .menu li {
    display: inline-block;
    position: relative;
    text-align: left; }
    .site-header .menu li a {
      display: block;
      text-decoration: none; }
    .site-header .menu li ul, .site-header .menu li ul ul {
      display: none;
      position: absolute;
      z-index: 110;
      top: 10px;
      left: 0;
      width: 200px;
      margin: 0;
      background: #000000; }
    .site-header .menu li ul ul {
      left: 100%;
      top: 0; }
    .site-header .menu li li {
      display: block; }
    .site-header .menu li:hover > a {
      display: block;
      background: none; }
    .site-header .menu li:hover > ul {
      display: block; }
  .site-header .menu ul ul ul li:hover ul {
    display: none; }
  .site-header .menu li.menu-parent-item > a:after {
    /* If you don't want the arrows on the top level drop down, simply remove this style */
    /*font-family: 'FontAwesome';
            font-weight: normal;
            font-style: normal;
            speak: none;
            vertical-align: middle;
            font-size: 9px;
            font-size: 0.5625rem;
            content: " \f078";
            width: calc(100% - 20px);
            display: block;
            position: absolute;*/ }
  .site-header .menu .current_page_item a,
  .site-header .menu .current-menu-item a {
    /**/ }
  .site-header .menu .current-menu-item > a,
  .site-header .menu .current-menu-ancestor > a,
  .site-header .menu .current_page_item > a,
  .site-header .menu .current_page_ancestor > a,
  .site-header .menu .current_page_parent > a {
    color: #ff6632;
    /* Nav bar link color for current menu item or ancestor */ }

#footercontainer .sub-menu {
  display: none; }

/*
.current-menu-item > a,
.current-menu-ancestor > a,
.current_page_item > a,
.current_page_ancestor > a,
.current_page_parent > a,
.current_page_item > a,
.current-menu-item > a {color: $color3 !important;}
*/
/**********************************************
font: 400 1.8rem/2.8rem $font__main;   400 700
font: 400 1.8rem/2.8rem $font__text;   
 
$color1: #ff6632; // Orange
$color2: #2c2c2c; // Charcoal
$color3: #374764; // Bleu

GENERAL STYLES 
**********************************************/
body {
  font: 400 1.8rem/2.8rem "Open Sans", sans-serif;
  color: #2c2c2c; }
  body [class*="ecol-"] {
    padding: 0; }
  @media only screen and (max-width: 1500px) {
    body {
      font: 400 1.6rem/2.5rem "Open Sans", sans-serif; } }
  @media only screen and (max-width: 1100px) {
    body {
      font: 400 1.6rem/2.2rem "Open Sans", sans-serif; } }
  body .site_w {
    width: 100%;
    max-width: 1400px;
    margin: 0 auto; }
  body .site-main {
    padding: 0 0 0 0; }
    @media only screen and (max-width: 1100px) {
      body .site-main {
        padding-top: 0; } }

h1 {
  font: 700 6rem/6.4rem "Titillium Web", sans-serif;
  margin: 0 0 0 0;
  padding: 0 0 0 0; }
  @media only screen and (max-width: 1500px) {
    h1 {
      font: 700 5rem/5.4rem "Titillium Web", sans-serif; } }
  @media only screen and (max-width: 1100px) {
    h1 {
      font: 700 4rem/4.4rem "Titillium Web", sans-serif; } }

h2 {
  font: 600 3.6rem/4rem "Titillium Web", sans-serif;
  margin: 0 0 0 0;
  padding: 0 0 0 0; }
  @media only screen and (max-width: 1500px) {
    h2 {
      font: 600 2.8rem/3rem "Titillium Web", sans-serif; } }
  @media only screen and (max-width: 1100px) {
    h2 {
      font: 600 2.5rem/2.9rem "Titillium Web", sans-serif; } }

h3 {
  font: 600 2.7rem/3rem "Open Sans", sans-serif;
  margin: 0 0 20px 0;
  padding: 0 0 0 0; }

h4 {
  font: 600 2rem/2.8rem "Open Sans", sans-serif;
  margin: 0 0 10px 0;
  padding: 0 0 0 0; }

a {
  color: #ff6632;
  text-decoration: none;
  -webkit-transition: .2s ease-in-out;
  -moz-transition: .2s ease-in-out;
  -o-transition: .2s ease-in-out;
  transition: .2s ease-in-out;
  cursor: pointer !important; }
  a:hover {
    text-decoration: underline; }

p {
  margin: 0 0 20px 0; }
  @media only screen and (max-width: 1500px) {
    p {
      margin: 0 0 10px 0; } }

sup {
  font-size: 9px;
  margin-left: 3px;
  vertical-align: 4px; }

strong {
  font-weight: 600 !important; }

/******* GENERAL ***************************/
.cta {
  display: inline-block;
  padding: 15px 20px;
  margin-top: 20px;
  color: #ffffff;
  background: #374764;
  font: 400 1.6rem/1.7rem "Titillium Web", sans-serif;
  text-transform: uppercase;
  text-decoration: none;
  transition: ease 0.3s; }
  @media only screen and (max-width: 450px) {
    .cta {
      padding: 7px 10px;
      font: 400 1.4rem/1.6rem "Titillium Web", sans-serif; } }
  .cta:hover {
    color: #374764;
    background: #ffffff;
    text-decoration: none;
    -moz-transform: translate(0px, -5px);
    -webkit-transform: translate(0px, -5px);
    -o-transform: translate(0px, -5px);
    -ms-transform: translate(0px, -5px);
    transform: translate(0px, -5px); }

.go-to-top {
  display: block;
  position: fixed;
  cursor: pointer;
  bottom: 18px;
  left: 50%;
  margin-left: -15px;
  height: 30px;
  width: 30px;
  background: rgba(44, 44, 44, 0.7);
  z-index: 50;
  text-decoration: none;
  text-align: center;
  border-radius: 30px; }
  .go-to-top:hover {
    background: rgba(55, 71, 100, 0.8);
    -webkit-transition: .2s ease-in-out;
    -moz-transition: .2s ease-in-out;
    -o-transition: .2s ease-in-out;
    transition: .2s ease-in-out; }
  .go-to-top img {
    width: 15px;
    padding: 5px 0 0 0; }

.g-recaptcha {
  transform: scale(0.77);
  transform-origin: 0 0 0;
  margin: 10px 0 0 0; }

.error404 [class*="ecol-"] {
  padding: 0; }

.error404 .wrap {
  padding: 100px 50px 50px 50px;
  text-align: center; }
  .error404 .wrap h1 {
    font: 600 5.0rem/5.5rem "Titillium Web", sans-serif;
    text-align: center;
    color: #ff6632;
    margin: 0 auto; }
    @media only screen and (max-width: 1500px) {
      .error404 .wrap h1 {
        font: 600 4.0rem/5.5rem "Titillium Web", sans-serif; } }
    @media only screen and (max-width: 450px) {
      .error404 .wrap h1 {
        font: 600 3.0rem/3.4rem "Titillium Web", sans-serif; } }
  .error404 .wrap ul {
    list-style-type: none; }
    .error404 .wrap ul li {
      font: 600 2.4rem/2.7rem "Titillium Web", sans-serif;
      padding: 10px 0 10px 0; }

.wpcf7-form input, .wpcf7-form textarea {
  border: none;
  border-radius: 0;
  border-bottom: 1px solid #dddddd;
  padding: 10px 0 10px 0;
  font: 300 14px/14px "Titillium Web", sans-serif;
  color: #000000;
  margin: 0 0 10px 0; }

.wpcf7-form select {
  color: #000000;
  border: none;
  border: 1px solid #dddddd;
  border-left: 5px solid #ff6632;
  width: 100%;
  height: 40px !important;
  background: url("../images/arrow-circ-down.svg") no-repeat 0 0 #ffffff;
  background-position: 98% 50%;
  background-size: 25px auto;
  font: 300 1.8rem/1.8rem "Titillium Web", sans-serif;
  padding: 0 0 0 10px;
  margin-bottom: 10px;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none; }

.wpcf7-form label {
  color: #999999;
  font: 300 1.3rem/1.9rem "Titillium Web", sans-serif;
  padding-bottom: 6px; }

.wpcf7-form input[type="text"], .wpcf7-form input[type="email"], .wpcf7-form input[type="tel"], .wpcf7-form textarea {
  font: 300 1.8rem/1.8rem "Titillium Web", sans-serif;
  color: #ff6632;
  padding-left: 10px;
  width: 100%; }

.wpcf7-form input[type="file"] {
  background: #cccccc;
  margin-top: -5px;
  border-bottom: 0;
  font: 300 2rem/2.2rem "Titillium Web", sans-serif; }

.wpcf7-form input[type="submit"] {
  float: right;
  padding: 8px 20px;
  background: #ff6632;
  font: 300 2rem/2.2rem "Titillium Web", sans-serif;
  text-transform: uppercase;
  text-decoration: none;
  border-radius: 6px;
  -webkit-transition: .2s ease-in-out;
  -moz-transition: .2s ease-in-out;
  -o-transition: .2s ease-in-out;
  transition: .2s ease-in-out;
  color: #ffffff; }
  .wpcf7-form input[type="submit"]:hover {
    background: #000000; }

.wpcf7-form input[type="checkbox"] {
  float: left;
  width: 20px;
  margin: 0 5px 20px 0; }

.wpcf7-form span.wpcf7-list-item {
  margin: 0 0 20px 0;
  margin-right: 30px; }

.wpcf7-form .wpcf7-form-control-wrap {
  font: 1.4rem/1.9rem "Titillium Web", sans-serif !important; }

.wpcf7-form .wpcf7-list-item-label {
  color: #2c2c2c;
  line-height: 0 !important; }

.wpcf7-form textarea {
  height: 100px;
  width: 100%;
  padding-left: 10px; }

.wpcf7-form p {
  padding: 0;
  margin: 0; }

.wpcf7-form .ajax-loader {
  display: none !important; }

.wpcf7-form div.wpcf7-response-output {
  margin: 50px 0 0 0;
  padding: 0;
  border: none; }

.wpcf7-form .wpcf7-response-output.wpcf7-validation-errors {
  color: #ffffff;
  background-color: red;
  border: 0;
  padding: 10px;
  line-height: 1.7rem;
  border-radius: 8px; }

.wpcf7-form .wpcf7-response-output.wpcf7-mail-sent-ok {
  color: #ffffff;
  background-color: #48e315;
  border: 0;
  padding: 10px;
  line-height: 1.7rem;
  border-radius: 8px; }

.wpcf7-form .g-recaptcha, .wpcf7-form .cf7sr-g-recaptcha {
  float: left;
  transform: scale(0.6);
  transform-origin: 0 0 0;
  margin: 30px 0 0 0; }

.full-screen {
  position: relative;
  height: 100vh;
  max-width: 2100px;
  width: 100%;
  background-size: cover !important;
  background-position: center center; }
  @media only screen and (max-width: 1100px) {
    .full-screen {
      height: 75vh; } }
  @media only screen and (max-width: 800px) {
    .full-screen {
      height: 50vh; } }
  @media only screen and (max-width: 450px) {
    .full-screen {
      height: 40vh; } }
  .full-screen .title {
    position: absolute;
    right: 10%;
    z-index: 3;
    height: 100vh;
    width: 25%;
    text-align: center;
    display: flex;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -ms-flex-align: center; }
    @media only screen and (max-width: 1500px) {
      .full-screen .title {
        width: 30%; } }
    @media only screen and (max-width: 1100px) {
      .full-screen .title {
        height: 75vh;
        width: 35%;
        right: 5%; } }
    @media only screen and (max-width: 800px) {
      .full-screen .title {
        height: 50vh;
        width: 40%;
        right: 50px; } }
    @media only screen and (max-width: 450px) {
      .full-screen .title {
        height: 40vh;
        width: 50%;
        right: 30px; } }
    .full-screen .title h1 {
      font: 700 9rem/9.5rem "Titillium Web", sans-serif;
      color: #ffffff;
      text-shadow: 3px 3px 8px rgba(0, 0, 0, 0.6); }
      @media only screen and (max-width: 1500px) {
        .full-screen .title h1 {
          font: 700 7.5rem/8rem "Titillium Web", sans-serif; } }
      @media only screen and (max-width: 1100px) {
        .full-screen .title h1 {
          font: 700 6rem/7rem "Titillium Web", sans-serif; } }
      @media only screen and (max-width: 800px) {
        .full-screen .title h1 {
          font: 700 5rem/6rem "Titillium Web", sans-serif; } }
      @media only screen and (max-width: 450px) {
        .full-screen .title h1 {
          font: 700 3rem/3.5rem "Titillium Web", sans-serif;
          padding-bottom: 10px; } }
      .full-screen .title h1 span {
        font: 400 4.5rem/5rem "Titillium Web", sans-serif; }
        @media only screen and (max-width: 1500px) {
          .full-screen .title h1 span {
            font: 400 4rem/4.5rem "Titillium Web", sans-serif; } }
        @media only screen and (max-width: 1100px) {
          .full-screen .title h1 span {
            font: 400 3.5rem/4rem "Titillium Web", sans-serif; } }
        @media only screen and (max-width: 800px) {
          .full-screen .title h1 span {
            font: 400 3rem/3.5rem "Titillium Web", sans-serif; } }
        @media only screen and (max-width: 450px) {
          .full-screen .title h1 span {
            font: 400 2rem/2.5rem "Titillium Web", sans-serif; } }
  .full-screen .deg {
    position: absolute;
    z-index: 2;
    background-image: linear-gradient(to left, rgba(255, 102, 50, 0.95) 20%, rgba(255, 102, 50, 0.1) 80%);
    width: 100%;
    height: 100vh;
    opacity: 0.90; }
    @media only screen and (max-width: 1100px) {
      .full-screen .deg {
        height: 75vh; } }
    @media only screen and (max-width: 800px) {
      .full-screen .deg {
        height: 50vh; } }
    @media only screen and (max-width: 450px) {
      .full-screen .deg {
        height: 40vh;
        background-image: linear-gradient(to left, rgba(255, 102, 50, 0.95) 30%, rgba(255, 102, 50, 0.1) 100%); } }
  .full-screen .N {
    position: absolute;
    right: 0;
    width: 1080px;
    height: 100%;
    background: url("../assets/images/N-w.svg") no-repeat center right;
    background-size: 1080px 1080px;
    opacity: 0.30;
    z-index: 1; }
    @media only screen and (max-width: 1500px) {
      .full-screen .N {
        background-size: 800px 800px; } }
    @media only screen and (max-width: 1100px) {
      .full-screen .N {
        background-size: 600px 600px; } }
    @media only screen and (max-width: 800px) {
      .full-screen .N {
        background-size: 550px 550px; } }
    @media only screen and (max-width: 450px) {
      .full-screen .N {
        background: none; } }

.partenaires-logos {
  text-align: center; }
  .partenaires-logos img {
    display: inline-block;
    max-width: 160px;
    max-height: 50px;
    height: auto;
    width: auto;
    margin: 0 30px 40px 30px; }
    @media only screen and (max-width: 450px) {
      .partenaires-logos img {
        max-width: 140px;
        max-height: 40px; } }

.video {
  width: 100%;
  max-width: 1100px;
  margin: 150px auto 100px auto; }
  .video .video-container {
    position: relative;
    padding-bottom: 56.25%;
    padding-top: 30px;
    height: 0;
    overflow: hidden; }
  .video .video-container iframe,
  .video .video-container object,
  .video .video-container embed {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%; }

.mobile-icon {
  display: none;
  cursor: pointer; }
  @media only screen and (max-width: 1100px) {
    .mobile-icon {
      position: absolute;
      z-index: 210;
      top: 15px;
      right: 30px;
      display: block;
      width: 40px;
      height: auto; } }
  @media only screen and (max-width: 800px) {
    .mobile-icon {
      top: 0;
      margin: 10px 0 0 0; } }
  @media only screen and (max-width: 450px) {
    .mobile-icon {
      top: 0;
      margin: 20px 0 0 0;
      right: 20px; } }

/******* NAVIGATION ***************************/
.site-header {
  position: fixed;
  z-index: 9;
  width: 100%;
  height: 85px;
  -webkit-transition: .2s ease-in-out;
  -moz-transition: .2s ease-in-out;
  -o-transition: .2s ease-in-out;
  transition: .2s ease-in-out; }
  @media only screen and (max-width: 1100px) {
    .site-header {
      position: relative;
      height: 0; } }
  .site-header .brand {
    position: fixed;
    display: block;
    cursor: pointer;
    height: auto;
    padding: 0 0 0 50px;
    transition: ease 0.3s; }
    @media only screen and (max-width: 1100px) {
      .site-header .brand {
        position: relative;
        padding: 0 0 0 30px; } }
    @media only screen and (max-width: 450px) {
      .site-header .brand {
        padding: 0 0 0 20px; } }
    .site-header .brand img {
      display: block;
      width: 93px;
      margin: 0 0 0 0;
      -webkit-transition: .2s ease-in-out;
      -moz-transition: .2s ease-in-out;
      -o-transition: .2s ease-in-out;
      transition: .2s ease-in-out; }
    .site-header .brand .tagline {
      margin: 0 auto;
      color: #999999;
      font: 400 1.2rem/1.4rem "Titillium Web", sans-serif;
      letter-spacing: 2px;
      padding-left: 80px;
      margin: 0;
      text-decoration: none !important; }
  .site-header .navi {
    float: right;
    width: 80%;
    padding: 0 50px 0 0; }
    @media only screen and (max-width: 1100px) {
      .site-header .navi {
        display: none; } }
    .site-header .navi .top-menu .menu {
      margin: 5px 0 0 0;
      padding: 0 0 0 0; }
      @media only screen and (max-width: 1100px) {
        .site-header .navi .top-menu .menu {
          text-align: left; } }
    .site-header .navi .top-menu .nav {
      float: right;
      width: 70%;
      text-align: right;
      margin: 0 0 0 0;
      padding: 0 0 0 0; }
      @media only screen and (max-width: 1100px) {
        .site-header .navi .top-menu .nav {
          width: 85%;
          padding: 0 0 0 20px;
          float: left; }
          .site-header .navi .top-menu .nav li {
            display: inline-block; }
            .site-header .navi .top-menu .nav li a {
              font: 400 2rem/2rem "Titillium Web", sans-serif;
              padding-right: 30px; } }
    .site-header .navi .top-menu .social {
      float: right; }
      @media only screen and (max-width: 1100px) {
        .site-header .navi .top-menu .social {
          display: block;
          width: 40px;
          float: left; } }
      .site-header .navi .top-menu .social a {
        display: block;
        padding: 20px 0 0 0;
        margin: 15px 0 0 15px;
        width: 25px;
        height: 25px;
        background: url("../assets/logos/linkedin-icon-w.svg") no-repeat 0 0;
        background-size: 25px auto;
        -webkit-transition: .2s ease-in-out;
        -moz-transition: .2s ease-in-out;
        -o-transition: .2s ease-in-out;
        transition: .2s ease-in-out;
        cursor: pointer;
        opacity: 0.8; }
        .site-header .navi .top-menu .social a:hover {
          opacity: 1.0;
          -moz-transform: translate(0px, -3px);
          -webkit-transform: translate(0px, -3px);
          -o-transform: translate(0px, -3px);
          -ms-transform: translate(0px, -3px);
          transform: translate(0px, -3px); }
    .site-header .navi .menu {
      text-align: right;
      margin: 0 0 0 0;
      padding: 0 0 0 0; }
      @media only screen and (max-width: 1100px) {
        .site-header .navi .menu {
          padding: 20px 0 0 60px; } }
      @media only screen and (max-width: 1100px) {
        .site-header .navi .menu .wpml-ls-native {
          padding: 0 0 0 50px; } }
  @media only screen and (max-width: 1100px) and (max-width: 1100px) {
    .site-header .navi .menu .wpml-ls-native {
      padding: 0 0 0 0; } }
  @media only screen and (max-width: 1100px) and (max-width: 450px) {
    .site-header .navi .menu .wpml-ls-native {
      padding: 0 10px 0 0; } }
    @media only screen and (max-width: 1100px) {
      .site-header .navi li {
        display: block; } }
    .site-header .navi li a {
      font: 400 2rem/2rem "Titillium Web", sans-serif;
      padding: 12px 0 0 15px;
      color: #ffffff;
      display: inline-block; }
      @media only screen and (max-width: 1100px) {
        .site-header .navi li a {
          display: block;
          padding: 15px 0 15px 0;
          font: 400 3rem/3.4rem "Titillium Web", sans-serif; } }
      .site-header .navi li a:hover {
        color: #2c2c2c; }
      .site-header .navi li a sup {
        font-size: 8px;
        margin-left: 3px;
        vertical-align: 6px; }
  @media only screen and (max-width: 1100px) {
    .site-header .navi.show {
      position: absolute;
      display: block;
      top: 0;
      right: 0;
      background: rgba(44, 44, 44, 0.8);
      width: 50%;
      height: 100vh;
      padding: 80px 0 0 0; } }
  @media only screen and (max-width: 450px) {
    .site-header .navi.show {
      width: 100%;
      height: 70vh; } }

.site-header-sm {
  background: rgba(230, 230, 230, 0.6);
  backdrop-filter: blur(5px);
  box-shadow: 1px 1px 4px rgba(0, 0, 0, 0.3); }
  .site-header-sm .navi li a {
    color: #2c2c2c; }
    .site-header-sm .navi li a:hover {
      color: #ff6632; }
  .site-header-sm .navi .top-menu .social a {
    background: url("../assets/logos/linkedin-icon.svg") no-repeat 0 0;
    background-size: 25px auto;
    opacity: 0.6; }

/******* PAGES ***************************/
.home h2 {
  text-align: center;
  color: #374764;
  padding: 0 0 30px 0; }
  @media only screen and (max-width: 450px) {
    .home h2 {
      padding: 0 10px 30px 10px; } }
  .home h2 sup {
    font-size: 16px;
    font-weight: normal;
    margin-left: 3px;
    vertical-align: 6px; }
    @media only screen and (max-width: 1100px) {
      .home h2 sup {
        font-size: 11px; } }

@media only screen and (max-width: 1100px) {
  .home h3 {
    font: 600 2.2rem/2.8rem "Open Sans", sans-serif; } }

.home .qui {
  padding: 100px 50px 0 50px; }
  @media only screen and (max-width: 1100px) {
    .home .qui {
      padding: 50px 50px 0 50px; } }
  @media only screen and (max-width: 800px) {
    .home .qui {
      padding: 30px 30px 30px 30px; } }
  @media only screen and (max-width: 450px) {
    .home .qui {
      padding: 20px 20px 20px 20px; } }
  .home .qui .description {
    padding: 30px 30px 0 0; }
    @media only screen and (max-width: 1100px) {
      .home .qui .description {
        padding: 0 30px 0 0; } }
    @media only screen and (max-width: 800px) {
      .home .qui .description {
        padding: 0; } }
  .home .qui .avantages {
    padding: 30px 0 0 0; }
    @media only screen and (max-width: 1100px) {
      .home .qui .avantages {
        padding: 0 0 0 0; } }
    .home .qui .avantages .box {
      float: left;
      text-align: center;
      width: 50%;
      height: 200px;
      display: flex;
      -webkit-box-align: center;
      -webkit-align-items: center;
      -ms-flex-align: center;
      justify-content: center; }
      .home .qui .avantages .box h4 {
        padding: 10px 0 0 0;
        color: #374764; }
        @media only screen and (max-width: 1500px) {
          .home .qui .avantages .box h4 {
            font: 600 1.8rem/2.2rem "Open Sans", sans-serif; } }
      .home .qui .avantages .box img {
        display: block;
        max-width: 60px;
        max-height: 60px;
        height: auto;
        width: auto;
        margin: 0 auto;
        opacity: 0.5; }
      .home .qui .avantages .box:nth-child(1) {
        border-bottom: 1px solid #dddddd; }
      .home .qui .avantages .box:nth-child(2) {
        border-bottom: 1px solid #dddddd;
        border-left: 1px solid #dddddd; }
      .home .qui .avantages .box:nth-child(4) {
        border-left: 1px solid #dddddd; }

.home .expertise {
  padding: 100px 0 0 0; }
  @media only screen and (max-width: 1100px) {
    .home .expertise {
      padding: 50px 0 0 0; } }
  .home .expertise .service {
    position: relative;
    height: 600px;
    width: 100%;
    background-size: cover;
    background-position: center center;
    margin-bottom: 10px; }
    @media only screen and (max-width: 1500px) {
      .home .expertise .service {
        height: 450px; } }
    @media only screen and (max-width: 1100px) {
      .home .expertise .service {
        height: 400px; } }
    @media only screen and (max-width: 800px) {
      .home .expertise .service {
        height: 500px; } }
    @media only screen and (max-width: 450px) {
      .home .expertise .service {
        height: auto;
        background-size: 150% auto;
        background-repeat: no-repeat;
        background-position: top center; } }
    .home .expertise .service .wrap {
      position: absolute;
      right: 0;
      width: 35%;
      height: 600px;
      padding: 50px 80px 0 80px;
      background-image: linear-gradient(to bottom, rgba(255, 255, 255, 0.95) 50%, rgba(255, 255, 255, 0.7) 100%);
      backdrop-filter: blur(8px); }
      @media only screen and (max-width: 1500px) {
        .home .expertise .service .wrap {
          height: 450px;
          padding: 50px;
          width: 45%; } }
      @media only screen and (max-width: 1100px) {
        .home .expertise .service .wrap {
          height: 400px;
          width: 50%;
          padding: 30px; } }
      @media only screen and (max-width: 800px) {
        .home .expertise .service .wrap {
          height: 500px; } }
      @media only screen and (max-width: 450px) {
        .home .expertise .service .wrap {
          position: inherit;
          width: 100%;
          height: auto;
          background-image: none;
          backdrop-filter: none;
          padding: 200px 20px 50px 20px; } }
      .home .expertise .service .wrap h3 {
        color: #ff6632;
        text-align: left;
        margin-bottom: 20px;
        text-transform: uppercase; }
    .home .expertise .service:nth-of-type(2) .wrap, .home .expertise .service:nth-of-type(4) .wrap {
      right: auto;
      left: 0; }

.home .traction-aid {
  padding: 100px 50px 100px 50px; }
  @media only screen and (max-width: 1100px) {
    .home .traction-aid {
      padding: 50px 50px 0 50px; } }
  @media only screen and (max-width: 800px) {
    .home .traction-aid {
      padding: 30px 30px 0 30px; } }
  @media only screen and (max-width: 450px) {
    .home .traction-aid {
      padding: 20px 20px 0 20px; } }
  .home .traction-aid .description {
    padding: 0 100px 0 0; }
    @media only screen and (max-width: 1100px) {
      .home .traction-aid .description {
        padding: 0 20px 50px 0; } }
    @media only screen and (max-width: 800px) {
      .home .traction-aid .description {
        padding: 0 20px 20px 0; } }
  @media only screen and (max-width: 800px) {
    .home .traction-aid img {
      padding-bottom: 50px; } }

.home .contact-soumission {
  position: relative;
  padding: 100px 50px 30px 50px;
  background: url("../assets/images/N-g.svg") no-repeat center right #f6f6f6;
  background-size: 850px auto; }
  @media only screen and (max-width: 1100px) {
    .home .contact-soumission {
      padding: 50px; } }
  @media only screen and (max-width: 800px) {
    .home .contact-soumission {
      padding: 30px;
      background-image: none; } }
  @media only screen and (max-width: 450px) {
    .home .contact-soumission {
      padding: 20px; } }
  .home .contact-soumission .desc {
    padding: 0 100px 0 0; }
    @media only screen and (max-width: 450px) {
      .home .contact-soumission .desc {
        padding: 0; } }
  .home .contact-soumission .radios .wpcf7-list-item-label {
    color: #ff6632;
    font: 700 2.4rem/2.7rem "Titillium Web", sans-serif; }
  .home .contact-soumission .radios input {
    width: 16px !important;
    height: 16px !important; }
  .home .contact-soumission .radios .wpcf7-list-item {
    display: block; }
  .home .contact-soumission textarea {
    height: 200px; }
  .home .contact-soumission input[type="text"], .home .contact-soumission input[type="email"], .home .contact-soumission input[type="tel"], .home .contact-soumission textarea {
    opacity: 0.7; }

.home .certs {
  padding: 100px 0 100px 0;
  text-align: center; }
  @media only screen and (max-width: 1100px) {
    .home .certs {
      padding: 50px 0 50px 0; } }
  .home .certs img {
    display: inline-block;
    max-width: 150px;
    max-height: 150px;
    height: auto;
    width: auto;
    margin: 30px 30px 0 30px; }
    @media only screen and (max-width: 1100px) {
      .home .certs img {
        max-width: 100px;
        max-height: 100px; } }

/******* Single pages ***************************/
/******* FOOTER *******************************/
.footercontainer {
  width: 100%;
  background: #2c2c2c; }
  .footercontainer [class*="ecol-"] {
    padding: 0; }
  .footercontainer .site_w {
    background: none; }
  .footercontainer .foot-cont {
    padding: 50px 0 50px 0; }
    @media only screen and (max-width: 1500px) {
      .footercontainer .foot-cont {
        padding: 50px; } }
    @media only screen and (max-width: 1100px) {
      .footercontainer .foot-cont {
        padding: 50px 0 50px 50px; } }
    @media only screen and (max-width: 800px) {
      .footercontainer .foot-cont {
        padding: 30px; } }
    @media only screen and (max-width: 450px) {
      .footercontainer .foot-cont {
        padding: 20px; } }
    .footercontainer .foot-cont #footer-1 {
      width: 13%;
      float: left;
      margin: 0 2% 0 0;
      font: 400 1.7rem/2.2rem "Titillium Web", sans-serif; }
      @media only screen and (max-width: 800px) {
        .footercontainer .foot-cont #footer-1 {
          width: 13%;
          float: left; } }
      @media only screen and (max-width: 450px) {
        .footercontainer .foot-cont #footer-1 {
          float: none; } }
      .footercontainer .foot-cont #footer-1 .branding .logo {
        width: 130px; }
        @media only screen and (max-width: 1100px) {
          .footercontainer .foot-cont #footer-1 .branding .logo {
            width: 110px; } }
        .footercontainer .foot-cont #footer-1 .branding .logo img {
          opacity: 1.0; }
    .footercontainer .foot-cont #footer-details {
      width: 43%;
      float: left;
      color: #ffffff;
      margin: 0 2% 0 0;
      font: 400 1.5rem/2.2rem "Open Sans", sans-serif; }
      @media only screen and (max-width: 800px) {
        .footercontainer .foot-cont #footer-details {
          width: 80%;
          padding: 0 0 30px 40px; } }
      @media only screen and (max-width: 450px) {
        .footercontainer .foot-cont #footer-details {
          float: none;
          width: 100%;
          padding: 30px 0 30px 0; } }
      .footercontainer .foot-cont #footer-details a {
        font-weight: 700; }
    .footercontainer .foot-cont #footer-3 {
      width: 40%;
      float: right;
      margin: 0 0 0 0;
      padding: 0 0 0 0; }
      @media only screen and (max-width: 800px) {
        .footercontainer .foot-cont #footer-3 {
          float: none;
          width: 100%; } }
      .footercontainer .foot-cont #footer-3 .iframe {
        display: block; }
  .footercontainer .site-info {
    padding: 0 0 40px 0;
    font: 300 13px/19px "Titillium Web", sans-serif;
    color: #ffffff !important; }
    @media only screen and (max-width: 1500px) {
      .footercontainer .site-info {
        padding: 0 50px 40px 50px; } }
    @media only screen and (max-width: 800px) {
      .footercontainer .site-info {
        width: 100%;
        padding: 0 30px 40px 30px; } }
    @media only screen and (max-width: 450px) {
      .footercontainer .site-info {
        width: 100%; } }
    @media only screen and (max-width: 800px) {
      .footercontainer .site-info [class*="ecol-"] {
        float: left;
        width: 50%; } }
    @media only screen and (max-width: 450px) {
      .footercontainer .site-info [class*="ecol-"] {
        float: none;
        width: 100%; } }
    .footercontainer .site-info a {
      color: #cccccc;
      -webkit-transition: .2s ease-in-out;
      -moz-transition: .2s ease-in-out;
      -o-transition: .2s ease-in-out;
      transition: .2s ease-in-out; }
      .footercontainer .site-info a:hover {
        color: #ff6632; }
    .footercontainer .site-info .custom {
      text-align: right; }
      @media only screen and (max-width: 800px) {
        .footercontainer .site-info .custom {
          text-align: right;
          margin-top: 0; } }
      @media only screen and (max-width: 450px) {
        .footercontainer .site-info .custom {
          text-align: left; } }
