@charset "UTF-8";

/*
▼カラー
	ヘッダー・フッター：hsl(0,0%,97%)
	ラベル：hsl(219,100%,97%)
	h2ライン：hsl(204,70%,53%)
	個人情報背景：hsl(0,0%,97%)
▼画像URL
	../image
*/
* {
	letter-spacing: 0;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}

html {
	-webkit-text-size-adjust: 100%;
}

body {
	font-size: 18px;
	font-family: 'Hiragino Kaku Gothic ProN', 'Meiryo', 'MS P Gothic', sans-serif;
	line-height: 1.6;
	text-align: left;
}

img {
	max-width: 100%;
	height: auto;
	display: block;
	margin: 0 auto;
	padding: 0;
}

.red {
	color: red;
}

.form .pc {
	display: none;
}

.form .mobile {
	display: block;
}


/*mailformproデフォルト*/
body {
	overflow-x: hidden;
}

div#mfp_hidden {
	overflow: hidden;
	width: 1px;
	height: 1px;
	padding: 0px;
	margin: 0px;
}

div#mfp_hidden input {
	margin: 10px;
}

div.mfp_thanks {
	padding: 30px;
}

div.mfp_thanks p {
	line-height: 1.7em;
}

div.mfp_thanks ul.mfp_caution {
	margin: 0px;
	padding: 0px;
}

div.mfp_thanks ul.mfp_caution li {
	display: block;
	color: #C00;
	margin: 0px;
	padding: 5px 0px;
}

div#mfp_thanks {
	text-align: center;
	font-size: 18px;
	padding: 20px 0px;
}

div#mfp_thanks strong {
	color: #C00;
	font-size: 24px;
}

form#mailformpro dl dd ul,
form#mailformpro dl dd ol {
	margin: 0px;
	padding: 0px;
}

form#mailformpro dl dd ul li,
form#mailformpro dl dd ol li {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

.optionally {
	display: block;
	background-color: #06C;
	border: solid 2px #06C;
	text-shadow: 0px 1px 2px #933;
	padding: 2px 5px;
	font-size: 10px;
	color: #FFF;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
	background-image: url(../image/header.png);
	background-size: 100% 100%;
}

form#mailformpro label {
	border-radius: 3px;
	margin: 3px;
	display: inline-block;
	white-space: nowrap;
}

form#mailformpro label.mfp_checked {
	padding: 3px;
	border: solid 1px #CCC;
	background-color: #E8EEF9;
	box-shadow: 0px 1px 3px #CCC inset;
}

form#mailformpro label.mfp_not_checked {
	padding: 3px;
	border: solid 1px #EEE;
}

table#mfp_confirm_table {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}

table#mfp_confirm_table tr.mfp_colored {
	background-color: #F6F7F9;
}

table#mfp_confirm_table tr.mfp_achroma {
	background-color: #FFF;
}

table#mfp_confirm_table tr th,
table#mfp_confirm_table tr td {
	text-align: left;
	font-size: 12px;
	border-top: solid 1px #CCC;
	padding: 5px 10px;
}

table#mfp_confirm_table tr th {
	white-space: nowrap;
	width: 200px;
}

div#mfp_phase_confirm {
	clear: both;
}

div#mfp_phase_confirm h4 {
	font-size: 36px;
	padding: 10px 0px 0px 0px;
	text-align: center;
}

div#mfp_overlay {
	position: absolute;
	display: none;
	z-index: 10001;
}

div#mfp_overlay_inner {
	background-color: #FFF;
	padding: 15px;
	margin: 0px auto;
	border-radius: 5px;
	box-shadow: 0px 0px 10px #000;
	width: 640px;
	max-width: 90%;
}

div#mfp_overlay_background {
	background-color: #000;
	position: absolute;
	display: none;
	z-index: 10000;
}

div#mfp_loading_screen {
	z-index: 20000;
	opacity: 0.8;
	display: none;
	background-color: #000;
	position: absolute;
}

