@charset "UTF-8";
/* 
  css設定 @charsetが消されるsass仕様へのハック用コメントです。削除しないでください。新規作成時も必須！
 */
@keyframes fadeIn {
  100% {
    opacity: 1;
  }
}

@keyframes verticalFade {
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes horizontalFade {
  100% {
    opacity: 1;
    transform: translateX(0);
  }
}

@keyframes circleFade {
  100% {
    width: 342rem;
    height: 342rem;
  }
}

@keyframes circleFadeSp {
  100% {
    width: 222rem;
    height: 222rem;
  }
}

@keyframes moveRight {
  100% {
    left: 100%;
  }
}

#top .site-header {
  position: absolute;
  background: #fff;
}

@media screen and (max-width: 768px) {
  #top .site-header {
    position: fixed;
  }
}

#top .mainVisual {
  position: relative;
}

#top .mainVisual .movie {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  overflow: hidden;
  z-index: 20;
  background-color: #000;
}

#top .mainVisual .movie video {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 100vw;
  transform: translate(-50%, -50%);
}

#top .mainVisual .bg {
  opacity: 0;
}

#top .mainVisual .thumbs {
  position: absolute;
  bottom: 20rem;
  left: 50%;
  transform: translateX(-50%);
  text-align: center;
  z-index: 10;
}

#top .mainVisual .thumbs li {
  display: inline-block;
  width: 10rem;
  height: 10rem;
  border: 1px solid #5C5E62;
  background-color: #5C5E62;
  transition: background-color .5s;
  margin-right: 15rem;
  z-index: 10;
  cursor: pointer;
}

#top .mainVisual .thumbs li:last-child {
  margin-right: 0;
}

#top .mainVisual .thumbs li.on {
  pointer-events: none;
  background-color: #fff;
}

#top .mainVisual .scenes {
  position: relative;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#top .mainVisual .scenes .images {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0;
  transition: opacity 2.5s;
}

#top .mainVisual .scenes .images.on {
  opacity: 1;
}

#top .mainVisual .scenes .image02 .in {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

#top .mainVisual .scenes .image02 .in.pc {
  background-color: #fff;
}

#top .mainVisual .scenes .image02 .in.pc .img01, #top .mainVisual .scenes .image02 .in.pc .img02, #top .mainVisual .scenes .image02 .in.pc .img03, #top .mainVisual .scenes .image02 .in.pc .img04,
#top .mainVisual .scenes .image02 .in.pc .img05, #top .mainVisual .scenes .image02 .in.pc .img06, #top .mainVisual .scenes .image02 .in.pc .img07, #top .mainVisual .scenes .image02 .in.pc .img08 {
  position: absolute;
  width: 25%;
  height: auto;
}

#top .mainVisual .scenes .image02 .in.pc .center {
  position: absolute;
  top: 50%;
  left: 0;
  width: 100%;
  transform: translateY(-50%);
}

#top .mainVisual .scenes .image02 .in.pc .img01 {
  top: 0;
  left: 0;
}

#top .mainVisual .scenes .image02 .in.pc .img02 {
  top: 0;
  left: 25%;
}

#top .mainVisual .scenes .image02 .in.pc .img03 {
  top: 0;
  left: 50%;
}

#top .mainVisual .scenes .image02 .in.pc .img04 {
  top: 0;
  left: 75%;
}

#top .mainVisual .scenes .image02 .in.pc .img05 {
  bottom: 0;
  left: 0%;
}

#top .mainVisual .scenes .image02 .in.pc .img06 {
  bottom: 0;
  left: 25%;
}

#top .mainVisual .scenes .image02 .in.pc .img07 {
  bottom: 0;
  left: 50%;
}

#top .mainVisual .scenes .image02 .in.pc .img08 {
  bottom: 0;
  left: 75%;
}

#top .mainVisual .scenes .image02 .in.pc .up {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
}

#top .mainVisual .scenes .image02 .in.pc .up div {
  position: absolute;
  top: 0;
  width: 25%;
}

