/*
Theme Name: CBM
Version: 1.0
*/

.pcontainer {
}

.ncontact .simplelink {
  color: #e40a1f;
  text-decoration: underline;
  font-size: 18px;
  line-height: 20px;
  margin-bottom: 0px;
  display: none;
}

.ncontact .simplelink:hover {
  text-decoration: none;
}

.smallertext {
  font-size:11px !important;
  color:#999 !important;
}

.gform_wrapper.gravity-theme .description, 
.gform_wrapper.gravity-theme .gfield_description,
.gform_wrapper.gravity-theme .gsection_description,
.gform_wrapper.gravity-theme .instruction {
  padding-top: 2px !important;
}
.gform_legacy_markup_wrapper li.hidden_label input[type="radio"],
.gform_legacy_markup_wrapper li.hidden_label input[type="checkbox"] {
  margin-top: 2px !important;
}

.gform_validation_errors {
  max-width: calc(100% - 16px) !important;
}

.gform_validation_errors h2 {
  line-height: 18px !important;
  padding: 5px !important;
}


section.ncontact form input[type="text"],
section.ncontact form input[type="email"] {
  font-family: lato,sans-serif;
  border: 0;
  width: 48%;
  font-size: 18px !important;
  line-height: 20px !important;
  color: #404040;
  padding: 10px !important;
  background-color: #f2f2f2;
  margin: 0 !important;
}

@media only screen and (max-width: 641px) {
  section.ncontact form input[type="text"],
  section.ncontact form input[type="email"] {
    width: 100% !important;
  }
}

.pcontainer .pbutton {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  background-position: center center;
  background-size: auto;
  background-repeat: no-repeat;
  background-image: url("/wp-content/themes/cbmcompany/assets/img/play.png");
}

.fancybox-skin {
    background: #000;
    -webkit-border-radius: 0px !important;
    -moz-border-radius: 0px !important;
    border-radius: 0 !important;
    padding: 2px !important;
}

#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content .moove-gdpr-button-holder {
    display: flex !important;
    flex-direction: row-reverse !important;
}
#moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content a.mgbutton, #moove_gdpr_cookie_info_bar .moove-gdpr-info-bar-container .moove-gdpr-info-bar-content button.mgbutton {
    padding: 8px 15px !important;
}

.gform_wrapper{
    display:block !important;
}

section.nrecherche h1.subtitle.atitle {
  font-size: 20px !important;
  line-height: 20px !important;
}

section.nrecherche h1.subtitle.atitle span { 
  display:block;
  font-size: 30px !important;
  line-height: 30px !important;
}

section.nnews article ol.breadcrumb {
    margin-top: -5px;
}


section.nreferences article .description p.subsubtitle {
    font-family: 'Lato',sans-serif;
    font-size: 19px;
    line-height: 19px;
    font-weight: 900;
    margin: 0;
    margin-bottom: 15px;
    color: #2e2a25;
}

section.ncontent h1 {
    font-family: 'Open Sans', sans-serif;
    font-size: 59px;
    line-height: 48px;
    font-weight: 300;
}
section.ncontact article {
  padding-top: 0px;
}
section.nnews article h1 {
  padding-top: 25px;
}
ol.breadcrumb {
  margin-top:20px;  
  margin-bottom:15px; 
}
.services ol.breadcrumb {
  margin-top:15px;  
}
ol.breadcrumb li .bold {
  font-weight: bold;
  font-size: 14px;
  line-height: 1.42857143;
}
ol.breadcrumb li a {
  font-size: 14px;
  line-height: 1.42857143;
  color:black;
  text-decoration: none;
}
ol.breadcrumb li a:hover {
  color:black;
  text-decoration: underline;
}
section.nrecherche h2.like-h1 {
    font-family: 'Lato', sans-serif;
    font-size: 30px;
    line-height: 30px;
    font-weight: normal;
    margin: 0;
    margin-bottom: 4px;
}
section.nrecherche h1.like-h2 {
    font-family: 'Lato', sans-serif;
    font-size: 50px;
    line-height: 50px;
    padding: 0;
    margin: 0;
    margin-bottom: 5px;
    font-weight: bold;
    color: #2e2a25;
}
.nrecherche p.simple span {
  font-weight: bold;
  text-transform: uppercase;
  line-height: 18px;
}

section.nreferences article .description h1 {
    font-family: 'Lato', sans-serif;
    font-size: 19px;
    line-height: 19px;
    font-weight: 900;
    margin: 0;
    margin-bottom: 15px;
    color: #2e2a25;
}

.nrecherche p a {
  color:#404040;
  font-size: 14px;
  line-height: 16px;
  text-decoration: none;
}
.nrecherche p a:hover {
  text-decoration: underline;
}

.nrecherche h1 a,
.nrecherche h2 a,
.nrecherche p.simple a {
  color:#e40a1f;
  text-decoration: none;
}

.nrecherche h1 a:hover,
.nrecherche h2 a:hover,
.nrecherche p.simple a:hover {
  color:#e40a1f;
  text-decoration: underline;
}
body .gform_wrapper ul li.field_description_below div.ginput_container_radio {
    margin-top: 0px !important;
}


a:hover .nicon--arrow-right {
    background-position: -812px -359px !important;
}