div#mfp_loading {
	z-index: 20001;
	position: absolute;
	display: none;
	width: 40px;
	height: 40px;
	background-image: url(../image/mfp_loading.gif);
}

/*.mfp_colored {
	background-color: #F6F7F9;
}*/
.mfp_achroma {
	background-color: #FFF;
}

div.mfp_err {
	clear: both;
	display: none;
	text-align: left;
	margin: 5px 0px 0px 0px;
	padding: 3px 0px 5px 17px;
	color: #F00;
	font-size: 12px;
	line-height: normal;
	background-image: url(../image/mfp_error.gif);
	background-repeat: no-repeat;
	background-position: 0px 1px;
}

.mfp_parent_error {
	border: solid 2px #F00;
}

.problem {
	background-color: #FCC;
}

div#mfp_error {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
}

div#mfp_error p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}

div#mfp_error p strong {
	font-size: 18px;
	color: #F00;
}

div#mfp_warning {
	background-color: #FEE;
	border: solid 1px #F00;
	padding: 10px;
	display: none;
}

div#mfp_warning p {
	padding: 0px;
	margin: 0px;
	font-size: 14px;
	text-align: center;
}

div#mfp_warning p strong {
	font-size: 18px;
	color: #F00;
}

div#mfp_price {
	color: #C00;
	font-size: 36px;
	padding: 10px;
	font-weight: bolder;
}

div#mfp_price span {
	color: #666;
	font-size: 12px;
	font-weight: normal;
}

/*
ul#mfp_phase_stat {
	padding: 10px;
}
ul#mfp_phase_stat li {
	float: left;
	padding: 8px 15px;
	border-radius: 3px;
	margin: 5px;
	list-style: none;
	font-size: 14px;
}
ul#mfp_phase_stat li.mfp_phase_arrow {
	box-shadow: none;
	padding: 8px 5px;
}
ul#mfp_phase_stat li.mfp_active_phase {
	background-color: #E8EEF9;
	box-shadow: 0px 0px 5px #000;
}
ul#mfp_phase_stat li.mfp_inactive_phase {
	background-color: #CCC;
	color: #666;
	box-shadow: 0px 0px 5px #CCC;
}
*/
div#mfp_shopping_cart {
	border: solid 1px #CCC;
	margin: 0px;
	padding: 0px;
}

div#mfp_shopping_cart p {
	margin: 0px;
	text-align: center;
	padding: 20px 10px;
	font-size: 12px;
	background-color: #FEE;
}

table.mfp_shoppingcart {
	border-spacing: 0px;
	border-collapse: collapse;
	width: 100%;
}

table.mfp_shoppingcart thead tr td {
	background-color: #EEE;
	border-bottom: solid 1px #CCC;
	text-align: center;
	font-size: 12px;
	padding: 5px;
}

table.mfp_shoppingcart tbody tr th,
table.mfp_shoppingcart tbody tr td {
	font-size: 12px;
	padding: 5px;
	border-bottom: solid 1px #CCC;
}

table.mfp_shoppingcart tbody tr td select {
	display: block;
	margin: 0px auto;
	text-align: center;
}

table.mfp_shoppingcart tbody tr td select option {
	text-align: center;
}

table.mfp_shoppingcart tbody tr th span {
	display: block;
	font-weight: normal;
	font-size: 10px;
	color: #666;
	padding: 3px 0px;
}

table.mfp_shoppingcart tfoot tr td {
	padding: 5px;
	font-size: 16px;
	font-weight: bolder;
	color: #900;
}

td.msc_price {
	font-size: 12px;
	text-align: right;
}

div.mfp_buttons {
	clear: both;
	padding: 10px 0px;
	text-align: center;
}

div.mfp_buttons button#mfp_button_cancel {}

.imagebutton {
	margin: 0px;
	padding: 0px;
	border: none;
	outline: none;
	background: none;
}

.mfp_element_all {
	max-width: 90%;
}

