@charset "UTF-8";
/****************************************************
 * Stylesheet
 *
 * 1.リセット
 * 2.共通設定
 * 3.レイアウト設定
 * 4.テンプレートスタイル
 * 5.コンテンツスタイル
 * 6.装飾
 * 7.印刷用調整
 * 
 ****************************************************/
/****************************************************
 * 1.リセット
 ****************************************************/
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  color: #000;
  background: #FFF;
  line-height: 1.5;
}

*, *::before, *::after {
  box-sizing: border-box;
}

body, div, dl, dt, dd, ul, ol, li, h1, h2, h3, h4, h5, h6, pre, code, form, fieldset, input, textarea, p, blockquote, th, td, figure {
  margin: 0;
  padding: 0;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

fieldset, img, svg {
  border: 0;
}

address, caption, cite, dfn, em, strong, th {
  font-style: normal;
  font-weight: normal;
}

ol, ul {
  list-style: none;
}

caption, th {
  text-align: left;
}

h1, h2, h3, h4, h5, h6 {
  font-size: 100%;
  font-weight: normal;
}

abbr {
  border: 0;
  font-variant: normal;
}

sup {
  vertical-align: text-top;
}

sub {
  vertical-align: text-bottom;
}

input, textarea, select, button {
  font-family: inherit;
  font-size: inherit;
  font-weight: inherit;
  color: inherit;
  margin: 0;
  padding: 0;
  border: none;
  outline: none;
  background: none;
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
}

input[type=submit], input[type=button], input[type=reset] {
  -moz-appearance: none;
  appearance: none;
  -webkit-appearance: none;
  border-radius: 0;
}

textarea {
  resize: vertical;
}

article, aside, footer, header, nav, section {
  display: block;
}

img, svg {
  max-width: 100%;
  height: auto;
  vertical-align: bottom;
}

a, a:focus, a:hover {
  text-decoration: none;
  color: inherit;
  outline: none;
}

/****************************************************
 * 2.共通
 ****************************************************/
html {
  background-color: transparent;
  background-image: none;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-size: 10px;
  font-weight: 400;
  font-style: normal;
  color: #000000;
  scroll-behavior: smooth;
  scroll-padding-top: 11.8rem;
}
@media only screen and (max-width: 1099px) {
  html {
    font-size: 9px;
  }
}
@media only screen and (max-width: 780px) {
  html {
    height: 100%;
    font-size: 10px;
    scroll-padding-top: 7.2rem;
  }
}

body {
  font-size: 1.6rem;
}
@media only screen and (max-width: 780px) {
  body {
    font-size: 1.3rem;
    -webkit-text-size-adjust: 100%;
  }
}

a {
  color: #000000;
}
a[href^="tel:"] {
  cursor: default;
}
a[href^="tel:"]:hover {
  text-decoration: none;
}

@media only screen and (max-width: 900px) {
  .pc {
    display: none !important;
  }
}

@media only screen and (max-width: 1279px) {
  .pc2 {
    display: none !important;
  }
}

@media only screen and (max-width: 780px) {
  .pc_tb {
    display: none !important;
  }
}

@media only screen and (min-width: 901px) {
  .tb_sp {
    display: none !important;
  }
}

@media only screen and (min-width: 781px) {
  .sp {
    display: none !important;
  }
}

.inner {
  width: 90%;
  max-width: 1080px;
  margin: 0 auto;
}
@media only screen and (max-width: 780px) {
  .inner {
    width: 87.6%;
  }
}

.fadeIn {
  opacity: 0;
  transition: opacity 0.5s cubic-bezier(0.7, 0, 1, 1);
}
.fadeIn.view {
  opacity: 1;
}
@media only screen and (min-width: 781px) {
  .fadeIn.delay1 {
    transition-delay: 0.3s;
  }
  .fadeIn.delay2 {
    transition-delay: 0.6s;
  }
  .fadeIn.delay3 {
    transition-delay: 0.9s;
  }
  .fadeIn.delay4 {
    transition-delay: 1.2s;
  }
  .fadeIn.delay5 {
    transition-delay: 1.5s;
  }
  .fadeIn.delay6 {
    transition-delay: 1.8s;
  }
  .fadeIn.delay7 {
    transition-delay: 2.1s;
  }
  .fadeIn.delay8 {
    transition-delay: 2.4s;
  }
  .fadeIn.delay9 {
    transition-delay: 2.7s;
  }
  .fadeIn.delay10 {
    transition-delay: 3s;
  }
}

.subTtlAnime01 {
  opacity: 0;
  transform: translateY(1rem);
  transition: opacity 0.5s cubic-bezier(0.7, 0, 1, 1), transform 0.5s cubic-bezier(0.7, 0, 1, 1);
}
.subTtlAnime01.view {
  opacity: 1;
  transform: translateY(0);
}

.subTtlAnime02 .en {
  opacity: 0;
  letter-spacing: -0.4em;
}
.subTtlAnime02 .en > * {
  display: inline-block;
  letter-spacing: normal;
}
.subTtlAnime02 .en span {
  opacity: 0;
  display: inline-block;
  transition: opacity 0.3s steps(1);
}
.subTtlAnime02 .en span:nth-child(1) {
  transition-delay: 0s;
}
.subTtlAnime02 .en span:nth-child(2) {
  transition-delay: 0.075s;
}
.subTtlAnime02 .en span:nth-child(3) {
  transition-delay: 0.15s;
}
.subTtlAnime02 .en span:nth-child(4) {
  transition-delay: 0.225s;
}
.subTtlAnime02 .en span:nth-child(5) {
  transition-delay: 0.3s;
}
.subTtlAnime02 .en span:nth-child(6) {
  transition-delay: 0.375s;
}
.subTtlAnime02 .en span:nth-child(7) {
  transition-delay: 0.45s;
}
.subTtlAnime02 .en span:nth-child(8) {
  transition-delay: 0.525s;
}
.subTtlAnime02 .en span:nth-child(9) {
  transition-delay: 0.6s;
}
.subTtlAnime02 .en span:nth-child(10) {
  transition-delay: 0.675s;
}
.subTtlAnime02 .en span:nth-child(11) {
  transition-delay: 0.75s;
}
.subTtlAnime02 .en span:nth-child(12) {
  transition-delay: 0.825s;
}
.subTtlAnime02 .en span:nth-child(13) {
  transition-delay: 0.9s;
}
.subTtlAnime02 .en span:nth-child(14) {
  transition-delay: 0.975s;
}
.subTtlAnime02 .en span:nth-child(15) {
  transition-delay: 1.05s;
}
.subTtlAnime02 .en span:nth-child(16) {
  transition-delay: 1.125s;
}
.subTtlAnime02 .en span:nth-child(17) {
  transition-delay: 1.2s;
}
.subTtlAnime02 .en span:nth-child(18) {
  transition-delay: 1.275s;
}
.subTtlAnime02 .en span:nth-child(19) {
  transition-delay: 1.35s;
}
.subTtlAnime02 .en span:nth-child(20) {
  transition-delay: 1.425s;
}
.subTtlAnime02 .en span:nth-child(21) {
  transition-delay: 1.5s;
}
.subTtlAnime02 .en span:nth-child(22) {
  transition-delay: 1.575s;
}
.subTtlAnime02 .en span:nth-child(23) {
  transition-delay: 1.65s;
}
.subTtlAnime02 .en span:nth-child(24) {
  transition-delay: 1.725s;
}
.subTtlAnime02 .en span:nth-child(25) {
  transition-delay: 1.8s;
}
.subTtlAnime02 .en span:nth-child(26) {
  transition-delay: 1.875s;
}
.subTtlAnime02 .en span:nth-child(27) {
  transition-delay: 1.95s;
}
.subTtlAnime02 .en span:nth-child(28) {
  transition-delay: 2.025s;
}
.subTtlAnime02 .en span:nth-child(29) {
  transition-delay: 2.1s;
}
.subTtlAnime02 .en span:nth-child(30) {
  transition-delay: 2.175s;
}
.subTtlAnime02 .ja {
  opacity: 0;
  display: inline-block;
  transition: opacity 0.5s ease;
}
.subTtlAnime02 .ja:not(.no_delay) {
  transition-delay: calc(var(--char-count) * 0.075s + 0.3s);
}
.subTtlAnime02.view .en {
  opacity: 1;
}
.subTtlAnime02.view .en span {
  opacity: 1;
}
.subTtlAnime02.view .ja {
  opacity: 1;
}

.bg-grad-anim01 {
  background: linear-gradient(to top right, #FF6200, #F6A50D, #FF8900);
  background-size: 400% 400%;
  animation: bgGradAnim 8s ease-in-out infinite;
}

.bg-grad-anim02 {
  background: linear-gradient(to bottom right, #F2B40C, #FFE05F, #F2B40C);
  background-size: 400% 400%;
  animation: bgGradAnim 8s ease-in-out infinite;
}
@keyframes bgGradAnim {
  0% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
  100% {
    background-position: 0% 50%;
  }
}
.midashi01 {
  margin-bottom: 1.5em;
}
@media only screen and (max-width: 780px) {
  .midashi01 {
    text-align: center;
  }
}
.midashi01 .en {
  font-family: "Montserrat", sans-serif;
  font-size: 2.4rem;
  font-weight: 800;
  line-height: 1.2;
  color: #0690FE;
  display: block;
}
@media only screen and (max-width: 780px) {
  .midashi01 .en {
    font-size: 1.5rem;
  }
}
.midashi01 .ja {
  margin-top: 0.3em;
  font-size: 4.5rem;
  font-weight: 700;
  line-height: 1.25;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .midashi01 .ja {
    font-size: 2.5rem;
  }
}
.midashi01 .ja em {
  font-style: normal;
  font-weight: 800;
  color: #0690FE;
}
.midashi01.center {
  text-align: center;
}
.midashi01.white .en, .midashi01.white .ja {
  color: #ffffff;
}

.midashi02 {
  margin-bottom: 2em;
}
@media only screen and (max-width: 780px) {
  .midashi02 {
    margin-bottom: 1.5em;
  }
}
.midashi02 .en {
  font-family: "Montserrat", sans-serif;
  font-size: 6rem;
  font-weight: 700;
  line-height: 1.2;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .midashi02 .en {
    font-size: 3.5rem;
  }
}
.midashi02 .ja {
  font-size: 1.8rem;
  font-weight: 500;
  display: block;
}
@media only screen and (max-width: 780px) {
  .midashi02 .ja {
    font-size: 1.4rem;
  }
}
.midashi02.center {
  text-align: center;
}
.midashi02.white {
  color: #ffffff;
}

.btn01 {
  width: 30.7rem;
  padding: 0.9em;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  color: #ffffff;
  background: linear-gradient(to right, #ffffff, #EDEDED 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #ffffff;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s, color 0.3s;
}
@media only screen and (max-width: 780px) {
  .btn01 {
    width: 27.2rem;
    font-size: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn01:hover {
    color: #0690FE;
    background-position: 0 0;
  }
}
.btn02 {
  width: 30.7rem;
  padding: 0.9em;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  color: #0690FE;
  background: linear-gradient(to right, #0092FF, #657CF7 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #0690FE;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s, color 0.3s;
}
@media only screen and (max-width: 780px) {
  .btn02 {
    width: 27.2rem;
    font-size: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .btn02:hover {
    color: #ffffff;
    background-position: 0 0;
  }
}
.btn03 {
  width: 33.7rem;
  padding: 0.9em;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  color: #ffffff !important;
  background-color: #000000;
  background-image: url("../img/icon_arrow05.png");
  background-repeat: no-repeat;
  background-size: 3.3rem auto;
  background-position: calc(100% - 1.6rem) center;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s;
}
@media only screen and (max-width: 780px) {
  .btn03 {
    width: 34.1rem;
    max-width: 100%;
    font-size: 1.6rem;
    background-size: 2.6rem auto;
  }
}
@media only screen and (min-width: 781px) {
  .btn03:hover {
    background-position: calc(100% - 0.8rem) center;
  }
}
.btn_contact {
  padding: 0.6em 1.5em;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff !important;
  background: linear-gradient(to bottom, #0690FE, #0690FE 50%, #0092FF 50%, #657CF7);
  background-size: 100% 200%;
  background-position: 0 0;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s;
}
@media only screen and (max-width: 780px) {
  .btn_contact {
    padding: 0.6em 1.2em;
    font-size: 1.6rem;
  }
}
.btn_contact:hover {
  background-position: 0 100%;
}
.btn_contact:before {
  width: 1.35em;
  height: 0.95em;
  margin-right: 0.4em;
  content: "";
  background-image: url("../img/icon_mail01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.1em;
}
.btn_recruit {
  padding: 0.6em 1.5em;
  font-family: "Montserrat", sans-serif;
  font-size: 2rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  color: #ffffff !important;
  background: linear-gradient(to bottom, #FFBA00, #FC5B13 50%, #FC5B13);
  background-size: 100% 200%;
  background-position: 0 0;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s;
}
@media only screen and (max-width: 780px) {
  .btn_recruit {
    padding: 0.6em 1.2em;
    font-size: 1.5rem;
  }
}
.btn_recruit:hover {
  background-position: 0 100%;
}
.btn_recruit:before {
  width: 1.6em;
  height: 1.6em;
  margin-right: 0.4em;
  content: "";
  background-image: url("../img/icon_recruit01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.5em;
}

/*追従バナー*/
.fix_bnr {
  position: fixed;
  z-index: 90;
}
@media only screen and (min-width: 781px) {
  .fix_bnr {
    bottom: 4.8rem;
    right: 4.8rem;
  }
}
@media only screen and (max-width: 780px) {
  .fix_bnr {
    width: 100%;
    bottom: 0;
    left: 0;
    display: flex;
  }
  .fix_bnr > div {
    width: 50%;
  }
}
@media only screen and (min-width: 781px) {
  .fix_bnr .recruit {
    width: 15rem;
    height: 15rem;
    border: solid 0.3rem #ffffff;
    border-radius: 50%;
    box-shadow: 0 0 2rem rgba(0, 0, 0, 0.16);
    overflow: hidden;
  }
}
.fix_bnr .recruit a {
  width: 100%;
  height: 100%;
  font-family: "Montserrat", sans-serif;
  text-align: center;
  color: #ffffff;
  background: linear-gradient(to bottom, #FFBA00, #FC5B13 50%, #FC5B13);
  background-size: 100% 200%;
  background-position: 0 0;
  display: block;
  transition: background-position 0.3s;
}
@media only screen and (min-width: 781px) {
  .fix_bnr .recruit a {
    padding-top: 2.2rem;
    font-size: 1.9rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-transform: uppercase;
    line-height: 1;
  }
  .fix_bnr .recruit a:hover {
    background-position: 0 100%;
  }
}
@media only screen and (max-width: 780px) {
  .fix_bnr .recruit a {
    padding: 0.6em 0;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    display: block;
  }
}
.fix_bnr .recruit a:before {
  width: 1.6em;
  height: 1.6em;
  margin-right: 0.4em;
  content: "";
  background-image: url("../img/icon_recruit01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.5em;
}
@media only screen and (min-width: 781px) {
  .fix_bnr .recruit a:before {
    width: 5rem;
    height: 5rem;
    display: block;
    margin: 0 auto 0.5rem auto;
  }
}
@media only screen and (max-width: 780px) {
  .fix_bnr .contact a {
    width: 100%;
    height: 100%;
    padding: 0.6em 0;
    font-family: "Montserrat", sans-serif;
    font-size: 2rem;
    font-weight: 700;
    letter-spacing: 0.03em;
    text-align: center;
    color: #ffffff !important;
    background: linear-gradient(to bottom, #0690FE, #0690FE 50%, #0092FF 50%, #657CF7);
    background-size: 100% 200%;
    background-position: 0 0;
    display: block;
  }
  .fix_bnr .contact a:before {
    width: 1.35em;
    height: 0.95em;
    margin-right: 0.4em;
    content: "";
    background-image: url("../img/icon_mail01.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.1em;
  }
}

/*cta*/
.cta {
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .cta {
    padding: 9.2rem 0;
    background-image: url("../img/cta_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .cta {
    padding: 3.8rem 0;
    background-image: url("../img/cta_bg_sp.jpg");
  }
}
@media only screen and (min-width: 781px) {
  .cta .inner {
    display: flex;
    justify-content: space-between;
  }
}
.cta .text {
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .cta .text {
    padding-top: 2rem;
  }
}
@media only screen and (max-width: 780px) {
  .cta .text {
    margin-bottom: 2rem;
  }
}
.cta .text p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7;
}
@media only screen and (max-width: 780px) {
  .cta .text p {
    font-size: 1.5rem;
  }
}
.cta .contact .btn a {
  display: block;
}
.cta .contact .btn a + a {
  margin-top: 1.2rem;
}
.cta .contact .btn a.contact {
  padding: 2.5rem 5rem 2.5rem 2.5rem;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: center;
  background-color: #ffffff;
  background-image: url("../img/icon_arrow01.png");
  background-size: 2.4rem auto;
  background-repeat: no-repeat;
  background-position: calc(100% - 2rem) center;
  border-radius: 0.4rem;
}
@media only screen and (min-width: 781px) {
  .cta .contact .btn a.contact {
    padding: 4.6rem 15rem;
    font-size: 2rem;
    font-weight: 700;
    background-position: calc(100% - 4rem) center;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1279px) {
  .cta .contact .btn a.contact {
    padding: 4.6rem 10rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .cta .contact .btn a.contact {
    padding: 4.6rem 6rem;
    background-position: calc(100% - 2rem) center;
  }
}
@media only screen and (min-width: 781px) {
  .cta .contact .btn a.contact:hover {
    color: #ffffff;
    background-color: #0690FE;
    background-image: url("../img/icon_arrow02.png");
  }
  .cta .contact .btn a.contact:hover:before {
    background-image: url("../img/icon_mail01.png");
  }
}
.cta .contact .btn a.contact:before {
  width: 2.65rem;
  height: 1.94rem;
  margin-right: 1em;
  content: "";
  background-image: url("../img/icon_mail02.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.2em;
}
@media only screen and (min-width: 781px) {
  .cta .contact .btn a.contact:before {
    vertical-align: -0.1em;
  }
}
.cta .contact .btn a.tel {
  padding: 2.5rem 5rem 2.5rem 2.5rem;
  font-size: 1.5rem;
  font-weight: 500;
  text-align: center;
  background-color: #ffffff;
  background-image: url("../img/icon_arrow01.png");
  background-size: 2.4rem auto;
  background-repeat: no-repeat;
  background-position: calc(100% - 2rem) center;
  border-radius: 0.4rem;
}
.cta .contact .btn a.tel:before {
  width: 2.5rem;
  height: 2.6rem;
  margin-right: 1em;
  content: "";
  background-image: url("../img/icon_tel01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.4em;
}
.cta .contact .btn a.recruit {
  padding: 2rem 5rem 2rem 2rem;
  font-family: "Montserrat", sans-serif;
  font-size: 2.5rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-align: center;
  color: #ffffff;
  background: linear-gradient(to bottom, #FFBA00, #FC5B13);
  border-radius: 0.4rem;
  position: relative;
  z-index: 1;
  overflow: hidden;
}
.cta .contact .btn a.recruit:before {
  width: 2.5rem;
  height: 2.6rem;
  margin-right: 0.5em;
  content: "";
  background-image: url("../img/icon_recruit01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.2em;
}
.cta .contact .btn a.recruit:after {
  width: 100%;
  height: 100%;
  content: "";
  background-image: url("../img/icon_arrow02.png");
  background-size: 2.4rem auto;
  background-repeat: no-repeat;
  background-position: calc(100% - 2rem) center;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
}
.cta .contact .tel_num {
  margin-top: 2.4rem;
  text-align: center;
  color: #ffffff;
}
.cta .contact .tel_num p {
  margin-bottom: 0.4em;
  font-size: 2rem;
  font-weight: 500;
}
.cta .contact .tel_num .num {
  font-family: "Montserrat", sans-serif;
  font-size: 3.2rem;
  font-weight: 600;
}

@media only screen and (min-width: 781px) {
  .cta_recruit {
    display: flex;
  }
}
.cta_recruit .link_box {
  position: relative;
}
@media only screen and (min-width: 781px) {
  .cta_recruit .link_box {
    width: 50%;
    padding: 6.4rem 7rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .cta_recruit .link_box {
    padding: 6.4rem 5rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1279px) {
  .cta_recruit .link_box {
    padding: 5rem 3rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .cta_recruit .link_box {
    padding: 3rem 2rem;
  }
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box {
    padding: 2.8rem 1.2rem;
  }
}
.cta_recruit .link_box .midashi02 {
  position: relative;
  z-index: 1;
}
.cta_recruit .link_box p {
  margin-bottom: 2.5em;
  font-size: 1.8rem;
  font-weight: 500;
  color: #ffffff;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box p {
    font-size: 1.5rem;
  }
}
.cta_recruit .link_box .btn {
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box .btn {
    text-align: center;
  }
}
.cta_recruit .link_box .img {
  position: absolute;
  bottom: 0;
  right: 4rem;
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box .img {
    right: 0;
    bottom: 26%;
  }
}
@media only screen and (min-width: 1600px) {
  .cta_recruit .link_box:nth-child(1) .midashi02 .en br {
    display: none;
  }
}
.cta_recruit .link_box:nth-child(1) .img {
  width: 30rem;
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box:nth-child(1) .img {
    width: 14.2rem;
  }
}
.cta_recruit .link_box:nth-child(2) .img {
  width: 29rem;
}
@media only screen and (max-width: 780px) {
  .cta_recruit .link_box:nth-child(2) .img {
    width: 14.6rem;
  }
}

/*ページネーション*/
.pagination {
  text-align: center;
  letter-spacing: -0.4em;
}
.pagination > * {
  display: inline-block;
  letter-spacing: normal;
}
.pagination > * {
  width: 4.3rem;
  height: 4.3rem;
  margin: 0 0.4rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  line-height: 4.3rem;
  text-align: center;
  color: #ffffff !important;
  background-color: #D5DBE2;
  border-radius: 50%;
  vertical-align: top;
}
@media only screen and (max-width: 780px) {
  .pagination > * {
    width: 3.6rem;
    height: 3.6rem;
    margin: 0.4rem !important;
    line-height: 3.6rem;
  }
}
.pagination .current {
  background-color: #171B1F;
}
.pagination .dots {
  line-height: 3rem;
}
.pagination .prev, .pagination .next {
  background-image: url("../img/icon_arrow03.png");
  background-size: cover;
  text-indent: 200%;
  white-space: nowrap;
  overflow: hidden;
}
.pagination .prev {
  margin-right: 2rem;
  transform: scaleX(-1);
}
.pagination .next {
  margin-left: 2rem;
}
.pagination a:hover {
  opacity: 0.6;
}

/*ページャー*/
.post-navigation {
  display: flex;
  border-top: solid 1px #D5DBE2;
}
@media only screen and (min-width: 781px) {
  .post-navigation {
    margin-top: 8rem;
    padding-top: 8rem;
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation {
    margin-top: 4rem;
    padding-top: 4rem;
    flex-wrap: wrap;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-list {
    width: 100%;
    padding-top: 2rem;
    text-align: center;
    order: 3;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous, .post-navigation .nav-next {
    width: 50%;
  }
}
.post-navigation .nav-previous a, .post-navigation .nav-next a {
  font-size: 1.5rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous a, .post-navigation .nav-next a {
    font-size: 1.3rem;
  }
}
.post-navigation .nav-previous a:before, .post-navigation .nav-previous a:after, .post-navigation .nav-next a:before, .post-navigation .nav-next a:after {
  width: 4.3rem;
  height: 4.3rem;
  background-image: url("../img/icon_arrow03.png");
  background-size: cover;
  border-radius: 50%;
  display: inline-block;
  vertical-align: -1em;
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous a:before, .post-navigation .nav-previous a:after, .post-navigation .nav-next a:before, .post-navigation .nav-next a:after {
    width: 3.6rem;
    height: 3.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .post-navigation .nav-previous a:hover, .post-navigation .nav-next a:hover {
    opacity: 0.6;
  }
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-previous {
    order: 1;
  }
}
.post-navigation .nav-previous a:before {
  margin-right: 1rem;
  content: "";
  transform: scale(-1, 1);
}
@media only screen and (max-width: 780px) {
  .post-navigation .nav-next {
    text-align: right;
    order: 2;
  }
}
.post-navigation .nav-next a:after {
  margin-left: 1rem;
  content: "";
}

/* ブロックエディタ用基本CSS */
.editor-area:after {
  content: "";
  display: block;
  clear: both;
}
.editor-area > *:last-child {
  margin-bottom: 0 !important;
}
.editor-area p {
  margin-bottom: 2em;
}
.editor-area h3 {
  margin-bottom: 0.8em;
  padding: 0.5em 1em;
  font-size: 2.2rem;
  font-weight: 700;
  background-color: #F4F4F4;
  border-left: solid 0.5rem #0690FE;
}
@media only screen and (max-width: 780px) {
  .editor-area h3 {
    font-size: 1.8rem;
  }
}
.editor-area h4 {
  margin-bottom: 0.8em;
  padding-left: 3.5rem;
  font-size: 2.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .editor-area h4 {
    font-size: 1.8rem;
  }
}
.editor-area h4:before {
  width: 2rem;
  height: 2rem;
  margin: 0 1.5rem 0 -3.5rem;
  content: "";
  background-image: url("../img/news/midashi_icon01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: 0;
}
.editor-area h5 {
  margin-bottom: 0.6em;
  font-size: 1.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .editor-area h5 {
    font-size: 1.6rem;
  }
}
.editor-area ul {
  margin-bottom: 2em;
}
.editor-area ul li {
  margin-bottom: 0.5em;
  padding-left: 3rem;
}
.editor-area ul li:before {
  width: 1.6rem;
  height: 1.6rem;
  margin: 0 1.4rem 0 -3rem;
  content: "";
  background-image: url("../img/news/check.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.1em;
}
.editor-area ol {
  margin-bottom: 2em;
  counter-reset: num;
}
.editor-area ol li {
  margin-bottom: 0.5em;
  padding-left: 3rem;
  counter-increment: num;
}
.editor-area ol li:before {
  width: 2rem;
  margin: 0 1rem 0 -3rem;
  content: counter(num) ".";
  color: #0690FE;
  font-weight: 700;
  display: inline-block;
  vertical-align: 0;
}
.editor-area .wp-block-image {
  margin-bottom: 2em;
}
.editor-area .alignleft {
  max-width: 50%;
  float: left;
  margin-right: 1.5em;
  margin-bottom: 2em;
}
.editor-area .alignright {
  max-width: 50%;
  float: right;
  margin-left: 1.5em;
  margin-bottom: 2em;
}
.editor-area .aligncenter {
  margin-bottom: 2em;
}
.editor-area .aligncenter img {
  display: block;
  margin-left: auto;
  margin-right: auto;
}
.editor-area .has-text-align-center {
  text-align: center;
}
.editor-area .has-text-align-right {
  text-align: right;
}
.editor-area blockquote {
  margin-bottom: 2.5em;
  margin-left: 0;
  padding: 1.2em 1.2em 1.2em 6rem;
  background-color: #F4F4F4;
  border-left: 0.25em solid #0690FE;
  position: relative;
  display: block;
}
@media only screen and (max-width: 780px) {
  .editor-area blockquote {
    padding-left: 4rem;
  }
}
.editor-area blockquote:before {
  width: 4rem;
  height: 4rem;
  content: "";
  background-color: #0690FE;
  background-image: url("../img/news/innyou.png");
  background-size: 2.4rem auto;
  background-repeat: no-repeat;
  background-position: center;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .editor-area blockquote:before {
    width: 3rem;
    height: 3rem;
    background-size: 2rem;
  }
}
.editor-area blockquote > *:last-child {
  margin-bottom: 0 !important;
}
.editor-area table {
  width: 100%;
  margin-bottom: 2em;
  border-collapse: collapse;
}
.editor-area table td, .editor-area table th {
  border: 1px solid #D5DBE2;
  padding: 0.5em;
}
.editor-area table th {
  background-color: #EDF3F7;
}
.editor-area .wp-block-columns {
  display: flex;
  margin-bottom: 2em;
}
.editor-area .wp-block-column {
  flex-grow: 1;
  margin-left: 0.625em;
  margin-right: 0.625em;
}
.editor-area .wp-block-media-text {
  display: grid;
}
.editor-area a {
  color: blue;
  text-decoration: underline;
  word-break: break-all;
}
.editor-area strong, .editor-area b {
  font-weight: bold;
}
.editor-area em, .editor-area i {
  font-style: italic;
}
.editor-area .wp-block-spacer {
  clear: both;
}

/*フォームベース*/
.form_area > p {
  margin-bottom: 2em;
}
.form_area .input_field_area {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 780px) {
  .form_area .input_field_area {
    margin-bottom: 2.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .form_area .input_field_area.table .input_field {
    width: 100%;
    margin-bottom: 0;
    display: table;
  }
  .form_area .input_field_area.table .input_field > * {
    display: table-cell;
  }
  .form_area .input_field_area.table .input_field .input_label {
    width: 30%;
    margin-bottom: 0;
    padding: 1em;
    vertical-align: top;
  }
  .form_area .input_field_area.table .input_field .input_area {
    padding: 1em;
    vertical-align: top;
  }
}
.form_area .input_field_area .input_field {
  margin-bottom: 2em;
}
.form_area .input_field_area .input_field .input_label {
  margin-bottom: 0.75em;
  font-size: 1.125em;
  font-weight: 500;
}
.form_area .input_field_area .input_field .input_label span {
  margin-left: 1em;
  padding: 0 0.5em;
  font-size: 0.7em;
  font-weight: 400;
  color: #0690FE;
  border: solid 1px #0690FE;
  border-radius: 0.4rem;
  display: inline-block;
  vertical-align: 0;
}
.form_area .input_field_area .input_field .input_area.row {
  display: flex;
  justify-content: space-between;
}
.form_area .input_field_area .input_field .input_area.row .col {
  width: 48%;
}
.form_area .input_field_area .input_field .input_area.row .col .label {
  white-space: nowrap;
  display: block;
}
.form_area .input_field_area .input_field .input_area .annotation {
  margin-top: 1em;
  font-size: 0.875em;
}
.form_area .privacy {
  margin-bottom: 5rem;
}
@media only screen and (max-width: 780px) {
  .form_area .privacy {
    margin-bottom: 2.5rem;
  }
}
.form_area .privacy > p {
  margin-bottom: 2em;
  text-align: center;
}
.form_area .privacy .box {
  height: 24rem;
  margin-bottom: 3.2rem;
  padding: 2em;
  border: solid 1px #D5DBE2;
}
@media only screen and (max-width: 780px) {
  .form_area .privacy .box {
    height: 14rem;
    padding: 1em;
  }
}
.form_area .privacy .box .scroll {
  width: 100%;
  height: 100%;
  padding-right: 1em;
  overflow: auto;
}
.form_area .privacy .box h3 {
  margin-bottom: 1em;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .form_area .privacy .box h3 {
    font-size: 1.6rem;
  }
}
.form_area .privacy .box h4 {
  margin-bottom: 1em;
  font-size: 1.6rem;
  font-weight: 700;
}
.form_area .privacy .box h5 {
  margin-bottom: 0.5em;
  font-size: 1.4rem;
  font-weight: 500;
  letter-spacing: 0.05em;
}
.form_area .privacy .box p {
  margin-bottom: 2em;
  font-size: 1.4rem;
  letter-spacing: 0.05em;
}
.form_area .privacy .check {
  text-align: center;
}
.form_area .submit {
  text-align: center;
}
.form_area .submit input[type=submit] {
  width: 30.7rem;
  padding: 0.9em;
  font-size: 1.8rem;
  font-weight: 700;
  text-align: center;
  color: #0690FE;
  background: linear-gradient(to right, #0092FF, #657CF7 50%, transparent 50%, transparent);
  background-size: 200% 100%;
  background-position: 100% 0;
  border: solid 0.2rem #0690FE;
  border-radius: 99px;
  display: inline-block;
  transition: background-position 0.3s, color 0.3s;
}
@media only screen and (max-width: 780px) {
  .form_area .submit input[type=submit] {
    width: 27.2rem;
    font-size: 1.6rem;
  }
}
@media only screen and (min-width: 781px) {
  .form_area .submit input[type=submit]:hover {
    color: #ffffff;
    background-position: 0 0;
  }
}
.form_area .submit input[type=submit]:disabled {
  opacity: 0.3 !important;
}
.form_area .wpcf7-text {
  width: 100%;
  padding: 0.75em;
  background-color: #F4F4F4;
  border-radius: 0.4rem;
}
.form_area .wpcf7-text::-moz-placeholder {
  color: #D5DBE2;
}
.form_area .wpcf7-text::placeholder {
  color: #D5DBE2;
}
.form_area .wpcf7-textarea {
  width: 100%;
  height: 16em;
  padding: 0.75em;
  background-color: #F4F4F4;
  border-radius: 0.4rem;
}
@media only screen and (max-width: 780px) {
  .form_area .wpcf7-textarea {
    height: 8em;
  }
}
.form_area .wpcf7-textarea::-moz-placeholder {
  color: #D5DBE2;
}
.form_area .wpcf7-textarea::placeholder {
  color: #D5DBE2;
}
.form_area .wpcf7-select {
  width: 100%;
  padding: 0.75em;
  background-color: #F4F4F4;
  background-image: url("../img/form_select_icon.png");
  background-repeat: no-repeat;
  background-position: calc(100% - 1rem) center;
  background-size: 1rem auto;
  border-radius: 0.4rem;
}
.form_area .wpcf7-radio {
  margin-bottom: -1em;
  display: block;
  letter-spacing: -0.4em;
}
.form_area .wpcf7-radio > * {
  display: inline-block;
  letter-spacing: normal;
}
.form_area .wpcf7-radio > * {
  margin-right: 1em !important;
  margin-bottom: 1em !important;
}
.form_area .wpcf7-radio label input {
  visibility: hidden;
  position: absolute;
  left: -9999999px;
}
.form_area .wpcf7-radio label input:checked + span:after {
  content: "";
}
.form_area .wpcf7-radio label input + span {
  padding-left: 4rem;
  display: inline-block;
  position: relative;
}
.form_area .wpcf7-radio label input + span:before {
  width: 2.4rem;
  height: 2.4rem;
  content: "";
  background-color: #ffffff;
  border: solid 1px #D5DBE2;
  border-radius: 50%;
  position: absolute;
  top: 0;
  left: 0;
}
.form_area .wpcf7-radio label input + span:after {
  width: 1.4rem;
  height: 1.4rem;
  content: none;
  background-color: #000000;
  border-radius: 50%;
  position: absolute;
  top: 0.5rem;
  left: 0.5rem;
}
.form_area .wpcf7-checkbox, .form_area .wpcf7-acceptance {
  margin-bottom: -1em;
  display: block;
  letter-spacing: -0.4em;
}
.form_area .wpcf7-checkbox > *, .form_area .wpcf7-acceptance > * {
  display: inline-block;
  letter-spacing: normal;
}
.form_area .wpcf7-checkbox > *, .form_area .wpcf7-acceptance > * {
  margin-right: 1em !important;
  margin-bottom: 1em !important;
}
.form_area .wpcf7-checkbox label input, .form_area .wpcf7-acceptance label input {
  visibility: hidden;
  position: absolute;
  left: -9999999px;
}
.form_area .wpcf7-checkbox label input:checked + span:after, .form_area .wpcf7-acceptance label input:checked + span:after {
  content: "";
}
.form_area .wpcf7-checkbox label input + span, .form_area .wpcf7-acceptance label input + span {
  padding-left: 4rem;
  display: inline-block;
  position: relative;
}
.form_area .wpcf7-checkbox label input + span:before, .form_area .wpcf7-acceptance label input + span:before {
  width: 2.4rem;
  height: 2.4rem;
  content: "";
  background-color: #ffffff;
  border: solid 1px #D5DBE2;
  position: absolute;
  top: 0;
  left: 0;
}
.form_area .wpcf7-checkbox label input + span:after, .form_area .wpcf7-acceptance label input + span:after {
  width: 1.6rem;
  height: 1rem;
  content: none;
  border-left: solid 0.2rem #000000;
  border-bottom: solid 0.2rem #000000;
  position: absolute;
  top: 0.4rem;
  left: 0.4rem;
  transform: rotate(-45deg);
}

/****************************************************
 * 3.レイアウト設定
 ****************************************************/
.container {
  width: 100%;
  padding-top: 11.8rem;
  overflow: hidden;
}
@media only screen and (max-width: 900px) {
  .container {
    padding-top: 7.2rem;
  }
}

/****************************************************
 * 4.テンプレートスタイル
 ****************************************************/
/*ヘッダーブロック*/
#header {
  width: 100%;
  height: 11.8rem;
  padding: 0 3.2rem;
  background-color: #ffffff;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 99;
  display: flex;
  justify-content: space-between;
  align-items: center;
}
@media only screen and (max-width: 1279px) and (min-width: 781px) {
  #header {
    padding: 0 2rem;
  }
}
@media only screen and (max-width: 900px) {
  #header {
    height: 7.2rem;
    padding: 0 1.2rem;
  }
}
#header .logo {
  width: 26.2rem;
}
@media only screen and (max-width: 1279px) {
  #header .logo {
    width: 18.75rem;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right {
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right .sp_menu {
    width: 4.8rem;
    height: 4.8rem;
    background-image: url("../img/sp_menu_open.png");
    background-size: cover;
  }
  #header .header_right .sp_menu.open {
    background-image: url("../img/sp_menu_close.png");
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav {
    width: 100%;
    height: calc(100vh - 7.2rem);
    padding-left: 4.4rem;
    font-size: 1.7rem;
    background-color: rgba(0, 0, 0, 0.85);
    position: absolute;
    top: 100%;
    left: 0;
    display: none;
  }
  #header .header_right nav:before {
    width: calc(100% - 4.4rem);
    height: 100%;
    content: "";
    background-color: #0690FE;
    position: absolute;
    top: 0;
    right: 0;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right nav ul {
    display: table;
  }
  #header .header_right nav ul > * {
    display: table-cell;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav ul {
    margin-bottom: 2.4rem;
    position: relative;
    z-index: 1;
  }
}
#header .header_right nav ul li {
  font-weight: 500;
}
@media only screen and (min-width: 901px) {
  #header .header_right nav ul li {
    padding: 0 2em;
    text-align: center;
    position: relative;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1599px) {
  #header .header_right nav ul li {
    padding: 0 1.5em;
  }
}
@media only screen and (min-width: 901px) and (max-width: 1279px) {
  #header .header_right nav ul li {
    padding: 0 1em;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right nav ul li:after {
    width: 0.5em;
    height: 0.5em;
    content: "";
    background-color: #0690FE;
    border-radius: 50%;
    position: absolute;
    top: calc(50% - 0.25em);
    left: calc(100% - 0.25em);
  }
  #header .header_right nav ul li:last-child:after {
    content: none;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav ul li {
    border-bottom: solid 1px #ffffff;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav ul li a {
    padding: 1.17em;
    color: #ffffff;
    background-image: url("../img/icon_arrow02.png");
    background-size: 2.4rem auto;
    background-repeat: no-repeat;
    background-position: calc(100% - 2.4rem) center;
    display: block;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right nav ul li a:hover {
    color: #0690FE;
  }
}
@media only screen and (min-width: 901px) {
  #header .header_right nav ul li a span {
    font-family: "Montserrat", sans-serif;
    font-size: 0.875em;
    color: #cccccc;
    display: block;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav .btn {
    width: 90%;
    max-width: 29.8rem;
    margin: 0 auto;
    position: relative;
    z-index: 1;
  }
}
@media only screen and (max-width: 900px) {
  #header .header_right nav .btn a {
    display: block;
  }
  #header .header_right nav .btn a + a {
    margin-top: 1.2rem;
  }
  #header .header_right nav .btn a.contact {
    padding: 2.5rem 5rem 2.5rem 2.5rem;
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    background-color: #ffffff;
    background-image: url("../img/icon_arrow01.png");
    background-size: 2.4rem auto;
    background-repeat: no-repeat;
    background-position: calc(100% - 2rem) center;
    border-radius: 0.4rem;
  }
  #header .header_right nav .btn a.contact:before {
    width: 2.65rem;
    height: 1.94rem;
    margin-right: 1em;
    content: "";
    background-image: url("../img/icon_mail02.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.2em;
  }
  #header .header_right nav .btn a.tel {
    padding: 2.5rem 5rem 2.5rem 2.5rem;
    font-size: 1.5rem;
    font-weight: 500;
    text-align: center;
    background-color: #ffffff;
    background-image: url("../img/icon_arrow01.png");
    background-size: 2.4rem auto;
    background-repeat: no-repeat;
    background-position: calc(100% - 2rem) center;
    border-radius: 0.4rem;
  }
  #header .header_right nav .btn a.tel:before {
    width: 2.5rem;
    height: 2.6rem;
    margin-right: 1em;
    content: "";
    background-image: url("../img/icon_tel01.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.4em;
  }
  #header .header_right nav .btn a.recruit {
    padding: 2rem 5rem 2rem 2rem;
    font-family: "Montserrat", sans-serif;
    font-size: 2.5rem;
    font-weight: 600;
    letter-spacing: 0.05em;
    text-align: center;
    color: #ffffff;
    background: linear-gradient(to bottom, #FFBA00, #FC5B13);
    border-radius: 0.4rem;
    position: relative;
    z-index: 1;
    overflow: hidden;
  }
  #header .header_right nav .btn a.recruit:before {
    width: 2.5rem;
    height: 2.6rem;
    margin-right: 0.5em;
    content: "";
    background-image: url("../img/icon_recruit01.png");
    background-size: cover;
    display: inline-block;
    vertical-align: -0.2em;
  }
  #header .header_right nav .btn a.recruit:after {
    width: 100%;
    height: 100%;
    content: "";
    background-image: url("../img/icon_arrow02.png");
    background-size: 2.4rem auto;
    background-repeat: no-repeat;
    background-position: calc(100% - 2rem) center;
    position: absolute;
    top: 0;
    left: 0;
    z-index: -1;
  }
}
#header .header_right .btn_area .btn_contact {
  margin-left: 0.8em;
  text-transform: uppercase;
}
@media only screen and (max-width: 1279px) {
  #header .header_right .btn_area .btn_contact {
    margin-left: 0.5em;
  }
}
@media only screen and (max-width: 1279px) {
  #header .header_right .btn_area .btn_contact:before {
    content: none;
  }
}
#header .header_right .btn_area .btn_recruit {
  text-transform: uppercase;
}
@media only screen and (max-width: 1279px) {
  #header .header_right .btn_area .btn_recruit:before {
    content: none;
  }
}

@media only screen and (min-width: 901px) {
  .home #header:not(.scroll) {
    background-color: transparent;
  }
}

/*フッターブロック*/
#footer {
  padding: 7rem 0;
  color: #ffffff;
  background-color: #171B1F;
}
@media only screen and (max-width: 780px) {
  #footer {
    padding: 0 0 8.5rem 0;
  }
}
#footer a {
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  #footer .inner {
    display: flex;
    justify-content: space-between;
    flex-direction: row-reverse;
  }
}
@media only screen and (min-width: 781px) {
  #footer .navi {
    padding-left: 2.4rem;
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  #footer .navi {
    margin-bottom: 4.8rem;
  }
}
@media only screen and (min-width: 781px) {
  #footer .navi ul {
    margin-top: -1em;
  }
}
@media only screen and (max-width: 780px) {
  #footer .navi ul {
    width: 114%;
    margin: 0 -7%;
  }
}
@media only screen and (min-width: 781px) {
  #footer .navi ul li + li {
    margin-top: 1em;
  }
}
#footer .navi ul li a {
  font-weight: 500;
  color: #ffffff;
  background-image: url("../img/icon_arrow01.png");
  background-repeat: no-repeat;
  background-size: 2.4rem auto;
  border-bottom: solid 1px #424D58;
  display: block;
}
@media only screen and (min-width: 781px) {
  #footer .navi ul li a {
    width: 25rem;
    padding: 1em 0;
    font-size: 1.8rem;
    background-position: right center;
  }
  #footer .navi ul li a:hover {
    background-image: url("../img/icon_arrow02.png");
  }
}
@media only screen and (max-width: 780px) {
  #footer .navi ul li a {
    padding: 1.17em 1.4em;
    font-size: 1.7rem;
    background-position: calc(100% - 1.2rem) center;
  }
}
@media only screen and (min-width: 781px) {
  #footer .navi .btn_area {
    margin-left: 7rem;
  }
}
@media only screen and (max-width: 780px) {
  #footer .navi .btn_area {
    margin-top: 4rem;
    text-align: center;
  }
}
@media only screen and (min-width: 781px) {
  #footer .navi .btn_area .btn_contact, #footer .navi .btn_area .btn_recruit {
    width: 19.5rem;
    padding: 0.6em 0;
    text-align: center;
    display: block;
  }
  #footer .navi .btn_area .btn_contact {
    margin-top: 1.4rem;
  }
}
@media only screen and (max-width: 780px) {
  #footer .navi .btn_area .btn_contact {
    margin-left: 1rem;
  }
}
#footer .footer_content .logo {
  width: 22.5rem;
  margin-bottom: 2.4rem;
}
@media only screen and (max-width: 780px) {
  #footer .footer_content .logo {
    width: 21.3rem;
    margin: 0 auto 2.4rem auto;
  }
}
#footer .footer_content dl {
  margin-bottom: 4rem;
  font-size: 1.4rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  #footer .footer_content dl {
    margin-bottom: 2.4rem;
    font-size: 1.3rem;
  }
}
#footer .footer_content dl dt {
  margin-bottom: 0.6em;
}
@media only screen and (max-width: 780px) {
  #footer .footer_content dl dt {
    text-align: center;
  }
}
#footer .footer_content dl dt span {
  padding: 0.1em 0.5em;
  border: solid 1px #ffffff;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  #footer .footer_content dl dd {
    text-align: center;
  }
}
#footer .footer_content dl dd + dt {
  margin-top: 1.2em;
}
#footer .footer_content .copyright {
  font-size: 1.4rem;
  font-weight: 500;
  color: #5D636A;
}
@media only screen and (max-width: 780px) {
  #footer .footer_content .copyright {
    text-align: center;
  }
}

