@charset "UTF-8";
/*--------------------------------------------------------------
Foundation
--------------------------------------------------------------*/
@import url("https://fonts.googleapis.com/css2?family=Montserrat:wght@400;600&display=swap");
html, body, div, span, applet, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
a, abbr, acronym, address, big, cite, code,
del, dfn, b, em, i, font, ins, kbd, q, s, samp,
small, strike, strong, sub, sup, tt, var, mark,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend, details,
table, caption, tbody, tfoot, thead, tr, th, td, figure, figcaption,
button, input, textarea, select, i {
  border: 0;
  font-style: inherit;
  font-weight: inherit;
  font-size: inherit;
  line-height: inherit;
  font-family: inherit;
  letter-spacing: inherit;
  color: inherit;
  margin: 0;
  outline: 0;
  padding: 0;
  vertical-align: baseline;
}

html {
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  font-size: 10px;
  scroll-behavior: smooth;
}

@media screen and (min-width: 768px) and (max-width: 1300px) {
  html {
    font-size: calc(100vw * 10 / 1300);
  }
}

@media screen and (max-width: 375px) {
  html {
    font-size: calc(100vw * 10 / 375);
  }
}

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

body {
  font-size: 1.6rem;
  line-height: 1.6;
  background: #fff;
  color: #0F0F0F;
  overflow-x: hidden;
  overflow-y: scroll;
  font-family: "Noto Sans JP", sans-serif;
}

ul, li {
  list-style: none;
}

table {
  border-collapse: collapse;
  width: 100%;
}

a:hover,
a:active,
a:focus {
  outline: 0;
}

a {
  backface-visibility: hidden;
  transition: .2s ease-in;
  transition-property: opacity, color, border, background, transform, box-shadow;
  opacity: 1;
  line-height: inherit;
}

img {
  vertical-align: middle;
}

img,
input[type="image"] {
  border: 0;
  height: auto;
  max-width: 100%;
}

input[type="submit"], input[type="button"], button {
  cursor: pointer;
  -webkit-appearance: none;
  border-radius: 0;
  font-size: inherit;
  letter-spacing: inherit;
  background: none;
}

strong {
  font-weight: bold;
}

a {
  text-decoration: none;
}

@media screen and (min-width: 768px) {
  a:hover,
  input[type="image"]:hover {
    opacity: 0.7;
  }
}

main {
  overflow: hidden;
}

.m_ft {
  font-family: "Zen Old Mincho", serif;
}

.ft_e {
  font-family: "Poppins", sans-serif;
}

/*--------------------------------------------------------------
Component
--------------------------------------------------------------*/
.evt {
  visibility: hidden;
}

.evt.done {
  visibility: visible;
}

.c_anchor {
  position: absolute;
  width: 100%;
  left: 0;
  margin-top: -8.6rem;
}

@media screen and (min-width: 768px) {
  body:has(#header.rec) .c_anchor {
    margin-top: -12rem;
  }
}

@media screen and (max-width: 767px) {
  .c_anchor {
    margin-top: -5rem;
  }
}

.c_btn.large a {
  height: 5rem;
}

@media screen and (min-width: 768px) {
  .c_btn.large a {
    min-width: 34.7rem;
  }
}

.c_btn a, .c_btn i {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 500;
  border: solid 1px #D0121B;
  background: #fff url(../img/arrow-right01.svg) no-repeat calc(100% - 1rem) center/1.6rem;
  border-radius: 3em;
  color: #D0121B;
  min-width: 22rem;
  height: 4rem;
  font-size: 1.4rem;
  max-width: 100%;
}

.c_btn a.b, .c_btn i.b {
  background-image: url(../img/arrow-left01.svg);
  background-position: 1rem center;
}

@media screen and (min-width: 768px) {
  .c_btn a.b:hover, .c_btn i.b:hover {
    background-image: url(../img/arrow-left01-b.svg);
  }
}

@media screen and (max-width: 767px) {
  .c_btn a, .c_btn i {
    width: 100%;
    height: 5rem;
    font-size: 1.6rem;
    background-position: calc(100% - 1.6rem);
  }
}

@media screen and (min-width: 768px) {
  .c_btn a:hover, .c_btn i:hover {
    color: #fff;
    background-color: #D0121B;
    background-image: url(../img/arrow-right04.svg);
    opacity: 1;
  }
}

.c_btn a {
  padding: 0 4em;
}

.c_btn i {
  transition: .2s ease-in;
  transition-property: opacity, color, border, background, transform, box-shadow;
  padding: 0 2em;
}

.c_more em {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 500;
  border: solid 1px #D0121B;
  background: #fff url(../img/arrow-down02.svg) no-repeat calc(100% - 1rem) center/1.6rem;
  border-radius: 3em;
  color: #D0121B;
  min-width: 22rem;
  height: 4rem;
  padding: 0 3em;
  font-size: 1.4rem;
  cursor: pointer;
}

@media screen and (max-width: 767px) {
  .c_more em {
    width: 100%;
    height: 5rem;
    font-size: 1.6rem;
    background-position: calc(100% - 1.6rem);
  }
}

@media screen and (min-width: 768px) {
  .c_more em {
    transition: .3s;
    transition-property: opacity, color, border, background, transform, box-shadow;
  }
  .c_more em:hover {
    color: #fff;
    background-color: #D0121B;
    background-image: url(../img/arrow-down03-w.svg);
    opacity: 1;
  }
}

.c_more + .more {
  display: none;
}

.c_more.open {
  display: none;
}

.c_more.open + .more {
  display: block;
}

.c_ttl {
  font-size: 4.4rem;
  font-weight: bold;
  margin-bottom: 6rem;
}

@media screen and (max-width: 767px) {
  .c_ttl {
    font-size: 4rem;
  }
}

.c_ttl p {
  color: #D0121B;
  font-weight: 500;
  font-size: 2.2rem;
  font-family: "Poppins", sans-serif;
}

@media screen and (max-width: 767px) {
  .c_ttl p {
    margin-top: .25em;
  }
}

.scroll_move .move {
  position: relative;
}

.c_cta {
  background: url(../img/bnr-contact-bg.png) no-repeat 50%/cover;
  height: 35rem;
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  color: #fff;
  margin: 6rem 0;
}

@media screen and (min-width: 768px) {
  .c_cta {
    height: 45rem;
  }
  .c_cta .u_inner {
    width: 116rem;
  }
}

.c_cta dl {
  background: url(../img/ico-mail.svg) no-repeat right center/15rem;
}

@media screen and (max-width: 767px) {
  .c_cta dl {
    background-position: right bottom;
    background-size: 7.5rem;
    padding: 6rem 0 9rem;
  }
}

.c_cta dt {
  font-size: 4.4rem;
  font-weight: bold;
  margin-bottom: 1em;
}

@media screen and (max-width: 767px) {
  .c_cta dt {
    font-size: 3.3rem;
  }
}

.c_cta dt i {
  display: block;
  font-family: "Poppins", sans-serif;
  font-size: .5em;
  font-weight: 500;
}

.c_cta dd {
  font-weight: 500;
}

.c_share {
  margin: 6rem 0;
  display: flex;
  gap: 2rem 6rem;
  background-image: repeating-linear-gradient(90deg, #0F0F0F, #0F0F0F 1px, transparent 1px, transparent 1rem), repeating-linear-gradient(90deg, #0F0F0F, #0F0F0F 1px, transparent 1px, transparent 1rem);
  background-position: left top, left bottom;
  background-repeat: repeat-x, repeat-x;
  background-size: 100% 1px, 100% 1px;
  padding: 2.5rem 2rem;
}

@media screen and (max-width: 767px) {
  .c_share {
    flex-direction: column;
  }
}

.c_share dt {
  font-weight: bold;
}

.c_share ul {
  display: flex;
  gap: 1rem 2rem;
  align-items: center;
}

@media screen and (max-width: 767px) {
  .c_share ul {
    flex-wrap: wrap;
  }
}

.c_share button {
  font-size: 1.2rem;
  background: #EEEEEE url(../img/ico-link.svg) no-repeat 1.5em center/1em;
  border-radius: 3em;
  height: 3rem;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 1.5em 0 3.6em;
  font-weight: 500;
}

.c_share a {
  display: block;
}

.c_toc {
  background: #F6F6F6;
  padding: 4.5rem 4rem 4rem;
}

.c_toc .ttl {
  font-weight: bold;
  line-height: 1;
  border-left: solid 0.15em #D0121B;
  font-size: 2rem;
  padding-left: .6em;
  margin-bottom: 1.2em;
}

.c_toc ul {
  counter-reset: item;
}

.c_toc ul ul {
  counter-reset: item2;
  margin: .4em 0 .5em;
}

.c_toc li {
  position: relative;
  padding-left: 1.5em;
  counter-increment: item;
}

.c_toc li + li {
  margin-top: .4em;
}

.c_toc li:before {
  content: counter(item) ".";
  position: absolute;
  left: 0;
  font-family: "Poppins", sans-serif;
  color: #D0121B;
  font-size: 1.8rem;
}

.c_toc li li {
  counter-increment: item2;
  font-size: 1.4rem;
}

.c_toc li li + li {
  margin-top: .2em;
}

.c_toc li li:before {
  content: counter(item2, lower-alpha) ".";
  color: #A29069;
  font-size: 1.6rem;
}

.animated {
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
  -webkit-animation-fill-mode: both;
  animation-fill-mode: both;
}

@-webkit-keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3rem, 0);
    transform: translate3d(0, 3rem, 0);
  }
  30% {
    opacity: .5;
  }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

@keyframes fadeInUp {
  from {
    opacity: 0;
    -webkit-transform: translate3d(0, 3rem, 0);
    transform: translate3d(0, 3rem, 0);
  }
  30% {
    opacity: .5;
  }
  to {
    opacity: 1;
    -webkit-transform: none;
    transform: none;
  }
}

.fadeInUp {
  -webkit-animation-name: fadeInUp;
  animation-name: fadeInUp;
}

/*--------------------------------------------------------------
Utility
--------------------------------------------------------------*/
.u_wrap {
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .u_inner {
    width: 108rem;
    max-width: calc(100% - 4rem);
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .u_inner {
    margin: 0 2rem;
  }
}

.u_switch_img {
  opacity: 1;
}

.u_relative {
  position: relative;
}

@media screen and (min-width: 768px) {
  .is_sp {
    display: none;
  }
  .is_tel {
    pointer-events: none;
    cursor: default;
  }
  .is_tel:hover {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  .is_pc {
    display: none;
  }
}

/*--------------------------------------------------------------
Layout/PageBase
--------------------------------------------------------------*/
:where(#header, #footer) a {
  display: block;
}

#header {
  position: fixed;
  width: 100%;
  top: 0;
  z-index: 66;
  height: 8.6rem;
  background: rgba(255, 255, 255, 0.95);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

@media screen and (min-width: 768px) {
  #header {
    padding: 2rem 4rem;
  }
  body:has(.top_main) #header {
    transition: .3s;
    transition-property: background, padding;
  }
  body:has(.top_main):not(.fixed):not(:has(.h_nav button.open)) #header {
    background: none;
    height: 10.6rem;
    padding: 2rem 3rem 2rem 4rem;
  }
  #header.rec {
    height: 12rem;
  }
}

@media screen and (max-width: 767px) {
  #header {
    height: 5rem;
    padding: 1.5rem 2rem;
  }
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) #header {
    background: none;
  }
  body.open #header {
    background: #fff;
  }
}

body:has(.top_main) .h_logo {
  transition: margin .3s;
}

body:has(.top_main) .h_logo a {
  transition: background .3s;
}

