/* ------------------------------------ */
.reservation {
	max-width: 1200px;
	width: 90%;
	margin: 0px auto 60px;
	border: #ccc 1px solid;
	padding: 40px;
	background-color: #fff;
}
.reservation .txt {
	text-align: center;
	margin-bottom: 30px;
	font-size: 110%;
	text-decoration:underline wavy #aaa;
} 
.reservation .txt br {
	display: none;
}
.reservation ul {
	display:-webkit-box;
    display:-moz-box;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
	margin-bottom: 40px;
}
.reservation li {
	float: left;
	width: 30%;
	margin-right: 5%;
}
.reservation li:nth-child(3) {
	margin-right: 0;
}
.reservation li span {
	color: #0A2047;
	font-size: 200%;
	font-family: 'Hind Siliguri', sans-serif;
	font-weight: 700;
}
.reservation li p {
	filter: drop-shadow(4px 4px 4px rgba(0,0,0,0.2));
	margin-bottom: 15px;
}
.reservation li strong {
	font-weight: 500;
	font-size: 110%;
	line-height: 160%;
}
.reservation .btn {
	max-width: 400px;
	width: 100%;
	margin: 0px auto;
}
.reservation .btn a {
	text-align: center;
	display: block;
	border: #0A2047 2px solid;
	background-color: #0A2047;
	color: #fff;
	padding: 20px 0;
	font-size: 120%;
	font-weight: 500;
	letter-spacing: 3px;
}
.reservation .btn a::before {
	font-family: "Font Awesome 5 Free";
	content: '\f35d';
	font-weight: 900;
	margin-right: 10px;
}
.reservation .btn a:hover {
	border: #0A2047 2px solid;
	background-color: #fff;
	color: #0A2047;
}
/* ------------------------------------ */
.reservation2 {
	max-width: 1200px;
	width: 90%;
	margin: 0px auto 60px;
	border: #ccc 1px solid;
	padding: 40px;
	background-color: #fff;
}
.reservation2 .ttl {
	text-align: center;
	color: #AA1D1D;
	font-size: 140%;
	font-weight: 500;
	margin-bottom: 20px;
}
.reservation2 .txt {
	text-align: center;
	margin-bottom: 50px;
}
.reservation2 ul {
	display:-webkit-box;
    display:-moz-box;
    display:-ms-flexbox;
    display:-webkit-flex;
    display:-moz-flex;
    display:flex;
    -webkit-box-lines:multiple;
    -moz-box-lines:multiple;
    -webkit-flex-wrap:wrap;
    -moz-flex-wrap:wrap;
    -ms-flex-wrap:wrap;
    flex-wrap:wrap;
	max-width: 800px;
	width: 100%;
	margin: 0px auto;
}
.reservation2 li {
	float: left;
	width: 48%;
	margin-right: 4%;
	box-shadow: 0px 4px 15px -6px rgba(0,0,0,0.6);
}
.reservation2 li:last-child {
	margin-right: 0;
}
.reservation2 li a {
	display: block;
	text-align: center;
	padding: 15px;
	color: #fff;
	border-radius:3px;
	-moz-border-radius:3px;
	-webkit-border-radius:3px;
}
.reservation2 li:nth-child(1) a {
	background-color: #AA1D1D;
}
.reservation2 li:nth-child(2) a {
	background-color: #0A2047;
}
.reservation2 li a span {
	display: block;
	text-align: center;
	background-color: #fff;
	margin-top: 10px;
	line-height: 160%;
	padding: 10px 0 12px;
	font-size: 110%;
	font-weight: 500;
	letter-spacing: 3px;
	border: #fff 1px solid;
	transition: .4s;
	border-radius:3px;
	-moz-border-radius:3px;
	-webkit-border-radius:3px;
}
.reservation2 li:nth-child(1) a span {
	color: #AA1D1D;
}
.reservation2 li:nth-child(2) a span {
	color: #0A2047;
}
.reservation2 li a:hover {
}
.reservation2 li:nth-child(1) a:hover {
}
.reservation2 li:nth-child(2) a:hover {
}
.reservation2 li a:hover span  {
	color: #fff;
}
.reservation2 li:nth-child(1) a:hover span {
	background-color: #AA1D1D;
}
.reservation2 li:nth-child(2) a:hover span {
	background-color: #0A2047;
}
/* ------------------------------------ */
.reservation3 {
	max-width: 1000px;
	width: 90%;
	margin: 0px auto 60px;
	border: #ccc 1px solid;
	background-color: #fff;
}
.reservation3 .ttl {
	text-align: center;
	background-color: #AA1D1D;
	color: #fff;
	padding: 25px 20px;
}
.reservation3 .ttl .br_clear {
}
.reservation3 .inner {
	max-width: 800px;
	width: 100%;
	margin: 0px auto;
	padding: 50px;
}
.reservation3 .inner dl {
	margin-bottom: 20px;
	width: 100%;
	display: table;
}
.reservation3 .inner dt,
.reservation3 .inner dd {
	letter-spacing: 1px;
	margin-bottom: 5px;
	display: table-cell;
	vertical-align: top;
}
.reservation3 .inner dt {
	font-weight: 400;
	width: 230px;
	position: relative;
}
.reservation3 .inner dt span {
	display: block;
	position: absolute;
	top: 5px;
	right: 20px;
	font-size: 70%;
	margin-left: 10px;
	background-color: #AA1D1D;
	color: #fff;
	line-height: 100%;
	font-weight: 400;
	padding: 2px 4px 4px;
}
.reservation3 .inner dd textarea,
.reservation3 .inner dd input,
.reservation3 .inner dd select {
	width: 100%;
	padding: 13px;
	border-radius:3px;
	-moz-border-radius:3px;
	-webkit-border-radius:3px;
	background-color: #F9F8F6;
	box-shadow:2px 2px 6px -6px #333 inset;
	margin-bottom: 10px;
}
.reservation3 .inner dd input.siz_s,
.reservation3 .inner dd select.siz_s {
	width: 90px;
}
.reservation3 .inner dd textarea:hover,
.reservation3 .inner dd input:hover,
.reservation3 .inner dd select:hover {
}
.reservation3 .inner dd .list {
	overflow: hidden;
}
.reservation3 .inner dd .list li {
	float: left;
	margin-right: 20px;
}
.reservation3 .inner dd .list li label {
	transition: .4s;
}
.reservation3 .inner dd .list li label input {
	width: auto;
	display: inline-block;
	margin-right: 5px;
	box-shadow: none;
}
.reservation3 .inner dd .list li label:hover {
	cursor: pointer;
	color: #ccc;
}
.reservation3 .inner .cap {
	font-size: 90%;
	margin-bottom: 30px;
}
input[type="submit"] {
  -webkit-appearance: none;
}
input.form_btn {
	font-family: 'Noto Sans JP', sans-serif;
	display: block;
	max-width: 350px;
	width: 100%;
	margin: 0px auto;
	background-color: #AA1D1D;
	text-align: center;
	border: none;
	font-size: 110%;
	line-height: 100%;
	font-weight: 200;
	padding: 25px 0 28px;
	letter-spacing: 2px;
	font-weight: 500;
	color: #fff;
	border-radius:6px;
	-moz-border-radius:6px;
	-webkit-border-radius:6px;
	transition: .4s;
}
input.form_btn:hover {
	cursor: pointer;
	background-color: #AA1D1D;
	color: rgba(255,255,255,.7);
}

