/* Sass Document */
body {
  background: -webkit-gradient(linear, left top, right top, from(#EAF5FF), to(#D5F5FF));
  background: linear-gradient(90deg, #EAF5FF 0%, #D5F5FF 100%);
}

#main_title_area {
  padding: 14.0416874886rem 0 3.125rem;
}
@media screen and (max-width: 1600px) {
  #main_title_area {
    padding: 14.0416874886vw 0 3.125vw;
  }
}
@media screen and (max-width: 840px) {
  #main_title_area {
    padding: 25.0666666667vw 0 5.3333333333vw;
  }
}
#main_title_area .wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0 1.875rem;
}
@media screen and (max-width: 1600px) {
  #main_title_area .wrap {
    gap: 0 1.875vw;
  }
}
@media screen and (max-width: 840px) {
  #main_title_area .wrap {
    gap: 0 4vw;
  }
}
#main_title_area .en {
  font-size: 5rem;
  font-weight: 600;
  line-height: 1.6;
  letter-spacing: 0;
  text-transform: uppercase;
}
@media screen and (max-width: 1600px) {
  #main_title_area .en {
    font-size: 5vw;
  }
}
@media screen and (max-width: 840px) {
  #main_title_area .en {
    font-size: 10.6666666667vw;
  }
}
#main_title_area .main_title {
  font-size: 1.25rem;
  font-weight: 700;
  line-height: 1.6;
  letter-spacing: 0;
}
@media screen and (max-width: 1600px) {
  #main_title_area .main_title {
    font-size: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  #main_title_area .main_title {
    font-size: 3.7333333333vw;
  }
}
#main_title_area .title_txt {
  width: 100%;
  font-size: 1rem;
  font-weight: 700;
  line-height: 1.6;
}
@media screen and (max-width: 1600px) {
  #main_title_area .title_txt {
    font-size: 1vw;
  }
}
@media screen and (max-width: 840px) {
  #main_title_area .title_txt {
    font-size: 3.2vw;
  }
}

