* {
  box-sizing: border-box;
}

.job-description {
  background-color: #f1f2f2;
  padding: 3rem 0
}

.job-description * {
  -webkit-box-sizing: border-box;
  box-sizing: border-box
}

.job-description h3,
.job-description h3.job-title,
.job-description h3.application-instructions-header {
  font-size: 2rem
}

.job-description h4.job-description-header,
.job-description h4.job-skills-header,
.job-description h4.job-notes-header,
.job-description h4.apply-with-header {
  font-size: 1rem
}

.job-description .job-description-content p,
.job-description .job-description-content span,
.job-description .job-description-content li,
.job-description .job-skills p,
.job-description .job-skills span,
.job-description .job-skills li,
.job-description .job-notes.important-notes p,
.job-description .job-notes.important-notes span,
.job-description .job-notes.important-notes li {
  font-size: 1rem
}

.job-description .job-addl-info .job-payrange,
.job-description .job-addl-info .job-payrange *,
.job-description .job-addl-info .salary-comment,
.job-description .job-addl-info .salary-comment *,
.job-description .job-addl-info .date,
.job-description .job-addl-info .date *,
.job-description .job-addl-info .job-status,
.job-description .job-addl-info .job-status *,
.job-description .job-addl-info .job-type,
.job-description .job-addl-info .job-type *,
.job-description .job-addl-info .job-ref,
.job-description .job-addl-info .job-ref *,
.job-description .job-addl-info .job-description__categories,
.job-description .job-addl-info .job-description__categories *,
.job-description .job-addl-info .location,
.job-description .job-addl-info .location * {
  font-size: 14px
}

.job-description .job-addl-info .view-location-label {
  font-size: 16px;
  font-weight: 600
}

.job-description .job-addl-info .location ul {
  margin-left: 50px
}

.job-description .job-notes-header {
  color: red
}

.job-description .content {
  background-color: white;
  padding: 1rem;
  margin: 0 auto;
  max-width: 65rem
}

.job-description .content .job-payrange {
  color: #598700
}

.job-description .modal .modal-content {
  position: fixed;
  width: 700px;
  max-height: 100vh;
  overflow: auto;
  left: -webkit-calc(50% - 350px);
  left: calc(50% - 350px);
  top: 0;
  padding: 0
}

@media (max-width: 450px) {
  .job-description .modal .modal-content {
    left: 0;
    width: 100%
  }
}

.job-description .modal .modal-content .CloseModalButton {
  font-family: sans-serif;
  font-style: normal;
  position: absolute;
  top: 8px;
  right: 11px;
  color: #aaa;
  font-size: 1.2em
}

.job-description .job-share-modal-component:not(.job-share-modal-component--mobile) .modal-content {
  width: 540px;
  left: -webkit-calc(50% - 270px);
  left: calc(50% - 270px);
  top: 6rem;
  max-height: -webkit-calc(100% - 12rem);
  max-height: calc(100% - 12rem);
  overflow-y: scroll
}

.job-description .job-share-modal-component.job-share-modal-component--mobile .modal-content {
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  width: 100%
}

.job-description .job-share-modal-component.job-share-modal-component--mobile .jobing-share-modal .modal-body {
  width: 100%
}

.job-description .job-share-modal-component.job-share-modal-component--mobile .social-icons,
.job-description .job-share-modal-component.job-share-modal-component--mobile .share-link {
  display: none
}

.job-description .job-share-modal-component.job-share-modal-component--mobile .submit {
  width: 100%;
  margin-left: 0
}

.job-description .apply-with-jobing-component .jobing-icon {
  width: 1.1rem;
  height: 1.1rem
}

