/* = Body
----------------------------------------------------------------------------------------------------------------- */
html { min-height: 100%; position: relative; }
body { height: 100%; }
img { vertical-align: middle; }

/* = Header
----------------------------------------------------------------------------------------------------------------- */
.header { -moz-border-radius: 2.625em; -webkit-border-radius: 2.625em; border-radius: 2.625em; zoom: 1; -moz-animation-duration: 0.2s; -webkit-animation-duration: 0.2s; animation-duration: 0.2s; -moz-animation-timing-function: ease-out; -webkit-animation-timing-function: ease-out; animation-timing-function: ease-out; background-color: #fff; font-size: 1rem; left: 0; padding: 1.5625rem 1.5rem; position: absolute; margin-top: 1.875rem; margin-right: 1.5rem; margin-left: 1.5rem; right: 0; top: 0; z-index: 200; }
.header::after { clear: both; content: "."; display: block; height: 0; overflow: hidden; visibility: hidden; }
.header.stickyInactive { -moz-animation-name: sticky-disappear; -webkit-animation-name: sticky-disappear; animation-name: sticky-disappear; position: absolute; top: 0; }
.header.stickyActive { -moz-animation-name: sticky-appear; -webkit-animation-name: sticky-appear; animation-name: sticky-appear; position: fixed; top: 0; }
.header .logo { float: left; }

.header > .menu { clear: both; margin-top: 3.5rem; }
.menuExtended .header > .menu { display: flex; width: 100%; flex-wrap: wrap; }
.header > .menu ul:nth-child(2) { order: 1; width: 100%; display: block; }
.header > .menu ul.lang-nav { order: 2; width: 100%; display: block; }
.header > .menu ul li { margin-bottom: 8px; }
.header > .menu .flag-icons ul li { margin-bottom: 0; }
.header > .menu ul li.apply { display: inline-block; }
.header > .menuTrigger { float: right; margin-top: 2px; margin-right: 5px; }

@media (min-width: 23.7rem) {
    .header { margin-right: 1.875rem; margin-left: 1.875rem; }
}

@media (min-width: 63.75rem) {
    .header { margin-left: 2.5rem; margin-top: 2.5rem; padding: 1.25rem 2.25rem; right: auto; width: auto; white-space: nowrap; -webkit-box-shadow: 10px 12px 15px 0px rgba(0, 0, 0, 0.03);  box-shadow: 10px 12px 15px 0px rgba(0, 0, 0, 0.03); }
    .header > .menu { clear: none; display: inline-block; margin-top: 0; vertical-align: middle; }
    .header > .menu ul:nth-child(2),
    .header > .menu ul.lang-nav { display: inline-block; vertical-align: middle; width: auto; }
    .header > .menu ul li { margin-bottom: 0; }
    .header .logo { display: inline-block; float: none; vertical-align: middle; }

    .menuExtended .header > .menu { display: inline-block; }

    .header > .menu > .menuList > .menuItem, .header > .menu > ul > li { display: inline-block; vertical-align: middle; margin: 0 4px; }
    .header > .menu > .menuList > .menuItem, .header > .menu > ul > li:last-child { margin-right: 0; }
}

@media (min-width: 63.75rem) and (max-width: 80rem) {
    .header { margin-left: 2rem; margin-top: 2rem; margin-right: 2em; padding: 1.25rem 2rem;  }

}

@media screen and (max-width: 360px) {
    .header {margin-top: 1.6rem; margin-left: 1.2rem; margin-right: 1.2rem;padding: 1.4rem 1.3rem;}
}

/* = Sidebar
----------------------------------------------------------------------------------------------------------------- */
.sidebar { background-color: #ffc20d; overflow: hidden; }
.sidebarLight { background-color: #fff; }

@media (min-width: 63.75rem) {
    .sidebar { height: 100vh; overflow: visible; }
    .sidebarSticky { position: fixed; right: 0; top: 0; }
}

/* = Footer
----------------------------------------------------------------------------------------------------------------- */
.footer { background-color: #fff; color: #333; font-size: 0.75rem; overflow: hidden; padding-top: 1.25rem; z-index: 100; }
.home .footer { background-color: #ffc20d; }
.pageCareer .footer { background: #ffc20d; }

.footer .copyright { display: block; margin-bottom: 1.75rem; padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 1.15rem; }
.footer .menu { margin-bottom: 1.5rem; color: inherit; display: block; text-align: left; }
.footer .menu:last-child { margin-bottom: 1.25rem; }
.footer .menuLink { color: inherit; }
.footer .menuLink:hover { color: #009132; }


@media (min-width: 23.7rem) {
    .footer .copyright { padding-left: 2.5rem; padding-right: 2.5rem; }
    .footer .menu { padding-left: 1rem; padding-right: 1rem; }
}

@media (min-width: 63.75rem) {
    .footer { background-color: transparent; bottom: 0; left: 0; padding-top: 0; position: absolute; right: 0; }
    .footer .menu { margin-bottom: 1.25rem; }

    .pagePeople .footer { color: #fff; }

    .pageCareers .footer { color: #fff; }
    .pageCareer .footer { background-color: transparent; }
    .footer .copyright { padding-top: 0; padding-left: 1.875rem; padding-right: 1.875rem; }
    .footer .menu { padding-left: .375rem; padding-right: .375rem; text-align: right; }
    .pageHasSidebar .footer .menu { bottom: 0; position: fixed; right: 0; }
}

/* = Apply
----------------------------------------------------------------------------------------------------------------- */
#apply .footer { display: none; }

/* = Careers
----------------------------------------------------------------------------------------------------------------- */
.pageCareers { background-color: #009132; }
.pageCareers main { color: #fff; margin-left: auto; margin-right: auto; max-width: 47.5rem; padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 4rem; opacity: 0; -webkit-transform: translateY(-5%); transform: translateY(-5%); }
.pageCareers main h1 { color: #ffc20d; }
.pageCareers main h2, .pageCareers main h3 { color: #fff; }
.pageCareers main h2 { margin-top: 5rem; }

.pageCareers.doAnimate main { opacity: 1; -webkit-transform: translateY(0); transform: translateY(0); -webkit-transition: all .5s ease-in-out; transition: all .5s ease-in-out; }

.pageCareers .cols.colsMain { display: flex; width: 100%; flex-wrap: wrap; }
.pageCareers .colsMain .colTwoThirds { order: 2; display: block; width: 100%; }
.pageCareers .colsMain .sidebar { order: 1; width: 100%; height: 70vh; }

.pageCareers .colThird.sidebar .heroContent { padding-top: 30px; padding-bottom: 30px; margin-top: 35vh; }
.pageCareers .colThird.sidebar .heroBackdrop img { object-position: 50% 15%; }


@media (min-width: 22.5rem) {
    .pageCareers main { padding-top: 4.5rem; }
}

@media (min-width: 23.7rem) {
    .pageCareers main { padding-left: 2.5rem; padding-right: 2.5rem; padding-top: 5rem; }
}

@media (min-width: 30rem) {
    .pageCareers main { padding-top: 6rem; }
}

@media (max-width: 30rem) {
    .pageCareers main h1 { font-size: 40px; }
}

@media (min-width: 48rem) {
    .pageCareers main h2 { margin-top: 7rem; }
    .pageCareers .colThird.sidebar .heroContent { margin-top: 0; }
}

@media (min-width: 63.75rem) {
    .pageCareers main { max-width: 48.75rem; padding-left: 2.5rem; padding-right: 2.5rem; padding-top: 14rem; }

    .pageCareers .cols.colsMain { display: block; }
    .pageCareers .colsMain .colTwoThirds { width: 66.66666666666667%; }
    .pageCareers .colsMain .sidebar { width: 33.3333333333333%; height: 100vh; }
}

/* = Career
----------------------------------------------------------------------------------------------------------------- */
.pageCareer { background-color: #ffc20d; overflow-y: scroll; }
.pageCareer main { margin-left: auto; margin-right: auto; max-width: 47.5rem; padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 4rem; padding-bottom: 2.5rem; }
.pageCareer main h1 sup { font-size: .4em; padding: 0 12px; line-height: 1; }
.pageCareer main h2 { font-size: 1.875rem; }
.pageCareer .sidebar { padding-top: 1.25rem; }

.pageCareer .sidebar .back { color: #009132; cursor: pointer; float: right; font-size: 1rem; font-weight: 700; overflow: hidden; outline: none; margin: .78125rem 0 1.625rem; padding-right: 30px; }
.pageCareer .sidebar .back::before { position: absolute; right: 0; top: 5px; content: '\f00d'; display: inline-block; font-family: FontAwesome, FontAwesomeExtended, serif; line-height: 1; vertical-align: baseline; }
.pageCareer .sidebar img { bottom: 0; position: absolute; right: 5%; left: auto; max-width: 100%; width: auto; max-height: 75%; height: auto; display: block; float: right; object-fit: contain; }

.hoverZoomActive .pageCareer .sidebar img { -moz-transform: scale(1.025); -ms-transform: scale(1.025); -webkit-transform: scale(1.025); transform: scale(1.025); }

.positionApply { margin-top: -150px; -webkit-transition: all .5s linear; transition: all .5s linear; opacity: 0; }
.positionApply .btn { z-index: 2; }

.pageCareer .cols.colsMain { display: flex; width: 100%; flex-wrap: wrap; }
.pageCareer .colsMain .colTwoThirds { order: 2; display: block; width: 100%; }
.pageCareer .colsMain .sidebar { order: 1; width: 100%; height: 60vh; position: relative; background-color: #fff; -webkit-transition: background-color .3s linear; transition: background-color .3s linear; }

.pageCareer .colsMain .pagerNav { order: 3; width: 100%; }

.pageCareer.showFullSpec main .job-intro { margin-top: -2rem; opacity: 0; max-height: 0; overflow: hidden; -webkit-transition-delay: 0s; transition-delay: 0s; }
.pageCareer .job-full-desc { max-height: 0; overflow: hidden; }
.pageCareer.showFullSpec .job-full-desc { max-height: 4000px; overflow: visible; }

@media (max-width: 1019px) {
    .positionApply { position: absolute; bottom: -120px; z-index: 2; width: 100%; left: 0; background: #fff; height: 120px; -webkit-transition: height .2s ease-out; transition: height .2s ease-out; }
    .positionApply-inner { padding: 0 2.5rem; height: 60px; bottom: 29px; position: absolute; width: 100%; -webkit-transition: margin .2s ease-out; transition: margin .2s ease-out; }

    .positionApply.stickyApply { position: fixed; top: 0; left: 0; right: 0; }
    .positionApply.stickyApply.mobMenuIsOn { height: 240px; }

    .pageCareer .sidebar .btnDark::before, .pageCareerDetail .sidebar .btnDark::after { background-image: -webkit-linear-gradient(left, #ffc20d 0, #ffc20d 50%, #009132 50.1%, #009132 100%); background-image: linear-gradient(to right, #ffc20d 0, #ffc20d 50%, #009132 50.1%, #009132 100%); }
}

@media (max-width: 859px) {
    .positionApply.stickyApply.mobMenuIsOn { height: 220px; }
}

@media (max-width: 379px) {
    .positionApply-inner { padding: 0 1.5rem; }
}

@media (max-height: 44rem) and (max-width: 1023px) {
    .pageCareer .colsMain .sidebar { height: 60vh; }
    .pageCareer .sidebar img { max-height: 68%; right: 14%; }
}

@media (max-height: 36rem) and (max-width: 1023px) {
    .pageCareer .colsMain .sidebar { height: 350px; }
}

@media (min-width: 22.5rem) {
    .pageCareer main { padding-top: 4.5rem; }
}

@media (min-width: 23.7rem) {
    .pageCareer main { padding-left: 2.5rem; padding-right: 2.5rem; padding-top: 5rem; }
}

@media (min-width: 30rem) {
    .pageCareer main { padding-top: 6rem; }
}

@media (min-width: 35rem) {
    .pageCareer .sidebar img { right: 10%; }
}

@media (min-width: 48rem) {
    .pageCareer .sidebar img { right: 14%; }
}

@media (min-width: 63.75rem) {
    .pageCareer main { max-width: 43.750em; padding-top: 12rem; padding-left: 3rem; padding-right: 3.5rem; padding-bottom: 6rem; }
    .pageCareer .sidebar { padding-top: 0; display: block; position: relative; padding-left: 2.5rem; padding-right: 2.5rem; padding-top: 2.5rem; }

    .pageCareer .sidebar img { -moz-backface-visibility: visible; -webkit-backface-visibility: visible; backface-visibility: visible; transform: translateZ(0); -webkit-filter: drop-shadow(5.625rem 5.625rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(5.625rem 5.625rem 0.125rem rgba(0, 0, 0, 0.17)); display: block; height: auto; max-width: 95%; max-height: 95%; width: auto; }
    .pageCareer .sidebar img { bottom: 0; position: absolute; left: -23%; right: auto; }
    .pageCareer.storeManager .sidebar img { left: -20%; max-width: 760px; }

    .pageCareer .footer .copyright { opacity: 0; transition: opacity .6s linear; }

    .pageCareer .cols.colsMain { display: block; }
    .pageCareer .colsMain .colTwoThirds { width: 66.66666666666667%; }
    .pageCareer .colsMain .sidebar { width: 33.3333333333333%; height: 100vh; }

    /*For page load animation*/
    .pageCareer main { overflow: visible; min-height: 100vh; max-height: 100vh; position: relative; }
    .pageCareer main h1 { transform-origin: left; font-size: 5rem;  -webkit-transform: scale(2); transform: scale(2);  position: absolute; z-index: 1;     -webkit-transition: font-size .75s ease-out; transition: all .75s ease-out; }
    .pageCareer .sidebar img { transform: scale(1.4); z-index: 1; }

    .pageCareer main .job-intro { -ms-transform: translateX(100%); -webkit-transform: translateX(100%); transform: translateX(100%); overflow: hidden; opacity: 0; height: 0; }
    .pageCareer main .btnDark:hover { transition-delay: 0s; }

    .pageCareer main .job-full-desc { max-height: 0; overflow: hidden; }

    .pageCareer.doAnimate main { overflow: visible; position: relative; }
    .pageCareer.doAnimate main h1 {  margin-bottom: 2rem; position: relative;    -webkit-transform: scale(1); transform: scale(1); }
    .pageCareer.doAnimate .sidebar img { transform: scale(1); z-index: 1; -webkit-transition: all 1.2s ease-out; transition: all 1.2s ease-out; }

    .pageCareer.doAnimate main .btnDark { transition-delay: 0s; }
    .pageCareer.doAnimate main .job-intro { padding-bottom: 1rem; max-height: 400px; -ms-transform: translateX(0); -webkit-transform: translateX(0); transform: translateX(0); opacity: 1; height: auto; overflow: visible; -webkit-transition: all .75s ease-out; transition: all .75s ease-out; -webkit-transition-delay: .75s; transition-delay: .75s; }
    .pageCareer.doAnimate main .job-intro.noDelay { -webkit-transition-delay: 0s; transition-delay: 0s; }


    .pageCareer.fixRightPanel .sidebar { position: fixed; }
    .pageCareer.fixRightPanel main { max-height: none; }
    .pageCareer.fixRightPanel .footer .copyright { opacity: 1; }

    .pageCareer.showFullSpec main .job-intro { padding-bottom: 0; margin-top: -2rem; opacity: 0; max-height: 0; overflow: hidden; -webkit-transition-delay: 0s; transition-delay: 0s; }
    .pageCareer .job-full-desc { max-height: 0; overflow: hidden; }
    .pageCareer.showFullSpec .job-full-desc { max-height: 4000px; overflow: visible; }
}

@media (min-width: 63.75rem) {
    .pageCareer:not(.storeManager) .sidebar img {  left: -15%;  }
    .pageCareerDetail:not(.storeManager) .sidebar img { left: 10%; }
}

@media (min-width: 68rem) and (max-height: 50rem) {
    .pageCareer main {  padding-left: 2.5rem;      padding-top: 11rem; }
}

@media (min-width: 63.75rem) and (max-height: 46rem) {
    .pageCareer main {  padding-left: 2.5rem;   padding-top: 11rem; }
}

@media (min-width: 87.5rem) {
    .pageCareer main {   max-width: 46em; }
    .pageCareer main h1 { font-size: 5.6rem; }
}

@media (min-width: 100rem) {
    .pageCareer .sidebar img { max-width: 80%; }
}

@media (min-width: 112rem) {
    .pageCareer .sidebar img { max-width: 75%; }
}

@media (min-width: 63.75rem) {
    [data-loc="fr"].pageCareer:not(.storeManager) .sidebar img {left: auto; right: 6%;  }
    [data-loc="fr"].pageCareerDetail:not(.storeManager) .sidebar img { left: 10%;  right: auto; position: absolute;  }
}

@media (min-width: 87.5rem) {
    [data-loc="fr"].pageCareer:not(.storeManager) .sidebar img {left: auto; right: 15%;  }
}

@media (max-height: 46.5rem)  and (min-width: 63.75rem) and (max-width: 75rem)  {
    [data-loc="fr"].pageCareer:not(.storeManager) .sidebar img,
    [data-loc="de"].pageCareer:not(.storeManager) .sidebar img  {     left: -5%; max-height: 80%;  }
}

/* = Career Detail
----------------------------------------------------------------------------------------------------------------- */
.pageCareerDetail { background-color: #fff; -webkit-transition: background-color .3s linear; transition: background-color .3s linear; }
.pageCareerDetail main { margin-bottom: 1.25rem; margin-left: auto; margin-right: auto; max-width: 47.5rem; padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 7rem; padding-bottom: 1rem; }
.pageCareerDetail .sidebar { padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 2rem; overflow: visible; position: relative; }
.pageCareerDetail .sidebar img { bottom: 0; position: absolute; -webkit-filter: drop-shadow(3.625rem 3.625rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(3.625rem 3.625rem 0.125rem rgba(0, 0, 0, 0.17)); display: block; float: right; height: auto; max-height: 80%; max-width: 80%; object-fit: contain; }

.pageCareerDetail .cols.colsMain { display: flex; width: 100%; flex-wrap: wrap; }
.pageCareerDetail .colsMain .colTwoThirds { order: 2; display: block; width: 100%; }
.pageCareerDetail .colsMain .sidebar { order: 1; width: 100%; height: 60vh; }

.pageCareerDetail .positionApply { margin-top: 0; opacity: 1; }

.pageCareerDetail .colsMain .sidebarLight { background-color: #ffc20d; }

@media (max-width: 859px) {
    .pageCareerDetail .sidebar img { max-height: 45vh; }
}

@media (max-width: 379px) {
    .positionApply-inner { padding: 0 1.5rem; }
    .pageCareerDetail .sidebar img { max-height: 40vh; }
}

@media (max-height: 44rem) and (max-width: 1023px) {
    .pageCareerDetail .colsMain .sidebar { height: 60vh; }
    .pageCareerDetail .sidebar img { max-height: 65%; right: 10%; }
}

@media (max-height: 36rem) and (max-width: 1023px) {
    .pageCareerDetail .colsMain .sidebar { height: 350px; }
}


@media (min-width: 22.5rem) {
    .pageCareerDetail main { padding-top: 7.5rem; }
}

@media (min-width: 23.7rem) {
    .pageCareerDetail main { padding-top: 8rem; padding-left: 2.5rem; padding-right: 2.5rem; }
}

@media (min-width: 31rem) {
    .pageCareerDetail main .job-full-desc h2 { font-size: 2.25em; }
}

@media (min-width: 63.75rem) {
    .pageCareerDetail .cols.colsMain { display: block; }
    .pageCareerDetail .colsMain .colTwoThirds { width: 66.66666666666667%; }
    .pageCareerDetail main { margin-bottom: 5rem; max-width: 43.75rem; padding-top: 12rem; padding-left: 3rem; padding-right: 3.5rem; padding-bottom: 2.5rem; }
    .pageCareerDetail .colsMain .sidebar { overflow: hidden; width: 33.3333333333333%; height: 100vh; position: fixed; overflow: visible; }
    .pageCareerDetail .sidebar img { bottom: 0; left: 10%; position: absolute; }
}

@media (min-width: 68rem) and (max-height: 50rem) {
    .pageCareerDetail main {  padding-left: 2.5rem;      padding-top: 11rem; }
}

@media (min-width: 63.75rem) and (max-height: 46rem) {
    .pageCareerDetail main { padding-left: 2.5rem;   padding-top: 11rem; }
}

@media (max-width: 82.5rem) and (min-width:63.75rem) {
    .positionApply a { float: right; display: block; clear: both; margin-bottom: 1rem; }
}

@media (min-width: 63.75rem) and (max-width: 72.5rem) {
    [data-loc="fr"] .positionApply a:first-child {  margin-top:110px; }
}

@media (min-width: 63.75rem) and (max-width: 100rem) {
    [data-loc="fr"] .positionApply a,
    [data-loc="de"] .positionApply a { float: right; display: block; clear: both; margin-bottom: 1rem;     z-index: 3; }
}

@media (min-width: 63.75rem) and (max-width: 90rem) {
    [data-loc="at"] .positionApply a,
    [data-loc="ch"] .positionApply a { float: right; display: block; clear: both; margin-bottom: 1rem;     z-index: 3; }
}

@media (min-width: 87.5rem) {
    .pageCareerDetail main {   max-width: 46em; }
}


/* = Food
----------------------------------------------------------------------------------------------------------------- */
@media (min-width: 63.75rem) {
    .pageFood .footer { color: #fff; }
}

/* = Our Bit
----------------------------------------------------------------------------------------------------------------- */
.pageOurBit { background-color: #fff; }
.pageOurBit main { margin-bottom: 1.25rem; margin-left: auto; margin-right: auto; max-width: 47.5rem; padding-left: 1.5rem; padding-right: 1.5rem; padding-top: 4rem; }
.pageOurBit main h2 { font-size: 1.875rem; }
.pageOurBit .sidebar img { height: 100%; object-fit: cover; width: 100%; object-position: 100% 100%; }
.pageOurBit .cols.colsMain { display: flex; width: 100%; flex-wrap: wrap; }
.pageOurBit .colsMain .colTwoThirds { order: 2; display: block; width: 100%; }
.pageOurBit .colsMain .sidebar { order: 1; width: 100%; height: 65vh; }

.pageOurBit .colsMain .sidebar .imgBG { height: 100%; overflow: hidden; }
.pageOurBit .colsMain .sidebar .imgBG img { -webkit-transition: all 0.2s ease-out; transition: all 0.2s ease-out; }
.pageOurBit .colsMain .sidebar .hoverZoomActive img { -moz-transform: scale(1.025); -ms-transform: scale(1.025); -webkit-transform: scale(1.025); transform: scale(1.025); }


@media (min-width: 22.5rem) {
    .pageOurBit main { padding-top: 4.5rem; }
}

@media (min-width: 23.7rem) {
    .pageOurBit main { padding-left: 2.5rem; padding-right: 2.5rem; padding-top: 5rem; }
}

@media (min-width: 30rem) {
    .pageOurBit main { padding-top: 5.5rem; }
}

@media (min-width: 48rem) {
    .pageOurBit main { padding-top: 6rem; }
}

@media (min-width: 63.75rem) {
    .pageOurBit .cols.colsMain { display: block; }
    .pageOurBit .colsMain .colTwoThirds { width: 66.66666666666667%; }
    .pageOurBit .colsMain .sidebar { width: 33.3333333333333%; height: 100vh; }

    .pageOurBit main { margin-bottom: 5rem; max-width: 48.75rem; padding-left: 3rem; padding-right: 3rem; padding-top: 14rem; padding-bottom: 2.5rem; }
    .pageOurBit .footer .menu { color: #fff; }

    .pageOurBit .sidebar img { object-position: 50% 50%; }
}

/* = Simple 1 col
----------------------------------------------------------------------------------------------------------------- */
.template1Col { padding-top: 9rem; width: auto; padding-left: 1.5rem; padding-right: 1.5rem; margin: 0 auto; min-height: 100vh; }

@media (min-width: 23.7rem) {
    .template1Col { padding-left: 2.5rem; padding-right: 2.5rem; }
}

@media (min-width: 48rem) {
    .template1Col { padding-left: 3.5rem; padding-right: 3.5rem; }
}

@media (min-width: 63.75rem) {
    .template1Col { padding-top: 12rem; }
}

@media (min-width: 60rem) {
    .template1Col { width: 800px; padding-left: 0; padding-right: 0; }
}

@media (min-width: 63.75rem) {
    .template1Col { padding-bottom: 7rem; }
}

/*General page animations*/
.no-js .animsition { opacity: 1; }

.animsition,
.animsition-overlay { position: relative; opacity: 0; -webkit-animation-fill-mode: both; animation-fill-mode: both; }
.animsition-overlay-slide { position: fixed; z-index: 1; width: 100%; height: 100%; background-color: #ddd; }
.animsition-loading,
.animsition-loading:after { width: 32px; height: 32px; position: fixed; top: 50%; left: 50%; margin-top: -16px; margin-left: -16px; border-radius: 50%; z-index: 100; }
.animsition-loading { background-color: transparent; border-top: 5px solid #009132; border-right: 5px solid #009132; border-bottom: 5px solid #009132; border-left: 5px solid #fff; -webkit-transform: translateZ(0); transform: translateZ(0); -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; -webkit-animation-timing-function: linear; animation-timing-function: linear; -webkit-animation-duration: .8s; animation-duration: .8s; -webkit-animation-name: animsition-loading; animation-name: animsition-loading; }

.pageCareers .animsition-loading { background-color: transparent; border-top: 5px solid #ffc20d; border-right: 5px solid #ffc20d; border-bottom: 5px solid #ffc20d; border-left: 5px solid #fff; }

.gridLoading.animsition-loading,
.gridLoading.animsition-loading:after { position: absolute; top: 200px; }

@media screen and (max-width: 1080px) {
    .gridLoading.animsition-loading,
    .gridLoading.animsition-loading:after { top: 150px; }
}

@media screen and (max-width: 480px) {
    .gridLoading.animsition-loading,
    .gridLoading.animsition-loading:after { top: 100px; }
}

@-webkit-keyframes animsition-loading {
    0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
    100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); }
}

@keyframes animsition-loading {
    0% { -webkit-transform: rotate(0deg); transform: rotate(0deg); }
    100% { -webkit-transform: rotate(360deg); transform: rotate(360deg); }
}

@-webkit-keyframes fade-in {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

@keyframes fade-in {
    0% { opacity: 0; }
    100% { opacity: 1; }
}

.fade-in { -webkit-animation-name: fade-in; animation-name: fade-in; }


/* = Other styles
----------------------------------------------------------------------------------------------------------------- */
.h-center-y { position: relative; top: 50%; -moz-transform: translateY(-50%); -webkit-transform: translateY(-50%); transform: translateY(-50%); }

.btnSmall { position: relative; display: inline-block; overflow: hidden; padding: 5px 15px; background-color: transparent; border-width: 0; cursor: pointer; font-family: Subway, Montserrat, Arial, sans-serif; font-size: 1rem; font-weight: 700; color: #009132; color: #fff; outline: none; -moz-border-radius: 4em; -webkit-border-radius: 4em; border-radius: 4em; -moz-transition: color 0.2s ease-out; -webkit-transition: color 0.2s ease-out; transition: color 0.2s ease-out; }

.btnSmall:hover { color: #009132; }
.btnSmall:active { opacity: 0.8; }
.btnSmall::before { content: ''; position: absolute; display: block; top: -1px; left: -1px; bottom: -1px; right: -1px; z-index: -1; background-image: -webkit-linear-gradient(left, #ffc20d 0, #ffc20d 50%, #009132 50.1%, #009132 100%); background-image: linear-gradient(to right, #ffc20d 0, #ffc20d 50%, #009132 50.1%, #009132 100%); background-color: #009132; background-position: 100% 0; background-size: 200%; -moz-transition: background-position 0.2s ease-out; -webkit-transition: background-position 0.2s ease-out; transition: background-position 0.2s ease-out; }
.btnSmall:hover::before,
.btnSmall:active::before { background-position: 0 0; }

.formError { display: none; margin-top: -10px; padding-bottom: 20px; color: red; }

/* = Job
----------------------------------------------------------------------------------------------------------------- */
.job { zoom: 1; display: block; float: none; font-size: 1rem; position: relative; }
.job::after { clear: both; content: "."; display: block; height: 0; overflow: hidden; visibility: hidden; }
.jobTitle { float: left; font-weight: 700; margin-bottom: .125rem; padding-right: 0.625rem; cursor: pointer; }
.jobDistance { float: right; font-weight: 700; font-size: 0.75rem; line-height: 1.579rem; margin-bottom: .125rem; padding-left: 0.625rem; text-align: right; }
.jobLocation { clear: both; display: block; margin-bottom: .25rem; width: 100%; font-size: 0.8125rem; cursor: pointer; }
.jobType { clear: left; float: left; font-size: 0.75rem; padding-right: 0.625rem; }
.jobClosing { float: left; clear: left; padding-left: 0; font-size: 0.75rem; text-align: right; }
.jobLabel { display: inline-block; font-weight: 700; margin-right: .25rem; }
.jobsItem.formToggle .job.formLabel { padding-left: 1.875rem; cursor: default; }

/* = Jobs List
    ----------------------------------------------------------------------------------------------------------------- */
.jobsTypes { border-bottom: 1px solid #ebebeb; font-weight: 700; padding: 1.25rem 1.25rem; }
.jobsList { list-style-type: none; margin-bottom: 0; overflow-y: auto; padding-left: 10px; padding-right: 10px; }
.jobsItem { zoom: 1; -moz-transition: background-color 0.2s ease-out; -webkit-transition: background-color 0.2s ease-out; transition: background-color 0.2s ease-out; float: none; padding-bottom: 1.25rem; padding-left: 0.625rem; padding-right: 0.625rem; padding-top: 1.25rem; position: relative; width: 100%; }
.jobsItem::after { clear: both; content: "."; display: block; height: 0; overflow: hidden; visibility: hidden; }
.jobsItem::before { left: 0.625rem; top: 1.5rem; }
.jobsItem + .jobsItem { border-top: 1px solid #ebebeb; margin-left: 0; padding-top: 1.25rem; }
.jobsItemHighlight { background-color: #e9ffe1; }
.jobsItemSelected { background-color: #fefacd; }
.jobsFilterResult { position: fixed; bottom: 0; left: 0; right: 0; height: 50px; border-top: 1px solid #ebebeb; padding: 0 20px; background: #fff; }
.jobsFilterResultInner { margin-top: -2px; }
.jobsCount { display: inline-block; font-size: 0.8125rem; margin-right: 1em; }
.jobsSave { font-size: 0.875rem; vertical-align: middle; }
.jobsApply .form .btn { clear: both; }
.jobsContinue { float: right; font-size: 0.875rem; margin-top: -2px; padding-top: 4px; }

.jobCheckboxOverlay { position: absolute; top: 3px; left: 0; width: 20px; height: 20px; cursor: pointer; z-index: 1; }

.jobsListLoading,
.jobsListLoadMore,
.jobsListNone { position: relative; padding: 60px 0; text-align: center; font-size: 0.875rem; }
.jobsListLoading,
.jobsListNone { position: absolute; top: 50%; width: 100%; margin-top: -40px; padding: 0 20px; }
.jobsListLoadMore { padding-bottom: 30px; }
.jobsListLoading::before,
.jobsListLoadMore::before { content: ""; position: absolute; top: 30px; left: 50%; width: 32px; height: 32px; margin: 0 0 0 -16px; background: url(/_img/loader.gif) center center no-repeat; }

.jobsTypes { padding: 0.9375rem 1.25rem; max-height: 56px; overflow: hidden; position: relative; z-index: 1; background: #fff; -webkit-transition: max-height .2s ease-in-out; transition: max-height .2s ease-in-out; }
.jobsTypes.jobTypesMore { max-height: 56px; }
.jobsTypes.jobTypesMore.on { background: #fff; max-height:300px; -moz-box-shadow: 0 0 6px #ddd; -webkit-box-shadow: 0 0 6px #ddd; box-shadow: 0 0 6px #ddd; }

.jobsTypes .filterHeading { display: none; cursor: pointer; margin-bottom: 15px; font-size: 1.3rem; line-height: 1.4; }
.jobsTypes .filterHeading:after { padding-left: 12px; content: '\f067'; font-family: FontAwesome, FontAwesomeExtended, serif; font-size: 18px; font-weight: normal; color: #009132; }
.jobsTypes.jobTypesMore.on .filterHeading:after { content: '\f068'; }
.jobsTypes .positionType { display: none; margin: 0 0 15px; }

.jobsTypes.jobTypesMore .filterHeading,
.jobsTypes.jobTypesMore .positionType { display: block; }
.jobsTypes.jobTypesMore .filterItemInline { margin-bottom: 12px; width: 48%; line-height: 1.2; }
.jobsTypes.jobTypesMore .filterItemWrap { overflow: hidden; }
.jobsTypes.jobTypesMore .filterItemWrap .filterItemInline:nth-child(even) { margin-left: 4%; clear:right; }
.jobsTypes.jobTypesMore .filterItemWrap .filterItemInline:nth-child(odd) { margin-left: 0; clear:left; }
.jobsTypes.jobTypesMore .filterItemWrap .filterItemInline::before { top: 0.05rem; }

.jobsItems { padding-top: 0.9375rem; padding-bottom: 0.9375rem; }

.jobsContinue.js-jobs-apply.disabled { pointer-events: none; cursor: default; opacity: 0.6; }

/* Media Queries */
@media (max-width: 28.7rem) {
    .jobsTypes { max-height: none; }
    .jobsTypes.jobTypesMore { max-height: 56px; }
    .jobsTypes .filterItemInline { width: 48%; line-height: 1.2; }
    .jobsTypes .filterItemWrap .filterItemInline::before { top: 0.05rem; }
    .jobsTypes .filterItemInline + .filterItemInline { margin-left: 0; }
    .jobsTypes .filterItemInline:nth-child(even) { margin-left: 4%; }
    .jobsTypes .filterItemInline:nth-child(odd) { margin-left: 0; }
}

@media (max-width: 48rem) {
    .jobsFilterResult { z-index: 1; }
    .jobsListLoading::before { background: none; }
}


@media (max-width: 22rem) {
    .jobsTypes.jobTypesMore .filterItemInline { width: 100%; margin-bottom: 18px; }
    .jobsTypes.jobTypesMore .filterItemWrap .filterItemInline:nth-child(even),
    .jobsTypes.jobTypesMore .filterItemWrap .filterItemInline:nth-child(odd) { margin-left: 0; clear:none; }
}

@media (min-width: 48rem) {
    .jobsFilterResult { position: absolute; }
    .jobsListWrap { position: absolute; top: 173px; bottom: 50px; left: 0; right: 0; overflow-y: auto; }
}

/* Content */
.mapContent { position: absolute; left: 50%; top: 50%; max-width: 35rem; width: 100%; padding: 1.875rem; color: #fff; -moz-transform: translate(-50%, -50%); -ms-transform: translate(-50%, -50%); -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.mapContent img { -webkit-filter: drop-shadow(0.9375rem 0.9375rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(0.9375rem 0.9375rem 0.125rem rgba(0, 0, 0, 0.17)); -moz-transition: all 0.2s ease-out; -webkit-transition: all 0.2s ease-out; transition: all 0.2s ease-out; -moz-backface-visibility: visible; -webkit-backface-visibility: visible; backface-visibility: visible; transform: translateZ(0); margin-bottom: 1.25rem; }
.hoverZoomActive .mapContent img { -moz-transform: scale(1.025); -ms-transform: scale(1.025); -webkit-transform: scale(1.025); transform: scale(1.025); }
.mapContent { z-index: 3; }

/* = Map Styles - Apply page
----------------------------------------------------------------------------------------------------------------- */
#apply .map { position: relative; min-height: 80vh; background: #2f543b url(/_img/map/loader.gif) center center no-repeat;  overflow: hidden; }
#apply .map::before { content: ''; display: block; padding-top: 80vh; }
#apply .map .loadingPane { position: absolute; display: none; top: 0; left: 0; width: 100%; height: 100%; z-index: 2; background: rgba(47, 84, 59, 0.6) url(/_img/map/loader-pane.gif) center center no-repeat; }

/* Inner */
#apply .mapInner { position: absolute; left: 0; top: 0; height: 80vh; width: 100%; }
.mapInner a[href^="http://maps.google.com/maps"],
.mapInner a[href^="https://maps.google.com/maps"] { display: none !important; }
.mapInner .gmnoprint a,
.mapInner .gmnoprint span,
.mapInner .gm-style-cc { display: none; }

.map .markerCount { position: absolute; top: 0; left: 0; width: 20px; height: 20px; line-height: 20px; text-align: center; background: #00a7e9; color: #fff; font-size: 10px; font-family: Arial; border-radius: 50%; overflow: hidden; }
.map .clusterSubCount { position: absolute; top: 5px; right: -5px; width: 22px; height: 22px; line-height: 22px; text-align: center; background: #00a7e9; color: #fff; font-size: 10px; font-family: Arial; border-radius: 50%; overflow: hidden; }

.map .mapPopover { position: absolute; top: 0; left: 0; padding: 12px 15px 15px; min-width: 150px; max-width: 350px; background: #fff; font-size: 14px; z-index: 3; border-radius: 10px; -webkit-filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); }
.map .mapPopover::before { content: ""; position: absolute; bottom: -10px; left: 50%; width: 23px; height: 30px; margin: 0 0 0 -17px; background: #fff; transform: rotate(147deg) skew(25deg); -webkit-transform: rotate(147deg) skew(25deg); z-index: 0; }
.map .mapPopover .mapPopoverInner { position: relative; z-index: 1; }
.map .mapPopover .name { font-weight: 700; color: #009132; }
.map .mapPopover .address { font-size: 0.8125rem; }

.map .tooltipPopover { position: absolute; top: 0; left: 0; margin-left: 283px; margin-top: -2px; padding: 15px 20px; min-height: 100px; min-width: 150px; max-width: 230px; background: #fff; font-size: 14px; z-index: 3; border-radius: 10px; -webkit-filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); }
.map .tooltipPopover::before { content: ""; position: absolute; top: 36px; left: 9px; width: 17px; height: 17px; margin: 0 0 0 -17px; background: #fff; transform: rotate(235deg) skew(25deg); -webkit-transform: rotate(235deg) skew(25deg); z-index: 0; }
.map .tooltipPopover .mapPopoverInner { position: relative; z-index: 1; }
.map .tooltipPopover .title { font-weight: 700; color: #009132; }
.map .tooltipPopover .text { margin-bottom: 10px; font-size: 0.8125rem; }
.map .tooltipPopover .btnSmall { padding: 2px 15px; font-size: 0.875rem; }

@media (min-width: 48rem) {
}

.map .mapDebug { position: fixed; top: 0; right: 0; padding: 10px 20px; background: blue; color: #fff; font-size: 13px; z-index: 9999; }
.map .mapDebug label { display: inline-block; width: 100px; }

/* SideBar */
.mapSidebar { overflow: hidden; height: auto; padding-bottom: 50px; background-color: #fff; color: #333; -moz-border-radius: 0.5rem; -webkit-border-radius: 0.5rem; border-radius: 0.5rem; }

.mapSidebarHeader { padding: 1.25rem; background-color: #ffc20d; color: #333; font-size: 1.3125rem; font-weight: 700; }
.mapSidebarHeader .formField { margin-bottom: 0; -webkit-filter: none; filter: none; }

.mapSidebarLocation { position: relative; overflow: hidden; display: inline-block; max-width: 95%; margin-bottom: 1.25rem; padding-left: 1.25rem; vertical-align: text-top; white-space: nowrap; text-overflow: ellipsis; }

/*.mapSidebarLocation.geoLocated::before { content: '\f041'; position: absolute; display: block; left: 0; top: -1px; color: #009132; font-family: FontAwesome, FontAwesomeExtended, serif; font-size: 18px; }*/

.mapSidebarHeader { padding: .75rem 1.25rem 1.25rem; font-size: 1.125rem; }
.mapSidebarHeader .formInput { padding: .625rem 0 .625rem 1.5rem; text-overflow: ellipsis; }
.mapSidebarLocation { margin-bottom: 0.9375rem; }

/* Info Window */
.mapInfoWindow { display: block; font-size: 1rem; font-weight: 700; padding: 1.25rem; }
.mapInfoWindowTitle { display: block; margin-bottom: .5em; color: #009132; font-size: 1.1875rem; }

/* Marker */
.mapMarkerHighlight { -webkit-filter: drop-shadow(0 0 0.4375rem #009132); filter: drop-shadow(0 0 0.4375rem #009132); }

/* Map Nearby */
.mapNearby { position: absolute; overflow: hidden; display: inline-block; top: 8.25rem; left: 1.875rem; padding: .78125rem 1.625rem; color: #fff; cursor: pointer; font-size: 1rem; font-weight: 700; outline: none; -moz-border-radius: 4em; -webkit-border-radius: 4em; border-radius: 4em; -webkit-filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); }
.mapNearby::before,
.mapNearby::after { content: ''; position: absolute; display: block; left: 0; height: 56%; width: 100%; background-color: #009132; -moz-transition: background-position 0.2s ease-out; -webkit-transition: background-position 0.2s ease-out; transition: background-position 0.2s ease-out; }
.mapNearby::before { top: 0; -moz-border-radius: 0.9375rem 0.9375rem 30% 30%; -webkit-border-radius: 0.9375rem 0.9375rem 30% 30%; border-radius: 0.9375rem 0.9375rem 30% 30%; }
.mapNearby::after { bottom: 0; -moz-border-radius: 30% 30% 0.9375rem 0.9375rem; -webkit-border-radius: 30% 30% 0.9375rem 0.9375rem; border-radius: 30% 30% 0.9375rem 0.9375rem; }

/* Media Queries */

@media (min-width: 48rem) {
    #apply .map,
    #apply .mapInner { height: 100vh; min-height: 400px; }
    #apply .map::before { padding-top: 100vh; }

    .mapSidebar { position: absolute; right: 3.75rem; top: 9.375rem; bottom: 3.125rem; height: auto; min-height: 350px; width: 22.5rem; padding-bottom: 0; -moz-box-shadow: 1.5rem 1.5rem 0.1875rem rgba(0, 0, 0, 0.17); -webkit-box-shadow: 1.5rem 1.5rem 0.1875rem rgba(0, 0, 0, 0.17); box-shadow: 1.5rem 1.5rem 0.1875rem rgba(0, 0, 0, 0.17); }

    .mapNearby { left: 2.5rem; top: 9.125rem; }

    .map .tooltipPopover { margin: 0; }
    .map .tooltipPopover::before { right: -9px; left: auto; }
}

@media (min-width: 78.125rem) {
    .mapSidebar { top: 3.125rem; }
}


/* = PAC Container
----------------------------------------------------------------------------------------------------------------- */
.pac-container { overflow: visible; margin-top: 10px; border-width: 0; font-family: Subway, Montserrat, Arial, sans-serif; font-size: 1rem; font-weight: 400; -moz-box-shadow: none; -webkit-box-shadow: none; box-shadow: none; -webkit-filter: drop-shadow(1.25rem 1.25rem 0.125rem rgba(0, 0, 0, 0.15)); filter: drop-shadow(1.25rem 1.25rem 0.125rem rgba(0, 0, 0, 0.15)); }

.pac-container::before { content: ''; position: absolute; bottom: 100%; left: 50%; width: 0; height: 0; border-color: transparent; border-style: solid; border-bottom-color: #fff; border-width: .625rem 1rem; -moz-transform: translateX(-50%); -ms-transform: translateX(-50%); -webkit-transform: translateX(-50%); transform: translateX(-50%); }
.pac-container::after { content: initial; }

.pac-container .pac-item { padding: .875rem 1.5rem; cursor: pointer; }
.pac-container .pac-item:first-child { border-top-width: 0; }

.pac-container { min-width: 320px; width: 320px; border: solid 1px #ebebeb; }

/* Z-Index */
.mapNearby::before,
.mapNearby::after { z-index: -1; }
.mapInner { z-index: 1; }
.mapSidebar { z-index: 2; }
.mapNearby { z-index: 3; }

/* = help tip*/
.everGreenTip { position: relative; float: left; width: 18px; height: 18px; font-size: 0;  }
.everGreenTip:before { line-height: 1.1; content: '\f05a'; font-family: FontAwesome, FontAwesomeExtended, serif; font-size: .9rem; position: absolute; cursor: pointer; }
.everGreenTip .help-tip { display: none; top: 30px; margin-left: -100px; width: 240px; padding: 15px 20px; background-color: #333; color: #fff; -webkit-border-radius: 6px; border-radius: 6px; position: absolute; z-index: 1; font-size: 0.8125rem; -webkit-filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); filter: drop-shadow(0.75rem 0.75rem 0.125rem rgba(0, 0, 0, 0.17)); }
.everGreenTip:hover .help-tip { display: inline-block; }
.everGreenTip:hover .help-tip:before { content: ""; position: absolute; top: -8px; left: 114px; width: 18px; height: 17px; margin: 0 0 0 -17px; background: #333; transform: rotate(147deg) skew(25deg); -webkit-transform: rotate(147deg) skew(25deg); z-index: 0; }




/* = Places Autocomplete
----------------------------------------------------------------------------------------------------------------- */
.placesWrap { position: relative; }
.placesResults { position: absolute; top: 48px; left: 20px; right: 20px; max-width: 350px; background: #fff; border: solid 1px #ccc; }
.placesResults.open { display: block; }
.placesResults ul,
.placesResults ul li { padding: 0; margin: 0; list-style: none; }
.placesResults ul li { padding: 10px 20px 10px 35px; border-bottom: solid 1px #ccc; color: #000; font-size: 13px; cursor: pointer; }
.placesResults ul li { background: url(/_img/icon/map-pin-gray.svg) 13px 11px no-repeat; background-size: 12px 16px; }
.placesResults ul li::before { content: none; }
.placesResults ul li:hover { background-color: #fbfbfb; }
.placesResults ul li.selected { background-color: #f2f2f2; }
.placesResults .placeArea { color: #999; font-size: 11px; margin-left: 5px; }
.placesWrap.loading::after { content: ""; position: absolute; top: 0; left: 0; right: 0; bottom:0; background: rgba(255, 255, 255, 0.8) url('/_img/loader.gif') center center no-repeat; 
                             -moz-border-radius: 1.5rem; -webkit-border-radius: 1.5rem; border-radius: 1.5rem; zoom: 1; z-index: 2;
}
