:root {
  --primary-color: #3dcd58;
}


body {
  font-family: "Nunito", sans-serif;
  margin: 0;
  margin-top: 80px;
  box-sizing: border-box;
}

h1 {
  font-size: clamp(2em, 5vw, 3em); /* minimum 2em, preferred 5vw, maximum 3em */
  font-weight: 700;
}

h2 {
  font-size: clamp(1.5em, 4vw, 2.25em); /* minimum 1.5em, preferred 4vw, maximum 2.25em */
  font-weight: 700;
}

h3 {
  font-size: clamp(1em, 3vw, 1.6em);
  font-weight: 700;
}

.vacancy-details .accordion-title,
h4 {
  font-size: clamp(1em, 2.5vw, 1.5em) !important;
  font-weight: 700 !important;
}

h5 {
  font-size: clamp(0.875em, 2vw, 1.3125em);
  font-weight: 700;
}

a,
h6 {
  font-size: clamp(0.75em, 1.5vw, 1.125em);
  font-weight: 700;
}
    .jobcard a:hover {
        color: white !important;
        text-decoration: underline !important;
    }

a.backbutton:hover {
    text-decoration: none !important;
}


header nav.navbar {
    position: fixed;
    top: 0px;
    width: 100vw !important;
    margin-bottom: 100% !important;
    box-shadow: 0 4px 32px 0 rgba(0, 0, 0, .25);
    z-index: 1000;
}
nav.loginsubnav a {
    color: hsla(0, 0%, 100%, 0.8);
}

nav.loginsubnav a.active {
    color: white !important
}
/* Responsiveness for Nav on mid-screen widths */
@media (max-width: 1400px) and (min-width: 990px) {
    .navbar-brand img {
        max-height: 30px !important;
    }

    .navbar-nav .nav-item {
        margin: 6px !important;
    }
}

@media (max-width: 1200px) and (min-width: 990px) {
    .navbar-brand img {
        max-height: 20px !important;
    }

    .navbar .navbar-nav .nav-item .nav-link, .navbar .nav-buttons a.btn {
        font-size: 12px !important
    }
}
/* Limit the logo height */
.navbar-brand img {
    max-height: 40px;
}

    /* Adjust logo for smaller screens */
    @media (max-width: 550px) {
        a.navbar-brand {
            width: 80%
        }
    }

    @media (max-width: 400px) {
        a.navbar-brand {
            width: 70%
        }
    }


    /* Add spacing between nav links */
    .navbar-nav .nav-link {
        padding-left: 1rem;
        padding-right: 1rem;
    }

    /* Style the nav-buttons */
    .nav-buttons .btn {
        margin-left: 0.5rem;
    }

    /* Adjust nav-buttons on smaller screens */
    @media (max-width: 991.98px) {
        .nav-buttons {
            flex-direction: column;
            width: 100%;
            margin-top: 1rem;
        }

            .nav-buttons .btn {
                width: 100%;
                margin: 0.25rem 0;
            }
    }

    .navbar-dark .navbar-nav .nav-link {
        color: hsla(0, 0%, 100%, 0.95);
    }

        .navbar-dark .navbar-nav .nav-link:focus,
        .navbar-dark .navbar-nav .nav-link:hover {
            color: hsla(0, 0%, 100%, 1);
        }

        .navbar-dark .navbar-nav .nav-link.disabled {
            color: hsla(0, 0%, 100%, 0.5);
        }

        .navbar-dark .navbar-nav .active > .nav-link,
        .navbar-dark .navbar-nav .nav-link.active,
        .navbar-dark .navbar-nav .nav-link.show,
        .navbar-dark .navbar-nav .show > .nav-link {
            color: #fff;
        }

    .navbar-dark .navbar-toggler {
        color: hsla(0, 0%, 100%, 0.85);
        border-color: hsla(0, 0%, 100%, 0.1);
    }

    .navbar-dark .navbar-toggler-icon {
        background-image: url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='30' height='30'%3E%3Cpath stroke='rgba(255, 255, 255, 0.5)' stroke-linecap='round' stroke-miterlimit='10' stroke-width='2' d='M4 7h22M4 15h22M4 23h22'/%3E%3C/svg%3E");
    }

    .navbar-dark .navbar-text {
        color: hsla(0, 0%, 100%, 0.85);
    }

        .navbar-dark .navbar-text a,
        .navbar-dark .navbar-text a:focus,
        .navbar-dark .navbar-text a:hover {
            color: #fff;
        }



    .list-group-flush > .list-group-item,
    .nav-tabs .nav-link,
    p {
        font-size: clamp(0.5em, 2.5vw, 1em); /* minimum 1em, preferred 2.5vw, maximum 1.5em */
    }