#top .mainVisual .scenes .image02 .in.pc .up .img02 {
  left: 25%;
}

#top .mainVisual .scenes .image02 .in.pc .up .img03 {
  left: 50%;
}

#top .mainVisual .scenes .image02 .in.pc .up .img04 {
  left: 75%;
}

#top .mainVisual .scenes .text01 {
  position: absolute;
  top: 45%;
  left: 50%;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  transform: translate(-50%, -45%);
  font-size: 48rem;
  line-height: 1.8;
  letter-spacing: 18rem;
  color: #696B6F;
  z-index: 19;
}

#top .open-image {
  position: relative;
}

#top .open-image:after, #top .open-image:before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: block;
}

#top .open-image:after {
  background-color: white;
  opacity: 1;
  transition: transform 1.7s,opacity 2.5s;
  transform: translateZ(0) scaleX(1);
  transform-origin: center left;
  z-index: 3;
}

#top .open-image:before {
  background-color: rgba(0, 0, 0, 0.2);
  opacity: 1;
  transition: transform 1.6s .3s,opacity 2.5s;
  transform: translateZ(0) scaleX(1);
  transform-origin: center left;
  z-index: 2;
}

#top .open-image.on:after {
  transform: translateZ(0) scaleX(0);
}

#top .open-image.on:before {
  transform: translateZ(0) scaleX(0);
}

#top .mess-action span {
  display: block;
  overflow: hidden;
}

#top .mess-action .inner {
  transition: width 1.5s 2s;
  width: 0%;
}

#top .mess-action .inner span {
  width: 600rem;
  width: 90vw;
  max-width: 650rem;
}

#top .mess-action.on .inner {
  width: 100%;
}

#top div.intro {
  text-align: center;
}

#top div.intro h2 {
  line-height: 1.7;
  font-size: 40rem;
  font-weight: normal;
  color: #FCF2DF;
}

#top div.intro .lead {
  font-size: 13rem;
  font-weight: normal;
  color: #FCF2DF;
}

#top div.intro .title-wrap {
  display: none;
  background-color: #C3B594;
  padding: 47rem 0 32rem;
}

#top div.intro .points {
  padding: 40rem 0;
  max-width: 820px;
}

#top div.intro .price {
  padding: 40rem 0 0;
  max-width: 1000px;
}

#top div.intro .header {
  margin-bottom: 150rem;
}

#top div.intro .information h3 {
  padding-bottom: 25rem;
  line-height: 1;
  font-size: 30rem;
}

#top div.intro .information .lead + .lead {
  padding-top: 2em;
}

#top div.intro .information {
  margin: 150rem auto 75rem;
  box-sizing: border-box;
  width: 900rem;
  background-color: #fff;
  box-shadow: 0px 5px 5px #ccc;
  padding-bottom: 110rem;
}

#top div.intro .information .wrapper {
  padding: 122rem 0 0;
  box-sizing: border-box;
}

#top div.intro .information .info-box {
  padding-bottom: 55rem;
}

#top div.intro .information .title {
  font-size: 24rem;
  padding-bottom: 55rem;
  font-weight: normal;
}

#top div.intro .information .info-lead {
  font-size: 30rem;
  margin-bottom: 50rem;
}

#top div.intro .information .holiday {
  font-size: 15rem;
  line-height: 2;
  margin-bottom: 50rem;
}

#top div.intro .information .entryButton {
  display: inline-block;
  width: 38%;
  padding-bottom: 20rem;
}

#top div.intro .information .entryButton a {
  display: block;
}

#top div.intro .information .entryButton.btn02 {
  margin-left: 4%;
}

#top div.intro .information .text01 {
  font-size: 13rem;
  line-height: 2;
  padding-bottom: 40rem;
}

#top div.intro .information .text02 {
  display: inline-block;
  font-size: 13rem;
  line-height: 2;
  padding: 10rem 20rem;
  border: 1px solid;
  margin-bottom: 40rem;
}

