/*
Theme Name: Avada Child
Description: Child theme for Avada theme
Author: ThemeFusion
Author URI: https://theme-fusion.com
Template: Avada
Version: 1.0.0
Text Domain:  Avada
*/

/**************************************
 *  General Styles
 */
/* h1, h2, h3, h4, h5, h6, p {
    word-break: break-word;
    hyphens: auto;
} */
.show {
    display: block !important;
    opacity: 1 !important;
}
.text-center {
    text-align: center;
}

.text-left {
    text-align: left;
}

.grid-item--empty {
    @media (max-width: 768px) {
        display: none;
    }
}

/**************************************
 *  Header Styles
 */
.kw-menu-button button {
    border-radius: 66px;
}
.kw-submenu-title a {
    text-decoration: none !important;
}

/**************************************
 *  Podcast Styles
 */
.kw-podcast-player .nav-tabs {
    display: flex !important;
    flex-wrap: wrap !important;
    flex-direction: row !important;
}

.kw-podcast-player .tab-pane {
    height: 450px;
}

.kw-podcast-player li {
    width: 120px !important;
    overflow: hidden;
}

@media only screen and (max-width: 1024px) {
    .kw-podcast-player .nav-tabs {
        flex-direction: column !important;
    }

    .kw-podcast-player .tab-pane {
        height: auto;
    }

    .kw-podcast-player li {
        width: auto !important;
    }
}

.kw-podcast-player li a {
    align-items: center !important;
    padding: 8px 30px !important;
    display: inline-block !important;
    white-space: nowrap !important;
    color: #888 !important;
    position: relative !important;
    background-color: rgba(0, 0, 0, 0.045) !important;
    transition: all 0.3s cubic-bezier(0.12, 0.75, 0.4, 1) !important;
    border-top: 0 !important;
    border-bottom: 0 !important;
    border-left: 0 !important;
    border-right: 0!important;
    width: 100% !important;
}

.kw-podcast-player li .fusion-tab-heading {
    font-family: Montserrat !important;
    min-height: 32px !important;
    font-size: 16px !important;
    font-weight: 600 !important;
    line-height: 120% !important;
    letter-spacing: -0.16px !important;;
}

.kw-podcast-player li.active .tab-link, .kw-podcast-player li .active {
    background-color: #75FBA3 !important;
}

/**************************************
 *  Header Styles Applicant Portal
 */
.kw-applicant-portal-header {
    left: 20px;
    right: 20px;
    margin: auto;
    width: 1408px !important;
}

@media only screen and (max-width: 1408px) {
    .kw-applicant-portal-header {
        width: auto !important;
    }
}

/**************************************
 *  2 Column Title + Text module
 */
.kw-linked-icon i {
    background-color: #75FBA3;
    padding: 12px;
    border-radius: 66px;
}

.kw-linked-icon:hover i {
    color: #0B0B0B !important;
}

/**************************************
 *  4 Cards with C2A module
 */
.kw-column-fixed-height-200 {
    min-height: 200px;
}

/**************************************
 *  Logo Slider module
 */
.kw-partner-carousel .swiper-slide {
    padding: 32px 48px;
    background-color: #ffffff;
}

/**************************************
 *  Talking Numbers module
 */
.kw-no-value-counter .display-counter {
    display: none;
}

/**************************************
 *  Newsletter & Product module
 */
.kw-relative-container {
    position: relative;
}

.kw-newsletter-image {
    position: absolute !important;
    top: 2em;
    right: -2em;
    width: 160px;
    height: auto;
    z-index: 10;
}

.kw-product-image {
    position: absolute !important;
    top: -5em;
    right: 10vw;
    width: 160px;
    height: auto;
    z-index: 10;
}

@media only screen and (max-width: 768px) {
    .kw-newsletter-image {
        top: -4em;
        right: -3em;
    }
}

@media only screen and (max-width: 1024px) {
    .kw-product-image {
        top: -7em;
        right: -3em;
    }
}

/**************************************
 *  Hide Search from Header
 */
.kw-hide-element {
    display: none;
}

/**************************************
 *  Country and Language Switcher
 */
/* Container style for switchers */
.pll-switchers {
    display: flex;
    gap: 16px;
    align-items: center;
    background-color: transparent;
    padding: 16px 0;
}

/* Wrapper for each select + icon + arrow */
.pll-select-wrapper {
    position: relative;
    display: inline-block;
}

/* Icon span (inserted before <select>) */
.pll-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    font-size: 18px;
    padding-top: 5px;
}

/* Select dropdown style */
.pll-select-wrapper select {
    appearance: none;
    -webkit-appearance: none;
    -moz-appearance: none;
    background: transparent;
    border: 1px solid #BCBCBC;
    color: #BCBCBC;
    padding: 12px 35px 12px 40px;
    border-radius: 66px;
    font-size: 14px;
    font-family: "Chillax Variable";
    font-style: normal;
    font-weight: 600;
    line-height: 16.8px;
    letter-spacing: 0.42px;
    cursor: pointer;
    width: 100%;
}

.pll-select-wrapper option {
    background-color: #000;
    color: #BCBCBC;
}

/* Remove default dropdown arrow in some browsers */
.pll-switchers select::-ms-expand {
    display: none;
}

/* Custom SVG arrow icon */
.pll-caret-icon {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    pointer-events: none;
    display: flex;
    align-items: center;
    justify-content: center;
}

