/* ------------------------------------------------------------------ step1 */
.post_content .web-booking h3 {
    margin: 0 0 1.5em !important;
    color: #0066b3;
    font-size: 24px;
}
.post_content .web-booking h4 {
    margin: 3em 0 1.5em !important;
    font-size: 20px;
}


.post_content ul.web-booking__area-list {
    list-style: none;
    margin: 0;
    padding: 0;
}
.web-booking__area-item {
    display: inline-block;
    padding: 4px 8px;
    border: 1px solid rgba(0, 0, 0, 0.25);
    border-radius: 2px;
    cursor: pointer;
    transition: color .2s ease, background-color .2s ease;
}
.web-booking__area-item:not(:last-child) {
    margin-right: 20px;
}

.web-booking__area-item--active,
.web-booking__area-item:hover {
    color: #fff;
    background-color: #066aab;
}

fieldset.web-booking__form-field {
    display: inline-block;
    padding: .35em .75em .625em 0;
    border: none;
}
fieldset.web-booking__form-field label {
    margin-right: 12px;
}
fieldset.web-booking__form-field select {
    min-width: 6em;
    padding: 4px 16px 4px 8px;
    border: 1px solid rgba(0, 0, 0, 0.25);
    border-radius: 2px;
}
.web-booking__form-verify-msg {
	height: 75px;
    padding: 20px 0;
	font-size: 14px;
	color: #c00;
}
.web-booking__form-submit {
    background-color: #066aab;
    padding: .75em;
    width: 320px;
    line-height: 1.5;
    color: #fff;
    letter-spacing: .5em;
    font-weight: 700;
    cursor: pointer;
    border: 2px solid #066aab;
    border-radius: 4px;
    transition: opacity .2s ease;
}
.web-booking__form-submit:hover,
.web-booking__form-submit:disabled {
    opacity: .7;
}
.web-booking-radio {
    display: inline-flex;
    align-items: center;
    cursor: pointer;
}
.web-booking-radio input[type=radio] {
    display: none;
}
.web-booking-radio__button {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1em;
    height: 1em;
    line-height: 1em;
    margin-right: .25em;
    border-radius: 999em;
    border: 1px solid #ccc;
    background-color: #fff;
}
.web-booking-radio__button::before {
    content: "";
    display: block;
    visibility: hidden;
    width: .625em;
    height: .625em;
    line-height: inherit;
    border-radius: inherit;
    background-color: #066aab;
}
.web-booking-radio input[type=radio]:checked ~ .web-booking-radio__button::before {
    visibility: visible;
}



/* ------------------------------------------------------------------ step2 */
.web-booking .empty-text {
	margin: 20px 0;
	font-size: 16px;
	font-weight: 700;
	line-height: 2;
}
.web-booking .empty-text a:hover {
	text-decoration: underline;
}
.web-booking__schedule-remark {
    display: flex;
    align-items: center;
    margin: 10px 0;
}
.web-booking__schedule-remark-square {
    display: inline-block;
    background-color: #FFEEDA;
    width: 100px;
    height: 20px;
}
.web-booking__flow-ctrls {
    margin: 0 0 20px;
}

/* iconFrame */
.-nt-iconFrame1{
	display: inline-flex !important;
	align-items: center;
    border: 1px solid #666;
    line-height: 2;
}
.-nt-iconFrame1__icon{
	display: flex;
	align-items: center;
	justify-content: center;
}
.-nt-iconFrame1__icon:first-child{
	margin-right: 1em;
}
.-nt-iconFrame1__icon:last-child{
	margin-left: 1em;
}
.-nt-iconFrame1__body{
	flex: 1 1;
}
@media all and (-ms-high-contrast: none){
	.-nt-iconFrame1__body{
		flex-basis: auto;
	}
}

/* table */
.-nt-table2__track {
	background-color: #eee;
}
.-nt-reviced__track{
	background-color: #FFEEDA;
}