#top div.intro .information .banners {
  width: 80%;
  margin: auto;
}

#top div.intro .information .banners li {
  padding-bottom: 20rem;
}

#top div.intro .information .banners li:last-child {
  padding-bottom: 0;
}

#top .banners {
  max-width: 720rem;
  width: 80%;
  margin: 0 auto 100px;
}

#top .banners li {
  padding-bottom: 20rem;
}

#top .banners li:last-child {
  padding-bottom: 0;
}

#top section.concept {
  position: relative;
}

#top section.concept .js-scroll {
  transition-delay: 2.5s;
}

#top section.concept .in {
  position: absolute;
  top: 260rem;
  left: 65%;
  transform: translateX(-50%);
  color: #5D6970;
  width: 90%;
  max-width: 650rem;
  text-align: center;
}

#top section.concept .concept-title {
  font-size: 24rem;
  line-height: 1.5;
  padding-bottom: 22rem;
  font-weight: normal;
}

#top section.concept .lead {
  font-size: 45rem;
  line-height: 1.5;
  padding-bottom: 35rem;
}

#top section.concept .lead span {
  letter-spacing: .1em;
}

#top section.concept .concept-lead {
  font-size: 20rem;
  line-height: 1.5;
  padding-bottom: 24rem;
}

#top section.concept .text {
  font-size: 13rem;
  line-height: 2;
}

#top .sections {
  padding: 95rem 0 90rem;
}

#top .sections .inner {
  margin: 0 auto;
  width: 90%;
  max-width: 1300rem;
  display: flex;
  justify-content: space-between;
  align-items: start;
}

#top .sections .texts {
  margin-top: 60rem;
  position: relative;
  left: -60rem;
  width: 40%;
  padding: 50rem 65rem;
  box-sizing: border-box;
  align-self: stretch;
  z-index: 3;
}

#top .sections .img,
#top .sections .images,
#top .sections .open-image {
  width: 60%;
}

#top .sections .title {
  font-size: 36rem;
  line-height: 1.3;
  display: inline-block;
  margin-bottom: 12rem;
  position: relative;
  font-weight: normal;
  letter-spacing: .1em;
}

#top .sections .title:after {
  content: "";
  display: block;
  position: absolute;
  left: 100%;
  margin-left: -40rem;
  bottom: 0;
  width: 80rem;
  transform: rotate(-45deg);
  height: 1px;
  background-color: #5D6970;
}

#top .sections .title .ja {
  font-size: 13rem;
  position: absolute;
  left: 100%;
  margin-left: 15rem;
  top: 100%;
  margin-top: 10rem;
  width: 190rem;
  font-family: 'Shippori Mincho', serif;
}

#top .sections .header {
  padding-bottom: 44rem;
}

#top .sections .text01 {
  font-size: 24rem;
  line-height: 2;
  padding-bottom: 30rem;
}

@media screen and (max-width: 1500px) {
  #top .sections .text01 {
    font-size: 22rem;
  }
}

#top .sections .button {
  max-width: 320rem;
}

#top .sections .button a {
  font-size: 15rem;
  position: relative;
  background-color: transparent;
  border: 1px solid #57BEC1;
  color: #57BEC1;
}

#top .sections .button a::after {
  content: "";
  position: absolute;
  display: block;
  top: 50%;
  right: 40rem;
  width: 9rem;
  height: 9rem;
  border-right: 1px solid #57BEC1;
  border-bottom: 1px solid #57BEC1;
  transform: translateY(-50%) rotate(-45deg);
}

#top .sections .button a::before {
  background-color: #57BEC1;
}

#top .sections .button a:hover {
  color: #fff;
}

#top .sections .button a:hover::after {
  border-color: #fff;
}

#top .sections .img {
  position: relative;
}

#top .sections .images {
  position: relative;
  z-index: 2;
}

