input[type=text]::-webkit-input-placeholder { /* Safari, Chrome(, Opera?) */
 color:gray;
 font-style:italic;
}
input[type=text]:-moz-placeholder { /* Firefox 18- */
 color:gray;
 font-style:italic;
}
input[type=text]::-moz-placeholder { /* Firefox 19+ */
 color:gray;
 font-style:italic;
}
input[type=text]:-ms-input-placeholder { /* IE (10+?) */
 color:gray;
 font-style:italic;
}



/* Hide the native radio button */
input[type="checkbox"] {
    display: none;
}

/* Give format to label text */
input[type="checkbox"] + label {
    color: black;
    font-family: Arial, sans-serif;
    font-size: 1.3em;
    font-weight:100;
    margin-top:2px;
}

/* Give format to unchecked radio button by formatting the empty span.
 * Here, we make it black and circular. */
input[type="checkbox"] + label span {
    background-color: #cecece;
    display: inline-block;
    width: 30px;
    height: 30px;
    margin:4px 10px 5px 0px;
    vertical-align: middle;
    cursor:pointer;
    -moz-border-radius: 10%;
    border-radius: 10%;
}

/* When the radio is checked, change just the color
 * (we could add a border, shadow, etc) */
input[type="checkbox"]:checked + label span{
     background-color: #009DB5;
}

/* Optional: Animations for changing state */
input[type="checkbox"] + label span,
input[type="checkbox"]:checked + label span {
  -webkit-transition:background-color 0.2s linear;
  -o-transition:background-color 0.2s linear;
  -moz-transition:background-color 0.2s linear;
  transition:background-color 0.2s linear;
}






.column-news .column-img, .column-events .column-img {display:flex;overflow:hidden;max-width: 349px;margin: 0 auto;}
.column-news .column-img img, .column-events .column-img img {max-height: 214px; object-fit: cover;}

.media-item_image .media-item-overlay-icon:after {
  content: '\f002';
  margin-left: 0;
}
.media-library .media-item {
    background-color: #f2f2f2;
    max-height: 240px;
    overflow: hidden;
}
.validate-form .error.global, .validate-form .success {
    background: #E0999D;
    border:1px red solid;
    color: #a00000;
    width: 100%;
    padding: 22px 25px;
    display: none;
}
.validate-form .success {
    border:1px #039FDC solid;
    background: #C4E4F3;
    color: #039FDC;
    display: block;
    font-family: "Montserrat",sans-serif;
    font-size: 1.1em;
}
.validate-form input.error, .validate-form select.error, .validate-form textarea.error, .error .jcf-file .jcf-fake-input {
    border: 1px #a00000 solid;
    color: #a00000;
}
.validate-form label.error {color:#A00000; font-weight:normal; font-style:italic; padding-top:8px}
.sucess-box {display:block;}
.modal-backdrop.fade.show {opacity: 0.5;}
.ekko-lightbox-container > div.ekko-lightbox-item {height: 100%;}
.ekko-lightbox-item iframe {width: 100%;height: 100%;}

.offer-block .jscroll-added {margin-top: -2px;}
.ui-autocomplete-loading { background: white url("/images/ui-anim_basic_16x16.gif") no-repeat scroll right center !important; }
.jcf-select-drop .jcf-list-content li:first-child {display:block;}

.no-touch .button-more-holder button:hover {
    background: #002991 !important;
    color: #fff !important;
}

.button-more-holder button:active, .button-more-holder button:focus {
    color: #312783;
}

.column-press .column-block {
    min-height: 213px;
}

.marg-press {
    margin-bottom: 70px;
}

.hero-banner .hero-banner-text {display:none;}

/* Ship locator */
#ship-locator {padding-bottom: 30px;}
#ship-locator #map { width: 100%; height: 500px; }
#ship-locator .map_infobulle { text-align: center; }
#ship-locator .map_infobulle img { text-align: center; max-width: 116px; }
#ship-locator .map_infobulle p {margin: 2px 0;}
#ship-locator .map_infobulle .boat { font-weight: 500; font-size: 17px; }
#ship-locator .map_infobulle .btn { min-width: 116px; font-size: 12px; margin-top: 5px;}
#hideroute { display: none; }
#map { max-width: 1025px;}

#leadership h3{
    color: #00a0e6;
    font-size: 3rem;
    margin-bottom: 70px
}
@media screen and (max-width: 767px){
    #leadership h3{
        margin-bottom: 40px
    }
}
.leadership--list {
    display: flex;
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    width: 100%;
}
.leadership--list:not(.listCounter-1) {
    margin: 0 auto;
    max-width: 804px;
}
.leadership--list-item {
    text-align: center
}
@media screen and (min-width: 991px){
    .leadership--list-item strong,
    .leadership--list-item span {
        width:135%
    }
}
@media screen and (min-width: 768px){
    .col-sm-6.leadership--list-item:nth-child(odd) {
        text-align: left;
    }
    .col-sm-6.leadership--list-item:nth-child(even) {
        text-align: right;
    }
    .col-sm-4.leadership--list-item:nth-child(3n+1) {
        text-align: left;
    }
    .col-sm-4.leadership--list-item:nth-child(3n+3) {
        text-align: right;
    }
    .col-sm-3.leadership--list-item:nth-child(4n+1) {
        text-align: left;
    }
    .col-sm-3.leadership--list-item:nth-child(4n+4) {
        text-align: right;
    }
}
.leadership--list-item > div{
    display: inline-block;
    max-width: 170px;
    text-align: center;
    width: 100%;
}