.mfp_element_text,
.mfp_element_number,
.mfp_element_select-one,
.mfp_element_email,
.mfp_element_tel,
.mfp_element_textarea,
.mfp_element_date {
	border: solid 1px #CCC;
	border-radius: 3px;
	box-shadow: 0px 0px 5px #CCC inset;
	padding: 3px 8px;
	margin: 2px;
	vertical-align: middle;
}

.mfp_element_checkbox,
.mfp_element_radio {
	vertical-align: middle;
	margin: 0px 2px;
}

.mfp_element_reset,
.mfp_element_button {
	border-radius: 5px;
	padding: 5px 10px;
	border: solid 1px #CCC;
	background: gradient(linear, center top, center bottom, from(#FEFEFE), to(#DEDEDE));
	background: -webkit-gradient(linear, center top, center bottom, from(#FEFEFE), to(#DEDEDE));
	background: -moz-linear-gradient(top, #FEFEFE, #DEDEDE);
	background: -ms-linear-gradient(top, #FEFEFE 0%, #DEDEDE 100%);
	text-shadow: 0px 2px 0px #FFF;
	font-size: 24px;
	cursor: pointer;
	outline: none;
}

.mfp_element_reset {
	color: #333;
}

input#mfp_reserve_item,
input#mfp_reserve_date {
	display: none;
}

div#mfp_reserve_wrapper {
	position: relative;
	overflow: hidden;
	border: solid 1px #CCC;
}

/*
div#mfp_reserve_inner {
	position: relative;
	padding: 0px 0px 0px 100px;
	overflow: auto;
}
*/
div#mfp_reserve_wrapper table {
	border-spacing: 0px;
	border-collapse: collapse;
}

/*
div#mfp_reserve_wrapper table.mfp_reserve_table_label {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 100px;
	background-color: #FEE;
	z-index: 100;
}
*/
div#mfp_reserve_wrapper table.mfp_reserve_table_value {
	padding: 0px 0px 0px 0px;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning {
	cursor: pointer;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_active:hover,
div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_warning:hover {
	background-color: #E8EEF9;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_value tr td.mfp_reserve_current {
	background-color: #0068B7;
	color: #FFF;
}

td.mfp_reserve_warning {
	background-color: #FFC;
}

/*
div#mfp_reserve_wrapper table tr td,div#mfp_reserve_wrapper table tr th {
	border: solid 1px #CCC;
	padding: 0px 5px;
	font-size: 12px;
	text-align: center;
	font-family: Osaka,"ＭＳ Ｐゴシック","MS PGothic",Sans-Serif;
	font-weight: normal;
	height: 20px;
	text-align: left;
}
*/
td.mfp_reserve_week_0 {
	color: #F00;
	background-color: #FEE;
}

td.mfp_reserve_week_6 {
	color: #00F;
	background-color: #EEF;
}

div.mfp_ok {
	border-radius: 5px;
	background-color: #090;
	border: solid 1px #090;
	display: inline-block;
	line-height: 1.5em;
	padding: 0px 5px;
	margin: 0px 2px;
	color: #FFF;
	font-size: 10px;
	background-image: url(images/header.png);
	background-size: 100% 100%;
	display: none;
}

div.prefcodeWrapper {
	position: relative;
}

div.prefcodeResult {
	position: absolute;
	top: 0px;
	left: 0px;
	padding: 5px;
	border: solid 1px #CCC;
	background-color: #FFF;
	box-shadow: 0px 0px 5px #CCC;
	display: none;
}

div.prefcodeResult div {
	cursor: pointer;
}

div.prefcodeResult div:hover {
	background-color: #C9EBFB;
}

div.prefcodeResult div.prefcodeNext {
	background-color: #EEE;
	text-align: center;
}

div.prefLoading {
	padding: 60px 100px;
	background: url(images/mfp_zip_loading.gif) no-repeat center center;
}

.hidefield {
	height: 0px;
	overflow: hidden;
}

.showfield {
	height: auto;
	overflow: visible;
}

/*エントリーフォーム*/
.fo1 {
	width: 1em;
}

.fo2 {
	width: 2em;
}

.fo3 {
	width: 3em;
}

.fo4 {
	width: 4em;
}

.fo5 {
	width: 5em;
}

.fo6 {
	width: 6em;
}

.fo7 {
	width: 7em;
}

.fo8 {
	width: 8em;
}

.fo9 {
	width: 9em;
}

.fo10 {
	width: 10em;
}

.fo11 {
	width: 11em;
}

.fo12 {
	width: 12em;
}

.fo13 {
	width: 13em;
}

.fo14 {
	width: 14em;
}

.fo15 {
	width: 15em;
}

.fo20 {
	width: 20em;
}

.fo25 {
	width: 25em;
}

textarea {
	min-height: 150px;
	max-height: 200px;
}

.form-container {
	clear: both;
}

.form #form-container form {
	width: 100%;
}

form#mailformpro p {
	padding: 10px;
}

form#mailformpro dl dd span.nowrap {
	white-space: nowrap;
}

form#mailformpro label {
	white-space: normal;
}