#top .sections .images img {
  -webkit-mask-image: url(../images/top/mask.png);
  -webkit-mask-repeat: no-repeat;
  -webkit-mask-size: auto 200%;
  -webkit-mask-position: 0px -900px;
  mask-image: url(../images/top/mask.png);
  mask-repeat: no-repeat;
  mask-size: auto 200%;
  mask-position: 0px -900px;
  transition: -webkit-mask-position 1.4s, mask-position 1.4s;
}

#top .sections .images.on img {
  -webkit-mask-position: 0px 0px;
  mask-position: 0px 0px;
}

#top .guides {
  text-align: center;
  margin-top: 100px;
}

#top .guides .movies {
  display: inline-block;
  width: 40%;
  margin: auto;
}

#top .guides .guide-movie {
  margin: 0 auto 100px;
}

#top .guides .guide-movie video {
  width: 100%;
  height: 100%;
}

#top .guides .guide-movie .click-btn {
  max-width: 560px;
  width: 100%;
  margin: auto;
  text-align: center;
  clear: both;
}

#top .guides .guide-movie video:focus {
  outline: none;
}

#top .guides .guide-movie .modal-wrapper {
  z-index: 999;
  position: fixed;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  padding: 10% 10px;
  text-align: center;
}

#top .guides .guide-movie .modal-wrapper:not(:target) {
  opacity: 0;
  visibility: hidden;
  transition: opacity .3s, visibility .3s;
}

#top .guides .guide-movie .modal-wrapper:target {
  opacity: 1;
  visibility: visible;
  transition: opacity .4s, visibility .4s;
  background: rgba(0, 0, 0, 0.8) !important;
}

#top .guides .guide-movie .modal-wrapper::after {
  display: inline-block;
  height: 100%;
  margin-left: -.05em;
  vertical-align: middle;
  content: "";
}

#top .guides .guide-movie .modal-wrapper .modal-window {
  box-sizing: border-box;
  display: inline-block;
  z-index: 20;
  position: relative;
  width: 94%;
  max-width: 800px;
  padding: 0;
  border-radius: 2px;
  vertical-align: middle;
}

#top .guides .guide-movie .modal-wrapper .modal-window .modal-content {
  max-height: 80vh;
  overflow-y: auto;
  text-align: left;
}

#top .guides .guide-movie .modal-overlay {
  z-index: 10;
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  border-radius: 0 !important;
  background: rgba(0, 0, 0, 0.8) !important;
}

#top .guides .guide-movie .modal-overlay:hover {
  opacity: 1 !important;
}

#top .guides .guide-movie .modal-wrapper .modal-close, #top .guides .guide-movie .modal-wrapper .modal-close02 {
  z-index: 20;
  position: absolute;
  top: -45px;
  right: -45px;
  width: 45px;
  color: #fff !important;
  font-size: 45px;
  font-weight: 700;
  line-height: 45px;
  text-align: center;
  text-decoration: none;
  text-indent: 0;
  padding: 0;
}

#top .guides .guide-movie .modal-wrapper .modal-close:hover, #top .guides .guide-movie .modal-wrapper .modal-close02:hover {
  color: #2b2e38 !important;
}

#top .section-position .texts,
#top .section-location .texts,
#top .section-plan .texts,
#top .section-asset .texts,
#top .section-brand .texts {
  order: 0;
  left: 60rem;
}

#top .section-position .open-image,
#top .section-location .open-image,
#top .section-plan .open-image,
#top .section-asset .open-image,
#top .section-brand .open-image {
  order: 1;
}

#top .section-access .open-image .caption,
#top .section-design .open-image .caption,
#top .section-lgente .open-image .caption,
#top .section-merit .open-image .caption {
  right: auto;
  left: 0;
}

#top .section-position {
  background-color: #FFFFFF;
}

#top .section-position .texts {
  background-color: #FFFFFF;
}

#top .section-access {
  background-color: #E8F2F8;
}

#top .section-access .texts {
  background-color: #E8F2F8;
}

#top .section-access .open-image::after {
  background-color: #E8F2F8;
}

#top .section-location {
  background-color: #FFFFFF;
}

#top .section-location .texts {
  background-color: #FFFFFF;
}

