@charset "UTF-8";

/*---------------------------------
	パンくず
---------------------------------*/
#breadcrumb {
	width: 100%;
	overflow: hidden;
	background-color: #dddddd;
	position: relative;
	top: 105px;
	padding: 10px 0;
}


/* IE10以降 */
@media all and (-ms-high-contrast: none) {

	#breadcrumb {
		width: 100%;
		overflow: hidden;
		background-color: #dddddd;
		position: relative;
		top: 105px;
		padding: 12px 0 6px;
	}

}


#breadcrumb ul {
	overflow: hidden;
}

#breadcrumb ul li {
	list-style: none;
	display: inline-block;
}

#breadcrumb ul li a {
	display: block;
	text-decoration: none;
}

#breadcrumb ul li a:after {
	content: "\f105";
	font-family: FontAwesome;
	margin: 0 5px;
}


@media screen and (max-width: 900px) {

	#breadcrumb {
		top: 60px;
	}

}


/*---------------------------------
	SINGLEページ
---------------------------------*/
body.single #post {
	width: 100%;
	font-size: 120%;
}

body.single #post .box {
	max-width: 800px;
	width: 100%;
	float: none;
	margin: 0 auto 30px;
	overflow: hidden;
}

body.single #post .box .msg {
	width: 100%;
	margin: 0 0 20px;
	padding: 5px;
	font-size: 110%;
	font-weight: bold;
	color: #ff0000;
	text-align: center;
	background-color: #f5f5f5;
	border: 1px solid #dddddd;
	box-sizing: border-box;
}

body.single #post p {
	font-size: 90% !important;
}

body.single #post table {
	max-width: 800px;
	width: 100%;
	margin: 0 auto 15px;
}

body.single #post table.info th {
	width: 150px;
	padding: 10px 10px 10px 0;
	border-bottom: 1px solid #e3e3e3;
	box-sizing: border-box;
}

body.single #post table td {
	padding: 10px;
	line-height: 1.5;
	border-bottom: 1px solid #e3e3e3;
	box-sizing: border-box;
}

body.single #post table td a,
body.single #post table td a:hover,
body.single #post .monthly-prev a,
body.single #post .monthly-prev a:hover,
body.single #post .monthly-next a,
body.single #post .monthly-next a:hover {
	border: none !important;
}

body.single #post table.info th.pic {
	width: 200px;
}

body.single #post table.info td {
	font-size: 90%;
}

body.single #post .monthly-prev,
body.single #post .monthly-next {
	font-size: 100% !important;
	margin: 0 !important;
}

body.single #post .monthly-prev a,
body.single #post .monthly-next a {
	padding: 0 !important;
}

.calendar-mark {
	font-size: 90% !important;
}

.calendar-mark.full {
	padding: 0; /* 15px */
}

.movie {
	overflow: hidden;
}

.movie p {
	margin: 15px 0 0;
}


@media screen and (max-width: 600px) {

	body.single #post table.info th {
		width: 100% !important;
		display: block;
		padding: 10px;
	}

	body.single #post table.info th.pic .imgbox.no {
		max-width: 300px;
		max-height: 250px;
		width: 100%;
		height: 100%;
		margin: 0 auto;
	}

	body.single #post table.info th.pic img {
		width: 100% !important;
		height: auto;
	}

	body.single #post table.info td {
		width: 100%;
		display: block;
	}

}


@media screen and (max-width: 360px) {

	.monthly-calendar table {
		font-size: 90%;
	}

}


/*---------------------------------
	予約ページ
---------------------------------*/
/* 指定日予約状況表示 */
.day-calendar {
	font-family: sans-serif;
	margin-bottom: 1.5rem;
}

.day-calendar h3 {
	font-size: 1.1rem;
	margin: 10px 0;
}

.day-calendar table {
	border: none;
	border-collapse: separate;
	width: 80%;
}

.day-calendar th,
.day-calendar td {
	text-align: center;
	padding: 0;
	vertical-align: middle;
	width: 50%;
}

th.day-left {
	padding: 0 !important;
	border-radius: 0 !important;
	border: none !important;
	border-bottom: 1px solid #dddddd !important;
	line-height: 0;
	box-sizing: border-box;
}

th.day-right {
	padding: 0 !important;
	border-radius: 0 !important;
	border: none !important;
	border-bottom: 1px solid #dddddd !important;
	box-sizing: border-box;
}

td.day-right {
	padding: 0 !important;
	border-radius: 0 !important;
	border: none !important;
	border-bottom: 1px solid #dddddd !important;
	font-size: 1.5rem;
	box-sizing: border-box;
}

a.booking-timelink {
	display: block;
}