.-nt-table1{
	min-width: 100%;
	border-collapse: collapse;
}
.-nt-table1__cell{
	text-align: left;
	vertical-align: top;
}
.-nt-table1__cell--head{
	font-weight: normal;
}
.-nt-table1__cell--body{}


@media (min-width: 768px){
	.-nt-table1 tr:not(:first-child) .-nt-table1__cell{
		padding-top: 2em;
	}
	.-nt-table1__cell{}
	.-nt-table1__cell--head{}
	.-nt-table1__cell--body{
		padding-left: 1em;
	}
}
/* SP only */
@media (max-width: 767px){
	.-nt-table1,
	.-nt-table1 thead,
	.-nt-table1 tbody,
	.-nt-table1 tr,
	.-nt-table1__cell{
		display: block;
	}
	.-nt-table1{}
	.-nt-table1 tr{
		margin-bottom: 1em;
		padding-bottom: 1em;
		border-bottom: 1px solid #ccc;
	}
	.-nt-table1__cell{}
	.-nt-table1__cell--head{}
	.-nt-table1__cell--body{}
}


.-nt-table2{
	min-width: 100%;
	border-collapse: collapse;
	background-color: #fff;
}
.-nt-table2--autoStripe tr:nth-child(2n){
	background-color: #F2F8FB;
}
.-nt-table2__cell{
	padding: .75em;
	border: 1px solid #ccc;
	
	font-weight: normal;
}
.-nt-table2__cell--head{
	color: #fff;
	background-color: #0066b3;
}
.-nt-table2__cell--body{}
.-nt-table2__cell--highlight{
	background-color: #ffeeda;
}

.-nt-table2__track{}
.-nt-table2__track--odd{
	background-color: #fff;
}
.-nt-table2__track--even{
	background-color: #F2F8FB;
}

.-nt-table2__cell--highlight,
.-nt-table2__track--odd .-nt-table2__cell--highlight,
.-nt-table2--autoStripe tr:nth-child(2n+1) .-nt-table2__cell--highlight{
	background-color: #ffeeda;
}
.-nt-table2__track--even .-nt-table2__cell--highlight,
.-nt-table2--autoStripe tr:nth-child(2n) .-nt-table2__cell--highlight{
	background-color: #ffd099;
}

.-nt-table2--small{
	font-size: .75em;
	line-height: 2em;
}
.-nt-table2--small .-nt-table2__cell{
	padding: .5em;
	font-size: 12px;
}
.-nt-table3{
	min-width: 100%;
	border-collapse: collapse;
	background-color: #fff;
	
	
	box-sizing: border-box;
}
.-nt-table3--small{
	font-size: .75em;
	line-height: 2em;
}
.-nt-table3__cell{
	padding: .25em .75em;
	border: 1px solid #ccc;
}
.-nt-table3__cell--head{
	background-color: #eaeaea;
}
.-nt-table3__cell--body{}

.-nt-table4{
	line-height: 1.333;
	background: #fff;
	min-width: 100%;
	table-layout: fixed;
	border-collapse: collapse;
}
.-nt-table4__cell{
	font-weight: normal;
	border: 1px solid #ccc;
	padding: .25em .5em;
}
.-nt-table4__cell--fill1{
	background: #ffd099;
}
.-nt-table4__cell--fill2{
	background: #ffeeda;
}
.-nt-table4__cell--color1{
	color: #c00;
}
.-nt-table4 > thead{
	color: #fff;
	background: #0066b3;
}
.-nt-table4--stripe > tbody > tr:nth-child(odd){
	background: #f2f8fb;
}
@media (min-width: 1280px){
	.-nt-table4--small{
		font-size: .75em;
	}
}
@media (max-width: 1279px){
	.-nt-table4{
		font-size: clamp(.5625em, 1.25vw, 1em);
	}
	.-nt-table4--small{
		font-size: clamp(.5625em, .9375vw, .75em);
	}
}
@media (max-width: 1023px) and (min-width: 768px){
	.-nt-table4{
		font-size: clamp(.5625em, 1.5625vw, 1em);
	}
	.-nt-table4--small{
		font-size: clamp(.5625em, 1.17vw, .75em);
	}
}
@media (max-width: 767px){
	.-nt-table4{
		font-size: clamp(.5625em, 3.125vw, 1em);
	}
	.-nt-table4--small{
		font-size: clamp(.5625em, 1.5625vw, .75em);
	}
}

