@charset "utf-8";



/* ==========================================================================
	hasei_main
========================================================================== */

#hasei_main{padding-bottom: 0;height: 480px;box-sizing:border-box;}
#hasei_main:after{
    content:"";
    display: block;
    width: calc(100% - var(--base-size80));
    height: 1px;
    position: absolute;
    right: 0;
    bottom: 0;
    background:#222;
    
}
#hasei_main h2{
    letter-spacing: 0.15em;
}
@media screen and (max-width : 800px ){

    #hasei_main{padding-bottom: 55px;height: auto;}
    #hasei_main:after{
        background:#ccc;
    }
    
}

/* ==========================================================================
	form_wrap
========================================================================== */
.form_wrap{
    width:100%;
    display: block;
    box-sizing:border-box;
    padding-top: 90px;
    padding-bottom: 64px;
}
.form{
    width: calc(100% - var(--rt-tit-width));
    padding-left:var(--base-size80);
    box-sizing:border-box;
    margin-bottom: 50px;
}
.intro_txt {
    font-size: 15px;
    line-height: 36px;
}
.intro_txt .r_txt {
    color:#f4521c;
}
#form{margin-top: 92px;}

.form .item{
	box-sizing:border-box;
	position:relative;
	-js-display: flex;
	display:-webkit-box;
	display: -webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
    margin-bottom: 50px;
    width: 100%;
}

.form .text_area {
    position: relative;
    width: 280px;
    width: clamp(200px,19.4vw,280px);
	vertical-align: middle;
    font-size: 18px;
    font-weight: bold;
    box-sizing:border-box;
    padding-top: 31px;
    padding-left: 10px;
    letter-spacing: 0.1em;
}
/*
.ie .form .text_area {
     width: 20%;   
}

.form.conf .text_area{
    padding-top: 0;
}
*/

textarea.form-item{    
    min-height:320px;
    padding:25px;
}
.form .text_area label{
    font-weight: bold;    
}
.form .text_area span{
    font-weight: 500;
    font-size: 15px;
    color:var(--base-link-color);
    padding-left: 2px;
}

.form .form_area {
    width: calc(100% - 280px);
    width:calc(100% - clamp(200px,19.4vw,280px));
}

.form .form_area p{
    position: relative;
	vertical-align: middle;
    font-size: 15px;
}



.form.conf .item{
    
    margin-bottom: 30px;
    padding-bottom: 30px;
    width: 100%;
    border-bottom: 1px solid #eee;
}
.form.conf .item:last-child{
    border:none;
    padding-bottom:0;
    margin-bottom:0;
}

.form.conf .text_area {padding-top: 0;}

.form-item {
	width: 100%;
	height: 90px;
	padding: 0 25px;
	background:#f6f6f6;
    border-radius:3px;
	font-size: 15px;
	box-sizing: border-box;
    border:none;
    transition:background ease .3s;
}


.form-item:focus {
    background-color: #e5e5e5;
    transition:background ease .3s;
}



/*
.form-foot{
    width: 100%;
	-js-display: flex;
	display:-webkit-box;
	display: -webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
    
}

.form-foot li{
    width: 48%;
}
.form-submit{
.form-submit.back{
    background: #bbb;
}
.form-submit:hover{
    background:#ff7a59;
}

.form-foot li .form-submit{
    width: 100%;
    margin-left: 0;
}

.form-list {
	-js-display: flex;
	display:-webkit-box;
	display: -webkit-flex;
	display:-moz-box;
	display:-ms-flexbox;
	display: flex;
	-webkit-justify-content: space-between;
    justify-content: space-between;
	-webkit-flex-wrap: wrap;
		-ms-flex-wrap: wrap;
			flex-wrap: wrap;
}
*/
.check_area{
    position: relative;
}


.check_area label {
	position: relative;
	padding-left: 30px;
	cursor: pointer;
    display:inline-block;
	font-size:15px;
    line-height: 1.5;
}


.check_area label a{
    color:var(--base-text-color);
    text-decoration: underline;
}
.check_area label a:hover{
    color:var(--base-link-color);
}


.check_area input {
	opacity: 0;
	position: absolute;
	left: 0;
	z-index: 0;
}
.check_area label:before,
.check_area label:after {
	content: "";
	display: block;
	position: absolute;
	box-sizing: border-box;
    -webkit-transition: opacity 0.3s all ease;
    transition: opacity 0.3s ease;
}
.check_area label:before {
	width: 20px;
	height: 20px;
    border-radius:3px;
	border: 1px solid #222;
	top: 2px;
	left: 0;
	z-index: 0;
}
.check_area input:checked + label:before {
	border-color: rgba(0, 0, 0, 1);
}


.check_area input + label:after {
	width: 20px;
	height: 20px;
	top: 2px;
	left: 0;
    background:url(../image/contact/check.png);
    background-size:cover;
	z-index: 1;
	opacity: 0;
}
.check_area input:checked + label:after {
	opacity: 1;
}

.link_btn_wrap{
    position: relative;
    width: 500px;
}
.form .link_btn{
    transition:all .3s var(--easeInOutCubic);
    padding: 22px 0 23px 38px;
    text-align:left;
    border:none;
    margin-top: 46px;
}

