@charset "utf-8";

html,body,h1,h2,h3,h4,h5,ul,ol,dl,li,table,th,td,p {
	margin: 0;
	padding: 0;
	line-height: 1.5;
    letter-spacing: 0.07rem;
	font-family: "arial","Hiragino Kaku Gothic ProN",Meiryo,sans-serif;
	color: #4d4d4d;
}
ul,ol,dl,li,table,th,td,p{
    font-size: 18px;
}
ul {
	list-style: none;
}
a {
	text-decoration: none;
	color: inherit;
	cursor: pointer;
    transition: 0.3s;
}
a:hover{
    opacity: 0.5;
}
img {
	border: none;
	vertical-align: bottom;
	width: 100%;
}
table{
    border-collapse: collapse;
}

.pc_none{
    display: none;
}

/* ------------------- */

.container{
    max-width: 1290px;
    margin: 0 auto;
    padding: 0 15px;
}

/* header */
header{
    background-color: #fff;
    width: 100%;
    position: fixed;
    z-index: 15;
}
header .container{
    padding: 20px 30px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    max-width: 1450px;
}
header h1 img{
    width: 350px;
    padding-bottom: 8px;
}

/* g-nav */
.burger{
    display: none;
}
.sp_nav{
	display: none;
    right: -700px;
}
.pc_nav{
    display: flex;
}
.pc_nav li{
    margin-left: 30px;
}
.pc_nav li a{
    font-weight: bold;
}

/* fv */
.fv{
    background-color: #edece6;
    position: relative;
    height: 700px;
    overflow: hidden;
    padding-top: 120px;
    margin-bottom: 80px;
}
.fv>.container{
    display: flex;
    align-items: center;
    height: 100%;
    max-width: 1450px;
}
.fv_text{
    z-index: 10;
}
.fv_text p{
    font-size: 22px;
    line-height: 1.7;
    text-shadow: 1px 1px 5px #fff;
}
.fv_text .main_copy{
    font-size: 36px;
    margin-bottom: 35px;
    font-weight: bold;
    color: #6f5b26;
    line-height: 1.5;
}
.fv .keyvisual{
    width: 1000px;
    position: absolute;
    top: 0;
    bottom: -80px;
    margin: auto;
    right: -200px;
}

/* ----------- */

section{
    margin-bottom: 80px;
}
h2{
    color: #af9c69;
    text-align: center;
    font-size: 36px;
    margin-bottom: 50px;
}
h3{
    font-size: 22px;
    margin-bottom: 20px;
}

#section_01 img{
    width: 250px;
    padding: 0 30px;
}
#section_01 ul{
    list-style: disc;
    margin-left: 25px;
}
.service_container{
    display: flex;
    justify-content: space-between;
    align-items: center;
    margin-bottom: 80px;
}
.service_container>div{
    max-width: 900px;
    margin-left: 30px;
}

.service_flex{
    display: flex;
    justify-content: space-between;
}
.service_child{
    width: 48%;
    margin-bottom: 80px;
}
.service_child img{
    display: block;
    margin: 0 auto 30px;
}

/* ------------- */

.about_us_table{
    margin-bottom: 30px;
    width: 100%;
}
.about_us_table th{
    width: 350px;
    font-size: 18px;
}
.about_us_table td{
    padding: 20px 0;
    line-height: 1.7;
    font-size: 18px;
}
.about_us_table th,.about_us_table td{
    border-bottom: 1px solid #b3b3b3;
}
.about_us_table tr:last-child th,.about_us_table tr:last-child td{
    border-bottom: none;
}

/* --------------- */

.mw_wp_form {
    max-width: 800px;
    margin: 0 auto 100px;
}
.warning{
    text-align: center;
    margin-bottom: 50px;
}
.mw_wp_form dl{
    display: flex;
    margin-bottom: 15px;
}
.mw_wp_form dl dt{
    width: 300px;
}
.mw_wp_form dl dd{
    width: 500px;
    margin-inline-start: 0;
}
.mw_wp_form dl dd input{
    width: 100%;
    height: 25px;
    border: 1px solid #b3b3b3;
    border-radius: 3px;
}

.mw_wp_form .free_form{
    display: block;
}

.mw_wp_form .free_form dt,.mw_wp_form .free_form dd{
    width: 100%;
}
.mw_wp_form .free_form dt{
    margin: 30px 0 10px;
}

.mw_wp_form dl dd textarea{
    width: 100%;
    height: 150px;
    border: 1px solid #b3b3b3;
    border-radius: 3px;
}
.hissu{
    color: #cc0000;
}
.submit-btn{
    text-align: center;
}
.submit-btn input{
    background: #6f5b26;
    color: #fff;
    border: none;
    width: 300px;
    line-height: 40px;
    font-weight: bold;
    font-size: 18px;
    margin: 20px auto 0;
    cursor: pointer;
    transition: 0.3s;
}
.submit-btn input:hover{
    opacity: 0.5;
}




