/*
プラグイン用のCSS
*/
@charset "utf-8";

/***********************************************************
                  Contact Form 7
************************************************************/
.wpcf7{
	text-align: center;
	margin-bottom: 100px;
}
.wpcf7 form{
	display: inline-block;
	width: 100%;
	max-width: 600px;
}
.wpcf7 form > div{
	margin-right: 10px;
	margin-bottom: 20px;
}
.wpcf7 form > div#contact_message_block{
	align-items: flex-start;
}
.wpcf7 form > div#contact_message_block > div.contact_column{
	padding-top: 5px;
}

.wpcf7 form > div > div.contact_column{
	display: flex;
	justify-content: left;
	margin-bottom: 3px;
}
/* .wpcf7 form > div > div.contact_column p{
	display: none;
} */
.wpcf7 form > div > div.contact_column > .contact_column_text{
	font-size: 14px;
	padding: 5px 10px;
}
/* .wpcf7 form > div > div.contact_column > .contact_column_required{
	font-size: 12px;
	text-align: right;
	padding: 10px;
	border: 1px solid #777;
	color: #333;
	padding: 5px 10px;
} */

.wpcf7 form > div > div.contact_column > .contact_column_required {
    font-size: 12px;
    text-align: right;
    border: 1px solid #777;
    color: #333;
    padding: 6px 10px 4px;
    line-height: 1;
}
.wpcf7 form > div > div.contact_value{
	text-align: left;
}
.wpcf7 form > div > div.contact_value input{
	height: 26px;
}
.wpcf7 form > div > div.contact_value textarea{
	resize: vertical;
}
.wpcf7 form .your_name{
	width: calc(100% - 250px);
	ime-mode: active;
}
.wpcf7 form .your_tel{
	width: calc(100% - 250px);
	ime-mode: disabled;
}
.wpcf7 form .your_email{
	width: calc(100% - 120px);
	ime-mode: disabled;
}
.wpcf7 form .your_message{
	width: calc(100% - 10px);
	height: 200px;
	max-width: 600px;
	ime-mode: active;
}
.wpcf7 form #submit_button_row{
	margin: 50px auto 10px;
	display: flex;
    justify-content: center;
}
input.wpcf7-form-control.wpcf7-submit.has-spinner {
	font-size: 16px;
	display: inline-block;
	color: #FFF;
	background-color: #242427;
	padding: 12px 68px;
	text-decoration: none;
	text-align: center;
	width: 100%;
	max-width: 240px;
	height: 50px;
	cursor: pointer;
	border: 0;
}
input.wpcf7-form-control.wpcf7-submit.has-spinner:hover {
	text-decoration: none;
	background-color: #454549;
}
.wpcf7 form > div > div.contact_value > .ajax-loader{
	position: relative;
	left: 10px;
}

.wpcf7-not-valid-tip {
	text-align: left;
}

/* Contact Form 7のお問い合わせフォーム上のエラーがある時のメッセージ */
.wpcf7 div[role="alert"]{
	color: #F00;
	font-weight: bold;
}

/* Contact Form 7のお問い合わせフォーム上の各種エラー項目へのメッセージ(全てのフォームの上) */
.wpcf7 div[role="alert"] ul li{
	color: #F00;
	font-weight: normal;
}

/* Contact Form 7のお問い合わせフォーム上の各種エラー項目へのメッセージ(項目の横) */
.wpcf7 span[role="alert"]{
	color: #F00;
}


/* スマホ画面の時 */
@media screen and (max-width: 900px) {
	.wpcf7{
		display: flex;
		justify-content: center;
	}
	.wpcf7 form > div {
		display: block;
	}
	.wpcf7 form > div > div.contact_value{
		text-align: left;
	}
	.wpcf7 form > div > div.contact_value input,
	.wpcf7 form > div > div.contact_value textarea{
		width: 98%;
	}
	.wpcf7 form > div > div.contact_column > .contact_column_text{
		padding: 5px 0;
	}
	.wpcf7 form > div > div#submit_button_block{
		text-align: center;
	}
	.wpcf7 form > div > div.contact_column > .contact_column_required {
		margin-right: 5px;
	}
}



