@import url('https://fonts.googleapis.com/css2?family=Oswald:wght@200;300;400&display=swap');


@charset "UTF-8";

html,body{  -webkit-text-size-adjust: none;}

body {
    font-family: Lato, "Noto Sans JP", "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	background-color: #fff;}
    

/*sp*/

.sp{display: inherit;}
.pc{display: none;}


@media screen and (min-width: 641px) {

.sp{display: none;}
.pc{display: inherit;}
.w100{width: 100%;}
}

input {
	cursor: pointer;
	display: inline-block;
	padding: 8px 8px;
	padding-left: 16px!important;
	vertical-align: middle;
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	width: 100%;
	color: inherit;
	margin-bottom: 0;
	background: white;
	border-radius: 0
}

input:focus {
	outline: 0
}

input[disabled] {
	cursor: not-allowed;
	color: #7f7f7f;
	pointer-events: none
}

input[readonly] {
	cursor: default;
	pointer-events: none;
	background: none;
	border: none
}

input[type=checkbox] {
	-webkit-appearance: checkbox;
	-moz-appearance: checkbox;
	appearance: checkbox;
	border: 1px solid #ccc;
	background: #eee
}

input[type=radio] {
	-webkit-appearance: radio;
	-moz-appearance: radio;
	appearance: radio
}

select {
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	font-size: 18px;
	color: #222;
}

[class*=-note] {
	text-align: left;
	display: block;
	margin-top: 8px;
	text-indent: -1em;
	padding-left: 1em;
	line-height: 1.4;
	font-size: 12px;
	color: #333;
    letter-spacing: 0.05em;
}

[class*=-note] a {
	text-decoration: underline
}

html {
	font-size: 62.5%
}

.wrap {
	min-height: 92vh
}

.-index header,
.-error header,
.-confirm header,
.-thanks header {
    height: 100px;
    display: flex;
    justify-content: center;
    align-items: center;
    background-color: #fff;
}

@media screen and (max-width: 640px) {
	.-index header,
	.-error header,
	.-confirm header,
	.-thanks header {
		 height: 66px;
	 }
}
.-error header {
	border-bottom: 1px solid #A0A0A0;
}
/*.-index .PageContainer,
.-error .PageContainer,
.-confirm .PageContainer,
.-thanks .PageContainer {
    background-color: #fff;
}*/

.-index .MainContent,
.-error .MainContent,
.-confirm .MainContent,
.-thanks .MainContent {
    max-width: 640px;
    margin: 20px auto 0;
}

img {
	max-width: 100%
}

.reserve {
	font-size: 62.5%;
	font-family: "小塚ゴシック Pro","Kozuka Gothic Pro","ヒラギノ角ゴ Pro W6","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,sans-serif;
	padding: 0;
	font-size: 16px;
	line-height: 1.4;
	width: 100%;
	letter-spacing: 0;
	margin: -4% auto 0
}
.-error .reserve {
	margin-top: 0;
	font-family: Lato,"小塚ゴシック Pro","Kozuka Gothic Pro","ヒラギノ角ゴ Pro W6","Hiragino Kaku Gothic Pro","メイリオ",Meiryo,sans-serif;

}

.reserve * {
	-webkit-box-sizing: border-box;
	box-sizing: border-box
}

.reserve-head {
	/* background: #324a91;
	background: -webkit-gradient(linear,left top,left bottom,color-stop(6%,transparent),color-stop(6%,#324a91));
	background: -o-linear-gradient(transparent 6%,#324a91 6%);
	background: linear-gradient(transparent 6%,#324a91 6%); */
	background: #fff;
	text-align: center;
	/*padding: 0 3% 3%*/
}

.reserve-head img {
	line-height: 1;
	max-width: 640px;
	width: 100%
}

.reserve .marker {
	background: -webkit-gradient(linear,left top,left bottom,color-stop(70%,transparent),color-stop(70%,#FF9D9D));
	background: -o-linear-gradient(top,transparent 70%,#FF9D9D 70%);
	background: linear-gradient(top,transparent 70%,#FF9D9D 70%)
}

.selectClinic {
	margin-bottom: 0;
}

.selectClinic-title {
	background: #BF9949;
	color: #fff;
	font-weight: bold;
    font-size: 16px;
    padding: 1em 4%;
	letter-spacing: 0.05em;
	line-height: 1.4;
	vertical-align: middle
}

.selectClinic-title img {
	max-width: 23px;
	margin-right: 10px;
	vertical-align: middle;
	-webkit-transform: translateY(-10%);
	-ms-transform: translateY(-10%);
	transform: translateY(-10%)
}

.selectClinic-title img.board {
	width: 18px;
     fill: #fff;
}

.selectClinic-body {
	/* background-image: -o-linear-gradient(135deg,#f5f9ff 25%,#e6f0ff 25%,#e6f0ff 50%,#f5f9ff 50%,#f5f9ff 75%,#e6f0ff 75%,#e6f0ff);
	background-image: linear-gradient(-45deg,#f5f9ff 25%,#e6f0ff 25%,#e6f0ff 50%,#f5f9ff 50%,#f5f9ff 75%,#e6f0ff 75%,#e6f0ff);
	background-size: 10px 10px;
	background-repeat: repeat; */
	padding: 16px 4px;
	/*border-bottom: 6px solid #aeccfd;*/
	position: relative;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

/*.selectClinic-body:after,.selectClinic-body:before {
	border: 30px solid transparent;
	border-top: 30px solid #7aa8fc;
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 100%;
	left: 50%
}*/

.selectClinic-body:before {
	border-top-color: white;
	-webkit-transform: translate(-50%,0%);
	-ms-transform: translate(-50%,0%);
	transform: translate(-50%,0%)
}

.selectClinic-body:after {
	-webkit-transform: translate(-50%,-20%);
	-ms-transform: translate(-50%,-20%);
	transform: translate(-50%,-20%)
}

.selectClinic input[type=radio] {
	display: none
}

.selectClinic input[type=radio]+.selectClinic-btn {
	width: calc(50% - 2% - 4px);
	margin: 1%;
	text-align: center;
	font-size: 16px;
	padding: 1em 4%;
	letter-spacing: 0.05em;
	font-weight: bold;
	line-height: 1;
	border-radius: 5px;
	color: #42506E;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #42506E;
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.selectClinic input[type=radio]+.selectClinic-btn:after {
	border-top: 1px solid #42506E;
	border-right: 1px solid #42506E;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.selectClinic input[type=radio]:checked+.selectClinic-btn {
	background: #42506E;
	color: white
}

.selectClinic input[type=radio]:checked+.selectClinic-btn:after {
	border-color: white;
	-webkit-transform: translate(-50%,-50%) rotate(135deg);
	-ms-transform: translate(-50%,-50%) rotate(135deg);
	transform: translate(-50%,-50%) rotate(135deg)
}

.selectDaytime {
	background: #3859a7;
	padding: 8% 2%;
	margin-bottom: 60px;
}

.selectDaytime-inner {
	background: white;
	padding: 8% 4%;
	max-width: 600px;
	margin: auto;
	background: -o-linear-gradient(45deg,transparent 10px,white 10px),-o-linear-gradient(315deg,transparent 10px,white 10px),-o-linear-gradient(225deg,transparent 10px,white 10px),-o-linear-gradient(135deg,transparent 10px,white 10px);
	background: linear-gradient(45deg,transparent 10px,white 10px),linear-gradient(135deg,transparent 10px,white 10px),linear-gradient(225deg,transparent 10px,white 10px),linear-gradient(315deg,transparent 10px,white 10px);
	background-position: bottom left,top left,top right,bottom right;
	background-size: 50% 50%;
	background-repeat: no-repeat
}

.clinicInfo {
	margin-bottom: 40px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.clinicInfo-title {
	color: #3859a7;
	font-weight: bold;
	font-size: 30px;
	letter-spacing: 0.1em;
	-webkit-box-ordinal-group: 2;
	-ms-flex-order: 1;
	order: 1
}

.clinicInfo-text {
	font-size: 18px;
	line-height: 1.5;
	margin-top: 20px;
	width: 100%;
	-webkit-box-ordinal-group: 4;
	-ms-flex-order: 3;
	order: 3
}

.clinicInfo-btn {
	min-width: 10em;
	-webkit-box-ordinal-group: 3;
	-ms-flex-order: 2;
	order: 2;
	margin-left: auto;
	text-align: center;
	font-size: 14px;
	padding: 0.8em 5% 0.8em 3%;
	letter-spacing: 0.05em;
	line-height: 1;
	border-radius: 5px;
	color: #324a91;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #324a91;
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.clinicInfo-btn:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: #324a91
}

.clinicInfo-btn:after {
	border-top: 1px solid #324a91;
	border-right: 1px solid #324a91;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.calendar-table {
	margin: 4% auto;
	border-collapse: collapse;
	width: 100%;
	table-layout: fixed
}

.calendar-table thead {
	border-bottom: 1px solid #324a91
}

.calendar-table thead th {
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 1
}

.calendar-table tbody {
	background: #eff6ff
}

.calendar-table td,.calendar-table th {
	border: 1px solid #324a91;
	text-align: center;
	padding: 2% 0
}

.calendar-table .month {
	background: #324a91;
	color: white;
	font-size: 20px;
	padding: 0.6em 0;
	letter-spacing: 0.1em;
	position: -webkit-sticky;
	position: sticky;
	top: 0;
	z-index: 1;
	width: auto
}

.calendar-table .day {
	line-height: 1;
	color: #414141;
	background: #e6e6e6;
	border: 1px solid #324a91;
	font-size: 18px;
	position: -webkit-sticky;
	position: sticky;
	top: calc(min(22px, 5.5vw) * 2.5);
	z-index: 1
}

.calendar-table .day.is-saturday {
	color: #658efc
}

.calendar-table .day.is-sunday {
	color: #e06666
}

.calendar-table .day.is-holiday {
	color: #e06666
}

.calendar-table .period {
	background: #e6e6e6;
	font-size: 14px;
	padding: 2px;
	color: #414141;
	max-width: 5em
}

.calendar-table .time {
	line-height: 1.4;
	/* font-size: 16px; */
	cursor: pointer;
	color: #b7d2fd;
	background: #eff6ff;
	pointer-events: none;
	font-size: 0
}

.calendar-table .time span {
	font-size: 18px;
}

.calendar-table .time:hover {
	background: #fff494!important
}

.calendar-table .time.is-ok {
	background: white;
	color: #e06666;
	font-size: 14px;
	pointer-events: auto
}

.calendar-table .time.is-few {
	background: white;
	color: #e68a34;
	pointer-events: auto;
	font-size: 14px;
}

.calendar-table .time.is-check {
	background-color: #fff494;
}

.calendar-table .time.is-ng {
	color: #696969;
	background: #cecece
}

.calendar-nav {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.calendar-next,.calendar-prev {
	width: 45%;
	text-align: center;
	font-size: 18px;
	padding: 0.8em 4%;
	letter-spacing: 0.05em;
	border: none;
	line-height: 1;
	border-radius: 5px;
	color: white;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	background: #e06868;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.calendar-next:after,.calendar-prev:after {
	border-top: 2px solid white;
	border-right: 2px solid white;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.calendar-next:hover,.calendar-prev:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04)
}

.calendar-prev:after {
	top: 50%;
	left: 4%;
	-webkit-transform: translate(50%,-50%) rotate(-135deg);
	-ms-transform: translate(50%,-50%) rotate(-135deg);
	transform: translate(50%,-50%) rotate(-135deg)
}

.calendar-next:after {
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg)
}

.reserveInfo {
	margin-bottom: 40px;
	background: #f9e9e9
}

.reserveInfo-title {
	background: #e06666;
	color: white;
	font-weight: bold;
	font-size: 22px;
	padding: 0.8em 4%;
	letter-spacing: 0.05em;
	line-height: 1;
	text-align: center
}

.reserveInfo-body {
	padding: 0 4% 4%;
	max-width: 600px;
	margin: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-ms-flex-wrap: wrap;
	flex-wrap: wrap;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center
}

.reserveInfo-heading {
	color: #e06666;
	font-weight: bold;
	font-size: 30px;
	padding: 30px 0;
	letter-spacing: 0.1em;
	line-height: 1;
	-webkit-box-ordinal-group: 2;
	-ms-flex-order: 1;
	order: 1
}

.reserveInfo-text {
	font-size: 22px;
	line-height: 1.7;
	letter-spacing: 0.1em;
	margin-bottom: 20px;
	border-top: 1px solid #e06666;
	width: 100%;
	padding-top: 30px;
	-webkit-box-ordinal-group: 4;
	-ms-flex-order: 3;
	order: 3
}

.reserveInfo-btn {
	min-width: 14em;
	-webkit-box-ordinal-group: 3;
	-ms-flex-order: 2;
	order: 2;
	margin-left: auto;
	text-align: center;
	font-size: 14px;
	padding: 0.8em 6% 0.8em 3%;
	text-decoration: none;
	line-height: 1;
	border-radius: 5px;
	color: #e06666;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #e06666;
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.reserveInfo-btn:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: #e06666
}

.reserveInfo-btn:after {
	border-top: 2px solid #e06666;
	border-right: 2px solid #e06666;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}


/* Form adjust */
.form-wrap {
	margin: auto;
	max-width: 640px
}

.form-item {
	width: 100%;
	padding-bottom: min(30px,5.75vw);
	margin-bottom: min(30px,5.75vw);
	border-bottom: 1px solid #c5cad8
}

.form-item input,.form-item option,.form-item select,.form-item textarea {
	background: white;
	border: 1px solid #3859a7;
	border-radius: 5px;
	width: 100%;
	font-size: min(16px,4vw);
	padding: 0.8em;
	height: auto;
	line-height: 1.4
}

.form-item textarea {
	min-height: 8em;
	resize: vertical
}

.form-ttl {
	width: 100%;
	display: inline-block;
	font-weight: 700;
	margin-bottom: min(16px,2vw);
	color: #3859a7;
	font-size: min(18px,4.5vw);
	letter-spacing: 0.1em
}

.form-select {
	position: relative;
	display: inline-block;
	width: 100%;
	margin-right: 2px
}

.form-select:before {
	position: absolute;
	top: 50%;
	right: 8px;
	content: "▼";
	font-size: 10px;
	display: block;
	color: #c4c4c4;
	line-height: 0;
	pointer-events: none
}

.form-span {
	min-width: 2em;
	max-width: 6em;
	font-size: min(12px,3vw);
	text-align: center
}

.submit-group {
	text-align: center
}

.submit-btn {
	background: -webkit-gradient(linear,left top,right top,from(#ee5858),color-stop(50%,#ff8989),to(#ee5858));
	background: -o-linear-gradient(left,#ee5858 0%,#ff8989 50%,#ee5858 100%);
	background: linear-gradient(90deg,#ee5858 0%,#ff8989 50%,#ee5858 100%);
	-webkit-box-shadow: 1px 1px 4px rgba(0,0,0,0.5),0px 0px 16px rgba(238,88,88,0.9) inset;
	box-shadow: 1px 1px 4px rgba(0,0,0,0.5),0px 0px 16px rgba(238,88,88,0.9) inset;
	color: white;
	text-align: center;
	width: 95%;
	margin: 0 auto;
	font-size: min(26px,6.5vw);
	line-height: 1;
	padding: 1.2em 4%;
	letter-spacing: 0.1em;
	border-radius: 50px;
	position: relative;
	-webkit-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
	text-shadow: 0px 0px 4px rgba(0,0,0,0.3);
	margin-bottom: min(40px,7vw);
	border: none
}

.submit-btn:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: white
}

.submit-btn:after {
	border-top: 2px solid white;
	border-right: 2px solid white;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear
}

.submit-btn[disabled] {
	background: #a8a8a8;
	-webkit-box-shadow: none;
	box-shadow: none;
	opacity: 0.5;
	pointer-events: none;
	text-shadow: none
}

.submit-back {
	width: 80%;
	text-align: center;
	font-size: min(16px,4vw);
	padding: 0.8em 4%;
	letter-spacing: 0.05em;
	line-height: 1;
	border-radius: 5px;
	color: #324a91;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #324a91;
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.submit-back:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: #324a91
}

.submit-back:before {
	border-top: 1px solid #324a91;
	border-right: 1px solid #324a91;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	left: 4%;
	-webkit-transform: translateY(-50%) rotate(-135deg);
	-ms-transform: translateY(-50%) rotate(-135deg);
	transform: translateY(-50%) rotate(-135deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear
}

.is-required {
	color: white;
	background: #42506E;
	font-weight: normal;
	font-size: min(12px,3vw);
	padding: 4px;
	width: 3em;
	border-radius: 4px;
	letter-spacing: 0.1em;
	line-height: 1;
	margin-right: 2%;
	margin-bottom: 2px;
	display: inline-block;
	text-align: center;
	vertical-align: middle
}

.agree {
	background: #e8e9e9;
	margin-top: min(16px,2vw);
	padding: 4%
}

.agree-btn {
	width: 100%;
	display: block;
	border: 1px solid #ebebeb;
	padding: 20px 0;
	text-align: center;
	color: #555;
	background: white;
	font-size: min(16px,4vw);
	margin-top: min(20px,3.5vw)
}

.agree-btn:hover {
	border: 0.5px solid #555
}

.agree-txt {
	font-size: min(16px,4vw);
	line-height: 1.7;
	margin-bottom: 10px
}

.agree-check {
	width: 100%;
	display: block;
	padding: 4%
}

.agree-check input {
	display: inline-block;
	width: auto;
	margin-right: 10px
}

.confirm-wrap {
	padding: 8% 4%;
	margin: auto;
	max-width: 500px
}

.confirm-item {
	width: 100%;
	margin-bottom: min(20px,3.5vw);
	border-bottom: 1px solid #3859a7
}

.confirm-item input,.confirm-item pre,.confirm-item select,.confirm-item textarea {
	width: 100%;
	font-size: min(18px,4.5vw);
	padding: 0.8em;
	height: auto;
	line-height: 1.4;
	cursor: default;
	pointer-events: none;
	font-weight: bold;
	letter-spacing: 0.05em
}

.confirm-ttl {
	width: 100%;
	font-weight: 700;
	color: #3859a7;
	font-size: min(14px,3.5vw);
	letter-spacing: 0.1em;
	position: relative;
	padding-left: 20px
}

.confirm-ttl:before {
	border: 8px solid transparent;
	border-left: 8px solid #3859a7;
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 50%;
	left: 0%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%)
}

.confirmMessage {
    background: #BF9949;
    color: #222;
	padding: 2%
}

.confirmMessage-inner {
	/* border: 1px solid #324a91; */
	position: relative;
	display: inline-block;
	margin: auto;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	padding: 3% 0;
}

/* .confirmMessage-inner:after {
	border: 8px solid transparent;
	border-top: 8px solid #324a91;
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 100%;
	left: 50%;
	-webkit-transform: translateX(-50%);
	-ms-transform: translateX(-50%);
	transform: translateX(-50%)
} */

.confirmMessage img {
	width: 60px;
	margin-right: 3%
}

.confirmMessage-text {
	font-size: 18px;
	letter-spacing: 0.05em;
	text-align: center;
	font-weight: bold;
    color: #222;
}

.caution {
	/* margin-bottom: 40px; */
}

.caution-title {
	margin-top: 30px;
	position: relative;
	background: #FFE04A;
	color: white;
	font-size: 16px;
	font-weight: bold;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
    padding: 4% 0;
    border-radius: 10px 10px 0 0;
}

.caution-title::before {
	content: url(../images/confirm/icon-arrow.svg);
	position: absolute;
	top: -30px;
}

.caution-title img {
	width: 30px;
	margin-right: 10px
}

.caution-body {
    border: 10px solid #FFE04A;
    border-top: none;
    border-bottom: none;
    padding: 4%;
}

.caution-body p {
	font-size: 15px;
    text-align: center;
    border-bottom: 1px solid #C9C9C9;
    padding-bottom: 10px;
    margin-bottom: 14px;
    color: #222;
}

.caution-list {
    color: #222;
    font-weight: normal;
    list-style: disc;
    letter-spacing: 0.05em;
    font-size: 15px;
    padding-left: 1.5em;
    margin: 10px 0;
}

.caution-list li {
	list-style: disc;
	margin-bottom: 4px;
}

.check {
	margin-bottom: 40px;
	text-align: center
}

.check-title {
	color: #222;
    font-weight: normal;
    font-size: 16px;
    display: inline-block;
    margin: auto;
    letter-spacing: 0.05em;
    white-space: nowrap;
    margin-bottom: 0;
}

.check input[type=checkbox] {
	display: inline-block;
	width: auto;
	margin-right: 10px;
	vertical-align: middle
}

.check-btn {
    border: none;
    width: 100%;
    margin: auto;
    display: block;
    padding: 4%;
    background: #FFE04A;
	border-radius: 0 0 10px 10px;
}

.thanx {
	min-height: 40vh;
	text-align: center;
	padding: 10% 6%;
	color: #000
}

.thanx-title {
	font-weight: bold;
	margin-bottom: min(40px,7vw);
	font-size: min(26px,6.5vw)
}

.thanx-title:after {
	content: "";
	width: min(30%,140px);
	height: 0;
	border-top: 1px solid #000;
	display: block;
	margin: auto;
	margin-top: min(40px,7vw)
}

.thanx-intro {
	font-weight: bold;
	font-size: min(18px,4.5vw);
	margin-bottom: min(60px,10.5vw)
}

.thanx-intro span {
	color: #e06666;
	font-weight: normal;
	letter-spacing: 0.1em
}

.thanx-text {
	font-size: min(16px,4vw);
	line-height: 1.7;
	margin-bottom: min(40px,7vw);
}

.thanx .call {
	font-size: min(30px,10vw);
	font-weight: bold;
	letter-spacing: 0.1em;
	line-height: 1.4;
}

.thanx .call span {
	font-size: min(14px,3.5vw);
	font-weight: normal;
	display: inline-block;
	position: relative;
}

.thanx .call span:after,.thanx .call span:before {
	content: "";
	width: min(20%,100px);
	height: 0;
	border-top: 1px solid #000;
	display: block;
	position: absolute;
	top: 50%;
}

.thanx .call span:before {
	right: 110%;
}

.thanx .call span:after {
	left: 110%;
}

.thanx-back {
	width: min(80%,300px);
	text-align: center;
	font-size: min(16px,4vw);
	padding: 0.8em 4%;
	letter-spacing: 0.05em;
	line-height: 1;
	border-radius: 5px;
	color: #324a91;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	border: 1px solid #324a91;
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear;
}

.thanx-back:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: #324a91;
}

.thanx-back:before {
	border-top: 1px solid #324a91;
	border-right: 1px solid #324a91;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	left: 4%;
	-webkit-transform: translateY(-50%) rotate(-135deg);
	-ms-transform: translateY(-50%) rotate(-135deg);
	transform: translateY(-50%) rotate(-135deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear;
}

.mfp-iframe-holder {
	padding-top: 100px;
}

.mfp-iframe-holder .mfp-content {
	min-height: 100%;
}

.modal-close {
	position: absolute;
	top: 50%;
	right: 10px;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
	color: rgba(255,255,255,0.5);
	font-size: 26px;
	width: 30px;
	height: 30px;
	display: block;
	background: none;
	border: none;
	line-height: 1;
}

.clinicDetail {
	padding: 5% 0;
}

.clinicDetail-inner {
	background: white;
	width: 90%;
	min-width: 300px;
	max-width: 600px;
	margin: auto;
}

.clinicDetail-head {
	position: relative;
	padding: 0.8em;
	background: #3859a7;
	color: white;
}

.clinicDetail-ttl {
	font-size: 18px;
	letter-spacing: 0.1em;
}

.clinicDetail-address {
	font-size: min(14px,3.5vw);
	letter-spacing: 0.1em;
	color: rgba(255,255,255,0.6);
}

.clinicDetail-img {
	width: 70%;
	margin: 20px auto;
}

.clinicDetail-table {
	margin: 0 auto 20px;
	border-collapse: collapse;
}

.clinicDetail-table td,.clinicDetail-table th {
	border-bottom: 1px solid #324a91;
	padding: 4% 2%;
	line-height: 1.4;
	vertical-align: top;
	font-size: 14px;
	color: #000;
}

.clinicDetail-table th {
	width: 6em;
	text-align: right;
	border-bottom: 1px solid #c0c0c0;
}

.clinicDetail-table td {
	border-bottom: 1px solid #e8e8e8;
}

.clinicDetail .googlemap {
	width: 100%;
}

.clinicDetail .googlemap iframe {
	width: 100%;
	height: min(50vw,300px);
}

@media screen and (min-width: 768px) {
	.clinicDetail-body {
			display:-webkit-box;
			display: -ms-flexbox;
			display: flex;
			-webkit-box-orient: horizontal;
			-webkit-box-direction: reverse;
			-ms-flex-direction: row-reverse;
			flex-direction: row-reverse;
			-ms-flex-wrap: wrap;
			flex-wrap: wrap;
			padding: 4%;
	}

	.clinicDetail-img {
			width: 30%;
			margin: 0;
	}

	.clinicDetail-table {
			width: 66%;
			margin: 0 4% 0 0;
	}
}

.loading {
	position: fixed;
	width: 100vw;
	height: 100vh;
	background: rgba(0,0,0,0.4);
	top: 0;
	left: 0;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
	z-index: 9999;
}

.spinner {
	margin: 100px auto;
	font-size: 25px;
	width: 1em;
	height: 1em;
	border-radius: 50%;
	position: relative;
	text-indent: -9999em;
	-webkit-animation: load5 1.1s infinite ease;
	animation: load5 1.1s infinite ease;
	-webkit-transform: translateZ(0);
	-ms-transform: translateZ(0);
	transform: translateZ(0);
}

@-webkit-keyframes load5 {
	0%,to {
			-webkit-box-shadow: 0em -2.6em 0em 0em #ffffff,1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.5),-1.8em -1.8em 0 0em rgba(255,255,255,0.7);
			box-shadow: 0em -2.6em 0em 0em #ffffff,1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.5),-1.8em -1.8em 0 0em rgba(255,255,255,0.7)
	}

	12.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.7),1.8em -1.8em 0 0em #ffffff,2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.5);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.7),1.8em -1.8em 0 0em #ffffff,2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.5)
	}

	25% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.5),1.8em -1.8em 0 0em rgba(255,255,255,0.7),2.5em 0em 0 0em #ffffff,1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.5),1.8em -1.8em 0 0em rgba(255,255,255,0.7),2.5em 0em 0 0em #ffffff,1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	37.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.5),2.5em 0em 0 0em rgba(255,255,255,0.7),1.75em 1.75em 0 0em #ffffff,0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.5),2.5em 0em 0 0em rgba(255,255,255,0.7),1.75em 1.75em 0 0em #ffffff,0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	50% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.5),1.75em 1.75em 0 0em rgba(255,255,255,0.7),0em 2.5em 0 0em #ffffff,-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.5),1.75em 1.75em 0 0em rgba(255,255,255,0.7),0em 2.5em 0 0em #ffffff,-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	62.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.5),0em 2.5em 0 0em rgba(255,255,255,0.7),-1.8em 1.8em 0 0em #ffffff,-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.5),0em 2.5em 0 0em rgba(255,255,255,0.7),-1.8em 1.8em 0 0em #ffffff,-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	75% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.5),-1.8em 1.8em 0 0em rgba(255,255,255,0.7),-2.6em 0em 0 0em #ffffff,-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.5),-1.8em 1.8em 0 0em rgba(255,255,255,0.7),-2.6em 0em 0 0em #ffffff,-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	87.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.5),-2.6em 0em 0 0em rgba(255,255,255,0.7),-1.8em -1.8em 0 0em #ffffff;
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.5),-2.6em 0em 0 0em rgba(255,255,255,0.7),-1.8em -1.8em 0 0em #ffffff
	}
}

@keyframes load5 {
	0%,to {
			-webkit-box-shadow: 0em -2.6em 0em 0em #ffffff,1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.5),-1.8em -1.8em 0 0em rgba(255,255,255,0.7);
			box-shadow: 0em -2.6em 0em 0em #ffffff,1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.5),-1.8em -1.8em 0 0em rgba(255,255,255,0.7)
	}

	12.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.7),1.8em -1.8em 0 0em #ffffff,2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.5);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.7),1.8em -1.8em 0 0em #ffffff,2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.5)
	}

	25% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.5),1.8em -1.8em 0 0em rgba(255,255,255,0.7),2.5em 0em 0 0em #ffffff,1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.5),1.8em -1.8em 0 0em rgba(255,255,255,0.7),2.5em 0em 0 0em #ffffff,1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	37.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.5),2.5em 0em 0 0em rgba(255,255,255,0.7),1.75em 1.75em 0 0em #ffffff,0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.5),2.5em 0em 0 0em rgba(255,255,255,0.7),1.75em 1.75em 0 0em #ffffff,0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	50% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.5),1.75em 1.75em 0 0em rgba(255,255,255,0.7),0em 2.5em 0 0em #ffffff,-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.5),1.75em 1.75em 0 0em rgba(255,255,255,0.7),0em 2.5em 0 0em #ffffff,-1.8em 1.8em 0 0em rgba(255,255,255,0.2),-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	62.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.5),0em 2.5em 0 0em rgba(255,255,255,0.7),-1.8em 1.8em 0 0em #ffffff,-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.5),0em 2.5em 0 0em rgba(255,255,255,0.7),-1.8em 1.8em 0 0em #ffffff,-2.6em 0em 0 0em rgba(255,255,255,0.2),-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	75% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.5),-1.8em 1.8em 0 0em rgba(255,255,255,0.7),-2.6em 0em 0 0em #ffffff,-1.8em -1.8em 0 0em rgba(255,255,255,0.2);
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.5),-1.8em 1.8em 0 0em rgba(255,255,255,0.7),-2.6em 0em 0 0em #ffffff,-1.8em -1.8em 0 0em rgba(255,255,255,0.2)
	}

	87.5% {
			-webkit-box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.5),-2.6em 0em 0 0em rgba(255,255,255,0.7),-1.8em -1.8em 0 0em #ffffff;
			box-shadow: 0em -2.6em 0em 0em rgba(255,255,255,0.2),1.8em -1.8em 0 0em rgba(255,255,255,0.2),2.5em 0em 0 0em rgba(255,255,255,0.2),1.75em 1.75em 0 0em rgba(255,255,255,0.2),0em 2.5em 0 0em rgba(255,255,255,0.2),-1.8em 1.8em 0 0em rgba(255,255,255,0.5),-2.6em 0em 0 0em rgba(255,255,255,0.7),-1.8em -1.8em 0 0em #ffffff
	}
}

