@charset "UTF-8";


/*--------------------------------------------
bg
--------------------------------------------*/
.p-bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/bg.jpg) no-repeat;
  background-size: cover;
  background-position: center;
  z-index: 0;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-bg {
    background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/bg_sp.jpg) no-repeat;
    background-size: cover;
    background-position: center;
  }
}

/* 黒背景（既存） */
.p-bg::after {
  content: "";
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, var(--bg-opacity, 0));
  transition: background 0.1s linear;
  position: absolute;
  top: 0;
  left: 0;
  z-index: +1;
}

/* 白背景（新規） */
.p-bg::before {
  content: "";
  width: 100%;
  height: 100%;
  background: linear-gradient(
    to bottom right,
    rgba(225, 231, 245, var(--white-opacity, 0)) 0%,
    rgba(255, 255, 255, var(--white-opacity, 0)) 80%,
    rgba(255, 255, 255, var(--white-opacity, 0)) 100%
  );
  transition: background 0.1s linear;
  position: absolute;
  top: 0;
  left: 0;
  z-index: +2;
}


/*--------------------------------------------
wrapper
--------------------------------------------*/
.p-wrapper {
  position: relative;
  width: 100%;
  z-index: 1;
}


/*--------------------------------------------
ttl
--------------------------------------------*/
.p-ttl {
  width: 100%;
  height: 100vh;
}

.p-ttl h2 {
  padding: 21vw 0 0 11.25vw;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-ttl h2 {
    text-align: center;
    padding: 21vh 0 0 0;
  }
}

.p-ttl__en {
  display: block;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 100;
  font-style: normal;
  letter-spacing: 0;
  font-size: 99px;
  color: #fff;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-ttl__en {
    font-size: 24.444vw;
  }
}

.p-ttl__jp {
  margin-top: 45px;
  display: block;
  font-size: 24px;
  font-weight: 300;
  color: #fff;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-ttl__jp {
    margin-top: 6.666vw;
    font-size: 5.555vw;
  }
}


/*--------------------------------------------
lead 
--------------------------------------------*/
.p-lead {
  width: 100%;
  font-family: "Noto Serif JP", serif;
  font-optical-sizing: auto;
  font-style: normal;
  font-weight: 300;
  font-size: 18px;
  line-height: 2em;
  color: #fff;
  padding: 6.25vw 11.25vw;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-lead {
    font-size: 5vw;
    padding: 10vw 9.444vw;
  }
}


/*--------------------------------------------
content_ttl
--------------------------------------------*/
.p-content_ttl {
  width: 100%;
  display: flex;
  flex-flow: column;
  justify-content: center;
  padding-bottom: 6vw;
  height: 59.531vw;
  margin-top: 3vw;
  position: relative;
  z-index: 0;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl {
    padding: 52vw 0 18.055vw 0;
    height: auto;
  }
}

/* -office */
.p-content_ttl.-office {
  margin-top: 8vw;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl.-office {
    margin-top: 17.777vw;
    padding: 50vw 0 18.055vw 0;
  }
}

.p-content_ttl__bg {
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl__bg {
    top: 17.777vw;
  }
}

.p-content_ttl__bg img {
  width: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl__bg img {
    width: 100%;
    object-fit: fill;
  }
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl.-office .p-content_ttl__bg {
    top: 0;
  }
}

.p-content_ttl h3 {
  width: 90%;
  margin: 0 auto;
  text-align: center;
}

.p-content_ttl__en {
  display: inline-block;
  font-family: "Barlow Condensed", sans-serif;
  font-weight: 100;
  font-style: normal;
  letter-spacing: 0;
  font-size: 110px;
  text-align: center;
  color: #fff;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl__en {
    font-size: 21.944vw;
  }
}

/* -office */
.p-content_ttl.-office .p-content_ttl__en {
  color: #000;
}

.p-content_ttl__jp {
  display: inline-block;
  width: 100%;
  font-size: 32px;
  font-weight: 300;
  margin-top: 25px;
  text-align: center;
  color: #fff;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl__jp {
    font-size: 6.111vw;
    margin-top: 8vw;
  }
}