.navbar-dark .navbar-nav .nav-link, .nav-buttons a.btn {
    font-size: clamp(0.4em, 0.9em, 1.2em) !important; /* minimum 1em, preferred 2.5vw, maximum 1.5em */

}

.navbar-dark .navbar-nav .nav-link {
    font-weight: 500;
    padding: 0px;
}

    .nav-tabs .nav-link {
        font-size: clamp(0.7em, 2.5vw, 1.5em); /* minimum 1em, preferred 2.5vw, maximum 1.5em */
        font-weight: 600;
    }

    .navbar-nav .nav-item {
        position: relative;
        margin: 10px;
    }

    .navbar-nav a.nav-link:after {
        content: "";
        position: absolute;
        height: 2.5px;
        width: 0%;
        background-color: rgba(255, 255, 255, 0.5);
        bottom: 0px;
        left: 50%;
        right: 50%;
        transition: all ease-in-out 0.3s;
    }

    .navbar-nav a.nav-link:hover:after {
        width: 100%;
        left: 0%;
        right: 0%;
        background-color: rgba(255, 255, 255, 1);
    }

    .bg-light {
        background-color: #3dcd58 !important;
    }

.bg-grey-schneider {
    background: #f3f2f2 !important;
}

.btn {
    border-radius: 50px;
    padding-inline: 1rem;
    padding-block: 0.35rem;
    border: 0px;
    font-size: clamp(0.8em, 2.5vw, 1em);
    font-weight: 700;
    color: #000000;
}

.rz-button-md .rz-button-text {
    line-height: 1.2rem !important;
}

