@charset "UTF-8";
/*　location page
----------------------------------------*/
/*----------------------------------------
	ページ共通のスタイル
----------------------------------------*/
.page-wrapper {
  overflow-x: hidden;
}
.page-wrapper * {
  font-feature-settings: normal;
}

.page-header {
  position: relative;
  z-index: 0;
  height: max(33.3333333333vw, 480px);
}

.page-header__bg {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.page-header__bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.page-header__bg .page-caption {
  position: absolute;
  right: 10px;
  bottom: 10px;
}

.page-container {
  max-width: 1080px;
  margin-inline: auto;
  padding: 0 20px;
  box-sizing: content-box;
}

.page-title {
  text-align: center;
}
.page-title h2 {
  font-size: 50px;
  font-weight: normal;
  color: #000;
  line-height: 1.48;
  text-transform: uppercase;
}
@media (max-width: 767px) {
  .page-title h2 {
    font-size: 40px;
  }
}
.page-title p {
  margin-top: 4px;
  font-size: 16px;
  line-height: 1.5;
  color: #333;
}
@media (max-width: 767px) {
  .page-title p {
    margin-top: 7px;
  }
}

.page-caption {
  font-size: 14px;
  line-height: 1.5;
  color: #fff;
  filter: drop-shadow(0 0 5px rgba(0, 0, 0, 0.7));
}
@media (max-width: 767px) {
  .page-caption {
    font-size: 11px;
  }
}

.is-pc {
  display: block;
}
@media (max-width: 767px) {
  .is-pc {
    display: none;
  }
}

.is-sp {
  display: none;
}
@media (max-width: 767px) {
  .is-sp {
    display: block;
  }
}

/*----------------------------------------
	ロケーションページ専用スタイル
----------------------------------------*/
/* 導入
----------------------------------------*/
.location-intro {
  padding: 80px 0 100px;
}
@media (max-width: 767px) {
  .location-intro {
    padding: 50px 0 38px;
  }
}

.location-intro__map {
  position: relative;
  margin-top: 56px;
}
@media (max-width: 575px) {
  .location-intro__map {
    margin: 26px calc(50% - 50vw) 0;
  }
}
.location-intro__map .area_cap {
  font-size: 11px;
  line-height: 1.875;
  color: #777;
  width: 70%;
  margin: 0 auto;
}
@media (max-width: 767px) {
  .location-intro__map .area_cap {
    width: 80%;
    font-size: 11px;
  }
}
.location-intro__map figcaption {
  position: absolute;
  right: 38px;
  bottom: 10px;
  margin: -1em auto 10px;
  font-size: 14px;
  line-height: 1.5;
  color: #777;
}
@media (max-width: 767px) {
  .location-intro__map figcaption {
    right: 20px;
    bottom: 0;
    font-size: 11px;
  }
}

.location-intro__text {
  margin-top: 60px;
  text-align: center;
  line-height: 2.2222222222;
}
@media (max-width: 767px) {
  .location-intro__text {
    margin-top: 26px;
    font-size: 12px;
  }
}

.location-intro__photo {
  margin-top: 60px;
}
@media (max-width: 575px) {
  .location-intro__photo {
    margin: 20px calc(50% - 50vw) 0;
  }
}
.location-intro__photo figcaption {
  margin-top: 10px;
  font-size: 15px;
  line-height: 1.4666666667;
  color: #777;
}
@media (max-width: 767px) {
  .location-intro__photo figcaption {
    padding: 0 20px;
    font-size: 11px;
  }
}

/* エリア紹介
----------------------------------------*/
.location-area {
  position: relative;
}
.location-area#terrace {
  padding-bottom: min(45.7142857143vw, 512px);
}
@media (max-width: 767px) {
  .location-area#terrace {
    padding-bottom: 88vw;
  }
}
.location-area#mitsukoshi {
  padding-bottom: min(36.7857142857vw, 412px);
}
@media (max-width: 767px) {
  .location-area#mitsukoshi {
    padding-bottom: 42.8571428571vw;
  }
}
@media (max-width: 575px) {
  .location-area#mitsukoshi {
    padding-bottom: 116.5333333333vw;
  }
}
.location-area#higashiyama {
  padding-bottom: min(45.7142857143vw, 512px);
}
@media (max-width: 767px) {
  .location-area#higashiyama {
    padding-bottom: 85.8666666667vw;
  }
}