/* Intranet Blocks */

/* Block presentation */
.content-box-head {
  background: #312783;
  color: #fff;
  padding: 20px;
  margin-bottom: 28px;
  display: flex;
}

.content-box-head h2 {
  color: #c2bfda;
  margin-bottom: 15px;
}

.content-box-head p {
  color: #fff;
  margin: 0 0 7px;
  font-size: 16px;
  line-height: 1.5;
}

.content-box-head-info {
  width: 30%;
  flex-shrink: 0;
  text-align: center;
  color: #fff;
  font-size: 16px;
  line-height: 1.125;
  padding: 2px 22px 0 0;
  max-width: 270px;
}

.content-box-head-info strong {
  display: block;
}

.content-box-head-description {
  flex-grow: 1;
}

.content-box-head-description.no-title {
    display:flex;
    margin-right: 50px;
}
.content-box-head-description.no-title p {text-align: justify; margin:auto;}

.content-box-head-photo {
  border: 4px solid #fff;
  width: 114px;
  border-radius: 50%;
  margin: 0 auto 10px;
  overflow: hidden;
  background: #fff;
}

.content-box-head-photo img {
  width: 100%;
}

/* Main links */
.content-box {
  background: #fff;
  padding: 12px;
  margin-bottom: 28px;
  display: block;
  font-family: "Lato", Helvetica, Arial, sans-serif;
}
.links-list {
  margin: 0;
  padding: 11px 0 0;
  list-style: none;
  font-size: 16px;
  line-height: 1.2;
  color: #312783;
}

.links-list li:before {
  content: '>';
  margin-right: 5px;
  text-decoration: none !important;
}

.links-list li:not(:last-child) {
  margin-bottom: 7px;
}

.links-list a {
  color: #312783;
}
/* H2 special */
.h2-decor {
  color: #312783;
  font-size: 22px;
  line-height: 1;
  margin: 0 0 15px;
  padding: 0 0 11px;
  font-weight: 300;
  position: relative;
}

.h2-decor:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 63px;
  height: 2px;
  background: #312783;
  content: '';
}

/* Content box */
.content-box p {
  margin: 0;
}

.content-box h2 + h3,
.content-box h2 + .h3,
.content-box .h2 + h3,
.content-box .h2 + .h3 {
  margin-top: -5px;
}

.content-box h2 + .content-box-subtitle,
.content-box .h2 + .content-box-subtitle {
  margin-top: -5px;
}

.content-box h3 {
    color: #312783;
    font-size: 16px;
    line-height: 1.2;
    font-weight: 700;
    margin: 0 0 7px;
}

.content-box-subtitle {
  color: #818181;
  display: block;
  margin-bottom: 15px;
  font-size: 16px;
  line-height: 1.2;
  font-weight: normal;
}

.content-box-post {
  margin-bottom: 7px;
}

@media (max-width: 1199px) {
  .content-box-img {
    max-width: 50%;
  }
}

@media (max-width: 991px) {
  .content-box {
    margin-bottom: 14px;
  }
}

.content-box-twocolumns {
  display: flex;
  padding-left: 6px;
  padding-right: 6px;
}

.content-box-twocolumns > * {
  padding: 0 6px;
}

.content-box-img {
  flex-shrink: 0;
}

.content-box-text {
  flex-grow: 1;
}
.content-box-text p {
    font-family: "Lato", Helvetica, Arial, sans-serif;
    font-size: 14px;
    line-height: 1.2;
    color: #000;
}

.content-box .btn {
  margin-top: 19px;
}

.content-box p {
  margin: 0;
}

.content-box .btn {
    min-width: auto;
    display: inline-block;
    margin-bottom: 0;
    font-weight: normal;
    text-align: center;
    vertical-align: middle;
    touch-action: manipulation;
    cursor: pointer;
    background-image: none;
    border: 1px solid transparent;
    white-space: nowrap;
    padding: 6px 12px;
    font-size: 14px;
    line-height: 1.2;
    border-radius: 4px;
    -webkit-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
} 

.content-box .btn.btn-default {
    color: #fff;
    background: #312783;
    font-weight: 700;
    font-size: 8px;
    line-height: 1.2;
    border-radius: 5px;
    padding: 5px 9px 4px;
    border: none;
}