/* hover/focus state */
.pll-select-wrapper select:hover,
.pll-select-wrapper select:focus {
    border-color: #aaa;
    outline: none;
}

/**************************************
 *  Applicant Portal
 */

/**************************************
 *  Job Search Field
 */
#jobsearch {
    width: 100%;
}

.jobsearch-wrapper {
    display: flex;
    gap: 24px;
    align-items: center;
}

.jobsearch-wrapper .input {
    flex: 1;
    position: relative;
    display: flex;
    align-items: center;
    height: 48px;
    gap: 12px;
    border-radius: 8px;
    border: 1.5px solid #DADDDF;
    background: #FFF;
}

.jobsearch-wrapper input {
    padding: 12px 16px;
}

.jobsearch-wrapper .search-icon {
    display: inline-flex;
    margin-right: 12px;
    padding: 12px 16px;
    border-right: 1.5px solid #DADDDF;
}

.jobsearch-wrapper .search-icon svg {
    width: 20px;
    height: 20px;
}

#jobtext {
    flex: 1;
    border: none;
    outline: none;
    background: transparent;
    font-size: 16px;
    color: #333;
    padding: 0;
}

#jobtext::placeholder {
    color: #999;
}

.jobsearch-wrapper .button {
    flex-shrink: 0;
}

.btn-primary {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 32px;
    cursor: pointer;
    transition: background 0.3s ease;
    white-space: nowrap;
    font-family: "Montserrat";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    text-decoration: none !important; 
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.btn-primary:hover {
    background: #000;
    color: #fff;
}

.btn-primary:active {
    background: #000;
    color: #fff;
}

.btn-light {
    background: #F8F8F8;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 32px;
    cursor: pointer;
    transition: background 0.3s ease, color 0.3s ease;
    white-space: nowrap;
    font-family: "Montserrat";
    font-size: 16px;
    font-style: normal;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    text-decoration: none !important; 
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
}

.btn-light:hover,
.btn-light:active {
  background: #EDEDED;
  color: #000;
}

/* Responsive */
@media (max-width: 768px) {
    .jobsearch-wrapper {
        flex-direction: column;
        gap: 16px;
    }

    .jobsearch-wrapper .input {
        width: 100%;
    }

    .jobsearch-wrapper .button {
        width: 100%;
    }

    .btn-primary {
        width: 100%;
    }

    .btn-light {
        width: 100%;
    }
}

/**************************************
 *  Job Search
 */
.jobsearch {
    width: 100%;
}

/* Specific styles for job search with filters */
.job-search-with-filters .jobsearch-wrapper {
    margin-bottom: 24px;
}

.job-search-with-filters .jobsearch-wrapper .input {
    height: 56px;
}

.job-search-with-filters .btn-primary {
    border-radius: 66px;
    padding: 16px 32px;
    height: 56px;
}

/* Job Search Filters */
.job-search-filters {
    width: 100%;
}

.filters-row {
    display: flex;
    gap: 16px;
    align-items: center;
}

.filter-item {
    flex: 1;
}

.filter-reset {
    flex-shrink: 0;
}

.reset-button {
    display: flex;
    align-items: center;
    gap: 8px;
    background: #F5F5F5;
    border-radius: 66px;
    border: none;
    color: #0B0B0B;
    cursor: pointer;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: -0.16px;
    padding: 12px 32px;
    transition: background 0.3s ease;
}

.reset-button:hover {
    background: #DADDDF;
}

.reset-button svg {
    width: 24px;
    height: 24px;
}

/* Custom Select Styles for Filters */
.filter-item .custom-select-wrapper {
    width: 100%;
}

.filter-item .custom-select-trigger {
    width: 100%;
    padding: 16px 20px;
    border: 1.5px solid #DADDDF;
    border-radius: 8px;
    font-size: 16px;
    color: #0B0B0B;
    background: #FFF;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: border-color 0.3s ease;
    user-select: none;
    height: 56px;
    box-sizing: border-box;
}

.filter-item .custom-select-trigger:hover {
    border-color: #999;
}

.filter-item .custom-select-wrapper.active .custom-select-trigger {
    border-color: #999;
}

.filter-item .custom-select-text {
    color: #0B0B0B;
    flex: 1;
    font-size: 16px;
}

.filter-item .custom-select-arrow {
    display: flex;
    align-items: center;
    transition: transform 0.3s ease;
}

.filter-item .custom-select-wrapper.active .custom-select-arrow {
    transform: rotate(180deg);
}

.filter-item .custom-select-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
}

/* Responsive for filters */
@media (max-width: 768px) {
    .filters-row {
        flex-direction: column;
    }

    .filter-item {
        width: 100%;
    }

    .filter-reset {
        width: 100%;
    }

    .reset-button {
        width: 100%;
        justify-content: center;
    }
}

.page-container {
    max-width: 1170px;
    margin-left: auto;
    margin-right: auto;
}

.job-detail-prev-next {
    display: flex;
    padding: 32px 0 64px 0;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 24px;
    align-self: stretch;
}

@media (min-width: 768px) {
    .job-detail-prev-next {
        flex-direction: row;
        padding: 32px 160px 64px 160px;
    }
}

/**************************************
 *  Job Introduction
*/
.job-introduction {
  margin: 64px 0;
}