.job-description .apply-with-jobing-component .ApplyModal {
  text-align: center;
  background-image: none;
  background: -moz-radial-gradient(50% 50%, farthest-side, #0061d6, #002c5f) no-repeat;
  background: -webkit-gradient(radial, 50% 50%, 0, 50% 50%, 350, from(#0061d6), to(#002c5f)) no-repeat;
  background-color: #002c5f
}

.job-description .apply-widget-component {
  display: block
}

.job-description .apply-widget-container--top {
  margin-top: 15px
}

.job-description .apply-button,
.job-description .map-button,
.job-description .job-share-button {
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  text-align: left;
  text-decoration: none;
  border-radius: 0.3125rem;
  border: none;
  cursor: pointer;
  line-height: 1
}

.job-description .map-button,
.job-description .job-share-button {
  font-size: 1rem;
  padding: 0.5rem;
  margin: 1rem 0;
  width: 100%;
  background-color: #f1f2f2;
  display: block;
  color: inherit
}

.job-description .map-button .fa,
.job-description .job-share-button .fa {
  margin-left: 0.25rem;
  width: 2rem;
  text-align: left
}

.job-description .map-button--flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -webkit-justify-content: flex-start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -ms-flex-align: center;
  align-items: center
}

.job-description .map-button--flex>div {
  width: -webkit-calc(100% - 3rem);
  width: calc(100% - 3rem)
}

.job-description .map-button--flex>div .map-button__label {
  width: 100%
}

.job-description .map-button__label {
  font-size: initial;
  overflow: hidden;
  white-space: nowrap;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  display: block
}

.job-description .apply-button {
  font-size: 1.1rem;
  padding: 1rem;
  display: inline-block;
  text-align: center;
  width: 100%
}

.job-description .apply-button.full {
  width: 100%
}

.job-description .apply-button .fa,
.job-description .apply-button .jobing-icon {
  margin-right: 1rem
}

.job-description .apply-button.apply-button__loading {
  cursor: not-allowed
}

.job-description .apply-button.apply-button__loading .ellipsis-loading__one {
  opacity: 0;
  -webkit-animation: dot 1.3s infinite;
  -webkit-animation-delay: 0s;
  animation: dot 1.3s infinite;
  animation-delay: 0s
}

.job-description .apply-button.apply-button__loading .ellipsis-loading__two {
  opacity: 0;
  -webkit-animation: dot 1.3s infinite;
  -webkit-animation-delay: 0.2s;
  animation: dot 1.3s infinite;
  animation-delay: 0.2s
}

.job-description .apply-button.apply-button__loading .ellipsis-loading__three {
  opacity: 0;
  -webkit-animation: dot 1.3s infinite;
  -webkit-animation-delay: 0.3s;
  animation: dot 1.3s infinite;
  animation-delay: 0.3s
}

@-webkit-keyframes dot {
  0% {
    opacity: 0
  }

  50% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

@keyframes dot {
  0% {
    opacity: 0
  }

  50% {
    opacity: 0
  }

  100% {
    opacity: 1
  }
}

.job-description .job-addl-info .simple-apply-container {
  display: none;
  background-color: #f1f2f2
}

.job-description .job-addl-info .simple-apply-container strong {
  display: block
}

.job-description .job-addl-info .simple-apply-container .apply-button {
  margin: 0
}

.job-description .simple-apply-container.bottom-styles .apply-button {
  margin-top: 1rem
}

.job-description .simple-apply-container.bottom-styles .apply-button .click-here-text {
  display: none
}

.job-description .simple-email-job-share {
  padding: 2rem 0
}

.job-description .simple-email-job-share .email-job-header {
  margin: 0
}

.job-description .simple-email-job-share .label {
  background-color: white;
  color: inherit;
  font-size: 1rem;
  padding: 0
}

.job-description .simple-email-job-share .eRecipient {
  border-radius: 5px;
  padding: 8px 5px;
  width: 100%;
  color: gray;
  border: 1px solid
}

.job-description .simple-email-job-share .email-submit-button {
  background: #4ebf02;
  color: #fff;
  border: 0;
  padding: 8px 12px;
  margin: 0;
  font-size: 18px;
  margin-top: 1rem;
  width: 100%;
  border-radius: 0.3125rem
}

@media (min-width: 768px) {
  .job-description .content {
    padding: 3rem
  }

  .job-description .main-content,
  .job-description .job-addl-info {
    display: inline-block;
    vertical-align: top
  }

  .job-description .main-content {
    width: -webkit-calc(100% - 15rem);
    width: calc(100% - 15rem);
    padding-right: 2rem
  }

  .job-description .job-addl-info {
    width: 15rem;
    padding-left: 2rem
  }

  .job-description .job-addl-info .simple-apply-container {
    display: block
  }

  .job-description .apply-widget-container--top {
    display: none
  }
}

.job-description .recommendation__container {
  background-color: white;
  font-size: 1rem;
  margin-bottom: 3em;
  color: #999
}

.job-description .recommendation__container .primary-background-color {
  color: white;
  border: 1px solid rgba(0, 0, 0, 0)
}

.job-description .recommendation__header__overlay-box {
  font-size: 10px;
  padding: 1.2em;
  display: inline-block;
  text-transform: uppercase;
  font-weight: bolder;
  border-radius: 0.3125em;
  background-color: white;
  -webkit-box-shadow: 0px 1px 14px -2px rgba(0, 0, 0, 0.2);
  box-shadow: 0px 1px 14px -2px rgba(0, 0, 0, 0.2);
  position: absolute;
  line-height: 0;
  left: 50%;
  top: 0;
  -webkit-transform: translateX(-50%) translateY(-50%);
  -ms-transform: translateX(-50%) translateY(-50%);
  transform: translateX(-50%) translateY(-50%)
}

.job-description .recommendation__header {
  text-align: center;
  padding-top: 25px;
  padding-bottom: 25px;
  font-weight: bolder;
  position: relative
}

.job-description .recommendation__header__title {
  font-size: 23px;
  font-weight: 500
}

.job-description .recommendation__header__title--320 {
  display: none
}

.job-description .recommendation__info-container,
.job-description .recommendation__button-container {
  width: 50%;
  display: inline-block
}

.job-description .recommendation__recommended-job-container {
  border-bottom: 1px solid #DDD;
  position: relative;
  padding: 1em
}

.job-description .recommendation__button-container {
  display: inline-block;
  vertical-align: top;
  text-align: center
}

.job-description .recommendation__recommended-job-container--top {
  border-top: 1px solid #DDD
}

.job-description .recommendation__info-container__headline {
  font-weight: bolder;
  padding-bottom: 0.25em;
  white-space: nowrap;
  overflow: hidden;
  -o-text-overflow: ellipsis;
  text-overflow: ellipsis;
  width: 80%
}

.job-description .recommendation__info-container__location {
  padding-bottom: 0.25em;
  color: #CCC
}

.job-description .recommendation__info-container__type {
  font-size: smaller;
  color: #CCC
}

.job-description .recommendation__footer {
  text-align: center;
  padding: 1em
}

.job-description .recommendation__footer .fa {
  margin-left: 2em
}

.job-description .recommendation__button-container__view-button,
.job-description .recommendation__button-container__apply-button {
  display: inline-block;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  border-radius: 0.3125em;
  cursor: pointer;
  border-style: solid;
  width: 45%;
  height: 2em;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  text-align: center;
  border-width: 1.2px;
  vertical-align: middle;
  line-height: 200%;
  font-size: 0.8em;
  font-weight: bold;
  overflow: hidden;
  text-decoration: none
}

.job-description .recommendation__button-container__view-button {
  color: #999;
  border-color: #999
}

.job-description .recommendation__button-container__view-button:hover {
  background-color: #999;
  border-color: #999;
  color: white
}

.job-description .recommendation__button-container__apply-button {
  border-width: 1px;
  margin-left: 10%
}

.job-description .recommendation__footer__search-all {
  display: inline-block;
  -webkit-transition: all 0.4s ease;
  -o-transition: all 0.4s ease;
  transition: all 0.4s ease;
  border-radius: 0.3125em;
  cursor: pointer;
  border-style: solid;
  padding: 0.25em;
  width: 15em;
  height: 2em;
  font-weight: bold;
  line-height: 1.5;
  font-size: 1em;
  text-decoration: none;
  max-width: 100%
}

.job-description .recommendation__footer__view-more {
  display: inline-block;
  cursor: pointer
}

@media (min-width: 1094px) {
  .job-description .recommendation__header__overlay-box {
    -webkit-transform: translate(-15px, 50%);
    -ms-transform: translate(-15px, 50%);
    transform: translate(-15px, 50%);
    left: 0;
    top: 0
  }
}

@media (min-width: 768px) {
  .job-description .recommendation__container {
    margin-left: auto;
    margin-right: auto;
    max-width: 65em
  }

  .job-description .recommendation__info-container {
    width: -webkit-calc(100% - 15em);
    width: calc(100% - 15em)
  }

  .job-description .recommendation__button-container {
    width: 15em;
    padding-left: 2em;
    vertical-align: middle
  }

  .job-description .recommendation__info-container {
    vertical-align: middle
  }

  .job-description .recommendation__info-container__type {
    display: inline-block;
    font-size: 1em;
    width: 30%;
    vertical-align: top;
    padding-left: 0.2em;
    font-weight: bolder;
    color: #999
  }

  .job-description .recommendation__info-container__headline-and-location-container {
    display: inline-block;
    width: 70%
  }

  .job-description .recommendation__recommended-job-container {
    padding: 1em 3em
  }
}

@media (max-width: 500px) {
  .job-description .recommendation__header__title--320 {
    display: inline
  }

  .job-description .recommendation__header__title--default {
    display: none
  }

  .job-description .recommendation__info-container {
    width: 100%;
    display: inline-block
  }

  .job-description .recommendation__button-container {
    width: 100%;
    display: inline-block;
    padding-top: 1em;
    text-align: center
  }

  .job-description .recommendation__button-container__apply-button {
    margin-left: 1em
  }

  .job-description .recommendation__button-container__view-button,
  .job-description .recommendation__button-container__apply-button {
    width: -webkit-calc((100% - 1em) / 2);
    width: calc((100% - 1em) / 2)
  }
}

.job-description .recommendation__button-container__view-button--only {
  width: 100%
}

.job-description .crm-apply-modal--mobile .modal-content {
  position: fixed;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: 20000001;
  overflow: scroll;
  height: 100vh
}

.job-description .job-description__categories-list {
  margin-left: 30px;
  list-style: disc
}