/**
 * buttons, links, text, title - default settings
 */
body, h1, h2, h3, h4, h5, li, p, span, a, a:hover {
    font-family: IBMPlexSans-Regular, Arial, sans-serif;
    font-size: 20px;
    font-weight: 300;
    hyphens: auto;
    line-height: 29px;
}
body, h1, h2, h3, h4, h5, li, p, span {
    color: #0F0064 !important;
}
a, a:hover {
    color: #0F0064;
}
a:hover {
    text-decoration: underline;
}
input::placeholder {
    color: #0F0064 !important;
    opacity: 0.5;
}
h1 {
    font-size: 44px;
    line-height: 57px;
    margin-bottom: 50px;
}
h2 {
    font-family: IBMPlexSans-Bold, Arial, sans-serif;
    font-size: 20px;
    line-height: 27px;
}
h3 {
    font-size: 30px;
    line-height: 39px;
    margin-bottom: 50px;
}
h4 {
    font-family: IBMPlexSans-SemiBold, Arial, sans-serif;
    font-size: 16px;
    font-weight: 400;
    line-height: 23px;
    margin: 0;
}
img {
    vertical-align: top;
}
ul {
    list-style: none;
    margin: 0;
    padding: 0;
}
.mobileOrder {
    display: none;
    visibility: hidden;
}
.linkColor,
.linkColor:hover {
    color: #FF6600;
}
/**
 * header
 */
header {
    display: grid;
    margin-bottom: 50px;
    position: relative;
}
header a:hover {
    color: inherit;
}
header a.active {
    font-family: IBMPlexSans-Bold, Arial, sans-serif;
    font-weight: 400;
    text-decoration: none;
}
#headerBackground {
    background-position: center center;
    background-size: cover;
    filter: opacity(20%);
    height: 100%;
    left: 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 1;
}
#headerBackground:after {
    background-color: #FFF;
    content: "";
    height: calc(5vw + 10px);
    position: absolute;
    top: 100%;
    transform: skewY(2.86241deg);
    transform-origin: bottom right;
    width: 100%;
    z-index: 1;
}
#headerWrapper {
    display: grid;
    gap: 25px;
    grid-template-columns: auto auto;
    left: 0;
    padding: 25px 25px 0;
    position: absolute;
    top: 0;
    width: 100%;
    z-index: 2;
}
#logoWrapper {
    justify-self: flex-start;
}
#logoWrapper svg {
    display: block;
    height: 100px;
}
#logoWrapper a:hover .logo-fill--gray {
    fill: #FF6600;
}
.logo-fill--gray {
    fill: #646363;
}
.logo-fill--white {
    fill: #FFF;
}
#langWrapper a, #slogan p {
    line-height: 27px;
}
#langWrapper {
    justify-self: flex-end;
    padding-top: 36px;
}
#langWrapper ul {
    display: grid;
    gap: 10px;
    grid-template-columns: auto auto auto;
}
#langWrapper li:after {
    content: "\00B7";
    font-weight: 400;
    padding-left: 0.5rem;
}
#langWrapper li:last-child:after {
    content: "";
}
#sloganWrapper {
    display: grid;
    grid-template-columns: 50%;
    margin: 125px 0 170px;
    padding: 0 25px;
}
#slogan {
    grid-column: 2;
    max-width: 650px;
}
#slogan h1 {
    margin: 0;
}
#slogan p {
    margin-bottom: 8px;
}
/**
 * main
 */
