@charset "utf-8";

.intro {
  position: relative;
  z-index: 2;
}
.intro__content {
  position: relative;
  z-index: 1;
  padding-block: 132px calc(311 / 1920 * 100%);
  grid-template-columns: 100%;
  align-items: start;
}
.intro__content__photo {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 1;
  width: 100%;
}
.intro__content__photo__item {
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: calc(404 / 1920 * 100%);
}
.intro__content__photo__item--1 {
  z-index: 2;
  margin-left: calc(20 / 1920 * -100%);
}
.intro__content__photo__item--2 {
  left: auto;
  right: 0;
}
.intro__content__photo__item--3 {
  margin-top: calc(256 / 1920 * 100%);
  margin-left: calc(134 / 1920 * 100%);
}
.intro__content__photo__item--4 {
  margin-top: calc(444 / 1920 * 100%);
  margin-left: calc(1424 / 1920 * 100%);
}
.intro__content__photo__item--5 {
  margin-top: calc(695 / 1920 * 100%);
  margin-left: calc(1549 / 1920 * 100%);
}
.intro__content__photo__item--6 {
  margin-top: calc(748 / 1920 * 100%);
  margin-left: calc(116 / 1920 * -100%);
}
.intro__content__desc {
  grid-column: 1;
  grid-row: 1;
  position: relative;
  z-index: 2;
  margin-top: calc(188 / 1920 * 100%);
}
/* .intro__content__desc__heading {
} */
.intro__content__desc__heading > span {
  display: block;
  margin-inline: auto;
}
.intro__content__desc__heading > span:nth-of-type(1) {
  width: calc(707 / 1920 * 100%);
}
.intro__content__desc__heading > span:nth-of-type(2) {
  width: calc(457 / 1920 * 100%);
}
.intro__content__desc__heading > span:nth-of-type(3) {
  width: calc(707 / 1920 * 100%);
}
.intro__content__desc__heading > span:nth-of-type(4) {
  width: calc(531 / 1920 * 100%);
}
.intro__content__desc__copy {
  max-width: min(calc(896 / 1920 * 100%), 896px);
  margin-top: 80px;
  margin-inline: auto;
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  line-height: 2;
}
.intro__content__desc__nav {
  max-width: min(95%, 720px);
  margin-top: 80px;
  margin-inline: auto;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: 24px;
}
/* .intro__content__desc__nav__btn {
} */
.intro__content__desc__nav__btn a {
  width: 100%;
}
.intro__content__desc__nav__btn a::after {
  width: calc(10 / 16 * 1em);
  background: rgb(var(--color-red));
  -webkit-mask: url('data:image/svg+xml;utf8,<svg width="9" height="12" viewBox="0 0 9 12" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M4.39062 10.5L4.39062 0.5L0.390625 0.5" stroke="%23000"/><path d="M8.39062 5.5L4.39062 10.5L0.390625 5.5" stroke="%23000"/></svg>') no-repeat center/100% auto;
  mask: url('data:image/svg+xml;utf8,<svg width="9" height="12" viewBox="0 0 9 12" fill="none" xmlns="http://www.w3.org/2000/svg"><path d="M4.39062 10.5L4.39062 0.5L0.390625 0.5" stroke="%23000"/><path d="M8.39062 5.5L4.39062 10.5L0.390625 5.5" stroke="%23000"/></svg>') no-repeat center/100% auto;
}
.intro__copy {
  height: 0;
}
.intro__copy__item {
  font-size: calc(180 / 1920 * 100vw);
  line-height: 1.216666667;
  background: linear-gradient(180deg, rgb(var(--color-black2)) 10%, #747474);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
  color: transparent;
  translate: 0 -58%;
}
@media (any-hover: hover) {
  .intro__content__desc__nav__btn a:hover::after {
    animation: none;
  }
}
@media screen and (min-width: 768px) {
  .intro__content__photo__item {
    opacity: 0;
  }
}
@media screen and (max-width: 767px){
  .intro__content {
    padding-block: 60px calc(90 / 380 * 100%);
  }
  .intro__content__photo {
    height: 100%;
  }
  .intro__content__photo__item--1 {
    margin-left: calc(21 / 380 * -100%);
    width: calc(130 / 380 * 100%);
  }
  .intro__content__photo__item--2 {
    width: calc(160 / 380 * 100%);
  }
  .intro__content__photo__item--3 {
    margin-top: calc(75 / 380 * 100%);
    margin-left: calc(77 / 380 * 100%);
    width: calc(120 / 380 * 100%);
  }
  .intro__content__photo__item--4 {
    top: auto;
    bottom: 0;
    margin-top: 0;
    margin-bottom: calc(84 / 380 * 100%);
    margin-left: calc(146 / 380 * 100%);
    width: calc(120 / 380 * 100%);
    z-index: 2;
  }
  .intro__content__photo__item--5 {
    top: auto;
    bottom: 0;
    margin-top: 0;
    margin-left: calc(224 / 380 * 100%);
    width: calc(162 / 380 * 100%);
  }
  .intro__content__photo__item--6 {
    top: auto;
    bottom: 0;
    margin-top: 0;
    margin-left: calc(50 / 380 * -100%);
    width: calc(162 / 380 * 100%);
  }
  .intro__content__desc {
    margin-block: calc(205 / 380 * 100%) calc(226 / 380 * 100%);
  }
  .intro__content__desc__heading > span:nth-of-type(1) {
    width: calc(318 / 380 * 100%);
  }
  .intro__content__desc__heading > span:nth-of-type(2) {
    width: calc(206 / 380 * 100%);
  }
  .intro__content__desc__heading > span:nth-of-type(3) {
    width: calc(318 / 380 * 100%);
  }
  .intro__content__desc__heading > span:nth-of-type(4) {
    width: calc(239 / 380 * 100%);
  }
  .intro__content__desc__copy {
    max-width: min(calc(320 / 380 * 100%), 560px);
    margin-top: 30px;
    font-size: 18px;
    line-height: 1.8;
  }
  .intro__content__desc__nav {
    max-width: 197px;
    margin-top: 30px;
    grid-template-columns: 100%;
    align-items: start;
    gap: 16px 0;
  }
  .intro__copy__item {
    font-size: calc(65 / 380 * 100vw);
    line-height: 1.215384615;
    translate: 0 -58%;
  }
}



.achievement {
  position: relative;
  z-index: 1;
  padding-block: calc(200 / 1920 * 100%) 120px;
  background: rgb(var(--color-black2));
}
/* .achievement__content {
}
.achievement__content__heading {
} */
.achievement__content__copy {
  max-width: 960px;
  margin-top: 48px;
}
.achievement__content__list {
  margin-top: 80px;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  align-items: stretch;
  background: linear-gradient(180deg, rgb(var(--color-white)) 1px, transparent 1px) repeat-y top -1px center/100% calc((100% / 2) + 1px), linear-gradient(-90deg, rgb(var(--color-white)) 1px, transparent 1px) repeat-x top left/calc((100% / 4) + 1px) 100%;
}
.achievement__content__list__item {
  box-sizing: border-box;
  padding: 40px calc(40 / 384 * 100%);
}
.achievement__content__list__item__photo {
  max-width: 80px;
  min-height: 80px;
  margin-inline: auto;
}
.achievement__content__list__item__photo img {
  height: 100%;
  object-fit: contain;
}
.achievement__content__list__item__heading {
  align-self: center;
  margin-top: 16px;
  margin-inline: -1em;
  font-size: clamp(18px, calc(28 / 1200 * 100vw), 28px);
  font-weight: 900;
  white-space: nowrap;
}
.achievement__content__list__item__heading small {
  display: block;
  font-size: calc(24 / 32 * 100%);
  margin-bottom: calc(12 / 24 * 1em);
}
.achievement__content__list__item__heading em {
  font-size: calc(64 / 32 * 100%);
  margin-inline: .05em;
}
.achievement__content__list__item__desc {
  flex: 1;
  margin-top: 32px;
}
.achievement__content__list__item__desc__copy {
  line-height: 1.5;
}
.achievement__content__list__item__desc__caution {
  margin-top: 8px;
  line-height: 1.416666667;
}
@media screen and (min-width: 768px) and (max-width: 1600px) {
  .achievement__content__list {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    background: linear-gradient(180deg, rgb(var(--color-white)) 1px, transparent 1px) repeat-y top -1px center/100% calc((100% / 3) + 1px), linear-gradient(-90deg, rgb(var(--color-white)) 1px, transparent 1px) repeat-x top left/calc((100% / 3) + 1px) 100%;
  }
}
@media screen and (max-width: 767px){
  .achievement {
    padding-block: calc(80 / 380 * 100%) 20px;
  }
  .achievement__content__copy {
    max-width: none;
    margin-top: 30px;
  }
  .achievement__content__list {
    margin-top: 20px;
    grid-template-columns: 100%;
    background: none;
  }
  .achievement__content__list__item {
    padding: 40px 0;
  }
  .achievement__content__list__item + .achievement__content__list__item {
    border-top: 1px solid rgb(var(--color-white));
  }
  .achievement__content__list__item__heading {
    font-size: 26px;
  }
  .achievement__content__list__item__heading small {
    font-size: calc(20 / 30 * 100%);
    margin-bottom: calc(8 / 20 * 1em);
  }
  .achievement__content__list__item__heading em {
    font-size: calc(60 / 30 * 100%);
  }
  .achievement__content__list__item__desc {
    margin-top: 30px;
  }
}



.workstyle {
  padding-block: 140px 94px;
  background: rgb(var(--color-white));
}
.workstyle__intro {
  max-width: 1472px;
  gap: 0 calc(48 / 1472 * 100%);
}
.workstyle__intro__photo {
  position: relative;
  z-index: 1;
  width: calc(688 / 1472 * 100%);
}
.workstyle__intro__photo::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: -140px;
  bottom: -140px;
  left: calc(59 / 688 * 100%);
  right: 0;
  margin-right: min(calc(var(--window-half-width) * -.125), calc(736px - var(--window-half-width)));
  background: url(../../img/recruit/bg_workstyle_intro.webp) no-repeat top left/cover;
}
.workstyle__intro__photo img {
  margin-top: -10px;
}
.workstyle__intro__desc {
  flex: 1;
}
/* .workstyle__intro__desc__heading {
} */
.workstyle__intro__desc__copy {
  margin-top: 48px;
}
.workstyle__content {
  max-width: 1472px;
  margin-top: 80px;
}
.workstyle__content__heading {
  font-size: clamp(28px, calc(48 / 1200 * 100vw), 48px);
}
.workstyle__content__heading small {
  display: block;
  font-size: calc(32 / 48 * 100%);
  margin-bottom: calc(8 / 32 * 1em);
}
.workstyle__content__heading em {
  font-size: calc(80 / 48 * 100%);
  font-weight: 400;
}
.workstyle__content__list {
  margin-top: 80px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  align-items: stretch;
  gap: 32px calc(64 / 1472 * 100%);
}
/* .workstyle__content__list__item {
} */
.workstyle__content__list__item__num {
  display: inline-block;
  padding-inline: .025em;
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  background: rgb(var(--color-black2));
}
.workstyle__content__list__item__heading {
  flex: 1;
  margin-top: 8px;
  line-height: 1.4;
}
.workstyle__content__list__item__photo {
  margin-top: 16px;
}
.workstyle__content__list__item__copy {
  margin-top: 16px;
  line-height: 1.6;
}
@media screen and (min-width: 768px) and (max-width: 1280px) {
  .workstyle__content__list__item__heading br {
    display: none;
  }
}
@media screen and (max-width: 767px){
  .workstyle {
    padding-block: 26px 54px;
  }
  .workstyle__intro {
    max-width: 560px;
    gap: 40px 0;
  }
  .workstyle__intro__photo {
    width: 100%;
  }
  .workstyle__intro__photo::before {
    top: -26px;
    bottom: -16px;
    left: calc(70 / 320 * 100%);
    margin-right: min(calc((15 / 190) * (var(--window-half-width) * 2) * -1), calc(280px - var(--window-half-width)));
  }
  .workstyle__intro__photo img {
    margin-top: -5px;
    width: calc(344 / 320 * 100%);
    max-width: none;
    margin-inline: calc(8 / 320 * -100%) calc(16 / 320 * -100%);
  }
  .workstyle__intro__desc {
    flex: 1 0 100%;
  }
  .workstyle__intro__desc__copy {
    margin-top: 30px;
  }
  .workstyle__content {
    max-width: 560px;
    margin-top: 55px;
  }
  .workstyle__content__heading {
    font-size: 30px;
  }
  .workstyle__content__heading small {
    font-size: calc(20 / 30 * 100%);
    margin-bottom: calc(8 / 20 * 1em);
  }
  .workstyle__content__heading em {
    font-size: calc(50 / 30 * 100%);
  }
  .workstyle__content__list {
    margin-top: 40px;
    grid-template-columns: 100%;
    gap: 40px 0;
  }
  .workstyle__content__list__item__num {
    font-size: 20px;
  }
  .workstyle__content__list__item__heading {
    font-size: 22px;
    margin-right: -1em;
  }
}