.job-introduction__content {
  display: flex;
  flex-direction: column;
  gap: 24px;
}

.job-introduction__header {
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.job-introduction__refNr{
    color: #595959;
    font-family: Montserrat;
    font-size: 13px;
    font-weight: 400;
    line-height: 150%;
}

.job-introduction__title {
    margin: 0;
    color: #0B0B0B !important;
    font-size: 54px !important;
    font-weight: 500 !important;
    line-height: 120% !important;
    letter-spacing: -1.62px !important;
}

.job-introduction__tags {
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 700;
    line-height: 150%;
}

.job-introduction__intro {
    margin: 0;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 24px;
    font-weight: 400;
    line-height: 150%;
}

.job-introduction__action {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

.job-introduction__contact {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 24px;
}

.job-introduction__contactLabel {
    color: #595959;
    font-family: Montserrat;
    font-size: 13px;
    font-weight: 400;
    line-height: 150%;
}

.job-introduction__contactImage--wrapper {
    width: 220px;
    height: 220px;
    justify-content: center;
    align-items: center;
    border-radius: 50%;
    overflow: hidden;
}

.job-introduction__contactInfo {
    display: flex;
    flex-direction: column;
    align-items: center;
}

.job-introduction__contactPerson {
    margin: 0;
    color: #0B0B0B;
    text-align: center;
    font-family: Montserrat;
    font-size: 20px;
    font-weight: 700;
    line-height: 120%;
}

.job-introduction__contactEmail {
    display: block;
    margin: 0;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
}

.job-introduction__contactPhone {
    display: block;
    margin: 0;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
    text-decoration: none ! important;
}

.job-introduction__button {
    margin-top:  24px;
}

@media (min-width: 992px) {
    .job-introduction {
        display: grid;
        grid-template-columns: 4fr 2fr;
        gap: 24px;
        align-items: start;
    }

    .job-introduction__button {
        margin-top: 0 !important;
    }
}

/**************************************
 *  Job Points
*/
.job-points {
    display: flex;
    flex-direction: column;
    gap: 24px;

    margin-bottom: 24px;
}

@media (min-width: 992px) {
    .job-points {
        flex-direction: row !important;
    }
    .job-points__column {
        width: 50% !important;
    }
}

.job-points__column {
    width: 100%;
    display: flex;
    padding: 32px;
    flex-direction: column;
    align-items: flex-start;
    gap: 16px;
    flex: 1 0 0;
    border-radius: 32px;
    background: #F5FAF6;
}

.job-points__title {
    margin-bottom: 0;
    color: #0B0B0B;
    font-family: Montserrat !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    line-height: 120% !important;
}

.job-points__column ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-direction: column;
    gap: 16px;
}

.job-points__column li {
    position: relative;
    padding-left: 20px;
}

.job-points__column li::before {
  content: "";
  position: absolute;
  left: 0;
  top: 6px;
  width: 12px;
  height: 12px;
  flex-shrink: 0;
  aspect-ratio: 1/1;
  border-radius: 12px;
  background: #75FBA3;
}

.job-points__listIcon::before {
    content: none !important;
}

.job-points__listIcon {
    display: flex;
    align-items: center !important;
    gap: 11px;
}

.job-points__listIconSVG {
    width: 48px;
    height: 48px;
    aspect-ratio: 1/1;
    flex-shrink: 0;
}

/**************************************
 *  Job Contact
*/
.job-contact {
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 32px;
  margin-bottom: 32px;
}

@media (min-width: 768px) {
    .job-contact {
        flex-direction: row;
        align-items: center;
        margin-top: 96px;
        margin-bottom: 96px;
    }
}


.job-contact__column {
  flex: 1 1 0;
}

.job-contact__title {
    margin: 0;
    color: #0B0B0B;
    font-size: 40px;
    font-weight: 500;
    line-height: 120%;
    letter-spacing: -1.2px;
}

.job-contact__desc {
    margin-bottom: 0 !important;
    margin-top: 24px !important;
    color: #595959;
    font-family: Montserrat;
    font-size: 20px;
    font-weight: 400;
    line-height: 120%;
}

.job-contact__column--image {
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: start;
}


@media (min-width: 768px) {
    .job-contact__column--image {
        align-items: center;
    }
}

.job-contact__image {
    width: 160px;
    height: 160px;
    object-fit: cover;
    border-radius: 50%;
    aspect-ratio: 1;
    object-position: top center;
}


.job-contact__position {
  font-size: 15px;
  margin-bottom: 8px;
  color: #555;
}

.job-contact__name {
    margin: 0;
    color: #0B0B0B !important;
    font-family: Montserrat !important;
    font-size: 20px !important;
    font-weight: 700 !important;
    line-height: 120% !important;
}

.job-contact__email {
    display: block;
    margin: 0;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
}

.job-contact__phone {
    display: block;
    margin: 0;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 400;
    line-height: 150%;
    text-decoration: none ! important;
}

/* @media (max-width: 768px) {
  .job-contact {
    flex-direction: column;
    text-align: center;
    gap: 32px;
  }
} */

/**************************************
 *  Salary range
*/
.salary-range {
    margin: 32px auto  64px;  /*TEMP AUTO */
}

.salary-range__title {
    color:  #0B0B0B;
    font-family: Montserrat;
    font-size: 24px;
    font-weight: 700;
    line-height: 120%;
}

.salary-range__bar {
    position: relative;
    height: 24px;
    flex-shrink: 0;
    border-radius: 24px;
    background-color: #F5FAF6;
}

.salary-range__fill {
    position: absolute;
    height: 24px;
    flex-shrink: 0;
    left: 24px; 
    right: 24px; 
    background: linear-gradient(90deg, #5CA282 0%, #223C30 100%);
    display: flex;
    align-items: center;
    justify-content: space-between;
}

@media (min-width: 992px) {
    .salary-range__fill {
        width: 478px;
        left: 396px;
        right: unset; 
    }
}


.salary-range__value {
  color: #FFF;
  font-family: Montserrat;
  font-size: 16px;
  font-weight: 700;
  line-height: 150%;
  padding-left: 16px;
  padding-right: 16px;
}

.salary-range__labels {
    position: absolute;
    display: flex;
    justify-content: space-between;
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 13px;
    font-weight: 400;
    line-height: 150%;
    top: 36px;
    width: 100%;
}

/**************************************
 *  Advertisement Actions
*/
.ad-actions {
    margin: 32px auto;
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 24px;
}

@media (min-width: 992px) {
    .ad-actions {
        align-items: start;
    }

    .ad-actions__group:first-child {
        grid-column: 1 / span 3 !important;
    }

    .ad-actions__group:last-child {
        grid-column: 4 / span 3 !important;
    }
}

.ad-actions__group {
    display: grid;
    flex-direction: column;
    gap: 10px;
}

.ad-actions__group:first-child {
    grid-column: 1 / span 6;
}

.ad-actions__group:last-child {
    grid-column: 1 / span 6;
}

.ad-actions__title {
    color: #0B0B0B;
    font-family: Montserrat;
    font-size: 16px;
    font-weight: 700;
    line-height: 150%;
    margin: 0;
}

.ad-actions__icons {
    display: flex;
    align-items: center;
    gap: 24px;
    flex-wrap: nowrap;
}

/* layout for the two groups */
.ad-actions__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
}
.ad-actions__icon:hover {
    opacity: 0.7;
    outline: none;
}

/* Shariff: scope to our ad-actions block */
.shariff--ad-actions {
    --ad-icon-size: 24px;
}
.shariff--ad-actions ul {
    gap: 10px;
    flex-wrap: nowrap !important;
}
.shariff--ad-actions.orientation-horizontal li {
    margin: 0 !important;
}
.shariff--ad-actions li {
    margin: 0 !important;
}
.shariff--ad-actions a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 40px;
    height: 40px;
    padding: 0;
    background: transparent !important;
    box-shadow: none;
    border: 0;
    color: transparent !important;
    text-decoration: none;
}

