@charset "UTF-8";
/*----------------------
  コンテンツ別の設定値
----------------------*/


html,
body,
div,
span,
applet,
object,
iframe,
h1,
h2,
h3,
h4,
h5,
h6,
p,
blockquote,
pre,
a,
abbr,
acronym,
address,
big,
cite,
code,
del,
dfn,
em,
img,
ins,
kbd,
q,
s,
samp,
small,
strike,
strong,
sub,
sup,
tt,
var,
b,
u,
i,
center,
dl,
dt,
dd,
ol,
ul,
li,
fieldset,
form,
label,
legend,
table,
caption,
tbody,
tfoot,
thead,
tr,
th,
td,
article,
aside,
canvas,
details,
embed,
figure,
figcaption,
hgroup,
menu,
nav,
output,
ruby,
section,
summary,
time,
mark,
audio,
video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font-weight: normal;
  vertical-align: baseline;
}

/* スワイプによるリロード無効 */
body{
	overscroll-behavior-y	: none;
}

/* HTML5 display-role reset for older browsers */

article,
aside,
details,
figure,
footer,
header,
hgroup,
menu,
nav,
section {
  display: block;
}

 body {
  line-height: 1;
}

 ol,
ul {
  list-style: none;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

input,
textarea,
select,
label {
  margin: 0;
  font-size: 100%;
  font-family: inherit;
  vertical-align: middle;
}
textarea{
	resize: none;/* サイズ固定 */
	line-height: 1em;
}
 img {
  vertical-align: top;
}

.clearfix:after {
  content: '';
  display: block;
  clear: both;
  height: 0;
}

a,
a:link {
  color: #444;
  text-decoration: none;
}

a:active,
a:focus {
  color: #444;
  text-decoration: none;
}

 html,
body {
  height: 100%;
}

 body {
  font-family: YuGothic, "游ゴシック", "ヒラギノ角ゴ Pro W3", "HiraKakuPro-W3", "メイリオ", "Meiryo", "ＭＳ Ｐゴシック", sans-serif;
  font-size: 15px;
  line-height: 1.8em;
  -webkit-text-size-adjust: 100%;
  line-break: strict;
  letter-spacing: 0.07em;
}

.no-transition {
  transition: none !important;
}



/* Keyframes
   ========================================================================== */

@-webkit-keyframes remodal-opening-keyframes {
  from {
	-webkit-transform: scale(1.05);
	transform: scale(1.05);
	opacity: 0;
  }
  to {
	-webkit-transform: none;
	transform: none;
	opacity: 1;
  }
}

@keyframes remodal-opening-keyframes {
  from {
	-webkit-transform: scale(1.05);
	transform: scale(1.05);
	opacity: 0;
  }
  to {
	-webkit-transform: none;
	transform: none;
	opacity: 1;
  }
}

@-webkit-keyframes remodal-closing-keyframes {
  from {
	-webkit-transform: scale(1);
	transform: scale(1);
	opacity: 1;
  }
  to {
	-webkit-transform: scale(0.95);
	transform: scale(0.95);
	opacity: 0;
  }
}

@keyframes remodal-closing-keyframes {
  from {
	-webkit-transform: scale(1);
	transform: scale(1);
	opacity: 1;
  }
  to {
	-webkit-transform: scale(0.95);
	transform: scale(0.95);
	opacity: 0;
  }
}

@-webkit-keyframes remodal-overlay-opening-keyframes {
  from {
	opacity: 0;
  }
  to {
	opacity: 1;
  }
}

@keyframes remodal-overlay-opening-keyframes {
  from {
	opacity: 0;
  }
  to {
	opacity: 1;
  }
}

@-webkit-keyframes remodal-overlay-closing-keyframes {
  from {
	opacity: 1;
  }
  to {
	opacity: 0;
  }
}

@keyframes remodal-overlay-closing-keyframes {
  from {
	opacity: 1;
  }
  to {
	opacity: 0;
  }
}

/* IE8
   ========================================================================== */

.lt-ie9 .remodal-overlay {
  background: #2b2e38;
}

.lt-ie9 .remodal {
  width: 700px;
}

/*

under_page_common

*/
/* 210319 スクロール出来ない対処用*/
#reserve
 {
  overflow: auto;
	background-image: url(../img/shop_bg.gif);
	min-height: 100vh;
  -webkit-overflow-scrolling: touch;
}
.under_page {
  opacity: 0;
}

.under_page.load {
  opacity: 1;
  transition: opacity 0.4s cubic-bezier(0.77, 0, 0.175, 1);
}

.under_page .contentsAnime {
  transform: translateY(20px);
}

.under_page .page_title {
  text-align: center;
  letter-spacing: 0.16em;
  text-align: center;
}

.under_page h2 {
  text-align: center;
  letter-spacing: 0.08em;
  font-weight: 600;
}

.under_page h2 span {
  display: inline-block;
  font-weight: 400;
}

.under_page h3 {
  font-weight: 600;
}

.under_page .box_first_line {
  display: block;
  margin: 0 auto;
  height: 98px;
}

.under_page .box_first_line.on span{
  height: 98px;
}

.under_page .box_first_line span {
  display: block;
  background: #313131;
  margin: 0 auto;
  width: 3px;
  transition: height 0.5s cubic-bezier(0.42, 0, 0.58, 1);
  transform-origin: center top;
  height: 0;
}

.under_page .box_line span {
  display: block;
  background: #313131;
  margin: 0 auto;
  transition: height 0.4s cubic-bezier(0.42, 0, 0.58, 1);
  height: 0;
}

.under_page .box{
  box-sizing: border-box;
}

.under_page .annotation_link,
.remodal .annotation_link {
  text-align: center;
}

.under_page .annotation_link a,
.under_page .annotation_link span {
  padding-bottom: 1px;
  border-bottom: 1px solid #acacac;
}

.under_page form p,
.sub-txt-line {
  font-weight: 600;
}

.contact-cont-title {
  margin-bottom: 2em !important;
}

.sub-txt-line {
  margin-bottom: 1em;
}

.under_page .alert {
  font-weight: 400;
  color: #f15051;
  height: 0;
  opacity: 0;
  transition: height 0.4s ease, opacity 0.4s ease;
  text-align: left;
}

.under_page .alert.show {
  opacity: 1;
}

.cssINPUTBIRTH {
	width: 150px;
	position: relative;
}

.cssTARGET {
	font-size: 20px;
	font-weight: bold;
}

.cssCONTACT_INFO{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: center;
	align-items: center;
}

.cssCONTACT_INFO p:not(.cssCONTACT_TITLE){
	width: 85%;
	line-height: 60px;
}

.cssCONTACT_INFO .form_text:not(.form_contactname){
	margin:0 0 5px 0!important;
	width: 85%!important;
}

.cssCONTACT_TITLE{
	width		: 180px;
	font-size	: 16px;
}

.cssCONTACT_NAME {
	display			: flex;
	width			: 85%;
	justify-content	: space-between;
}


.cssCONTACT_BIRTH {
	margin-bottom: 0!important;
}


.form_contactname {
	margin-bottom	: 5px!important;
	width			: 49%!important;
}

.cssLINEID {
	margin-bottom		:0!important;
	align-items: center;

}

.cssCENTER {
	display: flex;
	justify-content: flex-start;
	margin-bottom: 10px;
	align-items: center;
}

.cssBETWEEN {
	display: flex;
	justify-content: space-between;
}

.width45p {
	width: 45%!important;
}

.cssTEXTAREA {
	width: 97%;
	height: 110px;
}


.label-danger {
	background-color: #d9534f;
	display: inline;
	padding: .2em .6em .3em;
	font-size: 75%;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	text-align: center;
	white-space: nowrap;
	vertical-align: baseline;
	border-radius: .25em;
}

.label-nini {
	background-color: #008040;
	display: inline;
	padding: .2em .6em .3em;
	font-size: 75%;
	font-weight: 700;
	line-height: 1;
	color: #fff;
	text-align: center;
	white-space: nowrap;
	vertical-align: baseline;
	border-radius: .25em;
}


@media screen and (min-width: 751px),
print {
  .box_area {
	border: 3px solid #313131;
	margin: 0 auto 20px;
	width: 550px;
	padding: 60px 115px;
  }
  .box_area .btn {
	margin: 30px auto 0;
  }
  .under_page .page_title {
	font-size: 32px;
	padding-top: 240px;
	line-height: 32px;
	margin-bottom: 55px;
  }
  .under_page .box_line {
	height: 98px;
  }
  .under_page .box_line span {
	width: 3px;
  }
  .under_page .box_line.on span {
	height: 98px;
  }
  .under_page .box_area {
	border: 3px solid #313131;
	margin: 0 auto 20px;
	width: 550px;
	padding: 85px 115px 100px;
  }

  .under_page h2 {
	font-size: 24px;
	margin-bottom: 30px;
  }
  .under_page h2 span {
	padding-top: 15px;
	font-size: 18px;
  }
  .under_page h3 {
	font-size: 20px;
	margin-bottom: 15px;
  }
  .under_page .subtext {
	margin-bottom: 48px;
  }
  .under_page .alert {
	height: 0;
  }
  .under_page .alert.show {
	height: 30px;
  }
  .under_page .form_search input {
	display: block;
	width: 100%;
	border: 3px solid #313131;
	box-sizing: border-box;
	font-size: 16px;
	line-height: 54px;
	text-indent: 1em;
	margin-bottom: 20px;
  }
  *::-ms-backdrop, .under_page .form_search input{
	height: 60px;
	padding-top:4px;
  }
  *::-ms-backdrop, .remodal .form_search input{
	height: 60px;
	padding-top:4px;
  }

  #ID_来店契機備考_DIV{
  	margin-bottom: 20px;
  	margin-left: 165px;
  }
  #ID_来店契機詳細{
  	margin-left: 165px;
  }


  *::-ms-backdrop{
	padding-top:5px;
  }
  *::-ms-backdrop{
	padding-top:5px;
  }
 
  .under_page .form_btn {
	position: absolute;
	top: 0;
	right: 0;
	z-index: 8;
	display: block;
	padding: 20px;
	width: 60px;
	height: 60px;
	text-align: center;
	background: #313131;
	box-sizing: border-box;
  }

  .under_page .form_btn:hover {
	cursor: pointer;
  }
  .under_page .form_btn path {
	fill: #fff;
  }
  .under_page .form_btn .icon-search {
	width: 20px;
	height: 20px;
  }
  .under_page .form_btn .icon-dropdown {
	margin: 5px 4px;
	width: 12px;
	height: 10px;
  }
  .under_page .form_text {
	display: block;
	width: 100%;
	border: 3px solid #313131;
	box-sizing: border-box;
	font-size: 15px;
	line-height: 54px;
	text-indent: 1em;
	margin-bottom: 20px;
	padding: 0 8px;
	align-items: center;
	height: 54px;
  }
  *::-ms-backdrop, .under_page .form_text{
	height: 60px;
	padding-top:4px;
  }
  .under_page .form_text input{
	width: 88%;
	margin-top: -2px;
  }
  .under_page .form_name .form_text {
	width: calc(100% / 2 - 10px);
  }
  .under_page .form_post .shortt {
	width: 160px;
  }
  .under_page .form_post .long {
	width: 220px;
  }
  .under_page .form_post .annotation_link {
	margin: 0 0 20px 25px;
  }
  .under_page .form_phone .form_text {
	width: 158px;
  }
  .under_page .reserve-slider_head .form_check label {
	margin-left: 0;
	margin-right: 0;
  }
  .under_page .form_check input[type="checkbox"],
  .under_page .form_check input[type="radio"] {
	display: none;
  }
  .under_page .form_check label {
	display: inline-block;
	position: relative;
	width: 36px;
	height: 36px;
	border: 3px solid #313131;
	box-sizing: border-box;
	margin-left: 25px;
	margin-right: 5px;
	cursor: pointer;
  }
  .under_page .form_check input[type="checkbox"]:checked+label::after,
  .under_page .form_check input[type="radio"]:checked+label::after{
	position: absolute;
	top: -3px;
	left: -3px;
	content: '';
	background: url(../img/checked.png) center center no-repeat;
	background-size: 22px auto;
	width: 36px;
	height: 36px;
  }
  #ID_LAVEL_CHKPASSWORD::after {
	width: 30px;
	height: 30px;
	filter: invert(50%) sepia(0%) saturate(11%) hue-rotate(143deg) brightness(101%) contrast(93%);
  }
  .under_page .form_sex,
  .under_page .form_birth {
	margin-bottom: 40px;
  }
  .under_page .form_sex p:not(.alert),
  .under_page .form_birth p:not(.alert),
  .remodal .form_sex p:not(.alert),
  .remodal .form_birth p:not(.alert) {
	font-size: 18px;
  }
 
  .under_page .form_birth {
	display: flex;
	align-items: center;
  }
  .under_page .form_birth p:not(.alert) {
	font-size: 18px;
  }
  .under_page .form_child_num {
	display: flex;
	align-items: center;
	margin-bottom: 45px;
  }
  .under_page .form_child_num select {
	width: 54px;
	margin-left: 20px;
	margin-right: 5px;
  }
  .under_page .form_child_num p:not(.alert){
	font-size: 20px;
  }

  .under_page .form_submit {
	margin-left: 5px;
	width: 120px;
	height: 60px;
	font-size: 16px;
	color: white;
	background: #313131;
  }
  .under_page .form_submit:hover {
	cursor: pointer;
  }
  .under_page .form_card .form_text+.form_text {
	margin-top: -3px !important;
  }
  .under_page .form_card2_month,
  .under_page .form_card2_year,
  .under_page .form_card2_security {
	position: relative;
	display: inline-block;
  }
  .under_page .form_card2_month {
	width: 160px;
  }
  .under_page .form_card2_year {
	margin-left: 20px;
	width: 180px;
  }
  .under_page .form_card2_security {
	width: 190px;
  }
  .under_page .form_card2+.form_card2 {
	margin-top: 10px;
  }
  .under_page .inner_block {
	padding-bottom: 50px;
	border-bottom: 2px solid #e5e5e5;
	margin-bottom: 50px;
  }
  .under_page .bar {
	width: 15px;
	height: 4px;
	background: #313131;
	display: block;
	margin: 0 8px 20px;
  }
  .under_page .annotation_link {
	margin-top: 28px;
  }
  .under_page .annotation_link a,
  .under_page .annotation_link span {
	transition: all 0.4s ease;
  }
  .under_page .annotation_link a:hover,
  .under_page .annotation_link span:hover {
	opacity: 0.8;
	padding-bottom: 3px;
	cursor: pointer;
  }

  #ID_LAVEL_CHKPASSWORD {
	border: 1px solid gray;
	width: 25px;
	height: 25px;
	margin-left: 165px;
}
}

