@charset "utf-8";

* {
	margin: 0;
	padding: 0;
}

/* 月間予約カレンダー */
.monthly-calendar {
	clear: both;
	font-family: sans-serif;
	margin-bottom: 1.5rem;
	position: relative;
}
.monthly-calendar.calendar-overlay:after {
	background: rgba(255,255,255, 0.6);
	display: block;
	z-index: 1;
	height: 100%;
	width: 100%;
	content: "";
	position: absolute;
	top: 0;
}
.monthly-calendar.calendar-overlay .day-calendar {
	display: none;
}

.monthly-calendar table {
	width: 100%;
}

.monthly-calendar caption {
	font-size: 1.6rem;
	text-align: center;
	padding-bottom: 16px;
	padding-top: 16px;
}

.monthly-calendar th {
	font-size: 1.1rem;
	height: 20px;
	font-weight: normal;
}

.day-box {
	vertical-align: top;
	width: 14.285%;
}
.day-number {
	height: 20px;
	line-height: 20px;
	/*font-weight: bold;*/
	font-size: 12px;
}
.calendar-mark {
	height: 25px;
	line-height: 20px;
}
.week-title.sun,
.day-box.sun .day-number {
	color: #ff6347;
}

.week-title.sat,
.day-box.sat .day-number {
	color: #4169e1;
}

.day-box.holiday .day-number {
	color: #ff6347;
}

.monthly-calendar th,
.monthly-calendar td {
	text-align: center;
	border: 1px solid #eee;
}

.monthly-calendar td {
	padding: 0;
}

.day-box.no-day {
}

.day-box.today {
}

.day-box.today .day-number {
}
a.calendar-daylink {
	display: block;
	/*font-size: 4rem;*/
}
.active {
	background: #00BCD4;
	color: #FFF;
}
.calendar-daylink.active * {
	color: #FFF !important;
}

.monthly-prev {
	float: left;
}

.monthly-next {
	float: right;
	margin-right: 1rem;
}

.calendar-mark {
	color: #ddd;
	font-size: 1.4rem;
}

/* 指定日予約状況表示 */
.day-calendar {
	margin-top: 15px;
}
.day-calendar .calendar-mark {
	height: 40px;
	line-height: 40px;
}
.list-padding,
.day-calendar .calendar-mark.full {
	text-align: left;
	padding: 0 20px;
	z-index: 100;
}
.list-padding label {
	height: 40px;
	line-height: 40px;
	display: block;
}
.list-padding label input {
	margin-top: 14px;
}
.vacant .calendar-mark {
	/*font-size: 40px;*/
	color: #00BCD4;
}

.day-calendar h3 {
	display: none;
}
.day-calendar p {
	margin: 1em 0 0;
}

.day-calendar-list {
	width: 100%;
	border: 1px solid #eee;
	border-radius: 6px;
}
.day-calendar-flex {
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
}
.day-calendar-flex .day-left {
	width: 32%;
	border: 1px solid #eee;
	border-radius: 6px;
	overflow: hidden;
}
/*.day-calendar table {*/
	/*width: 100%;*/
	/*border: 1px solid #eee;*/
	/*border-collapse: separate;*/
	/*border-spacing: 0;*/
	/*border-radius: 6px;*/
	/*overflow: hidden;*/
/*}*/

/*.day-calendar th,*/
/*.day-calendar td {*/
	/*!*font-size: 1rem;*!*/
	/*text-align: center;*/
	/*padding: 0;*/
	/*vertical-align: middle;*/
	/*width: 50%;*/
	/*border-bottom: 1px solid #eee;*/

	/*!*padding: 10px 10px;*!*/
/*}*/
.day-calendar th,
.day-calendar th,
.day-calendar td {
	border-bottom: 1px solid #eee;
	border-top: 0;
}
.day-calendar th {
	background-color: #fff;
}
.day-calendar th {
	background-color: #fff;
}
.day-calendar th + th,
.day-calendar td {
	border-left: 1px solid #eee;
}
.day-calendar tr:last-child th,
.day-calendar tr:last-child td {
	border-bottom: none;
}

th.day-left {
	border-right: none;
	line-height: 2.5rem;
}

th.day-all {
	line-height: 2.5rem;
	height: 40px;
}
th.day-right a,
th.day-all a
{
	display: block;
	line-height: 40px;
}
th.day-right {
}

