body {
  background-color: #fff;
  background-color: #ffffff;
}

h3 {
  font-weight: bold;
  letter-spacing: 0.073em;
}

.p-mv {
  position: relative;
  width: 100%;
  height: 100vh;
  background: url(../img/mv.jpg) no-repeat center;
  background-size: cover;
}
.p-mv h1 {
  font-size: 9.3333333333vw;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.178em;
}
.p-mv span {
  color: #fff;
}

.p-mv__inner {
  position: absolute;
  top: 50%;
  left: 9.3333333333vw;
  width: 84vw;
}

.p-mv__btn {
  position: absolute;
  width: 32vw;
  margin-top: 6.6666666667vw;
  text-align: center;
  background: #dc0307;
}
.p-mv__btn a {
  position: relative;
  display: block;
  padding: 2.6666666667vw 0;
  font-size: 2.9333333333vw;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.178em;
}
.p-mv__btn a::after {
  position: absolute;
  top: 50%;
  width: 1.7333333333vw;
  height: 2.2666666667vw;
  margin-left: 4.6666666667vw;
  content: '';
  background: url(../img/icon_next.svg) no-repeat center;
  background-size: 100%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.p-item {
  margin-top: 15.6vw;
}
.p-item .p-item__inner {
  width: 100%;
}

.p-job {
  position: relative;
  margin-top: 15.7333333333vw;
}

.p-job::after {
  position: absolute;
  right: 0;
  bottom: 40vw;
  width: 90%;
  height: 34.2666666667vw;
  content: '';
  background: url(../img/bg_img01.png) no-repeat center;
}

.p-enviro::after {
  position: absolute;
  right: 0;
  bottom: -13.3333333333vw;
  z-index: -1;
  width: 100%;
  height: 34.2666666667vw;
  content: '';
  background: url(../img/bg_img02.png) no-repeat center;
}

.p-section__head {
  position: relative;
  z-index: 2;
  padding: 2.6666666667vw 0 9.3333333333vw 0;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 62%, 0 97%);
  clip-path: polygon(0 0, 100% 0, 100% 62%, 0 97%);
  text-align: center;
  background-color: #ad0306;
}
.p-section__head h2 {
  font-size: 7.2vw;
  color: #fff;
}
.p-section__head span {
  display: block;
  margin-top: -1.3333333333vw;
  font-size: 2.4vw;
  font-weight: bold;
  color: #fff;
}

.p-section__bg {
  position: relative;
}

.p-section__bg::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  width: 100%;
  padding: 1.3333333333vw 0 8vw 0;
  margin-top: 12.9333333333vw;
  -webkit-clip-path: polygon(0 0, 100% 0, 100% 99%, 0 15%);
  clip-path: polygon(0 0, 100% 0, 100% 99%, 0 15%);
  content: '';
  background-color: #5c0002;
}

.p-job__boxs {
  margin-top: 6.4vw;
}

.p-job__box span {
  font-size: 2.4vw;
  font-weight: bold;
  color: #ad0306;
}
.p-job__box h3 {
  margin-top: 0.8vw;
  font-size: 3.7333333333vw;
  font-weight: bold;
}
.p-job__box p {
  margin-top: 1.0666666667vw;
  font-size: 2.6666666667vw;
  line-height: 5.3333333333vw;
  letter-spacing: 0.073em;
}

.p-job__box:nth-of-type(2) {
  margin-top: 6vw;
}

.p-enviro {
  position: relative;
  margin-top: 22.6666666667vw;
}

.p-enviro__boxs {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  margin-top: 6.6666666667vw;
}

.p-enviro__wh {
  width: 100%;
}

.p-enviro__box {
  width: 98%;
  padding: 6.2666666667vw 6%;
  background: #ad0306;
}
.p-enviro__box h3 {
  padding-bottom: 2vw;
  font-size: 3.2vw;
  font-weight: bold;
  color: #fff;
  text-align: center;
  border-bottom: 1px solid #fff;
}
.p-enviro__box p {
  margin-top: 4vw;
  font-size: 2.6666666667vw;
  line-height: 5.3333333333vw;
  color: #fff;
  letter-spacing: 0.073em;
}

.p-enviro__box:last-of-type {
  margin-top: 4vw;
}

.p-recruit {
  position: relative;
  padding-bottom: 13.3333333333vw;
  margin-top: 22.6666666667vw;
  background: #efefef;
}