.form-group {
	margin-bottom: 20px;
}

.cssLINE_TEXT {
	font-weight: normal!important;
	color: #878787;
}

input[id^="ID_生年月日"] {
	border : 2px solid #313131;
	font-size: 14px;
	padding: 0 1em;
	line-height: 44px;
	height: 44px;
	width: 50%;
	margin-bottom: 6px;
}


@media (min-width: 751px){
	.col-sm-10 {
		width: 83.33333333%;
		float: left;
	}
	.control-label {
	   font-size: 16px;
	   float: left;
	   width: 165px;
	}
	.label-input {
	   line-height: 60px;
	}
	.cssRAITENKEIKI {
	display: flex;
}
	.label-check {
	   line-height: 36px;
	}
	input[type="date"]::-webkit-inner-spin-button{
/*	-webkit-appearance: none;*/
		height: 54px;
	}
	input[id^="ID_生年月日"]::-webkit-inner-spin-button{
/*  -webkit-appearance: none;*/
		height: 30px;
	}
	.cssTEXT{
		height: 54px;
		border : 3px solid #313131;
		font-size: 16px;
		padding: 0 1em;
	}
	.cssTEXT_FULL {
		width: 63%;
	}
	input[id^="ID_生年月日"] {
		border : 3px solid #313131;
		font-size: 16px;
		padding: 0 1em;
		line-height: 54px;
		height: 54px;
		width: 40%;
		margin-bottom: 6px;
	}
	.cssRAITENABOUT {
		width: 125px;
	}
	.reserve-box img {
		width: 327px;
		height: 327px;
		object-fit: cover;
		display: block;
		margin: auto;
		padding: 0;
	}
	.cssCONTACT_NOTES {
	   font-size: 15px;
	}
	.br-sp {
		display: none;
	}
}