@media (max-width: 767px) {
  .content-box-twocolumns {
    flex-direction: column;
  }
  .content-box-twocolumns .content-box-img {
    max-width: none;
    margin-bottom: 12px;
    order: 1;
  }
  .content-box-twocolumns .content-box-img img {
    width: 100%;
  }
  .content-box-twocolumns .content-box-text {
    order: 2;
  }
  .content-box-head {
    flex-direction: column;
  }
  .content-box-head-info {
    width: 100%;
    margin-bottom: 20px;
    max-width: none;
  }
}

/* Projects team list */
.projects-team-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.projects-team-list > li:not(:last-child) {
  margin-bottom: 18px;
}

.projects-team-list h3 {
  margin-bottom: 0;
  font-size: 15px;
  color: #312783;
  line-height: 1.2;
  font-weight: 700;
}

.bullet-list {
  color: #000;
  padding: 0;
  margin: 0;
  list-style: none;
}

.bullet-list li {
  position: relative;
  padding-left: 18px;
  font-size: 14px;
  font-family: "Lato", Helvetica, Arial, sans-serif;
}

.bullet-list li:after {
  width: 10px;
  height: 1px;
  background: #000;
  position: absolute;
  top: 8px;
  left: 0;
  content: '';
}

.bullet-list li a {
    /*color: #312783;*/
    text-decoration: none;
}

.bullet-list-gray {
  color: #818181;
}

.bullet-list-gray li:after {
  background: #a8a8a8;
}

.projects-list {
  padding: 0;
  margin: 0;
  list-style: none;
}

.projects-list > li:not(:last-child) {
  border-bottom: 1px solid #000;
  padding-bottom: 11px;
  margin-bottom: 6px;
}

.projects-list > li h3 {
  color: #000;
  font-size: 16px;
  line-height: 1.2;
  font-family: "Lato", Helvetica, Arial, sans-serif;
  font-weight: 700;
}

.projects-list-box {
  display: flex;
  margin: 0 -6px;
}

.projects-list-img {
  width: 48.7%;
  padding: 2px 6px 0;
}

.projects-list-img img {
  width: 100%;
}

.projects-list-info {
  flex-grow: 1;
  padding: 0 6px;
}

.projects-list-info h4 {
    font-size: 14px;
    font-family: "Lato", Helvetica, Arial, sans-serif;
    line-height: 1.2;
    margin: 0;
    font-weight: 700;
}

@media (max-width: 1199px) {
  .projects-list-box {
    flex-direction: column;
  }
  .projects-list-img {
    width: 100%;
    margin-bottom: 10px;
  }
}

.ressource-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.ressource-list > li:not(:last-child) {
  margin-bottom: 10px;
  padding-bottom: 11px;
  border-bottom: 1px solid #818181;
}

.ressource-list > li h3 {
  color: #000;
}

.intra h2.text-uppercase {
    font-size: 18px;
    font-weight: 700;
    margin: 0 0 5px;
    color: #312783;
    text-transform: uppercase;
    padding-bottom: 0;
}
.intra h2.text-uppercase:after {display:none;}

.news-box {
  color: #000;
  text-decoration: none;
}

.news-box:hover {
  text-decoration: none;
  color: #000;
}

.news-box:hover .news-box-img img {
  transform: scale(1.05);
}

.news-box-img {
  margin-bottom: 10px;
  overflow: hidden;
}

.news-box-img img {
  width: 100%;
  transition: transform 0.3s linear;
  transform: scale(1);
}

.intra p {
    font-family: "Lato", Helvetica, Arial, sans-serif;
    font-size: 14px;
    line-height: 1.2;
    color: #000;
}

/* Job list (bloc rh) */
.jobs-list {
  margin: 0;
  padding: 0;
  list-style: none;
}

.jobs-list li {
  border-top: 1px solid #312783;
  display: flex;
  padding-top: 5px;
}

.jobs-list li:not(:last-child) {
  padding-bottom: 7px;
}

.jobs-list li > *:not(:last-child) {
  padding-right: 20px;
}

.jobs-list-title {
  width: 33.6%;
}

.jobs-list-text {
  width: 50%;
  padding-top: 5px;
}

.jobs-list-text p {
  line-height: 1;
}

.jobs-list-subtitle {
  font-size: 15px;
  display: block;
  font-weight: normal;
}

.jobs-list-btn {
  display: flex;
  align-items: flex-end;
  justify-content: flex-end;
  flex-grow: 1;
}

@media (max-width: 991px) {
  .jobs-list li {
    flex-direction: column;
  }
  .jobs-list li > *:not(:last-child) {
    padding-right: 0;
  }
  .jobs-list-title, .jobs-list-text {
    width: 100%;
  }
}

/* Cookie banner button */
.cc-compliance .cc-btn {border:1px #FFF solid !important; text-decoration:none;}
