/*
プラグイン用のCSS
*/


/***********************************************************
                  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_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;
}
.wpcf7 form > div > div.contact_value > .wpcf7-submit{
	font-size: 16px;
	display: inline-block;
	color: #FFF;
	background-color: #242427;
	padding: 12px 40px;
	text-decoration: none;
	text-align: center;
	width: 200px;
	height: 50px;
	cursor: pointer;
	position: relative;
	left: 6.5%;
	border: 0;
}
.wpcf7 form > div > div.contact_value > .wpcf7-submit: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: 100%;
	}
	.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
************************************************************/
/*
プラグイン用のCSS
*/
/***********************************************************
                  Simple Booking Calendar
************************************************************/

.wpsbc-calendars-wrapper {
	color: #000;
  }
  
  .wpsbc-calendar {
	margin: 0 auto;
	width: 100% !important;
	border: 1px solid #707070 !important;
  }
  
  /* カレンダー本体のラッパー */
  .wpsbc-container {
  }
  
  .wpsbc-container[data-columns] .wpsbc-calendars {
    margin-left: unset !important;
    margin-right: unset !important;
    display: flex;
    width: 100%;
}
  
  .wpsbc-container[data-columns] .wpsbc-calendars .wpsbc-calendar {
	float: none !important;
	margin: 0 auto !important;
	border: 0 !important;
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar {
	background-color: #fff3df !important;
  }

  /* .l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-7 .wpsbc-date-number,
  .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-2 .wpsbc-date-number {
	border: 1px solid #AA031F !important;
    border-radius: 50%;
    width: 30px !important;
	height: 30px !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
	color: #aa031f !important;
  } */

  .l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-7 div:first-of-type,
  .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-2 div:first-of-type {
	border: 1px solid #AA031F !important;
    border-radius: 50%;
    width: 30px !important;
	height: 30px !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
	color: #aa031f !important;
  }

	.l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-7 .wpsbc-date-number,
  .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-2 .wpsbc-date-number {
	color: #aa031f !important;
  }


  .l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-icon-8 div:first-of-type {
    border-radius: 50%;
    width: 30px !important;
	height: 30px !important;
    top: 50% !important;
    left: 50% !important;
    transform: translate(-50%, -50%);
  }

  .l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-icon-6 div:first-of-type,
  .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-1 div:first-of-type,
  .l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-icon-7 div:first-of-type {
	background-color: transparent !important;
  }


  /* カレンダーの文字色を変更 */
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar table th {
	color: #3A2921 !important;
	font-weight: bold;
	text-align: center;
  }
  
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar table td {
	color: #3A2921 !important;
	font-weight: bold;
	text-align: center;
  }
  
  /* カレンダーの月を表示しているヘッダ部分 */
  .wpsbc-container .wpsbc-calendars .wpsbc-calendar .wpsbc-calendar-header {
	background-color: transparent !important;
	padding: 0 !important;
  }
  
  /* カレンダーの月送りのヘッダ部分 */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation {
	line-height: 40px !important;
  }
  
  /* カレンダーの月移動の前ボタン */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-prev {
	background-color: transparent !important;
  }
  
  .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;
  }
  
  .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-prev::after {
	content: url("../images/arrow-left.svg");
  }
  
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header
	.wpsbc-calendar-header-navigation
	.wpsbc-next::after {
	content: url("../images/arrow-right.svg");
  }
  
  /* カレンダーの月を表示しているヘッダ部分の後ろに画像を追加 */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header::after {
	content: url("../images/holiday.svg");
	float: right;
	margin-right: 35px;
	position: relative;
	top: -43px;
  }

  /* .shimobori .wpsbc-container
  .wpsbc-calendars
  .wpsbc-calendar
  .wpsbc-calendar-header::after {
	content: url("../images/holiday_02.svg");
	float: right;
	margin-right: 35px;
	position: relative;
	top: -45px;
	} */
  
  .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;
  }
  
  /* カレンダーの通常の背景を変更 */
  .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-1 div:first-of-type {
	background-color: transparent !important;
  }
  
  /* カレンダーの定休日の背景を変更 */
  .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-icon-2 div:first-of-type {
	/* background-color: #C0D6BA !important; */
	background-color: transparent !important;
	border-radius: 100%;
	width: 30px;
	height: 30px;
	position: relative;
	top: 5.5%;
  
	display: block;
	margin: 0 auto;
  }
  
  /* カレンダーの営業日でも定休日でもない時の背景色を変更 */
  .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;
  }
  
  /* カレンダーの日付のフォントサイズ */
  .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	table
	tr
	td
	.wpsbc-date-inner
	.wpsbc-date-number {
	    font-size: 14px !important;
    font-weight: 400;
    font-style: normal;
    font-family: 'EB Garamond',serif;
	color: #AA031F;
  }
  
  /* カレンダーのプルダウンの非表示 */
  .wpsbc-calendars-wrapper .wpsbc-select-container select {
	display: none;
  }
  
  /* カレンダーのプルダウンの代わりに月の数字を表示する */
  .wpsbc-container .wpsbc-select-container::before {
	color: #AA031F !important;
    display: block;
    position: relative;
    top: 10px;
    padding-bottom: 20px;
    font-size: 33px;
    font-weight: 400;
    font-style: normal;
    font-family: 'EB Garamond',serif;
    letter-spacing: 0.05em;
    line-height: 46px;
  }
  
  .wpsbc-container .wpsbc-select-container::after {
	font-size: 18px;
	display: block;
	color: #6e594f !important;
  }
  
  .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 #777 !important;
  }
  
  .wpsbc-calendar-wrapper th {
	font-size: 0 !important;
  }
  
  .wpsbc-calendar-wrapper th::after {
	font-size: 15px;
    font-weight: 400;
    font-style: normal;
    font-family: 'EB Garamond',serif;
	color: #AA031F;
  }
  
  .wpsbc-calendar-wrapper th:nth-child(1)::after {
	content: "mon";
	color: #AA031F;
  }
  
  .wpsbc-calendar-wrapper th:nth-child(2)::after {
	content: "tue";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(3)::after {
	content: "wed";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(4)::after {
	content: "thu";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(5)::after {
	content: "fri";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(6)::after {
	content: "sat";
  }
  
  .wpsbc-calendar-wrapper th:nth-child(7)::after {
	
	content: "sun";
  }
  .p-shop__detail .wpsbc-container .wpsbc-calendars .wpsbc-calendar table thead tr {
	border-bottom: 1px solid #AA031F !important;
  }
  @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: 28px;
	  display: block;
	  position: relative;
	  top: 10px;
	}
  
	.wpsbc-container .wpsbc-select-container::after {
	  font-size: 15px;
	  display: block;
	}
  
	.wpsbc-container
	  .wpsbc-calendars
	  .wpsbc-calendar
	  .wpsbc-calendar-header
	  .wpsbc-calendar-header-navigation {
	  line-height: 28px !important;
	  position: relative;
	  top: -10px;
	}
  
	.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 {
	  width: 22px;
	  height: 22px;
	}
   */
	/* .wpsbc-container
	  .wpsbc-calendars
	  .wpsbc-calendar
	  .wpsbc-calendar-header::after {
	  content: url("../image/holiday_s.png");
	} */
  
	.wpsbc-container[data-columns] .wpsbc-calendars {
	  margin-left: initial !important;
	  margin-right: initial !important;
	}
  
	.wpsbc-container[data-columns] .wpsbc-calendars .wpsbc-calendar {
	  width: 90%;
	}
	.wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-7 .wpsbc-date-number,
	.wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-2 .wpsbc-date-number {
		width: 30px !important;
	}
	/* .wpsbc-container
	  .wpsbc-calendars
	  .wpsbc-calendar
	  .wpsbc-calendar-header::after {
	  top: -44px;
	} */

	/* .shimobori .wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header::after {
		content: url("../images/holiday_02.svg");
		margin-right: 8px;
		top: -33px;
	} */

	.wpsbc-container
	.wpsbc-calendars
	.wpsbc-calendar
	.wpsbc-calendar-header::after {
		content: url("../images/holiday.svg");
		float: right;
		margin-right: 10px;
		position: relative;
		top: -31px;
	}

	.wpsbc-container .wpsbc-calendars .wpsbc-calendar table tr td .wpsbc-date-inner .wpsbc-date-number {
		position: static !important;
	}

	.l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-icon-8 div:first-of-type {
		width: 22px !important;
		height: 22px !important;
	}

	.l-main .wpsbc-container.wpsbc-calendar-2 .wpsbc-legend-item-7 div:first-of-type, .l-main .wpsbc-container.wpsbc-calendar-1 .wpsbc-legend-item-2 div:first-of-type {
		width: 22px !important;
		height: 22px !important;
	}

  }
  