/* hide Shariff’s built-in icon fonts/text */
.shariff--ad-actions .share_text,
.shariff--ad-actions .shariff-button-text,
.shariff--ad-actions .fa {
    display: none !important;
}

/* Use relative paths from style.css to your images directory */
.shariff--ad-actions .mail a {
    background: url('images/email.svg') center/var(--ad-icon-size) no-repeat !important;
}
.shariff--ad-actions .facebook a {
    background: url('images/facebook.svg') center/var(--ad-icon-size) no-repeat !important;
}
.shariff--ad-actions .linkedin a {
    background: url('images/linkedin.svg') center/var(--ad-icon-size) no-repeat !important;
}
.shariff--ad-actions .xing a {
    background: url('images/xing.svg') center/var(--ad-icon-size) no-repeat !important;
}
.shariff--ad-actions .whatsapp a {
    background: url('images/whatsapp.svg') center/var(--ad-icon-size) no-repeat !important;
}

/* Hover/focus styles to match your design (tweak as needed) */
.shariff--ad-actions a:hover, .shariff--ad-actions a:focus {
    opacity: 0.7;
    outline: none;
}

/* A11y: visually hidden helper (if you want to add sr-only spans) */
.sr-only {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0,0,0,0);
    white-space: nowrap;
    border: 0;
}

.background-image {
    background: url('images/image-2.svg') right top no-repeat;
    background-size: 50%;
}

.slide-range {
    display: none;
}

@media (min-width: 992px) {
    .slide-range {
        display: block;
    }
}

.slide-range--container {
    overflow: visible !important;
}

.slidecontainer {
    position: relative;
    width: 100%;
    margin: 148px 0;
    width: 100%;
}

#calcSlider {
    -webkit-appearance: none;
    width: 100%;
    height: 24px;
    flex-shrink: 0;
    border-radius: 24px;
    background: linear-gradient(90deg, #75FBA3 0%, #459561 100%);
    outline: none;
}

#calcSlider::-webkit-slider-thumb {
    -webkit-appearance: none;
    appearance: none;
    width: 0;
    height: 0;
}

.slider-thumb {
    position: absolute;
    top: 50%;
    transform: translate(-50%, -50%);
    width: 38px;
    height: 38px;
    border-radius: 50%;
    background: #75FBA3;
    border: 10px solid #fff;
    fill:  #FFF;
    filter: drop-shadow(0 4px 16px rgba(0, 0, 0, 0.08));
    color: #fff;
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    pointer-events: none;
    transition: left 0.1s ease;
}

.slider-thumb__brutto {
    color: #223C30;
    text-align: center;
    font-family: Montserrat;
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
}

