/*///////////////////////////////////////////////////////
// CompanyProfile Detail View
//////////////////////////////////////////////////////*/
.companyProfileDetail .introSlider {
    padding: 75px 0 50px 0;
}
.companyProfileDetail .introSlider .innerWrap {
    display: flex;
    flex-wrap: wrap;
}
.companyProfileDetail .introSlider .introSlideMedia {
    width: 100%;
}
.companyProfileDetail .introSlider .infoBox + .introSliderWrap .introSlides.slick-initialized {
    margin: 0;
}
.companyProfileDetail .introSlider .infoBox + .introSliderWrap .introSlides.slick-initialized .slick-slide {
    padding: 0;
}
.companyProfileDetail .rangeFaderGallery {
    padding: 50px 0;
}
.companyProfileDetail .detailHeaderLogo {
    background: var(--color-light);
}
.benefitsAccordion {
    padding: 30px 0 50px 0;
}
.companyProfileDetail .benefitLink a, .companyProfileDetail .benefitLink i:before {
    color: var(--color-elvipurple);
}
.detailHeaderJobs {
    display: none;
}
@media (hover: hover) and (pointer: fine) {
    .companyProfileDetail .benefitLink {
        cursor: pointer;
    }
    .companyProfileDetail .benefitLink:hover {
        background: var(--color-elvipurple);
    }
    .companyProfileDetail .benefitLink:hover a, .companyProfileDetail .benefitLink:hover i:before {
        color: #FFFFFF !important;
    }
    .detailJobsLink:hover *, .detailJobsLink:hover i:before {
        color: var(--color-elvipurple);
    }
}
@media (max-width: 767px) {
    .companyProfileDetail .introSlider {
        padding: 20px 0 40px 0;
    }
}

/*///////////////////////////////////////////////////////
// Career Groups
//////////////////////////////////////////////////////*/
.careerGroupsFooter {
    width: 100%;
}
.careerApprenticeships .careerItem, .careerStudies .careerItem {
    transition: width 150ms ease-in-out, opacity 300ms ease-in-out;
}
.careerApprenticeships .careerItem:nth-of-type(1n+6), .careerStudies .careerItem:nth-of-type(1n+5) {
    display: none;
    width: 0;
    opacity: 0;
}
.careerApprenticeships.showElements .careerItem:nth-of-type(1n+6), .careerStudies.showElements .careerItem.careerItem:nth-of-type(1n+5) {
    display: flex;
    width: auto;
    opacity: 1;
}
.showHideControl button {
    font-family: 'PT Sans', Arial, Helvetica, sans-serif;
    appearance: none;
    border: 0;
    background: none;
    font-size: 18px;
    line-height: 24px;
    color: var(--color-elvigray1);
    text-decoration: underline;
    margin-top: 20px;
    cursor: pointer;
}
.caShowHideButton.active .caShow, .csShowHideButton.active .csShow {
    display: none;
}
.caShowHideButton.active .caHide, .csShowHideButton.active .csHide {
    display: block;
}
.careerInternshipUrl {
    width: 100%;
    margin-top: 25px;
}
.careerInternshipUrl .icon-external-link::before {
    color: #fff;
}
@media (hover: hover) and (pointer: fine) {
    .showHideControl button:hover {
        color: var(--color-elvipurple);
        transition: color 150ms ease-in-out;
    }
}
@media (max-width: 767px) {
    .careerItem {
        /*width: auto;*/
        margin: 0 0 9px 0;
    }
    .careerApprenticeships.showElements .careerItem:nth-of-type(n+6), .careerStudies.showElements .careerItem.careerItem:nth-of-type(n+5) {
        width: 100%;
    }
    .showHideControl button {
        font-size: 15px;
        line-height: 18px;
        margin-top: 15px;
    }
}

/*///////////////////////////////////////////////////////
// Overlay Styles
//////////////////////////////////////////////////////*/
.companyProfileDetail .overlay .icon-close:before {
    color: var(--color-darkgray1);
}