/* nt form */
.-nt-formComponent1{
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	position: relative;
	
	max-width: 100%;
	box-sizing: border-box;
}
.-nt-formComponent1__icon{}
.-nt-formComponent1__note{}

.-nt-formComponent1__input:disabled ~ .-nt-formComponent1__icon,
.-nt-formComponent1__input:disabled ~ .-nt-formComponent1__note{
	opacity: .3;
}
/* select */
select.-nt-formComponent1__input{
	-webkit-appearance: none;
	-moz-appearance: none;
	appearance: none;
	
	cursor: pointer;
	
	padding: .5em;
	padding-right: 2em;
	
	border: 1px solid #ccc;
	border-radius: 4px;
	background-color: #fff;
	
	max-width: 100%;
	box-sizing: border-box;
}
select.-nt-formComponent1__input::-ms-expand{
	display: none;
}
select.-nt-formComponent1__input ~ .-nt-formComponent1__icon{
	position: absolute;
	top: 0;
	right: 1em;
	bottom: 0;
	margin: auto;
	
	width: .5em;
	height: .5em;
	
	border-style: solid;
	border-color: #259899;
	border-width: 0 1px 1px 0;
	
	transform: rotate(45deg);
	pointer-events: none;
}
select.-nt-formComponent1__input.-nt-is-error{
	border-color: #FF9100;
	background-color: #fee0ba;
}
select.-nt-formComponent1__input.-nt-is-error ~ .-nt-formComponent1__icon{
	border-color: #FF9100;
}



.-nt-formComponent2{
	cursor: pointer;
	display: inline-flex;
	align-items: center;
	position: relative;
	
	max-width: 100%;
	box-sizing: border-box;
}
.-nt-formComponent2__icon{}
.-nt-formComponent2__note{}

.-nt-formComponent2__input:disabled ~ .-nt-formComponent2__icon,
.-nt-formComponent2__input:disabled ~ .-nt-formComponent2__note{
	opacity: .3;
}
/* checkbox */
.-nt-formComponent1__input[type=checkbox]{
	display: none;
}
.-nt-formComponent1__input[type=checkbox] ~ .-nt-formComponent1__icon{
	width: 1em;
	height: 1em;
	line-height: 1em;
	margin-right: .25em;
	
	border-radius: 4px;
	border: 1px solid #ccc;
	background-color: #fff;
	
	transition: 
		ease-out 75ms background-color;
}
.-nt-formComponent1__input[type=checkbox]:checked ~ .-nt-formComponent1__icon{
	/*background-color: #259899;
	border-color: #ccc;*/
	border-color: #259899;
}
.-nt-formComponent1__input[type=checkbox] ~ .-nt-formComponent1__icon:before{
	content: "✓";
	
	color: #259899;
	display: block;
	visibility: hidden;
	font-size: 1.25em;
	transform: translate(.125em, -.125em);
}
.-nt-formComponent1__input[type=checkbox]:checked ~ .-nt-formComponent1__icon:before{
	visibility: visible;
}
.-nt-formComponent1__input[type=checkbox].-nt-is-error ~ .-nt-formComponent1__icon{
	border-color: #FF9100;
	background-color: #FEE0BA;
}
.-nt-formComponent1__input[type=checkbox].-nt-is-error ~ .-nt-formComponent1__icon:before{
	color: #000;
}
/* radio */
.-nt-formComponent2__input[type=radio],
.-nt-formComponent2__input[type=checkbox]{
	display: none;
}
.-nt-formComponent2__input[type=radio] ~ .-nt-formComponent2__icon,
.-nt-formComponent2__input[type=checkbox] ~ .-nt-formComponent2__icon{
	display: none;
}
.-nt-formComponent2__input[type=radio] ~ .-nt-formComponent2__note,
.-nt-formComponent2__input[type=checkbox] ~ .-nt-formComponent2__note{
	cursor: pointer;
	display: block;
	padding: .25em .75em;
	box-sizing: border-box;
	border-radius: 5px;
	
	color: inherit;
	font-size: .875em;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	background-color: #F1F2F3;
	
	transition:
		75ms ease-out color,
		75ms ease-out background-color,
		75ms ease-out opacity;
	
}
.-nt-formComponent2__input[type=radio].-nt-is-error ~ .-nt-formComponent2__note,
.-nt-formComponent2__input[type=checkbox].-nt-is-error ~ .-nt-formComponent2__note{
	border-color: #ff9100;
	background-color: #fee0ba;
}
.-nt-formComponent2__input[type=radio]:checked ~ .-nt-formComponent2__note,
.-nt-formComponent2__input[type=checkbox]:checked ~ .-nt-formComponent2__note{
	color: #fff;
	background-color: #0066b3;
}
.-nt-button2{
	cursor: pointer;
	display: block;
	padding: .25em .75em;
	box-sizing: border-box;
	border-radius: 5px;
	
	color: inherit;
	font-size: .875em;
	font-weight: 500;
	text-align: center;
	text-decoration: none;
	background-color: #F1F2F3;
	
	transition:
		75ms ease-out color,
		75ms ease-out background-color,
		75ms ease-out opacity;
	
	height: 100%; /* for button frame (flex) layout */
}

