@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&family=Noto+Serif+JP:wght@200..900&family=Roboto:ital,wght@0,100..900;1,100..900&display=swap");
:root {
  --fs-per: .0625;
  --fs-vw: 0.05208;
}

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

/* --------------------------------- */
/* スマホ（従来の可変フォント設定） */
/* --------------------------------- */
html {
  font-size: min(var(--fs-vw) * 1vw, var(--fs-per) * 1rem);
  color: #1a1a1a;
  font-family: "Noto Sans JP", sans-serif;
  font-optical-sizing: auto;
  font-weight: normal;
  font-style: normal;
  line-height: 2.1;
}

/* --------------------------------- */
/* PCサイズ以上 = フォント固定化    */
/* --------------------------------- */
@media (min-width: 1200px) {
  html {
    font-size: 1px;
  }
}
body {
  width: 100%;
  margin: 0 auto;
  overflow-x: hidden;
  background-repeat: repeat;
  background-position: left top;
}
body.open {
  overflow: hidden;
}

.main {
  position: relative;
  padding-top: 72rem;
}

.container {
  width: 1580rem;
  margin: 0 auto;
  max-width: calc(100% - 100rem);
}
a {
  text-decoration: none;
  color: inherit;
  cursor: pointer;
  transition: 0.4s;
}
a:hover {
  opacity: 0.7;
}
@media screen and (max-width: 1199.9px) {
  a:hover {
    opacity: 1;
  }
}

ul,
ol {
  list-style: none;
}

img {
  width: 100%;
  object-fit: contain;
  vertical-align: bottom;
}

.forSP {
  display: none;
}

/* backToTop */
.toTop {
  position: sticky;
  bottom: 16rem;
  margin: -66rem 0 16rem auto;
  right: 16rem;
  width: 50rem;
  z-index: 8;
}

.toTop__btn {
  cursor: pointer;
  width: 50rem;
  height: 50rem;
  background-image: url(../img/toTop.png);
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: all 0.4s;
}
.toTop__btn:hover {
  opacity: 0.7;
}

@media only screen and (max-width: 1199.9px) {
  :root {
    --fs-vw: .1333;
  }
  html {
    font-size: calc(var(--fs-vw) * 1vw);
  }
  body {
    background-size: 91rem;
  }
  .main {
    padding-top: 48rem;
  }
  .container {
    width: 750rem;
    max-width: 100%;
  }
  .forSP {
    display: block;
  }
  .forPC {
    display: none;
  }
  .toTop {
    bottom: 8rem;
    margin-bottom: 8rem;
    margin: -50rem 0 8rem auto;
    right: 8rem;
    width: 42rem;
  }
  .toTop__btn {
    width: 42rem;
    height: 42rem;
  }
}
@media (min-width: 768px) and (max-width: 1199.9px) {
  html {
    font-size: calc(var(--fs-vw) * 1vw * 0.6);
  }
}
body {
  font-size: 18rem;
  line-height: 1.5;
}

h1 {
  font-size: inherit;
  font-weight: inherit;
}

.heading--primary {
  font-size: 56rem;
}
.heading--secondary {
  font-size: 48rem;
}

@media screen and (max-width: 1199.9px) {
  body {
    font-size: 16rem;
  }
  .heading--primary {
    font-size: 32rem;
  }
  .heading--secondary {
    font-size: 28rem;
  }
}
.c-accordion__item {
  background-color: #fff;
}
.c-accordion__item:last-of-type .c-accordion__click,
.c-accordion__item:last-of-type .c-accordion__contents {
  border: 0;
}
.c-accordion__click {
  position: relative;
  display: flex;
  align-items: center;
  padding: 40rem 0;
  font-size: 18rem;
  letter-spacing: 0;
  line-height: 1.6666666667;
  border-bottom: 2rem solid #f4f4f4;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__click {
    padding: 60rem 0;
    font-size: 30rem;
    line-height: 2;
    padding-right: 81rem;
    align-items: baseline;
  }
}
.c-accordion__click::before {
  content: "Q";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44.19rem;
  height: 45rem;
  margin-right: 24rem;
  flex: none;
  font-size: 20rem;
  background-color: #fff;
  border: 1px solid #646464;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 1;
  color: #333;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__click::before {
    width: 65rem;
    height: 65rem;
    margin-right: 22rem;
    font-size: 30rem;
  }
}
.c-accordion__click.active {
  border-bottom: 0;
  /*
  padding-bottom: 22rem;
           @media only screen and (max-width: 1199.9px) {
  	padding-bottom: 15rem;
  }
           */
}
.c-accordion__click.active .c-accordion__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 16rem;
  height: 2rem;
  background-color: #136AB6;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__click.active .c-accordion__btn::after {
    width: 35rem;
    height: 2.7rem;
  }
}
.c-accordion__btn {
  position: absolute;
  right: 0rem;
  display: block;
  width: 30rem;
  height: 30rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__btn {
    right: 13rem;
    width: 35rem;
    height: 35rem;
  }
}
.c-accordion__btn::before {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  display: block;
  width: 30rem;
  height: 2rem;
  background-color: #333;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__btn::before {
    width: 35rem;
    height: 2.7rem;
  }
}
.c-accordion__btn::after {
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%) rotate(-90deg);
  display: block;
  width: 30rem;
  height: 2rem;
  background-color: #333;
  transition: 0.3s;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__btn::after {
    width: 35rem;
    height: 2.7rem;
  }
}
.c-accordion__contents {
  position: relative;
  display: none;
  border-top: 0;
  padding: 0 0 40rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  border-bottom: 2rem solid #f4f4f4;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__contents {
    padding: 0 0 60rem;
    padding-right: 81rem;
    font-size: 28rem;
    line-height: 2;
  }
}
.c-accordion__contents p {
  display: flex;
  align-items: baseline;
}
.c-accordion__contents p::before {
  content: "A";
  display: flex;
  align-items: center;
  justify-content: center;
  width: 44.19rem;
  height: 45rem;
  margin-right: 24rem;
  flex: none;
  font-size: 20rem;
  background-color: #313371;
  border: 1px solid #646464;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 1;
  color: #fff;
}
@media only screen and (max-width: 1199.9px) {
  .c-accordion__contents p::before {
    width: 65rem;
    height: 65rem;
    margin-right: 22rem;
    font-size: 30rem;
  }
}

.wpcf7-form {
  margin: 69rem auto 76rem;
  width: 100%;
  max-width: 1200rem;
}
@media only screen and (max-width: 1199.9px) {
  .wpcf7-form {
    margin-top: 40rem;
    margin-bottom: 80rem;
    width: 100%;
    max-width: 100%;
  }
}
.wpcf7-form .hidden-fields-container {
  display: none;
}
.wpcf7-form .c-btn {
  width: 500rem;
  margin: 54rem auto;
}
@media only screen and (max-width: 1199.9px) {
  .wpcf7-form .c-btn {
    width: 598rem;
    margin-top: 70rem;
    margin-bottom: 90rem;
  }
}

