@charset "UTF-8";

#sec1 {
  padding: 16vw 0px 11vw;
  background-image: url(../img/shared/bgft.jpg);
  background-position: center top;
  background-repeat: repeat;
  position: relative;
}

#sec1:before {
  content: "";
  position: absolute;
  left: 0px;
  right: 0px;
  bottom: -32vw;
  background-image: url(../img/shared/bgft_blur.png);
  background-position: center top;
  background-repeat: repeat-x;
  background-size: cover;
  transform: rotate(180deg);
  height: 32vw;
}

#sec1 .wrap:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 50%;
  right: -50%;
  bottom: 0px;
  background-image: url(../img/floor/s1_deco.png);
  background-position: left top;
  background-repeat: no-repeat;
  background-size: cover;
}

#sec1 .s1-img {
  position: relative;
}

#sec1 .s1-img h2 {
  position: absolute;
  top: 5vw;
  right: 5%;
  z-index: 1;
}

#sec1 .s1-img .img-inner {
  height: 100vw;
}

#sec1 .col-txt {
  margin-top: 6vw;
}

#sec1 .txt {
  margin-top: 4vw;
}

@media screen and (min-width: 768px) {
  #sec1 {
    padding: 123px 0px 83px;
  }

  #sec1:before {
    height: 250px;
    bottom: -250px;
    background-size: auto;
  }

  #sec1 .wrap:before {
    top: -30px;
    left: calc(50% - 31px);
    background-size: auto;
    width: 1214px;
    height: 1213px;
  }

  #sec1 .s1-img {
    margin: 0px 20px;
  }

  #sec1 .s1-img h2 {
    top: 36px;
    right: 51px;
  }

  #sec1 .s1-img .img-inner {
    height: 600px;
  }

  #sec1 .col-txt {
    margin: 49px auto 0px;
    width: 645px;
  }

  #sec1 .col-txt h3 {
    text-align: left;
  }

  #sec1 .txt {
    margin-top: 26px;
  }
}

#sec2 {
  padding: 0px 0px 22vw;
  line-height: 2.26;
}

#sec2 h2 {
  position: relative;
}

#sec2 h2:before {
  content: "";
  position: relative;
  display: block;
  top: 0px;
  left: 0px;
  background-image: url(../img/shared/line_black.png);
  background-position: center bottom;
  background-repeat: no-repeat;
  height: 15vw;
}

#sec2 .ttls-global {
  position: absolute;
  z-index: 1;
}

#sec2 .tit {
  position: absolute;
  z-index: 1;
  font-family: "Shippori Mincho", serif;
  font-weight: 600;
  letter-spacing: 0.2em;
  line-height: 1.5;
  font-size: 4vw;
  color: #fffcf3;
  bottom: 2vw;
  right: 2%;
}

#sec2 [class^=inner] {
  position: relative;
}

#sec2 [class^=s2-img] {
  position: relative;
}

#sec2 .ttls-global {
  top: 3vw;
  left: 3%;
}

#sec2 .ttls-global:before {
  margin-bottom: 0.5vw;
}

#sec2 .inner1 {
  z-index: 0;
  margin-top: 10vw;
}

#sec2 .inner1:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 50%;
  right: 0px;
  bottom: 0px;
  background-image: url(../img/shared/deco_rice.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100% auto;
  z-index: -1;
}

#sec2 .inner1 h4 {
  font-size: 4vw;
  letter-spacing: 0.2em;
  /* font-weight: 600; */
  line-height: 1.5;
  margin-top: 4vw;
}
#sec2 .inner1 h4 span{
  font-size: 14px;
  margin-top: 10px;
  display: block;
}

#sec2 .inner1 .s2-img1 {
  margin-top: 6vw;
}

#sec2 .inner1 .s2-img2 {
  margin-top: 3vw;
}

#sec2 .inner1 .txt {
  margin-top: 4vw;
}

#sec2 .inner2:before {
  content: "";
  position: absolute;
  top: 0px;
  left: -3%;
  right: 0px;
  bottom: 0px;
  background-image: url(../img/shared/line3.png);
  background-position: center top;
  background-repeat: no-repeat;
  background-size: 100% auto;
}

#sec2 .inner2 .s2-img3 {
  z-index: 1;
  margin: 0px 0px -4vw 20%;
}

#sec2 .inner2 .s2-img4 {
  margin: 0px 15% 0px 0px;
}