/* -office */
.p-content_ttl.-office .p-content_ttl__jp {
  color: #000;
}

.p-content_ttl p {
  max-width: 576px;
  width: 90%;
  margin: 70px auto 0 auto;
  font-size: 16px;
  line-height: 2em;
  font-weight: 300;
  color: #fff;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_ttl p {
    max-width: none;
    width: 88.888vw;
    margin: 14vw auto 0 auto;
    font-size: 4.444vw;
  }
}

/* -office */
.p-content_ttl.-office p {
  color: #000;
}


/*--------------------------------------------
content
--------------------------------------------*/
/* blc */
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_bg__blc {
    width: 100%;
    padding: 0 5.555vw 11.111vw 5.555vw;
  }
}

/* wh */
.p-content_bg__wh {
  padding-bottom: 4.218vw;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_bg__wh {
    width: 100%;
    padding: 0 5.555vw 11.111vw 5.555vw;
  }
}

/* content_four */
.p-content_four {
  display: flex;
  gap: 0 0.8vw;
  padding-top: 0.8vw;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_four {
    flex-flow: column;
    gap: 2.777vw;
    padding-top: 2.777vw;
  }
}

.p-content_four.-top {
  padding-top: 3.125vw;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_four.-top {
    padding-top: 0;
  }
}

.p-content_four_large {
  width: 55.468%;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_four_large {
    width: 100%;
  }
}

/* wh */
.p-content_bg__wh .p-content_four_large {
  width: 50.937%;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_bg__wh .p-content_four_large {
    width: 100%;
  }
}

.p-content_four_small {
  width: 43.75%;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  gap: 0.8vw 0;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_four_small {
    width: 100%;
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    gap: 2.777vw 0;
  }
}

/* wh */
.p-content_bg__wh .p-content_four_small {
  width: 48.281%;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_bg__wh .p-content_four_small {
    width: 100%;
  }
}

.p-content_four_small.-type_01 > div:nth-child(1) {
  width: 100%;
}

.p-content_four_small.-type_01 > div:nth-child(2),
.p-content_four_small.-type_01 > div:nth-child(3) {
  width: 49.107%;
}

/********* sp *********/
@media only screen and (max-width:750px) {

  .p-content_four_small.-type_01 > div:nth-child(2),
  .p-content_four_small.-type_01 > div:nth-child(3) {
    width: 48.437%;
  }
}

.p-content_four_small.-type_02 > div:nth-child(1),
.p-content_four_small.-type_02 > div:nth-child(2) {
  width: 49.107%;
}

/********* sp *********/
@media only screen and (max-width:750px) {

  .p-content_four_small.-type_02 > div:nth-child(1),
  .p-content_four_small.-type_02 > div:nth-child(2) {
    width: 48.437%;
  }
}

.p-content_four_small.-type_02 > div:nth-child(3) {
  width: 100%;
}

/* content_one*/
.p-content_one {
  padding-top: 0.8vw;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_one {
    padding-top: 2.777vw;
  }
}

/* content_three */
.p-content_three {
  display: flex;
  gap: 0 0.8vw;
  padding-top: 0.8vw;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three {
    flex-flow: column;
    gap: 2.777vw;
    padding-top: 2.777vw;
  }
}

.p-content_three.-top {
  padding-top: 3.125vw;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three.-top {
    padding-top: 0;
  }
}

.p-content_three_large {
  width: 55.468%;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three_large {
    width: 100%;
  }
}

.p-content_three_small {
  width: 43.75%;
  display: flex;
  flex-flow: column;
  gap: 0.8vw 0;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three_small {
    width: 100%;
    flex-flow: row-reverse;
    gap: 0 2.777vw;
  }
}

/* three type_02 */


.p-content_three.-type_02 .p-content_three_large {
  width: 50.937%;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three.-type_02 .p-content_three_large {
    width: 100%;
  }
}

.p-content_three.-type_02 .p-content_three_small {
  width: 48.281%;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_three.-type_02 .p-content_three_small {
    width: 100%;
  }
}












