@charset "UTF-8";

/* 仕事 */
.recruit__what {
  width: 100vw;
  background:
    url(/assets/images/pc/recruit/recruit__bg-1-1-pc.webp) bottom / contain
      no-repeat,
    url(/assets/images/pc/recruit/recruit__bg-1-2-pc.webp) bottom / cover
      no-repeat;
  background-blend-mode: multiply;
  padding: 127px 0;
}
.recruit__what-lead {
  width: min(1000px, 71vw);
  margin-inline: auto;
  text-align: center;
}
.recruit__what-lead h2 {
  margin-bottom: 55px;
  margin-inline: auto;
}
.recruit__what-lead p {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  line-height: 2;
  margin-bottom: 55px;
}
.recruit__what-wrap-h2-jp {
  font-size: clamp(3.2rem, 3.5vw, 4.9rem);
  letter-spacing: 0.1em;
}
.recruit__what-wrap-h2-en {
  font-size: clamp(1.6rem, 1.8vw, 2.6rem);
  letter-spacing: 0.05em;
}
.recruit__what-wrap {
  width: min(1200px, 85vw);
  margin-inline: auto;
  display: flex;
  gap: min(49px, 3.5vw);
}
.recruit__what-inner {
  display: flex;
  flex-direction: column;
  gap: 34px;
}
.recruit__what-inner picture {
  width: min(367px, 26vw);
  max-height: 334px;
  aspect-ratio: 367 / 334;
  height: auto;
}
.recruit__what-inner picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.recruit__what-inner p {
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
  line-height: 1.6;
  text-align: justify;
}
@media (max-width: 767px) {
  .recruit__what {
    width: 100vw;
    background:
      url(/assets/images/sp/recruit/recruit__bg-1-1-sp.webp) bottom / contain
        no-repeat,
      url(/assets/images/sp/recruit/recruit__bg-1-2-sp.webp) bottom / cover
        no-repeat;
    background-blend-mode: multiply;
    padding: 62px 0;
  }
  .recruit__what-lead {
    width: 85vw;
  }
  .recruit__what-wrap-h2-jp {
    letter-spacing: 0;
  }
  .recruit__what-lead h2 {
    margin-bottom: 48px;
  }
  .recruit__what-lead p {
    line-height: 1.6;
    margin-bottom: 42px;
    text-align: justify;
  }
  .recruit__what-wrap {
    gap: 44px;
    flex-direction: column;
  }
  .recruit__what-inner picture {
    width: 85vw;
    max-height: auto;
    aspect-ratio: 330 / 207;
  }
  .recruit__what-inner {
    gap: 23px;
  }
}
/* インタビュー */
.recruit__interview {
  width: 100vw;
  padding: 125px 0 21px;
}
.recruit__interview h2 {
  width: min(1000px, 71vw);
  margin-inline: auto;
  text-align: left;
  margin-bottom: 41px;
}
.recruit__interview-h2-jp {
  font-size: clamp(3.2rem, 3.5vw, 4.9rem);
  letter-spacing: 0.1em;
}
.recruit__interview-h2-en {
  font-size: clamp(1.6rem, 1.8vw, 2.6rem);
  letter-spacing: 0.05em;
}