@media (max-width: 750px){
	.control-label {
	   margin-bottom: 5px;
	   font-size: 14px;
	}
	input[type="date"]::-webkit-inner-spin-button{
		height: 44px;
	}
	.cssTEXT{
		height: 44px;
		border : 2px solid #313131;
		font-size: 14px;
		padding: 0 1em;
	}
	.cssTEXT_FULL {
		width: 95%;
	}
	input[id^="ID_BIRTH"],
	#ID_ADD_BIRTHDAY {
		border : 2px solid #313131;
		font-size: 14px;
		line-height: 44px;
    height: 44px;
    width: 40%;
		padding: 0 1em;
	}
	textarea[id="ID_BIKOU"] {
		font-size: 14px;
	}
	.cssRAITENABOUT {
		width: 160px;
	}
	.reserve-box img {
		width: 290px;
		height: 290px;
		object-fit: cover;
		display: block;
		margin: auto;
		padding: 0;
	}
	.cssTEXTDONE {
		font-size: 12px;
	}
	.disp-pc {
		display: none;
	}
	.disp-sp {
		padding: 0!important;
	}
	.cssCONTACT_NOTES {
       font-size: 13px;
    }

  .br-sp {
  	display: block;
  }

}
@media screen and (min-width: 751px) and (max-width: 830px),
print {
  .under_page .box_area {
	padding: 60px 65px;
  }
}

@media screen and (max-width: 750px) {
  .remodal .box_area {
	margin: 0 auto !important;
  }
  .remodal .js-1st .box_area {
	margin: 60px auto 0 !important;
  }
  .under_page .page_title,
  .remodal .page_title {
	font-size: 16px;
	padding-top: 130px;
	line-height: 16px;
	margin-bottom: 40px;
  }
  .under_page .box_first_line,
  .remodal .box_first_line {
	height: 49px;
  }
  .under_page .box_first_line.on span,
  .remodal .box_first_line.on span {
	height: 49px;
  }
  .under_page .box_first_line span,
  .remodal .box_first_line span {
	height: 0;
	width: 2px;
  }
  .under_page .box_line,
  .remodal .box_line {
	height: 49px;
  }
  .under_page .box_line span,
  .remodal .box_line span {
	width: 2px;
  }
  .under_page .box_line.on span,
  .remodal .box_line.on span {
	height: 49px;
  }
  .under_page .box_area,
  .remodal .box_area {
	border: 2px solid #313131;
	margin: 0 10px 15px;
	padding: 45px 30px;
	/* background: #FFF; */
  }

  .under_page h2,
  .remodal h2 {
	font-size: 14px;
	margin-bottom: 15px;
	line-height: 1.6em;
  }
  .under_page h2 span,
  .remodal h2 span {
	font-size: 12px;
	margin-top: 5px;
  }
  .under_page h3,
  .remodal h3 {
	font-size: 13px;
	margin-bottom: 20px;
  }
  .under_page h4,
  .remodal h4 {
	font-size: 10px;
	margin-bottom: 20px;
  }
  .under_page .subtext,
  .remodal .subtext {
	margin-top: 40px;
	line-height: 1.6em;
	font-size: 13px;
	margin-bottom: 38px;
  }
  .under_page .alert,
  .remodal .alert {
	font-size: 11px;
	height: 0;
  }
  .under_page .alert.show,
  .remodal .alert.show {
	height: 25px;
  }

  .under_page .form_btn,
  .remodal .form_btn {
	position: absolute;
	top: 0;
	right: 0;
	z-index: -1;
	display: block;
	padding: 16.5px;
	width: 45px;
	height: 45px;
	text-align: center;
	background: #313131;
	box-sizing: border-box;
  }
  .under_page .form_btn{
	z-index: 20;
  }
  .under_page .form_btn:hover,
  .remodal .form_btn:hover {
	cursor: pointer;
  }
  .under_page .form_btn path,
  .remodal .form_btn path {
	fill: #fff;
  }
  .under_page .form_btn .icon-search,
  .remodal .form_btn .icon-search {
	width: 12px;
	height: 12px;
  }
  .under_page .form_btn .icon-dropdown,
  .remodal .form_btn .icon-dropdown {
	margin: 2.75px 2.25px;
	width: 7.5px;
	height: 6.5px;
	vertical-align: top;
  }
  .under_page .form_text,
  .remodal .form_text{
	display: block;
	width: 100%;
	border: 2px solid #313131;
	box-sizing: border-box;
	line-height: 44px;
	text-indent: 1em;
	margin-bottom: 15px;
  }

  .under_page .form_text input,
  .remodal .form_text input {
	font-size: 21px;
	transform: scale(0.7);
	margin-top: -2px;
	width: 110%;
	transform-origin: left center;
  }
 
  .under_page .form_check input[type="checkbox"],
  .under_page .form_check input[type="radio"],
  .remodal .form_check input[type="checkbox"],
  .remodal .form_check input[type="radio"] {
	width: 30px;
	height: 30px;
	border: 2px solid #313131;
	box-sizing: border-box;
	margin-left: 5px;
	margin-right: 2px;
  }
  .under_page .form_check input[type="checkbox"]:checked,
  .under_page .form_check input[type="radio"]:checked,
  .remodal .form_check input[type="checkbox"]:checked,
  .remodal .form_check input[type="radio"]:checked {
	background: url(/reservation/common/img/checked.png) center center no-repeat;
	background-size: 14px auto;
  }
  .under_page .form_check span,
  .remodal .form_check span {
	font-size: 13px;
	margin-right: 20px;
  }

  .under_page .form_submit,
  .remodal .form_submit {
	margin-left: 5px;
	width: 80px;
	height: 44px;
	font-size: 13px;
	color: white;
	background: #313131;
  }
  .under_page .form_card .form_text+.form_text,
  .remodal .form_card .form_text+.form_text {
	margin-top: -2px !important;
  }
  .under_page .form_card2::after,
  .remodal .form_card2::after {
	content: "";
	display: block;
	clear: both;
	overflow: hidden;
  }

  .under_page .inner_block,
  .remodal .inner_block {
	padding-bottom: 50px;
	border-bottom: 2px solid #e5e5e5;
	margin-bottom: 40px;
  }
  .under_page .bar,
  .remodal .bar {
	width: 8px;
	height: 2px;
	background: #313131;
	display: block;
	margin: 0 4px 15px;
  }

  .under_page .pankuzu,
  .remodal .pankuzu {
	margin: 50px 10px 10px;
	text-align: center;
  }
  .under_page .pankuzu span:not(.j_sans),
  .remodal .pankuzu span {
	display: inline-block;
	width: 9px;
	height: 2px;
	background: #e5e5e5;
	margin: 0px 5px 2px;
  }
  .under_page .footer,
  .remodal .footer {
	padding-top: 10px;
  }
}

  #ID_来店契機備考_DIV{
  	margin-bottom: 15px;
  }