#sec2 .inner2 .s2-img5 {
  margin: 3vw 0px 0px;
}

#sec2 .inner3 .col-r {
  margin-top: 3vw;
}

#sec2 .inner4 .col-r li {
  list-style: none;
}
#sec2 .inner4 .col-l {
  margin-top: 7vw;
}

#sec2 .inner4 h5 {
  font-size: 17px;
  font-weight: 600;
  line-height: 1.55;
  letter-spacing: 0.2em;
}

#sec2 .inner4 .txt {
  margin: 3vw 0px 0px;
}

#sec2 .inner4 .note {
  margin-top: 7vw;
}
#sec2 .inner4 .f-btn {
  margin-top: 5vw;
}

#sec2 .inner5 .ttl-icon:before {
  display: inline-block;
  margin-bottom: 0px;
  margin-right: 7px;
}

#sec2 .inner5 .txt {
  margin: 2vw 0px 0px;
}

#sec2 .inner5 .s2-img10 {
  margin: 8vw 0px 0px 0px;
}

@media screen and (max-width: 767px) {
  #sec2 [class^=inner]+[class^=inner] {
    margin-top: 10vw;
  }

  #sec2 .inner1 .col-txt {
    text-align: center;
  }

  #sec2 .inner4 .txt {
    text-align: center;
  }
}

@media screen and (min-width: 768px) {
  #sec2 {
    padding: 0px 0px 168px;
  }

  #sec2 .wrap {
    max-width: 1240px;
    width: auto;
  }

  #sec2 h2:before {
    height: 99px;
  }

  #sec2 .tit {
    font-size: 16px;
    right: 12px;
    bottom: 6px;
  }

  #sec2 .ttls-global {
    top: 19px;
    left: 12px;
  }

  #sec2 .ttls-global:before {
    margin-bottom: 3px;
  }

  #sec2 .inner1 {
    margin-top: 105px;
  }

  #sec2 .inner1:before {
    top: -34px;
    left: auto;
    right: 83px;
    background-size: auto;
    width: 317px;
    height: 467px;
  }

  #sec2 .inner1 [class^=s2-img] {
    position: absolute;
  }

  #sec2 .inner1 .s2-img1 {
    top: -17px;
    left: 0px;
    width: calc(50% - 20px);
    height: 388px;
    margin: 0px;
  }

  #sec2 .inner1 .s2-img2 {
    top: 369px;
    right: 2px;
    width: calc(50% - 53px);
    height: 378px;
    margin: 0px;
  }

  #sec2 .inner1 .col-txt {
    width: 530px;
    margin-left: auto;
  }

  #sec2 .inner1 h3 {
    margin-left: 145px;
  }

  #sec2 .inner1 h4 {
    font-size: 18px;
    margin-top: 34px;
  }

  #sec2 .inner1 .txt {
    max-width: 900px;
    margin: 231px auto 0px;
  }

  #sec2 .inner2 {
    margin-top: 60px;
    align-items: flex-start;
    justify-content: space-between;
  }

  #sec2 .inner2:before {
    top: -203px;
    left: -130px;
    background-size: auto;
    width: 936px;
    height: 845px;
  }

  #sec2 .inner2 .col-l {
    margin-left: 12px;
    width: calc(50% - 36px);
  }

  #sec2 .inner2 .s2-img3 {
    margin: 0px 0px -23px auto;
    width: calc(100% - 192px);
    height: 255px;
  }

  #sec2 .inner2 .s2-img4 {
    width: calc(100% - 91px);
    height: 358px;
  }

  #sec2 .inner2 .s2-img5 {
    margin: 184px 153px 0px 0px;
    width: calc(50% - 206px);
    height: 276px;
  }

  #sec2 .inner3 {
    max-width: 1170px;
    margin: 0px auto 0px;
    justify-content: space-between;
    align-items: flex-start;
  }

  #sec2 .inner3:before {
    content: "";
    position: absolute;
    top: 322px;
    left: auto;
    right: -165px;
    background-image: url(../img/shared/line3.png);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: auto;
    transform: scaleX(-1);
    width: 936px;
    height: 845px;
  }

  #sec2 .inner3 .col-r {
    margin-top: -20px;
    width: calc(50% - 125px);
  }

  #sec2 .inner3 .col-r li {
    height: 310px;
  }

  #sec2 .inner3 .s2-img6 {
    margin: 70px 0px 0px 39px;
    width: calc(50% - 21px);
    height: 326px;
  }

  #sec2 .inner4 {
    max-width: 1126px;
    padding: 0px 20px;
    box-sizing: border-box;
    margin: 0px auto;
    justify-content: space-between;
    flex-direction: row-reverse;
  }

  #sec2 .inner4 .col-r {
    margin: 47px 84px 0px 0px;
    width: 390px;
  }

  #sec2 .inner4 .col-l {
    width: 450px;
    margin: -135px 0px 0px 0px;
  }

  #sec2 .inner4 h5 {
    font-size: 18px;
  }

  #sec2 .inner4 .txt {
    margin: 20px 50px 0px 68px;
  }

  #sec2 .inner4 .note {
    margin-top: 48px;
  }
  #sec2 .inner4 .f-btn {
    margin-top: 20px;
  }
  

  #sec2 .inner5 {
    max-width: 1000px;
    margin: 79px auto 0px;
    flex-direction: row-reverse;
    justify-content: space-between;
  }

  #sec2 .inner5 .col-r {
    width: 390px;
    margin: 55px 0px 0px 0px;
  }

  #sec2 .inner5 .txt {
    width: 367px;
    margin: 16px 0px 0px 33px;
    line-height: 2.66;
  }

  #sec2 .inner5 .s2-img10 {
    margin: 0px 0px 0px -53px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1080px) {
  #sec2 .inner5 .col-r {
    margin-right: 20px;
  }
}

