﻿
/*================================================
 * 採用情報 > TOP
 ================================================*/
/*******見出し*******/
h2.head_title .ff_english {
  font-size: 170px;
  letter-spacing: .08em;
}
h2.head_title .ja {
  font-size: 26px;
  letter-spacing: .08em;
  display: block;
  margin-top: 1.25em;
}
/*******メインエリア*******/
#recruit #main_area {
  position: relative;
  height: 800px;
  margin-top: 48px;
  overflow: hidden;
}
#recruit #main_area.mask > span.inner {
  display: inline-block;
  width: 100%;
  height: 100%;
  background: url("../image/recruit_main.jpg") no-repeat 50%/cover;
}
#recruit #main_area.mask > span.inner > div {
  height: 100%;
}
#recruit #main_area.mask.move .beta {
  background-color: #0078bd;
}
#recruit #main_area h1.ttl {
  padding-top: 25px;
}
#recruit #main_area h1.ttl .ff_english {
  font-size: 173px;
  font-weight: 500;
  -webkit-text-stroke: 1px #FFF;
  text-stroke: 1px #FFF;
  color: transparent;
  letter-spacing: 0.1em;
  display: inline-block;
  margin-left: -10px;
}
#recruit #main_area h1.ttl .ja {
  font-size: 32px;
  font-weight: bold;
  letter-spacing: .08em;
  color: #fff;
  display: block;
  margin-top: 30px;
}
/*******recruit*******/
section#recruit_area {
  padding-top: 0;
  position: relative;
}
section#recruit_area .wrap1100 {
  padding-top: 140px;
  padding-bottom: 170px;
  position: relative;
  color: #fff;
  min-width: 1240px;
}
section#recruit_area .wrap1100::after {
  content: "";
  width: 2000px;
  height: 100%;
  position: absolute;
  right: 70px;
  top: 0;
  z-index: -2;
  background-color: #0078BD;
}
section#recruit_area .photo {
  width: 1400px;
  height: 700px;
  position: absolute;
  top: -180px;
  right: -340px;
  z-index: -1;
  overflow: hidden;
}
section#recruit_area .photo > .inner {
  display: inline-block;
  width: 1400px;
  height: 700px;
  background: url("../image/front_recruit01.jpg") no-repeat center/cover;
}
section#recruit_area .photo.mask.move .beta {
  background-color: #0078bd;
}
section#recruit_area h2.head_title {
  margin-bottom: 125px;
}
section#recruit_area h2.head_title .ff_english {
  font-size: 222px;
  margin-left: -15px;
}
section#recruit_area h2.head_title .ja {
  font-size: 32px;
  margin-top: 1em;
}
section#recruit_area p.main_lead {
  font-size: 66px;
  line-height: 1.6;
  letter-spacing: .12em;
  margin-bottom: 90px;
  animation-fill-mode: both;
}
section#recruit_area p.main_lead.move {
  animation-name: blur;
  animation-duration: 0.8s;
  opacity: 1;
}
@keyframes blur {
  0% {
    filter: blur(2em);
    -webkit-filter: blur(2em);
  }
  100% {
    filter: blur(0);
    -webkit-filter: blur(0);
  }
}
@-webkit-keyframes blur {
  0% {
    filter: blur(2em);
    -webkit-filter: blur(2em);
  }
  100% {
    filter: blur(0);
    -webkit-filter: blur(0);
  }
}
section#recruit_area .wrap1100 > .inner {
  animation-delay: 0.3s;
}
section#recruit_area p.main_text {
  font-size: 24px;
  line-height: 3;
  padding-right: 570px;
  margin-bottom: 90px;
}
section#recruit_area p.btn a.hover_btn::after {
  border-color: transparent transparent #fff transparent;
}
section#recruit_area p.btn a.hover_btn .icon-arrow02 {
  color: #0078bd;
}
section#recruit_area p.img {
  position: relative;
}
section#recruit_area p.img img {
  position: absolute;
  right: -145px;
  top: -325px;
}
/*******job*******/
section#job_area {
  padding-top: 265px;
}
section#job_area .wrap1100 {
  margin-bottom: 95px;
}
section#job_area h2.head_title {
  margin-bottom: 40px;
}
section#job_area p.main_text {
  font-size: 22px;
  line-height: 2.5;
}
section#job_area .wrap1260 {
  min-width: 1240px;
}
section#job_area ul.items {
  opacity: 1;
}
section#job_area ul.items li.photo {
  width: 400px;
  max-width: 32%;
  height: 660px;
  position: relative;
  z-index: 1;
  overflow: hidden;
  color: #fff;
}
section#job_area ul.items li.photo:nth-child(1) {
  margin-top: 80px;
}
section#job_area ul.items li.photo:nth-child(2) {
  margin-top: 40px;
}
section#job_area ul.items li.photo > .inner {
  width: 100%;
  height: 100%;
  display: flex;
  flex-wrap: wrap;
  align-content: flex-end;
  padding: 45px 55px 75px 42px;
  position: relative;
}
section#job_area ul.items li.photo > .inner > img {
  position: absolute;
  z-index: -2;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}