.location-area__header {
  overflow: hidden;
  position: relative;
  z-index: 0;
  margin-inline: calc(50% - 50vw);
  height: max(48.6111111111vw, 700px);
}
@media (max-width: 767px) {
  .location-area__header {
    height: 53.3333333333vw;
  }
}

.location-area__header-bg {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.location-area__header-bg > .simpleParallax.simple-parallax-initialized {
  height: 100%;
}
.location-area__header-bg img {
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.location-area__header-bg .page-caption {
  position: absolute;
  top: 10px;
  right: 10px;
}
@media (max-width: 767px) {
  .location-area__header-bg .page-caption {
    top: initial;
    right: 6px;
    bottom: 6px;
  }
}

.location-area__box {
  position: relative;
  z-index: 0;
  width: 50%;
  margin-top: -160px;
  padding: 72px 30px 64px 0;
}
@media (max-width: 767px) {
  .location-area__box {
    width: 100%;
    margin-top: -35px;
    padding: 0;
  }
}
.location-area__box::before {
  position: absolute;
  z-index: -1;
  top: 0;
  right: 0;
  bottom: 0;
  content: "";
  width: 50vw;
  background: #fff;
}
@media (max-width: 767px) {
  .location-area__box::before {
    display: none;
  }
}

.location-area__name {
  font-size: 32px;
  font-weight: normal;
  line-height: 1.5;
  color: #000;
}
@media (max-width: 991px) {
  .location-area__name {
    font-size: 28px;
  }
}
@media (max-width: 767px) {
  .location-area__name {
    width: -moz-fit-content;
    width: fit-content;
    margin-left: -20px;
    padding: 14px 22px 0 20px;
    font-size: 24px;
    background: #fff;
  }
}

.location-area__copy {
  margin-top: 46px;
  font-size: 24px;
  line-height: 1.6666666667;
  color: #8C7245;
}
@media (max-width: 991px) {
  .location-area__copy {
    font-size: 18px;
  }
}
@media (max-width: 767px) {
  .location-area__copy {
    margin-top: 14px;
    font-size: 18px;
    line-height: 1.4444444444;
  }
}
#higashiyama .location-area__copy {
  color: #458C58;
}

.location-area__text {
  margin-top: 30px;
  font-size: 18px;
  line-height: 2.2222222222;
}
@media (max-width: 991px) {
  .location-area__text {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .location-area__text {
    margin-top: 12px;
    font-size: 12px;
    line-height: 2.1666666667;
  }
}

.location-area__photo {
  position: absolute;
}
#terrace .location-area__photo:nth-of-type(1) {
  right: 0;
  bottom: min(44.6428571429vw, 500px);
  width: min(32.1428571429vw, 360px);
}
@media (max-width: 767px) {
  #terrace .location-area__photo:nth-of-type(1) {
    right: -20px;
    bottom: 31.2vw;
    width: 32vw;
  }
}
#terrace .location-area__photo:nth-of-type(2) {
  left: 0;
  bottom: min(21.9642857143vw, 246px);
  translate: -12.5% 0;
  width: min(42.8571428571vw, 480px);
}
@media (max-width: 767px) {
  #terrace .location-area__photo:nth-of-type(2) {
    bottom: 53.3333333333vw;
    translate: 0;
    width: 42.6666666667vw;
  }
}
#terrace .location-area__photo:nth-of-type(3) {
  left: 50%;
  translate: 11.1111111111% 0;
  bottom: min(8.9285714286vw, 100px);
  width: min(24.1071428571vw, 270px);
}
@media (max-width: 767px) {
  #terrace .location-area__photo:nth-of-type(3) {
    left: 31.2vw;
    bottom: 17.6vw;
    translate: 0;
    width: 24vw;
  }
}
#mitsukoshi .location-area__photo:nth-of-type(1) {
  left: 0;
  bottom: min(8.9285714286vw, 100px);
  width: min(50.8928571429vw, 570px);
  clip-path: polygon(0 0, 90% 0, 100% 100%, 0% 100%);
}
@media (max-width: 991px) {
  #mitsukoshi .location-area__photo:nth-of-type(1) {
    left: -20px;
  }
}
@media (max-width: 575px) {
  #mitsukoshi .location-area__photo:nth-of-type(1) {
    bottom: 66.6666666667vw;
    width: min(80vw, 570px);
  }
}
#mitsukoshi .location-area__photo:nth-of-type(1) .page-caption {
  position: absolute;
  left: 10px;
  bottom: 5px;
}
#mitsukoshi .location-area__photo:nth-of-type(2) {
  right: 0;
  bottom: min(13.3928571429vw, 150px);
  width: min(50.8928571429vw, 570px);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 10% 100%);
}
@media (max-width: 991px) {
  #mitsukoshi .location-area__photo:nth-of-type(2) {
    right: -20px;
  }
}
@media (max-width: 575px) {
  #mitsukoshi .location-area__photo:nth-of-type(2) {
    bottom: 21.3333333333vw;
    width: min(80vw, 570px);
  }
}
#mitsukoshi .location-area__photo:nth-of-type(2) .page-caption {
  position: absolute;
  right: 10px;
  bottom: 5px;
}
#higashiyama .location-area__photo:nth-of-type(1) {
  right: 0;
  bottom: min(44.6428571429vw, 500px);
  width: min(32.1428571429vw, 360px);
}
@media (max-width: 767px) {
  #higashiyama .location-area__photo:nth-of-type(1) {
    right: initial;
    left: -20px;
    bottom: 37.8666666667vw;
    width: 32vw;
  }
}
#higashiyama .location-area__photo:nth-of-type(2) {
  left: 0;
  translate: -12.5% 0;
  bottom: min(21.9642857143vw, 246px);
  width: min(42.8571428571vw, 480px);
}
@media (max-width: 767px) {
  #higashiyama .location-area__photo:nth-of-type(2) {
    left: initial;
    right: -20px;
    bottom: 45.8666666667vw;
    width: 42.6666666667vw;
  }
}
#higashiyama .location-area__photo:nth-of-type(3) {
  left: 50%;
  translate: 11.1111111111% 0;
  bottom: min(8.9285714286vw, 100px);
  width: min(24.1071428571vw, 270px);
}
@media (max-width: 767px) {
  #higashiyama .location-area__photo:nth-of-type(3) {
    left: 35.4666666667vw;
    bottom: 14.4vw;
    width: 24vw;
  }
}
.location-area__photo .num-caption {
  position: absolute;
  left: 0;
  bottom: 0;
  width: min(2.1428571429vw, 24px);
  height: min(2.1428571429vw, 24px);
  display: grid;
  place-content: center;
  font-size: min(1.3392857143vw, 15px);
  line-height: 1;
  color: #fff;
  background: #000;
}
@media (max-width: 767px) {
  .location-area__photo .num-caption {
    width: 5.3333333333vw;
    height: 5.3333333333vw;
    font-size: 3.7333333333vw;
  }
}

