@charset "UTF-8";
/*-----------------------------------------------
	ttl
-----------------------------------------------*/
.form-ttl-main{
	position: relative;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.3;
	letter-spacing: 0.04em;
	width: 100%;
	padding: 2px 0 2px 12px;
	margin: 25px 0 15px;
	border-left: 4px solid #00ADC6;
}
.form-subttl{
	font-size: 1.8rem;
	font-weight: bold;
	margin: 30px 0 10px 0;
}
.form-subttl .necessary{
	display: inline-block;
	float: none;
	margin-left: 8px;
	vertical-align: middle;
}

.form-ttl-main .necessary {
	display: inline-block;
	float: none;
	margin-left: 5px;
	text-indent: 0;
	vertical-align: top;
}

.form-subtext{
	margin: 5px 0 15px;
}

.consul-flowtext {
	font-size: 1.4rem;
	padding: 11px 18px 8px;
	margin: 25px 0 60px;
	text-align: left;
	border: 1px dotted #FA2D37;
	color: #FA2D37;
}

@media only screen and (max-width: 767px){
	.consul-flowtext {
	font-size: 1.2rem!important;
	padding: 10px 15px;
	margin: 20px 0 40px;
	}
}
@media screen and (min-width:767px) {
	.form-ttl-main{
		font-size: 2.0rem;
		padding: 2px 0 0 16px;
		margin: 30px 0 15px;
	}
	.form-ttl-main .necessary{
		margin-left: 15px;
	}
	.form-subttl{
		font-size: 2.0rem;
	}
	.form-subtext{
		margin: 10px 0 20px;
	}
	.form-ttl-main::after{
		top: 0;
		margin: auto;
	}
}