#top .section-design {
  color: #fff;
  background-color: #57BEC1;
}

#top .section-design .open-image::after {
  background-color: #57BEC1;
}

#top .section-design .title:after {
  background-color: #fff;
}

#top .section-design .texts {
  background-color: #57BEC1;
}

#top .section-design .button a {
  border-color: #fff;
  border: 1px solid #fff;
  color: #fff;
}

#top .section-design .button a::after {
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transform: translateY(-50%) rotate(-45deg);
}

#top .section-design .button a::before {
  background-color: #fff;
}

#top .section-design .button a:hover {
  color: #57BEC1;
}

#top .section-design .button a:hover::after {
  border-color: #57BEC1;
}

#top .section-plan {
  background-color: #FFFFFF;
}

#top .section-plan .texts {
  background-color: #FFFFFF;
}

#top .section-lgente {
  background-color: #FCE5E5;
}

#top .section-lgente .texts {
  background-color: #FCE5E5;
}

#top .section-lgente .open-image::after {
  background-color: #FCE5E5;
}

#top .section-asset {
  background-color: #E8F2F8;
}

#top .section-asset .texts {
  background-color: #E8F2F8;
}

#top .section-asset .open-image::after {
  background-color: #E8F2F8;
}

#top .section-merit {
  background-color: #FFFFFF;
}

#top .section-merit .texts {
  background-color: #FFFFFF;
}

#top .section-brand {
  color: #fff;
  background-color: #869ED1;
}

#top .section-brand .open-image::after {
  background-color: #869ED1;
}

#top .section-brand .title:after {
  background-color: #fff;
}

#top .section-brand .texts {
  background-color: #869ED1;
}

#top .section-brand .button a {
  border-color: #fff;
  border: 1px solid #fff;
  color: #fff;
}

#top .section-brand .button a::after {
  border-right: 1px solid #fff;
  border-bottom: 1px solid #fff;
  transform: translateY(-50%) rotate(-45deg);
}

#top .section-brand .button a::before {
  background-color: #fff;
}

#top .section-brand .button a:hover {
  color: #869ED1;
}

#top .section-brand .button a:hover::after {
  border-color: #869ED1;
}

#top .fixed-bnr {
  position: fixed;
  top: 80%;
  right: 0;
  width: 215px;
  z-index: 10000;
  transition: .5s;
  opacity: 0;
}

#top .fixed-bnr .close {
  position: absolute;
  right: 0;
  top: -30px;
  width: 30px;
}