.recruit__interview-top-1 {
  display: grid;
  grid-template-columns: 55.5vw 1fr;
  grid-template-rows: 63% auto;
  margin-bottom: 96px;
}
.recruit__interview-top-1-img {
  grid-column: 1;
  grid-row: 1 / span 2;
  position: relative;
}
.recruit__interview-top-1-img picture {
  width: 100%;
  max-height: 576px;
  aspect-ratio: 911 / 576;
  height: auto;
  border-radius: 0 49px 49px 0;
  overflow: hidden;
}
.recruit__interview-top-1-img picture::before {
  content: "";
  width: 110%;
  height: 100%;
  max-height: 576px;
  aspect-ratio: 911 / 576;
  background-color: #0071ff;
  border-radius: 0 49px 49px 0;
  position: absolute;
  z-index: -1;
  top: 50%;
  right: -17px;
  transform: translateY(-50%) rotate(-357deg);
}
.recruit__interview-top-1-img picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.recruit__interview-top-1-img p {
  position: absolute;
  right: 0;
  bottom: -1.4vw;
  color: #0071ff;
  font-size: clamp(9.4rem, 13.5vw, 19rem);
  line-height: 1;
  padding-right: min(42px, 3vw);
}
.recruit__interview-top-1-h3 {
  grid-column: 2;
  grid-row: 1;
  align-self: flex-end;
  transform: translateX(min(-123px, -8vw));
}
.recruit__interview-top-1-h3 h3 {
  display: inline;
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  line-height: 1.6;
  color: #fff;
  padding: 0 19px;
  background: linear-gradient(35deg, #0071ff 65%, #333);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  white-space: nowrap;
}
.recruit__interview-top-1-p {
  grid-column: 2;
  grid-row: 2;
  align-self: center;
  margin-left: min(79px, 5.6vw);
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  line-height: 1.1;
}
.recruit__interview-top-1-p-name {
  font-size: clamp(6.5rem, 6.2vw, 8.8rem);
  margin-right: min(10px, 0.7vw);
}

.recruit__interview-top-2 {
  display: grid;
  grid-template-columns: 1fr 55.5vw;
  grid-template-rows: 63% auto;
  margin-bottom: 96px;
}
.recruit__interview-top-2-img {
  grid-column: 2;
  grid-row: 1 / span 2;
  position: relative;
}
.recruit__interview-top-2-img picture {
  width: 100%;
  max-height: 576px;
  aspect-ratio: 911 / 576;
  height: auto;
  border-radius: 49px 0 0 49px;
  overflow: hidden;
}
.recruit__interview-top-2-img picture::before {
  content: "";
  width: 110%;
  height: 100%;
  max-height: 576px;
  aspect-ratio: 911 / 576;
  background-color: #0071ff;
  border-radius: 49px 0 0 49px;
  position: absolute;
  z-index: -1;
  top: 50%;
  left: -17px;
  transform: translateY(-50%) rotate(357deg);
}
.recruit__interview-top-2-img picture img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top;
}
.recruit__interview-top-2-img p {
  position: absolute;
  left: 0;
  bottom: -1.4vw;
  color: #0071ff;
  font-size: clamp(9.4rem, 13.5vw, 19rem);
  line-height: 1;
  margin-left: min(42px, 3vw);
}
.recruit__interview-top-2-h3 {
  grid-column: 1;
  grid-row: 1;
  align-self: flex-end;
  justify-self: end;
  text-align: right;
  transform: translateX(min(123px, 8vw));
}
.recruit__interview-top-2-h3 h3 {
  display: inline;
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  line-height: 1.6;
  color: #fff;
  padding: 0 19px;
  background: linear-gradient(35deg, #333, #0071ff 65%);
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  white-space: nowrap;
}
.recruit__interview-top-2-p {
  grid-column: 1;
  grid-row: 2;
  align-self: center;
  justify-self: end;
  padding-right: min(79px, 5.6vw);
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  line-height: 1.1;
}
.recruit__interview-top-2-p-name {
  font-size: clamp(6.5rem, 6.2vw, 8.8rem);
  margin-right: min(10px, 0.7vw);
}

.recruit__interview-bottom {
  width: min(71vw, 1000px);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  margin-bottom: 104px;
  gap: min(68px, 4.8vw) min(78px, 5.5vw);
}
.recruit__interview-bottom-img {
  width: clamp(330px, 32.7vw, 458px);
  aspect-ratio: 458 / 321;
  height: auto;
  border-radius: 30px;
  overflow: hidden;
}
.recruit__interview-bottom-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.recruit__interview-bottom dl {
  width: clamp(330px, 32.7vw, 458px);
}
.recruit__interview-bottom dl dt {
  display: flex;
  gap: min(38px, 2.7vw);
  margin-bottom: 31px;
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  line-height: 2;
  align-items: center;
}
.recruit__interview-bottom-item-no {
  color: #0071ff;
  font-size: clamp(6.2rem, 6.1vw, 8.6rem);
  border-bottom: solid 1px #333;
  line-height: 1;
  padding-bottom: 27px;
}
.recruit__interview-bottom dl dd {
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
  line-height: 2;
  text-align: justify;
}
@media (max-width: 767px) {
  .recruit__interview h2 {
    width: 85vw;
    margin-bottom: 35px;
  }
  .recruit__interview-h2-jp {
    letter-spacing: 0;
  }
  .recruit__interview {
    width: 100vw;
    padding: 59px 0 0;
  }
  .recruit__interview-top-1 {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    margin-bottom: 53px;
  }
  .recruit__interview-top-1-img {
    grid-column: 1;
    grid-row: 1;
  }
  .recruit__interview-top-1-h3 {
    grid-column: 1;
    grid-row: 2;
    align-self: center;
    transform: translateX(0);
    margin: 33px 0 13px;
  }
  .recruit__interview-top-1-p {
    grid-column: 1;
    grid-row: 3;
    margin-left: 0;
    text-align: center;
    line-height: 1;
  }
  .recruit__interview-top-1-p-name {
    margin-right: 8px;
    margin-left: 10vw;
  }
  .recruit__interview-top-1-img picture {
    max-height: 285px;
    aspect-ratio: 390 / 285;
  }
  .recruit__interview-top-1-img picture::before {
    max-height: 285px;
    aspect-ratio: 390 / 285;
  }
  .recruit__interview-top-1-img p {
    bottom: -10px;
    margin-right: 7.5vw;
  }
  .recruit__interview-top-1-h3 h3 {
    padding-left: 7.5vw;
  }
  .recruit__interview-bottom {
    width: 85vw;
    margin-bottom: 60px;
    gap: 34px;
  }
  .recruit__interview-bottom dl dt {
    gap: 27px;
    margin-bottom: 22px;
    line-height: 1.6;
    align-items: flex-start;
  }
  .recruit__interview-bottom-item-no {
    line-height: 0.8;
    padding-bottom: 21px;
  }
  .recruit__interview-top-2 {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto auto;
    margin-bottom: 53px;
  }
  .recruit__interview-top-2-img {
    grid-column: 1;
    grid-row: 1;
  }
  .recruit__interview-top-2-img picture {
    max-height: 285px;
    aspect-ratio: 390 / 285;
  }
  .recruit__interview-top-2-img picture::before {
    max-height: 285px;
    aspect-ratio: 390 / 285;
  }

  .recruit__interview-top-2-img p {
    bottom: -10px;
    margin-right: 7.5vw;
  }
  .recruit__interview-top-2-h3 {
    grid-column: 1;
    grid-row: 2;
    transform: translateX(0);
    margin: 33px 0 13px;
  }
  .recruit__interview-top-2-p {
    grid-column: 1;
    grid-row: 3;
    margin-right: 0;
    line-height: 1;
    justify-self: center;
  }
  .recruit__interview-top-2-p-name {
    margin-right: 8px;
    margin-left: 10vw;
  }
  .recruit__interview-top-2-h3 h3 {
    padding-right: 7.5vw;
  }
  .recruit__interview-bottom dl {
    width: 85vw;
  }
  .recruit__interview-bottom-img {
    width: 85vw;
  }
}

/* 働く環境 */
.recruit__workstyle {
  width: 100vw;
  background: url(/assets/images/pc/recruit/recruit__bg-2-pc.webp) bottom /
    cover no-repeat;
  padding: 149px 0 118px;
}
.recruit__workstyle h2 {
  width: min(1000px, 71vw);
  margin-inline: auto;
  text-align: left;
  margin-bottom: 45px;
}
.recruit__workstyle-h2-jp {
  font-size: clamp(3.2rem, 3.5vw, 4.9rem);
  letter-spacing: 0.1em;
}
.recruit__workstyle-h2-en {
  font-size: clamp(1.6rem, 1.8vw, 2.6rem);
  letter-spacing: 0.05em;
}

.recruit__workstyle-growth {
  margin-bottom: 95px;
}
.recruit__workstyle-growth h3 {
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  letter-spacing: 0.15em;
  text-align: center;
  margin-bottom: 58px;
  display: flex;
  justify-content: center;
}
.recruit__workstyle-growth h3 span {
  position: relative;
}
.recruit__workstyle-growth h3 span::before {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  left: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.recruit__workstyle-growth h3 span::after {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  right: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.recruit__workstyle-growth ul {
  display: flex;
  align-items: center;
  gap: clamp(28px, 2.6vw, 37px);
  flex-direction: column;
}
.recruit__workstyle-growth ul li {
  width: min(1000px, 71vw);
  padding: 22px 30px;
  border-radius: 20px;
  background: url(/assets/images/pc/recruit/recruit__3_frame-pc.webp) center /
    cover no-repeat;
  display: grid;
  grid-template-columns: min(367px, 26vw) 1fr;
}
.recruit__workstyle-growth ul li h4 {
  background-color: #fff;
  width: 100%;
  border-radius: 20px;
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  color: #0071ff;
}
.recruit__workstyle-growth ul li h4 span {
  height: clamp(41px, 8.7vw, 122px);
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 20px;
  line-height: 1.2;
  text-align: center;
}
.recruit__workstyle-growth ul li p {
  color: #fff;
  margin-left: clamp(25.5px, 2.9vw, 41px);
  margin-right: min(24px, 1.7vw);
  align-content: center;
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
  text-align: justify;
  line-height: 1.6;
}
.recruit__workstyle-benefits ul {
  width: min(1000px, 71vw);
  margin-inline: auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: min(55px, 3.9vw);
}
.recruit__workstyle-benefits ul li {
  width: clamp(160px, 33vw, 472px);
  height: 217px;
  display: grid;
  grid-template-columns: 1fr 50%;
  background-color: #fff;
  border-radius: 20px;
  justify-self: center;
  align-self: center;
  box-shadow: 0 0 10px rgba(0, 113, 255, 0.45);
}
.recruit__workstyle-benefits-img {
  justify-self: center;
  align-self: center;
  width: min(163px, 11vw);
  height: auto;
}
.recruit__workstyle-benefits-img img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.recruit__workstyle-benefits-text {
  width: min(188px, 13vw);
  justify-self: left;
  align-self: center;
}
.recruit__workstyle-benefits-text h4 {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  margin-bottom: 18px;
  text-align: center;
}
.recruit__workstyle-benefits-text p {
  font-size: clamp(1.3rem, 1.1vw, 1.6rem);
  letter-spacing: 0.05em;
  text-align: justify;
}
.recruit__workstyle-benefits {
  margin-bottom: 95px;
}
.recruit__workstyle-benefits h3 {
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  letter-spacing: 0.15em;
  text-align: center;
  margin-bottom: 58px;
  display: flex;
  justify-content: center;
}
.recruit__workstyle-benefits h3 span {
  position: relative;
}
.recruit__workstyle-benefits h3 span::before {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  left: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.recruit__workstyle-benefits h3 span::after {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  right: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}

.recruit__workstyle-dorm {
  width: min(1000px, 71vw);
  margin-inline: auto;
}
.recruit__workstyle-dorm h3 {
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  letter-spacing: 0.15em;
  text-align: center;
  margin-bottom: 58px;
  display: flex;
  justify-content: center;
}
.recruit__workstyle-dorm h3 span {
  position: relative;
}
.recruit__workstyle-dorm h3 span::before {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  left: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.recruit__workstyle-dorm h3 span::after {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  right: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.recruit__workstyle-dorm-lead {
  line-height: 2;
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  text-align: center;
  margin-bottom: 41px;
}
.recruit__workstyle-main {
  display: grid;
  grid-template-columns: 1fr 56%;
  margin-bottom: 91px;
}
.recruit__workstyle-text {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
}
.recruit__workstyle-text h4 {
  padding: 6px 0 6px 31px;
  border: 1px solid #333;
  border-radius: 23px;
  background-color: #fff;
  width: 120%;
  transform: translateX(-31px);
  margin: min(61px, 4.3vw) 0 min(17px, 1.2vw) 0;
}
.recruit__workstyle-text-p-1 {
  margin-bottom: min(35px, 2.5vw);
}
.recruit__workstyle-text-p-2 {
  margin-bottom: min(21px, 1.5vw);
}
.recruit__workstyle-text ul {
  font-size: clamp(1.3rem, 1.1vw, 1.6rem);
  letter-spacing: 0.05em;
}
.recruit__workstyle-text ul {
  font-size: clamp(1.3rem, 1.1vw, 1.6rem);
}
.recruit__workstyle-text ul li {
  width: min(301px, 21.5vw);
  transform: translateX(clamp(33px, 3.1vw, 44px));
  position: relative;
}
.recruit__workstyle-text ul li:not(:last-child) {
  margin-bottom: min(23px, 1.6vw);
}
.recruit__workstyle-text ul li::before {
  position: absolute;
  content: "";
  background: url(/assets/images/common/check.webp) center / contain no-repeat;
  width: clamp(24px, 2.3vw, 33px);
  height: clamp(18px, 1.7vw, 25px);
  transform: translateX(calc(-1 * clamp(33px, 3.1vw, 44px)));
}
/* swiper-slide */
.recruit__workstyle-swiper-img {
  border-radius: 37px;
  background-color: #fff;
}
.recruit__workstyle-swiper-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.swiper-pagination-bullet {
  background: #fff !important;
  opacity: 1;
}
.swiper-pagination-bullet-active {
  background: #fff !important;
}
@media (max-width: 767px) {
  .recruit__workstyle {
    background: url(/assets/images/sp/recruit/recruit__bg-2-sp.webp) bottom /
      cover no-repeat;
    padding: 60px 0 0;
  }
  .recruit__workstyle h2 {
    width: 85vw;
    margin-bottom: 43px;
  }
  .recruit__workstyle-growth h3 {
    margin-bottom: 34px;
  }
  .recruit__workstyle-growth ul li {
    width: 85vw;
    height: 156px;
    padding: 21px 24px;
    border-radius: 11px;
    background: url(/assets/images/sp/recruit/recruit__3_frame-sp.webp) center /
      cover no-repeat;
    grid-template-columns: 1fr;
    grid-template-rows: 44px auto;
    gap: 13px;
  }
  .recruit__workstyle-growth ul li h4 {
    border-radius: 11px;
    align-content: center;
  }
  .recruit__workstyle-growth ul li h4 span {
    height: auto;
    padding: 7px;
  }
  .recruit__workstyle-growth ul li p {
    margin-left: 0;
    margin-right: 0;
  }
  .recruit__workstyle-growth {
    margin-bottom: 66px;
  }
  .recruit__workstyle-benefits h3 {
    margin-bottom: 37px;
  }
  .recruit__workstyle-benefits ul {
    width: 85vw;
    gap: 27px 8px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 1fr 1fr;
  }
  .recruit__workstyle-benefits ul li {
    width: 100%;
    height: 239px;
    grid-template-columns: 1fr;
    grid-template-rows: 111px auto;
    border-radius: 15px;
  }
  .recruit__workstyle-benefits-img {
    width: auto;
    height: 86px;
  }
  .recruit__workstyle-benefits-text {
    width: 80%;
    justify-self: center;
    align-self: flex-start;
  }
  .recruit__workstyle-benefits-text h4 {
    margin-bottom: 14px;
  }
  .recruit__workstyle-benefits {
    margin-bottom: 68px;
  }
  .recruit__workstyle-dorm {
    width: 85vw;
  }
  .recruit__workstyle-dorm h3 {
    margin-bottom: 33px;
  }
  .recruit__workstyle-dorm-lead {
    text-align: justify;
    line-height: 1.6;
  }
  .recruit__workstyle-main {
    grid-template-columns: 1fr;
    grid-template-rows: auto auto;
    margin-bottom: 61px;
  }
  .recruit__workstyle-text h4 {
    padding: 6px 0 6px 27px;
    border-radius: 17px;
    width: 85vw;
    transform: translateX(0);
    margin: 0;
  }
  .recruit__workstyle-text-p-1 {
    margin-bottom: 29px;
    margin-top: 13px;
    margin-left: 27px;
  }
  .recruit__workstyle-text-p-2 {
    margin-bottom: 22px;
    margin-left: 27px;
  }
  .recruit__workstyle-text ul {
    margin-left: 27px;
    margin-bottom: 43px;
  }
  .recruit__workstyle-text ul li {
    width: calc(85vw - 60px);
    transform: translateX(33px);
  }
  .recruit__workstyle-text ul li:not(:last-child) {
    margin-bottom: 12px;
  }
}

/* swiper-slider */
.recruit__workstyle-swiper-slider-img .swiper-wrapper {
  transition-timing-function: linear !important;
}
.recruit__workstyle-swiper-slider-img .swiper-slide {
  width: 347px;
  height: 344px;
  position: relative;
}
.recruit__workstyle-swiper-slider-img .swiper-slide img {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  width: auto;
  height: auto;
}
.swiper-slider-slide-1 img {
  top: 0;
  max-height: 258px;
  border-radius: 20px;
}
.swiper-slider-slide-2 img {
  bottom: 0;
  max-height: 258px;
  border-radius: 20px;
}

@media (max-width: 767px) {
  .recruit__workstyle-swiper-slider-img .swiper-slide {
    width: 139px;
    height: 137px;
  }
  .swiper-slider-slide-1 img {
    top: 0;
    max-height: 103px;
  }
  .swiper-slider-slide-2 img {
    bottom: 0;
    max-height: 103px;
  }
}

/*モーダル*/
/* モーダルボタン */
.Modal-flex {
  display: flex;
  margin-top: 100px;
  justify-content: center;
  width: min(1200px, 85vw);
  margin-inline: auto;
  position: relative;
  z-index: 1111;
}
.Modal-flex-button-span-jp {
  font-size: clamp(3.2rem, 3.5vw, 4.9rem);
  letter-spacing: 0.1em;
  white-space: nowrap;
}
.Modal-flex-button-span-en {
  font-size: clamp(1.6rem, 1.8vw, 2.6rem);
  letter-spacing: 0.05em;
}
.Modal-flex-Requirement {
  position: relative;
  width: min(595px, 42.5vw);
  aspect-ratio: 661 / 565;
  height: auto;
}
.Modal-flex-Requirement img {
  position: absolute;
  top: 0;
  left: 0;
  transition: opacity 0.3s ease;
}
.Modal-flex-Requirement-button-span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  z-index: 3;
}
.Modal-flex-QA {
  position: relative;
  width: min(595px, 42.5vw);
  aspect-ratio: 661 / 565;
  height: auto;
  transform: translateY(118px);
}
.Modal-flex-QA img {
  position: absolute;
  top: 0;
  left: 0;
  transition: opacity 0.3s ease;
}
.Modal-flex-QA-button-span {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  z-index: 3;
}
/* 通常画像 */
.Modal__img-default {
  z-index: 1;
  opacity: 1;
}
/* ホバー画像 */
.Modal__img-hover {
  z-index: 2;
  opacity: 0;
}
.Modal-flex-Requirement:hover .Modal__img-default {
  opacity: 0;
}
.Modal-flex-Requirement:hover .Modal__img-hover {
  opacity: 1;
}
.Modal-flex-QA:hover .Modal__img-default {
  opacity: 0;
}
.Modal-flex-QA:hover .Modal__img-hover {
  opacity: 1;
}

/* モーダルシステム */
.modal {
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  display: none;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.4s ease;
}
.modal.show {
  display: flex;
  opacity: 1;
  pointer-events: auto;
}
.modal-wrapper {
  position: relative;
  width: min(71vw, 1000px);
  padding: 67px 0 64px;
  margin-inline: auto;
  background-color: #fff;
  overflow-y: auto;
  height: 85dvh;
  z-index: 1001;
  transform: translateY(37.5px);
}
#closeModal2,
#closeModal1 {
  display: block;
  z-index: 9999;
  position: absolute;
  width: 30px;
  height: 30px;
  background-color: #fff;
  top: 29px;
  right: 29px;
}
#closeModal2 span,
#closeModal1 span {
  content: "";
  display: block;
  position: absolute;
  background-color: transparent;
  width: 20px;
  height: 2px;
  transition: all 0.5s;
  margin: 0 auto;
  top: 50%;
  left: 50%;
  transform: translateY(-50%);
}
#closeModal2 span::before,
#closeModal2 span::after,
#closeModal1 span::before,
#closeModal1 span::after {
  content: "";
  display: block;
  position: absolute;
  background-color: #898989;
  width: 20px;
  height: 2px;
}
#closeModal2 span::before,
#closeModal1 span::before {
  transform: translateX(-50%) rotate(45deg);
  top: 50%;
}
#closeModal2 span::after,
#closeModal1 span::after {
  transform: translateX(-50%) rotate(-45deg);
  top: 50%;
}
body.modal-open {
  overflow: hidden;
}