td.day-right {
	font-size: 1.5rem;
}

a.booking-timelink {
	display: block;
	text-align: left;
	padding: 0 20px;
	cursor: pointer;
	z-index: 100;
}
a.booking-timelink.active {
	background: #00BCD4;
	color: #FFF;
}
.day-left {
	position: relative;
}
.booking-time-text {
	position: absolute;
	top: 25%;
	left: 50px;
	z-index: -1;
}
.booking-time-text.active {
	z-index: 1;
	color: #FFF;
	background: transparent;
}
/* 予約フォーム */
.content-form {
	padding: 20px 0;
}
.content-form fieldset {
}

.content-form legend {
	display: none;
}

.content-form table {
	border: none;
	border-collapse: separate;
	border-spacing: 5px;
	margin: 0 0 5px 0;
	width: 99%;
}

.content-form th,
.content-form td {
	border-top: none;
	border-right: 1px solid #dddddd;
	border-bottom: 1px solid #dddddd;
	border-left: none;
	padding: 2px;
	vertical-align: middle;
}

.content-form th {
	font-size: 1rem;
	line-height: 2.2rem;
	padding-right: 10px;
	text-align: right;
	vertical-align: top;
	width: 30%;
}

.content-form td {
	font-size: 0.9rem;
}

.content-form input,
.content-form textarea {
	padding: 3px;
	margin-bottom: 3px;
	font-size: 1rem;
}

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

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

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

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

.input-number {
	float: left;
	margin-right: 1rem;
	text-align: center;
}

input.right {
	text-align: right;
}

.content-form .error-message {
	clear: both;
	color: red;
}
.error {
	color: red;
	padding: 10px 0 0;
}

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

/* 予約フォーム オプション表示項目 */
.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;
}
.headCalendar {
	position: relative;
	text-align: center;
	line-height: 30px;
	height: 30px;
	margin-bottom: 15px;
}

.monthly-prev-next {
	position: absolute;
	top:0;
	width: 100%;
}
.no-link {
	border-radius: 16px;
	background: #eee;
	color: #999;
	padding: 8px 16px;
	font-size: 1.2rem;
	
}
.monthly-prev {
	float: left;
}
.monthly-next {
	float: right;
}
.monthly-next a {
	border-radius: 16px;
	border: 1px solid #00BCD4;
	padding: 8px 16px;
	font-size: 1.2rem;

}
.monthly-prev a {
	border-radius: 16px;
	border: 1px solid #00BCD4;
	padding: 8px 16px;
	font-size: 1.2rem;
}

.booking-thanks {
	padding-top: 15px;
}
#booking-reservation-fieldset,
#booking-message-fieldset,
.entry-header,
.entry-footer {
	display: none;
}

h6 {
	margin-top: 15px;
	margin-bottom: 5px;
	font-weight: normal;
	color: #666;
}

#login input[type="text"], input[type="email"], input[type="number"], input[type="password"], input[type="search"], input[type="tel"], input[type="text"], input[type="url"], select, textarea {
	box-shadow: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}

input[type="text"],
input[type="password"]
{
	border-radius: 2px;
	line-height: 46px;
	box-shadow: none;
	-webkit-box-shadow: none;
	height: 46px;
	padding: 10px 16px;
	font-size: 18px;
	display: block;
	width: 100%;
	color: #555;
	background-color: #fff;
	background-image: none;
	border: 1px solid #ccc;

}

.tml-button {
	padding: 15px 40px;
	font-size: 16px;
	display: block;
	width: 100%;
}
.tml-links,
.tml-log-wrap .tml-label,
.tml-pwd-wrap .tml-label
{
	display: none;
}

.iframe-footer {
	position: absolute;
	bottom: 0;
	border-top: 0;
	padding:15px 20px 15px;
}

@media(max-width: 480px) {
	.day-calendar .calendar-mark {
		height: 35px;
		line-height: 40px;
	}
	.list-padding, .day-calendar .calendar-mark.full {
		text-align: center;
	}
	a.booking-timelink {
		text-align: center;
		padding: 0 20px 30px;
	}
	.booking-time-text {
		position: relative;
		top: auto;
		left: auto;
		text-align: center;
		display: block;
		margin-bottom: 10px;
	}
}