#privacy {
	border: #59CAC9 1px solid;
	padding: 20px 20px 10px;
	line-height: 170%;
	font-size: 90%;
	height: 200px;
	overflow: auto;
	margin: 40px 0 30px;
	border-radius:3px;
	-moz-border-radius:3px;
	-webkit-border-radius:3px;
}
#privacy li {
	margin-bottom: 15px;
}
#privacy li strong {
	display: block;
	font-weight: 500;
	font-size: 110%;
	margin-bottom: 5px;
}
#privacy li ol {
	list-style: outside disc;
	margin-left: 25px;
}
#privacy li ol li {
	margin-bottom: 0;
}
#thanks {
	max-width: 500px;
	width: 85%;
	margin: 100px auto 80px;
	background-color: #fff;
	padding: 40px;
}
#thanks dt {
	text-align: center;
	font-size: 150%;
	font-weight: 500;
	margin-bottom: 15px;
	letter-spacing: 4px;
}
#thanks dd {
}
#thanks dd a {
	display: block;
	font-weight:500;
	margin-top: 20px;
	background-color: #0A2047;
	color: #fff;
	padding: 15px 0;
	font-size: 110%;
	text-align: center;
	border-radius:3px;
	-moz-border-radius:3px;
	-webkit-border-radius:3px;
	transition: .3s;
}
#thanks dd a:hover {
	color: rgba(255,255,255,.7);
}
/* ------------------------------------ */



@media only screen and ( max-width : 900px ) {
	
	/* ------------------------------------ */
	.reservation .txt br {
		display: block;
	}
	.reservation li,
	.reservation li:nth-child(3) {
		width: 47.5%;
		margin-right: 5%;
		margin-bottom: 30px;
	}
	.reservation li:nth-child(2) {
		margin-right: 0;
	}
	.reservation li strong {
		font-weight: 400;
		font-size: 100%;
		line-height: 150%;
	}
	.reservation li strong br {
	}
	/* ------------------------------------ */ 
	.reservation3 .inner dl,
	.reservation3 .inner dt,
	.reservation3 .inner dd {
		display: block;
	}
	.reservation3 .inner dt {
		width: 100%;
		font-weight: 600;
	}
	.reservation3 .inner dt span {
		right: 0;
	}
	/* ------------------------------------ */
}
@media only screen and ( max-width : 680px ) {
	
	/* ------------------------------------ */
	.reservation {
		padding: 30px;
	}
	.reservation .txt {
		font-size: 100%;
	}
	.reservation li,
	.reservation li:nth-child(2),
	.reservation li:nth-child(3) {
		float: none;
		width: 100%;
		margin-right: 0;
		margin-bottom: 30px;
	}
	.reservation li p {
		max-width: 320px;
		width: 100%;
		margin: 0px auto 15px;
	}
	.reservation li strong {
		font-size: 110%;
	}
	/* ------------------------------------ */
	.reservation2 {
		padding: 30px 20px 20px;
	}
	.reservation2 .ttl {
		font-size: 110%;
		margin-bottom: 20px;
	}
	.reservation2 .txt {
		text-align: left;
		width: 90%;
		margin: 0px auto 30px;
	}
	.reservation2 .txt br {
		display: none;
	}
	.reservation2 li {
		float: none;
		width: 100%;
		margin-right: 0;
	}
	.reservation2 li:nth-child(1) {
		margin-bottom: 15px;
	}
	/* ------------------------------------ */
	.reservation3 .ttl {
		text-align: left;
		padding: 25px 20px;
	}
	.reservation3 .ttl .br_clear {
		display: none;
	}
	.reservation3 .inner {
		padding: 25px;
	}
	.reservation3 .inner dd input.siz_s {
		width: 80px;
	}
	.reservation3 .inner dd select.siz_s {
		width: 70px;
	}
	/* ------------------------------------ */
}