.occupation_list_area {
  padding: 3.75rem 0 8.4375rem;
}
.occupation_list_area .occupation_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1.25rem;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list {
    gap: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list {
    gap: 2.1333333333vw;
  }
}
.occupation_list_area .occupation_list > li {
  width: calc((100% - 1.25rem) / 2);
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li {
    width: calc((100% - 1.25vw) / 2);
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li {
    width: 100%;
  }
}
.occupation_list_area .occupation_list > li a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  padding: 1.625rem 1.25rem 1.625rem 2.5rem;
  background: #fff;
  border-radius: 0.625rem;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a {
    padding: 1.625vw 1.25vw 1.625vw 2.5vw;
    border-radius: 0.625vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2.6666666667vw;
    padding: 8vw;
    border-radius: 2.6666666667vw;
  }
}
.occupation_list_area .occupation_list > li a .in {
  position: relative;
  max-width: 25rem;
  width: 54.7945205479%;
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in {
    max-width: none;
    width: 100%;
  }
}
.occupation_list_area .occupation_list > li a .in .title03 {
  margin-bottom: 1.875rem;
  font-size: 1.60625rem;
  font-weight: 500;
  line-height: 1.5953307393;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in .title03 {
    margin-bottom: 1.875vw;
    font-size: 1.60625vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in .title03 {
    margin-bottom: 2.6666666667vw;
    font-size: 5.8666666667vw;
    line-height: 1.8636363636;
  }
}
.occupation_list_area .occupation_list > li a .in p {
  font-size: 0.975rem;
  font-weight: 400;
  line-height: 1.7519230769;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in p {
    font-size: 0.975vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in p {
    font-size: 3.4666666667vw;
    line-height: 1.8461538462;
  }
}
.occupation_list_area .occupation_list > li a .in ul {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 0.25rem;
  margin-top: 1.25rem;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in ul {
    gap: 0.25vw;
    margin-top: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in ul {
    gap: 1.0666666667vw;
    margin-top: 2.6666666667vw;
  }
}
.occupation_list_area .occupation_list > li a .in ul li {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 1.5rem;
  padding: 0 0.625rem;
  font-size: 0.75rem;
  font-weight: 400;
  line-height: 1;
  background: #AFD9FF;
  border-radius: 2.5rem;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in ul li {
    height: 1.5vw;
    padding: 0 0.625vw;
    font-size: 0.75vw;
    border-radius: 2.5vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in ul li {
    height: 5.3333333333vw;
    padding: 0 2.1333333333vw;
    font-size: 2.6666666667vw;
    border-radius: 5.3333333333vw;
  }
}
.occupation_list_area .occupation_list > li a .in .arrow {
  position: absolute;
  bottom: 0;
  right: -2.5rem;
  display: block;
  width: 2.5rem;
  height: 2.5rem;
  background: #434088;
  border-radius: 0.1875rem;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in .arrow {
    right: -2.5vw;
    width: 2.5vw;
    height: 2.5vw;
    border-radius: 0.1875vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in .arrow {
    position: relative;
    bottom: auto;
    right: auto;
    width: 8.5333333333vw;
    height: 8.5333333333vw;
    margin-left: auto;
    margin-top: 2.6666666667vw;
    border-radius: 0.64vw;
  }
}
.occupation_list_area .occupation_list > li a .in .arrow .arrow_in {
  position: absolute;
  display: inline-block;
  width: 0.9375rem;
  height: 0.0625rem;
  top: 50%;
  left: 50%;
  border-radius: 9999px;
  background-color: #fff;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
  -webkit-transition: left 0.6s;
  transition: left 0.6s;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in .arrow .arrow_in {
    width: 0.9375vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in .arrow .arrow_in {
    width: 3.6266666667vw;
  }
}
.occupation_list_area .occupation_list > li a .in .arrow .arrow_in::before, .occupation_list_area .occupation_list > li a .in .arrow .arrow_in::after {
  content: "";
  position: absolute;
  top: calc(50% - 0.03125rem);
  right: 0;
  width: 0.46875rem;
  height: 0.0625rem;
  border-radius: 9999px;
  background-color: #fff;
  -webkit-transform-origin: calc(100% - 0.03125rem) 50%;
          transform-origin: calc(100% - 0.03125rem) 50%;
}
@media screen and (max-width: 1600px) {
  .occupation_list_area .occupation_list > li a .in .arrow .arrow_in::before, .occupation_list_area .occupation_list > li a .in .arrow .arrow_in::after {
    width: 0.46875vw;
  }
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a .in .arrow .arrow_in::before, .occupation_list_area .occupation_list > li a .in .arrow .arrow_in::after {
    width: 1.6vw;
  }
}
.occupation_list_area .occupation_list > li a .in .arrow .arrow_in::before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}
.occupation_list_area .occupation_list > li a .in .arrow .arrow_in::after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}
.occupation_list_area .occupation_list > li a figure {
  max-width: 16.25rem;
  width: 35.6164383562%;
}
@media screen and (max-width: 840px) {
  .occupation_list_area .occupation_list > li a figure {
    max-width: none;
    width: 100%;
  }
}
.occupation_list_area .occupation_list > li a:hover {
  background: #D5ECFF;
  opacity: 1;
}
.occupation_list_area .occupation_list > li a:hover .in .arrow .arrow_in {
  left: 65%;
}
.occupation_list_area .occupation_list > li a:hover .in .arrow .arrow_in::before, .occupation_list_area .occupation_list > li a:hover .in .arrow .arrow_in::after {
  background-color: #D5ECFF;
}

.fv_area {
  position: relative;
  margin-bottom: 6.25rem;
}
@media screen and (max-width: 1600px) {
  .fv_area {
    margin-bottom: 6.25vw;
  }
}
@media screen and (max-width: 840px) {
  .fv_area {
    margin-bottom: 13.3333333333vw;
  }
}
.fv_area figure {
  max-width: 87.5rem;
  width: 72.9166666667%;
  margin-left: auto;
}
@media screen and (max-width: 840px) {
  .fv_area figure {
    width: 85%;
    height: 53.3333333333vw;
  }
}
.fv_area figure img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.fv_area .txt_area {
  position: absolute;
  top: 50%;
  left: 50%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-align: start;
      -ms-flex-align: start;
          align-items: flex-start;
  gap: 0.625rem;
  max-width: 87.5rem;
  width: 87.5%;
  -webkit-transform: translate(-50%, -50%);
          transform: translate(-50%, -50%);
}
@media screen and (max-width: 1600px) {
  .fv_area .txt_area {
    gap: 0.625vw;
  }
}
@media screen and (max-width: 840px) {
  .fv_area .txt_area {
    gap: 1.3333333333vw;
    width: 91.4666666667vw;
  }
}
.fv_area .txt_area .fv_title {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 6rem;
  padding: 0 1.875rem;
  font-size: 3.5rem;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.04rem;
  background: #434088;
}
@media screen and (max-width: 1600px) {
  .fv_area .txt_area .fv_title {
    height: 6vw;
    padding: 0 1.875vw;
    font-size: 3.5vw;
  }
}
@media screen and (max-width: 840px) {
  .fv_area .txt_area .fv_title {
    height: 10.6666666667vw;
    padding: 0 1.3333333333vw;
    font-size: 5.8666666667vw;
  }
}
.fv_area .txt_area .fv_txt {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  height: 3.25rem;
  padding: 0 1.5rem;
  font-size: 1.375rem;
  color: #fff;
  font-weight: 700;
  letter-spacing: 0.04rem;
  background: #434088;
}
@media screen and (max-width: 1600px) {
  .fv_area .txt_area .fv_txt {
    height: 3.25vw;
    padding: 0 1.5vw;
    font-size: 1.375vw;
  }
}
@media screen and (max-width: 840px) {
  .fv_area .txt_area .fv_txt {
    height: auto;
    padding: 1.6vw 2.1333333333vw;
    font-size: 3.2vw;
    line-height: 1.4;
  }
}

.character .wrap {
  max-width: 87.5rem;
  width: 72.9166666667%;
  padding: 4rem 0 6.25rem;
  background: #C3E0F5;
  border-radius: 0.625rem;
}
@media screen and (max-width: 1600px) {
  .character .wrap {
    padding: 4vw 0 6.25vw;
    border-radius: 0.625vw;
  }
}
@media screen and (max-width: 840px) {
  .character .wrap {
    width: 91.4666666667vw;
    padding: 8vw 5.3333333333vw 5.3333333333vw;
    border-radius: 2.6666666667vw;
  }
}
.character .title02 {
  margin-bottom: 0.8125rem;
  font-size: 2.5rem;
  font-weight: 600;
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 1600px) {
  .character .title02 {
    margin-bottom: 0.8125vw;
    font-size: 2.5vw;
  }
}
@media screen and (max-width: 840px) {
  .character .title02 {
    margin-bottom: 2.6666666667vw;
    font-size: 4.2666666667vw;
  }
}
.character .title02 + p {
  margin-bottom: 2.5rem;
  font-size: 1rem;
  font-weight: 500;
  text-align: center;
  line-height: 1.6;
}
@media screen and (max-width: 1600px) {
  .character .title02 + p {
    margin-bottom: 2.5vw;
    font-size: 1vw;
  }
}
@media screen and (max-width: 840px) {
  .character .title02 + p {
    margin-bottom: 5.3333333333vw;
    font-size: 3.2vw;
  }
}
.character .flex {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 1.25rem;
}
@media screen and (max-width: 1600px) {
  .character .flex {
    gap: 1.25vw;
  }
}
@media screen and (max-width: 840px) {
  .character .flex {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2.6666666667vw;
  }
}
.character .flex .box {
  width: 30rem;
  padding: 2.5rem;
  background: #fff;
  border-radius: 0.625rem;
}
@media screen and (max-width: 1600px) {
  .character .flex .box {
    width: 30vw;
    padding: 2.5vw;
    border-radius: 0.625vw;
  }
}
@media screen and (max-width: 840px) {
  .character .flex .box {
    width: 100%;
    padding: 5.3333333333vw;
    border-radius: 2.6666666667vw;
  }
}
.character .flex .box .title03 {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  width: 18.75rem;
  height: 2.625rem;
  margin: 0 auto 1.5rem;
  font-size: 1.25rem;
  color: #fff;
  font-weight: 600;
  background: #434088;
  border-radius: 3.125rem;
}
@media screen and (max-width: 1600px) {
  .character .flex .box .title03 {
    width: 18.75vw;
    height: 2.625vw;
    margin: 0 auto 1.5vw;
    font-size: 1.25vw;
    border-radius: 3.125vw;
  }
}
@media screen and (max-width: 840px) {
  .character .flex .box .title03 {
    width: 45.3333333333vw;
    height: 6.6666666667vw;
    margin: 0 auto 2.6666666667vw;
    font-size: 3.2vw;
    border-radius: 13.3333333333vw;
  }
}
.character .flex .box dl dt,
.character .flex .box dl dd {
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 2.1;
}
@media screen and (max-width: 1600px) {
  .character .flex .box dl dt,
  .character .flex .box dl dd {
    font-size: 1.125vw;
  }
}
@media screen and (max-width: 840px) {
  .character .flex .box dl dt,
  .character .flex .box dl dd {
    font-size: 3.2vw;
  }
}
.character .flex .box ul li {
  margin-left: 1.5em;
  font-size: 1.125rem;
  font-weight: 500;
  line-height: 2.1;
  list-style: disc;
}
@media screen and (max-width: 1600px) {
  .character .flex .box ul li {
    font-size: 1.125vw;
  }
}
@media screen and (max-width: 840px) {
  .character .flex .box ul li {
    font-size: 3.2vw;
  }
}

.job_description {
  padding: 7.6875rem 0 8.125rem;
}
@media screen and (max-width: 1600px) {
  .job_description {
    padding: 7.6875vw 0 8.125vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description {
    padding: 16vw 0;
  }
}
.job_description .title_area {
  margin-bottom: 4.375rem;
}
@media screen and (max-width: 1600px) {
  .job_description .title_area {
    margin-bottom: 4.375vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .title_area {
    margin-bottom: 8vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .title_area .en {
    margin-bottom: 2.6666666667vw;
    line-height: 1;
  }
}
.job_description .job_description_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  gap: 1rem;
}
@media screen and (max-width: 1600px) {
  .job_description .job_description_list {
    gap: 1vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list {
    gap: 2.6666666667vw;
  }
}
.job_description .job_description_list li {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
  width: calc((100% - 1rem) / 2);
  padding: 1.25rem;
  background: #fff;
  border-radius: 0.5rem;
}
@media screen and (max-width: 1600px) {
  .job_description .job_description_list li {
    width: calc((100% - 1vw) / 2);
    padding: 1.25vw;
    border-radius: 0.5vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list li {
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
    gap: 2.6666666667vw;
    width: 100%;
    padding: 5.3333333333vw;
    border-radius: 2.1333333333vw;
  }
}
.job_description .job_description_list li .in {
  max-width: 21.25rem;
  width: 46.5753424658%;
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list li .in {
    max-width: none;
    width: 1002%;
  }
}
.job_description .job_description_list li .in .title03 {
  margin: 1.25rem 0 1.5rem;
  font-size: 1.5rem;
  font-weight: 700;
  line-height: 1.3333333333;
  letter-spacing: 0.064375rem;
}
@media screen and (max-width: 1600px) {
  .job_description .job_description_list li .in .title03 {
    margin: 1.25vw 0 1.5vw;
    font-size: 1.5vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list li .in .title03 {
    margin: 0 0 2.6666666667vw;
    font-size: 4.2666666667vw;
  }
}
.job_description .job_description_list li .in p {
  font-size: 1rem;
  font-weight: 400;
  line-height: 1.7;
}
@media screen and (max-width: 1600px) {
  .job_description .job_description_list li .in p {
    font-size: 1vw;
  }
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list li .in p {
    font-size: 3.2vw;
  }
}
.job_description .job_description_list li figure {
  max-width: 22.5rem;
  width: 49.3150684932%;
}
@media screen and (max-width: 840px) {
  .job_description .job_description_list li figure {
    max-width: none;
    width: 1002%;
  }
}

.cv {
  padding: 5.625rem 0 5rem;
}
@media screen and (max-width: 1600px) {
  .cv {
    padding: 5.625vw 0 5vw;
  }
}
@media screen and (max-width: 840px) {
  .cv {
    padding: 26.6666666667vw 0;
  }
}
.cv .title02 {
  margin-bottom: 1.75rem;
  font-size: 3rem;
  font-weight: 700;
}
@media screen and (max-width: 1600px) {
  .cv .title02 {
    margin-bottom: 1.75vw;
    font-size: 3vw;
  }
}
@media screen and (max-width: 840px) {
  .cv .title02 {
    margin-bottom: 3.7333333333vw;
    font-size: 6.4vw;
  }
}
.cv .title02 + p {
  margin-bottom: 2.5rem;
  font-size: 1.375rem;
  color: #fff;
  font-weight: 500;
  text-align: center;
}
@media screen and (max-width: 1600px) {
  .cv .title02 + p {
    margin-bottom: 2.5vw;
    font-size: 1.375vw;
  }
}
@media screen and (max-width: 840px) {
  .cv .title02 + p {
    margin-bottom: 10.6666666667vw;
    font-size: 3.2vw;
  }
}
.cv .btn a {
  margin: auto;
}