.page-b {
	background: white;
	margin: 0;
}

.page-b .wrap {
	max-width: 800px;
	margin: auto;
}

img {
	max-width: 100%;
}



/* Form adjust */
.no-js form {
	display: none;
}

.reserve-nojs-note {
	display: none;
}

.no-js .reserve-nojs-note {
	display: block;
	color: red;
	font-size: 20px;
	text-align: center;
	padding: 20px 20px;
}

.Form__item {
	width: 100%;
	/* padding-bottom: 30px; */
    padding-bottom: 20px !important;
    margin-bottom: 20px;
}

.Form__item:not(:last-child) {
    border-bottom: 1px solid #C9C9C9;
}

.Form__item input,.Form__item option,.Form__item select,.Form__item textarea {
	background: white;
	border: 1px solid #222;
	border-radius: 5px;
	width: 100%;
	font-size: 16px;
	padding: 1.1em;
	height: auto;
	line-height: 1.4;
	transition: border-color ease 0.25s;
}
.Form__item input::placeholder,
.Form__item option::placeholder,
.Form__item select::placeholder,
.Form__item textarea::placeholder {
	color: #C9C9C9;
}

.Form__item input.is-error {
	border-color: #E06666;
}

.Form__item.-accompaniedParents.has-error > .inner {
	border: 1px solid #E06666;
}

