@charset "UTF-8";
/*color*/
/*font-family*/
/*filler color*/
/*text-shadow*/
/*media query break point*/
/*mainBP*/
/*gHeader用*/
/*quality用*/
/*salon用*/
/*lifeinfo用*/
/*design用*/
/*design用*/
/*grid settings*/
/* media query */
em,
i {
  font-style: normal;
}

i {
  display: inline-block;
}

.p-bg {
  background-image: url("../../images/top/bg.png");
  background-size: 20% auto;
  background-repeat: repeat-y;
  padding-bottom: 16rem;
}
@media only screen and (max-width: 768px) {
  .p-bg {
    padding-bottom: 8rem;
  }
}

:root {
  --dynamic-height: calc(100vh - 12vh - 85px);
}

.p-mv {
  width: 100%;
  height: 56vw;
  max-height: 100vh;
  min-height: 50vw;
  overflow: hidden;
  position: relative;
}
@media only screen and (max-width: 768px) {
  .p-mv {
    height: 78vh;
    min-height: 123vw;
    height: var(--dynamic-height);
    max-height: 61rem;
    max-height: 55rem;
  }
}
@media only screen and (max-width: 768px) and (max-height: 568px) {
  .p-mv {
    min-height: 112vw;
  }
}
.p-mv__cap {
  position: absolute;
  max-width: 1366px;
  width: 90%;
  left: 50%;
  transform: translate(-50%);
}
.p-mv__img {
  position: absolute;
  width: 100%;
  bottom: 0;
}
.p-mv__img img {
  width: 100%;
}
.p-mv__master {
  position: absolute;
  bottom: 0;
  left: 2vw;
  font-size: 5.2vw;
  letter-spacing: 0.04em;
  color: #9E8C7D;
}
.p-mv__master .ltt {
  display: inline-block;
}
.p-mv__master .ltt:nth-child(1) {
  transition-delay: 0.2s;
}
.p-mv__master .ltt:nth-child(2) {
  transition-delay: 0.4s;
}
.p-mv__master .ltt:nth-child(3) {
  transition-delay: 0.6s;
}
.p-mv__master .ltt:nth-child(4) {
  transition-delay: 0.8s;
}
.p-mv__master .ltt:nth-child(5) {
  transition-delay: 1s;
}
.p-mv__master .ltt:nth-child(6) {
  transition-delay: 1.2s;
}
.p-mv__master .ltt:nth-child(7) {
  transition-delay: 1.4s;
}
.p-mv__master .ltt:nth-child(8) {
  transition-delay: 1.6s;
}
.p-mv__master .ltt:nth-child(9) {
  transition-delay: 1.8s;
}
.p-mv__master .ltt:nth-child(10) {
  transition-delay: 2s;
}
.p-mv__master .ltt:nth-child(11) {
  transition-delay: 2.2s;
}
.p-mv__master .ltt:nth-child(12) {
  transition-delay: 2.4s;
}
.p-mv__master .ltt:nth-child(13) {
  transition-delay: 2.6s;
}
.p-mv__master .ltt:nth-child(14) {
  transition-delay: 2.8s;
}
.p-mv__master .ltt:nth-child(15) {
  transition-delay: 3s;
}
.p-mv__master .ltt:nth-child(16) {
  transition-delay: 3.2s;
}
.p-mv__master .ltt:nth-child(17) {
  transition-delay: 3.4s;
}
.p-mv__master .ltt:nth-child(18) {
  transition-delay: 3.6s;
}
.p-mv__master .ltt:nth-child(19) {
  transition-delay: 3.8s;
}
.p-mv__master .ltt:nth-child(20) {
  transition-delay: 4s;
}
.p-mv__master .ltt:nth-child(21) {
  transition-delay: 4.2s;
}
.p-mv__master .ltt:nth-child(22) {
  transition-delay: 4.4s;
}
.p-mv__master .ltt:nth-child(23) {
  transition-delay: 4.6s;
}
.p-mv__master .ltt:nth-child(24) {
  transition-delay: 4.8s;
}
.p-mv__overlay {
  position: absolute;
  top: calc(50% - 13vw);
  left: 50%;
  transform: translateX(-50%);
  width: 90%;
}
@media only screen and (max-width: 768px) {
  .p-mv__overlay {
    top: unset;
    bottom: 91vw;
    display: flex;
    justify-content: center;
    align-items: center;
  }
}
@media only screen and (max-width: 768px) and (max-height: 568px) {
  .p-mv__overlay {
    bottom: 86vw;
  }
}
.p-mv__overlay__copy {
  width: 20vw;
  max-width: 389px;
}
@media only screen and (max-width: 768px) {
  .p-mv__overlay__copy {
    width: 32vw;
  }
}
@media only screen and (max-width: 768px) and (max-height: 568px) {
  .p-mv__overlay__copy {
    width: 24vw;
  }
}
.p-mv__txt {
  position: absolute;
  top: 6vw;
  width: 100%;
  font-size: 36px;
  font-size: 3.6rem;
  font-size: min(2vw, 3.6rem);
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .p-mv__txt {
    top: unset;
    bottom: 73vw;
    font-size: 14px;
    font-size: 1.4rem;
  }
}
@media only screen and (max-width: 768px) and (max-height: 568px) {
  .p-mv__txt {
    bottom: 68vw;
  }
}