/* モーダル中身（共通） */

.modal-inner h3 {
  font-size: clamp(2.5rem, 2.5vw, 3.5rem);
  text-align: center;
}
/* モーダル中身（募集要項） */
.modal-inner h4 {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  width: min(63vw, 883px);
  margin-inline: auto;
  margin-top: 60px;
  margin-bottom: 28px;
  position: relative;
  transform: translateX(calc(1 * clamp(25px, 2.5vw, 35px)));
}
.modal-inner h4::before {
  position: absolute;
  content: "";
  width: clamp(12px, 1.2vw, 17px);
  height: clamp(12px, 1.2vw, 17px);
  background: linear-gradient(145deg, #333, #0071ff 90%);
  top: 50%;
  left: calc(-1 * clamp(25px, 2.5vw, 35px));
  transform: translateY(-50%);
}
.modal-inner-Requirement-top {
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
  line-height: 1.6;
  width: min(63vw, 883px);
  border-collapse: collapse;
  margin: 0 auto;
}
.modal-inner-Requirement-top th {
  white-space: nowrap;
  width: min(162px, 11vw);
  padding: min(24px, 1.7vw) min(31px, 2.2vw);
  text-align: left;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
  border-bottom: 1px solid #333;
  background-color: #e9ecf6;
  align-content: start;
}
.modal-inner-Requirement-top td {
  padding: min(24px, 1.7vw) min(31px, 2.2vw);
  text-align: left;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
}

.modal-inner-Requirement-bottom {
  width: min(63vw, 883px);
  margin: 0 auto;
  background-color: #e9ecf6;
  border-radius: 34px;
  padding: 25px 0;
}
.modal-inner-Requirement-bottom table {
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
  line-height: 1.6;
  width: min(55.3vw, 775px);
  border-collapse: collapse;
  margin: 0 auto;
}
.modal-inner-Requirement-bottom tr:not(:last-child) {
  border-bottom: 1px dashed #0071ff;
}
.modal-inner-Requirement-bottom th {
  color: #0071ff;
  white-space: nowrap;
  width: min(270px, 19.2vw);
  padding: 0 min(30px, 2vw);
  text-align: left;
}
.modal-inner-Requirement-bottom td {
  padding: min(25px, 1.7vw) min(30px, 2vw);
  text-align: left;
}

/* モーダル中身（QA） */
.modal-inner-QA dl {
  width: min(63vw, 883px);
  margin-inline: auto;
  margin-top: 75px;
}
.modal-inner-QA dl dt {
  display: flex;
  align-items: flex-start;
  gap: min(17px, 1.2vw);
  text-align: justify;
  background-color: #c5d0e1;
  padding: 20px 30px;
  border-top: 1px solid #333;
  border-bottom: 1px solid #333;
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
}
.modal-inner-QA dl dd {
  display: flex;
  align-items: flex-start;
  gap: min(17px, 1.2vw);
  text-align: justify;
  background-color: #e9ecf6;
  padding: 20px 30px;
  font-size: clamp(1.3rem, 1.5vw, 2.1rem);
}
.modal-inner-QA-u-q {
  color: #8e9fb6;
  font-size: clamp(2.2rem, 2.5vw, 3.5rem);
  line-height: 1;
}
.modal-inner-QA-u-a {
  color: #0071ff;
  font-size: clamp(2.2rem, 2.5vw, 3.5rem);
  line-height: 1;
}
@media (max-width: 767px) {
  .modal-wrapper {
    transform: translateY(35px);
    width: 85vw;
    padding: 45px 0 49px;
  }
  .Modal-flex {
    flex-direction: column;
    margin-top: 42px;
  }
  .Modal-flex-Requirement {
    width: 85vw;
  }
  .Modal-flex-QA {
    width: 85vw;
    transform: translateY(0);
  }
  #closeModal2,
  #closeModal1 {
    width: 13px;
    height: 13px;
    top: 15px;
    right: 15px;
  }
  #closeModal2 span,
  #closeModal1 span {
    width: 13px;
    height: 1.4px;
  }
  #closeModal2 span::before,
  #closeModal2 span::after,
  #closeModal1 span::before,
  #closeModal1 span::after {
    width: 13px;
    height: 1.4px;
  }
  .modal-inner h4 {
    width: 70vw;
    margin-top: 45px;
    margin-bottom: 16px;
  }
  .modal-inner-Requirement-top {
    width: 70vw;
  }
  .modal-inner-Requirement-top th {
    width: min(19vw, 86px);
    padding: min(10px, 2vw) min(9px, 2vw);
  }
  .modal-inner-Requirement-top td {
    padding: min(10px, 2vw) min(9px, 2vw);
    text-align: justify;
  }
  .modal-inner-Requirement-bottom {
    width: 70vw;
    border-radius: 25px;
    padding: 13px 0;
  }
  .modal-inner-Requirement-bottom table {
    width: 60vw;
  }
  .modal-inner-Requirement-bottom th {
    width: 21vw;
    padding: 12px min(12px, 3vw);
    align-content: flex-start;
  }
  .modal-inner-Requirement-bottom td {
    padding: 12px min(12px, 3vw);
    align-content: flex-start;
    text-align: justify;
  }
  .modal-inner-QA dl {
    width: 70vw;
    margin-top: 48px;
  }
  .modal-inner-QA dl dt {
    gap: 11px;
    padding: 12px 20px 15px 12px;
  }
  .modal-inner-QA dl dd {
    gap: 11px;
    padding: 12px 20px 15px 12px;
  }
}