section#job_area ul.items li.photo:hover > .inner > img {
  -webkit-transform: translate(-50%, -50%) scale(1.1);
  -ms-transform: translate(-50%, -50%) scale(1.1);
  transform: translate(-50%, -50%) scale(1.1);
}
section#job_area ul.items li.photo.mask.move .beta {
  background-color: #0078bd;
}
section#job_area ul.items h3 {
  font-size: 40px;
  letter-spacing: .08em;
  margin-bottom: 25px;
}
section#job_area ul.items p.text {
  font-size: 20px;
  line-height: 1.75;
}
section#job_area ul.items a.hover_btn {
  position: static;
}
section#job_area ul.items a.hover_btn:hover {
  opacity: 1;
}
section#job_area ul.items a.hover_btn .icon-arrow02 {
  font-size: 36px;
  right: 7px;
  bottom: 0px;
}
section#job_area ul.items a.hover_btn::after {
  border-width: 0 0 80px 80px;
  border-color: transparent transparent #0078BD transparent;
  bottom: 0;
}
/*******entry*******/
section#entry_area {
  padding-top: 155px;
  padding-bottom: 130px;
}
section#entry_area h2.head_title {
  text-align: center;
}
section#entry_area h2.head_title .ff_english {
  font-size: 120px;
}
section#entry_area h2.head_title .ja {
  margin-top: 18px;
}
section#entry_area ul {
  margin-top: 55px;
}
section#entry_area ul li a {
  display: flex;
  align-items: center;
  justify-content: center;
  flex-direction: column;
  width: 535px;
  height: 160px;
  text-align: center;
  border-radius: 160px;
  color: #fff;
  border: 2px solid #0078bd;
}
section#entry_area ul li a:hover {
  background-color: #fff;
  color: #0078bd;
  opacity: 1;
}
section#entry_area ul li a .ff_english {
  font-size: 48px;
  letter-spacing: .08em;
}
section#entry_area ul li a .ja {
  font-size: 20px;
  margin-top: 15px;
  letter-spacing: .08em;
}
/*================================================================================================
 *  スマートフォン向けデザイン
 ================================================================================================*/