/* Locations */
.companyProfileDetail .overlay {
    background: rgba(0,0,0,0.82);
}
.overlayContainer {
    display: none;
}
.overlayContainer.active {
    display: block;
}
.cpOverlay .overlayInner {
    max-width: 1400px;
    background: var(--color-light);
    border-radius: 7px;
    padding: 45px;
    min-height: 600px;
    display: flex;
    justify-content: center;
    align-items: center;
}
.cpCloseOverlay {
    position: absolute;
    right: 35px;
    top: 35px;
    cursor: pointer;
    padding: 10px;
}
.cpCloseOverlay i {
    font-size: 18px;
}
.cpLocationOverlay .overlayLogo {
    width: 170px;
    height: 170px;
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    top: -25px;
}
.cpLocationOverlay.active .overlayContent > div {
    display: block;
}
.cpLocationHeader h2 {
    margin-bottom: 14px;
}
.cpCurrentLocation {
    margin-bottom: 24px;
}
.cpCurrentLocation.iconWrap i.icon-marker {
    font-size: 14px;
}
.cpCurrentLocation.iconWrap i.icon-marker:before {
    color: var(--color-elvigray1);
}


/* Social Media */
.cpSocialList {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
}
.cpSocialOverlay.active .overlayContent > div {
    display: flex;
    justify-content: center;
}
.cpSocialItem {
    height: 50px;
    border: 1px solid var(--color-elvigray3);
    border-radius: 5px;
    text-decoration: none;
    display: flex;
    margin: 0 15px 15px 0;
}
.cpSocialLogo, .cpSocialTitle {
    display: flex;
    justify-content: center;
    align-items: center;
}
.cpSocialLogo {
    width: 51px;
    border-right: 1px solid var(--color-elvigray3);
}
.cpSocialLogo img {
    max-width: 75%;
    max-height: 75%;
    height: auto;
    object-fit: contain;
}
.cpSocialTitle {
    padding: 0 20px;
}
.cpSocialTitle span {
    font-size: 18px;
    line-height: 24px;
    color: var(--color-elvigray1);
}
@media (hover: hover) and (pointer: fine) {
    .cpCloseOverlay:hover i:before, .cpFurtherLocations:hover span, .cpFurtherLocations:hover i:before {
        color: var(--color-elvipurple);
        transition: color 150ms ease-in-out;
        cursor: pointer;
    }
    .cpSocialItem:hover .cpSocialTitle span {
        color: var(--color-elvipurple);
        transition: color 150ms ease-in-out;
    }
}
@media (max-width: 1460px) {
    .cpOverlay .overlayInner {
        width: calc(100% - 60px);
    }
}
@media (max-width: 767px) {
    .cpOverlay .overlayInner {
        width: calc(100% - 30px);
        min-height: 400px;
        padding: 30px;
        top: 40px;
    }
    .cpCloseOverlay {
        right: 15px;
        top: 15px;
    }
    .cpLocationOverlay .overlayLogo {
        width: 120px;
        height: 120px;
    }
    .cpSocialItem {
        height: 40px;
    }
    .cpSocialLogo {
        width: 41px;
    }
    .cpSocialTitle {
        padding: 0 10px;
    }
    .cpSocialTitle span {
        font-size: 16px;
        line-height: 21px;
    }
}