@media (min-width: 1200px) and (max-height: 995px) {
  .p-mv__txt {
    text-align: left;
    width: 36%;
    margin-left: 5%;
    top: 8vw;
    line-height: 1.5;
  }
  .p-mv__overlay {
    top: calc(50% - 6vw);
  }
}
.p-obi {
  background: #262626;
  padding: 0.1rem 0;
  /* 訴求・誘導・イベントなど */
}
.p-obi__wrap {
  margin: 4rem auto;
}
@media only screen and (max-width: 1080px) {
  .p-obi__wrap {
    margin: 1rem auto;
  }
}
.p-obi__wrap__list {
  display: grid;
  grid-template-columns: 1.8fr 1fr 1.5fr 1.5fr;
  align-items: center;
}
@media only screen and (max-width: 1080px) {
  .p-obi__wrap__list {
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-obi__wrap__list {
    grid-template-columns: 1fr;
    gap: 0.4rem;
  }
}
.p-obi__wrap__list__item:last-of-type .p-sokyu::after {
  display: none;
}
@media only screen and (max-width: 1080px) {
  .p-obi__wrap__list__item:nth-of-type(2n) .p-sokyu::after {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  .p-obi__wrap__list__item .p-sokyu::after {
    display: none;
  }
}
@media only screen and (max-width: 1080px) {
  .p-obi__wrap__list__item:nth-of-type(3), .p-obi__wrap__list__item:nth-of-type(4) {
    display: none;
  }
}
.p-obi__wrap__so {
  background: #9E8C7D;
  background-color: #936036;
  font-size: 36px;
  font-size: 3.6rem;
  font-size: min(2vw, 3.6rem);
  margin: 2rem auto;
  padding: 1rem 0;
  position: relative;
  display: flex;
  justify-content: center;
  align-items: center;
}
@media only screen and (max-width: 1080px) {
  .p-obi__wrap__so {
    font-size: 23px;
    font-size: 2.3rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-obi__wrap__so {
    font-size: 16px;
    font-size: 1.6rem;
    line-height: 1.4;
    display: block;
    margin: 0.7rem auto 1rem;
  }
}
.p-obi__wrap__so em {
  font-size: 1.34em;
}
.p-obi__wrap__so small {
  letter-spacing: 0;
  font-size: 14px;
  display: inline-block;
}
@media only screen and (max-width: 768px) {
  .p-obi__wrap__so small {
    font-size: 12px;
  }
}
.p-obi__wrap__so.mod--blue {
  background: linear-gradient(0deg, #2a3845 0%, #2f475d 40%, #3d5770 100%);
}
.p-obi__wrap__sobox {
  font-size: 2.6rem;
  display: block;
  position: relative;
  width: 21rem;
  margin-right: 2rem;
  background: #ffffff;
  /* background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 1) 10%, rgba(255, 255, 255, 1) 90%, rgba(255, 255, 255, 0) 100%); */
  color: #a67c52;
  padding: 0.5rem 2rem;
  /* border-radius: 33px; */
  line-height: 1.5;
  display: block;
}
@media only screen and (max-width: 768px) {
  .p-obi__wrap__sobox {
    margin: 0 auto 1rem;
    font-size: 2rem;
  }
}
.p-obi__wrap__sobox::after {
  content: "";
  position: absolute;
  width: calc(100% - 6px);
  height: calc(100% - 6px);
  border: 1px solid #936037;
  left: 3px;
  top: 3px;
}
.p-obi__ttls {
  display: grid;
  grid-template-columns: repeat(1, 1fr);
  padding: 2rem 0;
}
.p-obi__ttls-wrap {
  background: #6f5134;
  background: linear-gradient(0deg, #6f5134 0%, #8c6743 31%, #966f48 68%, #a67c52 100%);
}
.p-obi__ttls-wrap.mod--blue {
  background: linear-gradient(0deg, #2a3845 0%, #2f475d 40%, #3d5770 100%);
}
.p-obi__ttls--t1, .p-obi__ttls--t2 {
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
  padding: 1rem;
}
@media only screen and (max-width: 768px) {
  .p-obi__ttls--t1, .p-obi__ttls--t2 {
    padding-bottom: 1.5rem;
  }
}
.p-obi__ttls--t2 {
  max-width: 400px;
  width: 100%;
}
.p-obi__ttls--t1 {
  border-bottom: 1px solid;
}
.p-obi__ttl {
  line-height: 1;
  display: flex;
  justify-content: center;
  align-items: center;
  height: 3rem;
  font-size: 2.3rem;
}
@media only screen and (max-width: 768px) {
  .p-obi__ttl {
    font-size: 2rem;
  }
}
.p-obi__ttl-wrap {
  text-align: center;
  font-size: 2rem;
}
@media only screen and (max-width: 768px) {
  .p-obi__ttl-wrap {
    font-size: 1.7rem;
  }
}
.p-obi__ttl1 {
  font-size: 2rem;
  display: block;
  line-height: 1.5;
  height: unset;
}
@media only screen and (max-width: 768px) {
  .p-obi__ttl1 {
    font-size: 1.8rem;
  }
}
.p-obi__ttl1 em {
  font-size: 2.7rem;
}
@media only screen and (max-width: 768px) {
  .p-obi__ttl1 em {
    font-size: 2rem;
  }
}
.p-obi__ttl1 small {
  font-size: 0.8em;
}
.p-obi__ttl__btn {
  margin: 1rem auto;
}
.p-obi__ttl__btn a {
  display: block;
  width: 100%;
  background-color: #fff;
  padding: 1em 0;
  padding: 1rem;
  color: #A67C52;
}
.p-obi__ttl__btn a:hover {
  background-color: rgba(255, 255, 255, 0.85);
}
.p-obi__btn-wrap {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin: 3rem auto;
  width: 90%;
}
@media only screen and (max-width: 768px) {
  .p-obi__btn-wrap {
    grid-template-columns: repeat(1, 1fr);
    gap: 0.8rem;
  }
}
.p-obi__btn-wrap--1 {
  grid-template-columns: 1fr;
  max-width: 50rem;
}

.p-sokyu {
  position: relative;
  line-height: 1.2;
}
.p-sokyu::after {
  content: "";
  display: block;
  position: absolute;
  width: 1px;
  height: 5rem;
  background-color: #fff;
  right: 0;
  top: calc(50% - 2.5rem);
}
.p-sokyu--1 {
  display: grid;
  grid-template-columns: max-content max-content;
  gap: 2rem;
  justify-content: center;
}
@media only screen and (max-width: 768px) {
  .p-sokyu--1 {
    gap: 0.3rem;
  }
}
.p-sokyu__l {
  font-size: 25px;
  font-size: 2.5rem;
  font-size: min(1.3vw, 2.5rem);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__l {
    font-size: 20px;
    font-size: 2rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__l {
    font-size: 17px;
    font-size: 1.7rem;
    font-size: 15px;
    font-size: 1.5rem;
  }
}
.p-sokyu__l em {
  color: #A67C52;
  font-size: 1.76em;
}
@media only screen and (max-width: 768px) {
  .p-sokyu__l em {
    font-size: 1.4em;
  }
}
.p-sokyu__l span {
  display: block;
  font-size: 20px;
  font-size: 2rem;
  font-size: min(1vw, 2rem);
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__l span {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__l span {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
.p-sokyu__r {
  font-size: 39px;
  font-size: 3.9rem;
  font-size: min(2.2vw, 3.9rem);
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__r {
    font-size: 29px;
    font-size: 2.9rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__r {
    font-size: 25px;
    font-size: 2.5rem;
    font-size: 20px;
    font-size: 2rem;
    display: flex;
    align-items: flex-end;
  }
}
.p-sokyu__r em {
  color: #A67C52;
  font-size: 1.8em;
}
@media only screen and (max-width: 768px) {
  .p-sokyu__r em {
    font-size: 1.4em;
  }
}
.p-sokyu--2 {
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-sokyu__train {
  font-size: 39px;
  font-size: 3.9rem;
  font-size: min(2.3vw, 3.9rem);
  letter-spacing: 0.3rem;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__train {
    font-size: 28px;
    font-size: 2.8rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__train {
    font-size: 25px;
    font-size: 2.5rem;
    font-size: 19px;
    font-size: 1.9rem;
    border-top: 1px solid;
    padding-top: 0.4rem;
  }
}
.p-sokyu__train span {
  display: block;
  font-size: 14px;
  font-size: 1.4rem;
  font-size: min(0.7vw, 1.4rem);
  margin-bottom: -1.2vw;
  letter-spacing: 0;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__train span {
    font-size: 26px;
    font-size: 2.6rem;
    display: inline-block;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__train span {
    margin-right: 2rem;
    font-size: 1.6rem;
  }
}
.p-sokyu__train em {
  color: #A67C52;
  font-size: 1.8em;
}
@media only screen and (max-width: 768px) {
  .p-sokyu__train em {
    font-size: 1.4em;
  }
}
.p-sokyu--3 {
  display: flex;
  justify-content: center;
  align-items: center;
}
.p-sokyu__zeh {
  font-size: 32px;
  font-size: 3.2rem;
  font-size: min(1.8vw, 3.2rem);
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__zeh {
    font-size: 28px;
    font-size: 2.8rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__zeh {
    font-size: 25px;
    font-size: 2.5rem;
  }
}
.p-sokyu__zeh em {
  color: #A67C52;
}
.p-sokyu__zeh span {
  font-size: 17px;
  font-size: 1.7rem;
  font-size: min(0.8vw, 1.7rem);
  display: block;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__zeh span {
    font-size: 13px;
    font-size: 1.3rem;
  }
}
.p-sokyu__zeh__span {
  font-size: min(1.1vw, 2rem) !important;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__zeh__span {
    font-size: 15px !important;
  }
}
.p-sokyu--4 {
  display: grid;
  grid-template-columns: max-content max-content;
  justify-content: center;
  gap: 1rem;
}
.p-sokyu__l2 {
  font-size: 29px;
  font-size: 2.9rem;
  font-size: min(1.7vw, 2.9rem);
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  align-items: start;
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__l2 {
    font-size: 22px;
    font-size: 2.2rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__l2 {
    font-size: 17px;
    font-size: 1.7rem;
  }
}
.p-sokyu__r2 {
  font-size: 24px;
  font-size: 2.4rem;
  font-size: min(1.25vw, 2.4rem);
}
@media only screen and (max-width: 1080px) {
  .p-sokyu__r2 {
    font-size: 21px;
    font-size: 2.1rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-sokyu__r2 {
    font-size: 16px;
    font-size: 1.6rem;
  }
}
.p-sokyu__r2 em {
  color: #A67C52;
  font-size: 2.92em;
}

.p-cont {
  position: relative;
  margin: 16rem 0 8rem;
}
@media only screen and (max-width: 1080px) {
  .p-cont {
    margin: 8rem 0;
  }
}
.p-cont--sou {
  margin-bottom: 0;
}
.p-cont__img {
  width: calc(100% - (100% - 1366px) / 2);
  position: relative;
  overflow: hidden;
}
.p-cont__img img {
  width: 100%;
}
.p-cont__inf {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  right: calc(100vw - 1366px - (100% - 1366px) / 2);
  width: 37vw;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf {
    top: unset;
    transform: unset;
    padding: 3rem 1rem 2rem 5rem;
    padding-right: calc(100vw - 90% - 5%);
    right: 0 !important;
    width: 61vw;
    background: #2A3C4E;
    margin-top: -10rem;
    z-index: 1;
    position: relative;
  }
}
@media only screen and (max-width: 768px) {
  .p-cont__inf {
    padding: 2rem 1rem 2rem 2rem;
    width: 90%;
    margin-top: -1.5rem;
  }
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf-wrap {
    display: flex;
    justify-content: flex-end;
  }
}
.p-cont__inf__ttl {
  font-size: 90px;
  font-size: 9rem;
  font-size: min(5vw, 9rem);
  line-height: 1.3;
  position: relative;
  width: -moz-fit-content;
  width: fit-content;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__ttl {
    font-size: 60px;
    font-size: 6rem;
    position: absolute;
    top: -13rem;
    right: 10rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-cont__inf__ttl {
    font-size: 50px;
    font-size: 5rem;
    right: 5rem;
  }
}
.p-cont__inf__ttl span {
  font-size: 0.312em;
  display: block;
  position: absolute;
  white-space: nowrap;
}
.p-cont--kaname .p-cont__inf__ttl span {
  font-size: 0.28em;
  margin-left: -2.2rem;
  white-space: nowrap;
}
.p-cont__inf__ttl::before, .p-cont__inf__ttl::after {
  content: "";
  display: block;
  position: absolute;
  width: 5vw;
  height: 5vw;
  border: 0.7vw solid rgba(255, 255, 255, 0.5);
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__ttl::before, .p-cont__inf__ttl::after {
    width: 5rem;
    height: 5rem;
    border: 7px solid rgba(255, 255, 255, 0.5);
  }
}
.p-cont__inf__ttl::before {
  left: -2.4vw;
  top: -0.7vw;
  border-bottom: none;
  border-right: none;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__ttl::before {
    left: -2.5rem;
    top: -0.7rem;
  }
}
.p-cont__inf__ttl::after {
  right: -2.4vw;
  bottom: -3vw;
  border-top: none;
  border-left: none;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__ttl::after {
    right: -2rem;
    bottom: -3.5rem;
  }
}
.p-cont__inf__txt {
  font-size: 25px;
  font-size: 2.5rem;
  font-size: min(1.34vw, 2.5rem);
  line-height: 2.4;
  margin: 9rem auto 6rem;
  letter-spacing: 0.2em;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__txt {
    font-size: 14px;
    font-size: 1.4rem;
    margin: 0 auto 2rem;
  }
}
@media only screen and (max-width: 768px) {
  .p-cont__inf__txt {
    font-size: 12px;
    font-size: 1.2rem;
    letter-spacing: 0;
    margin: 0 auto 0.5rem;
    width: -moz-fit-content;
    width: fit-content;
  }
}
.p-cont__inf__btn {
  position: relative;
  justify-content: flex-end;
  padding-right: 3vw;
}
@media only screen and (max-width: 1080px) {
  .p-cont__inf__btn {
    padding-right: 0;
  }
}

.price {
  position: relative;
  width: 100%;
  margin: 1rem auto;
  border: 1px solid #fff;
  padding: 1.8rem;
  margin-top: 4rem;
  text-align: center;
  color: #fff;
  background: linear-gradient(0deg, #6f5134 0%, #8c6743 31%, #966f48 68%, #a67c52 100%);
}
.price.mod--blue {
  background: linear-gradient(0deg, #2a3845 0%, #2f475d 40%, #3d5770 100%);
}
.price .ttl {
  font-size: 2.4rem;
  font-size: 20px;
  font-size: 2rem;
  padding: 1rem;
  padding-top: unset;
  text-align: center;
  border-bottom: 1px solid #b2b2b2;
  color: #fff;
}
.price .ttl .last {
  display: inline-block;
  padding: 0 8%;
  border: 1px solid white;
  background-color: #6b0b0a;
  position: absolute;
  top: -2.2rem;
  left: 50%;
  transform: translateX(-50%);
}
.price-listwrap {
  display: grid;
  gap: 1rem;
  grid-template-columns: 1fr;
  max-width: 60rem;
  margin-inline: auto;
}
@media only screen and (max-width: 768px) {
  .price-listwrap {
    grid-template-columns: 1fr;
    gap: 0;
  }
}
.price_list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
.price_list li {
  position: relative;
}
.price_list li::before {
  content: "";
  position: absolute;
  bottom: -0.7rem;
  max-width: 45rem;
  width: 100%;
  height: 1px;
  background-color: #b2b2b2;
  left: 50%;
  transform: translateX(-50%);
}
.price_list li:last-of-type::before {
  display: none;
}
.price_list .sub {
  margin: 1rem auto -0.5rem;
}
.price_list .sub.novis {
  opacity: 0;
}
@media only screen and (max-width: 768px) {
  .price_list .sub.novis {
    display: none;
  }
}
.price_list_li {
  width: 100%;
  display: flex;
  justify-content: center;
  align-items: baseline;
  gap: 1rem 2rem;
  line-height: 1.4;
  text-align: left;
  margin-top: 0.5rem;
  flex-wrap: wrap;
}
.price_list_li span {
  font-size: 3rem;
  text-align: left;
  white-space: nowrap;
}
.price_list_li span em {
  font-size: 1.5em;
  line-height: 1.2;
}
.price_list_li span small {
  font-size: 1.8rem;
}
.price_cap {
  display: block;
  font-size: 1.1rem;
  line-height: 1.2;
  margin-top: 2rem;
  text-align: center;
}
@media only screen and (max-width: 768px) {
  .price_cap {
    text-align: left;
  }
}
.price_a {
  margin-top: 1rem;
}
.price_a a {
  max-width: 50rem;
  background: rgb(107, 10, 10);
  transition: 0.3s;
}
.price_a a:hover {
  background: rgb(87, 7, 7);
}
.price_b {
  margin-top: 1rem;
}
.price_b a {
  max-width: 50rem;
  background: rgb(38, 38, 39);
  transition: 0.3s;
}
.price_b a:hover {
  background: rgb(50, 50, 52);
}
.price_c {
  margin-top: 1rem;
}
.price_c a {
  max-width: 50rem;
  background: #8c6743;
  transition: 0.3s;
}
.price_c a:hover {
  background: #7b5835;
}

.p-limited {
  width: 90%;
  max-width: 1366px;
  margin: 0 auto;
  padding: 2rem 0;
}
.p-limited h3 {
  text-align: center;
  display: flex;
  justify-content: space-between;
  align-items: center;
  line-height: 1.4;
}
.p-limited h3 span {
  font-size: 18px;
  font-size: 1.8rem;
  padding: 0 1rem;
}
@media only screen and (max-width: 768px) {
  .p-limited h3 span {
    font-size: 1.6rem;
  }
}
.p-limited h3::before, .p-limited h3:after {
  content: "";
  opacity: 0;
  display: inline-block;
  flex-grow: 1;
  height: 1px;
  background-color: #fff;
}
.p-limited__wrap {
  display: flex;
  flex-flow: row nowrap;
  justify-content: space-between;
  align-items: stretch;
  margin: 0 auto;
  margin-top: 1rem;
}
@media only screen and (max-width: 1080px) {
  .p-limited__wrap {
    flex-direction: column;
    gap: 1rem;
  }
}
.p-limited__step {
  background: #fff;
  color: #010101;
  text-align: center;
  flex-grow: 1;
  position: relative;
  padding: 2.5rem 0;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
.p-limited__step::before, .p-limited__step::after {
  content: "";
  display: block;
  position: absolute;
  width: 10px;
  height: 55%;
  background: #101010;
}
@media only screen and (max-width: 1080px) {
  .p-limited__step::before, .p-limited__step::after {
    width: 0;
    height: 0;
    border-style: solid;
    border-right: 2.5rem solid transparent;
    border-left: 2.5rem solid transparent;
    border-top: 2.5rem solid #010101;
    border-bottom: 0;
    background-color: unset;
  }
}
.p-limited__step:first-child::before, .p-limited__step:first-child::after {
  display: none;
}
.p-limited__step:before {
  top: 0;
  left: -3%;
  bottom: auto;
  right: auto;
  transform-origin: right top;
  transform: rotate(-15deg) translateY(-5px);
}
@media only screen and (max-width: 1080px) {
  .p-limited__step:before {
    left: 50%;
    transform: translateX(-50%);
    top: -1rem;
  }
}
.p-limited__step:after {
  bottom: 0;
  left: -3%;
  top: auto;
  right: auto;
  transform-origin: right bottom;
  transform: rotate(15deg) translateY(5px);
}
@media only screen and (max-width: 1080px) {
  .p-limited__step:after {
    display: none;
  }
}
.p-limited__step-icon {
  color: #A67C52;
  line-height: 1.4;
  font-size: 2rem;
}
.p-limited__step-icon span {
  font-size: 1.5em;
}
.p-limited__step-img {
  width: 6rem;
  height: 6rem;
}
.p-limited__step-title {
  color: #A67C52;
}
.p-limited__step-text {
  font-size: 1.4rem;
  margin-top: 1rem;
}
.p-limited__entry {
  display: block;
  width: 100%;
  max-width: 500px;
  margin: 5rem auto 0;
  text-align: center;
  padding: 1.5rem;
  border: 1px solid rgba(255, 255, 255, 0.5);
  transition: 0.3s;
}
.p-limited__entry:hover {
  background-color: #2A3C4E;
}

.p-vr {
  max-width: 60rem;
  width: 90%;
  margin: 0 auto;
}
.p-vr-wrap {
  background: #151515;
  margin: 4rem 0;
  padding: 2rem 0 4rem;
}
.p-vr__ttl {
  text-align: center;
  font-size: 2.4rem;
  line-height: 1.4;
  margin: 1rem auto;
}
@media only screen and (max-width: 768px) {
  .p-vr__ttl {
    font-size: 1.8rem;
  }
}
.p-vr__txt {
  font-size: 1.4rem;
  text-align: center;
  line-height: 2;
  border-top: 1px solid;
  padding-top: 1rem;
}
@media only screen and (max-width: 768px) {
  .p-vr__txt {
    font-size: 1.2rem;
  }
}
.p-vr__img {
  overflow: hidden;
}
@media only screen and (max-width: 768px) {
  .p-vr__img {
    aspect-ratio: 1/0.8;
  }
}
.p-vr__img img {
  -o-object-fit: cover;
     object-fit: cover;
  width: 100%;
  height: 100%;
  transform: scale(1);
  transition: 0.3s;
}
.p-vr__overlay {
  position: absolute;
  left: 50%;
  transform: translateX(-50%);
  bottom: 0;
  color: #fff;
  font-weight: bold;
  font-size: 2.4rem;
  padding: 0.4rem 2rem;
  background-color: rgba(166, 124, 82, 0.85);
  width: 100%;
  text-align: center;
  transition: 0.3s;
}
@media only screen and (max-width: 768px) {
  .p-vr__overlay {
    font-size: 1.7rem;
  }
}
.p-vr__overlay em {
  font-family: "EB Garamond", serif;
}
.p-vr__overlay .u-arw--r {
  width: 1em;
  transition: 0.3s;
}
.p-vr__overlay .u-arw--r::before {
  width: 0.45em;
  height: 0.45em;
}
.p-vr a {
  margin-top: 2rem;
  display: block;
  position: relative;
}
.p-vr a:hover .p-vr__img img {
  transform: scale(1.1);
  transition: 0.3s;
}
.p-vr a:hover .p-vr__overlay {
  background-color: #A67C52;
  transition: 0.3s;
}
.p-vr a:hover .p-vr__overlay .u-arw--r {
  width: 1.5em;
  transition: 0.3s;
}
.p-vr__iframe-container {
  position: relative;
  width: 100%;
  height: 650px;
  overflow: hidden;
  scroll-behavior: none;
}
.p-vr__iframe-container iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

@media (max-width: 1518px) {
  .p-cont__img {
    width: 95%;
  }
  .p-cont__inf {
    right: calc(100vw - 90% - 5%);
  }
}
.p-small {
  font-size: 12px;
  text-align: center;
}

@media only screen and (max-width: 768px) {
  .u-spsmall {
    font-size: 8px;
  }
}

html:lang(en) .p-obi__wrap__list {
  grid-template-columns: 1fr 1fr;
  gap: 2rem 0;
}
@media only screen and (max-width: 1080px) {
  html:lang(en) .p-obi__wrap__list {
    grid-template-columns: 1fr;
  }
}
@media only screen and (max-width: 768px) {
  html:lang(en) .p-sokyu, html:lang(en) .p-sokyu__l2 {
    display: block;
    text-align: center;
  }
}
html:lang(en) .p-sokyu--1 {
  gap: 0;
}
html:lang(en) .p-sokyu--2::after {
  display: none;
}
html:lang(en) .p-sokyu__l2 {
  line-height: 2.55;
  display: block;
}
@media only screen and (max-width: 1080px) {
  html:lang(en) .p-sokyu__r2 {
    display: flex;
    align-items: center;
  }
}
@media only screen and (max-width: 1080px) {
  html:lang(en) .p-sokyu::after {
    display: none;
  }
}
@media only screen and (max-width: 768px) {
  html:lang(en) .p-nav__list {
    grid-template-columns: 1fr;
  }
  html:lang(en) .p-nav__list .u-sp {
    display: none;
  }
  html:lang(en) .p-nav__list .u-pc {
    display: block;
  }
}
@media only screen and (max-width: 768px) {
  html:lang(en) .p-nav__list__item a {
    padding: 1rem 0;
  }
}
@media only screen and (max-width: 768px) {
  html:lang(en) #concept .p-mv__detail,
  html:lang(en) #concept .p-mv__catch {
    line-height: 1.4;
  }
}
html:lang(en) .brandContents .anchorBtnWrap {
  background-color: #e6e6e6;
  padding: 30px 0;
  position: sticky;
  top: 0;
  z-index: 90;
}
@media only screen and (max-width: 768px) {
  html:lang(en) html:lang(en) .brandContents .anchorBtnWrap {
    position: static;
  }
}
html:lang(en) .brandContents .anchorBtn {
  display: flex;
  justify-content: space-between;
}
@media only screen and (max-width: 768px) {
  html:lang(en) html:lang(en) .brandContents .anchorBtn {
    flex-direction: column;
    gap: 1px;
  }
}
html:lang(en) .brandContents .anchorBtn li {
  width: 19%;
}
@media only screen and (max-width: 768px) {
  html:lang(en) html:lang(en) .brandContents .anchorBtn li {
    width: 100%;
  }
}

/* スマホのナビを遅く表示させたい場合 */
.spNavBar {
  bottom: -100%;
  transition-duration: 0.6s;
}
.spNavBar.on {
  bottom: -1px;
}/*# sourceMappingURL=top.css.map */