.p-recruit::after {
  position: absolute;
  right: 0;
  bottom: 1.3333333333vw;
  z-index: 1;
  width: 90%;
  height: 34.2666666667vw;
  content: '';
  background: url(../img/bg_img03.png) no-repeat center;
}

.p-recruit__head {
  padding-top: 8.6666666667vw;
  text-align: center;
}
.p-recruit__head h2 {
  font-size: 7.2vw;
  color: #000;
}
.p-recruit__head span {
  display: block;
  margin-top: -1.3333333333vw;
  font-size: 2.4vw;
  font-weight: bold;
  color: #000;
}

.p-recruit__boxs {
  position: relative;
  z-index: 2;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-flow: column;
  flex-flow: column;
  justify-content: space-between;
  margin-top: 6.6666666667vw;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
}
.p-recruit__boxs a {
  width: 100%;
  text-decoration: none;
}

.p-recruit__box {
  width: 100%;
}

.p-recruit__box:last-of-type {
  margin-top: 4vw;
}

.p-recruit__img {
  width: 100%;
  min-height: 40vw;
}

.p-recruit__img01 {
  background: url(../img/r_img01.jpg) no-repeat center;
  background-size: cover;
}

.p-recruit__img02 {
  background: url(../img/r_img02.jpg) no-repeat center;
  background-size: cover;
}

.p-recruit__txtArea {
  padding: 6%;
  font-size: 2.6666666667vw;
  background: #fff;
}
.p-recruit__txtArea h3 {
  font-size: 3.2vw;
  font-weight: bold;
  text-align: center;
}

.p-recruit__txt {
  margin-top: 1.0666666667vw;
  line-height: 5.3333333333vw;
}

.p-recruit__link {
  margin-top: 2.6666666667vw;
  text-align: right;
}

.p-txtBox {
  padding-bottom: 2vw;
  margin-top: 26.6666666667vw;
}

.p-txtBox__inner p {
  font-size: 6.6666666667vw;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.075em;
}

.p-head__inner .c-font span {
  font-family: futura-pt, sans-serif;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.075em;
}

.c-font {
  font-family: futura-pt, sans-serif;
  font-style: normal;
  font-weight: 700;
  letter-spacing: 0.075em;
}

.c-btn {
  position: relative;
  width: 80%;
  text-align: center;
  background: #ad0306;
}
.c-btn a {
  position: relative;
  display: block;
  padding: 5.3333333333vw 0;
  font-size: 3.2vw;
  font-weight: bold;
  color: #fff;
  text-decoration: none;
  letter-spacing: 0.178em;
}
.c-btn a::after {
  position: absolute;
  top: 50%;
  width: 2.4vw;
  height: 2.8vw;
  margin-left: 24vw;
  content: '';
  background: url(../img/icon_next.svg) no-repeat center;
  background-size: 100%;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}

.c-btn01 {
  margin: 22.6666666667vw auto 0;
}

.c-btn02 {
  margin: 10vw auto 0;
}

.c-btn::after {
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  width: 100%;
  height: 15.6vw;
  margin-top: 2vw;
  margin-left: 2vw;
  text-align: center;
  content: '';
  background: #5c0002;
}