#sec3 {
  background-image: url(../img/shared/bgft.jpg);
  background-position: center top;
  background-repeat: repeat;
  padding: 0px 0px 33vw;
  position: relative;
}

#sec3:before {
  content: "";
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  background-image: url(../img/shared/bg_deco.png);
  background-position: center top;
  background-repeat: repeat;
  background-size: 25% auto;
}

#sec3 h2 {
  margin: 0px auto;
  position: relative;
  line-height: 2.14;
  padding: 10vw 1% 0px 0px;
}

#sec3 h2:before {
  content: "";
  position: absolute;
  top: -6vw;
  right: 0px;
  background-image: url(../img/shared/line_black.png);
  background-position: right bottom;
  background-repeat: no-repeat;
  background-size: cover;
  width: 1px;
  height: 70vw;
}

#sec3 .s3-img {
  margin-top: 6vw;
}

#sec3 .txt {
  margin-top: 6vw;
}

#sec3 .s3-btn {
  margin: 6vw 18% 0px;
}

#sec3 .s3-btn li~li {
  margin-top: 6vw;
}

@media screen and (min-width: 768px) {
  #sec3 {
    padding: 0px 0px 250px;
  }

  #sec3:before {
    background-size: 175px 175px;
    width: calc(50% + 245px);
  }

  #sec3 h2 {
    margin: 0px 0px 0px 103px;
    padding: 75px 6px 0px 0px;
  }

  #sec3 h2:before {
    top: -55px;
    height: 400px;
  }

  #sec3 h2 span {
    margin-top: 33px;
  }

  #sec3 .s3-img {
    position: absolute;
    top: 142px;
    right: -133px;
    margin: 0px;
  }

  #sec3 .col-txt {
    width: 402px;
    margin: 54px 0px 0px -33px;
  }

  #sec3 .txt {
    margin-top: 0px;
  }

  #sec3 .s3-btn {
    margin: 37px 0px 0px;
  }

  #sec3 .s3-btn li {
    width: 227px;
  }

  #sec3 .s3-btn li~li {
    margin: 37px 0px 0px 175px;
  }
}

@media screen and (min-width: 768px) and (max-width: 1200px) {
  #sec3 .col-txt {
    margin-left: 20px;
  }
}

/* #popup-floor h2{
  position: relative;
  font-size: 19px;
  font-weight: 600;
  letter-spacing: 0.2em;
  line-height: 1.28;
}
#popup-floor .txt{
  line-height: 2;
  margin-top: 7vw;
} */

@media screen and (min-width: 768px) {
  .remodal-bg-red .f-col {
    width: 370px;
  }
  .remodal-bg-red .row+.row {
    margin: 35px 0px 0px;
  }
  .remodal-bg-red .row+.row+.row {
    margin: 22px 0px 0px;
  }
}