.Form__item textarea {
	height: 8em;
	resize: vertical;
}

.Form__itemLabel {
	width: 100%;
	display: flex;
	align-items: center;
	margin-bottom: 8px;
	color: #222;
	font-size: 15px;
	letter-spacing: 0.1em;
}

.Form__itemName {
	order: 2;
}

.Form__agreeTxt {
	font-size: 16px;
	line-height: 1.5;
	margin-bottom: 10px;
	display: block;
}

.Form__agreeNote {
	text-align: left;
	display: block;
	margin-top: 8px;
	text-indent: -1em;
	padding-left: 1em;
	line-height: 1.4;
	font-size: 14px;
}

.Form__itemType {
	display: flex;
	align-items: center;
	justify-content: center;
	order: 1;
	color: white;
	background: #e06666;
	font-weight: normal;
	font-size: 12px;
	width: 36px;
	height: 20px;
	border-radius: 4px;
	letter-spacing: 0.1em;
	line-height: 1;
	margin-right: 2%;
}

.Form__itemType.-required {
	background: #42506E;
}

.Form__holder.has-select {
	position: relative;
	display: inline-block;
	width: 100%;
	margin-right: 2px;
}

.Form__holder.has-select:before {
	position: absolute;
	top: 50%;
	right: 8px;
	content: "▼";
	font-size: 10px;
	display: block;
	color: #c4c4c4;
	line-height: 0;
	pointer-events: none;
}

