@charset "UTF-8";
/* font 設定 */
@import url("https://fonts.googleapis.com/css2?family=Cormorant+Infant:ital,wght@0,300..700;1,300..700&family=Cormorant:ital,wght@0,300..700;1,300..700&display=swap");
#pageContents {
  font-family: YakuHanMP, "Noto Serif JP", serif;
  background: url("../img/top/bg_texture.jpg") no-repeat center center;
  background-size: cover;
  background-attachment: fixed;
}
@media (max-width: 991px) {
  #pageContents {
    background-attachment: local;
  }
}
#pageContents {
  letter-spacing: 0.06em;
}
@media (max-width: 991px) {
  #pageContents {
    letter-spacing: inherit;
  }
}

.en {
  font-family: "Cormorant Infant", serif;
  font-weight: 400;
  overflow-wrap: anywhere;
}

/* 表示・非表示 */
.pc_only {
  display: block;
}

.pc_tab_only {
  display: block;
}

.tab_only {
  display: none;
}

.sp_tab_only {
  display: none;
}

.sp_only {
  display: none;
}

@media screen and (max-width: 960px) {
  .pc_only {
    display: none;
  }
  .pc_tab_only {
    display: block;
  }
  .tab_only {
    display: block;
  }
  .sp_tab_only {
    display: block;
  }
  .sp_only {
    display: none;
  }
}
@media screen and (max-width: 640px) {
  .pc_only {
    display: none;
  }
  .pc_tab_only {
    display: none;
  }
  .tab_only {
    display: none;
  }
  .sp_tab_only {
    display: block;
  }
  .sp_only {
    display: block;
  }
}
body main img {
  max-width: 100%;
  width: 100%;
  vertical-align: bottom;
}

body main a,
body main a:hover {
  text-decoration: none;
}

figure {
  position: relative;
}

picture {
  position: relative;
  display: inline-block;
}

figure figcaption, picture .caption,
.cap {
  position: absolute;
  bottom: 0;
  right: 0;
  z-index: 2;
  padding: 3px 5px;
  font-size: 10px;
  font-weight: 400;
  line-height: 1.2;
  letter-spacing: 0;
  background: rgba(0, 0, 0, 0.6);
  color: #fff;
}
figure figcaption.bgnone, picture .caption.bgnone,
.cap.bgnone {
  background: none;
  color: #000;
}
figure figcaption.bgnone.white, picture .caption.bgnone.white,
.cap.bgnone.white {
  color: #ffffff;
}
figure figcaption.outside, picture .caption.outside,
.cap.outside {
  position: static;
  padding: 0;
}
figure figcaption.outside.left, picture .caption.outside.left,
.cap.outside.left {
  text-align: left;
}
figure figcaption.outside.right, picture .caption.outside.right,
.cap.outside.right {
  text-align: right;
}

.ImgCap {
  font-size: 10px;
  padding-top: 5px;
  text-align: right;
}
.ImgCap.white {
  color: #ffffff;
}

small {
  font-size: clamp(10px, 1.1vw, 12px);
}

sup {
  font-size: 50%;
  vertical-align: top;
}

.flex {
  display: flex;
  flex-wrap: wrap;
}

.al {
  text-align: left;
}

.ar {
  text-align: right;
}

.ac {
  text-align: center;
}

.anno {
  font-size: clamp(10px, 1.1vw, 12px);
  line-height: 2;
  padding-top: 5px;
}

/*  */
.fade {
  transform: translateY(10px);
  opacity: 0;
  transition: 0.7s all ease;
}

.fade.is-show {
  transform: translateY(0);
  opacity: 1;
}

.blur {
  filter: blur(3px) brightness(3);
  opacity: 0;
  transition: 0.7s ease 0.2s;
}

.blur.filter_none {
  filter: none;
  opacity: 1;
}

.animCurtain {
  position: relative;
  background: rgba(255, 255, 255, 0.3);
}

.animCurtain figure {
  clip-path: inset(0 100% 0 0);
  transition: all 1.2s cubic-bezier(0.77, 0, 0.18, 1);
}

.animCurtain.is-active figure {
  clip-path: inset(0);
}

/*  */
.annotation_are {
  padding: 55px 0 75px;
}

.annotation_are .inner {
  max-width: 1420px;
  margin: 0 auto;
  padding: 0 20px;
}

.annotation_are p {
  font-size: clamp(10px, 1.1vw, 12px);
  line-height: 1.7;
  padding-left: 17px;
  position: relative;
}

