#top_visual {
  position: relative;
  z-index: 0;
  width: 100%;
  height: 830px;
  background: url(../img/bg_top_visual.png) no-repeat center;
  background-size: cover;
}
#top_visual p {
  width: 1070px;
  margin: 0 auto;
  padding-top: 230px;
  color: #fff;
  font-family: 'Noto Sans JP', sans-serif;
}
#top_visual p strong {
  display: block;
  font-weight: normal;
  font-size: 4.5rem;
  letter-spacing: 17px;
  line-height: 9rem;
}
#top_visual p small {
  display: block;
  padding: 30px 0 50px 0;
  font-weight: 500;
  font-size: 2.5rem;
  letter-spacing: 13px;
  line-height: 5rem;
}
#top_visual:after {
  position: absolute;
  bottom: -250px;
  left: -140px;
  color: #123c7e;
  font-weight: 600;
  font-size: 1.2rem;
  letter-spacing: 5px;
  transform: rotate(90deg);
  content: 'FIND THE FUTURE INCORPORATE VALUE';
}
@media screen and (max-width: 1470px) {
  #top_visual:after {
    display: none;
  }
}
@media screen and (max-width: 1150px) {
  #top_visual p {
    width: 600px;
  }
}
@media screen and (max-width: 768px) {
  #top_visual {
    height: 300px;
  }
  #top_visual p {
    width: 100%;
    padding: 90px 0 0 20px;
  }
  #top_visual p strong {
    font-size: 2.5rem;
    letter-spacing: 3px;
    line-height: 4rem;
  }
  #top_visual p small {
    padding: 20px 0 0 0;
    font-size: 1.5rem;
    letter-spacing: 5px;
    line-height: 2.1rem;
  }
}
#top_main {
  width: 100%;
  padding-bottom: 1px;
  background: url(../img/bg_top_square.png) repeat;
}
@media screen and (max-width: 768px) {
  #top_main .wrapper {
    padding: 30px 0 40px 0;
  }
}
#top_recruit {
  width: 100%;
  padding: 70px 0 105px 0;
  background: url(../img/bg_top_square.png) repeat;
}
#top_recruit .wrapper {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
}
#top_recruit .panel {
  position: relative;
  width: 330px;
  min-height: 350px;
  margin: 0;
}
#top_recruit .panel .panel_inner {
  position: absolute;
  height: auto;
  top: 1px;
  right: 1px;
  bottom: 1px;
  left: 1px;
  padding: 35px 0 15px 0;
  background-color: #fff;
  transition: .3s;
}
#top_recruit .panel .panel_inner h5 {
  padding-top: 150px;
  font-weight: 500;
  font-size: 2rem;
  text-align: center;
  transition: .3s;
}
#top_recruit .panel .panel_inner h5 br {
  display: none;
}
#top_recruit .panel .panel_inner p {
  padding-top: 15px;
  font-size: 1.5rem;
  line-height: 1.7;
  transition: .3s;
}
#top_recruit .panel .panel_inner:before {
  position: absolute;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  z-index: 2;
  content: '';
}
#top_recruit .panel .panel_inner:after {
  position: absolute;
  top: 317px;
  left: 297px;
  z-index: 5;
  width: 14px;
  height: 10px;
  background: #000;
  background: url(../img/mark_top_arrow.png) no-repeat 0 0;
  background-size: 14px 20px;
  content: '';
}
#top_recruit .panel .panel_inner:hover {
  background: #123c7e;
}
#top_recruit .panel .panel_inner:hover h5,
#top_recruit .panel .panel_inner:hover p {
  color: #fff;
}
#top_recruit .panel .panel_inner:hover:after {
  background-position: 0 -10px;
}
#top_recruit .panel:first-child .panel_inner:before {
  top: 122px;
  width: 82px;
  height: 58px;
  background: url(../img/icon_top_recruit01.png) no-repeat 0 0;
  background-size: 82px 116px;
}
#top_recruit .panel:first-child .panel_inner:hover:before {
  background-position: 0 -58px;
}
#top_recruit .panel:nth-child(2) .panel_inner:before {
  top: 120px;
  width: 65px;
  height: 62px;
  background: url(../img/icon_top_recruit02.png) no-repeat 0 0;
  background-size: 65px 124px;
}
#top_recruit .panel:nth-child(2) .panel_inner:hover:before {
  background-position: 0 -62px;
}
#top_recruit .panel:nth-child(3) .panel_inner:before {
  top: 120px;
  width: 65px;
  height: 58px;
  background: url(../img/icon_top_recruit03.png) no-repeat 0 0;
  background-size: 65px 116px;
}
#top_recruit .panel:nth-child(3) .panel_inner:hover:before {
  background-position: 0 -58px;
}
#top_recruit .panel:after {
  position: absolute;
  z-index: -1;
  overflow: hidden;
  bottom: 0%;
  left: 25%;
  width: 50%;
  top: 95%;
  background: rgba(18, 60, 126, 0.5);
  -webkit-box-shadow: 0 1px 50px rgba(18, 60, 126, 0.5);
  -moz-box-shadow: 0 1px 50px rgba(18, 60, 126, 0.5);
  box-shadow: 0 1px 50px rgba(18, 60, 126, 0.5);
  -webkit-border-radius: 90%;
  -moz-border-radius: 90%;
  -o-border-radius: 90%;
  border-radius: 90%;
  content: "";
}
@media screen and (max-width: 1150px) {
  #top_recruit .wrapper {
    width: 100%;
    justify-content: space-around;
    padding: 0 2%;
  }
  #top_recruit .panel {
    width: 31.6%;
    margin: 0;
  }
  #top_recruit .panel .panel_inner h5 {
    padding-top: 120px;
  }
  #top_recruit .panel .panel_inner h5 br {
    display: block;
  }
  #top_recruit .panel .panel_inner p {
    padding: 15px 10px 0 10px;
  }
  #top_recruit .panel .panel_inner:after {
    display: none;
  }
  #top_recruit .panel:first-child .panel_inner:before {
    top: 102px;
  }
  #top_recruit .panel:nth-child(2) .panel_inner:before,
  #top_recruit .panel:nth-child(3) .panel_inner:before {
    top: 100px;
  }
}
@media screen and (max-width: 768px) {
  #top_recruit {
    padding: 30px 0 50px 0;
  }
  #top_recruit .wrapper {
    display: block;
  }
  #top_recruit .panel {
    position: relative;
    width: 90%;
    min-height: 190px;
    margin: 0 auto 10px auto;
  }
  #top_recruit .panel .panel_inner {
    padding: 10px 0 15px 0;
  }
  #top_recruit .panel .panel_inner h5 {
    padding-top: 45px;
    font-size: 1.8rem;
  }
  #top_recruit .panel:first-child .panel_inner:before {
    top: 32px;
    width: 41px;
    height: 29px;
    background-size: 41px 58px;
  }
  #top_recruit .panel:first-child .panel_inner:hover:before {
    background-position: 0 -29px;
  }
  #top_recruit .panel:nth-child(2) .panel_inner:before {
    top: 30px;
    width: 32px;
    height: 31px;
    background-size: 32px 62px;
  }
  #top_recruit .panel:nth-child(2) .panel_inner:hover:before {
    background-position: 0 -31px;
  }
  #top_recruit .panel:nth-child(3) .panel_inner:before {
    top: 30px;
    width: 32px;
    height: 29px;
    background-size: 32px 58px;
  }
  #top_recruit .panel:nth-child(3) .panel_inner:hover:before {
    background-position: 0 -29px;
  }
}
/*# sourceMappingURL=top.css.map */