@charset "utf-8";

#content_Wrap {
  background: #fff;
  color: #333;
  padding: 0;
}


.main {
  width: 100%;
  margin-bottom: 50px;
}

.main .cap_Txt {
  left: 10px;
  bottom: 5%;
  text-align: center;
  margin: 0 auto;
}

.tate_text {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto 100px;
  display: flex;
  justify-content: center;
  align-items: flex-start;
  flex-direction: row-reverse;
  vertical-align: baseline;
}

.tate_text .tate_ttl {
  width: 56px;
  max-width: 100%;
  margin-left: 50px;
  position: relative;
}

.tate_text .tate_ttl:after {
  content: "";
  position: absolute;
  right: 10px;
  top: -100px;
  width: 2px;
  height: 80px;
  background: #8e0303;
}

.tate_text h3 {
  font-size: 40px;
  margin-left: 50px;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
}

.tate_text p {
  font-size: 18px;
  line-height: 2.3;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  white-space: nowrap;
}



.facade {
  width: 100%;
  position: relative;
  overflow-x: hidden;
}

.facade .title_yoko {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto 100px;
}

.facade h3 {
  width: 248px;
  max-width: 100%;
  margin-bottom: 30px;
}

.facade p {
  line-height: 2.3;
  margin-bottom: 40px;
}

.facade figure {
  z-index: 2;
}

.facade .red_en {
  width: 600px;
  position: absolute;
  right: -350px;
  bottom: 0;
  z-index: 1;
}



.entrance {
  width: 100%;
  position: relative;
  margin: 0 auto 0px;
  padding-bottom: 100px;
  overflow-x: hidden;
  overflow-y: hidden;
}

.entrance figure {
  position: relative;
  margin-bottom: 50px;
}

.entrance .ent_title {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
}

.entrance .ent_title h3 {
  width: 348px;
  max-width: 100%;
  margin-bottom: 30px;
  position: relative;
}

.entrance .ent_title p {
  line-height: 2.3;
}

.entrance .ent_title h3:after {
  content: "";
  position: absolute;
  left: 10px;
  top: -100px;
  width: 2px;
  height: 80px;
  background: #8e0303;
}

.entrance .red_en {
  width: 500px;
  position: absolute;
  right: -300px;
  top: 0;
  z-index: 2;
}

.circle {
  position: relative;
}

.circle img {
  clip-path: circle(145% at 50% -108%);
}


.living_park {
  width: 100%;
  background: #e6ecdd;
  padding: 0 0 100px;
  margin-bottom: 50px;
}

.living_park figcaption {
  bottom: 3%;
  right: 10px;
}

.living_park .living_ttl {
  width: 440px;
  max-width: 90%;
  margin: 50px auto 40px;
}

.living_park p {
  line-height: 2.3;
  text-align: center;
  color: #333;
  font-size: 16px;
}

.landscape_ttl {
  width: 1000px;
  max-width: 90%;
  margin: 100px auto 0;
  text-align: center;
}

.landscape_ttl h3 {
  width: 280px;
  max-width: 100%;
  margin: 0 auto 30px;
}

.landscape_ttl p {
  margin-bottom: 50px;
}

.living_park figcaption {
  bottom: 0px;
}

/* CG GALLERY */
.cg_Area .lead_copy {
  padding: 50px 0 30px;
  font-size: 30px;
  letter-spacing: 0.1em;
  text-align: center;
}

.Wrap02 .ritsumen {
  position: relative;
  width: 90%;
  max-width: 1000px;
  margin: 50px auto 0;
  padding-bottom: 50px;
}

.Wrap02 .ritsumen .txt_Box {
  position: absolute;
  top: 0;
  left: 0;
  width: 50%;
}

.Wrap02 .ritsumen .txt_Box .lead_copy {
  width: 100%;
  text-align: left;
  padding: 0 0 20px;
}

.Wrap02 .ritsumen figure {
  width: 60%;
  margin-left: auto;
}

.Wrap02 .ritsumen figure figcaption {
  bottom: -25px;
}

/*loop*/
.loop_wrap {
  padding-bottom: 50px;
}

.loop_wrap li a {
  /*pointer-events: none;*/
  /*display: block;*/
}

.loop_wrap li {
  width: auto;
  height: 400px;
  cursor: pointer;
}

.loop_wrap li img {
  max-height: 100%;
  max-width: 100%;
}

.modal {
  display: none;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100%;
  z-index: 1;
}

.modal__bg {
  background: rgba(0, 0, 0, 0.8);
  height: 100vh;
  position: absolute;
  width: 100%;
  z-index: 9;
}

.modal__content {
  left: 50%;
  position: fixed;
  top: 50%;
  transform: translate(-50%, -50%);
  width: 800px;
  max-width: 90%;
  z-index: 9;
}

.batsu {
  position: absolute;
  right: -40px;
  top: 0px;
  font-size: 25px;
  font-weight: bold;
  pointer-events: none;
}

#modal04 .modal__content,
#modal12 .modal__content,
#modal13 .modal__content,
#modal15 .modal__content {
  width: 600px;
}


/*-----------------------------
tab〜
-----------------------------*/
@media only screen and (max-width: 1024px) {}

/*-----------------------------
tabのみ
-----------------------------*/
/*@media only screen and (max-width: 1024px) and (min-width: 768px) {
  .teiki { width: 60%;}
}*/

/*-----------------------------
sp
-----------------------------*/
@media only screen and (max-width: 830px) {

  .main .cap_Txt {
    bottom: -15px;
  }

  .tate_text .tate_ttl {
    width: 30px;
    margin-left: 20px;
  }

  .tate_text h3 {
    font-size: 25px;
    margin-left: 20px;
  }

  .tate_text p {
    font-size: 14px;
    line-height: 2;
  }

  .tate_text .tate_ttl:after {
    top: -90px;
    right: 5px;
  }

  .facade h3 {
    width: auto;
    height: 15px;
  }

  .facade h3 img {
    max-width: 100%;
    max-height: 100%;
  }

  .facade p {
    line-height: 2;
    font-size: 14px;
  }

  .facade .red_en {
    width: 400px;
    right: -300px;
    bottom: -100px;
  }

  .facade .title_yoko {
    position: relative;
    z-index: 3;
  }

  .circle img {
    clip-path: circle(145% at 50% -108%);
  }

  .circle .cap_Txt {
    bottom: -10px;
  }

  .entrance {
    overflow-x: hidden;
    overflow-y: hidden;
    margin: 0 auto;
    padding-bottom: 50px;
  }

  .entrance .ent_title h3 {
    width: auto;
    height: 15px;
  }

  .entrance .ent_title h3 img {
    max-width: 100%;
    max-height: 100%;
  }

  .entrance .ent_title p {
    line-height: 2;
    font-size: 14px;
  }

  .entrance .red_en {
    bottom: inherit;
    top: -150px;
    ;
    width: 300px;
    right: -260px;
  }


  .living_park {
    padding: 0 0 50px;
  }

  .living_park .living_ttl {
    width: 250px;
    max-width: 80%;
  }

  .living_park p {
    line-height: 2;
    font-size: 14px;
    font-feature-settings: "palt";
  }

  .living_park figcaption {
    bottom: -18px;
  }


}