.c-form__table {
  width: 100%;
  margin-bottom: 80rem;
  border-spacing: unset;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table {
    margin: 0;
    margin-bottom: 90rem;
    width: 100%;
  }
}
.c-form__table dl {
  display: flex;
  align-items: flex-start;
  gap: 40rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dl {
    flex-direction: column;
    gap: 0;
  }
}
.c-form__table dl:not(:first-of-type) {
  margin-top: 36rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dl:not(:first-of-type) {
    margin-top: 60rem;
  }
}
.c-form__table dt {
  width: 250rem;
  margin-top: 11rem;
  background-color: #fff;
  font-size: 18rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.1em;
  display: flex;
  justify-content: space-between;
  flex: none;
  font-weight: 400;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dt {
    width: 100%;
    font-size: 32rem;
    margin-top: 0;
  }
}
.c-form__table dt > p {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dt > p {
    font-size: 28rem;
    justify-content: flex-start;
  }
}
.c-form__table dt .dre-origin-form-required-badge {
  width: 45rem;
  height: 28rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #a4a4a4;
  color: #333;
  font-size: 14rem;
  font-weight: 400;
  top: 0 !important;
  line-height: 1.5;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dt .dre-origin-form-required-badge {
    font-size: 22rem;
    width: 69.11rem;
    height: 43rem;
    top: 0;
    margin-left: 8rem;
    font-weight: bold;
  }
}
.c-form__table dt .dre-origin-form-required-badge.required {
  background-color: #D04E45;
  color: #fff;
  border: 0;
}
.c-form__table dt small {
  display: block;
  margin-top: 3rem;
  font-size: 15rem;
  letter-spacing: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dt small {
    display: inline;
    font-size: 12rem;
    margin-top: 0;
  }
}
.c-form__table dd {
  width: 740rem;
  text-align: left;
  font-size: 16rem;
  font-weight: 400;
  line-height: 1.5;
  color: #a4a4a4;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd {
    padding: 0;
    width: 100%;
    margin-top: 30rem;
    font-size: 28rem;
  }
  .c-form__table dd > p {
    font-size: 28rem;
  }
}
.c-form__table dd .wpcf7-list-item {
  display: block;
  margin-left: 0;
  font-weight: 400;
}
.c-form__table dd .wpcf7-list-item + .wpcf7-list-item {
  margin-top: 9rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd .wpcf7-list-item + .wpcf7-list-item {
    margin-top: 0;
  }
}
.c-form__table dd input {
  width: 100%;
  min-height: 50rem;
  padding: 14rem 24rem;
  font-size: 16rem;
  letter-spacing: 0.1em;
  border: 1px solid #AAAAAA;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd input {
    width: 100%;
    height: 100rem;
    min-height: unset;
    padding: 28rem 40rem;
    font-size: 30rem;
  }
}
.c-form__table dd input.size-m {
  width: 210rem;
  margin-bottom: 16rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd input.size-m {
    width: 281rem;
  }
}
.c-form__table dd input + input {
  display: block;
  margin-top: 8px;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd input + input {
    margin-top: 26rem;
  }
}
.c-form__table dd input[type=checkbox] {
  width: 24rem;
  height: 24rem;
  border: 1px solid #AAAAAA;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd input[type=checkbox] {
    width: 20rem;
    height: 20rem;
    margin-right: 8rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd .wpcf7-radio {
    display: flex;
    gap: 40rem;
  }
}
.c-form__table dd .wpcf7-radio label {
  display: flex;
  align-items: center;
  color: #1A1A1A;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd .wpcf7-radio label {
    font-size: 16rem;
  }
}
.c-form__table dd input[type=radio] {
  width: 20rem;
  height: 20rem;
  margin-right: 12rem;
  min-height: unset;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd input[type=radio] {
    width: 20rem;
    height: 20rem;
    margin-right: 8rem;
  }
}
.c-form__table dd textarea {
  border: 1px solid #AAAAAA;
  padding: 11rem 24rem;
  font-size: 16rem;
  width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd textarea {
    font-size: 30rem;
    line-height: 1.5;
    padding: 28rem 40rem;
  }
}
.c-form__table dd.select-wrap .arrow {
  width: fit-content;
  position: relative;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.select-wrap .arrow {
    width: 100%;
  }
}
.c-form__table dd.select-wrap .arrow::after {
  content: "";
  position: absolute;
  top: 17.5rem;
  right: 16rem;
  transform: translateY(0%);
  border-right: 8.5rem solid transparent;
  border-left: 8.5rem solid transparent;
  border-top: 15rem solid #ccc;
  border-bottom: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.select-wrap .arrow::after {
    border-right-width: 6.5rem;
    border-left-width: 6.5rem;
    border-top-width: 11rem;
    top: 12rem;
  }
}
.c-form__table dd.select-wrap p {
  position: relative;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.select-wrap p {
    width: 100%;
  }
}
.c-form__table dd select {
  width: 253rem;
  max-width: 100%;
  height: 50rem;
  background-color: #fff;
  border: 1px solid #AAAAAA;
  font-size: 16rem;
  padding: 14rem 16rem 15rem 24rem;
  -webkit-appearance: none;
  appearance: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd select {
    display: block;
    width: 100%;
    height: 100rem;
    padding: 29rem 40rem;
    font-size: 30rem;
  }
}
.c-form__table dd select::-ms-expand {
  display: none;
}
@media only screen and (min-width: 1200px) {
  .c-form__table dd.birth {
    margin-right: 0;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.birth {
    font-size: 14rem;
    font-weight: 400;
    padding-right: 21rem;
  }
}
.c-form__table dd.birth > p {
  display: flex;
}
.c-form__table dd.birth input {
  margin-bottom: 0;
  margin-right: 8rem;
  width: 186rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.birth input {
    width: 52rem;
    margin-right: 4rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.birth input.year {
    width: 96rem;
  }
}
.c-form__table dd.birth span + span {
  margin-left: 24rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table dd.birth span + span {
    margin-left: 16rem;
  }
}
.c-form__table dd .birth-box {
  display: flex;
  align-items: baseline;
}

.c-form__table--entry dt {
  padding-left: 29rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__table--entry dt {
    padding-left: 12rem;
  }
}

.c-form__input-flex {
  display: flex;
  gap: 22rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-flex {
    gap: 33rem;
  }
}
.c-form__input-flex.date {
  gap: 40rem;
  flex-wrap: wrap;
  row-gap: 12rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-flex.date {
    flex-direction: column;
    gap: 39rem;
  }
}
.c-form__input-flexitem > p {
  display: flex;
  gap: 20rem;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-flexitem > p {
    font-size: 28rem;
  }
}
.c-form__input-flexitem > p .c-form__input-note {
  flex: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-flexitem > p .c-form__input-note {
    margin-top: 0;
    font-size: 28rem;
  }
}
.c-form__input-flexitem > p input {
  flex: 1;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-flexitem .wpcf7-form-control-wrap {
    flex: 1;
  }
}
.c-form__input-note {
  color: #333;
  font-size: 14rem;
  line-height: 1.5;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__input-note {
    font-size: 24rem;
    margin-top: 22rem;
  }
}

.c-form_column {
  display: flex;
  gap: 14rem;
  flex-direction: column;
}

.privacy {
  margin: 0 auto 30rem;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .privacy {
    margin-bottom: 40rem;
    padding: 0 28rem;
  }
}
.privacy p {
  font-size: 18rem;
  font-weight: 400;
  letter-spacing: 0;
  line-height: 2;
}
@media only screen and (max-width: 1199.9px) {
  .privacy p {
    font-size: 26rem;
    line-height: 1.8;
  }
}
.privacy p a {
  text-decoration: underline;
}
.privacy .disabled-wrap {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 403rem;
  margin: 60rem auto 0;
  background: #F4F4F4;
  height: 100rem;
}
@media only screen and (max-width: 1199.9px) {
  .privacy .disabled-wrap {
    margin-top: 70rem;
    width: 100%;
  }
}
.privacy .disabled-wrap input {
  width: 20rem;
  height: 20rem;
  margin-right: 14rem;
  border-radius: 0;
  border: 1px solid #c7c7c7;
  box-shadow: 2px 2px 4px 0px rgba(0, 0, 0, 0.08);
}
@media only screen and (max-width: 1199.9px) {
  .privacy .disabled-wrap input {
    width: 32rem;
    height: 32rem;
    margin-right: 23rem;
  }
}
.privacy .disabled-btn {
  font-size: 17rem;
  font-weight: 400;
  line-height: 1.5;
}

.thanks_area {
  text-align: center;
  margin-bottom: 80px;
}
@media only screen and (max-width: 1199.9px) {
  .thanks_area {
    margin-bottom: 120px;
  }
}
.thanks_area p {
  font-size: 24px;
}
.thanks_area p:first-of-type {
  margin-bottom: 1em;
  font-size: 40px;
  font-weight: 700;
}
@media only screen and (max-width: 1199.9px) {
  .thanks_area p:first-of-type {
    font-size: 32px;
  }
}
@media only screen and (max-width: 1199.9px) {
  .thanks_area p {
    font-size: 28px;
  }
}

input[type=submit] {
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
}

span.wpcf7-spinner {
  display: none;
}

input[type=submit] {
  text-align: center;
}

input[type=submit] {
  position: relative;
  max-width: 100%;
}

::placeholder {
  color: #ACACAC;
}

/* 旧Edge対応 */
::-ms-input-placeholder {
  color: #ACACAC;
}

/* IE対応 */
:-ms-input-placeholder {
  color: #ACACAC;
}

.c-form__checkbox label {
  display: flex;
  align-items: center;
  gap: 8rem;
}
.c-form__checkbox .wpcf7-list-item {
  margin: 0 24rem 0 0;
}

.wpcf7-acceptance .wpcf7-list-item label {
  display: flex;
  align-items: center;
  gap: 8rem;
}

.c-form__submit {
  position: relative;
  width: fit-content;
  margin: 80rem auto 0;
  font-size: 22rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__submit {
    width: 337rem;
    height: rem;
    font-size: 18rem;
  }
}
.c-form__submit::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 18rem;
  transform: translate(0, -50%);
  display: block;
  width: 53rem;
  height: 7.5rem;
  background: url(../images/common/btn_arrow.svg) no-repeat;
  background-size: contain;
}

.wpcf7 form.sent .wpcf7-response-output {
  display: none;
}

.c-form__btnwrap {
  position: relative;
  margin: auto;
  width: 500rem;
  max-width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__btnwrap {
    width: 598rem;
  }
}
.c-form__btnwrap::after {
  content: "";
  position: absolute;
  right: 15rem;
  top: 50%;
  transform: translate(0, -50%) rotate(45deg);
  display: block;
  width: 8rem;
  height: 8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
@media only screen and (max-width: 1199.9px) {
  .c-form__btnwrap::after {
    border-width: 2rem;
    width: 15.94rem;
    height: 15.94rem;
    right: 27.28rem;
  }
}

#autozip,
#movable_zipaddr,
#zip_close {
  display: none;
}

.c-form__table dd input.size-m + .wpcf7-not-valid-tip {
  transform: translateY(-1em);
}

.c-table__row {
  position: relative;
  display: flex;
  padding: 32rem 0;
  align-items: flex-start;
  border-bottom: 2rem solid #f4f4f4;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__row {
    padding: 45rem 0;
    flex-direction: column;
    gap: 30rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-table__row--pconly {
    display: none;
  }
}
.c-table__row--sponly {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__row--sponly {
    display: flex;
  }
}
.c-table__heading, .c-table__detail {
  font-size: 18rem;
  line-height: 2;
  font-weight: 400;
  letter-spacing: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__heading, .c-table__detail {
    font-size: 32rem;
    line-height: 1.8;
  }
}
.c-table__heading {
  width: 22.8%;
  padding-left: 18rem;
  flex: none;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 700;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__heading {
    width: 100%;
    padding: 0 20rem;
    font-size: 32rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-table__heading--pconly {
    display: none;
  }
}
.c-table__heading--sponly {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__heading--sponly {
    display: inline;
  }
}
.c-table__detail {
  width: 77.2%;
  flex: 1;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .c-table__detail {
    width: 100%;
    padding: 0 40rem;
    font-size: 32rem;
  }
}

.c-title-english {
  font-family: "Noto Serif JP", serif;
}
.c-title-english--center {
  text-align: center;
}
.c-title-english__ja {
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .c-title-english__ja {
    font-size: 56rem;
    line-height: 1.4;
  }
}
.c-title-english__en {
  margin-top: 14rem;
  color: #313371;
  font-size: 20rem;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .c-title-english__en {
    font-size: 32rem;
    margin-top: 20rem;
  }
}

.c-single-title {
  font-size: 36rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.8;
  text-align: center;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1199.9px) {
  .c-single-title {
    font-size: 46rem;
    line-height: 1.55;
  }
}

.c-morebtn {
  width: fit-content;
  position: relative;
  color: #136AB6;
  display: flex;
  align-items: center;
  height: 44rem;
  font-size: 18rem;
}
.c-morebtn::after {
  content: "";
  display: block;
  width: 98rem;
  height: 44rem;
  margin-left: 12rem;
  background: url(../images/index/more_arrow.png) no-repeat;
  background-size: contain;
}

.c-btn {
  height: 63rem;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #313371;
  color: #fff;
  font-size: 18rem;
  box-shadow: 0px 0px 20rem 0px rgba(31, 32, 45, 0.08);
}
@media only screen and (max-width: 1199.9px) {
  .c-btn {
    height: 125rem;
    font-size: 32rem;
    box-shadow: 0px 0px 40rem 0px rgba(31, 32, 45, 0.08);
  }
}
.c-btn::after {
  content: "";
  position: absolute;
  right: 15rem;
  top: 50%;
  transform: translate(0, -50%) rotate(45deg);
  display: block;
  width: 8rem;
  height: 8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
@media only screen and (max-width: 1199.9px) {
  .c-btn::after {
    border-width: 2rem;
    width: 15.94rem;
    height: 15.94rem;
    right: 27.28rem;
  }
}
.c-btn--white {
  border: 1px solid #333;
  background-color: #fff;
  color: #333;
}
.c-btn--white::after {
  border-color: #333;
}

.c-pagenavi {
  width: fit-content;
  margin: 100rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagenavi {
    margin-top: 120rem;
  }
}

.c-pagenavi .wp-pagenavi {
  display: flex;
  gap: 3rem;
  justify-content: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagenavi .wp-pagenavi {
    gap: 5rem;
  }
}

.c-pagenavi .wp-pagenavi a, .c-pagenavi .wp-pagenavi span {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40rem;
  height: 40rem;
  border: 1px solid #A4A4A4;
  margin: 0;
  color: #333;
  font-family: "Roboto", sans-serif;
  font-size: 16rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagenavi .wp-pagenavi a, .c-pagenavi .wp-pagenavi span {
    width: 60rem;
    height: 60rem;
    font-size: 24rem;
    border-width: 1.5rem;
  }
}

.c-pagenavi .wp-pagenavi span.current {
  background-color: #313371;
  color: #fff;
  font-weight: 400;
}

.c-pagination {
  display: flex;
  position: relative;
  list-style: none;
  width: 100%;
  min-height: 305rem;
  margin: 0 auto;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination {
    display: flex;
    column-gap: 8rem;
    row-gap: 14rem;
    flex-wrap: wrap;
    justify-content: space-between;
    width: auto;
    height: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination:not(:has(.c-pagination__prev))::after {
    content: "";
    width: 270rem;
    display: block;
    order: 1;
  }
}
.c-pagination li {
  position: absolute;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination li {
    position: relative;
  }
}
.c-pagination li:hover {
  position: absolute;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination li:hover {
    position: relative;
  }
}
.c-pagination__thumb {
  position: relative;
  aspect-ratio: 3/2;
  overflow: hidden;
  margin: 18rem 0 24rem;
}
.c-pagination__thumb img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  object-fit: cover;
  width: 100%;
  height: 100%;
}
.c-pagination__back {
  font-size: 16rem;
  color: #136AB6;
  text-align: center;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 274rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination__back {
    left: auto;
    transform: unset;
  }
}
.c-pagination__back img {
  width: 32rem;
  height: 32rem;
  margin-bottom: 10rem;
}
.c-pagination__back .c-btn {
  max-width: 100%;
}
.c-pagination__back::marker {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination__back {
    order: 3;
    width: 100%;
    max-width: 598rem;
    margin: 80rem auto 0;
  }
}
.c-pagination__prev, .c-pagination__next {
  width: 270rem;
  top: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination__prev, .c-pagination__next {
    font-size: 28rem;
    line-height: 1.5;
  }
}
.c-pagination__prev {
  left: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination__prev {
    left: auto;
    order: 1;
  }
}
.c-pagination__next {
  right: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-pagination__next {
    right: auto;
    order: 2;
  }
}
.c-pagination__next .c-pagination__text {
  text-align: right;
}

.c-area {
  background-color: #F4F4F4;
}
.c-area .container {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-area .container {
    flex-direction: column-reverse;
    gap: 80rem;
    width: 100%;
    margin: 0;
    align-items: unset;
  }
}
.c-area__imgwrap {
  width: 50%;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__imgwrap {
    width: 100%;
    margin-bottom: 80rem;
  }
}
.c-area__textwrap {
  width: 50%;
  padding: 100rem 39rem 100rem 67rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__textwrap {
    width: calc(100% - 60rem);
    padding: 0;
    margin: 100rem auto 0;
  }
}
.c-area__box {
  background-color: #fff;
  padding: 60rem 40rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__box {
    padding: 80rem 20rem;
  }
}
.c-area__list {
  display: flex;
  flex-direction: column;
  gap: 34rem;
  margin-top: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__list {
    margin-top: 69rem;
    gap: 48rem;
  }
}
.c-area__item-heading {
  color: #313371;
  font-size: 24rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__item-heading {
    font-size: 36rem;
  }
}
.c-area__item-heading::before {
  content: "";
  margin-right: 7rem;
  width: 21rem;
  height: 21rem;
  background-color: #313371;
  border-radius: 50%;
  flex: none;
  margin-top: 1rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__item-heading::before {
    width: 36rem;
    height: 36rem;
    margin-top: 14rem;
    margin-right: 14rem;
  }
}
.c-area__item-text {
  padding-left: 28rem;
  margin-top: 2rem;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .c-area__item-text {
    font-size: 32rem;
    padding-left: 51.3rem;
    margin-top: 10rem;
  }
}

.c-cta {
  padding: 0 50rem;
  background-color: #F4F4F4;
  background: url(../images/common/bg-cta.jpg);
  background-size: cover;
}
@media only screen and (max-width: 1199.9px) {
  .c-cta {
    padding: 0;
    padding-top: 80rem;
    background-image: url(../images/common/bg-cta_sp.jpg);
  }
}
.c-cta__inner {
  display: flex;
  justify-content: space-between;
  max-width: 1750rem;
  margin: auto;
  width: 100%;
  /*
  @media only screen and (max-width: 1199.9px) {
  	flex-wrap: wrap;
  }
  	*/
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__inner {
    width: 100%;
    max-width: unset;
    flex-direction: column;
  }
}
.c-cta__textwrap {
  position: relative;
  margin-left: 3rem;
  padding: 0 30rem;
  display: flex;
  flex-direction: column;
  justify-content: center;
  /*
  @media only screen and (max-width: 1199.9px) {
  	width: 100%;
  	margin-top: 32rem;
  	padding: 32rem;
  }
  	*/
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__textwrap {
    padding: 0 12rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__textwrap {
    width: auto;
    padding: 80rem 75rem 97rem;
    margin-top: 0;
    margin-left: 0;
  }
}
.c-cta__textwrap::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #8D8D8D;
  mix-blend-mode: multiply;
}
.c-cta__tel {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  font-size: 41.88rem;
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  color: #fff;
  line-height: 1.1666666667;
  margin: 36rem 0 30rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__tel {
    font-size: 37rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__tel {
    font-size: 80rem;
    line-height: 1;
    margin-top: 29rem;
    margin-bottom: 32rem;
  }
}
.c-cta__tel::before {
  content: "";
  background: url(../images/common/icon-phone--white.svg);
  width: 40rem;
  height: 40rem;
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__tel::before {
    width: 82rem;
    height: 82rem;
  }
}
.c-cta__text {
  position: relative;
  color: #fff;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 24rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  line-height: 1.8;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__text {
    font-size: 20rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__text {
    font-size: 38rem;
  }
}
.c-cta__open {
  position: relative;
  width: 341rem;
  height: 49rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  color: #fff;
  font-size: 18rem;
  letter-spacing: 0;
  font-weight: 500;
  /*
  @media only screen and (max-width: 1199.9px) {
  	margin: auto;
  }
  */
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__open {
    width: 280rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__open {
    font-size: 28rem;
    width: 504rem;
    max-width: 100%;
    height: 70rem;
    margin: auto;
  }
}
.c-cta__list {
  display: flex;
  gap: 67rem;
  padding: 96rem 0;
  max-width: 100%;
  /*
  @media only screen and (max-width: 1199.9px) {
  	padding: 32rem 0 40rem;
  	gap: 32rem;
  }		
  	*/
}
@media only screen and (max-width: 1699.9px) and (min-width: 1200px) {
  .c-cta__list {
    gap: 32rem;
    max-width: 70%;
  }
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__list {
    gap: 20rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__list {
    flex-direction: column;
    row-gap: 30rem;
    padding: 96rem 0;
    padding-bottom: 83rem;
  }
}
.c-cta__listitem {
  text-align: center;
  width: 339rem;
  max-width: calc((100% - 67px) / 3);
  min-height: 339rem;
  background-color: rgba(255, 255, 255, 0.95);
  display: flex;
  flex-direction: column;
  font-size: 28rem;
  line-height: 1.8;
  font-weight: 700;
  letter-spacing: 0.05em;
  padding: 62rem 36rem 38rem;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__listitem {
    max-width: calc((100% - 20px) / 3);
    padding: 62rem 20rem 38rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__listitem {
    width: 690rem;
    max-width: calc(100% - 60rem);
    min-height: 210rem;
    margin: auto;
    padding: 46rem 21rem 40rem 53rem;
    flex-direction: row;
    column-gap: 62rem;
    justify-content: flex-end;
    align-items: center;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__listitem > div {
    width: 201rem;
  }
}
.c-cta__listitem > div img {
  display: block;
  width: 60rem;
  height: 60rem;
  margin: 0 auto 10rem;
}
.c-cta__listitem > a {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  height: 96rem;
  margin-top: 30rem;
  color: #fff;
  font-size: 18rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 500;
  background-color: #8D8D8D;
  box-shadow: 0px 4px 4px 0px rgba(51, 51, 51, 0.12);
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-cta__listitem > a {
    font-size: 16rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__listitem > a {
    width: 353rem;
    font-size: 24rem;
    flex: none;
    margin-top: 0;
  }
}
.c-cta__listitem > a.event {
  background-color: #313371;
}
.c-cta__listitem > a.document {
  background-color: #AAA550;
}
.c-cta__listitem > a.contact {
  background-color: #D5A02C;
}
@media only screen and (max-width: 1199.9px) {
  .c-cta__listitem > a::after {
    content: "";
    position: absolute;
    right: 33.51rem;
    top: 50%;
    transform: translate(0, -50%) rotate(45deg);
    display: block;
    width: 12rem;
    height: 12rem;
    border-top: 1px solid #fff;
    border-right: 1px solid #fff;
  }
}

.c-card {
  display: flex;
  flex-direction: column;
  row-gap: 36rem;
}
.c-card__imgwrap {
  position: relative;
  overflow: hidden;
}
.c-card__imgwrap img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.c-news__list {
  width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__list {
    border: 0;
    border-bottom: 4rem solid #313371;
  }
}
.c-news__item {
  display: flex;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item {
    padding: 0 20rem;
    width: 100%;
  }
}
.c-news__item:not(:first-of-type) a {
  border-top: 2rem solid #F3F3F3;
  padding-top: 32rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item:not(:first-of-type) a {
    padding-top: 40rem;
  }
}
.c-news__item a {
  position: relative;
  width: 100%;
  padding: 50rem 0;
  padding-right: 102rem;
  display: flex;
  gap: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a {
    padding: 40rem 0;
    gap: 22rem;
  }
}
.c-news__item a::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 38rem;
  transform: translate(0, -50%);
  background: url(../images/index/news-arrow.svg);
  background-size: contain;
  width: 25rem;
  height: 8rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a::after {
    display: none;
  }
}
.c-news__item a > dl {
  position: relative;
  width: 100%;
}
.c-news__item a > dl dt {
  display: flex;
  gap: 28rem;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a > dl dt {
    gap: 24rem;
  }
}
.c-news__item a > dl dt .cat {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #A9AACA;
  width: 144rem;
  height: 32rem;
  color: #fff;
  font-size: 14rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a > dl dt .cat {
    height: 51rem;
    width: 172rem;
    font-size: 22rem;
  }
}
.c-news__item a > dl dt .date {
  font-size: 16rem;
  letter-spacing: 0.003em;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a > dl dt .date {
    line-height: 1;
    font-size: 28rem;
  }
}
.c-news__item a > dl dd {
  margin-top: 20rem;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a > dl dd {
    margin-top: 17rem;
    font-size: 28rem;
  }
}
.c-news__item a > dl dd.text {
  font-size: 18rem;
  font-weight: 400;
  line-height: 2.2;
  letter-spacing: 0;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item a > dl dd.text {
    display: none;
  }
}
.c-news__item-imgwrap {
  width: 200rem;
  margin-left: 44rem;
  aspect-ratio: 1/1;
  position: relative;
  overflow: hidden;
  flex: none;
}
@media only screen and (max-width: 1199.9px) {
  .c-news__item-imgwrap {
    width: 176rem;
    margin-left: 0;
  }
}
.c-news__item-imgwrap img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.c-works__item-link {
  row-gap: 34rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-link {
    row-gap: 32rem;
  }
}
.c-works__item-imgwrap {
  aspect-ratio: 5/6;
}
.c-works__item-imgwrap img {
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
}
.c-works__item-new {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100rem;
  height: 50rem;
  color: #fff;
  background-color: #D5A02C;
  font-size: 20rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-new {
    width: 144rem;
    height: 77rem;
    font-size: 30rem;
  }
}
.c-works__item-detawrap {
  display: flex;
  align-items: center;
  gap: 17rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-detawrap {
    gap: 20rem;
  }
}
.c-works__item-cat {
  width: fit-content;
  min-width: 144rem;
  padding: 0 0.5em;
  height: 32rem;
  border: 1px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  font-size: 14rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-cat {
    font-size: 26rem;
    height: 46rem;
    min-width: 200rem;
    padding: 10rem;
  }
}
.c-works__item-area {
  font-size: 16rem;
  color: #858585;
  letter-spacing: 0.008em;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-area {
    font-size: 28rem;
  }
}
.c-works__item-text {
  margin-top: 20rem;
  font-size: 20rem;
  line-height: 1.8;
  font-weight: 500;
}
@media only screen and (max-width: 1199.9px) {
  .c-works__item-text {
    margin-top: 18rem;
    font-size: 30rem;
  }
}

.c-event {
  display: flex;
  flex-direction: column;
  row-gap: 36rem;
}
.c-event__item-imgwrap {
  aspect-ratio: 4/5;
}
.c-event__item-imgwrap.end {
  position: relative;
}
.c-event__item-imgwrap.end::before {
  content: "※イベントは終了いたしました。";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 18rem;
  background-color: rgba(52, 52, 52, 0.55);
  z-index: 10;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-imgwrap.end::before {
    font-size: 32rem;
  }
}
.c-event__item > a {
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: space-between;
  gap: 34rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item > a {
    gap: 40rem;
  }
}
.c-event__item .c-card__textwrap > p {
  font-size: 20rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.05em;
  height: 96rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item .c-card__textwrap > p {
    font-size: 30rem;
    height: auto;
  }
}
.c-event__item-cat {
  position: absolute;
  bottom: 0;
  right: 0;
  width: fit-content;
  min-width: 144rem;
  height: 32rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #fff;
  padding: 8rem;
  font-size: 14rem;
  font-weight: 400;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-cat {
    font-size: 26rem;
    height: 54rem;
    min-width: 242rem;
    padding: 11rem;
  }
}
.c-event__item-new {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 100rem;
  height: 50rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #D5A02C;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
  font-size: 20rem;
  padding: 8rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-new {
    font-size: 30rem;
    width: 144rem;
    height: 77rem;
    padding: 20rem;
  }
}
.c-event__item-detawrap {
  display: flex;
  flex-direction: column;
  row-gap: 14rem;
  padding: 24rem 5rem;
  border-top: 2rem solid #f3f3f3;
  border-bottom: 2rem solid #f3f3f3;
  height: 130rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-detawrap {
    margin-top: 35rem;
    padding: 32rem 11rem;
    row-gap: 18rem;
    height: 190rem;
  }
}
.c-event__item-detawrap > p {
  font-size: 18rem;
  font-weight: 400;
  line-height: 1.8;
  letter-spacing: 0.05em;
  display: flex;
  align-items: center;
  gap: 17rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .c-event__item-detawrap > p {
    font-size: 16rem;
    gap: 8rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-detawrap > p {
    font-size: 28rem;
    gap: 21rem;
  }
}
.c-event__item-detawrap > p::before {
  content: "";
  width: 24rem;
  height: 24rem;
  flex: none;
  display: block;
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .c-event__item-detawrap > p::before {
    width: 48rem;
    height: 48rem;
  }
}
.c-event__item-date:before {
  background-image: url(../images/common/icon-calendar02.svg);
}
.c-event__item-time:before {
  background-image: url(../images/common/icon-time.svg);
}
.c-event__item-area:before {
  background-image: url(../images/common/icon-area.svg);
}

.c-voice__item-link {
  row-gap: 34rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-link {
    font-size: 28rem;
  }
}
.c-voice__item-imgwrap {
  aspect-ratio: 495.42/326.25;
}
.c-voice__item-imgwrap img {
  top: 0;
  left: 50%;
  transform: translate(-50%, 0);
}
.c-voice__item-new {
  position: absolute;
  top: 0;
  left: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100rem;
  height: 50rem;
  color: #fff;
  font-size: 20rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 400;
}
.c-voice__item-detawrap {
  display: flex;
  align-items: center;
  gap: 17rem;
  margin-top: 28.75rem;
  flex-wrap: wrap;
  row-gap: 4rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-detawrap {
    margin-top: 32rem;
    gap: 30rem;
  }
}
.c-voice__item-detawrap + p {
  margin-top: 16rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-detawrap + p {
    font-size: 30rem;
  }
}
.c-voice__item-cat {
  width: fit-content;
  min-width: 144rem;
  padding: 0 0.5em;
  height: 32rem;
  border: 1px solid #333;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #fff;
  font-size: 14rem;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-cat {
    font-size: 26rem;
    height: 46rem;
    min-width: 200rem;
    padding: 10rem;
  }
}
.c-voice__item-area {
  font-size: 16rem;
  color: #858585;
  letter-spacing: 0.008em;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-area {
    font-size: 28rem;
  }
}
.c-voice__item-text {
  margin-top: 20rem;
  font-size: 20rem;
  line-height: 1.8;
  font-weight: 500;
}
@media only screen and (max-width: 1199.9px) {
  .c-voice__item-text {
    font-size: 28rem;
  }
}

.c-tel {
  margin-top: 40rem;
  margin-bottom: 40rem;
}
.c-tel__number {
  margin-top: 8rem !important;
  font-size: 48rem;
  display: flex;
  align-items: center;
  gap: 2rem;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .c-tel__number {
    font-size: 60rem;
    gap: 0;
  }
}
.c-tel__number::before {
  content: "";
  background: url(../images/common/icon-phone.svg);
  width: 48rem;
  height: 48rem;
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .c-tel__number::before {
    width: 64rem;
    height: 64rem;
  }
}
.c-tel__open {
  margin-top: 8rem !important;
  font-weight: 500;
  font-size: 18rem;
  line-height: 1.8;
}
@media only screen and (max-width: 1199.9px) {
  .c-tel__open {
    font-size: 28rem;
    margin-top: 8rem !important;
  }
}

.l-footer {
  padding: 150rem 0 180rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer {
    padding: 124rem 0 80rem;
    margin-bottom: 110rem;
  }
}
.l-footer__inner {
  display: flex;
  flex-wrap: wrap;
  gap: 200rem;
}
@media only screen and (max-width: 1499.9px) {
  .l-footer__inner {
    gap: 60rem;
    justify-content: space-between;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__inner {
    flex-direction: column;
    justify-content: unset;
    gap: 130rem;
    width: calc(100% - 100rem);
    max-width: unset;
  }
}
.l-footer__info {
  position: relative;
}
.l-footer__logo a {
  color: inherit;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__logo a {
    text-align: center;
  }
}
.l-footer__logo a > p {
  margin-bottom: 12rem;
  font-size: 17rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__logo a > p {
    font-size: 26rem;
  }
}
.l-footer__logo a img {
  width: 324.9996643066rem;
  height: 50.1111602783rem;
  object-fit: contain;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__logo a img {
    width: 416.6727905273rem;
    height: 64.2144470215rem;
    margin: 10rem auto 0;
  }
}
.l-footer__logo a:hover {
  color: inherit;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__info {
    text-align: center;
  }
}
.l-footer__address {
  margin-top: 40rem;
  font-size: 20rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__address {
    margin-top: 46rem;
    font-size: 28rem;
  }
}
.l-footer__tel, .l-footer__fax {
  font-size: 20rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__tel, .l-footer__fax {
    font-size: 28rem;
  }
}
.l-footer__tel {
  margin-top: 10rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__tel {
    margin-top: 16rem;
  }
}
.l-footer__fax {
  margin-top: 10rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__fax {
    margin-top: 12rem;
  }
}
.l-footer__box {
  display: flex;
  flex-direction: column;
  gap: 56rem;
  flex: 1;
  min-width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__box {
    gap: 100rem;
  }
}
.l-footer__nav {
  display: flex;
  gap: 92rem;
}
@media only screen and (max-width: 1399.9px) {
  .l-footer__nav {
    gap: 40rem;
  }
}
@media only screen and (max-width: 991.9px) {
  .l-footer__nav {
    gap: 28rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__nav {
    display: flex;
    flex-wrap: wrap;
    column-gap: 0;
    row-gap: 10rem;
  }
}
.l-footer__navlist {
  display: flex;
  flex-direction: column;
  gap: 18rem;
  position: relative;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navlist {
    display: flex;
    width: 100%;
    order: 1;
    gap: 40rem;
    height: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navlist + .l-footer__navlist {
    margin-top: 40rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navlist--spw50 {
    width: 50%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navlist--spcol2 {
    flex-wrap: wrap;
    flex-direction: row;
    column-gap: 0;
  }
}
.l-footer__subnavlist {
  display: flex;
  flex-direction: column;
  gap: 18rem;
  margin-top: 18rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__subnavlist {
    margin-top: 36rem;
    gap: 30rem;
  }
}
.l-footer__subnavlist li {
  position: relative;
  padding-left: 21rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__subnavlist li {
    padding-left: 33.14rem;
  }
}
.l-footer__subnavlist li::before {
  content: "";
  position: absolute;
  left: 5.41rem;
  top: 50%;
  transform: translate(0, -50%) rotate(45deg);
  display: block;
  width: 10rem;
  height: 10rem;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__subnavlist li::before {
    left: 5rem;
  }
}
.l-footer__navitem {
  font-size: 16rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navitem {
    font-size: 28rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navitem.sp-nowrap {
    white-space: nowrap;
  }
}
.l-footer__navitem--sp {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navitem--sp {
    display: flex;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navitem--pc {
    display: none;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__navitem--spw50 {
    width: 50%;
  }
}
.l-footer__snslist {
  display: flex;
  align-items: center;
  gap: 10rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__snslist {
    order: 1;
  }
}
.l-footer__snslist img {
  width: 75.38rem;
  height: 70rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__snslist img {
    width: 90.4615325928rem;
    height: 84rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__snslist.u-sponly {
    display: flex;
    justify-content: center;
    margin-top: 50rem;
  }
}
.l-footer__copy {
  margin-top: 3rem;
  margin-right: 10rem;
  text-align: right;
  color: #A4A4A4;
  font-size: 14rem;
  font-weight: 400;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__copy {
    text-align: center;
    font-size: 24rem;
    margin: 0;
  }
}
.l-footer__cta {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__cta {
    position: fixed;
    bottom: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
    display: flex;
    z-index: 10;
  }
}
.l-footer__cta-catalog, .l-footer__cta-event, .l-footer__cta-contact {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__cta-catalog, .l-footer__cta-event, .l-footer__cta-contact {
    bottom: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 2rem;
    width: 33.3333333333%;
    height: 110rem;
    color: #fff;
    font-size: 24rem;
    font-weight: 500;
    letter-spacing: 0.05em;
    line-height: 1;
  }
  .l-footer__cta-catalog::before, .l-footer__cta-event::before, .l-footer__cta-contact::before {
    content: "";
    display: block;
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 50rem;
    height: 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__cta-event {
    background-color: #313371;
  }
  .l-footer__cta-event::before {
    background-image: url(../images/common/icon-calendar.svg);
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__cta-catalog {
    background-color: #AAA550;
  }
  .l-footer__cta-catalog::before {
    background-image: url(../images/common/icon-document.svg);
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-footer__cta-contact {
    background-color: #CFA039;
  }
  .l-footer__cta-contact::before {
    background-image: url(../images/common/icon-mail.svg);
  }
}
.l-footer__cta.is-hidden {
  display: none !important;
}

.l-header {
  background-color: #fff;
  position: fixed;
  z-index: 1000;
  width: 100%;
  box-shadow: 0px 0px 20px 0px rgba(51, 51, 51, 0.0784313725);
}
@media only screen and (max-width: 1199.9px) {
  .l-header {
    left: 0;
    right: 0;
    top: 0;
  }
}
.l-header.white {
  background: transparent;
  box-shadow: unset;
}
@media only screen and (max-width: 1199.9px) {
  .l-header.white .l-header__menu-bar {
    background-color: #fff;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header.white .l-header__menu.active .l-header__menu-bar {
    background-color: #333;
  }
}
.l-header.white .l-header__navitem, .l-header.white .l-header__tel-number, .l-header.white .l-header__logo a > p {
  color: #fff;
}
.l-header.white .l-header__nav.active .l-header__navitem {
  color: #333;
}
.l-header.white .l-header__tel-number::before {
  background-image: url(../images/common/icon-phone--white.svg);
}
.l-header.white .l-header__nav .l-header__navitem > a:hover::after {
  background-color: #fff;
}
.l-header__inner {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 1920rem;
  height: 160rem;
  max-width: 100%;
  margin: auto;
  padding: 0 60rem 0 62rem;
  padding-bottom: 32rem;
}
@media only screen and (max-width: 1439.9px) and (min-width: 1200px) {
  .l-header__inner {
    padding: 0 40rem 32rem 42rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__inner {
    height: 111rem;
    justify-content: space-between;
    padding: 0 38rem 0 30rem;
  }
}
.l-header__logo a {
  color: inherit;
  display: flex;
  flex-direction: column;
  justify-content: center;
  transform: translateY(16rem);
}
@media only screen and (max-width: 1199.9px) {
  .l-header__logo a {
    transform: unset;
  }
}
.l-header__logo a > p {
  margin-bottom: 12rem;
  font-size: 17rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
}
@media only screen and (max-width: 1023.9px) {
  .l-header__logo a > p {
    font-size: 16rem;
  }
}
.l-header__logo a img {
  width: 271.8751525879rem;
  height: 41.9200134277rem;
  object-fit: contain;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__logo a img {
    width: 337.9999694824rem;
    height: 52.1157035828rem;
  }
}
.l-header__logo a:hover {
  color: inherit;
}
.l-header__logo p {
  font-size: 22rem;
  font-weight: 400;
  letter-spacing: 0.03em;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__logo p {
    font-size: 28rem;
    line-height: 1.4285714286;
  }
}
.l-header__block {
  display: flex;
  align-items: center;
  gap: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__block {
    flex-direction: column;
    order: 2;
    gap: 23rem;
    width: 100%;
    padding: 0 14rem;
  }
}
.l-header__snslist {
  display: flex;
  align-items: center;
  gap: 10rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__snslist {
    order: 1;
  }
}
.l-header__snslist img {
  width: 50rem;
  height: 46rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__snslist img {
    width: 90.4615325928rem;
    height: 84rem;
  }
}
@media only screen and (min-width: 1200px) {
  .l-header__cta.hidden {
    display: none;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__tel, .l-header__event, .l-header__contact {
    width: 100%;
    height: 110rem;
    color: #fff;
  }
}
.l-header__tel {
  display: flex;
  align-items: center;
  gap: 2rem;
  font-size: 41.88rem;
  font-family: "Roboto", sans-serif;
  font-weight: 600;
  line-height: 1.1666666667;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__tel {
    background-color: #D5A02C;
    font-size: 50rem;
    line-height: 1;
    order: 4;
    padding: 0 21rem 0 23rem;
  }
}
.l-header__tel-number {
  display: flex;
  justify-content: center;
  align-items: center;
}
.l-header__tel-number::before {
  content: "";
  background: url(../images/common/icon-phone.svg);
  width: 40rem;
  height: 40rem;
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__tel-number::before {
    background-image: url(../images/common/icon-phone--white.svg);
    width: 57rem;
    height: 57rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__tel-inner {
    display: block;
    width: 100%;
    text-align: center;
  }
}
.l-header__tel-info {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__tel-info {
    display: flex;
    width: 100%;
    justify-content: space-between;
    font-size: 15.56rem;
    margin-top: 6rem;
  }
  .l-header__tel-info .time {
    font-size: 18rem;
  }
}
.l-header__event, .l-header__document, .l-header__contact {
  position: fixed;
  bottom: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8rem;
  width: 306rem;
  height: 100rem;
  color: #fff;
  font-size: 18rem;
  font-weight: 400;
  box-shadow: 4px 0 8px rgba(51, 51, 51, 0.15);
  /*
  @media only screen and (max-width: 1199.9px) {
    width: 100%;
    height: 110rem;
    font-size: 28rem;
    font-weight: 500;
    gap: 5rem;
    position: inherit;
    bottom: auto;
    right: auto;
  }
    */
}
.l-header__event::before, .l-header__document::before, .l-header__contact::before {
  content: "";
  display: block;
  background-size: contain;
  background-position: center;
  background-repeat: no-repeat;
  width: 35rem;
  height: 35rem;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__event::before, .l-header__document::before, .l-header__contact::before {
    width: 53rem;
    height: 53rem;
  }
}
.l-header__event {
  right: 24rem;
  background-color: #313371;
}
.l-header__event::before {
  background-image: url(../images/common/icon-calendar.svg);
}
.l-header__document {
  right: 349rem;
  background-color: #AAA550;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__document {
    right: auto;
    order: 3;
  }
}
.l-header__document::before {
  background-image: url(../images/common/icon-document.svg);
}
.l-header__contact {
  right: 672rem;
  background-color: #CFA039;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__contact {
    display: none;
  }
}
.l-header__contact::before {
  background-image: url(../images/common/icon-mail.svg);
}
.l-header__nav {
  display: flex;
  flex-direction: column;
  gap: 31rem;
  align-items: flex-end;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__nav {
    position: fixed;
    right: 0;
    left: 0;
    top: 0;
    width: 100%;
    height: 100vh;
    transform: translateX(100%);
    background-color: #fff;
    transition: transform ease 0.4s;
    overflow-y: scroll;
  }
}
.l-header__nav.active {
  transform: translateX(0);
  display: flex;
  padding: 18rem 45rem 57rem;
  z-index: 999;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__nav.active {
    padding: 166rem 50rem;
    gap: 17rem;
  }
}
.l-header__nav.active .l-header__navlist {
  margin-top: 32rem;
}
.l-header__nav.active .l-header__cta {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 23rem;
}
.l-header__nav.active .l-header__subnavlist {
  display: flex;
  flex-direction: column;
  gap: 22rem;
  margin-top: 22rem;
}
.l-header__nav.active .l-header__subnavlist li {
  position: relative;
  padding-left: 35rem;
}
.l-header__nav.active .l-header__subnavlist li::before {
  content: "";
  position: absolute;
  left: 3.3rem;
  top: 50%;
  transform: translate(0, -50%) rotate(45deg);
  display: block;
  width: 10rem;
  height: 10rem;
  border-top: 1px solid #333;
  border-right: 1px solid #333;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__nav.active .l-header__event {
    order: 2;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__nav.active .l-header__event, .l-header__nav.active .l-header__document, .l-header__nav.active .l-header__contact {
    width: 100%;
    height: 110rem;
    font-size: 28rem;
    font-weight: 500;
    gap: 5rem;
    position: inherit;
    bottom: auto;
    right: auto;
  }
}
.l-header__nav .c-cta {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__nav .c-cta {
    display: block;
    width: 100%;
    margin: 86rem auto;
  }
}
.l-header__nav .c-cta__text {
  font-size: 16rem;
}
.l-header__nav .c-cta__text::before, .l-header__nav .c-cta__text::after {
  width: 15rem;
  height: 18rem;
}
.l-header__nav .c-cta__btn {
  width: 100%;
  max-width: 360rem;
  height: 81rem;
  margin: 4rem auto 0;
  font-size: 20.83rem;
  gap: 10rem;
}
.l-header__nav .c-cta__btn::before {
  width: 32.08rem;
  height: 30.57rem;
  transform: translateY(5rem);
}
.l-header__navlist {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 30rem;
  height: 100%;
}
@media only screen and (max-width: 1439.9px) and (min-width: 1200px) {
  .l-header__navlist {
    gap: 22rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navlist {
    display: flex;
    flex-direction: column;
    position: relative;
    align-items: flex-start;
    width: 100%;
    order: 1;
    gap: 22rem;
    height: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navlist::after {
    content: "";
    position: absolute;
    top: 0;
    left: 48rem;
    width: 2rem;
    height: 100%;
  }
}
.l-header__navitem {
  font-size: 20rem;
  font-weight: 500;
  line-height: 1;
  letter-spacing: 0.05em;
  position: relative;
  /*
  @media only screen and (max-width: 1199.9px) {
    display: flex;
    align-items: center;
    justify-content: space-between;
    border-bottom: 1px solid #ccc;
    padding: 20rem 7.5rem 20rem 6rem;
    font-size: 16rem;
    font-weight: normal;
    line-height: calc(23/16);
  }
  &::after{
    display: none;
    @media only screen and (max-width: 1199.9px) {
      content: "";
      display: block;
      width: 8.5rem;
      height: 17rem;
      background-repeat: no-repeat;
      background-size: contain;
      background-position: center;
      background-image: url(../images/arrow-right_blue.svg);
      margin-right: 8rem;
    }
  }
  */
}
@media only screen and (max-width: 1439.9px) and (min-width: 1200px) {
  .l-header__navitem {
    font-size: 16rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navitem {
    font-size: 28rem;
    line-height: 1.46;
  }
}
.l-header__navitem > a:hover::after {
  content: "";
  width: 100%;
  height: 1px;
  position: absolute;
  left: 0;
  bottom: -16rem;
  background-color: #333;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navitem > a:hover::after {
    display: none;
  }
}
.l-header__navitem .c-btn {
  width: 240rem;
  height: 50rem;
}
.l-header__navitem--sp {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navitem--sp {
    display: flex;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__navitem--pc {
    display: none;
  }
}
.l-header__menu {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .l-header__menu {
    width: 46rem;
    height: 38rem;
    padding: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    position: relative;
    cursor: pointer;
    box-sizing: border-box;
    z-index: 1000;
  }
}
@media only screen and (max-width: 1199.9px) {
  .l-header__menu-bar {
    position: absolute;
    left: 50%;
    width: 100%;
    height: 2rem;
    background-color: #333;
    transition: all 0.3s ease;
    transform: translateX(-50%);
  }
}
.l-header__menu-bar:nth-child(1) {
  top: 0;
}
.l-header__menu-bar:nth-of-type(2) {
  top: 50%;
}
.l-header__menu-bar:nth-child(3) {
  top: 100%;
}
.l-header__menu.active .l-header__menu-bar {
  transition: ease 0.4s;
}
.l-header__menu.active .l-header__menu-bar:nth-child(1) {
  top: 50%;
  transform: translateX(-50%) rotate(45deg);
}
.l-header__menu.active .l-header__menu-bar:nth-of-type(2) {
  opacity: 0;
}
.l-header__menu.active .l-header__menu-bar:nth-child(3) {
  top: 50%;
  transform: translateX(-50%) rotate(-45deg);
}
.l-header__menu.active::after {
  display: block;
  content: "CLOSE";
  font-size: 20rem;
  line-height: 1;
  position: absolute;
  bottom: -5rem;
  left: 50%;
  transform: translate(-50%, 100%);
}

.l-main {
  width: 1100rem;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .l-main {
    width: calc(100% - 60rem);
    max-width: unset;
  }
}

@media only screen and (max-width: 1199.9px) {
  .l-col3 {
    padding: 0;
  }
}
.l-col3__container {
  display: flex;
  gap: 36rem;
  flex-wrap: wrap;
}
@media only screen and (max-width: 1199.9px) {
  .l-col3__container {
    flex-direction: column;
  }
}
.l-col3__item {
  width: calc((100% - 72rem) / 3);
}
@media only screen and (max-width: 1199.9px) {
  .l-col3__item {
    width: 100%;
  }
}

.mv {
  position: relative;
}

.heading__container {
  position: absolute;
  top: 0;
  left: calc((100vw - 1440rem) / 2);
  width: 1440rem;
  height: 100%;
  z-index: 1;
}

.heading__wrapper {
  position: absolute;
  top: 72rem;
  left: 48rem;
  width: 1344rem;
}

.text--bg {
  color: #fff;
  background-color: #136AB6;
  display: inline-block;
  padding: 3rem 16rem;
  letter-spacing: 0.04em;
  margin-bottom: 8rem;
}
.text--bg:where(.heading--primary *) {
  padding: 4rem 16rem 10rem;
}
.text--bg:where(.heading__text *) {
  padding: 8rem 16rem 10rem;
  margin-bottom: 0;
}
.text--bg01 {
  padding-right: 0;
}
.text--bg02 {
  padding-left: 0;
}
.text--bg03 {
  padding-top: 2rem;
}

.heading--sub {
  font-size: 24rem;
  font-weight: bold;
}

.heading--primary {
  line-height: 1.18;
}

.heading__text {
  line-height: 1;
}

@media only screen and (max-width: 1439.9px) {
  .heading__container {
    width: 100%;
    left: 0;
  }
  .heading__wrapper {
    width: calc(100vw - 48rem);
  }
}
@media only screen and (max-width: 1199.9px) {
  .heading__wrapper {
    top: 24rem;
    left: 16rem;
    width: 343rem;
  }
  .text--bg {
    padding: 2rem 16rem 3rem 8rem;
    margin-bottom: 3rem;
  }
  .text--bg:where(.heading--primary *) {
    padding: 4rem 7rem 8rem 8rem;
  }
  .text--bg:where(.heading__text *) {
    padding: 6rem 8rem 7rem;
    margin-bottom: 0;
  }
  .text--bg02 {
    padding-top: 2rem;
  }
  .text--bg03 {
    padding-top: 6rem;
    transform: translateY(-4rem);
  }
  .heading--sub {
    font-size: 14rem;
  }
  .heading__text {
    font-size: 12rem;
  }
}
.container--bottom {
  position: absolute;
  right: calc((100vw - 1440rem) / 2);
  bottom: 0;
  width: 1440rem;
  height: 100%;
  z-index: 1;
}

.mv__lists {
  color: #fff;
  position: absolute;
  bottom: 24rem;
  right: 40rem;
  width: 1264rem;
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
}

.mv__list {
  width: 390rem;
  letter-spacing: 0.04em;
  cursor: pointer;
}
.mv__list .mv__link:hover {
  color: #fff;
  opacity: 1;
}
.mv__list .title__wrapper {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.mv__list .num {
  font-weight: 100;
  font-size: 56rem;
  line-height: 1;
  width: 67rem;
}
.mv__list .title {
  width: 308rem;
}
.mv__list .title--01 {
  width: 323rem;
}
.mv__list .mv__text {
  display: none;
  font-size: 14rem;
  margin-top: 16rem;
}

@media only screen and (max-width: 1439.9px) {
  .container--bottom {
    right: 0;
  }
  .mv__lists {
    width: calc(100vw - 176rem);
  }
  .mv__list {
    width: 28vw;
  }
  .mv__list .num {
    width: 4.6vw;
  }
  .mv__list .title {
    width: 22vw;
  }
  .mv__list .title--01 {
    width: 23vw;
  }
}
@media only screen and (max-width: 1199.9px) {
  .container--bottom {
    width: 375rem;
  }
  .mv__lists {
    bottom: 35rem;
    right: 16rem;
    width: 343rem;
  }
  .mv__list {
    width: 107rem;
  }
  .mv__list .title__wrapper {
    flex-direction: column;
    align-items: center;
    position: relative;
  }
  .mv__list .title__wrapper::after {
    content: "";
    position: absolute;
    bottom: -19rem;
    left: 50%;
    border-right: 1px solid #fff;
    border-bottom: 1px solid #fff;
    width: 8rem;
    height: 8rem;
    transform: rotate(45deg) translateX(-50%);
  }
  .mv__list .num {
    width: 100%;
    font-size: 24rem;
    text-align: center;
    margin-bottom: 6rem;
  }
  .mv__list .title {
    text-align: center;
    width: 100%;
    font-size: 9rem;
  }
}
.mv__slider {
  padding-top: 24rem;
}
.mv__slider .slider {
  margin-left: auto;
  width: calc(100vw - (100vw - 1440rem) / 2 - 96rem);
}
.mv__slider .slider::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  width: 100%;
  height: 200rem;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.66), transparent);
}

@media only screen and (max-width: 1439.9px) {
  .mv__slider .slider {
    width: calc(100vw - 96rem);
  }
}
@media only screen and (max-width: 1199.9px) {
  .mv__slider {
    padding-top: 0;
  }
  .mv__slider .slider {
    width: 375rem;
  }
  .mv__slider .slider::after {
    height: 135rem;
  }
}
.p-index__mv {
  position: relative;
  /*
  &::after{
    content: "";
    position: absolute;
    bottom: -70rem;
    left: 50%;
    transform: translateX(-50%);
    z-index: 1;
    width: 1px;
    height: 287rem;
    background-color: #fff;
  }
    */
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mv {
    height: 90dvh;
    max-height: 1460rem;
    padding-top: 0;
    overflow-y: hidden;
  }
}
.p-index__mv .mv_slide {
  position: relative;
}
.p-index__mv-copy {
  position: absolute;
  bottom: 188rem;
  left: 170rem;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-size: 56rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 700;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__mv-copy {
    font-size: 48rem;
    left: 5%;
    bottom: 27%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mv-copy {
    font-size: 67rem;
    bottom: 126rem;
    left: 60rem;
  }
}
.p-index__mv-copy p {
  text-shadow: 0px 0px 20px rgba(0, 0, 0, 0.25);
}
.p-index__mv-copy p span {
  font-size: 64rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__mv-copy p span {
    font-size: 56rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mv-copy p span {
    font-size: 77rem;
  }
}
.p-index__mv-copy img {
  object-fit: contain;
}
.p-index__event {
  padding: 180rem 0 163rem;
  border-top: 30rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event {
    position: relative;
    padding: 150rem 0 360rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .container {
    width: 720rem;
    max-width: 100%;
    margin: 0 0 0 auto;
  }
}
.p-index__event .c-title-english {
  text-align: center;
  margin-bottom: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .c-title-english {
    margin-bottom: 63rem;
  }
}
.p-index__event .c-btn {
  width: 300rem;
  margin: 80rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .c-btn {
    width: 598rem;
    max-width: 79.7%;
    position: absolute;
    bottom: 156rem;
    left: 50%;
    transform: translateX(-50%);
  }
}
.p-index__event .c-event__list {
  gap: 45rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .c-event__list {
    gap: 73rem;
    overflow-x: hidden;
    flex-direction: row;
    flex-wrap: nowrap;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .c-event__list {
    /* スライド幅を固定 */
    /* スライド間余白（70rem） */
    /* slick-list の見える範囲を調整（左隠す・右は見せる） */
    /* slick の勝手な width:auto を抑える */
  }
  .p-index__event .c-event__list .c-event__item {
    width: 597rem !important;
  }
  .p-index__event .c-event__list .c-event__item .c-card__textwrap > p {
    height: 128rem;
  }
  .p-index__event .c-event__list .slick-slide {
    margin-right: 70rem;
  }
  .p-index__event .c-event__list .slick-list {
    padding-left: 0 !important; /* 左側は完全に隠す */
    padding-right: 53rem !important; /* 右だけ見せる */
    overflow: hidden !important; /* visible は使わない */
  }
  .p-index__event .c-event__list .slick-track {
    display: flex !important;
  }
}
.p-index__event .c-event__item {
  width: calc((100% - 90rem) / 3);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__event .c-event__item {
    width: 597rem;
  }
}
.p-index__works {
  position: relative;
  background: url(../images/index/bg-voice.jpg);
  background-color: #f4f4f4;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works {
    padding: 180rem 0;
  }
}
.p-index__works-title {
  position: absolute;
  top: 0;
  transform: translateY(-50%);
  writing-mode: vertical-lr;
  display: flex;
  align-items: center;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-title {
    position: relative;
    width: 100%;
    margin: 0;
    padding: 0 24rem;
    writing-mode: unset;
    transform: unset;
    text-align: center;
    justify-content: center;
    margin-bottom: 63rem;
  }
}
.p-index__works-title .ja {
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-title .ja {
    font-size: 56rem;
    line-height: 1;
    letter-spacing: 0.1em;
  }
}
.p-index__works-title .en {
  color: #313371;
  font-size: 20rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  padding-left: 14rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-title .en {
    margin-top: 20rem;
    font-size: 32rem;
  }
}
.p-index__works-inner {
  position: relative;
  left: 0;
  width: calc(91.1% + 40rem);
  margin-left: auto;
  padding: 150rem 0;
  height: auto; /* ← 高さをリセット */
  overflow: visible;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-inner {
    width: 100%;
    padding: 0 32rem 0 34rem;
    margin: auto;
  }
}
.p-index__works-box {
  padding-left: 9.66%;
  padding-left: 192rem;
  margin-left: auto;
  overflow-x: hidden;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-box {
    padding: 0;
    margin: auto;
    overflow: unset;
  }
}
.p-index__works-slide {
  width: 100%;
  transform: translateX(80rem);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide {
    width: 100%;
    display: flex;
    column-gap: 38rem;
    row-gap: 48rem;
    transform: unset;
    flex-wrap: wrap;
  }
}
.p-index__works-slide .slick-track {
  display: flex !important;
  flex-wrap: nowrap !important; /* 折り返さない */
}
.p-index__works-slide .slick-slide {
  margin: 0 25rem; /* ← 左右の余白（スライド間の間隔） */
  width: 500rem !important; /* ← 各スライドの幅を固定したい場合 */
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .slick-slide {
    margin: 0;
    width: calc((100% - 38rem) / 2);
  }
}
.p-index__works-slide .slick-list {
  margin: 0 -25rem; /* ← 全体のズレを補正（重要！） */
  overflow-x: hidden;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .slick-list {
    margin: 0;
  }
}
.p-index__works-slide .slick-prev, .p-index__works-slide .slick-next {
  width: 40rem;
  height: 40rem;
  width: 40rem;
  height: 40rem;
  top: 0;
  left: -232rem;
  border: 1px solid #A4A4A4;
  background: #fff;
}
.p-index__works-slide .slick-prev::before, .p-index__works-slide .slick-next::before {
  color: #333333;
  font-size: 18rem;
}
.p-index__works-slide .slick-prev:hover, .p-index__works-slide .slick-next:hover {
  background: #313371;
}
.p-index__works-slide .slick-prev:hover::before, .p-index__works-slide .slick-next:hover::before {
  color: #fff;
}
.p-index__works-slide .slick-prev {
  transform: translate(-100%, 0);
}
.p-index__works-slide .slick-next {
  transform: translate(-100%, 100%);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .l-col3__item {
    margin: 0;
    width: calc((100% - 38rem) / 2);
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .c-works__item-detawrap {
    flex-direction: column;
    gap: 18rem;
  }
}
.p-index__works-slide .c-works__item-detawrap .c-works__item-cat {
  border: 1px solid #A4A4A4;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .c-works__item-detawrap .c-works__item-cat {
    width: 100%;
    border-width: 0.63px;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .c-works__item-detawrap .c-works__item-area {
    width: 100%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works-slide .c-works__item-text {
    width: 100%;
    font-size: 28rem;
  }
}
.p-index__works .c-btn {
  width: 300rem;
  margin-top: 79rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__works .c-btn {
    width: 598rem;
    margin: 96rem auto 0;
  }
}
.p-index__concept {
  padding: 150rem 0 87rem;
  background-image: linear-gradient(to bottom, #fff 19.6%, #313371 19.6%, #313371 85.25%, #fff 85.25%);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept {
    padding: 66rem 0 67rem;
    background: #313371;
  }
}
.p-index__concept .c-title-english {
  text-align: left;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__concept .c-title-english .c-title-english__ja {
    line-height: 1.44;
  }
  .p-index__concept .c-title-english .c-title-english__ja br.u-sponly {
    display: block;
  }
}
.p-index__concept-inner {
  position: relative;
  max-width: 1920rem;
  min-height: 1112rem;
  width: 100%;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept-inner {
    min-height: unset;
    padding-top: 457rem;
  }
}
.p-index__concept-inner::before {
  content: "";
  position: absolute;
  left: 0;
  z-index: 0;
  display: block;
  width: 81%;
  max-width: 1557rem;
  height: 940rem;
  background: url(../images/index/concept-image.jpg);
  background-size: cover;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept-inner::before {
    width: 100%;
    height: 611rem;
    aspect-ratio: 750/611;
    top: 0;
  }
}
.p-index__concept-textwrap {
  width: 54.43%;
  background: #fff;
  padding: 120rem 170rem 114rem 130rem;
  position: absolute;
  bottom: 0;
  right: 0;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__concept-textwrap {
    padding: 100rem;
    width: 70%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept-textwrap {
    position: relative;
    width: calc(100% - 61rem);
    bottom: auto;
    padding: 85rem 50rem;
    right: unset;
    margin-left: auto;
  }
}
.p-index__concept-text {
  margin: 50rem 0;
  font-size: 18rem;
  letter-spacing: 0.05em;
  line-height: 2.2;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept-text {
    font-size: 32rem;
    margin: 47rem 0 60rem;
  }
}
.p-index__concept .c-btn + .c-btn {
  margin-top: 28rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept .c-btn + .c-btn {
    margin-top: 39rem;
  }
}
.p-index__concept .c-btn {
  justify-content: start;
  width: 572rem;
  padding-left: 116rem;
  max-width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept .c-btn {
    width: 590rem;
    transform: translateX(-9rem);
  }
}
.p-index__concept .c-btn--white {
  width: 390rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__concept .c-btn--white {
    width: 590rem;
    transform: translateX(-9rem);
  }
}
.p-index__voice {
  padding: 149rem 0 151rem;
  background: url(../images/index/bg-voice.jpg);
  background-size: cover;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice {
    padding: 180rem 0;
  }
}
.p-index__voice .c-title-english {
  text-align: center;
  margin-bottom: 83rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice .c-title-english {
    margin-bottom: 85rem;
  }
}
.p-index__voice .c-card__imgwrap {
  aspect-ratio: 495.42/326.25;
}
.p-index__voice-inner {
  position: relative;
  max-width: 1920rem;
  height: auto; /* ← 高さをリセット */
  overflow: hidden;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice-inner {
    margin: 0;
    max-width: unset;
  }
}
.p-index__voice-slide {
  /*
  .slick-slide:nth-child(even) {
    margin-top: 62rem; 
    @media only screen and (max-width: 1199.9px) {
      margin-top: 74rem;
    }
  }
  */
}
.p-index__voice-slide .slick-slide {
  margin: 0 25rem; /* ← 左右の余白（スライド間の間隔） */
  width: 500rem !important;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice-slide .slick-slide {
    width: calc(100vw - 160rem) !important;
  }
}
.p-index__voice-slide .slick-slide .l-col3__item {
  width: 100%;
}
.p-index__voice-slide .slick-list {
  margin: 0 -25rem; /* ← 全体のズレを補正（重要！） */
  overflow-x: hidden;
}
.p-index__voice-slide .slick-slide {
  display: inline-block; /* 必要に応じて */
}
.p-index__voice-slide.slick-center-force .slick-track {
  display: flex !important;
  justify-content: center;
}
.p-index__voice .c-btn {
  width: 300rem;
  margin: 80rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice .c-btn {
    width: 598rem;
    max-width: 100%;
    margin-top: 96rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice .c-card__textwrap > p {
    text-align: left;
  }
}
.p-index__voice .c-voice__item-cat {
  border: 1px solid #A4A4A4;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__voice .c-voice__item-cat {
    border: 0.63px solid #A4A4A4;
  }
}
.p-index__news {
  background: url(../images/index/news-bg-logo.svg);
  background-size: 30.8%;
  background-repeat: no-repeat;
  background-position: left 3rem bottom 9rem;
  max-width: 1920rem;
  width: 100%;
  padding: 168rem 0 180rem;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news {
    padding: 180rem 0;
    background-size: 78.8%;
    background-position: left -114rem top -85.96rem;
    margin: 0;
  }
}
.p-index__news-inner {
  display: flex;
  max-width: 1640rem;
  width: 100%;
  gap: 112rem;
  margin: auto;
  padding: 0;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__news-inner {
    gap: 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-inner {
    flex-direction: column;
    gap: 34rem;
    width: calc(100% - 100rem);
  }
}
.p-index__news-title {
  width: 335rem;
  margin-left: 14rem;
  writing-mode: vertical-lr;
  display: flex;
  align-items: center;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__news-title {
    width: 20%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-title {
    width: 100%;
    margin: 0;
    padding: 0 24rem;
    writing-mode: unset;
    text-align: center;
    justify-content: center;
  }
}
.p-index__news-title .ja {
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  margin-left: 14rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-title .ja {
    margin-left: 0;
    margin-bottom: 20rem;
    font-size: 56rem;
    letter-spacing: 0.1em;
    line-height: 1.4;
  }
}
.p-index__news-title .en {
  color: #313371;
  font-size: 20rem;
  font-weight: 600;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-title .en {
    font-size: 32rem;
    letter-spacing: 0.1em;
    line-height: 1;
  }
}
.p-index__news .c-news__list {
  border-bottom: 0;
}
.p-index__news-list {
  width: 78.6%;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-list {
    width: 100%;
    border: 0;
  }
}
.p-index__news-list .c-btn {
  margin: 94rem auto 0;
  width: 300rem;
  max-width: 26.5%;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-list .c-btn {
    margin-top: 66rem;
    width: 598rem;
    max-width: calc(100% - 152rem);
  }
}
.p-index__news-item {
  display: flex;
  align-items: center;
}
.p-index__news-item:not(:first-of-type) a {
  border-top: 2rem solid #F3F3F3;
}
.p-index__news-item a {
  position: relative;
  width: 100%;
  padding-top: 0;
  padding-bottom: 26rem;
  padding-right: 102rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a {
    padding: 50rem 92rem 30rem 0;
  }
}
.p-index__news-item a::after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 38rem;
  transform: translate(0, -50%);
  background: url(../images/index/news-arrow.svg);
  background-size: contain;
  width: 25rem;
  height: 8rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a::after {
    width: 24rem;
    top: 138rem;
    right: 26.98rem;
  }
}
.p-index__news-item a > dl {
  position: relative;
  width: 100%;
}
.p-index__news-item a > dl dt {
  display: flex;
  gap: 28rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a > dl dt {
    gap: 16.51rem;
  }
}
.p-index__news-item a > dl dt .cat {
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #A9AACA;
  width: 144rem;
  height: 32rem;
  color: #fff;
  font-size: 14rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a > dl dt .cat {
    width: 237.3rem;
    height: 51rem;
    font-size: 22rem;
  }
}
.p-index__news-item a > dl dt .date {
  font-size: 16rem;
  letter-spacing: 0.003em;
  font-family: "Roboto", sans-serif;
  font-weight: 400;
  color: #646464;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a > dl dt .date {
    font-size: 28rem;
  }
}
.p-index__news-item a > dl dd {
  margin-top: 20rem;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 500;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__news-item a > dl dd {
    margin-top: 16rem;
    font-size: 32rem;
  }
}
.p-index__sns {
  padding: 150rem 0 126rem;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns .c-title-english {
    font-size: 56rem;
  }
}
.p-index__sns-subtitle {
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  font-size: 26rem;
  letter-spacing: 0.01em;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns-subtitle {
    font-size: 36rem;
  }
}
.p-index__sns-subtitle::before {
  content: "";
}
.p-index__sns-subtitle::after {
  content: "";
  margin-left: 5.5rem;
  display: block;
  width: 28.75rem;
  height: 28.75rem;
  background-image: url(../images/common/icon-arrow02.svg);
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns-subtitle::after {
    width: 40rem;
    height: 40rem;
    margin-left: 8rem;
    margin-top: 2rem;
  }
}
.p-index__sns-follow {
  display: flex;
  gap: 56rem;
  align-items: center;
  justify-content: center;
  margin: 71rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns-follow {
    margin-top: 90rem;
    gap: 35rem;
    max-width: calc(100% - 100rem);
  }
}
.p-index__sns-followtitle {
  font-size: 32rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 600;
  line-height: 1;
  letter-spacing: 0.01em;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns-followtitle {
    font-size: 38rem;
  }
}
.p-index__sns-followlist {
  display: flex;
  gap: 20.08rem;
  align-items: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__sns-followlist {
    gap: 0;
  }
}
.p-index__sns-followlist li {
  width: 96.92rem;
  height: 90rem;
}
.p-index__youtube {
  margin-top: 100rem;
}
.p-index__youtube .p-index__sns-subtitle {
  margin-bottom: 25.5rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__youtube .p-index__sns-subtitle {
    margin-bottom: 40rem;
  }
}
.p-index__youtube .p-index__sns-subtitle::before {
  content: "";
  margin-right: 5.5rem;
  display: block;
  width: 62.5rem;
  height: 57.5rem;
  background-image: url(../images/common/icon-youtube.svg);
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__youtube .p-index__sns-subtitle::before {
    width: 86rem;
    height: 80rem;
    margin-right: 0;
  }
}
.p-index__youtube-inner {
  width: 1197rem;
  max-width: 62.18%;
  margin: auto;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__youtube-inner {
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__youtube-inner {
    width: calc(100% - 60rem);
    max-width: unset;
  }
}
.p-index__youtube-list {
  display: flex;
  flex-wrap: wrap;
  gap: 23.8rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__youtube-list {
    gap: 24rem;
  }
}
.p-index__youtube-item {
  width: calc((100% - 47.6rem) / 3);
  aspect-ratio: 16/9;
  position: relative;
  overflow: hidden;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__youtube-item {
    width: 100%;
  }
}
.p-index__youtube-item iframe {
  width: 100%;
  max-width: 100%;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, 0px);
  width: 100%;
  height: 100%;
}
.p-index__instagram {
  margin-top: 67rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram {
    margin-top: 65rem;
  }
}
.p-index__instagram .p-index__sns-subtitle {
  margin-bottom: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram .p-index__sns-subtitle {
    margin-bottom: 40rem;
  }
}
.p-index__instagram .p-index__sns-subtitle::before {
  content: "";
  margin-right: 17rem;
  display: block;
  width: 32rem;
  height: 32rem;
  background-image: url(../images/common/icon-instagram--bk.svg);
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram .p-index__sns-subtitle::before {
    width: 43rem;
    height: 43rem;
    margin-right: 20rem;
  }
}
.p-index__instagram-inner {
  width: 1197rem;
  max-width: 62.18%;
  margin: auto;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__instagram-inner {
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram-inner {
    width: calc(100% - 60rem);
    max-width: unset;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram .instagram-gallery-list {
    display: flex;
    gap: 18rem !important;
  }
  .p-index__instagram .instagram-gallery-list > a {
    width: calc((100% - 18rem) / 2) !important;
  }
  .p-index__instagram .instagram-gallery-list > a:nth-last-of-type(-n+4) {
    display: none !important;
  }
  .p-index__instagram .instagram-gallery-list .instagram-gallery-item__wrap {
    border-radius: 0 !important;
  }
}
.p-index__instagram-list {
  display: flex;
  flex-wrap: wrap;
  gap: 18rem;
}
.p-index__instagram-item {
  width: calc((100% - 54rem) / 4);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__instagram-item {
    width: calc((100% - 18rem) / 2);
  }
}
.p-index__instagram-item > a, .p-index__instagram-item iframe, .p-index__instagram-item image {
  width: 100%;
  max-width: 100% !important;
  min-width: 100% !important;
}
.p-index__col2 {
  display: flex;
  gap: 12rem;
  margin-bottom: 100rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__col2 {
    flex-direction: column;
    gap: 16rem;
    margin-bottom: 120rem;
  }
}
.p-index__col2-link {
  width: 50%;
  aspect-ratio: 955/413;
  padding: 23rem 28rem;
  background-size: cover;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__col2-link {
    width: 100%;
    padding: 22rem 22rem 21.2rem;
    aspect-ratio: 750/360;
  }
}
.p-index__col2-link:first-of-type {
  background-image: url(../images/index/bg-company.jpg);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__col2-link:first-of-type {
    background-image: url(../images/index/bg-company_sp.jpg);
  }
}
.p-index__col2-link:last-of-type {
  background-image: url(../images/index/bg-staff.jpg);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__col2-link:last-of-type {
    background-image: url(../images/index/bg-staff_sp.jpg);
  }
}
.p-index__col2-inner {
  position: relative;
  border: 1px solid #fff;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-index__col2-title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  letter-spacing: 0.1em;
}
.p-index__col2-title dt {
  font-size: 40rem;
  font-weight: 700;
}
.p-index__col2-title dd {
  margin-top: 14rem;
  font-size: 20rem;
  font-weight: 600;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__col2-title dd {
    margin-top: 0;
  }
}
.p-index__col2-more {
  position: absolute;
  bottom: 24rem;
  right: 30rem;
  display: flex;
  align-items: center;
  gap: 10rem;
  color: #fff;
  font-size: 18rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__col2-more {
    bottom: 12rem;
  }
}
.p-index__col2-more::after {
  content: "";
  transform: rotate(45deg);
  display: block;
  width: 8rem;
  height: 8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
.p-index__mingei {
  padding: 150rem 0 62rem;
  background-image: linear-gradient(to bottom, #fff 51.75%, #313371 51.75%, #313371 51.75%);
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei {
    padding: 116rem 30rem 100rem;
    width: 100%;
  }
}
.p-index__mingei-inner {
  display: flex;
  gap: 118.78rem;
  width: 82.13%;
  max-width: 1577rem;
  padding: 0 65rem 0 78rem;
  margin: auto;
  background: #fff;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-inner {
    flex-direction: column;
    gap: 48rem;
    width: 100%;
    max-width: unset;
    padding: 0;
  }
}
.p-index__mingei-imgwrap {
  padding-top: 137rem;
  padding-bottom: 130.22rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-imgwrap {
    padding: 0;
  }
}
.p-index__mingei-textwrap {
  padding-top: 146rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-textwrap {
    padding: 0 46rem 80rem;
  }
}
.p-index__mingei-textwrap > p {
  margin-top: 50rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-textwrap > p {
    margin: 55rem 4rem 0;
    font-size: 32rem;
  }
}
.p-index__mingei-textwrap .c-btn {
  margin-top: 50rem;
  width: 300rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-index__mingei-textwrap .c-btn {
    margin-bottom: 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-textwrap .c-btn {
    margin-top: 60rem;
    width: 100%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-index__mingei-textwrap .c-title-english {
    margin: 0 4rem;
  }
  .p-index__mingei-textwrap .c-title-english .c-title-english__en {
    font-size: 26rem;
    letter-spacing: 0.1em;
    line-height: 1;
  }
}

.scroll {
  position: absolute;
  right: 50%;
  bottom: 0;
}
@media only screen and (max-width: 1199.9px) {
  .scroll {
    right: 38rem;
  }
}
.scroll > span {
  display: block;
  transform: translateY(-117rem);
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-weight: 900;
  font-size: 12rem;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .scroll > span {
    writing-mode: vertical-lr;
    font-size: 20rem;
    text-transform: uppercase;
  }
  @supports (-webkit-touch-callout: none) {
    .scroll > span {
      /* iOS Safari だけに適用される */
      padding-right: 24rem; /* 例：調整したい値 */
    }
  }
}

/* 線のアニメーション部分 */
.scroll::before {
  animation: scroll 2s infinite;
  background-color: #fff;
  bottom: 0rem;
  content: "";
  height: 100rem;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}

/* 線の背景色 */
.scroll::after {
  background-color: transparent;
  bottom: 0rem;
  content: "";
  height: 100rem;
  left: 0;
  margin: auto;
  position: absolute;
  right: 0;
  width: 1px;
}

/* 線のアニメーション */
@keyframes scroll {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  50% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  51% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}
.p-page main:not(.p-event__single, .p-works__single, .p-contact__main) {
  margin-bottom: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-page main:not(.p-event__single, .p-works__single, .p-contact__main) {
    margin-bottom: 124rem;
  }
}
.p-page__mv {
  position: relative;
  height: 480rem;
  background: url(../images/index/news-bg-logo.svg);
  background-size: 30.78%;
  background-repeat: no-repeat;
  background-position: right 122rem bottom -214rem;
  border-bottom: 30rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__mv {
    min-height: 300rem;
    padding: 96rem 0;
    background-position: right -61rem bottom -148rem;
    background-size: 390rem;
  }
}
.p-page__mv-title {
  position: absolute;
  bottom: 67rem;
  left: 170rem;
  font-size: 48rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  letter-spacing: 0.1em;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__mv-title {
    font-size: 58rem;
    top: 50%;
    left: 30rem;
    bottom: auto;
    transform: translateY(-50%);
  }
}
.p-page__mv-title span {
  display: block;
  margin-top: 14rem;
  font-size: 20rem;
  color: #313371;
  letter-spacing: 0.1em;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__mv-title span {
    font-size: 26rem;
    line-height: 1.5;
  }
}
.p-page .c-breadcrumb {
  position: absolute;
  bottom: 24rem;
  right: 170rem;
  width: 100%;
  max-width: 1580rem;
  height: 36rem;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}
@media only screen and (max-width: 1199.9px) {
  .p-page .c-breadcrumb {
    font-size: 20rem;
    height: 30rem;
    right: 30rem;
    bottom: 26rem;
    flex-wrap: wrap;
  }
}
.p-page .c-breadcrumb .c-breadcrumb__item {
  color: #646464;
  font-size: 15rem;
  display: flex;
  align-items: center;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-page .c-breadcrumb .c-breadcrumb__item {
    font-size: 20rem;
  }
}
.p-page .c-breadcrumb .c-breadcrumb__item:not(:last-of-type)::after {
  content: "/";
  display: block;
  flex: none;
  margin: 0 17rem;
}
.p-page .c-breadcrumb .c-breadcrumb__item a {
  text-decoration: underline;
}
@media only screen and (max-width: 1199.9px) {
  .p-page .c-breadcrumb .u-pconly {
    display: none !important;
  }
}
.p-page .c-breadcrumb .u-pconly::after {
  display: none !important;
}
@media only screen and (min-width: 1200px) {
  .p-page .c-breadcrumb .u-sponly {
    display: none !important;
  }
}
.p-page .c-breadcrumb .u-sponly::after {
  display: none !important;
}
.p-page__catnavi {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 7rem;
  margin: auto;
  width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__catnavi {
    max-width: 100%;
    gap: 10rem;
    justify-content: flex-start;
  }
}
.p-page__catnavi-title {
  text-align: center;
  font-size: 32rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.05em;
  margin-bottom: 31rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__catnavi-title {
    font-size: 38rem;
    margin-bottom: 35rem;
  }
}
.p-page__cat {
  width: calc((100% - 28rem) / 5);
  min-width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__cat {
    width: calc((100% - 10rem) / 2);
  }
}
.p-page__catlink {
  width: 100%;
  height: 56rem;
  padding: 8rem 7rem;
  font-family: "Noto Serif JP", serif;
  background-color: #fff;
  font-size: 20rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  color: #333;
  border: 2px solid #333;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__catlink {
    font-size: 30rem;
    padding: 10rem;
    height: 90rem;
    border: 1.33px solid #333;
  }
}
.p-page__catlink span {
  width: 100%;
  height: 100%;
  padding: 0 0.25em;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-page__catlink.active {
  background-color: #313371;
  border: 0;
  color: #fff;
}
.p-page__catlink.active span {
  border: 1px solid #fff;
}
.p-page__catlink::after {
  display: none;
}
.p-page__col2 {
  display: flex;
  gap: 32rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2 {
    flex-direction: column;
    gap: 45.79rem;
  }
}
.p-page__col2-link {
  width: 48.4%;
  min-height: 219rem;
  padding: 12rem 14rem;
  background-size: cover;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2-link {
    width: 100%;
    min-height: 312.21rem;
    padding: 17rem 20rem 17.21rem;
  }
}
.p-page__col2-link.staff {
  background-image: url(../images/common/bg-staff.jpg);
}
.p-page__col2-link.blog {
  background-image: url(../images/common/bg-blog.jpg);
}
.p-page__col2-link.company {
  background-image: url(../images/common/bg-company.jpg);
}
.p-page__col2-link.about {
  background-image: url(../images/common/bg-about.jpg);
}
.p-page__col2-link.hiraya {
  background-image: url(../images/common/bg-hiraya.jpg);
}
.p-page__col2-inner {
  position: relative;
  border: 1px solid #fff;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2-inner {
    min-height: 278rem;
  }
}
.p-page__col2-title {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  color: #fff;
  letter-spacing: 0.1em;
  font-size: 22rem;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
  /*
  dt{
    font-size: 40rem;
    font-weight: 700;
  }
  dd{
    margin-top: 14rem;
    font-size: 20rem;
    font-weight: 600;
  }
    */
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2-title {
    font-size: 32.1rem;
    display: flex;
    align-items: center;
    min-height: 100%;
  }
}
.p-page__col2-more {
  position: absolute;
  bottom: 10rem;
  right: 12rem;
  display: flex;
  align-items: center;
  gap: 10rem;
  color: #fff;
  font-size: 15rem;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2-more {
    font-size: 22.07rem;
    bottom: 15.92rem;
    right: 18.42rem;
    gap: 14.82rem;
  }
}
.p-page__col2-more::after {
  content: "";
  transform: rotate(45deg);
  display: block;
  width: 8rem;
  height: 8rem;
  border-top: 1px solid #fff;
  border-right: 1px solid #fff;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__col2-more::after {
    width: 11.4rem;
    height: 11.4rem;
  }
}
.p-page__nomv {
  padding-top: 200rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__nomv {
    padding-top: 111rem;
  }
}
.p-page__nomv .c-breadcrumb {
  position: relative;
  margin: 30rem auto;
  bottom: auto;
  right: auto;
}
@media only screen and (min-width: 1200px) {
  .p-page__nomv .c-breadcrumb {
    padding: 0 1em;
  }
}
.p-page__nomv .c-breadcrumb__wrap {
  border-top: 10rem solid #313371;
}
.p-page__single {
  max-width: 1000rem;
  margin: auto;
  width: 100%;
  line-height: 2.2;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-page__single {
    width: calc(100% - 100rem);
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-page__single {
    line-height: 2.1;
  }
}
.p-page__single-data {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 21rem;
  border-top: 4rem solid #313371;
  margin-top: 18rem;
  padding-top: 18rem;
  margin-bottom: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__single-data {
    margin-top: 32rem;
    padding-top: 26rem;
    margin-bottom: 64rem;
  }
}
.p-page__single-data .cat {
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #A4A4A4;
  height: 32rem;
  min-width: 144rem;
  padding: 8rem;
  font-size: 14rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__single-data .cat {
    font-size: 26rem;
    height: 51rem;
    min-width: 237rem;
  }
}
.p-page__single-data .area {
  color: #858585;
  font-size: 16rem;
  letter-spacing: 0.008em;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-page__single-data .area {
    font-size: 28rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-page__single-imgwrap {
    margin-bottom: 50rem;
  }
}

.p-works__archive {
  margin-top: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__archive {
    margin-top: 112rem;
  }
}
.p-works__archive .l-col3__container {
  margin-top: 90rem;
  column-gap: 36rem;
  row-gap: 42rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__archive .l-col3__container {
    row-gap: 60rem;
    margin: 74.21rem auto 0;
    width: calc(100% - 60rem);
  }
}
.p-works__archive .l-col3__item {
  width: calc((100% - 72rem) / 3);
}
@media only screen and (max-width: 1199.9px) {
  .p-works__archive .l-col3__item {
    width: 100%;
  }
}
.p-works__single {
  padding-bottom: 50rem;
}
.p-works__single-wrap {
  padding: 117rem 0 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single-wrap {
    margin: auto;
    width: 100%;
    padding: 61rem 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single .c-single-title {
    text-align: left;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single .p-page__single-data {
    justify-content: flex-start;
  }
}
.p-works__single-topimg {
  margin: 50rem auto 0;
}
.p-works__single-topimg img {
  display: block;
  margin: auto;
  max-width: 100%;
}
.p-works__single-toptext {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  max-width: calc(100% - 110rem);
  margin: 50rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single-toptext {
    max-width: unset;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-works__single-block {
  margin-top: 50rem;
}
@media only screen and (min-width: 1200px) {
  .p-works__single-block {
    margin-top: 0;
    width: calc(50% - 8rem);
    margin-bottom: 0;
  }
}
.p-works__single-img {
  margin: 0 auto;
  display: block;
  object-fit: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single-img {
    width: 690rem;
    max-width: 100%;
  }
}
.p-works__single-caption {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  max-width: calc(100% - 110rem);
  margin: 8rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single-caption {
    margin-top: 16rem;
    font-size: 30rem;
    line-height: 2.1;
    padding: 0 13rem;
    max-width: unset;
  }
}
.p-works__single-imglist {
  padding-bottom: 100rem;
  border-bottom: 4rem solid #313371;
}
@media only screen and (min-width: 1200px) {
  .p-works__single-imglist {
    display: flex;
    flex-wrap: wrap;
    gap: 16rem;
    margin-top: 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single-imglist {
    padding-bottom: 120rem;
  }
}
.p-works__single .c-pagination {
  margin-top: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__single .c-pagination {
    margin-top: 112rem;
  }
}
.p-works__recommend {
  margin-top: 150rem;
  padding: 150rem 0;
  background-color: #F4F4F4;
}
.p-works__recommend .c-title-english {
  text-align: center;
  margin-bottom: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__recommend .c-title-english .c-title-english__ja {
    font-size: 50rem;
  }
}
.p-works__recommend-inner {
  max-width: 1920rem;
  width: 100%;
  padding: 0 88rem;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__recommend-inner {
    padding: 0 50rem;
  }
}
.p-works__recommend-list {
  display: flex;
  justify-content: center;
  gap: 36rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-works__recommend-list {
    row-gap: 48rem;
    column-gap: 38rem;
    flex-wrap: wrap;
    justify-content: flex-start;
  }
}
.p-works__recommend-item {
  width: calc((100% - 108rem) / 4);
}
@media only screen and (max-width: 1199.9px) {
  .p-works__recommend-item {
    width: calc((100% - 38rem) / 2);
  }
}
.p-works__recommend-item .c-works__item-detawrap {
  flex-wrap: wrap;
}
.p-works__recommend-slide .slick-slide {
  margin: 0 18rem; /* ← 左右の余白（スライド間の間隔） */
  width: calc((100% - 108rem) / 4);
}

.p-event__archive {
  margin-top: 170rem;
  margin-bottom: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__archive {
    margin: 150rem 0;
  }
}
.p-event__archive .l-col3__container {
  margin-top: 90rem;
  column-gap: 39rem;
  row-gap: 42rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__archive .l-col3__container {
    gap: 70rem;
    margin-top: 74rem;
  }
}
.p-event__archive .l-col3__item {
  width: calc((100% - 78rem) / 3);
}
@media only screen and (max-width: 1199.9px) {
  .p-event__archive .l-col3__item {
    width: calc(100% - 60rem);
    margin: auto;
  }
}
.p-event__single-wrap {
  padding: 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-wrap {
    padding: 57.16rem 0rem 0;
  }
}
.p-event__single-cat {
  width: fit-content;
  min-width: 144rem;
  border: 1px solid #a4a4a4;
  background-color: #fff;
  font-size: 14rem;
  line-height: 1;
  letter-spacing: 0.05em;
  padding: 7rem;
  display: flex;
  align-items: center;
  justify-content: center;
  height: 32rem;
  margin-bottom: 18rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-cat {
    min-width: 250rem;
    font-size: 26rem;
    height: 46rem;
    margin-bottom: 20rem;
  }
}
.p-event__single-main {
  margin-bottom: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-main {
    padding: 0 30rem;
  }
}
.p-event__single-main img {
  margin: 0 auto;
  display: block;
  width: 100%;
  max-width: 1000rem;
  max-height: 600rem;
  object-fit: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-main img {
    max-height: unset;
  }
}
.p-event__single .c-single-title {
  text-align: left;
  padding-bottom: 10rem;
  border-bottom: 2rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single .c-single-title {
    padding-bottom: 32rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single .c-breadcrumb {
    max-width: calc(100% - 60rem);
  }
}
.p-event__single-datalabel {
  width: 95rem;
  border: 1px solid #a4a4a4;
  background-color: #A9AACA;
  font-size: 16rem;
  line-height: 1.5;
  letter-spacing: 0.05em;
  font-weight: 500;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  height: 27rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-datalabel {
    width: 150rem;
    height: 52rem;
    font-size: 28rem;
  }
}
.p-event__single-data {
  margin-bottom: 60rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-data {
    margin-bottom: 61rem;
  }
}
.p-event__single-data > span {
  display: flex;
  align-items: center;
  gap: 24rem;
  margin-top: 24rem;
  margin-left: 14rem;
  font-size: 18rem;
  line-height: 1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-data > span {
    font-size: 30rem;
    margin-left: 22rem;
    margin-top: 33rem;
  }
}
.p-event__single-data > span + span {
  margin-top: 24rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-data > span + span {
    margin-top: 22rem;
  }
}
.p-event__single-contents {
  margin-top: 10rem;
  padding-bottom: 100rem;
  margin-bottom: 80rem;
  border-bottom: 4rem solid #313371;
}
.p-event__single-block {
  margin-top: 50rem;
  margin-bottom: 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-block {
    margin: 45rem auto 0;
    width: calc(100% - 60rem);
  }
}
.p-event__single-box {
  background-color: #F8F8F8;
  padding: 37rem 33rem;
  margin-top: 72rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box {
    width: calc(100% - 60rem);
    margin: 56rem auto 72rem;
  }
}
.p-event__single-box dl {
  display: flex;
  gap: 52rem;
  padding: 29rem 0;
  border-bottom: 1px solid #EAEAEA;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl {
    flex-direction: column;
    gap: 20rem;
  }
}
.p-event__single-box dl:first-of-type {
  padding-top: 0;
}
.p-event__single-box dl:last-of-type {
  border: 0;
  padding-bottom: 0;
}
.p-event__single-box dl dt {
  min-width: 140rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl dt {
    min-width: 159rem;
  }
}
.p-event__single-box dl dt > p {
  border: 1px solid #D3D3D3;
  background-color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 6rem 14rem 5rem;
  width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl dt > p {
    font-size: 30rem;
  }
}
.p-event__single-box dl dd {
  flex: 1;
  font-size: 18rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl dd {
    font-size: 30rem;
  }
}
.p-event__single-box dl dd iframe {
  max-width: 100% !important;
  margin-top: 28rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl dd iframe {
    margin-top: 24rem;
  }
}
.p-event__single-box dl dd p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-box dl dd p + p {
    margin-top: 1.55em;
  }
}
.p-event__single-subheading {
  padding: 10rem 0;
  font-size: 22rem;
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 0.05em;
  border-bottom: 2px solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-subheading {
    border-left: 0;
    font-size: 42rem;
    padding: 0 13rem 16rem;
  }
}
.p-event__single-content {
  margin-top: 32rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content {
    margin-top: 45rem;
    padding: 0 13rem;
  }
}
.p-event__single-content p {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content p {
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-event__single-content p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content p + p {
    margin-top: 1.55em;
  }
}
.p-event__single-content p img {
  margin-top: 60rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content p img {
    margin-top: 0;
  }
}
.p-event__single-content ul {
  margin-top: 2.2em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content ul {
    margin-top: 2.1em;
  }
}
.p-event__single-content ul > li {
  display: flex;
  gap: 20rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content ul > li {
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-event__single-content ul > li::before {
  content: "✓";
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  flex: none;
  margin-top: 9rem;
  line-height: 1;
  font-size: 9.4rem;
  width: 21rem;
  height: 21rem;
  border-radius: 50%;
  background-color: #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-content ul > li::before {
    content: "✓";
    color: #fff;
    display: flex;
    align-items: center;
    justify-content: center;
    line-height: 1;
    font-size: 16rem;
    width: 36rem;
    height: 36rem;
    margin-top: 16rem;
  }
}
.p-event__single-caption {
  margin-top: 8rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single-caption {
    margin-top: 16rem;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-event__single .c-btn {
  width: 500rem;
  max-width: 100%;
  margin: 50rem auto 170rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single .c-btn {
    margin: 70rem auto 0;
    width: 598rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-event__single .p-contact__form .c-btn {
    margin: 0rem auto 0;
  }
}
.p-event__reserve .c-title-english {
  margin: 0 auto 80rem;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-event__reserve .c-title-english {
    margin-bottom: 100rem;
  }
}

.p-voice__archive {
  margin-top: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__archive {
    margin-top: 112rem;
  }
}
.p-voice__archive .l-col3__container {
  margin-top: 90rem;
  column-gap: 36rem;
  row-gap: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__archive .l-col3__container {
    row-gap: 60.57rem;
    width: calc(100% - 40rem);
    margin: 74rem auto 0;
  }
}
.p-voice__archive .l-col3__item {
  width: calc((100% - 72rem) / 3);
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__archive .l-col3__item {
    width: 100%;
  }
}
.p-voice__single {
  padding-bottom: 50rem;
}
.p-voice__single-wrap {
  padding: 117rem 0 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-wrap {
    padding: 60rem 50rem 0;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single .c-single-title {
    text-align: left;
  }
}
.p-voice__single-main .c-btn {
  width: fit-content;
  padding: 0 50rem;
  margin: 60rem auto 0;
}
.p-voice__single-contents {
  margin-top: 10rem;
  padding-bottom: 100rem;
  margin-bottom: 80rem;
  border-bottom: 4rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-contents {
    margin-top: 40rem;
  }
}
.p-voice__single-block {
  margin-top: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-block {
    margin-top: 60rem;
  }
}
.p-voice__single-subheading {
  padding-bottom: 14rem;
  font-size: 22rem;
  font-weight: 700;
  line-height: 2.2;
  letter-spacing: 0.05em;
  border-bottom: 2rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-subheading {
    font-size: 36rem;
    line-height: 1.8;
  }
}
.p-voice__single-content {
  margin-top: 32rem;
  line-height: 2.2;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-content {
    margin-top: 40rem;
    line-height: 2.1;
  }
}
.p-voice__single-content p {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-content p {
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-voice__single-content p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-voice__single-content p + p {
    margin-top: 1.55em;
  }
}
@media only screen and (min-width: 1200px) {
  .p-voice__single-content {
    display: flex;
    flex-wrap: wrap;
    gap: 16rem;
    /* 通常の段落は1カラム（全幅） */
    /* 中身が画像だけの段落を2カラムにする */
  }
  .p-voice__single-content > p {
    width: 100%;
  }
  .p-voice__single-content > p img {
    display: inline-block;
    width: calc(50% - 16rem);
  }
  .p-voice__single-content > p img:first-of-type {
    margin-top: calc(1.67em + 16rem);
  }
  .p-voice__single-content > p img:nth-of-type(odd) {
    margin-right: 8rem;
  }
  .p-voice__single-content > p img:nth-of-type(even) {
    margin-left: 8rem;
  }
  .p-voice__single-content > p img:nth-of-type(n+3) {
    margin-top: 16rem;
  }
  .p-voice__single-content > p img + br {
    display: none !important;
  }
  .p-voice__single-content > p:has(> img:only-child) {
    width: calc(50% - 8rem); /* 2カラム用の幅 */
  }
  .p-voice__single-content > p:has(> img:only-child) img {
    width: 100%;
    height: auto;
    display: block;
  }
}
.p-voice__single .p-page__single-data {
  justify-content: flex-start;
}

.p-news__archive {
  padding-top: 150rem;
}
.p-news__archive .c-news__list {
  margin-top: 90rem;
  padding-top: 40rem;
  border-top: 4rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__archive .c-news__list {
    margin: 108rem auto 0;
    padding-top: 68rem;
    padding-bottom: 68rem;
    border-bottom: 4rem solid #313371;
  }
}
.p-news__single .p-page__single-data {
  justify-content: flex-start;
  padding-left: 20.61rem;
}
.p-news__single .p-page__single-data .cat {
  background: #A9AACA;
  border: 0;
  color: #fff;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single .c-single-title {
    text-align: left;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-wrap {
    width: calc(100% - 100rem);
    margin: 49.3rem auto 0;
  }
}
.p-news__single-main {
  padding-top: 117rem;
}
.p-news__single-contents {
  margin-top: 40rem;
  margin-bottom: 80rem;
  padding-bottom: 100rem;
  border-bottom: 4rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents {
    margin-top: 0;
    padding: 0 20rem 120rem;
  }
}
.p-news__single-contents h2.wp-block-heading {
  margin-top: 50rem;
  margin-bottom: 32rem;
  font-size: 24rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
  padding-bottom: 10rem;
  border-bottom: 2rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents h2.wp-block-heading {
    font-size: 36rem;
  }
}
.p-news__single-contents h3.wp-block-heading {
  margin-top: 50rem;
  margin-bottom: 32rem;
  background-color: #F4F7FF;
  padding: 8rem 20rem;
  font-size: 20rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents h3.wp-block-heading {
    font-size: 32rem;
  }
}
.p-news__single-contents h4.wp-block-heading {
  margin-top: 28rem;
  margin-bottom: 0;
  color: #313371;
  font-weight: 700;
  font-size: 18rem;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents h4.wp-block-heading {
    font-size: 30rem;
  }
}
.p-news__single-contents p {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents p {
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-news__single-contents p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents p + p {
    margin-top: 1.55em;
  }
}
.p-news__single-contents figure {
  margin: 60rem 0;
}
.p-news__single-contents ul {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-news__single-contents ul {
    margin-top: 1.55em;
  }
}
.p-news__single .c-pagination {
  min-height: 115rem;
}
.p-news__single .c-pagination__title {
  margin-top: 32rem;
}
.p-news__single .c-pagination__prev, .p-news__single .c-pagination__next {
  max-width: 270rem;
  width: auto;
}

@media only screen and (min-width: 1200px) {
  .p-company .l-main {
    max-width: 1000rem;
  }
}
.p-company .p-company__profile {
  margin-top: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-company .p-company__profile {
    margin-top: 180rem;
  }
}
.p-company .p-company__profile .c-table {
  margin-top: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-company .p-company__profile .c-table {
    margin-top: 55rem;
  }
}
.p-company__access {
  padding: 150rem 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-company__access {
    padding: 180rem 0;
  }
}
.p-company__access .c-title-english {
  text-align: center;
}
.p-company__access-mapwrap {
  margin-top: 80rem;
  position: relative;
  width: 100%;
  aspect-ratio: 100/54;
  overflow: hidden;
}
@media only screen and (max-width: 1199.9px) {
  .p-company__access-mapwrap {
    margin-top: 100rem;
  }
}
.p-company__access-mapwrap iframe {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}
.p-company__access-text {
  margin-top: 50rem;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-company__access-text {
    margin-top: 60rem;
    font-size: 32rem;
  }
}

.p-privacy .l-inner {
  width: 1119rem;
  max-width: 58.3%;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy .l-inner {
    width: 650rem;
    max-width: 86.67%;
  }
}
.p-privacy__lead {
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__lead {
    font-size: 30rem;
    text-align: left;
    line-height: 2.1;
    letter-spacing: 0.05em;
  }
  .p-privacy__lead br {
    display: none;
  }
}
.p-privacy__content {
  counter-reset: privacy 0;
  padding: 150rem 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__content {
    padding: 110rem 0 20rem;
  }
}
.p-privacy__section {
  margin-top: 50rem;
}
.p-privacy__section.info {
  width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__section.info {
    width: 100%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__section.info .p-privacy__heading {
    font-size: 30rem;
  }
}
.p-privacy__section.info .p-privacy__heading::before {
  display: none;
}
.p-privacy__section h3 {
  font-size: 20rem;
  font-weight: 700;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__section h3 {
    font-size: 32rem;
    line-height: 2.1;
  }
}
.p-privacy__heading {
  font-size: 22rem;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.05em;
  padding-bottom: 10rem;
  border-bottom: 2rem solid #313371;
  margin-bottom: 20rem;
}
.p-privacy__heading::before {
  counter-increment: privacy 1;
  content: counter(privacy) ".";
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__heading {
    font-size: 36rem;
    padding-bottom: 22rem;
    margin-bottom: 30rem;
    display: flex;
  }
}
.p-privacy__text {
  font-size: 18rem;
  line-height: 2.1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__text {
    font-size: 30rem;
  }
}
.p-privacy__list {
  padding: 18rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__list {
    padding: 24rem 0;
  }
}
.p-privacy__list li {
  display: flex;
  align-items: baseline;
  font-size: 18rem;
  line-height: 2.1;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__list li {
    font-size: 30rem;
  }
}
.p-privacy__list li::before {
  content: "○︎";
  margin-right: 5rem;
  display: block;
}
@media only screen and (max-width: 1199.9px) {
  .p-privacy__list li::before {
    margin-right: 8rem;
  }
}
.p-privacy__list.link li::before {
  display: none;
}
.p-privacy__list.link li a {
  color: #313371;
  text-decoration: underline;
}

.p-catalog__mv {
  background: url(../images/contact/catalog_top.jpg);
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  padding-bottom: 126rem;
}
@media only screen and (max-width: 1920px) {
  .p-catalog__mv {
    aspect-ratio: 1920/1084;
    position: relative;
  }
}
@media only screen and (min-width: 1920.1px) {
  .p-catalog__mv {
    max-width: 1920rem;
    margin: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__mv {
    background-image: url(../images/contact/catalog_top_sp.jpg);
    aspect-ratio: 750/1493;
    height: 1493rem;
    position: relative;
  }
}
.p-catalog__mv .c-breadcrumb {
  margin-top: 19rem;
  margin-bottom: 117rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__mv .c-breadcrumb {
    margin: 35rem 26rem 54rem;
    width: auto;
  }
}
.p-catalog__mv .c-title-english {
  width: 100%;
  max-width: 1580rem;
  margin: auto;
  margin-bottom: 615rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-catalog__mv .c-title-english {
    position: absolute;
    top: 12%;
    left: 50%;
    transform: translateX(-50%);
    margin: 0;
    padding-left: 8%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__mv .c-title-english {
    display: none;
  }
}
.p-catalog__mv .c-btn {
  width: 500rem;
  margin: auto;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-catalog__mv .c-btn {
    position: absolute;
    bottom: 6%;
    left: 50%;
    transform: translateX(-50%);
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__mv .c-btn {
    bottom: 131rem;
    left: 50%;
    transform: translateX(-50%);
    width: calc(100% - 100rem);
    position: absolute;
    max-width: 649rem;
  }
}
.p-catalog__lead {
  max-width: 1300rem;
  margin: auto;
  padding: 181rem 0 150rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-catalog__lead {
    padding-bottom: 0;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead {
    width: 100%;
    padding: 0;
  }
}
.p-catalog__lead-box {
  position: relative;
  background-color: #F3F3F3;
  display: flex;
  gap: 31rem;
  padding: 40rem 60rem 0 89rem;
  margin: 0 127rem;
  align-items: flex-end;
}
@media only screen and (max-width: 1299.9px) and (min-width: 1200px) {
  .p-catalog__lead-box {
    flex-direction: column-reverse;
    gap: 0;
    width: calc(100% - 100rem);
    margin: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-box {
    flex-direction: column;
    align-items: unset;
    margin: 234rem 30rem 0;
    width: calc(100% - 60rem);
    padding: 341rem 21rem 69rem;
    gap: 0;
  }
}
.p-catalog__lead-img {
  width: 337rem;
}
@media only screen and (max-width: 1299.9px) and (min-width: 1200px) {
  .p-catalog__lead-img {
    margin: auto;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-img {
    position: relative;
    width: 100%;
  }
}
.p-catalog__lead-img img {
  position: relative;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-img img {
    position: absolute;
    width: 461rem;
    margin-top: -123rem;
    right: 26rem;
    bottom: 0;
  }
}
.p-catalog__lead-label {
  position: absolute;
  top: -80rem;
  left: -41rem;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  border-radius: 50%;
  background-color: #A9AACA;
  width: 204rem;
  height: 204rem;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 25rem;
  line-height: 1.35;
  letter-spacing: 0;
}
@media only screen and (max-width: 1299.9px) and (min-width: 1200px) {
  .p-catalog__lead-label {
    width: 180rem;
    height: 180rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-label {
    width: 256rem;
    height: 256rem;
    left: -38rem;
    top: -426rem;
    font-size: 32rem;
  }
}
.p-catalog__lead-list {
  padding-top: 18rem;
  padding-bottom: 39rem;
  flex: none;
}
@media only screen and (max-width: 1299.9px) and (min-width: 1200px) {
  .p-catalog__lead-list {
    width: 95%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-list {
    padding: 0;
  }
}
.p-catalog__lead-list li {
  background-color: #fff;
  display: flex;
  align-items: baseline;
  padding: 19rem 34rem 19rem 26rem;
  font-size: 18rem;
  letter-spacing: 0.05em;
  line-height: 1.8;
  gap: 9rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-list li {
    padding: 26rem 24rem 22rem;
    gap: 13rem;
    font-size: 28rem;
  }
}
.p-catalog__lead-list li + li {
  margin-top: 20rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-list li + li {
    margin-top: 24rem;
  }
}
.p-catalog__lead-list li span {
  display: inline-block;
  background-color: #FFFBAB;
  font-weight: 700;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-list li span {
    display: inline;
  }
}
.p-catalog__lead-list li::before {
  content: "";
  width: 26rem;
  height: 26rem;
  background: url(../images/contact/catalog_check.svg);
  background-size: contain;
  background-repeat: no-repeat;
  transform: translateY(4rem);
  flex: none;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__lead-list li::before {
    width: 38rem;
    height: 38rem;
  }
}
.p-catalog__faq {
  padding: 150rem 0;
}
.p-catalog__faq .c-title-english {
  text-align: center;
}
.p-catalog__faq-inner {
  max-width: 1300rem;
  margin: 80rem auto 0;
  width: 67.71%;
}
@media only screen and (max-width: 1299.9px) and (min-width: 1200px) {
  .p-catalog__faq-inner {
    width: calc(100% - 100rem);
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__faq-inner {
    width: calc(100% - 60rem);
    max-width: unset;
    margin-top: 16.3rem;
  }
}
.p-catalog__contact {
  background-color: #F4F4F4;
  padding: 120rem 0 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact {
    padding: 130rem 0 0;
  }
}
.p-catalog__contact h2 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact h2 {
    font-size: 50rem;
  }
}
.p-catalog__contact-inner {
  background-color: #fff;
  max-width: 1300rem;
  margin: 114rem auto 0;
  width: 67.71%;
  padding: 110rem 150rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-catalog__contact-inner {
    padding: 60rem 50rem;
    width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact-inner {
    width: 100%;
    max-width: unset;
    margin-top: 110rem;
    padding: 108rem 49rem 36rem;
  }
}
.p-catalog__contact-text {
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-catalog__contact-text:first-of-type {
  font-size: 18rem;
  font-weight: 500;
  padding: 0 13rem 6rem;
  border-bottom: 1px solid #333;
  margin: 80rem auto 0;
  width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact-text:first-of-type {
    font-size: 30rem;
    padding: 0 5rem 30rem;
    margin-top: 90rem;
  }
}
.p-catalog__contact-text:nth-of-type(2) {
  margin-top: 52rem;
  font-size: 17rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact-text:nth-of-type(2) {
    margin-top: 70rem;
    font-size: 26rem;
  }
}
.p-catalog__contact-text--attention {
  margin-top: 17rem;
  font-size: 17rem;
  color: #D04E45;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact-text--attention {
    margin-top: 28rem;
    font-size: 26rem;
  }
}
.p-catalog__contact-text--note {
  margin-top: 76rem;
  font-size: 17rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__contact-text--note {
    margin-top: 90rem;
    font-size: 26rem;
  }
}
.p-catalog__confirm .p-catalog__contact h1 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__confirm .p-catalog__contact h1 {
    font-size: 50rem;
  }
}
.p-catalog__confirm .p-catalog__contact h1 span {
  padding-left: 1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__confirm .p-catalog__contact h1 span {
    padding: 0;
    display: block;
  }
}
.p-catalog__confirm .p-catalog__contact .c-form__table dl {
  padding: 32rem 0;
  border-bottom: 1px solid #F3F3F3;
}
.p-catalog__confirm .p-catalog__contact .c-form__table dl:not(:first-of-type) {
  margin-top: 0;
}
.p-catalog__confirm .p-catalog__contact .c-form__table dd {
  color: #1A1A1A;
}
.p-catalog__confirm .p-catalog__contact .c-form__table dt {
  margin-top: 0;
}
.p-catalog__confirm .p-catalog__contact .wpcf7-form-control.wpcf7-previous {
  margin-top: 40rem;
  background: unset;
  border: 0;
  color: #333;
  border-bottom: 1px solid #333;
  line-height: 1.8;
  font-size: 17rem;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__confirm .p-catalog__contact .wpcf7-form-control.wpcf7-previous {
    font-size: 26rem;
    margin-bottom: 80rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-catalog__confirm .dre-origin-form-table.c-form__table {
    margin-bottom: 0;
  }
}

.p-thanks .c-breadcrumb {
  margin-bottom: 167rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks .c-breadcrumb {
    margin-bottom: 105rem;
    padding-right: 30rem;
  }
}
.p-thanks__inner {
  max-width: 1400rem;
  margin: auto;
  width: 72.92%;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__inner {
    width: calc(100% - 100rem);
  }
}
.p-thanks__title {
  text-align: center;
  margin-bottom: 80rem;
  color: #313371;
  font-size: 40rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 1.5;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__title {
    font-size: 42rem;
    line-height: 1.6;
  }
}
.p-thanks__text {
  text-align: center;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  font-weight: 400;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__text {
    text-align: left;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-thanks__text p + p {
  margin-top: 56rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__text p + p {
    margin-top: 45rem;
  }
}
.p-thanks__text--note {
  color: #8D8D8D;
  font-size: 16rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__text--note {
    font-size: 28rem;
    margin-top: 50rem !important;
  }
}
.p-thanks .c-btn {
  width: 500rem;
  max-width: 100%;
  margin: 80rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks .c-btn {
    width: 598rem;
    margin-top: 108rem;
  }
}
.p-thanks__event {
  background-color: #F3F3F3;
  padding: 110rem 118rem;
  margin-top: 150rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-thanks__event {
    padding: 60rem 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__event {
    padding: 150rem 50rem;
  }
}
.p-thanks__event .p-thanks__title {
  color: #333;
  font-size: 36rem;
  line-height: 1.4;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__event .p-thanks__title {
    font-size: 40rem;
    margin-bottom: 80rem;
  }
}
.p-thanks__event .c-event__item a {
  display: flex;
  flex-direction: row;
  gap: 60rem;
  background: #fff;
  padding: 70rem 100rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-thanks__event .c-event__item a {
    padding: 70rem 50rem;
    gap: 32rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__event .c-event__item a {
    flex-direction: column;
    padding: 74rem 47rem;
    margin-top: 40rem;
  }
}
.p-thanks__event .c-event__item-imgwrap {
  width: 295rem;
  flex: none;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-thanks__event .c-event__item-imgwrap {
    width: 45%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__event .c-event__item-imgwrap {
    width: 100%;
  }
}
.p-thanks__event .c-event__item .c-card__textwrap {
  flex: 1;
}
.p-thanks__event .c-event__item .c-card__textwrap > p {
  font-size: 24rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-thanks__event .c-event__item .c-card__textwrap > p {
    font-size: 28rem;
  }
}

.p-contact__main {
  background-color: #F4F4F4;
  padding-bottom: 150rem;
}
.p-contact .p-page__mv {
  background-color: #fff;
}
.p-contact__inner {
  max-width: 1300rem;
  margin: 0 auto;
  padding-top: 114rem;
  width: 67.71%;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-contact__inner {
    width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__inner {
    max-width: unset;
    width: 100%;
  }
}
.p-contact__lead {
  font-size: 22rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__lead {
    font-size: 32rem;
  }
}
.p-contact__box {
  position: relative;
  margin: 120rem auto 100rem;
  background: #fff;
  width: 657rem;
  max-width: 100%;
  transform: translateX(2.5rem);
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box {
    margin-top: 150rem;
    margin-bottom: 108rem;
    width: calc(100% - 60rem);
    transform: unset;
  }
}
.p-contact__box::after {
  content: "";
  background: #313371;
  position: absolute;
  top: 10rem;
  left: 10rem;
  z-index: -1;
  display: block;
  width: 100%;
  height: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box::after {
    top: 16rem;
    right: -16rem;
    left: auto;
    /* display: block; */
    z-index: 0;
  }
}
.p-contact__box > dl {
  position: relative;
  background: #fff;
  display: block;
  z-index: 5;
  padding: 34rem;
}
.p-contact__box > dl dt {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}
.p-contact__box > dl dt p {
  position: relative;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 24rem;
  line-height: 1;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box > dl dt p {
    font-size: 38rem;
  }
}
.p-contact__box > dl dt p::before, .p-contact__box > dl dt p::after {
  content: "";
  display: block;
  width: 12rem;
  height: 1rem;
  background-color: #333;
  position: absolute;
  top: 50%;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box > dl dt p::before, .p-contact__box > dl dt p::after {
    width: 24rem;
  }
}
.p-contact__box > dl dt p::before {
  left: -14rem;
  transform: translate(-100%, -50%);
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box > dl dt p::before {
    left: -20rem;
  }
}
.p-contact__box > dl dt p::after {
  right: -14rem;
  transform: translate(100%, -50%);
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box > dl dt p::after {
    right: -20rem;
  }
}
.p-contact__box-number {
  margin-top: 23rem;
  font-size: 57.72rem;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2rem;
  font-family: "Roboto", sans-serif;
  font-weight: 700;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box-number {
    font-size: 80rem;
    gap: 0;
  }
}
.p-contact__box-number::before {
  content: "";
  background: url(../images/common/icon-phone.svg);
  width: 64rem;
  height: 64rem;
  background-size: contain;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box-number::before {
    width: 82rem;
    height: 82rem;
  }
}
.p-contact__box-open {
  border: 1px solid #333;
  font-weight: 500;
  font-size: 18rem;
  line-height: 1.8;
  text-align: center;
  width: 341rem;
  padding: 9rem 33rem;
  margin: 25rem auto 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__box-open {
    margin-top: 32rem;
    width: 504rem;
    padding: 11rem 39rem 10rem 44rem;
    font-size: 28rem;
  }
}
.p-contact__form {
  background-color: #fff;
  padding: 110rem 150rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-contact__form {
    padding: 60rem 50rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__form {
    padding: 108rem 49rem;
  }
}
.p-contact__form-text {
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: center;
}
.p-contact__form-text:first-of-type {
  font-size: 18rem;
  font-weight: 500;
  padding: 0 13rem 6rem;
  border-bottom: 1px solid #333;
  margin: 80rem auto 0;
  width: fit-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__form-text:first-of-type {
    font-size: 30rem;
    margin-top: 90rem;
    padding: 0 5rem 30rem;
  }
}
.p-contact__form-text:nth-of-type(2) {
  margin-top: 52rem;
  font-size: 17rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__form-text:nth-of-type(2) {
    font-size: 26rem;
    margin-top: 70rem;
  }
}
.p-contact__form-text--attention {
  margin-top: 17rem;
  font-size: 17rem;
  color: #D04E45;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__form-text--attention {
    font-size: 26rem;
    margin-top: 28rem;
  }
}
.p-contact__form-text--note {
  margin-top: 76rem;
  font-size: 17rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__form-text--note {
    margin-top: 90rem;
    font-size: 26rem;
  }
}
.p-contact__form-text--note a {
  text-decoration: underline;
}
.p-contact__confirm h1 {
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.1em;
  margin-bottom: 114rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__confirm h1 {
    font-size: 50rem;
    margin-bottom: 110rem;
  }
}
.p-contact__confirm h1 span {
  padding-left: 1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__confirm h1 span {
    padding: 0;
    display: block;
  }
}
.p-contact__confirm .p-contact__form .c-form__table dl {
  padding: 32rem 0;
  border-bottom: 1px solid #F3F3F3;
}
.p-contact__confirm .p-contact__form .c-form__table dl:not(:first-of-type) {
  margin-top: 0;
}
.p-contact__confirm .p-contact__form .c-form__table dt {
  margin-top: 0;
}
.p-contact__confirm .p-contact__form .c-form__table dd {
  color: #1A1A1A;
}
.p-contact__confirm .p-contact__form .wpcf7-form-control.wpcf7-previous {
  margin-top: 40rem;
  background: unset;
  border: 0;
  color: #333;
  border-bottom: 1px solid #333;
  line-height: 1.8;
  font-size: 17rem;
  letter-spacing: 0.05em;
  margin-bottom: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__confirm .p-contact__form .wpcf7-form-control.wpcf7-previous {
    font-size: 26rem;
    margin-bottom: 80rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-contact__confirm .dre-origin-form-table.c-form__table {
    margin-bottom: 0;
  }
}

@media only screen and (max-width: 1199.9px) {
  .p-catalog-thanks .p-thanks__inner {
    width: 100%;
  }
  .p-catalog-thanks .p-thanks__main {
    width: calc(100% - 100rem);
    margin: auto;
  }
}

.p-404 .l-inner {
  padding: 120rem 0 0;
}
.p-404__text {
  font-size: 24rem;
  line-height: 2.2;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-404__text {
    font-size: 30rem;
    line-height: 2.1;
  }
}

@media only screen and (max-width: 1199.9px) {
  .p-service h1 {
    font-size: 44rem;
  }
}

.p-concept__concept {
  padding: 150rem 0 250rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept {
    padding: 112rem 0 180rem;
  }
}
.p-concept__concept .c-title-english {
  text-align: center;
}
.p-concept__concept-box {
  display: flex;
  gap: 75rem;
  max-width: 1920rem;
  margin: 90rem auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-box {
    width: 100%;
    max-width: unset;
    flex-direction: column-reverse;
    gap: 80rem;
    margin-top: 80rem;
    margin-bottom: 0;
  }
}
.p-concept__concept-textwrap {
  margin-left: 230rem;
  flex: 1;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept__concept-textwrap {
    margin-left: 8.85%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-textwrap {
    margin-left: 0;
    width: calc(100% - 100rem);
    margin: 0 auto;
  }
}
.p-concept__concept-textwrap dt {
  color: #313371;
  font-size: 32rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-textwrap dt {
    font-size: 48rem;
    line-height: 1.8;
    text-align: center;
  }
}
.p-concept__concept-textwrap dd {
  margin-top: 50rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-textwrap dd {
    margin-top: 60rem;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-concept__concept-textwrap dd p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-textwrap dd p + p {
    margin-top: 1.55em;
  }
}
.p-concept__concept-textwrap dd .c-btn {
  width: 500rem;
  margin-top: 70rem;
  max-width: 52.1%;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-textwrap dd .c-btn {
    width: 598rem;
    max-width: 93.44%;
    margin: 70rem auto 0;
  }
}
.p-concept__concept-imgwrap {
  width: 885rem;
  max-width: 46.1%;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__concept-imgwrap {
    width: 100%;
    max-width: unset;
  }
}
.p-concept__feelings {
  background-color: #F4F4F4;
  padding-bottom: 141rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings {
    padding-bottom: 150rem;
  }
}
.p-concept__feelings-inner {
  position: relative;
  max-width: 1920rem;
  margin: auto;
  padding-top: 150rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-inner {
    width: 100%;
    max-width: unset;
    padding-top: 180rem;
  }
}
.p-concept__feelings-title {
  position: absolute;
  top: 0;
  left: 170rem;
  transform: translateY(-50%);
  writing-mode: vertical-lr;
  display: flex;
  align-items: center;
  font-family: "Noto Serif JP", serif;
  height: max-content;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-title {
    position: relative;
    writing-mode: unset;
    width: 100%;
    margin: 0;
    padding: 0;
    transform: unset;
    left: auto;
    top: auto;
    justify-content: center;
    text-align: center;
    margin-bottom: 90rem;
  }
}
.p-concept__feelings-title .ja {
  font-size: 40rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-title .ja {
    font-size: 50rem;
    letter-spacing: 0.1em;
    line-height: 1;
  }
}
.p-concept__feelings-title .en {
  color: #313371;
  font-size: 20rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  padding-left: 14rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-title .en {
    font-size: 32rem;
    letter-spacing: 0.1em;
    line-height: 1;
    padding-left: 0;
    margin-top: 20rem;
  }
}
.p-concept__feelings-imgwrap {
  position: relative;
  text-align: right;
}
.p-concept__feelings-img01 {
  width: 1289rem;
  max-width: 67.2%;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-img01 {
    width: 700rem;
    max-width: 93.34%;
  }
}
.p-concept__feelings-img02 {
  position: absolute;
  width: 503rem;
  max-width: 26.2%;
  top: 267rem;
  right: 90rem;
}
@media only screen and (max-width: 1919.9px) and (min-width: 1200px) {
  .p-concept__feelings-img02 {
    top: 76%;
    right: 4.5%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-img02 {
    width: 333rem;
    max-width: 44.4%;
    top: 230rem;
    right: 30rem;
  }
}
.p-concept__feelings-text {
  width: 1300rem;
  max-width: 67.8%;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text {
    width: calc(100% - 100rem);
    max-width: unset;
  }
}
.p-concept__feelings-text dt {
  color: #313371;
  font-size: 32rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 700;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text dt {
    font-size: 42rem;
    line-height: 1.7;
  }
}
.p-concept__feelings-text dt span {
  position: relative;
  display: block;
  color: #7677A8;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text dt span {
    display: flex;
  }
}
.p-concept__feelings-text dt span::before {
  content: "―";
  display: inline-block;
  width: 45rem;
  margin-right: 2rem;
  color: #7677A8;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text dt span::before {
    width: 41rem;
    margin-right: 20rem;
  }
}
.p-concept__feelings-text dd {
  width: 832rem;
  max-width: 64%;
  margin-top: 40rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text dd {
    width: 100%;
    max-width: unset;
    margin-top: 24rem;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-concept__feelings-text dd p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-text dd p + p {
    margin-top: 1.55em;
  }
}
.p-concept__feelings-box {
  overflow-x: hidden;
}
.p-concept__feelings-box:first-of-type .p-concept__feelings-text {
  margin: 80rem auto 100rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:first-of-type .p-concept__feelings-text {
    margin-top: 240rem;
  }
}
.p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text {
  margin: 100rem auto 100rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text {
    margin-top: 0;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text {
    margin-top: 100rem;
    margin-bottom: 236rem;
  }
}
.p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text dt, .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text dd {
  width: 832rem;
  max-width: 64%;
  margin-left: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text dt, .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-text dd {
    width: 100%;
    max-width: unset;
  }
}
.p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-imgwrap {
  text-align: left;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-imgwrap {
    text-align: center;
  }
}
.p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img01 {
  margin-right: 310rem;
}
@media only screen and (max-width: 1919.9px) and (min-width: 1200px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img01 {
    margin-right: 16.5%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img01 {
    margin: 0 auto;
    width: calc(100% - 60rem);
  }
}
.p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img02 {
  position: absolute;
  width: 503rem;
  max-width: 26.2%;
  top: auto;
  left: auto;
  bottom: 200rem;
  left: 90rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img02 {
    bottom: 58%;
    left: 4.6%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__feelings-box:nth-of-type(2) .p-concept__feelings-img02 {
    width: 333rem;
    max-width: 44.4%;
    left: 0;
    bottom: 117.42rem;
  }
}
.p-concept__initiatives {
  padding: 150rem 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives {
    padding: 160rem 0 428rem;
  }
}
.p-concept__initiatives .c-title-english {
  text-align: center;
}
.p-concept__initiatives-inner {
  max-width: 1580rem;
  width: 82.3%;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-inner {
    width: calc(100% - 100rem);
    max-width: unset;
  }
}
.p-concept__initiatives-nav {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  gap: 30rem;
  width: 1110rem;
  max-width: 85.4%;
  margin: 62rem auto 96rem;
  position: relative;
  z-index: 3;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept__initiatives-nav {
    max-width: 100%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-nav {
    gap: 20rem;
    width: calc(100% - 18rem);
    max-width: unset;
    margin-top: 90rem;
    margin-bottom: 119rem;
  }
}
.p-concept__initiatives-navlink {
  width: 350rem;
  height: 150rem;
  aspect-ratio: 35/15;
  max-width: calc((100% - 60rem) / 3);
  padding: 13rem 15rem;
  background-color: #A9AACA;
  box-shadow: 5rem 5rem 10rem 0px rgba(64, 65, 77, 0.08);
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-navlink {
    width: 306rem;
    max-width: calc((100% - 20rem) / 2);
    aspect-ratio: 306/150;
    padding: 13rem;
  }
}
.p-concept__initiatives-navlink:hover {
  background-color: #313371;
  opacity: 1;
}
.p-concept__initiatives-navlink p {
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  border: 1px solid #fff;
  color: #fff;
  font-size: 24rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  text-align: center;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-navlink p {
    font-size: 28rem;
    line-height: 1.4;
  }
}
.p-concept__initiatives-navlink p br.tabonly {
  display: none;
}
@media only screen and (max-width: 1499.9px) and (min-width: 1200px) {
  .p-concept__initiatives-navlink p br.tabonly {
    display: block;
  }
}
.p-concept__initiatives-list {
  counter-reset: number 0;
  margin-top: 100rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-list {
    margin-top: 119rem;
  }
}
.p-concept__initiatives-item {
  position: relative;
  padding-top: 220rem;
  margin-top: -220rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-item {
    padding-top: 131rem;
    margin-top: -131rem;
  }
}
.p-concept__initiatives-item::before {
  counter-increment: number 1;
  content: counter(number) " ";
  width: 57rem;
  height: 57rem;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: #313371;
  margin: auto;
  color: #fff;
  font-family: "Noto Serif JP", serif;
  font-size: 32rem;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 20rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-item::before {
    width: 78rem;
    height: 78rem;
    font-size: 43.79rem;
    margin-bottom: 30rem;
  }
}
.p-concept__initiatives-item::after {
  content: "";
  position: absolute;
  z-index: 3;
  top: 220rem;
  left: 50%;
  transform: translate(-50%, 5rem);
  border: 1px solid #fff;
  width: 47rem;
  height: 47rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-item::after {
    top: 131rem;
    width: 64rem;
    height: 64rem;
    transform: translate(-50%, 7rem);
  }
}
.p-concept__initiatives-item + .p-concept__initiatives-item {
  margin-top: -120rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-item + .p-concept__initiatives-item {
    margin-top: -11rem;
  }
}
.p-concept__initiatives-itemlead {
  text-align: center;
}
.p-concept__initiatives-itemlead dt {
  font-family: "Noto Serif JP", serif;
  font-size: 32rem;
  font-weight: 700;
  line-height: 1;
  color: #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemlead dt {
    font-size: 46rem;
    line-height: 1.8;
  }
}
.p-concept__initiatives-itemlead dd {
  margin-top: 24rem;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemlead dd {
    margin-top: 30rem;
    font-size: 32rem;
    line-height: 2;
    text-align: left;
  }
}
.p-concept__initiatives-sublist {
  margin-top: 45rem;
  background-color: #F8F8F8;
  padding: 100rem 0;
  counter-reset: sub-number 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist {
    margin-top: 50rem;
    padding: 70rem 45rem 85rem;
  }
}
.p-concept__initiatives-sublist > .flex {
  display: flex;
  gap: 80rem;
  width: 1090rem;
  max-width: 69%;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > .flex {
    width: 100%;
    max-width: unset;
    flex-direction: column;
    gap: 70rem;
  }
}
.p-concept__initiatives-sublist > .flex > li {
  width: 495rem;
  max-width: calc((100% - 80rem) / 2);
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > .flex > li {
    width: 100%;
    max-width: unset;
  }
}
.p-concept__initiatives-sublist > .flex > li .p-concept__initiatives-itemimg {
  width: auto;
  max-width: 100%;
  margin-bottom: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > .flex > li .p-concept__initiatives-itemimg {
    margin-bottom: 40rem;
  }
}
.p-concept__initiatives-sublist > li {
  width: 1090rem;
  max-width: 69%;
  margin: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 70rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept__initiatives-sublist > li {
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li {
    flex-direction: column-reverse;
    gap: 40rem;
    width: 100%;
    max-width: unset;
  }
}
.p-concept__initiatives-sublist > li + li {
  margin-top: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li + li {
    margin-top: 80rem;
  }
}
.p-concept__initiatives-sublist > li > dl {
  flex: 1;
  padding-left: 34rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li > dl {
    padding-left: 0;
  }
}
.p-concept__initiatives-sublist > li > dl .flex {
  display: flex;
  gap: 39rem;
  margin-top: 40rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li > dl .flex {
    column-gap: 20rem;
    row-gap: 30rem;
    flex-wrap: wrap;
  }
}
.p-concept__initiatives-sublist > li > dl .flex .flex-item {
  width: calc((100% - 117rem) / 4);
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li > dl .flex .flex-item {
    width: calc((100% - 20rem) / 2);
  }
}
.p-concept__initiatives-sublist > li > dl .flex .flex-item dt {
  font-weight: 500;
  text-align: center;
  margin: 20rem auto 7rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li > dl .flex .flex-item dt {
    margin-top: 24rem;
    margin-bottom: 6rem;
    font-size: 30rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li > dl .flex .flex-item dd {
    font-size: 28rem;
    letter-spacing: 0.03em;
    line-height: 1.9;
  }
}
.p-concept__initiatives-sublist > li.reverse {
  flex-direction: row-reverse;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li.reverse {
    flex-direction: column-reverse;
  }
}
.p-concept__initiatives-sublist > li.reverse > dl {
  padding-left: 0;
  padding-right: 34rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-sublist > li.reverse > dl {
    padding-right: 0;
  }
}
.p-concept__initiatives-itemheading {
  color: #5D5FA5;
  font-family: "Noto Serif JP", serif;
  font-size: 24rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 700;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemheading {
    font-size: 38rem;
    display: flex;
  }
}
.p-concept__initiatives-itemheading::before {
  counter-increment: sub-number 1;
  content: counter(sub-number) ".";
}
.p-concept__initiatives-itemtext {
  margin-top: 20rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemtext {
    margin-top: 15rem;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-concept__initiatives-itemtext small {
  display: block;
  margin-top: 5rem;
  font-size: 14rem;
  line-height: 2.2;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemtext small {
    margin-top: 15rem;
    font-size: 24rem;
    line-height: 1.8;
  }
}
.p-concept__initiatives-itemimg {
  width: 396rem;
  max-width: 36.4%;
  flex: none;
}
@media only screen and (max-width: 1199.9px) {
  .p-concept__initiatives-itemimg {
    width: 100%;
    margin: auto;
    max-width: unset;
  }
}
.p-concept .p-page__col2 {
  width: 1000rem;
  max-width: 52.1%;
  margin: auto;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-concept .p-page__col2 {
    width: unset;
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-concept .p-page__col2 {
    width: calc(100% - 40rem);
    max-width: unset;
  }
}

.p-hiraya .p-page__nomv .c-breadcrumb__wrap {
  border: 0;
}
.p-hiraya__mvwrap {
  border-top: 10rem solid #313371;
}
.p-hiraya__inner {
  width: 1400rem;
  max-width: 73%;
  margin: auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__inner {
    width: calc(100% - 100rem);
    max-width: unset;
  }
}
.p-hiraya__title {
  font-family: "Noto Serif JP", serif;
  font-size: 44rem;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.1em;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__title {
    font-size: 45rem;
  }
  .p-hiraya__title span {
    font-size: 50rem;
  }
}
.p-hiraya__lead {
  padding: 97rem 0 100rem;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__lead {
    padding: 80rem 0 120rem;
  }
}
.p-hiraya__lead-text {
  margin-top: 80rem;
  font-size: 20rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__lead-text {
    font-size: 31rem;
    line-height: 2.1;
  }
}
.p-hiraya__lead p + p {
  margin-top: 1.67em;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__lead p + p {
    margin-top: 1.55em;
  }
}
.p-hiraya__list {
  counter-reset: hiraya 0;
}
.p-hiraya__item {
  display: flex;
  align-items: center;
  gap: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item {
    flex-direction: column;
    gap: 90rem;
  }
}
.p-hiraya__item-textwrap {
  flex: 1;
}
.p-hiraya__item-textwrap dt {
  display: flex;
  align-items: center;
  position: relative;
  padding-left: 74rem;
  color: #313371;
  font-size: 32rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item-textwrap dt {
    padding-left: 95rem;
    font-size: 42rem;
    white-space: nowrap;
    padding-top: 50rem;
    margin-bottom: 40rem;
  }
}
.p-hiraya__item-textwrap dt::before {
  counter-increment: hiraya 1;
  content: counter(hiraya, decimal-leading-zero) " ";
  position: absolute;
  left: 0;
  bottom: 0;
  z-index: -1;
  font-size: 100rem;
  color: #f4f4f4;
  line-height: 1;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item-textwrap dt::before {
    font-size: 140rem;
    top: 0;
  }
}
.p-hiraya__item-textwrap dd {
  margin-top: 28rem;
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  color: #000;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item-textwrap dd {
    margin-top: 11rem;
    font-size: 30rem;
    line-height: 2.1;
  }
}
.p-hiraya__item-imgwrap {
  width: 518rem;
  max-width: 37%;
  flex-wrap: none;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item-imgwrap {
    width: 100%;
    max-width: unset;
  }
}
.p-hiraya__item:nth-of-type(even) {
  flex-direction: row-reverse;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item:nth-of-type(even) {
    flex-direction: column;
  }
}
.p-hiraya__item:not(:first-of-type) {
  margin-top: 80rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya__item:not(:first-of-type) {
    margin-top: 85.46rem;
  }
}
.p-hiraya .p-page__col2 {
  width: 1000rem;
  max-width: 71.43%;
  margin: 150rem auto 0;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-hiraya .p-page__col2 {
    width: unset;
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-hiraya .p-page__col2 {
    width: calc(100% - 40rem);
    max-width: unset;
    margin-top: 180rem;
  }
}

.p-staff .c-title-english {
  text-align: center;
}
.p-staff__greeting {
  margin-top: 147rem;
  position: relative;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting {
    margin-top: 95rem;
  }
}
.p-staff__greeting::before {
  content: "";
  position: absolute;
  top: 136rem;
  right: 0;
  z-index: -1;
  display: block;
  width: 41.35%;
  height: 107rem;
  background-color: #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting::before {
    display: none;
  }
}
.p-staff__greeting::after {
  content: "";
  position: absolute;
  bottom: 325rem;
  left: 0;
  z-index: -1;
  display: block;
  width: 58.65%;
  height: 544rem;
  background-color: #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting::after {
    bottom: 270rem;
  }
}
.p-staff__greeting-bg {
  position: relative;
  max-width: 1920rem;
  margin: 90rem auto 0;
  padding-bottom: 355rem;
  width: 100%;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-bg {
    margin-top: 100rem;
    padding-bottom: 285rem;
    overflow-x: hidden;
  }
}
.p-staff__greeting-bg::after {
  content: "";
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 0;
  display: block;
  width: 794rem;
  height: 682rem;
  background-image: url(../images/company/logo-bg.svg);
  background-repeat: no-repeat;
  background-size: contain;
  background-color: #fff;
  background-position-x: right;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-staff__greeting-bg::after {
    width: 40%;
    bottom: 10%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-bg::after {
    display: none;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-inner {
    width: 100%;
    margin: auto;
    padding-top: 579rem;
  }
}
.p-staff__greeting-textwrap {
  margin-left: 170rem;
  padding: 120rem 604rem 120rem 142rem;
  background-color: #fff;
  width: 1440rem;
  max-width: 75%;
}
@media only screen and (max-width: 1800px) and (min-width: 1600px) {
  .p-staff__greeting-textwrap {
    padding-left: 60rem;
  }
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-staff__greeting-textwrap {
    width: 75%;
    padding: 60rem 302rem 60rem 70rem;
    margin-left: 80rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-textwrap {
    width: calc(100% - 60rem);
    max-width: unset;
    padding: 185rem 36rem 100rem;
    margin-left: 0;
    margin: auto;
    position: relative;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-textwrap::before {
    content: "";
    position: absolute;
    bottom: -285rem;
    right: -194rem;
    z-index: 0;
    display: block;
    width: 674rem;
    height: 635rem;
    background-image: url(../images/company/logo-bg.svg);
    background-repeat: no-repeat;
    background-size: contain;
    background-color: #fff;
    background-position-x: right;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-textwrap::after {
    content: "";
    position: absolute;
    top: -20rem;
    right: -30rem;
    z-index: -1;
    display: block;
    width: 58.65%;
    height: 544rem;
    background-color: #313371;
  }
}
.p-staff__greeting-imgwrap {
  position: absolute;
  right: 0;
  top: 80rem;
  z-index: 1;
  width: 754rem;
}
@media only screen and (max-width: 1599.9px) and (min-width: 1200px) {
  .p-staff__greeting-imgwrap {
    width: 40%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-imgwrap {
    width: calc(100% - 100rem);
    top: 0;
    right: 50%;
    transform: translateX(50%);
  }
}
.p-staff__greeting-heading {
  font-size: 46rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: #313371;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-heading {
    font-size: 42rem;
  }
}
.p-staff__greeting-name {
  margin-top: 28rem;
  font-weight: 700;
  font-size: 36rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-family: "Noto Serif JP", serif;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-name {
    margin-top: 30rem;
    font-size: 38rem;
  }
}
.p-staff__greeting-text {
  margin-top: 55rem;
  font-size: 18rem;
  line-height: 2.5;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__greeting-text {
    margin-top: 60rem;
    font-size: 30rem;
    line-height: 2.1;
    position: relative;
  }
}
.p-staff__inner {
  width: 1300rem;
  max-width: 67.71%;
  margin: auto;
  position: relative;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-staff__inner {
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__inner {
    width: calc(100% - 60rem);
    max-width: unset;
  }
}
.p-staff__staff {
  margin-top: -144rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff {
    margin-top: -69rem;
  }
}
.p-staff__staff-topimg {
  margin-bottom: 100rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-topimg {
    margin-bottom: 120rem;
  }
}
.p-staff__staff-list {
  margin-top: 70rem;
  padding: 60rem 0;
  border-top: 4rem solid #313371;
  border-bottom: 4rem solid #313371;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-list {
    padding: 70rem 0;
  }
}
.p-staff__staff-item {
  padding: 50rem 75rem;
  background-color: #f8f8f8;
  display: flex;
  gap: 95rem;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-staff__staff-item {
    flex-direction: column;
    row-gap: 40rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-item {
    display: block;
    padding: 60rem 36rem;
  }
}
.p-staff__staff-item + .p-staff__staff-item {
  margin-top: 50rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-item + .p-staff__staff-item {
    margin-top: 60rem;
  }
}
.p-staff__staff-itemimg {
  width: 343rem;
  height: 343rem;
  aspect-ratio: 1/1;
  margin: 0 auto;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-itemimg {
    width: 300rem;
    height: 300rem;
    float: left;
    margin: 0;
    margin-right: 48rem;
  }
}
.p-staff__staff-itemtext {
  flex: 1;
}
.p-staff__staff-itemtext .position {
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 20rem;
  line-height: 1.5;
  letter-spacing: 0;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-itemtext .position {
    font-size: 30rem;
    margin-top: 65rem;
  }
}
.p-staff__staff-itemtext .name {
  display: flex;
  align-items: center;
  gap: 30rem;
  margin-top: 14rem;
  font-family: "Noto Serif JP", serif;
  font-weight: 700;
  font-size: 32rem;
  line-height: 1.5;
  letter-spacing: 0;
}
@media only screen and (max-width: 1499.9px) and (min-width: 1400px) {
  .p-staff__staff-itemtext .name {
    flex-direction: column;
    align-items: flex-start;
    row-gap: 4rem;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-itemtext .name {
    font-size: 40rem;
    flex-direction: column;
    align-items: baseline;
  }
}
.p-staff__staff-itemtext .name--en {
  display: inline-block;
  color: #A9AACA;
  font-size: 20rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
  font-weight: 600;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-itemtext .name--en {
    display: block;
    font-size: 26rem;
    margin-bottom: 75rem;
  }
}
.p-staff__staff-table {
  margin-top: 10rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-table {
    margin-top: 0;
  }
}
.p-staff__staff-table dl {
  padding: 30rem 0;
  display: flex;
  gap: 100rem;
  border-top: 2rem solid #eaeaea;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-table dl {
    gap: 51rem;
    padding: 40rem 0;
  }
}
.p-staff__staff-table dl dt {
  font-size: 20rem;
  font-weight: 500;
  line-height: 1.8;
  letter-spacing: 0.05em;
  flex: none;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-table dl dt {
    font-size: 32rem;
  }
}
.p-staff__staff-table dl dd {
  font-size: 18rem;
  line-height: 1.8;
  letter-spacing: 0.05em;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-table dl dd {
    font-size: 30rem;
  }
}
.p-staff__staff-table dl:first-of-type {
  border-top: 0;
}
.p-staff__staff-table dl:last-of-type {
  padding-bottom: 0;
}
.p-staff__staff-table dl.message {
  flex-direction: column;
  gap: 15rem;
}
@media only screen and (max-width: 1199.9px) {
  .p-staff__staff-table dl.message {
    gap: 22rem;
  }
}
.p-staff .p-page__col2 {
  width: 1000rem;
  max-width: 52.1%;
  margin: 150rem auto 0;
}
@media only screen and (max-width: 1399.9px) and (min-width: 1200px) {
  .p-staff .p-page__col2 {
    width: unset;
    max-width: 80%;
  }
}
@media only screen and (max-width: 1199.9px) {
  .p-staff .p-page__col2 {
    margin-top: 181rem;
    width: calc(100% - 40rem);
    max-width: unset;
  }
}

.u-bt-gray {
  border-top: 1px solid #ccc;
}

.u-bb-gray {
  border-bottom: 1px solid #ccc;
}

.u-d-inlineblock {
  display: inline-block;
}

.u-d-none {
  display: none;
}

.u-sponly {
  display: none;
}
@media only screen and (max-width: 1199.9px) {
  .u-sponly {
    display: block;
  }
}

@media only screen and (max-width: 1199.9px) {
  .u-pconly {
    display: none;
  }
}/*# sourceMappingURL=style.css.map */

/* top reform */
.p-index__reform {
  padding: 70rem 0;
  background-image: url(../images/index/bg-reform.jpg);
  background-size: cover;
}
.p-index__reform-inner {
  width: 879rem;
  margin: auto;
  background-color: rgba(255, 255, 255, 0.96);
  padding: 60rem 0;
}
.p-index__reform .c-title-english {
  text-align: center;
}
.p-index__reform .c-title-english__ja{
	line-height: 1.4;
}
.p-index__reform-text {
  font-size: 18rem;
  line-height: 2.2;
  letter-spacing: 0.05em;
  margin: 40rem auto;
  text-align: center;
}
@media only screen and (max-width: 1199.9px) {
  .p-index__reform-text {
    font-size: 32rem;
    line-height: 2.1;
	  margin:80rem auto;
	  text-align:left;
  }
}
.p-index__reform .c-btn {
  width: 350rem;
  height: 63rem;
  margin: auto;
}

@media only screen and (max-width: 1199.9px) {
	.p-index__reform .c-btn {
		height: 125rem;
		width: calc(100% - 60rem);
	}
}
@media only screen and (max-width: 1199.9px) {
	.p-index__reform-inner {
		width: calc(100% - 100rem);
		padding: 60rem 40rem;
	}
}