body:has(#header.rec) .h_logo a {
  display: flex;
  align-items: center;
  gap: 1rem 2rem;
}

@media screen and (min-width: 768px) and (max-width: 1300px) {
  body:has(#header.rec) .h_logo a {
    flex-direction: column;
    align-items: flex-end;
  }
}

@media screen and (min-width: 768px) {
  body:has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo {
    margin-top: 1rem;
  }
  body:has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo a {
    background: url(../img/logo-w.svg) no-repeat center top/contain;
  }
  body:has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo img {
    opacity: 0;
  }
}

@media screen and (max-width: 767px) {
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo {
    margin-top: 1rem;
  }
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo a {
    background: url(../img/logo-w.svg) no-repeat center top/contain;
  }
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_logo img {
    opacity: 0;
  }
}

.h_logo img {
  display: block;
  width: 29.8rem;
}

@media screen and (max-width: 767px) {
  .h_logo img {
    width: 14.9rem;
  }
}

.h_logo i {
  color: #D0121B;
  font-family: "Poppins", sans-serif;
  font-size: 1.1rem;
  border-radius: 3em;
  min-width: 8.54em;
  border: solid 1px #D0121B;
  text-align: center;
  white-space: nowrap;
}

.h_nav {
  font-weight: 500;
}

@media screen and (min-width: 768px) {
  .h_nav {
    display: flex;
    font-size: 1.5rem;
    gap: 1.32em;
    margin-right: 1rem;
  }
  #header.rec .h_nav {
    order: 2;
  }
  .h_nav .sub {
    position: absolute;
    left: 0;
    top: 8.6rem;
    width: 100%;
    background: rgba(255, 255, 255, 0.95);
    animation: itemFadeOut .3s;
  }
  .h_nav .row {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
    gap: 3rem 2rem;
    padding: 2.2rem 2rem 3rem;
  }
  .h_nav .row:has(.sns) {
    align-items: flex-end;
  }
  .h_nav .c_btn {
    width: 100% !important;
    text-align: center;
  }
  .h_nav .c_btn a {
    background-image: url(../img/ico-close.svg);
  }
  .h_nav .c_btn a:hover {
    background-image: url(../img/ico-close-b.svg);
  }
  .h_nav .list {
    width: 38.6rem;
  }
  .h_nav .list .meth {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .h_nav .list .meth li {
    width: 50%;
  }
  .h_nav .list .meth li:nth-child(2n + 0) {
    padding-left: 1.5rem;
  }
  .h_nav .list .zero {
    flex-direction: row;
    flex-wrap: wrap;
  }
  .h_nav .list .zero li {
    width: 50%;
  }
  .h_nav .list .zero li:nth-child(2n + 0) {
    padding-left: 1.5rem;
  }
  .h_nav .list.rec {
    width: auto;
    align-items: flex-start;
    gap: 4rem;
  }
  .h_nav .list.rec > * {
    width: 40rem;
  }
  .h_nav .list.rec ul {
    flex-direction: row;
    flex-wrap: wrap;
    margin-top: 1rem;
  }
  .h_nav .list.rec li {
    width: 50%;
  }
  .h_nav .large .list {
    width: 46rem;
  }
}

@media screen and (max-width: 767px) {
  .h_nav {
    margin-bottom: 5rem;
  }
  .h_nav .c_btn {
    display: none;
  }
  .h_nav > li {
    border-bottom: solid 1px #eee;
  }
  .h_nav > li > a {
    line-height: 7.4rem;
    font-size: 1.8rem;
  }
  .h_nav .row {
    padding-bottom: 3rem;
  }
  .h_nav .row > * {
    margin-bottom: 4rem;
  }
}

.h_nav .list li a[href="#"] {
  pointer-events: none;
  opacity: .5;
}

.h_nav .sub {
  display: none;
}

.h_nav button {
  position: relative;
}

.h_nav button.open + .sub {
  display: block;
  animation: itemFadeIn .3s;
}

@media screen and (max-width: 767px) {
  .h_nav button {
    background: url(../img/arrow-down01.svg) no-repeat right center/2rem;
    width: 100%;
    height: 7.4rem;
    text-align: left;
    font-size: 1.8rem;
  }
  .h_nav button.open {
    background-image: url(../img/arrow-up01.svg);
  }
}

@media screen and (min-width: 768px) {
  .h_nav button:hover {
    color: #D0121B;
    opacity: 1;
  }
  .h_nav button:hover:before {
    opacity: 1;
  }
  .h_nav button:before {
    content: '';
    position: absolute;
    height: 2px;
    background: #D0121B;
    bottom: -.5em;
    width: 100%;
    opacity: 0;
    transition: opacity .3s;
  }
  .h_nav button.open {
    color: #D0121B;
  }
  .h_nav button.open:before {
    opacity: 1;
  }
  .h_nav button.active {
    color: #D0121B;
  }
}

.h_nav .list > a {
  position: relative;
}

.h_nav .list > a:after {
  content: '';
  position: absolute;
  background: url(../img/arrow-right01.svg) no-repeat left center/contain;
  width: 1.6rem;
  height: 1.6rem;
  bottom: 1rem;
  right: 1rem;
}

.h_nav .list > a img {
  width: 100%;
  border-radius: .4rem;
}

.h_nav .list > a i {
  position: absolute;
  top: 50%;
  translate: 0 -50%;
  color: #fff;
  font-size: 1.8rem;
  font-weight: bold;
  left: 4rem;
}

@media screen and (max-width: 767px) {
  .h_nav .list > a i {
    left: 2rem;
  }
}

.h_nav .list > a + * {
  margin-top: 2rem;
}

@media screen and (max-width: 767px) {
  .h_nav .list > a + * {
    margin-top: 1.5rem;
  }
}

@media screen and (min-width: 768px) {
  .h_nav .list ul {
    display: flex;
    flex-direction: column;
    gap: .7em 0;
  }
}

.h_nav .list li a {
  font-weight: 400;
  padding-left: 1.7em;
  background: url(../img/arrow-right02.svg) no-repeat left 0.3em/1.6rem;
}

@media screen and (max-width: 767px) {
  .h_nav .list li a {
    background-position: left .45em;
    font-size: 1.4rem;
    padding: .15em 0 .15em 1.5em;
  }
}

.h_nav .list .com {
  display: flex;
  justify-content: space-between;
}

@media screen and (min-width: 768px) {
  .h_nav .list .com {
    padding-right: 3.5rem;
  }
}

.h_nav .list .work {
  display: flex;
  flex-direction: row;
  flex-wrap: wrap;
  white-space: nowrap;
}

@media screen and (max-width: 767px) {
  .h_nav .list .work {
    display: none;
  }
}

.h_nav .list .work li {
  width: 33.33%;
}

.h_nav .sns {
  display: flex;
  gap: 1rem;
}

.h_nav .sns img {
  width: 2.6rem;
}

@media screen and (min-width: 768px) {
  .h_nav .nav {
    width: 38.6rem;
  }
}

.h_nav .nav li + li {
  margin-top: 1rem;
}

.h_nav .nav a {
  border-radius: .4rem;
  height: 7rem;
  padding: 0 2rem;
  display: flex;
  border: 1px solid #EEEEEE;
  align-items: center;
  gap: 1em;
  background: #fff url(../img/arrow-right01.svg) no-repeat calc(100% - 2rem) center/1.6rem;
}

@media screen and (max-width: 767px) {
  .h_nav .nav a {
    font-size: 1.4rem;
  }
}

.h_nav .nav img {
  width: 4rem;
}

@media screen and (max-width: 767px) {
  .h_nav .nav img {
    width: 3.5rem;
  }
}

.h_left {
  display: flex;
  align-items: center;
  gap: 2rem;
}

@media screen and (min-width: 768px) {
  .h_entry {
    width: 20rem;
  }
  #header.rec .h_entry {
    order: 3;
  }
}

.h_entry a {
  background: #D0121B;
  height: 5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border-radius: .6rem;
  gap: .5em;
  font-size: 1.5rem;
}

@media screen and (max-width: 767px) {
  .h_entry a {
    height: 5rem;
    font-size: 1.6rem;
  }
}

@media screen and (min-width: 768px) {
  .h_mail {
    width: 16rem;
  }
}

.h_mail a {
  background: #D0121B;
  height: 4.6rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border-radius: .6rem;
  gap: .5em;
  font-size: 1.5rem;
}

@media screen and (max-width: 767px) {
  .h_mail a {
    height: 5rem;
    font-size: 1.6rem;
  }
}

.h_mail a:before {
  content: '';
  background: url(../img/h-mail.svg) no-repeat 50%/contain;
  width: 1.4rem;
  height: 1.1rem;
}

.c_lang {
  display: flex;
  font-size: 1.4rem;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}

.c_lang li + li {
  position: relative;
  margin-left: 1.2em;
}

.c_lang li + li:before {
  content: '';
  position: absolute;
  background: url(../img/lang-slash.svg) no-repeat 50%/contain;
  width: .6rem;
  height: 100%;
  left: -.8em;
  top: 0;
}

.c_lang a {
  opacity: .2;
}

.c_lang a[aria-current=true] {
  pointer-events: none;
  opacity: 1;
}

.h_sns {
  display: flex;
  gap: .6rem;
}

@media screen and (max-width: 767px) {
  .h_sns {
    gap: 1rem;
  }
}

.h_sns img {
  width: 1.6rem;
}

@media screen and (max-width: 767px) {
  .h_sns img {
    width: 2.6rem;
  }
}

.h_corp a {
  background: url(../img/arrow-right01.svg) no-repeat left center/1em;
  padding-left: 1.5em;
  font-size: 1.2rem;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .h_corp a {
    font-size: 1.8rem;
  }
}

.h_top {
  width: 100%;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .h_top {
    flex-direction: column;
    margin-top: 4rem;
  }
}

@media screen and (min-width: 768px) {
  .h_top {
    order: 1;
  }
}

@media screen and (min-width: 768px) {
  #toggle_menu {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: .8rem 2rem;
  }
  body:has(.top_main) #toggle_menu {
    transition: padding .3s;
  }
  body:has(.top_main):not(.fixed):not(:has(.h_nav button.open)) #toggle_menu {
    background: #fff;
    height: 6.6rem;
    padding: 1rem 2rem 1rem 4rem;
    border-radius: .8rem;
    backdrop-filter: blur(3px);
  }
  body:has(#header.rec) #toggle_menu {
    flex-wrap: wrap;
  }
}

@media screen and (max-width: 767px) {
  .h_menu {
    position: absolute;
    right: 2rem;
    top: 1rem;
    cursor: pointer;
    transition: top .3s;
  }
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_menu {
    top: 2rem;
  }
  body:not(.open):has(.top_main):not(.fixed):not(:has(.h_nav button.open)) .h_menu .open {
    border: none;
  }
  .h_menu img {
    width: 3.3rem;
  }
  .h_menu .open {
    border: solid 1px #D0121B;
    border-radius: .4rem;
  }
  .h_menu .close {
    position: absolute;
    left: 0;
    opacity: 0;
  }
  body.open .h_menu .close {
    opacity: 1;
  }
  #toggle_menu {
    position: fixed;
    overflow-y: auto;
    height: calc(100% - 5rem);
    top: 5rem;
    left: 0;
    width: 100%;
    background: #fff;
    padding: 8rem 4rem 4rem;
  }
  #header.rec #toggle_menu {
    padding-top: 2rem;
  }
  .h_lang {
    position: absolute;
    top: 3rem;
    right: 4rem;
  }
  body.open {
    overflow-y: hidden;
  }
  body.open #toggle_menu {
    display: block;
    animation: itemFadeIn 1s;
  }
  body:not(.open) #toggle_menu {
    display: none;
    animation: itemFadeOut .8s;
  }
}