form#mailformpro dl dd span.eg {
	white-space: nowrap;
	color: #666;
}

form#mailformpro dl dd ul.caution {
	list-style: none;
	color: #666;
	font-size: 0.95rem;
	margin-left: 2rem;
}

form#mailformpro dl dd ul.caution li:before {
	content: "※";
	margin-left: -1rem;
	color: hsl(13, 58%, 49%);
}

form#mailformpro dl dd.no-ok .mfp_ok {
	display: none !important;
}

/*mailformpro変更*/
form#mailformpro {
	padding: 10px 0 30px 0;
}

form#mailformpro dl {
	display: table;
	width: 100%;
}

form#mailformpro dl dt {
	float: none;
	margin: 0px;
	display: table-cell;
	width: 25%;
	clear: both;
	padding: 10px;
	text-align: right;
	border-top: solid 1px #CCC;
	margin: 0px;
}

form#mailformpro dl dd {
	display: table-cell;
	border-top: solid 1px #CCC;
	margin: 0px;
	padding: 10px;
	line-height: 1.5em;
	text-align: left;
}

form#mailformpro dl dd:hover {
	background: #FFD3E1;
}

#form-header {
	border-bottom: 1px solid #ccc;
	padding: 10px 0;
	margin-bottom: 15px;
	background: hsl(0, 0%, 97%);
}

#form-header ul.form-container {
	display: table;
}

#form-header ul.form-container li {
	display: table-cell;
	vertical-align: bottom;
}

#form-header ul.form-container li.logo {
	width: 200px;
	height: auto;
}

#form-header ul.form-container li.page-title {
	padding-left: 20px;
	font-size: 0.95rem;
}

#top-message {
	font-size: 0.9rem;
}

#top-message>p {
	margin-bottom: 20px;
}

#top-message .box {
	margin-bottom: 20px;
}

#top-message .box h2 {
	font-weight: bold;
	font-size: 1.1rem;
	position: relative;
	padding-bottom: .2em;
	border-bottom: 2px solid #ccc;
}

#top-message .box h2::after {
	position: absolute;
	bottom: -2px;
	left: 0;
	z-index: 2;
	content: '';
	width: 20%;
	height: 2px;
	background-color: hsl(204, 70%, 53%);
}

#top-message .box.tel a {
	font-weight: bold;
	font-size: 1.5rem;
}

#top-message .box div,
#top-message .box ul {
	margin: 5px 0 0 10px;
}

#top-message .box ul li {
	list-style: disc;
	margin-left: 15px;
}

#top-message .box ol li {
	list-style: decimal;
	margin-left: 30px;
}

#form-footer {
	background: hsl(0, 0%, 97%);
	font-size: 0.9rem;
	border-top: 1px solid #ccc;
}

#form-footer ul.com {
	text-align: center;
	padding: 10px 0;
}

#form-footer ul.com li {
	display: inline-block;
}

#form-footer ul.com li:nth-child(2) {
	margin: 0 5px 0 15px;
}

