html {
  scroll-behavior: smooth; }

@font-face {
  font-family: 'assistant';
  src: url("../../fonts/assistant/Assistant-Regular.ttf") format("truetype");
  font-weight: 400;
  font-style: normal; }

@font-face {
  font-family: 'assistant';
  src: url("../../fonts/assistant/Assistant-SemiBold.ttf") format("truetype");
  font-weight: 600;
  font-style: normal; }

@font-face {
  font-family: 'assistant';
  src: url("../../fonts/assistant/Assistant-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal; }

@font-face {
  font-family: 'assistant';
  src: url("../../fonts/assistant/Assistant-ExtraBold.ttf") format("truetype");
  font-weight: 900;
  font-style: normal; }

.job-page {
  width: 100%; }
  .job-page__banner {
    min-height: 300px;
    position: relative; }
    .job-page__banner .banner-background {
      position: absolute;
      z-index: -1;
      bottom: 0;
      left: 0;
      height: 100%;
      width: 100%; }
      .job-page__banner .banner-background img {
        width: 100%;
        height: 100%;
        object-fit: cover; }
    .job-page__banner .banner-content {
      text-align: start;
      padding-inline: 240px;
      padding-top: 130px;
      padding-bottom: 24px; }
      .job-page__banner .banner-content .back-btn {
        font-family: "assistant";
        color: #414141;
        font-size: 20px;
        line-height: 28px;
        font-weight: 600;
        display: -ms-inline-flexbox;
        display: inline-flex;
        text-decoration: none;
        margin-bottom: 16px; }
      .job-page__banner .banner-content .job-title {
        color: #D71323;
        width: 693px;
        max-height: 112px;
        margin-bottom: 24px;
        overflow: hidden; }
      .job-page__banner .banner-content .banner-bottom {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
            justify-content: space-between;
        -ms-flex-align: center;
            align-items: center;
        margin-bottom: 24px; }
        .job-page__banner .banner-content .banner-bottom .job-attributes {
          display: -ms-flexbox;
          display: flex;
          -ms-flex-align: center;
              align-items: center;
          gap: 16px; }
          .job-page__banner .banner-content .banner-bottom .job-attributes .attribute {
            display: -ms-flexbox;
            display: flex;
            gap: 3px;
            -ms-grid-column-align: center;
                justify-items: center;
            margin: 0; }
        .job-page__banner .banner-content .banner-bottom .job-share .share-popup {
          right: unset;
          left: 48px; }
  .job-page__body {
    margin-top: 10px;
    padding-inline: 240px;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: justify;
        justify-content: space-between;
    margin-bottom: 48px; }
    .job-page__body .mobile-form {
      display: none; }
  .job-page__description {
    width: 707px;
    text-align: right;
    font-family: "assistant";
    font-weight: 400;
    font-size: 20px;
    line-height: 28px; }
    .job-page__description.no-form {
      width: 1200px; }
    .job-page__description p {
      font-family: "assistant";
      font-weight: 400;
      font-size: 20px;
      line-height: 28px;
      margin-bottom: 15px;
      text-align: right; }
    .job-page__description h1,
    .job-page__description h2,
    .job-page__description h3,
    .job-page__description h4,
    .job-page__description h5,
    .job-page__description h6 {
      color: #1f1c22;
      font-weight: 600;
      font-size: 24px;
      line-height: 32px;
      text-align: right;
      font-family: "assistant"; }
    .job-page__description .job-data {
      text-align: right;
      margin-top: 32px; }
      .job-page__description .job-data span {
        font-family: "assistant";
        color: #515151;
        font-size: 18px;
        font-weight: 400; }
      .job-page__description .job-data .job-date {
        border-right: 1px solid #515151;
        margin-inline-start: 8px;
        padding-inline-start: 8px; }
  .job-page__form {
    width: 464px;
    background-color: #F9F9F9;
    box-shadow: 0px -1px 26.4px 0px rgba(0, 0, 0, 0.13);
    height: fit-content;
    padding-block: 24px; }
    .job-page__form .job-data-mobile {
      display: none; }
    .job-page__form .form-header .form-title {
      text-align: center;
      color: #414141;
      margin-bottom: 32px; }
    .job-page__form .form-header .close-mobile-form-btn {
      display: none; }
    .job-page__form .form-header .mobile-handle {
      display: none; }
    .job-page__form .form-label {
      color: #414141; }
    .job-page__form .form-group-input {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-direction: column;
          flex-direction: column;
      text-align: right;
      font-family: "assistant";
      width: 418px;
      margin: auto;
      padding-inline: 24px; }
    .job-page__form .form-group-file {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-direction: column;
          flex-direction: column;
      text-align: right;
      font-family: "assistant";
      width: 418px;
      margin: auto;
      padding-inline: 24px;
      height: 104px;
      margin-bottom: 4px; }
    .job-page__form .form-group-radio {
      text-align: right;
      font-family: "assistant";
      width: 416px;
      margin: auto;
      margin-bottom: 44px;
      padding-inline: 24px; }
      .job-page__form .form-group-radio .radio-label {
        color: #414141;
        font-weight: 400;
        font-size: 18px;
        line-height: 24px;
        text-align: right;
        margin-bottom: 4px; }
      .job-page__form .form-group-radio .radio-options {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
            align-items: center;
        gap: 24px;
        -ms-flex-pack: start;
            justify-content: start;
        padding-block: 9px; }
      .job-page__form .form-group-radio .radio-group {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-align: center;
            align-items: center;
        gap: 6px;
        cursor: pointer; }
        .job-page__form .form-group-radio .radio-group .input-label {
          color: #696969;
          margin-bottom: 0;
          cursor: pointer; }
    .job-page__form .form-group-checkbox {
      width: 418px;
      padding-inline: 24px;
      margin: auto;
      display: -ms-flexbox;
      display: flex;
      -ms-flex-align: baseline;
          align-items: baseline;
      gap: 8px;
      margin-top: 25px; }
      .job-page__form .form-group-checkbox input {
        accent-color: #D71323;
        cursor: pointer; }
      .job-page__form .form-group-checkbox label {
        text-align: right;
        cursor: pointer;
        color: #414141; }
        .job-page__form .form-group-checkbox label a {
          color: #D71323;
          text-decoration: underline;
          cursor: pointer; }
    .job-page__form .form-error-message {
      color: #D71323;
      font-weight: 400;
      font-size: 16px;
      height: 24px; }
    .job-page__form .error-input input {
      border: 1.5px solid #D71323 !important; }
    .job-page__form .error-input .before-upload, .job-page__form .error-input .after-upload {
      border: 1.5px dashed #D71323 !important; }
    .job-page__form .form-actions {
      display: -ms-flexbox;
      display: flex;
      -ms-flex-pack: end;
          justify-content: end;
      width: 418px;
      padding-inline: 24px; }
      .job-page__form .form-actions .btn-primary {
        margin-top: 32px;
        margin-bottom: 24px; }
    .job-page__form .form-submit-error-message {
      color: #D71323;
      text-align: center;
      display: none; }
  .job-page .cbc-group-breadcrumbs {
    padding-block: 24px; }
  @media screen and (max-width: 1700px) {
    .job-page .cbc-group-breadcrumbs {
      margin-inline-start: 140px; }
    .job-page__banner .banner-content {
      padding-inline: 140px; }
    .job-page__body {
      padding-inline: 140px; }
    .job-page__description {
      width: 500px; }
      .job-page__description.no-form {
        width: auto; } }
  @media screen and (max-width: 768px) {
    .job-page .cbc-group-breadcrumbs {
      margin-inline-start: 0;
      padding-inline: 16px;
      top: 88px;
      overflow: scroll;
      width: calc(100vw - 16px); }
      .job-page .cbc-group-breadcrumbs a, .job-page .cbc-group-breadcrumbs span {
        white-space: nowrap;
        display: -ms-flexbox;
        display: flex; }
    .job-page__banner .banner-content {
      padding-inline: 16px;
      padding-bottom: 24px;
      padding-top: 120px; }
      .job-page__banner .banner-content .back-btn {
        font-size: 18px;
        line-height: 24px;
        margin-bottom: 24px;
        display: inline-block; }
      .job-page__banner .banner-content .job-title {
        font-size: 36px;
        line-height: 40px;
        margin-bottom: 24px;
        width: 100%;
        max-height: unset; }
      .job-page__banner .banner-content .banner-bottom {
        -ms-flex-align: start;
            align-items: start;
        -ms-flex-direction: column;
            flex-direction: column;
        gap: 24px;
        margin-bottom: 0; }
        .job-page__banner .banner-content .banner-bottom .job-attributes {
          display: -ms-flexbox;
          display: flex;
          -ms-flex-align: center;
              align-items: center;
          -ms-flex-wrap: wrap;
              flex-wrap: wrap;
          gap: 8px; }
          .job-page__banner .banner-content .banner-bottom .job-attributes span {
            font-weight: 18px;
            line-height: 24px; }
        .job-page__banner .banner-content .banner-bottom .job-share .share-popup {
          right: 0;
          left: unset; }
    .job-page__body {
      padding-inline: 16px;
      margin-top: 40px;
      -ms-flex-direction: column;
          flex-direction: column; }
      .job-page__body .mobile-form {
        display: block;
        margin-top: 40px; }
        .job-page__body .mobile-form .open-form-btn {
          width: 100%; }
    .job-page__description {
      width: 100%;
      margin-top: 0; }
      .job-page__description.no-form {
        width: 100%; }
      .job-page__description p {
        font-size: 18px;
        line-height: 24px;
        margin-bottom: 24px;
        font-weight: 400;
        color: #1f1c22; }
      .job-page__description h1,
      .job-page__description h2,
      .job-page__description h3,
      .job-page__description h4,
      .job-page__description h5,
      .job-page__description h6 {
        font-size: 20px;
        line-height: 26px;
        font-weight: 600;
        text-align: right;
        color: #1f1c22; }
    .job-page__form {
      width: 100%;
      height: 100vh;
      position: fixed;
      top: 0;
      left: 0;
      right: 0;
      overflow: hidden;
      padding-block: unset;
      transform-origin: bottom;
      transform: scaleY(0);
      transition: all 0.3s ease;
      z-index: 101;
      background-color: rgba(0, 0, 0, 0.8); }
      .job-page__form .job-application-form {
        width: 100%;
        margin-top: 56px;
        background-color: #F9F9F9;
        border-top-left-radius: 16px;
        border-top-right-radius: 16px;
        overflow: hidden; }
      .job-page__form.mobile-form-open {
        transform: scaleY(1);
        overflow: scroll; }
      .job-page__form .form-header {
        display: -ms-flexbox;
        display: flex;
        -ms-flex-pack: justify;
            justify-content: space-between;
        -ms-flex-align: center;
            align-items: center;
        padding-inline: 15px;
        background-color: #ffffff;
        height: 80px;
        padding-top: 36px;
        padding-bottom: 16px;
        border-bottom: 1px solid #e6e6e6;
        padding-inline: 16px; }
        .job-page__form .form-header .form-title {
          margin: 0;
          font-weight: 600;
          font-size: 20px;
          color: #1f1c22; }
        .job-page__form .form-header .close-mobile-form-btn {
          border: none;
          background: none;
          display: block;
          width: 21px;
          height: 21px;
          margin: 0;
          padding: 0; }
          .job-page__form .form-header .close-mobile-form-btn img {
            width: 100%;
            height: 100%; }
        .job-page__form .form-header .mobile-handle {
          display: block;
          position: absolute;
          left: 50%;
          transform: translateX(-50%);
          top: 68px;
          width: 32px;
          height: 4px;
          border-radius: 2px;
          z-index: 5;
          background-color: #414141; }
      .job-page__form .job-data-mobile {
        display: block;
        padding: 24px 16px; }
        .job-page__form .job-data-mobile .title {
          color: #D71323;
          text-align: start;
          font-weight: 700;
          font-size: 24px;
          line-height: 28px;
          max-height: 56px;
          overflow: hidden;
          margin-bottom: 8px;
          font-family: "assistant"; }
        .job-page__form .job-data-mobile .job-data {
          display: -ms-flexbox;
          display: flex;
          -ms-flex-pack: start;
              justify-content: start;
          gap: 8px;
          font-family: "assistant";
          color: #1f1c22;
          font-weight: 400;
          font-size: 18px; }
          .job-page__form .job-data-mobile .job-data .job-number {
            border-left: 1px solid #1f1c22;
            padding-left: 8px; }
      .job-page__form .form-group-input {
        width: 100%;
        padding-inline: 16px; }
      .job-page__form .form-group-file {
        width: 100%;
        padding-inline: 16px; }
        .job-page__form .form-group-file .input-file {
          background-color: #ffffff; }
      .job-page__form .form-group-radio {
        width: 100%;
        padding-inline: 16px;
        margin-bottom: 32px; }
        .job-page__form .form-group-radio .radio-group input {
          width: 18px;
          height: 18px; }
        .job-page__form .form-group-radio .radio-group .input-label {
          font-weight: 18px; }
      .job-page__form .form-group-checkbox {
        width: 100%;
        padding-inline: 16px;
        margin-top: 30px; }
        .job-page__form .form-group-checkbox .checkbox-input {
          transform: scale(1.35); }
      .job-page__form .form-actions {
        width: 100%;
        margin-block: 32px; }
        .job-page__form .form-actions .btn-primary {
          width: 100%; }
    .job-page .popup-submit {
      z-index: 999; } }
