@charset "utf-8";

/**
 *
 *  ページ用CSS
 *　design
 */

/*--------------------------------------------------------------------------
   Overwright
---------------------------------------------------------------------------*/
.page-ttl::before{
	background-image:url(../image/bg_ttl.jpg);		
}

.page-ttl{
  position: relative;
}


.page-ttl::after{
	content: "エントランスロビー完成予想図";
  position: absolute;
  bottom: 5px;
  right: 8px;
  text-shadow: -1px -1px 6px rgba(0,0,0,0.99),-1px -1px 6px rgba(0,0,0,0.99);
}

.landplan-img{
  position: relative;
  margin: 50px auto 10px;
}

.landplan-img .landplan-ttl{
  position: absolute;
  top: 10px;
  left: 10px;
  border: 1px solid #fff;
  font-size: 22px;
  padding: 5px 20px;

}

.landplan-img .landplan-hanrei{
  position: absolute;
  bottom: 0;
  left: 10px;
}


@media screen and (max-width: 768px) {

  .page-ttl::after{
    font-size: 11px;
    position: absolute;
  bottom: 41%;
  right: 8px;
  }

  .landplan-img .landplan-ttl{
    position: static;
    display: inline-block;
    border: 1px solid #fff;
    font-size: 17px;
    padding: 5px 20px;
    margin-bottom: 20px;
  
  }

  .landplan-img .landplan-hanrei{
    position: static;
    bottom: 0;
    left: 10px;
  }

}


/*--------------------------------------------------------------------------
   Content
---------------------------------------------------------------------------*/
.pic .caption{
  display: block;
  font-size: 1.2rem;
  text-align: right;  
}

img.shadow{
  box-shadow: 0px 10px 20px 0px rgba(0, 0, 0, 0.4);  
}

/* sec01
-----------------------------------------------------------------*/
.sec01{
  padding: 80px 0 90px;  
}

/* intro */
.sec01 .intro{
  margin-bottom: 110px;  
}

.sec01 .intro .txt-area{
  max-width: 1000px;
  width: 90%;
  margin: 0 auto;
}
.sec01 .intro .txt-area h2{
  margin-bottom: 60px;
  font-size: 3.8rem;
  line-height: 1.4;
  font-weight: 500;
  text-align: center;
}

.sec01 .intro .txt-area .txt{
  font-size: 1.6rem;
  line-height: 2.4;
  text-align: center;
  margin-bottom: 30px;
}

.sec01 .txt .cap,.sec02 .txt .cap{
  font-size: 1.2rem;
}

.sec01 .pic,.sec02 .pic{
  position: relative;
}

.sec01 .pic .caption,.sec02 .pic .caption{
  position: absolute;
  display: block;
  font-size: 1.2rem;
  text-align: right;
  right: 5px;
  bottom: 5px;  
}

.sec02 .pic .caption.black,.sec01 .pic .caption.black{
 color: #000;  
}

.sec01 .pic .number{
  position: absolute;
  display: block;
  font-size: 1.7rem;
  text-align: center;
  left: 15px;
  top: 15px;
  padding: 1px 12px 1px;
  background: #1d2088;  
}

.sec01 .landplan-box .pic .number,
.sec02 .landplan-box .pic .number{
  position: absolute;
  display: block;
  font-size: 1.7rem;
  text-align: center;
  left: 7px;
  top: auto;
  bottom: 7px;
  padding: 0 12px 1px;
  background: #1d2088;  
}


.sec01 .l-01{
  margin-bottom: 70px;
}

.sec01 .txt-lead{
  margin: 10px 0;
  font-size: 3rem;  
}
.sec01 .txt-lead2{
  font-size: 2.2rem !important;  
}

.sec02 .txt-lead{
  margin: 10px 0;
  font-size: 1.7rem;  
}

.sec01 .txt,.sec02 .txt{
  font-size: 1.5rem;
  line-height: 2;
  margin-bottom: 20px;  
}

.sec03 .txt{
  font-size: 1.5rem;
  line-height: 2;
  margin: 20px 0;  
}


.sec01 .l-02.layout-box,
.sec02 .l-02.layout-box,
.sec03 .l-03.layout-box{
  -ms-flex-wrap: wrap;
flex-wrap: wrap;
}

.sec01 .l-02 .landplan-box,
.sec02 .l-02 .landplan-box{
  width: 31%;
  text-align: left;
  margin-bottom: 40px;
}