form#mailformpro dl.last {
	border-bottom: solid 1px #CCC;
}

div#mfp_reserve_inner {
	position: relative;
	padding: 0px 0px 0px 75px;
	overflow: auto;
}

div#mfp_reserve_wrapper table.mfp_reserve_table_label {
	position: absolute;
	top: 0px;
	left: 0px;
	width: 75px;
	background-color: #FEE;
	z-index: 100;
}

div#mfp_reserve_wrapper table tr td,
div#mfp_reserve_wrapper table tr th {
	border: solid 1px #CCC;
	padding: 5px 10px;
	font-size: 15px;
	text-align: center;
	font-family: Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	font-weight: normal;
	height: 20px;
	text-align: left;
}

/*フォーカス時の背景色変更*/
input:focus {
	background: hsl(194, 79%, 83%);
}

textarea:focus {
	background: hsl(194, 79%, 83%);
}

/*予約ステップバー*/
#mfp_phase_stat {
	display: none;
}

/*他ファイル変更*/
.mfp_colored {
	background-color: transparent;
}

.mfp_achroma {
	background-color: transparent;
}

/*任意ボタン*/
form#mailformpro .option {
	display: block;
	background-color: #fff;
	border: solid 1px #ccc;
	text-shadow: 0px 1px 2px #ccc;
	padding: 2px 5px;
	font-size: 12px;
	color: #444;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
	background-size: 100% 100%;
}

/*必須ボタン*/
form#mailformpro .must {
	display: block;
	background-color: #C00;
	text-shadow: 0px 1px 2px #933;
	padding: 2px 5px;
	font-size: 12px;
	color: #FFF;
	float: left;
	margin: 0px 5px;
	border-radius: 4px;
	box-shadow: 0px 0px 5px #CCC;
}

/*任意項目アコーディオン*/
div.form-accordion {
	width: 100%;
	margin: 20px 0;
}

div.form-accordion .title {
	font-size: 0.9rem;
}

div.form-accordion>ul>li>a {
	display: block;
	color: #0000ff;
	font-size: 0.95rem;
	text-decoration: underline;
	cursor: pointer;
	padding: 10px 12px;
}

div.form-accordion>ul>li>a,
div.form-accordion>ul>li>a:after,
div.form-accordion>ul>li>a.active:after,
div.form-accordion>ul>li>a:before,
div.form-accordion>ul>li>a.active:before {
	color: #0000ff;
}

div.form-accordion>ul>li>a:hover,
div.form-accordion>ul>li>a:hover:after,
div.form-accordion>ul>li>a.active:hover:after,
div.form-accordion>ul>li>a:hover:before,
div.form-accordion>ul>li>a.active:hover:before {
	color: red;
}

div.form-accordion>ul>li>a:before {
	content: "\0025B6";
}

div.form-accordion>ul>li>a:after {
	content: "入力する";
}

div.form-accordion>ul>li>a.active:before {
	content: "\0025BC";
}

div.form-accordion>ul>li>a.active:after {
	content: "閉じる";
}

div.form-accordion>ul>li>ul {
	display: none;
}

/*プライバシーポリシー*/
#pp-box {
	margin: 15px auto;
	border: 1px solid red;
	font-size: 13px;
	padding: 10px 15px;
	width: 95%;
	background: hsl(0, 0%, 97%);
}

/*確認画面へのボタン*/
button.mfp_next,
button.mfp_prev {
	margin: 10px;
}

button.mfp_next {
	float: right;
}

button.mfp_prev {
	float: left;
}

