@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@400;500;700&display=swap");
/*
	$weight:フォントの太さ
*/
/*
	$weight:フォントの太さ
	@include f_serif(700);
*/
/*
	$weight:フォントの太さ
	@include f_din(600);
*/
/* MESSAGE */
.sec_message {
  position: relative;
  width: 100%;
  height: 65vh;
  min-height: 650px;
}
@media print, screen and (min-width: 992px) {
  .sec_message {
    margin-bottom: 12rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_message {
    margin-bottom: 6rem;
  }
}
.sec_message .bg_box {
  position: relative;
  width: 100%;
  height: 100%;
}
.sec_message .bg_box::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.15);
}
.sec_message .bg_box img {
  width: 100%;
  height: 100%;
}
.sec_message .inner {
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  margin: auto;
}
.sec_message .inner .content_wrap {
  width: 100%;
  height: 100%;
}
.sec_message .inner .content_wrap .content_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  row-gap: 2rem;
}
.sec_message .inner .content_wrap .content_block .text_box {
  color: #FFFFFF;
  max-width: 640px;
  margin: auto;
}
.sec_message .inner .content_wrap .content_block .text_box .text {
  font-family: "Noto Serif JP", sans-serif;
  font-weight: 400;
  font-style: normal;
  font-size: 1.4rem;
  margin-top: 2rem;
  line-height: 2.4;
  text-shadow: 0 0 5px rgba(0, 0, 0, 0.7);
  letter-spacing: 0.1em;
}
@media (min-width: 768px) {
  .sec_message .inner .content_wrap .content_block .text_box .text {
    font-size: 1.6rem;
  }
}
.sec_message .inner .content_wrap .content_block .text_box::before {
  display: block;
  content: "";
  width: 240px;
  height: 70px;
  background: url(/assets/img/careers/message-title.png);
  background-repeat: no-repeat;
  background-size: cover;
  margin: 0 auto 4rem;
}