.slimWrapper, .wideWrapper, footer {
    margin: 0 auto 100px;
    max-width: 1300px;
    padding: 0 25px;
    width: 100%;
}
.slimWrapper {
    max-width: 650px;
}
.introduction {
    padding-bottom: 48px;
}
#filter-dropdown {
    gap: 20px;
    grid-template-columns: 1fr;
    padding-bottom: 20px;
}
#filter-dropdown .column,
#filter-search .column {
    padding: 0;
}
#filter-search .column {
    padding-bottom: 29px;
}
.ui.form input:not([type]),
.ui.form input[type="date"],
.ui.form input[type="datetime-local"],
.ui.form input[type="email"],
.ui.form input[type="file"],
.ui.form input[type="number"],
.ui.form input[type="password"],
.ui.form input[type="search"],
.ui.form input[type="tel"],
.ui.form input[type="text"],
.ui.form input[type="time"],
.ui.form input[type="url"] {
    border: 1px solid #0F0064;
    border-radius: 0;
    color: #0F0064;
    font-family: IBMPlexSans-Regular, Arial, sans-serif;
    font-size: 20px;
    font-weight: 300;
    height: 45px;
    hyphens: auto;
    line-height: 29px;
    padding: 0 20px;
    width: 100%;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
}
.ui.form input:not([type]):focus,
.ui.form input[type="date"]:focus,
.ui.form input[type="datetime-local"]:focus,
.ui.form input[type="email"]:focus,
.ui.form input[type="file"]:focus,
.ui.form input[type="number"]:focus,
.ui.form input[type="password"]:focus,
.ui.form input[type="search"]:focus,
.ui.form input[type="tel"]:focus,
.ui.form input[type="text"]:focus,
.ui.form input[type="time"]:focus,
.ui.form input[type="url"]:focus {
    border: 1px solid #FF6600;
    border-radius: 0;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
}
.buttonWrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 25px 50px;
}
.ui.primary.button,
.ui.secondary.button {
    background: #FFF;
    border-bottom: 2px solid #FF6600;
    border-radius: 0;
    color: #0F0064;
    display: inline-block;
    font-family: IBMPlexSans-Regular, Arial, sans-serif;
    font-size: 24px;
    font-weight: 300;
    hyphens: auto;
    line-height: 32px;
    margin: 0;
    padding: 0 0 10px;
    position: relative;
    text-align: left;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
}
.ui.primary.button:hover,
.ui.secondary.button:hover {
    background: inherit;
    color: #FF6600 !important;
}
.ui.primary.button:hover {
    border-bottom: none;
    padding-bottom: 12px;
}
.ui.secondary.button {
    border-bottom: none;
    color: #FF6600 !important;
}
.ui.primary.button:focus,
.ui.primary.button:visited,
.ui.secondary.button:focus,
.ui.secondary.button:visited {
    background-color: inherit;
    color: inherit;
}
.ui.secondary.button:after {
    background-color: #FF6600;
    bottom: 0;
    content: "";
    height: 2px;
    left: 0;
    position: absolute;
    transition: all ease-in-out 0.5s;
    width: 100%;
    -moz-transition: all ease-in-out 0.5s;
    -o-transition: all ease-in-out 0.5s;
    -webkit-transition: all ease-in-out 0.5s;
}
.ui.secondary.button:hover:after {
    left: 50%;
    width: 0;
}
.ui.grid {
    margin: 0 !important;
}
.ui.grid > .row {
    display: grid;
    gap: 0 25px;
    grid-template-columns: 1fr 1fr 1fr 1fr;
    padding: 0;
}
.ui.grid > .row > [class *= "four wide computer"].column {
    border-bottom: 1px solid #0F0064;
    padding: 24px 0;
    width: 100% !important;
}
.ui.grid > .row.title > [class *= "four wide computer"].column {
    padding-top: 0;
}
.noJobs {
    padding: 24px 0 0 !important;
}
.columnWrapper {
    display: grid;
    gap: 50px 75px;
    grid-template-columns: 1fr 1fr;
}
.contentImage {
    align-self: baseline;
    position: relative;
}
.contentImage img {
    object-fit: initial;
    width: 100%;
}
.contentImage:after {
    background-color: #FFF;
    bottom: 0;
    content: "";
    height: calc(30px + 10px);
    left: 0;
    position: absolute;
    top: 100%;
    transform: skewY(-2.86241deg);
    transform-origin: bottom left;
    width: 100%;
    z-index: 1;
}
.contentText {
    margin-top: 78px;
}
/**
 * Footer.
 */
footer {
    margin: 300px auto 100px;
}
footer a,
footer a:hover,
footer p {
    font-size: 16px;
    line-height: 23px;
}
.topFooterWrapper {
    display: grid;
    gap: 0 25px;
    grid-template-columns: 1fr 1fr;
}
.topFooterWrapper div {
    border-top: 1px solid #0F0064;
    padding: 10px 0 40px;
}
.bottomFooterWrapper {
    display: flex;
    flex-wrap: wrap;
    gap: 10px 25px;
    padding: 50px 0 100px;
}
.bottomFooterWrapper a,
.bottomFooterWrapper a:hover,
.bottomFooterWrapper p {
    line-height: 20px;
}
/**
 * Multi select
 */