.slider-thumb__netto {
    color: var(--Off-Black, #0B0B0B);
    text-align: center;
    font-family: Montserrat;
    font-size: 13px;
    font-style: normal;
    font-weight: 400;
    line-height: 150%;
    margin-top: 55px;
}

.slider-thumb__brutto-value {
    white-space: nowrap; 
    color: #223C30;
    text-align: center;
    font-family: Montserrat;
    font-size: 16px;
    font-style: normal;
    font-weight: 700;
    line-height: 150%;
}

.slider-thumb__netto-value {
    white-space: nowrap; 
    color: #223C30;
    text-align: center;
    font-family: Montserrat;
    font-size: 24px;
    font-style: normal;
    font-weight: 700;
    line-height: 120%;
}   

/**************************************
 *  Job Number Search
 */
.jobsNumberSearch {
    width: 100%;
    max-width: 600px;
}

#job-number-search-form .form-wrap {
    display: flex;
    gap: 24px;
    align-items: center;
    flex-wrap: wrap;
    justify-content: flex-end;
}

#job-number-search-form .inputs-row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 12px;
    width: 100%;
}

#job-number-search-form .inputs-row input {
    flex: 1;
    min-width: 0;
    padding: 14px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #333;
    outline: none;
    transition: border-color 0.3s ease;
}

#job-number-search-form .inputs-row input:focus {
    border-color: #999;
}

#job-number-search-form .inputs-row input::placeholder {
    color: #999;
}

#job-number-search-form .separator {
    font-size: 20px;
    color: #333;
    font-weight: 300;
    flex-shrink: 0;
}

#job-number-search-form .button-wrap {
    flex-shrink: 0;
}

.btn-inserat {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 32px;
    font-family: "Montserrat";
    font-style: normal;
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.btn-inserat:hover {
    background: #0B0B0B;
    color: #ffffff;
}

.btn-inserat:active {
    background: #222222;
}

/* Responsive */
@media (max-width: 768px) {
    #job-number-search-form .form-wrap {
        flex-direction: column;
        align-items: stretch;
    }

    #job-number-search-form .button-wrap {
        width: 100%;
    }

    .btn-inserat {
        width: 100%;
    }
}

/**************************************
 *  Unsolicited Application
 */
.unsolicitedApplication {
    width: 100%;
    max-width: 600px;
}

.unsolicitedApplication .form-wrap {
    display: flex;
    flex-direction: column;
    gap: 16px;
}

/* Custom Select Styles */
.job-search-filters .custom-select-wrapper {
    position: relative;
    width: 100%;
}

.custom-select-trigger {
    width: 100%;
    padding: 14px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #333;
    background: #ffffff;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: border-color 0.3s ease;
    user-select: none;
}

.custom-select-trigger:hover {
    border-color: #999;
}

.custom-select-wrapper.active .custom-select-trigger {
    border-color: #999;
}

.custom-select-text {
    color: #999;
    flex: 1;
}

.custom-select-text.has-selection {
    color: #333;
}

.custom-select-arrow {
    color: #666;
    font-size: 12px;
    transition: transform 0.3s ease;
}

.custom-select-wrapper.active .custom-select-arrow {
    transform: rotate(180deg);
}

.custom-select-wrapper {
    position: relative;
    overflow: visible;
}

.custom-select-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #ffffff;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    z-index: 9999;
    display: none;
    max-height: 300px;
    overflow-y: auto;
}

.custom-select-wrapper.active .custom-select-dropdown {
    display: block;
}

.custom-select-options {
    padding: 8px 0;
}

.custom-select-option {
    display: flex;
    align-items: center;
    padding: 10px 20px;
    cursor: pointer;
    transition: background 0.2s ease;
    margin: 0;
}

.custom-select-option:hover {
    background: #f9f9f9;
}

.custom-select-option input[type="checkbox"] {
    margin-right: 10px;
    cursor: pointer;
}

.custom-select-option span {
    color: #333;
    font-size: 16px;
}

.custom-select-option input[type="checkbox"]:checked + span {
    font-weight: 500;
}

/* Button styles */
.unsolicitedApplication .button-wrap {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
}

.btn-bewerben {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 40px;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.btn-bewerben:hover {
    background: #0B0B0B;
    color: #ffffff;
}

.btn-bewerben:active {
    background: #222222;
}

/* Responsive */
@media (max-width: 768px) {
    .unsolicitedApplication .button-wrap {
        justify-content: stretch;
    }

    .btn-bewerben {
        width: 100%;
    }
}

/**************************************
 *  Jobs Abo Form
 */
.jobsabo {
    width: 100%;
}

#jobs-abo-form {
    width: 100%;
}

.jobs-abo-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
    margin-top: 24px;
}

.jobs-abo-grid .grid-item {
    width: 100%;
}

.jobs-abo-grid .grid-button {
    grid-column: span 2;
    display: flex;
    justify-content: flex-end;
}

/* Email input styling for jobs abo */
.jobs-abo-grid .form-group-seam {
    margin: 0;
}

.jobs-abo-grid .form-group-seam input[type="email"],
.jobs-abo-grid .form-group-seam input[type="text"] {
    width: 100%;
    padding: 14px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #333;
    background: #ffffff;
    outline: none;
    transition: border-color 0.3s ease;
}

