@charset "UTF-8";

/*=======================================================
MV
=======================================================*/
.bl_mv {
  background: url(../images/recruit/mv_bg.jpg) top center / cover no-repeat;
  height: 480px;
  padding-top: 252px;
}
.bl_mv_txtWrapper {
  background: url(../images/recruit/mv_txtWrapper.png) top center / contain no-repeat;
  width: 500px;
  height: 220px;
  padding-top: 42px;
  margin: 0 auto;
}
.bl_mv_ttl {
  font-size: 32px;
  text-align: center;
  color: #f7e787;
  margin-bottom: 12px;
}
.bl_mv_txt {
  font-size: 20px;
  text-align: center;
  color: #fff;
}
@media screen and (max-width: 750px) {
  .bl_mv {
    background: url(../images/recruit/mv_bg_sp.jpg) top center / cover no-repeat;
    height: 800px;
    padding-top: 504px;
  }
  .bl_mv_txtWrapper {
    width: 610px;
    height: 268px;
    padding-top: 52px;
    margin: 0 auto;
  }
  .bl_mv_ttl {
    font-size: 40px;
  }
  .bl_mv_txt {
    font-size: 30px;
  }
}
/* 募集中止 */
.el_txt.el_bigTxt {
  font-size: 28px;
}
.bl_jobDescription.--deactive{
	pointer-events: none;
	opacity: 0.7;
}
@media screen and (max-width: 750px) {
  .el_txt.el_bigTxt {
    font-size: 34px;
  }
}
/*=======================================================
求人
=======================================================*/
.bl_job {
  padding: 58px 0 80px;
}
.bl_intro {
  margin: 0 auto 140px;
  font-size: 20px;
  text-align: center;
}
.bl_intro {
  color: rgba(78, 46, 46, 0.7);
}
.bl_intro .--strong {
  font-size: 28px;
}
.bl_intro > p + p {
  margin-top: 30px;
}
.bl_workTxt {
  font-size: 18px;
  text-align: center;
  margin-bottom: 136px;
}
@media screen and (max-width: 750px) {
  .bl_intro {
    margin: 0 auto 330px;
    font-size: 28px;
  }
  .bl_intro .--strong {
    font-size: 36px;
  }
  .bl_workTxt {
    font-size: 28px;
    margin-bottom: 344px;
  }
}