.mfp_element_submit,
button.mfp_next {
	border-radius: 5px;
	padding: 10px 20px;
	border: solid 1px #eb6100;
	background: gradient(linear, center top, center bottom, from(#fccdad), to(#FE9800));
	background: -webkit-gradient(linear, center top, center bottom, from(#fccdad), to(#FE9800));
	background: -moz-linear-gradient(top, #fccdad, #FE9800);
	background: -ms-linear-gradient(top, #fccdad 0%, #FE9800 100%);
	text-shadow: 0px 1px 0px #333;
	box-shadow: 0px 2px 10px #999;
	font-size: 24px;
	cursor: pointer;
	outline: none;
	color: #fff;
}

.mfp_element_submit:hover,
.mfp_element_reset:hover,
.mfp_element_button:hover,
button.mfp_next:hover {
	background: gradient(linear, center top, center bottom, from(#F7F7F7), to(#7ECEF4));
	background: -webkit-gradient(linear, center top, center bottom, from(#F7F7F7), to(#7ECEF4));
	background: -moz-linear-gradient(top, #F7F7F7, #7ECEF4);
	background: -ms-linear-gradient(top, #F7F7F7 0%, #7ECEF4 100%);
	box-shadow: 0px 2px 15px #7ECEF4;
	border: solid 1px #0375ab;
	text-shadow: 0px 2px 0px #0375ab;
}

/*前のページに戻るボタン*/
button.mfp_prev {
	font-size: 10px;
	border-radius: none;
	padding: 5px 10px;
	border: none;
	background: none;
	text-shadow: none;
	font-size: 15px;
	cursor: pointer;
	outline: none;
	text-decoration: underline;
}

button.mfp_prev:hover {
	background: none;
	box-shadow: none;
}

/*送信エラー発生時*/
.mfp_element_submit:disabled {
	border-radius: 5px;
	padding: 10px 20px;
	border: solid 1px #666;
	background: #ccc;
	text-shadow: 0px 1px 0px #666;
	box-shadow: none;
	font-size: 24px;
	cursor: default;
	outline: none;
	color: #fff;
}

.mfp_element_submit:disabled:before {
	content: url(../image/button-caution.png);
	padding-right: 10px;
}

.mfp_element_submit:disabled:hover,
.mfp_element_reset:disabled:hover,
.mfp_element_button:disabled:hover {
	background: #ccc;
	box-shadow: none;
	border: solid 1px #666;
	text-shadow: 0px 1px 0px #666;
	cursor: default;
}

/*確認画面*/
.mfp_element_button#mfp_button_send {
	border-radius: 5px;
	padding: 10px 20px;
	border: solid 1px #eb6100;
	background: gradient(linear, center top, center bottom, from(#fccdad), to(#FE9800));
	background: -webkit-gradient(linear, center top, center bottom, from(#fccdad), to(#FE9800));
	background: -moz-linear-gradient(top, #fccdad, #FE9800);
	background: -ms-linear-gradient(top, #fccdad 0%, #FE9800 100%);
	text-shadow: 0px 1px 0px #333;
	box-shadow: none;
	font-size: 24px;
	cursor: pointer;
	outline: none;
	color: #fff;
}

.mfp_element_button#mfp_button_send:hover {
	border-radius: 5px;
	padding: 10px 20px;
	background: gradient(linear, center top, center bottom, from(#F7F7F7), to(#7ECEF4));
	background: -webkit-gradient(linear, center top, center bottom, from(#F7F7F7), to(#7ECEF4));
	background: -moz-linear-gradient(top, #F7F7F7, #7ECEF4);
	background: -ms-linear-gradient(top, #F7F7F7 0%, #7ECEF4 100%);
	border: solid 1px #0375ab;
	text-shadow: 0px 2px 0px #0375ab;
	box-shadow: none;
	font-size: 24px;
	cursor: pointer;
	outline: none;
	color: #fff;
}

.mfp_element_button#mfp_button_cancel {
	font-size: 10px;
	border-radius: none;
	padding: 5px 10px;
	border: none;
	background: none;
	text-shadow: none;
	font-size: 15px;
	cursor: pointer;
	outline: none;
	text-decoration: underline;
}

.mfp_element_button#mfp_button_cancel:hover {
	background: none;
	box-shadow: none;
}

div#mfp_overlay_inner .overlay-header {
	margin: 10px 30px;
}

div#mfp_overlay_inner .overlay-header img {
	display: inline;
	width: 30px;
	height: auto;
}

div#mfp_overlay_inner .overlay-title {
	padding-left: 10px;
	font-size: 23px;
}

div#mfp_overlay_inner p {
	text-align: left;
	font-size: 13px;
}

table#mfp_confirm_table tr td {
	line-height: 1.5em;
	word-break: break-all;
	font-size: 18px;
}


/* 点滅 */
div#mfp_overlay_inner .overlay-header img {
	-webkit-animation: blink 0.7s ease-in-out infinite alternate;
	-moz-animation: blink 0.7s ease-in-out infinite alternate;
	animation: blink 0.7s ease-in-out infinite alternate;
}

@-webkit-keyframes blink {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

@-moz-keyframes blink {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

@keyframes blink {
	0% {
		opacity: 0;
	}

	100% {
		opacity: 1;
	}
}

/*予約ページ*/
.reserve .top-caution {
	font-weight: bold;

}

.reserve .top-caution p {
	font-weight: normal;
	font-size: 0.95rem;
	padding: 0 1.5rem !important;
}

#mfp_reserve_wrapper {
	margin-bottom: 40px;
}

td.mfp_reserve_disabled {
	background-color: #efefef;
}

div#mfp_reserve_wrapper table tr td.mfp_reserve_disabled {
	border: solid 1px #efefef;
}

/*ジャッジID*/
.judge-id #check {
	display: inline;
}

.judge-id #check #judge-button {
	font-size: 1rem;
	margin-left: 10px;
}

.judge-id #status {}

.judge-id .eg-box {
	margin: -10px 0 30px 30px;
}

.judge-id .eg-box th {
	vertical-align: top;
	padding: 5px 0;
}

.judge-id .eg-box td {
	word-break: break-all;
	border: 1px solid #ccc;
	padding: 5px 15px;
}

/*金額計算*/
.hide-input {
	display: none;
}

.price {
	padding-bottom: 10px;
}

.price input {
	border: none;
	border-radius: 0;
	box-shadow: none;
	vertical-align: bottom;
	margin: 0 0 -10px 0;
	background-color: white;
	width: 8.5rem;
	color: #C00;
	font-size: 36px;
	font-weight: bolder;
}

.price span {
	color: #666;
	font-size: 12px;
	font-weight: normal;
}

@media all and (min-width: 641px) {
	.form-container {
		margin: 0 auto;
		width: 95%;
	}


	/*入力フォーム*/
	form#mailformpro dl dt,
	form#mailformpro dl dd {
		font-size: 18px;
	}

	/*ジャッジID*/
	.judge-id .eg-box th {
		padding: 5px 15px 5px 0;
	}

}

@media screen and (max-width: 800px) {
	form#mailformpro dl dt {
		float: none;
		width: auto;
		font-size: 12px;
		padding: 5px;
		text-align: left;
	}

	form#mailformpro dl dd {
		clear: both;
		border-top: none;
		padding: 5px 15px;
		font-size: 12px;
		line-height: 1.5em;
	}

	div.mfp_buttons button {
		font-size: 23px;
	}

	div#mfp_phase_confirm h4 {
		font-size: 18px;
	}

	ul#mfp_phase_stat {
		padding: 0px;
	}

	ul#mfp_phase_stat li {
		float: left;
		text-align: center;
		padding: 5px 0px;
		border-radius: 3px;
		margin: 5px;
		list-style: none;
		font-size: 14px;
		width: 28%;
	}

	ul#mfp_phase_stat li.mfp_phase_arrow {
		bos-shadow: none;
		display: none;
	}

	ul#mfp_phase_stat li.mfp_active_phase {
		background-color: #E8EEF9;
		box-shadow: 0px 0px 5px #000;
	}

	ul#mfp_phase_stat li.mfp_inactive_phase {
		background-color: #CCC;
		color: #666;
		box-shadow: 0px 0px 5px #CCC;
	}

	table#mfp_confirm_table tr th {
		white-space: nowrap;
		width: 100px;
	}

	div#mfp_thanks {
		text-align: center;
		font-size: 18px;
		padding: 20px 0px;
	}

	div#mfp_thanks strong {
		color: #C00;
		font-size: 24px;
		display: block;
	}
}



