@charset "UTF-8";

.list .l-headerLogo{
  opacity: 0;
  pointer-events: none;
}
.list .l-headerLogo.w{
  opacity: 1;
  pointer-events: inherit;
}
.list .l-headerLogo::after{
  color: #fff;
}

main.l-main{
  padding: 120px 0;
  background-color: #F7F5F1;
}
.detail main.l-main{
  padding: 70px 0;
}
@media(max-width: 768px) {
  main.l-main{
    padding: 60px 0;
  }
  .detail main.l-main{
    padding: 40px 0;
  }
}

.mv{
  position: relative;
}
.mv .tit{
  position: absolute;
  top: 50%;
  left: 0;
  transform: translateY(-50%);
  width: 100%;
  text-align: center;
  font-size: clamp(1rem, 1.4vw, 1.7rem);
  color: #fff;
  z-index: 1;
}
.mv .tit strong{
  display: block;
  font-size: clamp(2.8rem, 6vw, 8rem);
  line-height: 1;
  margin: 0 auto 15px;
}
.detail .mv .tit{
  position: relative;
  top: inherit;
  left: inherit;
  transform: none;
  width: 100%;
  padding: 160px 0 0;
  background-color: #F7F5F1;
  color: #4E6D6B;
}
@media(max-width: 768px) {
  .mv .tit strong{
    margin: 0 auto 5px;
  }
  .detail .mv .tit{
    padding: 90px 0 0;
  }
}
.list .head-txt{
  text-align: center;
  font-size: clamp(1.4rem, 2.4vw, 2.8rem);
  line-height: 1.4;
  margin: 0 0 100px;
}
.footerNotice{
  background-color: #fff;
}