@media screen and (max-width: 900px) {
  /*******見出し*******/
  h2.head_title .ff_english {
    font-size: 18.933vw;
  }
  h2.head_title .ja {
    font-size: 4vw;
    margin-top: 3.733vw;
  }
  /*******メインエリア*******/
  #recruit #main_area {
    height: 106.667vw;
    margin-top: 4vw;
  }
  #recruit #main_area.mask > span.inner {
    background-image: url(../image/recruit_main_sp.jpg);
  }
  #recruit #main_area.mask > span.inner > div {
    align-items: flex-end;
    padding-bottom: 10vw;
  }
  #recruit #main_area .wrap1100 {
    padding: 0 8.2vw;
  }
  #recruit #main_area h1.ttl {
    padding-top: 0;
  }
  #recruit #main_area h1.ttl .ff_english {
    font-size: 20vw;
    margin-left: 0;
  }
  #recruit #main_area h1.ttl .ja {
    font-size: 4.533vw;
    margin-top: 5.5vw;
  }
  /*******recruit*******/
  section#recruit_area .wrap1100 {
    padding: 14.133vw 16vw 30.5vw 10vw;
    min-width: auto;
  }
  section#recruit_area .wrap1100::after {
    right: 9.333vw;
  }
  section#recruit_area .photo {
    width: 85vw;
    height: 80vw;
    top: -18.667vw;
    right: 0;
  }
  section#recruit_area .photo > .inner {
    width: 100%;
    height: 100%;
    background-image: url("../image/front_recruit01_sp.jpg");
  }
  section#recruit_area h2.head_title {
    margin-bottom: 9vw;
  }
  section#recruit_area h2.head_title .ff_english {
    font-size: 18.933vw;
  }
  section#recruit_area h2.head_title .ja {
    font-size: 4.267vw;
  }
  section#recruit_area .wrap1100 > .inner {
    animation-delay: 0.8s;
  }
  section#recruit_area p.main_lead {
    font-size: 6.4vw;
    margin-bottom: 9vw;
  }
  section#recruit_area p.main_text {
    font-size: 4vw;
    line-height: 2.25;
    padding-right: 6vw;
    margin-bottom: 10vw;
  }
  section#recruit_area p.img img {
    right: -12.633vw;
    top: 16vw;
    width: 73.86vw;
    height: auto;
  }
  /*******job*******/
  section#job_area {
    padding-top: 59vw;
  }
  section#job_area .wrap1100 {
    margin-bottom: 10vw;
    padding: 0 5.7vw;
  }
  section#job_area h2.head_title {
    margin-bottom: 9.933vw;
  }
  section#job_area h2.head_title .ff_english {
    letter-spacing: 0.04em;
  }
  section#job_area p.main_text {
    font-size: 4vw;
    line-height: 2;
    padding: 0 4vw;
  }
  section#job_area .wrap1260 {
    min-width: auto;
    padding: 0 7vw;
  }
  section#job_area ul.items {
    margin: 0 -7vw;
  }
  section#job_area ul.items li.photo {
    width: 100%;
    max-width: 100%;
    height: 58.667vw;
  }
  section#job_area ul.items li.photo:nth-child(1) {
    margin: 0 9vw 0 0;
  }
  section#job_area ul.items li.photo:nth-child(2) {
    margin: 5.5vw 4.5vw 0;
  }
  section#job_area ul.items li.photo:nth-child(3) {
    margin: 5.5vw 0 0 9vw;
  }
  section#job_area ul.items li.photo > .inner {
    padding: 5.333vw 16vw 5.333vw 8vw;
  }
  section#job_area ul.items h3 {
    font-size: 7vw;
    margin-bottom: 3.5vw;
  }
  section#job_area ul.items p.text {
    font-size: 3.8vw;
  }
  section#job_area ul.items a.hover_btn .icon-arrow02 {
    font-size: 5.6vw;
    right: 1.333vw;
    bottom: 0.267vw;
  }
  section#job_area ul.items a.hover_btn::after {
    border-width: 0 0 13.333vw 13.333vw;
  }
  /*******entry*******/
  section#entry_area {
    padding-top: 20vw;
    padding-bottom: 10.667vw;
  }
  section#entry_area h2.head_title .ff_english {
    font-size: 18.933vw;
  }
  section#entry_area h2.head_title .ja {
    margin-top: 4vw;
  }
  section#entry_area ul {
    margin-top: 12vw;
  }
  section#entry_area ul li:nth-child(2) {
    margin-top: 5.333vw;
    ;
  }
  section#entry_area ul li a {
    width: 80vw;
    height: 24vw;
    border-radius: 24vw;
    padding-bottom: 1.333vw;
  }
  section#entry_area ul li a .ff_english {
    font-size: 8vw;
  }
  section#entry_area ul li a .ja {
    font-size: 3.467vw;
    margin-top: 2.667vw;
  }
}