#gototop {
  position: fixed;
  right: 1rem;
  bottom: 1rem;
  z-index: 10;
}

#gototop.show {
  display: block;
  animation: itemFadeIn 1s;
}

#gototop:not(.show) {
  display: none;
  animation: itemFadeOut .8s;
}

@keyframes itemFadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}

@keyframes itemFadeOut {
  from {
    opacity: 1;
    display: block;
  }
  to {
    opacity: 0;
  }
}

#footer {
  border-top: solid 2px #D0121B;
  padding: 6.5rem 2rem 6.5rem;
}

@media screen and (min-width: 768px) {
  #footer {
    padding: 6.5rem 0 4rem;
  }
  #footer .u_inner {
    width: 120rem;
  }
}

.f_logo img {
  width: 30.6rem;
}

@media screen and (min-width: 768px) {
  .f_nav {
    display: flex;
    justify-content: space-between;
    margin-bottom: 6rem;
  }
  .f_nav p {
    margin-bottom: 1rem;
  }
  .f_nav > ul > li {
    margin-bottom: 3rem;
  }
  .f_nav li li {
    margin-top: .5rem;
  }
  .f_nav li li a {
    font-size: 1.4rem;
  }
  .f_nav li li a:before {
    content: '∟';
    color: #ccc;
  }
}

@media screen and (max-width: 767px) {
  .f_nav {
    margin-bottom: 7.5rem;
  }
  .f_nav > ul > li {
    border-top: solid 1px #eee;
  }
  .f_nav .first {
    border-top: none;
  }
  .f_nav li ul {
    border-top: solid 1px #eee;
    padding: 1.5rem 0;
    display: none;
  }
  .f_nav li li a {
    background: url(../img/arrow-right02.svg) no-repeat left 0.45em/1.6rem;
    font-size: 1.4rem;
    padding: .15em 0 .15em 1.5em;
  }
}