.rz-button-md {
    font-size: 1.0625rem;
    font-weight: normal;
    padding: 0.5rem 2rem !important;
    height: fit-content !important;
}

    .modal-card-button {
        border-top-right-radius: 0;
        border-top-left-radius: 0;
    }

    .btn-lg {
        padding-inline: 2rem;
        padding-block: 1.1rem;
        font-size: clamp(1.2em, 2.5vw, 1em);
        font-weight: 800;
    }

    .bg-secondary,
    .btn-secondary {
        background-color: #ffd100 !important;
    }

    .text-secondary {
        color: #ffd100 !important;
    }

    .btn-primary-2,
    .bg-primary-2 {
        background-color: #009530 !important;
    }

    .text-warning {
        color: #009530 !important;
    }

    .text-primary {
        color: #009530 !important;
    }

    .text-danger {
        color: #707070 !important;
    }

    .text-info {
        color: #035970 !important;
    }

    .text-muted {
        color: #9fa0a4 !important;
    }

    .bg-muted {
        background-color: #9fa0a474 !important;
    }

    .btn-primary,
    .bg-primary {
        background-color: #3dcd58 !important;
    }

    .text-success {
        color: #0e1f2c !important;
    }

    .bg-success {
        background-color: #0e1f2c !important;
    }

    .btn-primary:hover {
        color: #fff;
        background-color: #3dcd58;
        border-color: transparent;
    }

    .btn-secondary:hover {
        background-color: #ffd100;
    }

    .home-about p.btn,
    .home-about .col-12.btn {
        color: #ffffff;
        border-radius: 20px;
    }

    .rounded-20 {
        border-radius: 20px;
    }

    .rounded-25 {
        border-radius: 25px;
    }

    @media screen and (max-width: 662px) {
        .btn-lg {
            padding-inline: 2rem;
            padding-block: 0.8rem;
            font-size: clamp(1em, 2.5vw, 1em);
            font-weight: 800;
        }
    }

    .h_160 {
        min-height: 160px;
        display: flex;
        justify-content: center;
        align-items: center;
    }

    /* ========================= HOME PAGE =========================== */

    .about-sustainability {
        display: grid;
        grid-template-columns: repeat(2, 2fr);
        grid-template-rows: repeat(3, max-content);
        gap: 1rem;
        justify-content: space-between;
    }

    .card.one {
        grid-area: 1/1 /2 /2;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .card.two {
        grid-area: 1/2 /2 /3;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .card.three {
        grid-area: 2/1 /3 /2;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .card.four {
        grid-area: 2/2 /3 /3;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .card.five {
        grid-area: 3/1 /4 /2;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .card.six {
        grid-area: 3/2 /4 /3;
        justify-content: center;
        padding: 0.5rem;
        border-radius: 15px;
    }

    .home-latest-opportunities .carousel-inner .list-group-item,
    .home-latest-opportunities .card-body .list-group-item {
        padding-top: 0;
    }

    .img-fluid {
        width: 100%;
        height: auto;
    }

    .navbar-brand img {
        min-width: 50px;
        max-width: 100%;
        height: auto;
    }

    .nav-section {
        display: flex;
        justify-content: space-between;
        flex: 1;
        width: 100%;
    }

    .home-latest-opportunities:not(.values) .card {
        border: 0.25rem solid #009530;
        border-radius: 20px;
        min-width: 200px;
        max-width: 364px;
        /*min-height: 320px;*/
    }

    .home-latest-opportunities .card-footer,
    .success-card.card-footer {
        border-bottom-left-radius: calc(30px - 1rem);
        border-bottom-right-radius: calc(30px - 1rem);
    }

    .benefitCard {
        width: 90%;
    }

        .benefitCard img {
            max-height: 150px;
            width: auto;
        }

    .home-latest-opportunities .list-group-item {
        padding-block: 0.8rem;
        padding-left: 0rem;
    }

    .home-latest-opportunities .card-body {
        padding-block: 0rem;
    }


    .carousel-inner {
        position: relative;
        width: 100%;
        overflow: hidden;
        display: flex;
        gap: 1rem;
    }

    .carousel-indicators {
        margin-top: 2rem;
        bottom: -60px;
    }

        .carousel-indicators li {
            width: 20px;
            height: 20px;
            border-radius: 50%;
            background-color: #009530;
        }

    .values .carousel-indicators li {
        background-color: white;
    }

    .nav-tabs .nav-link {
        border-top-left-radius: 1rem;
        border-top-right-radius: 1rem;
    }

    .nav-link {
        display: block;
        padding: 0.5rem 0.4rem;
    }

    .nav-tabs .nav-item.show .nav-link,
    .nav-tabs .nav-link.active {
        color: #0e1f2c;
        background-color: #ffffff !important;
        border-color: transparent;
    }

    .nav-tabs .nav-item .nav-link,
    .nav-tabs .nav-link {
        color: #0e1f2c;
        background-color: #ffd100;
        border-color: black;
        border-bottom-color: transparent;
        padding: 10px 20px;
        min-width: 200px;
        text-align: center;
    }

    .nav-tabs {
        background-color: #009530;
    }

    .tab-pane {
        background-color: #fff;
    }

    .tab-pane {
        margin: 0.8rem;
        padding: 1rem;
        border: none;
    }

    .support .tab-pane {
        border: none;
    }

    .home-about-quick-links .card {
        display: grid;
        grid-template-columns: 100%;
        grid-template-rows: 4fr;
        margin-bottom: 2rem;
    }

        .home-about-quick-links .card img {
            grid-area: 1 / 1 / 4 / 2;
        }

        .home-about-quick-links .card::after {
            content: "";
            position: absolute;
            top: 0;
            box-shadow: 220px 220px 200px 4000px rgba(27, 61, 88, 0.5) inset;
        }

.image-container {
    position: relative;
    display: inline-block; /* Adjust as needed: inline-block, block, or flex */
}

    .image-container img {
        display: block; /* Ensures there's no gap below the image */
    }

.overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 255, 255, 0.3); /* Whitish transparent hue */
    pointer-events: none; /* Ensure interaction is with the underlying image */
    z-index: 1; /* Adjust as needed to sit above the image */
}



.home-about-quick-links .card .card-body {
    /*grid-area: 2 / 1 / 6 / 2;*/
    background-color: #e6e7e7;
    min-height: clamp(8em, 2.5vw, 1.5em);
    padding-top: 0px;
    padding-bottom: 0px;
}

            .home-about-quick-links .card .card-body p > img {
                width: clamp(2em, 2.5vw, 1.5em);
                height: auto;
            }

        .home-about-quick-links .card a {
            color: #000000;
        }

    .v-culture-benefits .card {
        align-items: center;
    }

    .home-latest-opportunities.values .card {
        border: none;
        border-radius: 20px;
    }

    /*============================================ Success stories 😊😊😊😊 ============================================*/

    .aavashQuote {
        display: grid;
        grid-template-columns: repeat(8, 1fr);
        grid-template-rows: repeat(8, max-height);
    }

    .avash {
        grid-area: 1/1/8/5;
    }

    .aavash-quote-text {
        grid-area: 2/3/6/8;
        /* font-size: clamp(0.9em, 2.5vw, 1em); */
    }

    .aavash-quote {
        grid-area: 6/3/7/8;
    }

    @media screen and (max-width: 992px) {
        .aavash-quote-text {
            grid-area: 2/4/5/8;
            font-size: clamp(0.9em, 2.5vw, 1em);
        }

        .aavash-quote {
            grid-area: 5/5/7/7;
        }
    }

    .aavashQuote {
        display: grid;
        grid-template-columns: repeat(8, 1fr);
        grid-template-rows: repeat(8, max-height);
    }

    .avash {
        grid-area: 1/1/8/5;
    }

    .aavash-quote-text {
        grid-area: 2/3/6/8;
    }

        .aavash-quote-text h3 {
            font-size: clamp(2.3em, 2.5vw, 1em);
        }

    .aavash-quote {
        grid-area: 6/3/7/8;
    }

    @media screen and (min-width: 572px) and (max-width: 992px) {
        .aavash-quote-text p {
            font-size: clamp(1.2em, 2.5vw, 1em);
        }
    }

    @media screen and (max-width: 992px) {
        .aavashQuote {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            grid-template-rows: repeat(8, max-content);
        }

        .avash {
            grid-area: 1/1/8/5;
        }

        .aavash-quote-text {
            grid-area: 2/4/5/8;
        }

        .aavash-quote {
            grid-area: 5/5/7/7;
        }
    }

    @media screen and (min-width: 992.1px) {
        .aavash-quote-text {
            grid-area: 2/3/6/8;
        }

        .aavash-quote {
            grid-area: 6/4/7/7;
        }
    }

    @media screen and (min-width: 992.1px) and (max-width: 1399px) {
        .aavash-quote-text {
            grid-area: 2/4/6/8;
        }

        .aavash-quote {
            grid-area: 6/5/7/7;
        }
    }

    section.success-card .card {
        display: grid;
        margin-bottom: 8rem;
        background: #f3f2f2
    }

    section.success-card .modal-body .card {
        display: inline-block;
    }

    section.success-card .card-footer {
        align-self: stretch;
    }

    section.success-card .card > img {
        justify-self: center;
        position: relative;
        bottom: 40%;
    }

    .tanya-quote-container {
        display: grid;
        grid-template-columns: repeat(8, 1fr);
        grid-template-rows: repeat(8, max-height);
    }

    .tanya {
        grid-area: 1/6/8/8;
    }

    .tanya-quote-text {
        grid-area: 2/3/6/6;
    }

    .tanya-quote {
        grid-area: 6/3/7/6;
    }

    .tanya-quote-text h3 {
        font-size: clamp(2.3em, 2.5vw, 1em);
    }

    @media screen and (max-width: 713px) {
        .tanya-quote-container {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            grid-template-rows: repeat(8, max-content);
        }

        .tanya {
            grid-area: 1/6/8/-1;
        }

        .tanya-quote-text {
            grid-area: 2/1/5/6;
        }

        .tanya-quote {
            grid-area: 5/2/7/5;
        }
    }

    @media screen and (min-width: 714px) and (max-width: 992px) {
        .tanya-quote-container {
            display: grid;
            grid-template-columns: repeat(8, 1fr);
            grid-template-rows: repeat(8, max-content);
        }

        .tanya {
            grid-area: 1/6/8/-1;
        }

        .tanya-quote-text {
            grid-area: 2/2/5/6;
        }

        .tanya-quote {
            grid-area: 5/3/7/5;
        }
    }

    @media screen and (min-width: 992.1px) and (max-width: 1399px) {
        .tanya-quote-text {
            grid-area: 2/2/6/6;
        }

        .tanya-quote {
            grid-area: 6/3/7/5;
        }

        .tanya-quote-text h3 {
            font-size: clamp(1.4em, 2.5vw, 1em);
        }
    }

    .accordion .card .card-header p a {
        display: grid;
        gap: 0rem 1rem;
        align-items: center;
        grid-template-columns: max-content 3fr max-content;
        grid-template-rows: max-content;
    }

    .accordion > .card > .card-header .accordion-icon {
        grid-area: 1/ 1/ 2/ 2;
    }

    .accordion > .card > .card-header p.accordion-title {
        grid-area: 1/ 2/ 2/ 3;
    }

    .accordion > .card > .card-header a .fa-solid {
        grid-area: 1/ 3/ 2/ 4;
    }

    .accordion > .card > .card-header a:hover {
        text-decoration: none;
    }

    .accordion > .card > .card-header a.collapsed .fa-solid {
        transition: 0.4s;
        -webkit-transform: rotate(0deg);
        -ms-transform: rotate(0deg);
        transform: rotate(0deg);
        color: #ffd100;
        font-size: 1.4rem;
    }

    .accordion > .card > .card-header a:not(.collapsed) .fa-solid {
        transition: 0.4s;
        -webkit-transform: rotate(225deg);
        -ms-transform: rotate(225deg);
        transform: rotate(225deg);
        color: #ffd100;
        font-size: 1.4rem;
    }

    .accordion > .card:has(a:not(.collapsed)) {
        margin-bottom: 1rem;
    }

    .accordion > .card > .card-header {
        border-radius: 100px;
    }

    .accordion > .card > .card-header {
        background-color: var(--primary-color);
    }

        .accordion > .card > .card-header a {
            color: var(--white);
        }

    .accordion > .card {
        margin-bottom: 1rem;
        border: 0px;
    }

        .accordion > .card > .card-header a.collapsed .fa-solid {
            transition: 0.4s;
            -webkit-transform: rotate(0deg);
            -ms-transform: rotate(0deg);
            transform: rotate(0deg);
        }

    /* Vacancy =========================================== */
    /***** Track Styles *****/

    input[type="range"] {
        width: 100%;
        background: #281432;
    }
        /***** Chrome, Safari, Opera, and Edge Chromium *****/
        input[type="range"]::-webkit-slider-runnable-track {
            background: #281432;
            height: 0.5rem;
        }

        /******** Firefox ********/
        input[type="range"]::-moz-range-track {
            background: #281432;
            height: 0.5rem;
        }

        /***** Thumb Styles *****/
        /***** Chrome, Safari, Opera, and Edge Chromium *****/
        input[type="range"]::-webkit-slider-thumb {
            -webkit-appearance: none; /* Override default look */
            appearance: none;
            margin-top: -5px; /* Centers thumb on the track */
            background-color: #009530;
            height: 2rem;
            width: 1rem;
            cursor: grab;
        }

        /***** Thumb Styles *****/
        /***** Firefox *****/
        input[type="range"]::-moz-range-thumb {
            border: none; /*Removes extra border that FF applies*/
            border-radius: 0; /*Removes default border-radius that FF applies*/
            background-color: #009530;
            height: 2rem;
            width: 2rem;
            border-radius: 50%;
            cursor: grab;
        }

        input[type="range"]::after {
            content: "";
        }

    .accordion-title {
        font-size: 1rem;
    }

    .back-arrow {
        max-width: 3%;
    }

    @media screen and (max-width: 597px) {
        .accordion.vacancy-details .btn-link img.img-fluid {
            width: 60%;
            height: auto;
        }

        .accordion > .card > .card-header a:not(.collapsed) .fa-solid,
        .accordion > .card > .card-header a.collapsed .fa-solid {
            font-size: 1rem;
        }

        a.btn img {
            width: 15% !important;
        }

        .btn-lg {
            padding-inline: 0.6rem;
            padding-block: 0.4rem;
            font-size: clamp(0.5em, 2.5vw, 1em);
            font-weight: 800;
        }

        .btn {
            padding-inline: 0.6rem;
            padding-block: 0.4rem;
            font-size: clamp(0.5em, 2.5vw, 1em);
            font-weight: 800;
        }

        .nav-buttons .btn {
            padding-inline: 0.7rem;
            padding-block: 0.2rem;
            font-size: clamp(0.9em, 2.5vw, 1em);
            font-weight: 800;
        }

        .accordion > .card > .card-header {
            padding-block: 0.3rem;
            padding-inline: 0.8rem;
            border-radius: 60px;
        }

        .nav-tabs .nav-link {
            font-size: clamp(0.7em, 2.5vw, 1.5em);
            font-weight: 600;
        }

        .back-arrow {
            max-width: 8%;
        }
    }


#openchat .material-symbols-outlined, #chatPopup .material-symbols-outlined {
    font-size: 15px !important;
}
/*********** Radzen Overrides ****************************/
.rz-calendar-inline {
    border: none;
}


@keyframes bounce {
    0%, 100% {
      transform: translateY(-25%);
      animation-timing-function: cubic-bezier(0.8,0,1,1);
    }
  
    50% {
      transform: none;
      animation-timing-function: cubic-bezier(0,0,0.2,1);
    }
  }
  
  .animate-bounce-new {
    animation: bounce 1s infinite;
  }
