/* CSS Document */
@charset "utf-8";

.wrapper{
	padding: 20px 10px 30px 10px;
	background: #FFF;
}
h1{
	font-size: 0;
	text-align: center;
}
h1 a{
}
h1 img{
	width: 100%;
}
h2{
	margin-top: 20px;
	padding: 7px 10px;
	background: #F39C12;
	font-size: 18px;
	color: #FFF;
	font-weight: bold;
	text-align: center;
}
h2.blue{
	background: #3498DB;
}
.table_box{
	margin-top: 10px;
}
.tel{
	margin-top: 20px;
	border: 1px solid #E74090;
	border-top: none;
}
.tel .title{
	padding: 7px 10px;
	background: #E74090;
	font-size: 18px;
	color: #FFF;
	font-weight: bold;
	text-align: center;
}
.tel .inner{
	padding: 7px 10px;
}
.tel .number{
	font-family: 'Roboto', sans-serif;
	font-size: 32px;
	color: #E74090;
	font-weight: 700;
	text-align: center;
}
.tel .number:before{
	content: "TEL.";
	font-size: 16px;
}
.tel .number a{
	color: #E74090;
}
.tel p{
	margin-top: 5px;
	font-size: 13px;
}
.reserve_caution{
	margin-top: 10px;
	font-size: 13px;
	text-align: center;
}
.reserve_caution span{
	color: #D90000;
}
#reserve{
	margin-top: 10px;
}
#reserve table th{
	background: none;
}
#reserve table td{
	border-color: #E74090;
}
#reserve table th span.req:before,
#reserve table th span.opt:before{
	margin-left: 10px;
	padding: 2px 5px;
	border-radius: 5px;
	display: inline-block;
	vertical-align: middle;
	font-size: 13px;
	color: #FFF;
	text-align: center;
}
#reserve table th span.req:before{
	content: "必須";
	background: #D90000;
}
#reserve table th span.opt:before{
	content: "任意";
	background: #2980B9;
}
#reserve table input.short{
	width: 3em;
}
#reserve table select.short,
#reserve table input.medium{
	width: 4em;
}
#reserve table td.reserve{
	padding-top: 5px;
	font-size: 0;
}
#reserve table td.reserve div{
	margin: 5px 15px 0 0;
	display: inline-block;
	vertical-align: middle;
	font-size: 14px;
}
#reserve table td.reserve div input,
#reserve table td.reserve div select{
	font-size: 16px;
}
#reserve table td.num{
	padding-top: 5px;
}
#reserve table td.num div{
	margin-top: 5px;
}
#reserve table td div.check{
	font-size: 15px;
}
.policy{
	margin-top: 15px;
	padding: 10px;
	border: 1px solid #DDD;
}
.policy .title{
	font-weight: bold;
	text-align: center;
}
.policy p{
	margin-top: 5px;
}
.btn_box{
	margin-top: 20px;
	font-size: 0;
	text-align: center;
}
.btn_box button{
	width: 49%;
	padding: 15px;
	display: inline-block;
	background: #F39C12;
	border: none;
	outline: none;
	font-size: 18px;
	color: #FFF;
	font-weight: bold;
}
.btn_box button.confirm{
	width: 80%;
}
.btn_box button.back{
	margin-left: 2%;
	background: #CCC;
}


/* thanks */

.thanks{
	margin-top: 15px;
}
.thanks .title{
	font-size: 20px;
	font-weight: bold;
	text-align: center;
}
.thanks p{
	margin-top: 5px;
}


/* footer */

footer{
	padding: 15px;
	font-size: 13px;
	text-align: center;
}