button.-nt-button2{
	border: 0;
	width: 100%;
}
.-nt-button2[disabled]{
	opacity: .25;
	pointer-events: none;
}
.-nt-button2[lang=en]{
	font-weight: normal;
	padding-bottom: .35em;
}
.-nt-button2:hover,
.-nt-button2--active,
.-nt-button2.-nt-js-tab_switch.-nt-is-active{
	color: #fff;
	background-color: #0066b3;
}
.-nt-button2--active{
	pointer-events: none;
}
.-nt-button2--pdf,
.-nt-button2--pdf:hover{
	color: #fff;
	background-color: #CE1923;
}
.-nt-button2--pdf:hover{
	opacity: .75;
}
.-nt-button2--excel,
.-nt-button2--excel:hover{
	color: #fff;
	background-color: #106B37;
}
.-nt-button2--excel:hover{
	opacity: .75;
}
.-nt-button2--word,
.-nt-button2--word:hover{
	color: #fff;
	background-color: #2D5C9F;
}
.-nt-button2--word:hover{
	opacity: .75;
}
.-nt-button2--skin1,
.-nt-button2--skin1:hover{
	color: #fff;
	background-color: #FFAE00;
}
.-nt-button2--skin1:hover{
	opacity: .75;
}
.-nt-button2--skin2,
.-nt-button2--skin2:hover{
	color: #fff;
	background-color: #259899;
}
.-nt-button2--skin2:hover{
	opacity: .75;
}

/* ------------------------------------------------------------------ step3 */
.required-label {
	font-size: 14px;
	color: #d63637;
}

.post_content .web-booking.web-booking--step3 h4 {
    margin: 3em 0 1.5em !important;
	padding-bottom: 8px;
    font-size: 20px;
	border-bottom: 1px solid #999;
}
.post_content .web-booking table {
	font-size: 14px;
}