.ui-multiselect {
    background-color: inherit;
    border: 1px solid #0F0064;
    border-radius: 0;
    cursor: pointer;
    height: 45px;
    overflow: hidden;
    padding: 0 20px;
    position: relative;
    text-align: left;
    -moz-border-radius: 0;
    -webkit-border-radius: 0;
}
.ui-multiselect span {
    display: block;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    width: 90%;
}
.ui-multiselect span.ui-icon {
    background: url("../images/svg/icons/arrow-down.svg") no-repeat 0 10px / 12px 24px;
    height: 43px;
    padding: 0;
    position: absolute;
    right: 0;
    top: 0;
    width: 32px;
}
.ui-multiselect.ui-state-active span.ui-icon {
    background: url("../images/svg/icons/arrow-up.svg") no-repeat 0 10px / 12px 24px;
}
.ui-multiselect-header {
    margin-bottom: 3px;
    padding: 0 0 0 4px;
}
.ui-multiselect-header ul {
    font-size: 1em;
}
.ui-multiselect-header ul li {
    display: none;
    float: left;
    padding: 0 10px 0 0;
}
.ui-multiselect-header a {
    text-decoration: none;
}
.ui-multiselect-header li.ui-multiselect-close {
    display: block;
    float: right;
    padding-right: 0;
    text-align: right;
}
.ui-multiselect-menu {
    background: #FFF;
    border: 1px solid #0F0064;
    display: none;
    max-width: 100%;
    position: absolute;
    text-align: left;
    z-index: 10000;
}
.ui-multiselect-checkboxes {
    height: inherit !important;
    margin-bottom: 10px;
    max-height: 400px !important;
    position: relative;
}
.ui-multiselect-checkboxes label {
    border-bottom: 1px solid #0F0064;
    cursor: pointer;
    display: block;
    padding: 0 0 10px;
}
.ui-multiselect-checkboxes li:first-child {
    padding-top: 10px;
}
.ui-multiselect-checkboxes li:last-child {
    padding-bottom: 0;
}
.ui-multiselect-checkboxes li {
    clear: both;
    padding: 0 20px 10px;
}
.ui-widget-header.ui-corner-all.ui-multiselect-header.ui-helper-clearfix {
    display: none;
}
.ui-corner-all input[type='checkbox']:not(:checked),
.ui-corner-all input[type='checkbox']:checked {
    left: -9999px;
    opacity: 0;
    position: absolute;
}
.ui-corner-all input[type='checkbox'] + span {
    backface-visibility: hidden;
    display: inline-block;
    font-size: 17px;
    line-height: 24px;
    padding-left: 35px;
    position: relative;
    user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    -webkit-backface-visibility: hidden;
    -webkit-user-select: none;
}
.ui-corner-all input[type='checkbox'] + span::before,
.ui-corner-all input[type='checkbox'] + span::after {
    content: '';
    left: 0;
    position: absolute;
    top: 1px;
    z-index: 0;
}
.ui-corner-all input[type='checkbox'] + span::before {
    border: 2px solid #0F0064;
    height: 22px;
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    width: 22px;
}
.ui-corner-all input[type='checkbox'] + span::after {
    background: #0F0064;
    content: "\002D";
    font-size: 18px;
    height: auto;
    line-height: 22px;
    text-align: center;
    transform: scale(0);
    transition: all 300ms cubic-bezier(0.4, 0, 0.2, 1);
    width: 22px;
    -webkit-transform: scale(0);
}
.ui-state-hover input[type='checkbox'] + span::after {
    transform: scale(0.5);
    -webkit-transform: scale(0.5);
}
.ui-corner-all input[type='checkbox']:checked + span::after {
    transform: scale(1);
    -webkit-transform: scale(1);
}
/**
 * Jobabo.
 */
#step-2 {
    display: none;
}
#subscriptionWrapper {
    padding-bottom: 29px;
}
/**
 * Parsley
 */
.parsley-error {
    border: 1px solid #F00 !important;
}
.parsley-errors-list li {
    color: #F00 !important;
    font-size: 16px;
    list-style: none;
    margin: 5px 0 15px;
    padding: 0;
}
/**
* media screen (tablets, smartphones)
 */
@media only screen and (max-width: 800px) {
    .desktopOrder {
        display: none;
        visibility: hidden;
    }
    .mobileOrder {
        display: block;
        visibility: visible;
    }
    #sloganWrapper {
        display: block;
        margin-bottom: 100px;
        padding: 25px 25px 0;
    }
    h1 {
        font-size: 30px;
        line-height: 39px;
    }
    h3 {
        font-size: 24px;
        line-height: 32px;
    }
    .ui.primary.button,
    .ui.secondary.button {
        font-size: 22px;
        line-height: 28px;
    }
    .columnWrapper {
        grid-template-columns: 1fr;
    }
    .contentText {
        margin-top: 0;
    }
    .ui.grid > .row {
        grid-template-columns: 1fr;
    }
    .ui.grid > .row > [class *= "four wide computer"].column {
        border-bottom: none;
        padding: 0 0 20px;
    }
    .ui.grid > .row > [class *= "four wide computer"].column:first-child {
        padding-top: 0;
    }
    .ui.grid .row.job {
        border-bottom: 1px solid #0F0064;
        margin-bottom: 20px;
    }
    .ui.grid .row.job:last-child {
        margin-bottom: 0;
    }
    footer {
        margin-top: 200px;
    }
    .bottomFooterWrapper {
        padding-bottom: 50px;
    }
}
@media only screen and (max-width: 600px) {
    .topFooterWrapper {
        grid-template-columns: 1fr;
    }
}