.link_btn_wrap:before{
    content:'';
  position: absolute;
    top: 0;
    bottom: 0;
    right: 30px;
    margin:auto;
    width: 50px;
    height: 1px;
    background:#fff;
    transition:all .3s var(--easeInOutCubic);
    z-index:20;
}
.link_btn_wrap:after{
    content: '';
    position: absolute;
    top: 31px;
    right: 30px;
    width: 10px;
    height: 1px;
    transform: rotate(35deg);
    background:#fff;
    transition:all .3s var(--easeInOutCubic);
    z-index:20;
}



.form-foot .link_btn_wrap,
.form-foot .link_btn{
     width: 100%;   
}

.form-foot{
    position: relative;
    	-js-display: flex;
    	display:-webkit-box;
    	display: -webkit-flex;
    	display:-moz-box;
    	display:-ms-flexbox;
    	display: flex;
    	-webkit-justify-content: space-between;
        justify-content: space-between;
    	-webkit-flex-wrap: wrap;
    		-ms-flex-wrap: wrap;
    			flex-wrap: wrap;
    max-width:1050px;
    width: 100%;
}
.form-foot li{
    width: 47.8619%;    
}

.link_btn_wrap.rev .link_btn{
    text-align: right;
    padding: 22px 38px 23px 0;
    
}
.link_btn_wrap.rev:before{
    right:auto;
    left:30px;
    
}
.link_btn_wrap.rev:after{
    left: 30px;
    transform: rotate(145deg);
}


.link_btn_wrap:hover:before{
    transform: translateX(8px);
    width: 58px;
}
.link_btn_wrap:hover:after{
    right: 22px;
}


.link_btn_wrap.rev:hover:before{
    transform: translateX(-8px);
    width: 58px;
}
.link_btn_wrap.rev:hover:after{
    left: 22px;
}



.thanks .link_btn:after{
    top: 27px;
}



@media screen and (max-width : 1050px ){ 
    .rt_box.form_wrap{padding-right: 0;}
    .form{width: 100%;padding-right:var(--base-size80);}
}
@media screen and (max-width : 950px ){ 
    .rt_box.list .link_area a {
        width: 48%;
        margin-right: 4%;
    }
    .rt_box.list .link_area a:nth-child(3n){
        margin-right: 4%;
    }
    .rt_box.list .link_area a:nth-child(2n){
        margin-right: 0%;
    }
}

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


    .form_wrap{
        padding-top: 42px;
        padding-bottom: 15px;
    }
    .form{
        width: 100%;
        padding-left:6vw;
        margin-bottom: 48px;
    }
    .intro_txt {
        font-size: 13px;
        line-height: 26px;
    }
    #form{margin-top: 48px;}

    .form .item{
        display: block;
        margin-bottom: 36px;
    }

    .form .text_area {
        position: relative;
        width: 100%;
        padding-top: 0;
        padding-left: 0;
        font-size: 14px;
    }
    textarea.form-item{    
        min-height:180px;
        padding:20px;
    }
    .form .text_area span{
        font-size: 13px;
    }

    .form .form_area {
        width: 100%;
        margin-top: 19px;
    }
    .form .item:nth-child(4){
        margin-bottom: 26px;
    }

    .form-item {
        width: 100%;
        height: 60px;
        padding: 0 20px;
        background:#f6f6f6;
        border-radius:3px;
        font-size: 14px;
    }


    .form.conf .item{
        margin-bottom: 36px;
        padding-bottom: 0px;
        border-bottom: none;
    }


    .form.conf .item p{
        text-align:left;
    }
    
    .form .form_area p{text-align: center;}
    .check_area label {
        padding-left: 20px;
        font-size:12px;
    }



    .check_area label:before {
        width: 15px;
        height: 15px;
        top: 2px;
    }
    .check_area input + label:after {
        width: 15px;
        height: 15px;
        top: 2px;
        left: 0;
    }

    .link_btn_wrap{
        width: 100%;
    }
    .form .link_btn{
        width: 100%;
        padding: 20px 0 22px 20px;
        margin-top: 40px;
    }

    .link_btn_wrap:before{
        right: 35px;
        width: 27px;
    }
    .link_btn_wrap:after{
        top:28px;
        right: 35px;
        width: 6px;
    }


    .link_btn_wrap:hover:before{
        transform: translateX(0);
        width: 27px;
    }
    .link_btn_wrap:hover:after{
        right: 35px;
    }
    
    .form-foot{
      
        display: block;
    }
    .form-foot li{
        width: 100%;    
    }
    .form-foot li:first-child{
        margin-bottom: 20px;
    }
    
    .link_btn_wrap.rev .link_btn{
        padding: 20px 20px 22px 0;

    }
    .link_btn_wrap.rev:before{
        right:auto;
        left:35px;
    }
    .link_btn_wrap.rev:after{
        left: 35px;
    }



    .link_btn_wrap.rev:hover:before{
        transform: translateX(0);
        width: 27px;
    }
    .link_btn_wrap.rev:hover:after{
        left: 35px;
    }
    .form-foot .link_btn{
        margin-top: 20px;
    }
    
    

    .thanks .link_btn:after{
        top: 25px;
    }

}