.list main ul{
  max-width: 1180px;
  width: 90%;
  margin: 0 auto;
  display: flex;
  justify-content: flex-start;
  flex-wrap: wrap;
  padding-bottom: 40px;
}
.list main ul li{
  width: calc(100% / 3 - 20px);
  margin: 0 30px 30px 0;
  background-color: #fff;
  position: relative;
  display: flex;
}
.list main ul li:nth-child(3n){
  margin-right: 0;
}
.list main ul li.new:after{
  content: 'NEW';
  position: absolute;
  top: -6px;
  right: -6px;
  color: #fff;
  background: linear-gradient(to right, #AA9649 0%, #C0AE72 40%, #AA9649 100%);
  font-size: clamp(1.6rem,1.8vw,2rem);
  padding: 5px 10px;
  font-family: "EB Garamond", serif;
  font-optical-sizing: auto;
  font-weight: 400;
  font-style: normal;
}
.list main ul li a{
  display: block;
  padding: 10px 10px 20px!important;
  transition: .3s;
  box-shadow: 3px 3px 2px rgba(0,0,0,.3);
  display: flex;
  flex-direction: column;
}
.list main ul li a:hover{
  box-shadow: 0 0 0 rgba(0,0,0,0);
}
.list main ul li .flex{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  align-items: center;
  flex-grow: 1;
}
.list main ul li .type{
  color: #fff;
  text-align: center;
  background-color: #001130;
  align-items: center;
  line-height: 1;
  width: 50%;
}
.list main ul li .type strong{
  display: block;
  background: linear-gradient(90deg, #397D87 0%, #1A4E56 100%);
  padding: 10px 0;
  font-size: clamp(4rem,4.4vw,5rem);
}
.list main ul li .type strong span{
  font-size: clamp(1.4rem,1.6vw,1.8rem);
}
.list main ul li .type .madori{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  align-items: center;
  font-size: clamp(2rem,2.2vw,2.4rem);
  padding: 10px 0;
  border-bottom: solid 1px #fff;
}
.list main ul li .type .madori.short{
  padding: 5px 0;
}
.list main ul li .type .madori:last-of-type{
  border: none;
}
.list main ul li .type .madori em{
  display: block;
  font-style: normal;
  font-size: clamp(1rem,1vw,1.1rem);
  margin: 0 0 2px;
  width: 100%;
}
.list main ul li .type .madori .plus{
  display: block;
  font-style: normal;
  font-size: clamp(1rem,1vw,1.1rem);
  margin-left: 5px;
}
.list main ul li .menseki{
  line-height: 1;
  margin: 20px 0 10px;
  color: #000;
  width: 48%;
}
.list main ul li .menseki .t1{
  display: block;
  font-size: clamp(1.2rem,1.4vw,1.6rem);
  margin: 0 0 5px;
  text-align: center;
}
.list main ul li .menseki strong{
  font-size: clamp(3.8rem,3.6vw,5rem);
  line-height: 1;
  text-align: center;
  display: block;
}
.list main ul li .menseki strong span{
  font-size: clamp(2rem,2.5vw,4rem);
}
.list main ul li .menseki .t2{
  font-size: clamp(1rem,1.2vw,1.4rem);
  margin: 10px 0 0 ;
  color: #000;
  text-align: center;
  display: block;
}
.list main ul li .zu{
  width: 100%;
  margin: 30px auto;
  flex-grow: 1;
}
.list main ul li .btn{
  max-width: 210px;
  width: 90%;
  max-height: 40px;
  margin: 20px auto 0;
  border-radius: 50px;
  text-align: center;
  color: #fff;
  padding: 10px 5px;
  font-size: clamp(1.6rem,1.7vw,1.8rem);
  line-height: 1;
  position: relative;
  border: solid 1px #333;
  color: #333;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-grow: 1;
}
.list main ul li .btn:after{
  content: '';
  background: url(../images/floorplan/detail/arw01.svg) no-repeat bottom right;
  display: block;
  margin-left: 10px;
  width: 29px;
  height: 8px;
}
@media(max-width: 980px) {
  .list main ul li{
    width: calc(100% / 2 - 10px);
    margin: 0 20px 20px 0;
    background-color: #fff;
  }
  .list main ul li:nth-child(3n){
    margin-right: 20px;
  }
  .list main ul li:nth-child(2n){
    margin-right: 0;
  }
}
@media(max-width: 768px) {
  .list .head-txt{
    margin: 0 20px 50px;
}
  .list main ul{
    display: block;
    padding-bottom: 20px;
  }
  .list main ul li{
    width: 100%;
    margin: 0 0 30px;
  }
  .list main ul li a{
    box-shadow: 2px 2px 1px rgba(0,0,0,.3);
  }
}

.detail .info{
}
.detail .info .inner{
  max-width: 1120px;
  width: 90%;
  margin: 0 auto;
  padding: 80px 40px;
  background-color: #fff;
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.detail .info .inner .zu{
  max-width: 594px;
  width: 60%;
}
.detail .info .inner .zu span{
  display: block;
  width: 55%;
  margin: 5% 0 0 auto;
}
.detail .info .inner .data{
  max-width: 480px;
  width: 40%;
}
.detail .info .inner .data .type{
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  color: #fff;
  text-align: center;
  background-color: #001130;
  line-height: 1;
  width: 90%;
}
.detail .info .inner .data .type strong{
  display: flex;
  justify-content: center;
  background: linear-gradient(90deg, #397D87 0%, #1A4E56 100%);
  padding: 20px 0;
  font-size: clamp(4rem,4.8vw,5.6rem);
  width: 50%;
  align-items: center;
}
.detail .info .inner .data .type strong span{
  font-size: clamp(1.4rem,1.6vw,1.8rem);
}
.detail .info .inner .data .type .madori-box{
  width: 50%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.detail .info .inner .data .type .madori{
  font-size: clamp(2.2rem,2.4vw,3rem);
  width: fit-content;
  margin: 0 auto;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  border-bottom: solid 1px #fff;
  padding: 5px 0;
}
.detail .info .inner .data .type .madori:last-of-type{
  border: none;
}
.detail .info .inner .data .type .madori em{
  display: block;
  font-style: normal;
  font-size: clamp(1rem,1vw,1.1rem);
  margin: 0 0 2px;
  width: 100%;
}
.detail .info .inner .data .type .madori .plus{
  display: block;
  font-style: normal;
  font-size: clamp(1rem,1vw,1.1rem);
  margin-left: 5px;
}
.detail .info .inner .data .type .madori sup{
  font-size: clamp(1rem,1vw,1.1rem);
  transform: translate(3px, -10px);
}
.detail .info .inner .data .notes2{
  margin: 5px 0 0;
  font-size: clamp(1rem,1vw,1.1rem);
}
.detail .info .inner .data .menseki{
  font-size: clamp(2.2rem,3.4vw,4rem);
  line-height: 1;
  margin: 20px 0;
}
.detail .info .inner .data .menseki .t1{
  display: block;
  font-size: clamp(1.2rem,1.4vw,1.6rem);
  margin: 0 0 5px;
}
.detail .info .inner .data .menseki strong{
  font-size: clamp(4.8rem,5.6vw,7rem);
}
.detail .info .inner .data .menseki .t2{
  font-size: clamp(1rem,1.2vw,1.4rem);
  margin: 0 0 0 -5px;
}
.detail .info .inner .data .txt{
  display: block;
  font-size: clamp(1rem,1.2vw,1.4rem);
  padding: 0;
  margin: 0 0 15px;
}
.detail .info .inner .data .txt:last-of-type{
  margin-bottom: 30px;
}
.detail .info .inner .data .txt span{
  display: inline-block;
  margin-right: 1rem;
}
.detail .info .inner .data .feature{
  padding: 0 0 30px;
}
.detail .info .inner .data .feature p{
  position: relative;
  width: 100%;
  border-bottom: dashed 1px #918B8A;
  text-align: left;
  padding: 10px 0 10px 15px;
  font-size: clamp(1rem,1.2vw,1.5rem);
  line-height: 1.4;
  position: relative;
}
.detail .info .inner .data .feature p:before{
  content: '';
  position: absolute;
  top: 16px;
  left: 0;
  width: 10px;
  height: 10px;
  border: solid 1px #918B8A;
}
.detail .info .inner .btn{
  max-width: 300px;
  width: 90%;
  display: block;
  border-radius: 50px;
  padding: 10px 5px;
  font-size: clamp(1.2rem,1.4vw,1.6rem);
  background: #8E94AC;
  text-align: center;
  color: #fff;
  position: relative;
  margin: 0 auto;
  transition: .3s;
}
.detail .info .inner .data .btn:hover{
  opacity: .7;
}
.detail .info .inner .other{
  width: 100%;
  margin-top: 30px;
  font-size: clamp(1rem,1vw,1.1rem);
  line-height: 1.4;
}
.detail .info .inner .other span{
  display: block;
  max-width: 318px;
  margin-top: 10px;
}
.detail .info .inner .btn.sp{
  display: none;
}
.detail .back{
  max-width: 300px;
  width: 90%;
  display: block;
  border-radius: 50px;
  padding: 10px 5px;
  font-size: clamp(1.2rem,1.4vw,1.6rem);
  border: solid 1px #4E6D6B;
  text-align: center;
  color: #4E6D6B;
  position: relative;
  margin: 50px auto 0;
  transition: .3s;
}
.detail .back:hover{
  background: #4E6D6B;
  color: #fff;
}
.detail .notes{
  max-width: 1140px;
  width: 90%;
  margin: 50px auto;
  font-size: clamp(1rem,1.1vw,1.2rem);
  line-height: 1.4;
}
@media(max-width: 768px) {
  .detail .info{
    padding: 0;
  }
  .detail .info .inner{
    display: block;
    padding: 20px;
  }
  .detail .info .inner .zu{
    max-width: 658px;
    width: 100%;
    margin: 0 auto;
  }
  .detail .info .inner .zu span{
    width: 84%;
    margin: 3% auto 0;
  }
  .detail .info .inner .data{
    max-width: 450px;
    width: 100%;
    margin: 0 auto 20px;
  }
  .detail .info .inner .data .type{
    width: 100%;
  }
  .detail .info .inner .data .menseki{
    margin: 10px 0;
  }
  .detail .info .inner .data .menseki .t1{
    font-size: clamp(1.2rem,1.4vw,1.6rem);
  }
  .detail .info .inner .data .menseki .t2{
    font-size: clamp(1.2rem,1.2vw,1.4rem);
  }
  .detail .info .inner .data .txt{
    font-size: clamp(1.2rem,1.2vw,1.4rem);
    margin: 0 0 5px;
  }
  .detail .info .inner .data .txt:last-of-type{
    margin-bottom: 20px;
  }
  .detail .info .inner .data .feature{
    padding: 0 0 20px;
  }
  .detail .info .inner .data .feature p:before{
    top: 13px;
  }
  .detail .info .inner .btn{
    max-width: 300px;
    width: 90%;
    display: block;
    border-radius: 50px;
    padding: 10px 5px;
    font-size: clamp(1.2rem,1.4vw,1.6rem);
    background: #8E94AC;
    text-align: center;
    color: #fff;
    position: relative;
    margin: 0 auto;
    transition: .3s;
  }
  .detail .info .inner .btn.pc{
    display: none;
  }
  .detail .info .inner .btn.sp{
    display: block;
    margin: 20px auto 0;
  }
  .detail .info .notes{
    margin: 30px auto 0;
  }
}

.movie-box{
  padding: 50px 0;
}
.movie-box .tit{
  width: 100%;
  text-align: center;
  font-size: clamp(1.8rem, 3vw, 4rem);
  line-height: 1;
  margin: 0 auto 15px;
}
.movie-box .modal-open{
  max-width: 565px;
  width: 90%;
  margin: 0 auto;
  display: block;
}
/* モーダルと背景の指定 */
.modal-open{
  cursor: pointer;
}
.modal{
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  text-align: center;
  background: rgba(0,0,0,50%);
  padding: 40px 20px;
  overflow: auto;
  opacity: 0;
  visibility: hidden;
  transition: .3s;
  box-sizing: border-box;
  z-index: 100;
}
/* モーダルの擬似要素の指定 */
.modal:before{
  content: "";
  display: inline-block;
  vertical-align: middle;
  height: 100%;
  margin-left: -0.2em;
}
/* クラスが追加された時の指定 */
.modal.is-active{
  opacity: 1;
  visibility: visible;
}
/* モーダル内側の指定 */
.modal-container{
  position: relative;
  display: inline-block;
  vertical-align: middle;
  max-width: 600px;
  width: 90%;
}
/* モーダルを閉じるボタンの指定 */
.modal-close{
  position: absolute;
  display: flex;
  align-items: center;
  justify-content: center;
  top: -20px;
  right: -20px;
  width: 40px;
  height: 40px;
  color: #fff;
  background: #000;
  border-radius: 50%;
  cursor: pointer;
}
/* モーダルのコンテンツ部分の指定 */
.modal-content{
  text-align: left;
  line-height: 1.8;
}
.modal-content .movie{
  width: 100%;
  aspect-ratio: 16 / 9;
}
.modal-content .movie iframe,
.modal-content .movie video {
  width: 100%;
  height: 100%;
}
@media(max-width: 768px) {
  .movie-box{
    padding: 30px 0;
  }
}