@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
    min-height: 785px;
    position: relative;
}
.mainVisual::after {
	position: absolute;
	bottom: -36px;
	left: 50%;
	width: 2500px;
	height: 1500px;
	content: '';
	transform: translate(-50%);
	background: url("../img/index/main_bg.png") no-repeat center bottom / 2500px auto;
}
.mainVisual .flexBox {
	margin: 0 auto;
	width: 100%;
	max-width: 1600px;
	z-index: 2;
	position: relative;
	/* display: flex;
	align-items: flex-start;
	justify-content: space-between;
	box-sizing: border-box; */
}
.mainVisual .flexBox .subBox01 {
	width: calc(100% - 374px);
}
.mainVisual .leftBox {
	width: 100%;
	max-width: 1227px;
	position: relative;
}
.mainVisual h2 {
	margin-bottom: 48px;
	margin-left: -165px;
}
.mainVisual .movieBox {
	margin: 0 auto;
    max-width: 432px;
    position: absolute;
	bottom: 16.7%;
    left: 28%;
    padding: 1px;
    border-radius: 16px;
	box-shadow: 0px 0px 3px 0px rgba(0, 0, 0, 0.6);
    box-sizing: border-box;
}
.mainVisual .movieBox .title {
	width: 85%;
    position: absolute;
    top: -40px;
    left: 50%;
    text-align: center;
    transform: translateX(-50%);
}
.mainVisual .movieBox .title img {
	width: 687px;
}
.mainVisual .movieBox .innerBox {
	height: 120px;
	background-color: #fff;
	border-radius: 15px;
	overflow: hidden;
}
.mainVisual .movieBox video {
	width: 170%;
    margin-top: -138px;
}
.mainVisual .tableBox {
	padding: 10px;
	width: 430px;
	background: linear-gradient( to left, rgba(71,180,221, 1), rgba(50,168,214,1), rgba(21,152,206,1) , rgba(1,138,201,1));
	border-radius: 10px;
	box-sizing: border-box;
	box-shadow: 0 1px 5px rgba(0,0,0,0.2) ;
	position: absolute;
	top: 75px;
    right: 45px;
}
.mainVisual .tableBox .innerBox {
	padding: 42px 15px 12px;
	background: #FBFCFE url(../img/index/inner_bg01.png) repeat left top / 15px auto;
	border-radius: 10px;
	box-shadow: 0 0 3px rgba(0,0,0,0.2);
	position: relative;
	box-sizing: border-box;
}
.mainVisual .tableBox .innerBox .img01 {
	margin: 3px auto 6px;
	width: 72px;
}
.mainVisual .tableBox .innerBox::before {
	width: 249px;
	height: 99px;
	position: absolute;
	top: -65px;
	left: 50%;
	transform: translateX(-50%);
	content: '';
	background: url(../img/index/tab_img01.png) no-repeat center center / 249px;
}
.mainVisual .tableBox .innerBox .subBox {
	margin-bottom: 10px;
}
.mainVisual .tableBox .innerBox .img {
	margin: 0 auto 5px;
	width: 72px;
	display: block;
}
.mainVisual .tableBox .innerBox h3 {
	font-size: 2.8rem;
	font-weight: 500;
	font-family: "Zen Maru Gothic", serif;
	text-align: center;
	letter-spacing: 0.05em;
}
.mainVisual .tableBox .innerBox h3 small {
	font-size: 2.2rem;
}
.mainVisual .tableBox .innerBox h3 span {
	margin-right: 3px;
	padding: 2px 9px 4px;
	color: #fff;
	display: inline-block;
	line-height: 1;
	border: 2px solid #dc961e;
	background-color: transparent;
	border-radius: 8px;
	box-sizing: border-box;
	color: #dc961e;
	font-size: 2.8rem;
	font-weight: 500;
}
.mainVisual .tableBox .innerBox .addTitle {
	margin-bottom: 5px;
	font-size: 2.25rem;
	font-weight: 700;
	font-family: "Zen Maru Gothic", serif;
	text-align: center;
	letter-spacing: 0.05em;
}
.mainVisual .tableBox .iframeBox {
	margin: 0 43px;
	height: 425px;
	overflow-y: scroll;
}
.mainVisual .tableBox .stepUl {
	margin-bottom: 15px;
	display: flex;
	justify-content: space-between;
}
.mainVisual .tableBox .stepUl li {
	width: 185px;
}
.mainVisual .tableBox .stepUl a {
	padding: 3px 5px 6px;
	display: flex;
	align-items: center;
	justify-content: center;
	color: #3DA0C9;
	font-size: 1.9rem;
	letter-spacing: 2px;
	text-align: center;
	background-color: #fff;
	border-radius: 30px;
	box-sizing: border-box;
	box-shadow: 0 1px 1px rgba(0,0,0,0.2);
	position: relative;
	pointer-events: none;
}
.mainVisual .tableBox .stepUl.on a {
	pointer-events: auto;
}
.mainVisual .tableBox .stepUl a.active {
	pointer-events: auto;
}
.mainVisual .tableBox .stepUl .on::after {
	width: 20px;
	height: 10px;
	position: absolute;
	bottom: -10px;
	left: 50%;
	transform: translateX(-50%);
	content: "";
	background: url(../img/index/arrow01.png) no-repeat center bottom / 20px;
}
.mainVisual .tableBox .stepUl span {
	margin-left: 5px;
	font-size: 2.4rem;
}
.mainVisual .tableBox .stepUl .on {
	color: #fff;
	background-color: #3DA0C9;
}
.mainVisual .mailForm .listUl {
	margin-bottom: 15px;
}
.mainVisual .mailForm .listUl>li {
	margin-top: 5px;
	border: 1px solid #EAF0F3;
	background-color: #fff;
	border-radius: 5px;
}
.mainVisual .mailForm .ttl {
	padding: 6px 6px 9px;
	font-size: 1.6rem;
	text-align: center;
	border-bottom: 1px solid #EAF0F3;
}
.mainVisual .errorMsg01,
.mainVisual .errorMsg02 {
	display: none;
}
.mainVisual .errorMsg01 .error,
.mainVisual .errorMsg02 .error {
	display: none;
}
.mainVisual .mailForm .radioList {
	padding: 10px 0 12px;
	display: flex;
	justify-content: center;
 }