/*

register

*/

@media screen and (min-width: 751px),
print {
  #register.under_page h2 {
	margin-top: 60px;
	line-height: 1.4em;
  }
  #register.under_page .note {
	letter-spacing: 0.02em;
  }
  #register.under_page .mail {
	margin-bottom: 65px;
  }
  #register.under_page .pass_note {
	margin-top: 45px;
	font-size: 20px;
	margin-bottom: 15px;
  }
  #register.under_page .btn {
	width: 200px;
  }
}

@media screen and (max-width: 750px) {
  #register.under_page .form_name.name2 {
	margin-bottom: 15px;
  }
  #register.under_page .mb {
	margin-bottom: 32px;
  }
  #register.under_page .note {
	font-size: 12px;
	line-height: 1.6em;
	margin-bottom: 2px;
	letter-spacing: 0.02em;
  }
  #register.under_page .pass_note {
	margin-top: -10px;
	font-size: 12px;
	margin-bottom: 15px;
  }
  #register.under_page .box_area .btn {
	margin: 50px auto 5px;
  }
}
/*

reserve

*/

.reserve-box {
  position: relative;
}

.reserve-box:after {
  content: '';
  width: calc(100% + 6px);
  height: calc(100% + 6px);
  background: #fff;
  position: absolute;
  bottom: -3px;
  left: -3px;
  transition: height 0.8s cubic-bezier(0.42, -0.01, 0.63, 0.18) 0.2s;
  transform-origin: center top;
  z-index: 9;
}

.reserve-box.reserve-btn:after {
  transition: height 0.4s cubic-bezier(0.42, -0.01, 0.63, 0.18) 0.1s;
}

.reserve-box.on:after {
  height: 0%;
}

.js-1st .reserve-box:after {
  content: none;
}

/*

reserve-confirm

*/

-confirm .sub-txt{
  font-weight: 600;
  margin-bottom: 50px;
  margin-top: 0!important;
  text-align: center;
}

@media screen and (min-width: 751px),
print {
  -confirm .getpass_outer {
	margin-top: 28px;
	text-align: center;
  }
  -confirm .getpass {
	position: relative;
  }
  -confirm .getpass:hover::after {
	opacity: 0;
  }
  -confirm .getpass:after {
	content: "";
	position: absolute;
	z-index: -1;
	left: 0;
	right: 100%;
	bottom: -3px;
	background: #878787;
	width: 100%;
	height: 1px;
	transition: right 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  }
  -confirm #pass h2 {
	padding-top: 30px;
  }
  -confirm #pass p {
	font-size: 20px;
	text-align: left;
	font-weight: 600;
	padding-bottom: 60px;
	padding-top: 20px;
	line-height: 1.6em;
  }
}

@media screen and (max-width: 750px) {
  -confirm .sub-txt{
	font-size:14px;
  }
  -confirm .getpass_outer {
	margin-top: 10px;
	text-align: center;
	font-size: 12px;
  }
  -confirm .getpass {
	position: relative;
  }
  -confirm .getpass:after {
	content: "";
	position: absolute;
	z-index: -1;
	left: 0;
	right: 100%;
	bottom: -3px;
	background: #878787;
	width: 100%;
	height: 1px;
	transition: right 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  }
  -confirm #pass p {
	font-size: 14px;
	font-weight: 600;
	text-align: left;
  }
}

/* RESERVEページ用CSS */

.reserve-btn {
  text-align: center;
}

.reserve-btn .btn {
  display: inline-block;
  width: 260px;
  height: auto;
}

@media screen and (max-width: 750px) {
  .reserve-btn .btn {
	display: block;
	margin: 0 auto;
	max-width: 185px;
  }
}

.reserve-btn .btn .btn_hover_red::after {
  background: #886c3d;
}

@media screen and (min-width: 751px),
print {
  .reserve-btn .btn a {
	padding: 16px 0 12px;
	font-size: 16px;
	font-weight: 600;
	height: 100%;
	line-height: 1.5em;
  }

}

@media screen and (max-width: 750px) {
  .reserve-btn .btn a {
	padding: 14px 0 8px;
	font-size: 12px;
	font-weight: 600;
	height: 100%;
	line-height: 1.3em;
  }

  .reserve-btn .btn button {
	padding: 14px 0 8px;
	font-size: 12px;
	font-weight: 600;
	height: 100%;
	line-height: 1.3em;
	width:100%;
	color: #000;
  }

  .btn button {
	display: block;
	width: 100%;
	line-height: 34px;
	font-size: 14px;
	letter-spacing: 0.14em;
	text-align: center;
	background: #fff;
	vertical-align: unset;
	padding-top: 4px;
	color: #000;
  }
  .btn button::after {
	background: #f18a83;
  }
}

.reserve-btn .btn a span {
  display: block;
  font-weight: 300;
  font-family: sans-serif;
}

@media screen and (max-width: 750px) {
  .reserve-btn .btn a span {
	font-size: 18px;
	color: #878787;
	transform: scale(0.5);
  }
}


@media screen and (max-width: 750px) {
  .reserve-btn .btn+.btn {
   /* margin-top: 24px;*/
   margin-top: 5px;
  }
}

.reserve-btn .btn.is-active a {
  color: white;
  background: #886c3d;
}

.reserve-btn .btn.is-active a span {
  color: white;
}

.reserve-time {
  margin-top: 60px;
}

@media screen and (max-width: 750px) {
  .reserve-time {
	margin-top: 30px;
  }
}

