@charset "UTF-8";
/*=============================================
******************* lead  ********************
*=============================================*/
#lead {
  padding: 14vw 0;
}
#lead h2 {
  text-align: center;
  margin: 5vw 0 8vw;
}
#lead .txt span {
  display: block;
  margin-top: 35px;
}
@media screen and (min-width: 768px) {
  #lead {
    padding: 275px 0 225px;
  }
  #lead .wrap {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: space-between;
    max-width: 1080px;
    gap: 20px;
  }
  #lead .ttl-icon span {
    margin-top: 17px;
  }
  #lead .ttl-icon span::before {
    height: 194px;
  }
  #lead h2 {
    text-align: left;
    margin: -5px 0 0 37px;
    letter-spacing: 0.25em;
    min-width: 338px;
  }
  #lead .txt {
    width: 595px;
    text-align: justify;
  }
  #lead .txt span {
    margin-top: 40px;
  }
}
@media (max-width: 1350px) and (min-width: 768px) {
  #lead h2 {
    margin-left: 50px;
  }
}

/*=============================================
******************* owner  **********************
*=============================================*/
#owner {
  padding: 15vw 0;
}
#owner .row {
  margin-top: 8vw;
  gap: 8vw;
}
#owner .row .photo {
  width: 70vw;
  margin: 0 auto;
}
#owner .row h3 {
  font-size: 5.5vw;
  letter-spacing: 0.1em;
}
#owner .row h2 {
  margin: 3vw 0 6vw;
  letter-spacing: 0.1em;
  font-size: 6vw;
}
#owner .row h2 small {
  font-size:4vw;
  display: block;
  letter-spacing: 0.1em;
}
#owner .row h2 span {
  font-size: 13px;
  color: #65603d;
  display: inline-block;
  margin: -5px 0 0 10px;
  transform: translateY(-1vw);
  letter-spacing: 0.1em;
}
@media screen and (min-width: 768px) {
  #owner {
    padding: 143px 0 235px;
  }
  #owner .wrap {
    max-width: 1120px;
  }
  #owner .ttl-icon {
    top: 94px;
  }
  #owner .ttl-icon span {
    margin-top: 15px;
  }
  #owner .ttl-icon span:before {
    height: 307px;
  }
  #owner .row {
    margin-top: 0;
    justify-content: space-between;
    flex-direction: row-reverse;
    align-items: end;
    gap: 30px;
  }
  #owner .row .photo {
    width: auto;
    margin: 0 -41px 0 0;
  }
  #owner .row .content {
    width: 404px;
    margin-bottom: 38px;
    margin-left: 60px;
  }
  #owner .row .content h3 {
    font-size: 22px;
    line-height: 60px;
    letter-spacing: 0.2em;
    margin-left: -2px;
  }
  #owner .row .content h2 {
    line-height: 50px;
    margin: 7px 0 54px -1px;
    letter-spacing: 0.2em;
    font-size:28px;
  }
  #owner .row .content h2 small {
    line-height: 40px;
    letter-spacing: 0.2em;
    font-size: 18px;
  }
  #owner .row .content h2 span {
    font-size: 14px;
    letter-spacing: 0.1em;
    margin-left: 10px;
    transform: translateY(-4px);
  }
}