.footer-mobile {
  padding: 10px;
  clear:both;  
}
ul.fmenu {
  display:block;
  clear:both;   
  padding: 0; 
  margin-bottom:20px;
}
ul.fmenu li {
    display: inline-block;
    list-style: none;
    margin-right:10px;
    font-size: 12px;
}
ul.fmenu.fmenubold li {
  text-transform: uppercase;
  font-weight:bold;
  font-size: 14px;
}

header .navbar-default form.search input[type="text"] {
  background: none;
}

header .navbar-default form.search input[type="text"]:focus {
  outline: none;
}


/*************************************/
/*************SERVICES MENU***********/
/*************************************/

ul.middlemenu li a { 
  padding-bottom: 5px;
}
ul.middlemenu ul.sub-menu li {
    display: block;
    width: 100%;
    margin: 0;
    padding: 0;
    border-bottom:1px solid #f9f9f9;
    background-color: #fff;

    transition: background-color 0.25s ease;
}

ul.middlemenu ul.sub-menu li:last-child{
  border-bottom:0;
  border-bottom-right-radius: 10px;
}

ul.middlemenu ul.sub-menu li a {
    padding: 10px 10px;
    font-size:16px;
    line-height: 16px;
    text-decoration: none;
    transition: color 0.25s ease;
}


ul.middlemenu ul.sub-menu li.active {
  background-color: #e40a1f;
}
ul.middlemenu ul.sub-menu li.active a {
  color:white;
}
ul.middlemenu ul.sub-menu li.active:hover, 
ul.middlemenu ul.sub-menu li:hover {
  background-color: #000;
}
ul.middlemenu ul.sub-menu li:hover a {
  color:white;
}
ul.middlemenu ul.sub-menu {
    position: absolute;
    z-index: 99999;
    opacity: 0;
    visibility: hidden;
    width: auto;
    border-bottom-right-radius: 10px;
          
    box-shadow: 0px 0px 11px -2px rgba(0,0,0,0.30);
    -webkit-box-shadow: 0px 0px 11px -2px rgba(0,0,0,0.30);
    -moz-box-shadow: 0px 0px 11px -2px rgba(0,0,0,0.30);

    padding: 0;

    list-style: none;
    margin: 0;
    margin-left: -10px;
    list-style: none;
}

ul.middlemenu>li:hover  ul.sub-menu {
    opacity: 1;
    visibility: visible;
}

/*************************************/
/*************SERVICES****************/
/*************************************/

.nsicon {
    display: inline-block;
    vertical-align: middle;
    background-repeat: no-repeat;
}

.nsicon--services { background-position: 0px 0px; width: 88px; height: 88px; background-size: cover;}

.nsicon--scircle {
    width: 130px;
    height: 130px;
    background-position: center;
    background-size: cover;
    margin:0 50px;
    display: block;
}

.services .scircle p {
    font-family: 'Lato', sans-serif;
    font-size: 20px;
    line-height: 28px;
    font-weight: 900;
    padding: 0;
    margin: 0;
    margin-top: 20px;
    text-transform: uppercase;
    text-align: center;
}

.scircle .container {
  position: relative;
  height:550px;
  background-position: center bottom;
  background-size: auto;
  background-repeat: no-repeat;
  background-image: url("/wp-content/themes/cbmcompany/assets/img/cbm-circle.gif");
  margin-bottom:100px;
}

.scircle-top-left {
  position: absolute;
  top:0;
  left:50%;
  margin-left:-450px;
  display: inline-block;
}

.scircle-top-right {
  position: absolute;
  top:0;
  right:50%;
  margin-right:-450px;
  display: inline-block;
}

.scircle-bottom-left {
  position: absolute;
  bottom:0;
  left:50%;
  margin-left:-450px;
  display: inline-block;
}

.scircle-bottom-right {
  position: absolute;
  bottom:0;
  right:50%;
  margin-right:-450px;
  display: inline-block;
}

ul.smenu {
  padding: 0;
  display: block;
  list-style: none;
  text-align: center;
  margin-bottom: 70px;
}
ul.smenu li {
  display: inline-block;
  list-style: none;
}
ul.smenu li a.sbtn {

  text-align: center;
}
ul.smenu li a.sbtn .ico {
  transition: background-color 0.25s ease;
  background-color: #383738;
  border-radius: 20px;
  padding:30px;
  margin:20px 40px;
  display: block;
  text-align: center;
  margin-bottom: 12px;
}
ul.smenu li a.sbtn:hover .ico  {
  background-color: #e40a1f;
}
ul.smenu li.active a.sbtn .ico  {
  background-color: #e40a1f;
}
ul.smenu li .titre {
  display: block;
  text-align: center;
  font-family: 'Lato', sans-serif;
  font-size: 20px;
  line-height: 24px;
  font-weight: bold;
  color:#3f3f3f;
  text-align: center;
}
ul.smenu li.active .titre {
  font-weight: 900;
  text-decoration: underline;
}
ul.smenu li a.sbtn:hover .titre  {
  font-weight: 900;
  text-decoration: underline;
}
.services {
  margin-top:-250px;
  position:relative;
  z-index:1;
}
.services p.smedia {
  font-family: 'Lato', sans-serif;
  font-size: 50px;
  line-height: 58px;
  font-weight: 700;
  color:white;
  padding: 0;
  margin: 0;
  margin-bottom: 44px;    
}
.services h1 {
  font-family: 'Lato', sans-serif;
  font-size: 50px;
  line-height: 58px;
  font-weight: 700;
  padding: 0;
  margin: 0;
  margin-top: 40px;
  margin-bottom: 0px;   
}

