@keyframes floating-y {
  0% {
    transform: translateY(-20px);
  }
  100% {
    transform: translateY(20px);
  }
}
.anim-floaty {
  animation: floating-y 1.8s ease-in-out infinite alternate-reverse;
}

.recruit_section {
  position: relative;
}

.recruit_inner {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .recruit_inner {
    max-width: 110rem;
    padding: 11.1rem 0 9.5rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_inner {
    max-width: 67rem;
    padding: 10rem 0 6.6rem;
  }
}
@media screen and (min-width: 769px) {
  .recruit_inner {
    display: grid;
    justify-content: space-between;
    grid-template-columns: auto auto;
  }
}
@media screen and (max-width: 768px) {
  .recruit_inner {
    display: flex;
    flex-direction: column;
  }
}
@media screen and (min-width: 769px) {
  .recruit_inner .recruit_head, .recruit_inner .recruit_lead {
    grid-column: 1/2;
  }
}

.recruit_head {
  display: flex;
  flex-direction: column;
  position: relative;
}
@media screen and (min-width: 769px) {
  .recruit_head {
    gap: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_head {
    gap: 1.5rem;
  }
}
.recruit_head p {
  position: relative;
  background-image: url(../img/recruitment/head_p_bg2.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: auto 100%;
}
@media screen and (min-width: 769px) {
  .recruit_head p {
    width: 19.2rem;
    height: 5.2rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_head p {
    width: 28.8rem;
    height: 7.8rem;
  }
}
.recruit_head p svg {
  clip-path: polygon(0 0, 100% 0, 100% 61.539%, 0 61.539%);
}
.recruit_head p svg > * {
  fill-opacity: 0;
  translate: 0 20px;
  transition: 0.3s linear;
}
.recruit_head p svg > *:nth-of-type(1) {
  transition-delay: 0.4s;
}
.recruit_head p svg > *:nth-of-type(2) {
  transition-delay: 0.6s;
}
.recruit_head p svg > *:nth-of-type(3) {
  transition-delay: 0.8s;
}
.recruit_head p svg > *:nth-of-type(4) {
  transition-delay: 1s;
}
.recruit_head p svg > *:nth-of-type(5) {
  transition-delay: 1.2s;
}
.recruit_head p svg > *:nth-of-type(6) {
  transition-delay: 1.4s;
}
.recruit_head p svg > *:nth-of-type(7) {
  transition-delay: 1.6s;
}
.recruit_head p svg > *:nth-of-type(8) {
  transition-delay: 1.8s;
}
.recruit_head p svg > *:nth-of-type(9) {
  transition-delay: 2s;
}
.recruit_head p svg > *:nth-of-type(10) {
  transition-delay: 2.2s;
}
.recruit_head p svg > *:nth-of-type(11) {
  transition-delay: 2.4s;
}
.recruit_head p svg > *:nth-of-type(12) {
  transition-delay: 2.6s;
}
.recruit_head p svg > *:nth-of-type(13) {
  transition-delay: 2.8s;
}
.recruit_head p svg > *:nth-of-type(14) {
  transition-delay: 3s;
}
.recruit_head p svg > *:nth-of-type(15) {
  transition-delay: 3.2s;
}
.recruit_head h2 {
  letter-spacing: 0.04em;
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  .recruit_head h2 {
    line-height: 1;
    font-size: 5.7rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_head h2 {
    line-height: 1.259;
    font-size: 8.5rem;
  }
}
.recruit_head.is-animated p svg > * {
  translate: 0 0;
  fill-opacity: 1;
}

.recruit_lead {
  position: relative;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .recruit_lead {
    padding-top: 4rem;
    line-height: 1.667;
    font-size: 1.8rem;
  }
  .recruit_lead > p {
    font: inherit;
  }
  .recruit_lead > p:first-of-type {
    margin-top: -0.333em;
  }
  .recruit_lead > p:last-of-type {
    margin-bottom: -0.333em;
  }
}
@media screen and (max-width: 768px) {
  .recruit_lead {
    padding-top: 2.8rem;
    line-height: 1.643;
    font-size: 2.8rem;
  }
  .recruit_lead > p {
    font: inherit;
  }
  .recruit_lead > p:first-of-type {
    margin-top: -0.321em;
  }
  .recruit_lead > p:last-of-type {
    margin-bottom: -0.321em;
  }
}

.recruit_anchors {
  display: flex;
}
@media screen and (min-width: 769px) {
  .recruit_anchors {
    grid-column: 2/3;
    grid-row: 1/3;
    align-items: flex-end;
    gap: 1.3rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_anchors {
    gap: 2.2rem;
    padding-top: 9rem;
  }
}

.recruit_anchor {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  .recruit_anchor {
    width: 13rem;
    height: 13rem;
    line-height: 1.273;
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_anchor {
    width: 21rem;
    height: 21rem;
    line-height: 1.236;
    font-size: 3.4rem;
  }
}
.recruit_anchor::before, .recruit_anchor::after {
  content: "";
  position: absolute;
  border: 1px solid #2b2b2b;
  border-radius: 50%;
  inset: 0;
}
.recruit_anchor::before {
  background: #fffff2;
}
@media screen and (min-width: 769px) {
  .recruit_anchor::before {
    translate: 0 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_anchor::before {
    translate: 0 1rem;
  }
}
.recruit_anchor span {
  position: relative;
  text-align: center;
  color: #fff;
  z-index: 2;
}
.recruit_anchor svg {
  stroke: #2b2b2b;
  fill: #fffff2;
  position: absolute;
  width: 0.682em;
  height: 0.819em;
  bottom: 0.682em;
  rotate: 90deg;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .recruit_anchor:hover::after, .recruit_anchor:hover span, .recruit_anchor:hover svg {
    translate: 0 0.6rem;
  }
}
@media screen and (max-width: 768px) {
  .recruit_anchor:hover::after, .recruit_anchor:hover span, .recruit_anchor:hover svg {
    translate: 0 1rem;
  }
}
.recruit_anchor.col1::after {
  background: #0039bc;
}
.recruit_anchor.col2::after {
  background: #ff7c46;
}
.recruit_anchor.col3::after {
  background: #20aa5f;
}

.guide_section {
  position: relative;
  z-index: 3;
}
.guide_section::before, .guide_section::after {
  content: "";
  display: block;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .guide_section::before, .guide_section::after {
    background-image: url(../img/recruitment/bg_b_pc.png);
    height: 19.034vw;
  }
}
@media screen and (max-width: 768px) {
  .guide_section::before, .guide_section::after {
    background-image: url(../img/recruitment/bg_b_sp.png);
    height: 20vw;
  }
}
.guide_section::after {
  scale: -1 -1;
}

.guide_inner {
  position: relative;
  margin: 0 auto;
  color: #fff;
}
@media screen and (min-width: 769px) {
  .guide_inner {
    max-width: 110rem;
    margin-top: -6rem;
    padding-bottom: 9.5rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_inner {
    max-width: 67rem;
    padding: 0 0 5.5rem;
  }
}
.guide_inner::before {
  content: "";
  position: absolute;
  background: #2771e8;
  width: 100vw;
  left: 50%;
  translate: -50% 0;
}
@media screen and (min-width: 769px) {
  .guide_inner::before {
    min-width: 1140px;
    top: 5.9rem;
    bottom: -0.1rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_inner::before {
    top: -0.1rem;
    bottom: -0.1rem;
  }
}

.guide_bg {
  position: absolute;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .guide_bg {
    background-image: url(../img/recruitment/guide_bg_pc.png);
    width: 21rem;
    height: 15rem;
    right: -13.2rem;
    bottom: -5.3rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_bg {
    background-image: url(../img/recruitment/guide_bg_sp.png);
    width: 20rem;
    height: 12rem;
    right: -4rem;
    bottom: -6.4rem;
  }
}

.guide_image {
  position: absolute;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .guide_image {
    width: 34.7rem;
    right: -3.2rem;
    top: -20rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_image {
    width: 43.8rem;
    right: -22.9rem;
    top: -15rem;
  }
}
.guide_image::before {
  content: "";
  position: absolute;
  background-position: right top;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 769px) {
  .guide_image::before {
    background-image: url(../img/recruitment/guide_image_bg_pc.png);
    width: 12rem;
    height: 30.2rem;
    right: -10.1rem;
    top: -27.8rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_image::before {
    background-image: url(../img/recruitment/guide_image_bg_sp.png);
    width: 16rem;
    height: 58rem;
    right: 18.9rem;
    top: -51.4rem;
  }
}
.guide_image figure {
  position: relative;
  width: 100%;
}

.guide_sub {
  display: flex;
  gap: 0.589em;
  position: relative;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 769px) {
  .guide_sub {
    margin-bottom: 6rem;
    line-height: 1;
    font-size: 3.4rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_sub {
    margin-bottom: 7rem;
    line-height: 1.347;
    font-size: 5.2rem;
  }
  .guide_sub > h3 {
    font: inherit;
  }
  .guide_sub > h3:first-of-type {
    margin-top: -0.173em;
  }
  .guide_sub > h3:last-of-type {
    margin-bottom: -0.173em;
  }
}
.guide_sub::before {
  content: "";
  flex-shrink: 0;
  background-image: url(../img/bg1.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  width: 0.883em;
  height: 0.883em;
  translate: 0 13.334%;
}
.guide_sub h3 {
  font-weight: 800;
}
.guide_sub strong {
  color: #ffd125;
}

.guide_box {
  position: relative;
  background: #fff;
  border: 1px solid;
  color: #2b2b2b;
}
@media screen and (min-width: 769px) {
  .guide_box {
    border-radius: 3.5rem;
    padding: 5.5rem 10.3rem 6rem 10rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_box {
    border-radius: 5.5rem;
    padding: 5rem 3.3rem;
  }
}

.guide_detail {
  display: grid;
  align-items: stretch;
}
@media screen and (min-width: 769px) {
  .guide_detail {
    grid-template-columns: 14.6rem 1fr;
    gap: 0 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_detail {
    grid-template-columns: 18.9rem 1fr;
    gap: 0 2.3rem;
  }
}
.guide_detail > dt {
  border-bottom: 1px solid;
  padding: 4rem 0 4rem 2rem;
  line-height: 1;
  font-weight: 800;
  color: #0039bc;
}
@media screen and (min-width: 769px) {
  .guide_detail > dt {
    font-size: 2.4rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_detail > dt {
    font-size: 3.6rem;
  }
}
.guide_detail > dt:last-of-type {
  border-bottom: 0;
}
.guide_detail > dd {
  display: flex;
  flex-direction: column;
  position: relative;
}
@media screen and (min-width: 769px) {
  .guide_detail > dd {
    gap: 0.5rem;
    padding: 4rem 0 4rem 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_detail > dd {
    gap: 2rem;
    padding: 3.8rem 0 3.8rem 2rem;
  }
}
.guide_detail > dd::after {
  content: "";
  position: absolute;
  background-image: url(../img/line1.svg);
  background-repeat: repeat-x;
  background-position: left top;
  background-size: auto 100%;
  left: 0;
  right: 0;
}
@media screen and (min-width: 769px) {
  .guide_detail > dd::after {
    height: 4px;
    bottom: -0.15rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_detail > dd::after {
    height: 0.6rem;
    bottom: -0.2rem;
  }
}
.guide_detail > dd:last-of-type::after {
  display: none;
}

.guide_list {
  display: flex;
}
@media screen and (min-width: 769px) {
  .guide_list {
    gap: 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_list {
    flex-direction: column;
    gap: 1rem;
  }
}
.guide_list > li {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.guide_list > li::before {
  content: "";
  background: #0039bc;
}
@media screen and (min-width: 769px) {
  .guide_list > li::before {
    width: 1.1rem;
    height: 1.1rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_list > li::before {
    width: 1.7rem;
    height: 1.7rem;
  }
}

.guide_text {
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .guide_text {
    line-height: 1.625;
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_text {
    line-height: 1.6;
    font-size: 2.5rem;
  }
}

.guide_note {
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .guide_note {
    line-height: 1.715;
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .guide_note {
    line-height: 1.546;
    font-size: 2.2rem;
  }
}

.bene_section {
  position: relative;
  z-index: 2;
}
@media screen and (min-width: 769px) {
  .bene_section {
    margin-top: -19.033vw;
  }
}
@media screen and (max-width: 768px) {
  .bene_section {
    margin-top: -20vw;
  }
}
.bene_section::after {
  content: "";
  display: block;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .bene_section::after {
    background-image: url(../img/recruitment/bg_o_pc.png);
    height: 19.034vw;
  }
}
@media screen and (max-width: 768px) {
  .bene_section::after {
    background-image: url(../img/recruitment/bg_o_sp.png);
    height: 20vw;
  }
}

.bene_inner {
  position: relative;
  margin: 0 auto;
  color: #fff;
}
@media screen and (min-width: 769px) {
  .bene_inner {
    max-width: 110rem;
    padding: calc(19.034vw - 1rem) 0 2.5rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_inner {
    max-width: 67rem;
    padding: calc(20vw + 2rem) 0 7.5rem;
  }
}
.bene_inner::before {
  content: "";
  position: absolute;
  background: #ff7c46;
  width: 100vw;
  left: 50%;
  translate: -50% 0;
}
@media screen and (min-width: 769px) {
  .bene_inner::before {
    min-width: 1140px;
    top: -0.1rem;
    bottom: -0.1rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_inner::before {
    top: -0.1rem;
    bottom: -0.1rem;
  }
}

.bene_sub {
  display: flex;
  gap: 0.589em;
  position: relative;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 769px) {
  .bene_sub {
    margin-bottom: 6rem;
    line-height: 1;
    font-size: 3.4rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_sub {
    margin-bottom: 7rem;
    line-height: 1.347;
    font-size: 5.2rem;
  }
  .bene_sub > h3 {
    font: inherit;
  }
  .bene_sub > h3:first-of-type {
    margin-top: -0.173em;
  }
  .bene_sub > h3:last-of-type {
    margin-bottom: -0.173em;
  }
}
.bene_sub::before {
  content: "";
  flex-shrink: 0;
  background-image: url(../img/bg1.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  width: 0.883em;
  height: 0.883em;
  translate: 0 13.334%;
}
.bene_sub h3 {
  font-weight: 800;
}
.bene_sub strong {
  color: #ffd125;
}

.bene_panels {
  display: grid;
  position: relative;
}
@media screen and (min-width: 769px) {
  .bene_panels {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.7rem 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panels {
    grid-template-columns: repeat(2, 1fr);
    gap: 1.9rem 3.1rem;
  }
}

.bene_panel {
  display: flex;
  align-items: center;
  position: relative;
  background: #fff;
  border: 1px solid;
  color: #2b2b2b;
}
@media screen and (min-width: 769px) {
  .bene_panel {
    border-radius: 3.5rem;
    height: 16rem;
    padding: 0 0 0 4.2rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel {
    flex-direction: column;
    gap: 4.5rem;
    border-radius: 5.5rem;
    padding: 5.5rem 0 6.5rem;
  }
}

.bene_panel_image {
  display: flex;
  align-items: center;
}
@media screen and (min-width: 769px) {
  .bene_panel_image {
    width: 10rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image {
    height: 10.4rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img1 {
    padding-right: 3.1rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img1 {
    width: 10.6rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img2 {
    padding-right: 3.8rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img2 {
    width: 9.7rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img3 {
    padding-right: 3.5rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img3 {
    width: 10.1rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img4 {
    padding-right: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img4 {
    width: 11.3rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img5 {
    padding-right: 3.2rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img5 {
    width: 10.5rem;
  }
}
@media screen and (min-width: 769px) {
  .bene_panel_image.img6 {
    padding-right: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_image.img6 {
    width: 13.1rem;
  }
}

.bene_panel_caption {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 769px) {
  .bene_panel_caption {
    gap: 2rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_caption {
    align-items: center;
    gap: 3rem;
  }
}

.bene_panel_sub {
  line-height: 1;
  font-weight: 800;
  color: #0039bc;
}
@media screen and (min-width: 769px) {
  .bene_panel_sub {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_sub {
    font-size: 3.6rem;
    text-align: center;
  }
}

.bene_panel_text {
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .bene_panel_text {
    line-height: 1.625;
    font-size: 1.6rem;
  }
  .bene_panel_text > p {
    font: inherit;
  }
  .bene_panel_text > p:first-of-type {
    margin-top: -0.312em;
  }
  .bene_panel_text > p:last-of-type {
    margin-bottom: -0.312em;
  }
}
@media screen and (max-width: 768px) {
  .bene_panel_text {
    line-height: 1.5;
    font-size: 2.4rem;
  }
  .bene_panel_text > p {
    font: inherit;
  }
  .bene_panel_text > p:first-of-type {
    margin-top: -0.25em;
  }
  .bene_panel_text > p:last-of-type {
    margin-bottom: -0.25em;
  }
  .bene_panel_text {
    text-align: center;
  }
}

.step_section {
  position: relative;
}
@media screen and (min-width: 769px) {
  .step_section {
    margin-top: -19.033vw;
  }
}
@media screen and (max-width: 768px) {
  .step_section {
    margin-top: -20vw;
  }
}
.step_section::before {
  content: "";
  display: block;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .step_section::before {
    background-image: url(../img/recruitment/step_bg_pc.png);
    height: 27.819vw;
  }
}
@media screen and (max-width: 768px) {
  .step_section::before {
    background-image: url(../img/recruitment/step_bg_sp.png);
    height: 38.667vw;
  }
}

.step_inner {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .step_inner {
    max-width: 110rem;
    margin-top: -4rem;
    padding-bottom: 8rem;
  }
}
@media screen and (max-width: 768px) {
  .step_inner {
    max-width: 67rem;
    margin-top: -4.5rem;
    padding-bottom: 7.5rem;
  }
}

.step_sub {
  display: flex;
  gap: 0.589em;
  position: relative;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 769px) {
  .step_sub {
    margin-bottom: 6rem;
    line-height: 1;
    font-size: 3.4rem;
  }
}
@media screen and (max-width: 768px) {
  .step_sub {
    margin-bottom: 7rem;
    line-height: 1.347;
    font-size: 5.2rem;
  }
  .step_sub > h3 {
    font: inherit;
  }
  .step_sub > h3:first-of-type {
    margin-top: -0.173em;
  }
  .step_sub > h3:last-of-type {
    margin-bottom: -0.173em;
  }
}
.step_sub::before {
  content: "";
  flex-shrink: 0;
  background-image: url(../img/bg1.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  width: 0.883em;
  height: 0.883em;
  translate: 0 13.334%;
}
.step_sub h3 {
  font-weight: 800;
}
.step_sub strong {
  color: #ffd125;
}

.step_flows {
  display: flex;
  position: relative;
  width: 100%;
}
@media screen and (min-width: 769px) {
  .step_flows {
    gap: 0.3rem;
  }
}
@media screen and (max-width: 768px) {
  .step_flows {
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media screen and (min-width: 769px) {
  .step_flows > li {
    width: 100%;
  }
}
@media screen and (max-width: 768px) {
  .step_flows > li {
    width: 33.3rem;
  }
  .step_flows > li:nth-of-type(2n+1) {
    margin-top: -9.1rem;
  }
  .step_flows > li:nth-of-type(2n+1) .step_flow {
    background-image: url(../img/recruitment/step_flow_bg1_sp.png);
    padding-right: 0.7rem;
  }
  .step_flows > li:nth-of-type(2n+1) .step_flow h5 {
    right: 0.7rem;
  }
  .step_flows > li:nth-of-type(2n) {
    margin-top: 5.6rem;
  }
  .step_flows > li:nth-of-type(2n) .step_flow {
    background-image: url(../img/recruitment/step_flow_bg2_sp.png);
    padding-left: 0.7rem;
  }
  .step_flows > li:nth-of-type(2n) .step_flow h5 {
    left: 0.7rem;
  }
  .step_flows > li:nth-of-type(1) {
    margin-top: 0;
  }
  .step_flows > li:nth-of-type(2) {
    margin-top: 14.7rem;
  }
  .step_flows > li:last-of-type .step_flow {
    background: none;
  }
  .step_flows > li:last-of-type .step_flow::before {
    content: "";
    position: absolute;
    background: #fff;
    border: 0.2rem solid #2b2b2b;
    border-radius: 5.5rem;
    left: 0;
    right: 0.7rem;
    top: 0;
    bottom: 0;
  }
}

.step_flow {
  display: flex;
  flex-direction: column;
  align-items: center;
  position: relative;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: 100% 100%;
}
@media screen and (min-width: 769px) {
  .step_flow {
    gap: 2rem;
    background-image: url(../img/recruitment/step_flow_bg_pc.png);
    height: 16.2rem;
    padding: 4.3rem 1rem 0 0;
  }
}
@media screen and (max-width: 768px) {
  .step_flow {
    gap: 2.5rem;
    height: 31rem;
    padding: 10rem 0 0;
  }
}
.step_flow h5 {
  display: flex;
  justify-content: center;
  align-items: baseline;
  position: absolute;
  background: #ffd125;
  border: 1px solid;
  left: 0;
  margin: 0 auto;
  line-height: 1;
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  .step_flow h5 {
    border-radius: 0.4rem 0.4rem 1rem 1rem;
    gap: 0.5rem;
    width: 7rem;
    height: 3rem;
    right: 1rem;
    top: -0.3rem;
    padding: 0.4rem 0 0;
  }
}
@media screen and (max-width: 768px) {
  .step_flow h5 {
    border-radius: 0.8rem 0.8rem 2rem 2rem;
    gap: 0.5rem;
    width: 14rem;
    height: 6rem;
    right: 0;
    top: -0.6rem;
    padding: 0.8rem 0 0;
  }
}
@media screen and (min-width: 769px) {
  .step_flow h5 small {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .step_flow h5 small {
    font-size: 2.4rem;
  }
}
@media screen and (min-width: 769px) {
  .step_flow h5 span {
    font-size: 1.7rem;
  }
}
@media screen and (max-width: 768px) {
  .step_flow h5 span {
    font-size: 3.4rem;
  }
}
.step_flow h4 {
  position: relative;
  line-height: 1;
  font-weight: 800;
  color: #0039bc;
}
@media screen and (min-width: 769px) {
  .step_flow h4 {
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .step_flow h4 {
    font-size: 3.6rem;
  }
}

.step_flow_text {
  position: relative;
  font-weight: 700;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .step_flow_text {
    line-height: 1.572;
    font-size: 1.4rem;
  }
  .step_flow_text > p {
    font: inherit;
  }
  .step_flow_text > p:first-of-type {
    margin-top: -0.285em;
  }
  .step_flow_text > p:last-of-type {
    margin-bottom: -0.285em;
  }
}
@media screen and (max-width: 768px) {
  .step_flow_text {
    line-height: 1.667;
    font-size: 2.4rem;
  }
  .step_flow_text > p {
    font: inherit;
  }
  .step_flow_text > p:first-of-type {
    margin-top: -0.333em;
  }
  .step_flow_text > p:last-of-type {
    margin-bottom: -0.333em;
  }
}

.step_note {
  position: relative;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .step_note {
    padding-top: 3rem;
    line-height: 1.223;
    font-size: 1.8rem;
  }
  .step_note > p {
    font: inherit;
  }
  .step_note > p:first-of-type {
    margin-top: -0.111em;
  }
  .step_note > p:last-of-type {
    margin-bottom: -0.111em;
  }
}
@media screen and (max-width: 768px) {
  .step_note {
    padding-top: 6.5rem;
    line-height: 1.63;
    font-size: 2.7rem;
  }
  .step_note > p {
    font: inherit;
  }
  .step_note > p:first-of-type {
    margin-top: -0.314em;
  }
  .step_note > p:last-of-type {
    margin-bottom: -0.314em;
  }
}

.entry_section {
  position: relative;
  color: #fff;
}
.entry_section::after {
  content: "";
  display: block;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  width: 100%;
  scale: -1 -1;
}
@media screen and (min-width: 769px) {
  .entry_section::after {
    background-image: url(../img/recruitment/bg_b_pc.png);
    height: 19.034vw;
  }
}
@media screen and (max-width: 768px) {
  .entry_section::after {
    background-image: url(../img/recruitment/bg_b_sp.png);
    height: 20vw;
  }
}

.entry_bg {
  position: relative;
}
@media screen and (min-width: 769px) {
  .entry_bg {
    height: 20.498vw;
  }
}
@media screen and (max-width: 768px) {
  .entry_bg {
    height: 28vw;
  }
}
.entry_bg::before, .entry_bg::after {
  content: "";
  display: block;
  position: absolute;
  background-position: center bottom;
  background-repeat: no-repeat;
  background-size: 100% 100%;
  inset: 0;
}
.entry_bg::before {
  opacity: 0;
  translate: 0 30px;
  transition: opacity 0.4s linear, translate 0.4s ease-out;
}
@media screen and (min-width: 769px) {
  .entry_bg::before {
    background-image: url(../img/recruitment/entry_bg2_pc.png);
  }
}
@media screen and (max-width: 768px) {
  .entry_bg::before {
    background-image: url(../img/recruitment/entry_bg2_sp.png);
  }
}
.entry_section.is-animated .entry_bg::before {
  opacity: 1;
  translate: 0 0;
}
@media screen and (min-width: 769px) {
  .entry_bg::after {
    background-image: url(../img/recruitment/entry_bg1_pc.png);
  }
}
@media screen and (max-width: 768px) {
  .entry_bg::after {
    background-image: url(../img/recruitment/entry_bg1_sp.png);
  }
}

.entry_inner {
  position: relative;
  margin: 0 auto;
}
@media screen and (min-width: 769px) {
  .entry_inner {
    max-width: 110rem;
    margin-top: -9.5rem;
    padding: 0 0 5rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_inner {
    max-width: 67rem;
    padding: 0.8rem 0 7rem;
  }
}
.entry_inner::before {
  content: "";
  position: absolute;
  background: #2771e8;
  width: 100vw;
  left: 50%;
  bottom: -0.1rem;
  translate: -50% 0;
}
@media screen and (min-width: 769px) {
  .entry_inner::before {
    min-width: 1140px;
    top: 9.4rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_inner::before {
    top: -0.1rem;
  }
}

.entry_head {
  display: flex;
  flex-direction: column;
  position: relative;
}
@media screen and (min-width: 769px) {
  .entry_head {
    gap: 1.8rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_head {
    gap: 1.5rem;
  }
}
.entry_head p {
  position: relative;
  background-image: url(../img/recruitment/head_p_bg1.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: auto 100%;
}
@media screen and (min-width: 769px) {
  .entry_head p {
    width: 14rem;
    height: 5.2rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_head p {
    width: 21rem;
    height: 7.8rem;
  }
}
.entry_head p svg {
  clip-path: polygon(0 0, 100% 0, 100% 61.539%, 0 61.539%);
}
.entry_head p svg > * {
  fill-opacity: 0;
  translate: 0 20px;
  transition: 0.3s linear;
}
.entry_head p svg > *:nth-of-type(1) {
  transition-delay: 0.4s;
}
.entry_head p svg > *:nth-of-type(2) {
  transition-delay: 0.6s;
}
.entry_head p svg > *:nth-of-type(3) {
  transition-delay: 0.8s;
}
.entry_head p svg > *:nth-of-type(4) {
  transition-delay: 1s;
}
.entry_head p svg > *:nth-of-type(5) {
  transition-delay: 1.2s;
}
.entry_head p svg > *:nth-of-type(6) {
  transition-delay: 1.4s;
}
.entry_head p svg > *:nth-of-type(7) {
  transition-delay: 1.6s;
}
.entry_head p svg > *:nth-of-type(8) {
  transition-delay: 1.8s;
}
.entry_head p svg > *:nth-of-type(9) {
  transition-delay: 2s;
}
.entry_head p svg > *:nth-of-type(10) {
  transition-delay: 2.2s;
}
.entry_head p svg > *:nth-of-type(11) {
  transition-delay: 2.4s;
}
.entry_head p svg > *:nth-of-type(12) {
  transition-delay: 2.6s;
}
.entry_head p svg > *:nth-of-type(13) {
  transition-delay: 2.8s;
}
.entry_head p svg > *:nth-of-type(14) {
  transition-delay: 3s;
}
.entry_head p svg > *:nth-of-type(15) {
  transition-delay: 3.2s;
}
.entry_head h2 {
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  .entry_head h2 {
    letter-spacing: 0.04em;
    line-height: 1;
    font-size: 5.7rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_head h2 {
    letter-spacing: -0.04em;
    line-height: 1.259;
    font-size: 8.5rem;
  }
}
.entry_head.is-animated p svg > * {
  translate: 0 0;
  fill-opacity: 1;
}

.entry_lead {
  position: relative;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .entry_lead {
    padding-top: 4rem;
    line-height: 1.667;
    font-size: 1.8rem;
  }
  .entry_lead > p {
    font: inherit;
  }
  .entry_lead > p:first-of-type {
    margin-top: -0.333em;
  }
  .entry_lead > p:last-of-type {
    margin-bottom: -0.333em;
  }
}
@media screen and (max-width: 768px) {
  .entry_lead {
    padding-top: 2.8rem;
    line-height: 1.643;
    font-size: 2.8rem;
  }
  .entry_lead > p {
    font: inherit;
  }
  .entry_lead > p:first-of-type {
    margin-top: -0.321em;
  }
  .entry_lead > p:last-of-type {
    margin-bottom: -0.321em;
  }
}
.entry_lead span {
  display: inline-block;
  background: #ffd125;
  margin: 0 0.2em;
  padding: 0 0.2em 0 0.3em;
  color: #2b2b2b;
}

.entry_sub {
  display: flex;
  gap: 0.589em;
  position: relative;
  margin-top: 7rem;
  letter-spacing: 0.01em;
}
@media screen and (min-width: 769px) {
  .entry_sub {
    line-height: 1;
    font-size: 3.4rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_sub {
    line-height: 1.347;
    font-size: 5.2rem;
  }
  .entry_sub > h3 {
    font: inherit;
  }
  .entry_sub > h3:first-of-type {
    margin-top: -0.173em;
  }
  .entry_sub > h3:last-of-type {
    margin-bottom: -0.173em;
  }
}
.entry_sub::before {
  content: "";
  flex-shrink: 0;
  background-image: url(../img/bg1.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: contain;
  width: 0.883em;
  height: 0.883em;
  translate: 0 13.334%;
}
.entry_sub h3 {
  font-weight: 800;
}

.entry_text {
  position: relative;
  letter-spacing: 0.04em;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .entry_text {
    padding-top: 4rem;
    line-height: 1.625;
    font-size: 1.6rem;
  }
  .entry_text > p {
    font: inherit;
  }
  .entry_text > p:first-of-type {
    margin-top: -0.312em;
  }
  .entry_text > p:last-of-type {
    margin-bottom: -0.312em;
  }
}
@media screen and (max-width: 768px) {
  .entry_text {
    padding-top: 5rem;
    line-height: 1.616;
    font-size: 2.6rem;
  }
  .entry_text > p {
    font: inherit;
  }
  .entry_text > p:first-of-type {
    margin-top: -0.307em;
  }
  .entry_text > p:last-of-type {
    margin-bottom: -0.307em;
  }
}

.entry_steps {
  counter-reset: entry_steps;
  display: flex;
  position: relative;
}
@media screen and (min-width: 769px) {
  .entry_steps {
    justify-content: space-between;
    align-items: stretch;
    gap: 6.9rem;
    padding-top: 5rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_steps {
    flex-direction: column;
    gap: 5.8rem;
    padding-left: 4.5rem;
    padding-top: 6rem;
  }
}
.entry_steps > li {
  counter-increment: entry_steps;
  position: relative;
  width: 100%;
}
.entry_steps > li + li::before {
  content: "";
  position: absolute;
  background-image: url(../img/entry_step_arrow.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
}
@media screen and (min-width: 769px) {
  .entry_steps > li + li::before {
    width: 1.8rem;
    height: 2.1rem;
    left: -4.1rem;
    top: 50%;
    translate: 0 -50%;
  }
}
@media screen and (max-width: 768px) {
  .entry_steps > li + li::before {
    width: 2.1rem;
    height: 2.6rem;
    left: 50%;
    top: -4rem;
    translate: -50% 0;
    rotate: 90deg;
  }
}

.entry_step {
  display: flex;
  flex-direction: column;
  background: #fff;
  border: 1px solid;
  text-align: justify;
  color: #2b2b2b;
}
@media screen and (min-width: 769px) {
  .entry_step {
    gap: 2rem;
    border-radius: 3.5rem;
    height: 100%;
    padding: 3.5rem 5.4rem 3.5rem 4.9rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_step {
    gap: 3rem;
    border-radius: 5.5rem;
    padding: 5.4rem 4.4rem 6.4rem 6.9rem;
  }
}
.entry_step::after {
  content: counter(entry_steps);
  display: flex;
  justify-content: center;
  align-items: center;
  position: absolute;
  background-image: url(../img/balloon_y.png);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 2.455em;
  height: 2.455em;
  top: 2rem;
  line-height: 1;
  font-weight: 800;
}
@media screen and (min-width: 769px) {
  .entry_step::after {
    left: -2.7rem;
    font-size: 2.2rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_step::after {
    left: -4.6rem;
    font-size: 3.8rem;
  }
}

.entry_step_text {
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .entry_step_text {
    line-height: 1.455;
    font-size: 2.2rem;
  }
  .entry_step_text > p {
    font: inherit;
  }
  .entry_step_text > p:first-of-type {
    margin-top: -0.227em;
  }
  .entry_step_text > p:last-of-type {
    margin-bottom: -0.227em;
  }
}
@media screen and (max-width: 768px) {
  .entry_step_text {
    line-height: 1.375;
    font-size: 3.2rem;
  }
  .entry_step_text > p {
    font: inherit;
  }
  .entry_step_text > p:first-of-type {
    margin-top: -0.187em;
  }
  .entry_step_text > p:last-of-type {
    margin-bottom: -0.187em;
  }
}

.entry_step_address {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 769px) {
  .entry_step_address {
    gap: 1rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_step_address {
    gap: 1.5rem;
  }
}
.entry_step_address > dt {
  line-height: 1;
  font-weight: 700;
}
@media screen and (min-width: 769px) {
  .entry_step_address > dt {
    font-size: 1.4rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_step_address > dt {
    font-size: 2.2rem;
  }
}
.entry_step_address > dd {
  line-height: 1;
}
@media screen and (min-width: 769px) {
  .entry_step_address > dd {
    font-size: 1.2rem;
  }
}
@media screen and (max-width: 768px) {
  .entry_step_address > dd {
    font-size: 2rem;
  }
}
.entry_step_address > dd::before {
  content: "";
  display: inline-block;
  background-image: url(../img/mail01.svg);
  background-position: center center;
  background-repeat: no-repeat;
  background-size: contain;
  width: 1.5em;
  height: 1em;
  margin-right: 0.4em;
  vertical-align: middle;
  translate: 0 5%;
}
.entry_step_address > dd a {
  text-decoration: underline;
}