@charset "UTF-8";

/*  ========================
  *********  共通  *********
=============================================  */
body {
  color: #3E3E3E;
  background-color: #F1F1F1;
}

.main {
  width: 100%;
}

img {
  display: inline-block;
}

.inner {
  max-width: 1100px;
  width: 90%;
  margin: auto;
}

.center {
  text-align: center;
}

a {
  text-decoration: none;
  color: inherit;
}

a:hover {
  opacity: 0.8;
}

.pc_only {
  display: block;
}

.sp_only {
  display: none;
}

h1 span {
  display: block;
  font-size: min(3.9vw, 15px);
  line-height: 2;
  color: #3E3E3E;
}

/*  ========================
  *********  main  *********
=============================================  */
h1 {
  margin-bottom: 56px;
}

.recruit h2.top_line {
  position: relative;
  font-size: min(6.25vw, 32px);
  letter-spacing: 0.1em;
  padding-top: 40px;
  margin: 80px 0 40px;
  text-align: left;
}

.recruit h2.top_line::before {
  content: "";
  position: absolute;
  background-size: contain;
  width: 15px;
  height: 1px;
  left: 0;
  top: 0;
  margin: auto;
  background: #61B7D9;
}

.recruit h2.top_line::after {
  content: "";
  position: absolute;
  background-size: contain;
  width: calc(100% - 20px);
  height: 1px;
  left: 20px;
  top: 0;
  margin: auto;
  background: #DDDDDD;
  /* 以下bge_style.cssでnoneがかかっているため */
  display: inline-block !important;
}

.recruit {
  font-size: min(5vw, 16px);
  line-height: 1.75;
  background: #fff;
  padding-bottom: 50px;
}

.recruit h2 {
  font-size: min(6.4vw, 40px);
  font-weight: 500;
}

.recruit .table01 {
  border-collapse: collapse;
  width: 100%;
  text-align: left;
}

.recruit .table01 tr {
  border-top: 1px solid #ddd;
}

.recruit .table01 tr:last-child {
  border-bottom: 1px solid #ddd;
}

.recruit .table01 th {
  width: 24%;
  font-weight: 700;
  color: #3E3E3E;
}

.recruit .table01 th,
.recruit .table01 td {
  vertical-align: top;
  padding: 1.5em 0;
  background: none !important;
  border: none;
}

.recruit .recruit_cv {
  background: #DFEAF8;
  border-radius: 24px;
  padding: 40px;
  margin: 80px 0 124px;
}

.recruit .recruit_cv h2 {
  margin: 0;
  text-align: center;
  font-size: min(7.2vw, 32px);
}

.recruit .btn_common_01 {
  text-align: center;
}

.recruit .btn_common_01 a {
  font-size: 24px;
  padding: 30px 40px 30px 20px;
  width: 540px;
}

.recruit .btn_common_01 a::before,
.recruit .btn_common_01 a::after {
  right: 1.5%;
  width: 90px;
  height: 90px;
}

/*  ========================
  *********  SP  *********
=============================================  */
@media screen and (max-width: 768px) {
  .inner {
    width: 90%;
    margin: 0 auto;
  }

  .pc_only {
    display: none;
  }

  .sp_only {
    display: block;
  }

  h1 {
    font-size: 14vw;
    margin-bottom: 7vw;
  }

  .recruit h2.top_line {
    position: relative;
    font-size: min(6.25vw, 32px);
    letter-spacing: 0.1em;
    padding-top: 8.53vw;
    margin-bottom: 8.53vw;
    margin-top: 17vw;
  }

  .recruit h2.top_line:before {
    width: 10px;
    height: 1px;
  }

  .recruit h2.top_line:after {
    width: calc(100% - 16px);
    height: 1px;
    left: 16px;
  }

  .recruit h1 span {
    line-height: 3.5;
  }

  .recruit .table01 th,
  .recruit .table01 td {
    display: block;
    width: 100%;
  }

  .recruit .table01 td {
    padding-top: 0;
  }

  .recruit .recruit_cv {
    background: #DFEAF8;
    border-radius: 12px;
    padding: 6.4vw;
    margin: 17vw 0 21.33vw;
  }

  .recruit .btn_common_01 a {
    font-size: 4.8vw;
    padding: 7vw 10.66vw 7vw 10vw;
    width: 100%;
    box-sizing: border-box;
    border-radius: 33vw;
  }

  .recruit .recruit_cv h2 {
    line-height: 1.4;
  }

  .recruit .btn_common_01 a::before,
  .recruit .btn_common_01 a::after {
    right: 3%;
    width: 27vw;
    height: 27vw;
  }
}