@media screen and (max-width: 750px) {
  .reserve-time h3 {
	margin-bottom: 0;
  }
}

.reserve-time table {
  margin-top: 20px;
  width: 100%;
  border-bottom: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  .reserve-time table {
	margin-top: 8px;
	border-width: 1px;
  }
}

.reserve-time table tr {
  border-top: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  .reserve-time table tr {
	border-width: 1px;
  }
}

.reserve-time table th,
.reserve-time table td {
  padding: 10px 0;
  vertical-align: middle;
}

@media screen and (max-width: 750px) {
  .reserve-time table th,
  .reserve-time table td {
	padding: 8px 0;
  }
}

.reserve-time table th {
  font-size: 20px;
  text-align: left;
}

@media screen and (max-width: 750px) {
  .reserve-time table th {
	font-size: 13px;
  }
}

.reserve-time table td {
  width: 260px;
}

@media screen and (max-width: 750px) {
  .reserve-time table td {
	width: 160px;
  }
}

.reserve-time .btn {
  margin: 0;
}

@media screen and (max-width: 750px) {
  .reserve-time .btn {
	/*max-width: 160px;*/
	max-width: 140px;
	display: inline-block;
  }
}



@media screen and (max-width: 750px) {
  .reserve-time .btn a {
	padding: 10px 0 4px;
  }
}

.reserve-time .btn.is-disable {
  border-color: #e5e5e5;
}

.reserve-time .btn.is-disable a {
  color: #e5e5e5!important;
  pointer-events: none;
}


*[id^="reserve"] {
  padding: 240px 0 0;
}

@media screen and (min-width: 751px) {
  *[id^="reserve"] .attention {
	margin-bottom: 50px;
  }
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] {
	padding: 90px 0 0;
  }
}


*[id^="reserve"] .reserve-step {
  min-height: 121px;
  margin-bottom: 42px;
  text-align: center;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step {
	margin-bottom: 0;
	min-height: 0;
	height: 122px;
  }
}

*[id^="reserve"] .reserve-step ul {
  display: inline-block;
  margin-bottom: 40px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step ul {
	margin-bottom: 6px;
  }
}

*[id^="reserve"] .reserve-step li {
  position: relative;
  float: left;
  width: 46px;
  height: 46px;
  font-size: 17px;
  line-height: 46px;
  text-align: center;
  color: white;
  border-radius: 50%;
  background: #e5e5e5;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step li {
	width: 27px;
	height: 27px;
	font-size: 10px;
	line-height: 27px;
  }
}

*[id^="reserve"] .reserve-step li+li {
  margin-left: 66px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step li+li {
	margin-left: 40px;
  }
}

*[id^="reserve"] .reserve-step li:nth-of-type(n+2)::before {
  content: "";
  position: absolute;
  left: -33px;
  top: 50%;
  display: block;
  margin-top: -1.5px;
  width: 30px;
  height: 3px;
  background: #e5e5e5;
  transition: all 0.5s ease;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step li:nth-of-type(n+2)::before {
	left: -18px;
	margin-top: -1px;
	width: 17px;
	height: 2px;
  }
}

*[id^="reserve"] .reserve-step li:nth-last-of-type(n+2)::after {
  content: "";
  position: absolute;
  right: -33px;
  top: 50%;
  display: block;
  margin-top: -1.5px;
  width: 30px;
  height: 3px;
  background: #e5e5e5;
  transition: all 0.5s ease;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step li:nth-last-of-type(n+2)::after {
	right: -18px;
	margin-top: -1px;
	width: 16px;
	height: 2px;
  }
}

*[id^="reserve"] .reserve-step li.is-active {
  background: #886c3d;
}

*[id^="reserve"] .reserve-step li.is-after::after {
  background: #886c3d;
}

*[id^="reserve"] .reserve-step li.is-before::before {
  background: #886c3d;
}

*[id^="reserve"] .reserve-step li span {
  font-size: 14px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step li span {
	display: inline-block;
	margin: 0 -50%;
	width: 200%;
	font-size: 16px;
	transform: scale(0.5);
  }
}

*[id^="reserve"] .reserve-step p {
  font-size: 16px;
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step p {
	font-size: 12px;
	letter-spacing: 0;
	margin: 26px 0;
  }
}

*[id^="reserve"] .reserve-step p a {
  font-weight: inherit;
  text-decoration: underline;
}

*[id^="reserve"] .reserve-step p a span {
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-step p a span {
	display: none;
  }
}

*[id^="reserve"] .reserve-box {
  margin-bottom: 0;
  background-color: #fff;
}

*[id^="reserve"] .reserve-box h2 {
  margin-bottom: 20px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h2 {
	margin-bottom: 0;
  }
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h2+h3 {
	font-weight: 300;
  }
}

*[id^="reserve"] .reserve-box h2+.inner_block {
  margin-top: 90px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h2+.inner_block {
	margin-top: 40px;
  }
}

*[id^="reserve"] .reserve-box h2 span {
  display: inline-block;
  margin-right: 0.4em;
}

*[id^="reserve"] .reserve-box h2 span svg {
  position: relative;
  top: -2px;
  max-width: 32px;
  max-height: 32px;
  vertical-align: bottom;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h2 span svg {
	top: -3px;
	max-width: 17px;
	max-height: 17px;
  }
}

*[id^="reserve"] .reserve-box h3 {
  margin-bottom: 10px;
  text-align: center;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h3 {
	margin-bottom: 20px;
	line-height: 1.5;
  }
}

*[id^="reserve"] .reserve-box h3+h2 {
  margin: 50px 0 40px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h3+h2 {
	margin-bottom: 20px;
  }
}

*[id^="reserve"] .reserve-box h3.tleft {
  text-align: left;
}

*[id^="reserve"] .reserve-box+.reserve-box {
  margin-top: 20px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box+.reserve-box {
	margin-top: 15px;
  }
}

*[id^="reserve"] .reserve-box .inner_block {
  margin: 0;
  padding: 0;
  border: none;
}

*[id^="reserve"] .reserve-box .inner_block+.inner_block {
  margin-top: 30px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box .inner_block h2 {
	display: none;
  }
}

*[id^="reserve"] .reserve-box .inner_block h3 {
  margin-bottom: 15px;
}

*[id^="reserve"] .reserve-box .inner_block select,
*[id^="reserve"] .reserve-box .inner_block .form_text {
  margin: 0;
}


*[id^="reserve"] .reserve-inner {
  margin-top: 40px;
  padding-top: 40px;
  text-align: center;
  border-top: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-inner {
	margin-top: 24px;
	padding-top: 20px;
	border-top-width: 1px;
  }
}

*[id^="reserve"] .reserve-inner h4 {
  font-size: 18px;
  font-weight: 600;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-inner h4 {
	margin-bottom: 8px;
	font-size: 11px;
	line-height: 1.5em;
  }
}

*[id^="reserve"] .reserve-inner p {
  font-size: 16px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-inner p {
	margin-bottom: 16px;
	font-size: 10px;
	line-height: 1.5em;
	color: #878787;
  }
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-inner .reserve-btn .btn {
	margin: 30px auto 0;
  }
}

*[id^="reserve"] .reserve-form {
  margin-top: 50px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-form {
	margin-top: 20px;
  }
}