.jobs-abo-grid .form-group-seam input:focus {
    border-color: #999;
}

.jobs-abo-grid .form-group-seam input::placeholder {
    color: #999;
}

/* Jobs Abo Submit button */
.btn-abo-submit {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 40px;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.btn-abo-submit:hover {
    background: #000;
    color: #fff;
}

.btn-abo-submit:active {
    background: #000;
    color: #fff;
}

/* Make sure custom selects work in jobs abo grid */
.jobs-abo-grid .custom-select-wrapper {
    width: 100%;
}

.jobs-abo-grid .custom-select-trigger {
    width: 100%;
    padding: 12px 16px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #999;
    background: #ffffff;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: border-color 0.3s ease;
    user-select: none;
}

.jobs-abo-grid .custom-select-trigger:hover {
    border-color: #999;
}

.jobs-abo-grid .custom-select-wrapper.active .custom-select-trigger {
    border-color: #999;
}

.jobs-abo-grid .custom-select-text.has-selection {
    color: #333;
}

/* Email input styling for jobs abo */
.jobs-abo-grid .form-group-seam {
    margin: 0;
}

.jobs-abo-grid .form-group-seam input[type="email"],
.jobs-abo-grid .form-group-seam input[type="text"] {
    width: 100%;
    padding: 16px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #333;
    background: #ffffff;
    outline: none;
    transition: border-color 0.3s ease;
    height: 58px;
    box-sizing: border-box;
}

.custom-select-option input[type="radio"] {
    display: none;
}

.custom-select-option span {
    color: #333;
    font-size: 16px;
}

/* Success message */
.success {
    margin-top: 24px;
    padding: 16px;
    background: #f0f9f4;
    border-radius: 8px;
    color: #2c7a4f;
}

/* Alert */
.alert-danger {
    margin-top: 24px;
    padding: 16px;
    background: #f9f0f0;
    border-radius: 8px;
    color: #7a2c2c;
}

/* Responsive */
@media (max-width: 768px) {
    .jobs-abo-grid {
        grid-template-columns: 1fr;
    }

    .jobs-abo-grid .grid-button {
        grid-column: span 1;
        justify-content: stretch;
    }

    .btn-abo-submit {
        width: 100%;
    }
}

/**************************************
 *  Job Search Results
 */
.job-search-results {
    width: 100%;
    margin-top: 32px;
}

.job-cards-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 24px;
    margin-bottom: 40px;
}

/* Job Card Styles */
.job-card {
    position: relative;
    background: #FFFFFF;
    border-radius: 16px;
    padding: 32px;
    display: flex;
    flex-direction: column;
    box-shadow: 0 2px 8px rgba(0, 0, 0, 0.08);
    transition: box-shadow 0.3s ease, transform 0.3s ease;
}

.job-card:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

.job-card-badge {
    position: absolute;
    top: 32px;
    right: 32px;
    padding: 6px 12px;
}

.job-card-header {
    margin-bottom: 8px;
}

.job-refnr {
    color: #595959;
    font-family: "Montserrat";
    font-size: 13px;
    font-weight: 400;
    line-height: 19.5px;
}

.job-card-body {
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 8px;
}

.job-card-title {
    margin: 0;
    font-family: "Montserrat" !important;
    font-size: 24px !important;
    font-weight: 700 !important;
    line-height: 28.8px !important;
    letter-spacing: -0.72px !important;
    color: #2C3E50 !important;
}

.job-card-title a {
    color: #2C3E50;
    text-decoration: none;
    transition: color 0.3s ease;
}

.job-card-title a:hover {
    color: #595959
}

.job-card-subtitle {
    margin: 0;
    font-family: "Montserrat" !important;
    font-size: 16px !important;
    font-weight: 700 !important;
    line-height: 24px !important;
    color: #223C30 !important;
}

.job-card-description {
    margin: 0;
    font-family: "Montserrat";
    font-size: 14px;
    font-weight: 400;
    line-height: 20px;
    color: #666;
}

.job-card-footer {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    margin-top: auto;
    padding-top: 4px;
}

.job-card-meta {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}

.job-card-location {
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 700;
    line-height: 19.2px;
    color: #0B0B0B;
}

.job-card-location a {
    text-decoration: none !important;
}

.job-card-date {
    font-family: "Montserrat";
    font-size: 14px;
    font-weight: 400;
    line-height: 16.8px;
    color: #666;
}

.job-card-link {
    display: flex;
    align-items: center;
    gap: 8px;
    color: #0B0B0B;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: -0.16px;
    text-decoration: none !important;
    transition: color 0.3s ease;
    white-space: nowrap;
    flex-shrink: 0;
    background: #75FBA3;
    padding: 12px 32px;
    border-radius: 66px;
}

.job-card-link:hover {
    background: #0B0B0B;
    color: #FFFFFF;
}

.job-card-link svg {
    width: 24px;
    height: 24px;
    flex-shrink: 0;
}

/* Load More Button */
.load-more-wrapper {
    display: flex;
    justify-content: center;
    margin-top: 40px;
    margin-bottom: 40px;
}

.btn-load-more {
    display: flex;
    align-items: center;
    gap: 12px;
    background: transparent;
    border: 2px solid #0B0B0B;
    border-radius: 66px;
    color: #0B0B0B;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    padding: 14px 32px;
    cursor: pointer;
    transition: all 0.3s ease;
}

