@charset "utf-8";

/* --------------------------------------- */
/* 採用情報　下層ページ
/* --------------------------------------- */

/* common
-------------------------------------------*/
section+.in-page-anchor+section {
  margin-top: -24px;
}

.recUnder-sec-tit {
  font-size: min(calc((40 / 1200) * 100vw), 40px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  position: relative;
  margin-bottom: min(calc((35 / 1200) * 100vw), 35px);
  padding-left: min(calc((60 / 1200) * 100vw), 60px);
  padding-bottom: min(calc((6 / 1200) * 100vw), 6px);
  border-bottom: 2px solid #66b9d6;
}

.recUnder-sec-tit::before {
  content: '';
  display: block;
  width: min(calc((35 / 1200) * 100vw), 35px);
  height: min(calc((35 / 1200) * 100vw), 35px);
  border-radius: 50%;
  border: min(calc((5 / 1200) * 100vw), 5px) solid #66b9d6;
  box-sizing: border-box;
  position: absolute;
  left: min(calc((10 / 1200) * 100vw), 10px);
  top: min(calc((15 / 1200) * 100vw), 15px);
}

.recUnder-sec-tit_s {
  font-size: 75%;
}

.recUnder-third-tit {
  font-size: min(calc((30 / 1200) * 100vw), 30px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  margin-top: 34px;
}

.recUnder-fourth-tit {
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 700;
  line-height: 1.9;
  letter-spacing: .1em;
}

.recUnder-third-tit+.recUnder-fourth-tit {
  margin-top: 20px;
}

.recUnder-serif-tit {
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-size: min(calc((70 / 1200) * 100vw), 70px);
  font-weight: 900;
  line-height: 1;
  letter-spacing: .1em;
}

.recUnder-num-tit {
  display: flex;
}

.recUnder-num-tit_left {
  color: #66b9d6;
}

.recUnder-num-tit_left_en {
  display: block;
  font-family: "Roboto Condensed";
  font-weight: 700;
  font-size: min(calc((18 / 1200) * 100vw), 18px);
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
}

.recUnder-num-tit_left_num {
  display: block;
  font-family: "Roboto Condensed";
  font-weight: 700;
  font-size: min(calc((90 / 1200) * 100vw), 90px);
  letter-spacing: 0;
  line-height: 1;
  text-align: center;
}

.recUnder-num-tit_right {
  margin-left: 1.5em;
  margin-top: .2em;
}

.recUnder-num-tit_right_desc {
  font-size: min(calc((30 / 1200) * 100vw), 30px);
  font-weight: 700;
  line-height: 1.26;
  letter-spacing: .1em;
}

.recUnder-num-tit_right_desc_s {
  font-size: 80%;
}

.recUnder-horizontal-tit {
  font-size: min(calc((35 / 1200) * 100vw), 35px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  position: relative;
  padding-left: min(calc((50 / 1200) * 100vw), 50px);
  margin-top: 47px;
}

.recUnder-horizontal-tit::before {
  content: '';
  display: block;
  width: min(calc((40 / 1200) * 100vw), 40px);
  height: 5px;
  background-color: #66b9d6;
  position: absolute;
  left: 0;
  top: min(calc((26 / 1200) * 100vw), 26px);
}

.recUnder-vertical-tit {
  font-size: min(calc((30 / 1200) * 100vw), 30px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  position: relative;
  padding-left: min(calc((13 / 1200) * 100vw), 13px);
  margin-top: 20px;
}

.recUnder-vertical-tit::before {
  content: '';
  display: block;
  width: 5px;
  height: 71%;
  background-color: #66b9d6;
  position: absolute;
  left: 0;
  top: min(calc((9 / 1200) * 100vw), 9px);
}

.recUnder-square-tit {
  font-size: min(calc((24 / 1200) * 100vw), 24px);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: .1em;
  position: relative;
  padding-left: min(calc((25 / 1200) * 100vw), 25px);
}

.recUnder-square-tit::before {
  content: '';
  display: block;
  width: min(calc((20 / 1200) * 100vw), 20px);
  height: min(calc((20 / 1200) * 100vw), 20px);
  background-color: #66b9d6;
  position: absolute;
  left: 0;
  top: min(calc((8 / 1200) * 100vw), 8px);
}


.fig-tit {
  font-size: min(calc((40 / 1200) * 100vw), 40px);
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: .1em;
  text-align: center;
  position: relative;
  padding-bottom: min(calc((15 / 1200) * 100vw), 15px);
  display: table;
  margin: 0 auto;
}

.fig-tit::after {
  content: '';
  display: block;
  width: min(calc((100 / 1200) * 100vw), 100px);
  height: 2px;
  background-color: #66b9d6;
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
}

.recUnder-txt-n {
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 400;
  line-height: 1.9;
  letter-spacing: .1em;
  margin-top: 12px;
}

.recUnder_frame+.recUnder-txt-n {
  margin-top: 20px;
}

.recUnder-serif-tit+.recUnder-txt-n {
  margin-top: 36px;
}

.recUnder-txt-m {
  font-size: min(calc((18 / 1200) * 100vw), 18px);
  font-weight: 400;
  line-height: 1.88;
  letter-spacing: .05em;
}

.recUnder-num-tit+.recUnder-txt-m {
  margin-top: 12px;
}

.recUnder_indent-inner {
  padding: 0 min((calc(35 / 1200) * 100vw), 35px);
}

.recUnder_bullet-ul>li+li {
  margin-top: 19px;
}

.recUnder_bullet-ul_tit {
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 700;
  line-height: 1.7;
  letter-spacing: .1em;
  text-indent: -1em;
  padding-left: 1em;
}

.recUnder_bullet-ul_desc {
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 400;
  line-height: 1.7;
  letter-spacing: .1em;
}

.recUnder-lightbox-ul {
  margin-top: 50px;
}

.recUnder-lightbox-ul>li {
  background-color: #e1eff5;
  border-radius: min(calc((20 / 1200) * 100vw), 20px);
  padding: min(calc((24 / 1200) * 100vw), 24px) min(calc((30 / 1200) * 100vw), 30px);
  position: relative;
}

.recUnder-lightbox-ul>li+li {
  margin-top: 60px;
}

.recUnder-star-ul>li {
  padding-left: 1.5em;
  position: relative;
}

.recUnder-star-ul>li::before {
  content: '★';
  display: inline-block;
  width: 1em;
  height: 1em;
  color: #66b9d6;
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 700;
  position: absolute;
  left: 0;
  top: .15em;
}

.recUnder-star-ul>li+li {
  margin-top: 15px;
}

.recUnder-star-ul>li .font-s {
  font-size: 80%;
  text-indent: -1em;
  padding-left: 1em;
  display: inline-block;
}


@media screen and (max-width: 767px) {

  .recUnder-sec-tit {
    font-size: calc((48 / 750) * 100vw);
    margin-bottom: calc((30 / 750) * 100vw);
    padding-left: calc((65 / 750) * 100vw);
    padding-bottom: calc((5 / 750) * 100vw);
  }

  .recUnder-sec-tit::before {
    width: calc((40 / 750) * 100vw);
    height: calc((40 / 750) * 100vw);
    border: 3px solid #66b9d6;
    left: calc((10 / 750) * 100vw);
    top: calc((18 / 750) * 100vw);
  }

  .recUnder-sec-tit_s {
    margin-top: -.2em;
    display: block;
  }

  .recUnder-third-tit {
    font-size: calc((33 / 750) * 100vw);
    margin-top: calc((35 / 750) * 100vw);
  }

  .recUnder-fourth-tit {
    font-size: calc((30 / 750) * 100vw);
  }

  .recUnder-serif-tit {
    font-size: calc((74 / 750) * 100vw);
  }

  .fig-tit {
    font-size: calc((48 / 750) * 100vw);
    padding-bottom: calc((18 / 750) * 100vw);
  }

  .fig-tit::after {
    width: calc((100 / 750) * 100vw);
  }

  .recUnder-txt-n {
    font-size: calc((26 / 750) * 100vw);
    margin-top: calc((28 / 750) * 100vw);
  }

  .recUnder_frame+.recUnder-txt-n {
    margin-top: calc((45 / 750) * 100vw);
  }

  .recUnder-serif-tit+.recUnder-txt-n {
    margin-top: calc((54 / 750) * 100vw);
  }

  .recUnder-txt-m {
    font-size: calc((24 / 750) * 100vw);
    line-height: 2;
  }

  .recUnder-num-tit+.recUnder-txt-m {
    margin-top: calc((20 / 750) * 100vw);
  }

  .recUnder-num-tit_right {
    margin-left: 1em;
  }

  .recUnder-num-tit_left_en {
    font-size: calc((22 / 750) * 100vw);
  }

  .recUnder-num-tit_left_num {
    font-size: calc((110 / 750) * 100vw);
  }

  .recUnder-num-tit_right_desc {
    font-size: calc((36 / 750) * 100vw);
    line-height: 1.26;
  }

  .recUnder-horizontal-tit {
    font-size: calc((42 / 750) * 100vw);
    padding-left: calc((40 / 750) * 100vw);
    margin-top: calc((35 / 750) * 100vw);
  }

  .recUnder-horizontal-tit::before {
    width: calc((30 / 750) * 100vw);
    top: calc((28 / 750) * 100vw);
  }

  .recUnder-vertical-tit {
    font-size: calc((34 / 750) * 100vw);
    padding-left: calc((24 / 750) * 100vw);
    margin-top: calc((20 / 750) * 100vw);
  }

  .recUnder-vertical-tit::before {
    width: calc((10 / 750) * 100vw);
    height: calc((38 / 750) * 100vw);
    top: calc((9 / 750) * 100vw);
  }

  .recUnder-lightbox-ul {
    margin-top: calc((30 / 750) * 100vw);
  }

  .recUnder-lightbox-ul>li {
    border-radius: calc((20 / 750) * 100vw);
    padding: calc((30 / 750) * 100vw) calc((30 / 750) * 100vw);
  }

  .recUnder-lightbox-ul>li+li {
    margin-top: calc((70 / 750) * 100vw);
  }

  .recUnder-square-tit {
    font-size: calc((29 / 750) * 100vw);
    padding-left: calc((40 / 750) * 100vw);
  }

  .recUnder-square-tit::before {
    content: '';
    display: block;
    width: calc((25 / 750) * 100vw);
    height: calc((25 / 750) * 100vw);
    background-color: #66b9d6;
    position: absolute;
    left: 0;
    top: calc((9 / 750) * 100vw);
  }

  .recUnder-star-ul>li {
    padding-left: calc((35 / 750) * 100vw);
  }

  .recUnder-star-ul>li+li {
    margin-top: calc((30 / 750) * 100vw);
  }

  .recUnder-star-ul>li::before {
    font-size: calc((28 / 750) * 100vw);
    top: calc((3 / 750) * 100vw);
  }

  .recUnder-star-ul>li .font-s {
    font-size: 85%;
    margin-top: calc((13 / 750) * 100vw);
  }

}


/* メインビジュアル
-------------------------------------------*/
.recUnderMvBl {
  overflow: hidden;
  background: url(../img/recruit_what_mv.webp) no-repeat center 0/cover;
}

.recUnderMv_inner {
  max-width: 1580px;
  height: 700px;
  padding: 0 40px;
  box-sizing: border-box;
  margin: 0 auto;
  position: relative;
}

.recUnderMv_txtwrap {
  position: absolute;
  left: 40px;
  bottom: 54px;
  margin: auto 0;
  text-shadow: rgb(0, 0, 0) 3px 3px 30px;
  color: #fff;
  z-index: 2;
}

.recUnderMv_txt_en {
  display: block;
  font-family: "Roboto Condensed";
  font-weight: 700;
  font-size: 100px;
  letter-spacing: .01em;
  line-height: 1;
}

.recUnderMv_txt_jp {
  display: block;
  font-weight: 700;
  font-size: 30px;
  letter-spacing: .1em;
  line-height: 1.3;
  position: relative;
  top: -.08em;
}


@media screen and (max-width: 767px) {
  .recUnderMv_inner {
    height: calc((900 / 750) * 100vw);
    padding: 0 calc((30 / 750) * 100vw);
  }

  .recUnderMv_txtwrap {
    left: calc((30 / 750) * 100vw);
    bottom: calc((50 / 750) * 100vw);
    text-shadow: rgba(0, 0, 0, .6) 1.5px 1.5px 15px;
  }

  .recUnderMv_txt_en {
    font-size: calc((110 / 750) * 100vw);
  }

  .recUnderMv_txt_jp {
    font-size: calc((33 / 750) * 100vw);
  }
}


/*  パンくず
-------------------------------------------*/
.recUnderPnkzBl {
  padding: 15.25px 0;
  background-color: #f1f1f1;
}

.recUnderPnkz_ul {
  display: flex;
  flex-wrap: wrap;

}

.recUnderPnkz_ul>li {
  display: inline-block;
  font-size: 1.3rem;
  line-height: 1.5;
  letter-spacing: .05em;
}

.recUnderPnkz_ul>li+li {
  margin-left: 2.0em;
  position: relative;
}

.recUnderPnkz_ul>li+li::before {
  content: '';
  display: inline-block;
  width: 1px;
  height: 16px;
  background-color: #000;
  position: absolute;
  left: -1.0em;
  top: 3px;
}


@media screen and (max-width: 767px) {
  .recUnderPnkzBl {
    padding: 7.5px 0;
  }

  .recUnderPnkz_ul>li {
    font-size: 1rem;
  }

  .recUnderPnkz_ul>li+li {
    margin-left: 1.6em;
  }

  .recUnderPnkz_ul>li+li::before {
    height: 10px;
    left: -.85em;
    top: 3px;
  }
}


/* 「ラクサスへ応募する」
-------------------------------------------*/
.recEntryBtnBl {
  margin-top: -15px;
}


/* 「ラクサスへ応募する」
-------------------------------------------*/
.recUnder_frame {
  margin: 20px auto 0;
}

.recUnder_frame_tit {
  background-color: #1f385a;
  font-size: min(calc((24 / 1200) * 100vw), 24px);
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: .1em;
  text-align: center;
  color: #fff;
  padding: .45em 1em .55em 1em;
}

.recUnder_frame_inner {
  background-color: #dce3eb;
  overflow: hidden;
  padding: 1.9em 2em;
}

.recUnder_frame_imgwrap {
  float: right;
  width: 48.2%;
  margin: 1.4% 2% 0 4%;
}


@media screen and (max-width: 767px) {
  .recUnder_frame {
    margin: calc((45 / 750) * 100vw) auto 0;
  }

  .recUnder_frame_inner {
    padding: calc((30 / 750) * 100vw) 15px;
    display: flex;
    flex-wrap: wrap;
    flex-direction: column-reverse;
  }

  .recUnder_frame_imgwrap {
    float: none;
    width: 100%;
    margin: calc((20 / 750) * 100vw) 0 0;
  }

  .recUnder_frame_tit {
    font-size: calc((29 / 750) * 100vw);
  }

  .recUnder_bullet-ul>li+li {
    margin-top: calc((30 / 750) * 100vw);
  }

  .recUnder_bullet-ul_tit,
  .recUnder_bullet-ul_desc {
    font-size: calc((26 / 750) * 100vw);
  }

}


/* ボタンエリア
-------------------------------------------*/
.recUnderBtnsBl {
  padding: 100px 0;
  background: url(../img/recruit_under_mv.webp) no-repeat center 0 / cover;
  position: relative;
}

.recUnderBtnsBl::before {
  content: '';
  display: block;
  width: 100%;
  height: 100%;
  background: rgba(255, 255, 255, 1);
  position: absolute;
  top: 0;
  left: 0;
  z-index: 0;
  mix-blend-mode: color;
}

.recUnderBtns_ul {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  margin: 0 auto;
  position: relative;
  z-index: 3;
}

.recUnderBtns_ul>li {
  width: 60%;
  margin: 0 auto;
}

.recUnderBtns_ul>li:nth-child(n+2) {
  margin-top: 5.1%;
}

.recUnderBtns_ul_btn {
  display: block;
  background-color: rgba(31, 56, 90, .8);
  padding: 1.7em 3em 1.3em 1.8em;
  position: relative;
}

.recUnderBtns_ul_btn:hover {
  background-color: rgba(76, 126, 247, .8);
}

.recUnderBtns_ul_btn::before {
  content: '';
  display: block;
  width: 11px;
  height: 20px;
  background: url(../img/arrow_right_white.webp) no-repeat center / contain;
  position: absolute;
  right: 6%;
  top: calc(50% - 10px);
  transform: rotate(180deg);
}

.recUnderBtns_ul_btn_txt-en {
  color: #fff;
  display: block;
  font-family: "Roboto Condensed";
  font-weight: 700;
  font-size: 1.6rem;
  letter-spacing: 0;
  line-height: 1;
}

.recUnderBtns_ul_btn_txt-jp {
  color: #fff;
  display: block;
  font-size: 2.4rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: .06em;
  margin-top: 3px;
}


@media screen and (max-width: 767px) {
  .recUnderBtnsBl {
    padding: calc((120 / 750) * 100vw) 0;
  }

  .recUnderBtns_ul {
    display: block;
    margin: 0 auto;
  }

  .recUnderBtns_ul>li {
    width: auto;
    margin-right: 0;
  }

  .recUnderBtns_ul>li:nth-child(n+2) {
    margin-top: 20px;
  }

  .recUnderBtns_ul_btn_txt-en {
    font-size: 1rem;
    letter-spacing: .1em;
  }

  .recUnderBtns_ul_btn_txt-jp {
    font-size: 1.4rem;
    letter-spacing: .08em;
    margin-top: 3px;
  }

  .recUnderBtns_ul_btn {
    padding: 16px 30px 12px 15px;
  }

  .recUnderBtns_ul_btn:hover {
    background-color: rgba(31, 56, 90, .8);
  }

  .recUnderBtns_ul_btn::before {
    width: 10px;
    height: 16px;
    right: 15px;
    top: calc(50% - 7px);
  }

}

/* 紺色ボタン btn-navy
-------------------------------------------*/
.btn-navy {
  background-color: rgba(31, 56, 90, .7);
  border: 1px solid #1f385a;
  border-radius: 9999px;
  display: table;
  margin: 25px auto 0;
  padding: .85em 2.5em 1.05em 2.5em;
  cursor: pointer;
}

.btn-navy:hover {
  background-color: #fff;
  opacity: 1;
}

.btn-navy_txt {
  font-size: min(calc((20 / 1200) * 100vw), 20px);
  font-weight: 400;
  line-height: 1.4;
  letter-spacing: .1em;
  text-align: center;
  color: #fff;
  position: relative;
  padding-left: min(calc((14 / 1200) * 100vw), 14px);
}

.btn-navy:hover .btn-navy_txt {
  color: #1f385a;
}

.btn-navy_txt::after {
  content: '';
  display: block;
  width: min(calc((7 / 1200) * 100vw), 7px);
  height: min(calc((14 / 1200) * 100vw), 14px);
  background: url(../img/arrow_right_white_2.webp) no-repeat center / contain;
  position: absolute;
  left: 0;
  top: min(calc((8 / 1200) * 100vw), 8px);
}

.btn-navy:hover .btn-navy_txt::after {
  background: url(../img/arrow_top_blue_2.webp) no-repeat center / contain;
}


@media screen and (max-width: 767px) {
  .btn-navy {
    margin: calc((40 / 750) * 100vw) auto 0;
    padding: calc((10 / 750) * 100vw) calc((30 / 750) * 100vw);
  }

  .btn-navy:hover {
    background-color: rgba(31, 56, 90, .7);
    opacity: 1;
  }

  .btn-navy_txt {
    font-size: calc((26 / 750) * 100vw);
    padding-left: calc((20 / 750) * 100vw);
    line-height: 1;
  }

  .btn-navy:hover .btn-navy_txt {
    color: #fff;
  }

  .btn-navy_txt::after {
    width: calc((9 / 750) * 100vw);
    height: calc((18 / 750) * 100vw);
    top: calc((10 / 750) * 100vw);
  }

  .btn-navy:hover .btn-navy_txt::after {
    background: url(../img/arrow_right_white_2.webp) no-repeat center / contain;
  }
}


@media screen and (max-width: 420px) {
  .btn-navy {
    padding: calc((8 / 750) * 100vw) calc((30 / 750) * 100vw) calc((12 / 750) * 100vw) calc((30 / 750) * 100vw);
  }
}


/* 無限スライダー
-------------------------------------------*/
.recUnderInfiniteSliderBl {
  padding: 10px 0;
}

.recUnderInfiniteSlider_ul .slick-slide {
  margin: 0 5px;
}

.recUnderInfiniteSlider_ul_imgwrap {
  position: relative;
}

.recUnderInfiniteSlider_ul_imgwrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
  border: 10px solid rgba(255, 255, 255, .75);
  box-sizing: border-box;
  pointer-events: none;
  z-index: 1;
}

.recUnderInfiniteSliderBl .slider.slick-initialized {
  margin-bottom: 0;
}