.location-area__caption {
  position: absolute;
  right: 0;
  bottom: min(3.5714285714vw, 40px);
  font-size: 14px;
  line-height: 1.5;
  text-align: right;
}
@media (max-width: 767px) {
  .location-area__caption {
    bottom: 8vw;
    font-size: 11px;
  }
  #higashiyama .location-area__caption {
    bottom: 0;
  }
}
.location-area__caption small {
  font-size: 100%;
}

/* アクセス
----------------------------------------*/
.location-access {
  padding: 80px 0 120px;
}
@media (max-width: 767px) {
  .location-access {
    padding: 50px 0 80px;
  }
}

.location-access__text {
  margin-top: 52px;
  font-size: 18px;
  line-height: 2.2222222222;
  text-align: center;
}
@media (max-width: 991px) {
  .location-access__text {
    font-size: 16px;
  }
}
@media (max-width: 767px) {
  .location-access__text {
    margin-top: 20px;
    font-size: 12px;
  }
}

.location-access__map {
  position: relative;
  margin-top: 52px;
  border: 1px solid #ddd;
}
@media (max-width: 767px) {
  .location-access__map {
    margin-top: 20px;
  }
  .location-access__map img {
    max-width: none;
    width: min(200%, 1080px);
  }
}
.location-access__map figcaption {
  position: absolute;
  right: 10px;
  bottom: 10px;
  font-size: 14px;
  line-height: 1.5;
  color: #777;
}
@media (max-width: 767px) {
  .location-access__map figcaption {
    right: 0;
    bottom: -24px;
    font-size: 11px;
  }
}