.btn-load-more:hover {
    background: #0B0B0B;
    color: #FFFFFF;
}

.btn-load-more svg {
    width: 18px;
    height: 18px;
}

/* Responsive Grid */
@media (max-width: 1024px) {
    .job-cards-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: 20px;
    }
}

@media (max-width: 768px) {
    .job-cards-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .job-card {
        padding: 20px;
    }

    .job-card-badge {
        top: 20px;
        right: 20px;
    }

    .job-card-footer {
        flex-direction: column;
        align-items: flex-start;
    }

    .job-card-link {
        width: 100%;
        justify-content: space-between;
    }
}

/* Debug styles */
.job-fields {
    font-size: 12px;
    color: #999;
    margin-top: 8px;
}

/**************************************
 *  Info and Deletion Form
 */
.infoanddeletion {
    width: 100%;
    max-width: 100%;
}

.infoanddeletion .title {
    margin-bottom: 24px;
}

#info-and-deletion-form {
    width: 100%;
}

.infoanddeletion .form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 16px;
}

.infoanddeletion .grid-item {
    width: 100%;
}

.infoanddeletion .grid-button {
    grid-column: span 2;
    display: flex;
    justify-content: flex-end;
}

/* Custom select styling for info and deletion form */
.infoanddeletion .custom-select-wrapper {
    width: 100%;
    position: relative;
}

.infoanddeletion .custom-select-trigger {
    width: 100%;
    padding: 16px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #999;
    background: #ffffff;
    cursor: pointer;
    display: flex;
    justify-content: space-between;
    align-items: center;
    transition: border-color 0.3s ease;
    user-select: none;
    height: 58px;
    box-sizing: border-box;
}

.infoanddeletion .custom-select-trigger:hover {
    border-color: #999;
}

.infoanddeletion .custom-select-wrapper.active .custom-select-trigger {
    border-color: #999;
}

.infoanddeletion .custom-select-text {
    color: #999;
    flex: 1;
    font-size: 16px;
}

.infoanddeletion .custom-select-text.has-selection {
    color: #333;
}

.infoanddeletion .custom-select-arrow {
    display: flex;
    align-items: center;
    transition: transform 0.3s ease;
}

.infoanddeletion .custom-select-wrapper.active .custom-select-arrow {
    transform: rotate(180deg);
}

.infoanddeletion .custom-select-dropdown {
    position: absolute;
    top: calc(100% + 4px);
    left: 0;
    right: 0;
    background: #ffffff;
    border: 1px solid #ddd;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    z-index: 9999;
    display: none;
    max-height: 300px;
    overflow-y: auto;
}

.infoanddeletion .custom-select-wrapper.active .custom-select-dropdown {
    display: block;
}

.infoanddeletion .custom-select-options {
    padding: 8px 0;
}

.infoanddeletion .custom-select-option {
    display: flex;
    align-items: center;
    padding: 10px 20px;
    cursor: pointer;
    transition: background 0.2s ease;
    margin: 0;
}

.infoanddeletion .custom-select-option:hover {
    background: #f9f9f9;
}

.infoanddeletion .custom-select-option input[type="radio"] {
    display: none;
}

.infoanddeletion .custom-select-option span {
    color: #333;
    font-size: 16px;
}

.infoanddeletion .custom-select-option input[type="radio"]:checked + span {
    font-weight: 500;
}

/* Email input styling */
.infoanddeletion .form-group-seam {
    margin: 0;
}

.infoanddeletion .form-group-seam input[type="email"],
.infoanddeletion .form-group-seam input[type="text"] {
    width: 100%;
    padding: 16px 20px;
    border: 1px solid #ddd;
    border-radius: 8px;
    font-size: 16px;
    color: #333;
    background: #ffffff;
    outline: none;
    transition: border-color 0.3s ease;
    height: 58px;
    box-sizing: border-box;
}

.infoanddeletion .form-group-seam input:focus {
    border-color: #999;
}

.infoanddeletion .form-group-seam input::placeholder {
    color: #999;
}

/* Submit button */
.infoanddeletion .btn-submit {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 50px;
    padding: 12px 40px;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.infoanddeletion .btn-submit:hover {
    background: #000;
    color: #fff;
}

.infoanddeletion .btn-submit:active {
    background: #000;
    color: #fff;
}

/* Success message */
.infoanddeletion #successtext {
    margin-top: 24px;
    padding: 16px;
    background: #f0f9f4;
    border-radius: 8px;
    color: #2c7a4f;
}

.d-none {
    display: none;
}

/* Responsive */
@media (max-width: 768px) {
    .infoanddeletion .form-grid {
        grid-template-columns: 1fr;
    }

    .infoanddeletion .grid-button {
        grid-column: span 1;
        justify-content: stretch;
    }

    .infoanddeletion .btn-submit {
        width: 100%;
    }
}

/**************************************
 *  Application Form
 */

.application-form-container {
    width: 100%;
    max-width: 800px;
    margin: 0 auto;
}

.application-title {
    font-family: "Montserrat" !important;
    font-size: 28px !important;
    font-weight: 700 !important;
    line-height: 1.3 !important;
    color: #0B0B0B !important;
    margin: 0 0 32px 0 !important;
    word-break: break-word;
}

.application-form {
    width: 100%;
}