.annotation_are p.asterisk::before {
  content: "※";
  position: absolute;
  left: 0;
  top: 0;
}

@media screen and (max-width: 640px) {
  .annotation_are {
    padding: 70px 0;
  }
}
/* slideScroll */
.swipeIcon {
  display: none;
}

@media screen and (max-width: 640px) {
  .slideBox {
    position: relative;
    overflow-x: auto;
  }
  .slideImg {
    max-width: 160vw;
    width: auto;
  }
  .swipeIcon {
    display: block;
    position: absolute;
    top: 50%;
    left: 150px;
    z-index: 301;
    width: 100px;
    animation: horizontal 1s ease-in-out infinite alternate;
  }
  @keyframes horizontal {
    0% {
      transform: translate(-30%, -50%);
    }
    100% {
      transform: translate(-70%, -50%);
    }
  }
}
/* 下層誘導
------------------------------------------*/
#all-contents {
  font-family: YakuHanMP, "Noto Serif JP", serif;
  padding-top: 130px;
  padding-bottom: 140px;
  background: url("../img/top/bg_texture.jpg") no-repeat center center;
  background-size: cover;
  background-attachment: fixed;
}
@media (max-width: 991px) {
  #all-contents {
    padding-top: 70px;
    padding-bottom: 80px;
    background-attachment: local;
  }
}
#all-contents .secTitle {
  font-size: clamp(24px, 3vw, 40px);
  color: #a08c6e;
  text-align: center;
  margin-bottom: 20px;
}
#all-contents .all-contents_list li {
  width: 20%;
}
#all-contents .all-contents_list a {
  display: block;
  position: relative;
  overflow: hidden;
}
@media (min-width: 992px) {
  #all-contents .all-contents_list a {
    aspect-ratio: 1/1.429;
  }
}
#all-contents .all-contents_list a:after {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  transform: scale(1);
  z-index: 0;
  transition: all 0.6s;
}
#all-contents .all-contents__concept a:after {
  background: url("../img/common/allcontents/concept.webp") no-repeat center center;
  background-size: cover;
}
#all-contents .all-contents__location a:after {
  background: url("../img/common/allcontents/location.webp") no-repeat center center;
  background-size: cover;
}
#all-contents .all-contents__access a:after {
  background: url("../img/common/allcontents/access.webp") no-repeat center center;
  background-size: cover;
}
#all-contents .all-contents__design a:after {
  background: url("../img/common/allcontents/design.webp") no-repeat center center;
  background-size: cover;
}
#all-contents .all-contents__plan a:after {
  background: url("../img/common/allcontents/plan.webp") no-repeat center center;
  background-size: cover;
}
#all-contents .all-contents_list a::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(22, 22, 22, 0.3);
  z-index: 1;
}
@media (hover: hover) {
  #all-contents .all-contents_list a:hover:after {
    transform: scale(1.08);
  }
}
#all-contents .copyWrap {
  color: #fff;
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
  z-index: 3;
  display: flex;
  justify-content: center;
  flex-direction: row-reverse;
}
#all-contents .copyWrap .subTtl {
  margin-left: 5px;
  letter-spacing: 0.03em;
  text-shadow: 0 0 12px #000;
}
@media (min-width: 992px) {
  #all-contents .copyWrap .subTtl {
    white-space: normal;
    writing-mode: vertical-rl;
    -ms-text-orientation: mixed;
    text-orientation: mixed;
    position: relative;
    -webkit-font-smoothing: antialiased;
  }
}
#all-contents .copyWrap h3 {
  font-size: 20px;
  letter-spacing: 0.09em;
  text-shadow: 0 0 12px #000;
}
#all-contents .tcu {
  text-combine-upright: all;
}
@media (min-width: 992px) {
  #all-contents .verticalText {
    writing-mode: vertical-rl;
    text-orientation: upright;
    -webkit-text-orientation: upright;
    -ms-text-orientation: upright;
    display: block;
    flex-shrink: 0;
  }
}
@media (max-width: 991px) {
  #all-contents .all-contents_list li {
    width: 50%;
  }
  #all-contents .all-contents_list a {
    aspect-ratio: 4/3;
  }
  #all-contents .copyWrap h3 {
    display: none;
  }
  #all-contents .copyWrap .subTtl {
    font-size: 20px;
  }
  #all-contents .all-contents_list li:last-child {
    width: 100%;
  }
  #all-contents .all-contents_list li:last-child a {
    aspect-ratio: 10/4;
  }
}