.service-headerBox{
    background-color: #C9C9C9;
    padding-bottom: 0;
    padding-top: 100px;
}
.service-header{
    margin-bottom: 80px;
}
.service-head__eg{
    font-family: "Alegreya", serif;
    font-style: italic;
    font-size: 6.4rem;
    font-weight: 600;
    text-align: center;
}
.service-head__ja{
    font-size: 1.8rem;
    text-align: center;
}
.service-hd__image{
    width: 100%;
}
.service-hd__image img{
    max-height: 640px;
    object-fit: cover;
}
@media screen and (min-width: 768px){
    .service-header{
        margin-bottom: 100px;
    }
    .service-head__eg{
        font-size: 6.4rem;
    }
}
.example-inr p{
    text-align: center;
}
.exampleBox{
    text-align: center;
}
.example-topText{
    text-align: center;
    display: inline;
    font-size: 2.4rem;
    font-weight: 700;
    background: linear-gradient(transparent 50%, #fff 0%);
    margin-bottom: 50px;
}

.example-textBg{
    position: relative;
    background: no-repeat center center / contain;
    background-image: url(/system_panel/uploads/images/question-img.png);
    height: 200px;
    width: auto;
    margin-bottom: 50px;
}
.example-textBg p{
    font-size: 2.0rem;
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 100%;
}
.example-wrap{
    max-width: 380px;
    width: 100%;
    margin: 0 auto 50px;
}
.example-wrap p{
    display: block;
    font-size: 2.0rem;
    padding: 10px;
    border: solid 1px #707070;
    border-radius: 5px;
}
.example-imageBox{
    margin-bottom: 15px;
}
@media screen and (min-width: 768px){
    .example-topText{
        font-size: 4.0rem;
    }
    .example-textBg{
        margin-bottom: 100px;
    }
    .example-textBg p{
        font-size: 3.0rem;
    }
    .example-flexBox{
        display: flex;
        flex-wrap: wrap;
        justify-content: center;
        gap: 30px;
        max-width: 760px;
        margin: 0 auto;
    }
    .example-wrap{
        width: calc((100% - 30px) / 2);
        margin: 0;
    }
}
@media screen and (min-width: 1024px){
    .example-flexBox{
        max-width: none;
    }
    .example-wrap{
        width: calc((100% - 60px) / 3);
        margin: 0;
    }
    .example-wrap p{
        padding: 30px 10px;
    }
}
@media screen and (min-width: 1080px){
}
.catchBox{
    background: no-repeat center center / cover;
    background-image: url(/system_panel/uploads/images/catch1.jpg);
    padding: 60px 0;
}
.catch-inrBox{
    position: relative;
}
.catchBox p{
    color: #fff;
    text-align: center;
}
.catch-title{
    font-size: 2.0rem;
}
.catchBox p strong{
    font-size: 3.0rem;
    font-weight: 400;
}
.catch-text{
    font-size: 1.8rem;
}
.catch-tree01Box{
    position: absolute;
    top: 90px;
    right: 20px;
    width: 100px;
}
@media screen and (min-width: 768px){
    .catch-title{
        font-size: 3.2rem;
    }
    .catch-title span br{
        display: none;
    }
    .catchBox p strong{
        font-size: 4.0rem;
    }
    .catch-text{
        font-size: 2.0rem;
    }
    .catch-treeBox01{
        width: 200px;
        top: 20px;
    }
}
@media screen and (min-width: 1024px){
}
@media screen and (min-width: 1080px){
}
.workBox h3{
    font-size: 3.2rem;
    text-align: center;
    margin-bottom: 80px;
}
.work-wrap{
    margin: 0 auto;
    flex: 1;
    margin-bottom: 30px;
    max-width: 300px;
}
.work-wrap p{
    font-size: 1.8rem;
    font-weight: 700;
    text-align: left;
}
.work-imageBox{
    margin: 0 auto;
    text-align: center;
    margin-bottom: 15px;
}


@media screen and (min-width: 768px){
    .work-flexBox{
        display: flex;
        gap: 20px;
    }
    .work-wrap{
        margin-bottom: 0;
    }

}
@media screen and (min-width: 1024px){
    .work-flexBox{
    }
}
@media screen and (min-width: 1080px){
}
.reasonBox{
    overflow: hidden;
    position: relative;
}
.reason-wrap{
    flex: 1;
    margin: 0 auto;
    max-width: 340px;
    margin-bottom: 30px;
}
.reason-flexWrap{
    position: relative;
    z-index: 1;
}
.reason-imageBox{
    text-align: center;
    margin-bottom: 15px;
}
.reason-title{
    text-align: center;
    font-weight: 700;
    font-size: 2.0rem;
    margin-bottom: 15px;
}
.reason__en{
    font-size: 5.0rem;
    font-family: "Alegreya", serif;
    font-style: italic;
    font-weight: 600;
}
.reason__ja {
    font-size: 1.8rem;
}
.reason-titleBox{
    margin-bottom: 40px;
    position: relative;
    z-index: 1;
}
.reason-bgTree01{
    object-fit: cover;
    position: absolute;
    width: 700px;
    height: auto;
    top: -150px;
    left: -150px;
    opacity: 7%;
}
.reason-bgTree02{
    object-fit: cover;
    position: absolute;
    width: 700px;
    height: auto;
    bottom: -200px;
    right: -150px;
    opacity: 7%;
}
@media screen and (min-width: 768px){
    .reason-title{
        font-size: min(2.1vw, 2.4rem);
    }
    .reason__en{
        font-size: 6.4rem;
    }
    .reason-titleBox{
        margin-bottom: 80px;
    }
    .reason-flexWrap{
        display: flex;
        gap: 20px;
        justify-items: center;
        margin: 0 auto;
    }
    .reason-bgTree02{
        bottom: -200px;
    }
    .reason-wrap{
        margin-bottom: 0;
    }
}
@media screen and (min-width: 1024px){
}
@media screen and (min-width: 1080px){
}
.catch-title{
    margin-bottom: 50px;
}
.catch-tree02Box{
    position: absolute;
    bottom: -100px;
    left: 20px;
    width: 100px;
}
@media screen and (min-width: 768px){
    .catch-tree02Box{
        bottom: -100px;
        width: 130px;
    }
}
@media screen and (min-width: 1024px){
}
@media screen and (min-width: 1080px){
}
.contact-hd__en{
    font-size: 5.0rem;
    font-family: "Alegreya", serif;
    font-style: italic;
    font-weight: 600;
}
.contact-hd__jp{
    font-size: 1.8rem;
    margin-bottom: 40px;
}
.contactBox{
    background-color: #F9F8F6;
}
.contactText{
    text-align: center;
    font-size: 1.8rem;
    margin-bottom: 100px;
}
.form-bg{
    padding: 40px 15px;
    background: no-repeat center center / cover;
    background-image: url(/system_panel/uploads/images/bg_form.jpg);
}
@media screen and (min-width:768px){
    .contact-hd__en{
        font-size: 6.4rem;
    }
    .contact-hd__jp{
        font-size: 1.8rem;
        margin-bottom: 40px;
    }
    .form-bg{
        padding: 60px 15px;
    }
    .contactText{
        font-size: 2.0rem;
    }
}
/*フォーム外側*/
.contact-mail-box{
    padding: 70px 0;
}
.contact-form-otr{
    padding: 30px 15px 40px;
    text-align: left;
    max-width: 1100px;
    margin: 0 auto;
    background: #fff;
}
/*フォーム注意書き*/
.formnote {
    color: #e7280d;
    text-align: right;
    max-width: 1000px;
    font-size: 1.4rem;
    margin-bottom: 20px;
}
/*フォーム*/
.form.formWrap {
    max-width: 1000px;
    margin: 0 auto 100px auto;
}
/*行*/
.row{
    margin: 0;
}
.row.formRow {
    border-top: 1px solid #999999;
    display:-webkit-box;
	display:-ms-flexbox;
    display: flex;
    padding: 15px 0;
    flex-wrap: wrap;
}
.formRow-bottom{
    border-bottom: 1px solid #999999;
}
label{
    font-size: 1.4rem;
}
/*左*/
.formTh{
    width: 100%;
    margin-bottom: 5px;
}
.labeltxt{
    display: inline-block;
}
.labelText01{
    font-weight: 500;
}
.d-inline-block .labelText02{
    margin-right: 15px;
}
.d-inline-block:last-of-type .labelText02{
    margin-right: 0;
}
.requiredText  {
    color: #e7280d;
    margin-left: 10px;
    display: inline-block;
}
/*右*/
.formTd {
    width: 100%;
    text-align: left;
}
/*ラジオボタン*/
.radio-div{
    display: inline-block;
    vertical-align: middle;
}
.radio-div:not(:last-of-type) {
    margin-right: 20px;
}
.radio {
    margin-right: 10px;
}
/*インプット*/
.input {
    width: 100%;
}
/*郵便番号*/
.input.zipInput {
    width: 40%;
}
/*内容*/
.textarea {
    width: 100%;
    height: 120px;
}
/*ボタン*/
.form-btn-otr{
    padding-top: 50px;
    text-align: center;
}
.formBtn{
    cursor: pointer;
    background-color: #3C3C3C;
    border: none;
    max-width: 300px;
    width: 100%;
    line-height: 60px;
    color: #fff;
    letter-spacing: 0.05em;
    position: relative;
}
.formBtn:focus {
	outline:0;
}
@media screen and (min-width:768px) {
    .contact-form-otr {
        padding:30px 15px 60px 15px;
    }
    .radio-div{
        display: block;
        margin-right: 0;
    }
    label{
        font-size: 1.6rem;
    }
    .formTh {
        width: 30%;
        margin-bottom: 0;
    }
    .formTd {
        width: 70%;
    }
    .input.zipInput {
        width: 30%;
    }
    .form-btn-otr:first-of-type{
        margin-bottom:20px;
    }
    .formBtn{
        max-width: 400px;
        line-height: 80px;
    }
    .selectArea-year{
        display: flex;
    }
    .row.formRow{
        padding: 15px 10px;
    }
    .d-block{
        display: inline-block!important;
    }
    .d-block:nth-of-type(4){
        padding-left: 1px;
    }
}

/*プライバシーポリシー*/
.privacy-box{
    padding-top: 40px;
}
.privacy{
    padding: 40px 0 70px;
}
.privacyBox {
    overflow-y: scroll;
    text-align:left;
    max-width:1000px;
    margin: 0 auto;
    height:300px;
    border: 1px solid #ccc;
    padding:30px 15px 0;
    background: #fff;
}
.privacyDt {
    font-weight: 700;
    padding-bottom: 3px;
}
.privacyDd-top {
    margin-bottom: 55px;
}
.privacyDd {
    margin-bottom: 35px;
}
@media screen and (min-width:768px) {
    .privacy-box{
        padding-top: 60px;
    }
    .privacy{
        padding: 60px 0 150px;
    }
    .privacyBox {
        padding:30px 30px 0;
    }
}

/*

施工事例Works


*/
.worksBox{
    background: no-repeat center center / cover;
    background-image: url(/system_panel/uploads/images/works-bg.jpg);
}
.works-title{
    text-align: center;
    font-weight: 700;
    font-size: 2.0rem;
    margin-bottom: 15px;
}
.works__en{
    font-size: 5.0rem;
    font-family: "Alegreya", serif;
    font-style: italic;
    font-weight: 600;
    color: #fff;
}
.works__ja {
    font-size: 1.8rem;
    color: #fff;
}
.works-titleBox{
    margin-bottom: 40px;
}
.article-title{
    font-size: 2.4rem;
    margin-bottom: 40px;
    color: #fff;
}
.post-leftWrap{
    width: 100%;
    text-align: center;
    max-width: 600px;
    margin: 0 auto 50px auto;
}
.post-rightWrap{
    width: 100%;
    text-align: center;
    max-width: 600px;
    margin: 0 auto 50px auto;
}
.post-leftWrap img{
    object-fit: cover;
}
.post-rightWrap img{
    object-fit: cover;
}
.post-detail{
    color: #fff;
    margin-bottom: 30px;
    text-align: left;
}
.post-tag{
    color: #fff;
    text-align: left;
}
@media screen and (min-width: 768px){
    .works-title{
        font-size: 2.4rem;
    }
    .works__en{
        font-size: 6.4rem;
    }
    .works-titleBox{
        margin-bottom: 80px;
    }
    .works-flexBox{
        display: flex;
        gap: 50px;
    }
    .article-title{
        font-size: 3.2rem;
        margin-bottom: 80px;
    }
    .post-leftWrap{
        width: 50%;
        margin-bottom: 0;
    }
    .post-rightWrap{
        flex: 1;
    }
    .post-rightWrap figure{
        margin-bottom: 30px;
    }

}
@media screen and (min-width: 1024px){

}
@media screen and (min-width: 1080px){
}