/* JOB */
.sec_job {
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .sec_job {
    margin-bottom: 12rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_job {
    margin-bottom: 6rem;
  }
}
@media (min-width: 768px) {
  .sec_job .inner {
    padding: 0;
  }
}
.sec_job .content_block {
  display: -ms-grid;
  display: grid;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -ms-grid-columns: 1fr;
  grid-template-columns: 1fr;
  margin-top: 6rem;
}
@media (min-width: 768px) {
  .sec_job .content_block {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    margin-top: 10rem;
  }
}
.sec_job .content_block .text_box {
  max-width: 420px;
  margin: auto;
  padding: 2rem 0;
}
@media (min-width: 768px) {
  .sec_job .content_block .text_box {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
    padding: 3rem;
  }
}
.sec_job .content_block .text_box .title {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-style: normal;
  font-size: 2.4rem;
  color: #2D325F;
  border-bottom: 2px solid #2D325F;
  margin-bottom: 1rem;
  padding-bottom: 0.25em;
}
.sec_job .content_block .text_box .text {
  margin-top: 2rem;
}
.sec_job .content_block .text_box .qualification {
  font-size: 1.4rem;
}
.sec_job .content_block .text_box .qualification .term {
  width: 5em;
  background: #FF8800;
  color: #FFFFFF;
  text-align: center;
  padding: 0 0.1em;
}
.sec_job .content_block .text_box .qualification .box {
  font-family: "Noto Sans JP", sans-serif;
  font-weight: 700;
  font-style: normal;
  margin-top: 0.4rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
@media print, screen and (min-width: 992px) {
  .sec_job .content_block .text_box .qualification .box {
    font-size: 1.6rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_job .content_block .text_box .qualification .box {
    font-size: 1.4rem;
  }
}
.sec_job .content_block .text_box .qualification .box .definition + .definition::before {
  content: "・";
}
.sec_job .content_block .text_box .description {
  font-size: 1.4rem;
  margin-top: 2rem;
}
.sec_job .content_block .text_box .description .term {
  width: 7em;
  background: #FF8800;
  color: #FFFFFF;
  text-align: center;
  padding: 0 0.1em;
}
.sec_job .content_block .text_box .description .box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 0.4rem;
}
.sec_job .content_block .text_box .description .box .definition + .definition::before {
  content: "・";
}
@media (min-width: 768px) {
  .sec_job .content_block .image_box {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
}
@media (min-width: 768px) {
  .sec_job .content_block:nth-of-type(even) .text_box {
    -webkit-box-ordinal-group: 2;
        -ms-flex-order: 1;
            order: 1;
  }
  .sec_job .content_block:nth-of-type(even) .image_box {
    -webkit-box-ordinal-group: 3;
        -ms-flex-order: 2;
            order: 2;
  }
}

/* FLOW */
.sec_flow {
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .sec_flow {
    margin-bottom: 6rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_flow {
    margin-bottom: 3rem;
  }
}
.sec_flow .inner {
  max-width: 640px;
}
.sec_flow .content_block {
  margin-top: 6rem;
}
.sec_flow .content_block .title {
  width: 10em;
  color: #FFFFFF;
  background: #2D325F;
  text-align: center;
  margin: auto;
  padding: 0.25rem 0.5rem;
}
.sec_flow .content_block .image_box {
  margin-top: 2rem;
}
.sec_flow .content_block .image_box .figure {
  display: -ms-grid;
  display: grid;
  place-items: center;
}
.sec_flow .content_block .text_box {
  background: #F2F2F2;
  margin-top: 2rem;
  padding: 1rem 2rem;
}
.sec_flow .content_block .text_box .text {
  font-size: 1.4rem;
}

/* VISION */
.sec_vision {
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .sec_vision {
    margin-bottom: 12rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_vision {
    margin-bottom: 6rem;
  }
}
.sec_vision .bg_box {
  position: relative;
}
.sec_vision .bg_box::after {
  content: "";
  position: absolute;
  inset: 0;
  background-color: rgba(0, 0, 0, 0.15);
}
.sec_vision .bg_box img {
  aspect-ratio: 1/1;
  -o-object-position: 42.5%;
     object-position: 42.5%;
}
@media (min-width: 768px) {
  .sec_vision .bg_box img {
    aspect-ratio: auto;
  }
}
.sec_vision .inner {
  max-width: 1200px;
  position: absolute;
  width: 100%;
  height: 100%;
  inset: 0;
  margin: auto;
}
.sec_vision .inner .content_wrap {
  width: 100%;
  height: 100%;
}
.sec_vision .inner .content_wrap .content_block {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  width: 100%;
  height: 100%;
  row-gap: 2rem;
}
.sec_vision .inner .content_wrap .content_block .text_box {
  color: #FFFFFF;
  margin: 50px auto auto 0;
}
.sec_vision .inner .content_wrap .content_block .text_box .catch {
  font-family: "Noto Serif JP", sans-serif;
  font-weight: 700;
  font-style: normal;
  line-height: 1;
  color: #2D325F;
  -webkit-writing-mode: vertical-rl;
      -ms-writing-mode: tb-rl;
          writing-mode: vertical-rl;
  letter-spacing: 0.2em;
}
@media print, screen and (min-width: 992px) {
  .sec_vision .inner .content_wrap .content_block .text_box .catch {
    font-size: clamp(2.8rem, 1.6rem + 1.5vw, 4.2rem);
  }
}
@media screen and (max-width: 991px) {
  .sec_vision .inner .content_wrap .content_block .text_box .catch {
    font-size: 2.8rem;
  }
}
.sec_vision .inner .content_wrap .content_block .text_box .catch span {
  display: inline-block;
  background-color: rgba(255, 255, 255, 0.8666666667);
  margin: 0 0.4em;
  padding: 0.4em;
}
.sec_vision .inner .content_wrap .content_block .text_box .catch br + span {
  margin-top: 1em;
}

/* SUMMARY */
.sec_summary {
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .sec_summary {
    margin-bottom: 12rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_summary {
    margin-bottom: 6rem;
  }
}
.sec_summary .content_block {
  margin-top: 4rem;
}
.sec_summary .content_block .title {
  text-align: center;
  border: 2px solid #E6E6E6;
  margin: auto;
  padding: 0.5em 1em;
}
@media print, screen and (min-width: 992px) {
  .sec_summary .content_block .title {
    width: 370px;
    font-size: 2rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_summary .content_block .title {
    width: 280px;
    font-size: 1.8rem;
  }
}
.sec_summary .content_block .list {
  margin-top: 3rem;
}
.sec_summary .content_block .list .group {
  display: -ms-grid;
  display: grid;
}
@media print, screen and (min-width: 992px) {
  .sec_summary .content_block .list .group {
    -ms-grid-columns: 12em auto;
    grid-template-columns: 12em auto;
  }
}
@media screen and (max-width: 991px) {
  .sec_summary .content_block .list .group {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}
.sec_summary .content_block .list .group .term {
  font-weight: bold;
  border-bottom: 1px solid #E6E6E6;
  padding: 0.75em 0.75em 1em;
  font-size: 1.4rem;
}
@media print, screen and (min-width: 992px) {
  .sec_summary .content_block .list .group .term {
    text-align: center;
  }
}
@media screen and (max-width: 991px) {
  .sec_summary .content_block .list .group .term {
    -ms-grid-columns: 1fr;
    grid-template-columns: 1fr;
  }
}
.sec_summary .content_block .list .group .box {
  padding: 0.75em 0.75em 1em;
}
@media print, screen and (min-width: 992px) {
  .sec_summary .content_block .list .group .box {
    border-bottom: 1px solid #E6E6E6;
  }
}
.sec_summary .content_block .list .group .box .definition {
  font-weight: normal;
  font-size: 1.4rem;
}
.sec_summary .content_block .list .group .box .definition .hours {
  border-collapse: collapse;
  width: 100%;
  margin-top: 1rem;
}
.sec_summary .content_block .list .group .box .definition .hours th {
  border: 1px solid #E6E6E6;
  padding: 0.25em 0.5em;
}
.sec_summary .content_block .list .group .box .definition .hours td {
  border: 1px solid #E6E6E6;
  padding: 0.25em 0.5em;
}
.sec_summary .content_block .list .group .box .definition .hours span {
  display: inline-block;
}
.sec_summary .content_block .link_box {
  margin-top: 3rem;
}

/* BENEFITS */
.sec_benefits {
  background: #F2F2F2;
  position: relative;
}
@media print, screen and (min-width: 992px) {
  .sec_benefits {
    padding-top: 6rem;
    padding-bottom: 6rem;
  }
}
@media screen and (max-width: 991px) {
  .sec_benefits {
    padding-top: 3rem;
    padding-bottom: 3rem;
  }
}
.sec_benefits .content_block {
  position: relative;
  background-color: #FFFFFF;
  margin-top: 10rem;
  padding: 6rem 1rem;
}
.sec_benefits .content_block .title {
  position: relative;
  z-index: 10;
  font-size: 1.8rem;
  text-align: center;
  margin-bottom: 2rem;
}
.sec_benefits .content_block .text_box {
  position: relative;
  z-index: 10;
}
.sec_benefits .content_block .text_box .text {
  font-size: 1.4rem;
  text-align: center;
}
.sec_benefits .content_block::after {
  position: absolute;
  display: block;
  content: "";
  width: 240px;
  height: 240px;
  border-radius: 50%;
  top: -60px;
  left: 0;
  right: 0;
  margin: auto;
  background-color: #FFFFFF;
  z-index: 1;
}
.sec_benefits .content_block.holiday .title::before {
  position: absolute;
  display: block;
  content: "";
  background: url(/assets/img/careers/holiday-icon.svg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 68px;
  height: 68px;
  top: -73px;
  left: 0;
  right: 0;
  margin: auto;
}
.sec_benefits .content_block.holiday .text_box {
  max-width: 600px;
  margin: auto;
}
.sec_benefits .content_block.holiday .text_box dl.list .term {
  font-weight: bold;
  margin-top: 1.4rem;
}
.sec_benefits .content_block.holiday .text_box dl.list .box .definition {
  font-size: 1.4rem;
}
.sec_benefits .content_block.holiday .text_box dl.list .box.leave {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.sec_benefits .content_block.holiday .text_box dl.list .box.leave .definition + .definition::before {
  content: "・";
}
.sec_benefits .content_block.allowance .title::before {
  position: absolute;
  display: block;
  content: "";
  background: url(/assets/img/careers/allowance-icon.svg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 72px;
  height: 72px;
  top: -77px;
  left: 0;
  right: 0;
  margin: auto;
}
.sec_benefits .content_block.allowance .text_box {
  max-width: 420px;
  margin: auto;
}
.sec_benefits .content_block.allowance .text_box ul.list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}
.sec_benefits .content_block.allowance .text_box ul.list .item {
  font-size: 1.4rem;
}
.sec_benefits .content_block.allowance .text_box ul.list .item + .item::before {
  content: "・";
}
.sec_benefits .content_block.other .title::before {
  position: absolute;
  display: block;
  content: "";
  background: url(/assets/img/careers/other-icon.svg);
  background-repeat: no-repeat;
  background-size: cover;
  width: 64px;
  height: 64px;
  top: -69px;
  left: 0;
  right: 0;
  margin: auto;
}
.sec_benefits .content_block.other .text_box {
  max-width: 540px;
  margin: auto;
}
.sec_benefits .content_block.other .text_box ul.list .item {
  font-size: 1.4rem;
  text-align: center;
}
.sec_benefits .content_block.other .text_box dl.list {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: auto;
}
.sec_benefits .content_block.other .text_box dl.list .group {
  display: -ms-grid;
  display: grid;
  -ms-grid-columns: 5em auto;
  grid-template-columns: 5em auto;
}
.sec_benefits .content_block.other .text_box dl.list .group .box {
  text-align: left;
}
.sec_benefits .content_block.other .text_box .text {
  margin-top: 2rem;
}
.sec_benefits .content_block.other .text_box .text span {
  display: inline-block;
}