@charset "utf-8";

.wrapper{
	padding-left: 2vw;
	padding-right: 2vw;
	position: relative;
}


/* header */

header{
	width: 100%;
	height: 16vw;
	background: #FFF;
	position: fixed; top: 0; left: 0;
	z-index: 50;
}
header h1{
	width: 30%;
	position: absolute; top: 50%; left: 2vw;
	transform: translateY(-50%);
	font-size: 0;
}

.phone{
	width: 44%;
	position: absolute; top: 0; right: 0;
}
.phone a{
	height: 16vw;
	padding: 2vw;
	background: #DD2E1E;
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}
.phone a img{
	width: 5.2vw;
}
.phone a span{
	font-size: 4.2vw;
	font-weight: 700;
	letter-spacing: 0.05em;
}


/* main */

main{
	padding-top: 16vw;
}

.kv{
	min-height: 100vw;
	margin: 6vw 0 10vw 2vw;
	padding: 50vw 2vw 2vw 2vw;
	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: 10vw;
	background: #F7F7F7;
	position: absolute; bottom: -10vw; 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: 10vw;
}
.kv .catch .mid{
	font-size: 6.2vw;
}
.kv .catch .mid span{
	font-size: 5vw;
}
.kv .catch .bottom{
	margin-top: 1vw;
	font-family: "Playfair Display", serif;
	font-weight: 400;
	font-size: 4vw;
}

.intro{
	padding: 2vw 0 10vw 0;
}
.intro .item{
	margin-top: 8vw;
}
.intro .thum{
	width: 70%;
	margin: 0 auto;
}
.intro .inner{
	margin-top: 8vw;
}
.intro h2{
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 700;
	font-size: 6vw;
	color: #BD0015;
	letter-spacing: 0.2em;
}
.intro h3{
	margin-top: 1vw;
	font-family: "Playfair Display", serif;
	font-weight: 400;
	color: #BD0015;
}
.intro p{
	margin-top: 4vw;
	line-height: 2;
	color: #111;
}
.intro .btn{
	width: 80%;
	margin: 6vw auto 0 auto;
}
.intro .btn a{
	padding: 2vw;
	background: #DD2E1E;
	border-radius: 7vw;
	display: block;
	font-size: 4.5vw;
	font-weight: 700;
	line-height: 10vw;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}


/* undercolumn */

.h2_box{
	padding: 8vw 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: 7vw;
	color: #222;
}
.h2_box h3{
	margin-top: 2vw;
	font-family: "Playfair Display", serif;
	font-weight: 700;
	font-size: 4vw;
	color: #BD0015;
}

.contact{
	padding: 8vw 0 0 0;
	background: #F7F7F7;
}
.contact .wrapper{
	padding: 8vw 2vw;
	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: 2vw;
}
.contact .item{
	margin-top: 6vw;
}
.contact .title{
	font-size: 4vw;
	color: #222;
	font-weight: 500;
}
.contact .title span{
	color: #EA3E32;
}
.contact .inner{
	margin-top: 3vw;
}

.contact .btn{
	margin-top: 8vw;
	font-size: 0;
	text-align: center;
}
.contact .btn button{
	padding: 2vw;
	background: none;
	border: none;
	outline: none;
	display: inline-block;
	font-size: 4vw;
	line-height: 12vw;
	color: #FFF;
	font-weight: bold;
}
.contact button.conf_btn{
	width: 70%;
	background: #BD0015;
}
.contact button.submit_btn{
	width: 45%;
	background: #BD0015;
}
.contact button.back_btn{
	width: 45%;
	margin-left: 5%;
	background: #AAA;
}

.thanks{
	padding: 8vw 2vw;
	background: #F7F7F7;
}
.thanks .wrapper{
	padding: 8vw 2vw;
	background: #FFF;
}
.thanks h4{
	font-family: "Noto Serif JP", "Times New Roman", "YuMincho", "Hiragino Mincho ProN", "Yu Mincho", "MS PMincho", serif;
	font-weight: 700;
	font-size: 5.5vw;
}
.thanks .text{
	margin-top: 4vw;
	font-size: 4vw;
	color: #333;
}
.thanks p{
	margin-top: 4vw;
	font-size: 3.5vw;
	color: #333;
}
.thanks .back{
	width: 55%;
	margin: 6vw auto 0 auto;
}
.thanks .back a{
	padding: 2.5vw 2vw 3.5vw 2vw;
	background: #222;
	display: block;
	font-size: 4vw;
	color: #FFF;
	text-decoration: none;
	text-align: center;
}


/* footer */

footer{
}
footer .top{
	padding: 8vw 2vw;
	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: 30%;
}
footer .top p{
	margin-top: 2vw;
	font-size: 3.5vw;
}
footer .top .tel_box{
	margin-top: 3vw;
	display: inline-block;
}
footer .top .tel_box .tel{
}
footer .top .tel_box .tel a{
	font-size: 8vw;
	font-weight: 700;
	color: #FFF;
}
footer .top .tel_box .tel a span{
	font-size: 4.5vw;
}
footer .top .tel_box .time{
	margin-top: 1vw;
	font-size: 3.5vw;
	text-align: center;
}
footer .top .link{
	margin-top: 4vw;
	display: flex;
	justify-content: space-between;
}
footer .top .link div{
	width: 48%;
}
footer .top .link div a{
	padding: 2vw 1vw;
	border: 1px solid #FFF;
	display: block;
	font-size: 4vw;
	font-weight: 700;
	color: #FFF;
	text-align: center;
	text-decoration: none;
}
footer .bottom{
	padding: 4vw;
}
footer .bottom .logo{
	width: 30%;
}
footer .bottom .copy{
	margin-top: 3vw;
	font-size: 3.2vw;
	color: #CCC;
}