.f_nav p {
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .f_nav p {
    height: 7.4rem;
    font-size: 1.8rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  .f_nav p i {
    background: url(../img/arrow-down01.svg) no-repeat right center/contain;
    width: 3rem;
    height: 2rem;
    cursor: pointer;
  }
  .f_nav p.open + ul {
    display: block;
  }
}

.f_nav li a[href="#"] {
  pointer-events: none;
  opacity: .5;
}

.f_row {
  border-top: solid 1px #eee;
  padding-top: 4rem;
}

@media screen and (max-width: 767px) {
  .f_row {
    text-align: center;
  }
}

@media screen and (min-width: 768px) {
  .f_row {
    display: flex;
    justify-content: space-between;
  }
  .f_row .right {
    display: flex;
    flex-direction: column;
    justify-content: space-between;
  }
  .f_row .row {
    display: flex;
    align-items: flex-end;
    gap: 4rem;
    margin-bottom: 3.5rem;
  }
}

.f_sns {
  display: flex;
  gap: 1rem;
}

@media screen and (max-width: 767px) {
  .f_sns {
    justify-content: center;
    margin: 3rem 0 3.5rem;
  }
}

.f_sns img {
  width: 2.6rem;
}

.f_info dt {
  font-size: 1.4rem;
  font-weight: 500;
  margin-bottom: .3em;
}

.f_info dd {
  font-size: 1.2rem;
  line-height: 1.8;
}

.f_info dd a {
  display: inline-block;
}

.f_link ul {
  display: flex;
  align-items: center;
  font-size: 1rem;
  gap: 3em;
}

@media screen and (max-width: 767px) {
  .f_link ul {
    justify-content: center;
    margin: 0 -2rem 4.5rem;
    gap: 2.5em;
  }
}

@media screen and (min-width: 768px) {
  .f_link {
    order: 1;
  }
}

.f_link .inf {
  width: 13em;
}

.f_link .vt {
  width: 11em;
}

.f_link .mirai {
  width: 4.8em;
}

@media screen and (max-width: 767px) {
  .f_lang {
    margin: 4rem 0;
  }
}

.f_lang ul {
  justify-content: flex-end;
}

@media screen and (max-width: 767px) {
  .f_lang ul {
    justify-content: center;
  }
}

@media screen and (min-width: 768px) {
  .f_lang {
    order: 2;
  }
}

.f_copy {
  font-family: "Poppins", sans-serif;
  font-size: 1.1rem;
  text-align: center;
}

@media screen and (min-width: 768px) {
  .f_copy {
    font-size: 1.2rem;
    text-align: right;
    order: 3;
  }
}

/*--------------------------------------------------------------
Project
--------------------------------------------------------------*/
@media screen and (min-width: 768px) {
  .top_header {
    position: relative;
    height: 100vh;
    min-height: 60rem;
    padding-left: 12rem;
    padding-bottom: 6rem;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
  }
}

.top_main .bg {
  overflow: hidden;
  position: absolute;
  inset: 0;
  z-index: -1;
}

.top_main .bg:before {
  content: '';
  position: absolute;
  inset: 0;
  background: rgba(0, 0, 0, 0.3);
  z-index: 1;
}

.top_main .bg iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

@media screen and (min-width: 768px) {
  .top_main .swiper-fade .swiper-slide {
    transition-property: opacity !important;
  }
  .top_main .box {
    padding-right: 9.5rem;
    display: flex;
    justify-content: space-between;
    align-items: center;
    position: relative;
    transition: top .3s;
    top: 0;
  }
  body:not(.fixed) .top_main .box {
    top: 23rem;
  }
  .top_main .slide {
    width: 22rem;
  }
  .top_main .slide a:hover {
    opacity: 1;
  }
  .top_main .swiper-slide img {
    transition: transform .2s;
    position: relative;
  }
  .top_main .swiper-slide-prev {
    opacity: 1 !important;
  }
  .top_main .swiper-slide-prev img {
    left: -5rem;
  }
  .top_main .swiper-slide-next {
    opacity: 1 !important;
  }
  .top_main .swiper-slide-next img {
    right: -5rem;
  }
  .top_main .swiper-slide-active {
    z-index: 1 !important;
  }
  .top_main .swiper-slide-active img {
    transform: scale(1.09);
  }
}

@media screen and (max-width: 767px) {
  .top_main {
    position: relative;
    z-index: 0;
    height: 100vh;
    height: 100svh;
    min-height: 65rem;
  }
  .top_main .swiper-slide {
    width: 45.3vw;
    margin: 0 1rem;
  }
  .top_main .pager {
    display: flex;
    gap: 1.8vw;
    position: absolute;
    width: 100%;
    bottom: 0;
    justify-content: center;
  }
  .top_main .swiper-pagination-bullet {
    height: 1.8vw;
    width: 1.8vw;
    border-radius: 50%;
    cursor: pointer;
    background: #fff;
  }
  .top_main .swiper-pagination-bullet-active {
    background: #D0121B;
  }
}

.top_main .slide {
  position: relative;
}

@media screen and (max-width: 767px) {
  .top_main .slide {
    position: absolute;
    padding-bottom: 2rem;
    width: 100%;
    bottom: 5.3vw;
  }
}

.top_main .slide img {
  border-radius: .8rem;
  aspect-ratio: 480 / 352;
  object-fit: cover;
}

.top_main .wrap {
  padding: 1rem 5rem;
  margin-bottom: 5rem;
}

@media screen and (max-width: 767px) {
  .top_main p {
    width: 26.8rem;
    position: absolute;
    top: 50%;
    translate: 0 -50%;
  }
}

.top_main p img {
  width: 85.6rem;
}

@media screen and (min-width: 768px) {
  .top_main p img {
    position: relative;
    left: -5rem;
  }
}

.top_main .btn i {
  position: absolute;
  top: 0;
  cursor: pointer;
  z-index: 2;
  width: 3rem;
  height: 100%;
  background: url(../img/slide-prev.svg) no-repeat 50%/contain;
}

.top_main .btn .prev {
  left: -2.6rem;
}

.top_main .btn .next {
  background-image: url(../img/slide-next.svg);
  right: -2.6rem;
}

.top_news {
  position: relative;
}

@media screen and (min-width: 768px) {
  .top_news {
    opacity: 0;
    transition: opacity .3s;
  }
  body.fixed .top_news {
    opacity: 1;
  }
}

@media screen and (max-width: 767px) {
  .top_news {
    background: #F6F6F6;
    padding: 5rem 2rem 0;
  }
  .top_news ul {
    background: #fff;
    border-radius: .8rem;
    padding: 3rem;
  }
  .top_news li + li {
    padding: 1.8rem 0;
    margin-top: 1.8rem;
    border-top: solid 1px #EEEEEE;
  }
  .top_news li:nth-child(n + 4) {
    display: none;
  }
}

@media screen and (min-width: 768px) {
  .top_news {
    border-radius: .8rem 0 0 .8rem;
    padding: 5rem 0 5rem 6rem;
    background: #F6F6F6;
    display: flex;
  }
  .top_news .ttl {
    width: 14rem;
  }
  .top_news .pc {
    width: calc(100% - 14rem);
  }
  .top_news .swiper-wrapper {
    position: relative;
    left: -5rem;
  }
  .top_news .slide {
    overflow: hidden;
  }
  .top_news li {
    width: 34.4rem;
    border-left: dotted 2px #ddd;
    position: relative;
    left: -2px;
  }
  .top_news li a {
    padding: 0 5rem;
    display: block;
  }
}

.top_news li p {
  display: flex;
  gap: 2rem;
  line-height: 1.4;
  margin-bottom: .6em;
}

.top_news li p + * {
  display: -webkit-box;
  -webkit-box-orient: vertical;
  overflow: hidden;
  text-overflow: ellipsis;
  -webkit-line-clamp: 2;
}

.top_news li time {
  font-size: 1.4rem;
  font-family: "Poppins", sans-serif;
}

.top_news li i {
  font-size: 1.2rem;
  background: #E8E8E8;
  font-weight: 500;
  min-width: 12rem;
  text-align: center;
  border-radius: 3em;
  padding: 0 1em;
}

.top_news .ttl {
  font-size: 2rem;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .top_news .ttl {
    font-size: 2.6rem;
    margin-bottom: 1.5rem;
    margin-left: 1.5rem;
  }
}

.top_news .c_btn {
  position: absolute;
  right: 12rem;
  bottom: -2rem;
}

@media screen and (max-width: 767px) {
  .top_news .c_btn {
    bottom: auto;
    top: 8rem;
    right: 2rem;
  }
}

.top_news .c_btn a {
  min-width: 10rem;
  padding: 0 1.5em 0 0;
}

.top_news .btn {
  position: absolute;
  right: 24rem;
  width: 7rem;
  z-index: 1;
  bottom: -1.5rem;
  display: flex;
  justify-content: space-between;
}

.top_news .btn i {
  cursor: pointer;
  z-index: 2;
  width: 3rem;
  height: 3rem;
  background: url(../img/slide-prev.svg) no-repeat 50%/contain;
}

.top_news .btn .next {
  background-image: url(../img/slide-next.svg);
}

.top_lead {
  padding: 4rem 0 6rem;
  position: relative;
}

.top_lead:before {
  content: '';
  position: absolute;
  background: #F6F6F6;
  inset: 0 0 50%;
  z-index: -1;
}

@media screen and (min-width: 768px) {
  .top_lead {
    padding: 8rem 0 13rem;
    overflow: hidden;
    text-align: center;
    background: url(../img/lead-bg.svg) no-repeat center bottom/100%;
  }
}

@media screen and (min-width: 768px) and (max-width: 1440px) {
  .top_lead {
    background-size: 144rem;
  }
}

@media screen and (min-width: 768px) {
  .top_lead .row {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    position: relative;
    left: 50%;
    translate: -50% 0;
    width: 160rem;
  }
  .top_lead .left {
    width: 36.6rem;
    left: -1.5rem;
  }
  .top_lead .right {
    width: 48.4rem;
    position: relative;
    left: -6rem;
    margin-top: 16.5rem;
  }
  .top_lead .box {
    margin-top: 7.5rem;
  }
}

@media screen and (max-width: 767px) {
  .top_lead .box {
    background: url(../img/lead-bg.svg) no-repeat center bottom/144rem;
    padding: 8rem 2rem 12rem;
  }
}

.top_lead figure {
  position: relative;
  z-index: 0;
}

.top_lead figure .s {
  position: absolute;
  z-index: -1;
}

.top_lead figure img {
  width: 100%;
  border-radius: .8rem;
}

.top_lead .left {
  aspect-ratio: 366 / 360;
}

@media screen and (max-width: 767px) {
  .top_lead .left {
    margin-right: 2rem;
    aspect-ratio: 730 / 544;
    margin-left: -1rem;
  }
}

.top_lead .left > img {
  margin-left: auto;
  display: block;
  width: 30rem;
}

@media screen and (max-width: 767px) {
  .top_lead .left > img {
    width: 68%;
  }
}

.top_lead .left .s {
  bottom: 0;
  left: 0;
  width: 22rem;
}

@media screen and (max-width: 767px) {
  .top_lead .left .s {
    width: 49%;
  }
}

.top_lead .right {
  display: flex;
  align-items: flex-end;
  aspect-ratio: 484 / 420;
}

@media screen and (max-width: 767px) {
  .top_lead .right {
    aspect-ratio: 780 / 632;
    margin-left: 2rem;
    margin-right: -3.5rem;
  }
}

.top_lead .right > img {
  width: 36rem;
}

@media screen and (max-width: 767px) {
  .top_lead .right > img {
    width: 73%;
  }
}

.top_lead .right .s {
  top: 0;
  right: 0;
  width: 28rem;
}

@media screen and (max-width: 767px) {
  .top_lead .right .s {
    width: 56%;
  }
}

.top_lead .ttl {
  font-size: 4.2rem;
  letter-spacing: .06em;
  margin-bottom: 7rem;
}

@media screen and (max-width: 767px) {
  .top_lead .ttl {
    font-size: 3.5rem;
    margin-bottom: 6rem;
  }
}

.top_lead p {
  font-weight: 500;
  line-height: 1.8;
}

.top_lead .c_btn {
  margin-top: 6rem;
}

@media screen and (max-width: 767px) {
  .top_lead .c_btn {
    margin-top: 5rem;
  }
}

@media screen and (min-width: 768px) {
  .top_inner {
    width: 124rem;
    max-width: calc(100% - 4rem);
    margin: 0 auto;
  }
}

@media screen and (max-width: 767px) {
  .top_inner {
    margin: 0 2rem;
  }
}

.top_style {
  margin-bottom: 6rem;
}

@media screen and (min-width: 768px) {
  .top_style {
    padding-right: 4rem;
    display: flex;
    justify-content: space-between;
    align-items: flex-end;
    margin-bottom: 6rem;
  }
}

.top_style .ttl p {
  font-size: 7rem;
  line-height: 1.2;
  margin-bottom: 4rem;
  font-family: "Poppins", sans-serif;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .top_style .ttl p {
    font-size: 4rem;
    margin-bottom: 3.3rem;
  }
}

.top_style .ttl :not(p) {
  font-size: 2rem;
  color: #D0121B;
  font-weight: bold;
}

.top_style .catch p {
  display: flex;
  flex-direction: row-reverse;
  color: #D0121B;
  font-family: "Zen Old Mincho", serif;
  font-size: 3rem;
  letter-spacing: .06em;
  line-height: 2.5;
}

.top_style .catch p span {
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
}

@media screen and (max-width: 767px) {
  .top_style .catch {
    display: flex;
    justify-content: center;
    margin-top: 6rem;
  }
}

.style_sec {
  color: #fff;
  margin-bottom: 1rem;
}

@media screen and (min-width: 768px) {
  .style_sec header {
    position: absolute;
    right: 4rem;
    top: 8rem;
  }
}

@media screen and (min-width: 768px) and (min-width: 768px) {
  .style_sec .desc {
    width: 124rem;
    margin: 0 auto;
  }
}

.style_sec header {
  display: flex;
  flex-direction: row-reverse;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .style_sec header {
    justify-content: space-between;
  }
}

.style_sec header * {
  writing-mode: vertical-rl;
}

.style_sec header .ttl {
  font-family: "Zen Old Mincho", serif;
  font-size: 6rem;
  letter-spacing: .4em;
  position: relative;
  padding-top: 1em;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .style_sec header .ttl {
    font-size: 3rem;
    margin-top: 1.4em;
    text-indent: -1.4em;
  }
}

.style_sec header p {
  font-size: 6rem;
  font-weight: 500;
  font-family: "Poppins", sans-serif;
  line-height: 1.2;
}

@media screen and (max-width: 767px) {
  .style_sec header p {
    font-size: 3.5rem;
  }
}

.style_sec .box {
  position: relative;
}

@media screen and (max-width: 767px) {
  .style_sec .box {
    padding: 5rem 2rem 12rem;
  }
}

@media screen and (min-width: 768px) {
  .style_sec .box {
    height: 77rem;
    display: flex;
    align-items: flex-end;
    padding-bottom: 18rem;
  }
}

.style_sec .box img {
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: -1;
}

.style_sec .ttl2 {
  background-color: #D0121B;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
  font-size: 3.2rem;
  font-weight: bold;
  display: inline;
  color: #fff;
  padding: 0 .5em;
  line-height: 1.7;
}

.style_sec .ttl2 + p {
  margin-top: 3rem;
  text-shadow: 0 0 0.6rem rgba(0, 0, 0, 0.8);
}

@media screen and (max-width: 767px) {
  .style_sec .ttl2 + p {
    margin-top: 2rem;
  }
}

.style_sec ul {
  display: inline-flex;
  padding: 6rem 6rem 0;
  border-radius: .8rem .8rem 0 0;
  gap: 2.1rem;
  position: relative;
  top: -9rem;
}

@media screen and (max-width: 767px) {
  .style_sec ul {
    padding: 0 2rem;
    flex-direction: column;
    top: -8.5rem;
  }
}

@media screen and (min-width: 768px) {
  .style_sec ul {
    background: #fff;
    margin-left: calc(50% - 68rem);
  }
}

.style_sec li {
  flex: 1;
}

@media screen and (min-width: 768px) {
  .style_sec li {
    width: 38.6rem;
  }
}

.style_sec li img {
  border-radius: .6rem;
  width: 100%;
}

.style_sec li a {
  position: relative;
  display: block;
}

.style_sec li a:after {
  content: '';
  position: absolute;
  background: url(../img/arrow-right01.svg) no-repeat 50%/contain;
  width: 2.8rem;
  height: 2.8rem;
  right: 2rem;
  bottom: 2rem;
}

.style_sec li p {
  font-size: 2.4rem;
  font-weight: bold;
  position: absolute;
  bottom: 4rem;
  left: 4rem;
  text-shadow: 0 0 0.6rem rgba(0, 0, 0, 0.8);
}

.style_sec li small {
  display: block;
  font-size: 1.6rem;
  line-height: 1.8;
  margin-top: .8em;
  font-weight: 500;
}

@media screen and (max-width: 767px) {
  .style_sec li small {
    display: none;
  }
}

.top_method ul {
  margin: 0 1rem 1rem;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

@media screen and (max-width: 767px) {
  .top_method ul {
    margin: 0 0 1rem;
  }
}

.top_method li {
  position: relative;
}

@media screen and (min-width: 768px) {
  .top_method li {
    width: calc(33.33% - .666rem);
  }
}

.top_method li a {
  display: block;
  overflow: hidden;
}

.top_method li a:hover {
  opacity: 1;
}

.top_method li a:hover img {
  transform: scale(1.02);
}

.top_method li a:hover .c_btn i {
  color: #fff;
  background-color: #D0121B;
  background-image: url(../img/arrow-right04.svg);
  opacity: 1;
}

.top_method .full {
  width: 100%;
}

.top_method img {
  width: 100%;
  transition: transform .3s;
}

.top_method dl {
  color: #fff;
  width: 100%;
  position: absolute;
  top: 50%;
  translate: 0 -50%;
}

@media screen and (max-width: 767px) {
  .top_method dl {
    background: url(../img/arrow-right01.svg) no-repeat calc(100% - 2rem) center/2.8rem;
    padding: 0 2rem;
  }
}

@media screen and (min-width: 768px) {
  .top_method dl {
    text-align: center;
    padding: 0 8%;
    left: 50%;
    translate: -50%  -50%;
  }
}

.top_method dt {
  font-size: 3.2rem;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .top_method dt {
    font-size: 3rem;
  }
}

.top_method dd {
  font-weight: 500;
  line-height: 1.875;
  margin-top: 3.5rem;
}

@media screen and (max-width: 767px) {
  .top_method dd {
    display: none;
  }
}

.top_method .c_btn {
  margin-top: 3rem;
}

@media screen and (max-width: 767px) {
  .top_method .c_btn {
    display: none;
  }
}

.more_issue {
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 500;
  border: solid 1px #D0121B;
  background: #fff url(../img/arrow-down02.svg) no-repeat calc(100% - 1.5rem) center/1.6rem;
  border-radius: 3em;
  color: #D0121B;
  height: 5rem;
  margin-top: 4rem;
  cursor: pointer;
}

@media screen and (min-width: 768px) {
  .more_issue {
    display: none;
  }
}

.top_issue {
  padding: 16rem 0 14rem;
  background: #F6F6F6;
}

@media screen and (max-width: 767px) {
  .top_issue {
    padding: 11rem 0 10rem;
  }
}

@media screen and (max-width: 767px) {
  .top_issue .ptn_relate {
    grid-template-columns: repeat(1, 1fr);
  }
  .top_issue .ptn_relate h3, .top_issue .ptn_relate h4 {
    min-height: 11rem;
    padding-left: 13rem;
    margin-bottom: 2rem;
  }
  .top_issue .ptn_relate > div {
    position: relative;
    padding: 2rem 2rem 4rem;
  }
  .top_issue .ptn_relate > div:nth-child(n + 3) {
    display: none;
  }
  .top_issue .ptn_relate > div > div {
    width: auto;
  }
  .top_issue .ptn_relate > div > div:has(figure) {
    position: absolute;
    width: 11rem;
    left: 2rem;
    top: 2rem;
  }
  .top_issue .ptn_relate.open + .more_issue {
    display: none;
  }
  .top_issue .ptn_relate.open > div:nth-child(n + 3) {
    display: block;
  }
}

@media screen and (min-width: 768px) {
  .top_issue .ptn_relate > div {
    border-radius: .6rem;
    background: #fff;
    padding: 4rem;
    gap: 0 4rem;
    border: solid 1px #F6F6F6;
    display: flex;
    align-items: center;
    justify-content: space-between;
  }
  .top_issue .ptn_relate > div p {
    font-size: 1.4rem;
  }
  .top_issue .ptn_relate > div p + p {
    margin-top: 1rem;
  }
  .top_issue .ptn_relate .u_inner {
    position: relative;
    left: 50%;
    translate: -50% 0;
    width: 124rem;
  }
}

.top_recruit {
  position: relative;
}

.top_recruit img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center top;
  top: 0;
  left: 0;
  z-index: -1;
  transition: transform .2s;
}

.top_recruit .u_inner {
  position: relative;
}

@media screen and (max-width: 767px) {
  .top_recruit .u_inner {
    padding: 10rem 0 14rem;
  }
}

.top_recruit .u_inner:before {
  content: '';
  position: absolute;
  background: url(../img/arrow-right05.svg) no-repeat 50%/contain;
  width: 15rem;
  height: 15rem;
  right: 0;
  bottom: 0;
  transition: background .3s;
}

@media screen and (max-width: 767px) {
  .top_recruit .u_inner:before {
    width: 7.5rem;
    height: 7.5rem;
    background-image: url(../img/arrow-right05-sp.svg);
    bottom: 2rem;
  }
}

.top_recruit .ttl {
  display: flex;
  font-size: 3rem;
  font-weight: bold;
  gap: 2rem;
  align-items: flex-end;
  margin-bottom: 4rem;
}

@media screen and (max-width: 767px) {
  .top_recruit .ttl {
    margin-bottom: 6.5rem;
  }
}

.top_recruit .ttl p {
  font-size: 1.6rem;
  font-weight: 500;
  font-family: "Poppins", sans-serif;
}

.top_recruit a {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #fff;
  position: relative;
  overflow: hidden;
}

@media screen and (min-width: 768px) {
  .top_recruit a {
    height: 68rem;
    padding-bottom: 7rem;
  }
  .top_recruit a:hover {
    opacity: 1;
  }
  .top_recruit a:hover img {
    transform: scale(1.04);
  }
  .top_recruit a:hover .u_inner:before {
    background-image: url(../img/arrow-right05-b.svg);
  }
}

.top_recruit .catch {
  font-size: 3.5rem;
  font-weight: bold;
  margin-top: 4rem;
}

@media screen and (max-width: 767px) {
  .top_recruit .catch {
    text-decoration: underline;
    text-decoration-thickness: 1px;
  }
}

@media screen and (min-width: 768px) {
  .top_recruit .catch {
    margin-top: 7rem;
    font-size: 4.2rem;
    position: relative;
  }
  .top_recruit .catch:before, .top_recruit .catch:after {
    content: '';
    position: absolute;
    width: 65rem;
    border-bottom: solid 1px #fff;
    top: 1.3em;
    left: -.4em;
  }
  .top_recruit .catch:after {
    top: 2.9em;
  }
}

.low_header {
  margin-top: 8.6rem;
  height: 36.6rem;
  color: #fff;
  mask: url(../img/kv-clip.svg) no-repeat center bottom/cover;
  position: relative;
  display: flex;
  align-items: center;
  margin-bottom: 3rem;
  text-shadow: 0 0 1rem rgba(0, 0, 0, 0.6);
}

@media screen and (max-width: 767px) {
  .low_header {
    margin-top: 5rem;
    mask-image: url(../img/kv-clip-sp.svg);
  }
}

.low_header.small {
  padding-bottom: 4rem;
}

@media screen and (min-width: 768px) {
  .low_header.small {
    padding-bottom: 5rem;
  }
  .low_header.small .u_inner {
    width: 90%;
  }
}

.low_header.small p:not(.ttl) {
  font-size: 1.8rem;
  margin-top: 2rem;
}

@media screen and (max-width: 767px) {
  .low_header.small h1 {
    font-size: 3.4rem;
  }
}

.low_header img {
  position: absolute;
  height: 100%;
  object-fit: cover;
  width: 100%;
  left: 0;
  top: 0;
  z-index: -1;
}

.low_header p:not(.ttl) {
  font-family: "Poppins", sans-serif;
  font-size: 2.2rem;
  font-weight: 500;
  margin-top: .2em;
}

.low_header h1, .low_header .ttl {
  font-size: 4.6rem;
  font-weight: bold;
  line-height: 1.5;
}

.low_path {
  display: flex;
  font-size: 1.2rem;
  white-space: nowrap;
  overflow-x: auto;
  gap: 4.5rem;
  margin-bottom: 6rem;
}

.low_path + .low_path {
  margin-top: -5rem;
}

.low_path a {
  color: #ccc;
}

.low_path a[href="#"] {
  color: inherit;
  pointer-events: none;
}

.low_path li + li {
  position: relative;
}

.low_path li + li:before {
  content: '';
  position: absolute;
  width: 2rem;
  border-bottom: solid 1px #ccc;
  top: .8em;
  left: -3.2rem;
}

.nav-links {
  margin-top: 6rem;
  display: flex;
  justify-content: center;
  gap: 1em;
  font-size: 1.2rem;
  font-weight: 500;
  font-family: "Poppins", sans-serif;
}

.nav-links span, .nav-links a {
  display: block;
  width: 2.5em;
  line-height: 2.5;
  text-align: center;
  border: solid 1px #D0121B;
  border-radius: 50%;
}

.nav-links a {
  color: #D0121B;
  background: #fff;
}

.nav-links .dots {
  color: #D0121B;
  border: none;
  margin: 0 -1rem;
}

.nav-links .current {
  color: #fff;
  background: #D0121B;
}

.nav-links .prev {
  border: none;
  background: url(../img/pager-prev.svg) no-repeat 50%/contain;
  color: transparent;
}

.nav-links .prev * {
  display: none;
}

.nav-links .next {
  border: none;
  background: url(../img/pager-next.svg) no-repeat 50%/contain;
  color: transparent;
}

.nav-links .next * {
  display: none;
}

.pagination .screen-reader-text {
  clip: rect(1px, 1px, 1px, 1px);
  position: absolute;
}

.info_list {
  margin-bottom: 6rem;
}

@media screen and (min-width: 768px) {
  .info_list .ptn_col {
    gap: 6rem 2rem;
  }
}

.info_list .ptn_col h3, .info_list .ptn_col h4 {
  text-align: left;
}

@media screen and (min-width: 768px) {
  .info_list .ptn_col {
    position: relative;
    left: 50%;
    translate: -50% 0;
    width: 124rem;
  }
}

.thanks_body {
  text-align: center;
}

.thanks_body .ttl {
  font-size: 3.6rem;
  font-weight: bold;
  margin: 0 0 3rem;
}

@media screen and (max-width: 767px) {
  .thanks_body .ttl {
    font-size: 3rem;
  }
}

.contact-form:has(.h2) {
  margin-left: 3rem;
}

@media screen and (max-width: 767px) {
  .contact-form:has(.h2) {
    margin-left: 2.5rem;
  }
}

.contact-form:has(.h2) .contact-form-item:has(textarea[name="特記事項がございましたら、ご記入ください"]) {
  margin-left: -3rem;
  margin-top: 3rem;
}

@media screen and (max-width: 767px) {
  .contact-form:has(.h2) .contact-form-item:has(textarea[name="特記事項がございましたら、ご記入ください"]) {
    margin-left: -2.5rem;
  }
}

.contact-form:has(.h2) .contact-form-item:has(.contact-form-privacy-policy-checkbox) {
  margin-left: -3rem;
}

@media screen and (max-width: 767px) {
  .contact-form:has(.h2) .contact-form-item:has(.contact-form-privacy-policy-checkbox) {
    margin-left: -2.5rem;
  }
}

.contact-form:has(.h2) .contact-form-item:has(.contact-form-submit-outer) {
  margin-left: -3rem;
}

@media screen and (max-width: 767px) {
  .contact-form:has(.h2) .contact-form-item:has(.contact-form-submit-outer) {
    margin-left: -2.5rem;
  }
}

.contact-form:has(.h2) .h2 {
  display: block;
}

.contact-form:has(.h2) .contact-form-item__inner:has(.h2) {
  display: flex;
  flex-direction: column;
}

.contact-form:has(.h2) .contact-form-item__inner:has(.h2) .contact-form-description {
  order: 1;
}

.contact-form:has(.h2) .contact-form-item__inner:has(.h2) .contact-form-label {
  order: 2;
}

.contact-form:has(.h2) .contact-form-item__inner:has(.h2) .contact-form-radio-list {
  order: 3;
}

.contact-form:has(.h2) .contact-form-item__inner:has(.h2) .contact-form-textbox {
  order: 3;
}

.contact-form .h2 {
  left: -3rem;
}

@media screen and (max-width: 767px) {
  .contact-form .h2 {
    left: -2.5rem;
  }
}

h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)),
.h2 {
  font-weight: bold;
  font-size: 3.6rem;
  margin: 6.5rem 0 3rem;
  position: relative;
  padding-left: .75em;
}