/****************************************************
 * 5.コンテンツスタイル
 ****************************************************/
/*TOPページ*/
@media only screen and (min-width: 781px) {
  .p-top__mv {
    padding-top: 3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv {
    padding-top: 2rem;
  }
}
.p-top__mv .outer {
  background-size: cover;
  background-position: center center;
  transform: skewY(-5deg);
}
@media only screen and (min-width: 781px) {
  .p-top__mv .outer {
    padding: 26rem 0 14rem 0;
    background-image: url("../img/top/mv_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .outer {
    padding: 15rem 0 5rem 0;
    background-image: url("../img/top/mv_bg_sp.jpg");
  }
}
.p-top__mv .outer .inner {
  transform: skewY(5deg);
}
@media only screen and (min-width: 781px) {
  .p-top__mv .outer .inner {
    width: 95%;
    max-width: 1920px;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .outer .inner {
    width: 92%;
  }
}
.p-top__mv .catchcopy {
  color: #ffffff;
}
.p-top__mv .catchcopy h2 {
  margin-bottom: 0.5em;
  font-size: 3.2rem;
  font-weight: 700;
  line-height: 1.2;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .catchcopy h2 {
    font-size: 2.1rem;
  }
}
.p-top__mv .catchcopy .en {
  font-family: "Montserrat", sans-serif;
  font-size: 12rem;
  font-weight: 800;
  line-height: 0.875;
}
@media only screen and (max-width: 1099px) {
  .p-top__mv .catchcopy .en {
    font-size: 10rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__mv .catchcopy .en {
    font-size: 5.6rem;
  }
}
.p-top__mv .box {
  max-width: 80.2rem;
  margin-top: 4rem;
  padding: 1em;
  background-color: #ffffff;
  border-radius: 0.8rem;
  display: flex;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .box {
    margin-top: 2rem;
  }
}
.p-top__mv .box .img {
  width: 17rem;
  margin-right: 2rem;
  border-radius: 0.4rem;
  overflow: hidden;
}
.p-top__mv .box .img > img, .p-top__mv .box .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .box .img {
    width: 11rem;
    margin-right: 1rem;
  }
}
.p-top__mv .box .text {
  width: calc(100% - 19rem);
}
@media only screen and (max-width: 780px) {
  .p-top__mv .box .text {
    width: calc(100% - 12rem);
  }
}
.p-top__mv .box .text p {
  margin-bottom: 0.3em;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-top__mv .box .text .link {
    text-align: right;
  }
}
.p-top__mv .box .text .link a {
  font-weight: 700;
  color: #0690FE;
  border-bottom: solid 1px transparent;
  display: inline-block;
}
.p-top__mv .box .text .link a:hover {
  border-bottom-color: #0690FE;
}
.p-top__mv .box .text .link a:after {
  width: 1em;
  height: 1em;
  margin-left: 0.5em;
  content: "";
  background-image: url("../img/icon_arrow01.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.1em;
}
.p-top__intro {
  margin-bottom: 5rem;
  position: relative;
  z-index: 3;
}
.p-top__intro .outer {
  width: 100%;
  position: relative;
  z-index: 2;
}
.p-top__intro .outer:before {
  width: 117.5%;
  height: 100%;
  content: "";
  background: linear-gradient(to right, #0092FF, #657CF7);
  transform: skewY(5deg);
  transform-origin: top right;
  position: absolute;
  top: 7.5%;
  left: -8.75%;
  z-index: -1;
}
@media only screen and (max-width: 780px) {
  .p-top__intro .outer:before {
    top: 2.75%;
  }
}
.p-top__intro .outer:after {
  width: 117.5%;
  height: 100%;
  content: "";
  background: linear-gradient(to bottom, transparent, transparent 50%, #EDEDED 51%, #EDEDED);
  transform: skewY(-5deg);
  transform-origin: top left;
  position: absolute;
  top: 7.5%;
  left: -8.75%;
  z-index: -2;
}
@media only screen and (max-width: 780px) {
  .p-top__intro .outer:after {
    top: 2.75%;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__intro .inner {
    display: flex;
  }
}
@media only screen and (min-width: 781px) and (max-width: 900px) {
  .p-top__intro .inner {
    padding-bottom: 6rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__intro .inner {
    padding-top: 6.5rem;
  }
}
.p-top__intro .text {
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-top__intro .text {
    width: 65%;
    position: relative;
    z-index: 1;
  }
}
.p-top__intro .text h2 {
  margin-bottom: 0.5em;
  font-size: 4.6rem;
  font-weight: 700;
  line-height: 1.26;
}
@media only screen and (max-width: 1099px) {
  .p-top__intro .text h2 {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__intro .text h2 {
    font-size: 2.5rem;
  }
}
.p-top__intro .text p {
  margin-bottom: 2em;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}
@media only screen and (max-width: 780px) {
  .p-top__intro .text p {
    font-size: 1.5rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__intro .text .btn {
    text-align: center;
  }
}
.p-top__intro .text .fig01 {
  width: 23.6rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transform: translate(-50%, -50%);
}
@media only screen and (min-width: 781px) {
  .p-top__intro .img {
    width: 56%;
    margin-right: -21%;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__intro .img {
    width: 90%;
    margin: 0 auto;
  }
}
.p-top__intro .img img {
  width: 126%;
  max-width: none;
  margin-left: -13%;
}
@media only screen and (min-width: 781px) {
  .p-top__intro .img img {
    margin-top: -20rem;
  }
}
.p-top__business {
  padding-bottom: 8rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__business {
    padding-bottom: 6rem;
  }
}
.p-top__business:after {
  width: 100%;
  height: 40%;
  content: "";
  background: linear-gradient(to bottom, #ffffff, #E9F1F8);
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
}
.p-top__business .inner {
  position: relative;
  z-index: 1;
}
.p-top__business .midashi01 + p {
  margin-bottom: 2em;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__business .midashi01 + p {
    font-size: 1.5rem;
    text-align: left;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__business ol {
    margin-bottom: 4rem;
    display: flex;
    justify-content: center;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__business ol {
    margin-bottom: 2.8rem;
  }
}
.p-top__business ol li {
  width: 34.4rem;
  height: 25.8rem;
  margin: 0 1.2rem;
  background-size: cover;
  background-position: center center;
  border-radius: 1.6rem;
  overflow: hidden;
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li {
    width: 100%;
    height: 12.9rem;
    margin: 0 0 0.8rem 0;
    display: flex;
    align-items: center;
  }
}
.p-top__business ol li .num {
  padding-left: 1.6rem;
  font-family: "Montserrat", sans-serif;
  font-size: 7rem;
  font-weight: 800;
  color: #ffffff;
  opacity: 0.5;
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li .num {
    width: 50%;
    padding-left: 2rem;
    font-size: 4.5rem;
  }
}
.p-top__business ol li p {
  margin-top: 8rem;
  font-size: 2.2rem;
  font-weight: 700;
  text-align: center;
  color: #ffffff;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li p {
    width: 50%;
    margin: 0;
    font-size: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__business ol li:nth-child(1) {
    background-image: url("../img/top/business_img01.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li:nth-child(1) {
    background-image: url("../img/top/business_img01_sp.jpg");
  }
}
@media only screen and (min-width: 781px) {
  .p-top__business ol li:nth-child(2) {
    background-image: url("../img/top/business_img02.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li:nth-child(2) {
    background-image: url("../img/top/business_img02_sp.jpg");
  }
}
@media only screen and (min-width: 781px) {
  .p-top__business ol li:nth-child(3) {
    background-image: url("../img/top/business_img03.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__business ol li:nth-child(3) {
    background-image: url("../img/top/business_img03_sp.jpg");
  }
}
.p-top__business .btn {
  text-align: center;
}
.p-top__business .fig01 {
  width: 18.3rem;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -1;
  transform: translate(60%, -20%);
}
@media only screen and (max-width: 780px) {
  .p-top__business .fig01 {
    width: 9.15rem;
  }
}
.p-top__business .fig02 {
  width: 23.6rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  transform: translate(-50%, -30%);
}
@media only screen and (max-width: 780px) {
  .p-top__business .fig02 {
    width: 11.8rem;
  }
}
.p-top__recruit {
  padding-bottom: 11.2rem;
  background-color: #E9F1F8;
}
@media only screen and (max-width: 780px) {
  .p-top__recruit {
    padding-bottom: 5rem;
  }
}
.p-top__recruit .inner {
  max-width: 1200px;
}
.p-top__recruit .box {
  width: 100%;
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .p-top__recruit .box {
    height: 32rem;
    background-image: url("../img/top/recruit_bnr_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-top__recruit .box {
    height: 25.5rem;
    background-image: url("../img/top/recruit_bnr_bg_sp.jpg");
  }
}
.p-top__recruit .box a {
  width: 100%;
  height: 100%;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-top__recruit .box a {
    padding-top: 14.4rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__recruit .box a:hover .text {
    background-position: calc(100% - 2rem) center;
  }
}
.p-top__recruit .box a .text {
  background-image: url("../img/icon_arrow02.png");
  background-repeat: no-repeat;
  background-size: 5.6rem auto;
  background-position: calc(100% - 4rem) center;
  transition: background-position 0.3s;
}
@media only screen and (max-width: 780px) {
  .p-top__recruit .box a .text {
    padding-left: 2rem;
    background-size: 4rem auto;
    background-position: calc(100% - 2rem) 80%;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__recruit .box a .text {
    width: 60%;
    max-width: 640px;
    height: 100%;
    margin: 0 0 0 auto;
    display: flex;
    align-items: center;
  }
}
.p-top__recruit .box a .text p {
  font-size: 4rem;
  font-weight: 700;
  line-height: 1.125;
  color: #ffffff;
}
@media only screen and (max-width: 900px) {
  .p-top__recruit .box a .text p {
    font-size: 3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__recruit .box a .text p {
    font-size: 2.1rem;
  }
}
.p-top__recruit .box a .text p span {
  margin-bottom: 0.2em;
  font-family: "Montserrat", sans-serif;
  font-weight: 500;
  opacity: 0.4;
  display: block;
}
.p-top__staff {
  padding-top: 8.8rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-top__staff {
    padding-top: 3rem;
  }
}
.p-top__staff .scroll_text {
  width: 100%;
  font-family: "Montserrat", sans-serif;
  font-size: 13rem;
  font-weight: 800;
  color: #F4F4F4;
  position: absolute;
  top: 13.6rem;
  left: 0;
  z-index: -1;
}
@media only screen and (max-width: 780px) {
  .p-top__staff .scroll_text {
    font-size: 6.5rem;
    top: 6rem;
  }
}
.p-top__staff .outer {
  width: 100%;
  padding-bottom: 12rem;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 780px) {
  .p-top__staff .outer {
    padding-bottom: 3rem;
  }
}
.p-top__staff .outer:before {
  width: 117.5%;
  height: 50%;
  content: "";
  background: linear-gradient(to right, #0092FF, #657CF7);
  transform: skewY(-5deg);
  transform-origin: top left;
  position: absolute;
  top: 57.5%;
  left: -8.75%;
  z-index: -1;
}
@media only screen and (max-width: 780px) {
  .p-top__staff .outer:before {
    height: 75%;
    top: 27.75%;
  }
}
.p-top__staff .outer:after {
  width: 117.5%;
  height: 50%;
  content: "";
  background: linear-gradient(to bottom, transparent, transparent 50%, #EDEDED 51%, #EDEDED);
  transform: skewY(5deg);
  transform-origin: top right;
  position: absolute;
  top: 57.5%;
  left: -8.75%;
  z-index: -2;
}
@media only screen and (max-width: 780px) {
  .p-top__staff .outer:after {
    height: 75%;
    top: 27.75%;
  }
}
.p-top__staff .inner {
  position: relative;
  z-index: 1;
}
.p-top__staff h2 {
  width: 62.3rem;
  margin: 0 auto 2.5rem auto;
}
@media only screen and (max-width: 780px) {
  .p-top__staff h2 {
    width: 34.2rem;
    margin-bottom: 2rem;
  }
}
.p-top__staff h2 + p {
  margin-bottom: 2em;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.7;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-top__staff h2 + p {
    font-size: 1.5rem;
    text-align: left;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__staff ul {
    margin-bottom: 4rem;
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__staff ul {
    margin-bottom: 3rem;
  }
}
.p-top__staff ul li {
  position: relative;
  box-shadow: 0 0 4rem rgba(0, 0, 0, 0.1);
}
@media only screen and (min-width: 781px) {
  .p-top__staff ul li {
    width: 31.8%;
    height: 33rem;
    margin: 0 2.3% 0 0;
  }
  .p-top__staff ul li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__staff ul li {
    width: 100%;
    height: 22rem;
    margin-bottom: 1.2rem;
  }
}
.p-top__staff ul li a {
  width: 100%;
  height: 100%;
  border-radius: 0.8rem;
  overflow: hidden;
  display: block;
}
.p-top__staff ul li a > img, .p-top__staff ul li a > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.p-top__staff ul li a:hover .box {
  background-position: calc(100% - 0.8rem) center;
}
.p-top__staff ul li .box {
  width: 90%;
  padding: 1em 5rem 1em 1em;
  background-color: rgba(255, 255, 255, 0.9);
  background-image: url("../img/icon_arrow01.png");
  background-repeat: no-repeat;
  background-size: 2.4rem auto;
  background-position: calc(100% - 1.6rem) center;
  border-radius: 0.4rem;
  position: absolute;
  left: 5%;
  bottom: 1.6rem;
  transition: background-position 0.3s;
}
.p-top__staff ul li .box .meta {
  font-size: 0.875em;
  font-weight: 500;
  color: #0690FE;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-top__staff ul li .box .meta {
    font-size: 0.75em;
  }
}
.p-top__staff ul li .box h3 {
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-top__staff ul li .box h3 {
    font-size: 1.4rem;
  }
}
.p-top__staff .btn {
  text-align: center;
}
.p-top__staff .fig01 {
  width: 11rem;
  position: absolute;
  top: 23rem;
  left: 0;
  z-index: -1;
  transform: translate(-50%, 0);
}
.p-top__staff .fig02 {
  width: 11rem;
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: -1;
  transform: translate(50%, -50%);
}
.p-top__news {
  padding: 10rem 0;
}
@media only screen and (max-width: 780px) {
  .p-top__news {
    padding: 5rem 0;
  }
}
.p-top__news .inner {
  max-width: 1200px;
  position: relative;
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner:after {
    content: "";
    display: block;
    clear: both;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner .ttl {
    width: 18rem;
    float: left;
  }
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner .content {
    width: calc(100% - 20rem);
    max-width: 89rem;
    float: right;
  }
}
.p-top__news .inner .content .news_list li + li {
  margin-top: 1em;
}
.p-top__news .inner .content .news_list li a {
  width: 100%;
  padding: 3.2rem 9.6rem 3.2rem 4rem;
  background-color: #F4F4F4;
  background-image: url("../img/icon_arrow01.png");
  background-repeat: no-repeat;
  background-position: calc(100% - 2.4rem) center;
  background-size: 2.4rem auto;
  border-radius: 1.6rem;
  display: block;
  overflow: hidden;
  transition: background-position 0.3s;
  letter-spacing: -0.4em;
}
.p-top__news .inner .content .news_list li a > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner .content .news_list li a:hover {
    background-position: calc(100% - 1.2rem) center;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .content .news_list li a {
    padding: 1.6rem 5rem 1.6rem 1.6rem;
    background-position: calc(100% - 1.6rem) center;
  }
}
.p-top__news .inner .content .news_list li a > * {
  vertical-align: top;
}
.p-top__news .inner .content .news_list li .date {
  width: 12rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  color: #9F9F9F;
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .content .news_list li .date {
    width: 9rem;
    font-size: 1.3rem;
  }
}
.p-top__news .inner .content .news_list li .cate {
  width: 9.6rem;
  margin-right: 4.8rem;
  margin-top: -0.1em;
  padding: 0.1em 0.1em 0.2em 0.1em;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
  background-color: #0690FE;
  border-radius: 99px;
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .content .news_list li .cate {
    width: 6rem;
    margin-right: 0;
    font-size: 1.2rem;
  }
}
.p-top__news .inner .content .news_list li p {
  width: calc(100% - 26.4rem);
  padding-top: 0.2em;
  font-weight: 500;
  line-height: 1.2;
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .content .news_list li p {
    width: 100%;
    margin-top: 0.5em;
    padding-top: 0;
    display: block;
  }
}
.p-top__news .inner .btn {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner .btn {
    width: 100%;
    padding-top: 4rem;
    clear: both;
  }
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .btn {
    padding-top: 2.5rem;
  }
}
.p-top__news .inner .fig01 {
  position: absolute;
  z-index: -1;
}
@media only screen and (min-width: 781px) {
  .p-top__news .inner .fig01 {
    width: 23.6rem;
    bottom: 0;
    left: 0;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (max-width: 780px) {
  .p-top__news .inner .fig01 {
    width: 16.9rem;
    top: 0;
    right: 0;
    transform: translate(50%, 15%);
  }
}

/*下層ページ*/
.pagetitle {
  width: 100%;
  height: 35rem;
  margin-bottom: 3.5rem;
  padding-top: 8.5rem;
  background-image: url("../img/pagetitle_bg.png");
  background-size: 1920px auto;
  background-repeat: no-repeat;
  background-position: center bottom;
}
@media only screen and (max-width: 780px) {
  .pagetitle {
    height: 25rem;
    padding-top: 6rem;
  }
}
@media only screen and (max-width: 780px) {
  .pagetitle .midashi01 {
    text-align: left !important;
  }
}
.pagetitle .midashi01 .ja {
  font-size: 3.6rem;
}
@media only screen and (max-width: 780px) {
  .pagetitle .midashi01 .ja {
    font-size: 2.5rem;
  }
}
.pagetitle .pankuzu {
  font-size: 1.4rem;
  letter-spacing: -0.4em;
}
.pagetitle .pankuzu > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .pagetitle .pankuzu {
    font-size: 1.2rem;
  }
}
.pagetitle .pankuzu a {
  color: #ffffff;
}
.pagetitle .pankuzu a:after {
  width: 0.6rem;
  height: 0.9rem;
  margin: 0 1em;
  content: "";
  background-image: url("../img/icon_arrow04.png");
  background-size: cover;
  display: inline-block;
  vertical-align: 0;
}
.pagetitle .pankuzu span {
  color: rgba(255, 255, 255, 0.5);
}

.p-company__message {
  padding-bottom: 16.4rem;
  background: linear-gradient(to bottom, #ffffff, #E9F1F8 50%, #E9F1F8);
  position: relative;
}
@media only screen and (max-width: 900px) {
  .p-company__message {
    padding-bottom: 14rem;
  }
}
@media only screen and (min-width: 901px) {
  .p-company__message:after {
    width: 100%;
    height: 46.7rem;
    content: "";
    background-image: url("../img/company/intro_bg.png");
    background-size: cover;
    background-position: center center;
    position: absolute;
    top: 0;
    left: 0;
  }
}
.p-company__message .inner {
  max-width: 1000px;
  position: relative;
  z-index: 2;
}
.p-company__message .img01 {
  width: 24rem;
  position: absolute;
  top: 0;
  right: 0;
  transform: translate(5%, -20%);
}
.p-company__message .img01 img {
  width: 187%;
  max-width: none;
}
@media only screen and (max-width: 1099px) {
  .p-company__message .img01 {
    width: 18rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-company__message .img01 {
    width: 13.5rem;
    transform: translate(20%, -20%);
  }
}
.p-company__message .img02 {
  width: 20.9rem;
  position: absolute;
  bottom: 0;
  left: 0;
  transform: translate(-120%, 35%);
}
@media only screen and (max-width: 1099px) {
  .p-company__message .img02 {
    width: 15rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-company__message .img02 {
    width: 11.2rem;
    transform: translate(-120%, 70%);
  }
}
.p-company__message .img02 img {
  width: 214%;
  max-width: none;
}
.p-company__message .box {
  padding: 7.2rem;
  background-color: #ffffff;
  border-radius: 1.6rem;
  box-shadow: 0 0 3rem rgba(0, 0, 0, 0.05);
}
@media only screen and (max-width: 1279px) {
  .p-company__message .box {
    padding: 6rem;
  }
}
@media only screen and (max-width: 1099px) {
  .p-company__message .box {
    padding: 3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-company__message .box {
    padding: 2rem;
  }
}
.p-company__message .box .midashi01 {
  margin-bottom: 2.5em;
}
.p-company__message .box .midashi01 .ja {
  margin-top: 0.8em;
  font-size: 3.8rem;
}
@media only screen and (max-width: 780px) {
  .p-company__message .box .midashi01 .ja {
    font-size: 2.5rem;
  }
}
.p-company__message .box p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-company__message .box p {
    font-size: 1.5rem;
    text-align: left;
  }
}
.p-company__philosophy {
  margin-bottom: 11.2rem;
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy {
    margin-bottom: 6rem;
  }
}
@media only screen and (min-width: 901px) {
  .p-company__philosophy .outer {
    position: relative;
    z-index: 2;
  }
  .p-company__philosophy .outer:before {
    width: 95%;
    max-width: 1600px;
    height: 100%;
    content: "";
    background: linear-gradient(to right, #0092FF, #657CF7);
    transform: skewX(-10deg);
    transform-origin: top left;
    position: absolute;
    top: 0%;
    left: 0%;
    z-index: -1;
  }
}
@media only screen and (min-width: 901px) and (max-width: 780px) {
  .p-company__philosophy .outer:before {
    top: 2.75%;
  }
}
@media only screen and (min-width: 901px) {
  .p-company__philosophy .outer .img01 {
    width: 80%;
    max-width: 1200px;
    height: 100%;
    transform: skewX(10deg);
    transform-origin: top right;
    position: absolute;
    top: -8rem;
    right: 0;
    z-index: -2;
    overflow: hidden;
  }
  .p-company__philosophy .outer .img01 span {
    width: 108.815%;
    height: 100%;
    display: block;
    position: absolute;
    top: 0;
    left: -8.815%;
    transform: skewX(-5deg);
    overflow: hidden;
  }
  .p-company__philosophy .outer .img01 span > img, .p-company__philosophy .outer .img01 span > video {
    width: 100%;
    max-width: none;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
@media only screen and (min-width: 901px) and (max-width: 780px) {
  .p-company__philosophy .outer .img01 {
    top: -4rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-company__philosophy .outer {
    background: linear-gradient(to right, #0092FF, #657CF7);
  }
  .p-company__philosophy .outer .img01 {
    width: 114%;
    margin: 0 -7%;
  }
  .p-company__philosophy .outer .img01 span {
    width: 100%;
    height: 20rem;
    display: block;
    overflow: hidden;
  }
  .p-company__philosophy .outer .img01 span > img, .p-company__philosophy .outer .img01 span > video {
    width: 100%;
    max-width: none;
    height: 100%;
    -o-object-fit: cover;
    object-fit: cover;
  }
}
.p-company__philosophy .inner {
  padding: 8rem 0;
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy .inner {
    padding: 4rem 0;
  }
}
@media only screen and (min-width: 781px) {
  .p-company__philosophy .midashi01 {
    margin-bottom: 2em;
  }
}
.p-company__philosophy h3 {
  margin-bottom: 0.7em;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.26;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy h3 {
    font-size: 2.6rem;
  }
}
.p-company__philosophy p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.72;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-company__philosophy p {
    font-size: 1.5rem;
  }
}
.p-company__profile {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 780px) {
  .p-company__profile {
    margin-bottom: 6rem;
  }
}
.p-company__profile .inner {
  max-width: 1000px;
}
.p-company__profile .table {
  max-width: 84rem;
  margin: 5.7rem auto 8.8rem auto;
}
@media only screen and (max-width: 780px) {
  .p-company__profile .table {
    margin-bottom: 4rem;
  }
}
.p-company__profile .table table {
  width: 100%;
}
.p-company__profile .table table tbody tr td {
  padding: 3.3rem 0;
  letter-spacing: 0.06em;
  vertical-align: top;
  border-bottom: solid 1px #D5DBE2;
}
@media only screen and (max-width: 780px) {
  .p-company__profile .table table tbody tr td {
    padding: 1.8rem 0;
  }
}
.p-company__profile .table table tbody tr td:first-child {
  width: 18rem;
  padding-top: 3rem;
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-company__profile .table table tbody tr td:first-child {
    width: 30%;
    padding-top: 1.5rem;
    padding-right: 1em;
    font-size: 1.5rem;
  }
}
.p-company__profile .table table tbody tr td:last-child {
  color: #333333;
}
.p-company__profile .table table tbody tr td a {
  text-decoration: underline;
}
.p-company__profile .table table tbody tr:first-child td {
  border-top: solid 1px #D5DBE2;
}
@media only screen and (min-width: 781px) {
  .p-company__profile .access ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.p-company__profile .access ul li {
  margin-bottom: 2rem;
}
@media only screen and (min-width: 781px) {
  .p-company__profile .access ul li {
    width: 48%;
  }
}
.p-company__profile .access ul li .map {
  width: 100%;
  height: 38rem;
  margin-bottom: 1em;
}
.p-company__profile .access ul li .map iframe {
  width: 100%;
  height: 100%;
}
.p-company__profile .access ul li h3 {
  margin-bottom: 0.5em;
  font-size: 1.8rem;
  font-weight: 500;
  letter-spacing: 0.06em;
}
@media only screen and (max-width: 780px) {
  .p-company__profile .access ul li h3 {
    font-size: 1.5rem;
  }
}
.p-company__profile .access ul li p {
  letter-spacing: 0.06em;
  color: #333333;
}

.p-business__overview {
  margin-bottom: 8rem;
}
@media only screen and (min-width: 781px) {
  .p-business__overview .inner {
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-business__overview .text {
    width: 55%;
    position: relative;
    z-index: 1;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__overview .text {
    margin-bottom: 2rem;
  }
}
.p-business__overview .text .midashi01 .ja {
  margin-top: 0.7em;
}
.p-business__overview .text p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
}
@media only screen and (max-width: 780px) {
  .p-business__overview .text p {
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-business__overview .img {
    width: 50%;
    margin-right: -5%;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__overview .img {
    width: 80%;
    margin: 0 auto;
  }
}
.p-business__overview .img img {
  width: 135%;
  max-width: none;
}
@media only screen and (min-width: 781px) {
  .p-business__overview .img img {
    margin-top: -17.5%;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__overview .img img {
    margin: -17.5%;
  }
}
.p-business__provided {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 780px) {
  .p-business__provided {
    margin-bottom: 4rem;
  }
}
.p-business__provided .outer {
  width: 100%;
  position: relative;
  z-index: 2;
}
.p-business__provided .outer:before {
  width: 117.5%;
  height: 100%;
  content: "";
  background: linear-gradient(to right, #0092FF, #657CF7);
  transform: skewY(-5deg);
  transform-origin: top left;
  position: absolute;
  top: 7.5%;
  left: -8.75%;
  z-index: -1;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .outer:before {
    top: 2.75%;
  }
}
.p-business__provided .inner {
  padding: 8rem 0 12rem 0;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .inner {
    padding: 5rem 0 6rem 0;
  }
}
@media only screen and (min-width: 781px) {
  .p-business__provided .content {
    display: flex;
    justify-content: space-between;
  }
}
.p-business__provided .content dl {
  background-color: #ffffff;
  border-radius: 1.6rem;
  box-shadow: 0 0 8rem rgba(0, 0, 0, 0.2);
  overflow: hidden;
}
@media only screen and (min-width: 781px) {
  .p-business__provided .content dl {
    width: 48%;
  }
}
.p-business__provided .content dl dt {
  padding: 1em;
  font-size: 2.4rem;
  font-weight: 700;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .content dl dt {
    font-size: 1.8rem;
  }
}
.p-business__provided .content dl dd {
  padding: 2.4rem 4rem 4rem 4rem;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .content dl dd {
    padding: 1.2rem 1.5rem;
  }
}
.p-business__provided .content dl dd p {
  margin-bottom: 1em;
  font-weight: 500;
}
.p-business__provided .content dl dd ul li {
  padding: 1.6rem 1.6rem 1.6rem 5.6rem;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.27;
  border-radius: 0.8rem;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .content dl dd ul li {
    padding: 1rem 1rem 1rem 4rem;
    font-size: 1.5rem;
  }
}
.p-business__provided .content dl dd ul li + li {
  margin-top: 0.8rem;
}
.p-business__provided .content dl dd ul li:before {
  width: 2.4rem;
  height: 2.4rem;
  margin: 0 1.6rem 0 -4rem;
  content: "";
  background-size: cover;
  display: inline-block;
  vertical-align: -0.3em;
}
@media only screen and (max-width: 780px) {
  .p-business__provided .content dl dd ul li:before {
    width: 2rem;
    height: 2rem;
    margin: 0 1rem 0 -3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-business__provided .content dl:first-child {
    margin-bottom: 2rem;
  }
}
.p-business__provided .content dl:first-child dt {
  background-color: #DCD9ED;
}
.p-business__provided .content dl:first-child dd ul li {
  background-color: #F1F0F8;
}
.p-business__provided .content dl:first-child dd ul li:before {
  background-image: url("../img/icon_check02.png");
}
.p-business__provided .content dl:last-child dt {
  background-color: #CBE1F4;
}
.p-business__provided .content dl:last-child dd ul li {
  background-color: #E4EEF7;
}
.p-business__provided .content dl:last-child dd ul li:before {
  background-image: url("../img/icon_check01.png");
}
.p-business__provided .fig01 {
  width: 28.5rem;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  transform: translate(50%, 0);
}
@media only screen and (max-width: 780px) {
  .p-business__provided .fig01 {
    width: 14.25rem;
    top: 1rem;
  }
}
.p-business__provided .scroll_text {
  font-family: "Montserrat", sans-serif;
  font-size: 13rem;
  font-weight: 800;
  color: #ffffff;
  opacity: 0.18;
  position: absolute;
  top: 50%;
  left: 0;
}
.p-business__strengths {
  margin-bottom: 10rem;
}
@media only screen and (max-width: 780px) {
  .p-business__strengths {
    margin-bottom: 5rem;
  }
}
.p-business__strengths .midashi01 {
  margin-bottom: 2.5em;
}
.p-business__strengths .table table {
  width: 100%;
}
.p-business__strengths .table table tbody tr td {
  padding: 2.6rem 2.4rem;
  font-weight: 500;
  vertical-align: top;
  border: solid 1px #D5DBE2;
}
@media only screen and (max-width: 780px) {
  .p-business__strengths .table table tbody tr td {
    padding: 1.5rem;
  }
}
.p-business__strengths .table table tbody tr td:first-child {
  width: 22rem;
  padding: 2.4rem;
  font-size: 1.8rem;
  font-weight: 700;
  background-color: #EDF3F7;
  border-right: none;
}
@media only screen and (max-width: 780px) {
  .p-business__strengths .table table tbody tr td:first-child {
    width: 30%;
    padding: 1.4rem 1.5rem;
    font-size: 1.5rem;
  }
}
.p-business__strengths .table table tbody tr td:last-child {
  border-left: none;
}
.p-business__thought {
  padding-bottom: 16rem;
  background: linear-gradient(to bottom, #ffffff, #D4E7F7);
}
@media only screen and (max-width: 780px) {
  .p-business__thought {
    padding-bottom: 6rem;
  }
}
.p-business__thought .inner {
  padding-top: 6.4rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-business__thought .inner {
    padding-top: 3.2rem;
  }
}
.p-business__thought .midashi01 .ja {
  font-size: 3.8rem;
}
@media only screen and (max-width: 780px) {
  .p-business__thought .midashi01 .ja {
    font-size: 2.4rem;
  }
}
.p-business__thought .midashi01 + p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 2;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-business__thought .midashi01 + p {
    font-size: 1.5rem;
    text-align: left;
  }
}
.p-business__thought .fig01 {
  width: 18.3rem;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: -1;
  transform: translate(-50%, 25%);
}
@media only screen and (max-width: 780px) {
  .p-business__thought .fig01 {
    width: 9.15rem;
    transform: translate(-50%, 50%);
  }
}
.p-business__thought .fig02 {
  width: 25.6rem;
  position: absolute;
  top: 0;
  right: 0;
  z-index: -1;
  transform: translate(50%, 0);
}
@media only screen and (max-width: 780px) {
  .p-business__thought .fig02 {
    width: 12.8rem;
  }
}

.p-news__list {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-news__list {
    margin-bottom: 6rem;
  }
}
.p-news__list .news_list {
  margin-bottom: 10rem;
}
@media only screen and (max-width: 780px) {
  .p-news__list .news_list {
    margin-bottom: 5rem;
  }
}
.p-news__list .news_list li + li {
  margin-top: 1em;
}
.p-news__list .news_list li a {
  width: 100%;
  padding: 3.2rem 9.6rem 3.2rem 4rem;
  background-color: #F4F4F4;
  background-image: url("../img/icon_arrow01.png");
  background-repeat: no-repeat;
  background-position: calc(100% - 2.4rem) center;
  background-size: 2.4rem auto;
  border-radius: 1.6rem;
  display: block;
  overflow: hidden;
  transition: background-position 0.3s;
  letter-spacing: -0.4em;
}
.p-news__list .news_list li a > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (min-width: 781px) {
  .p-news__list .news_list li a:hover {
    background-position: calc(100% - 1.2rem) center;
  }
}
@media only screen and (max-width: 780px) {
  .p-news__list .news_list li a {
    padding: 1.6rem 5rem 1.6rem 1.6rem;
    background-position: calc(100% - 1.6rem) center;
  }
}
.p-news__list .news_list li a > * {
  vertical-align: top;
}
.p-news__list .news_list li .date {
  width: 12rem;
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  color: #9F9F9F;
}
@media only screen and (max-width: 780px) {
  .p-news__list .news_list li .date {
    width: 9rem;
    font-size: 1.3rem;
  }
}
.p-news__list .news_list li .cate {
  width: 9.6rem;
  margin-right: 4.8rem;
  margin-top: -0.1em;
  padding: 0.1em 0.1em 0.2em 0.1em;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
  background-color: #0690FE;
  border-radius: 99px;
}
@media only screen and (max-width: 780px) {
  .p-news__list .news_list li .cate {
    width: 6rem;
    margin-right: 0;
    font-size: 1.2rem;
  }
}
.p-news__list .news_list li p {
  width: calc(100% - 26.4rem);
  padding-top: 0.2em;
  font-weight: 500;
  line-height: 1.2;
}
@media only screen and (max-width: 780px) {
  .p-news__list .news_list li p {
    width: 100%;
    margin-top: 0.5em;
    padding-top: 0;
    display: block;
  }
}
.p-news__detail {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-news__detail {
    margin-bottom: 6rem;
  }
}
.p-news__detail .news_headding {
  margin-bottom: 8rem;
  padding-bottom: 8rem;
  border-bottom: solid 1px #D5DBE2;
}
@media only screen and (max-width: 780px) {
  .p-news__detail .news_headding {
    margin-bottom: 4rem;
    padding-bottom: 4rem;
  }
}
.p-news__detail .news_headding .cate span {
  margin: 0 0.5em 0.25em 0;
  padding: 0.1em 1em 0.2em 1em;
  font-weight: 500;
  text-align: center;
  color: #ffffff;
  background-color: #0690FE;
  border-radius: 99px;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-news__detail .news_headding .cate span {
    font-size: 1.2rem;
  }
}
.p-news__detail .news_headding h2 {
  margin: 0.5em 0;
  font-size: 3.4rem;
  font-weight: 700;
  line-height: 1.25;
}
@media only screen and (max-width: 780px) {
  .p-news__detail .news_headding h2 {
    font-size: 2.5rem;
  }
}
.p-news__detail .news_headding .date {
  letter-spacing: -0.4em;
}
.p-news__detail .news_headding .date > * {
  display: inline-block;
  letter-spacing: normal;
}
.p-news__detail .news_headding .date span {
  font-family: "Montserrat", sans-serif;
  font-weight: 600;
  color: #9F9F9F;
}
.p-news__detail .news_headding .date span:before {
  margin-right: 0.5em;
  content: "";
  background-size: cover;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-news__detail .news_headding .date span {
    font-size: 1.3rem;
  }
}
.p-news__detail .news_headding .date span.post_date:before {
  width: 1.2rem;
  height: 1.2rem;
  background-image: url("../img/news/post_date.png");
  vertical-align: 0;
}
.p-news__detail .news_headding .date span.update_post {
  margin-left: 1em;
}
.p-news__detail .news_headding .date span.update_post:before {
  width: 1.1rem;
  height: 1.4rem;
  background-image: url("../img/news/update_post.png");
  vertical-align: -0.1em;
}
.p-news__detail .news_headding .icatch {
  margin-top: 3rem;
  text-align: center;
}

.p-contact__form {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-contact__form {
    margin-bottom: 6rem;
  }
}
.p-contact__form .inner {
  max-width: 1000px;
}

/**Recruit site**/
.pagetitle_recruit {
  width: 100%;
  height: 30rem;
  margin-bottom: 10rem;
  padding-top: 8.5rem;
  position: relative;
  overflow: hidden;
}
@media only screen and (max-width: 780px) {
  .pagetitle_recruit {
    height: 20rem;
    margin-bottom: 5rem;
    padding-top: 6rem;
  }
}
.pagetitle_recruit:before {
  width: 100%;
  height: 100%;
  content: "";
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (min-width: 781px) {
  .pagetitle_recruit:before {
    background-image: url("../img/recruit/mv_text.png");
    background-size: auto 100%;
  }
}
@media only screen and (max-width: 780px) {
  .pagetitle_recruit:before {
    background-image: url("../img/recruit/mv_text_sp.png");
    background-size: cover;
  }
}
.pagetitle_recruit .inner {
  max-width: 1360px;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .pagetitle_recruit .midashi01 {
    text-align: left !important;
  }
}
.pagetitle_recruit .midashi01 .ja {
  font-size: 3.6rem;
}
@media only screen and (max-width: 780px) {
  .pagetitle_recruit .midashi01 .ja {
    font-size: 2.5rem;
  }
}
.pagetitle_recruit .pankuzu {
  font-size: 1.4rem;
  letter-spacing: -0.4em;
}
.pagetitle_recruit .pankuzu > * {
  display: inline-block;
  letter-spacing: normal;
}
@media only screen and (max-width: 780px) {
  .pagetitle_recruit .pankuzu {
    font-size: 1.2rem;
  }
}
.pagetitle_recruit .pankuzu a {
  color: #ffffff;
}
.pagetitle_recruit .pankuzu a:after {
  width: 0.6rem;
  height: 0.9rem;
  margin: 0 1em;
  content: "";
  background-image: url("../img/icon_arrow04.png");
  background-size: cover;
  display: inline-block;
  vertical-align: 0;
}
.pagetitle_recruit .pankuzu span {
  color: rgba(255, 255, 255, 0.5);
}

@media only screen and (min-width: 781px) {
  .p-recruit__mv {
    height: 48.75vw;
    max-height: 78.4rem;
    display: flex;
    flex-direction: row-reverse;
  }
  .p-recruit__mv .left {
    width: 35%;
  }
  .p-recruit__mv .right {
    width: 65%;
  }
}
.p-recruit__mv .left {
  background-color: #ffffff;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .left {
    padding-top: 1.6rem;
  }
}
.p-recruit__mv .left:after {
  width: 0;
  height: 0;
  margin-top: -1.5rem;
  content: "";
  border-style: solid;
  border-width: 1.5rem 0 1.5rem 3rem;
  border-color: transparent transparent transparent #ffffff;
  position: absolute;
  top: 50%;
  left: 100%;
}
.p-recruit__mv .left p {
  font-weight: 700;
  line-height: 1.45;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .left p {
    font-size: 3.1875vw;
    white-space: nowrap;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
  }
}
@media only screen and (min-width: 781px) and (min-width: 1600px) {
  .p-recruit__mv .left p {
    font-size: 5.1rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .left p {
    margin-bottom: 3.2rem;
    font-size: 2.6rem;
    text-align: center;
  }
}
.p-recruit__mv .left p em {
  font-style: normal;
  font-weight: 700;
  color: #FE730D;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .left .scroll {
    width: 5.25vw;
    margin-left: -2.625vw;
    position: absolute;
    bottom: 0;
    left: 50%;
  }
}
@media only screen and (min-width: 781px) and (min-width: 1600px) {
  .p-recruit__mv .left .scroll {
    width: 8.4rem;
    margin-left: -4.2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .left .scroll {
    width: 4.1rem;
    margin: 0 auto;
  }
}
.p-recruit__mv .right {
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .right {
    padding-top: 10rem;
    padding-bottom: 4rem;
  }
}
.p-recruit__mv .right:before {
  width: 100%;
  height: 100%;
  content: "";
  background-size: cover;
  background-position: center center;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .right:before {
    background-image: url("../img/recruit/mv_text.png");
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .right:before {
    background-image: url("../img/recruit/mv_text_sp.png");
  }
}
.p-recruit__mv .right h1 {
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .right h1 {
    position: absolute;
    top: 50%;
    left: 50%;
    z-index: 2;
    transform: translate(-50%, -50%);
  }
}
.p-recruit__mv .right h1 .en {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  display: block;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .right h1 .en {
    font-size: 5.36vw;
    white-space: nowrap;
  }
}
@media only screen and (min-width: 781px) and (min-width: 1921px) {
  .p-recruit__mv .right h1 .en {
    font-size: 10.3rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .right h1 .en {
    font-size: 5.15rem;
    line-height: 0.9;
    text-align: center;
  }
}
.p-recruit__mv .right h1 .ja {
  font-weight: 700;
}
@media only screen and (min-width: 781px) {
  .p-recruit__mv .right h1 .ja {
    font-size: 1.25vw;
  }
}
@media only screen and (min-width: 781px) and (min-width: 1600px) {
  .p-recruit__mv .right h1 .ja {
    font-size: 2rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__mv .right h1 .ja {
    margin-top: 0.5em;
    font-size: 1.6rem;
    text-align: center;
    display: block;
  }
}
.p-recruit__intro {
  background-size: cover;
  background-position: center center;
}
@media only screen and (min-width: 781px) {
  .p-recruit__intro {
    margin-bottom: 8rem;
    padding: 11rem 0;
    background-image: url("../img/recruit/intro_bg.jpg");
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro {
    margin-bottom: 4rem;
    padding: 4.4rem 0;
    background-image: url("../img/recruit/intro_bg_sp.jpg");
  }
}
.p-recruit__intro .inner {
  max-width: 1360px;
}
@media only screen and (min-width: 901px) {
  .p-recruit__intro .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 900px) {
  .p-recruit__intro .ttl {
    margin-bottom: 2.4rem;
  }
}
.p-recruit__intro .ttl h2 {
  font-family: "Montserrat", sans-serif;
  font-weight: 700;
  line-height: 1.2;
  color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-recruit__intro .ttl h2 {
    font-size: 8rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1599px) {
  .p-recruit__intro .ttl h2 {
    font-size: 6.5rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1279px) {
  .p-recruit__intro .ttl h2 {
    font-size: 5.5rem;
  }
}
@media only screen and (min-width: 781px) and (max-width: 1099px) {
  .p-recruit__intro .ttl h2 {
    font-size: 4.5rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro .ttl h2 {
    font-size: 3.8rem;
  }
}
.p-recruit__intro .box {
  padding: 3em;
  background-color: #ffffff;
}
@media only screen and (max-width: 1279px) {
  .p-recruit__intro .box {
    padding: 2em;
  }
}
.p-recruit__intro .box p {
  font-size: 1.8rem;
  line-height: 2.2;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro .box p {
    font-size: 1.4rem;
  }
}
.p-recruit__intro .box p.strong {
  margin-bottom: 1em;
  font-size: 2.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-recruit__intro .box p.strong {
    font-size: 1.6rem;
  }
}
.p-recruit__strengths {
  margin-bottom: 8rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths {
    margin-bottom: 4rem;
  }
}
.p-recruit__strengths .inner {
  max-width: 1360px;
}
@media only screen and (min-width: 781px) {
  .p-recruit__strengths .midashi02 .en {
    vertical-align: middle;
  }
  .p-recruit__strengths .midashi02 .ja {
    margin-left: 2em;
    display: inline-block;
    vertical-align: middle;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths .midashi02 {
    text-align: center;
  }
}
.p-recruit__strengths ol {
  max-width: 1224px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  position: relative;
}
.p-recruit__strengths ol:after {
  width: 30.9rem;
  height: 26.8rem;
  content: "";
  background-image: url("../img/recruit/strengths_img01.png");
  background-size: cover;
  position: absolute;
  bottom: -8rem;
  right: 0;
  z-index: 1;
}
@media only screen and (max-width: 1099px) {
  .p-recruit__strengths ol:after {
    width: 23.1rem;
    height: 20rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths ol:after {
    width: 16.1rem;
    height: 18.25rem;
    bottom: -4rem;
  }
}
.p-recruit__strengths ol li {
  text-align: center;
  position: relative;
}
@media only screen and (min-width: 901px) {
  .p-recruit__strengths ol li {
    width: 33.333%;
    border-top: solid 1px #D6D6D6;
    border-left: solid 1px #D6D6D6;
    padding: 3rem;
  }
  .p-recruit__strengths ol li:before {
    width: 3.6rem;
    height: 3.6rem;
    content: "";
    background-color: #ffffff;
    position: absolute;
    top: -1.8rem;
    left: -1.8rem;
    z-index: 1;
  }
  .p-recruit__strengths ol li:nth-child(3n) {
    border-right: solid 1px #D6D6D6;
  }
  .p-recruit__strengths ol li:nth-child(3n):after {
    width: 3.6rem;
    height: 3.6rem;
    content: "";
    background-color: #ffffff;
    position: absolute;
    top: -1.8rem;
    right: -1.8rem;
    z-index: 1;
  }
  .p-recruit__strengths ol li:nth-child(-n+3) {
    border-top: none;
  }
  .p-recruit__strengths ol li:nth-child(-n+3):before {
    content: none;
  }
  .p-recruit__strengths ol li.border-none {
    border-right: none;
  }
}
@media only screen and (max-width: 900px) {
  .p-recruit__strengths ol li {
    width: 50%;
    padding: 2.4rem 0;
    border-bottom: solid 1px #D6D6D6;
  }
  .p-recruit__strengths ol li:nth-child(2n) {
    border-left: solid 1px #D6D6D6;
  }
  .p-recruit__strengths ol li:nth-child(2n):before {
    width: 1px;
    height: 2.4rem;
    content: "";
    background-color: #ffffff;
    position: absolute;
    top: 0;
    left: -1px;
    z-index: 1;
  }
  .p-recruit__strengths ol li:nth-child(2n):after {
    width: 4rem;
    height: 4rem;
    content: "";
    background-color: #ffffff;
    position: absolute;
    bottom: -2rem;
    left: -2rem;
    z-index: 1;
  }
  .p-recruit__strengths ol li.border-none {
    border-bottom: none;
  }
}
.p-recruit__strengths ol li .num {
  font-family: "Montserrat", sans-serif;
  font-size: 3.9rem;
  font-weight: 700;
  border-bottom: solid 0.4rem #000000;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths ol li .num {
    font-size: 2.7rem;
  }
}
.p-recruit__strengths ol li .fig {
  width: 10.4rem;
  margin: 1em auto;
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths ol li .fig {
    width: 5.2rem;
    margin: 0.5em auto;
  }
}
.p-recruit__strengths ol li p {
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.6;
}
@media only screen and (max-width: 780px) {
  .p-recruit__strengths ol li p {
    font-size: 1.4rem;
  }
}
.p-recruit__interview {
  margin-bottom: 6.4rem;
  padding: 8rem 0;
  position: relative;
  overflow: hidden;
}
@media only screen and (max-width: 780px) {
  .p-recruit__interview {
    margin-bottom: 3.2rem;
    padding: 4rem 0;
  }
}
.p-recruit__interview .inner {
  max-width: 1360px;
  position: relative;
}
@media only screen and (min-width: 901px) {
  .p-recruit__interview .inner {
    display: flex;
    align-items: center;
  }
}
@media only screen and (min-width: 901px) {
  .p-recruit__interview .text {
    width: 38rem;
  }
}
@media only screen and (max-width: 900px) {
  .p-recruit__interview .text {
    margin-bottom: 3rem;
  }
  .p-recruit__interview .text .midashi02 {
    text-align: center;
  }
}
@media only screen and (min-width: 901px) {
  .p-recruit__interview .slide_area {
    width: calc(100% - 38rem);
  }
}
.p-recruit__interview .slide_area .swiper {
  position: relative;
}
.p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a {
  width: 100%;
  height: 44rem;
  display: block;
  position: relative;
  overflow: hidden;
}
.p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a > img, .p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 1099px) {
  .p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a {
    height: 33rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a {
    height: 25rem;
  }
}
.p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a:before {
  width: 100%;
  height: 60%;
  content: "";
  background: linear-gradient(to bottom, rgba(0, 0, 0, 0), rgba(0, 0, 0, 0.7));
  position: absolute;
  bottom: 0;
  left: 0;
}
.p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a p {
  width: calc(100% - 10rem);
  padding: 0 0 4rem 4rem;
  font-size: 2.6rem;
  font-weight: 700;
  line-height: 1.38;
  color: #ffffff;
  position: absolute;
  bottom: 0;
  left: 0;
  z-index: 10;
}
@media only screen and (max-width: 780px) {
  .p-recruit__interview .slide_area .swiper .swiper-wrapper .swiper-slide a p {
    width: calc(100% - 6rem);
    padding: 0 0 2rem 2rem;
    font-size: 1.6rem;
  }
}
.p-recruit__interview .slide_area .swiper .swiper-button-next {
  width: 4.8rem;
  height: 4.8rem;
  background-image: url("../img/icon_arrow03.png");
  background-size: cover;
  position: absolute;
  top: calc(100% - 7.2rem);
  left: calc(100% - 7.2rem);
  z-index: 10;
}
@media only screen and (max-width: 780px) {
  .p-recruit__interview .slide_area .swiper .swiper-button-next {
    width: 2.4rem;
    height: 2.4rem;
    top: calc(100% - 4.4rem);
    left: calc(100% - 4.4rem);
  }
}
.p-recruit__interview .slide_area .swiper .swiper-button-next:after {
  content: none;
}
@media only screen and (max-width: 900px) {
  .p-recruit__interview .slide_area .btn {
    margin-top: 3rem;
    text-align: center;
  }
}
@media only screen and (min-width: 901px) {
  .p-recruit__interview .bg_text {
    font-family: "Montserrat", sans-serif;
    font-size: 13rem;
    font-weight: 700;
    color: #ffffff;
    opacity: 0.2;
    position: absolute;
    top: 50%;
    left: 0;
    transform: translate(-75%, -50%) rotate(90deg);
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__description {
    position: relative;
    z-index: 1;
  }
  .p-recruit__description:before {
    width: 1920px;
    height: 76.8rem;
    content: "";
    background-image: url("../img/recruit/description_text.png");
    background-repeat: no-repeat;
    background-size: 23.1rem auto;
    background-position: calc(100% - 8rem) 0;
    position: absolute;
    top: -6.4rem;
    left: 0;
    z-index: -1;
  }
}
.p-recruit__description .inner {
  max-width: 1200px;
}
.p-recruit__description .midashi02:before {
  width: 0.2rem;
  height: 7.2rem;
  margin: 0 auto 0.5em auto;
  content: "";
  background-color: #000000;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .midashi02:before {
    height: 3.6rem;
  }
}
.p-recruit__description .midashi02 + p {
  margin-bottom: 2.5em;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .midashi02 + p {
    font-size: 1.5rem;
    text-align: left;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__description .job {
    max-width: 1000px;
    margin: 0 auto 9.6rem auto;
    display: flex;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__description .job li {
    width: 31.2%;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .job li {
    margin-bottom: 3rem;
  }
}
.p-recruit__description .job li .img {
  margin-bottom: 1.25em;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .job li .img {
    text-align: center;
  }
}
.p-recruit__description .job li p {
  font-size: 2rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .job li p {
    font-size: 1.6rem;
    text-align: center;
  }
}
.p-recruit__description .job li p:before {
  width: 2.2rem;
  height: 2.2rem;
  margin-right: 2.4rem;
  content: "";
  background-image: url("../img/icon_check03.png");
  background-size: cover;
  display: inline-block;
  vertical-align: -0.2em;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .job li p:before {
    width: 1.76rem;
    height: 1.76rem;
    margin-right: 1rem;
  }
}
.p-recruit__description .bg {
  padding: 7.8rem 0 6.4rem 0;
  position: relative;
  background-image: url("../img/recruit/description_bg.jpg");
  background-size: cover;
  background-position: center center;
  position: relative;
  z-index: 2;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .bg {
    padding: 4rem 0;
  }
}
.p-recruit__description .bg:before {
  width: 0;
  height: 0;
  margin-left: -8.4rem;
  content: "";
  border-style: solid;
  border-width: 3rem 8.4rem 0 8.4rem;
  border-color: #ffffff transparent transparent transparent;
  position: absolute;
  top: 0;
  left: 50%;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .bg:before {
    margin-left: -4.2rem;
    border-width: 1.5rem 4.2rem 0 4.2rem;
  }
}
@media only screen and (min-width: 901px) {
  .p-recruit__description .bg .inner {
    display: flex;
    justify-content: space-between;
  }
}
.p-recruit__description .bg dl {
  background-color: #ffffff;
}
@media only screen and (min-width: 901px) {
  .p-recruit__description .bg dl {
    width: 48%;
  }
}
@media only screen and (max-width: 900px) {
  .p-recruit__description .bg dl.tec {
    margin-bottom: 3rem;
  }
}
.p-recruit__description .bg dl.tec dt span {
  background-color: #F2B40C;
}
.p-recruit__description .bg dl.tec dt span:before, .p-recruit__description .bg dl.tec dt span:after {
  background-color: #F2B40C;
}
@media only screen and (min-width: 781px) {
  .p-recruit__description .bg dl.tec dd ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__description .bg dl.tec dd ul li {
    width: 47.6%;
  }
}
.p-recruit__description .bg dl.tec dd ul li:before {
  background-image: url("../img/icon_check04.png");
}
.p-recruit__description .bg dl.pos dt span {
  background-color: #DE661A;
}
.p-recruit__description .bg dl.pos dt span:before, .p-recruit__description .bg dl.pos dt span:after {
  background-color: #DE661A;
}
.p-recruit__description .bg dl.pos dd ul li:before {
  background-image: url("../img/icon_check03.png");
}
.p-recruit__description .bg dl dt {
  text-align: center;
}
.p-recruit__description .bg dl dt span {
  width: 80%;
  max-width: 38rem;
  padding: 0.3em;
  font-size: 2.6rem;
  font-weight: 700;
  text-align: center;
  color: #ffffff;
  position: relative;
  display: inline-block;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .bg dl dt span {
    font-size: 2rem;
  }
}
.p-recruit__description .bg dl dt span:before, .p-recruit__description .bg dl dt span:after {
  width: 0.7em;
  height: 100%;
  content: "";
  position: absolute;
  top: 0;
}
.p-recruit__description .bg dl dt span:before {
  right: 100%;
  transform: skewX(10deg) translateX(50%);
}
.p-recruit__description .bg dl dt span:after {
  left: 100%;
  transform: skewX(-10deg) translateX(-50%);
}
.p-recruit__description .bg dl dd {
  padding: 4rem 4rem 2.4rem 4rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .bg dl dd {
    padding: 2rem 2rem 1rem 2rem;
  }
}
.p-recruit__description .bg dl dd ul li {
  margin-bottom: 0.8em;
  padding: 1.2em 1.2em 1.2em 3.8em;
  font-size: 1.8rem;
  font-weight: 700;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .p-recruit__description .bg dl dd ul li {
    font-size: 1.4rem;
  }
}
.p-recruit__description .bg dl dd ul li:before {
  width: 1.2em;
  height: 1.2em;
  margin: 0 1.3em 0 -2.5em;
  content: "";
  background-size: cover;
  display: inline-block;
  vertical-align: -0.2em;
}
.p-recruit__description .bg dl dd ul li.noicon {
  padding: 1.2em 0;
  text-align: center;
  background-color: transparent;
}
.p-recruit__description .bg dl dd ul li.noicon:before {
  content: none;
}
.p-recruit__flow {
  margin-bottom: 14rem;
  padding-top: 24rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-recruit__flow {
    margin-bottom: 7rem;
    padding-top: 12rem;
  }
}
.p-recruit__flow .scroll_text {
  width: 100%;
  position: absolute;
  top: 2.4rem;
  left: 0;
  z-index: -1;
}
@media only screen and (max-width: 780px) {
  .p-recruit__flow .scroll_text {
    top: 1.2rem;
  }
}
.p-recruit__flow .scroll_text span {
  font-family: "Montserrat", sans-serif;
  font-size: 11.9rem;
  font-weight: 700;
  color: #F2F2F2;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-recruit__flow .scroll_text span {
    font-size: 6rem;
  }
}
.p-recruit__flow .inner {
  max-width: 1200px;
}
.p-recruit__flow .midashi02 {
  margin-bottom: 3.5em;
}
@media only screen and (max-width: 780px) {
  .p-recruit__flow .flow_img {
    max-width: 23rem;
  }
}
.p-recruit__numbers {
  margin-bottom: 9.6rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__numbers {
    margin-bottom: 4.8rem;
  }
}
.p-recruit__numbers .outer {
  width: 92%;
  max-width: 1760px;
  margin: 0 auto;
  padding: 4rem;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .p-recruit__numbers .outer {
    width: 100%;
    padding: 2rem;
  }
}
.p-recruit__numbers .outer .inner {
  width: 100%;
  max-width: none;
}
.p-recruit__numbers .midashi02 {
  margin-top: -7.6rem;
  margin-bottom: 7rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__numbers .midashi02 {
    margin-top: -4rem;
    margin-bottom: 3rem;
  }
}
.p-recruit__numbers .midashi02:before {
  width: 0.2rem;
  height: 7.2rem;
  margin: 0 auto 0.5em auto;
  content: "";
  background-color: #000000;
  display: block;
}
@media only screen and (max-width: 780px) {
  .p-recruit__numbers .midashi02:before {
    height: 3.6rem;
  }
}
.p-recruit__career {
  margin-bottom: 7rem;
  padding: 7rem 0 3rem 0;
}
@media only screen and (max-width: 780px) {
  .p-recruit__career {
    margin-bottom: 4rem;
    padding: 4rem 0 2rem 0;
  }
}
.p-recruit__career .inner {
  max-width: 1200px;
}
@media only screen and (min-width: 781px) {
  .p-recruit__career .headding {
    margin-bottom: 5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__career .headding {
    margin-bottom: 3rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__career .headding .midashi02 {
    margin-bottom: 0;
  }
}
.p-recruit__career .headding p {
  font-size: 1.8rem;
  font-weight: 500;
  color: #ffffff;
}
@media only screen and (max-width: 780px) {
  .p-recruit__career .headding p {
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__career ul {
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
  }
}
.p-recruit__career ul li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-recruit__career ul li {
    width: 48%;
    margin-bottom: 4rem;
    padding: 4rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__career ul li {
    margin-bottom: 2rem;
    padding: 2rem;
  }
}
.p-recruit__career ul li .img {
  width: 100%;
  height: 25rem;
  overflow: hidden;
}
.p-recruit__career ul li .img > img, .p-recruit__career ul li .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-recruit__career ul li .img {
    height: 20rem;
  }
}
.p-recruit__career ul li p {
  margin-top: 1em;
  font-size: 2.2rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-recruit__career ul li p {
    font-size: 1.6rem;
  }
}
.p-recruit__career ul li p span {
  font-size: 0.68em;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-recruit__career ul li p span {
    display: block;
  }
}
.p-recruit__benefits {
  margin-bottom: 10rem;
  padding-bottom: 18.5rem;
  position: relative;
  z-index: 1;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits {
    margin-bottom: 5rem;
    padding-bottom: 9rem;
  }
}
.p-recruit__benefits .outer {
  width: 92%;
  max-width: 1760px;
  margin: 0 auto;
  padding: 11.6rem 4rem 4rem 4rem;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits .outer {
    width: 100%;
    padding: 6rem 2rem 2rem 2rem;
  }
}
.p-recruit__benefits .outer .inner {
  width: 100%;
  max-width: 1360px;
  margin: 0 auto;
  padding: 0 8rem;
  background-color: #ffffff;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits .outer .inner {
    padding: 2rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-recruit__benefits .midashi02 {
    margin-bottom: 1.5rem;
    position: relative;
    top: -3.5rem;
  }
}
.p-recruit__benefits .midashi02 + p {
  margin-bottom: 2em;
  font-size: 3.2rem;
  font-weight: 700;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits .midashi02 + p {
    margin-bottom: 1em;
    font-size: 2.2rem;
  }
}
.p-recruit__benefits .midashi02 + p em {
  font-style: normal;
  font-weight: 700;
  color: #DE661A;
}
@media only screen and (min-width: 781px) {
  .p-recruit__benefits ul {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
}
.p-recruit__benefits ul li {
  text-align: center;
}
@media only screen and (min-width: 781px) {
  .p-recruit__benefits ul li {
    width: 32%;
    margin: 0 2% 5rem 0;
  }
  .p-recruit__benefits ul li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits ul li {
    margin-bottom: 2rem;
  }
}
.p-recruit__benefits ul li .img {
  width: 100%;
  height: 25rem;
  overflow: hidden;
}
.p-recruit__benefits ul li .img > img, .p-recruit__benefits ul li .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits ul li .img {
    height: 20rem;
  }
}
.p-recruit__benefits ul li h3 {
  margin: 1em 0 0.2em 0;
  font-size: 2.4rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits ul li h3 {
    font-size: 1.6rem;
  }
}
.p-recruit__benefits ul li p {
  margin-top: 1em;
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits ul li p {
    font-size: 1.4rem;
  }
}
.p-recruit__benefits .img01 {
  width: 22rem;
  position: absolute;
  right: -4rem;
  bottom: -4rem;
}
.p-recruit__benefits .img02 {
  width: 27.1rem;
  position: absolute;
  left: -4rem;
  bottom: -4rem;
}
.p-recruit__benefits .scroll_text {
  font-family: "Montserrat", sans-serif;
  font-size: 11.9rem;
  font-weight: 700;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-recruit__benefits .scroll_text {
    font-size: 6rem;
  }
}
.p-recruit__culture {
  margin-bottom: 11.2rem;
}
@media only screen and (max-width: 780px) {
  .p-recruit__culture {
    margin-bottom: 6rem;
  }
}
.p-recruit__culture .inner {
  max-width: 1200px;
}
@media only screen and (min-width: 781px) {
  .p-recruit__culture .midashi02 .en {
    vertical-align: middle;
  }
  .p-recruit__culture .midashi02 .ja {
    margin-left: 2em;
    display: inline-block;
    vertical-align: middle;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__culture .midashi02 {
    text-align: center;
  }
}
@media only screen and (min-width: 1280px) {
  .p-recruit__culture .slide_area {
    width: 120%;
    margin: 0 -10%;
  }
}
@media only screen and (max-width: 480px) {
  .p-recruit__culture .slide_area {
    width: 90%;
    margin: 0 0 0 auto;
  }
}
@media only screen and (max-width: 480px) {
  .p-recruit__culture .slide_area .swiper {
    overflow: visible;
  }
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide {
  height: 35rem;
  padding-top: 3rem;
  overflow: hidden;
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide > img, .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 1279px) {
  .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide {
    height: 32rem;
  }
}
@media only screen and (max-width: 1099px) {
  .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide {
    height: 30rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide {
    height: 25rem;
    padding-top: 4rem;
  }
}
@media only screen and (max-width: 480px) {
  .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide {
    height: 20rem;
  }
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide p {
  width: 100%;
  text-align: center;
  position: absolute;
  top: 0;
  left: 0;
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide p span {
  width: 86%;
  padding: 0.6em;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.26;
  color: #ffffff;
  background-color: #000000;
  border-radius: 99px;
  display: inline-block;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide p span {
    font-size: 1.5rem;
    border-radius: 1.5rem;
  }
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide p span:after {
  width: 0;
  height: 0;
  margin-left: -1.1rem;
  content: "";
  border-style: solid;
  border-width: 1.5rem 1.1rem 0 1.1rem;
  border-color: #000000 transparent transparent transparent;
  position: absolute;
  top: 100%;
  left: 50%;
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide:nth-child(odd) span {
  background-color: #DE661A;
}
.p-recruit__culture .slide_area .swiper .swiper-wrapper .swiper-slide:nth-child(odd) span:after {
  border-color: #DE661A transparent transparent transparent;
}

.p-appication__detail {
  margin-bottom: 5rem;
  padding-bottom: 20rem;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail {
    margin-bottom: 3rem;
    padding-bottom: 10rem;
  }
}
.p-appication__detail .inner {
  max-width: 1200px;
}
.p-appication__detail .table {
  max-width: 1000px;
  margin: 0 auto;
}
.p-appication__detail .table table {
  width: 100%;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table {
    display: block;
  }
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody {
    display: block;
  }
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr {
    display: block;
  }
}
.p-appication__detail .table table tbody tr td {
  padding: 3.3rem;
  letter-spacing: 0.06em;
  vertical-align: top;
  border-bottom: solid 1px #D5DBE2;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td {
    padding: 2rem;
    display: block;
  }
}
.p-appication__detail .table table tbody tr td:first-child {
  width: 23rem;
  padding: 3rem 2rem;
  font-size: 1.8rem;
  font-weight: 500;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td:first-child {
    width: auto;
    padding: 2rem 1rem;
    font-size: 1.5rem;
    border-bottom: none;
  }
}
.p-appication__detail .table table tbody tr td:last-child {
  color: #333333;
}
.p-appication__detail .table table tbody tr td > *:last-child {
  margin-bottom: 0 !important;
}
.p-appication__detail .table table tbody tr td h3 {
  margin-bottom: 0.8em;
  padding: 0.5em 1em;
  font-size: 2.2rem;
  font-weight: 700;
  background-color: #F4F4F4;
  border-left: solid 0.5rem #FFBA00;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td h3 {
    font-size: 1.8rem;
  }
}
.p-appication__detail .table table tbody tr td p {
  margin-bottom: 1em;
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td p {
    font-size: 1.5rem;
  }
}
.p-appication__detail .table table tbody tr td dl {
  background-color: #ffffff;
  border-radius: 1rem;
  box-shadow: 0 0 3rem rgba(0, 0, 0, 0.16);
  overflow: hidden;
}
.p-appication__detail .table table tbody tr td dl + dl {
  margin-top: 3rem;
}
.p-appication__detail .table table tbody tr td dl dt {
  padding: 0.5em 2rem;
  font-size: 2rem;
  font-weight: 700;
  color: #ffffff;
  background-color: #FE730D;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td dl dt {
    font-size: 1.8rem;
  }
}
.p-appication__detail .table table tbody tr td dl dd {
  padding: 2rem;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .table table tbody tr td dl dd {
    padding: 1.2rem 1.5rem;
  }
}
.p-appication__detail .table table tbody tr td dl dd p {
  font-size: 1.6rem;
  font-weight: 500;
}
.p-appication__detail .table table tbody tr td a {
  text-decoration: underline;
}
@media only screen and (min-width: 781px) {
  .p-appication__detail .table table tbody tr:first-child td {
    border-top: solid 1px #D5DBE2;
  }
}
.p-appication__detail .scroll_text {
  font-family: "Montserrat", sans-serif;
  font-size: 11.9rem;
  font-weight: 700;
  position: absolute;
  bottom: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-appication__detail .scroll_text {
    font-size: 6rem;
  }
}
.p-appication__career {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-appication__career {
    margin-bottom: 6rem;
  }
}
.p-appication__career .outer {
  width: 92%;
  max-width: 1760px;
  margin: 0 auto;
  padding: 11.6rem 4rem 4rem 4rem;
  background-color: #F8F8F8;
}
@media only screen and (max-width: 780px) {
  .p-appication__career .outer {
    width: 100%;
    padding: 6rem 2rem 2rem 2rem;
  }
}
.p-appication__career .outer .inner {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
}
.p-appication__career .midashi02 {
  margin-bottom: 2.5em;
}
.p-appication__career ul > li {
  background-color: #ffffff;
}
@media only screen and (min-width: 781px) {
  .p-appication__career ul > li {
    padding: 3em;
    display: flex;
  }
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li {
    padding: 2em;
  }
}
.p-appication__career ul > li + li {
  margin-top: 2em;
}
@media only screen and (min-width: 781px) {
  .p-appication__career ul > li .photo {
    width: 16rem;
    margin-right: 5rem;
    text-align: center;
  }
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .photo {
    margin-bottom: 3rem;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
.p-appication__career ul > li .photo .img {
  width: 16rem;
  height: 16rem;
  border-radius: 50%;
  overflow: hidden;
}
.p-appication__career ul > li .photo .img > img, .p-appication__career ul > li .photo .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .photo .img {
    width: 10rem;
    height: 10rem;
  }
}
.p-appication__career ul > li .photo .name {
  margin-top: 0.5em;
  font-size: 1.8rem;
  font-weight: 500;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .photo .name {
    padding-left: 2em;
    font-size: 1.5rem;
  }
}
@media only screen and (min-width: 781px) {
  .p-appication__career ul > li .biography {
    width: calc(100% - 21rem);
  }
}
.p-appication__career ul > li .biography ol {
  counter-reset: num;
  position: relative;
}
.p-appication__career ul > li .biography ol:before {
  width: 1px;
  height: 110%;
  content: "";
  background-color: #000000;
  position: absolute;
  top: -5%;
  left: 6rem;
}
.p-appication__career ul > li .biography ol li {
  padding-top: 0.75rem;
  padding-left: 9rem;
  counter-increment: num;
  position: relative;
}
.p-appication__career ul > li .biography ol li + li {
  margin-top: 2em;
}
.p-appication__career ul > li .biography ol li:before {
  content: counter(num, decimal-leading-zero);
  font-family: "Montserrat", sans-serif;
  font-size: 3rem;
  font-weight: 600;
  position: absolute;
  top: 0;
  left: 0;
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .biography ol li:before {
    font-size: 2.5rem;
  }
}
.p-appication__career ul > li .biography ol li:after {
  width: 1.5rem;
  height: 1.5rem;
  content: "";
  background-color: #000000;
  border-radius: 50%;
  position: absolute;
  top: 1.5rem;
  left: 5.25rem;
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .biography ol li:after {
    top: 1.25rem;
  }
}
.p-appication__career ul > li .biography ol li h3 {
  margin-bottom: 0.5em;
  font-size: 1.8rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-appication__career ul > li .biography ol li h3 {
    font-size: 1.5rem;
  }
}
.p-appication__career ul > li .biography ol li p {
  font-weight: 500;
}
.p-appication__career .btn {
  margin-top: 10rem;
  text-align: center;
}
@media only screen and (max-width: 780px) {
  .p-appication__career .btn {
    margin-top: 5rem;
  }
}

.p-interview__list {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-interview__list {
    margin-bottom: 6rem;
  }
}
.p-interview__list .inner {
  max-width: 1360px;
}
.p-interview__list .interview_list {
  margin-bottom: 10rem;
  display: flex;
  flex-wrap: wrap;
}
@media only screen and (max-width: 780px) {
  .p-interview__list .interview_list {
    margin-bottom: 5rem;
  }
}
@media only screen and (min-width: 1100px) {
  .p-interview__list .interview_list li {
    width: 18%;
    margin: 0 2.5% 4% 0;
  }
  .p-interview__list .interview_list li:nth-child(5n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 1099px) and (min-width: 901px) {
  .p-interview__list .interview_list li {
    width: 24%;
    margin: 0 1.3% 4% 0;
  }
  .p-interview__list .interview_list li:nth-child(4n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 900px) and (min-width: 481px) {
  .p-interview__list .interview_list li {
    width: 32%;
    margin: 0 2% 4% 0;
  }
  .p-interview__list .interview_list li:nth-child(3n) {
    margin-right: 0;
  }
}
@media only screen and (max-width: 480px) {
  .p-interview__list .interview_list li {
    width: 48%;
    margin: 0 4% 4% 0;
  }
  .p-interview__list .interview_list li:nth-child(2n) {
    margin-right: 0;
  }
}
.p-interview__list .interview_list li a {
  display: block;
}
.p-interview__list .interview_list li a:hover .text h3 {
  color: #DE661A;
}
.p-interview__list .interview_list li .img {
  height: 24rem;
  overflow: hidden;
}
.p-interview__list .interview_list li .img > img, .p-interview__list .interview_list li .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (max-width: 780px) {
  .p-interview__list .interview_list li .img {
    height: 16.5rem;
  }
}
.p-interview__list .interview_list li .text h3 {
  margin: 0.8em 0;
  font-size: 1.8rem;
  font-weight: 500;
}
@media only screen and (max-width: 780px) {
  .p-interview__list .interview_list li .text h3 {
    font-size: 1.5rem;
  }
}
.p-interview__list .interview_list li .text .meta {
  font-size: 1rem;
  font-weight: 500;
}
.p-interview__detail {
  margin-bottom: 11rem;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail {
    margin-bottom: 6rem;
  }
}
.p-interview__detail .inner {
  max-width: 1200px;
}
@media only screen and (min-width: 1100px) {
  .p-interview__detail .headding {
    margin-bottom: 11rem;
    display: flex;
  }
}
@media only screen and (max-width: 1099px) {
  .p-interview__detail .headding {
    margin-bottom: 6rem;
  }
}
.p-interview__detail .headding .img {
  overflow: hidden;
}
.p-interview__detail .headding .img > img, .p-interview__detail .headding .img > video {
  width: 100%;
  max-width: none;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media only screen and (min-width: 1100px) {
  .p-interview__detail .headding .img {
    width: 45%;
  }
}
@media only screen and (max-width: 1099px) {
  .p-interview__detail .headding .img {
    width: 100%;
    height: 35rem;
  }
}
@media only screen and (max-width: 1099px) and (max-width: 780px) {
  .p-interview__detail .headding .img {
    height: 25rem;
  }
}
.p-interview__detail .headding .text {
  color: #ffffff;
}
@media only screen and (min-width: 1100px) {
  .p-interview__detail .headding .text {
    width: 55%;
    padding: 14rem 8rem;
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 1099px) {
  .p-interview__detail .headding .text {
    width: 100%;
    padding: 4rem;
  }
}
@media only screen and (max-width: 1099px) and (max-width: 780px) {
  .p-interview__detail .headding .text {
    padding: 3rem 2rem;
  }
}
.p-interview__detail .headding .text h2 {
  font-size: 3.6rem;
  font-weight: 700;
  line-height: 1.25;
}
@media only screen and (min-width: 1100px) {
  .p-interview__detail .headding .text h2 {
    max-width: 72rem;
  }
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .headding .text h2 {
    font-size: 2.4rem;
  }
}
.p-interview__detail .headding .text .meta {
  margin-top: 1em;
  font-weight: 500;
}
.p-interview__detail .interview_contents + .interview_contents {
  margin-top: 10rem;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents + .interview_contents {
    margin-top: 5rem;
  }
}
.p-interview__detail .interview_contents .question {
  max-width: 1000px;
  margin: 0 auto 2.5rem auto;
  position: relative;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .question {
    margin-bottom: 1.5rem;
  }
}
@media only screen and (min-width: 1100px) {
  .p-interview__detail .interview_contents .question:before {
    font-family: "Montserrat", sans-serif;
    font-size: 2rem;
    font-weight: 600;
    content: "Staff Interview";
    white-space: nowrap;
    color: #D5DBE2;
    position: absolute;
    top: 1rem;
    left: -3%;
    transform-origin: left top;
    transform: rotate(90deg);
  }
}
.p-interview__detail .interview_contents .question .num {
  font-family: "Montserrat", sans-serif;
  font-size: 4rem;
  font-weight: 700;
  font-style: italic;
  color: #DE661A;
  display: inline-block;
  vertical-align: middle;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .question .num {
    font-size: 2.4rem;
  }
}
.p-interview__detail .interview_contents .question h3 {
  margin-left: 1em;
  font-size: 1.8rem;
  font-weight: 500;
  line-height: 1.25;
  display: inline-block;
  vertical-align: middle;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .question h3 {
    font-size: 1.5rem;
  }
}
.p-interview__detail .interview_contents .answer {
  max-width: 1000px;
  margin: 0 auto;
}
.p-interview__detail .interview_contents .answer h4 {
  margin-bottom: 0.6em;
  font-size: 4.4rem;
  font-weight: 700;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .answer h4 {
    font-size: 2.4rem;
  }
}
.p-interview__detail .interview_contents .answer p {
  line-height: 2.5;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .answer p {
    line-height: 1.8;
  }
}
.p-interview__detail .interview_contents .img {
  width: 100%;
  margin-top: 4rem;
}
@media only screen and (max-width: 780px) {
  .p-interview__detail .interview_contents .img {
    margin-top: 2rem;
  }
}
.p-interview__detail .interview_contents .img img {
  width: 100%;
}

.p-privacy__content .block {
  margin-bottom: 3em;
}
.p-privacy__content h3 {
  margin-bottom: 0.5em;
  font-size: 2.2rem;
  font-weight: 700;
}
.p-privacy__content h4 {
  margin-bottom: 0.5em;
  font-size: 2rem;
  font-weight: 500;
}
.p-privacy__content h5 {
  font-weight: 500;
}
.p-privacy__content p, .p-privacy__content ol, .p-privacy__content ul {
  margin-bottom: 1.5em;
}
.p-privacy__content p + h4, .p-privacy__content ol + h4, .p-privacy__content ul + h4 {
  margin-top: 1em;
}
.p-privacy__content ol {
  padding-left: 1em;
  list-style: decimal outside;
}
.p-privacy__content ol > li {
  margin-bottom: 0.5em;
}
.p-privacy__content ol > li:last-child {
  margin-bottom: 0;
}
.p-privacy__content ul {
  padding-left: 1em;
  list-style: disc outside;
}
.p-privacy__content ul > li {
  margin-bottom: 0.5em;
}
.p-privacy__content ul > li:last-child {
  margin-bottom: 0;
}

/****************************************************
 * 6.装飾
 ****************************************************/
.underline {
  text-decoration: underline;
}

.bold {
  font-weight: 700;
}

/****************************************************
 * 7.印刷用調整
 ****************************************************/
@media print {
  @page {
    /* A4縦サイズ */
    size: 210mm 297mm;
  }
  html {
    font-size: 10pt !important;
  }
  body {
    margin: 0 !important;
    padding: 0 !important;
  }
  * {
    -webkit-print-color-adjust: exact;
  }
  .container {
    padding: 0 !important;
  }
  #header {
    position: static !important;
  }
  img {
    display: block !important;
  }
}