/* --------------- */

/* フッター */
.copyright{
    background: #d5d5d8;
    padding: 15px 0;
    text-align: center;
}


/* --------- */

.contact_box{
    padding-top: 300px;
    text-align: center;
}
.contact_box p{
    margin-bottom: 50px;
}
.to_top_button{
    display: block;
    text-align: center;
    background: #e58341;
    color: #fff;
    border: none;
    width: 300px;
    line-height: 40px;
    font-weight: bold;
    font-size: 18px;
    margin: 200px auto 100px;
    cursor: pointer;
    transition: 0.3s;
}
.to_top_button:hover{
    opacity: 0.5;
}

/* --------- */


.contact_box{
    padding-top: 300px;
    text-align: center;
}
.contact_box p{
    margin-bottom: 50px;
}
.to_top_button{
    display: block;
    text-align: center;
    background: #6f5b26;
    color: #fff;
    border: none;
    width: 300px;
    line-height: 40px;
    font-weight: bold;
    font-size: 18px;
    margin: 200px auto 100px;
    cursor: pointer;
    transition: 0.3s;
}
.to_top_button:hover{
    opacity: 0.5;
}




/* Media Query　----------------------------------- */
@media screen and (max-width:767px){

    header{
        padding: 10px 5px;
    }
    header .container{
        display: block;
    }
    header h1 img{
        width: 300px;
        padding-bottom: 10px;
    }    
    

    .pc_nav{
        display: none;
    }

	.slide{
		right: 0;
	}
    .burger{
		display: block;
        width: 50px;
        height: 50px;
        z-index: 5000;
		
        position: fixed;
        top: 25px;
        right: 10px;
    }
    .burger span{
		position: absolute;
		width: 35px;
		height: 3px;
		background: #6f5b26;
		border-radius: 3px;
        top: 10px;
        transition: 0.3s;
		right: 0;
		left: 0;
		margin: auto;
    }
    .burger span:nth-child(1){
        top: 0px;
    }
    .burger span:nth-child(3){
        top: 21px;
    }
    .active span:nth-child(1){
        transform: rotate(45deg);
        top: 12px;
		background: #fff;
        box-shadow: none;
    }
    .active span:nth-child(3){
        transform: rotate(-45deg);
		top: 12px;
		background: #fff;
        box-shadow: none;
    }
    .active span:nth-child(2){
        opacity: 0;
    }

	.sp_nav{
		display: block;
		position: fixed;
		/* right: -100vw; */
		top: 0;
		transition: 0.5s;
		z-index: 40;
		opacity: 0.9;

		background: #6f5b26;
		box-shadow: #fff 0 0 5px;
		height: 100%;
		width: 90vw;
	}
	.sp_nav ul{
		margin: 100px 20px;
	}
	.sp_nav ul li{
		border-bottom: 1px solid #fff;
	}
	.sp_nav ul li a{
		color: #fff;
		padding: 0 15px;
		line-height: 50px;
		display: block;
	}
    
    /* fv */
    .fv .keyvisual{
        width: 500px;
        top: auto;
        bottom: 40px;
        right: -150px;    
    }
    .fv>.container{
        display: block;
    }
    .fv_text p{
        font-size: 18px;
        letter-spacing: 0.03rem;
    }
    .fv_text .main_copy{
        line-height: 1.4;
        font-size: 28px;
        margin-bottom: 15px;
    }
    
    /* ----------- */
    
    h2{
        font-size: 28px;
    }
    h3{
        font-size: 20px;
        text-align: center;
    }
    #section_01 img{
        width: 200px;
    }
    
    .service_container{
        display: block;
    }
    .service_container img{
        display: block;
        margin: 0 auto 30px;
    }
    .service_container>div{
        margin-left: 0;
    }
    
    
    .service_flex{
        display: block;
    }
    .service_child{
        width: 100%;
    }
    
    /* ------------- */
    
    .about_us_table{
        margin-bottom: 20px;
    }
    
    .about_us_table tr{
        display: flex;
        flex-direction: column;
        padding: 10px 0;
    }
    .about_us_table th{
        width: 100%;
        font-size: 18px;
        border-bottom: none;
        text-align: left;
    }
    .about_us_table td{
        padding: 5px 0 10px;
        font-size: 18px;
    }
    .map{
        height: 250px;
        margin-bottom: 100px;
    }

    /* ----------- */

       .mw_wp_form dl{
        display: block;
    }
    .mw_wp_form dl dt{
        margin-bottom: 7px;
    }
    .mw_wp_form dl dd{
        margin: 0 0 20px;
        max-width: 100%;
    }

    /* ---------- */

    .contact_box{
        padding-top: 200px;
    }
    
}