@charset "utf-8";

@media screen and (min-width:769px){

.wrapper{
	width: 1000px;
	margin: 0 auto;
	padding: 0;
}


/* header */

header{
	width: 100%;
	height: 100px;
	background: #FFF;
	position: fixed; top: 0; left: 0;
	z-index: 50;
}
header h1{
	width: 140px;
	position: absolute; top: 50%; left: 43px;
	transform: translateY(-50%);
	font-size: 0;
}

.phone{
	width: 100px;
	position: absolute; top: 0; right: 0;
}
.phone a{
	height: 100px;
	padding: 10px;
	background: #DD2E1E;
	display: flex;
	align-items: center;
	justify-content: space-between;
	flex-wrap: wrap;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}
.phone a img{
	width: 30px;
	margin: 0 auto;
}
.phone a span{
	width: 100%;
	font-size: 11px;
	font-weight: 700;
	letter-spacing: 0.05em;
}


/* main */

main{
	padding-top: 100px;
}

.kv{
	min-height: 900px;
	margin: 40px 0 120px 66px;
	padding: 460px 27px 27px 27px;
	background: url(../images/main_image.webp) no-repeat center left;
	background-size: cover;
	position: relative;
}
.kv::before{
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.15);
	position: absolute; top: 0; left: 0;
}
.kv::after{
	content: "";
	width: 100%;
	height: 120px;
	background: #F7F7F7;
	position: absolute; bottom: -120px; left: 0;
}
.kv .catch{
	position: relative;
	z-index: 10;
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 700;
	color: #FFF;
	letter-spacing: 0.2em;
}
.kv .catch .top{
	font-size: 90px;
}
.kv .catch .mid{
	font-size: 55px;
}
.kv .catch .mid span{
	font-size: 40px;
}
.kv .catch .bottom{
	margin-top: 10px;
	font-family: "Playfair Display", serif;
	font-weight: 400;
	font-size: 30px;
}

.intro{
	padding: 60px 0 140px 0;
}
.intro .item{
	margin-top: 120px;
	display: flex;
	align-items: flex-start;
}
.intro .item:nth-child(even){
	flex-direction: row-reverse;
}
.intro .thum{
	width: 500px;
	margin: 0;
}
.intro .inner{
	width: 500px;
	margin-top: 0;
	padding: 65px 60px 0 60px;
}
.intro h2{
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 700;
	font-size: 35px;
	color: #BD0015;
	letter-spacing: 0.2em;
}
.intro h3{
	margin-top: 10px;
	font-family: "Playfair Display", serif;
	font-weight: 400;
	font-size: 20px;
	color: #BD0015;
}
.intro p{
	margin-top: 40px;
	font-size: 15px;
	line-height: 2;
	color: #111;
}
.intro .btn{
	width: 80%;
	margin: 50px auto 0 auto;
}
.intro .btn a{
	padding: 10px;
	background: #DD2E1E;
	border: 1px solid #DD2E1E;
	border-radius: 28px;
	display: block;
	font-size: 18px;
	font-weight: 700;
	line-height: 34px;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}
.intro .btn a:hover{
	background: #FFF;
	color: #DD2E1E;
}


/* undercolumn */

.h2_box{
	padding: 100px 0 140px 0;
}
.h2_box h2{
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 900;
	font-size: 40px;
	color: #222;
}
.h2_box h3{
	margin-top: 10px;
	font-family: "Playfair Display", serif;
	font-weight: 700;
	font-synthesis: 25px;
	color: #BD0015;
}

.contact{
	padding: 115px 0 0 0;
	background: #F7F7F7;
}
.contact .wrapper{
	padding: 83px 150px 233px 150px;
	background: #FFF;
}
.contact p{
	color: #333;
	text-align: center;
}
.contact p span{
	color: #EA3E32;
}
.contact p.conf_text{
	color: #D80000;
	font-weight: 700;
}
.contact .box{
	padding-top: 50px;
}
.contact .item{
	margin-top: 20px;
}
.contact .title{
	font-size: 15px;
	color: #222;
	font-weight: 500;
}
.contact .title span{
	color: #EA3E32;
}
.contact .inner{
	margin-top: 15px;
}

.contact .btn{
	margin-top: 80px;
	font-size: 0;
	text-align: center;
}
.contact .btn button{
	padding: 9px 10px;
	background: none;
	outline: none;
	display: inline-block;
	font-size: 16px;
	line-height: 40px;
	color: #FFF;
	font-weight: bold;
}
.contact button.conf_btn{
	width: 280px;
	background: #BD0015;
	border: 1px solid #BD0015;
}
.contact button.submit_btn{
	width: 280px;
	background: #BD0015;
	border: 1px solid #BD0015;
}
.contact button.conf_btn:hover,
.contact button.submit_btn:hover{
	background: #FFF;
	color: #BD0015;
}
.contact button.back_btn{
	width: 280px;
	margin-left: 20px;
	background: #AAA;
	border: 1px solid #AAA;
}
.contact button.back_btn:hover{
	background: #FFF;
	color: #AAA;
}

.thanks{
	padding: 115px 0 120px 0;
	background: #F7F7F7;
}
.thanks .wrapper{
	padding: 90px 20px 120px 20px;
	background: #FFF;
	text-align: center;
}
.thanks h4{
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 700;
	font-size: 35px;
}
.thanks .text{
	margin-top: 50px;
	font-size: 18px;
	color: #333;
}
.thanks p{
	margin-top: 50px;
	font-size: 15px;
	color: #333;
}
.thanks .back{
	width: 280px;
	margin: 100px auto 0 auto;
}
.thanks .back a{
	padding: 15px;
	background: #222;
	border:1px solid #222;
	display: block;
	font-size: 16px;
	color: #FFF;
	text-decoration: none;
	text-align: center;
}
.thanks .back a:hover{
	background: #FFF;
	color: #222;
}


/* footer */

footer{
}
footer .top{
	height: 430px;
	padding: 85px 0 0 0;
	background: url(../images/footer_bg.webp) no-repeat center left;
	background-size: cover;
	position: relative;
	color: #FFF;
}
footer .top::before{
	content: "";
	width: 100%;
	height: 100%;
	background: rgba(0,0,0,0.40);
	position: absolute; top: 0; left: 0;
}
footer .top .logo{
	width: 140px;
}
footer .top p{
	margin-top: 15px;
	font-size: 14px;
}
footer .top .tel_box{
	margin-top: 5px;
	display: inline-block;
}
footer .top .tel_box .tel{
}
footer .top .tel_box .tel a{
	font-size: 45px;
	font-weight: 700;
	color: #FFF;
}
footer .top .tel_box .tel a span{
	font-size: 30px;
}
footer .top .tel_box .time{
	margin-top: 0;
	font-size: 15px;
	text-align: center;
}
footer .top .link{
	margin-top: 20px;
	display: flex;
	justify-content: flex-start;
}
footer .top .link div{
	width: 400px;
	margin-right: 30px;
}
footer .top .link div a{
	padding: 12px;
	border: 1px solid #FFF;
	display: block;
	font-size: 18px;
	font-weight: 700;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}
footer .top .link div a:hover{
	background: #FFF;
	color: #111;
}
footer .bottom{
	padding: 80px 0 20px 0;
}
footer .bottom .logo{
	width: 140px;
}
footer .bottom .copy{
	margin-top: 40px;
	font-size: 12px;
	color: #CCC;
}

}
