@charset "utf-8";

/*色味は導入後調整してください。*/

* {
	margin: 0;
	padding: 0;
}

/* ===============================

色味の変更箇所
送信ボタン、チェックボックス、ラジオボタン

===============================*/
#booking-form.content-form button{
	-webkit-appearance: none;
    display: inline-block;
    padding: 0.5em 1em;
    text-decoration: none;
    border-radius: 4px;
    color: #ffffff;
    border: 0;
    /*
    border-bottom: solid 3px #c1ae8a;
	background-image: -webkit-linear-gradient(#ab8744 0%, #c1ae8a 100%);
	background-image: linear-gradient(#ab8744 0%, #c1ae8a 100%);
    */
    background: #32a2e8;
    box-shadow: 0px 2px 2px rgba(0, 0, 0, 0.29);
   	cursor: pointer;
}
.content-form .checkbox_box {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: #fff;
    border: 1px solid #000;
    position: relative;
    margin: 5px 5px 0 0;
    top: 4px;
    border-radius: 2px;
}
.content-form input[type="checkbox"]:checked + .checkbox_box::before {
	content: "";
	position: absolute;
	border-left: 3px solid #32a2e8;
	border-bottom: 3px solid #32a2e8;
	width: 15px;
	height: 7px;
	left: 50%;
	top: 50%;
	transform: rotate(-45deg);
	margin-left: -8px;
	margin-top: -5px;
}

.content-form .radio_box {
    display: inline-block;
    width: 20px;
    height: 20px;
    background: #fff;
    border: 1px solid #000;
    position: relative;
    margin: 5px 5px 0 0;
    top: 4px;
    border-radius: 20px;
}
.content-form input[type="radio"]:checked + .radio_box::before {
	content: "";
	position: absolute;
    background: #32a2e8;
	width: 10px;
	height: 10px;
	left: 50%;
	top: 50%;
	transform: translate(-50%,-50%);
    border-radius: 20px; 
}


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

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

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

.monthly-calendar th {
	font-weight: bold;
	padding: 5px;
}

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

.monthly-calendar td {
	padding: 6px 0;
}
.day-box.today {
	background-color: rgba(66, 103, 178, .4);
}

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 table {
	border: none;
	border-collapse: collapse;
	border-spacing: 0;
    width: 300px;
    margin: auto;
}
@media (max-width: 559px){
    .day-calendar table {
    	width: 100%;
    }
}
.day-calendar p {
    text-align: center;
}
.day-calendar th,
.day-calendar td {
	font-weight: normal;
	text-align: center;
	padding: 0;
	vertical-align: middle;
	width: 50%;
}

th.day-left,
th.day-right,
td.day-right {
	padding: 10px;
}
th.day-left {
	border: 1px solid #dddddd;
	line-height: 2.5rem;
}
th.day-right {
	border: 1px solid #dddddd;
}
td.day-right {
	border: 1px solid #dddddd;
	font-size: 1.5rem;
}
.calendar-mark.full,
a.booking-timelink {
	display: block;
	padding: 10px 0;
	position: relative;
}
.calendar-daylink {
    position: relative;
}
a.booking-timelink::after
.calendar-daylink::after {
	content: "";
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translateX(-50%);
	margin-top: 0.6em;
	width: 1.1em;
	margin-left: -0.5px;
	height: 1px;
	background: #fff;
}
.notice_text {
    display: inline-block;
    position: relative;
    font-size: 80%;
    font-weight: normal;
    padding-left: 1em;
}
.notice_text::before {
    content: "\00203b";
    position: absolute;
    left: 0;
}
.size_4 input {
    width: 4em;
}
@media (max-width: 767px){
    .notice_text {
        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-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 {
	line-height: 2.2rem;
	padding-right: 10px;
	text-align: right;
	vertical-align: top;
	width: 30%;
}

.content-form td {
}

.content-form input,
.content-form textarea {
	padding: 3px;
	margin-bottom: 3px;
	line-height: 1.5;
    font-size: 16px;
    font-family: unset;
}

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

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

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

.content-text.fat {
	width: 95%;
}
textarea.content-text.fat {
    padding: 10px;
}

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

input.right {
	text-align: right;
}

.content-form .error-message {
	clear: both;
	color: red;
	font-weight: bold;
    letter-spacing: 1.2px;
    text-shadow: 
        1px 1px 0 #fff,-1px -1px 0 #fff,/*右下、左上*/
        -1px 1px 0 #fff, 1px -1px 0 #fff,/*右上、左下*/
        0px 1px 0 #fff,0 -1px 0 #fff,/*右、左*/
        -1px 0 0 #fff, 1px 0 0 #fff;/*上、下*/
}

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

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

.content-form label.field-item {
	margin-right: 4px;
}

.content-form label.field-item input {
	margin-right: 15px;
}

.content-form select {
	font-size: 14px;
	padding: 1px 5px 3px;
}

@media only screen and (max-width: 767px){
	.content-form th,
	.content-form td {
		display: block;
		width: 100%;
		border: 0;
		padding: 5px;
	}
	.content-form th {
		border-right: 1px solid #fff;
	    padding-bottom: 0;
	}
	.content-form td {
		border-right: 1px solid #fff;
		border-bottom: 1px solid #fff;
	}
	.content-form th {
		text-align: left;
	}
	.content-form td::after {
		content: "";
		display: block;
		clear :both;
	}
	.content-text.fat {
		width: 100%;
	}
}

.form_textbox {
	width: 100%;
	min-height: 100px;
}

.form_radio li,
.form_checkbox li {
	display: inline-block;
	padding-right: 15px;
}

.content-form button:hover {
    -ms-transform: translateY(2px);
    -webkit-transform: translateY(2px);
    transform: translateY(2px);
    box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
    border-bottom-width: 2px;
	margin-bottom: 2px;
}
.content-form button:active{
    -ms-transform: translateY(4px);
    -webkit-transform: translateY(4px);
    transform: translateY(4px);
    box-shadow: 0px 0px 1px rgba(0, 0, 0, 0.2);
    border-bottom: none;
	margin-bottom: 4px;
}

.content-form select {
	padding: 5px 10px;
}

.content-form input[type="checkbox"],
.content-form input[type="radio"] {
    display: none;
}