*[id^="reserve"] .reserve-form p {
  font-weight: 600;
}

*[id^="reserve"] .reserve-form .reserve-input {
  position: relative;
  margin-bottom: 20px;
}

*[id^="reserve"] .reserve-form .reserve-input:last-of-type {
  margin: 0;
}

*[id^="reserve"] .reserve-form .reserve-input:last-of-type select {
  margin: 0;
}

*[id^="reserve"] .reserve-slider {
  margin: 0 -70px 30px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider {
	margin: 0 0 50px;
  }
}

*[id^="reserve"] .reserve-slider li {
  position: relative;
}

*[id^="reserve"] .reserve-slider_box {
  position: relative;
/*  margin-top: 80px;*/
  padding-bottom: 20px;
  width: 327px;
  overflow: hidden;
}

@media screen and (min-width: 751px),
print {
  *[id^="reserve"] .reserve-slider_box:nth-of-type(2n-1) {
	float: left;
  }
  *[id^="reserve"] .reserve-slider_box:nth-of-type(2n) {
	float: right;
  }
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_box {
	margin-top: 50px;
	padding-bottom: 0;
	width: 100%;
  }
}

*[id^="reserve"] .reserve-slider_box .reserve-slider_txt {
  position: absolute;
  top: 0;
  right: 0;
  z-index: 9998;
  padding-top: 100%;
  width: 100%;
  transition: all 0.5s ease;
  box-sizing: border-box;
  background: rgba(119, 146, 144, 0.8);
}

*[id^="reserve"] .reserve-slider_box .reserve-slider_txt p {
  font-size: 11px;
  line-height: 1.4em;
  position: absolute;
  top: 50%;
  left: 50%;
  padding: 30px;
  width: 100%;
  color: white;
  transform: translate(-50%, -50%);
  box-sizing: border-box;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_box .reserve-slider_txt p {
	padding: 20px;
	font-size: 11px;
	line-height: 1.4;
  }
}

*[id^="reserve"] .reserve-slider_head p {
  position: absolute;
  top: 10px;
  z-index: 9;
  display: block;
  width: 36px;
  height: 36px;
  background: white;
  cursor: pointer;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_head p {
	top: 5px;
	width: 40px;
	height: 40px;
  }
}

*[id^="reserve"] .reserve-slider_head p.left {
  left: 10px;
  cursor: default;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_head p.left {
	left: 5px;
  }
}

*[id^="reserve"] .reserve-slider_head p.right {
  right: 10px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_head p.right {
	right: 5px;
  }
}

*[id^="reserve"] .reserve-slider_head p.is-black {
  background: #313131;
}

*[id^="reserve"] .reserve-slider_head p.is-black path {
  fill: white;
}

*[id^="reserve"] .reserve-slider_head p.is-gray {
  background: #878787;
}

*[id^="reserve"] .reserve-slider_head p.is-gray path {
  fill: white;
}

*[id^="reserve"] .reserve-slider_head p.is-lightgray {
  background: #dcdcdc;
}

*[id^="reserve"] .reserve-slider_head p.is-lightgray path {
  fill: white;
}

*[id^="reserve"] .reserve-slider_head p svg {
  position: absolute;
  top: 50%;
  left: 50%;
  max-width: 24px;
  max-height: 24px;
  transform: translate(-50%, -50%);
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_head p svg {
	max-width: 18px;
	max-height: 18px;
  }
}

*[id^="reserve"] .reserve-slider_head p svg path {
  fill: #313131;
}

*[id^="reserve"] .reserve-slider_head p.form_check input {
  display: none;
}

*[id^="reserve"] .reserve-slider_head p.form_check input+label {
  border: none;
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  cursor: pointer;
}

*[id^="reserve"] .reserve-slider_head p.form_check input+label::after {
  content: "";
  position: absolute;
  top: 13% !important;
  left: 30% !important;
  display: block;
  width: 15px !important;
  height: 19px !important;
  border-bottom: 4px solid #e5e5e5;
  border-right: 4px solid #e5e5e5;
  box-sizing: border-box;
  transform: rotate(45deg) !important;
  background-image: none !important;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_head p.form_check input+label::after {
	top: 30% !important;
	left: 38% !important;
	width: 8px !important;
	height: 12px !important;
	border-bottom: 3px solid #e5e5e5 !important;
	border-right: 3px solid #e5e5e5 !important;
  }
}

*[id^="reserve"] .reserve-slider_head p.form_check input:checked+label {
  background: #886c3d;
}

*[id^="reserve"] .reserve-slider_head p.form_check input:checked+label::after {
  border-color: white;
}

*[id^="reserve"] .reserve-slider_foot h4 {
  font-size: 16px;
  text-align: center;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-slider_foot h4 {
	text-align: left;
  }
}

*[id^="reserve"] .reserve-slider img {
  max-width: 100%;
}

*[id^="reserve"] .reserve-confirm {
  padding: 40px 0 60px;
  line-height: 1.5em;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm {
	font-size: 13px;
	padding: 30px 0 40px;
  }
}

*[id^="reserve"] .reserve-confirm:nth-of-type(n+2) {
  padding: 60px 0;
  border-top: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm:nth-of-type(n+2) {
	padding: 50px 0;
	border-width: 1px;
  }
}

/*@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm:nth-of-type(2) {
	border-top: none;
  }
}*/

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm:last-of-type {
	padding-bottom: 0;
  }
}

*[id^="reserve"] .reserve-confirm h3 {
  text-align: left;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm h3 {
	font-size: 13px;
	font-weight: 600;
  }
}

*[id^="reserve"] .reserve-confirm a {
  margin-left: 2em;
  color: #878787;
  text-decoration: underline;
}

@media screen and (min-width: 751px),
print {
  *[id^="reserve"] .reserve-confirm a.for_pc {
	display: inline-block !important;
  }
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm a.for_sp {
	display: inline-block !important;
  }
}

*[id^="reserve"] .reserve-confirm>dl {
  margin-top: 40px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm>dl {
	margin-top: 20px;
  }
}

*[id^="reserve"] .reserve-confirm>dl dt {
  color: #878787;
}

*[id^="reserve"] .reserve-confirm .col>dl {
  margin-top: 40px;
}

@media screen and (min-width: 751px),
print {
  *[id^="reserve"] .reserve-confirm .col>dl {
	width: 266px;
  }
  *[id^="reserve"] .reserve-confirm .col>dl:nth-of-type(2n-1) {
	float: left;
  }
  *[id^="reserve"] .reserve-confirm .col>dl:nth-of-type(2n) {
	float: right;
  }
}

*[id^="reserve"] .reserve-confirm .col>dl dt {
  color: #878787;
}

*[id^="reserve"] .reserve-confirm .col>dl dd img {
  display: block;
  margin: 10px 0;
  width: 100%;
}

*[id^="reserve"] .reserve-confirm_box {
  margin-top: 40px;
  padding: 40px;
  font-size: 18px;
  line-height: 1.5em;
  border: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm_box {
	margin-top: 20px;
	padding: 20px;
	font-size: 13px;
	border-width: 1px;
  }
}

*[id^="reserve"] .reserve-confirm_box h4 {
  font-weight: 600;
}

*[id^="reserve"] .reserve-confirm_box dl {
  display: table;
  padding: 0 0 12px;
  margin: 0 0 12px;
  width: 100%;
}