a {
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

.p-head {
  position: relative;
  width: 100%;
  height: 40vw;
}

.p-head--01 {
  background: url(../img/recurlt_mv01.jpg) no-repeat center;
  background-size: cover;
}

.p-head--02 {
  background: url(../img/recurlt_mv02.jpg) no-repeat center;
  background-size: cover;
}

.p-head--03 {
  background: url(../img/contact_mv01.jpg) no-repeat center;
  background-size: cover;
}

.p-head__inner {
  position: absolute;
  top: 50%;
  left: 50%;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
.p-head__inner h1 {
  font-size: 8vw;
}
.p-head__inner span {
  color: #fff;
}
.p-head__inner .p-head__sub {
  display: block;
  font-size: 2.9333333333vw;
  font-weight: bold;
  color: #fff;
  text-align: center;
}

.p-recruit__ttl {
  margin-top: 17.3333333333vw;
  font-size: 4.5333333333vw;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.075em;
}

.p-recruit__ttl--bottom {
  margin-top: 2.6666666667vw;
  font-size: 4.5333333333vw;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0.075em;
}

.p-recruit__txt {
  margin-top: 5.3333333333vw;
  font-size: 2.6666666667vw;
  line-height: 5.3333333333vw;
  text-align: center;
}

.p-detail {
  position: relative;
}

.p-detail__inner {
  padding: 13.3333333333vw 0;
  margin-top: 24vw;
  background: #efefef;
}

.p-detail__head {
  position: absolute;
  top: 0;
  left: 50%;
  display: inline-block;
  font-size: 3.3333333333vw;
  font-weight: bold;
  color: #fff;
  letter-spacing: 0.075em;
  background: #414853;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}

.p-detail__head--01 {
  padding: 4vw 2.6666666667vw;
  margin-top: -6.6666666667vw;
  margin-left: -45.3333333333vw;
}

.p-detail__head--02 {
  padding: 4vw 4vw;
  margin-top: -9.3333333333vw;
  margin-left: -45.3333333333vw;
  text-align: right;
}

.p-detail__head::before {
  position: absolute;
  top: 0;
  right: 0;
  display: inline-block;
  width: 100vw;
  height: 100%;
  margin-right: 61.3333333333vw;
  content: '';
  background: #414853;
}

.p-detail__head--02::before {
  margin-right: 53.3333333333vw;
  content: '';
}

.p-detail__box {
  padding: 6.6666666667vw 12vw;
  font-size: 2.6666666667vw;
  background: #fff;
}
.p-detail__box tr {
  display: block;
  margin-bottom: 4.6666666667vw;
}
.p-detail__box th {
  display: block;
  width: 100%;
  padding: 2.6666666667vw 0 0;
  font-size: 2.9333333333vw;
  font-weight: bold;
  text-align: left;
}
.p-detail__box td {
  display: table-row;
  padding: 2.6666666667vw 0;
}

.c-ttl {
  color: #ad0306;
}

.c-min li {
  padding-left: 1em;
  margin-top: 0.4vw;
  font-size: 2.4vw;
  text-indent: -1em;
}

.c-ttl-head {
  margin-top: 2.6666666667vw;
}

.c-mt {
  margin-top: 2vw;
}

.c-mt3 {
  margin-top: 0.4vw;
}

.c-topBox {
  padding: 6.6666666667vw 0;
  margin-top: 26.6666666667vw;
  background: #efefef;
}
.c-topBox .c-topBox__btn a {
  display: block;
  width: 50%;
  padding: 2.6666666667vw 0;
  margin: 0 auto;
  font-size: 2.6666666667vw;
  color: #fff;
  text-align: center;
  text-decoration: none;
  background: #5c0002;
}

.p-contact {
  max-width: 715px;
  padding-bottom: 18.6666666667vw;
  margin: 0 auto;
}

.p-contact__inner {
  padding: 0 5%;
}

.p-contact__form {
  margin-top: 13.3333333333vw;
}

.p-contact__txtArea {
  margin-top: 18.6666666667vw;
  text-align: center;
}
.p-contact__txtArea p {
  margin-top: 2.6666666667vw;
  font-size: 3.2vw;
}

.p-contact-box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-flow: column;
  flex-flow: column;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: start;
  margin-top: 6.6666666667vw;
}
.p-contact-box label {
  font-size: 2.6666666667vw;
}
.p-contact-box input {
  width: 100%;
  padding: 4vw 4vw;
  margin-top: 2vw;
  font-size: 2.6666666667vw;
  background: #f0f0f0;
  border: none;
}
.p-contact-box textarea {
  width: 100%;
  height: 40vw;
  padding: 2.6666666667vw 4vw;
  margin-top: 2vw;
  font-size: 2.6666666667vw;
  background: #f0f0f0;
  border: none;
}
.p-contact-box ::-webkit-input-placeholder {
  color: #d5d5d5;
}
.p-contact-box ::-moz-placeholder {
  color: #d5d5d5;
}
.p-contact-box ::-ms-input-placeholder {
  color: #d5d5d5;
}
.p-contact-box ::placeholder {
  color: #d5d5d5;
}

.p-contact__btn {
  text-align: center;
}

.p-contact__btn input {
  width: 50%;
  padding: 2.6666666667vw 0;
  margin: 0 auto;
  margin-top: 18.6666666667vw;
  font-size: 2.6666666667vw;
  color: #fff;
  background: #ad0306;
  border: none;
}

.p-contact__txtArea .p-contact__ttl {
  font-size: 4.2666666667vw;
}
.p-contact__txtArea .p-contact__sub {
  font-size: 3.6vw;
}
.p-contact__txtArea .p-contact__txt {
  font-size: 2.6666666667vw;
}

.p-contact-thanks .c-topBox {
  margin-top: 0;
}

.p-contact-thanks .p-contact__txtArea {
  margin-top: 40vw;
}
.p-contact-thanks .p-contact {
  margin-bottom: 40vw;
}

.p-top .p-txtBox {
  margin-bottom: 26.6666666667vw;
}

#error li {
  font-size: 2.6666666667vw;
}

.p-contact-content .c-topBox {
  margin-top: 0;
}

input[type='submit'] {
  -webkit-box-sizing: content-box;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  border: none;
  border-radius: 0;
  -webkit-appearance: button;
  -moz-appearance: button;
  appearance: button;
}
input[type='submit']::-webkit-search-decoration {
  display: none;
}
input[type='submit']::focus {
  outline-offset: -2px;
}
@media (prefers-color-scheme: light) {
  :root {
    --color-base: #ffffff;
    --color-bg: #3b3f43;
    --color-main: #032f40;
    --color-sub: #011c26;
    --color-point: #5c7073;
  }
}
@media (prefers-color-scheme: dark) {
  :root {
    --color-base: #000;
    --color-bg: #3b3f43;
    --color-main: #287496;
    --color-sub: #37a1d0;
    --color-point: #d0b737;
  }
}
@media only screen and (min-width: 768px) {
  .p-mv h1 {
    font-size: 70px;
  }
  .p-mv__inner {
    left: 100px;
    width: 621px;
  }
  .p-mv__btn a {
    padding: 20px 0;
    font-size: 18px;
  }
  .p-mv__btn a::after {
    width: 8px;
    height: 11px;
    margin-left: 55px;
  }
  .p-mv__btn {
    width: 240px;
    margin-top: 50px;
  }
  .p-item {
    margin-top: 117px;
  }
  .p-job {
    margin-top: 118px;
  }
  .p-job::after {
    bottom: 42px;
    width: 100%;
    height: 257px;
  }
  .p-enviro::after {
    bottom: -136px;
    width: 100%;
    height: 257px;
  }
  .p-section__head h2 {
    font-size: 50px;
  }
  .p-section__head span {
    margin-top: -8px;
    font-size: 14px;
  }
  .p-section__head {
    padding: 10px 0 60px 0;
  }
  .p-section__bg::after {
    padding: 10px 0 60px 0;
    margin-top: 97px;
    margin-top: 97px;
  }
  .p-job__boxs {
    margin-top: 48px;
  }
  .p-job__box span {
    font-size: 14px;
  }
  .p-job__box h3 {
    margin-top: 6px;
    font-size: 20px;
  }
  .p-job__box p {
    margin-top: 8px;
    font-size: 16px;
    line-height: 30px;
  }
  .p-job__box:nth-of-type(2) {
    margin-top: 45px;
  }
  .p-enviro {
    margin-top: 170px;
  }
  .p-enviro__boxs {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row;
    flex-flow: row;
    margin-top: 50px;
  }
  .p-enviro__wh {
    width: 440px;
  }
  .p-enviro__box h3 {
    padding-bottom: 15px;
    font-size: 20px;
  }
  .p-enviro__box p {
    margin-top: 30px;
    font-size: 16px;
    line-height: 30px;
  }
  .p-enviro__box {
    padding: 47px 6%;
  }
  .p-enviro__box:last-of-type {
    margin-top: 0;
  }
  .p-recruit {
    padding-bottom: 100px;
    margin-top: 170px;
  }
  .p-recruit::after {
    bottom: -59px;
    width: 100%;
    height: 257px;
  }
  .p-recruit__head h2 {
    font-size: 50px;
  }
  .p-recruit__head span {
    margin-top: -8px;
    font-size: 14px;
  }
  .p-recruit__head {
    padding-top: 65px;
  }
  .p-recruit__boxs a {
    width: 440px;
  }
  .p-recruit__boxs {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-flow: row;
    flex-flow: row;
  }
  .p-recruit__boxs {
    margin-top: 90px;
  }
  .p-recruit__box {
    width: 98%;
  }
  .p-recruit__box:last-of-type {
    margin-top: 0;
  }
  .p-recruit__img {
    min-height: 240px;
  }
  .p-recruit__txtArea h3 {
    font-size: 18px;
  }
  .p-recruit__txtArea {
    font-size: 16px;
  }
  .p-recruit__txt {
    margin-top: 8px;
    line-height: 30px;
  }
  .p-recruit__link {
    margin-top: 3px;
  }
  .p-txtBox {
    padding-bottom: 15px;
    margin-top: 200px;
  }
  .p-txtBox__inner p {
    font-size: 60px;
  }
  .c-btn a {
    padding: 30px 0;
    font-size: 20px;
  }
  .c-btn a::after {
    width: 8px;
    height: 11px;
    margin-left: 110px;
  }
  .c-btn {
    width: 397px;
  }
  .c-btn01 {
    margin: 170px auto 0;
  }
  .c-btn02 {
    margin: 75px auto 0;
  }
  .c-btn::after {
    width: 397px;
    height: 90px;
    margin-top: 10px;
    margin-left: 10px;
  }
  a:hover {
    opacity: 0.7;
  }
  .l-header__logo a:hover {
    opacity: 1;
  }
  .p-head {
    height: 390px;
  }
  .p-head__inner h1 {
    font-size: 70px;
  }
  .p-head__inner .p-head__sub {
    font-size: 20px;
  }
  .p-recruit__ttl {
    margin-top: 180px;
    font-size: 30px;
  }
  .p-recruit__ttl--bottom {
    margin-top: 10px;
    font-size: 30px;
  }
  .p-recruit__txt {
    margin-top: 30px;
    font-size: 16px;
    line-height: 40px;
  }
  .p-detail__inner {
    padding: 150px 0;
    margin-top: 180px;
  }
  .p-detail__head {
    font-size: 25px;
  }
  .p-detail__head--01 {
    padding: 30px 30px;
    margin-top: -48px;
    margin-left: -46.4285714286vw;
  }
  .p-detail__head--02 {
    padding: 30px 30px;
    margin-top: -71px;
    margin-left: -47.1428571429vw;
  }
  .p-detail__head::before {
    margin-right: 463px;
  }
  .p-detail__head--02::before {
    margin-right: 377px;
  }
  .p-detail__box {
    padding: 50px 90px;
    font-size: 14px;
  }
  .p-detail__box tr {
    display: inherit;
    margin-bottom: 0;
  }
  .p-detail__box th {
    display: table-cell;
    width: 30%;
    padding: 20px 0;
    font-size: 14px;
    border-bottom: 1px solid rgb(229, 229, 229);
  }
  .p-detail__box td {
    display: block;
    padding: 20px 0;
    border-bottom: 1px solid rgb(229, 229, 229);
  }
  .c-min li {
    margin-top: 3px;
    font-size: 12px;
  }
  .c-ttl-head {
    margin-top: 20px;
  }
  .c-mt {
    margin-top: 15px;
  }
  .c-mt3 {
    margin-top: 3px;
  }
  .c-topBox {
    padding: 50px 0;
    margin-top: 200px;
  }
  .c-topBox .c-topBox__btn a {
    width: 350px;
    padding: 24px 0;
    font-size: 16px;
  }
  .p-contact {
    padding-bottom: 140px;
  }
  .p-contact__inner {
    padding: 0;
  }
  .p-contact__form {
    margin-top: 140px;
  }
  .p-contact__txtArea {
    margin-top: 140px;
  }
  .p-contact__txtArea p {
    margin-top: 20px;
    font-size: 20px;
  }
  .p-contact-box {
    -ms-flex-flow: row;
    flex-flow: row;
    align-items: center;
    margin-top: 50px;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-align: center;
    -ms-flex-align: center;
  }
  .p-contact-box label {
    width: 30%;
    font-size: 16px;
  }
  .p-contact-box input {
    padding: 20px 30px;
    margin-top: 0;
    font-size: 16px;
  }
  .p-contact-box textarea {
    height: 200px;
    padding: 20px 30px;
    margin-top: 0;
    font-size: 16px;
  }
  .p-contact__btn input {
    width: 350px;
    padding: 24px 0;
    margin-top: 140px;
    font-size: 16px;
  }
  .p-contact__txtArea .p-contact__ttl {
    font-size: 28px;
  }
  .p-contact__txtArea .p-contact__sub {
    font-size: 23px;
  }
  .p-contact__txtArea .p-contact__txt {
    font-size: 16px;
    line-height: 35px;
  }
  .p-contact-thanks .p-contact__txtArea {
    margin-top: 140px;
  }
  .p-contact-thanks .p-contact {
    margin-bottom: 0;
  }
  .p-top .p-txtBox {
    margin-bottom: 200px;
  }
  #error li {
    font-size: 16px;
  }
}
@media only screen and (min-width: 1024px) {
  .p-detail__head--01 {
    margin-left: -500px;
  }
  .p-detail__head--02 {
    margin-left: -500px;
  }
}