/*=======================================================
メイン
=======================================================*/
#job .ly_cont_inner {
  padding: 60px 0;
}
.bl_jobDescriptionList {
  position: relative;
}
/*職種ボタン*/
.bl_jobDescription_radio {
  display: none;
}
.bl_jobDescription_btn {
  width: 192px;
  height: 72px;
  border-radius: 36px;
  font-size: 18px;
  color: #4e2e2e;
  text-align: center;
  background: #cccbc8;
  display: flex;
  justify-content: center;
  align-items: center;
  cursor: pointer;
  position: absolute;
  top: -102px;
  z-index: 5;
  overflow: hidden;
  transition: 0.3s ease;
}
.bl_jobDescription_btn:hover {
  opacity: 0.7;
  transition: 0.3s ease;
}
/*職種見出し*/
.bl_recruit_ttl {
  height: 56px;
  margin-bottom: 40px;
  color: #fff;
  background: #78746b;
  font-size: 30px;
  font-weight: 600;
  display: flex;
  justify-content: center;
  align-items: center;
}
.bl_jobDescription_radio:checked + .bl_jobDescription_btn {
  background: #d2c3bc;
  transition: 0.3s ease;
}
/*職種ボタン・見出し カラー、位置設定*/
#jobBtn + .bl_jobDescription_btn {
  left: 0;
}
#jobBtn02 + .bl_jobDescription_btn {
  left: 208px;
}
#jobBtn03 + .bl_jobDescription_btn {
  left: 416px;
}
#jobBtn04 + .bl_jobDescription_btn {
  left: 624px;
  display: flex;
  flex-wrap: wrap;
}
#jobBtn04 + .bl_jobDescription_btn > span {
  display: block;
  margin-top: -11px;
}
#jobBtn05 + .bl_jobDescription_btn {
  left: 832px;
}
/* テキスト */
.bl_jobTxt {
  text-align: center;
}
.bl_jobTxt + .bl_jobTxt {
  margin-top: 26px;
}
/*テーブル*/
.bl_jobDescription_info {
  display: none;
}
.bl_jobDescription_radio:checked ~ .bl_jobDescription_info {
  display: block;
}
.bl_jobDescription_table {
  width: 100%;
  background: #fff;
  margin-top: 36px;
}
.bl_jobDescription_tbody > tr + tr th {
  border-top: 1px solid #a2a2a2;
}
.bl_jobDescription_tbody > tr + tr td {
  border-top: 1px solid #fff;
}
.bl_jobDescription_tbody > tr > th {
  width: 256px;
  height: 89px;
  text-align: center;
  background: #475763;
  border-right: 1px solid #a2a2a2;
  color: #fff;
  font-size: 18px;
  background: #78746b;
}
.bl_jobDescription_tbody > tr > th {
  padding-top: 3px;
}
.bl_jobDescription_tbody > tr > td {
  padding: 28px 29px 29px 48px;
  line-height: 1.6;
  letter-spacing: 0;
  background: #f0eee7;
}
.bl_jobDescription_tbody > tr:nth-of-type(4) td .bl_bulletList {
  margin-bottom: 26px;
}
.bl_jobDescription_tbody dl > div {
  display: flex;
  flex-wrap: wrap;
}
.bl_jobDescription_tbody .bl_workList {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
@media screen and (max-width: 750px) {
  #job .ly_cont_inner {
    padding: 60px 0;
  }
  /*職種ボタン*/
  .bl_jobDescription_btn {
    width: 220px;
    height: 104px;
    border-radius: 104px;
    font-size: 28px;
    top: -286px;
  }
  /*職種見出し*/
  .bl_recruit_ttl {
    height: 72px;
    margin-bottom: 50px;
    font-size: 34px;
  }
  /*職種ボタン・見出し カラー、位置設定*/
  #jobBtn02 + .bl_jobDescription_btn {
    left: 235px;
  }
  #jobBtn03 + .bl_jobDescription_btn {
    left: 470px;
  }
  #jobBtn04 + .bl_jobDescription_btn {
    top: -159px;
    left: 88px;
    width: 250px;
  }
  #jobBtn04 + .bl_jobDescription_btn > span {
    font-size: 26px;
    margin-top: -25px;
  }
  #jobBtn05 + .bl_jobDescription_btn {
    top: -159px;
    left: 353px;
  }
  /* テキスト */
  .bl_jobTxt {
    font-size: 27px;
    letter-spacing: 0;
  }
  .bl_jobTxt + .bl_jobTxt {
    margin-top: 42px;
  }
  /*テーブル*/
  .bl_jobDescription_table {
    width: 100%;
    border: 2px solid #a2a2a2;
    margin-top: 48px;
  }
  .bl_jobDescription_tbody > tr + tr th,
  .bl_jobDescription_tbody > tr + tr td {
    border-top: none;
  }
  .bl_jobDescription_tbody > tr + tr td .sp_bold {
    font-weight: 700;
  }
  .bl_jobDescription_tbody > tr > th {
    width: 100%;
    height: auto;
    display: block;
    text-align: left;
    border-right: none;
    font-size: 28px;
    padding: 20px 25px;
    border-bottom: 2px solid #a2a2a2;
  }
  .bl_jobDescription_tbody > tr > td {
    width: 100%;
    display: block;
    padding: 20px 25px;
    border-bottom: 2px solid #a2a2a2;
  }
  .bl_jobDescription_tbody > tr:last-of-type td {
    border-bottom: none;
  }
  .bl_jobDescription_tbody .bl_workList {
    gap: 16px;
  }
}

/*=======================================================
サンクスMV
=======================================================*/
.bl_lower_mv_ttl::after {
  background: url(../images/recruit/mv_ttl.svg) top center/contain no-repeat;
  width: 58px;
  height: 13px;
}
@media screen and (max-width: 750px) {
  .bl_lower_mv_ttl::after {
    width: 141px;
    height: 32px;
  }
}