*[id^="reserve"] .reserve-confirm_box dl:nth-last-of-type(n+2) {
  border-bottom: 2px solid #e5e5e5;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-confirm_box dl:nth-last-of-type(n+2) {
	border-width: 1px;
  }
}

*[id^="reserve"] .reserve-confirm_box dl:last-of-type {
  padding: 0;
  margin: 0;
}

*[id^="reserve"] .reserve-confirm_box dl dt,
*[id^="reserve"] .reserve-confirm_box dl dd {
  display: table-cell;
}

*[id^="reserve"] .reserve-confirm_box dl dd {
  text-align: right;
}

*[id^="reserve"] .reserve-confirm_box span {
  font-weight: 600;
}

*[id^="reserve"] .reserve-confirm_btn {
  margin-top: 20px !important;
}

*[id^="reserve"] .slick-slider {
  margin-bottom: 20px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .slick-slider {
	margin-bottom: 4px;
  }
}

*[id^="reserve"] .slick-dots {
  position: absolute;
  bottom: -60px;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .slick-dots {
	bottom: -24px;
	text-align: right;
  }
}

*[id^="reserve"] .slick-dots li {
  width: auto;
  height: auto;
  margin: 0 8px;
  padding: 0;
  opacity: .2;
  cursor: pointer;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .slick-dots li {
	margin: 0 6px;
  }
}

*[id^="reserve"] .slick-dots li button {
  padding: 0;
  width: 6px;
  height: 6px;
  background: #313131;
  border-radius: 50%;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .slick-dots li button {
	width: 5px;
	height: 5px;
  }
}

*[id^="reserve"] .slick-dots li button::before {
  display: none;
}

*[id^="reserve"] .slick-dots li.slick-active {
  opacity: 1;
}

*[id^="reserve"] .slick-arrow {
  position: absolute;
  top: auto;
  bottom: -57px;
  z-index: 9;
  width: 10px;
  height: 10px;
  border-width: 0;
  border-style: solid;
  border-color: #313131;
  transform: rotate(45deg);
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .slick-arrow {
	display: none !important;
  }
}

*[id^="reserve"] .slick-arrow::before {
  display: none;
}

*[id^="reserve"] .slick-prev {
  left: 23%;
  border-bottom-width: 2px;
  border-left-width: 2px;
}

*[id^="reserve"] .slick-next {
  right: 23%;
  border-top-width: 2px;
  border-right-width: 2px;
}

-complete h2 {
  line-height: 1.5em;
}

-complete .reserve-btn .btn {
  margin-top: 0;
}

@media screen and (max-width: 750px) {
  -complete .reserve-btn .btn+.btn {
	margin-top: 15px;
  }
}

.js-hidden {
  transition: max-height 0.8s ease;
  max-height: 0;
  overflow: hidden;
}

.js-hidden.on {
  max-height: 10000px;
}

.modal-box h2 span {
  margin-right: 10px;
}

@media screen and (max-width: 320px),
/*

common

*/

.contentsAnime {
  transform: translateY(40px);
  opacity: 0;
  transition: opacity 1s ease, transform 0.8s ease;
}

.contentsAnime.on {
  opacity: 1;
  transform: translate(0);
}

.delay1 {
  transition-delay: 0.1s !important;
}

.delay2 {
  transition-delay: 0.2s !important;
}

.delay3 {
  transition-delay: 0.3s !important;
}

.delay4 {
  transition-delay: 0.4s !important;
}

.delay5 {
  transition-delay: 0.5s !important;
}

.delay6 {
  transition-delay: 0.6s !important;
}

.progressbar {
  width: 0;
  height: 1px;
  background: #8b8b8b;
  position: fixed;
  top: 50%;
  left: 0;
  transition: width 0.8s cubic-bezier(0.47, 0, 0.745, 0.715);
}

.progressbar.on {
  width: 100%;
}

.j_sans,
*[id^="reserve"] .reserve-info p a,
*[id^="reserve"] .reserve-slider_foot h4,
*[id^="reserve"] .reserve-confirm .col>dl dd span {
  font-family: 'Josefin Sans', sans-serif;
  font-weight: bold;
}

.oxygen,
.reserve-time table th,
#calendar.fc .fc-day-number,
#calendar .fc-content-skeleton .fc-today::after {
  font-family: 'Oxygen', sans-serif;
}

.mincho {
  font-family: "游明朝 Light", "游明朝", "YuMincho", "Yu Mincho", "ヒラギノ明朝 ProN W6", "HiraMinProN-W6", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}

input,
button,
textarea {
	margin: 0;
	padding: 0;
	background: none;
/*  border: none;*/
	border: #fff;
	border-radius: 0;
	outline: none;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
}
select {
	-webkit-appearance: none;/* ベンダープレフィックス(Google Chrome、Safari用) */
	-moz-appearance: none; /* ベンダープレフィックス(Firefox用) */
	appearance: none; /* 標準のスタイルを無効にする */
	
	position: relative;
	z-index: 9;
	display: block;
	/*width: 130%;*/
	height: 60px;
	border: 3px solid #313131;
	box-sizing: border-box;
	font-size: 16px;
	color: #000000;
	font-weight: 700;
	line-height: 54px;
	padding: 0 0.3em;
	margin-bottom: 20px;

	background-color: #ffffff;
	background-image: url(../img/down.svg);
	background-position: right 7px center;
	background-repeat: no-repeat;
	background-size: 13px 13px;
}

.select_form_year{
	padding: 0 1.1em 0 0.1em;
}

p.attention{
  font-size: 12px;
  color:#d9534f;
  line-height: 1.7em;
  font-weight: lighter;
  margin-top:5px;
}

.gray {
	color: #878787 !important;
	font-size: 15px;
}

html {
	color: #313131;
}


/* ▼スマホ */
@media screen and (max-width: 750px) {
	select{
		border: 2px solid #313131;
		line-height: 44px;
		height: 44px;
	}
}


@keyframes menu_on2 {
  0% {
	transform: skew(15deg);
	opacity: 0.4;
  }
  100% {
	transform: skew(0deg);
	opacity: 1;
  }
}