/* メッセージ */
.recruit__message {
  width: 100vw;
  background: url(/assets/images/pc/recruit/recruit__bg-3-pc.webp) top / cover
    no-repeat;
  padding-top: 673px;
  padding-bottom: 122px;
  margin-top: -470px;
}
.recruit__message-lead {
  width: min(1000px, 71vw);
  margin-inline: auto;
  margin-bottom: 58px;
  color: #fff;
  text-align: center;
}
.recruit__message-lead p {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  line-height: 2;
}
.recruit__message-lead h2 {
  margin-bottom: 58px;
}
.recruit__message-h2-jp {
  font-size: clamp(3.2rem, 3.5vw, 4.9rem);
  letter-spacing: 0.1em;
}
.recruit__message-h2-en {
  font-size: clamp(1.6rem, 1.8vw, 2.6rem);
  letter-spacing: 0.05em;
}
.recruit__message ul {
  display: flex;
  justify-content: center;
  width: min(1200px, 85vw);
  margin-inline: auto;
}

.recruit__message ul li {
  background-color: rgba(255, 255, 255, 0.8);
  border-radius: 0 66px;
  width: clamp(330px, 25vw, 360px);
  height: clamp(209px, 24vw, 341px);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 0 min(43px, 3vw);
}
.recruit__message ul li:first-child {
  transform: translateX(min(3vw, 45px));
}
.recruit__message ul li:nth-child(2) {
  margin-top: min(132px, 9.4vw);
}
.recruit__message ul li:last-child {
  transform: translateX(calc(-1 * min(3vw, 45px)));
}
.recruit__message ul li h3 {
  font-size: clamp(2.5rem, 2vw, 3rem);
  margin-bottom: min(36px, 2.5vw);
}
.recruit__message ul li p {
  font-size: clamp(1.5rem, 1.5vw, 2.1rem);
  text-align: justify;
}
@media (max-width: 767px) {
  .recruit__message {
    background: url(/assets/images/sp/recruit/recruit__bg-3-sp.webp) top / cover
      no-repeat;
    padding-top: 173px;
    padding-bottom: 62px;
    margin-top: -125px;
  }
  .recruit__message-lead h2 {
    margin-bottom: 45px;
  }
  .recruit__message-lead {
    width: 85vw;
    margin-bottom: 45px;
  }
  .recruit__message-lead p {
    text-align: justify;
  }
  .recruit__message ul {
    flex-direction: column;
  }
  .recruit__message ul li {
    border-radius: 0 44px;
    width: auto;
    padding: 0 40px;
    justify-content: flex-start;
  }
  .recruit__message ul li:first-child {
    transform: translateX(0);
  }
  .recruit__message ul li:last-child {
    transform: translateX(0);
  }
  .recruit__message ul li:nth-child(2) {
    margin: 30px 0;
  }
  .recruit__message ul li h3 {
    margin-bottom: 23px;
    margin-top: 40px;
  }
  .recruit__message ul li p {
    line-height: 1.6;
  }
}
