:root{
    --darkblue: #012D43;
    --rosso: #7B221D;
    --rosso-dark: #7B221D;
    --yellow: #f5bf23;
    --lightgreen: #008C3C;
    --lightgrey: #;
    --grey: #4C4C4C;
    --bs-body-bg: #f1f1f1;
}
.rubik {
  font-family: "Rubik", sans-serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.coda-regular {
  font-family: "Coda", system-ui;
  font-weight: 500;
  font-style: normal;
}
.coda-extrabold {
  font-family: "Coda", system-ui;
  font-weight: 800;
  font-style: normal;
}
@font-face {
  font-family: 'radj-light';
  src: url('/fonts/rajdhani.light.ttf') format('truetype');
  font-weight: light;
  font-style: light;
}
@font-face {
  font-family: 'radj-medium';
  src: url('/fonts/rajdhani.medium.ttf') format('truetype');
  font-weight: medium;
  font-style: medium;
}
@font-face {
  font-family: 'radj-bold';
  src: url('/fonts/rajdhani.bold.ttf') format('truetype');
  font-weight: bold;
  font-style: bold;
}
@font-face {
  font-family: 'radj-semibold';
  src: url('/fonts/rajdhani.semibold.ttf') format('truetype');
  font-weight: semibold;
  font-style: semibold;
}
.radj-light{
    font-family: 'radj-light';
}
.radj-bold{
    font-family: 'radj-bold';
}
.radj-semibold{
    font-family: 'radj-semibold';
}
.radj-medium{
    font-family: 'radj-medium';
}

body.bg-light-grey{
    background-color: #f4f4f4 !important;
}
.text-clamp{
    font-size: clamp(11px, 1.1vw, 14px);
}
.text-blue{
    color: var(--rosso);
}
.text-grey{
    color: var(--grey) !important;
}
.text-dark-green{
    color: var(--darkblue) !important;
}
.text-rosso{
    color: var(--rosso) !important;
}
.text-light-green{
    color: var(--lightgreen) !important;
}
.text-white{
    color: white !important;
}
.text-yellow{
    color: var(--yellow) !important;
}
.text-green{
    color: var(--lightgreen);
}
.text-shadow{
    text-shadow: 1px 1px 4px black;
}
.text-breakall{
    word-break: break-all;
}
.bg-dark-green{
    background-color:var(--darkblue) !important;
}
.bg-rosso{
    background-color: var(--rosso) !important;
}
.bg-light-green{
    background-color: var(--lightgreen) !important;
}
.bg-light-grey{
    background-color: #f4f4f4 !important;
}
.bg-black{
    background-color: black !important;
}
.bg-green{
    background-color: var(--lightgreen) !important;
}
.link-social{
    color: var(--darkblue);
    text-decoration: none;
}
.link-social:hover{
    color: var(--rosso);
    text-decoration: underline;
}
.link-simple{
    cursor: pointer;
    color: var(--darkblue);
}
.link-simple:hover{
    cursor: pointer;
    color: var(--rosso);
}
.ls-xs {
    letter-spacing: -.025em;
}
.ls-xxs {
    letter-spacing: -.05em;
}
.lh-reg {
    line-height: 1em !important;
}
.lh-xs {
    line-height: .85em;
}
.nav-pills .nav-link{
    color: var(--darkblue);
}
.nav-pills .nav-link:hover{
    color: var(--rosso);
}
.nav-pills .nav-link.active:hover{
    color: white !important;
    background-color: var(--rosso) !important;
}
.nav-pills .nav-link.active, .nav-pills .show>.nav-link {
    color: var(--rosso) !important;
    background-color: white !important;
    border-radius: 50px;
    transition: .5s;
}
.nav-pills .nav-link:hover .hover-underline-animation::after, a:hover .hover-underline-animation::after {
    transform: scaleX(1);
    transform-origin: bottom left;
}
.hover-underline-animation {
    display: inline-block;
    position: relative;
}
.hover-underline-animation::after {
    content: '';
    position: absolute;
    width: 100%;
    transform: scaleX(0);
    height: 2px;
    bottom: -8px;
    left: 0;
    background-color: var(--rosso);
    transform-origin: bottom right;
    transition: transform 0.25s ease-out;
}
a.link-unstyled {
    color: inherit;
    text-decoration: none;
}
.active a{
    color: var(--rosso) !important;
    font-weight: 500;
}
.mt-6{
    margin-top: 80px !important;
}
.mt-8{
    margin-top: 120px !important;
}
.btn-right{
    position: absolute;
    right: 10px;
    top: 12px;
}
.btn.btn-primary{
    color: white;
    background-color: var(--rosso);
    border-color: var(--rosso);
    outline-color: var(--rosso);
}
.btn.btn-primary:hover{
    color: white;
    background-color: var(--rosso);
    border-color: var(--rosso);
    outline-color: var(--rosso);
}
.btn.btn-primary:hover i{
    transform: translate(10px);
    transition: transform 0.25s ease-out;
}
.btn.btn-rosso{
    color: white !important;
    background-color: var(--rosso) !important;
    transition: .5s;
}
.btn.btn-rosso:hover{
    color: var(--rosso) !important;
    background-color: white; !important;
    outline: 2px solid var(--rosso);
}
.btn.btn-white{
    color: white !important;
    background-color: transparent; !important;
    transition: .5s;
}
.btn.btn-white:hover{
    color: white !important;
    background-color: transparent !important;
    text-decoration: underline;
}

.btn.btn-yellow{
    color: white !important;
    background-color: var(--yellow) !important;
    transition: .5s;
}
.btn.btn-yellow:hover{
    color: var(--yellow) !important;
    background-color: transparent !important;
    outline: 2px solid var(--yellow) !important;
}
.btn.btn-yellow:hover i{
    transform: translate(10px);
    transition: transform 0.25s ease-out;
}


.btn.btn-more{
    color: white !important;
    background-color: var(--rosso) !important;
    transition: .5s;
}
.btn.btn-more:hover{
    color: var(--rosso) !important;
    background-color: transparent !important;
    outline: 2px solid var(--rosso) !important;
}
.btn.btn-more:hover i{
    transform: translate(10px);
    transition: transform 0.25s ease-out;
}
.btn.btn-more.btn-outline{
    color: var(--lightgreen) !important;
    background-color: transparent !important;
    border: 1px solid var(--lightgreen);
    transition: .5s;
}
.btn.btn-more.btn-outline:hover{
    color: var(--darkblue) !important;
    background-color: var(--lightgreen) !important;
    border: 1px solid var(--lightgreen) !important;
}
.btn.btn-dark-green.btn-outline{
    color: var(--darkblue) !important;
    background-color: transparent !important;
    border: 1px solid var(--darkblue);
    transition: .5s;
}
.btn.btn-dark-green.btn-outline:hover{
    color: white !important;
    background-color: var(--darkblue) !important;
    border: 1px solid var(--darkblue) !important;
}
.btn.btn-dark-green{
    color: var(--rosso) !important;
    background-color: var(--darkblue) !important;
    border: 1px solid var(--darkblue);
    transition: .5s;
}
.btn.btn-dark-green:hover{
    color: var(--darkblue) !important;
    background-color: var(--rosso) !important;
    border: 1px solid var(--rosso) !important;
}
.btn-default{
    background-color: #eee !important;
    color: dimgray !important;
}
.inline{
    display: inline-block !important;
}
.grid{
    display: grid;
    gap: 1rem;
    grid-template-columns : repeat(auto-fit, minmax(350px, 1fr));
}
.grid > .d-square{
    min-height: 400px;
}
.grid-layout{

}
.grid-layout-item{
    transform: translateY(20px);
    transition: opacity 0.6s ease, transform 0.6s ease;
    transition-delay: var(--delay);
}
.grid-layout-item.show {
    opacity: 1;
    transform: translateY(0);
}
.grid-latest-jobs {
    grid-row: span 2;
}
.clip-svg{
    clip-path: url(#mask-shape);
    -webkit-clip-path: url(#mask-shape);
    width: 40%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
}
.drop-shadow{
    filter: drop-shadow(-1px 6px 3px rgba(50, 50, 0, 0.25));
}
.fs-8{
    font-size: 0.85em;
}
.p-45{
    padding: 2rem !important;
}
.img-container .img-preview {
    object-fit: cover;
    object-position: 0px 0px;
    overflow: hidden;
}
.img-container .img-banner {
    height: 100%;
    border-radius: 7px;
}
.img-container .img-banner {
    width: 100%;
}
.img-banner-center {
    object-fit: cover !important;
    object-position: center center !important;
}
.img-banner {
    object-fit: cover;
    object-position: 0px 0px;
}
.img-container, .img-preview {
    overflow: hidden;
    text-align: center;
    /* width: 100%; */
}
.img-container-banner {
    height: 400px;
    border-radius: 16px;
    /* background: url(../img/logo_1800x600.png); */
    background-repeat: no-repeat;
    background-color: white;
}
.b-all {
    border: 1px solid #e7eaec;
}
.img-container, .img-shop {
    overflow: hidden;
    text-align: center;
    /* width: 100%; */
}
.img-container, .img-preview {
    overflow: hidden;
    text-align: center;
    /* width: 100%; */
}
.img-container-logo {
    position: absolute;
    left: 15%;
    bottom: 50%;
    z-index: 999;
    width: 60%;
    max-width: 220px;
    /* line-height: 150px; */
    /* background: url(../img/logo_175x54.png); */
}
.list-jobs > li{
    border: 1px solid #bbb;
    padding: 10px 14px;
    border-radius: 7px;
    margin: 1px 1px 5px 1px;
    transition: all .3s ease-in-out;
    min-height: 80px;
}
.list-jobs > li a{
    text-decoration: none;
}
.list-jobs > li:hover{
    color: white !important;
    outline: 1px solid var(--rosso);
    border-color: var(--rosso);
/*    transform: scale(1.02);*/
}
.list-jobs > li:hover h6{
    color: var(--rosso) !important;
}
.list-jobs > li .rounded-pill{
    transition: transform .3s ease-in-out;
    opacity: 0;
}
.list-jobs > li:hover .rounded-pill{
    transform: translateX(10px);
    opacity: 1;
}

.max-h-400{
    max-height: 400px;
}
.icon-player{
    position: absolute;
    top: 50%;
    width: 100%;
}
.list-sm > li{
    margin-bottom: .5em;
}
.list-md > li{
    margin-bottom: 1em;
}
.fa-15x{
    font-size: 1.5em;
}
.fa-15x + span{
    vertical-align: text-bottom;
}
.portrait-name{
    position: absolute;
    right: 0px;
    bottom: 0px;
/*    background-color: #c00c1da1;*/
    width: 100%;
    padding: 15px 0px 10px 20px;
}
.timeline {
    position: relative;
}
.timeline>li::before {
    content: '';
    position: absolute;
    width: 3px;
    background-color: var(--rosso);
    top: 0;
    bottom: 0;
    left: 6px;
}
.timeline>li {
    counter-increment: item;
    padding: 6px 0px 10px 40px;
    margin-left: 0px;
    position: relative;
    line-height: 1.15em;
    list-style: none;
}
.timeline>li::after {
    text-align: center;
    padding-top: 8px;
    z-index: 10;
    content: counter(item);
    position: absolute;
    width: 30px;
    height: 30px;
    border: none;
    background-color: var(--rosso);
    border-radius: 50%;
    top: 0;
    left: -38px;
    margin-left: 30px;
}
.timeline>li:nth-last-child(1)::before{
    width: 0px;
}
.clippy{
    position: absolute;
    top: -999;
    left: -999;
}
.badge-outline {
    border: 1px solid var(--rosso) !important;
    color: var(--rosso) !important;
    border-radius: 25px !important;
    margin-right: 3px;
}
.portrait{
    min-height: 250px;
}
.benefice{
    min-height: 250px;
    max-height: 275px;
}
.shadow-light{
    box-shadow: rgba(0, 0, 0, 0.1) 0px 10px 15px -3px, rgba(0, 0, 0, 0.05) 0px 4px 6px -2px;
}
.job-desc{
    padding-right: 10%;
}
.blur{
    background: rgba(255, 255, 255, 0.2); /* Fond semi-transparent */
    backdrop-filter: blur(3px);          /* Flou d'arrière-plan */
    -webkit-backdrop-filter: blur(3px);  /* Support Safari */
}
@media only screen and (max-width: 768px) {
    .block-infos{
        position: relative !important;
        max-width: 100% !important;
        aspect-ratio: auto !important;
    }
    .job-desc{
        padding-right: 0px;
    }
}

.scroll {
    overflow-y: scroll; /* scroll activé */
    scrollbar-width: none; /* Firefox */
    -ms-overflow-style: none; /* Internet Explorer 10+ */
}
.scroll::-webkit-scrollbar {
    display: none; /* Chrome, Safari, Edge */
}

.block-infos {
    background-color: var(--rosso);
    aspect-ratio: 1;
    border-radius: 30px;
    position: absolute;
    right: 10px;
    bottom: 0px;
    max-width: 400px;
}
.block-infos .item {
    width: 27.5%;
    display: flex;
    flex-direction: column;
    flex-grow: 1;
    gap: .85em;
}
.border-special{
    border: .5px solid white;
    opacity: .2;
}
.footer{
    background: url('img/biotech-footer.svg');
    background-size: 100%;
}
.pos-abs{
    position: absolute;
    left: 5px;
    top: 5px;
    width: -webkit-fill-available;    
}
.hero {
    position: absolute;
    top: 250px;
    left: 50px;
    width: -webkit-fill-available;
    margin-right: 50px;
}
.fs-0{
    font-size: 62px;
}
.pill {
    border: 1px solid silver;
    color: silver;
    padding: 2px 10px;
    border-radius: 25px;
}
.surrounded {
    outline: 4px solid var(--darkblue);
    padding: 0px 14px 2px 14px;
    border-radius: 50px;
    line-height: 60px;
    display: inline-block;
}
.fa-rotate-315{
    transform: rotate(315deg);
    font-size: 67px;
    vertical-align: bottom;
    margin-bottom: 4px;
}
input{
    background-color: #f4f4f4;
    border: 1px solid #ededed;
    border-radius: 30px;
}
input::placeholder{
    font-family: 'poppins-regular', helvetica, arial;
}
.vert-bot{
    vertical-align: bottom;
}
.no-border-right{
    border-top-right-radius: 0px !important;
    border-top-left-radius: 1rem !important;
    border-bottom-right-radius: 0px !important;
    border-bottom-left-radius: 1rem !important;
}
.no-border-bottom{
    border-top-left-radius: 1rem !important;
    border-top-right-radius: 1rem !important;
    border-bottom-left-radius: 0px !important;
    border-bottom-right-radius: 0px !important;
}
.item-square {
    background-color: #7ef0ad;
    height: 15vh;
    width: 15vh;
    border-radius: 20px;
    display: flex;
    flex-direction: column;
    flex-wrap: nowrap;
    justify-content: flex-end;
    padding: 12px;
    align-content: flex-start;
}
.item-square h5{
    margin-bottom: 0px;
    font-family: poppins-regular, helvetica, arial;
    font-size: 1.1rem;
}
.item-square a {
    display: inline-flex;
    justify-content: flex-end;
    flex-direction: column;
}
.custom-video-player{
    position: relative;
    display: inline-block;
    overflow: hidden;
}

.modal-dialog {
/*      max-width: 800px;*/
      margin: 30px auto;
}
.modal-body {
  position:relative;
  padding:0px;
}
.close {
  position:absolute;
  right:0px;
  top:0;
  z-index:999;
  font-size:1.5rem;
  font-weight: normal;
  color:#ddd;
  opacity:1;
}


/* MODAL APLLY */

.modal.fade .modal-dialog {
    transition: transform .3s ease-out;
    transform: translate(0%, 25%);
}
.modal{
    z-index: 99999;
}
.modal-apply .modal-content{
  border-radius : 15px;
}
.modal-apply .modal-header{
  display: flex;
}
.inmodal.modal-apply .modal-header {
    padding: 15px 15px !important;
    text-align: center;
}
.modal-apply .apply_infos {
    display: flex;
    flex-grow: 1;
    width: 55%;
    max-width: 60%;
    flex-wrap: wrap;
    justify-content: space-evenly;
    align-content: flex-start;
    text-align: left;
    flex-direction: column;
    margin-left: 5%;
}
.modal-apply .company_logo {
    display: flex;
    flex-grow: 1;
    width: 30%;
    max-width: 30%;
    flex-wrap: nowrap;
    justify-content: space-around;
    align-content: space-between;
    flex-direction: row;
    align-items: center;
    padding: 15px 10px;
    border-radius: 10px;
    border: 1px solid #ccc;
    background-color: white;
    max-height: 90px;
}
.modal-apply .company_logo img{
    object-fit: scale-down;
    object-position: center center;
    max-height: 88px;
    background-color: white;
    width: -webkit-fill-available;
}
.modal-apply .form .control-label {
    font-size: 0.85rem;
    color: var(--darkblue);
    margin-bottom: 0.1rem;
    text-align: left;
    font-family: Poppins, Helvetica Neue, Helvetica, -apple-system, BlinkMacSystemFont, Segoe UI, Helvetica Neue, Arial, sans-serif;
}
.modal-apply .form .form-control {
    border-color: silver;
    background-color: white;
    border-radius: 7px;
    padding: 6px 12px;
    font-size: 1.1em;
    height: 45px;
    color: #333;
}
.modal-apply .form .form-control:focus{
    box-shadow: none;
}
.modal-apply .mandatory-apply{
    color: #999;
}
.modal-apply .mandatory-apply::after{
    content:"*";
    color: var(--rosso);
}
.modal-apply .help-block {
    display: block;
    margin-top: 5px;
    margin-bottom: 10px;
    color: #ed5565;
    font-size: 0.9em;
}
.modal-apply .drop-box {
    background: #ffffff;
    border: 1px solid #c0c0c0;
    border-radius: 7px;
    text-align: left;
    padding: 11px 12px;
    cursor: pointer;
    height: 45px;
    color: #bbb;
    display: inline-block;
    width: 100%;
    position: relative;
}
.modal-apply .drop-box .file-name{
    color: #333 !important;
    text-overflow: ellipsis;
    width: 80%;
    overflow: hidden;
    white-space: nowrap;
    display: block;
}
.modal-apply .btn-apply {
/*    height: 80px;*/
    font-size: 1.5em;
    font-weight: 600;
    color: white;
    border-radius: 7px;
    background-color: var(--rosso);
    white-space: normal;
    cursor: pointer;
}
.modal-apply .btn-apply:hover {
    background-color: var(--rosso-dark);
    cursor: pointer;
    transition: 0.5s;
}
.modal-apply .drop-box-upload:after {
    content: "\f093";
    font: normal normal normal 14px/1 FontAwesome;
    font-size: 1.2em;
    text-rendering: auto;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    transform: translate(0, 0);
    text-align: center;
    float: right;
    background-color: #e7eaec;
    color: #999;
    border-radius: 4px;
    padding: 12px 1px;
    margin-top: -8px;
    margin-right: -9px;
    height: 37px;
    width: 12%;
}
.modal-apply .remove-file {
    position: absolute;
    top: 3px;
    right: 2px;
    width: 12%;
}
.modal-apply ::placeholder { /* Chrome, Firefox, Opera, Safari 10.1+ */
  color: #bbb;
  opacity: 1; /* Firefox */
}
.modal-apply :-ms-input-placeholder { /* Internet Explorer 10-11 */
  color: #bbb;
}
.modal-apply ::-ms-input-placeholder { /* Microsoft Edge */
  color: #bbb;
}
.modal-apply .action_link{
    color: var(--rosso);
}
.modal-apply .action_link:hover{
    color: var(--rosso);
    text-decoration: underline;
    transition: 0.3s;
}
.modal-apply .drop-box:hover {
    border-color: var(--rosso);
    outline: 1px solid var(--rosso);
}
.modal-apply ::selection{
    color: white !important;
    background-color: var(--rosso);
}
.modal-apply .form-control:focus {
    border-color: var(--rosso) !important;
    outline: 1px solid var(--rosso);
}
.d-flex-apply {
    display: flex;
    flex-direction: column;
    flex-wrap: wrap;
    text-align: left;
}
.d-flex-contact {
    display: flex;
    flex-direction: row;
    flex-wrap: nowrap;
    align-content: center;
    justify-content: space-between;
    align-items: center;
}
.d-flex-contact .col-1{
    flex: 0 1 auto;
}
.d-flex-contact .col-2{
    flex: 0 1 auto;
    text-overflow: ellipsis;
    overflow: hidden;
}
.ibox-apply {
    padding: 25px 25px;
    border-radius: 20px;
    box-shadow: 0px 0px 25px silver;
    margin-bottom: 25px;
    background-color: #f3f3f4;
}
.text-apply{
    color: var(--rosso) !important;
}
.modal-apply .text-overflow {
    text-overflow: ellipsis;
    overflow: hidden;
    width: 89%;
    display: inline-block;
}
.modal-open .modal-backdrop.fade:not(.show) {
    opacity: 45% !important;
}
.fade:not(.show){
    opacity: unset;
}
.form-pswd-checked{
    float:right;
    margin-top: -34px;
    margin-right:32px;
    padding: 0px 10px;
    width: 45px;
}
.justify-content-center{
    justify-content: center !important;
}
.form-check-input:checked {
    background-color: var(--rosso);
    border-color: var(--rosso);
}
.checkbox-grey {
    background-color: #e3e3e3;
    border-radius: 25px;
}
.impotant-note{
    color: var(--rosso) !important;
    background-color: #d5dcec;
    display: block;
    padding: 7px 12px;
    border-radius: 7px;
    font-weight: 400;
}
.h-55{
    height: 55px;
}
.min-h-100{
    min-height: 100px;
}
.card-footer-price{
    padding: 10px;
}
.br-0{
    border-top-right-radius: 0px !important;
    border-bottom-right-radius: 0px !important;
}
.img-zoom {
  transition: transform 0.3s ease; 
}

.img-zoom:hover {
  transform: scale(1.15);
}