@media screen and (min-width: 751px),
print {
  .hover_border {
	position: relative;
  }
  .hover_border:hover:before {
	right: 0;
  }
  .hover_border:before {
	content: "";
	position: absolute;
	z-index: -1;
	left: 0;
	right: 100%;
	bottom: -3px;
	background: #313131;
	height: 1px;
	transition: right 0.4s cubic-bezier(0.77, 0, 0.175, 1);
  }
  .hover_border.gray:before {
	background: #878787;
  }
  .btn_hover {
	position: relative;
	display: block;
	overflow: hidden;
	transition: 0.5s ease-in-out;
	z-index: 0;
  }
  input[type="submit"]:hover .btn_hover:after {
	transform: translateX(0);
  }
  .btn_hover input[type="submit"]:hover {
	cursor: pointer;
/*	color: #fff;*/
color: #886c3d;
	background: transparent;
  }
  input[type="submit"] .btn_hover {
	position: relative;
	display: block;
	overflow: hidden;
	transition: 0.5s ease-in-out;
	z-index: 0;
  }
  input[type="submit"] .btn_hover:after {
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: #313131;
	transform: translateX(-101%);
	transition: 0.4s ease-in-out;
	z-index: -1;
  }
  input[type="submit"] .btn_hover:hover {
	color: #fff;
	background: transparent;
  }
  input[type="submit"] .btn_hover:hover:after {
	transform: translateX(0);
  }
  .btn_hover path,
  .btn_hover polygon {
	transition: 0.5s ease-in-out;
	fill: #313131;
  }
  .btn_hover:after {
	content: '';
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0;
	left: 0;
	background-color: #886c3d;
	transform: translateX(-101%);
	transition: 0.4s ease-in-out;
	z-index: -1;
  }
  .btn_hover:hover {
	color: #fff;
	background: transparent;
	cursor: pointer;
  }
  .btn_hover:hover:after {
	transform: translateX(0);
  }
  .btn_hover:hover path,
  .btn_hover:hover polygon {
	fill: #fff;
  }
  .btn_hover_black:after {
	background-color: #fff;
  }
  .btn_hover_black:hover {
	color: #313131;
	background: transparent;
  }
  html {
	background: #fff;
  }
  .for_sp {
	display: none !important;
  }
  .for_pc {
	display: block !important;
  }

  .pankuzu {
	position: fixed;
	right: 4px;
	top: 0;
	z-index: 2;
	font-size: 10px;
	transform: rotate(-90deg) translateY(30px);
	transform-origin: right bottom;
	line-height: 10px;
	width: 100vh;
	text-align: center;
	letter-spacing: 0.16em;
	/*transition: transform 0.4s cubic-bezier(0.25, 0.46, 0.45, 0.94) 0.8s, opacity 0.3s ease 0.8s;*/
	opacity: 0;
  }
  .pankuzu.on {
	opacity: 1;
	transform: rotate(-90deg) translateY(0);
  }
  .btn {
	width: 170px;
	height: 54px;
	border: 3px solid #313131;
	box-sizing: border-box;
  }
  .btn a {
	display: block;
	width: 100%;
	line-height: 44px;
	font-size: 14px;
	letter-spacing: 0.14em;
	text-align: center;
	background: #fff;
	vertical-align: unset;
	padding-top: 4px;
  }

  .btn a.selected {
  color:#fff;
  background:#886c3d;
}

  .btn_black a {
	background: #313131;
	color: #fff;
  }
  .btn input[type="submit"] {
	display: block;
	width: 100%;
	line-height: 45px;
	font-size: 14px;
	letter-spacing: 0.14em;
	text-align: center;
	vertical-align: unset;
	padding-top: 3px;
	background: #fff;
	transition: 0.5s ease-in-out;
	font-weight: 600;
  }

}

*[id^="reserve"] .reserve-ttl {
  margin-bottom: 30px;
  text-align: center;
  font-size: 32px;
  font-weight: 600;
  letter-spacing: 0.2em;
}

@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-ttl {
	font-size: 14px;
  }
}

@media screen and (max-width: 750px) {
  .for_sp {
	display: block !important;
  }
  .for_pc {
	display: none !important;
  }
  header {
	background: #fff;
	width: 100%;
	display: flex;
	justify-content: space-between;
	padding: 14px 0;
	position: fixed;
	top: 0;
	left: 0;
	z-index: 2;
  }
  /* 200422修正作業 */
  header .logo {
	/*margin-left: 10px;*/
  }
  header .logo a {
	display: block;
	/*height: 16px;*/
  }
  header .logo img {
	/*height: 10px;*/
	width: auto;
	/*margin-top: 4px;*/
  }

  .btn {
	width: 185px;
	height: 42px;
	border: 2px solid #313131;
	box-sizing: border-box;
	margin: 0 auto;
  }
  .btn a {
	display: block;
	width: 100%;
	line-height: 34px;
	font-size: 12px;
	letter-spacing: 0.14em;
	text-align: center;
	background: #fff;
	padding-top: 4px;
	font-weight: 600;
  }
  .btn_black a {
	background: #313131;
	color: #fff;
  }
  .btn input[type="submit"] {
	display: block;
	width: 100%;
	line-height: 36px;
	font-size: 12px;
	letter-spacing: 0.14em;
	text-align: center;
	background: #fff;
	padding-top: 2px;
	font-weight: 600;
  }
  .pankuzu {
	margin: 30px 10px 10px;
	font-size: 9px;
	line-height: 9px;
	letter-spacing: 0.16em;
  }


}
/*reserve*/
@media screen and (min-width: 751px), print{
  .cssinfomation{
	   font-size: 14px;
	   margin-top: 35px;
  }

  .cssinfomation p{
	  letter-spacing: 0.01em;
	  line-height: 18px;
	  text-align: center;
  }

  .under_page .box_area, .remodal .box_area {
	  padding: 60px 115px;
  }
}
@media screen and (max-width: 750px) {
  *[id^="reserve"] .reserve-box h2{
	margin-bottom: 6px;
  }

}

.cssBTN_DBL{
	display: -webkit-flex;
	display: flex;
	-webkit-justify-content: space-around;
	justify-content: space-around;
}

@media screen and (min-width: 751px),
print {
  .reserve-btn .btn button {
	padding: 16px 0 12px;
	font-size: 16px;
	font-weight: 600;
	height: 100%;
	line-height: 1.5em;
  }
  .btn button {
	display: block;
	width: 100%;
	line-height: 44px;
	font-size: 14px;
	letter-spacing: 0.14em;
	text-align: center;
	background: #fff;
	vertical-align: unset;
	padding-top: 4px;
  }
  .btn button::after {
  	background: #f18a83;
  }

}

.css_TOP {
	margin: 20px auto;
}
/******************choco ログイン *********************************/
.cssLOGIN {
    font-size: x-large;
    text-align: center;
}

img[class="cssLOGIN_IMG"]{
    width: 45px;
    height: auto;
    margin-bottom: 10px;
}


input[id^="ID_姓"],
input[id^="ID_名"] {
	width: 30%;
}

input[id^="ID_性別"] {
	position: relative;
	width: 100%;
	overflow: hidden;
	cursor: pointer;
}

/******************choco HP *********************************/


@media only screen and (min-width: 920px) {
	ul.photo_gallery{
		max-width: 100%;
	}
}

/* 連絡者情報 */
.cssCAMPAIGN{
	display: -webkit-flex;
	display: flex;
	-webkit-align-items: center;
	align-items: center;
}

.css無効{
	border: none!important;
	cursor: default!important;
	pointer-events: none;
}


/*** ▼共通CSS　****/
.FS012{ font-size: 12px; }

.FW500{ font-weight: 500!important; }

.MT0{ margin-top: 0px!important; }
.MT015{ margin-top: 15px; }
.MT030{ margin-top: 30px; }


.MB0{ margin-bottom: 0px!important; }
.MB010{ margin-bottom: 10px; }
.MB015{ margin-bottom: 15px; }
.MB020{ margin-bottom: 20px; }
.MB030{ margin-bottom: 30px; }

.ML0{ margin-left: 0px!important; }


.PB015{ padding-bottom: 15px; }
.PB030{ padding-bottom: 30px; }

.WD0100{ width: 100px;}
.WD0120{ width: 120px;}

.DP_FLEX{
	display: flex;
	align-items: center;
}
