@charset "utf-8";
/* CSS Document */


/* kv
   ================================================================== */
.kv{
	margin: 0 0 0;
	position: relative;
    background-image: url("../images/webp/kv_bg_sp.webp");
    background-position: center center;
    background-repeat: no-repeat;
    background-size: cover;
}

.kv::before{
    content: "";
    background-image: url("../images/webp/cover.webp");
    background-position: center center;
    background-repeat: repeat;
    background-size: 3px;
    width: 100%;
    height: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

.kv .inner{
	padding: 0;
    position: relative;
    z-index: 1;
}

.kv h1{
    line-height: 0;
}

.kv h1 img{
    width: 100%;
}


/* price_block
   ================================================================== */
.price_block{
	padding: 2vw 0 25vw;
    border-bottom: 5px solid #222;
    box-sizing: border-box;
	position: relative;
}

.price_block::before{
    content: "";
    background-image: url("../images/webp/repeat_house.webp");
    background-position: left bottom;
    background-repeat: repeat-x;
    background-size: 100%;
    width: 300vw;
    height: 16vw;
    position: absolute;
    bottom: 0;
    left: 0;
}

.price_block .banner_top{
    margin: 0 0 0;
    position: relative;
    line-height: 0;
}

.price_block .cockroach{
    position: absolute;
    top: -20vw;
    left: 68vw;
    width: 26vw;
}

.price_block .note{
    margin: 8vw 0 0;
    font-size: 3.4vw;
}

.w490_banners{
    margin: 8vw 0 0;
    font-size: 0;
    line-height: 0;
}

.w490_banners li{
    margin: 4vw 0 0;
    line-height: 0;
}


.price_block table{
    margin: 6vw auto 0;
    width: 100%;
    box-sizing: border-box;
}

.price_block table th,
.price_block table td{
    border: 1px solid #ddd;
    background: #fff;
    box-sizing: border-box;
}

.price_block table th,
.price_block table td p,
.price_block table td{
    font-size: 3.3vw;
    line-height: 170%;
    letter-spacing: 0.1em;
}

.price_block table th{
    padding: 1vw 0 1vw 4vw;
    width: 25vw;
    vertical-align: middle;
    background: #F6F6F6;
}

.price_block table td{
    padding: 4vw;
}

.price_block table .box + .box{
    margin: 3vw 0 0;
    padding: 3vw 0 0;
    border-top: 1px dashed #ccc;
}

.price_block table .box h3{
    font-size: 3.7vw;
    font-weight: 400;
    color: #E74C3C;
}

.price_block table .box p{
    padding: 0 0 0 3vw;
}

.price_block .peace_main{
    margin: 12vw auto 0;
}


/* voices_block
   ================================================================== */
.voices_block{
	padding: 10vw 0 15vw;
}

.voices_block .anime_btn{
	margin: 15vw 0 0;
}


/* voices_slider
   ================================================================== */
.slider_wrap{
	margin: 8vw 0 0;
}

.voices_slider{
	margin: 0 0 0 !important;
    width: 80vw;
	position: relative;
    overflow: inherit !important;
}

.voices_slider{
    opacity: 0;
    transition: .3s;
}

.voices_slider.swiper-container-horizontal{
    opacity: 1;
}

.voices_slider .swiper-wrapper{
	line-height: 0;
}

.voices_slider .swiper-slide{
	padding: 4vw 4vw 7vw;
    background: #fff;
    border: 5px solid #ddd;
    border-radius: 20px;
    box-sizing: border-box;
    box-shadow: 0 10px 0 rgba(0,0,0,.16);
}

.voices_slider .profile{
	display: flex;
    align-items: center;
}

.voices_slider .thum{
	width: 12vw;
    line-height: 0;
}

.voices_slider .txt{
    padding: 3vw 0 0 2vw;
    width: calc(100% - 12vw);
	font-size: 5vw;
    font-family: "Zen Maru Gothic";
    color: #E74C3C;
}

.voices_slider .text_box{
	margin: 3vw 0 0;
    min-height: 100vw;
}

.voices_slider .text_box p{
    font-size: 3.6vw;
    font-weight: 500;
	color: #222;
    font-family: "Zen Maru Gothic";
}

.voices_slider .text_box p + p{
    margin: 3vw 0 0;
}


/* area_block
   ================================================================== */
.area_block{
	padding: 5vw 0 15vw;
}

.area_block .flex_box{
	margin: 8vw 0 0;
}

.area_block .photo{
	margin: 0 auto;
    width: 80vw;
}

.area_block .text_box{
	margin: 8vw 0 0;
}

.area_block .text_box h3{
	display: flex;
    align-items: center;
}

.area_block .text_box h3 .icon{
    width: 7vw;
	display: block;
    line-height: 0;
}

.area_block .text_box h3 .icon img{
    width: 100%;
}

.area_block .text_box h3 .text{
    padding: 0 0 0 4vw;
    width: calc(100% - 7vw);
	display: block;
    font-size: 3.9vw;
    color: #32A350;
    font-weight: 700;
    line-height: 1;
    box-sizing: border-box;
}

.area_block .area_list_box{
    margin: 6vw 0 0;
}

.area_block .area_list_box h4{
    font-size: 4vw;
}

.area_block .area_list_box ul{
    margin: 2vw 0 0;
    font-size: 0;
}

.area_block .area_list_box ul li{
    margin: 1vw 1% 0 0;
    font-size: 3.0vw;
    width: calc((100% - 4%) / 5);
    height: 8vw;
    background: #32A350;
    color: #fff;
    border-radius: 5px;
    display: inline-flex;
    justify-content: center;
    align-items: center;
    text-align: center;
    box-sizing: border-box;
}

.area_block .area_list_box ul li:nth-child(5n+5){
    margin-right: 0;
}

.area_block .area_list_box ul.outside li{
    background: #bbb;
}


/* faq
   ================================================================== */
.faq{
	padding: 5vw 0 20vw;
}

.faq .list{
	margin: 8vw 0 0;
}

.faq .list > li{
	margin: 4vw 0 0;
}

.faq .list h3{
	padding: 3vw 3vw;
    font-size: 3.6vw;
    font-weight: 500;
    color: #fff;
    background: #C0392B;
    position: relative;
}

.faq .list h3::before{
    margin: 0 3vw 0 0;
    font-size: 3.8vw;
    font-weight: 700;
    content: "Q.";
    vertical-align: text-bottom;
}

.faq .list .answer_box{
	padding: 4vw 3vw;
    border: 1px solid #C0392B;
    border-top: none;
}


/* column_block
   ================================================================== */
.column_block{
	padding: 5vw 0 20vw;
}

.column_block .column_list{
	margin: 8vw 0 0;
}

.column_block .anime_btn{
	margin: 15vw 0 0;
}


/* column_list
   ================================================================== */
.column_list > li{
	margin: 6vw 0 0;
}

.column_block .column_list > li{
    box-shadow: 0 5px 0 rgba(0,0,0,.16);
}

.column_list > li:first-child{
	margin: 0 0 0;
}

.column_list li a{
    padding: 4vw 3vw;
    background: #fff;
    border: 4px solid #fff;
	display: block;
}

.column_page .column_list li a{
    border-color: #eee;
}

.column_list li a span{
	display: block;
}

.column_list li a .icon{
    margin: -7vw 0 0 10vw;
	width: 20vw;
	line-height: 0;
    position: relative;
}

.column_list li a .icon img{
	width: 100%;

}

.column_list li a .icon::before{
    content: "";
    background: #D90000;
    width: 30vw;
    height: 1px;
    position: absolute;
    top: 70%;
    right: 100%;
}

.column_list li a .title{
    font-size: 3.6vw;
    line-height: 170%;
    font-weight: 700;
	overflow: hidden;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
}


/* ecology_block
   ================================================================== */
.ecology_block{
	padding: 5vw 0 20vw;
}

.ecology_block .list{
	margin: 8vw 0 0;
}

.ecology_block .list > li{
	margin: 4vw 0 0;
    padding: 1vw 3vw 4vw 1vw;
    background: #fff;
    border: 3px solid #B2B29B;
    border-radius: 10px;
    position: relative;
}

.ecology_block .list .sp_flex{
	display: flex;
    align-items: center;
}

.ecology_block .list .icon{
	width: 20vw;
    line-height: 0;
}

.ecology_block .list h3{
	padding: 5vw 0 0 3vw;
    font-size: 4vw;
    width: calc(100% - 20vw);
    font-weight: 900;
    box-sizing: border-box;
}

.ecology_block .list p{
	margin: 2vw 0 0 5vw;
    font-size: 3.6vw;
}


/* common_table
   ================================================================== */	
.common_table{
	margin: 0 auto;
    width: 100%;
    border-bottom: 1px solid #ddd;
}

.common_table th,
.common_table td{
	padding: 3vw 4vw;
    font-size: 3.5vw;
    line-height: 170%;
    letter-spacing: 0.1em;
    font-family: "Noto Sans JP";
    width: 100%;
    display: block;
    box-sizing: border-box;
}

.common_table th{
    border-top: 1px solid #ddd;
	background: #F6F6F6;
    font-weight: 700;
}

.common_table td{
	background: #fff;
    overflow: hidden;
}

.common_table td a{
	display: inline-block;
    font-size: inherit;
    line-height: inherit;
}

.common_table td .box + .box{
	margin: 4vw 0 0;
    padding: 4vw 0 0;
    position: relative;
}

.common_table td .box + .box::before{
	content: "";
    border-top: 1px dashed #ddd;
    position: absolute;
    top: 0;
    left: -50vw;
    width: 2000%;
}


/* company_block
   ================================================================== */
.company_block{
	padding: 5vw 0 0;
}

.company_block .common_table{
	margin: 8vw 0 0;
}


/* disclaimer_block
   ================================================================== */
.disclaimer_block{
	padding: 15vw 0 20vw;
}

.disclaimer_block .top_text{
	margin: 8vw 0 0;
}

.disclaimer_block .list{
	margin: 6vw 0 0;
}

.disclaimer_block .list > li{
	margin: 6vw 0 0;
}

.disclaimer_block .list h3{
	margin: 0 0 4vw;
    padding: 3vw 3vw;
    font-size: 3.6vw;
    background: #F6F6F6;
}

.disclaimer_block .list ul{
	margin: 4vw 0 0;
}

.disclaimer_block .list ul > li{
	margin: 3vw 0 0;
}

.disclaimer_block .list h4{
	margin: 0 0 1vw;
    font-size: 3.5vw;
}


/* contact
   ================================================================== */
.contact{
	padding: 5vw 0 25vw;
}

/* form */
.contact form{
	margin-top: 8vw;
}

.contact .top_text{
	margin: 0 0 2vw;
    text-align: center;
    font-size: 3.1vw;
}

.contact .conf_text{
    margin: 0 0 2vw;
	font-size: 4vw;
    color: #E64C3B;
    text-align: center;
    font-weight: 700;
	line-height: 150%;
}

.contact .req{
	color: #E64C3B;
}

.contact table{
    margin: 0 auto 0;
	width: 100%;
	line-height: 150%;
	box-sizing: border-box;
}

.contact th,
.contact td{
	width: 100%;
	display: block;
	font-weight: normal;
	border-bottom: none;
	box-sizing: border-box;
	font-size: 16px;
	letter-spacing: 0.10em;
}

.contact th{
	padding: 20px 0 0;
    font-weight: 500;
}

.contact td{
	padding: 10px 0 0;
    position: relative;
}

.contact input,
.contact select,
.contact textarea{
	margin: 0;
	padding: 15px;
	font-size: 16px;
	box-sizing: border-box;
	width: 100%;
    background: #F7F7F7;
	border: 1px solid #F7F7F7;
	vertical-align: middle;
}

.contact select{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	background-image: url("../images/common/down-arrow.svg");
    background-color: #F8F8F8;
	background-repeat: no-repeat;
	background-size: 10px 8px;
	background-position: right 16px center;
}

.contact input:focus,
.contact textarea:focus,
.contact select:focus{
	outline: none;
}

textarea::-webkit-input-placeholder,
input::-webkit-input-placeholder{
    color: #ccc;
}

textarea::-moz-placeholder,
input::-moz-placeholder{
    color: #ccc; opacity: 1;
}

textarea:-ms-input-placeholder,
input:-ms-input-placeholder{
    color: #ccc;
}

.contact textarea{
    height: 50vw;
	line-height: 150%;
}

/* ボタン */
.zas_btn_area{
	margin: auto;
	text-align: center;
	padding: 60px 0 0;
	font-size: 0;
	box-sizing: border-box;
	max-width: 500px;
}

.zas_btn_area button{
	padding: 16px 0;
	border: none;
	font-size: 16px;
	background: #D90000;
	width: 65%;
	max-width: 260px;
    letter-spacing: 0.1em;
	color: #FFF;
	position: relative;
	overflow: hidden;
	text-align: center;
    transition: .3s;
}

.zas_btn_area .zas_btn01{
	width: 65%;
	max-width: 260px;
}

.zas_btn_area .zas_btn02{
	margin-right: 2%;
	background: #ccc;
	width: 28%;
}

.zas_btn_area .zas_btn03{
	width: 65%;
	max-width: 260px;
}


/* thanks
   ================================================================== */
.thanks p{
    margin: 8vw 0 0;
	font-size: 4vw;
	line-height: 150%;
}

.thanks .go_top_btn{
	margin: 8vw 0 0;
	text-align: center;
}


/* column_page
   ================================================================== */
.column_page{
	padding: 5vw 0 25vw;
}

.column_page .column_list{
	margin: 10vw 0 0;
}


/* pagination
   ================================================================== */
.pagination{
	text-align: center;
	padding: 10vw 0 5px;
	font-size: 0;
}

.pagination li{
	display: inline-block;
    vertical-align: top;
	margin: 6px 3px 0;
}

.pagination li.disabled{
	display: none;
}

.pagination a,
.pagination .active span{
	text-decoration: none;
	background: #ddd;
	color: #FFF;
	padding: 2px 0 0;
	display: flex;
	justify-content: center;
	align-items: center;
    font-size: 10px;
    width: 40px;
    height: 40px;
    box-sizing: border-box;
    letter-spacing: 0;
    transition: all ease-out 0.3s;
    font-family: "メイリオ","ms pgothic", sans-serif;
}

.pagination .active span{
	display: none;
}

.pagination .active a{
	background: #D90000;
    pointer-events: none;
}


/* sns_area
   ================================================================== */
.sns_area{
	margin: 4vw 0 0;
	line-height: 1;
    overflow: hidden;
}

.sns_area div{
	margin-bottom: 5px;
	margin-right: 5px;
	float: left;
	display: inline-block;
	font-size: 0;
	line-height: 1;
}

.linebutton img{
	width: 21px;
}



/* detail_page
   ================================================================== */
.detail_page{
	margin: 12vw 0 0;
	font-size: 16px;
	word-break: break-all;
}

.detail_page .detail_box h1{
	border-bottom: 1px solid #D90000;
	font-size: 18px;
	font-weight: bold;
	margin: 0 0 10px;
	padding: 0 10px 10px;
	word-break: break-all;
	line-height: 150%;
}

.detail_page .f_box{
	margin: 4vw 0 0;
    font-size: 0;
}

.detail_page .hiduke{
    margin-right: 4vw;
    font-size: 3.5vw;
    color: #333;
    font-weight: 400;
    display: inline-block;
    vertical-align: middle;
}

.detail_page .detail_categories{
	margin: -.5vw 0 0;
    display: inline-block;
	vertical-align: middle;
}

.detail_page .detail_categories > ul{
    font-size: 0;
}

.detail_page .detail_categories > ul > li{
    margin: .5vw .5vw 0 0;
    padding: 1vw 3vw;
    display: inline-block;
    vertical-align: top;
    box-sizing: border-box;
    font-size: 3vw;
    line-height: 150%;
    color: #fff;
    background: #D90000;
    border-radius: 0;
}

.detail_page .photo{
	margin: 4vw 0 0;
	line-height: 0;
}
	
.detail_page .photo img{
	max-height: 500px;
}
	
.detail_page .detail_body{
	margin: 4vw 0 0;
    clear: both;
}


/* detail_btn_area
   ================================================================== */
.detail_btn_area{
	margin: 10vw 0 0;
    padding: 10px;
	font-size: 0;
    text-align: center;
    background: #F9F9F9;
}

.detail_btn_area .btn{
	margin: 0;
	display: inline-block;
	vertical-align: top;
	box-sizing: border-box;
	width: 40%;
    max-width: 310px;
}
	
.detail_btn_area .btn.prev,
.detail_btn_area .btn.next{
	width: 28%;
}

.detail_btn_area .btn.back{
	margin: 0 2%;
}

.detail_btn_area .btn a,
.detail_btn_area .btn button{
	display: block;
	margin: auto;
	padding: 10px 0;
    box-sizing: border-box;
	width: 100%;
    height: 50px;
	background: #fff;
    border: 1px solid #ddd;
	color: #333;
	text-align: center;
	font-size: 16px;
	letter-spacing: 0.10em;
	font-family: "Noto Sans JP","メイリオ","ms pgothic", sans-serif;
}


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


    /* kv
       ================================================================== */
    .kv{
        background-image: url("../images/webp/kv_bg.webp");
    }

    .kv::before{
        background-size: 3px;
    }

    .kv .inner{
        padding: 0 2.0vw;
    }

    .kv h1{
        padding: 3.5vw 2.5vw 0 3.0vw;
    }


    /* price_block
       ================================================================== */
    .price_block{
        padding: 3.0vw 0 17.0vw;
    }

    .price_block::before{
        background-size: 197.9vw;
        width: 100vw;
        height: 10.0vw;
    }

    .price_block .banner_top{
        margin: 1.0vw 0 0;
    }
    
    .price_block .banner_top::before{
        content: "";
        background-image: url("../images/webp/discount01_balloon.webp");
        background-position: center center;
        background-repeat: no-repeat;
        background-size: 100%;
        width: 14.0vw;
        height: 14.0vw;
        position: absolute;
        top: 3.5vw ;
        left: 76.0vw;
        z-index: 1;
    }

    .price_block .cockroach{
        position: absolute;
        top: -15.2vw;
        left: 64.6vw;
        width: 33.7vw;
    }

    .price_block .note{
        margin: 2.5vw 0 0;
        font-size: 1.4vw;
        line-height: 2.3vw;
    }

    .w490_banners{
        margin: .5vw 0 0;
    }

    .w490_banners li{
        margin: 2.0vw 2% 0 0;
        width: 49%;
        display: inline-block;
        vertical-align: top;
        box-sizing: border-box;
    }

    .w490_banners li:nth-child(2n+2){
        margin-right: 0;
    }


    .price_block table{
        margin: 4.0vw auto 0;
    }

    .price_block table th,
    .price_block table td p,
    .price_block table td{
        font-size: 1.5vw;
        line-height: 2.5vw;
    }

    .price_block table th{
        padding: 1.0vw 1.0vw 1.0vw 3.0vw;
        width: 21.0vw;
    }

    .price_block table td{
        padding: 1.4vw 0 2.5vw 2.3vw;
    }

    .price_block table .box + .box{
        margin: 1.5vw 0 0;
        padding: 1.5vw 0 0;
    }

    .price_block table .box h3{
        font-size: 1.7vw;
    }

    .price_block table .box p{
        padding: 0 0 0 1.0vw;
    }

    .price_block .peace_main{
        margin: 5.5vw auto 0;
        width: 86.0vw;
    }


    /* voices_block
       ================================================================== */
    .voices_block{
        padding: 4.0vw 0 10.7vw;
    }

    .voices_block .anime_btn{
        margin: 8.0vw 0 0;
    }


    /* voices_slider
       ================================================================== */
    .slider_wrap{
        margin: 4.5vw 0 0;
    }

    .voices_slider{
        margin: 0 0 0 !important;
        width: 78.0vw;
    }

    .voices_slider .swiper-slide{
        padding: 2.0vw 3.0vw;
    }

    .voices_slider .thum{
        width: 3.6vw;
    }

    .voices_slider .txt{
        padding: 1.0vw 0 0 1.5vw;
        width: calc(100% - 3.6vw);
        font-size: 2.3vw;
    }

    .voices_slider .text_box{
        margin: 2.0vw 0 0;
        min-height: 48.0vw;
    }

    .voices_slider .text_box p{
        font-size: 1.6vw;
        line-height: 2.8vw;
    }

    .voices_slider .text_box p + p{
        margin: 2.0vw 0 0;
    }


    /* area_block
       ================================================================== */
    .area_block{
        padding: 5.4vw 0 10.0vw;
    }

    .area_block .flex_box{
        margin: 4.0vw 0 0;
        display: flex;
    }

    .area_block .photo{
        margin: 0 auto;
        width: 35.0vw;
    }

    .area_block .text_box{
        margin: 0 0 0;
        padding: 0 0 0 3.5vw;
        width: calc(100% - 35.0vw);
        box-sizing: border-box;
    }

    .area_block .text_box h3 .icon{
        width: 3.1vw;
    }

    .area_block .text_box h3 .text{
        padding: 0 0 0 1.5vw;
        width: calc(100% - 3.1vw);
        font-size: 1.9vw;
    }

    .area_block .area_list_box{
        margin: 2.0vw 0 0;
    }

    .area_block .area_list_box + .area_list_box{
        margin: 2.5vw 0 0;
    }

    .area_block .area_list_box h4{
        font-size: 2.0vw;
    }

    .area_block .area_list_box ul{
        margin: 1.0vw 0 0;
    }

    .area_block .area_list_box ul li{
        margin: .5vw 1% 0 0;
        font-size: 1.4vw;
        width: calc((100% - 5%) / 6);
        height: 3.3vw;
    }

    .area_block .area_list_box ul li:nth-child(5n+5){
        margin-right: 1%;
    }

    .area_block .area_list_box ul li:nth-child(6n+6){
        margin-right: 0;
    }


    /* faq
       ================================================================== */
    .faq{
        padding: 6.6vw 0 14.5vw;
    }

    .faq .list{
        margin: 5.0vw 0 0;
    }

    .faq .list > li{
        margin: 2.5vw 0 0;
    }

    .faq .list h3{
        padding: 1.8vw 2.5vw;
        font-size: 1.6vw;
    }

    .faq .list h3::before{
        margin: 0 1.5vw 0 0;
        font-size: 1.8vw;
    }

    .faq .list .answer_box{
        padding: 2.5vw;
    }


    /* column_list
       ================================================================== */
    .column_list > li{
        margin: 3.5vw 0 0;
    }

    .column_list li a{
        padding: 2.2vw 3.0vw 3.0vw;
        transition: .3s;
    }

    .column_list li a:hover{
        border-color: #D90000 !important;
    }

    .column_list li a .icon{
        margin: -4.0vw 0 0 4.0vw;
        width: 7.4vw;
    }

    .column_list li a .icon::before{
        width: 12.0vw;
    }

    .column_list li a .title{
        margin: .3vw 0 0;
        font-size: 1.6vw;
        -webkit-line-clamp: 1;
    }


    /* ecology_block
       ================================================================== */
    .ecology_block{
        padding: 7.7vw 0 17.3vw;
    }

    .ecology_block .list{
        margin: 4.0vw 0 0;
    }

    .ecology_block .list > li{
        margin: 2.5vw 0 0;
        padding: 2.6vw 2.0vw 5.5vw 17.0vw;
        position: relative;
    }

    .ecology_block .list .sp_flex{
        display: block;
    }

    .ecology_block .list .icon{
        width: 13.0vw;
        position: absolute;
        top: 1.0vw;
        left: 1.5vw;
    }

    .ecology_block .list h3{
        padding: 0;
        font-size: 2.0vw;
        width: 100%;
    }

    .ecology_block .list p{
        margin: 1.0vw 0 0;
        font-size: 1.6vw;
        line-height: 2.6vw;
    }
   

    /* common_table
       ================================================================== */	
    .common_table{
        border-bottom: none;
    }
    
    .common_table th,
    .common_table td{
    	padding: 1.5vw 3.0vw;
        font-size: 1.5vw;
        line-height: 3.0vw;
        width: auto;
        display: table-cell;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }
    
    .common_table th{
        width: 21.0vw;
    }

    .common_table td .box + .box{
    	margin: 2vw 0 0;
        padding: 2vw 0 0;
    }


    /* company_block
       ================================================================== */
    .company_block{
        padding: 5.0vw 0 0;
    }

    .company_block .common_table{
        margin: 5.0vw 0 0;
    }


    /* disclaimer_block
       ================================================================== */
    .disclaimer_block{
        padding: 5.0vw 0 21.5vw;
    }

    .disclaimer_block .top_text{
        margin: 3.5vw 0 0;
    }

    .disclaimer_block .list{
        margin: 3.0vw 0 0;
    }

    .disclaimer_block .list > li{
        margin: 3.0vw 0 0;
    }

    .disclaimer_block .list h3{
        margin: 0 0 1.8vw;
        padding: 1.5vw 2.5vw;
        font-size: 1.6vw;
    }

    .disclaimer_block .list ul{
        margin: 1.8vw 0 0;
    }

    .disclaimer_block .list ul > li{
        margin: 1.7vw 0 0;
    }

    .disclaimer_block .list h4{
        margin: 0 0 .8vw;
        font-size: 1.5vw;
    }


    /* contact
       ================================================================== */
    .contact{
    	padding: 5.0vw 0 23.0vw;
    }
    
    /* form */
    .contact form{
        margin-top: 5.7vw;
    }

    .contact .top_text{
    	margin: 0 0 3vw;
        font-size: 1.5vw;
    }
        
    .contact .conf_text{
        margin: 0 0 3vw;
    	font-size: 1.5vw;
    }

    .contact table{
        margin: 0 auto 0;
        width: 70%;
    }
    
    .contact th,
    .contact td{
        width: auto;
    	font-size: 15px;
    }
    
    .contact th{
    	padding: 20px 0 0;
        box-sizing: border-box;
    }
    
    .contact .title_top th{
    	padding-top: 31px;
        vertical-align: top;
    }
    
    .contact td{
    	padding: 18px 0;
    }
    
    .contact input,
    .contact select,
    .contact textarea{
    	margin: 0;
    	padding: 15px;
    	font-size: 16px;
    }
	
	.contact select{
		vertical-align: middle;
	}
    
    .contact textarea{
        height: 230px;
    }
    
    /* ボタン */
    .zas_btn_area{
    	margin: auto;
    	text-align: center;
    	padding: 50px 0 0;
    	font-size: 0;
    	box-sizing: border-box;
    }
    
    .zas_btn_area button{
    	padding: 18px 0;
    	font-size: 16px;
    	border: 1px solid #D90000;
        transition: .3s;
        cursor: pointer;
    	width: 50%;
    	max-width: 280px;
    }
    
    .zas_btn_area .zas_btn01{
    	width: 50%;
    	max-width: 280px;
    }
    
    .zas_btn_area .zas_btn02{
    	margin-right: 2%;
    	width: 28%;
        border-color: #ccc;
    }
    
    .zas_btn_area .zas_btn03{
    	width: 50%;
    	max-width: 280px;
    }
    
    .zas_btn_area .zas_btn01:hover,
    .zas_btn_area .zas_btn03:hover{
    	background: #fff;
    }
    
    .zas_btn_area .zas_btn02:hover{
    	opacity: .5;
    }
    
    .zas_btn_area .zas_btn01:hover,
    .zas_btn_area .zas_btn03:hover{
    	color: #D90000;
    }


    /* thanks
       ================================================================== */
    .thanks p{
        margin: 3vw 0 0;
    	font-size: 1.6vw;
        line-height: 3.9vw;
        text-align: center;
    }
    
    .thanks .go_top_btn{
    	margin: 6vw 0 0;
    }
 	

    /* column_page
       ================================================================== */
    .column_page{
    	padding: 5.0vw 0 23.0vw;
    }

    .column_page .column_list{
        margin: 5.0vw 0 0;
    }


	/* pagination
	   ================================================================== */
	.pagination{
		margin: 6vw 0 0;
		padding: 0;
	}

    .pagination a,
    .pagination .active span{
    	padding: 1px 0 0;
    }
	
	.pagination a:hover{
		background: #D90000;
	}
     

	/* sns_area
	   ================================================================== */
    .sns_area {
        margin: 2vw 0 0;
    }
    
	.sns_area div{
		margin-bottom: 0;
		margin-right: 5px;
	}


    /* detail_page
       ================================================================== */
    .detail_page{
    	margin: 5vw 0 0;
    }
    
    .detail_page .detail_box h1{
    	font-size: 20px;
    	margin: 0 0 10px;
    	padding: 0 10px 10px;
    }
    
    .detail_page .f_box{
    	margin: 2vw 0 0;
    }
    
    .detail_page .hiduke{
        margin-right: 2vw;
        font-size: 1.8vw;
    }
    
    .detail_page .detail_categories{
    	margin: -5px 0 0;
    }
    
    .detail_page .detail_categories > ul{
        font-size: 0;
    }
    
    .detail_page .detail_categories > ul > li{
        padding: .5vw 2vw;
        margin: 5px 5px 0 0;
        font-size: 1.5vw;
        transition: .3s;
    }
    
    .detail_page .photo{
    	margin: 2vw 0 0;
    }
    	
    .detail_page .detail_body{
    	margin: 3vw 0 0;
    }


	/* detail_btn_area
	   ================================================================== */
    .detail_btn_area .btn,
    .detail_btn_area .btn.next,
    .detail_btn_area .btn.prev{
    	width: 32%;
    }

    .detail_btn_area .btn.back{
    	margin: 0 2%;
    }
    
	.detail_btn_area .btn a,
	.detail_btn_area .btn button{
		padding: 0;
		width: 100%;
        height: 45px;
        line-height: 45px;
		text-align: center;
		font-size: 15px;
		letter-spacing: 0.10em;
		transition: .3s;
		cursor: pointer;
	}
	
	.detail_btn_area .btn a:hover,
	.detail_btn_area .btn button:hover{
		background: #D90000;
		border-color: #D90000;
        color: #fff;
	}

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


    /* kv
       ================================================================== */
    .kv .inner{
        padding: 0 20px;
    }

    .kv h1{
        padding: 35px 25px 0 30px;
    }


    /* price_block
       ================================================================== */
    .price_block{
        padding: 30px 0 170px;
    }

    .price_block::before{
        background-size: 1979px;
        width: 100vw;
        height: 100px;
    }

    .price_block .banner_top{
        margin: 10px 0 0;
    }
    
    .price_block .banner_top::before{
        content: "";
        background-image: url("../images/webp/discount01_balloon.webp");
        background-position: center center;
        background-repeat: no-repeat;
        background-size: 100%;
        width: 140px;
        height: 140px;
        position: absolute;
        top: 35px ;
        left: 760px;
        z-index: 1;
    }

    .price_block .cockroach{
        position: absolute;
        top: -152px;
        left: 646px;
        width: 337px;
    }

    .price_block .note{
        margin: 25px 0 0;
        font-size: 14px;
        line-height: 23px;
    }

    .w490_banners{
        margin: 5px 0 0;
    }

    .w490_banners li{
        margin: 20px 2% 0 0;
        width: 49%;
        display: inline-block;
        vertical-align: top;
        box-sizing: border-box;
    }

    .w490_banners li:nth-child(2n+2){
        margin-right: 0;
    }


    .price_block table{
        margin: 40px auto 0;
    }

    .price_block table th,
    .price_block table td p,
    .price_block table td{
        font-size: 15px;
        line-height: 25px;
    }

    .price_block table th{
        padding: 10px 10px 10px 30px;
        width: 210px;
    }

    .price_block table td{
        padding: 14px 0 25px 23px;
    }

    .price_block table .box + .box{
        margin: 15px 0 0;
        padding: 15px 0 0;
    }

    .price_block table .box h3{
        font-size: 17px;
    }

    .price_block table .box p{
        padding: 0 0 0 10px;
    }

    .price_block .peace_main{
        margin: 55px auto 0;
        width: 860px;
    }


    /* voices_block
       ================================================================== */
    .voices_block{
        padding: 40px 0 107px;
    }

    .voices_block .anime_btn{
        margin: 80px 0 0;
    }


    /* voices_slider
       ================================================================== */
    .slider_wrap{
        margin: 45px 0 0;
    }

    .voices_slider{
        margin: 0 0 0 !important;
        width: 780px;
    }

    .voices_slider .swiper-slide{
        padding: 20px 30px;
    }

    .voices_slider .thum{
        width: 36px;
    }

    .voices_slider .txt{
        padding: 10px 0 0 15px;
        width: calc(100% - 36px);
        font-size: 23px;
    }

    .voices_slider .text_box{
        margin: 20px 0 0;
        min-height: 480px;
    }

    .voices_slider .text_box p{
        font-size: 16px;
        line-height: 28px;
    }

    .voices_slider .text_box p + p{
        margin: 20px 0 0;
    }


    /* area_block
       ================================================================== */
    .area_block{
        padding: 54px 0 100px;
    }

    .area_block .flex_box{
        margin: 40px 0 0;
        display: flex;
    }

    .area_block .photo{
        margin: 0 auto;
        width: 400px;
    }

    .area_block .text_box{
        margin: 0 0 0;
        padding: 0 0 0 35px;
        width: calc(100% - 400px);
        box-sizing: border-box;
    }

    .area_block .text_box h3 .icon{
        width: 31px;
    }

    .area_block .text_box h3 .text{
        padding: 0 0 0 15px;
        width: calc(100% - 31px);
        font-size: 19px;
    }

    .area_block .area_list_box{
        margin: 20px 0 0;
    }

    .area_block .area_list_box + .area_list_box{
        margin: 25px 0 0;
    }

    .area_block .area_list_box h4{
        font-size: 20px;
    }

    .area_block .area_list_box ul{
        margin: 10px 0 0;
    }

    .area_block .area_list_box ul li{
        margin: 5px 1% 0 0;
        font-size: 15px;
        width: calc((100% - 5%) / 6);
        height: 33px;
    }

    .area_block .area_list_box ul li:nth-child(5n+5){
        margin-right: 1%;
    }

    .area_block .area_list_box ul li:nth-child(6n+6){
        margin-right: 0;
    }


    /* faq
       ================================================================== */
    .faq{
        padding: 66px 0 145px;
    }

    .faq .list{
        margin: 50px 0 0;
    }

    .faq .list > li{
        margin: 25px 0 0;
    }

    .faq .list h3{
        padding: 18px 25px;
        font-size: 16px;
    }

    .faq .list h3::before{
        margin: 0 15px 0 0;
        font-size: 18px;
    }

    .faq .list .answer_box{
        padding: 25px;
    }


    /* column_block
       ================================================================== */
    .column_block{
        padding: 60px 0 114px;
    }

    .column_block .column_list{
        margin: 50px 0 0;
    }

    .column_block .anime_btn{
        margin: 76px 0 0;
    }


    /* column_list
       ================================================================== */
    .column_list > li{
        margin: 35px 0 0;
    }

    .column_list li a{
        padding: 22px 30px 30px;
    }

    .column_list li a .icon{
        margin: -40px 0 0 40px;
        width: 74px;
    }

    .column_list li a .icon::before{
        width: 120px;
    }

    .column_list li a .title{
        margin: 3px 0 0;
        font-size: 16px;
        -webkit-line-clamp: 1;
    }


    /* ecology_block
       ================================================================== */
    .ecology_block{
        padding: 77px 0 173px;
    }

    .ecology_block .list{
        margin: 40px 0 0;
    }

    .ecology_block .list > li{
        margin: 25px 0 0;
        padding: 26px 20px 55px 170px;
        position: relative;
    }

    .ecology_block .list .sp_flex{
        display: block;
    }

    .ecology_block .list .icon{
        width: 130px;
        position: absolute;
        top: 10px;
        left: 15px;
    }

    .ecology_block .list h3{
        padding: 0;
        font-size: 20px;
        width: 100%;
    }

    .ecology_block .list p{
        margin: 10px 0 0;
        font-size: 16px;
        line-height: 26px;
    }
  

    /* common_table
       ================================================================== */	
    .common_table{
        border-bottom: none;
    }
    
    .common_table th,
    .common_table td{
    	padding: 15px 30px;
        font-size: 15px;
        line-height: 30px;
        width: auto;
        display: table-cell;
        border-top: 1px solid #ddd;
        border-bottom: 1px solid #ddd;
    }
    
    .common_table th{
        width: 210px;
    }

    .common_table td .box + .box{
    	margin: 20px 0 0;
        padding: 20px 0 0;
    }


    /* company_block
       ================================================================== */
    .company_block{
        padding: 50px 0 0;
    }

    .company_block .common_table{
        margin: 50px 0 0;
    }


    /* disclaimer_block
       ================================================================== */
    .disclaimer_block{
        padding: 50px 0 215px;
    }

    .disclaimer_block .top_text{
        margin: 35px 0 0;
    }

    .disclaimer_block .list{
        margin: 30px 0 0;
    }

    .disclaimer_block .list > li{
        margin: 30px 0 0;
    }

    .disclaimer_block .list h3{
        margin: 0 0 18px;
        padding: 15px 25px;
        font-size: 16px;
    }

    .disclaimer_block .list ul{
        margin: 18px 0 0;
    }

    .disclaimer_block .list ul > li{
        margin: 17px 0 0;
    }

    .disclaimer_block .list h4{
        margin: 0 0 8px;
        font-size: 15px;
    }


    /* contact
       ================================================================== */
    .contact{
    	padding: 50px 0 230px;
    }
    
    /* form */
    .contact form{
        margin-top: 57px;
    }

    .contact .top_text{
        margin: 0 0 30px;
    	font-size: 15px;
    }
    
    .contact .conf_text{
        margin: 0 0 30px;
    	font-size: 15px;
    }
    
    .contact table{
        margin: 0 auto 0;
        width: 70%;
    	font-size: 15px;
    }
    
    .contact th{
    	padding: 20px 0 0;
    }
    
    .contact td{
    	padding: 18px 0 0;
    }
    
    .contact input,
    .contact select,
    .contact textarea{
    	font-size: 16px;
    	padding: 22px 20px;
    }
    
    .contact textarea{
        height: 275px;
    }
    
    /* ボタン */
    .zas_btn_area{
    	padding: 90px 0 0;
    }
    
    .zas_btn_area button{
    	padding: 17px 0;
    	font-size: 16px;
        width: 280px;
    }
    
    .zas_btn_area .zas_btn01{
    	width: 280px;
    }
    
    .zas_btn_area .zas_btn02{
    	margin-right: 2%;
    	width: 28%;
    }
    
    .zas_btn_area .zas_btn03{
    	width: 280px;
    }


    /* thanks
       ================================================================== */
    .thanks p{
        margin: 30px 0 0;
    	font-size: 16px;
        line-height: 39px;
    }
    
    .thanks .go_top_btn{
    	margin: 60px 0 0;
    }
 	

    /* column_page
       ================================================================== */
    .column_page{
    	padding: 50px 0 230px;
    }

    .column_page .column_list{
        margin: 50px 0 0;
    }


	/* pagination
	   ================================================================== */
	.pagination{
		margin: 80px 0 0;
		padding: 0;
	}

    .pagination a,
    .pagination .active span{
        padding: 2px 0 0;
    	font-size: 13px;
    	width: 50px;
    	height: 50px;
    }
     

	/* sns_area
	   ================================================================== */
    .sns_area {
        margin: 25px 0 0;
    }
    
	.sns_area div{
		margin-right: 10px;
	}


    /* detail_page
       ================================================================== */
    .detail_page{
    	margin: 65px 0 0;
    }
    
    .detail_page .detail_box h1{
    	font-size: 25px;
    	margin: 0 0 10px;
    	padding: 0 10px 10px;
    }
    
    .detail_page .f_box{
    	margin: 20px 0 0;
    }
    
    .detail_page .hiduke{
        margin-right: 23px;
        font-size: 15px;
    }
    
    .detail_page .detail_categories > ul{
        font-size: 0;
    }
    
    .detail_page .detail_categories > ul > li{
        margin: 5px 5px 0 0;
        padding: 5px 15px;
        font-size: 13px;
    }
    
    .detail_page .photo{
    	margin: 20px 0 0;
    }
    	
    .detail_page .detail_body{
    	margin: 25px 0 0;
    }


	/* detail_btn_area
	   ================================================================== */
	.detail_btn_area{
		margin: 110px 0 0;
		font-size: 0;
		text-align: center;
	}
	
	.detail_btn_area .btn{
		margin: 0;
	}
	
	.detail_btn_area .btn.back{
		margin: 0 20px;
	}
	
	.detail_btn_area .btn a,
	.detail_btn_area .btn button{
		padding: 0;
		width: 100%;
        height: 60px;
        line-height: 60px;
		text-align: center;
		font-size: 16px;
		letter-spacing: 0.10em;
    }
    

}