.service {
  margin-top: 0px;
  margin-bottom: 0px;
  padding-top:60px;
  padding-bottom:60px;
}
.a24 a.nbutton,
.service a.nbutton {
    transition: background-color 0.25s ease;
    display: inline-block;
    margin-top: 20px;
    background-color: #e40a1f;
    font-family: 'Lato', sans-serif;
    color: #fff;
    font-size: 16px;
    line-height: 16px;
    font-weight: 900;
    padding: 12px 18px;
    -webkit-border-radius: 10px;
    -moz-border-radius: 10px;
    border-radius: 10px;
    text-transform: uppercase;
}
.a24 a.nbutton:hover,
.service a.nbutton:hover {
  background-color: #383738;
  text-decoration: none;
}
.a24 a.nbutton.reverse-color,
.service a.nbutton.reverse-color {
    background-color: #fff;
    color: #e40a1f;
}
.a24 a.nbutton.reverse-color:hover,
.service a.nbutton.reverse-color:hover {
  background-color: #383738;
  color: #fff;
}
.service h2 {
  font-family: 'Lato', sans-serif;
  font-size: 30px;
  line-height: 38px;
  font-weight: bold;
  padding: 0;
  margin: 0;
  margin-bottom: 35px;
}
.service p {
  font-family: 'Lato', sans-serif;
  font-size: 18px;
  line-height: 26px;
  font-weight: normal;
  padding: 0;
  margin: 0;
  margin-bottom: 10px;
}
.services .fcontainer {
  padding-right:0;
  padding-left:0;
}

.services .media-spacer {
  height:98px;
  display: block;
}

/*************************************/
/*************MENUS*******************/
/*************************************/
header .navbar-default ul.middlemenu li {
  margin-left: 10px !important;
}
header .navbar-default ul.middlemenu li a {
  font-size: 18px !important;
}

_postuler {
  height:600px;
}

/*************************************/
/*************MEDIAS******************/
/*************************************/

@media (min-width: 701px){
  .footer-mobile {
    display: none;
  }
}

@media only screen and (max-width: 1199px) {
header .navbar-default ul.middlemenu li a {
    font-size: 17px;
}
ul.middlemenu ul.sub-menu li a {
    font-size:15px;
}
header .navbar-default ul.middlemenu li a {
    font-size: 14px !important;
}
}


@media only screen and (max-width: 991px) {
header .navbar-default ul.middlemenu li a {
    font-size: 14px;
}
ul.middlemenu ul.sub-menu li a {
    font-size:12px;
}
header .navbar-default ul.middlemenu li a {
    font-size: 10px !important;
}
header .navbar-default ul.middlemenu li {
  margin-left: 5px !important;
}
_postuler {
  height:400px !important;
}
}


@media only screen and (max-width: 700px){

  .a24-youtube {
    height:180px !important;
  }
.navbar-nav  ul.sub-menu { 
  margin:0;
  padding:0;
}
.navbar-nav  ul.sub-menu li.active a {
  background-color: #e7e7e7;
  color: #555;
}
.navbar-nav  ul.sub-menu li a {
    padding-top: 10px;
    padding-bottom: 10px;
    padding-left:30px;
    display: block;
    color:#777;
}
}

@media only screen and (max-width: 991px) {

  .services .img-responsive {
      margin: 0 auto;
  }


  .scircle .container {
    height:350px;
    background-size: 300px auto;
  }

  .scircle-bottom-right,
  .scircle-top-right {
    margin-right:-300px;
  }

  .scircle-bottom-left,
  .scircle-top-left {
    margin-left:-300px;
  }

  .nsicon--scircle {
      width: 70px;
      height: 70px;
      margin:0 50px;
  }

  .services .scircle p {
      font-size: 16px;
      line-height: 22px;
      margin-top: 10px;
  }
}


@media only screen and (max-width: 700px){
  .scircle .container {
    height:225px;
    background-size: 125px auto;
    background-position: center;
  }

  .scircle-bottom-right,
  .scircle-top-right {
    margin-right:-140px;
  }

  .scircle-bottom-left,
  .scircle-top-left {
    margin-left:-140px;
  }

  .nsicon--scircle {
      width: 40px;
      height: 40px;
      margin:0 30px;
  }

  .services .scircle p {
      font-size: 12px;
      line-height: 16px;
      margin-top: 7px;
  }
}

@media (max-width: 991px){

  .services h1,
  .services p.smedia {
    font-size: 38px;
    line-height: 42px;
  }
  .services p.smedia {
    margin-bottom: 88px;
  }
  .nicon--services {
    width: 50px;
    height: 50px;
  }
  ul.smenu li a.sbtn .ico {
    padding: 15px;
    margin: 10px 10px;
  }
  ul.smenu li .titre {
    font-size: 14px;
    line-height: 18px;
  }
  .service h2 {
    font-size: 22px;
    line-height: 26px;
  }
  .services .media-spacer {
    height:56px;
    display: block;
  }
}