h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)) + h3,
.h2 + h3 {
  margin-top: 3.5rem;
}

@media screen and (max-width: 767px) {
  h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)),
  .h2 {
    font-size: 3rem;
  }
}

h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)):nth-child(1),
.h2:nth-child(1) {
  margin-top: 0;
}

h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)):before, h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)):after,
.h2:before,
.h2:after {
  content: '';
  position: absolute;
  height: .55em;
  width: .13em;
  left: 0;
  top: .3em;
  background: #D0121B;
}

h2:not(.ttl, .defo, .h3, .popup-title, :where(header h2, .ptn_col h2, .ptn_relate h2)):after,
.h2:after {
  left: 0;
  top: 0.95em;
  background: #0F0F0F;
}

h3:not(.ttl, .ttl2, .h2, .defo, :where(header h3, .ptn_col h3, .ptn_relate h3)),
.h3 {
  font-weight: bold;
  font-size: 3rem;
  margin: 4.5rem 0 3rem;
  position: relative;
  padding-bottom: .3em;
  border-bottom: solid 1px #EEEEEE;
}

h3:not(.ttl, .ttl2, .h2, .defo, :where(header h3, .ptn_col h3, .ptn_relate h3)) + h4,
.h3 + h4 {
  margin-top: 3.5rem;
}

@media screen and (max-width: 767px) {
  h3:not(.ttl, .ttl2, .h2, .defo, :where(header h3, .ptn_col h3, .ptn_relate h3)),
  .h3 {
    font-size: 2.4rem;
  }
}

h3:not(.ttl, .ttl2, .h2, .defo, :where(header h3, .ptn_col h3, .ptn_relate h3)):nth-child(1),
.h3:nth-child(1) {
  margin-top: 0;
}

h3:not(.ttl, .ttl2, .h2, .defo, :where(header h3, .ptn_col h3, .ptn_relate h3)):before,
.h3:before {
  content: '';
  position: absolute;
  height: 1px;
  width: 1.33em;
  left: 0;
  bottom: -1px;
  background: #D0121B;
}

h4:not(.ttl, .ttl2, .h2, .h3, .defo, :where(header h4, .ptn_col h4, .ptn_relate h4)),
.h4 {
  font-weight: bold;
  font-size: 2.4rem;
  margin: 4.5rem 0 3rem;
  padding-bottom: .3em;
  border-bottom: solid 1px #EEEEEE;
}

h4:not(.ttl, .ttl2, .h2, .h3, .defo, :where(header h4, .ptn_col h4, .ptn_relate h4)) + h5,
.h4 + h5 {
  margin-top: 3.5rem;
}

@media screen and (max-width: 767px) {
  h4:not(.ttl, .ttl2, .h2, .h3, .defo, :where(header h4, .ptn_col h4, .ptn_relate h4)),
  .h4 {
    font-size: 2.2rem;
  }
}

h5:not(.ttl, .ttl2, .defo),
.h5 {
  font-weight: bold;
  font-size: 2rem;
  margin: 4.5rem 0 .6em;
}