/*///////////////////////////////////////////////////////
// Company Profile Consent
//////////////////////////////////////////////////////*/
.btnCompanyConsent {
    position: absolute;
    width: 100%;
    height: 100%;
    left: 0;
    top: 0;
}
.companyProfileConsent {
    padding: 150px 0 100px 0;
    background: var(--color-elvigray4);
}
.companyProfileConsent .innerWrap {
    background: #ffffff;
    border-radius: 40px;
    padding: 60px;
}
.cpConsentTable {
    display: table;
    width: 100%;
    margin-top: 100px;
}
.cpConsentRow {
    display: flex;
    border-bottom: 1px solid var(--color-elvigray3);
    padding: 25px 0;
}
.cpConsentRow:last-child {
    border: 0;
}
.cpConsentCell:nth-child(1) {
    width: 20%;
}
.cpConsentCell:nth-child(2) {
    width: 80%;
}
.cpConsentHeader {
    font-weight: 600;
}
.cpConsentCell span {
    white-space: nowrap;
}
.cpConsentCell img {
    max-width: 100%;
    max-height: 100%;
    height: auto;
    border: 1px solid var(--color-elvigray3);
    margin-bottom: 25px;
}
.cpConsentInfobox img {
    max-width: 400px;
    /*aspect-ratio: 16 / 9;*/
    display: block;
    margin: 50px 0 0 0;
}
.formBlock > span, #frc-captcha-response-error {
    font-size: 14px;
    font-weight: 600;
    padding-bottom: 6px;
    display: inline-block;
    color: #555;
}
.formBlock.formCheck > span, .formBlock.formCheck > span ul li {
    font-size: 16px;
    font-weight: 400;
    line-height: 1.5em;
}
.formBlock.formCheck, .formCheck.error span {
    border: 0 !important;
}
.formBlock.formCheck.error span:before, .formSignature.error .signature-pad--body canvas, .frc-captcha.error, .frc-captcha.error-highlight {
    border: 1px solid #c0392b !important;
}
#frc-captcha-response-error {
    color: #c0392b;
}
.formBlock.formCheck > span ul {
    padding-left: 15px;
}
.formBlock.formCheck > span ul li {
    font-size: 16px;
    font-weight: 400;
}
.cpConsentForm {
    margin-bottom: 100px;
}
.cpConsentForm h3 {
    margin-bottom: 25px;
}
.cpConsentForm span h3 {
    margin-bottom: 0;
    font-size: 20px !important;
}
.cpConsentForm span h3:first-child {
    padding-top: 0 !important;
}
.cpConsentForm .innerWrap {
    padding: 100px 60px;
}
.cpConsentForm .formBlock {
    margin-bottom: 20px;
}
.cpConsentForm .formCheck span.error {
    display: none !important;
}
/*.cpConsentMore {
    opacity: 0;
    height: 0;
    transition: all 250ms ease;
}
.cpConsentMore.active {
    opacity: 1;
    height: 100%;
}*/
/*.cpConsentForm .formBlock > span {
    font-weight: 400;
}*/
.cpConsentForm .formBlock > span strong {
    font-weight: 600;
}
/*
.formSignature canvas {
    width: 100%;

    max-width: 500px;
}*/
.signature-pad--footer {
    text-align: right;
    width: 600px;
}
#consentSignature {
    opacity: 0;
    height: 0;
    width: 0;
    margin: 0;
    padding: 0;
}
#cpConsentSend {
    cursor: pointer;
}


/* ConsentSaved Tempplate */
.consentSaved {
    padding-top: 170px;
    background: var(--color-elvigray4);
    min-height: 100vh;
}
.consentSaved .innerWrap {
    max-width: 960px;
    background: #fff;
    padding: 60px;
    border-radius: 40px;
}


/* Internal Notice */
.internalNotice {
    position: fixed;
    z-index: 1000;
    bottom: 0;
    background: var(--color-elvi-companies);
    text-align: center;
    padding: 10px 20px;
}
.internalNotice .innerWrap {
    display: flex;
    justify-content: center;
    align-items: center;
}
.noticeContent span {
    font-family: 'DIN', Arial, Helvetica, sans-serif;
    font-size: 24px;
    color: #ffffff;
}
.noticeClose {
    cursor: pointer;
    margin: 6px 0 0 20px;
}
.noticeClose i:before {
    color: #ffffff;
    font-size: 22px;
}