.location-access__list {
  display: flex;
  align-items: center;
  margin-top: 86px;
}
@media (max-width: 767px) {
  .location-access__list {
    margin-top: 30px;
    display: block;
  }
}

.location-access__item {
  margin: 0 auto;
}
.location-access__item:nth-of-type(1) {
  width: min(42.1428571429vw, 472px);
}
@media (max-width: 767px) {
  .location-access__item:nth-of-type(1) {
    width: 335px;
  }
}
.location-access__item:nth-of-type(2) {
  width: min(38.3928571429vw, 430px);
}
@media (max-width: 767px) {
  .location-access__item:nth-of-type(2) {
    position: relative;
    width: 335px;
    margin-top: 42px;
  }
  .location-access__item:nth-of-type(2)::before {
    position: absolute;
    top: -21px;
    left: 50%;
    translate: -50% 0;
    content: "";
    height: 1px;
    width: calc(100vw - 40px);
    background: #ddd;
  }
}

.location-access-car {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  margin-top: 195px;
}
@media (max-width: 767px) {
  .location-access-car {
    display: block;
    margin-top: 60px;
  }
}

.location-access-car__bgArea {
  overflow: hidden;
  position: relative;
  z-index: 0;
  grid-column: 1/2;
  grid-row: 1/3;
  margin-left: calc((100vw - 200%) / -2);
}
@media (max-width: 767px) {
  .location-access-car__bgArea {
    margin-inline: calc(50% - 50vw);
    height: 53.3333333333vw;
  }
}

.location-access-car__bg {
  position: absolute;
  z-index: -1;
  inset: 0;
}
.location-access-car__bg > .simpleParallax.simple-parallax-initialized {
  height: 100%;
}
.location-access-car__bg img {
  height: 100%;
  width: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}
.location-access-car__bg .page-caption {
  position: absolute;
  right: 10px;
  bottom: 10px;
}

.location-access-car__box {
  grid-column: 2/3;
  grid-row: 1/2;
  margin-left: 70px;
}
@media (max-width: 767px) {
  .location-access-car__box {
    margin-left: 0;
    margin-top: 36px;
  }
}

.location-access-car__list {
  grid-column: 2/3;
  grid-row: 2/3;
  margin-left: 70px;
  margin-top: 32px;
  padding-top: 35px;
  border-top: 1px solid #ddd;
}
@media (max-width: 767px) {
  .location-access-car__list {
    margin-left: 0;
    margin-top: 20px;
    padding-top: 25px;
    padding-bottom: 17px;
    border-bottom: 1px solid #ddd;
  }
}

.location-access-car__title {
  font-size: 19px;
  line-height: 1.4736842105;
  color: #8C7245;
}
@media (max-width: 767px) {
  .location-access-car__title {
    font-size: 13px;
    text-align: center;
  }
}

.location-access-car__copy {
  margin-top: 18px;
  font-size: min(2.2222222222vw, 24px);
  line-height: 1.6666666667;
  color: #000;
}
@media (max-width: 767px) {
  .location-access-car__copy {
    margin-top: 5px;
    font-size: 18px;
    text-align: center;
  }
}

.location-access-car__text {
  margin-top: 30px;
  font-size: 18px;
  line-height: 2.2222222222;
}
@media (max-width: 991px) {
  .location-access-car__text {
    font-size: 15px;
  }
}
@media (max-width: 767px) {
  .location-access-car__text {
    margin-top: 20px;
    font-size: 12px;
    line-height: 2.3333333333;
    text-align: center;
  }
}

.location-access-car__item {
  width: min(39.1964285714vw, 439px);
}
@media (max-width: 767px) {
  .location-access-car__item {
    width: 335px;
    margin: 0 auto;
  }
}
.location-access-car__item:not(:first-of-type) {
  margin-top: 32px;
}
@media (max-width: 767px) {
  .location-access-car__item:not(:first-of-type) {
    margin-top: 18px;
  }
}

/*----------------------------------------
	アニメーション
----------------------------------------*/
[data-scroll-anima] {
  opacity: 0;
  transition: opacity 1.7s ease;
}

[data-scroll-anima=true] {
  opacity: 1;
}/*# sourceMappingURL=location.css.map */