@charset "utf-8";

* {
	margin: 0;
	padding: 0;
}

h1.entry-title {
	margin-bottom: 1em;
	color: #fff;
	background-color: #434443;
	display: block;
	text-align: center;
	border-radius: 0.4em;
	padding: 10px 20px;
}

.monthly-prev-next {
	margin-top: 2em;
}

/* 月間予約カレンダー */
.monthly-calendar {
	clear: both;
	font-family: sans-serif;
	margin-bottom: 1.5rem;
}

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

.monthly-calendar caption {
/*	font-size: 1.1rem;*/
	text-align: center;
}

.monthly-calendar th {
/*	font-size: 1.1rem;*/
	font-weight: bold;
}

/* 月カレンダーの過去日の日付数字を薄く表示 */
.monthly-calendar .day-number.day-past {
    color: #333 !important;
    opacity: 0.5;
}

.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;
}

.monthly-calendar td {
	padding: 6px 0;
}

.day-box {
	border: 1px solid #434443;
	border-radius: 0.15em;
}


.day-box.no-day {
	background-color: #f0f0f0;
	border: none;
}

.day-box.today {
	background-color: #ffffe0;
}

/* 残席あり（vacant / low） → 薄い黄色 */
.day-box.vacant,
.day-box.low {
    background-color: #fff8c7 !important;
}

/* 「－」＝ disable、「休館」＝ closed、「×」＝ forcedx → グレー */
.day-box.disable,
.day-box.closed,
.day-box.forcedx {
    background-color: #f0f0f0 !important;
}

a.calendar-daylink {
	display: block;
}

.monthly-prev {
	float: left;
}

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

.calendar-mark {
	color: #888888;
/*	font-size: 1.4rem;*/
}

/* 指定日予約状況表示 */
.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;
	border-spacing: 1px 5px;
	width: 80%;
}

.day-calendar table tr:nth-child(odd) {
/*	display: none;*/
}

.day-calendar th,
.day-calendar td {
/*	font-size: 1rem;*/
	text-align: center;
	padding: 0;
	vertical-align: middle;
	width: 50%;
}

th.day-left {
	-moz-border-radius-topleft: 10px;
	-moz-border-radius-bottomleft: 10px;
	border-top-left-radius: 10px;
	border-bottom-left-radius: 10px;
	border: 1px solid #dddddd;
	line-height: 2.5rem;
}

th.day-right {
	-moz-border-radius-topright: 10px;
	-moz-border-radius-bottomright: 10px;
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	border: 1px solid #dddddd;
}

td.day-right {
	-moz-border-radius-topright: 10px;
	-moz-border-radius-bottomright: 10px;
	border-top-right-radius: 10px;
	border-bottom-right-radius: 10px;
	border: 1px solid #dddddd;
/*	font-size: 1.5rem;*/
}

a.booking-timelink {
	display: block;
}

/* 予約フォーム */
.content-form fieldset {
	border: 1px solid #dddddd;
	padding: 10px 0 0 10px;
	margin: 0 0 1.5rem 0;
	width: 99%;
}

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

.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;
	font-size: 1.1em;
}

.content-text.small {
	width: 3rem;
	font-size: 1.1em;
}

.content-text.medium {
	width: 48%;
	font-size: 1.1em;
}

.content-text.fat {
	width: 95%;
	font-size: 1.1em;
}

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


/* スマホ時に人数ブロックを縦積み＆左ずれを解消 */
@media (max-width: 600px) {
  .content-form .input-number {
    display: inline-table;         /* インラインのクセを消す */
    margin: 0 !important;   /* PC用の左右マージンを無効化 */
    padding: 0;             /* 念のため */
  }
  .content-form .input-number label {
    display: block;         /* ラベルは上、入力は下に */
    margin: 0 0 4px 0;
    text-align: left;
  }
  .content-form .input-number input {
    display: block;
    margin: 0;              /* 左ずれの元になりがちな margin-left をクリア */
    width: 3em;             /* お好みで固定幅（省略可） */
  }

  /* 2つ目以降だけに残ってる左マージンを消す保険 */
  .content-form td .input-number + .input-number {
    margin-left: 0 !important;
  }

  /* 念のため子ども欄だけピンポイントでリセット */
  #client-child {
    margin-left: 0 !important;
  }
}


input.right {
	text-align: right;
}

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

.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;
}

.content-form .input-number label { display:block; margin: 0 0 6px 0; }