.mainVisual .mailForm .radioList li {
	margin: 0 39px 0 0;
	font-size: 1.4rem;
}
.mainVisual .mailForm .radioList li:last-child {
	margin-right: 0;
}
.mainVisual .mailForm input[type="radio"] {
    display: none;
}
.mainVisual .mailForm input[type="radio"] + span {
    padding-left: 28px;
    display: inline-block;
	line-height: 20px;
    background: url("../img/index/radio_img01.png") no-repeat left center / 20px;
}
.mainVisual .mailForm input[type="radio"]:checked + span {
    background-image: url("../img/index/radio_img02.png");
}
.mainVisual .mailForm .money {
	padding: 5px 0 5px;
	display: flex;
	justify-content: center;
	align-items: center;
}
.mainVisual .mailForm .num {
    margin-right: 8px;
    padding: 4px 10px 5px;
    width: 126px;
    height: 33px;
    color: #50646e;
    font-size: 1.4rem;
    letter-spacing: 0.5px;
    border: 1px solid #EAF0F3;
    background-color: #FBFCFE;
    box-sizing: border-box;
	-webkit-appearance:none;
	appearance:none;
	box-shadow: none;
}
.mainVisual .mailForm .money p {
	font-size: 1.4rem;
}
.mainVisual .btn {
	text-align: center;
}
.mainVisual .btn a {
	padding: 10px 57px;
	width: 292px;
	height: 73px;
	display: inline-block;
	color: #fff;
	background: url(../img/index/btn_bg02.png) no-repeat left top / 292px;
	box-sizing: border-box;
	position: relative;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	transform: rotate(0.05deg);
	-ebkit-transform: rotate(0.05deg);
	font-weight: 600;
	text-shadow: 1px 1px 1px rgba(0,0,0,0.4);
}
.mainVisual .btn a:hover {
	opacity: 0.7;
}
.mainVisual .btn a::before {
    width: 43px;
    height: 43px;
    position: absolute;
    right: 16px;
    top: 50%;
    content: '';
    background: url(../img/index/arrow03.png) no-repeat right center / 43px;
    margin-top: -24px;
}
.step02 {
	display: none;
}
.mailForm .formDl {
    margin: 0 auto 16px;
    display: flex;
    flex-wrap: wrap;
}
.mailForm .formDl dt, .mailForm .formDl dd {
    margin-bottom: 5px;
    border: 1px solid #EAF0F3;
    vertical-align: top;
    background-color: #fff;
    border-collapse: collapse;
}
.mailForm .formDl dt {
    padding: 12px 6px 14px 10px;
    width: 114px;
    font-size: 1.4rem;
    box-sizing: border-box;
	letter-spacing: -0.4px;
}
.mailForm .formDl dd {
	padding: 0 5px;
    width: calc(100% - 114px);
    box-sizing: border-box;
	border-left: none;
}
.mailForm .formDl dt:last-of-type {
    margin-bottom: 0;
}
.mailForm .formDl dd:last-child {
    margin-bottom: 0;
}
.mailForm .formDl input[type="text"], .mailForm .formDl input[type="email"], .mailForm .formDl input[type="tel"], .mailForm .formDl select,.mailForm .formDl input[type="textarea"] {
    padding: 0 10px;
    width: 100%;
    height: 37px;
	color: #50646e;
    border: 1px solid #EAF0F3;
    font-size: 1.4rem;
    border-radius: 0;
    -webkit-appearance: none;
    box-sizing: border-box;
	background-color: #FBFCFE;
}
placeholder-shown {
    color: #BDC7CF;
}
::-webkit-input-placeholder {
    color: #BDC7CF;
}
:-moz-placeholder {
    color: #BDC7CF;
    opacity: 1;
}
::-moz-placeholder {
    color: #BDC7CF;
    opacity: 1;
}
:-ms-input-placeholder {
    color: #BDC7CF;
}
.mailForm .formDl select {
	background: #FBFCFE url("../img/index/arrow02.png") no-repeat right 10px center / 10px;
	color: #BDC7CF;
	-webkit-appearance:none;
	appearance:none;
	box-shadow: none;
}
.mailForm .formDl select.color {
	color: #50646e;
}
select::-ms-expand { 
	display: none;
}
.mainVisual .mailForm .submit {
	text-align: center;
}
.mainVisual .mailForm .submit input {
	padding: 10px 20px 20px;
	width: 292px;
	height: 73px;
	display: inline-block;
	color: #fff;
	font-size: 2.6rem;
	background: url(../img/index/btn_bg03.png) no-repeat left top / 292px;
	box-sizing: border-box;
	border: none;
	cursor: pointer;
	position: relative;
}
.mainVisual .mailForm .submit input::before {
	width: 40px;
	height: 40px;
	position: absolute;
	right: 20px;
	top: 50%;
	content: '';
	background: url(../img/index/arrow03.png) no-repeat right center / 40px;
}
@media all and (min-width: 897px) and (max-width: 1570px) { 
	.mainVisual .movieBox {
		width: 33%;
	}
	.mainVisual .movieBox .innerBox {
		height: 90px;
	}
	.mainVisual .movieBox video {
		margin-top: -34%;
	}
}
@media all and (min-width: 897px) and (max-width: 1280px) { 
	.mainVisual .movieBox {
		left: 27%;
	}
}
/* @media all and (min-width: 897px) and (max-width: 1400px) {
	.mainVisual .leftBox {
		max-width: 1000px;
	}
	.mainVisual .movieBox {
		bottom: 110px;
        left: 292px;
        max-width: 350px;
	}
	.mainVisual .movieBox .innerBox {
		height: 110px;
	}
	.mainVisual .movieBox video {
		width: 171%;
		margin-top: -109px;
	}
} */
/* @media all and (min-width: 897px) and (max-width: 1500px) {
	.mainVisual .flexBox {
		padding-left: 10px;
	}
	.mainVisual .leftBox {
		margin-top: 70px;
		width: 780px;
	}
	.mainVisual .movieBox {
		max-width: 712px;
		padding: 20px;
	}
	.mainVisual .movieBox video {
		margin-top: -137px;
	}
	.mainVisual .flexBox {
		max-width: 1300px;
	}
	.mainVisual .movieBox .title img {
		width: 570px;
	}
	.mainVisual .movieBox .innerBox {
		height: 100px;
	}
} */
@media all and (min-width: 897px) {
	.mainVisual .mailForm .submit input:hover {
		opacity: 0.7;
	}
}
p.thanks {
	margin-bottom: 10px;
	font-size: 1.6rem;
	text-align: center;
}
.btn.thanks a {
	padding: 16px 57px 15px 10px;
	font-size: 2rem;
}
.diagnosis {
    background: url("../img/index/bg_img.png") repeat left top;
}
.diagnosis {
    margin-top: -59px;
    padding: 129px 0 60px;
    background: url("../img/index/bg_img.png") repeat left top / cover;
}
.diagnosis .cenTxt {
    margin-bottom: 4px;
    font-size: 1.6rem;
    font-weight: 500;
    text-align: center;
    letter-spacing: 2.4px;
}
.diagnosis .cenTxt span {
    color: #dc961e;
}
.diagnosis h2 {
    margin-bottom: 31px;
    font-size: 3.4rem;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    transform: rotate(0.05deg);
    -ebkit-transform: rotate(0.05deg);
    text-align: center;
    letter-spacing: 4px;
    position: relative;
}
.diagnosis h2::before, .diagnosis h2::after {
    position: absolute;
    top: -53px;
    left: 56px;
    width: 117px;
    height: 130px;
    content: '';
    background: url("../img/index/photo01.png") no-repeat left top / 117px;
}
.diagnosis h2::after {
    background-image: url("../img/index/photo02.png");
    background-size: 111px;
    width: 111px;
    height: 151px;
    right: 54px;
    top: -76px;
    left: auto;
}
.diagnosis h2 span {
    color: #3B9FC7;
    font-size: 5rem;
    background: url("../img/index/line_img.png") repeat-x left bottom 10px/ 8px;
}
.diagnosis h2 .orange {
	color: #DB951C;
}
.diagnosis h2 small {
	font-size: 2.8rem;
}
.diagnosis .pointUl {
    display: flex;
}
.diagnosis .pointUl li {
    margin-right: 17px;
    padding-bottom: 35px;
    width: 390px;
    background-color: #fff;
    box-shadow: 1px 1px 1px rgba(0, 0, 0, 0.1);
    border-radius: 8px;
    text-align: center;
}
.diagnosis .pointUl li:nth-child(3n) {
    margin-right: 0;
}
.diagnosis .pointUl .num {
    margin: -20px auto 7px;
    padding-top: 17px;
    width: 88px;
    height: 88px;
    color: #fff;
    font-size: 1.2rem;
    font-weight: 300;
    text-align: center;
    background-color: #3DA0C9;
    border-radius: 100%;
    border: 4px solid #fff;
    box-shadow: 0px -1px 0px rgba(0,0,0,0.05);
    box-sizing: border-box;
    letter-spacing: 1px;
    line-height: 1;
    position: relative;
}
.diagnosis .pointUl .num::after {
    height: 20px;
    width: 28px;
    position: absolute;
    bottom: -8px;
    left: 50%;
    transform: translateX(-50%);
    content: '';
    background: url("../img/index/arrow01.png") no-repeat center / 28px;
}
.diagnosis .pointUl .num2 {
	margin-bottom: 14px;
}
.diagnosis .pointUl .num span {
    display: block;
}
.diagnosis .pointUl .num span {
	margin-top: 2px;
    color: #FCEF9E;
    font-size: 3.1rem;
	font-weight: 800;
}
.diagnosis .pointUl li p {
    font-size: 1.9rem;
    font-weight: 600;
    font-family: 'M PLUS Rounded 1c', sans-serif;
    transform: rotate(0.05deg);
    -ebkit-transform: rotate(0.05deg);
    letter-spacing: 2.5px;
    line-height: 1.59;
}
.diagnosis .pointUl li .num02 {
    font-size: 2.4rem;
}
.diagnosis .pointUl li .orange {
    letter-spacing: 1px;
}
.diagnosis .pointUl li .orange small {
    font-size: 1.9rem;
}
.diagnosis .pointUl li p .sml {
	font-size: 1.6rem;
}
.voice {
    padding: 70px 0 62px;
}
.voice .listUl {
	margin-top: -30px;
    display: flex;
    justify-content: space-between;
    flex-wrap: wrap;
}
.voice .listUl li {
	margin-top: 30px;
    width: 585px;
	min-height: 453px;
    background-color: #fff;
    border-radius: 8px;
    box-shadow: 1px 1px 1px rgba(0,0,0,0.1);
}
.voice .listUl .imgBox {
    margin: -15px 0 23px;
    padding: 0 11px 6px;
    display: flex;
    box-sizing: border-box;
    border-bottom: 1px solid #ECF3F4;
}
.voice .listUl .photo {
    margin-right: 18px;
    width: 130px;
    border: 4px solid #fff;
    border-radius: 100%;
}
.voice .listUl .imgBox .textBox {
    margin-top: 18px;
    display: flex;
    justify-content: space-between;
    align-items: center;
	position: relative;
}
.voice .listUl .imgBox .textBox::before {
	position: absolute;
	top: 16px;
	bottom: 0;
	left: 63px;
	height: calc(100% - 30px);
	width: 2px;
	background-color: #8CC7DF;
	content: '';
}
.voice .listUl .imgBox .textBox .name {
    margin: -5px 41px 0 0;
    color: #3C9FC8;
    font-size: 3.2rem;
    font-weight: 500;
}
.voice .listUl .imgBox .textBox .name span {
    margin-left: 3px;
    font-size: 1.6rem;
    font-weight: 300;
}
.voice .listUl .imgBox .textBox p {
    font-size: 1.4rem;
    line-height: 1.73;
    letter-spacing: 1px;
}
.voice .listUl .ttl {
	margin-bottom:11px;
	color: #3ca0c8;
	text-align: center;
	font-size: 2.1rem;
	letter-spacing: 1.5px;
}
.voice .listUl .txt {
	text-align: center;
	font-size: 1.4rem;
	line-height: 2.05;
}
.support {
	margin-bottom: 60px;
	padding-top: 70px;
}
.support .headLine02 {
	margin-bottom: 28px;
}
.support .headLine02::after {
	width: 1128px;
	background-image: url(../img/index/h2_img03.png);
	background-size: 1128px;
}
.support .doctorsBox {
	margin-bottom: 30px;
	padding: 19px 19px 17px;
	background-color: #fff;
	border-radius: 8px;
	box-sizing: border-box;
	box-shadow: 1px 1px 1px rgba(0,0,0,0.1);
	position: relative;
}
.support .doctorsBox::after {
    position: absolute;
    bottom: -23px;
    left: 50%;
    transform: translateX(-50%);
    width: 31px;
    height: 60px;
    background: url(../img/index/arrow04.png) no-repeat center bottom / 129px;
    content: '';
}
.support .doctorsBox li {
	margin: 0 3px 11px 0;
	padding: 13px 5px 16px;
	display: inline-block;
	width: 186px;
	color: #3ca0c8;
	font-size: 1.8rem;
	border: 2px solid #3C9FC8;
	box-sizing: border-box;
	border-radius: 6px;
	text-align: center;
}
.support .doctorsBox li:last-child {
	margin-right: 0;
}
.support .doctorsBox p {
	font-size: 1.8rem;
	letter-spacing: 1.5px;
	text-align: center;
}
.support .doctorsBox p span {
	font-size: 2.1rem;
}
.support .doctorsBox p .blue {
	color: #3C9FC8;
}
.support .doctorsBox p .orange {
	color: #DB951C;
}
.support .doctorsBox p .big {
	font-size: 2rem;
}
.support .doctorsBox p small {
	font-size: 1.6rem;
}
.support .imgBox {
	margin: 0 auto 30px;
	width: 1085px;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.support .imgBox .img {
	margin-top: 6px;
	width: 220px;
}
.support .imgBox p {
	font-size: 1.8rem;
	letter-spacing: 0.8px;
	line-height: 1.9;
	text-align: center;
}
.support .txtBox {
	border-radius: 10px;
	background-color: #fff;
}
.support .txtBox .ttl {
	padding: 10px 20px 14px;
	color: #fff;
	font-size: 1.8rem;
	text-align: center;
	background-color: #3DA0C9;
	border-radius: 10px 10px 0 0;
	box-sizing: border-box;
	letter-spacing: 0.8px;
}
.support .txtBox .ttl span {
	margin-right: 6px;
	padding: 0 2px 4px;
	display: inline-block;
	min-width: 165px;
	line-height: 1.5;
	background-color: #DB951D;
	text-align: center;
	box-sizing: border-box;
	border-radius: 5px;
}
.support .txtBox p {
	padding: 17px 10px 22px;
	font-size: 1.4rem;
	line-height: 2;
	letter-spacing: 0.5px;
	text-align: center;
	box-shadow: 1px 1px 1px rgba(0,0,0,0.1);
	box-sizing: border-box;
	border-radius: 0 0 10px 10px;
}
.chosen {
	padding: 68px 0 60px;
}
.chosen .headLine02 {
	margin-bottom: 30px;
}
.chosen .headLine02::after {
	margin-top: 10px;
	width: 1120px;
	background-image: url(../img/index/h2_img04.png);
	background-size: 1120px;
}
.chosen .chosenUl {
	margin-top: -15px;
	display: flex;
}
.chosen .chosenUl li {
	margin: 15px 15px 0 0;
	width: 390px;
	min-height: 420px;
	background-color: #fff;
	box-shadow: 1px 1px 1px rgba(0,0,0,0.1);
	border-radius: 8px;
}
.chosen .chosenUl li:nth-child(3n) {
	margin-right: 0;
}
.chosen .chosenUl .photoBox {
	display: flex;
	justify-content: space-between;
}
.chosen .chosenUl .photoBox .img {
	margin-bottom: 14px;
	width: calc(100% - 60px);
}
.chosen .chosenUl .photoBox .img img {
	width: 100%;
	border-radius: 8px 0 8px 0;
}
.chosen .chosenUl .photoBox .num {
	margin: 13px 11px 0 0;
	color: #3C9FC8;
	font-size: 1.2rem;
	line-height: 1;
	text-align: center;
}
.chosen .chosenUl .photoBox .num span {
	margin-top: 3px;
	display: block;
	font-size: 3rem;
	font-weight: 600;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	transform: rotate(0.05deg);
	-ebkit-transform: rotate(0.05deg);
}
.chosen .chosenUl .textBox {
	text-align: center;
}
.chosen .chosenUl .textBox h3 {
	margin-bottom: 6px;
	font-size: 1.7rem;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	transform: rotate(0.05deg);
	-ebkit-transform: rotate(0.05deg);
	letter-spacing: 0.5px;
}
.chosen .chosenUl .textBox h3 span {
	font-size: 2.2rem;
}
.chosen .chosenUl .textBox .txt {
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: 0.5px;
}
.chosen .chosenUl .textBox p {
	font-size: 1.5rem;
	line-height: 1.8;
	letter-spacing: 2px;
}
.faq {
	padding: 69px 0 60px;
	background-color: #fff;
}
.faq .headLine02 {
	margin-bottom: 29px;
}
.faq .headLine02::after {
	background-image: url(../img/index/h2_img05.png);
	background-size: 186px;
	width: 194px;;
}
.faq dl {
	padding-bottom: 25px;
	border-bottom: 1px solid #E2EAEE;
}
.faq dt,
.faq dd {
	padding-left: 38px;
}
.faq dt {
	margin-bottom: 8px;
	padding-top: 18px;
	font-size: 2.3rem;
	font-weight: 600;
	letter-spacing: -0.2px;
	border-top: 1px solid #E2EAEE;
	font-family: 'M PLUS Rounded 1c', sans-serif;
	transform: rotate(0.05deg);
	-ebkit-transform: rotate(0.05deg);
	position: relative;
}
.faq dt::before {
	width: 30px;
	height: 30px;
	position: absolute;
	top: 20px;
	left: 0;
	content: '';
	background: url(../img/index/faq_img01.png) no-repeat left top / 30px;
}
.faq dd {
	margin-bottom: 25px;
	font-size: 1.4rem;
	line-height: 2;
	letter-spacing: 1.1px;
	position: relative;
}
.faq dd::before {
	width: 20px;
	height: 20px;
	position: absolute;
	top: 5px;
	left: 10px;
	content: '';
	background: url(../img/index/faq_img02.png) no-repeat left top / 20px;
}
.faq dd:last-child {
	margin-bottom: 0;
}
.mind {
	padding: 67px 0 53px;
}
.mind .headLine02 {
	margin-bottom: 25px;
	font-size: 3.1rem;
}
.mind .headLine02::after {
	margin-top: 5px;
	background-image: url(../img/index/h2_img06.png);
	background-size: 884px;
	width: 884px;
}
.mind .listUl {
	margin: -20px auto 0;
	width: 1120px;
	display: flex;
	flex-wrap: wrap;
}
.mind .listUl li {
	margin: 20px 80px 0 0;
	width: 320px;
	text-align: center;
}
.mind .listUl li .photo {
	margin: 0 auto 12px;
	width: 233px;
}
.mind .listUl li:nth-child(3n) {
	margin-right: 0;
}
.mind .listUl li h3 {
    font-size: 2.2rem;
    margin-bottom: 5px;
}
.mind .listUl li h3 small {
	font-size: 1.8rem;
}
.mind .listUl li p {
	font-size: 1.5rem;
	line-height: 1.85;
}
@media all and (max-width: 896px) {
	.mainVisual {
	    min-height: 900px;
	    position: relative;
	}
	.mainVisual::after { 
		width: 100%;
		height: 100%;
		background-image: url("../img/index/sp_main_bg.png");
		background-size: 100% auto;
	}
	.mainVisual .flexBox {
		padding: 54px 0 91px;
		display: block;
		max-width: inherit;
	}
	.mainVisual .leftBox {
		margin: 0 0 33px;
		width: auto;
		max-width: inherit;
	}
	.mainVisual .flexBox .subBox01 {
		width: auto;
	}
	.mainVisual h2 {
		margin: 0 auto 58px;
	}
	.mainVisual h2 img {
		width: 100%;
	}
	.mainVisual .movieBox {
		margin: 0 auto;
        max-width: 53.3%;
        border-radius: 9px;
        box-sizing: border-box;
        left: 24.2%;
        bottom: 57vw;
	}
	.mainVisual .movieBox .title img {
		width: 277px;
		image-orientation: none;
	}
	.mainVisual .movieBox .innerBox {
		height: 14.5vw;
		border-radius: 7px;
	}
	.mainVisual .movieBox .title {
		top: -5.4vw;
		width: 87%;
	}
	.mainVisual .movieBox video {
		margin-top: -18vw;
	}
	.mainVisual .tableBox {
		margin: -284px 15px 0;
	    padding: 5px;
	    width: auto;
		bottom: auto;
		right: auto;
		z-index: 2;
		position: relative;
	}
	.mainVisual .tableBox .subBox {
		padding: 0 8px 15px 5px;
		display: flex;
		flex-wrap: wrap;
		align-items: center;
		justify-content: space-between;
	}
	.mainVisual .tableBox .innerBox::before {
		height: 43px;
		width: 195px;
		top: -34px;
		background-size: 163px;
		background: url(../img/index/sp_tab_img01.png) no-repeat center center / 195px;
	}
	.mainVisual .tableBox .innerBox h3 {
		margin-bottom: 0;
		font-size: 2.1rem;
		letter-spacing: 0;
		display: inline-block;
		width: calc(100% - 50px);
	}
	.mainVisual .tableBox .innerBox h3 span {
		padding: 2px 7px 4px;
		border-radius: 5px;
		font-size: 2.1rem;
	}
	.mainVisual .tableBox .innerBox h3 small {
	    font-size: 1.8rem;
	}
	.mainVisual .tableBox .innerBox .addTitle {
		font-size: 1.8rem;
	}
	.mainVisual .tableBox .innerBox {
	    padding: 16px 6px 12px 15px;
	}
	.mainVisual .tableBox .iframeBox {
		margin: 0;
		height: auto;
		overflow: inherit;
	}
	.mainVisual .tableBox .stepUl {
	    margin: 0 auto 9px;
		max-width: 330px;
	}
	.mainVisual .tableBox .stepUl li {
	    width: 149px;
	}
	.mainVisual .tableBox .stepUl a {
		font-size: 1.4rem;
	}
	.mainVisual .tableBox .stepUl .on::after {
		bottom: -7px;
	}
	.mainVisual .tableBox .stepUl span {
	    margin-left: 3px;
	    font-size: 1.8rem;
	}
	.mainVisual .btn a {
		padding: 7px 20px 10px;
		width: 226px;
		height: 57px;
		font-size: 2.5rem;
		background: url(../img/index/btn_bg03.png) no-repeat left top / 227px;
	}
	.mainVisual .btn a::before {
		position: initial;
		width: 0;
	}
	.mainVisual .tableBox .innerBox .img01 {
		margin: 0;
		width: 42px;
		display: inline-block;
	}
	.mailForm .formDl {
		margin-bottom: 11px;
	}
	.mailForm .formDl dd {
		padding: 5px;
	}
	.mailForm .formDl dt {
		padding-right: 5px;
		width: 113px;
	}
	.mainVisual .mailForm .submit input {
		padding: 1px 20px 10px;
		width: 226px;
		height: 57px;
		font-size: 2.5rem;
		background: url(../img/index/btn_bg03.png) no-repeat left top / 227px;
	}
	.diagnosis {
	    padding: 100px 0 60px;
	}
	.diagnosis .cenTxt {
	    margin-bottom: 1px;
	    font-size: 1.5rem;
	    line-height: 1.4;
	}
	.diagnosis h2::before, .diagnosis h2::after {
	    top: -70px;
	    left: 0;
	    width: 67px;
	    height: 78px;
	    background-size: 67px;
	}
	.diagnosis h2::after {
	    background-size: 63px;
		width: 64px;
		height: 92px;
		right: 0px;
		left: auto;
		top: -83px;
	}
	.diagnosis h2 {
		margin: -8px 0 25px;
		font-size: 2rem;
		line-height: 1.2;
	}
	.diagnosis h2 small {
	    font-size: 1.7rem;
	}
	.diagnosis h2 span {
		font-size: 3.7rem;
		background: url("../img/index/line_img.png") repeat-x left bottom 4px/ 8px;
	}
	.diagnosis .pointUl {
		margin-top: -16px;
	    flex-wrap: wrap;
	}
	.diagnosis .pointUl li {
		margin: 16px 0 0 0;
		padding-bottom: 20px;
		width: 100%;
		min-height: 184px;
		box-sizing: border-box;
	}
	.diagnosis .pointUl .num {
	    margin: -10px auto 7px;
	    padding-top: 12px;
	    width: 65px;
	    height: 65px;
	    font-size: 1.2rem;
		border: 2px solid #fff;
	}
	.diagnosis .pointUl .num span {
	    margin-top: 0;
	    font-size: 2.3rem;
	}
	.diagnosis .pointUl li p {
	    font-size: 1.6rem;
	    letter-spacing: 1.1px;
	    line-height: 1.5;
	}
	.diagnosis .pointUl li .num02 {
	    font-size: 2rem;
	}
	.diagnosis {
	    padding-bottom: 40px;
	}
	.comDiagn {
		padding: 18px 15px;
	}
	.comDiagn .note {
	    letter-spacing: 0.9px;
	}
	.voice {
	    padding: 36px 0 38px;
	}
	.voice .listUl .imgBox {
	    margin: -10px 0 15px;
	    padding: 0 5px 6px;
	}
	.voice .listUl .photo {
	    margin-right: 10px;
	    width: 100px;
	}
	.voice .listUl .imgBox .textBox {
	    margin-top: 13px;
		}
	.voice .listUl .imgBox .textBox .name {
	    margin: -10px 23px 0 0;
	    font-size: 3rem;
		width: 48px;
	}
	.voice .listUl .imgBox .textBox .name span {
		margin-left: 0;
	}
	.voice .listUl .imgBox .textBox p {
	    font-size: 1.2rem;
	    line-height: 1.5;
	    letter-spacing: 1px;
	}
	.voice .listUl .imgBox .textBox::before {
		top: 11px;
	    left: 56px;
	    height: calc(100% - 20px);
	}
	.voice .listUl .ttl {
	    margin-bottom: 7px;
	    font-size: 1.7rem;
		font-weight: 500;
	    letter-spacing: 1.5px;
		line-height: 1.4;
	}
	.voice .listUl .txt {
	    font-size: 1.3rem;
	    line-height: 1.78;
	}
	.voice .listUl {
	    margin-top: -15px;
	}
	.voice .listUl li {
	    margin-top: 15px;
		padding-bottom: 27px;
	    width: 100%;
	    min-height: 314px;
	}
	.support {
	    margin-bottom: 40px;
	    padding-top: 25px;
	}	
	.support .headLine02 {
	    margin-bottom: 11px;
	}
	.support .headLine02::after {
	    width: 316px;
	    background-image: url(../img/index/sp_h2_img03.png);
	    background-size: 316px;
	}
	.support .doctorsBox p .big {
	    font-size: 1.7rem;
	}
	.support .doctorsBox {
	    margin-bottom: 16px;
	    padding: 9px 7px 10px 10px;
	}
	.support .doctorsBox li {
	    margin: 0 2px 5px 0;
	    padding: 6px 5px 9px;
	    width: 105px;
	    font-size: 1.4rem;
	    border-radius: 5px;
	}
	.support .doctorsBox ul {
		margin-bottom: 2px;
		text-align: center;
	}
	.support .doctorsBox p {
	    font-size: 1.3rem;
	    letter-spacing: 1.5px;
	    text-align: center;
	    line-height: 1.3;
	}
	.support .doctorsBox p span {
	    font-size: 1.6rem;
	}
	.support .imgBox {
		margin-bottom: 20px;
		width: auto;
		display: block;
	}
	.support .imgBox .img {
	    margin: 0 0 11px;
	    width: 100%;
	}
	.support .imgBox p {
	    font-size: 1.6rem;
	    letter-spacing: 0;
	    line-height: 1.63;
	}
	.support .txtBox .ttl {
	    padding: 16px 20px 13px;
	    font-size: 1.5rem;
	    line-height: 1.7;
	}
	.support .txtBox .ttl span {
	    padding: 1px 2px 5px;
	    min-width: 148px;
	    font-size: 1.6rem;
	}
	.support .txtBox p {
	    padding: 9px 10px 18px;
	    font-size: 1.3rem;
	    line-height: 1.6;
	    letter-spacing: 0;
	}
	.chosen {
	    padding: 35px 0 40px;
	}
	.chosen .headLine02 {
	    margin-bottom: 25px;
	}
	.chosen .headLine02::after {
	    margin-top: 5px;
	    width: 100%;
		max-width: 380px;
	    background-image: url(../img/index/sp_h2_img04.png);
	    background-size: 100%;
	}
	.chosen .chosenUl {
		margin-top: -10px;
	    flex-wrap: wrap;
	}
	.chosen .chosenUl li {
	    margin: 10px 0 0;
	    padding-bottom: 23px;
	    width: 100%;
	    min-height: 332px;
	    border-radius: 10px;
	}
	.chosen .chosenUl .photoBox .num {
	    margin: 13px 7px 0 0;
	}
	.chosen .chosenUl .photoBox .num span {
	    margin-top: 1px;
	    font-size: 2.2rem;
	}
	.chosen .chosenUl .photoBox .img {
	    margin-bottom: 7px;
	    width: calc(100% - 45px);
	}
	.chosen .chosenUl .textBox h3 {
		margin-bottom: 2px;
	}
	.chosen .chosenUl .textBox p {
	    font-size: 1.3rem;
	    line-height: 1.63;
	    letter-spacing: 1px;
	}
	.faq {
	    padding: 34px 0 40px;
	}
	.faq .headLine02 {
	    margin-bottom: 27px;
	}
	.faq .headLine02::after {
	    background-image: url(../img/index/sp_h2_img05.png);
	    background-size: 146px;
	    width: 144px;
	}
	.faq dl {
	    padding-bottom: 19px;
	}
	.faq dt {
	    margin-bottom: 7px;
	    padding-top: 18px;
	    font-size: 2.1rem;
	}
	.faq dd {
	    margin-bottom: 20px;
	    font-size: 1.3rem;
	    line-height: 1.7;
	}
	.faq dd::before {
	    top: 2px;
	}
	.mind {
	    padding: 35px 0 34px;
	}
	.mind .headLine02 {
	    margin-bottom: 35px;
		font-size: 2rem;
	}
	.mind .headLine02::after {
	    margin-top: 5px;
	    background-image: url(../img/index/sp_h2_img06.png);
	    background-size: 175px;
	    width: 175px;
	}
	.mind .listUl {
		margin-top: -18px;
	    width: auto;
		display: block;
	}
	.mind .listUl li {
	    margin: 18px auto 0;
	    width: 100%;
		max-width: 300px;
	}
	.mind .listUl li .photo {
	    margin-bottom: 8px;
	    width: 60.5%;
	}
	.mind .listUl li h3 {
		margin-bottom: 7px;
	    font-size: 2.2rem;
	}
	.mind .listUl li h3 small {
		font-size: 1.8rem;
	}
	.mind .listUl li p {
	    font-size: 1.5rem;
	    line-height: 1.8;
	    letter-spacing: 0;
	}
	.mind .listUl li:nth-child(3n) {
	    margin: 18px auto 0;
	}
	.mainVisual .btn.thanks a {
	    padding: 13px 44px 10px 3px;
	    font-size: 1.7rem;
	}
	.chosen .chosenUl .photoBox .img img {
	    border-radius: 10px 0 4px 0;
	}
	.support .doctorsBox::after {
	    bottom: -15px;
	    width: 31px;
	    height: 56px;
	    background-size: 81px;
	}
}
@media all and (max-width: 374px) {
	.mainVisual .tableBox .stepUl li {
	    width: 123px;
	}
	.mailForm .formDl dt {
	    padding: 12px 3px 14px 4px;
	    width: 94px;
		font-size: 1.2rem;
	}
	.mailForm .formDl dd {
	    width: calc(100% - 94px);
	}
	.mainVisual .tableBox .innerBox {
	    padding: 16px 12px 12px;
	}
	.diagnosis h2::before, .diagnosis h2::after {
	    width: 54px;
	    background-size: 54px;
	}
	.diagnosis h2::after {
	    background-size: 57px;
	    top: -111px;
	}
	.diagnosis h2 span {
	    font-size: 3.2rem;
	}
	.voice .listUl .ttl {
	    font-size: 1.6rem;
	    letter-spacing: 0;
	}
	.voice .listUl .txt {
	    font-size: 1.2rem;
	}
	.comDiagn .note {
	    letter-spacing: 0;
	}
	.support .doctorsBox ul {
	    text-align: center;
	}
	.support .imgBox p {
	    font-size: 1.4rem;
	    letter-spacing: -0.1px;
	}
	.support .txtBox p {
	    font-size: 1.2rem;
	    letter-spacing: -0.3px;
	}
	.chosen .headLine02 {
		letter-spacing: 0;
	}
	.support .doctorsBox p small {
	    font-size: 1.3rem;
	}
}
@media all and (min-width: 450px) and (max-width: 896px) {
	.mainVisual .tableBox {
		margin-top: -60vw;
	}
}
@media all and (min-width: 500px) and (max-width: 896px) { 
	.mainVisual .flexBox {
		padding-bottom: 28vw;
	}
}
@media all and (max-width: 374px) {
	.mainVisual .tableBox {
		margin-top: -74vw;
	}
	.mainVisual .tableBox .innerBox h3 {
		font-size: 1.8rem;
	}
	.mainVisual .tableBox .innerBox h3 span {
		font-size: 1.7rem;
	}
}

/**** thanks ****/
section.thanksSec {
    padding: 230px 0;
    background: url(../img/index/bg_img.png) repeat left top / cover;
}
section.thanksSec a{
    text-decoration: underline;
    color: #3ea0c9;
}
section.thanksSec h2{
	text-align: center;
	margin-bottom: 30px;
}
section.thanksSec p.thanks{
	margin-bottom: 30px
}

@media all and (max-width: 769px) {
	section.thanksSec h2{font-size: 20px;}
	}