.application-form .form-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 20px;
    margin-bottom: 24px;
}

.application-form .grid-item {
    width: 100%;
}

.application-form .grid-full {
    grid-column: span 2;
}

.application-form .grid-button {
    display: flex;
    justify-content: flex-end;
    margin-top: 8px;
}

/* Form Labels */
.application-form .form-label {
    display: block;
    margin-bottom: 8px;
    font-family: "Montserrat";
    font-size: 14px;
    font-weight: 600;
    color: #0B0B0B;
}

/* Form Inputs */
.application-form .form-input,
.application-form .form-select,
.application-form .form-textarea {
    width: 100%;
    padding: 16px 20px;
    border: 1.5px solid #DADDDF;
    border-radius: 8px;
    font-size: 16px;
    font-family: "Montserrat";
    color: #0B0B0B;
    background: #FFF;
    outline: none;
    transition: border-color 0.3s ease;
    box-sizing: border-box;
}

.application-form .form-input:focus,
.application-form .form-select:focus,
.application-form .form-textarea:focus {
    border-color: #999;
}

.application-form .form-input::placeholder,
.application-form .form-textarea::placeholder {
    color: #999;
}

.application-form .form-select {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='24' height='24' viewBox='0 0 24 24' fill='none'%3E%3Cpath d='M6 9L12 15L18 9' stroke='%230B0B0B' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 16px center;
    background-size: 24px;
    padding-right: 48px;
}

.application-form .form-textarea {
    resize: vertical;
    min-height: 120px;
}

/* File Upload Styling */
.file-upload-wrapper {
    position: relative;
}

.file-upload-wrapper input[type="file"] {
    position: absolute;
    width: 0.1px;
    height: 0.1px;
    opacity: 0;
    overflow: hidden;
    z-index: -1;
}

.file-upload-label {
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 16px 20px;
    border: 1.5px dashed #DADDDF;
    border-radius: 8px;
    background: #F9FAFB;
    cursor: pointer;
    transition: all 0.3s ease;
}

.file-upload-label:hover {
    border-color: #999;
    background: #F5F5F5;
}

.file-upload-label svg {
    flex-shrink: 0;
}

.file-upload-label .file-name {
    font-family: "Montserrat";
    font-size: 16px;
    color: #666;
    flex: 1;
}

.file-upload-wrapper input[type="file"]:focus + .file-upload-label {
    border-color: #999;
}

/* Checkbox Styling */
.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
    margin-top: 4px;
    width: 18px;
    height: 18px;
    cursor: pointer;
    flex-shrink: 0;
}

.checkbox-label span {
    font-family: "Montserrat";
    font-size: 14px;
    color: #666;
    line-height: 1.6;
}

.checkbox-label a {
    color: #0B0B0B;
    text-decoration: underline;
}

.checkbox-label a:hover {
    color: #75FBA3;
}

/* Submit Button */
.btn-apply {
    background: #75FBA3;
    color: #0B0B0B;
    border: none;
    border-radius: 66px;
    padding: 16px 48px;
    font-family: "Montserrat";
    font-size: 16px;
    font-weight: 600;
    line-height: 19.2px;
    letter-spacing: 0.48px;
    cursor: pointer;
    transition: all 0.3s ease;
    white-space: nowrap;
}

.btn-apply:hover {
    background: #000;
    color: #fff;
}

.btn-apply:disabled {
    background: #DADDDF;
    color: #999;
    cursor: not-allowed;
}

/* Success and Error Messages */
.success-message,
.kw-error-message {
    margin-top: 24px;
    padding: 16px 24px;
    border-radius: 8px;
    font-family: "Montserrat";
    font-size: 16px !important;
}

.success-message {
    background: #F0F9F4;
    color: #2C7A4F;
    border: 1px solid #75FBA3;
}

.kw-error-message {
    background: #FEF2F2;
    color: #DC2626;
    border: 1px solid #FCA5A5;
}

/* Responsive */
@media (max-width: 768px) {
    .application-title {
        font-size: 22px !important;
        margin-bottom: 24px !important;
    }

    .application-form .form-grid {
        grid-template-columns: 1fr;
        gap: 16px;
    }

    .application-form .grid-full {
        grid-column: span 1;
    }

    .application-form .grid-button {
        justify-content: stretch;
    }

    .btn-apply {
        width: 100%;
    }
}

.is-hidden {
    display: none;
}

.consent-panel {
    margin-bottom: 1.25rem;
}

.consent-panel .checkbox-label {
    display: flex; gap: .5rem; align-items: flex-start;
}

.consent-panel input[type="checkbox"] {
    margin-top: .3rem;
}

/* Inline field error styling for application form */
.application-form .kw-field-error {
    display: block;
    color: #DC2626;
    font-size: .9rem;
    margin: 6px 0;
}

.application-form .grid-item.has-error .form-input,
.application-form .grid-item.has-error .form-select,
.application-form .grid-item.has-error .form-textarea,
.application-form .grid-item.has-error input[type="file"],
.application-form .grid-item.has-error input[type="email"],
.application-form .grid-item.has-error input[type="tel"],
.application-form .grid-item.has-error input[type="text"],
.application-form .grid-item.has-error select,
.application-form .grid-item.has-error textarea {
    border-color: #DC2626 !important;
    box-shadow: 0 0 0 1px rgba(220, 38, 38, 0.15);
}