/*=============================================
******************* floor  ********************
*=============================================*/
#floor {
  padding: 14vw 0;
  position: relative;
}
#floor:before {
  content: '';
  position: absolute;
  bottom: 72vw;
  right: 0;
  width: 17%;
  height: 238vw;
  background: url('../img/shared/bg2.jpg') repeat;
  z-index: -1;
}
#floor h2 {
  font-size: 5vw;
  line-height: 2;
  text-align: center;
}
#floor .row {
  gap: 6vw;
}
#floor .row1 {
  margin-bottom: 6vw;
}
#floor .row2 {
  margin: 10vw 0;
}
#floor .row2 .bg {
  background: #fff;
  padding: 5vw;
}
#floor .row2 .bg h2 {
  margin-bottom: 6vw;
  font-size: 5.2vw;
  padding-right: 6vw;
  line-height: 1;
  border-bottom: 1px solid;
  display: table;
}
#floor .floor-js {
  line-height: 1;
}
#floor .floor-js .slick-dots {
  text-align: left;
  position: relative;
}
@media screen and (min-width: 768px) {
  #floor {
    padding: 115px 0 144px;
  }
  #floor:before {
    bottom: 284px;
    right: 0;
    width: 16%;
    height: 1300px;
  }
  #floor .wrap {
    max-width: 1128px;
    position: static;
  }
  #floor .ttl-icon {
    top: 144px;
  }
  #floor .ttl-icon span {
    margin-top: 13px;
  }
  #floor .photo1 {
    text-align: right;
    width: 350px;
    margin-left: auto;
    margin-right: calc(50% - 750px);
  }
  #floor h2 {
    font-size: 22px;
    line-height: 50px;
    letter-spacing: 0.3em;
  }
  #floor .text {
    position: absolute;
    top: 241px;
    left: calc(50% - 468px);
    letter-spacing: 0.28em;
  }
  #floor .row {
    gap: 0;
  }
  #floor .row1 {
    gap: 20px;
    margin: -97px 0 0;
    justify-content: space-between;
    align-items: end;
  }
  #floor .row1 .photo {
    margin-left: 29px;
  }
  #floor .row1 h2 {
    margin-bottom: 13px;
    width: 150px;
    height: 315px;
    text-align: left;
  }
  #floor .row2 {
    margin: 182px 0 83px;
    gap: 0;
  }
  #floor .row2 .photo {
    position: absolute;
    left: calc(50% - 50vw);
    right: calc(50% - -64px);
    height: 597px;
  }
  #floor .row2 .photo img {
    width: 100%;
    height: 100%;
    object-fit: cover;
  }
  #floor .row2 .bg {
    width: 589px;
    box-sizing: border-box;
    margin: 101px -36px 0 auto;
    padding: 44px;
    padding-bottom: 61px;
  }
  #floor .row2 .bg h2 {
    font-size: 24px;
    padding-left: 5px;
    padding-bottom: 1px;
    letter-spacing: 0.12em;
    padding-right: 49px;
    margin-bottom: 50px;
  }
  #floor .row2 .bg .floormap {
    margin: 0 0 0 8px;
  }
  #floor .row3 {
    flex-direction: row-reverse;
    justify-content: space-between;
  }
  #floor .row3 .floor-js {
    margin-right: -36px;
    width: calc(83% - 2px);
  }
  #floor .row3 .floor-js .slick-dots {
    margin: 22px 0 0 7px;
  }
  #floor .row3 h2 {
    margin-top: 126px;
    margin-left: -1px;
    width: 150px;
    height: 320px;
    text-align: left;
  }
}
@media (max-width: 1070px) and (min-width: 768px) {
  #floor .text {
    left: 70px;
  }
}

/*=============================================
******************* guide  ********************
*=============================================*/
#guide {
  padding: 15vw 0;
}
#guide h2 {
  text-align: center;
  margin: 4vw 0 8vw;
}
#guide .txt {
  margin-top: 4vw;
}

@media screen and (min-width: 768px) {
  #guide {
    padding: 183px 0 154px;
  }
  #guide .ttl-icon {
    top: 133px;
  }
  #guide h2 {
    margin: 0 0 51px 5px;
    letter-spacing: 0.24em;
  }
  #guide .map {
    text-align: center;
    margin-left: 7px;
  }
  #guide .txt {
    text-align: center;
    margin-top: 41px;
    margin-left: 9px;
  }
}

/*=============================================
******************* root  **********************
*=============================================*/
#root {
  position: relative;
}
#root .inner {
  background: url('../img/shared/background.jpg') repeat;
  will-change: clip-path;
  overflow: hidden;
  height: calc((100vh));
}
#root .set {
  overflow: hidden;
  height: 50%;
}
#root .scroll {
  display: -webkit-flex;
  display: -moz-flex;
  display: -ms-flex;
  display: -o-flex;
  display: flex;
  width: 200vw;
  will-change: transform;
  height: 100%;
}
#root .scroll p {
  width: 100vw;
  min-width: 100vw;
}
#root .scroll p img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
#root .scroll.right {
  transform: translateX(-100%);
}
@media screen and (min-width: 768px) {
  #root .inner {
    top: 0;
    display: flex;
  }
  #root .inner .set {
    width: 50%;
    height: 100%;
  }
  #root .inner .set .scroll {
    width: 100vw;
  }
  #root .inner .set p {
    width: calc(50vw);
    min-width: calc(50vw);
  }
}

#reserves {
  margin-top: -100vh;
}

#banner {
  margin-bottom: 0;
}
#banner a h2 {
  font-size:20px;
  line-height:160%;
  padding-bottom: 22px;
  }
@media screen and (min-width: 768px) {
  #banner a {
    padding: 248px 0 203px;
  }
  #banner a h2 {
    padding-bottom: 22px;
  }
  #banner a h2:before {
    top: 15px;
  }
}

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