@charset "utf-8";

* {
	margin: 0;
	padding: 0;
}

/* 月間予約カレンダー */
.monthly-calendar h3, .day-calendar h3 {
	font-size: 2.0rem !important;
}

#reservation-box .left {
	float: left;
}

#reservation-box .right {
	float: right;
}

.day-calendar {
	clear: both;
}

.monthly-calendar {
	clear: both;
	font-family: sans-serif;
	margin-bottom: 1.5rem;
}

.monthly-calendar h3,
.day-calendar h3,
.content-form h3 {
	background: #2E2E2E !important;
    margin: 0 !important;
}

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

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

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

.day-box.sun {
	background-color: #ffeff2;
}

.week-title.sun,
.day-box.sun .day-number {
	/*color: #ff6347;*/
	color: #d82b4c;
}

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

.day-box.sat {
	background-color: #ffeff2;
}

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

.day-box.holiday {
	background-color: #ffeff2;
}

.monthly-calendar table,
.monthly-calendar th,
.monthly-calendar td {
	/*text-align: center;*/
	text-align: center !important;
	border: 1px solid lightgray;
	font-weight: normal;
}

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

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

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

a.calendar-daylink {
	display: block;
	text-decoration: underline;
}

.monthly-prev-next {
	margin-bottom: 10px;
}

.monthly-prev-next a {
	color: #999999;
}

.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%;*/
	width: 100%;
	border-collapse: collapse;
    border-spacing: 0;
}

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

th.day-left,
td.day-right {
	text-align: center !important;
	vertical-align: middle !important;
	padding: 15px 0 !important;
	border: 1px solid #dddddd;
	font-size: 1.5rem;
}

th.day-left {
	background-color: #f5f3f1;
}

.day-calendar tr:first-child th{
	background-color: #f5f3f1;
	text-align: center !important;
	padding: 5px 0 !important;
}

td.day-right .calendar-mark {
	text-align: center;
}

a.booking-timelink {
	display: block;
	text-decoration: underline;
}

/* 予約フォーム */
.content-form fieldset {
	/*border: 1px solid #dddddd;*/
	border: none;
	padding: 10px 0 0 0;
	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;*/
	border: none;
	padding: 2px;
	vertical-align: middle;
	display: block;
	width: 100%;
}

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

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

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

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

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

#action-button button {
    width: 100%;
    max-width: 240px;
    height: auto;
    padding: 12px 20px;
    margin-top: 25px;
    vertical-align: middle;
    color: #fff;
    background: #c2a57b;
    border: 1px solid #c2a57b;
    border-radius: 3px;
    cursor: pointer;
    font-size: 1.6rem;
}

#booking-confirm-fieldset th {
	font-weight: bold;
}

#booking_client-fieldset label[for^="service"],
#booking_client-fieldset label[for^="style"] {
	margin-right: 20px;
}

#booking_client-fieldset label[for^="style"] {
	font-size: 1.8rem;
	white-space: nowrap;
}

#reservation-form,
#fitting-reservation-form {
	padding: 0 5px;
}

#reservation-form strong,
#fitting-reservation-form strong {
	font-weight: bold;
}

#reservation-form h3,
#fitting-reservation-form h3 {
	color: #fff;
    text-align: center;
    background: #000;
	padding: 5px 0;
    font-size: 1.6rem;
}

#reservation-form table,
#fitting-reservation-form table {
	width: 100%;
	margin: 0;
}

#reservation-form table tbody,
#fitting-reservation-form table tbody {
	border: 1px solid #dddddd;
}

#reservation-form .monthly-calendar table th,
#reservation-form .day-calendar table th,
#fitting-reservation-form .monthly-calendar table th,
#fitting-reservation-form .day-calendar table th {
	margin: 0;
	padding: 0;
    font-weight: normal;
    margin-bottom: 5px;
    border-left: none;
    font-size: 2.0rem;
}

#reservation-form .monthly-calendar table td,
#reservation-form .day-calendar table td,
#fitting-reservation-form .monthly-calendar table td,
#fitting-reservation-form .day-calendar table td {
	padding: 5px 0 20px 0;
}

#reservation-form .monthly-calendar table tr,
#reservation-form .day-calendar table tr,
#fitting-reservation-form .monthly-calendar table tr,
#fitting-reservation-form .day-calendar table tr {
    display: table-row;
}

#booking_client-fieldset .must {
	color: #d82b4c;
	margin-left: 5px;
}
#booking_client-fieldset th,
#booking-message-fieldset th {
	text-align: left;
}

#booking_client-fieldset label,
#booking-message-fieldset label {
	font-size: 1.5rem;
}

#booking_client-fieldset input[type='text'],
#booking_client-fieldset input[type='tel'],
#booking_client-fieldset input[type='email'],
#booking_client-fieldset textarea {
	-webkit-appearance: none;
    -moz-appearance: none;
    appearance: none;
    border: none;
    outline: none;
    display: block;
    width: 100%;
    padding: 10px;
    box-sizing: border-box;
    background: #fff;
    border: solid 1px #ccc;
}

#booking_client-fieldset tr:nth-child(5) td label {
	width: 30%;
	display: inline-block;
}

#booking-confirm-fieldset th,
#booking-confirm-fieldset td {
	text-align: left;
	font-size: 1.5rem;
}

@media screen and (max-width: 480px) {
	#booking_client-fieldset tr:nth-child(5) td label {
		width: 100%;
		display: block;
	}
	th.day-left, td.day-right {
		padding: 10px 0 !important;
	}
	.monthly-calendar h3, .day-calendar h3 {
		font-size: 1.1rem !important;
	}
	#reservation-form .monthly-calendar table th,
	#fitting-reservation-form .monthly-calendar table th {
		font-size: 1.2rem !important;
	}
	#reservation-form .monthly-calendar table td,
	#reservation-form .day-calendar table td,
	#fitting-reservation-form .monthly-calendar table td,
	#fitting-reservation-form .day-calendar table td {
		padding: 5px 0 5px 0 !important;
	}
}