@media (max-width: 768px) {
  #top .mainVisual .scenes .text01 {
    font-size: 28rem;
    line-height: 2;
    letter-spacing: 10rem;
  }
  #top div.intro {
    padding-bottom: 25rem;
  }
  #top div.intro h2 {
    line-height: 1.7;
    font-size: 24rem;
    padding-bottom: 18rem;
  }
  #top div.intro .lead {
    padding: 0 40rem;
  }
  #top div.intro .title-wrap {
    padding: 53rem 0 50rem;
  }
  #top div.intro .header {
    margin-bottom: 0rem;
  }
  #top div.intro .points {
    padding: 40rem 0;
    max-width: 820px;
  }
  #top div.intro .price {
    padding: 70rem 0 0;
    max-width: 820px;
  }
  #top div.intro .information {
    margin: 0 auto;
    width: 90%;
    box-sizing: border-box;
    padding: 45rem 25rem 25rem;
    box-shadow: none;
  }
  #top div.intro .information .wrapper {
    padding: 0;
  }
  #top div.intro .information .title {
    padding-bottom: 22rem;
    letter-spacing: .1em;
  }
  #top div.intro .information .info-lead {
    font-size: 22rem;
    letter-spacing: .1em;
    padding-bottom: 33rem;
  }
  #top div.intro .information .entryButton {
    display: block;
    width: 100%;
    padding-bottom: 30rem;
  }
  #top div.intro .information .entryButton a {
    padding: 16rem 0;
    font-size: 15rem;
  }
  #top div.intro .information .entryButton.btn02 {
    margin-left: 0;
  }
  #top div.intro .information .text01 {
    padding-bottom: 30rem;
    text-align: left;
  }
  #top div.intro .information .banners {
    width: 100%;
  }
  #top div.intro .information .banners li {
    padding-bottom: 20rem;
  }
  #top div.intro .information .banners li:last-child {
    padding-bottom: 0;
  }
  #top .banners.oneldk {
    padding: 0 25rem;
    margin: 0 auto 50px;
  }
  #top section.concept {
    padding-bottom: 100rem;
    background-color: #fff;
  }
  #top section.concept .in {
    transform: translate(0);
    margin: 0 auto;
    position: static;
    padding-top: 55rem;
    top: 0rem;
  }
  #top section.concept .lead {
    font-size: 30rem;
    line-height: 1.5;
    padding-bottom: 28rem;
    letter-spacing: 0;
  }
  #top section.concept .concept-title {
    font-size: 21rem;
    padding-bottom: 20rem;
  }
  #top section.concept .concept-lead {
    font-size: 20rem;
    padding-bottom: 30rem;
  }
  #top section.concept .text {
    font-size: 12rem;
    line-height: 2;
  }
  #top .guides {
    text-align: center;
    margin-bottom: 60px;
  }
  #top .guides .movies {
    display: block;
    width: 90%;
    margin: 0 auto 20px;
  }
  #top .guides .guide-movie {
    margin-bottom: 0;
  }
  #top .guides .guide-movie .modal-wrapper .modal-close, #top .guides .guide-movie .modal-wrapper .modal-close02 {
    right: -10px;
  }
  #top .sections {
    padding: 0 0 0rem;
  }
  #top .sections .texts {
    width: 100% !important;
    order: 2 !important;
  }
  #top .sections .img {
    width: 100% !important;
    order: 0 !important;
  }
  #top .sections .inner {
    width: 100%;
    max-width: auto;
    max-width: inherit;
    flex-direction: column;
  }
  #top .sections .texts {
    padding: 30rem 8% 55rem;
    margin: 0 auto;
    right: 0 !important;
    left: 0 !important;
    box-sizing: border-box;
    width: 100%  !important;
  }
  #top .sections .open-image,
  #top .sections .img,
  #top .sections .images {
    width: 100%;
    width: 100% !important;
    order: 0 !important;
  }
  #top .sections .title {
    font-size: 36rem;
  }
  #top .sections .header {
    padding-bottom: 40rem;
  }
  #top .sections .text01 {
    font-size: 20rem;
    padding-bottom: 35rem;
  }
  #top .sections .button a {
    font-size: 15rem;
    position: relative;
    padding-top: 15rem;
    padding-bottom: 15rem;
  }
  #top .sections .button a::after {
    right: 40rem;
    width: 9rem;
    height: 9rem;
  }
  #top .sections .images img {
    -webkit-mask-image: url(../images/top/mask.png);
    -webkit-mask-repeat: no-repeat;
    -webkit-mask-size: auto 200%;
    -webkit-mask-position: 0px -900px;
    mask-image: url(../images/top/mask.png);
    mask-repeat: no-repeat;
    mask-size: auto 200%;
    mask-position: 0px -900px;
    transition: -webkit-mask-position 1.4s, mask-position 1.4s;
  }
  #top .sections .images.on img {
    -webkit-mask-position: 0px 0px;
    mask-position: 0px 0px;
  }
  #top .section-position .texts {
    width: 100%;
    order: 2;
  }
  #top .section-position .img {
    width: 100%;
    order: 0;
  }
  #top .fixed-bnr {
    position: fixed;
    top: 80%;
    right: 0;
    width: 215px;
    z-index: 10000;
    transition: .5s;
    opacity: 0;
  }
  #top .fixed-bnr .close {
    position: absolute;
    right: 0;
    top: -30px;
    width: 30px;
  }
}

/*# sourceMappingURL=top.css.map */