@media all and (min-width: 1024px) {
	.form .mobile {
		display: none;
	}

	.form .pc {
		display: block;
	}

	.form-container {
		width: 1004px;
	}

	.form .tel a {
		pointer-events: none;
		/*リンクを非リンクに変える*/
		cursor: default;
		/*マウスカーソルを矢印のまま変えない*/
		text-decoration: none;
	}

	.form .mail a:hover {
		color: red;
	}


	/*入力フォーム*/
	form#mailformpro dl dt,
	form#mailformpro dl dd {
		font-size: 16px;
		border-right: 1px solid #ccc;
	}

	form#mailformpro dl dt {
		background: hsl(219, 100%, 97%);
		border-left: 1px solid #ccc;
	}

	form#mailformpro .box-required dl:last-child,
	form#mailformpro .box-option dl:last-child {
		border-bottom: solid 1px #CCC;
	}

	form#mailformpro .box-mix .box-required dl:last-child {
		border-bottom: none;
	}

	/*予約ステップバー*/
	#mfp_phase_stat {
		display: block;
		position: relative;
		list-style: none;
		margin: 0 0 30px 0;
		padding: 0;
		text-align: center;
		width: 100%;
		overflow: hidden;
		*zoom: 1;
		font-size: 0.9rem;
	}

	#mfp_phase_stat li {
		position: relative;
		float: left;
		display: inline-block;
		line-height: 40px;
		padding: 0 30px 0 10px;
		background-color: #eee;
		-moz-box-sizing: border-box;
		-webkit-box-sizing: border-box;
		box-sizing: border-box;
	}

	#mfp_phase_stat li.mfp_phase_arrow {
		display: none;
	}

	#mfp_phase_stat li:before,
	#mfp_phase_stat li:after {
		position: absolute;
		left: -15px;
		display: block;
		content: '';
		background-color: #eee;
		border-left: 4px solid #FFF;
		width: 20px;
		height: 20px;
	}

	#mfp_phase_stat li:after {
		top: 0;
		-moz-transform: skew(30deg);
		-ms-transform: skew(30deg);
		-webkit-transform: skew(30deg);
		transform: skew(30deg);
	}

	#mfp_phase_stat li::before {
		bottom: 0;
		-moz-transform: skew(-30deg);
		-ms-transform: skew(-30deg);
		-webkit-transform: skew(-30deg);
		transform: skew(-30deg);
	}

	#mfp_phase_stat li:first-child {
		-moz-border-radius-topleft: 4px;
		-webkit-border-top-left-radius: 4px;
		border-top-left-radius: 4px;
		-moz-border-radius-bottomleft: 4px;
		-webkit-border-bottom-left-radius: 4px;
		border-bottom-left-radius: 4px;
	}

	#mfp_phase_stat li:first-child:before,
	#mfp_phase_stat li:first-child:after {
		content: none;
	}

	#mfp_phase_stat li:last-child {
		-moz-border-radius-topright: 4px;
		-webkit-border-top-right-radius: 4px;
		border-top-right-radius: 4px;
		-moz-border-radius-bottomright: 4px;
		-webkit-border-bottom-right-radius: 4px;
		border-bottom-right-radius: 4px;
	}

	#mfp_phase_stat li.mfp_active_phase {
		color: #FFF;
		background-color: #26bfa1;
	}

	#mfp_phase_stat li.mfp_active_phase:before,
	#mfp_phase_stat li.mfp_active_phase:after {
		background-color: #26bfa1;
	}

	.step2 #mfp_phase_stat li {
		width: 50%;
	}

	.step3 #mfp_phase_stat li {
		width: 33.333%;
	}

	.step4 #mfp_phase_stat li {
		width: 25%;
	}

	.step5 #mfp_phase_stat li {
		width: 20%;
	}

	div.mfp_buttons button {
		font-size: 23px;
	}


}