.detail {
  padding-block: 120px 112px;
}
.detail__intro {
  max-width: 1472px;
  gap: 0 calc(48 / 1472 * 100%);
}
.detail__intro__photo {
  width: calc(688 / 1472 * 100%);
}
.detail__intro__photo img {
  margin-top: -28px;
}
.detail__intro__desc {
  flex: 1;
  max-width: 640px;
}
/* .detail__intro__desc__heading {
} */
.detail__intro__desc__copy {
  margin-top: 48px;
}
.detail__content {
  max-width: 1280px;
  margin-top: 60px;
}
.detail__content + .detail__content {
  margin-top: 80px;
}
.detail__content__head {
  margin-bottom: 48px;
}
.detail__content__head__heading {
  box-sizing: border-box;
  border-left: 3px solid rgb(var(--color-red));
  padding-left: calc(20 / 32 * 1em);
  line-height: 1.4375;
}
.detail__content__head__copy {
  max-width: 640px;
  margin-top: 32px;
}
/* .detail__content__body {
} */
.detail__content__body__heading {
  font-size: clamp(16px, calc(24 / 1200 * 100vw), 24px);
  margin-bottom: 16px;
}
.detail__content__body__heading:nth-of-type(n+2) {
  margin-top: 80px;
}
/* .detail__content__body__list {
} */
.detail__content__body__list__item {
  position: relative;
  z-index: 1;
  margin-bottom: -1px;
  grid-template-columns: minmax(max-content, calc(192 / 1280 * 100%)) minmax(0, 1fr);
  align-items: stretch;
}
.detail__content__body__list__item__term {
  align-content: center;
  align-items: center;
  box-sizing: border-box;
  border-top: 1px solid #555;
  border-bottom: 1px solid #555;
  padding: 48px calc(16 / 192 * 100%);
}
.detail__content__body__list__item__term__copy {
  font-size: clamp(14px, calc(20 / 1200 * 100vw), 20px);
}
.detail__content__body__list__item__desc {
  box-sizing: border-box;
  border-top: 1px solid #c1c1c1;
  border-bottom: 1px solid #c1c1c1;
  padding: 48px 16px;
}
/* .detail__content__body__list__item__desc__copy {
} */
.detail__content__body__list__item__desc__copy em {
  font-size: calc(20 / 16 * 100%);
}
/* .detail__content__body__list__item__desc__list {
} */
.detail__content__body__list__item__desc__list__item {
  box-sizing: border-box;
  padding-left: calc(17 / 16 * 1em);
  background: url('data:image/svg+xml;utf8,<svg width="10" height="10" viewBox="0 0 10 10" fill="none" xmlns="http://www.w3.org/2000/svg"><circle cx="5" cy="5" r="5" fill="%23D9D9D9"/></svg>') no-repeat top calc(10 / 16 * 1em) left 0/calc(10 / 16 * 1em) auto;
}
.detail__content__body__list__item__desc__caution {
  margin-top: 10px;
  font-size: clamp(10px, calc(14 / 1200 * 100vw), 14px);
}
.detail__content__body__more {
  max-width: fit-content;
  margin-top: 40px;
}
@media screen and (max-width: 767px){
  .detail {
    padding-block: 65px 60px;
  }
  .detail__intro {
    max-width: 560px;
    gap: 15px 0;
  }
  .detail__intro__photo {
    width: 100%;
  }
  .detail__intro__photo img {
    margin-top: -8px;
    width: calc(344 / 320 * 100%);
    max-width: none;
    margin-inline: calc(8 / 320 * -100%) calc(16 / 320 * -100%);
  }
  .detail__intro__desc {
    flex: 1 0 100%;
    max-width: none;
  }
  .detail__intro__desc__copy {
    margin-top: 30px;
  }
  .detail__content {
    max-width: 560px;
  }
  .detail__content__head {
    margin-bottom: 40px;
  }
  .detail__content__head__heading {
    padding-left: calc(18 / 20 * 1em);
    line-height: 1.45;
  }
  .detail__content__head__copy {
    max-width: none;
    margin-top: 17px;
  }
  .detail__content__body__heading {
    font-size: 20px;
    margin-bottom: 20px;
  }
  .detail__content__body__heading:nth-of-type(n+2) {
    margin-top: 60px;
  }
  .detail__content__body__list__item {
    grid-template-columns: minmax(max-content, calc(90 / 320 * 100%)) minmax(0, 1fr);
  }
  .detail__content__body__list__item__term {
    padding: 20px 0;
  }
  .detail__content__body__list__item__term__copy {
    font-size: 16px;
  }
  .detail__content__body__list__item__desc {
    padding: 20px 16px;
  }
  .detail__content__body__list__item__desc__copy em {
    font-size: calc(18 / 16 * 100%);
    line-height: 1.4;
  }
  .detail__content__body__list__item__desc__list__item + .detail__content__body__list__item__desc__list__item {
    margin-top: 8px;
  }
  .detail__content__body__list__item__desc__caution {
    margin-top: 5px;
    font-size: 12px;
    line-height: 1.4;
  }
  .detail__content__body__more {
    max-width: none;
    margin-top: 30px;
  }
}