.Form__supplement {
	text-align: left;
	display: block;
	margin-top: 8px;
	text-indent: -1em;
	padding-left: 1em;
	line-height: 1.4;
	font-size: 14px;
	color: #FF8484;
}

.Form__privacyLink {
	line-height: 1.4;
	font-size: 14px;
	text-align: center;
}

.Form__item.-accompaniedParents > .inner {
	background: #e8e9e9;
	margin-top: -20px;
	padding: 4%;
}

.Form__item.-accompaniedParents > .inner strong {
	font-weight: bold;
}

.Form__item.-accompaniedParents .Form__itemLabel {
	font-size: 16px;
	color: #222;
  	line-height: 1.7;
  	margin-bottom: 10px;
}

.Form__item.-accompaniedParents .Form__inputList {}

.Form__item.-accompaniedParents .Form__inputList li {
	width: 100%;
	display: block;
	padding: 0 0 8px;
}

.Form__item.-accompaniedParents .Form__inputList li input {
	display: inline-block;
	width: auto;
	margin-right: 10px;
}

.Form__item.-accompaniedParents .Form__inputList li span {
	font-size: 16px;
}

.Form__item.-accompaniedParents .Form__download {
	width: 100%;
    display: block;
    border: 1px solid #ebebeb;
    /* padding: 20px 0; */
    /* text-align: center; */
    color: #555;
    /* background: white; */
    font-size: 14px;
    margin-top: 6px;
}