@media screen and (max-width: 767px) {
  h5:not(.ttl, .ttl2, .defo),
  .h5 {
    font-size: 1.9rem;
  }
}

h6:not(.ttl, .ttl2, .defo, #main h6),
.h6 {
  font-weight: bold;
  font-size: 1.8rem;
  margin: 4.5rem 0 .6em;
}

@media screen and (max-width: 767px) {
  h6:not(.ttl, .ttl2, .defo, #main h6),
  .h6 {
    font-size: 1.7rem;
  }
}

.ptn_cover {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 56rem;
  color: #fff;
}

.ptn_cover .ttl {
  text-align: center;
  font-size: 3.2rem;
  margin-bottom: 1em;
  font-weight: bold;
}

.article_body .ptn_cover {
  width: 100vw;
  position: relative;
  left: 50%;
  translate: -50% 0;
}

.ptn_cover img {
  position: absolute;
  width: 100%;
  height: 100%;
  object-fit: cover;
  top: 0;
  left: 0;
  border-radius: 0;
  z-index: -1;
}

.ptn_cover p a {
  color: #fff !important;
}

.ptn_row {
  display: flex;
  justify-content: space-between;
  flex-wrap: nowrap;
  align-items: flex-start;
  margin: 3rem auto 0;
  gap: 3rem;
}

@media screen and (max-width: 767px) {
  .ptn_row {
    flex-direction: column;
  }
}

.ptn_row figure {
  width: 100%;
}

.ptn_row figure img {
  border-radius: .4rem;
}

@media screen and (min-width: 768px) {
  .ptn_row figure {
    width: 44rem;
  }
}

@media screen and (min-width: 768px) {
  .ptn_row > *:not(figure) {
    width: calc(100% - 52rem);
    margin-top: 2rem;
  }
}

.ptn_col {
  margin: 3rem auto 0;
  gap: 2rem;
  display: grid;
  grid-template-columns: repeat(1, 1fr);
}

@media screen and (max-width: 767px) {
  .article_body .ptn_col {
    grid-template-columns: repeat(1, 1fr);
  }
}

@media screen and (min-width: 768px) {
  .ptn_col.large {
    width: 124rem;
    position: relative;
    left: 50%;
    translate: -50% 0;
  }
}

.ptn_col.article h2, .ptn_col.article h3, .ptn_col.article h4, .ptn_col.article h5 {
  text-align: left;
}

.ptn_col figure {
  margin: 0 -2rem 3.5rem;
}

.article_body .ptn_col figure {
  margin: 0 -2rem 3.5rem;
}

@media screen and (max-width: 767px) {
  .article_body .ptn_col figure {
    margin: 0 0 2.5rem;
  }
}

.ptn_col figure img {
  border-radius: .4rem;
  width: 100%;
  aspect-ratio: 306 / 200;
  object-fit: cover;
}

@media screen and (max-width: 767px) {
  .ptn_col figure {
    margin: 0 0 2.5rem;
  }
}

.ptn_col > * {
  background: #F6F6F6;
  border-radius: .6rem;
  padding: 2rem 4rem 4rem;
  display: block !important;
}

@media screen and (max-width: 767px) {
  .ptn_col > * {
    padding: 2rem 2rem 4rem;
  }
}

.ptn_col > * p + p {
  margin-top: .8em;
}

.ptn_col h2, .ptn_col h3, .ptn_col h4, .ptn_col h5 {
  text-align: center;
  font-size: 2.2rem;
  font-weight: bold;
  margin-bottom: 1em;
}

@media screen and (max-width: 767px) {
  .ptn_col h2, .ptn_col h3, .ptn_col h4, .ptn_col h5 {
    font-size: 2rem;
  }
}

.ptn_col p:not(.num):has(time, strong) {
  margin-top: .8em;
  display: flex;
  gap: 2rem;
}

.ptn_col p:not(.num):has(time, strong) a {
  font-size: 1.2rem;
  background: #E8E8E8;
  font-weight: 500;
  min-width: 12rem;
  text-align: center;
  border-radius: 3em;
  padding: 0 1em;
  font-style: normal !important;
}

.ptn_col p i, .ptn_col p em {
  font-size: 1.2rem;
  background: #E8E8E8;
  font-weight: 500;
  min-width: 12rem;
  text-align: center;
  border-radius: 3em;
  padding: 0 1em;
  font-style: normal !important;
}

.ptn_col p time, .ptn_col p strong {
  font-family: "Poppins", sans-serif;
  font-size: 1.4rem;
  font-weight: normal;
}

.ptn_col .num {
  color: #D0121B;
  font-size: 4.9rem;
  font-weight: 500;
  margin: 2rem 0 1rem;
  text-align: center;
}

.ptn_col .num strong {
  font-family: "Poppins", sans-serif;
  font-size: 6rem;
  font-weight: 500;
}

.ptn_col .small {
  font-size: 1.4rem;
  text-align: center;
}

.ptn_col .c_btn {
  margin-top: 3rem;
}

.ptn_col article > a {
  display: block;
}

@media screen and (min-width: 768px) {
  .ptn_card {
    grid-template-columns: repeat(2, 1fr);
  }
}

.ptn_card h2, .ptn_card h3, .ptn_card h4, .ptn_card h5 {
  text-align: left;
}

.ptn_card em {
  font-weight: 400;
  font-size: 1.4rem;
  display: block;
  margin-left: -1.4rem;
  margin-top: .5em;
}

.ptn_card > * {
  padding: 4rem;
}

@media screen and (max-width: 767px) {
  .ptn_card > * {
    padding: 3rem;
  }
}

.ptn_card > * li {
  position: relative;
  padding-left: 1.4rem;
  font-weight: bold;
  margin-top: 1em;
}

.ptn_card > * li:before {
  content: '';
  position: absolute;
  background: #D0121B;
  width: .375em;
  height: .375em;
  border-radius: 50%;
  left: 0;
  top: .6em;
}

@media screen and (min-width: 768px) {
  .ptn_col2 {
    width: 82rem;
    margin: 0 auto;
    grid-template-columns: repeat(2, 1fr);
  }
}

@media screen and (min-width: 768px) {
  .ptn_col3 {
    grid-template-columns: repeat(3, 1fr);
  }
}

.ptn_col4 {
  grid-template-columns: repeat(2, 1fr);
}

.ptn_col4.large h2, .ptn_col4.large h3, .ptn_col4.large h4, .ptn_col4.large h5 {
  font-size: 2rem;
}

@media screen and (max-width: 767px) {
  .ptn_col4 {
    gap: 1rem;
  }
  .ptn_col4 > * {
    padding: 1.5rem 1.5rem 2.5rem;
  }
  .ptn_col4 figure {
    margin: 0 0 2rem;
  }
}

@media screen and (min-width: 768px) {
  .ptn_col4 {
    grid-template-columns: repeat(4, 1fr);
  }
  .ptn_col4 > * {
    padding-left: 3rem;
    padding-right: 3rem;
  }
  .ptn_col4 figure {
    margin-right: -1rem;
    margin-left: -1rem;
  }
}

.ptn_col4 h2, .ptn_col4 h3, .ptn_col4 h4, .ptn_col4 h5 {
  font-size: 1.6rem;
}

.ptn_relate {
  margin: 3rem auto 0;
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .article_body .ptn_relate {
    grid-template-columns: repeat(1, 1fr);
  }
}

@media screen and (min-width: 768px) {
  .ptn_relate {
    grid-template-columns: repeat(2, 1fr);
  }
  .article_body .ptn_relate {
    grid-template-columns: repeat(2, 1fr);
  }
}

.ptn_relate h3, .ptn_relate h4 {
  font-weight: bold;
  font-size: 1.8rem;
  margin-bottom: .6em;
}

.ptn_relate > div {
  border-radius: .6rem;
  background: #fff;
  padding: 4rem;
  border: solid 1px #F3F3F3;
  display: flex;
  align-items: center;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .ptn_relate > div {
    position: relative;
    padding: 2rem 2rem 4rem;
    gap: 0;
  }
}

.ptn_relate > div > div {
  width: calc(100% - 26rem);
}

@media screen and (max-width: 767px) {
  .ptn_relate > div > div {
    width: calc(100% - 13rem);
  }
}

.ptn_relate > div > div:has(figure) {
  width: 22rem;
}

@media screen and (max-width: 767px) {
  .ptn_relate > div > div:has(figure) {
    width: 11rem;
  }
}

.ptn_relate > div p {
  font-size: 1.4rem;
}

.ptn_relate > div p + p {
  margin-top: 1rem;
}

.article_body .ptn_relate figure {
  margin: 0;
}

.ptn_relate figure img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: .4rem;
}

.ptn_nav {
  margin: 6rem 0;
  display: flex;
  flex-wrap: wrap;
  gap: 1rem;
}

.ptn_nav a {
  display: block;
  border: solid 1px #D0121B;
  font-size: 1.4rem;
  font-weight: 500;
  padding: .2em 2em;
  border-radius: 3em;
  color: #D0121B;
}

.ptn_nav .active {
  background: #D0121B;
  color: #fff;
  pointer-events: none;
}

.ptn_relate p a, .ptn_col:not(:has(time)) p a {
  font-size: 1.4rem;
  color: #D0121B;
  font-weight: 500;
  text-decoration: underline;
}

.ptn_relate p a:before, .ptn_col:not(:has(time)) p a:before {
  content: '» ';
}

:where(.wp-block-post-content, .article_body) p:not(.c_btn, .c_more) a, :where(.wp-block-post-content, .article_body) td a, :where(.wp-block-post-content, .article_body) figcaption a {
  color: #D0121B;
  text-decoration: underline;
}

:where(.wp-block-post-content, .article_body) p:not(.c_btn, .c_more) em, :where(.wp-block-post-content, .article_body) td em, :where(.wp-block-post-content, .article_body) figcaption em {
  font-style: italic;
}

:where(.wp-block-post-content, .article_body) td a:before {
  content: '» ';
}

:where(.wp-block-post-content, .article_body) .c_btn {
  margin: 3rem 0;
}

:where(.wp-block-post-content, .article_body) figure {
  margin: 3rem 0;
}

:where(.wp-block-post-content, .article_body) figure img {
  border-radius: .6rem;
}

:where(.wp-block-post-content, .article_body) figure video {
  width: 100%;
  border-radius: .6rem;
}

:where(.wp-block-post-content, .article_body) .is-provider-youtube iframe {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9;
}

:where(.wp-block-post-content, .article_body) .ptn_fig img, :where(.wp-block-post-content, .article_body) .ptn_fig video {
  width: 63rem;
  max-width: 100%;
}

:where(.wp-block-post-content, .article_body) .ptn_fig_small img {
  width: 25rem;
}

:where(.wp-block-post-content, .article_body) .ptn_full img {
  width: 100%;
}

:where(.wp-block-post-content, .article_body) figcaption {
  font-size: 1.2rem;
  margin-top: .6em;
}

:where(.wp-block-post-content, .article_body) iframe {
  width: 100%;
  display: block;
  margin: 3rem 0;
}

:where(.wp-block-post-content, .article_body) .ptn_comment {
  display: none;
}

:where(.wp-block-post-content, .article_body) p + p {
  margin-top: 1.6em;
}

:where(.wp-block-post-content, .article_body) p > a:has( > img) {
  display: inline-block;
}

:where(.wp-block-post-content, .article_body) sup {
  font-size: .6em;
  vertical-align: .4em;
}

:where(.wp-block-post-content, .article_body) .ptn_tbags_ttl {
  position: relative;
}

@media screen and (min-width: 768px) {
  :where(.wp-block-post-content, .article_body) .ptn_tbags_ttl {
    width: 63rem;
  }
}

:where(.wp-block-post-content, .article_body) .ptn_tbags_ttl img {
  position: absolute;
  right: 0;
  width: 6rem;
  bottom: 0;
}

:where(.wp-block-post-content, .article_body) > .wp-block-columns {
  align-items: flex-start;
  margin: 3rem 0;
}

:where(.wp-block-post-content, .article_body) > .wp-block-columns h2, :where(.wp-block-post-content, .article_body) > .wp-block-columns h3, :where(.wp-block-post-content, .article_body) > .wp-block-columns h4, :where(.wp-block-post-content, .article_body) > .wp-block-columns h5 {
  margin-top: 0;
}

@media screen and (max-width: 767px) {
  :where(.wp-block-post-content, .article_body) > .wp-block-columns {
    flex-direction: column;
  }
}

:where(.wp-block-post-content, .article_body) > .wp-block-columns > * {
  width: 100%;
}

.ptn_cap {
  font-size: 1.4rem;
}

figure + .ptn_cap {
  margin-top: -2.5rem;
}

.ptn_fig2 + .ptn_cap {
  margin-top: -2.5rem;
}

.has-text-align-right {
  text-align: right;
}

.has-text-align-center {
  text-align: center;
}

.has-small-font-size {
  font-size: 1.3rem !important;
}

.has-medium-font-size {
  font-size: 2rem !important;
}

@media screen and (max-width: 767px) {
  .has-medium-font-size {
    font-size: 1.8rem !important;
  }
}

.has-large-font-size {
  font-size: 3.6rem !important;
}

@media screen and (max-width: 767px) {
  .has-large-font-size {
    font-size: 2.4rem !important;
  }
}

.has-x-large-font-size {
  font-size: 4.2rem !important;
}

@media screen and (max-width: 767px) {
  .has-x-large-font-size {
    font-size: 3rem !important;
  }
}

@media screen and (min-width: 768px) {
  .com_msg figure {
    float: left;
    width: 35%;
    margin: 0;
    margin-right: 3rem;
    margin-bottom: 3rem;
  }
}

.ptn_comment {
  margin: 3rem 0 1em;
  color: #D0121B;
  font-size: 1.2rem;
}

.ptn_comment:before, .ptn_comment:after {
  content: '※※↓';
}

.ptn_comment:after {
  content: '※※';
}

.article_body {
  margin-bottom: 6rem;
}

.article_body .data {
  display: flex;
  gap: 2rem;
  line-height: 1.4;
  margin-bottom: -5rem;
}

.article_body .data time {
  font-size: 1.4rem;
  font-family: "Poppins", sans-serif;
}

.article_body .data i, .article_body .data a {
  font-size: 1.2rem;
  background: #E8E8E8;
  font-weight: 500;
  min-width: 12rem;
  text-align: center;
  border-radius: 3em;
  padding: 0 1em;
  color: #0F0F0F;
  text-decoration: none;
}

.article_body + .c_btn {
  margin-bottom: 6rem;
}

.article_body .wp-block-media-text {
  display: grid;
  gap: 4rem;
}

@media screen and (min-width: 768px) {
  .article_body .wp-block-media-text {
    gap: 8rem;
    grid-template-columns: 1fr 1fr;
  }
}

.ptn_ul a, .ptn_ol a {
  color: #D0121B;
  text-decoration: underline;
}

.ptn_ol {
  counter-reset: item;
  margin: 3rem 0;
}

.ptn_ol li {
  position: relative;
  padding-left: 2.2em;
  counter-increment: item;
}

.ptn_ol li + li {
  margin-top: .6em;
}

.ptn_ol li:before {
  content: counter(item);
  position: absolute;
  left: 0;
  font-family: "Poppins", sans-serif;
  font-size: 1.2rem;
  color: #fff;
  width: 1.92em;
  line-height: 1.92;
  text-align: center;
  background: #D0121B;
  border-radius: 50%;
  top: .1em;
  font-weight: 500;
}

.ptn_ul {
  margin: 3rem 0;
}

.ptn_ul li {
  position: relative;
  padding-left: .8em;
}

.ptn_ul li + li {
  margin-top: .6em;
}

.ptn_ul li:before {
  content: '';
  position: absolute;
  width: .25em;
  height: .25em;
  background: #D0121B;
  border-radius: 50%;
  top: .6em;
  left: 0;
}

.ptn_row, .ptn_col {
  margin: 3rem auto;
}

.ptn_faq {
  border-top: solid 1px #D0121B;
  margin: 6rem 0;
}

.ptn_faq details {
  border-bottom: solid 1px #D0121B;
  padding: 0 2rem;
  line-height: 2;
  position: relative;
}

@media screen and (max-width: 767px) {
  .ptn_faq details {
    padding: 0 1rem;
  }
}

.ptn_faq details[open] summary {
  background-image: url(../img/arrow-up02.svg);
}

.ptn_faq summary {
  cursor: pointer;
  font-weight: 600;
  background: url(../img/arrow-down04.svg) no-repeat right center/1.125em;
  padding-right: 2em;
  padding: 2rem 3rem;
}

.ptn_faq summary, .ptn_faq p {
  display: block;
  position: relative;
}

.ptn_faq summary::-webkit-details-marker, .ptn_faq p::-webkit-details-marker {
  display: none;
}

.ptn_faq summary:before, .ptn_faq p:before {
  content: 'Q.';
  position: absolute;
  left: 0;
  font-family: "Poppins", sans-serif;
  font-size: 1.8rem;
  font-weight: 600;
  color: #D0121B;
  top: 1em;
}

.ptn_faq p {
  padding: 0 0 2rem 3rem;
  margin-top: -.5rem;
}

.ptn_faq p:before {
  content: 'A.';
  color: #A29069;
  top: -.1em;
}

.ptn_profile {
  background-image: repeating-linear-gradient(90deg, #0F0F0F, #0F0F0F 1px, transparent 1px, transparent 1rem), repeating-linear-gradient(90deg, #0F0F0F, #0F0F0F 1px, transparent 1px, transparent 1rem);
  background-position: left top, left bottom;
  background-repeat: repeat-x, repeat-x;
  background-size: 100% 1px, 100% 1px;
  padding: 3.5rem 2rem 4rem;
  margin: 6rem 0;
}

@media screen and (max-width: 767px) {
  .ptn_profile {
    padding: 3rem 0 4rem;
  }
}

.ptn_profile > div > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem 0;
}

.ptn_profile .ttl {
  font-weight: bold;
  border-left: solid 2px #D0121B;
  line-height: 1;
  margin-bottom: 1.5em;
  padding-left: .8em;
}

.ptn_profile figure {
  width: 12rem;
}

.ptn_profile figure img {
  border-radius: 50%;
  aspect-ratio: 1 / 1;
  width: 100%;
}

@media screen and (max-width: 767px) {
  .ptn_profile figure {
    margin: 0 auto;
  }
}

@media screen and (min-width: 768px) {
  .ptn_profile p {
    width: calc(100% - 16.5rem);
  }
}

.ptn_profile p strong {
  display: block;
  margin-bottom: .5em;
}

.wp-block-pullquote {
  margin: 3rem 0;
}

.wp-block-pullquote.large {
  border-top: solid 3px #D0121B;
  border-bottom: solid 1px #D0121B;
  text-align: center;
  position: relative;
  padding: 4.5rem 0;
}

@media screen and (max-width: 767px) {
  .wp-block-pullquote.large {
    padding: 3rem 0;
  }
}

.wp-block-pullquote.large:before {
  content: '';
  position: absolute;
  width: 100%;
  left: 0;
  top: 2px;
  border-bottom: solid 1px #D0121B;
}

.wp-block-pullquote.large cite {
  font-size: 1.6rem;
}

.wp-block-pullquote.large p {
  font-size: 3rem;
  font-weight: bold;
}

@media screen and (max-width: 767px) {
  .wp-block-pullquote.large p {
    font-size: 2.6rem;
  }
}

.wp-block-pullquote:not(.large) {
  background: #F6F6F6;
  border: solid 1px #eee;
  padding: 4rem 4rem 3rem;
  z-index: 0;
  position: relative;
  margin: 2rem auto;
}

@media screen and (max-width: 767px) {
  .wp-block-pullquote:not(.large) {
    padding: 4rem 3rem 2.5rem;
  }
}

.wp-block-pullquote:not(.large):before, .wp-block-pullquote:not(.large):after {
  content: '';
  position: absolute;
  background: url(../img/quote-left.svg) no-repeat 50%/contain;
  width: 3.5rem;
  height: 2.9rem;
  z-index: -1;
}

.wp-block-pullquote:not(.large):before {
  left: 1rem;
  top: 1rem;
}

.wp-block-pullquote:not(.large):after {
  background-image: url(../img/quote-right.svg);
  right: 1rem;
  bottom: 1rem;
}

.wp-block-pullquote:not(.large) p {
  font-size: 1.6rem;
  text-align: left;
}

.wp-block-pullquote:not(.large) cite {
  color: #888888;
  font-size: 1.4rem;
  display: block;
  text-align: right;
  margin-top: .6em;
}

.ptn_fn {
  background: #F6F6F6;
  border: solid 1px #eee;
  padding: 4rem;
  position: relative;
  margin: 2rem auto;
}

@media screen and (max-width: 767px) {
  .ptn_fn {
    padding: 3rem 2rem;
  }
}

.ptn_fn li {
  position: relative;
  padding-left: 2em;
}

.ptn_fn li + li {
  margin-top: .6em;
}

.ptn_fn li em {
  position: absolute;
  color: #D0121B;
  left: 0;
}

.ptn_tbl1 {
  margin: 3rem auto;
}

.ptn_tbl1 table {
  table-layout: fixed;
}

.ptn_tbl1 td {
  padding: .9em 1.2em;
}

@media screen and (max-width: 767px) {
  .ptn_tbl1 td {
    padding: .9em .5em;
  }
}

.ptn_tbl1 tr:nth-child(1) td {
  background: #D0121B;
  color: #fff;
  font-weight: bold;
  border-bottom: solid 1px #D0121B;
  border-left: solid 1px #D0121B;
}

.ptn_tbl1 tr:nth-child(1) td:last-child {
  border-right: solid 1px #D0121B;
}

.ptn_tbl1 tr:nth-child(1) td + td {
  border-left: solid 1px #fff;
}

.ptn_tbl1 tr + tr td {
  border: solid 1px #eee;
}

@media screen and (min-width: 768px) {
  .ptn_tbl1 {
    overflow: visible !important;
  }
}

@media screen and (max-width: 767px) {
  .ptn_tbl1 {
    overflow: hidden;
    overflow-x: auto;
  }
  .ptn_tbl1 table {
    width: 100rem;
  }
}

.wp-block-table:has(th) {
  margin: 3rem auto;
}

.wp-block-table:has(th) th {
  background: #D0121B;
  color: #fff;
  font-weight: bold;
}

.wp-block-table:has(th) td, .wp-block-table:has(th) th {
  padding: .9em 1.2em;
  border: solid 1px #eee;
}

.ptn_tbl2, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) {
  margin: 3rem auto;
}