.jobsearch {
  margin-block: 80px calc(-250px + -80px);
}
.jobsearch__content {
  max-width: 1792px;
  grid-template-columns: minmax(0, 1fr) calc(997 / 1792 * 100%);
  align-items: stretch;
  box-shadow: 4px 4px 16px rgba(0, 0, 0, .25);
  overflow: hidden;
}
.jobsearch__content__desc {
  position: relative;
  z-index: 2;
  grid-template-columns: calc(671 / 795 * 100%);
  place-content: center;
  place-items: center;
}
.jobsearch__content__desc::before {
  content: "";
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: calc(864 / 795 * 100%);
  height: 100%;
  clip-path: polygon(0% 0%, calc(800 / 864 * 100%) 0%, 100% 100%, 0% 100%);
  background: url(../../img/common/bg_search.webp) no-repeat center/cover;
}
.jobsearch__content__desc img {
  transform: translateZ(0px);
  filter: drop-shadow(4px 4px 16px rgba(108, 23, 23, .2));
}
.jobsearch__content__photo {
  grid-column: 2;
  grid-row: 1;
  position: relative;
  z-index: 1;
}
.jobsearch__content__chevron {
  grid-column: 2;
  grid-row: 1;
  justify-self: end;
  align-self: end;
  position: relative;
  z-index: 2;
  place-items: center;
  width: clamp(70px, calc(120 / 1200 * 100vw), 120px);
  height: clamp(70px, calc(120 / 1200 * 100vw), 120px);
  background: #fff;
}
.jobsearch__content__chevron::before {
  content: "";
  display: block;
  width: calc(24 / 120 * 100%);
  height: calc(16 / 120 * 100%);
  background: rgb(var(--color-red));
  -webkit-mask: var(--svg-chevron) no-repeat center/100% auto;
  mask: var(--svg-chevron) no-repeat center/100% auto;
  rotate: -45deg;
}
@media (any-hover: hover) {
  .jobsearch__content__photo {
    transition: scale .3s;
  }
  .jobsearch__content:hover .jobsearch__content__photo {
    scale: 1.05;
  }
  .jobsearch__content:hover .jobsearch__content__chevron::before {
    animation: chevronExternalAnimation .5s;
  }
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .jobsearch {
    margin-block: 80px calc(-50px + -80px);
  }
}
@media screen and (max-width: 767px) {
  .jobsearch {
    margin-block: 40px calc(-116px + -40px);
  }
  .jobsearch__content {
    max-width: 560px;
    grid-template-columns: 100%;
    box-shadow: 4px 4px 8px rgba(0, 0, 0, .2);
  }
  .jobsearch__content__desc {
    grid-template-columns: calc(280 / 320 * 100%);
    grid-column: 1;
    grid-row: 1;
    padding-block: 32px 30px;
  }
  .jobsearch__content__desc::before {
    width: 100%;
    clip-path: none;
    background: url(../../img/common/bg_search-sp.webp) no-repeat center/cover;
  }
  .jobsearch__content__desc img {
    filter: none;
  }
  .jobsearch__content__chevron {
    grid-column: 1;
    width: 44px;
    height: 44px;
  }
  .jobsearch__content__chevron::before {
    width: calc(13 / 44 * 100%);
    height: calc(8 / 44 * 100%);
  }
}



.brandsite {
  padding-top: calc(250px + 76px);
}
@media screen and (min-width: 768px) and (max-width: 1400px) {
  .brandsite {
    padding-top: calc(50px + 76px);
  }
}
@media screen and (max-width: 767px) {
  .brandsite {
    padding-top: calc(116px + 50px);
  }
}