@media (max-width: 701px){
  .services {
    margin-top:-190px;
  }
  ul.smenu li .titre {
    font-size: 12px;
    line-height: 16px;
  }
  .nicon--services {
    width: 40px;
    height: 40px;
  }
  .services p.smedia {
      margin-bottom: 62px;
  }
  .services h1,
  .services p.smedia {
    font-size: 28px;
    line-height: 34px;
  }
  .services .media-spacer {
    height:59px;
    display: block;
  }
}

/***************************************************************/
/*************************** ADD 2024 **************************/
/***************************************************************/


/*************************** SPACERS **************************/
.a24--mt-1{
  margin-top: -7px !important;
}

/****************/
.a24-pt-0 {
  padding-top: 0px !important;
}

.a24-pb-0 {
  padding-bottom: 0px !important;
}

.a24-mt-0 {
  margin-top: 0px !important;
}

.a24-mb-0 {
  margin-bottom: 0px !important;
}

.a24-py-0 {
  padding-top: 0px !important;
  padding-bottom: 0px !important;
}

.a24-my-0 {
  margin-top: 0px !important;
  margin-bottom: 0px !important;
}

/****************/


.a24-pt-1 {
  padding-top: 7px !important;
}

.a24-pb-1 {
  padding-bottom: 7px !important;
}

.a24-mt-1 {
  margin-top: 7px !important;
}

.a24-mb-1 {
  margin-bottom: 7px !important;
}

.a24-py-1 {
  padding-top: 7px !important;
  padding-bottom: 7px !important;
}

.a24-my-1 {
  margin-top: 7px !important;
  margin-bottom: 7px !important;
}

/****************/

.a24-pt-2 {
  padding-top: 14px !important;
}

.a24-pb-2 {
  padding-bottom: 14px !important;
}

.a24-mt-2 {
  margin-top: 14px !important;
}

.a24-mb-2 {
  margin-bottom: 14px !important;
}

.a24-py-2 {
  padding-top: 14px !important;
  padding-bottom: 14px !important;
}

.a24-my-2 {
  margin-top: 14px !important;
  margin-bottom: 14px !important;
}

/****************/

.a24-pt-3 {
  padding-top: 24px !important;
}

.a24-pb-3 {
  padding-bottom: 24px !important;
}

.a24-mt-3 {
  margin-top: 24px !important;
}

.a24-mb-3 {
  margin-bottom: 24px !important;
}

.a24-py-3 {
  padding-top: 24px !important;
  padding-bottom: 24px !important;
}

.a24-my-3 {
  margin-top: 24px !important;
  margin-bottom: 24px !important;
}

/****************/

.a24--mt-5 {
  margin-top:-35px !important;
}

.a24-pt-5 {
  padding-top: 35px !important;
}

.a24-pb-5 {
  padding-bottom: 35px !important;
}

.a24-mt-5 {
  margin-top: 35px !important;
}

.a24-mb-5 {
  margin-bottom: 35px !important;
}

.a24-py-5 {
  padding-top: 35px !important;
  padding-bottom: 35px !important;
}

.a24-my-5 {
  margin-top: 35px !important;
  margin-bottom: 35px !important;
}

.a24-px-5 {
  padding-left: 35px !important;
  padding-right: 35px !important;
}

/***************************************************************/

.a24 {
  margin-left:-15px; 
  margin-right:-15px;
}

.a24 h2 {
  font-size: 40px;
  line-height: 45px;
  font-weight: 900;
  font-family: 'Lato', sans-serif;
}

.a24 h3 {
  font-size: 32px;
  line-height: 38px;
  font-weight: 600;
  color:#e40a1f;
}

.a24 h4 {
  font-size: 25px;
  line-height: 30px;
  font-weight: 600;
  color:#e40a1f;
}

.a24 ul {
  list-style: inside;  
  padding: 0;
  margin: 0;
}

.a24 li,
.a24 p {
  font-family: 'Lato', sans-serif;
  font-size: 16px;
  line-height: 22px;
  font-weight: normal;
}

.a24-button,
.a24-button:active, 
.a24-button:visited, 
.a24-button:focus {
  font-size: 18px;
  line-height: 24px;
  font-weight: 800;
  text-decoration: none;
  color: #fff !important;
  border: 2px solid #e40a1f;
  border-radius: 10px;
  padding: 5px 12px;
  background-color: #e40a1f;
  transition: all 0.2s ease-out;
  text-transform: uppercase;
}

.a24-button:hover {
  color: #e40a1f !important;
  background-color:#fff;
  text-decoration: none;
}

.a24-align-middle {
  vertical-align: middle;
}

.a24-inline-block {
  display: inline-block;
}

.a24-float-right {
  float: right;
}

.a24-font-weight-bold p,
.a24-font-weight-bold {
  font-weight: bold !important;
}

.a24-font-weight-bolder p,
.a24-font-weight-bolder {
  font-weight: bolder !important;
}

.a24-bg-grey {
  background-color: #f2f2f2;
}

.a24-spacer {
  height: 50px;
  display: block;
}

