@charset "utf-8";
/* ------------------------------
    共通パーツ
------------------------------ */
*{
    margin: 0;
    padding: 0;
}
html { 
    font-size: 62.5%; 
}
body{
    font-size: 1.6rem;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 400;
    font-style: normal;
    /* background-color: #fff5ea; */
    color: #72151a;
}
p{
    letter-spacing: 0.08em;
}
.fz_30{
    font-size: 3rem;
}
.flex_box{
    display: flex;
    align-items: center;
}

.fv{
    width: 100%;
    height: 100vh;
    position: relative;
}
.fv_flex{
    width: 100%;
    height: 100%;
}
.fv_flex img{
    width: 50%;
    object-fit: cover;
    height: 100vh;
}
.mainvisual{
    display: flex;
    justify-content: center;
    align-items: center;
    width: 100% !important;
    /* height: 850px; */
    height: 100vh;
}
.slide_container.sp_only{
    display: none;
}
.swiper.pc_vertical{
    width: 50%;
    width: 100%;
    height: 850px;
    height: 100vh;
}
.swiper-wrapper .swiper-slide{
    width: 100% !important;
    height: 100vh !important;
}
.swiper-wrapper img{
	width:100vw !important;
    height: 100vh !important;
    object-fit: cover;
}
.float{
    width: 100%;
    height: 160px;
    background-color: rgba(255,255,255,0.5);
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    display: flex;
    align-items: center;
    justify-content: center;
}
.float_img{
    /* position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%);
    z-index: 5; */
    max-width: 572px;
    width: 100%;
}

.intro{
    margin: 60px auto 0;
    width: 100%;
}
.explain{
    flex-direction: column;
    justify-content: center;
}
.explain p{
    text-align: center;
    letter-spacing: 0.08em;
    line-height: 2;
}
.explain .fz_30{
    line-height: 1.6;
}
.intro .images{
    width: 100%;
    max-width: 1200px;
}
.intro .images.interior{
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-around;
    margin: 1em auto;
}
.intro .images.interior img{
    width: 50%;
    padding: 1em;
}
.interior01{
    max-width: 500px;
}
.interior03{
    max-width: 520px;
}
.interior04{
    max-width: 530px;
}

.detail{
    max-width: 1400px;
    width: 100%;
    margin: 90px auto 86px;
}
.pdf,
.apply{
    flex-direction: column;
    width: 50%;
}
.btn{
    max-width: 480px;
    width: 100%;
    background-color: #72151a;
    color: #fff;
    padding: 0.5em 3em;
    justify-content: center;
}
.pdf img{
    max-width: 315px;
    width: 100%;
}
.pdf .btn{
    margin: 30px 0 0;
}
.apply .btn{
    margin: 24px 0 0;
}
.apply .renove{
    max-width: 368px;
    width: 100%;
    margin: 40px auto 36px;
}
.apply .exterior{
    max-width: 664px;
    width: 100%;
}
.contact{
    max-width: 868px;
    width: 100%;
    margin: 0 auto;
}
.contact img{
    max-width: 134px;
    width: 100%;
    margin: 0 32px 0 0;
}
.map{
    max-width: 868px;
    width: 100%;
    aspect-ratio: 4 / 3;
    margin: 60px auto;
}
.map iframe{
    width: 100%;
    height: 100%;
    border: 0;
}

.footer{
    margin: 40px 0 0;
}
.footer img{
    width: 100%;
}

@media screen and (max-width: 768px) {


.mainvisual{
    height: 100vh;
    height: auto;
}
.swiper.pc_vertical{
    height: 100vh;
    height: 100%;
}
.swiper-wrapper .swiper-slide{
    height: 100vh !important;
    height: 100% !important;
}
.swiper-wrapper img{
    height: 100% !important;
    object-fit: cover;
    object-fit: contain;
}

    /* mainvisual */
    .pc_only{
        display: none;
    }
    .sp_only{
        display: block;
    }
    .mainvisual{
        display: flex;
        flex-direction: column;
        width: 100% !important;
        height: 100vh;
    }
    .mainvisual.pc_only{
        display: none;
    }
    .swiper-wrapper .swiper-slide{
        width: 100% !important;
        height: 50vh !important;
    }
    .slide_container.sp_only{
        display: block;
    }
    .sp_only .swiper{
        width: 100%;
        height: 50%;
        /* height: 100%; */
    }
    .sp_only .swiper-slide{
        display: flex;
        justify-content: center;
        align-items: center;
    }
    
    .sp_only .swiper-wrapper img {
        object-fit: unset;
        object-fit: cover;
        max-width: 100%;
    }

    .fv_flex{
        flex-direction: column;

    }
    .fv_flex img{
        width: 100%;
        height: 50vh;
    }
    .float_img{
        padding: 0 2em;
    }
    .explain {
        padding: 0 1em;
    }
    .explain .fz_30{
        font-size: 2.4rem;
    }
    .info{
        padding: 0 2em;
    }
    .detail{
        flex-direction: column;
        margin: 60px 0;
    }
    .intro .images.interior img{
        width: 100%;
    }
    .pdf, .apply {
        width: 100%;
    }
    .pdf .btn {
        padding: .5em 2em;
    }
    .apply {
        margin: 60px 0 0;
    }
    .apply .fz_30{
        font-size: 2.4rem;
        padding: 0 1em 0 0;
    }
    .contact {
        flex-direction: column;
    }
    /* .btn {
        width: 480px;
    } */
}

@media screen and (max-width: 390px) {
    .btn p{
        font-size: 1.2rem;
    }
}