/***********************************************************
                  Simple Booking Calendar
************************************************************/

:root {

	/* 月 */
	--calendar-month-color: #333333;
	--calendar-month-font-size: 38px;
	--calendar-month-font-family: garamond-premier-pro, serif;
	--calendar-month-font-style: normal;
	--calendar-month-font-weight: normal;
  
	/* 曜日 */
	--calendar-day-color: inherit;
	--calendar-day-holiday-color: red;
	--calendar-day-color: #333333;
	--calendar-day-font-size: 14px;
	--calendar-day-font-family: garamond-premier-pro, serif;
	--calendar-day-font-style: normal;
	--calendar-day-font-weight: normal;
  
	/* 日 */
	--calendar-date-color: inherit;
	--calendar-date-font-size: 14px;
	--calendar-date-font-family: garamond-premier-pro, serif;
	--calendar-date-font-style: normal;
	--calendar-date-font-weight: normal;
  
	/* etc */
	--calendar-outer-frame-color: #333333;
	--calendar-border-color: #333333;
	--calendar-background-color: transparent;
  }
  
  .wpsbc-calendars-wrapper {
	color: var(--calendar-day-color);
  }
  
  .wpsbc-calendar {
	margin: 0 auto;
	width: 100% !important;
	border: 1px solid var( --calendar-outer-frame-color) !important;
  }
  
  /* カレンダー本体のラッパー */
  
  .wpsbc-container[data-columns] .wpsbc-calendars {
	margin-left: unset !important;
	margin-right: unset !important;
  }
  
  .wpsbc-container[data-columns] .wpsbc-calendars .wpsbc-calendar {
	float: none !important;
	margin: 0 auto !important;
	/* max-width: 480px !important; */
	max-width: 100% !important;
	padding: 17px 34px 13px;
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar {
	background-color: var(--calendar-background-color) !important;
  }

  #shop_list .wpsbc-container .wpsbc-calendars .wpsbc-calendar table thead tr th {
	padding: 0 0 14px 0 !important;
  }
  
  /* カレンダーの文字色を変更 */
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar table th {
	text-align: center;
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar table td {
	text-align: center;
  }
  
  /* カレンダーの月を表示しているヘッダ部分 */
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar .wpsbc-calendar-header {
	background-color: transparent !important;
	padding: 0 !important;
	position: relative;
  }
  
  /* カレンダーの月送りのヘッダ部分 */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation {
	  line-height: 1 !important;
	  position: static !important;
	  padding: 0 !important;
	  display: grid;
	  grid-template-columns: 25px 1fr 25px;
	  align-items: center;
	  width: 100%;
	  margin-bottom: 8px;
  }
  
  /* カレンダーの月移動の前ボタン */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-prev {
	background-color: transparent !important;
	position: static !important;
	margin-top: 0 !important;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1 !important;
	grid-column: 1 / 2;
  }
  
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-prev
	.wpsbc-arrow {
	border-width: 0 !important;
  }
  
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-next {
	background-color: transparent !important;
	position: static !important;
	margin-top: 0 !important;
	display: flex;
	justify-content: center;
	align-items: center;
	line-height: 1 !important;
	grid-column: 3 / 4;
  }
  
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-next
	.wpsbc-arrow {
	border-width: 0 !important;
  }
  
  .wpsbc-container
  .wpsbc-calendars
  .wpsbc-calendar
  .wpsbc-calendar-header
  .wpsbc-calendar-header-navigation
  .wpsbc-next::after {
	content: '';
	display: inline-block;
	width: 18px;
	height: 14px;
	background-image: url("../images/calendar/arrow-right.png");
	background-size: contain;
	background-repeat: no-repeat;
	vertical-align: middle;
  }
  
  .wpsbc-container
  .wpsbc-calendars
  .wpsbc-calendar
  .wpsbc-calendar-header
  .wpsbc-calendar-header-navigation
  .wpsbc-prev::after {
	content: '';
	display: inline-block;
	width: 18px;
	height: 14px;
	background-image: url("../images/calendar/arrow-left.png");
	background-size: contain;
	  background-repeat: no-repeat;
	vertical-align: middle;
  }
  
  /* カレンダーの月を表示しているヘッダ部分の後ろに画像を追加 */
  .wpsbc-container
  .wpsbc-calendars
  .wpsbc-calendar
  .wpsbc-calendar-header::after {
	  content: '';
	  display: inline-block;
	  width: 62px;
	  height: 15px;
	  background-image: url("../images/calendar/holiday.png");
	  background-size: contain;
	  background-repeat: no-repeat;
	  vertical-align: middle;
	  position: absolute;
	  top: 50%;
	  /* right: 50px; */
	  right: 28px;
	  transform: translate(0, -50%);
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar-wrapper {
	position: relative;
	/* top: -25px;
	margin-bottom: -40px; */
  }
  
  /* カレンダーの該当なし日付の背景を変更 */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	table
	tr
	td
	.wpsbc-date.wpsbc-gap {
	background-color: transparent !important;
  }
  
  /* カレンダーの通常の背景を変更 */
  #shop_list .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-1 div:first-of-type,
  #shop_list .wpsbc-container.wpsbc-calendar-3 .wpsbc-legend-item-icon-5 div:first-of-type,
  #shop_list .wpsbc-container.wpsbc-calendar-4 .wpsbc-legend-item-icon-7 div:first-of-type {
	background-color: transparent !important;
  }

  /* カレンダーの定休日の背景を変更 */
  /* .wpsbc-legend-item-icon-color:first-of-type {
	border-radius: 50%;
	width: 26px;
	height: 26px;
	top: 45%;
	left: 50%;
	transform: translate(-50%, -45%);
	right: 50%;
  } */

  .wpsbc-legend-item-icon[data-type=single] div:first-of-type {
	border-radius: 50%;
    position: absolute;
    top: 50%;
    left: 50%;
	right: 50%;
    display: block;
    width: 22px;
    height: 22px;
    transform: translate(-50%, -50%);
}

  
  /* カレンダーの営業日でも定休日でもない時の背景色を変更 */
  .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-3 div:first-of-type {
	background-color: transparent !important;
  }
  
  .wpsbc-date-inner {
	/* height: 35px !important;
	line-height: 35px !important; */
	height: 25px !important;
	line-height: 25px !important;
  }
  
  /* カレンダーの日付のフォントサイズ */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	table
	tr
	td
	.wpsbc-date-inner
	.wpsbc-date-number {
	font-size: var(--calendar-date-font-size) !important;
	font-family: var(--calendar-date-font-family);
	font-style: var(--calendar-date-font-style);
	font-weight: var(--calendar-date-font-weight);
	color: var(--calendar-date-color);
  }
  
  /* カレンダーのプルダウンの非表示 */
  .wpsbc-calendars-wrapper .wpsbc-select-container select {
	display: none;
  }
  
  /* カレンダーのプルダウンの代わりに月の数字を表示する */
  .wpsbc-container .wpsbc-select-container::before {
	font-family: var(--calendar-month-font-family);
	font-style: var(--calendar-month-font-style);
	font-weight: var(--calendar-month-font-weight);
	font-size: var(--calendar-month-font-size);
	color: var(--calendar-month-color) !important;
	display: block;
	grid-column: 2 / 3;
  }
  
  .wpsbc-container .wpsbc-select-container::after {
	font-size: 38px;
	display: block;
  }
  
  .wpsbc-container[data-current_month="1"] .wpsbc-select-container::before {
	content: "1";
  }
  
  .wpsbc-container[data-current_month="2"] .wpsbc-select-container::before {
	content: "2";
  }
  
  .wpsbc-container[data-current_month="3"] .wpsbc-select-container::before {
	content: "3";
  }
  
  .wpsbc-container[data-current_month="4"] .wpsbc-select-container::before {
	content: "4";
  }
  
  .wpsbc-container[data-current_month="5"] .wpsbc-select-container::before {
	content: "5";
  }
  
  .wpsbc-container[data-current_month="6"] .wpsbc-select-container::before {
	content: "6";
  }
  
  .wpsbc-container[data-current_month="7"] .wpsbc-select-container::before {
	content: "7";
  }
  
  .wpsbc-container[data-current_month="8"] .wpsbc-select-container::before {
	content: "8";
  }
  
  .wpsbc-container[data-current_month="9"] .wpsbc-select-container::before {
	content: "9";
  }
  
  .wpsbc-container[data-current_month="10"] .wpsbc-select-container::before {
	content: "10";
  }
  
  .wpsbc-container[data-current_month="11"] .wpsbc-select-container::before {
	content: "11";
  }
  
  .wpsbc-container[data-current_month="12"] .wpsbc-select-container::before {
	content: "12";
  }
  
  /* デフォルトの曜日表記を非表示にして英語表記の曜日に変更 */
  /* #main_contents .wpsbc-calendar-wrapper thead {
	border-bottom: 1px solid var(--calendar-border-color) !important;
  } */
  
  #main_contents .wpsbc-calendar-wrapper tbody:before {
	  content: "";
	  height: 1px;
	  width: 100%;
	  padding: 0;
	  display: block;
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar table tbody {
	border-top: 1px solid var(--calendar-border-color) !important;
  }
  
  .wpsbc-calendar-wrapper th {
	font-size: 0 !important;
  }
  
  .wpsbc-calendar-wrapper th::after {
	color: var(--calendar-day-color);
	font-size: var(--calendar-day-font-size);
	font-family: var(--calendar-day-font-family);
	font-style: var(--calendar-day-font-style);
	font-weight: var(--calendar-day-font-weight);
  }
  
  .wpsbc-calendar-wrapper th:nth-child(1)::after {
	content: "月";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(2)::after {
	content: "火";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(3)::after {
	content: "水";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(4)::after {
	content: "木";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(5)::after {
	content: "金";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(6)::after {
	content: "土";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(7)::after {
	content: "日";
	color: var(--calendar-day-holiday-color);
  }
  
  @media screen and (max-width: 540px) {
	/* .wpsbc-calendars-wrapper {
	  padding-top: 0;
	}
  
	.wpsbc-date-inner {
	  height: 25px !important;
	  line-height: 25px !important;
	}
  
	.wpsbc-container .wpsbc-select-container::before {
	  font-size: var(--calendar-month-font-size);
	  display: block;
	  position: relative;
	}
  
	.wpsbc-container .wpsbc-select-container::after {
	  font-size: 15px;
	  display: block;
	}
  
	.wpsbc-container
	  .wpsbc-calendars
	  .wpsbc-calendar
	  table
	  tr
	  td
	  .wpsbc-date-inner
	  .wpsbc-date-number {
	  font-size: 13px !important;
	  font-weight: 400;
	}
  
	.wpsbc-container
	  .wpsbc-calendar-1
	  .wpsbc-legend-item-icon-1
	  div:first-of-type {
	  border-radius: 100%;
	  width: 20px;
	  height: 20px;
	  left: 28.5%;
	}
  
	.wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-2 div:first-of-type,
	.wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-icon-6 div:first-of-type {
	  width: 22px;
	  height: 22px;
	}
  
	.wpsbc-container[data-columns] .wpsbc-calendars {
	  margin-left: initial !important;
	  margin-right: initial !important;
	}
  
	.wpsbc-container[data-columns] .wpsbc-calendars .wpsbc-calendar {
	  width: 90%;
	  padding: 15px;
	}
  
	.wpsbc-container
	  .wpsbc-calendars
	  .wpsbc-calendar
	  .wpsbc-calendar-header::after {
	  top: -44px;
	} */
  }