/*-----------------------------------------------
	table
-----------------------------------------------*/
.tbl-basis{
	border: 2px solid #E6E6E6;
	width: 100%;
}
.form-block__product{
	margin-bottom: 30px;
}
.check-block{
	margin-top: 10px;
}
.check-block .check-block__col{
	margin-bottom: 15px;
}
.check-block th{
	display: block;
	text-align: center;
	padding: 8px 0 10px;
	background: #F7F7F7;
}
.check-block th input{
	height: 22px;
	width: 22px;
	margin-bottom: 0;
}
.check-block td{
	display: block;
	padding: 5px;
	color: #fff;
}
.check-block__item img{
	max-width: 200px;
	height: 100px;
	display: inline-block;
}
.check-block tr:first-child td{
	color: #fff;
}
.check-block__smile_nexta{background: #ed6d34;}
.check-block__smile_wide{background: #f26255;}
.check-block__smile_seven{background: #1495cc;}
.check-block__anshin_kaigo{background: #2953a6;}

.check-block .check-block__item{
	color: #333!important;
	padding: 15px 10px;
  /* width: 83%; */
	text-align: center;
}
.check-block .check-block__img{
	display: flex;
	justify-content: center;
	align-items: center;
	margin: 0 auto 12px;
}
@media screen and (min-width:767px) {
	.check-block{
		display: flex;
		flex-wrap: wrap;
	}
	.check-block .check-block__col{
		width: calc(100% / 2 - 10px);
		margin: 0 20px 20px 0;
	}
	.check-block .check-block__col:nth-child(even){
		margin: 0 0 20px 0;
	}
	.check-block .check-block__img {
		height: 100px;
	}
	.check-block .check-block__item{
		padding: 16px 10px 12px;
	}
}
@media screen and (max-width:767px) {
	.check-block__item img{
		height: 80px;
	}
	.check-block th input{
		height: 18px;
		width: 18px;
	}
}

.iryo-check th{background: #fff6fb;}
.iryo-check td{background: #e8437e;}
.chronic-check th{background: #fde8d0;}
.chronic-check td{background: #f39800;}
.ichiji-check th{background: #ffebeb;}
.ichiji-check td{background: #ed3b3b;}
.desease-check th{background: #ecfff9;}
.desease-check td{background: #00a67b;}

.contact footer{margin-bottom: 0;}

/*-----------------------------------------------
	form-block
-----------------------------------------------*/
.form-block {
	display: table;
	font-size: 1.6rem;
	width: 100%;
	border-bottom: 1px solid #D9D9D9;
}
.form-block input[type="radio"] {
	margin: 3px 3px 0px 5px;
}

.form-block .cell-w {
	display: table-cell;
	background: #f2f2f2;
	width: 310px;
	padding: 15px;
	border-left: 1px solid #D9D9D9;
	font-weight: bold;
	vertical-align: top;
}

.form-block .cell-s {
	display: table-cell;
	background: #F0F0F0;
	width: 100px;
	padding: 15px;
	border-right: 1px solid #D9D9D9;
	border-left: 1px solid #D9D9D9;
	font-weight: bold;
	vertical-align: top;
}

.form-block .cell-r {
  display: table-cell;
  border-right: 1px solid #D9D9D9;
  vertical-align: top;
}

.form-block .cell-inner {
  padding: 15px;
}

.block-bottom {
  border-bottom: 1px solid #D9D9D9;
	margin-bottom: 20px;
}
.block-top {
	border-top: 1px solid #D9D9D9;
}

.form-block input,
.form-block select {
  /* margin-bottom: 10px; */
}

.form-block-child {
  display: table;
  width: 100%;
  border-bottom: 1px solid #D9D9D9;
}

.form-block-child:last-child {
  border-bottom: none;
}

.form-block-child dt {
  display: table-cell;
  background: #f5f5f5;
  width: 210px;
  padding: 15px;
  font-weight: bold;
  vertical-align: top;
}

.form-block-child dd {
  display: table-cell;
  padding: 15px;
  vertical-align: top;
}

@media screen and (min-width:767px) {
  .border-rad-t{
	border-radius: 5px;
  }
  .border-rad-b {
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
  }
  .border-rad-tl{
	border-top-left-radius: 5px;
  }
  .border-rad-tr{
	border-top-right-radius: 5px;
  }
  .border-rad-bl{
	border-bottom-left-radius: 5px;
  }
  .border-rad-br{
	border-bottom-right-radius: 5px;
  }
}
@media only screen and (max-width: 767px) {
  .form-block {
	display: block;
	border-top: 2px solid #cccccc;
  }
  .form-block .cell-w {
	display: block;
	background: #f2f2f2;
	width: 100%;
	padding: 10px;
	border-left: none;
  }
  .form-block .cell-s {
	display: block;
	background: #f2f2f2;
	width: 100%;
	padding: 10px;
	border-right: none;
	border-left: none;
	border-bottom: 2px solid #fff;
  }
  .form-block .cell-r {
	display: block;
	border-right: none;
  }
  .form-block .cell-inner {
	padding: 10px 0;
  }
  .form-block-child {
	display: block;
	width: 100%;
	border-bottom: none;
  }
  .form-block-child dt {
	display: block;
	width: 100%;
	padding: 10px;
  }
  .form-block-child dd {
	display: block;
	padding: 10px 0;
  }
}

.zip_link {
	color: #0090d9!important;
	text-decoration: underline;
	font-size: 1.4rem;
}
@media screen and (min-width:767px) {
	.zip_link {
		padding-left: 12px;
	}
}

/*-----------------------------------------------
	layout
-----------------------------------------------*/
.flex-formItem,
.flex-name,
.flex-zip,
.flex-address,
.flex-tel,
.flex-date {
	display: -webkit-box;
	display: flex;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}

@media only screen and (max-width: 767px) {
	.flex-formItem {
		-ms-flex-wrap: wrap;
		-webkit-flex-wrap: wrap;
		flex-wrap: wrap;
	}
}

/* お名前 */
.flex-name {
	width: 100%;
}

.flex-name:first-child {
	margin-right: 20px;
}

.flex-name span:first-child {
	width: 45px;
}

.flex-name span:last-child {
	width: calc(100% - 45px);
}

@media only screen and (max-width: 767px) {
	.flex-name {
		margin-right: 0;
	}

	.flex-name:first-child {
		margin-right: 0;
		margin-bottom: 10px;
	}

	.flex-name dt {
		width: 45px;
	}

	.flex-name dd {
		width: 100%;
	}
}

/* ご住所＿郵便番号 */
.flex-zip {
	display: flex;
	align-items: center;
	flex-direction: row;
	/* margin-right: 10px; */
}

.flex-zip input {
	width: 100px;
	margin-left: 10px;
}

.input-post__search {
	font-size: 14px;
	margin-left: 12px;
}

a.form-outerlink {
	display: inline-block;
	text-decoration: underline;
	padding-right: 1.4em;
	background-image: url(../img/icon/ico_blank.svg);
	background-size: 1em 1em;
	background-position: center right;
	background-repeat: no-repeat;
	color: #1D3994;
}

/* 電話番号 */
.flex-tel input:nth-child(1),
.flex-tel input:nth-child(2),
.flex-tel input:nth-child(3) {
	width: 80px;
}

.input-tel1,
.input-tel2 {
	margin-right: 30px;
	position: relative;
}

.input-tel1:after,
.input-tel2:after {
	content: '';
	width: 10px;
	height: 1px;
	background: #9a9a9a;
	position: absolute;
	display: block;
	top: 0;
	bottom: 0;
	margin: auto;
	right: -20px;
}

@media only screen and (max-width: 767px) {
	.flex-tel {
		-webkit-box-pack: justify;
		-ms-flex-pack: justify;
		justify-content: space-between;
		max-width: 400px;
	}

	.flex-tel input:nth-child(1),
	.flex-tel input:nth-child(3),
	.flex-tel input:nth-child(5) {
		width: 100%;
	}

	.input-tel1:after,
	.input-tel2:after {
		width: 12px;
		right: -21px;
	}
}

/* 生年月日 */
.flex-date span {
	box-sizing: border-box;
	width: 45px;
	padding-left: 10px;
}

.flex-date:first-child select {
	width: 140px;
}

@media only screen and (max-width: 767px) {
	.flex-date:not(:last-child) {
		margin-right: 10px;
	}

	.flex-date span {
		width: auto;
		padding-left: 8px;
	}
}

/* メールアドレス */
input[name="email"] {
	max-width: 400px;
	outline: none;
	border: 1px solid #c2cad3;
	padding: 8px;
	font-size: 1.6rem;
	border-radius: 3px;
	box-shadow: inset 0 2px 1px rgba(0, 0, 0, 0.075);
	transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;
}

/* アンケート */
.questionList>div:not(:last-of-type) {
	margin-bottom: 3px;
}

/* その他　ご質問・ご要望など */
textarea[name="other"] {
	display: block;
	font-family: "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, sans-serif;
	height: 150px;
	resize: vertical;
}

@media only screen and (max-width: 767px) {
	textarea[name="other"] {
		height: 100px;
	}
}

/* ラジオボタン リスト */
.form-block .radio-block__col {
	display: block;
}

.form-block .radio-block__col:not(:first-of-type) {
	margin-top: 3px;
}

/* チェックボックス リスト */
.form-block .check-block__col:not(:first-of-type) {
	margin-top: 5px;
}


/* 相談方法 / 希望日程 */
.radioList li {
	display: inline-block;
}

.radioList li:not(:last-of-type) {
	margin: 0 20px 0 0;
}

@media screen and (max-width:767px) {
	.radioList li {
		display: list-item;
	}

	.radioList li:not(:last-of-type) {
		margin: 0 0 5px 0;
	}
}

.input-ex {
	display: block;
	color: #808080;
	margin: 7px 0 0 -0.3em;
}


/*-----------------------------------------------
	form parts
-----------------------------------------------*/
textarea {
	resize: none;
	height: 150px;
}

.notice-box {
	background: #e6e6e7;
	border-radius: 5px;
	padding: 10px;
	font-size: 1.2rem;
	margin-top: 15px;
}

.err-txt {
	color: #df0d0e;
}
.form-block .err-txt {
	font-size: 1.2rem;
	margin-top: 8px;
}
.form-block .err-txt + .err-txt {
	margin-top: 3px;
}
@media screen and (min-width:767px) {
	.form-block .err-txt {
		font-size: 1.4rem;
	}
}

.err-block {
	padding: 15px;
	background: #ffebeb;
	border: 1px dashed #f2264c;
	margin: 15px 0 15px 0;
}

.err-block__ttl {
	color: #f2264c;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	margin-bottom: 8px;
}

.err-block > ul li {
	color: #f2264c;
	margin-bottom: 3px;
}

.err-block > p {
	color: #f2264c;
	display: table;
	position: relative;
	padding-left: 40px;
	text-align: left;
}

@media screen and (min-width:767px) {
	.err-block {
		padding: 20px 25px;
	}

	.err-block__ttl {
		font-size: 2.0rem;
		margin-bottom: 10px;
	}
}

.note-hyphen {
	font-size: 1.2rem;
}

@media screen and (min-width:767px) {
	.note-hyphen {
		display: block;
		margin-left: -5px;
	}
}

.len-vshort {
	width: 80px;
}

.len-short {
	width: 100px;
}

.len-middle {
	width: 200px;
}

.len-long {
	width: 400px;
}

.len-wide {
	width: 100%;
}

.float-item {
	float: left;
	margin-right: 10px;
}

span.float-item,
label.float-item {
	margin-top: 5px;
}

input[type="radio"].float-item {
	margin-top: 10px;
	margin-right: 3px;
}
@media only screen and (max-width: 320px) {
	.float-item{float: none!important;}
}

.necessary {
	display: block;
	float: right;
	background: #FA2D37;
	color: #fff;
	font-size: 1.2rem;
	padding: 3px 8px;
	border-radius: 15px;
	line-height: 1.4;
}

.optional {
	display: block;
	float: right;
	background: #8f98a3;
	color: #fff;
	font-size: 1.2rem;
	padding: 3px 8px;
	border-radius: 15px;
	line-height: 1.4;
}

.pri {
	background-color: #fff;
	border: 1px solid #E6E6E6;
	height: 150px;
	border-radius: 5px;
	overflow-x: hidden;
	overflow-y: scroll;
	padding: 12px 20px;
	font-size: 1.2rem;
}

.pri::-webkit-scrollbar {
	width: 6px;
}

.pri::-webkit-scrollbar-track {
	border-radius: 5px;
	background: #eee;
}

.pri::-webkit-scrollbar-thumb {
	border-radius: 5px;
	background: #666;
}

@media only screen and (max-width: 767px) {
	textarea {
		height: 100px;
	}
	.len-long {
		width: 100%;
	}
	.job-item{
		width: 100%;
	}
}

/*-----------------------------------------------
	button
-----------------------------------------------*/
#stepLast {
	padding: 15px;
	position: relative;
}
#stepLast p {
	text-align: center;
	margin-bottom: 15px;
	font-size: 1.2rem;
}
@media screen and (min-width:767px) {
	#stepLast p {font-size: 1.4rem;}
}

.btn-next,
.btn-unanswered,
.btn-send {
	position: relative;
	display: block;
	font-size: 2.0rem;
	font-weight: bold;
	letter-spacing: 2px;
	padding: 15px;
	border-radius: 3px;
	cursor: pointer;
}

.btn-next {
	color: #fff;
	width: 400px;
	margin: 0 auto;
	background-color: #FA2D37;
	box-shadow: rgba(217, 43, 43, 1) 0px 3px 0;
}
.btn-next:hover {
	opacity: 0.7;
	text-decoration: none;
}
@media only screen and (max-width: 767px) {
	.btn-next:hover {
		opacity: 1.0;
	}
	.btn-next, .btn-unanswered, .btn-send{
		font-size: 1.8rem;
		padding: 15px;
		letter-spacing: inherit;
	}
}

.btn-unanswered {
	background: #fff;
	border: 2px solid #FA2D37;
	width: 400px;
	margin: 0 auto;
	color: #FA2D37;
}

.btn-send {
	color: #fff;
	width: 400px;
	margin: 0 auto;
	background-color: #FA2D37;
	box-shadow: rgba(217, 43, 43, 1) 0px 3px 0;
}
.btn-send:hover {
	opacity: 0.7;
	text-decoration: none;
}
@media only screen and (max-width: 767px) {
	.btn-send:hover {
		opacity: 1.0;
	}
}

.btn-back {
	position: absolute;
	display: block;
	color: #333;
	font-size: 1.6rem;
	font-weight: bold;
	letter-spacing: 3px;
	width: 100px;
	height: 40px;
	left: 15px;
	top: 0;
	bottom: 0;
	margin: auto;
	background-color: #fff;
	border: 1px solid #dfdfdf;
	border-bottom: 2px solid #bbb;
	border-radius: 3px;
}
.btn-back:hover {
	opacity: 0.7;
	text-decoration: none;
}
@media only screen and (max-width: 767px) {
	.btn-back:hover {
		opacity: 1.0;
	}
}

@media only screen and (max-width: 767px) {
	.btn-next,
	.btn-unanswered,
	.btn-send {
		width: 100%;
	}
	.btn-back {
		position: static;
		margin-top: 20px;
	}
}

/*-----------------------------------------------
	STEP
-----------------------------------------------*/
.form-flow {
	font-size: 1.6rem;
	line-height: 1.2;
	margin: 0 auto 56px;
	width: 900px;
}

.form-flow::after {
	content: "";
	display: block;
	clear: both;
}

.form-flow li {
	width: 300px;
	text-align: center;
	float: left;
	font-weight: bold;
	vertical-align: middle;
	height: 65px;
	padding-top: 18px;
	position: relative;
	color: #00008F;
}

.form-flow li:nth-child(1) {
	border-top: solid 1px #00008F;
	border-left: solid 1px #00008F;
	border-bottom: solid 1px #00008F;
}

.form-flow li:nth-child(1):before {
	position: absolute;
	margin: auto;
	content: "";
	width: 0;
	height: 65px;
	border-right: 1px solid #00008F;
	top: 0;
	bottom: 0;
	right: -1px;
	z-index: 10;
}

.form-flow li:nth-child(1):after {
	position: absolute;
	margin: auto;
	content: "";
	background: #fff;
	width: 15px;
	height: 15px;
	border-top: 1px solid #00008F;
	border-right: 1px solid #00008F;
	top: 0;
	bottom: 0;
	right: -8px;
	transform: rotate(45deg);
	z-index: 20;
}

.form-flow li:nth-child(2) {
	border-top: solid 1px #00008F;
	border-bottom: solid 1px #00008F;
}

.form-flow li:nth-child(2):before {
	position: absolute;
	margin: auto;
	content: "";
	width: 0;
	height: 65px;
	border-right: 1px solid #00008F;
	top: 0;
	bottom: 0;
	right: -1px;
	z-index: 10;
}

.form-flow li:nth-child(2):after {
	position: absolute;
	margin: auto;
	content: "";
	background: #fff;
	width: 15px;
	height: 15px;
	border-top: 1px solid #00008F;
	border-right: 1px solid #00008F;
	top: 0;
	bottom: 0;
	right: -8px;
	transform: rotate(45deg);
	z-index: 20;
}

.form-flow li:nth-child(3) {
	border-top: solid 1px #00008F;
	border-right: solid 1px #00008F;
	border-bottom: solid 1px #00008F;
}

.form-flow li.current {
	border-color: #00008F;
	color: #fff;
	background: #00008F;
}

.form-flow li.arrow-current:after {
	border-color: #00008F;
	background: #00008F;
}

.form-flow li.arrow-current:before {
	border-color: #00008F;
}

.form-flow__no {
	font-size: 2.2rem;
	padding-left: 3px;
	margin-right: 10px;
}
.form-flow__text {
	font-size: 1.8rem;
}

@media only screen and (max-width: 767px) {
	.form-flow {
		width: 90%;
		min-width: 300px;
		margin: 0 auto 40px;
	}
	.form-flow li {
		height: 70px;
		width: 33%;
		text-align: left;
		font-size:1.4rem;
	}
	.form-flow li:nth-child(1) {
		padding: 3px 10px 0 10px;
	}
	.form-flow li:nth-child(1):before {
		height: 70px;
	}
	.form-flow li:nth-child(1):after {
		width: 12px;
		height: 12px;
		right: -8px;
	}
	.form-flow li:nth-child(2) {
		padding: 3px 10px 0 20px;
	}
	.form-flow li:nth-child(2):before {
		height: 70px;
	}
	.form-flow li:nth-child(2):after {
		width: 12px;
		height: 12px;
		right: -8px;
	}
	.form-flow li:nth-child(3) {
		padding: 3px 10px 0 20px;
	}
	.form-flow__text {
		font-size:1.4rem;
	}
}

/*-----------------------------------------------
	資料請求はお電話でも承ります
-----------------------------------------------*/
.form-box__tel {
	position: relative;
	display: flex;
	justify-content: center;
	align-items: center;
	width: 72%;
	padding: 10px;
	margin: 30px auto 50px;
}

.form-box__tel::before,
.form-box__tel::after {
	position: absolute;
	top: 0;
	width: 12px;
	height: 100%;
	content: '';
	border-top: solid 1px #00008F;
	border-bottom: solid 1px #00008F;
}

.form-box__tel::before {
	border-left: solid 1px #00008F;
	left: 0;
}

.form-box__tel::after {
	border-right: solid 1px #00008F;
	right: 0;
}

.form-box__tel__desc {
	color: #00008F;
	font-size: 1.6rem;
	font-weight: bold;
	line-height: 1.5;
	text-align: center;
}

.form-box__tel__info {
	display: block;
	font-size: 1.2rem;
	font-weight: normal;
}

.form-box__tel a {
	display: flex;
	align-items: center;
	justify-content: center;
	cursor: default;
}

.form-box__tel__num {
	display: flex;
	align-items: center;
	font-family: Arial, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, "メイリオ", Meiryo, sans-serif;
	color: #00008F;
	font-size: 3.2rem;
	line-height: 1.2;
	text-align: center;
	margin: 0 0 0 6px;
}

.form-box__tel__free {
	color: #fff;
	font-size: 1.2rem;
	font-weight: normal;
	padding: 4px 8px;
	margin: 0 0 0 5px;
	background-color: #00008F;
	border-radius: 15px;
}

.form-box__tel img {
	width: 30px;
	height: 35px;
}

@media only screen and (min-width: 768px) {
	.form-box__tel__desc {
		font-size: 1.8rem;
		padding: 0 15px 0 0;
		margin: 0 20px 0 0;
		border-right: 1px solid #00008F;
	}

	.form-box__tel a {
		padding: 5px 0;
	}

	.form-box__tel__num {
		letter-spacing: 0.02em;
	}

	.form-box__tel__free {
		padding: 6px 8px;
		margin: 0 0 0 10px;
	}
}

@media only screen and (max-width: 767px) {
	.form-box__tel {
		flex-direction: column;
		width: auto;
		padding: 5px;
		margin: 20px auto 30px;
	}
}

/*-----------------------------------------------
	個人情報の取り扱い
-----------------------------------------------*/
.board {
	margin: 20px 0;
}

.board .board-ttl {
	background: #49494D;
	color: #fff;
	font-size: 1.8rem;
	font-weight: bold;
	padding: 8px 15px 6px;
}

.board .board-inner {
	border-bottom: 1px solid #D9D9D9;
	border-right: 1px solid #D9D9D9;
	border-left: 1px solid #D9D9D9;
	padding: 20px;
}

.board .board-inner::after {
	content: "";
	display: block;
	clear: both;
}

.top-page .board-inner .line2 {
	width: 216px;
	float: left;
	line-height: 1.2;
	margin-bottom: 14px;
}

.top-page .board-inner .line2:last-child {
	margin-bottom: 0;
}

.top-page .board-inner .line2 .panel-icon {
	float: left;
	margin: 0 15px 0 10px;
}

.top-page .board-inner .line2 h3 {
	float: left;
}

.board.pamph img {
	border: 1px solid #ddd;
}

@media only screen and (max-width: 767px) {
	.board {
		margin-bottom: 15px;
	}
	.board .board-ttl {
		font-size: 1.6rem;
		padding: 8px 10px 6px;
	}
	.board .board-inner {
		padding: 10px;
	}

	.top-page .board-inner .line2 {
		width: 100%;
		margin: 0 0 10px 0 !important;
	}
	.top-page .board-inner .line2 .panel-icon {
		float: left;
		margin: 0 10px 0 0;
	}
	.top-page .board-inner .line2 h3 {
		float: none;
	}
}



/*-----------------------------------------------
	thanks
-----------------------------------------------*/
.thanks-box {
	text-align: center;
}

.thanks-box .thanks-ttl {
	color: #00008F;
	font-size: 2.6rem;
	margin-bottom: 15px;
}

.thanks-box .thanks-link {
	margin-top: 30px;
}

@media only screen and (max-width: 767px) {
	.thanks-box {
		width: 100%;
		padding: 0 15px;
	}
	.thanks-box .thanks-ttl {
		font-size: 1.8rem;
	}
	.thanks-box .thanks-link {
		margin-top: 10px;
	}
}

/** コンテンツの表示非表示
*****************************************************************/
@media screen and (max-width: 767px) {
	.sp-hide{ display: none !important; }
}
@media screen and (min-width: 768px) {
	.sp-show { display: none !important;}
}

/* consul（PC） */
ul.flow {
	display: flex;
	justify-content: space-between;
	margin-top: 20px;
}
.flow li { /* コンテンツブロック */
	border: #E6F3F5 3px solid;
	width: 34%;
	text-align: center;
	padding: 15px 20px;
	position: relative;
}
.flow li:first-child,
.flow li:last-child {
	width: 28%;
}
.flow li:not(:last-child):after {
	content: '';
	position: absolute;
	display: block;
	width: 0;
	height: 0;
	right: -40px;
	top: 0;
	bottom: 0;
	margin: auto;
	border-left: 20px solid #FAE789;
	border-top: 24px solid transparent;
	border-bottom: 24px solid transparent;
}
.flow li .step_img { /* アイコン */
	width: 70px;
	margin: 0 auto;
}
.flow li:nth-child(2) .step_img { /* アイコン */
	width: 85px;
}
.flow li dt.step_title { /* タイトル */
	color: #00ADC6;
	font-size: 1.8rem;
	font-weight: bold;
	line-height: 1.4;
	text-align: center;
	margin: 8px auto 5px;
}
.flow li dt.step_title span { /* タイトル */
	font-size: 1.4rem;
}
.flow li dd.step_text { /* 説明 */
	text-align: left;
}

  /* consul（SP） */
@media only screen and (max-width: 767px) {
	ul.flow {
	display: block;
	margin-top: 10px;
	}
  .flow li { /* コンテンツブロック */
	width: 100% !important;
	padding: 12px 15px;
	}
	.flow li:not(:last-child) {
	margin-bottom: 30px;
	}
	.flow li:not(:last-child):after {
	right: 0;
	left: 0;
	top: auto;
	bottom: -50px;
	border-top: 14px solid #c6e567;
	border-left: 18px solid transparent;
	border-right: 18px solid transparent;
	}
	.flow li .step_img { /* アイコン */
		width: 60px;
	}
	.flow li:nth-child(2) .step_img { /* アイコン */
	width: 75px;
	}
}

/* カレンダー */
#visit1, #visit2 {
  cursor: pointer;
}
.visit .input_wrapper {
  position: relative;
  width: 200px;
  cursor: pointer;
}
.visit .message_input_placeholder {
  pointer-events: none;
  position: absolute;
  background: url(/axalife/consul/img/icon_calendar.svg);
  background-position-x: left;
  background-repeat: no-repeat;
  top: 8px;
  left: 10px;
  width: 200px;
  padding-left: 35px;
  padding-top: 0;
  color: #999;
  height: 22px;
}
#visit1_root .picker__header,
#visit2_root .picker__header {
  display: flex;
  justify-content: center;
  cursor: text;
  align-items: center;
}
#visit1_root .picker__month,
#visit2_root .picker__month {
 order: 2;
}
#visit1_root .picker__year,
#visit2_root .picker__year {
 order: 1;
 color: #000;
 font-size: 1em;
 font-style: inherit;
}
#visit1_root .picker__year::after,
#visit2_root .picker__year::after {
  content: "年";
  font-size: 20px;
}
#visit1_root .picker__month::after,
#visit2_root .picker__month::after {
  content: "月";
  font-size: 20px;
}

#visit1_root .picker__month,
#visit1_root .picker__year,
#visit2_root .picker__month,
#visit2_root .picker__year {
	/* font-weight: 500; */
  display: inline-block;
  margin-left: .25em;
  margin-right: .25em;
  font-size: 30px;
  font-style: normal;
}

.sp { display: none;}
@media only screen and (max-width: 767px) {
  .sp { display: block }
}
label.mr_10 { margin-right: 10px;}

/* vue.js */
[v-cloak] {
	display: none;
}

/* カレンダー */
/* レイアウト・サイズ・カラー調整 */
.consul .flatpickr-calendar {
	width: auto;
	padding: 10px;
	box-shadow: rgba(0, 0, 0, 0.2) 0px 0px 10px 0;
}
.consul .flatpickr-months {
	padding-bottom: 5px;
}
.consul .flatpickr-current-month {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 0;
}
.consul .flatpickr-months .flatpickr-prev-month,
.consul .flatpickr-months .flatpickr-next-month {
	top: 10px;
	line-height: 1;
	color: #333;
	fill: #333;
}
.consul .flatpickr-months .flatpickr-prev-month:hover svg,
.consul .flatpickr-months .flatpickr-next-month:hover svg {
	fill: #00008F;
}
.consul .flatpickr-day {
	color: #333;
}
.consul .flatpickr-day.selected,
.consul .flatpickr-day.selected:hover,
.consul .flatpickr-day.selected.prevMonthDay,
.consul .flatpickr-day.selected.nextMonthDay {
	background: #00008F;
	border-color: #00008F;
}
.consul .flatpickr-day.selected:hover {
	opacity: 0.7;
}
.consul .flatpickr-innerContainer {
	font-size: 1.5rem;
}
@media screen and (min-width:768px) {
	.consul .flatpickr-innerContainer {
		font-size: 1.6rem;
	}
}

/* 年の上下ボタンを非表示にする */
.flatpickr-months .flatpickr-current-month .numInputWrapper span.arrowUp,
.flatpickr-months .flatpickr-current-month .numInputWrapper span.arrowDown {
	display: none !important;
}

/* サフィックス配置 */
.flatpickr-months .flatpickr-current-month .numInputWrapper {
	position: relative;
	display: flex;
	align-items: center;
	justify-content: center;
	width: auto;
	color: #333;
}
.flatpickr-months .flatpickr-current-month .numInputWrapper:hover {
	background: #fff;
}
.flatpickr-months .flatpickr-current-month .flatpickr-monthDropdown-months {
	color: #333;
	font-size: 1.8rem;
	margin-left: 5px;
	padding: 5px;
	box-shadow: none;
}
.flatpickr-months .flatpickr-current-month input.cur-year[disabled] {
    width: 4ch;
	color:#333;
	opacity: 1;
}
.flatpickr-months .flatpickr-current-month .numInputWrapper .cur-year {
	color:#333;
	font-size: 1.8rem;
	padding: 0;
}
.flatpickr-months .flatpickr-current-month .numInputWrapper .year-suffix {
	position: relative;
	width: auto;
    font-size: 1.8rem;
	line-height: 1;
	padding: 0;
	pointer-events: none;
	opacity: 1 !important;
	border: none;
}

.flatpickr-months .flatpickr-current-month .flatpickr-monthDropdown-months {
	font-weight: normal;
}

.flatpickr-months .flatpickr-current-month .year-display {
  display: block;
  font-size: 1.8rem;
  font-weight: normal;
  position: relative;
}

.flatpickr-months .flatpickr-current-month .numInput.cur-year {
  display: none !important;
}

.flatpickr-months .flatpickr-current-month .numInputWrapper {
  display: inline-block;
}

@media screen and (min-width:768px) {
	.flatpickr-months .flatpickr-current-month .flatpickr-monthDropdown-months,
	.flatpickr-months .flatpickr-current-month .numInputWrapper .cur-year,
	.flatpickr-months .flatpickr-current-month .numInputWrapper .year-suffix,
	.flatpickr-months .flatpickr-current-month .year-display {
		font-size: 2.0rem;
	}
}
