.revitalize #hero{
    background: #F8F5E5;
    z-index: 10;
    position: relative;
    min-height: 610px;
}
.revitalize #hero .inner{
    width: 956px;
    margin: 0 auto;
    position: relative;
    padding-top: 170px;
}

.revitalize #hero h2.catch{
font-size:30px;
font-weight:400;
line-height: 1.75;
}
.revitalize #hero h3{
    font-size: 25px;
    font-weight: 400;
    line-height: 1.75;
    position: relative;
    padding-left: 40px;
    z-index: 10;
    margin: 30px 0px 40px -1em;
}

.revitalize #hero h3::before {
    content: url('/asset/images/revitalize/img01.png');
    position: absolute;
    left: 0;
    top: 50%;
    transform: translateY(-50%);
    margin-bottom: 0;
    width: 90px;
    height: 90px;
    z-index: -10;

}

.revitalize #hero p.text{
    width:100%;
    max-width: 335px;
    line-height: 2;
    letter-spacing: 1px;
    font-size: 15px;
}
.revitalize #hero img.illust{
    position: absolute;
    right: 0;
    bottom: -170px;
    width: 640px;
}
.revitalize img.border{
    margin-top: 0px;
    width: 100%;
}
_::-webkit-full-page-media, _:future, :root .revitalize img.border{
    margin-top: -25px;
    
}
/*totutotu*/
.revitalize #totutotu{
    padding-top:170px;
}

.revitalize #totutotu .inner{
    width: 900px;
    margin: 0 auto;
    text-align: center;
    padding-bottom: 166px;
border-bottom: 1px dotted #707070;
}

.revitalize #totutotu h2 img.icon{
    margin: 0 auto;
    display: block;
    width: 65px;
}

.revitalize #totutotu h2{
    font-size: 25px;
    font-weight: 400;
    display: block;
    text-align: center;
    letter-spacing: 1px;
    margin: 20px auto;
}

.revitalize #totutotu h2 img.logo{
    margin: 20px auto 50px;
    display: block;
    width: 172px;
}


.revitalize #totutotu img.illust{
    margin:0 auto 100px;
}

/*place*/

.revitalize #place{
    padding-top:170px;
}

.revitalize #place .inner{
    width: 900px;
    margin: 0 auto;
    text-align: center;
    padding-bottom: 166px;
border-bottom: 1px dotted #707070;
}

.revitalize #place h2 img.icon{
    margin: 0 auto;
    display: block;
    width: 65px;
}

.revitalize #place h2{
    font-size: 25px;
    font-weight: 400;
    display: block;
    text-align: center;
    letter-spacing: 1px;
    margin: 20px auto;
}


.revitalize #place img.illust{
    margin: 80px auto;
    width: 343px;
}

.revitalize #place .news-single{
    display: flex;
    width: 560px;
    margin: 10px auto 20px;
    gap: 30px;
    text-align: left;
}

.revitalize #place .news-thumbnail img{
    width: 112px;
}

.revitalize #place .news-more a.btn{
margin-top:80px;
}

/*sdgs*/
.revitalize #sdgs{
    padding-top:80px;
}

.revitalize #sdgs .inner{
    width: 900px;
    margin: 0 auto;
    text-align: center;
    padding-bottom: 80px;
border-bottom: 1px dotted #707070;
}

.revitalize #sdgs .inner h2{
    display: block;
    text-align: center;
    margin: 0 auto;
    font-size: 18px;
    font-weight: 500;
    letter-spacing: 2px;
}

.revitalize #sdgs .inner h2 img{
    display: block;
    margin: 0 auto -15px;
    width: 160px;
}

.revitalize #sdgs .inner .flexwrap{
display: flex;
width: 580px;
margin: 30px auto;
justify-content: space-between;
}

.revitalize #sdgs .inner .flexwrap .item{
    width: 150px;
    }
.revitalize #sdgs .inner .flexwrap .item h3{
    font-size: 16px;
    font-weight: 400;
}

.revitalize #sdgs .inner .flexwrap .item span{
display: block;
}

.revitalize #sdgs .inner .flexwrap .item img{
    max-width: 112px;
    max-height: 112px;    
}
@media (max-width: 768px) {
    .revitalize #hero .inner {
        width: 100%;
padding:40px 20px;
    }
    .revitalize #hero img.illust{
        position: relative;
    }
    .revitalize #hero h2.catch {
        font-size: 26px;
        text-align: center;
    }
    .revitalize #hero h3::before {
        content: url('/asset/images/revitalize/img01.png');
        position: absolute;
        margin-bottom: 0;
        width: 90px;
        height: 90px;
        z-index: -10;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
    
    }
    .revitalize #hero h3 {
        font-size: 20px;
        padding-left: 0px;
        text-align: center;
        letter-spacing: 5px;
        margin: 40px auto 60px;
    }

    .revitalize #hero p.text {
        font-size: 15px;
        text-align: left;
        position: relative;
        margin-top: 40px;
    }

    .revitalize #hero img.illust {
        width: 100%;
        bottom:0;
        margin:0;
    }

    
    .revitalize #totutotu .inner,
    .revitalize #place .inner,
    .revitalize #sdgs .inner {
        width: 90%;
padding:40px 0px;
    }

    .revitalize #totutotu {
        padding-top: 80px;
    }

    .revitalize #totutotu h2,
    .revitalize #place h2,
    .revitalize #sdgs .inner h2 {
        font-size: 20px;
    }

    .revitalize #totutotu img.illust {
        margin-bottom: 40px;
    }
    .revitalize #place {
        padding-top: 20px;
    }
    .revitalize #place img.illust {
        margin: 40px auto;
        width: 100%;
        max-width: 223px;
    }
    .revitalize #place .news-single {
        width: 100%;
    }

    .revitalize #place .news-thumbnail img {
        width: 100%;
        max-width: 110px;
    }

    .revitalize #place .news-more a.btn {
        margin-top: 40px;
    }
    .revitalize #sdgs .inner .flexwrap {
        flex-direction: column;
        width: 100%;
    }

    .revitalize #sdgs .inner .flexwrap .item {
        width: 100%;
        margin-bottom: 20px;
        display: flex;
        max-width: 325px;
        gap: 25px;
        justify-content: flex-start;
        margin-left: 10px;
        align-items: center;
    
    }
    .revitalize #sdgs .inner .flexwrap .item h3 {
        font-size: 15px;
        text-align: left;
        line-height: 1.5;
    }
    .revitalize #sdgs .inner .flexwrap .item img{
        max-width: 64px;
        max-height: 64px;    
    }
}