.Form__item.-accompaniedParents .Form__download:hover {
	/* border: 0.5px solid #555; */
}

.Form__error {
	color: #E06666;
	margin-top: 10px;
	line-height: 1.4;
	font-size: 14px;
	font-weight: normal;
}

.Form__error.-accompanied_parents {
	margin-top: 16px;
  padding-left: 16px;
}

.Form__item.-confirm {
	padding-bottom: 0;
}

.Form__item.-confirm dt {
	width: 100%;
    font-weight: normal;
    color: #42506E;
    font-size: min(14px,3.5vw);
    letter-spacing: 0.06em;
    position: relative;
    padding-left: 10px;
}

/* .Form__item.-confirm dt::before {
	border: 8px solid transparent;
	border-left: 8px solid #3859a7;
	content: "";
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: 50%;
	left: 0%;
	-webkit-transform: translateY(-50%);
	-ms-transform: translateY(-50%);
	transform: translateY(-50%);
} */

.Form__item.-confirm dd {
    width: 100%;
    font-size: 15px;
    padding: 10px 10px 0;
    height: auto;
    line-height: 1.4;
    cursor: default;
    pointer-events: none;
    font-weight: 500;
    letter-spacing: 0.05em;
    color: #222;
}


.Form__submit {
	text-align: center;
}