.a24-small-spacer {
  height: 25px;
  display: block;
}

.a24-big-spacer {
  height: 100px;
  display: block;
}

.a24-full-media {
  display: flex; 
  height: 100%; 
  flex-direction: column; 
  padding-top:100px;
}

.a24-full-media-media {
  margin-top:-100px;
}

.a24-full-media-cont {
  margin-top:100px; 
  padding-bottom:100px;
  display: flex; 
  justify-content: center; 
  background-repeat:repeat-y;
  background-position: center center; 
  background-image:url(/wp-content/themes/cbmcompany/assets/img/a24-bar02.gif);
}

.a24-pillar {
  padding-bottom:100px;   
  background-image:url(/wp-content/themes/cbmcompany/assets/img/a24-bar03.gif);
  background-position: top center;
  background-size: auto;
}

.a24-pillar-firstchild {
  background-image:url(/wp-content/themes/cbmcompany/assets/img/a24-square01.gif) !important;
}

.a24-pillar-cont {
  max-width:1155px; 
  background-color:white; 
  margin:0 auto;
  padding-bottom:80px;
}

.a24-pillar-icont {
  display: table;
  margin-top:30px;
}

.a24-pillar-first {
  display: table-cell;
  vertical-align: middle;
  float: none;
}

.a24-pillar-media {
  padding-right:50px;
  width:100%;
}

.a24-pillar-second {
  padding-right:80px;
  padding-left:50px;
  display: table-cell;
  vertical-align: middle;
  float: none;
}

.a24-mw1155 {
  max-width:1155px;
}

.a24-leftgrey {
  display: flex; 
  height: 100%; 
  flex-direction: column; 
  background-position: center center; 
  background-image:url('/wp-content/themes/cbmcompany/assets/img/a24-bar01.gif');
}

.a24-leftgrey-cont {
  display: flex;
  justify-content: center;
}

.a24-rightgrey-small { display: flex; height: 100%; gap: 150px; } 
.a24-rightgrey-small-cont { flex-grow:1; flex-basis:50%;display: flex; justify-content: flex-end;     } 
.a24-rightgrey-small-icont { display:inline-block;max-width:525px; } 
.a24-rightgrey-small-cont-media { flex-shrink:2; flex-basis:50%;justify-content: flex-start;  ; } 

.a24-leftgrey-small { display: flex; height: 100%; gap: 150px; } 
.a24-leftgrey-small-cont-media { flex-shrink:2; flex-basis:50%;justify-content: flex-end; text-align :right; ; } 
.a24-leftgrey-small-cont { flex-grow:1; flex-basis:50%;display: flex; justify-content: flex-start;     } 
.a24-leftgrey-small-icont { display:inline-block;max-width:525px; } 

.a24-map-title .a24-map-title-para {
  width:70%;
}

/***************************************************************/
.a24-metier {
  text-align:center;
}

.a24-poste {
  margin-bottom: 30px;
  border: 2px dashed #e40a1f;
  padding:30px;
  text-align: center;
}

.a24-poste-top {
  min-height: 100px;
  display: block;
}

.a24-poste-bottom {
  display: block;
}

.a24-bg-rounded-red {
  background-color:#e40a1f;
  border-radius: 10px;
  padding: 60px 100px;
  color:white !important;
}
.a24-bg-rounded-red .container {
  margin-right: 15px;
  margin-left: 15px;
}

.a24-bg-rounded-red h2 {
  color:white;
}

.a24-bg-rounded-red .a24-right {
  text-align: right;
}

.a24-testimony {
  border-radius: 10px;
  background-color: #e40a1f !important;
  padding: 30px 60px;

  display: flex;
  flex-direction: row;
  flex-wrap: nowrap;
  justify-content: normal;
  align-items: normal;
  align-content: normal;
  gap: 60px;;
  margin-bottom: 5px;;
}
.a24-testimony-img {
  height: auto;
  display: flex;
  flex-grow: 0;
  flex-shrink: 1;
  flex-basis: auto;
  align-self: auto;
  order: 0;
  align-items: center; 
}

.a24-testimony-img img {
  width:120px;;
  height:auto;
}

.a24-testimony-desc {
  flex-grow:1;
  display: block;
  flex-grow: 1;
  flex-shrink: 1;
  flex-basis: auto;
  align-self: auto;
  order: 0;
  padding: 30px 0;
}

.a24-testimony-desc p {
  color:white;

}

.a24-bg-rounded-red .a24-button,
.a24-bg-rounded-red .a24-button:active, 
.a24-bg-rounded-red .a24-button:visited, 
.a24-bg-rounded-red .a24-button:focus {
  color: #e40a1f !important;
  border: 2px solid #ffffff;
  background-color: #ffffff;
  transition: all 0.2s ease-out;
  text-transform: uppercase;
}

.a24-bg-rounded-red h3 {
  font-size: 25px;
  line-height: 30px;
  font-weight: 600;
  color:white !important;
}

.a24-bg-rounded-red .a24-button:hover {
  color: #ffffff !important;
  background-color:#e40a1f;
}

h3.a24-cartridge {
  background-color:#e40a1f;
  color: #ffffff !important;
  padding:10px 26px;
  display: inline-block;
  font: weight 900px !important;
}

