/* LESS Document */
html {
  scroll-behavior: smooth;
}
body {
  background: url(../img/bg_jobs_pc.webp) repeat right 0;
}
@media screen and (max-width: 767px) {
  body {
    background: url(../img/bg_jobs_sp.webp) repeat center 0;
  }
}
body::before {
  content: none;
}
/*+++++++++++++++++++++++++++++++++++++++++++
	pageHeader
+++++++++++++++++++++++++++++++++++++++++++ */
.pageHeader hgroup {
  padding-left: 140px;
}
@media screen and (max-width: 767px) {
  .pageHeader hgroup {
    padding-left: 15vw;
  }
}
.pageHeader hgroup h1 {
  margin-left: 20px;
  order: 1;
}
@media screen and (max-width: 767px) {
  .pageHeader hgroup h1 {
    margin-left: 1rem;
  }
}
.pageHeader hgroup p {
  color: #E9659D;
  top: -20px;
}
@media screen and (max-width: 1023px) {
  .pageHeader hgroup p {
    font-size: 10rem;
  }
}
@media screen and (max-width: 767px) {
  .pageHeader hgroup p {
    top: 0;
    font-size: 6vw;
  }
}
.pageHeader hgroup p span {
  top: -90px;
  left: -150px;
}
@media screen and (max-width: 767px) {
  .pageHeader hgroup p span {
    top: -14vw;
    left: -15vw;
  }
}
/*+++++++++++++++++++++++++++++++++++++++++++
	article
+++++++++++++++++++++++++++++++++++++++++++ */
article.box {
  padding: 60px;
}
@media screen and (max-width: 767px) {
  article.box {
    padding: 20px;
  }
}
article h2 {
  margin: 0 0 30px;
  text-align: center;
  font-size: 3.6rem;
  text-shadow: 3px 0 #fff, -3px 0 #fff, 0 3px #fff, 0 -3px #fff, 2px 2px #fff, -2px 2px #fff, 2px -2px #fff, -2px -2px #fff, 1px 3px #fff, -1px 3px #fff, 3px 1px #fff, -3px 1px #fff;
}
@media screen and (max-width: 767px) {
  article h2 {
    font-size: 7.2vw;
  }
}
article h3 {
  margin: 55px 0 20px;
  padding: 0;
  border: none;
}
/*+++++++++++++++++++++++++++++++++++++++++++
	flowArea
+++++++++++++++++++++++++++++++++++++++++++ */
.flowArea {
  margin: 0 0 100px;
}
.flowArea ol {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 65px;
  flex-wrap: wrap;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .flowArea ol {
    flex-direction: column;
    align-items: center;
  }
}
.flowArea ol li {
  width: 165px;
  text-align: center;
  font-weight: bold;
  position: relative;
  counter-increment: num;
}
@media screen and (max-width: 767px) {
  .flowArea ol li {
    width: 100%;
  }
}
.flowArea ol li:not(:last-child)::after {
  content: '\f30b';
  font-family: 'Font Awesome 7 Free';
  font-weight: 900;
  color: #E9659D;
  font-size: 3.2rem;
  line-height: 1;
  position: absolute;
  top: 50px;
  right: -50px;
}
@media screen and (max-width: 767px) {
  .flowArea ol li:not(:last-child)::after {
    content: '\f309';
    margin: auto;
    top: auto;
    bottom: -50px;
    right: 0;
    left: 0;
  }
}
.flowArea ol li figure {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 0;
  align-items: center;
  justify-content: center;
  width: 120px;
  height: 120px;
  margin: 0 auto 10px;
  border-radius: 50%;
  background: #FFF;
  position: relative;
}
.flowArea ol li figure::before {
  content: counter(num);
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 0;
  align-items: center;
  justify-content: center;
  width: 43px;
  height: 43px;
  border-radius: 50%;
  background: #E9659D;
  color: #FFF;
  font-size: 3.2rem;
  font-weight: bold;
  font-family: 'Poppins', sans-serif;
  position: absolute;
  top: -8px;
  left: -8px;
}
/*+++++++++++++++++++++++++++++++++++++++++++
	tabNav
+++++++++++++++++++++++++++++++++++++++++++ */
.tabNav {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 20px;
  justify-content: flex-start;
  flex-wrap: wrap;
  margin: 0 0 30px;
}
.tabNav li {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 0;
  justify-content: center;
  align-items: center;
  min-width: 250px;
  min-height: 60px;
  padding: 5px 10px;
  border: #D01D69 3px solid;
  border-radius: 10px;
  background: #FFF;
  color: #D01D69;
  font-size: 2rem;
  font-weight: bold;
  cursor: pointer;
  transition: 0.2s;
}
@media screen and (max-width: 767px) {
  .tabNav li {
    max-width: 250px;
    width: calc(50% - 20px);
    min-width: 0;
    font-size: 4vw;
  }
}
.tabNav li.current {
  background: #D01D69;
  color: #FFF;
}
.tabNav li:hover {
  opacity: 0.7;
}
.tabContents_item {
  display: none;
}
.tabContents_item.current {
  display: block;
}
.tabContents_item .box:not(:last-child) {
  margin: 0 0 70px;
}
@media screen and (max-width: 767px) {
  .tabContents_item .box:not(:last-child) {
    margin-bottom: 30px;
  }
}
.tabContents .recruitTable,
.tabContents .recruitTable2 {
  border-top: #F0D1E4 1px solid;
}
.tabContents .recruitTable .dl,
.tabContents .recruitTable2 .dl {
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 40px;
  align-items: center;
  justify-content: flex-start;
  padding: 12px 15px;
  border-bottom: #F0D1E4 1px solid;
}
@media screen and (max-width: 767px) {
  .tabContents .recruitTable .dl,
  .tabContents .recruitTable2 .dl {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
  }
}
.tabContents .recruitTable .dl dt,
.tabContents .recruitTable2 .dl dt {
  flex-shrink: 0;
  display: flex;
  justify-content: space-between;
  align-items: stretch;
  flex-wrap: nowrap;
  gap: 0;
  justify-content: center;
  align-items: center;
  min-width: 168px;
  min-height: 45px;
  padding: 5px 10px;
  background: #BA76BC;
  border-radius: 10px;
  color: #FFF;
  font-weight: bold;
  font-size: 2rem;
}
@media screen and (max-width: 767px) {
  .tabContents .recruitTable .dl dt,
  .tabContents .recruitTable2 .dl dt {
    font-size: 4vw;
    align-self: center;
  }
}
.tabContents .recruitTable .dl dd a,
.tabContents .recruitTable2 .dl dd a {
  color: #BA76BC;
}
.tabContents .recruitTable2 {
  border-color: #D3F0D1;
}
.tabContents .recruitTable2 .dl {
  border-color: #D3F0D1;
}
.tabContents .recruitTable2 .dl dt {
  background: #76BC8B;
}
.tabContents .recruitTable2 .dl dd a {
  color: #76BC8B;
}