/* 予約フォーム */
.content-form fieldset {
	border: 1px solid #dddddd;
	margin: 0 auto 30px !important;
	padding: 10px 10px 0 10px !important;
	max-width: 800px !important;
	width: 100% !important;
	box-sizing: border-box;
}

.content-form legend {
	font-size: 1.1rem;
	font-weight: bold;
	padding: 0 5px;
}

.content-form table {
	border: none;
	border-collapse: collapse !important;
	border-spacing: 0 !important;
	margin: 0 0 5px 0 !important;
	width: 100% !important;
}

.content-form th {
	font-size: 100% !important;
	line-height: 0 !important;
	padding-right: 0 !important;
	text-align: center !important;
	vertical-align: middle !important;
	width: 200px !important;
	border-top: none;
	border-right: none !important;
	border-bottom: 1px solid #dddddd;
	border-left: none;
	padding: 0 !important;
	vertical-align: middle;
	box-sizing: border-box;
}

.content-form td {
	font-size: 100% !important;
	line-height: 1.5;
	border-top: none;
	border-right: none !important;
	border-bottom: 1px solid #dddddd;
	border-left: none!important;
	padding: 10px!important;
	vertical-align: middle;
	box-sizing: border-box;
}

.content-form input,
.content-form textarea {
	width: 100% !important;
	padding: 10px !important;
	background-color: #f5f5f5 !important;
	border: none !important;
	box-sizing: border-box !important;
}

fieldset#booking_client-fieldset label input {
	width: auto !important;
	margin: 0 5px 0 0;
}

fieldset#booking_client-fieldset label span.accept a::after {
	content: "\f08e";
	font-family: FontAwesome;
	margin: 0 5px;
}

.content-form button {
	padding: 3px 7px;
}

.content-text.small {
	width: 3rem;
	text-align: center;
}

.content-text.medium {
	width: 48%;
}

.content-text.fat {
	width: 95%;
}

.input-number {
	float: left;
	margin-right: 0;
	text-align: center;
	width: 50px;
}

.monthly-calendar td {
	padding: 6px 0;
	width: 14.285% !important;
}

input.right {
	text-align: right;
}

.content-form .error-message {
	clear: both;
	color: red;
}

.content-form .required {
	color: red;
}

.calendar-mark a.calendar-daylink {
	padding: 0 !important;
}

/* 予約フォーム オプション表示項目 */
.content-form input.booking-option-number {
	text-align: right;
	width: 3rem;
}

.content-form label.field-item {
	margin-right: 0.4rem;
}

.content-form label.field-item input {
	margin-right: 0.15rem;
}

.content-form select {
	font-size: 1rem;
	padding: 0.1rem 0.15rem;
}

/***** チェックボックスON *****/
#action-button button {
	cursor: pointer;
	margin: 0 0 30px !important;
	color: #ffffff !important;
	text-align: center !important;
	background-color: #ff8c00 !important;
	border: 1px solid #ff8c00 !important;
	text-decoration: none !important;
	padding: 10px 15px !important;
	transition: none 0s ease 0s !important;
}

#action-button button:hover {
	opacity: 0.6;
}

/***** チェックボックスOFF *****/
#action-button button:disabled,
#action-button button:disabled:hover {
	color: #333333 !important;
	text-align: center !important;
	background-color: #f5f5f5 !important;
	border: 1px solid #cccccc !important;
	text-decoration: none !important;
	margin: 0 0 30px !important;
	padding: 10px 15px !important;
	transition: none 0s ease 0s !important;
}


@media screen and (max-width: 480px) {

	.content-form th {
		display: block;
		padding: 5px 0 !important;
		text-align: left !important;
		width: 100% !important;
		line-height: normal !important;
	}

	.content-form td {
		display: block;
		text-align: left !important;
		width: 100% !important;
		line-height: normal !important;
	}

	.content-form td:last-child {
		border-bottom: none !important;
	}

}


/*---------------------------------
	ページ送り
---------------------------------*/
.nav-below {
	max-width: 800px;
	width: 100%;
	margin: 15px auto;
	text-align: center;
	overflow: hidden;
}

.nav-below .previous {
	width: 128px;
	float: left;
	position: relative;
}

.nav-below .next {
	width: 128px;
	float: right;
	position: relative;
}

.nav-below .previous a {
	display: block;
	text-align: center;
	background-color: #dcdcdc;
	text-decoration: none;
	padding: 10px;
}

.nav-below .next a {
	display: block;
	text-align: center;
	background-color: #dcdcdc;
	text-decoration: none;
	padding: 10px;
}

.nav-below .previous a:hover,
.nav-below .next a:hover {
	color: #ffffff;
	background-color: #ee7800;
}