.a24-poste h2 { 
  font-size: 25px;
  line-height: 30px;
  font-weight: 600;
  padding:0;
  margin:0;
  color:#e40a1f;
}

.a24-poste p { 
  font-size: 18px;
  line-height: 28px;
  font-weight: 600;
  padding:0;
  margin:0;
}

/***************************************************************/

.a24-detail-offer .cadre {
  border: 2px dashed #e40a1f;
  padding:50px 100px;
}

.a24-detail-offer .cadre .col-md-4 {
  padding: 15px 0 ;
}

/***************************************************************/

.a24-image-container {
  position: relative;
  display: inline-block;
}

.a24-image-container img {
  display: block;
  width: 100%;
  height: auto;
}

.a24-play-button {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: rgba(0, 0, 0, 0.5);
  color: white;
  border: none;
  border-radius: 50%;
  padding: 10px 15px;
  font-size: 24px;
  cursor: pointer;
  outline: none;
}

section.nmap.a24-nmap .pays .infos a {
  padding: 0px;
  border-radius: 0px;
  background:none;
  color:#e40a1f;
  text-decoration: underline;
}

section.nmap.a24-nmap .pays .infos a:hover {
  padding: 0px;
  border-radius: 0px;
  background:none;
  color:#e40a1f;
  text-decoration: none;
}

.a24-play-button:hover {
  background-color: rgba(0, 0, 0, 0.7);
}

@media only screen and (max-width: 700px) {
  section.a24-map-title {
    display: none !important;
  }
}

/***************************************************************/

.swiper-notification {
  display:none;
}
.swiperStandardBy1 {
  display: flex;
  flex-direction: column;
}

.swiperBy1,
.swiperBy3,
.swiperBy5 {
  position: relative;
}

.swiperBy1 .swiper-header ,
.swiperBy3 .swiper-header ,
.swiperBy5 .swiper-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 10px;
  box-sizing: border-box;
  z-index: 10;
  background: rgba(255, 255, 255, 0.8); /* Optional: to make the header stand out */
}
.swiperBy1-button-next, .swiperBy1-button-prev,
.swiperBy3-button-next, .swiperBy3-button-prev,
.swiperBy5-button-next, .swiperBy5-button-prev{
  display: flex;;
  position:inherit;
  height: 37px;
  width: 30px;
  margin: 0;
  cursor: pointer;
  display: flex;
  align-items: end;
  justify-content: center;
  background-position: top center;
  background-repeat: no-repeat;
}

.swiper-pagination-bullet-active {
  background-color: #e40a1f;
}

.swiper-pagination-bullet {
  width: 10px;;
  height: 10px;;
}
.swiperBy1-pagination,
.swiperBy3-pagination,
.swiperBy5-pagination {
  float:right;
}

.swiperBy1-button-next,
.swiperBy3-button-next,
.swiperBy5-button-next {
  background-image: url('/wp-content/themes/cbmcompany/assets/img/next-simple.png');
}
.swiperBy1-button-prev,
.swiperBy3-button-prev,
.swiperBy5-button-prev {
  background-image: url('/wp-content/themes/cbmcompany/assets/img/prev-simple.png');
}

.a24-bg-rounded-red .swiperBy1-button-next,
.a24-bg-rounded-red .swiperBy3-button-next,
.a24-bg-rounded-red .swiperBy5-button-next {
  background-image: url('/wp-content/themes/cbmcompany/assets/img/white-arrow-right.png');
}

.a24-bg-rounded-red .swiperBy1-button-prev,
.a24-bg-rounded-red .swiperBy3-button-prev,
.a24-bg-rounded-red .swiperBy5-button-prev {
  background-image: url('/wp-content/themes/cbmcompany/assets/img/white-arrow-left.png');
}

.swiperBy1-button-next[aria-disabled="true"],
.swiperBy3-button-next[aria-disabled="true"],
.swiperBy5-button-next[aria-disabled="true"],
.swiperBy1-button-prev[aria-disabled="true"],
.swiperBy3-button-prev[aria-disabled="true"],
.swiperBy5-button-prev[aria-disabled="true"] {
  opacity: 0.5;
}

.swiperBy1-buttons,
.swiperBy3-buttons ,
.swiperBy5-buttons {
  display: flex !important;
  flex-direction: row;
  width:60px;
  float: right;
  margin-top: 45px;
}

.swiperBy1-button-next::after, 
.swiperBy1-button-prev::after,
.swiperBy3-button-next::after, 
.swiperBy3-button-prev::after, 
.swiperBy5-button-next::after, 
.swiperBy5-button-prev::after {
  content: '';
}

.a24-right-square {
  height: 110%;
  left: 20%;
  position: relative;
  background-color: #f2f2f2;
  top: 0;
  width: 80%;
}


.a24-left-square {
  height: 110%;
  right: 0;
  position: relative;
  background-color: #f2f2f2;
  top: 0;
  width: 80%;
}

.a24-full-square {
  height: 110%;
  right: 0;
  position: relative;
  background-color: #f2f2f2;
  top: 0;
  width: 80%;
}

.a24-half-media {
  position: relative;
}

.a24-left-media,
.a24-right-media {
  display:inline-block;
  max-width:570px;
  position:relative;
  top:-90%;
}

