
#reservation{
	width: 700px;
	margin: 0 auto;
	padding-top: 40px;
	padding-bottom: 50px;
}

.toptxt{
	font-size: 14px;
	line-height: 25px;
	text-align: left;
	margin: 0 0 40px 0;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.toptxt.cancel{
	border-bottom: 1px solid #000;
	padding-bottom: 40px;
}

.res_info{
	text-align: left;
	border: 2px solid #000;
	box-shadow: 0px 0px 0px 2px #ffffff inset, 0px 0px 0px 3px #000000 inset;
	margin: 0 0 30px 0;
	padding: 20px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.res_info dl{
	display: table;
	width: 100%;
	font-size: 0;
	line-height: 0;
}

.res_info dt,
.res_info dd{
	display: table-cell;
	vertical-align: top;
	font-size: 18px;
	line-height: 25px;
	margin: 0;
	padding: 0;
}

.res_info dt{	width: 90px;}
.res_info dd{}
.res_info dd span{	font-size: 12px;}


/** form **/

.form{
	margin: 0;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.cbox{
	width: 100%;
	text-align: left;
	margin: 0 0 30px 0;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
#kakunin .cbox{
	margin-bottom: 20px;
	padding-bottom: 20px;
	border-bottom: 1px dotted #ddd;
}

.kakunin_div{
	text-align: left;
	margin-bottom: 25px;
	padding-bottom: 25px;
	border-bottom: 1px dotted #ddd;
}
.kakunin_div p{
	font-size: 16px;
	line-height: 25px;
	text-align: left;
}
.kakunin_div dl{
	display: table;
	width: 100%;
	font-size: 0;
	line-height: 0;
}

.kakunin_div dt,
.kakunin_div dd{
	display: table-cell;
	vertical-align: top;
	font-size: 16px;
	line-height: 25px;
	text-align: left;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.kakunin_div dt{
	position: relative;
	width: 85px;
	text-align: justify;
	text-align-last: justify;
	padding-right: 15px;
}
.kakunin_div dt:after{
	content: ":";
	position: absolute;
	top: -1px;
	right: 4px;
}
.kakunin_div dd{}
.total{
	display: inline-flex;
	font-size: 20px;
	font-weight: bold;
	line-height: 26px;
	border: 2px solid #ff0000;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.total span{
	width: 95px;
	text-align: center;
	color: #fff;
	background: #ff0000;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.total em{
	text-align: center;
	color: #ff0000;
	background: #fff;
	padding: 0 10px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.kakunin_div .total{	margin-top: 20px;}

.form_in{
	display: flex;
	justify-content: space-between;
}
.form_in p{
	width: 100%;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.form_in p:nth-of-type(2){	padding-left: 10px;}
.form_in p .select_bg{
	display: inline-flex;
}
/*.form_in p select{	width: 310px;}*/

.co_number .select_bg{
	display: inline-block;
	margin-right: 10px;
}
.co_number select{	width: 180px;}

.co_number .total{
	margin-top: 10px;
}

#card_div{
	position: relative;
	margin-top: 10px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.card_title{
	display: inline-block;
	vertical-align: top;
	font-size: 16px;
	line-height: 20px;
	color: #fff;
	background: #000;
	padding: 5px 10px;
	position: absolute;
	top: -30px;
	left: -1px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.card_caution{
	text-align: left;
	margin-top: 10px;
	padding: 15px 20px;
	color: #ff0000;
	background: #ffe2e2;
	border-radius: 5px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.card_caution div{
	font-size: 16px;
	font-weight: bold;
	line-height: 25px;
	margin: 0 0 10px 0;
}
.card_caution div span{
	position: relative;
	bottom: -6px;
	margin-right: 5px;
}
.cbox .card_caution p{
	font-size: 14px;
	line-height: 20px;
}


.check_box .cbox{
	border-bottom: 1px dotted #ddd;
	margin: 0 0 20px 0;
	padding-bottom: 20px;
}

.cbox h4{
	position: relative;
	font-size: 16px;
	line-height: 25px;
	margin: 0 0 5px 0;
}

.cbox h4 em.hissu{
	position: relative;
	bottom: -3px;
	display: inline-block;
	vertical-align: top;
	font-size: 12px;
	font-weight: normal;
	line-height: 15px;
	color: #ff0000;
	border: 1px solid #ff0000;
	border-radius: 2px;
	margin: 0 0 0 5px;
	padding: 0 5px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.cbox p{
	font-size: 16px;
	line-height: 25px;
}

.cbox .prv{
	display: flex;
	align-items: stretch;
	align-content: center;
	justify-content: flex-start;
	border: 1px solid #ccc;
}
.cbox .prv p:nth-of-type(1){
	width: calc(100% - 140px);
	font-size: 12px;
	line-height: 20px;
	text-align: left;
	padding: 15px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.cbox .prv p:nth-of-type(1) a{
	color: #000;
	text-decoration: underline;
}
.cbox .prv p:nth-of-type(1) a:hover{	text-decoration: none;}
.cbox .prv p:nth-of-type(2){
	width: 140px;
	display: inline-flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	border-left: 1px dotted #ccc;
	font-size: 16px;
	line-height: 25px;
}
.cbox .prv p:nth-of-type(2) span{	margin-right: 10px;}

.cbox .cat_text{
	position: relative;
	display: inline-block;
	vertical-align: top;
	font-size: 13px;
	line-height: 1.4;
	margin: 13px 0 0 0;
	padding-left: 15px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
			box-sizing: border-box;
}
.cbox .cat_text span{
	position: absolute;
	top: 0;
	left: 0;
	color: #ff0000;
}


.submit{
	width: 100%;
	text-align: center;
}
.submit p{
	font-size: 14px;
	line-height: 22px;
	text-align: center;
	padding: 10px 0 40px 0;
}

.submit p.submit_caution{
	display: inline-block;
	text-align: left;
	margin-top: -20px;
	font-size: 13px;
	line-height: 20px;
}

.submit p.submit_caution em{
	display: inline-block;
	color: #ffffff;
	background: #000;
	padding: 0 5px;
	margin-bottom: 5px;
}

.submit p.submit_caution span{
	color: #ff0000;
}

.submit_bt{
	display: inline-flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	width: 100%;
	max-width: 220px;
	height: 45px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	font-size: 16px;
	line-height: 24px;
	color: #fff;
	background: #000;
	border: 1px solid #000;
	border-radius: 0;
	-webkit-transition	: 0.2s ease-in-out;
	-moz-transition	: 0.2s ease-in-out;
	-o-transition	: 0.2s ease-in-out;
	transition		: 0.2s ease-in-out;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.submit_bt:hover{
	color: #000;
	background: #fff;
	text-decoration: none;
}


.w1{	width		: 220px;}
.s1{	width		: 220px;}
.w2{	width		: 100%;}
.w3{	width		: 150px;}
.select{	width	: 170px;}
.s2{	width		: 200px;}
.s3{	width		: 200px;}

.form textarea{
	width: 100%;
	height: 100px;
	padding			: 15px;
	font-family		: Meiryo,'Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
    vertical-align	: middle;
	border-radius	: 3px;
	border: none;
	background: #ececec;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.form input[type="text"],
.form input[type="email"],
.form input[type="tel"]{
	padding			: 15px;
	font-family		: Meiryo,'Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
	border-radius	: 3px;
	border: none;
	background: #ececec;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.form input::placeholder,
.form textarea::placeholder{	color: #999;}
.form input:-ms-input-placeholder,
.form textarea:-ms-input-placeholder{	color: #999;}
.form input::-ms-input-placeholder,
.form textarea::-ms-input-placeholder{	color: #999;}

.form input[type="file"]{
	display: block;
	margin: 0 0 10px 0;
}
.form input[type="file"]:last-of-type{	margin-bottom: 0;}

select{
	width: 100%;
	font-size: 16px;
	line-height: 20px;
	padding: 17px 30px 17px 15px;
	border: none;
	border-radius: 3px;
	font-family: Meiryo,'Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
	background: #ececec;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
			box-sizing: border-box;
}
.select_bg{
	position: relative;
	display: block;
}
.select_bg:before{
	content: '';
	display: inline-block;
	width: 30px;
	height: 52px;
	background: #ccc;
	border-radius: 0 3px 3px 0;
	position: absolute;
	top: 1px;
	right: 1px;
}
.select_bg:after{
	content: '';
	display: inline-block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 5px 0 5px;
	border-color: #000 transparent transparent transparent;
	position: absolute;
	top: calc(50% - 5px);
	right: 10px;
}

.chk_bar{
	font-size: 0;
	line-height: 0;
}

.chk_bar li{
	display: inline-block;
	vertical-align: top;
	width: calc(100% / 4);
	border-top: 1px solid #ddd;
	border-bottom: 1px solid #ddd;
	border-right: 1px solid #ddd;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.chk_bar li:first-of-type{
	border-left: 1px solid #ddd;
	border-radius: 3px 0 0 3px;
}
.chk_bar li:last-of-type{	border-radius: 0 3px 3px 0;}

.chk_bar input[type="checkbox"],
.chk_bar input[type="radio"]{	display: none;}

.chk_bar input[type="checkbox"] + label,
.chk_bar input[type="radio"] + label{
	display: inline-flex;
	align-items: center;
	align-content: center;
	justify-content: center;
	width: 100%;
	height: 40px;
	font-size: 14px;
	line-height: 16px;
	text-align: center;
	color: #333;
	background: #fff;
	border: none;
	cursor: pointer;
	padding: 0 3px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.chk_bar input[type="checkbox"]:checked + label,
.chk_bar input[type="radio"]:checked + label{
	color: #fff;
	background: #ff7676;
	box-shadow:none;
	-moz-box-shadow:none;
	-webkit-box-shadow:none;
}

.error,
.over{
	margin: 0;
	text-align: center;
	font-size: 14px;
	line-height: 22px;
}
.over{	padding-bottom: 50px;}

.error span{
	display: inline-block;
	font-size: 14px;
	font-weight: bold;
	line-height: 22px;
	color: #ff0000;
	padding: 80px 0;
}
.over div{
	display: inline-block;
	font-size: 20px;
	font-weight: bold;
	line-height: 24px;
	padding: 10px 0 0 0;
}
.over div span{
	font-size: 34px;
	line-height: 1;
}
.over div em{
	display: block;
	margin-bottom: 30px;
}

.kometxt{
	width: auto;
	margin: 30px auto 0 auto;
}
.kometxt li{
	position: relative;
	font-size: 12px;
	line-height: 18px;
	text-align: left;
	padding-left: 15px;
	margin-bottom: 5px;
}
.kometxt li span{
	color: #ff0000;
	position: absolute;
	top: 0;
	left: 0;
}

.error_text{
    display: block;
    font-size: 14px;
    line-height: 20px;
    margin-bottom: 30px;
    color: #ff0000;
    font-weight: bold;
}

.error_text:empty{ display: block;}

.error_block h4{
	color: #ff0000 !important;
	animation-name: indfade !important;
	animation-duration: 2.0s;
	animation-timing-function: ease-out;
	animation-delay: 0.0s;
	animation-iteration-count: infinite;
	animation-fill-mode: backwards;
}
@keyframes indfade {
	0%{
		opacity: 1.0;
		filter: alpha(opacity=100);
	}
	80% {
		opacity: 1.0;
		filter: alpha(opacity=100);
	}
	85% {
		opacity: 0.3;
		filter: alpha(opacity=30);
	}
	90% {
		opacity: 1.0;
		filter: alpha(opacity=100);
	}
	95% {
		opacity: 0.3;
		filter: alpha(opacity=30);
	}
	100%{
		opacity: 1.0;
		filter: alpha(opacity=100);
	}
}

.error_block input[type="text"],
.error_block input[type="email"],
.error_block input[type="tel"],
.error_block textarea{
    border-color: #ff0000 !important;
    background: #fff5f5 !important;
}

.capt_bg{
	width: 100%;
	border-bottom: 1px dotted #ddd;
	margin: 0 0 20px 0;
	padding: 0 0 20px 0;
}

.capt{
	width: 280px;
	margin: 0 auto;
	padding: 0 10px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.capt div{
	width: 100%;
	display: flex;
	align-items: center;
	align-content: center;
	justify-content: space-between;
	margin: 0 0 10px 0;
}

.capt div span{
	font-size: 34px;
	line-height: 40px;
	color: #999;
}

.capt div input[type="text"]{
	width: 110px;
	padding: 7px;
	font-size		: 16px;
	line-height: 20px;
	font-family: Meiryo,'Hiragino Kaku Gothic ProN','Hiragino Sans',sans-serif;
	border-radius: 3px;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}

.capt p{
	font-size: 11px;
	line-height: 16px;
	text-align: left;
	padding: 0 0;
	-webkit-box-sizing: border-box;
	   -moz-box-sizing: border-box;
	        box-sizing: border-box;
}
.capt p em{	color: #ff0000;}


/*=================================================
 * CSS for SP
 * ================================================= */

@media screen and (max-width: 650px) {
	#reservation{
		width: auto;
		margin: 0;
		padding-top: 25px;
		padding-bottom: 30px;
	}
	.toptxt{
		font-size: 13px;
		line-height: 25px;
		text-align: left;
		margin: 0 0 15px 0;
		padding: 0 15px;
	}
	.res_info{
		margin: 0 15px 30px 15px;
		padding: 15px;
	}
	.res_info dl{	margin-bottom: 5px;}
	.res_info dl:last-of-type{	margin-bottom: 0;}
	.res_info dt,
	.res_info dd{
		display: table-cell;
		vertical-align: top;
		font-size: 14px;
		line-height: 18px;
		margin: 0;
		padding: 0;
	}
	.res_info dt{	width: 71px;}
	.res_info dd span{	font-size: 11px;}

	/** form **/
	.form{
		display: block;
		width: auto;
		margin: 0;
		padding: 0 15px;
	}
	.form_in{
		display: block;
	}
	.form_in p{
		width: auto;
		-webkit-box-sizing: border-box;
		   -moz-box-sizing: border-box;
		        box-sizing: border-box;
	}
	.form_in p:nth-of-type(2){	padding-left: 0;}
	.form_in p .select_bg:first-of-type{	margin-bottom: 0;}
	.form_in p:nth-of-type(1) select{	width: 90px;	padding-left: 10px;}
	.form_in p:nth-of-type(1),
	.form_in p:nth-of-type(2),
	.form_in p:nth-of-type(3){
		display: inline-block;
	}
	.form_in p:nth-of-type(2) select,
	.form_in p:nth-of-type(3) select{
		padding-left: 10px;
	}
	.s3{	width: 70px;}
	.co_number .select_bg{
		display: block;
		width: 180px;
		margin: 0 0 10px 0;
	}
	.co_number .select_bg:last-of-type{	margin-bottom: 0;}

	.cbox{
		width: auto;
		margin: 0 0 15px 0;
	}

	.cbox p{
		font-size: 14px;
		line-height: 22px;
	}
	.form textarea{	height: 120px;}
	.form textarea,
	.form input[type="text"],
	.form input[type="email"],
	.form input[type="tel"]{
		font-size: 16px;
	}

}