@media screen and (max-width: 767px) {
  .ptn_tbl2 table, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) table {
    border-bottom: solid 1px #eee;
  }
}

.ptn_tbl2 td, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td {
  padding: .9em 1.2em;
}

.ptn_tbl2 td + td, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td + td {
  border: solid 1px #eee;
}

@media screen and (max-width: 767px) {
  .ptn_tbl2 td + td, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td + td {
    border-top: none;
    border-bottom: none;
  }
}

@media screen and (max-width: 767px) {
  .ptn_tbl2 td, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td {
    float: left;
    width: 100%;
    padding: .9em 1em;
  }
}

.ptn_tbl2 td:first-child, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td:first-child {
  background: #D0121B;
  color: #fff;
  font-weight: bold;
}

@media screen and (min-width: 768px) {
  .ptn_tbl2 td:first-child, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) td:first-child {
    width: 26rem;
    border-bottom: solid 1px #fff;
    border-top: solid 1px #fff;
    border-left: solid 1px #D0121B;
    border-right: solid 1px #D0121B;
  }
}

.ptn_tbl2 tr:first-child td:first-child, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) tr:first-child td:first-child {
  border-top: solid 1px #D0121B;
}

.ptn_tbl2 tr:last-child td:first-child, .wp-block-table:not(.ptn_tbl1, .ptn_tbl3, :has(th)) tr:last-child td:first-child {
  border-bottom: solid 1px #D0121B;
}