.sa24-big-icon{
  text-align: center;
}

.sa24-big-icon h3 {
  text-align: center;
  font-family: 'Lato', sans-serif;
  font-size: 60px;
  font-weight: 900;
  line-height: 20px;
}

.sa24-big-icon p {
  text-align: center;
  font-family: 'Lato', sans-serif;
  font-size: 15px;
  line-height: 23px;
  font-weight: 700;
}

.sa24-icon {
  text-align: center;
}

.sa24-icon p {
  text-align: center;
  font-family: 'Lato', sans-serif;
  font-size: 24px;
  line-height: 27px;
  font-weight: 700;
}

.nsicon--sa24 {
  width: 110px;
  height: 110px;
  background-position: center;
  background-size: contain;
  margin: 0 auto;
  display: block;
}

.banner {
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  height: 390px;
  margin: 0 auto;
}

/*************************** LINKEDIN **************************/

.right-linkedin {
  align-items: center;
  align-self: flex-end;
  background-color: #e40a1f;
  border-top-left-radius: 50%;
  border-bottom-left-radius: 50%;
  background-position: 50% 50%;
  background-size: cover;
  display: flex;
  height: 85px;
  justify-content: flex-end;
  min-width: 85px;
  padding: 0 18.4px;
  position: fixed;
  right: 0;
  top: 50%;
  z-index: 99999999;
}

.right-linkedin .icon-linkedin {
  width:34px;
  transition: all 0.2s ease-out;
}

.right-linkedin a:hover .icon-linkedin {
  scale: 1.2;
}

.v3-offer .smedia {
  margin-left:15px !important;
}

.text-3columns {
  column-count: 3; 
  column-gap:40px;
}

.text-2columns {
  column-count: 2; 
  column-gap:40px;
}


/*************************** MEDIAS QUERY **************************/

@media (min-width: 991.0001px){
  .a24-md-mt-0 {
    margin-top: 0px !important;
  }
  .a24-md--mt-5 {
    margin-top:-35px;
  }
}

@media (max-width: 1400px){
  .a24-leftgrey-small,
  .a24-rightgrey-small {
    gap: 135px;
  }

  
  .a24-bg-rounded-red {
    margin:15px;
  }
  .a24-bg-rounded-red .a24-right-media{
    max-width: 100%;
    width: 100%;
    display: block;
    position: unset;
  }
}

@media (max-width: 1320px){
  .a24-leftgrey-small,
  .a24-rightgrey-small {
    gap: 65px;
  }
  .a24-rightgrey-small-icont,
  .a24-leftgrey-small-icont {
    max-width: 548px;
  }
}

@media (max-width: 1199px){

  .text-3columns {
    column-count: 2; 
    column-gap:40px;
  }

  .container-full.a24-pillar {
    padding-right: 45px !important;
    padding-left: 15px !important;
    margin-right: auto !important;
    margin-left: auto !important;
    width: 970px !important;
  }

  .a24-leftgrey-small,
  .a24-rightgrey-small {
    gap: 40px;
  }

  .a24-left-media, .a24-right-media {
    max-width: 438px;
  }

  .a24-rightgrey-small-icont,
  .a24-leftgrey-small-icont {
    max-width: 458px;
  }

  .swiperStandardBy1 {
    width:484px;
  }

  .a24-bg-rounded-red .swiperStandardBy1 {
    width:100%;
  }

  .a24-bg-rounded-red {
    padding: 30px 60px;
  }

  .a24-pillar-cont {
    display: block;
  }

  .a24-pillar-second {
    padding-right: 30px;
    padding-left: 30px;
  }

  .a24-pillar-media {
    padding-right: 30px;
  }
}