.Form__submit button,
.Form__submit input,
.Confirm__action.-submit button,
.Confirm__action.-submit input{
	/* background: -webkit-gradient(linear,left top,right top,from(#ee5858),color-stop(50%,#ff8989),to(#ee5858));
    background: -o-linear-gradient(left,#ee5858 0%,#ff8989 50%,#ee5858 100%);
    background: linear-gradient(90deg,#ee5858 0%,#ff8989 50%,#ee5858 100%); */
	background: #BF9949;
    /* -webkit-box-shadow: 1px 1px 4px rgb(0 0 0 / 50%), 0px 0px 16px rgb(238 88 88 / 90%) inset; */
    box-shadow: 0 4px 5px rgb(0 0 0 / 40%);
    color: white;
    text-align: center;
    width: 85%;
    margin: 0 auto;
    font-size: 20px;
    letter-spacing: 0.01em;
    font-weight: 700;
    padding: 1.2em 4%;
    /* letter-spacing: 0.1em; */
    border-radius: 50px;
    position: relative;
    -webkit-transition: all 0.1s linear;
    -o-transition: all 0.1s linear;
    transition: all 0.1s linear;
    /* text-shadow: 0px 0px 4px rgb(0 0 0 / 30%); */
    margin-bottom: 20px;
    border: none;
    cursor: pointer;
}

