/*!*************************************************************************************************************************************************************************************************************************!*\
  !*** 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);
  -webkit-text-size-adjust: 100%;
  text-size-adjust: 100%;
}

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;
}

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: #145072;
}
.wp-pagenavi span.current {
  display: inline-block;
  padding: 7px 9px 7px 10px;
  margin: 0 2px;
  font-size: 14px;
  line-height: 1;
  color: #fff;
  background: #145072;
  border: 1px solid #000;
  border-radius: 3px;
  box-shadow: 0px 0px 3px rgba(35, 24, 21, 0.2);
}

.c-tel {
  display: inline-block;
}
.c-tel__inner {
  display: flex;
  align-items: center;
  font-size: var(--c-tel-font-size, 21px);
  font-weight: bold;
  line-height: 1;
  color: var(--c-tel-color-text, #fff);
}
.c-tel__inner::before {
  display: block;
  flex: 0 0 auto;
  width: var(--c-tel-icon-size, 18px);
  height: var(--c-tel-icon-size, 18px);
  margin-right: var(--c-tel-gap, 8px);
  content: "";
  background: var(--c-tel-url-tel-icon, url("../img/pc/icon_tel_white_theme.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-loaded {
  animation: slide1 120s -60s linear infinite;
}
.c-slider-smooth__group--dummy-loaded {
  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-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-qa {
  background: #ffffff;
}
.c-qa__title-inner {
  display: flex;
  align-items: center;
  padding: 19px 34px;
}
.c-qa__title-inner::before {
  position: relative;
  display: block;
  flex: 0 0 auto;
  width: 20px;
  height: 19px;
  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 18px;
  font-size: 18px;
  font-weight: bold;
  line-height: 30px;
  color: #36474f;
  letter-spacing: 0.1em;
}
.c-qa__content-inner {
  padding: 16px 32px 30px;
}
.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-price-table {
  background-color: #fff;
}
.c-price-table__title {
  position: relative;
  display: flex;
  justify-content: center;
  padding: 18px 20px;
  font-size: 22px;
  font-weight: bold;
  line-height: 30px;
  color: #fff;
  background: #36474f;
}
.c-price-table__title::after {
  position: absolute;
  bottom: -13px;
  left: calc(50% - 13px);
  display: block;
  width: 26px;
  height: 14px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  background: #36474f;
}
.c-price-table__inner {
  margin: 30px 0 0;
  border: 6px solid #dbe9f0;
}
.c-price-table__body {
  display: flex;
  flex-direction: column;
  container-type: inline-size;
}
.c-price-table__body .row {
  display: flex;
  gap: 20px 0;
  min-height: 66px;
}
.c-price-table__body .row:nth-of-type(n + 2) {
  border-top: 1px dashed rgba(75, 147, 178, 0.5);
}
.c-price-table__body .row:nth-child(even) {
  background: #fbfcfd;
}
@container (width < 990px) {
  .c-price-table__body .row {
    flex-wrap: wrap;
  }
}
.c-price-table__body .row__text-block {
  display: flex;
  flex: 1 1 auto;
  padding: 0 20px;
  border-right: 1px dashed rgba(75, 147, 178, 0.5);
}
@container (width < 990px) {
  .c-price-table__body .row__text-block {
    flex: 0 0 auto;
    width: 100%;
  }
}
.c-price-table__body .row__title {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  padding: 8px 10px 8px 28px;
  font-size: 20px;
  font-weight: bold;
  line-height: 30px;
}
.c-price-table__body .row__note {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  width: 28%;
  padding-left: 30px;
  font-size: 16px;
  line-height: 24px;
}
.c-price-table__body .row .price-unit {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  justify-content: flex-end;
  width: 290px;
  padding: 14px 56px 14px 0;
  margin-left: auto;
  font-weight: bold;
  line-height: 1;
}
.c-price-table__body .row .price-unit__price {
  font-size: 20px;
}
.c-price-table__body .row .price-unit__suffix {
  margin-left: 8px;
  font-size: 20px;
}
.c-price-table__body .row .price-unit__tax {
  position: relative;
  top: -2px;
  margin-left: 8px;
  font-size: 16px;
  font-weight: normal;
}

.c-post-front-news-card a {
  height: 100%;
}
.c-post-front-news-card__image {
  height: 254px;
  background-color: #9e9e9f;
}
.c-post-front-news-card__image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-post-front-news-card__main {
  padding-top: 10px;
  margin: 0 auto;
}
.c-post-front-news-card__title {
  font-size: 18px;
  font-weight: bold;
  line-height: 33px;
  color: #42342c;
  letter-spacing: 0.05em;
}
.c-post-front-news-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
  margin-top: 8px;
}
.c-post-front-news-card__date {
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  color: #c7c8c8;
}

.c-post-category-list__title a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 60px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background-color: #145072;
}
.c-post-category-list__title a::after {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 10px);
  display: block;
  width: 20px;
  height: 11px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  background-color: #145072;
}
.c-post-category-list__list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-top: 22px;
}
.c-post-category-list__list .parent__title a {
  position: relative;
  padding: 19px 32px;
  font-size: 16px;
  line-height: 22px;
  background-color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 3px;
}

.c-post-archive-bar a {
  display: grid;
  grid-template-columns: 302px 1fr;
  gap: 10px;
  overflow: hidden;
  background: #fff;
}
.c-post-archive-bar__image {
  padding: 10px;
}
.c-post-archive-bar__image-inner {
  position: relative;
  height: 100%;
  overflow: hidden;
  background: #9e9e9f;
}
.c-post-archive-bar__image-inner img {
  position: absolute;
  inset: 0;
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-post-archive-bar__main {
  min-height: 208px;
  padding: 24px 24px 20px;
}
.c-post-archive-bar__title {
  font-size: 16px;
  font-weight: bold;
  line-height: 29px;
  letter-spacing: 0.05em;
}
.c-post-archive-bar__content {
  margin-top: 14px;
  font-size: 14px;
  line-height: 25px;
  color: #868686;
}
.c-post-archive-bar__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  margin-top: 18px;
}
.c-post-archive-bar__category {
  padding: 8px 16px;
  font-size: 12px;
  line-height: 1;
  color: #b3b3b4;
  background: #ededed;
}
.c-post-archive-bar__date {
  display: block;
  font-size: 15px;
  font-weight: bold;
  line-height: 1;
  color: #b2b2b3;
}

.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-button-arrow {
  width: var(--c-button-arrow-width, 302px);
  height: var(--c-button-arrow-height, 58px);
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: var(--c-button-arrow-color-text, #36474f);
  background-color: var(--c-button-arrow-color-bg, #fff);
  border-radius: calc(var(--c-button-arrow-height, 58px) / 2);
}
.c-button-arrow__inner {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  padding: 0 24px 0 36px;
}
.c-button-arrow__inner::after {
  display: block;
  width: 34px;
  height: 10px;
  margin-left: auto;
  content: "";
  background-image: var(--NAMESPACE-arrow_image, url("../img/pc/c_button_arrow_arrow_theme.svg"));
  background-repeat: 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-recruit-form__input-list {
  display: flex;
  flex-direction: column;
  gap: 60px;
}
.b-recruit-form .row {
  width: 100%;
}
.b-recruit-form .row__title label {
  display: flex;
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
}
.b-recruit-form .row__title label b {
  position: relative;
  top: 2px;
  margin-left: 10px;
  font-size: 14px;
  color: #e30012;
}
.b-recruit-form .row__content {
  margin-top: 20px;
}
.b-recruit-form .row__content .wpcf7-radio {
  display: flex;
  gap: 40px;
  margin-top: -10px;
}
.b-recruit-form .row__content textarea,
.b-recruit-form .row__content input[type=text],
.b-recruit-form .row__content input[type=email],
.b-recruit-form .row__content input[type=tel] {
  width: 95%;
  padding: 12px 12px;
  font-size: 15px;
  line-height: 1.5em;
  text-align: left;
  appearance: none;
  background-color: #fff;
  border-radius: 1px;
}
.b-recruit-form .row__content input[type=date] {
  width: 200px;
  max-width: 50%;
  padding: 12px 12px;
  font-size: 15px;
  line-height: 1.5em;
  text-align: left;
  appearance: none;
  background-color: #fff;
  border-radius: 1px;
}
.b-recruit-form .row__content input.p-postal-code {
  width: 284px;
}
.b-recruit-form .row__content .p-region {
  margin-top: 12px;
}
.b-recruit-form .row__place-note {
  margin: 12px 0 0 16px;
  font-size: 16px;
  line-height: 1;
  color: #c6bdb5;
}
.b-recruit-form__consent {
  display: flex;
  justify-content: center;
  margin-top: 40px;
}
.b-recruit-form__consent label {
  display: flex;
  gap: 10px;
}
.b-recruit-form__consent label a {
  display: inline;
  text-decoration: underline;
}
.b-recruit-form__buttons {
  margin-top: 60px;
}
.b-recruit-form__buttons p {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: center;
}
.b-recruit-form__buttons .wpcf7-submit {
  display: block;
  width: 230px;
  height: 64px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  text-align: center;
  background: #145072;
  border-radius: 6px;
}
.b-recruit-form__buttons .wpcf7-submit:disabled {
  opacity: 0.5;
}

.b-post-nav ul {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  max-width: 1200px;
  margin: 0 auto;
  border-left: 2px solid #fff;
}
.b-post-nav li {
  border-right: 2px solid #fff;
}
.b-post-nav li a {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 88px;
  padding-top: 24px;
}
.b-post-nav li a span {
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
}
.b-post-nav li a img {
  margin-top: 16px;
}

.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: #36474f;
}
.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;
  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-header-content__container {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  max-width: 1894px;
  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);
}
.b-header-content__nav {
  display: flex;
  gap: 14px;
  align-items: center;
}
.b-header-content__menu {
  display: flex;
  align-items: center;
  height: 44px;
  filter: drop-shadow(var(--b-header-content-nav-shadow, unset));
}
@container (width < 1320px) {
  .b-header-content__menu {
    display: none;
  }
}
.b-header-content__menu li {
  padding: 0 32px;
}
.b-header-content__menu li a {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.b-header-content__menu li a span {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: var(--b-header-content-color-text, #36474f);
}
.b-header-content__menu li a img {
  margin-top: 14px;
}
.b-header-content__menu li + li {
  position: relative;
}
.b-header-content__menu li + li::before {
  position: absolute;
  top: calc(50% - 25px);
  left: 0;
  display: block;
  width: 2px;
  height: 50px;
  content: "";
  background: var(--b-header-content-color-menu-border, rgba(255, 255, 255, 0.3));
}
.b-header-content__button-area {
  position: relative;
}
.b-header-content__contact {
  width: 250px;
}
.b-header-content__contact a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background: radial-gradient(circle at -10px -30px, #2790c4 0, #145072 120px);
  border-radius: 3px;
}
.b-header-content__contact a::before {
  display: block;
  width: 24px;
  height: 24px;
  margin-right: 12px;
  content: "";
  background: url("../img/pc/icon_calendar_white.svg") no-repeat;
}
.b-header-content__contact a::after {
  display: block;
  width: 18px;
  height: 18px;
  margin-left: 16px;
  content: "";
  background: url("../img/pc/b_header_contact_chevron.svg") no-repeat;
}
.b-header-content__tel {
  position: absolute;
  bottom: -42px;
  left: 0;
}

.b-header-blank {
  position: relative;
  max-width: 1920px;
  height: 142px;
  margin: 0 auto;
  background: #fff;
}
.b-header-blank::before {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  display: block;
  width: 294px;
  height: 174px;
  clip-path: polygon(0 0, 100% 0, calc(100% - 40px) 100%, 0 100%);
  content: "";
  background: #fff;
}

.b-header {
  position: relative;
  z-index: 7000;
  max-width: 1920px;
  margin: 0 auto;
}
.b-header__fixed {
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  height: 88px;
  padding-top: 14px;
  background: #fff;
  transition: all 0.2s;
  transform: translateY(-100%);
  --b-header-content-color-text: #111310;
  --b-header-content-color-menu-border: rgba(237, 237, 237, 0.5);
  --b-header-content-logo-width: 201px;
  --b-header-content-logo-height: 43px;
  --b-header-content-logo-margin: 10px 0 0 40px;
}
.b-header__fixed--visible {
  transform: translateY(0%);
}
.b-header__content {
  position: absolute;
  top: 0;
  right: 0;
  left: 0;
  height: 140px;
  padding-top: 36px;
}
.b-header__content--main {
  --b-header-content-logo-width: 149px;
  --b-header-content-logo-height: 102px;
  --b-header-content-logo-margin: -4px 0 0 8px;
}
.b-header__content--sub {
  --b-header-content-color-text: #fff;
  --b-header-content-logo-width: 149px;
  --b-header-content-logo-height: 102px;
  --b-header-content-logo-margin: -4px 0 0 8px;
}

.b-footer {
  position: relative;
  max-width: 1920px;
  padding: 0 0 60px;
  margin: 0 auto 0;
  background: #f5f6f6 url("../img/pc/b_footer_bg.png") no-repeat bottom right/cover;
}
.b-footer__container {
  position: relative;
  z-index: 10;
  display: flex;
  max-width: 1220px;
  padding-left: 24px;
  margin: 0 auto;
}
.b-footer__block-1 {
  flex: 0 0 auto;
  width: 32%;
  max-width: 430px;
  padding-top: 80px;
}
.b-footer__block-2 {
  position: relative;
  width: 70%;
  max-width: 860px;
  padding: 80px 0 0 30px;
}
.b-footer__block-3 {
  position: relative;
  width: 10%;
  max-width: 212px;
  padding: 128px 0 0 0;
}
.b-footer__logo {
  width: 149px;
  height: 103px;
  margin-left: 56px;
}
.b-footer .address-block {
  max-width: 354px;
  margin-top: 44px;
}
.b-footer .address-block__title {
  padding-bottom: 20px;
  font-size: 16px;
  line-height: 1;
  border-bottom: 2px solid rgba(218, 219, 219, 0.5);
}
.b-footer .address-block__title span {
  display: block;
  margin-top: 14px;
  font-size: 18px;
  font-weight: bold;
}
.b-footer .address-block__address {
  margin: 22px 0 0;
  font-size: 16px;
  line-height: 33px;
}
.b-footer .address-block__button {
  width: 240px;
  margin-top: 20px;
}
.b-footer .address-block__button a {
  position: relative;
  display: flex;
  align-items: center;
  height: 58px;
  padding-left: 36px;
  border: 1px solid #36474f;
  border-radius: 29px;
}
.b-footer .address-block__button a::after {
  display: block;
  flex: 0 0 auto;
  width: 9px;
  height: 16px;
  margin-left: 36px;
  content: "";
  background: url("../img/pc/b_footer_button_chevron.svg") no-repeat;
}
.b-footer .address-block__sns {
  display: flex;
  gap: 32px;
  align-items: center;
  margin-top: 90px;
}
.b-footer .address-block__sns li + li {
  display: flex;
}
.b-footer .address-block__sns li + li::before {
  display: block;
  width: 1px;
  height: 28px;
  margin-right: 38px;
  content: "";
  background: #dadbdb;
}
.b-footer .address-block__tel {
  margin-top: 22px;
  font-size: 16px;
  line-height: 28px;
}
.b-footer__nav {
  position: relative;
  display: grid;
  grid-template-rows: repeat(3, 92px);
  grid-template-columns: repeat(3, 208px);
  grid-auto-flow: column;
  gap: 18px 56px;
}
.b-footer__nav .item {
  height: 100%;
  border-bottom: 2px solid rgba(218, 219, 219, 0.5);
}
.b-footer__nav .item a {
  height: 100%;
  padding: 12px 0 0;
  background: url("../img/pc/b_footer_nav_chevron.svg") top calc(50% - 12px) right 0/5px 9px no-repeat;
}
.b-footer__nav .item span {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
}
.b-footer__nav .item img {
  max-height: 14px;
  margin-top: 8px;
}
.b-footer__copyright {
  max-width: 1208px;
  padding: 0 20px;
  margin: 100px auto 0;
}
.b-footer__copyright::before {
  display: block;
  width: 108px;
  height: 1px;
  margin-bottom: 20px;
  content: "";
  background: #36474f;
}

.b-contact-main {
  position: relative;
  z-index: 100;
}
.b-contact-main__slash {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  justify-content: center;
}
.b-contact-main__slash span {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #145072;
  letter-spacing: 0.1em;
}
.b-contact-main__slash::before {
  position: relative;
  top: 8px;
  display: block;
  width: 2px;
  height: 20px;
  content: "";
  background: #145072;
  transform: rotate(-32deg);
}
.b-contact-main__slash::after {
  position: relative;
  top: 8px;
  display: block;
  width: 2px;
  height: 20px;
  content: "";
  background: #145072;
  transform: rotate(32deg);
}
.b-contact-main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 24px;
}
.b-contact-main__title span {
  margin-top: 20px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
}
.b-contact-main__container {
  display: grid;
  grid-template-columns: repeat(auto-fit, 388px);
  gap: 18px;
  max-width: 1200px;
  margin: 54px auto 0;
}
.b-contact-main__container > * {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 146px;
  border-left: 3px solid #f6f5f5;
}
.b-contact-main__container > *:last-of-type {
  border-right: 3px solid #f6f5f5;
}
.b-contact-main__container .tel-area__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 238px;
  height: 52px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
  background: #dbe9f0;
}
.b-contact-main__container .tel-area__title::after {
  position: absolute;
  bottom: -21px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 22px;
  content: "";
  background: #dbe9f0;
}
.b-contact-main__container .tel-area__tel {
  margin-top: 30px;
  --c-tel-icon-size: 20px;
  --c-tel-font-size: 30px;
  --c-tel-gap: 10px;
  --c-tel-color-text: #36474f;
  --c-tel-url-tel-icon: url("../img/pc/icon_tel_theme_white.svg");
}
.b-contact-main__container .tel-area__time {
  margin-top: 12px;
  font-size: 16px;
  line-height: 1;
}
.b-contact-main__container .line-area__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 238px;
  height: 52px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
  background: #dbe9f0;
}
.b-contact-main__container .line-area__title::after {
  position: absolute;
  bottom: -21px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 22px;
  content: "";
  background: #dbe9f0;
}
.b-contact-main__container .line-area__button {
  width: 270px;
  height: 59px;
  margin: 34px auto 0;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.b-contact-main__container .contact-area__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 238px;
  height: 52px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
  background: #dbe9f0;
}
.b-contact-main__container .contact-area__title::after {
  position: absolute;
  bottom: -21px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 22px;
  content: "";
  background: #dbe9f0;
}
.b-contact-main__container .contact-area__button {
  width: 270px;
  margin-top: 32px;
}
.b-contact-main__container .contact-area__button a {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 60px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background: radial-gradient(circle at -10px -30px, #2790c4 0, #145072 120px);
}
.b-contact-main__container .contact-area__button a::before {
  display: block;
  width: 28px;
  height: 18px;
  margin-right: 12px;
  content: "";
  background: url("../img/pc/icon_mail_white.svg") no-repeat;
}
.b-contact-main__container .contact-area__button a::after {
  display: block;
  width: 9px;
  height: 16px;
  margin-left: 20px;
  content: "";
  background: url("../img/pc/b_contact_chevron.svg") no-repeat center;
}
.b-contact-main__note {
  margin-top: 46px;
  text-align: center;
}

.b-contact {
  padding: 112px 40px 100px;
  background: #fff;
}

.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: #145072;
  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-single .background {
  max-width: 1920px;
  margin: 0 auto;
}
.p-single .background::after {
  display: block;
  height: 40px;
  content: "";
  background: url("../img/pc/contact_bg_bottom.png") no-repeat top center;
}
.p-single .background__inner {
  padding: 62px 40px 94px;
  background: #f4f4f4;
}
.p-single .background__container {
  display: grid;
  grid-template-columns: 1fr 232px;
  gap: 52px;
  max-width: 1200px;
  margin: 0 auto;
}
.p-single .background__category {
  display: flex;
  flex-direction: column;
  gap: 44px;
}
.p-single .post__main-block {
  position: relative;
  z-index: 10;
  padding-bottom: 45px;
  background-color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-single .post__title-block {
  padding: 44px 0 20px;
  margin: 0 45px;
  border-bottom: 2px solid #f5f5f5;
}
.p-single .post__title {
  font-size: 27px;
  font-weight: bold;
  line-height: 40px;
}
.p-single .post__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 20px;
  align-items: center;
  margin-top: 14px;
}
.p-single .post__category {
  padding: 8px 16px;
  font-size: 12px;
  line-height: 1;
  color: #b3b3b4;
  background: #ededed;
}
.p-single .post__date {
  display: block;
  flex: 0 0 auto;
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  color: #b3b3b4;
}
.p-single .post__content {
  padding: 32px 45px 43px;
}
.p-single .post__content h2 {
  width: calc(100% + 90px);
  padding-right: 45px;
  padding-left: 45px;
  margin-left: -45px;
  font-size: 24px;
  background-color: #145072;
}
.p-single .post__content h3 {
  font-size: 24px;
  color: #42342c;
  border-bottom: 3px solid #eeeeef;
}
.p-single .post .relation {
  padding-top: 30px;
  margin: 0 55px;
  border-top: 1px solid #d8d9d9;
}
.p-single .post .relation__title {
  font-size: 19px;
  font-weight: bold;
  line-height: 1;
  color: #145072;
  text-align: center;
  letter-spacing: 0.1em;
}
.p-single .post .relation__title::after {
  display: block;
  width: 79px;
  height: 2px;
  margin: 22px auto 0;
  content: "";
  background-color: #145072;
}
.p-single .post .relation__list {
  margin-top: 26px;
}
.p-single .post .relation .item {
  margin-top: 20px;
}
.p-single .post .relation .item a {
  display: flex;
}
.p-single .post .relation .item__image {
  display: flex;
  flex: 0 0 auto;
  align-items: center;
  width: 104px;
  background-color: #9e9e9f;
}
.p-single .post .relation .item__image img {
  object-fit: cover;
  width: 100%;
  height: 68px;
}
.p-single .post .relation .item__title {
  display: flex;
  flex: 1 1 auto;
  align-items: center;
  justify-content: space-between;
  min-height: 68px;
  padding: 8px 1em 8px 2em;
  font-size: 18px;
  font-weight: bold;
  line-height: 26px;
  background-color: #f4f4f4;
}
.p-single .post .relation .item__title::after {
  display: block;
  flex: 0 0 auto;
  width: 20px;
  height: 20px;
  margin-left: 1em;
  content: "";
  background-image: url("../img/pc/single_relation_chevron.svg");
  background-repeat: no-repeat;
}
.p-single .post__post-navi {
  position: relative;
  height: 60px;
  margin: 38px auto 0;
  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: #145072;
  border-radius: 3px;
}
.p-single .post__post-navi .prev-btn a {
  width: 100%;
  height: 100%;
  padding: 23px 0 0 58px;
}
.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: #145072;
  border-radius: 3px;
  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: #145072;
  border-radius: 3px;
}
.p-single .post__post-navi .next-btn a {
  width: 100%;
  height: 100%;
  padding: 23px 0 0 21px;
}
.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-single .post__sns {
  display: flex;
  align-items: center;
  padding: 16px 36px;
  margin-top: 39px;
  background-color: #fff;
}
.p-single .post__sns ul {
  display: flex;
  align-items: center;
  margin-left: -6px;
}
.p-single .post__sns ul li {
  margin-left: 10px;
}
.p-single .recently {
  margin-top: 48px;
}
.p-single .recently__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 64px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  background-color: #145072;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 3px;
}
.p-single .recently__title::after {
  position: absolute;
  bottom: -10px;
  left: calc(50% - 10px);
  display: block;
  width: 20px;
  height: 11px;
  clip-path: polygon(0 0, 100% 0, 50% 100%);
  content: "";
  background-color: #145072;
}
.p-single .recently__list {
  position: relative;
  padding: 0 10px;
  margin-top: 22px;
  background-color: #fff;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 3px;
}
.p-single .recently .item {
  border-bottom: 1px solid #eaeaeb;
}
.p-single .recently .item:last-of-type {
  border-bottom: none;
}
.p-single .recently .item a {
  padding: 18px 10px 24px;
}
.p-single .recently .item__title {
  font-size: 16px;
  line-height: 24px;
}
.p-single .recently .item__date {
  display: block;
  margin-top: 14px;
  font-size: 14px;
  font-weight: bold;
  line-height: 1;
  color: #b3b3b4;
}
.p-single .b-contact {
  padding-top: 76px;
}

.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;
}

@keyframes front_mv_fadein {
  0% {
    opacity: 0;
    transform: translateY(-40px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.p-front-page .mv {
  position: relative;
  max-width: 1920px;
  height: 1320px;
}
.p-front-page .mv__bg {
  position: absolute;
  inset: 0;
  z-index: 10;
}
.p-front-page .mv__bg-2 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 20;
  width: 294px;
  height: 100%;
  clip-path: polygon(0 0, 100% 0, calc(100% - 40px) 172px, 112px 172px, 112px 100%, 0 100%);
  background: linear-gradient(to bottom, #fff 630px, transparent 1210px);
}
.p-front-page .mv__container {
  display: grid;
  grid-template-columns: 112px 1fr;
}
.p-front-page .mv__left {
  position: relative;
  z-index: 30;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-top: 210px;
}
.p-front-page .mv__text {
  font-size: 17px;
  font-weight: bold;
  line-height: 1;
  letter-spacing: 0.1em;
  writing-mode: vertical-rl;
  text-orientation: upright;
}
.p-front-page .mv__scroll {
  padding: 4px;
  margin-top: 74px;
}
.p-front-page .mv__scroll img {
  width: 13px;
  height: 118px;
}
.p-front-page .mv__right {
  position: relative;
  z-index: 30;
  height: clamp(800px, 100vh, 960px);
}
.p-front-page .mv__large-shadow {
  position: absolute;
  bottom: 114px;
  left: 52px;
  z-index: 100;
  width: 781px;
  height: 334px;
  opacity: 0;
  animation: 0.6s front_mv_fadein 1.2s forwards;
}
.p-front-page .mv__large {
  position: absolute;
  bottom: 94px;
  left: 92px;
  z-index: 110;
  width: 785px;
  height: 360px;
  opacity: 0;
  animation: 0.6s front_mv_fadein 1.2s forwards;
}
.p-front-page .mv__badge {
  position: absolute;
  right: 130px;
  bottom: 104px;
  width: 228px;
  height: 251px;
  opacity: 0;
  animation: 0.6s front_mv_fadein 1.2s forwards;
}
.p-front-page .concept {
  position: relative;
  z-index: 100;
  margin-top: -544px;
  overflow: hidden;
  pointer-events: none;
}
.p-front-page .concept__container {
  position: relative;
  max-width: 1686px;
  padding: 0 40px;
  margin: 0 auto 0;
}
.p-front-page .concept__bg img {
  position: absolute;
  top: 0;
  left: 304px;
  z-index: -1;
  width: 1424px;
  max-width: unset;
  height: 984px;
}
.p-front-page .concept__block {
  position: relative;
  z-index: 100;
  padding-top: 276px;
  pointer-events: auto;
}
.p-front-page .concept__title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.p-front-page .concept__title span {
  margin-top: 24px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
}
.p-front-page .concept__title::after {
  display: block;
  width: 52px;
  height: 3px;
  margin-top: 18px;
  content: "";
  background: #c6dee5;
}
.p-front-page .concept__headline {
  margin-top: 16px;
  font-size: 38px;
  font-weight: bold;
  line-height: 58px;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-front-page .concept__english {
  margin-top: 18px;
}
.p-front-page .concept__text {
  width: 490px;
  margin-top: 30px;
}
.p-front-page .concept__note {
  display: inline-block;
  padding: 16px 26px;
  margin-top: 20px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  background: #ededed;
  border-radius: 3px;
}
.p-front-page .concept__slider {
  height: 115px;
  margin-top: 96px;
}
.p-front-page .concept__slider .c-slider-smooth__group {
  padding-right: 80px;
}
.p-front-page .feature {
  padding: 328px 0 0;
  margin-top: -68px;
  overflow: hidden;
  background: url("../img/pc/front_feature_base_bg.png") no-repeat top center;
}
.p-front-page .feature__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .feature__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-front-page .feature__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-front-page .feature__list {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 48px;
  margin-top: 46px;
  isolation: isolate;
}
.p-front-page .feature__list::before {
  position: absolute;
  top: -120px;
  right: 0;
  left: 0;
  z-index: -1;
  display: block;
  height: 2178px;
  content: "";
  background: url("../img/pc/front_feature_base_bg_2.png") no-repeat top center;
}
.p-front-page .feature__list .section__block {
  width: 490px;
}
.p-front-page .feature__list .section__headline {
  margin-top: 24px;
  font-size: 38px;
  font-weight: bold;
  line-height: 58px;
  letter-spacing: 0.1em;
}
.p-front-page .feature__list .section__english {
  margin-top: 18px;
}
.p-front-page .feature__list .section__text {
  margin-top: 28px;
}
.p-front-page .feature__list .section:nth-child(even) .section__headline {
  color: #fff;
}
.p-front-page .feature__list .section:nth-child(even) .section__text {
  color: #fff;
}
.p-front-page .feature__list .section:nth-child(1) .section__container, .p-front-page .feature__list .section:nth-child(2) .section__container, .p-front-page .feature__list .section:nth-child(3) .section__container {
  display: flex;
  gap: 98px;
  max-width: 1796px;
}
.p-front-page .feature__list .section:nth-child(1) .section__bg, .p-front-page .feature__list .section:nth-child(2) .section__bg, .p-front-page .feature__list .section:nth-child(3) .section__bg {
  width: calc(100% - 490px - 98px);
  height: 465px;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-front-page .feature__list .section:nth-child(1) .section__bg img, .p-front-page .feature__list .section:nth-child(2) .section__bg img, .p-front-page .feature__list .section:nth-child(3) .section__bg img {
  object-fit: none;
  object-position: center;
  height: 100%;
}
.p-front-page .feature__list .section:nth-child(1) .section__block, .p-front-page .feature__list .section:nth-child(2) .section__block, .p-front-page .feature__list .section:nth-child(3) .section__block {
  flex: 0 0 auto;
  padding: 50px 0 0;
}
.p-front-page .feature__list .section:nth-child(1) .section__container, .p-front-page .feature__list .section:nth-child(3) .section__container {
  padding-right: 40px;
  margin-right: auto;
}
.p-front-page .feature__list .section:nth-child(2) .section__container {
  flex-direction: row-reverse;
  padding-left: 40px;
  margin-left: auto;
}
.p-front-page .feature__list .section:nth-child(4) {
  overflow: hidden;
}
.p-front-page .feature__list .section:nth-child(4) .section__container {
  position: relative;
  max-width: 1648px;
  height: 596px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-front-page .feature__list .section:nth-child(4) .section__bg {
  position: absolute;
  inset: 0;
  z-index: -1;
  height: 100%;
}
.p-front-page .feature__list .section:nth-child(4) .section__bg img {
  position: absolute;
  top: 0;
  left: -136px;
  width: 1920px;
  max-width: unset;
  height: 100%;
  object-fit: none;
  object-position: center;
}
.p-front-page .feature__list .section:nth-child(4) .section__block {
  position: relative;
  padding: 78px 0 0;
}
.p-front-page .feature__list .section:nth-child(4) .section__badge {
  position: absolute;
  top: 32px;
  left: 366px;
  width: 222px;
  height: 274px;
}
.p-front-page .service {
  padding: 94px 0 0;
  overflow: hidden;
}
.p-front-page .service__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .service__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-front-page .service__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-front-page .service__container {
  display: flex;
  gap: 40px;
  justify-content: space-between;
  max-width: 1796px;
  padding-right: 40px;
  margin-top: 28px;
}
.p-front-page .service__bg {
  width: calc(100% - 490px - 40px);
  max-width: 1130px;
  height: 529px;
}
.p-front-page .service__bg img {
  object-fit: none;
  object-position: center;
  height: 100%;
}
.p-front-page .service__block {
  flex: 0 0 auto;
  width: 490px;
  padding: 40px 0 0;
}
.p-front-page .service__headline {
  margin-top: 24px;
  font-size: 38px;
  font-weight: bold;
  line-height: 58px;
  letter-spacing: 0.1em;
}
.p-front-page .service__english {
  margin-top: 18px;
}
.p-front-page .service__text {
  margin-top: 28px;
}
.p-front-page .service .price-section {
  padding: 0 40px;
}
.p-front-page .service .price-section__list {
  display: flex;
  flex-direction: column;
  gap: 50px;
  max-width: 1200px;
  margin: -30px auto 0;
}
.p-front-page .service .engines {
  position: relative;
  z-index: 100;
  padding: 68px 40px 0;
}
.p-front-page .service .engines__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .service .engines__title span {
  margin-top: 18px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  color: #145072;
}
.p-front-page .service .engines__list {
  display: flex;
  flex-direction: column;
  gap: 20px;
  max-width: 1200px;
  margin: 26px auto 0;
}
.p-front-page .service .engines__list dl {
  display: grid;
  grid-template-columns: 234px 1fr;
  gap: 14px;
}
.p-front-page .service .engines__list dl dt {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 62px;
  padding: 10px 10px;
  font-size: 20px;
  font-weight: bold;
  color: #145072;
  text-align: center;
  background: #eaeff1;
}
.p-front-page .service .engines__list dl dt::after {
  position: absolute;
  top: calc(50% - 7px);
  right: -9px;
  display: block;
  width: 10px;
  height: 14px;
  clip-path: polygon(0 0, 100% 50%, 0 100%);
  content: "";
  background: #eaeff1;
}
.p-front-page .service .engines__list dl dd {
  display: flex;
  align-items: center;
  min-height: 62px;
  padding: 10px 32px;
  background: #eaeff1;
}
.p-front-page .customer {
  height: 1130px;
  padding: 148px 0 0;
  margin-top: -66px;
  background: url("../img/pc/front_customer_bg.png") no-repeat top center;
}
.p-front-page .customer__title {
  position: relative;
  font-size: 25px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  text-align: center;
  letter-spacing: 0.1em;
  isolation: isolate;
}
.p-front-page .customer__title span {
  display: block;
  margin-top: 16px;
  font-size: 33px;
}
.p-front-page .customer__title img {
  margin: 22px auto 0;
}
.p-front-page .customer__title::before {
  position: absolute;
  top: -52px;
  left: calc(50% - 450px);
  z-index: -1;
  display: block;
  width: 875px;
  height: 208px;
  content: "";
  background: url("../img/pc/front_customer_title_deco.png") no-repeat;
}
.p-front-page .customer__list {
  margin-top: 32px;
}
.p-front-page .customer__list .c-slider__track {
  justify-content: center;
  overflow: unset;
}
.p-front-page .customer__list .c-slider__item {
  width: 380px;
  margin-right: 28px;
}
.p-front-page .customer__list .c-slider__arrow-left {
  top: 278px;
  left: 20%;
  width: 58px;
  height: 58px;
  background: #36474f url("../img/pc/front_customer_chevron_left.svg") center/9px 16px no-repeat;
  border-radius: 50%;
}
.p-front-page .customer__list .c-slider__arrow-right {
  top: 278px;
  right: 20%;
  width: 58px;
  height: 58px;
  background: #36474f url("../img/pc/front_customer_chevron_right.svg") center/9px 16px no-repeat;
  border-radius: 50%;
}
.p-front-page .customer__list .item__image {
  height: 254px;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 328px 100%, 328px 226px, 0 226px);
  background: #9e9e9f;
}
.p-front-page .customer__list .item__image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-front-page .customer__list .item__title {
  max-width: 310px;
  height: 48px;
  margin-top: -16px;
  font-size: 16px;
  font-weight: bold;
  line-height: 24px;
}
.p-front-page .customer__chunk {
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.p-front-page .customer__button {
  margin: 50px auto 0;
}
.p-front-page .flow {
  max-width: 1920px;
  padding: 12px 40px 10px;
  margin: -1px auto 0;
  background: #f5f6f6 url("../img/pc/front_flow_bg.png") no-repeat top 100px center;
}
.p-front-page .flow__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .flow__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-front-page .flow__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-front-page .flow__list {
  position: relative;
  z-index: 100;
  display: grid;
  grid-template-columns: repeat(auto-fill, 381px);
  grid-gap: 34px 30px;
  justify-content: center;
  max-width: 1203px;
  margin: 20px auto 0;
  isolation: isolate;
  container-type: inline-size;
}
.p-front-page .flow__list .item {
  position: relative;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-front-page .flow__list .item__image {
  height: 205px;
}
.p-front-page .flow__list .item__image img {
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.p-front-page .flow__list .item__block {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1px 20px 32px;
  background: #fff;
}
.p-front-page .flow__list .item__counter {
  position: relative;
  z-index: 100;
  margin-top: -60px;
}
.p-front-page .flow__list .item__title {
  margin-top: -32px;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-front-page .flow__list .item__text {
  width: 310px;
  margin-top: 16px;
}
.p-front-page .flow__list .item::before {
  position: absolute;
  top: 186px;
  left: -30px;
  z-index: -1;
  display: block;
  width: 30px;
  height: 1px;
  content: "";
  background: #145072;
  transform: rotate(4deg);
}
@container (width < 792px) {}
@container (792px <= width < 1203px) {
  .p-front-page .flow__list .item:nth-of-type(2n + 2) {
    top: 20px;
  }
  .p-front-page .flow__list .item:nth-of-type(2n + 2)::after {
    position: absolute;
    top: 204px;
    right: -25px;
    z-index: -1;
    width: 90px;
    height: 8px;
    content: "";
    background: url("../img/pc/front_flow_line.svg") no-repeat;
  }
}
@container (1203px <= width) {
  .p-front-page .flow__list .item:nth-of-type(3n + 2) {
    top: 20px;
  }
  .p-front-page .flow__list .item:nth-of-type(3n + 3)::after {
    position: absolute;
    top: 204px;
    right: -25px;
    z-index: -1;
    width: 90px;
    height: 8px;
    content: "";
    background: url("../img/pc/front_flow_line.svg") no-repeat;
  }
  .p-front-page .flow__list .item:nth-of-type(3n + 3) {
    top: 40px;
  }
  .p-front-page .flow__list .item:nth-of-type(3n + 3)::after {
    position: absolute;
    top: 204px;
    right: -25px;
    z-index: -1;
    width: 90px;
    height: 8px;
    content: "";
    background: url("../img/pc/front_flow_line.svg") no-repeat;
  }
}
.p-front-page .flow__list .item:first-of-type::before {
  display: none;
}
.p-front-page .flow__list .item:last-of-type::after {
  display: none;
}
.p-front-page .reason {
  padding: 150px 40px 114px;
  background: url("../img/pc/front_reason_bg.jpg") no-repeat center/cover;
}
.p-front-page .reason__slash {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  justify-content: center;
}
.p-front-page .reason__slash span {
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  letter-spacing: 0.2em;
}
.p-front-page .reason__slash::before {
  position: relative;
  top: 8px;
  display: block;
  width: 2px;
  height: 20px;
  content: "";
  background: #fff;
  transform: rotate(-32deg);
}
.p-front-page .reason__slash::after {
  position: relative;
  top: 8px;
  display: block;
  width: 2px;
  height: 20px;
  content: "";
  background: #fff;
  transform: rotate(32deg);
}
.p-front-page .reason__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 6px;
}
.p-front-page .reason__title span {
  font-size: 39px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
  letter-spacing: 0.1em;
}
.p-front-page .reason__title span em {
  font-size: 53px;
  font-style: normal;
}
.p-front-page .reason__title img {
  margin-top: 20px;
}
.p-front-page .reason__list {
  display: grid;
  grid-template-columns: repeat(auto-fill, 580px);
  gap: 42px 40px;
  justify-content: center;
  max-width: 1200px;
  margin: 44px auto 0;
}
.p-front-page .reason__list .item {
  padding: 4px;
  background: #f7f5f2;
}
.p-front-page .reason__list .item__inner {
  padding: 30px 30px 32px;
  background: #fff;
}
.p-front-page .reason__list .item__title-block {
  display: flex;
}
.p-front-page .reason__list .item__counter {
  display: flex;
  align-items: center;
  width: 106px;
  height: 26px;
  border-right: 2px solid #f5f6f6;
}
.p-front-page .reason__list .item__title {
  align-items: center;
  margin-left: 24px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-front-page .reason__list .item__main-block {
  display: flex;
  gap: 20px;
  align-items: center;
  margin-top: 20px;
}
.p-front-page .reason__list .item__image {
  flex: 0 0 auto;
}
.p-front-page .reason__list .item__image img {
  width: 88px;
  height: 88px;
}
.p-front-page .news {
  position: relative;
  z-index: 100;
  padding: 94px 0 86px;
}
.p-front-page .news__container {
  display: grid;
  grid-template-columns: 74px calc(100% - 74px - 56px);
  gap: 56px;
  max-width: 1810px;
  padding-left: 40px;
  margin: 20px 0 0 auto;
}
.p-front-page .news__title {
  width: 74px;
  height: 181px;
}
.p-front-page .news .c-slider__track {
  overflow: unset;
}
.p-front-page .news .c-slider__item {
  width: 380px;
  margin-right: 24px;
}
.p-front-page .news .c-slider__arrow-left {
  top: 98px;
  left: -30px;
  width: 58px;
  height: 58px;
  background: #fff url("../img/pc/front_news_chevron_left.svg") center/9px 16px no-repeat;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
  border-radius: 50%;
}
.p-front-page .news__button {
  margin: 58px auto 0;
}
.p-front-page .thoughts {
  position: relative;
  max-width: 1920px;
  margin: -294px auto 0;
  background: url("../img/pc/front_thoughts_bg.png") no-repeat top center;
}
.p-front-page .thoughts__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 1441px;
  padding: 308px 40px 100px;
}
.p-front-page .thoughts__headline {
  margin-top: 18px;
  font-size: 35px;
  font-weight: bold;
  line-height: 56px;
  color: #36474f;
  text-align: center;
  letter-spacing: 0.1em;
}
.p-front-page .thoughts__english {
  margin-top: 30px;
}
.p-front-page .thoughts__text {
  margin-top: 30px;
  text-align: center;
}
.p-front-page .thoughts__slider {
  position: absolute;
  right: 0;
  bottom: -60px;
  left: 0;
  z-index: 1000;
  height: 115px;
}
.p-front-page .thoughts__slider .c-slider-smooth__group {
  padding-right: 80px;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-front-page .thoughts .area-block {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .thoughts .area-block__title {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 146px;
  height: 46px;
  margin-top: 44px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  background: #fff;
  border-radius: 23px;
}
.p-front-page .thoughts .area-block__text {
  margin-top: 14px;
  font-size: 18px;
  font-weight: bold;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-front-page .thoughts .area-block__note {
  font-size: 14px;
}
.p-front-page .bg-1 {
  position: relative;
  z-index: 100;
  max-width: 1920px;
  margin: -36px auto -36px;
  overflow: hidden;
}
.p-front-page .bg-1::before {
  display: block;
  width: 1920px;
  height: 40px;
  content: "";
  background: url("../img/pc/front_bg_1_top.png") no-repeat top center;
}
.p-front-page .bg-1__inner {
  padding: 88px 0 68px;
  background: #dbe9f0 url("../img/pc/front_bg_1_deco.png") no-repeat top center;
}
.p-front-page .bg-1::after {
  display: block;
  width: 1920px;
  height: 40px;
  content: "";
  background: url("../img/pc/front_bg_1_bottom.png") no-repeat bottom center;
}
.p-front-page .instagram-section {
  display: flex;
  justify-content: center;
  padding: 0 40px;
}
.p-front-page .qa {
  padding: 46px 40px 0;
}
.p-front-page .qa__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-front-page .qa__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-front-page .qa__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-front-page .qa__list {
  display: flex;
  flex-direction: column;
  gap: 32px;
  max-width: 1200px;
  margin: 42px auto 0;
}
.p-front-page .qa__item {
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-front-page .b-contact {
  padding-top: 110px;
}

.p-contact .bg-area {
  max-width: 1920px;
  margin: 0 auto;
}
.p-contact .bg-area__inner {
  background: #f4f4f4;
}
.p-contact .bg-area::after {
  display: block;
  height: 40px;
  content: "";
  background: url("../img/pc/contact_bg_bottom.png") no-repeat top center;
}
.p-contact .main {
  padding: 84px 40px 78px;
}
.p-contact .main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-contact .main__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-contact .main__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-contact .main__info {
  margin-top: 24px;
  text-align: center;
}
.p-contact .main__container {
  display: grid;
  grid-template-columns: repeat(auto-fit, 388px);
  gap: 18px;
  justify-content: center;
  max-width: 1200px;
  margin: 52px auto 0;
}
.p-contact .main__container > * {
  display: flex;
  flex-direction: column;
  align-items: center;
  height: 146px;
  border-left: 3px solid #f6f5f5;
}
.p-contact .main__container > *:last-of-type {
  border-right: 3px solid #f6f5f5;
}
.p-contact .main__container .tel-area__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 238px;
  height: 52px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
  background: #dbe9f0;
}
.p-contact .main__container .tel-area__title::after {
  position: absolute;
  bottom: -21px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 22px;
  content: "";
  background: #dbe9f0;
}
.p-contact .main__container .tel-area__tel {
  margin-top: 30px;
  --c-tel-icon-size: 20px;
  --c-tel-font-size: 30px;
  --c-tel-gap: 10px;
  --c-tel-color-text: #36474f;
  --c-tel-url-tel-icon: url("../img/pc/icon_tel_theme_white.svg");
}
.p-contact .main__container .tel-area__time {
  margin-top: 12px;
  font-size: 16px;
  line-height: 1;
}
.p-contact .main__container .line-area__title {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 238px;
  height: 52px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
  background: #dbe9f0;
}
.p-contact .main__container .line-area__title::after {
  position: absolute;
  bottom: -21px;
  left: calc(50% - 1px);
  display: block;
  width: 2px;
  height: 22px;
  content: "";
  background: #dbe9f0;
}
.p-contact .main__container .line-area__button {
  width: 270px;
  height: 59px;
  margin: 34px auto 0;
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-contact .form {
  max-width: 1116px;
  margin: 68px auto 0;
  font-family: "Hiragino Kaku Gothic Pro", "ヒラギノ角ゴ Pro W3", Meiryo, メイリオ, Osaka, "MS PGothic", arial, helvetica, sans-serif;
}
.p-contact .b-contact {
  padding-top: 76px;
}

.p-archive .main {
  max-width: 1920px;
  margin: 0 auto;
}
.p-archive .main::after {
  display: block;
  height: 40px;
  content: "";
  background: url("../img/pc/contact_bg_bottom.png") no-repeat top center;
}
.p-archive .main__bg {
  padding: 60px 40px 76px;
  background: #f4f4f4;
}
.p-archive .main__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-archive .main__title span {
  margin-top: 20px;
  font-family: "ヒラギノ明朝 Pro", "Hiragino Mincho Pro", "游明朝", "Yu Mincho", YuMincho, "Noto Serif JP", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-size: 20px;
  font-weight: bold;
  line-height: 1;
  color: #474645;
  letter-spacing: 0.1em;
}
.p-archive .main__container {
  display: grid;
  grid-template-columns: 1fr 232px;
  gap: 54px;
  max-width: 1200px;
  margin: 56px auto 0;
}
.p-archive .main__list {
  display: flex;
  flex-direction: column;
  gap: 36px;
}
.p-archive .main__item {
  filter: drop-shadow(0 0 9px rgba(0, 0, 0, 0.1));
}
.p-archive .main__category {
  display: flex;
  flex-direction: column;
  gap: 44px;
}
.p-archive .wp-pagenavi {
  padding: 86px 0 0;
}
.p-archive .b-contact {
  padding-top: 76px;
}

.p-about-us .mv {
  position: relative;
  height: 555px;
  background: url("../img/pc/about_mv_bg.jpg") no-repeat top center;
}
.p-about-us .mv__bg {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 10;
  width: 294px;
  height: 174px;
  clip-path: polygon(0 0, 100% 0, calc(100% - 40px) 100%, 0 100%);
  background: #fff;
}
.p-about-us .mv__fg {
  position: absolute;
  inset: 0;
  z-index: 20;
  padding: 292px 0 0;
}
.p-about-us .mv__inner {
  max-width: 1820px;
  padding: 0 40px;
  margin: 0 auto;
}
.p-about-us .mv__title {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
}
.p-about-us .mv__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-about-us .philosophy {
  padding: 80px 40px 40px;
}
.p-about-us .philosophy__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about-us .philosophy__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-about-us .philosophy__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-about-us .philosophy .engine {
  max-width: 1200px;
  padding: 4px;
  margin: 78px auto 0;
  border: 1px solid #25758e;
}
.p-about-us .philosophy .engine__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1px 40px 44px;
  border: 1px solid rgba(37, 117, 142, 0.5);
}
.p-about-us .philosophy .engine__title {
  width: 100%;
  max-width: 560px;
  margin-top: -30px;
  font-size: 38px;
  font-weight: bold;
  line-height: 50px;
  color: #36474f;
  text-align: center;
  letter-spacing: 0.1em;
  background: #fff;
}
.p-about-us .philosophy .engine__english {
  margin-top: 20px;
}
.p-about-us .philosophy .engine__text {
  margin-top: 28px;
  text-align: center;
}
.p-about-us .philosophy .customer {
  padding: 94px 0 0;
}
.p-about-us .philosophy .customer__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about-us .philosophy .customer__title span {
  font-size: 33px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-about-us .philosophy .customer__title img {
  margin-top: 24px;
}
.p-about-us .philosophy .customer__list {
  position: relative;
  z-index: 100;
  display: grid;
  grid-template-columns: repeat(auto-fit, 380px);
  gap: 30px;
  justify-content: center;
  margin-top: 52px;
}
.p-about-us .philosophy .customer__list .item {
  padding: 4px;
  background: #fff;
  border: 1px solid #25758e;
}
.p-about-us .philosophy .customer__list .item__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1px 30px 36px;
  border: 1px solid rgba(37, 117, 142, 0.5);
}
.p-about-us .philosophy .customer__list .item__counter {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 84px;
  height: 30px;
  margin-top: -22px;
  background: #fff;
}
.p-about-us .philosophy .customer__list .item__english {
  margin-top: 16px;
}
.p-about-us .philosophy .customer__list .item__title {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 40px;
  font-size: 24px;
  font-weight: bold;
  line-height: 1;
  color: #36474f;
  letter-spacing: 0.1em;
}
.p-about-us .philosophy .customer__list .item__title::after {
  width: 42px;
  height: 2px;
  margin-top: 32px;
  content: "";
  background: #36474f;
}
.p-about-us .philosophy .customer__list .item__text {
  margin-top: 14px;
}
.p-about-us .greeting {
  display: flex;
  flex-direction: column;
  align-items: center;
  max-width: 1920px;
  height: 1158px;
  padding: 204px 40px 0;
  margin: -98px auto 0;
  background: url("../img/pc/about_greeting_bg.jpg") no-repeat top center;
}
.p-about-us .greeting__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about-us .greeting__title span {
  margin-top: 24px;
  font-size: 16px;
  font-weight: bold;
  line-height: 1;
  color: #fff;
}
.p-about-us .greeting__title::after {
  display: block;
  width: 52px;
  height: 3px;
  margin-top: 20px;
  content: "";
  background: #c6dee5;
}
.p-about-us .greeting__headline {
  margin-top: 16px;
  font-size: 38px;
  font-weight: bold;
  line-height: 58px;
  color: #fff;
  text-align: center;
  letter-spacing: 0.1em;
}
.p-about-us .greeting__english {
  margin-top: 16px;
}
.p-about-us .greeting__text {
  margin-top: 28px;
  color: #fff;
  text-align: center;
}
.p-about-us .greeting__signature {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-top: 42px;
}
.p-about-us .greeting__signature span {
  font-size: 16px;
  line-height: 1;
  color: #fff;
}
.p-about-us .greeting__signature img {
  margin-top: 10px;
}
.p-about-us .company {
  padding: 122px 40px 70px;
}
.p-about-us .company__title {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.p-about-us .company__title::before {
  display: block;
  width: 55px;
  height: 40px;
  margin-bottom: 16px;
  content: "";
  background: url("../img/pc/icon_section_title_logo.svg") no-repeat;
}
.p-about-us .company__title span {
  margin-top: 24px;
  font-size: 18px;
  font-weight: bold;
  line-height: 1;
  color: #3e3a39;
  letter-spacing: 0.1em;
}
.p-about-us .company__list {
  margin-top: 28px;
}
.p-about-us .google-map-section__gmap {
  height: 402px;
}
