/*!*************************************************************************************************************************************************************************************************************************!*\
  !*** css ./node_modules/css-loader/dist/cjs.js??ruleSet[1].rules[0].use[2]!./node_modules/sass-loader/dist/cjs.js??ruleSet[1].rules[0].use[3]!./node_modules/webpack-dart-sass-glob/index.js!./src/scss/styles-pc.scss ***!
  \*************************************************************************************************************************************************************************************************************************/
@charset "UTF-8";
:root {
  --base-letter-spacing: 0.05em;
}

* {
  letter-spacing: var(--base-letter-spacing);
}

html {
  scroll-behavior: smooth;
}

body {
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  color: #111310;
  letter-spacing: 0.05em;
  word-break: break-word;
  background: #fff;
}

a {
  display: block;
  color: inherit;
  text-decoration: none;
  opacity: 1;
  transition: all 0.3s ease;
}
a:hover {
  cursor: pointer;
  opacity: 0.7;
}

img {
  display: block;
  max-width: 100%;
  height: auto;
}

address {
  font-style: normal;
}

main {
  width: 100%;
}

/*recaptureバッジを非表示に*/
.grecaptcha-badge {
  display: none;
}

body {
  font-size: 16px;
  line-height: 2.0625;
}

a[href^="tel:"] {
  pointer-events: none;
}

.h-tac {
  text-align: center;
}

.h-oh {
  overflow: hidden;
}

.h-ct {
  display: block;
  overflow: hidden;
  font-size: 0;
  text-indent: 100%;
  white-space: nowrap;
}

.h-overflow-x-scroll {
  overflow-x: scroll;
}

.effect-fade {
  opacity: 0;
  transition: all 0.3s;
  transform: translate(0, 45px);
}
.effect-fade.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}

.effect-slidein {
  opacity: 0;
  transition: opacity 1s, transform 0.8s;
  transform: translateX(-80px);
}
.effect-slidein.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}

.effect-slidein-right {
  opacity: 0;
  transition: opacity 1s, transform 0.8s;
  transform: translateX(80px);
}
.effect-slidein-right.effect-scroll {
  opacity: 1;
  transform: translate(0, 0);
}