/* content_two*/
.p-content_two {
  padding-top: 0.8vw;
  display: flex;
  justify-content: space-between;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_two {
    padding-top: 2.777vw;
  }
}

.p-content_two .p-content__btn {
  width: 49.609%;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content_two .p-content__btn {
    width: 48.437%;
  }
}

/* 共通 btn */
.p-content__btn {
  overflow: hidden;
  position: relative;
  cursor: pointer;
}

.p-content__btn img {
  display: block;
  transition: transform 0.2s ease;
}

.p-content__btn__txt {
  width: 14.062vw;
  height: 14.062vw;
  position: fixed;
  background: linear-gradient(120deg, rgba(26, 64, 113, 0.9), rgba(70, 95, 133, 0.9));
  display: block;
  opacity: 0;
  border-radius: 50%;
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  /* Safari対応 */
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.2);
  z-index: +1;
  pointer-events: none;
  transition: opacity 0.3s ease;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content__btn__txt {
    display: none;
  }
}

.p-content__btn__txt span {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.093vw;
  font-weight: 400;
  color: #fff;
}

.p-content__btn__txt_sp {
  display: none;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content__btn__txt_sp {
    display: block;
    position: absolute;
    left: 2.777vw;
    bottom: 2.777vw;
  }

  .p-content__btn__txt_sp span {
    font-size: 3.888vw;
    line-height: 1.4em;
    font-weight: 400;
    color: #fff;
    padding-right: 0.8em;
    position: relative;
  }

  .p-content__btn__txt_sp span::after {
    content: "";
    width: 1.305vw;
    height: 2.777vw;
    background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/arrow_wh.svg) no-repeat;
    background-size: contain;
    position: absolute;
    bottom: 0.2em;
    right: 0;
  }
}

/* hover */
.p-content__btn:hover img {
  transform: scale(1.1);
}


/*--------------------------------------------
concept
--------------------------------------------*/
.p-concept {
  padding: 7.5vw 0 12.5vw 0;
  background: #000;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-concept {
    padding: 46.666vw 0 37.222vw 0;
  }
}

.p-concept h3 {
  background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/ic_outside_s.svg) no-repeat;
  background-size: 16px;
  background-position: right top 0.35em;
  font-size: 24px;
  font-weight: 300;
  color: #fff;
  width: fit-content;
  margin: 0 auto;
  text-align: center;
  padding-right: 1em;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-concept h3 {
    background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/ic_outside_s.svg) no-repeat;
    background-size: 4.261vw;
    background-position: right top 0.35em;
    font-size: 6.666vw;
  }
}

.p-concept a {
  display: block;
  width: 90%;
  max-width: 677px;
  margin: 25px auto 0 auto;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-concept a {
    width: 86.111vw;
    max-width: none;
    margin: 6.5vw auto 0 auto;
  }
}


/*--------------------------------------------
modal
--------------------------------------------*/
.p-modal {
  width: 100%;
  height: 100%;
  background: #000;
  padding: 1.25vw;
  display: none;
  align-items: center;
  position: fixed;
  justify-content: space-between;
  top: 0;
  left: 0;
  z-index: 1000;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal {
    flex-flow: column-reverse;
  }
}

/* close */
.p-modal__close {
  width: 24px;
  height: 24px;
  background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/close_wh.svg) no-repeat;
  background-size: cover;
  position: absolute;
  top: 19px;
  right: 24px;
  z-index: +2;
  cursor: pointer;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__close {
    width: 6.65vw;
    height: 6.65vw;
    top: 4.452vw;
    right: 4.452vw;
  }
}

/* nav */
.p-modal__nav {
  width: 18%;
  height: 100%;
  display: flex;
  align-items: center;
  overflow-y: auto;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__nav {
    display: block;
    width: 88.888vw;
    height: auto;
    overflow: inherit;
    border-top: solid 1px #333;
    padding: 2vh 0 5vh 0;
  }
}

.p-nav {
  display: none;
  flex-flow: column;
  gap: 11px 0;
  margin-left: 38px;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-nav {
    width: 100%;
    flex-flow: row;
    flex-wrap: wrap;
    justify-content: start;
    gap: 2vw 4%;
    margin-left: 0;
  }
}