.web-booking--step3 fieldset.web-booking__form-field input[type=text],
.web-booking--step3 fieldset.web-booking__form-field input[type=tel],
.web-booking--step3 fieldset.web-booking__form-field input[type=email] {
	width: 16em;
	padding: 4px 8px;
	border: 1px solid rgba(0, 0, 0, 0.25);
    border-radius: 2px;
}
.web-booking--step3 fieldset.web-booking__form-field {
	display: block;
	line-height: 1.2;
}
.web-booking--step3 .wb-l-label {
	display: inline-block;
	width: 8em;
}
.web-booking--step3 h5 {
	margin: 2em 0 1em;
}
.web-booking--step3 .web-booking-radio {
	display: flex;
	margin-bottom: 8px;
}
.web-booking-input--fw {
	width: 100% !important;
}
.web-booking-input--textarea {
	width: 100%;
}
.web-booking__form-back {
    background-color: #aaa;
    padding: .75em;
    width: 320px;
    line-height: 1.5;
    color: #fff;
    letter-spacing: .5em;
    font-weight: 700;
    cursor: pointer;
    border: 2px solid #aaa;
    border-radius: 4px;
    transition: opacity .2s ease;
}
.web-booking__form-back:hover {
    opacity: .7;
}
.web-booking__form-ctrls {
	display: flex;
	align-items: center;
}
.web-booking__form-ctrls button {
	margin-right: 20px;
	margin-bottom: 20px;
}
.web-booking__form-ctrls button:last-child {
	margin-right: 0;
}
.web-booking__form-ctrls--justify-center {
	justify-content: center;
}
.web-booking-note--hint {
	font-size: 12px;
	font-weight: 400;
	color: #666;
}
.web-booking-note--important {
	font-size: 12px;
	font-weight: 400;
	color: #c00;
}
/* ------------------------------------------------------------------ step4 */
.web-booking--step4 {
	text-align: center;
}
.web-booking-tks {
	font-size: 14px;
	font-weight: 500;
	margin-bottom: 40px;
}
.web-booking-noti {
	font-size: 14px;
	font-weight: 500;
	color: #c00;
	margin-bottom: 40px;
}
.web-booking__form-back2 {
	display: inline-block;
    padding: .75em;
    width: 320px;
    line-height: 1.5;
    color: #333;
    letter-spacing: .5em;
    font-weight: 700;
    cursor: pointer;
    border: 2px solid #333;
    border-radius: 4px;
	background-color: transparent;
    transition: opacity .2s ease;
}
.web-booking__form-back2:hover {
    opacity: .7;
}
.web-booking-num {
	margin: 20px;
}
.web-booking-num__txt {
	font-size: 18px;
	font-weight: 700;
}
.web-booking-num__cont span {
	display: inline-block;
	padding: 8px 48px;
	background-color: #eee;
	font-size: 18px;
	font-weight: 700;
}
/* ------------------------------------------------------------------ flow */
.post_content .flex-start {
    display: flex;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    justify-content: flex-start;
}
.post_content .current_state{
	max-width: 780px;
	width: 100%;
	height: auto;
	margin: 60px auto 60px;
}
.post_content .flow ul.flex-start{
	justify-content: space-between;
	list-style: none;
}
.post_content .flow ul li {
	width: 23.8%;
	height: 60px;
	padding-left: 12px;
	background: #E3E3E3;
	font-size: .9rem;
	font-weight: 700;
	text-align: center;
	line-height: 60px;
	position: relative;
	color:#212121;
}
.post_content .flow ul li:before {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 0 30px 24px;
	border-color: transparent transparent transparent #fff;
	position: absolute;
	top: 0;
	left: 0;
}
.post_content .flow ul li:after {
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 30px 0 30px 24px;
	border-color: transparent transparent transparent #E3E3E3;
	position: absolute;
	top: 0;
	right: -24px;
	z-index: 1;
}
.post_content .flow ul li:nth-child(1):before {
	display: none;
}
.post_content .flow ul li:nth-child(4):after {
	display: none;
}
.post_content .flow ul li.on {
	background: #0066b3;
	color:#fff;
}
.post_content .flow ul li.on:after {
	border-color: transparent transparent transparent #0066b3;
}

.hidden {
	display: none;
}

/* overwrite contact form 7 */
.wpcf7-list-item {
	display: block !important;
	margin: 0 0 .6em !important;
}
span.wpcf7-not-valid-tip {
	display: inline-block !important;
	font-size: 12px;
	margin-left: 12px;
}
span.wpcf7-not-valid-tip:before {
	content: '*';
}