@keyframes fadeInTop {
  from {
    opacity: 0;
    transform: translateY(-80px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.effect-fadeintop {
  opacity: 0;
  transform: translateY(-80px);
}
.effect-fadeintop.effect-scroll {
  animation-name: fadeInTop;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
}

@keyframes fadeInBottom {
  from {
    opacity: 0;
    transform: translateY(80px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.effect-fadeinbottom {
  opacity: 0;
  transform: translateY(80px);
}
.effect-fadeinbottom.effect-scroll {
  animation-name: fadeInBottom;
  animation-duration: 0.8s;
  animation-fill-mode: forwards;
}

.wpcf7 .note {
  margin-bottom: 5px;
  text-align: left;
}
.wpcf7 .memo {
  margin-bottom: 5px;
  text-align: left;
}
.wpcf7 .buttons {
  margin-top: 40px;
  text-align: center;
}
.wpcf7-list-item {
  display: block;
  margin: 3px 0 0 1em;
}
.wpcf7-not-valid-tip {
  display: block;
  font-size: 15px;
  font-weight: normal;
  color: #dc3232;
}
.wpcf7 textarea,
.wpcf7 input[type=text],
.wpcf7 input[type=email],
.wpcf7 input[type=tel] {
  width: 95%;
  padding: 6px 3px;
  font-size: 15px;
  line-height: 1.5em;
  text-align: left;
  appearance: none;
  background-color: #fdfdfd;
  border: 1px solid #ccc;
  border-radius: 1px;
}
.wpcf7 input[type=date] {
  min-width: 50%;
  min-height: 27px;
  padding: 6px 3px;
  font-size: 15px;
  line-height: 1.5em;
  text-align: left;
  appearance: none;
  background-color: #fdfdfd;
  border: 1px solid #ccc;
  border-radius: 1px;
}
.wpcf7 input[type=number] {
  padding: 6px 3px;
  font-size: 15px;
  line-height: 1.5em;
  text-align: left;
  appearance: none;
  background-color: #fdfdfd;
  border: 1px solid #ccc;
  border-radius: 1px;
}
.wpcf7 input {
  position: relative;
}
.wpcf7 input[type=checkbox], .wpcf7 input[type=radio] {
  top: -2px;
  margin-right: 6px;
}
.wpcf7 input[type=tel] {
  width: 50%;
}
.wpcf7 input[type=submit], .wpcf7 input[type=reset], .wpcf7 input[type=button],
.wpcf7 input button {
  display: inline-block;
  appearance: none;
  cursor: pointer;
  border: none;
}
.wpcf7 th {
  width: 25%;
  padding: 16px 20px;
  font-size: 16px;
  font-weight: normal;
  color: #111;
  text-align: left;
  vertical-align: middle;
  background-color: #eee;
  border-top: 1px solid #ddd;
  border-bottom: 1px solid #ddd;
}
.wpcf7 th b {
  margin-left: 4px;
  color: #d74a5b;
}
.wpcf7 td {
  width: 75%;
  padding: 16px 20px;
  font-size: 15px;
  color: #111;
  text-align: left;
  vertical-align: middle;
  border-bottom: 1px solid #eee;
}
.wpcf7 td.mia input[type=text], .wpcf7 td.mia input[type=email] {
  width: 70%;
}
.wpcf7 table {
  border-spacing: 0;
  border-collapse: collapse;
  background-color: #fff;
  border: 1px solid #ddd;
}
.wpcf7 table.in_tbl {
  width: 80%;
  margin-bottom: 10px;
}
.wpcf7 table.in_tbl th {
  width: 160px;
}
.wpcf7 #wpcf7cpcnf td > p {
  font-size: 15px;
}
.wpcf7 .wpcf7cp-btns {
  margin-top: 4em;
  text-align: center;
}
.wpcf7 .wpcf7cp-form-hide {
  display: none;
}
.wpcf7 #wpcf7cpcnf {
  position: relative;
  padding-bottom: 45px;
}
.wpcf7 .recaptcha_text {
  margin-top: 8px;
  font-size: 12px;
}
.wpcf7 .recaptcha_text a {
  display: inline-block;
  text-decoration: underline;
}
.wpcf7 .recaptcha_text a:hover {
  text-decoration: none;
}

.wp-pagenavi {
  padding: 80px 0 0;
  text-align: center;
}
.wp-pagenavi a {
  display: inline-block;
  padding: 7px 9px 7px 10px;
  margin: 0 2px;
  font-size: 14px;
  line-height: 1;
  color: #3e3a39;
  background-color: #fff;
  border: 1px solid rgba(133, 122, 133, 0.2);
  border-radius: 3px;
  box-shadow: 0px 0px 3px rgba(35, 24, 21, 0.1);
}
.wp-pagenavi a:hover {
  color: #fff;
  text-decoration: none;
  background: #04092a;
}
.wp-pagenavi span.current {
  display: inline-block;
  padding: 7px 9px 7px 10px;
  margin: 0 2px;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  background: #04092a;
  border: 1px solid #000;
  border-radius: 3px;
  box-shadow: 0px 0px 3px rgba(35, 24, 21, 0.2);
}

.c-work-slider-2 .c-slider__track {
  justify-content: center;
  overflow: unset;
}
.c-work-slider-2 .c-slider__arrow-left {
  right: calc(50% - 336px);
  bottom: -34px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/c_work_slider_chevron_left.svg") center/9px 16px no-repeat;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 50%;
}
.c-work-slider-2 .c-slider__arrow-right {
  right: calc(50% - 420px);
  bottom: -34px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/c_work_slider_chevron_right.svg") center/9px 16px no-repeat;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 50%;
}
.c-work-slider-2 .item {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 830px;
  height: 552px;
  margin-right: 28px;
}
.c-work-slider-2 .item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-work-slider-2__sub-slider {
  margin-top: 60px;
}
.c-work-slider-2__sub-slider ul {
  display: grid;
  grid-template-columns: repeat(auto-fit, 102px);
  gap: 8px;
  justify-content: center;
}
.c-work-slider-2__sub-slider ul li {
  height: 68px;
}
.c-work-slider-2__sub-slider ul li button {
  width: 100%;
  height: 100%;
}
.c-work-slider-2__sub-slider ul li button:hover {
  cursor: pointer;
  opacity: 0.7;
}
.c-work-slider-2__sub-slider ul li button img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-tel {
  display: inline-block;
}
.c-tel__inner {
  display: flex;
  align-items: center;
  font-size: var(--c-tel-font-size, 28px);
  font-weight: bold;
  line-height: 1;
  color: var(--c-tel-color-text, #141414);
}
.c-tel__inner::before {
  display: block;
  flex: 0 0 auto;
  width: var(--c-tel-icon-size, 21px);
  height: var(--c-tel-icon-size, 21px);
  margin-right: var(--c-tel-gap, 14px);
  content: "";
  background: var(--c-tel-url-tel-icon, url("../img/pc/icon_tel_theme_white.svg")) no-repeat;
}

.c-slider-smooth {
  overflow-x: hidden;
}
@keyframes slide1 {
  0% {
    transform: translateX(calc(100% - 5px));
  }
  to {
    transform: translateX(-100%);
  }
}
@keyframes slide2 {
  0% {
    transform: translateX(-5px);
  }
  to {
    transform: translateX(-200%);
  }
}
.c-slider-smooth__inner {
  display: flex;
  flex: 0 0 auto;
  height: 100%;
}
.c-slider-smooth__group {
  display: flex;
  flex: 0 0 auto;
  height: 100%;
}
.c-slider-smooth__group--main {
  animation: slide1 120s -60s linear infinite;
}
.c-slider-smooth__group--dummy {
  animation: slide2 120s linear infinite;
}
.c-slider-smooth__item {
  height: 100%;
}
.c-slider-smooth__item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-slider-one {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider__container {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider__track {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider__item {
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider__item img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-slider-one__main-slider .c-slider__arrow-right {
  right: -16px;
  bottom: -6px;
  width: 56px;
  height: 56px;
  background: #fff url("../img/pc/c_slider_one_chevron_right.svg") center/9px 16px no-repeat;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 50%;
}
.c-slider-one__main-slider .c-slider__arrow-left {
  right: 52px;
  bottom: -6px;
  width: 56px;
  height: 56px;
  background: #fff url("../img/pc/c_slider_one_chevron_left.svg") center/9px 16px no-repeat;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 50%;
}
.c-slider-one__sub-slider {
  margin-top: 8px;
}
.c-slider-one__sub-slider ul {
  display: grid;
  grid-template-columns: repeat(3, 176px);
  grid-gap: 8px;
}
.c-slider-one__sub-slider li {
  height: 118px;
  cursor: pointer;
}
.c-slider-one__sub-slider li:hover {
  cursor: pointer;
  opacity: 0.7;
}
.c-slider-one__sub-slider li img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-slider-fade {
  width: 100%;
  height: 100%;
}
.c-slider-fade .keen-slider {
  position: relative;
  width: 100%;
  height: 100%;
}
.c-slider-fade .keen-slider .keen-slider__slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
}
.c-slider-fade .keen-slider .keen-slider__slide img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}

.c-slider {
  position: relative;
}
.c-slider__wrapper {
  width: 100%;
}
.c-slider__container {
  width: 100%;
  overflow: hidden;
}
.c-slider__track {
  display: flex;
}
.c-slider__item {
  flex: 0 0 auto;
  overflow: unset;
}
.c-slider__arrow-right {
  position: absolute;
}
.c-slider__arrow-right:hover {
  cursor: pointer;
  opacity: 0.7;
}
.c-slider__arrow-left {
  position: absolute;
}
.c-slider__arrow-left:hover {
  cursor: pointer;
  opacity: 0.7;
}

.c-recruit-table {
  position: relative;
  padding: 34px 0 67px;
  background-color: #fff;
}
.c-recruit-table__title {
  width: 94.6%;
  padding: 17px 20px 15px;
  margin: 0 auto 26px;
  font-size: 18px;
  font-weight: bold;
  line-height: 31px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.05em;
  background-color: #04092a;
}
.c-recruit-table dl {
  display: flex;
  justify-content: space-between;
  width: 84.5%;
  margin: 0 auto;
  line-height: 1.6;
}
.c-recruit-table dt {
  width: 16%;
  padding: 18px 0 11px 6px;
  font-size: 16px;
  font-weight: normal;
  color: #04092a;
  text-align: justify;
  text-align-last: justify;
  border-bottom: 1px dashed rgba(113, 112, 113, 0.25);
}
.c-recruit-table dd {
  width: 79%;
  padding: 18px 0 11px 2px;
  font-size: 16px;
  border-bottom: 1px dashed rgba(113, 112, 113, 0.25);
}
.c-recruit-table__button {
  width: 362px;
  margin: 87px auto 0;
  background-color: #04092a;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.2);
}
.c-recruit-table__button a {
  display: flex;
  align-items: center;
  min-height: 66px;
  padding: 10px 30px;
  font-weight: bold;
  line-height: 20px;
  color: #fff;
}
.c-recruit-table__button a::after {
  display: block;
  flex: 0 0 auto;
  width: 22px;
  height: 22px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/c_recruit_table_chevron.svg") no-repeat;
}

.c-qa {
  background: #ffffff;
}
.c-qa__title-inner {
  display: flex;
  align-items: center;
  padding: 19px 24px;
}
.c-qa__title-inner::before {
  position: relative;
  top: 4px;
  display: block;
  flex: 0 0 auto;
  width: 23px;
  height: 20px;
  content: "";
  background-repeat: no-repeat;
  background-image: url("../img/pc/c_qa_q.png");
  background-image: image-set(url("../img/pc/c_qa_q.png") 1x, url("../img/pc/c_qa_q@2x.png") 2x);
}
.c-qa__title-inner::after {
  display: block;
  width: 16px;
  height: 9px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/c_qa_chevron.svg") no-repeat;
}
.c-qa__title {
  padding: 0 24px;
  font-size: 20px;
  font-weight: bold;
  line-height: 30px;
  color: #04092a;
  letter-spacing: 0.1em;
}
.c-qa__content-inner {
  padding: 16px 32px 30px;
  color: #04092a;
}
.c-qa__content-close {
  display: flex;
  gap: 4px;
  align-items: center;
  justify-content: center;
  width: 114px;
  height: 36px;
  margin: 24px auto 0;
  color: #000;
  background-color: #ddd;
}
.c-qa__content-close::before {
  position: relative;
  top: -1px;
  display: block;
  font-size: 20px;
  line-height: 1;
  content: "×";
}

.c-post-front-product-card a {
  height: 100%;
  padding: 8px;
  border-top: 1px solid rgba(20, 20, 20, 0.5);
  border-bottom: 1px solid rgba(20, 20, 20, 0.5);
  border-left: 1px solid rgba(20, 20, 20, 0.5);
}
.c-post-front-product-card__image {
  height: 302px;
  background: #9e9e9f;
}
.c-post-front-product-card__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.c-post-front-product-card__main {
  padding: 20px 32px 32px;
}
.c-post-front-product-card__title {
  height: 66px;
  font-size: 20px;
  font-weight: bold;
  line-height: 33px;
  letter-spacing: 0.1em;
}
.c-post-front-product-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.c-post-front-product-card__term {
  padding: 7px 15px;
  font-size: 14px;
  line-height: 20px;
  background: #f5f6f6;
}
.c-post-front-product-card__content {
  margin-top: 16px;
}

.c-post-archive-bar {
  padding: 14px;
  background: #fff;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.1);
}
.c-post-archive-bar__inner {
  display: flex;
  gap: 66px;
}
.c-post-archive-bar__image {
  position: relative;
  flex: 0 0 auto;
  width: 466px;
  height: 356px;
  background: #9e9e9f;
}
.c-post-archive-bar__image img {
  position: absolute;
  object-fit: cover;
  inset: 0;
  width: 100%;
  height: 100%;
}
.c-post-archive-bar__main {
  flex: 1 1 auto;
  padding: 22px 12px 8px 0;
}
.c-post-archive-bar__title {
  font-size: 31px;
  font-weight: bold;
  line-height: 48px;
  letter-spacing: 0.1em;
}
.c-post-archive-bar__sub-title {
  margin-top: 12px;
  font-size: 17px;
  font-weight: bold;
  line-height: 24px;
  color: #5d3260;
}
.c-post-archive-bar__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.c-post-archive-bar__term {
  padding: 7px 15px;
  font-size: 14px;
  line-height: 20px;
  background: #f5f6f6;
}
.c-post-archive-bar__content {
  margin-top: 24px;
}
.c-post-archive-bar__button {
  margin: 18px 0 0 auto;
}

.js-toggle-card {
  overflow: hidden;
}
.js-toggle-card__button:hover {
  cursor: pointer;
  opacity: 0.7;
}
.js-toggle-card__content {
  visibility: hidden;
  transition: all 0.2s;
}
.js-toggle-card__close:hover {
  cursor: pointer;
  opacity: 0.7;
}

.c-facility-category__title {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 18px 20px;
  font-size: 18px;
  font-weight: bold;
  line-height: 28px;
  color: #fff;
  background: #04092a;
}
.c-facility-category .table {
  padding: 4px 18px 0;
  background: #fff;
  border-right: 1px solid rgba(114, 113, 113, 0.5);
  border-bottom: 1px solid rgba(114, 113, 113, 0.5);
  border-left: 1px solid rgba(114, 113, 113, 0.5);
}
.c-facility-category .table__list {
  container-type: inline-size;
}
.c-facility-category .table__list .row {
  display: flex;
  flex-wrap: wrap;
  gap: 10px 0;
  padding: 17px 0;
  border-bottom: 1px dashed rgba(114, 113, 113, 0.5);
}
.c-facility-category .table__list .row:last-of-type {
  border-bottom: unset;
}
@container (width < 1000px) {
  .c-facility-category .table__list .row {
    flex-wrap: wrap;
  }
}
.c-facility-category .table__list .row__info {
  padding-left: 20px;
}
.c-facility-category .table__list .row__other {
  display: flex;
  padding-left: 20px;
  margin-left: auto;
}
.c-facility-category .table__list .row__note {
  flex: 1 1 auto;
}
.c-facility-category .table__list .row__number {
  flex: 0 0 auto;
  width: 114px;
  margin-left: auto;
  text-align: center;
}

.c-button-arrow {
  width: var(--c-button-arrow-width, 214px);
  height: var(--c-button-arrow-height, 54px);
}
.c-button-arrow__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 0 34px;
  background-color: var(--c-button-arrow-bg-color, #141414);
  border: 1px solid var(--c-button-arrow-border-color, #474645);
  border-radius: 3px;
}
.c-button-arrow__inner::after {
  display: block;
  width: 32px;
  height: 10px;
  margin-left: auto;
  content: "";
  background: var(--c-button-arrow-arrow-url, url("../img/pc/c_button_arrow_gray.svg")) no-repeat;
}

.c-archive-nothing {
  max-width: 1084px;
  padding: 100px 0;
  margin: 0 auto;
}

.b-top-button__button {
  position: fixed;
  right: 100px;
  bottom: 72px;
  z-index: 9000;
  width: 53px;
  height: 53px;
  visibility: hidden;
  opacity: 0;
  transition: 0.3s;
  cursor: pointer;
  opacity: 0.7;
}
.b-top-button__button--visible {
  visibility: visible;
  opacity: 1;
}

.b-site-banner {
  padding: 94px 40px 84px;
  border-bottom: 1px solid #868686;
}
.b-site-banner__title {
  display: flex;
  justify-content: center;
}
.b-site-banner__list {
  display: flex;
  flex-wrap: wrap;
  gap: 32px;
  justify-content: center;
  margin-top: 36px;
}
.b-site-banner__item {
  width: 587px;
  height: 162px;
}

.b-privacy-policy__text {
  font-size: 16px;
  line-height: 31px;
}
.b-privacy-policy__text span {
  font-size: 18px;
  font-weight: bold;
}

.b-post-vertical-slider {
  height: 100%;
}
.b-post-vertical-slider .c-slider {
  width: 100%;
  height: 100%;
}
.b-post-vertical-slider .c-slider__container {
  height: 100%;
}
.b-post-vertical-slider .c-slider__track {
  height: 100%;
}
.b-post-vertical-slider .c-slider .item {
  width: 100%;
  height: 100%;
}
.b-post-vertical-slider .c-slider .item__inner {
  display: flex;
  gap: 20px;
  align-items: center;
  height: 100%;
  padding: 0 24px 0 30px;
}
.b-post-vertical-slider .c-slider .item__inner::after {
  display: block;
  flex: 0 0 auto;
  width: 18px;
  height: 18px;
  margin-left: auto;
  content: "";
  background: #fff;
  background: url("../img/pc/b_post_vertical_slider_chevron.svg");
}
.b-post-vertical-slider .c-slider .item__text {
  font-size: 16px;
  font-weight: bold;
  line-height: 24px;
  color: #fff;
}

.b-post-nav ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 22px;
  max-width: 1200px;
  margin: 0 auto;
}
.b-post-nav li a {
  display: flex;
  align-items: center;
  height: 96px;
  padding: 0 32px;
  background: #04092a;
}
.b-post-nav li a span {
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
}
.b-post-nav li a::after {
  display: block;
  width: 29px;
  height: 29px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/b_post_nav_chevron.svg") no-repeat;
}

.b-post-content * {
  max-width: 100%;
}
.b-post-content > *:first-child {
  margin-top: unset;
}
.b-post-content > *:first-child * {
  margin-top: unset;
}
.b-post-content > *:last-child {
  margin-bottom: unset;
}
.b-post-content > *:last-child * {
  margin-bottom: unset;
}
.b-post-content h2 {
  max-width: unset;
  padding: 7px 43px;
  margin: 40px calc(50% - 450px) 18px;
  font-size: 20px;
  font-weight: bold;
  line-height: 2.3em;
  color: #fff;
  background: #04092a;
}
.b-post-content h3 {
  padding: 14px 0;
  margin: 40px 0 14px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1.291em;
  border-bottom: 2px solid #eeeeef;
}
.b-post-content p {
  font-size: 16px;
  line-height: 2.0625;
  letter-spacing: 0.05em;
}
.b-post-content p img {
  max-width: 100%;
  height: auto;
  margin: 30px 0;
}
.b-post-content a {
  display: inline;
  text-decoration: underline;
}
.b-post-content a:hover {
  text-decoration: none;
}
.b-post-content ul {
  margin: 0 0 30px 1.3em;
  list-style: disc;
}
.b-post-content ol {
  margin: 0 0 30px 1.5em;
  list-style: decimal;
}
.b-post-content .aligncenter {
  margin: 0 auto;
}
.b-post-content .alignleft {
  margin-right: auto;
}
.b-post-content .alignright {
  margin-left: auto;
}

.b-post-breadcrumbs__list {
  display: flex;
  gap: 2px;
  align-items: center;
}
.b-post-breadcrumbs__item {
  display: flex;
  gap: 6px;
  align-items: center;
  line-height: 1;
}
.b-post-breadcrumbs__item::after {
  display: block;
  content: "＞";
}
.b-post-breadcrumbs__item:last-child::after {
  display: none;
}
.b-post-breadcrumbs__link {
  padding: 4px;
}

.b-mv {
  max-width: 1920px;
  height: 536px;
  padding-top: 234px;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center;
}
.b-mv__inner {
  max-width: 1690px;
  padding: 0 40px;
  margin: 0 auto;
}
.b-mv__title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.b-mv__title img {
  position: relative;
  left: -4px;
}
.b-mv__title span {
  margin-top: 26px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
}
.b-mv__title::after {
  display: block;
  width: 80px;
  height: 2px;
  margin-top: 26px;
  content: "";
  background: #fff;
}

.b-history-block__list {
  display: flex;
  flex-direction: column;
  gap: 19px;
  max-width: 1200px;
  margin: 0 auto;
}
.b-history-block__list dl {
  display: grid;
  grid-template-columns: 220px 1fr;
}
.b-history-block__list dt {
  position: relative;
  display: flex;
  align-items: center;
  min-height: 60px;
  padding: 10px 20px 10px 60px;
  font-size: 18px;
  font-weight: bold;
  line-height: 28px;
  color: #fff;
  text-align: center;
  background-color: #04092a;
}
.b-history-block__list dd {
  display: flex;
  align-items: center;
  min-height: 60px;
  padding: 10px 20px 10px 66px;
  background-color: #f5f5f5;
}

.b-header-content__container {
  display: flex;
  justify-content: space-between;
  max-width: 1886px;
  padding: 0 40px;
  margin: 0 auto;
  container-type: inline-size;
}
.b-header-content__logo {
  width: var(--b-header-content-logo-width, 0);
  height: var(--b-header-content-logo-height, 0);
  margin: var(--b-header-content-logo-margin, 0);
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.5));
}
.b-header-content__nav {
  display: flex;
  align-items: center;
}
.b-header-content__menu {
  display: flex;
  align-items: center;
  height: 44px;
  margin: 0 20px 0 0;
}
@container (width < 1320px) {
  .b-header-content__menu {
    display: none;
  }
}
.b-header-content__menu li {
  padding: 0 28px;
}
.b-header-content__menu li a {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.b-header-content__menu li a span {
  font-size: 15px;
  font-weight: bold;
  line-height: 1;
  color: var(--b-header-content-color-text, #fff);
  text-shadow: var(--b-header-content-nav-text-shadow, unset);
}
.b-header-content__menu li a img {
  margin-top: 16px;
}
.b-header-content__menu li + li {
  position: relative;
}
.b-header-content__menu li + li::before {
  position: absolute;
  top: calc(50% - 20px);
  left: 0;
  display: block;
  width: 1px;
  height: 40px;
  content: "";
  background: var(--b-header-content-color-menu-border, rgba(255, 255, 255, 0.3));
}
.b-header-content__button-area {
  display: flex;
  gap: 14px;
  align-items: center;
}
.b-header-content__recruit {
  width: 168px;
}
.b-header-content__recruit a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  border: 1px solid #fff;
  border-radius: 3px;
}
.b-header-content__recruit a::before {
  display: block;
  width: 18px;
  height: 25px;
  margin-right: 12px;
  content: "";
  background: url("../img/pc/icon_recruit_white.svg") no-repeat;
}
.b-header-content__contact {
  width: 176px;
}
.b-header-content__contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  border: 1px solid #fff;
  border-radius: 3px;
}
.b-header-content__contact a::before {
  display: block;
  width: 28px;
  height: 18px;
  margin-right: 12px;
  content: "";
  background: url("../img/pc/icon_mail_white.svg") no-repeat;
}

.b-header-blank {
  height: 134px;
  background: url("../img/pc/b_header_blank_bg.jpg") center no-repeat;
}

.b-header {
  position: relative;
  z-index: 7000;
  max-width: 1920px;
  margin: 0 auto;
}
.b-header__content {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 104px;
  padding-top: 36px;
}
.b-header__content--main {
  --b-header-content-logo-width: 251px;
  --b-header-content-logo-height: 66px;
  --b-header-content-logo-margin: 0 0 0 10px;
}

.b-footer {
  position: relative;
  max-width: 1920px;
  padding-bottom: 30px;
  margin: 0 auto 0;
  overflow: hidden;
  background: url("../img/pc/b_footer_bg.jpg") center/cover no-repeat;
}
.b-footer__container {
  position: relative;
  z-index: 10;
  display: flex;
  max-width: 1242px;
  padding-left: 24px;
  margin: 0 auto;
}
.b-footer__block-1 {
  flex: 0 0 auto;
  width: 30%;
  max-width: 430px;
  padding-top: 82px;
}
.b-footer__block-2 {
  position: relative;
  width: 70%;
  max-width: 860px;
  padding: 68px 0 0 40px;
}
.b-footer__block-3 {
  position: relative;
  width: 10%;
  max-width: 212px;
  padding: 128px 0 0 0;
}
.b-footer__logo {
  width: 104px;
  height: 104px;
  margin-left: 126px;
  filter: drop-shadow(0 0 14px rgba(0, 0, 0, 0.5));
}
.b-footer .address-block {
  max-width: 354px;
  margin-top: 36px;
}
.b-footer .address-block__title {
  font-size: 16px;
  line-height: 1;
  color: #fff;
  text-align: center;
}
.b-footer .address-block__title span {
  display: block;
  margin-top: 18px;
  font-size: 20px;
  font-weight: bold;
}
.b-footer .address-block__address {
  margin: 30px 0 0;
  font-size: 16px;
  line-height: 33px;
  color: #fff;
  text-align: center;
}
.b-footer .address-block__button {
  width: 240px;
  height: 58px;
  margin: 36px 0 0 56px;
}
.b-footer .address-block__button a {
  position: relative;
  display: flex;
  align-items: center;
  height: 100%;
  padding: 0 26px 0 36px;
  color: #fff;
  border: 1px solid #fff;
  border-radius: 29px;
}
.b-footer .address-block__button a::after {
  display: block;
  width: 9px;
  height: 16px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/b_footer_button_chevron.svg") no-repeat;
}
.b-footer__nav {
  position: relative;
  display: grid;
  grid-template-rows: repeat(3, 80px);
  grid-template-columns: repeat(3, 184px);
  grid-auto-flow: column;
  gap: 28px 54px;
}
.b-footer__nav .item {
  height: 100%;
  border-bottom: 1px solid rgba(198, 199, 200, 0.5);
}
.b-footer__nav .item a {
  height: 100%;
  padding: 12px 0 0;
}
.b-footer__nav .item span {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.b-footer__nav .item img {
  max-height: 14px;
  margin-top: 8px;
}
.b-footer__banner-list {
  display: flex;
  flex-wrap: wrap;
  gap: 24px;
  margin-top: 44px;
}
.b-footer__copyright {
  max-width: 1120px;
  padding: 0 20px;
  margin: 60px auto 0;
  color: #fff;
}
.b-footer__copyright::before {
  display: block;
  width: 108px;
  height: 1px;
  margin-bottom: 20px;
  content: "";
  background: #fff;
}

.b-contact {
  padding: 124px 0 108px;
}
.b-contact__container {
  display: flex;
  max-width: 1696px;
  padding: 0 40px;
  margin: 0 auto;
}
.b-contact__left {
  flex: 1;
  padding-top: 18px;
}
.b-contact__right {
  flex: 2;
  padding-top: 16px;
}
.b-contact__right .contact-area {
  display: flex;
  justify-content: space-between;
  max-width: 676px;
}
.b-contact__right .contact-area__fax {
  margin-top: 2px;
}
.b-contact__right .contact-area__right {
  margin-left: 20px;
}
.b-contact__right .contact-area__button {
  width: 318px;
}
.b-contact__right .contact-area__button a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 58px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background: #000;
}
.b-contact__right .contact-area__button a::before {
  display: block;
  width: 23px;
  height: 14px;
  margin-right: 20px;
  content: "";
  background: url("../img/pc/icon_mail_white.svg") no-repeat;
}
.b-contact__text {
  margin-top: 44px;
}

.b-company dl {
  display: grid;
  grid-template-columns: 158px 1fr;
  grid-gap: 0 50px;
  max-width: 936px;
  padding: 0 40px;
  margin: 0 auto;
}
.b-company dt {
  display: flex;
  min-height: 55px;
  font-weight: normal;
  color: #04092a;
  text-align: justify;
  text-align-last: justify;
  word-break: break-all;
  border-bottom: 1px dashed rgba(113, 112, 113, 0.25);
}
.b-company dt span {
  width: 100%;
  padding: 10px 0;
}
.b-company dd {
  display: flex;
  align-items: center;
  min-height: 55px;
  padding: 10px 0;
  border-bottom: 1px dashed rgba(113, 112, 113, 0.25);
}

.p-workflow .b-mv {
  background-image: url("../img/pc/workflow_mv_bg.jpg");
}
.p-workflow .top-section {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 66px 40px 0;
}
.p-workflow .top-section__headline {
  font-size: 35px;
  font-weight: bold;
  line-height: 62px;
  letter-spacing: 0.1em;
  text-align: center;
}
.p-workflow .top-section__english {
  margin-top: 26px;
}
.p-workflow .top-section__text {
  margin-top: 28px;
  text-align: center;
}
.p-workflow .flow {
  position: relative;
  padding-bottom: 134px;
  background: linear-gradient(to top, #f5f5f5 400px, transparent 400px);
}
.p-workflow .flow__smooth {
  position: absolute;
  right: 0;
  bottom: -62px;
  left: 0;
  height: 183px;
}
.p-workflow .flow__list {
  margin-top: 28px;
}
.p-workflow .flow__list .section {
  position: relative;
  padding: 1px 0;
}
.p-workflow .flow__list .section__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
  overflow: hidden;
}
.p-workflow .flow__list .section__bg img {
  position: absolute;
}
.p-workflow .flow__list .section__fg {
  position: relative;
  z-index: 20;
}
.p-workflow .flow__list .section__container {
  position: relative;
}
.p-workflow .flow__list .section__block {
  max-width: 420px;
}
.p-workflow .flow__list .section__counter {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 140px;
  height: 42px;
  clip-path: polygon(6px 0, calc(100% - 6px) 0, 100% 6px, 100% calc(100% - 6px), calc(100% - 6px) 100%, 6px 100%, 0 calc(100% - 6px), 0 6px);
  background: #e6e6e9;
}
.p-workflow .flow__list .section__title {
  margin-top: 30px;
  font-size: 38px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-workflow .flow__list .section__english {
  position: relative;
  left: 4px;
  margin-top: 24px;
}
.p-workflow .flow__list .section__text {
  position: relative;
  left: 4px;
  margin-top: 22px;
}
.p-workflow .flow__list .section__other {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  max-width: 1200px;
  height: 84px;
  margin: 2px auto 50px;
  font-size: 23px;
  font-weight: bold;
  line-height: 1;
  color: #04092a;
  letter-spacing: 0.1em;
  background: #fff;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.1);
}
.p-workflow .flow__list .section__other::before {
  position: absolute;
  bottom: -22px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 32px;
  content: "";
  background: #5d3260;
}
.p-workflow .flow__list .section__other::after {
  position: absolute;
  bottom: -22px;
  left: calc(50% - 4px);
  display: block;
  width: 8px;
  height: 8px;
  content: "";
  background: #5d3260;
  border-radius: 50%;
}
.p-workflow .flow__list .section__other--2 {
  margin-top: 182px;
}
.p-workflow .flow__list .section__other--2::before, .p-workflow .flow__list .section__other--2::after {
  display: none;
}
.p-workflow .flow__list .section__pin {
  position: absolute;
  left: calc(50% - 4px);
  z-index: 200;
  width: 8px;
  height: 34px;
}
.p-workflow .flow__list .section__pin::before {
  position: absolute;
  bottom: 0;
  left: 3px;
  display: block;
  width: 2px;
  height: 100%;
  content: "";
  background: #5d3260;
}
.p-workflow .flow__list .section__pin::after {
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  display: block;
  height: 8px;
  content: "";
  background: #5d3260;
  border-radius: 50%;
}
.p-workflow .flow__list .section:nth-child(1) {
  z-index: 100;
  margin-top: 24px;
}
.p-workflow .flow__list .section:nth-child(1) .section__bg img {
  top: 0;
  right: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(1) .section__fg {
  padding-top: 90px;
}
.p-workflow .flow__list .section:nth-child(1) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(1) .section__block {
  min-height: 534px;
}
.p-workflow .flow__list .section:nth-child(1) .section__pin {
  top: 498px;
}
.p-workflow .flow__list .section:nth-child(2) {
  margin-top: -158px;
  background: #f5f5f5;
}
.p-workflow .flow__list .section:nth-child(2) .section__bg img {
  top: 66px;
  left: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(2) .section__fg {
  padding-top: 174px;
}
.p-workflow .flow__list .section:nth-child(2) .section__container {
  display: flex;
  justify-content: flex-start;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(2) .section__block {
  min-height: 448px;
}
.p-workflow .flow__list .section:nth-child(2) .section__pin {
  top: 560px;
}
.p-workflow .flow__list .section:nth-child(3) {
  min-height: 508px;
}
.p-workflow .flow__list .section:nth-child(3) .section__bg img {
  top: 0;
  right: -124px;
  width: 1939px;
  max-width: unset;
  height: 508px;
}
.p-workflow .flow__list .section:nth-child(3) .section__fg {
  min-height: 506px;
  padding-top: 104px;
}
.p-workflow .flow__list .section:nth-child(3) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1688px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(3) .section__title {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(3) .section__text {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(3) .section__pin {
  top: 494px;
}
.p-workflow .flow__list .section:nth-child(4) {
  z-index: 100;
  margin-top: 24px;
}
.p-workflow .flow__list .section:nth-child(4) .section__bg img {
  top: 0;
  right: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(4) .section__fg {
  padding-top: 90px;
}
.p-workflow .flow__list .section:nth-child(4) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(4) .section__block {
  min-height: 534px;
}
.p-workflow .flow__list .section:nth-child(4) .section__pin {
  top: 498px;
}
.p-workflow .flow__list .section:nth-child(5) {
  margin-top: -158px;
  background: #f5f5f5;
}
.p-workflow .flow__list .section:nth-child(5) .section__bg img {
  top: 66px;
  left: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(5) .section__fg {
  padding-top: 174px;
}
.p-workflow .flow__list .section:nth-child(5) .section__container {
  display: flex;
  justify-content: flex-start;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(5) .section__block {
  min-height: 448px;
}
.p-workflow .flow__list .section:nth-child(5) .section__pin {
  top: 560px;
}
.p-workflow .flow__list .section:nth-child(6) {
  min-height: 508px;
}
.p-workflow .flow__list .section:nth-child(6) .section__bg img {
  top: 0;
  right: -124px;
  width: 1939px;
  max-width: unset;
  height: 508px;
}
.p-workflow .flow__list .section:nth-child(6) .section__fg {
  min-height: 506px;
  padding-top: 104px;
}
.p-workflow .flow__list .section:nth-child(6) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1688px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(6) .section__title {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(6) .section__text {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(6) .section__pin {
  top: 494px;
}
.p-workflow .flow__list .section:nth-child(7) {
  z-index: 100;
  margin-top: 24px;
}
.p-workflow .flow__list .section:nth-child(7) .section__bg img {
  top: 0;
  right: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(7) .section__fg {
  padding-top: 90px;
}
.p-workflow .flow__list .section:nth-child(7) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(7) .section__block {
  min-height: 534px;
}
.p-workflow .flow__list .section:nth-child(7) .section__pin {
  top: 498px;
}
.p-workflow .flow__list .section:nth-child(8) {
  margin-top: -158px;
  background: #f5f5f5;
}
.p-workflow .flow__list .section:nth-child(8) .section__bg img {
  top: 66px;
  left: 514px;
  width: 1105px;
  max-width: unset;
  height: 534px;
}
.p-workflow .flow__list .section:nth-child(8) .section__fg {
  padding-top: 174px;
}
.p-workflow .flow__list .section:nth-child(8) .section__container {
  display: flex;
  justify-content: flex-start;
  max-width: 1250px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(8) .section__block {
  min-height: 448px;
}
.p-workflow .flow__list .section:nth-child(8) .section__pin {
  top: 560px;
}
.p-workflow .flow__list .section:nth-child(9) {
  min-height: 508px;
}
.p-workflow .flow__list .section:nth-child(9) .section__bg img {
  top: 0;
  right: -124px;
  width: 1939px;
  max-width: unset;
  height: 508px;
}
.p-workflow .flow__list .section:nth-child(9) .section__fg {
  min-height: 506px;
  padding-top: 104px;
}
.p-workflow .flow__list .section:nth-child(9) .section__container {
  display: flex;
  justify-content: flex-end;
  max-width: 1688px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-workflow .flow__list .section:nth-child(9) .section__title {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(9) .section__text {
  color: #fff;
}
.p-workflow .flow__list .section:nth-child(9) .section__pin {
  top: 494px;
}

.p-single .post {
  padding-bottom: 96px;
  background: #f5f3f3;
}
.p-single .post__breadcrumbs {
  max-width: 1300px;
  padding: 18px 40px;
  margin: 0 auto;
}
.p-single .post__title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  max-width: 1200px;
  padding: 26px 54px;
  margin: 18px auto 0;
  font-size: 26px;
  font-weight: bold;
  line-height: 34px;
  letter-spacing: 0.1em;
  background: #fff;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.1);
}
.p-single .post__title span {
  font-size: 17px;
  line-height: 24px;
  color: #5d3260;
}
.p-single .post__slider {
  padding: 44px 0 40px;
  background: linear-gradient(to top, #fff 222px, transparent 222px);
}
.p-single .post__slider .c-work-slider__sub-slider {
  max-width: 1202px;
  margin-inline: auto;
}
.p-single .post__container {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(508px, 1fr));
  gap: 24px;
  justify-content: center;
  max-width: 1280px;
  padding: 0 40px;
  margin: 46px auto 0;
}
.p-single .post__container .information {
  padding: 40px 46px 40px;
  background: #fff;
}
.p-single .post__container .information__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-single .post__container .information__title::after {
  display: block;
  width: 144px;
  height: 1px;
  margin-top: 20px;
  content: "";
  background: #5d3260;
}
.p-single .post__container .information__list {
  margin-top: 12px;
}
.p-single .post__container .information__list dl {
  display: grid;
  grid-template-columns: 118px 1fr;
  gap: 16px;
  font-size: 16px;
  line-height: 28px;
}
.p-single .post__container .information__list dl dt {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  margin: 14px 0;
  font-weight: normal;
  background: #f5f6f6;
}
.p-single .post__container .information__list dl dd {
  display: flex;
  align-items: center;
  padding: 14px 0;
  border-bottom: 1px solid rgba(198, 199, 200, 0.5);
}
.p-single .post__container .description {
  padding: 40px 58px 40px;
  background: #fff;
}
.p-single .post__container .description__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-single .post__container .description__title::after {
  display: block;
  width: 144px;
  height: 1px;
  margin-top: 20px;
  content: "";
  background: #5d3260;
}
.p-single .post__container .description__detail {
  margin-top: 30px;
}
.p-single .post .catalog {
  max-width: 1280px;
  padding: 0 40px;
  margin: 48px auto 0;
}
.p-single .post .catalog__link {
  background: #fff;
}
.p-single .post .catalog__inner {
  display: grid;
  grid-template-columns: 202px 1fr;
  padding: 18px 0;
}
.p-single .post .catalog__title {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 58px;
  border-right: 1px solid #f5f5f5;
}
.p-single .post .catalog__text {
  display: flex;
  align-items: center;
  padding: 0 42px 0 50px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
}
.p-single .post .catalog__text::after {
  display: block;
  width: 40px;
  height: 40px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/icon_download_black_white.svg") no-repeat;
}
.p-single .post .pickup {
  padding: 0 40px;
}
.p-single .post .pickup__inner {
  max-width: 1200px;
  padding: 56px 0 0;
  margin: 46px auto 0;
  background: #fff;
}
.p-single .post .pickup__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-single .post .pickup__title::after {
  display: block;
  width: 66px;
  height: 1px;
  margin-top: 20px;
  content: "";
  background: #5d3260;
}
.p-single .post .pickup__content {
  padding: 46px 46px 58px;
}
.p-single .post .pickup__content h2 {
  width: 100%;
  padding-right: 0;
  padding-left: 0;
  margin-right: 0;
  margin-left: 0;
  font-size: 24px;
  font-weight: bold;
  line-height: 36px;
  color: #04092a;
  background: unset;
}
.p-single .post .pickup__content h2::after {
  display: block;
  width: 60px;
  height: 1px;
  margin-top: 12px;
  content: "";
  background: #9d9e9e;
}
.p-single .post .pickup__content h3 {
  font-size: 20px;
  font-weight: bold;
  line-height: 28px;
  color: #04092a;
  border-bottom: unset;
}
.p-single .post .post-navi {
  position: relative;
  margin-top: 60px;
}
.p-single .post .post-navi__fg {
  position: relative;
  z-index: 20;
  max-width: 1200px;
  height: 60px;
  margin-inline: auto;
  line-height: 1;
}
.p-single .post .post-navi .prev-btn {
  position: absolute;
  left: 0;
  width: 197px;
  height: 100%;
  font-weight: bold;
  color: #fff;
  background-color: #04092a;
}
.p-single .post .post-navi .prev-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.p-single .post .post-navi .prev-btn::before {
  position: absolute;
  top: 22px;
  left: 14px;
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background: url("../img/pc/single_chevron_left.svg") no-repeat;
}
.p-single .post .post-navi .return-list-btn {
  position: absolute;
  left: 50%;
  width: 346px;
  height: 100%;
  font-weight: bold;
  color: #fff;
  text-align: center;
  background-color: #04092a;
  transform: translateX(-50%);
}
.p-single .post .post-navi .return-list-btn a {
  width: 100%;
  height: 100%;
  padding: 23px 0 0 0;
}
.p-single .post .post-navi .next-btn {
  position: absolute;
  right: 0;
  width: 197px;
  height: 100%;
  font-weight: bold;
  color: #fff;
  background-color: #04092a;
}
.p-single .post .post-navi .next-btn a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 100%;
}
.p-single .post .post-navi .next-btn::before {
  position: absolute;
  top: 22px;
  right: 14px;
  display: block;
  width: 18px;
  height: 18px;
  content: "";
  background: url("../img/pc/single_chevron_right.svg") no-repeat;
}

.p-part .main {
  max-width: 1920px;
  padding: 88px 0 0;
  margin: 0 auto;
}
.p-part .main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-part .main__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 24px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-part .main__title span::before {
  display: block;
  width: 62px;
  height: 2px;
  margin-bottom: 18px;
  content: "";
  background: #5d3260;
}
.p-part .main__nav {
  display: grid;
  grid-template-columns: repeat(auto-fit, 386px);
  gap: 20px;
  max-width: 1280px;
  padding: 0 40px;
  margin: 38px auto 0;
}
.p-part .main__nav li a {
  display: flex;
  align-items: center;
  height: 96px;
  padding: 0 32px;
  background: #04092a;
}
.p-part .main__nav li a span {
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
}
.p-part .main__nav li a::after {
  display: block;
  width: 29px;
  height: 29px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/b_post_nav_chevron.svg") no-repeat;
}
.p-part .main__list {
  display: flex;
  flex-direction: column;
  gap: 94px;
  align-items: center;
  padding: 62px 40px 110px;
  margin-top: 58px;
  background: #f5f5f5;
}
.p-part .main__list .category-section {
  width: 100%;
  max-width: 1200px;
}
.p-part .main__list .category-section__title {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 74px;
  padding: 4px 20px;
  font-size: 22px;
  font-weight: bold;
  line-height: 30px;
  color: #fff;
  letter-spacing: 0.1em;
  background: #04092a;
}
.p-part .main__list .category-section__list {
  display: flex;
  flex-direction: column;
  gap: 34px;
  margin-top: 38px;
}
.p-part .main__list .category-section__list .part {
  padding: 14px;
  background: #fff;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.1);
}
.p-part .main__list .category-section__list .part__inner {
  display: flex;
  gap: 66px;
}
.p-part .main__list .category-section__list .part__image {
  position: relative;
  flex: 0 0 auto;
  width: 466px;
  height: 356px;
  background: #9e9e9f;
}
.p-part .main__list .category-section__list .part__main {
  flex: 1 1 auto;
  padding: 22px 12px 8px 0;
}
.p-part .main__list .category-section__list .part__title {
  font-size: 31px;
  font-weight: bold;
  line-height: 48px;
  letter-spacing: 0.1em;
}
.p-part .main__list .category-section__list .part__sub-title {
  margin-top: 12px;
  font-size: 17px;
  font-weight: bold;
  line-height: 24px;
  color: #5d3260;
}
.p-part .main__list .category-section__list .part__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.p-part .main__list .category-section__list .part__term {
  padding: 7px 15px;
  font-size: 14px;
  line-height: 20px;
  background: #f5f6f6;
}
.p-part .main__list .category-section__list .part__detail {
  margin-top: 24px;
}
.p-part .main__list .category-section__list .part__button {
  width: 212px;
  margin: 18px 0 0 auto;
}
.p-part .main__list .category-section__list .part__button a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 52px;
  background: #141414;
  border: 1px solid #474645;
  border-radius: 3px;
}
.p-part .main__list .category-section__list .part__button a::before {
  display: block;
  width: 28px;
  height: 18px;
  margin-right: 16px;
  content: "";
  background: url("../img/pc/icon_mail_white.svg") no-repeat;
}

.p-notfound .main {
  max-width: 1240px;
  padding: 250px 20px 200px;
  margin: 0 auto;
}
.p-notfound .main a {
  display: inline-block;
  margin-top: 60px;
  text-decoration: underline;
}

.p-front-page {
  max-width: 1920px;
  margin: 0 auto;
}
.p-front-page .mv {
  position: relative;
  height: clamp(800px, 100vh, 958px);
  overflow: hidden;
}
@keyframes front_mv_fadein {
  0% {
    opacity: 0;
    transform: translateY(-40px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.p-front-page .mv__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
  background: url("../img/pc/front_mv_bg_base.jpg") no-repeat center;
}
.p-front-page .mv__bg-2 {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 540px);
  z-index: 20;
  width: 1440px;
  background: linear-gradient(to right, transparent 30%, #000 904px, transparent 90%);
}
.p-front-page .mv__bg-3 {
  position: absolute;
  top: 0;
  bottom: 0;
  left: calc(50% - 540px);
  z-index: 30;
  width: 1440px;
}
.p-front-page .mv__bg-4 {
  position: absolute;
  inset: 0;
  z-index: 40;
  background: url("../img/pc/front_mv_filter.png") no-repeat center bottom;
  mix-blend-mode: lighten;
}
.p-front-page .mv__bg-5 {
  position: absolute;
  inset: 0;
  z-index: 50;
  background: rgba(0, 0, 0, 0.2);
  mix-blend-mode: multiply;
}
.p-front-page .mv__fg {
  position: absolute;
  inset: 0;
  z-index: 100;
  padding: 0 40px;
}
.p-front-page .mv__inner {
  position: relative;
  opacity: 0;
  animation: 0.6s front_mv_fadein 2s forwards;
  display: flex;
  flex-direction: column;
  max-width: 1646px;
  height: 100%;
  margin-inline: auto;
}
.p-front-page .mv div:nth-child(1 of .mv__spacer) {
  flex-grow: 296;
}
.p-front-page .mv div:nth-child(2 of .mv__spacer) {
  flex-grow: 10;
}
.p-front-page .mv div:nth-child(3 of .mv__spacer) {
  flex-grow: 0;
}
.p-front-page .mv div:nth-child(4 of .mv__spacer) {
  flex-grow: 108;
}
.p-front-page .mv div:nth-child(5 of .mv__spacer) {
  flex-grow: 58;
}
.p-front-page .mv__headline {
  font-size: 27px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  letter-spacing: 0.1em;
}
.p-front-page .mv__large {
  position: relative;
  left: -20px;
}
.p-front-page .mv__text {
  position: relative;
  left: -20px;
}
.p-front-page .mv__scroll {
  position: absolute;
  right: 8px;
  bottom: 58px;
  width: 12px;
  height: 118px;
}
.p-front-page .mv .vertical-slider {
  display: grid;
  grid-template-columns: 138px 1fr;
  width: 642px;
  padding: 10px 0;
  background: #000;
  border-radius: 0 3px 0 0;
}
.p-front-page .mv .vertical-slider__title {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 44px;
  border-right: 1px solid rgba(255, 255, 255, 0.3);
}
.p-front-page .mv .vertical-slider__slider {
  height: 44px;
}
.p-front-page .concept {
  padding: 108px 0 114px;
}
.p-front-page .concept__container {
  display: flex;
  max-width: 1696px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-front-page .concept__left {
  flex: 1;
  padding-top: 18px;
}
.p-front-page .concept__right {
  flex: 2;
}
.p-front-page .concept__button {
  margin-top: 96px;
}
.p-front-page .concept__headline {
  font-size: 35px;
  font-weight: bold;
  line-height: 62px;
  letter-spacing: 0.1em;
}
.p-front-page .concept__english {
  margin-top: 26px;
}
.p-front-page .concept__text {
  max-width: 760px;
  margin-top: 26px;
}
.p-front-page .feature {
  min-height: 1433px;
  padding: 656px 0 40px;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 706px 100%, 680px calc(100% - 36px), 0 calc(100% - 36px));
  background: url("../img/pc/front_feature_bg.jpg") no-repeat center top, linear-gradient(to bottom, transparent 200px, #070b24 200px);
}
.p-front-page .feature__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .feature__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 26px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  color: #9c9c9d;
}
.p-front-page .feature__title span::before {
  display: block;
  width: 62px;
  height: 2px;
  margin-bottom: 18px;
  content: "";
  background: #fff;
}
.p-front-page .feature__list {
  margin: 40px 0 0 9.6%;
}
.p-front-page .feature__list .c-slider {
  margin: -20px 0;
}
.p-front-page .feature__list .c-slider__track {
  padding: 20px 0;
  overflow: unset;
}
.p-front-page .feature__list .c-slider__item {
  width: 380px;
  height: 428px;
  margin-right: 34px;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.1);
}
.p-front-page .feature__list .c-slider__arrow-right {
  top: 212px;
  left: -30px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/front_feature_chevron_left.svg") center/9px 16px no-repeat;
  border-radius: 50%;
}
.p-front-page .feature__button {
  --c-button-arrow-bg-color: #fff;
  --c-button-arrow-arrow-url: url("../img/pc/c_button_arrow_black.svg");
  margin: 56px auto 0;
}
.p-front-page .product {
  padding: 66px 0 86px;
}
.p-front-page .product__container {
  display: flex;
  max-width: 1696px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-front-page .product__left {
  flex: 1;
}
.p-front-page .product__right {
  flex: 2;
}
.p-front-page .product__text {
  max-width: 750px;
  padding-top: 10px;
}
.p-front-page .product__slider {
  margin-top: 56px;
}
.p-front-page .product__slider .c-slider__track {
  overflow: unset;
}
.p-front-page .product__slider .c-slider__item {
  width: 412px;
}
.p-front-page .product__slider .c-slider__item > * {
  height: 100%;
}
.p-front-page .product__slider .c-slider__arrow-left {
  bottom: -29px;
  left: 150px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/front_product_chevron_left.svg") center/9px 16px no-repeat;
  border: 1px solid #141414;
  border-radius: 50%;
}
.p-front-page .product__slider .c-slider__arrow-right {
  bottom: -29px;
  left: 240px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/front_product_chevron_right.svg") center/9px 16px no-repeat;
  border: 1px solid #141414;
  border-radius: 50%;
}
.p-front-page .product__button {
  margin: 52px auto 0;
}
.p-front-page .workflow {
  position: relative;
  height: 632px;
  clip-path: polygon(0 36px, 680px 36px, 706px 0, 100% 0, 100% 100%, 0 100%);
}
.p-front-page .workflow__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
}
.p-front-page .workflow__bg-2 {
  position: absolute;
  inset: 0;
  z-index: 20;
  background: rgba(4, 9, 42, 0.7);
  mix-blend-mode: multiply;
}
.p-front-page .workflow__fg {
  position: absolute;
  inset: 0;
  z-index: 30;
  padding: 210px 0 0;
}
.p-front-page .workflow__container {
  display: flex;
  max-width: 1696px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-front-page .workflow__left {
  flex: 1;
  padding-top: 18px;
}
.p-front-page .workflow__right {
  flex: 2;
}
.p-front-page .workflow__title {
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.6));
}
.p-front-page .workflow__button {
  margin-top: 96px;
  --c-button-arrow-bg-color: #fff;
  --c-button-arrow-arrow-url: url("../img/pc/c_button_arrow_black.svg");
}
.p-front-page .workflow__headline {
  font-size: 35px;
  font-weight: bold;
  line-height: 62px;
  letter-spacing: 0.1em;
  color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.6));
}
.p-front-page .workflow__english {
  margin-top: 26px;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.6));
}
.p-front-page .workflow__text {
  max-width: 760px;
  margin-top: 26px;
  color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.6));
}
.p-front-page .parts {
  padding: 58px 40px 1px;
  background: #04092a;
  display: flex;
  justify-content: center;
}
.p-front-page .parts__banner {
  margin-bottom: -30px;
  background: #fff;
}
.p-front-page .topics {
  padding: 144px 40px 104px;
}
.p-front-page .topics__container {
  display: grid;
  grid-template-columns: 150px 1fr;
  max-width: 1200px;
  margin: 0 auto;
}
.p-front-page .topics__list {
  border-top: 1px solid rgba(20, 20, 20, 0.5);
}
.p-front-page .topics__list .item {
  background: #fff;
  border-bottom: 1px solid rgba(20, 20, 20, 0.5);
}
.p-front-page .topics__list .item__title-inner {
  display: flex;
  align-items: center;
  padding: 24px 36px;
}
.p-front-page .topics__list .item__title-inner::after {
  display: block;
  flex: 0 0 auto;
  width: 29px;
  height: 29px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/front_topics_chevron.svg") no-repeat;
}
.p-front-page .topics__list .item__date {
  margin-right: 20px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #b2b2b3;
}
.p-front-page .topics__list .item__title {
  padding: 0 20px;
  font-size: 18px;
  font-weight: bold;
  line-height: 28px;
  letter-spacing: 0.1em;
}
.p-front-page .topics__list .item__content-inner {
  padding: 16px 32px 30px;
  background: #f5f5f5;
}
.p-front-page .topics__list .item__content-close {
  display: flex;
  gap: 4px;
  align-items: center;
  justify-content: center;
  width: 114px;
  height: 36px;
  margin: 24px auto 0;
  color: #000;
  background-color: #ffffff;
}
.p-front-page .topics__list .item__content-close::before {
  position: relative;
  top: -1px;
  display: block;
  font-size: 20px;
  line-height: 1;
  content: "×";
}
.p-front-page .recruit {
  position: relative;
  height: 456px;
}
.p-front-page .recruit__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
  overflow: hidden;
}
.p-front-page .recruit__bg img {
  position: absolute;
  top: 0;
  left: -339px;
  width: 1920px;
  max-width: unset;
  height: 456px;
}
.p-front-page .recruit__fg {
  position: relative;
  z-index: 20;
  padding-top: 78px;
}
.p-front-page .recruit__inner {
  position: relative;
  max-width: 1242px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-front-page .recruit__title {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 176px;
  height: 54px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  background: #fff;
}
.p-front-page .recruit__container {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  margin-top: 194px;
}
.p-front-page .recruit__text {
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
}

.p-feature .b-mv {
  background-image: url("../img/pc/feature_mv_bg.jpg");
}
.p-feature .nav__container {
  display: grid;
  grid-template-columns: minmax(0, 1000px) minmax(720px, 1fr);
}
.p-feature .nav__image {
  height: 803px;
}
.p-feature .nav__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.p-feature .nav__block {
  padding: 106px 0 0;
}
.p-feature .nav__inner {
  width: 574px;
  margin: 0 auto;
}
.p-feature .nav__list {
  border-top: 1px solid rgba(156, 156, 157, 0.5);
}
.p-feature .nav__list .item {
  border-bottom: 1px solid rgba(156, 156, 157, 0.5);
}
.p-feature .nav__list .item a {
  position: relative;
  display: flex;
  padding: 32px 0 20px;
}
.p-feature .nav__list .item a::after {
  position: absolute;
  top: calc(50% - 15px);
  right: 0;
  display: block;
  width: 30px;
  height: 30px;
  content: "";
  background: url("../img/pc/feature_nav_chevron.svg") no-repeat;
}
.p-feature .nav__list .item__counter {
  flex: 0 0 auto;
  margin-right: 44px;
}
.p-feature .nav__list .item__title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.p-feature .nav__list .item__title span {
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
  color: #141414;
}
.p-feature .nav__list .item__title img {
  position: relative;
  left: 4px;
  margin-top: 20px;
}
.p-feature .nav__qa {
  width: 572px;
  margin-top: 40px;
}
.p-feature .nav__qa a {
  display: flex;
  align-items: center;
  height: 88px;
  padding: 0 36px 0 48px;
  background: #f5f5f5;
  border-radius: 6px;
}
.p-feature .nav__qa a span {
  margin-right: 20px;
  font-size: 22px;
  font-weight: bold;
  line-height: 1;
}
.p-feature .nav__qa a::after {
  display: block;
  width: 30px;
  height: 30px;
  margin-left: auto;
  content: "";
  background: url("../img/pc/feature_nav_chevron.svg") no-repeat;
}
.p-feature .main-section {
  padding: 158px 0 0;
}
.p-feature .main-section__list .section {
  padding: 1px 0 116px;
}
.p-feature .main-section__list .section__bg {
  position: relative;
  max-width: 1690px;
  height: 550px;
  margin-top: -48px;
  box-shadow: 0 0 9px rgba(0, 0, 0, 0.06);
}
.p-feature .main-section__list .section__bg > img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-feature .main-section__list .section__counter {
  position: absolute;
  bottom: 40px;
  width: 23px;
  height: 248px;
}
.p-feature .main-section__list .section__bottom {
  max-width: 1494px;
  padding: 0 40px;
  margin: 48px auto 0;
}
.p-feature .main-section__list .section__container {
  display: flex;
  gap: 80px;
  max-width: 1308px;
}
.p-feature .main-section__list .section__block {
  padding: 10px 0 0;
}
.p-feature .main-section__list .section__title {
  font-size: 35px;
  font-weight: bold;
  line-height: 62px;
  letter-spacing: 0.1em;
}
.p-feature .main-section__list .section__english {
  margin-top: 10px;
}
.p-feature .main-section__list .section__english::after {
  display: block;
  width: 144px;
  height: 1px;
  margin-top: 30px;
  content: "";
  background: #5d3260;
}
.p-feature .main-section__list .section__text {
  margin-top: 26px;
}
.p-feature .main-section__list .section__image {
  flex: 0 0 auto;
  width: 629px;
  height: 343px;
  clip-path: polygon(17px 0, calc(100% - 17px) 0, 100% 17px, 100% calc(100% - 17px), calc(100% - 17px) 100%, 17px 100%, 0 calc(100% - 17px), 0 17px);
}
.p-feature .main-section__list .section:nth-of-type(1) {
  background: #f5f5f5;
}
.p-feature .main-section__list .section:nth-of-type(1) .section__bg {
  margin-left: auto;
}
.p-feature .main-section__list .section:nth-of-type(1) .section__counter {
  left: 44px;
}
.p-feature .main-section__list .section:nth-of-type(2) .section__counter {
  right: 44px;
}
.p-feature .main-section__list .section:nth-of-type(3) {
  background: #f5f5f5;
}
.p-feature .main-section__list .section:nth-of-type(3) .section__bg {
  margin-left: auto;
}
.p-feature .main-section__list .section:nth-of-type(3) .section__counter {
  left: 44px;
}
.p-feature .main-section__list .section:nth-of-type(4) .section__counter {
  right: 44px;
}
.p-feature .main-section__list .section:nth-of-type(5) {
  background: #f5f5f5;
}
.p-feature .main-section__list .section:nth-of-type(5) .section__bg {
  margin-left: auto;
}
.p-feature .main-section__list .section:nth-of-type(5) .section__counter {
  left: 44px;
}
.p-feature .qa {
  position: relative;
  padding: 98px 40px 200px;
  background: #04092a;
}
.p-feature .qa__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-feature .qa__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 16px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  color: #9c9c9d;
  letter-spacing: 0.1em;
}
.p-feature .qa__title span::before {
  display: block;
  width: 62px;
  height: 1px;
  margin-bottom: 16px;
  content: "";
  background: #9c9c9d;
}
.p-feature .qa__list {
  display: grid;
  flex-direction: column;
  gap: 24px;
  max-width: 1200px;
  margin: 42px auto 0;
}
.p-feature .qa__smooth {
  position: absolute;
  right: 0;
  bottom: -62px;
  left: 0;
  height: 183px;
}

.p-contact .main {
  position: relative;
  padding: 88px 0 122px;
  background: #f5f6f6;
}
.p-contact .main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-contact .main__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 24px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
}
.p-contact .main__title span::before {
  display: block;
  width: 62px;
  height: 2px;
  margin-bottom: 18px;
  content: "";
  background: #04092a;
}
.p-contact .main__info {
  margin-top: 40px;
  line-height: 33px;
  text-align: center;
}
.p-contact .main .tel-area {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 22px;
}
.p-contact .main .tel-area__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 20px;
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
}
.p-contact .main .tel-area__title::after {
  display: block;
  width: 42px;
  height: 1px;
  margin-top: 14px;
  content: "";
  background: #04092a;
}
.p-contact .main .tel-area__tel {
  margin-top: 24px;
}
.p-contact .main .tel-area__fax {
  margin-top: 12px;
  line-height: 1;
  text-align: center;
}
.p-contact .main__smooth-slider {
  margin: 110px 0 -46px;
}
.p-contact .main__smooth-slider .c-slider-smooth__group {
  padding-right: 80px;
}
.p-contact .form {
  max-width: 820px;
  margin: 58px auto 0;
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
}
.p-contact .form .wpcf7 .wpcf7-submit {
  width: 324px;
  height: 70px;
  font-size: 18px;
  line-height: 1;
  color: #fff;
  background: #04092a;
}
.p-contact .privacy-policy {
  margin-top: 108px;
}
.p-contact .privacy-policy__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
}
.p-contact .privacy-policy__title::after {
  display: block;
  width: 42px;
  height: 2px;
  margin-top: 16px;
  content: "";
  background: #04092a;
}
.p-contact .privacy-policy__scroll {
  max-width: 1200px;
  max-height: 548px;
  padding: 54px 84px;
  margin: 28px auto 0;
  overflow: scroll;
  background: #fff;
}

.p-archive .main {
  max-width: 1920px;
  padding: 88px 0 0;
  margin: 0 auto;
}
.p-archive .main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-archive .main__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 24px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-archive .main__title span::before {
  display: block;
  width: 62px;
  height: 2px;
  margin-bottom: 18px;
  content: "";
  background: #5d3260;
}
.p-archive .main__nav {
  margin-top: 36px;
}
.p-archive .main__bg {
  padding: 62px 40px 56px;
  margin-top: 58px;
  background-color: #f5f5f5;
}
.p-archive .main__list {
  display: flex;
  flex-direction: column;
  gap: 38px;
  max-width: 1200px;
  margin: 0 auto;
}
.p-archive .main__item > * {
  height: 100%;
}
.p-archive .wp-pagenavi {
  padding: 86px 0 0;
}
.p-archive .b-contact {
  margin-top: 32px;
}

.p-about .b-mv {
  background-image: url("../img/pc/about_mv_bg.jpg");
}
.p-about .philosophy {
  padding: 80px 40px 1px;
  background: #f5f5f5;
}
.p-about .philosophy__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about .philosophy__title span {
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-about .philosophy__title img {
  margin-top: 20px;
}
.p-about .philosophy__title::after {
  display: block;
  width: 60px;
  height: 2px;
  margin-top: 22px;
  content: "";
  background: #5d3260;
}
.p-about .philosophy__block {
  position: relative;
  max-width: 1200px;
  margin: 40px auto -56px;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.06));
}
.p-about .philosophy__inner {
  padding: 50px 78px;
  clip-path: polygon(8px 0, calc(100% - 8px) 0, 100% 8px, 100% calc(100% - 8px), calc(100% - 8px) 100%, 8px 100%, 0 calc(100% - 8px), 0 8px);
  background: #fff;
}
.p-about .philosophy__headline {
  font-size: 35px;
  font-weight: bold;
  line-height: 62px;
  text-align: center;
  letter-spacing: 0.1em;
}
.p-about .philosophy__english {
  display: flex;
  justify-content: center;
  margin-top: 10px;
}
.p-about .philosophy__text {
  padding-top: 38px;
  margin-top: 40px;
  text-align: center;
  border-top: 1px solid #d9dada;
}
.p-about .company {
  padding: 146px 0 0;
}
.p-about .company__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about .company__title span {
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-about .company__title img {
  margin-top: 20px;
}
.p-about .company__title::after {
  display: block;
  width: 60px;
  height: 2px;
  margin-top: 22px;
  content: "";
  background: #5d3260;
}
.p-about .company__list {
  margin-top: 18px;
}
.p-about .company__slider {
  margin-top: 46px;
}
.p-about .company__slider .c-slider__track {
  overflow: unset;
}
.p-about .company__slider .c-slider__item {
  width: 583px;
  height: 338px;
  margin-right: 38px;
}
.p-about .company__slider .c-slider__arrow-left {
  top: 140px;
  left: 31.5%;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/about_company_chevron_left.svg") center/9px 16px no-repeat;
  border-radius: 50%;
}
.p-about .company__slider .c-slider__arrow-right {
  top: 140px;
  right: 31.5%;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/about_company_chevron_right.svg") center/9px 16px no-repeat;
  border-radius: 50%;
}
.p-about .company__google-map {
  height: 436px;
  margin-top: 44px;
}
.p-about .greeting {
  padding: 104px 40px 84px;
}
.p-about .greeting__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about .greeting__title span {
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-about .greeting__title img {
  margin-top: 20px;
}
.p-about .greeting__title::after {
  display: block;
  width: 60px;
  height: 2px;
  margin-top: 22px;
  content: "";
  background: #5d3260;
}
.p-about .greeting__headline {
  font-size: 35px;
  font-weight: bold;
  line-height: 56px;
  letter-spacing: 0.1em;
  margin-top: 32px;
  text-align: center;
}
.p-about .greeting__text {
  margin-top: 18px;
  text-align: center;
}
.p-about .greeting__signature {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-top: 36px;
  font-size: 16px;
}
.p-about .greeting__signature span {
  margin-left: 16px;
  font-size: 23px;
  font-weight: bold;
}
.p-about .equipment {
  padding: 80px 40px 76px;
  background: #f5f5f5;
}
.p-about .equipment__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about .equipment__title span {
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-about .equipment__title img {
  margin-top: 20px;
}
.p-about .equipment__title::after {
  display: block;
  width: 60px;
  height: 2px;
  margin-top: 22px;
  content: "";
  background: #5d3260;
}
.p-about .equipment__title::after {
  margin-top: 16px;
}
.p-about .equipment__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
  max-width: 1200px;
  margin: 30px auto 0;
}
.p-about .history {
  padding: 76px 40px 88px;
}
.p-about .history__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about .history__title span {
  font-size: 35px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
}
.p-about .history__title img {
  margin-top: 20px;
}
.p-about .history__title::after {
  display: block;
  width: 60px;
  height: 2px;
  margin-top: 22px;
  content: "";
  background: #5d3260;
}
.p-about .history__list {
  margin-top: 34px;
}
.p-about .recruit {
  position: relative;
  padding-bottom: 180px;
  background: #f5f5f5;
}
.p-about .recruit .title-block {
  position: relative;
  height: 404px;
}
.p-about .recruit .title-block__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
}
.p-about .recruit .title-block__filter {
  position: absolute;
  inset: 0;
  z-index: 20;
  background: rgba(4, 9, 42, 0.7);
  mix-blend-mode: multiply;
}
.p-about .recruit .title-block__fg {
  position: absolute;
  inset: 0;
  z-index: 30;
  padding: 180px 40px 0;
}
.p-about .recruit .title-block__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.6));
}
.p-about .recruit .title-block__title span {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 24px;
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  color: #b2b2b3;
  letter-spacing: 0.1em;
}
.p-about .recruit .title-block__title span::before {
  display: block;
  width: 62px;
  height: 2px;
  margin-bottom: 16px;
  content: "";
  background: #fff;
}
.p-about .recruit__list {
  position: relative;
  z-index: 100;
  display: flex;
  flex-direction: column;
  gap: 38px;
  max-width: 1200px;
  margin: -34px auto 0;
}
.p-about .recruit__smooth {
  position: absolute;
  right: 0;
  bottom: -62px;
  left: 0;
  height: 183px;
}
