body.recruitment footer {
    margin-top: 0;
}

.recruitment-offers {
    background-color: rgba(236, 243, 251, 0.45);
    padding: 60px 20px 0;
    margin-top: 60px;
}

.recruitment-offers > .container-tmp {
    max-width: 1120px;
}

.recruitment-offers .row {
    margin-top: 39px;
    --gap-h: 30px;
    --gap-v: 30px;
}

.recruitment-offers .recruitment-offers-header {
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.recruitment-offers .recruitment-offers-header h2 {
    font-size: 28px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.29;
    letter-spacing: normal;
    text-align: left;
    color: #00a9e3;
    width: 100%;
    margin: 0;
    max-width: 40%;
}

.recruitment-offers .custom-select.has-reset .placeholder {
    background: white;
    font-size: 16px;
    font-weight: normal;
}

.recruitment-offers .recruitment-offers-header .recruitment-offers-filters {
    display: flex;
    gap: 10px;
    width: 100%;
    justify-content: flex-end;
}

.recruitment-offers .recruitment-offers-header .recruitment-offers-filters > form {
    display: flex;
    gap: 10px;
    width: 100%;
    justify-content: flex-end;
}

.recruitment-offers .recruitment-offers-header .recruitment-offers-filters > div {
    max-width: 272px;
    width: 100%;
}

.recruitment-offers .card-wrapper {
    max-width: 247px;
    width: 100%;
}

.recruitment-offers .recruitment-offer-card {
    border-radius: 20px;
 box-shadow: 0px 17px 29px 0 rgba(0, 0, 0, 0.04);
    background-color: #ffffff;
    max-width: 247px;
    display: flex;
    flex-direction: column;
    padding: 26px 20px 29px;
    gap: 9px;
    height: 100%;
}

.recruitment-offers .recruitment-offer-card h3 {
    font-size: 16px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.5;
    letter-spacing: normal;
    text-align: left;
    color: #1b1819;
    margin: 0;
}

.recruitment-page .banner .location,
.recruitment-offers .recruitment-offer-card .location,
.recruitment-offers .recruitment-offer-card p {
    font-size: 13px;
    font-weight: normal;
    line-height: 1.38;
    letter-spacing: normal;
    text-align: left;
    color: #959595;
    margin-top: 0;
}
.recruitment-offers .recruitment-offer-card p {
    margin-bottom: 9px;
}

.recruitment-page .banner .location,
.banner-info .location,
.recruitment-offers .recruitment-offer-card .location {
    color: var(--black);
    display: flex;
    align-items: center;
    gap: 9px;
    margin-top: auto;
}

.banner-info .location {
    justify-content: center;
    margin-top: 35px;
    font-size: 13px;
    gap: 8px;
}

.recruitment-page .banner .location {
    justify-content: center;
    margin-top: 30px;
}
.banner-info .location::before,
.recruitment-page .banner .location::before,
.recruitment-offers .recruitment-offer-card .location::before {
    content: "";
    -webkit-mask-image: url(/assets/img/svg/recruitment-pin.svg);
    mask-image: url(/assets/img/svg/recruitment-pin.svg);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: var(--primary);
    width: 16px;
    height: 21px;
    display: block;
    transition: var(--transition);
    z-index: 1;
    position: relative;
}
.banner-info .location::before {
    height: 20px;
}
.recruitment-offers .recruitment-offer-card .button {
    margin-top: 15px;
    padding: 4px 20px 6px;
    font-size: 14px;
    width: 100%;
}


.recruitment-offers.listing .pagination {
    margin: 0 auto 0;
    padding-top: 60px;
}

.recruitment-offers .more-results {
    font-size: 16px;
    font-weight: normal;
    line-height: 1.63;
    letter-spacing: normal;
    text-align: center;
    color: #959494;
    display: flex;
    justify-content: center;
    margin-top: 55px;
}

.recruitment-offers .more-results:hover {
    color: #1a1a1a;
}

.recruitment-page .job-offer-wrapper {
    margin-top: 85px;
}

.recruitment-page .job-offer-wrapper .container {
    display: flex;
    gap: 20px;
    justify-content: space-between;
}

.recruitment-page .job-offer-wrapper .template {
    margin: 0 ;
    max-width: 580px;
    flex: 1;
}

.recruitment-page .job-offer-wrapper .template .template-module > *:first-child {
    margin-top: 0 ;
}

.recruitment .content .form {
    margin: 70px 0 100px;
}

.recruitment .content .form .button-wrapper {
    text-align: center;
    display: flex;
    justify-content: center;    
}

.recruitment .content .form .row > .privacy-policy {
    margin-top: 0px;
}

.recruitment-page .job-offer-wrapper .form {
    max-width: 500px;
    width: 100%;
    flex: 1;
}

.recruitment-page .job-offer-wrapper .form .row {
    flex-direction: column;
}

.recruitment .content .form .row .input-wrapper.file {
    margin-top: 10px;
}

.form .row .input-wrapper.file {
    display: flex;
    align-items: center;
    gap: 20px;
    border: none;
    padding: 0;
}

.form .row .input-wrapper.file input {
    max-width: 130px;
    color: transparent;
}

.form .row .input-wrapper .file-upload::file-selector-button {
    display: none;
}

.form .row .input-wrapper .file-upload::-webkit-file-upload-button {
    visibility: hidden;
}


.form .row .input-wrapper .file-upload {
    color: transparent;
    position: relative;
    width: 140px;
    height: 40px;
    cursor: pointer;
    border: none;
    background: transparent;
    appearance: none;
}

.form .row input.file-upload::before {
    content: 'Upload CV';
    display: inline-block;
    border-radius: 30px;
    background-color: rgba(213, 228, 246, 0.4);
    padding: 10px 20px;
    outline: none;
    white-space: nowrap;
    -webkit-user-select: none;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    line-height: 1;
    color: var(--primary);
    transition: var(--transition);
}

.form .row input.file-upload:hover::before {
    color: var(--white);
    background-color: var(--primary);
}


.form .row .input-wrapper.file input+label {
    left: 0 !important;
    top: 0 !important;
    z-index: 1;
    font-size: 13px;
    font-weight: 300;
    line-height: 1.38;
    text-align: left;
    color: #959595;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    flex-direction: row-reverse;
    transform: none;
    gap: 7px;
    padding: 0;
}

.recruitment-page .job-offer-wrapper .form .row > .privacy-policy {
    margin-top: 10px;
}

.recruitment-page .job-offer-wrapper .form .row .button {
    width: 100%;
    margin-top: 5px;
    /* color: var(--white); */
    
}

/* .recruitment-page .job-offer-wrapper .form .row .button::before {
    opacity: 1;
    background-color: var(--primary);
}

.recruitment-page .job-offer-wrapper .form .row .button:hover {
    color: var(--primary);
}

.recruitment-page .job-offer-wrapper .form .row .button:hover::before {
    opacity: 0.4;
    background-color: #d5e4f6;
} */

.recruitment-page .job-offer-wrapper .pagination {
    padding: 58px 0;
    width: 100%;
    margin-top: 80px;
    border-top: 2px solid #f5f5f5;
}

.recruitment-page .job-offer-wrapper .pagination ul {
    margin: auto;
    width: 100%;
    padding: 0;
    display: flex;
    justify-content: space-between;
}

.recruitment-page .job-offer-wrapper .pagination ul li {
    display: inline-block;
    vertical-align: middle;
    cursor: pointer;
    font-size: 16px;
    font-weight: 500;
    font-stretch: normal;
    font-style: normal;
    line-height: 1.38;
    letter-spacing: normal;
    text-align: left;
    color: var(--primary);
    transition: var(--transition);
    display: flex;
    align-items: center;
    gap: 9px;
}

.recruitment-page .job-offer-wrapper .pagination ul li:not(.prev, .next):hover a {
    color: var(--primary);
}

.recruitment-page .job-offer-wrapper .pagination ul li a {
    gap: 9px;
    display: flex;
    align-items: center;
}


.listing .recruitment-page .job-offer-wrapper .pagination ul li.next.disabled a,
.listing .recruitment-page .job-offer-wrapper .pagination ul li.prev.disabled a {
    background-color: unset;
    opacity: 1;
}


.recruitment-page .job-offer-wrapper .pagination ul li.disabled {
    opacity: 0.6;
}


.recruitment-page .job-offer-wrapper .pagination ul li.disabled {
    cursor: default;
    pointer-events: none;
}

.recruitment-page .job-offer-wrapper .open-form-mobile {
    display: none;
    position: fixed;
    bottom: 0;
    width: 100%;
    z-index: 3;
    padding: 4px 20px 5px;
    color: var(--white);

}

.recruitment-page .job-offer-wrapper .open-form-mobile::before {
    border-radius: 0;
    opacity: 1;
    background-color: var(--primary)
}

.recruitment-page .job-offer-wrapper .form .close-form {
    width: 30px;
    height: 30px;
    right: 0px;
    top: 20px;
    transition: var(--transition);
    position: absolute;
    cursor: pointer;
    display: none;
}

.recruitment-page .job-offer-wrapper .form .close-form::before {
    content: "";
    position: absolute;
    width: 12px;
    height: 12px;
    right: 20px;
    top: 10px;
    -webkit-mask-image: url(/assets/img/svg/close-header.svg);
    mask-image: url(/assets/img/svg/close-header.svg);
    -webkit-mask-repeat: no-repeat;
    mask-repeat: no-repeat;
    background-color: var(--black);
    cursor: pointer;
    transition: var(--transition);
}


@media(max-width: 1024px) {

    .recruitment-offers .recruitment-offers-header {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

    .recruitment-offers .recruitment-offers-header .recruitment-offers-filters {
        justify-content: center;
    }

    .recruitment-offers .row {
        --gap-h: 30px;
        --gap-v: 30px;
        justify-content: center;
    }

    .recruitment-offers .recruitment-offer-card {
        max-width: 262px;
    }

}

@media(max-width: 768px) {

    .recruitment-offers {
        padding: 40px 0 60px;
        margin-top: 40px;
    }

    .recruitment-offers .recruitment-offers-header {
        flex-direction: column;
        align-items: center;
        gap: 20px;
    }

    .recruitment-offers .recruitment-offers-header h2 {
        max-width: 100%;
        text-align: center;
    }

    .recruitment-offers .recruitment-offers-header .recruitment-offers-filters {
        justify-content: center;
    }

    .recruitment-offers .recruitment-offers-header .recruitment-offers-filters form {
        flex-direction: column;
        align-items: center;
    }

    .recruitment-offers .row {
        margin-top: 20px;
        --gap-h: 20px;
        --gap-v: 20px;
        justify-content: center;
    }

    .recruitment-offers .more-results {
        font-size: 14px;
        line-height: 1.71;
        margin-top: 30px;
    }

    .recruitment-page .job-offer-wrapper {
        margin-top: 30px;
    }

    .recruitment-page .job-offer-wrapper .form {
        position: fixed;
        height: 100vh;
        max-width: 100%;
        background-color: white;
        top: 0;
        right: 0;
        flex-direction: column;
        transform: translateX(100%);
        transition: var(--transition);
        -webkit-transition: var(--transition);
        z-index: 20;
        width: 92vw;
        padding: 20px;
    }

    .recruitment-page .job-offer-wrapper .form.open {
        transform: translateX(0%);
        overflow: auto;
    }

    body:has(.form.open) header::before {
        opacity: .8;
        pointer-events: auto;
    }

    .recruitment-page .job-offer-wrapper .form,
    .recruitment-page .job-offer-wrapper .template {
        max-width: 100%;
    }

    .recruitment-page .job-offer-wrapper .form .row {
        padding-top: 80px;
    }

    .recruitment-page .job-offer-wrapper .form .row .input {
        font-size: 14px;
    }

    .recruitment-page .job-offer-wrapper .container {
        flex-direction: column;
    }

    .recruitment-page .job-offer-wrapper .open-form-mobile {
        display: block;
    }

    .recruitment .form .row .input-wrapper:has(textarea),
    .recruitment-page .form .row .input-wrapper:has(textarea) {
        margin-top: 0;
    }
    
    .form .row .input-wrapper.file {
        flex-direction: column;
    }

    .form .row .input-wrapper.file input {
        max-width: 100%;
        width: 100%;
    }

    .form .row input.file-upload::before {
        width: calc(92vw - 84px);
        text-align: center;
        font-size: 14px;
        padding: 8px 20px;
    }

    .recruitment .content .form .row input.file-upload::before {
        width: calc(100vw - 99px);
        
    }

    .recruitment-page .job-offer-wrapper .form .close-form {
        display: block;
    }

    .recruitment-page .job-offer-wrapper .pagination {
        padding: 12px 20px;
        border-radius: 0;
        margin: 40px -20px 0;
        width: calc(100% + 40px);
    }

    .recruitment-page .job-offer-wrapper .pagination ul li {
        font-size: 14px;
    }

    .recruitment .content .form {
        margin: 30px 0 40px;
    }

    .recruitment .content .form .button-wrapper .button {
        width: 100%;
    }
}

@media(max-width: 500px) {
        .recruitment-offers .recruitment-offers-header .recruitment-offers-filters>div,
    .recruitment-offers .recruitment-offer-card {
        max-width: 100%;
    }

    .recruitment-offers .recruitment-offers-header h2 {  
        font-size: 24px;
        line-height: 1.17;
    }

    .recruitment-offers .recruitment-offers-header .recruitment-offers-filters {
        flex-direction: column;
    }

    .recruitment-offers .recruitment-offers-header .input-wrapper.select-wrapper .custom-select .options-wrapper,
    .recruitment-offers .recruitment-offers-header .input-wrapper.select-wrapper .custom-select .placeholder{
        font-size: 14px;
        min-height: 45px;
    } 

    .recruitment-offers .recruitment-offers-header .input-wrapper.select-wrapper .custom-select .options-wrapper {
        margin-top: -14px;  
        padding-left: 14px;
    }

    .recruitment-offers .recruitment-offers-header .input-wrapper label {
        left: 21px;
        top: 11px;
    }

    .recruitment-offers .recruitment-offers-header .select-wrapper:has(.isSelected) label {
        left: 21px !important;
    }

    .recruitment-offers .card-wrapper,
    .input-wrapper.select-wrapper {
        max-width: 100%;
    }


}