.p-nav li span {
  display: inline-block;
  font-size: 13px;
  line-height: 1.3em;
  color: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  position: relative;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-nav li span {
    font-size: 3.111vw;
    padding-left: 3vw;
  }
}

.p-nav li span:hover,
.p-nav li span.-current {
  color: rgba(255, 255, 255, 1);
}

.p-nav li span:hover::before,
.p-nav li span.-current::before {
  content: "";
  width: 10px;
  height: 10px;
  background: #fff;
  position: absolute;
  left: -22px;
  top: 0.35em;
  border-radius: 50%;
}

/********* sp *********/
@media only screen and (max-width:750px) {

  .p-nav li span:hover::before,
  .p-nav li span.-current::before {
    width: 2vw;
    height: 2vw;
    left: 0;
    top: 0.35em;
  }
}

/* content */
.p-modal__content {
  width: 80%;
  height: 100%;
  display: flex;
  align-items: center;
  display: none;
}

/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content {
    width: 88.888vw;
  }
}

.p-modal__content__inner__ph {
  width: 100%;
  max-height: 78.125vh;
  overflow: auto;
  position: relative;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content__inner__ph {
    max-height: none;
  }
}

.p-modal__ph {
  display: none;
}

/* thumbnail */
.p-content__thumbnail {
  width: fit-content;
  display: flex;
  gap: 0 12px;
  position: sticky;
  bottom: 10px;
  z-index: +1;
  margin: -49px 9px 0 auto;
}
/********* sp *********/
@media only screen and (max-width:750px) {
.p-content__thumbnail {
    gap: 0 2.5%;
    position: static;
    justify-content: center;
    margin: 2vw auto 0 auto;
  }
}

.p-content__thumbnail li {
  width: 74px;
  cursor: pointer;
  overflow: hidden;
  position: relative;
  background: #000;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-content__thumbnail li {
    width: 18%;
  }
}

.p-content__thumbnail li img {
  display: block;
  position: relative;
  z-index: 0;
}

.p-content__thumbnail li.-current img {
  opacity: 0.4;
}

.p-modal__txt {
  display: none;
  margin-top: 20px;
  gap: 0 32px;
  justify-content: space-between;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__txt {
    flex-flow: column;
    margin-top: 10vw;
    gap: 5vw 0;
    justify-content: space-between;
    align-items: center;
  }
}

.p-modal__txt dl {
  width: 100%;
}

.p-modal__txt dl dt {
  width: 100%;
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6em;
  color: #fff;
  padding-bottom: 0.5em;
  border-bottom: solid 1px #333;
}
/********* sp *********/
@media only screen and (max-width:750px) {
.p-modal__txt dl dt {
    font-size: 3.111vw;
  }
}

.p-modal__txt dl dd {
  font-size: 14px;
  font-weight: 400;
  line-height: 1.6em;
  color: #fff;
  padding-top: 0.5em;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__txt dl dd {
    font-size: 3.111vw;
  }
}

/* nav */
.p-modal__content__nav {
  width: 128px;
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content__nav {
    width: 30vw;
    gap: 0;
    justify-content: space-between;
  }
}

.p-modal__content__nav li {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  border: solid 1px #333;
  cursor: pointer;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content__nav li {
    width: 13vw;
    height: 13vw;
  }
}

.p-modal__content__nav li:first-child {
  background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/content_nav_back.svg) no-repeat;
  background-position: top 20px center;
  background-size: 20px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content__nav li:first-child {
    background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/content_nav_back.svg) no-repeat;
    background-position: top 4.8vw center;
    background-size: 5vw;
  }
}

.p-modal__content__nav li:last-child {
  background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/content_nav_next.svg) no-repeat;
  background-position: top 20px center;
  background-size: 20px;
}
/********* sp *********/
@media only screen and (max-width:750px) {
  .p-modal__content__nav li:last-child {
    background: url(/recruitment/wp/wp-content/themes/onozo_recruit/assets/images/photo/content_nav_next.svg) no-repeat;
    background-position: top 4.8vw center;
    background-size: 5vw;
  }
}