.ptn_tbl3 {
  margin: 3rem 0;
}

.ptn_tbl3 td {
  padding: 0 1.2em .9em;
  border-bottom: solid 1px #eee;
}

@media screen and (max-width: 767px) {
  .ptn_tbl3 td {
    float: left;
    width: 100%;
    padding: .9em 0;
  }
}

.ptn_tbl3 tr + tr td {
  padding-top: 1em;
}

.ptn_tbl3 td:first-child {
  font-weight: bold;
  position: relative;
}

@media screen and (min-width: 768px) {
  .ptn_tbl3 td:first-child {
    padding-left: .7em;
  }
}

.ptn_tbl3 td:first-child:before {
  content: '';
  position: absolute;
  width: 2.5em;
  border-bottom: solid 1px #D0121B;
  bottom: -1px;
  left: 0;
}

@media screen and (min-width: 768px) {
  .ptn_tbl3 td:first-child {
    width: 26rem;
  }
}

h5 + figure {
  margin-top: 0;
}

h5 + .ptn_fig2 {
  margin-top: 0;
}

.ptn_fig2 {
  margin: 3rem 0;
  gap: 3rem 5rem;
}

.ptn_fig2:has(figure + figure) figure img {
  width: 100%;
}

@media screen and (max-width: 767px) {
  .ptn_fig2 {
    grid-template-columns: repeat(1, 1fr);
  }
  .article_body .ptn_fig2 {
    grid-template-columns: repeat(1, 1fr);
  }
}

.rec_header {
  position: relative;
  margin: 14rem 0 8rem;
}

@media screen and (max-width: 767px) {
  .rec_header {
    margin: 6rem 0 3rem;
  }
}

.rec_header .bg {
  position: absolute;
  left: 50%;
  translate: -50% 0;
  width: 100%;
  top: 13rem;
  z-index: -1;
  mask: url(../img/recruit-bg-clip.svg) no-repeat center top/299rem;
}

@media screen and (max-width: 767px) {
  .rec_header .bg {
    top: 10rem;
    right: 0;
    left: auto;
    translate: 0;
    width: 200%;
    mask-size: calc(100rem + 250vw);
  }
}

.rec_header .bg img {
  width: 100%;
  object-fit: cover;
  height: 107rem;
}

@media screen and (max-width: 767px) {
  .rec_header .bg img {
    height: calc(40rem + 120vw);
  }
}

.rec_header .slide {
  display: flex;
  overflow: hidden;
  padding-bottom: 2.2rem;
  margin-bottom: 4.5rem;
}

@media screen and (max-width: 767px) {
  .rec_header .slide {
    margin-bottom: 2.5rem;
  }
}

.rec_header .slide p {
  animation: scroll-left 80s infinite linear .5s both;
  display: flex;
  gap: 2rem;
  padding-right: 2rem;
}

.rec_header .slide img {
  height: 32.2rem;
  max-width: none;
  width: auto;
  border-radius: 1rem;
}

@media screen and (max-width: 767px) {
  .rec_header .slide img {
    height: 20rem;
    border-radius: .5rem;
  }
}

.rec_header .slide img:nth-child(even) {
  position: relative;
  top: 2.2rem;
}

.rec_header .low_path {
  justify-content: flex-end;
  color: #fff;
  margin-bottom: 2rem;
}

.rec_header .low_path a {
  color: rgba(255, 255, 255, 0.5);
}

.rec_header .low_path li + li:before {
  border-color: rgba(255, 255, 255, 0.5);
}

.rec_header .catch {
  color: #fff;
  font-size: 5.6rem;
  font-weight: 800;
}

@media screen and (max-width: 767px) {
  .rec_header .catch {
    font-size: 4rem;
  }
}

@keyframes scroll-left {
  from {
    transform: translateX(0);
  }
  to {
    transform: translateX(-100%);
  }
}

.rec_msg {
  margin-bottom: 11rem;
}

@media screen and (min-width: 768px) {
  .rec_msg {
    margin-bottom: 11rem;
  }
  .rec_msg .row {
    display: flex;
    flex-direction: row-reverse;
    align-items: flex-end;
  }
  .rec_msg .row .fig {
    width: calc(50% - 1rem);
  }
  .rec_msg .desc {
    width: 56rem;
    padding-bottom: 15rem;
  }
}

@media screen and (max-width: 767px) {
  .rec_msg .c_ttl {
    margin-bottom: 3rem;
  }
}

@media screen and (max-width: 767px) {
  .rec_msg .desc {
    margin: 3rem 2rem;
  }
}

.rec_msg .desc p {
  font-size: 1.8rem;
  line-height: 2.4;
}

@media screen and (min-width: 768px) {
  .rec_msg .desc p {
    font-size: 2rem;
    white-space: nowrap;
  }
}

.rec_msg figure {
  aspect-ratio: 670 / 647;
  position: relative;
  max-width: 67rem;
}

@media screen and (max-width: 767px) {
  .rec_msg figure {
    width: auto;
    margin: 0 2rem;
  }
}

.rec_msg figure img {
  position: absolute;
  border-radius: 1rem;
}

.rec_msg figure .a {
  position: static;
  width: 48%;
}

.rec_msg figure .b {
  width: 30%;
  top: 17%;
  right: 17%;
}

.rec_msg figure .c {
  width: 36%;
  top: 43%;
  left: 12%;
}

.rec_msg figure .d {
  width: 42%;
  right: 0;
  bottom: 0;
}

.rec_lead {
  display: flex;
  justify-content: space-between;
  margin-bottom: 10rem;
}

@media screen and (max-width: 767px) {
  .rec_lead {
    flex-direction: column;
    gap: 2.5rem;
  }
}

@media screen and (max-width: 767px) {
  .rec_lead {
    margin-bottom: 8rem;
  }
}

@media screen and (min-width: 768px) {
  .rec_lead figure {
    width: 44rem;
  }
}

.rec_lead figure img {
  border-radius: .4rem;
}

@media screen and (min-width: 768px) {
  .rec_lead .desc {
    margin-top: 2.5rem;
    width: calc(100% - 52rem);
  }
}

.rec_lead .ttl {
  font-size: 3.4rem;
  font-weight: 800;
  margin-bottom: 1em;
}

.c_sec {
  margin-bottom: 10rem;
}

@media screen and (max-width: 767px) {
  .c_sec {
    margin-bottom: 8rem;
  }
}

.c_sec .c_btn {
  text-align: center;
  margin-top: 3rem;
}

.rec_deck p {
  font-weight: bold;
  font-size: 1.8rem;
}

.rec_deck figure {
  width: 88rem;
  margin: 3rem auto;
  max-width: 100%;
}

.rec_deck iframe {
  background: padding-box padding-box rgba(0, 0, 0, 0.1);
  border-radius: .6rem;
  box-shadow: rgba(0, 0, 0, 0.2) 0px 0.5rem 1.5rem;
  width: 100%;
  height: auto;
  aspect-ratio: 560 / 315;
}

.rec_staff .row {
  display: flex;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .rec_staff .row {
    flex-direction: column;
    gap: 2.5rem;
  }
}

@media screen and (min-width: 768px) {
  .rec_staff .row .desc {
    width: calc(100% - 52rem);
    margin-top: 3rem;
  }
}

@media screen and (min-width: 768px) {
  .rec_staff .row figure {
    width: 44rem;
  }
}

.rec_staff .row figure img {
  border-radius: .4rem;
}

.rec_staff ul {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 2rem;
}

@media screen and (max-width: 767px) {
  .rec_staff ul {
    grid-template-columns: repeat(1, 1fr);
    gap: 2rem;
  }
}

.rec_work li {
  padding-bottom: 4rem;
}

.ptn_data > * {
  padding: 4rem 3rem;
}

.article_body .ptn_data figure {
  margin: 0;
}

.ptn_data figure {
  margin: 0;
}

.ptn_data p {
  text-align: center;
}

.ptn_data b {
  display: block;
  font-family: "Poppins", sans-serif;
  color: #D0121B;
  font-size: 4.9rem;
  font-weight: 500;
  margin: 2rem 0 1rem;
}

.ptn_data data {
  font-size: 6rem;
}

.ptn_data small {
  display: block;
  font-size: 1.4rem;
}

.rec_news li {
  padding: 2rem 0;
  border-bottom: solid 1px #EEEEEE;
}

.rec_news li a {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
}

@media screen and (max-width: 767px) {
  .rec_news li a {
    flex-direction: column;
    gap: .5rem;
  }
}

.rec_news li p {
  display: flex;
  align-items: center;
  gap: 2rem;
}

@media screen and (min-width: 768px) {
  .rec_news li p {
    width: 25rem;
  }
}

.rec_news li time {
  font-size: 1.4rem;
  font-family: "Poppins", sans-serif;
}

.rec_news li i {
  font-size: 1.2rem;
  background: #E8E8E8;
  font-weight: 500;
  min-width: 12rem;
  text-align: center;
  border-radius: 3em;
  padding: .1em 1em;
}

@media screen and (min-width: 768px) {
  .rec_news .ttl {
    width: calc(100% - 25rem);
  }
}

.rec_entry .c_btn {
  display: grid;
  gap: 2rem;
  margin: 2rem 0 3.5rem;
  grid-template-columns: repeat(3, 1fr);
}

@media screen and (max-width: 767px) {
  .rec_entry .c_btn {
    grid-template-columns: repeat(1, 1fr);
  }
}

.rec_entry li a {
  width: 100%;
  height: 5rem;
  background-position: calc(100% - 1.5rem);
}

.rec_entry .ttl {
  font-weight: bold;
  font-size: 2rem;
  display: flex;
  gap: 1em;
  align-items: flex-end;
}

@media screen and (max-width: 767px) {
  .rec_entry .ttl {
    flex-direction: column;
    gap: .2em;
    align-items: flex-start;
  }
}

.rec_entry .ttl small {
  font-size: 1.6rem;
  font-weight: normal;
}

.com_tech .ptn_tbl1 td {
  text-align: center;
}

.com_tech .ptn_tbl1 td a:before {
  content: none;
  text-decoration: none;
}

.com_tech .ptn_tbl1 .tokkyologo {
  width: 40%;
}

.com_tech .ptn_tbl1 .tokkyologo2 {
  width: 30%;
}

.com_tech .ptn_tbl1:has(td:nth-child(4)) td:nth-child(2) {
  text-align: left;
  width: 40%;
}

.com_tech .ptn_tbl1:has(td:nth-child(5)) td:nth-child(5) {
  width: 10%;
}

/*# sourceMappingURL=style.css.map */