.Form__submit button:hover,.Form__submit input:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: white;
}

.Form__submit button:after,.Form__submit input:after {
	border-top: 2px solid white;
	border-right: 2px solid white;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	right: 4%;
	-webkit-transform: translate(-50%,-50%) rotate(45deg);
	-ms-transform: translate(-50%,-50%) rotate(45deg);
	transform: translate(-50%,-50%) rotate(45deg);
	-webkit-transition: all 0.1s linear;
	-o-transition: all 0.1s linear;
	transition: all 0.1s linear;
}

.Confirm__action.-back a {
	width: 80%;
	text-align: center;
	font-size: 16px;
	padding: 0.8em 4%;
	letter-spacing: 0.05em;
	line-height: 1;
	border-radius: 5px;
	color: #324a91;
	cursor: pointer;
	display: inline-block;
	vertical-align: middle;
	/* border: 1px solid #324a91; */
	background: white;
	position: relative;
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear;
	text-decoration: underline;
}
/*
.Confirm__action.-back a:hover {
	-webkit-transform: scale(1.04);
	-ms-transform: scale(1.04);
	transform: scale(1.04);
	color: #324a91;
}

.Confirm__action.-back a:before {
	border-top: 1px solid #324a91;
	border-right: 1px solid #324a91;
	display: block;
	width: 10px;
	height: 10px;
	content: "";
	position: absolute;
	top: 50%;
	left: 4%;
	-webkit-transform: translateY(-50%) rotate(-135deg);
	-ms-transform: translateY(-50%) rotate(-135deg);
	transform: translateY(-50%) rotate(-135deg);
	-webkit-transition: all 0.2s linear;
	-o-transition: all 0.2s linear;
	transition: all 0.2s linear;
}
*/
._ContactForm {
	padding: 0;
}

.Confirm__actionContainer {
	text-align: center;
}

._ContactForm__content {
	padding: 24px 10px;
}
._ContactForm__content.Confirm {
	padding: 24px 10px 0;
	margin: auto;
	/* width: 448px; */
}

.Form__submit button[disabled],
.Form__submit input[disabled],
.Confirm__action.-submit button[disabled],
.Confirm__action.-submit input[disabled] {
	background: #a8a8a8;
	-webkit-box-shadow: none;
	box-shadow: none;
	opacity: 0.5;
	pointer-events: none;
	text-shadow: none;
}

._ThanksMessage__body {
	padding: 76px 0 104px;
	margin: auto;
	width: 448px;
}

._ThanksMessage__lead {
	font-size: 34px;
	line-height: 1;
	text-align: center;
	letter-spacing: 0.142em;
	color: #324990;
	font-weight: bold;
}

._ThanksMessage__description {
	margin-top: 32px;
	font-size: 18px;
	line-height: 2;
	letter-spacing: 0.016em;
}

._ThanksMessage__tel {
	margin-top: 30px;
	background-color: #E7E9E9;
	padding: 21px 0;
	text-align: center;
}

._ThanksMessage__telText {
	font-size: 18px;
	line-height: 1.555;
	letter-spacing: 0.016em;
	color: #324990;
}

._ThanksMessage__telNumber {
	margin-top: 16px;
	font-size: 30px;
	line-height: 1;
	letter-spacing: 0.016em;
	color: #324990;
}

._DuplicateMessage__body {
	padding: 35px 0 93px;
	margin: 0 auto;
	width: 448px;
}

._DuplicateMessage__description {
	margin-top: 32px;
	font-size: 18px;
	line-height: 2;
	letter-spacing: 0.016em;
}

._DuplicateMessage__description b {
	font-weight: bold;
	color: #E06666;
}

._DuplicateMessage__informationContainer {
	margin-top: 46px;
}

._DuplicateMessageInformation {}

._DuplicateMessageInformation:not(:first-child) {
	margin-top: 54px;
}

._DuplicateMessageInformation__description {
	font-size: 18px;
	line-height: 2;
	letter-spacing: 0.016em;
}

._DuplicateMessageInformation__description b {
	text-decoration: underline;
	color: #555555;
}

._DuplicateMessageInformation__tel {
	margin-top: 7px;
	background-color: #E7E9E9;
	padding: 24px;
	text-align: center;
}

._DuplicateMessageInformation__telLead {
	font-size: 18px;
	line-height: 1;
	font-weight: bold;
}

._DuplicateMessageInformation__telNumber {
	margin-top: 16px;
	font-size: 30px;
	line-height: 1;
	font-weight: bold;
	color: #324990;
}

._DuplicateMessageInformation__telTime {
	margin-top: 12px;
	font-size: 16px;
	line-height: 1;
	font-weight: bold;
	color: #324990;
}

._DuplicateMessage__message {
	margin-top: 33px;
	font-size: 18px;
	line-height: 2;
	letter-spacing: 0.016em;
}


/*-----------------------------------------
220317_追加
共通
-----------------------------------------*/


.header_logo {
    height: 40px;
    width: auto;
}

/*-----------------------------------------
step1
-----------------------------------------*/
.ui-datepicker {
	width: 24rem;
	box-shadow: 0 3px 10px rgb(0 0 0 / 20%);
}

.ui-datepicker table  {
	font-size: 1.8rem;
}

.ui-datepicker th {
    padding: 0.2em 0.3em;
}

.ui-datepicker .ui-datepicker-title {
	font-size: 17px;
}

.ui-datepicker .ui-datepicker-header {
	border: 1px solid #42506E;
    background: #42506E;
    color: #fff;	
}

.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next {
    position: absolute;
    top: 7px;
}

.ui-state-active, .ui-widget-content .ui-state-active {
	border: 1px solid #42506E;
    background: #42506E;
    color: #fff;
}
.ui-state-highlight, .ui-widget-content .ui-state-highlight {
	border: 1px solid #42506E;
}

.ui-datepicker td span, .ui-datepicker td a {
	text-align: center;
}

.Form__datePart .Form__item {
	padding-bottom: 10px !important;
    margin-bottom: 10px;
}
.Form__datePart .Form__item:not(:last-child) {
	border: none
}

.Form__datePart.-date {
	display: block;
	margin-bottom: 8px;
}