@media (max-width: 991px){ 
  .a24-xs-mt-0 {
    margin-top: 0px !important;
  }
  .container-full.a24-pillar {
    padding-right: 30px !important;
  }
  .container-full.a24-pillar {
    width: 735px !important;
  }
  .a24-pillar-second {
    padding-right: 20px;
    padding-left: 20px;
  }
  .a24-pillar-media {
    padding-right: 0px;
  }
  .a24-leftgrey-small,
  .a24-rightgrey-small {
    padding-left:0 !important;
    padding-right:0 !important;
  }
  .a24-leftgrey-small,
  .a24-rightgrey-small,
  .a24-leftgrey-small-cont,
  .a24-leftgrey-small-icont,
  .a24-leftgrey-small-cont-media,
  .a24-rightgrey-small-cont,
  .a24-rightgrey-small-cont-media,
  .a24-rightgrey-small-icont {
    display: block !important;
  }

  .a24-right-media, 
  .a24-left-media, 
  .swiperStandardBy1, 
  .a24-leftgrey-small-icont,
  .a24-rightgrey-small-icont {
    max-width: 100% !important;
  }

  .a24-right-media, 
  .a24-left-media, 
  .swiperStandardBy1, 
  .a24-leftgrey-small-cont,
  .a24-leftgrey-small-cont-media,
  .a24-rightgrey-small-cont,
  .a24-rightgrey-small-cont-media {
    width:100% !important;
  }

  .a24-leftgrey-small,
  .a24-rightgrey-small {
    max-width: 720px;
    margin:0 auto;
    padding:0 15px;

  }

  .swiperBy1-buttons,
  .swiperBy3-buttons ,
  .swiperBy5-buttons {
    display: flex !important;
    flex-direction: row;
    width:60px;
    float: right;
    margin-top: 45px;
  }

  .swiperBy1-buttons,
  .swiperBy3-buttons,
  .swiperBy5-buttons,
  .swiperBy1-button-prev,
  .swiperBy1-button-next,
  .swiperBy3-button-prev,
  .swiperBy3-button-next {
    display: none !important;
  }

  .a24 h3 {
    font-size: 27px;
    line-height: 27px;
  }

  .a24 h4 {
    font-size: 21px;
    line-height: 24px;
  }

  .a24-spacer {
    height: 25px;
    display: block;
  }
  
  .a24-small-spacer {
    height: 12px;
    display: block;
  }
  
  .a24-big-spacer {
    height: 50px;
    display: block;
  }

  .a24-full-media-media {
    margin-top:-50px;
  }

  .a24-full-media-cont {
    margin-top: 50px;
    padding-bottom: 50px;
  }

  .a24-detail-offer .cadre {
    padding: 18px 35px;
  }

  .a24-detail-offer .cadre .col-md-4 {
    padding: 5px 0;
  }

  .sa24-big-icon h3 {
    font-size: 40px;
    line-height: 4px;
  }
  .a24 h2 {
    font-size: 30px;
    line-height: 38px;
  }

  .nsicon--sa24 {
    width: 85px;
    height: 85px;
  }

  .right-linkedin {
    height: 50px;
    min-width: 50px;
    padding: 0px 12.4px;
  }

  .sa24-icon p {
    font-size: 17px;
    line-height: 18px;
    margin-bottom: 30px;
  }

  .right-linkedin .icon-linkedin {
    width:20px;
  }

  .banner { 
    height: 250px;
  }


  /*************************** SPACERS **************************/

  .a24--mt-1{
    margin-top: -3px !important;
  }


  .a24-pt-1 {
    padding-top: 3px !important;
  }

  .a24-pb-1 {
    padding-bottom: 3px !important;
  }

  .a24-mt-1 {
    margin-top: 3px !important;
  }

  .a24-mb-1 {
    margin-bottom: 3px !important;
  }

  .a24-py-1 {
    padding-top: 3px !important;
    padding-bottom: 3px !important;
  }

  .a24-my-1 {
    margin-top: 3px !important;
    margin-bottom: 3px !important;
  }

  /****************/

  .a24-pt-2 {
    padding-top: 7px !important;
  }

  .a24-pb-2 {
    padding-bottom: 7px !important;
  }

  .a24-mt-2 {
    margin-top: 7px !important;
  }

  .a24-mb-2 {
    margin-bottom: 7px !important;
  }

  .a24-py-2 {
    padding-top: 7px !important;
    padding-bottom: 7px !important;
  }

  .a24-my-2 {
    margin-top: 7px !important;
    margin-bottom: 7px !important;
  }

  /****************/

  .a24-pt-3 {
    padding-top: 12px !important;
  }

  .a24-pb-3 {
    padding-bottom: 12px !important;
  }

  .a24-mt-3 {
    margin-top: 12px !important;
  }

  .a24-mb-3 {
    margin-bottom: 12px !important;
  }

  .a24-py-3 {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
  }

  .a24-my-3 {
    margin-top: 12px !important;
    margin-bottom: 12px !important;
  }

  /****************/

  .a24--mt-5 {
    margin-top:-17px !important;
  }

  .a24-pt-5 {
    padding-top: 17px !important;
  }

  .a24-pb-5 {
    padding-bottom: 17px !important;
  }

  .a24-mt-5 {
    margin-top: 17px !important;
  }

  .a24-mb-5 {
    margin-bottom: 17px !important;
  }

  .a24-py-5 {
    padding-top: 17px !important;
    padding-bottom: 17px !important;
  }

  .a24-my-5 {
    margin-top: 17px !important;
    margin-bottom: 17px !important;
  }

  .a24-px-5 {
    padding-left: 17px !important;
    padding-right: 17px !important;
  }
  /*********************************************************/

  .a24-testimony {
    padding: 5px 10px;
    gap: 20px;
  }

  .a24-testimony img {
    display: none;;
  }

  .a24-bg-rounded-red {
    padding: 20px;
  }

  .a24-bg-rounded-red h2 {
    margin-top:0px;
    padding-top:0px;
  }
}

@media (max-width: 764px){
  .text-3columns,
  .text-2columns {
    column-count: 1; 
    column-gap:0px;
  }

  .v3-offer .smedia {
    margin-left:0px !important;
  }
  .container-full.a24-pillar {
    width: 100% !important;
  }

  .a24-pillar-cont {
    padding-bottom: 0px;
  }

  .a24-pillar-icont,
  .a24-pillar-second,
  .a24-pillar-first {
    display: block;
  }

  .a24-pillar-second {
    margin-top:20px;
  }

  .a24-pillar {
    padding-bottom: 60px;
  }

  .a24-pillar,
  .a24-pillar-firstchild {
    background: none !important;
  }
  h3.a24-cartridge {
    padding: 5px 16px;
  }
}