@media screen and (max-width: 768px) {

  .sec01 .intro .txt-area h2{
  font-size: 2.8rem;
}

.sec01 .pic .number{
  position: absolute;
  display: block;
  font-size: 1.4rem;
  text-align: center;
  left: 5px;
  top: 5px;
  padding: 1px 10px;
}

.sec01 .txt-lead,.sec02 .txt-lead{
  margin-bottom: 0;
  font-size: 2.4rem;  
}

.sec01 .l-02 .landplan-box,
.sec02 .l-02 .landplan-box{
  width: 100%;
  text-align: left;
  margin-bottom: 40px;
}

.sec01 .txt,.sec02 .txt{
  font-size: 1.3rem;
  line-height: 2;
  margin-bottom: 20px;  
}

}



/* sec02
-----------------------------------------------------------------*/
.sec02{
  background:url(../../common/image/bg_body03.jpg);
  background-size: cover;
  padding: 100px 0 20px;
}

.sec02 h3,.sec03 h3{
font-size: 2.8rem;
margin-bottom: 20px;
border-bottom: #dcb747 1px solid;
padding-bottom: 10px;
position: relative;
}

.sec02 h3 span,.sec03 h3 span{
  font-size: 2.5rem;
  color: #dcb747;
  position: absolute;
  right: 0;
  bottom: 0;
  }

.sec02 .servicelist{
display: -webkit-box;
display: -ms-flexbox;
display: flex;
-ms-flex-wrap: wrap;
flex-wrap: wrap;
-webkit-box-pack: justify;
-ms-flex-pack: justify;
justify-content: space-between;
 }

.sec02 .servicelist li{
  background: #0a4561;
  border: 1px solid #fff;
  width: 48%;
  text-align: center;
  padding: 3% 1%;
  margin-bottom: 2%;
}


@media screen and (max-width: 768px) {

  .sec02{
    background:url(../../common/image/bg_body03.jpg);
    background-size: cover;
    padding: 50px 0 20px;
  }

  .sec02 h3,.sec03 h3{
    font-size: 2.0rem;
    margin-bottom: 20px;
    border-bottom: #dcb747 1px solid;
    padding-bottom: 10px;
    position: relative;
    }

    .sec02 h3 span,.sec03 h3 span{
      font-size: 1.8rem;

      }

}

/* sec03
-----------------------------------------------------------------*/
.sec03{
  position: relative;
  padding: 100px 0 100px;
}


.sec03 .l-03 .landplan-box{
  width: 35%;
  text-align: left;
  margin-bottom: 40px;
}

.sec03 .l-03 .security-img{
  width: 62%;
  text-align: left;
  margin-bottom: 40px;
}



.sec03 .security-box .pic{
  width: 40%;
}

.sec03 .security-box .txt-area{
  width: 55%;
}

.sec03 .security-box .txt-lead{
  font-size: 1.5rem;
}

.sec03 .security-box .txt-lead span{
  font-size: 1.3rem;
  background: #c9c2ac;
  color: #01111c;
  padding: 0px 8px;
  margin-right: 5px;
}



@media screen and (max-width: 768px) {

  .sec03{
    background-size: cover;
    padding: 50px 0 20px;
  }

  .sec03 .security-box{
    background: #1d2c36;
    padding: 5%;
  }

  .sec03 .l-03 .landplan-box,.sec03 .l-03 .security-img{
    width: 100%;
    text-align: left;
    margin-bottom: 10px;
  } 

  .sec03 .txt-lead{
    font-size: 1.5rem;
    line-height: 2;
    margin: 5px 0;  
  }

  .sec03 .txt{
    font-size: 1.3rem;
    line-height: 2;
    margin: 5px 0;  
  }

  .sec03 .layout-box{
    margin-bottom: 30px;
  }

  .sec03 .layout-box .pic{
    margin-top: 30px;
  }

}





/*--------------------------------------------------------------------------
   mobile
---------------------------------------------------------------------------*/
@media screen and (max-width: 768px) {

  
  .pic .caption{
    font-size: 1rem;
  }
  main section .inner{
    padding: 0 25px; 
  }

/* sec01
-----------------------------------------------------------------*/
  .sec01{
    padding: 50px 0 65px;  
  }

/* intro */
  .sec01 .intro{
    display: block;
    margin-bottom: 60px;  
  }
  .sec01 .intro .pic{
    margin-bottom: 35px;
    width: 100%;  
  }
  .sec01 .intro .pic .caption{
    padding-right: 10px;  
  }
  .sec01 .intro .txt-area{
    max-width: none;
    width: 100%;
    padding: 0 25px;  
  }
  .sec01 .intro .txt-area h2{
    width: 76.8vw;
    margin: 0 auto 25px;
  }
  .sec01 .intro .txt-area h2 img{
    transform: none;  
  }
  .sec01 .intro .txt-area .txt-lead{
    font-size: 2.8rem;
  }
  .sec01 .intro .txt-area .txt{
    font-size: 1.4rem;
    line-height: 2;
    text-align: justify;
  }




}