@charset "UTF-8";

 /* +++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
reservation
+++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ */

#tel .tel span {
	display: inline-block;
	vertical-align: middle;
}
#tel .tel img { vertical-align: middle; }

#request h2 {
	text-align: center;
}
#request dl:after {
	content: "";
	display: block;
	background: no-repeat center center;
	background-size: cover;
	-moz-background-size: cover;
	-webkit-background-size: cover;
}
#request dl dd ul li {
	padding-left: 1em;
	text-indent: -1em;
	letter-spacing: -0.01em;
}
#request dl dd ul li:before {
	content: "";
	width: 0.9em;
	height: 0.9em;
	background: #fff;
	margin-bottom: 4px;
	margin-left: -2px;
	display: inline-block;
	vertical-align: middle;
	border-radius: 50%;
	-moz-border-radius: 50%;
	-webkit-border-radius: 50%;
}

#tel a {
	max-width: 500px;
	line-height: 32px;
	text-align: center;
	border: 1px solid #fff;
	display: block;
	margin: 0 auto;
	position: relative;
	padding: 19px 40px 10px;
	box-sizing: border-box;
	-moz-box-sizing: border-box;
	-webkit-box-sizing: border-box;
}
#tel a:after {
	content: "";
	width: 20px;
	height: 0;
	overflow: hidden;
	padding: 20px 0 0;
	box-sizing: content-box;
	-moz-box-sizing: content-box;
	-webkit-box-sizing: content-box;
	border: 1px solid transparent;
	border-top-color: #fff;
	background: none;
	cursor: pointer;
	position: absolute;
	top: 0;
	bottom: 0;
	right: 20px;
	margin: auto 0;
	border-right-color: #fff;
	transform: rotate(45deg);
	-moz-transform: rotate(45deg);
	-webkit-transform: rotate(45deg);
}

@media screen and (min-width:981px){
	#mainVis {
		background-image: url(../images/reservation/main_pc.jpg);
	}

	#tel { padding: 72px 0 0; }
	#tel .tel { margin: 22px 0 23px; }
	#tel .tel span {
		color: #bfa37b;
		font-size: 20px;
	}
	#tel .tel img {
		height: 32px;
		margin-left: 15px;
		margin-right: 28px;
	}
	#tel .tel small { font-size: 14px; }

	#request { padding-bottom: 194px; }
	#request h2 {
		margin: 136px 0 44px;
	}
	#request dl {
		position: relative;
	}
	#request dl:after {
		width: calc(50% - 310px);
		height: 0;
		padding-top: 55.9%;
		position: absolute;
		top: 0;
		left: 0;
		background-image: url(../images/reservation/img_request_pc.jpg);
		box-shadow: 0 -200px 100px -100px rgba(0,0,0,1) inset;
	}
	#request dl > * {
		margin: 0 auto;
		width: 980px;
		padding-left: 210px;
		box-sizing: border-box;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
	}
	#request dl dd + dt { margin-top: 19px; }
	#request dl dt span {
		display: block;
		font-size: 18px;
		padding-left: 20px;
		position: relative;
	}
	#request dl dt span:after {
		content: "";
		width: 10px;
		height: 1px;
		display: block;
		background: #fff;
		position: absolute;
		top: 16px;
		left: 0;
	}
	#request dl dd:after {
		content: "";
		display: block;
		margin-top: 23px;
		border-bottom: 1px solid #444;
	}
	#request dl dd { padding-top: 6px; }
	#request dl dd ul,
	#request dl dd p { padding-left: 20px; }
	#request dl dd ul li + li { margin-top: 2em; }
}
@media screen and (max-width:980px){
	#mainVis {
		background-image: url(../images/reservation/main_sp.jpg);
	}

	#tel a {
		margin: 0 15px 15px;
		padding-left: 10px;
	}
	#tel > p:first-child {
		font-size: 13px;
		letter-spacing: 0;
		padding: 34px 0 16px;
	}
	#tel .tel span {
		color: #bfa37b;
		font-size: 17.5px;
		margin-right: 24px;
	}
	#tel .tel img {
		height: 28px;
	}
	#tel .tel small {
		font-size: 12px;
		margin-top: 6px;
		display: inline-block;
	}
	#tel .tel + p {
		padding: 4px 15px 90px;
		letter-spacing: 0;
	}
	#tel .tel + p span { display: inline-block; }

	#request { padding-bottom: 40px; }
	#request:after {
		content: "";
		width: 100%;
		height: 0;
		padding-top: 120%;
		display: block;
		background: no-repeat center center url(../images/reservation/img_request_sp.jpg);
		background-size: cover;
		-moz-background-size: cover;
		-webkit-background-size: cover;
	}
	#request h2 img {
		height: 19px;
		margin-bottom: 17px;
	}
	#request dl {
		margin: 0 15px;
		padding-bottom: 20px;
	}
	#request dt {
		font-size: 15px;
		padding-left: 17px;
		margin-bottom: 5px;
	}
	#request dl dd + dt { margin-top: 12px; }
	#request dt span {
		display: block;
		position: relative;
	}
	#request dt span:after {
		content: "";
		width: 10px;
		height: 1px;
		display: block;
		background: #fff;
		position: absolute;
		top: 11px;
		left: -14px;
	}
	#request dl dd {
		padding-left: 17px;
		padding-bottom: 13px;
		border-bottom: 1px solid #444;
	}
	#request dl dd ul li {
		text-indent: -0.7em;
	}
	#request dl dd ul li + li { margin-top: 2em; }
}