.date-wrap {
	display: grid;
    grid-template-columns: 1fr 1fr;
    grid-gap: 8px;
}

select:invalid {
	color: #c9c9c9;
  }


/*-----------------------------------------
step2
-----------------------------------------*/
.step3-header {
	border-top: 10px #42506E solid;
}

.step3-mv {
	margin-bottom: 24px;
}

.step3-body {
	padding: 16px;
}

.step3-body p {
	font-size: 16px;
	margin-bottom: 16px;
    line-height: 1.6;
    letter-spacing: .05em;
}

.step3-body p strong {
    background: -webkit-gradient(linear,left top,left bottom,color-stop(70%,transparent),color-stop(70%,#FFE775));
    background: -o-linear-gradient(top,transparent 70%,#FFE775 70%);
    background: linear-gradient(top,transparent 70%,#FFE775 70%);
	font-weight: bold;
}

.step3-body .tel-wrap {
    margin: 50px 6px 0;
    border: 2px solid #222;
    padding: 16px 10px;
    /*box-shadow: 5px 5px 0 #fff186;*/
    position: relative;
	background-color: #F5F5F5;
}
.step3-body .tel-wrap::after {
	content: url(../images/thanks/icon-tel.svg);
	position: absolute;
	top: -24px;
    left: -14px;
    z-index: 3;
}
.step3-body .tel-wrap::before {
        content: "";
        position: absolute;
        width: 100%;
        height: 100%;
        top: 8px;
        left: 8px;
        z-index: -1;
        -webkit-background-size: 4px 4px;
        -moz-background-size: 4px 4px;
        background-size: 6px 6px;
        background-image: -webkit-gradient(linear, 0 0, 100% 100%, color-stop(0.25, #afafaf), color-stop(0.25, transparent), color-stop(0.5, transparent), color-stop(0.5, #17a2ff), color-stop(0.75, #17a2ff), color-stop(0.75, transparent), to(transparent));
        background-image: -webkit-linear-gradient(-45deg, #fff186 25%, transparent 25%, transparent 50%, #fff186 50%, #fff186 75%, transparent 75%, transparent);
        background-image: -moz-linear-gradient(-45deg, #fff186 25%, transparent 25%, transparent 50%, #fff186 50%, #fff186 75%, transparent 75%, transparent);
        background-image: -ms-linear-gradient(-45deg, #fff186 25%, transparent 25%, transparent 50%, #fff186 50%, #fff186 75%, transparent 75%, transparent);
        background-image: -o-linear-gradient(-45deg, #fff186 25%, transparent 25%, transparent 50%, #fff186 50%, #fff186 75%, transparent 75%, transparent);
        background-image: linear-gradient(-45deg, #fff186 25%, transparent 25%, transparent 50%, #fff186 50%, #fff186 75%, transparent 75%, transparent);
    }

.step3-body .tel-wrap h2 {
	text-align: center;
	font-weight: bold;
	font-size: 18px;
	border-bottom: 1px solid #c9c9c9;
	padding-bottom: 8px;
	margin-bottom: 8px;
}

.step3-body .tel-wrap .number {
	font-family: 'Oswald', sans-serif;
    font-weight: 400;
    font-size: 24px;
    text-align: center;
	margin-bottom: 8px;
}

.step3-body .tel-wrap .number a {
	text-decoration: none;
	color: #222;
}

.step3-body .tel-wrap dl {
	display: flex;
    justify-content: center;
}

.step3-body .tel-wrap dl dt {
	background: #42506E;
	padding: 2px 5px;
	color: #fff;
	border-radius: 3px;
	font-size: 13px;
	margin-right: 8px;
}


.step3-body .covid19-wrap {
	position: relative;
    margin: 30px 6px 0;
}
.step3-body .covid19-wrap img {
}

.step3-body .covid19-wrap a {
    display: block;
    color: #fff;
    padding: 20px 0;
    font-size: 22px;
    background: #42506E;
    text-decoration: none;
    width: 73%;
    text-align: center;
    border-radius: 4px;
    font-weight: bold;
    position: absolute;
    bottom: 56px;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
}

@media screen and (max-width: 640px) {
	.step3-body p {
		font-size: 15px;
	}
	.step3-body .covid19-wrap a {
		padding: 15px 0;
		font-size: 14px;
		bottom: 30px;
	}
}



/*shop 追加 220530*/

.sec-shoplist{
background-color:#fff/* #9bc8db*/;
padding: 0 15px;
max-width: 600px;
margin: 0 auto;
}

.area-ttl{
display: none!important;
background-color: #4a4b4c;
margin: 10px auto 20px;
display: block;
height: 50px;
line-height: 50px;
text-align: center;
font-size: 22px;
color: #fff;
}
.city-ttl{
background-color: #4a4b4c;
margin: 10px auto;
display: block;
height: 40px;
line-height: 40px;
text-align: center;
font-size: 18px;
color: #fff;
}
.shop{
display: none;
background-color: #fff;
padding: 20px 12px;
box-shadow: 2px 3px 0 #BF9949;
border: 1px solid #BF9949;
margin-bottom: 10px;
}
.shop-ttl{
background-color: #e4e5e6;
margin: 0 auto 8px;
display: block;
height: 42px;
line-height: 42px;
text-align: center;
font-size: 20px;
color: #333;
font-weight: 600;
}
.teikei{
font-size: 14px;
font-weight: 300;
}
.shop table{
font-size: 14px;
color: #333;
line-height: 1.4;
margin-bottom: 8px;
}

th{
width: 26%;
font-weight: 600;
padding: 4px 0;
}
td{
width:74%;
padding: 4px 0;
}
.map{
    position: relative;
    width: 100%;
    height: 0;
    padding-top: 56.25%;/*比率をお好みで*/
}
.map iframe{
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
}


@media screen and (min-width: 641px) {

.shop{
padding: 30px;
}
.shop-ttl{
margin: 0 auto 8px;
height: 54px;
line-height: 54px;
font-size: 27px;
}
.teikei{
font-size: 18px;
}
.shop table{
font-size: 17px;
color: #333;
line-height: 1.4;
margin-bottom: 15px;
}

th{
width: 20%;
font-weight: 600;
padding: 5px 0;
}
td{
width:80%;
padding: 5px 0;
}
.map{
    position: relative;
    width: 80%;
    margin: 10px auto;
    height: 0;
    padding-top: 56.25%;
}

}