@charset "utf-8";
/*------------------------------------------------------------
	index
------------------------------------------------------------*/
.mainVisual {
	height: 104.8rem;
	padding-top: 18.6rem;
	position: relative;
	z-index: 1;
	background: url(../img/index/main_visual_bg.webp) no-repeat bottom center;
	background-size: cover;
	box-sizing: border-box;
}
.mainVisual .textBox {
	max-width: 129.6rem;
	margin: 0 auto;
}
.mainVisual .en {
	margin-bottom: 1.4rem;
	font-size: 2rem;
	font-weight: 600;
	letter-spacing: 1.6rem;
}
.mainVisual .ttl {
	margin: 0 0 0.7rem -1.5rem;
	color: #E96C12;
	font-size: 9rem;
	line-height: 8rem;
	letter-spacing: -1.8rem;
}
.mainVisual .ttl .txt01 {
	letter-spacing: 0;
}
.mainVisual .ttl .sml01 {
	font-size: 5rem;
	letter-spacing: 0;
}
.mainVisual .ttl .txt02 {
	display: block;
	margin-top: 0.9rem;
}
.mainVisual .ttl .big {
	font-size: 10rem;
	letter-spacing: 0;
}
.mainVisual .ttl .sml02 {
	margin-left: -2.3rem;
	font-size: 6.4rem;
	letter-spacing: 0;
}
.mainVisual .title {
	margin-bottom: 2.4rem;
	font-size: 2.5rem;
	font-weight: 700;
	letter-spacing: 0.2rem;
}
.mainVisual .title span {
	font-weight: 300;
}
.mainVisual ul {
	margin-left: -1.8rem;
}
.mainVisual li {
	width: 20rem;
	height: 19.8rem;
	margin-right: 0.8rem;
	padding-top: 6.5rem;
	text-align: center;
	font-size: 1.8rem;
	font-weight: 700;
	background: url(../img/index/main_visual_img.webp) no-repeat center center;
	background-size: 100% 100%;
	box-sizing: border-box;
}
.mainVisual li span {
	margin-top: -0.2rem;
	display: block;
	font-size: 2.8rem;
	line-height: 1.15;
	letter-spacing: 0;
	font-family: "Noto Serif JP", serif;
}
.mainVisual li:last-child {
	margin-bottom: 0;
}
.mainVisual .list04 {
	letter-spacing: 0.05rem;
}
.mainVisual .list03 {
	padding-top: 7.3rem;
}
.mainVisual .list03 span {
	margin-top: -0.1rem;
	font-size: 3.4rem;
}
.mainVisual .list02 {
	padding-top: 5.8rem;
}
.mainVisual .list02 span {
	margin: 0 0 -0.1rem;
	font-size: 2.4rem;
}
.mainVisual .list02 span span {
	margin: 0;
	letter-spacing: -0.3rem;
}
.mainVisual .list01 {
	padding-top: 6.5rem;
}
.mainVisual .list01 span {
	margin-top: 0.1rem;
	font-size: 3.4rem;
}
.mainVisual .list01 .num {
	display: inline-block;
	font-weight: 600;
	margin: 0;
	font-size: 2.8rem;
}
#main .anxiety {
	margin-top: -36rem;
	padding: 48.7rem 0 21.1rem;
	position: relative;
	background: url(../img/index/anxiety_bg.webp) no-repeat bottom center;
	background-size: cover;
}
#main .anxiety .img {
	position: absolute;
	left: 0;
	bottom: -7.2rem;
	width: 33.1rem;
}
#main .anxiety h2 {
	margin-bottom: 8.4rem;
	text-align: center;
	font-size: 4.4rem;
	font-weight: 700;
	line-height: 1;
	color: #77A8CB;
	letter-spacing: 0.22rem;
}
#main .anxiety h2 span {
	display: inline-block;
	font-size: 9rem;
	position: relative;
}
#main .anxiety h2 span::before {
	position: absolute;
	left: 50%;
	top: -1.4rem;
	width: 1rem;
	height: 1rem;
	background-color: #77A8CB;
	border-radius: 100%;
	content: "";
	transform: translateX(-50%);
}
#main .anxiety ul {
	width: 70rem;
	margin: 0 auto 5.7rem;
}
#main .anxiety li {
	margin-bottom: 2rem;
	padding: 1.4rem 10.1rem 1.7rem;
	font-size: 2.6rem;
	font-weight: 700;
	color: #fff;
	letter-spacing: 0.208rem;
	border-radius: 3.5rem;
	background: #77A8CB url(../img/common/icon14.webp) no-repeat left 5rem top 44%;
	background-size: 3.7rem auto;
}
#main .anxiety li:last-child {
	margin-bottom: 0 !important;
}
#main .anxiety p {
	text-align: center;
	font-weight: 500;
	line-height: 1.6;
	font-size: 3.4rem;
	letter-spacing: 0.272rem;
}
#main .anxiety p span {
	color: #77A8CB;
	font-size: 6rem;
	letter-spacing: 0.48rem;
}
#main .never {
	padding-top: 11.5rem;
}
#main .never h2 {
	margin-bottom: 2.8rem;
	text-align: center;
	font-size: 6.2rem;
}
#main .never h2 span {
	margin-top: -1rem;
	display: block;
	color: #E96C12;
	font-size: 7.4rem;
	letter-spacing: -0.6rem;
}
#main .never .topText {
	margin-bottom: 6.2rem;
	text-align: center;
	font-size: 3.4rem;
	font-weight: 500;
	letter-spacing: 0.272rem;
}
#main .never li {
	width: 25%;
	position: relative;
}
#main .never li img {
	width: 100%;
}
#main .never li p {
	position: absolute;
	left: 0;
	top: 50%;
	width: 100%;
	text-align: center;
	color: #fff;
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.224rem;
	transform: translateY(-54%);
}
#main .never li p .big {
	font-size: 3.8rem;
	letter-spacing: 0.304rem;
}
#main .figures {
	padding: 24.3rem 0 14.6rem;
	background: url(../img/index/figures_bg01.webp) repeat-x center top,url(../img/index/figures_bg02.webp) no-repeat center top;
	background-size: 4.7rem auto,cover;
}
#main .figures .content {
	max-width: 104rem;
}
#main .figures h2 {
	margin-bottom: 4.7rem;
	text-align: center;
	font-size: 4rem;
	font-weight: 700;
	letter-spacing: 0.72rem;
}
#main .figures h2 .orage {
	margin-bottom: -2.8rem;
	display: block;
	color: #E96C12;
	font-size: 7rem;
	font-weight: 900;
	letter-spacing: -0.5rem;
	font-family: "Noto Serif JP", serif;
}
#main .figures h2 .bgi01 {
	font-weight: 600;
	font-size: 11rem;
}
#main .figures h2 .bgi02 {
	font-weight: 600;
	font-size: 14rem;
}
#main .figures ul {
	border-top: 0.2rem solid #E96C12;
}
#main .figures ul:last-child {
	border-bottom: 0.2rem solid #E96C12;
}
#main .figures li {
	width: 40.2rem;
	padding: 2.2rem 3.7rem;
	height: 45.8rem;
	position: relative;
	box-sizing: border-box;
}
#main .figures li:not(:last-child)::before {
	position: absolute;
	right: 0;
	top: 3rem;
	width: 0.2rem;
	bottom: 2.8rem;
	background-color: #E96C12;
	content: "";
}
#main .figures .list02 {
	width: calc(100% - 40.2rem);
}
#main .figures li .img {
	position: absolute;
	bottom: 5.4rem;
	right: 0;
	width: 38rem;
}
#main .figures li p {
	font-size: 3rem;
	font-weight: 700;
	line-height: 1.48;
	letter-spacing: 0.3rem;
}
#main .figures li .big {
	margin: -1.1rem -0.7rem 0;
	display: block;
	font-size: 5rem;
	font-weight: 500;
}
#main .figures li .num {
	line-height: 1;
	font-size: 18rem;
	color: #E96C12;
	font-weight: 500;
	letter-spacing: -0.036rem;
	font-family: "Oswald", sans-serif;
}
#main .figures .list01 {
	padding: 1.1rem 0;
}
#main .figures .list01 .img {
	width: 24rem;
	right: 8.4rem;
}
#main .figures .list01 .num {
	font-size: 10rem;
	letter-spacing: 0;
}
#main .figures .list03 {
	padding-left: 0;
	width: 66.6rem;
}
#main .figures .list03 .img {
	width: 41.4rem;
	right: 3.1rem;
	bottom: 3.3rem;
}
#main .figures .list03 .big {
	margin: -0.2rem -0.2rem 0;
	font-size: 4rem;
}
#main .figures .list03 .num {
	font-size: 12rem;
}
#main .figures .list04 {
	width: calc(100% - 66.6rem)
}
#main .figures .list04 .img {
	width: 27rem;
	right: -6rem;
	bottom: 4.9rem;
}
#main .figures .list04 .big {
	margin: -0.2rem -0.2rem 0;
	font-size: 4rem;
}
#main .figures .list04 .num {
	font-size: 10rem;
}
#main .figures .list04 .sml {
	margin-top: -0.1rem;
	display: block;
	font-size: 1.4rem;
	line-height: 1.57;
	font-weight: 500;
	text-indent: -1em;
	padding-left: 1em;
	letter-spacing: 0.112rem;
}
#main .life {
	padding: 13.9rem 0 12.6rem;
	background: url(../img/index/life_bg02.webp) repeat-x bottom center,url(../img/index/life_bg01.webp) no-repeat top center;
	background-size: 14.2rem auto,cover;
}
#main .life .content {
	max-width: 104rem;
	position: relative;
}
#main .life h2 {
	margin-bottom: 2.9rem;
	text-align: center;
	color: #FFF96C;
	font-size: 4rem;
	font-weight: 700;
	letter-spacing: 0.72rem;
}
#main .life h2 .white {
	margin-bottom: 0.8rem;
	display: block;
	font-size: 11rem;
	line-height: 1;
	color: #fff;
	letter-spacing: 0;
}
#main .life h2 .sml {
	font-size: 7rem;
	font-weight: 900;
	letter-spacing: -0.07rem;
}
#main .life h2 .big {
	margin-left: -1rem;
	font-size: 14rem;
	letter-spacing: -2.4rem;
}
#main .life .bgText {
	margin-bottom: 4rem;
	position: relative;
	padding: 0.9rem 2rem 1rem;
	text-align: center;
	font-size: 3.4rem;
	font-weight: 700;
	letter-spacing: 0.34rem;
	background-color: #fff;
	border-radius: 1rem;
}
#main .life .bgText::before {
	position: absolute;
	left: 50%;
	bottom: -1rem;
	background: url(../img/common/icon15.webp) no-repeat;
	background-size: 100% 100%;
	width: 2.1rem;
	height: 1rem;
	content: "";
	transform: translateX(-50%);
}
#main .life .img01 {
	margin-bottom: 3.5rem;
}
#main .life ul {
	margin-bottom: 4.4rem;
	position: relative;
}
#main .life ul::after {
	width: 32rem;
	content: "";
}
#main .life li {
	width: 32rem;
}
#main .life li .bgBox {
	padding: 2.2rem 2rem 3.5rem;
	position: relative;
	text-align: center;
	border-radius: 1rem;
	background: #FFF96C;
}
#main .life li h3 {
	margin-bottom: 1.4rem;
	padding-bottom: 1.2rem;
	font-size: 3.6rem;
	font-weight: 700;
	color: #E96C12;
	letter-spacing: 0.36rem;
	border-bottom: 0.2rem solid #E96C12;
}
#main .life li .title {
	margin-bottom: 0.8rem;
	font-size: 3.2rem;
	font-weight: 700;
}
#main .life li .title .num {
	margin: 0 0.5rem;
	line-height: 1.2;
	font-size: 6rem;
}
#main .life li .title .unit {
	font-size: 4.2rem;
	font-weight: 900;
	line-height: 1;
}
#main .life li .text {
	font-weight: 500;
	font-size: 2.4rem;
	letter-spacing: 0.24rem;
	line-height: 1.45;
}
#main .life li .note {
	margin-top: 1rem;
	text-indent: -1em;
	padding-left: 1em;
	color: #fff;
	font-size: 1.4rem;
	line-height: 1.71;
	letter-spacing: 0.112rem;
}
#main .life li:last-child .bgBox::before {
	position: absolute;
	left: 50%;
	bottom: -8rem;
	background: url(../img/common/icon16.webp) no-repeat;
	background-size: 100% 100%;
	width: 8rem;
	height: 8rem;
	transform: translateX(-50%);
	content: "";
}
#main .life .img02 {
	width: 70.1rem;
	margin-left:  auto;
}
#main .life .img02 span {
	display: block;
	width: fit-content;
	margin: 2.9rem -0.7rem 0 auto;
	color: #fff;
	font-size: 1.4rem;
	line-height: 1.71;
	letter-spacing: 0.084rem;
}
#main .life .pho {
	position: absolute;
	left: -1.9rem;
	bottom: -12.6rem;
	width: 43.1rem;
}
#main .danger {
	padding: 10.1rem 0 11.2rem;
	color: #fff;
	position: relative;
	background: url(../img/index/danger_bg.webp) no-repeat top center;
	background-size: cover;
}
#main .danger h2 {
	margin-bottom: 4.1rem;
	text-align: center;
	font-size: 5rem;
	font-weight: 500;
	line-height: 1.35;
	letter-spacing: 0.5rem;
}
#main .danger h2 span {
	color: #FFE9B1;
	letter-spacing: 0.3rem;
}
#main .danger h2 .big {
	font-size: 7rem;
	letter-spacing: 0.7rem;
}
#main .danger p {
	max-width: 90rem;
	margin: 0 auto;
	text-align: justify;
	line-height: 2;
	letter-spacing: 0.18rem;
}
#main .danger .comArrow {
	bottom: -10rem;
}
#main .reason {
	padding: 15.9rem 0 4rem;
	position: relative;
}
#main .reason h2 {
	padding-top: 7rem;
	margin-bottom: 5.5rem;
	text-align: center;
	font-size: 5rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
	background: url(../img/index/reason_h2_img.webp) no-repeat top center;
	background-size: 29.7rem auto;
}
#main .reason h2 > span {
	display: block;
	color: #957E6D;
	font-size: 12rem;
	font-weight: 700;
	line-height: 1;
}
#main .reason h2 .num {
	margin: -1rem -1rem 0 0;
	display: inline-block;
	vertical-align: middle;
	font-size: 22rem;
	font-weight: 400;
}
#main .reason .bgBox {
	position: relative;
}
#main .reason .bgBox::before {
	position: absolute;
	left: 0;
	top: 10rem;
	width: 100%;
	bottom: 10rem;
	background-color: #FFEFE4;
	content: "";
}
#main .reason .imgBox {
	margin-bottom: 8rem;
	align-items: flex-start;
	position: relative;
	z-index: 1;
}
#main .reason .imgBoxL {
	flex-direction: row-reverse;
}
#main .reason .textBox {
	margin: 6rem -6.8rem 0 0;
	min-height: 40rem;
	width: calc(50% + 12.4rem);
	padding: 5rem 10rem 7.3rem;
	color: #fff;
	border-radius: 0 1rem 1rem 0;
	position: relative;
	background:#957E6D;
	box-sizing: border-box;
}
#main .reason .imgBoxL .textBox {
	margin: 6rem 0 0 -6.8rem;
	border-radius: 1rem 0 0 1rem;
}
#main .reason .widBox {
	max-width: 62.5rem;
	margin-left: auto;
	overflow: hidden;
}
#main .reason .imgBoxL .widBox {
	margin: 0;;
}
#main .reason .textBox .num {
	margin-bottom: 0.8rem;
	font-size: 3rem;
	width: fit-content;
	position: relative;
	color: #FFE9B1;
	font-weight: 500;
	letter-spacing: 0.3rem;
	font-family: "Oswald", sans-serif;
}
#main .reason .textBox .num::before {
	position: absolute;
	left: calc(100% + 3.5rem);
	top: 53%;
	width: 1000rem;
	height: 0.2rem;
	content: "";
	background-color: #FFE9B1;
}
#main .reason .textBox h3 {
	margin-bottom: 1.9rem;
	font-size: 5rem;
	font-weight: 600;
	line-height: 1.42;
	font-family: "Noto Serif JP", serif;
}
#main .reason .textBox h3 span {
	letter-spacing: -0.6rem;
	display: block;
}
#main .reason .textBox p {
	text-align: justify;
	line-height: 2;
	letter-spacing: 0.18rem;
}
#main .reason .textBox .yellow {
	font-weight: 700;
	color: #FFE9B1;
}
#main .reason .pho {
	width: calc(50% - 5.6rem);
	border-radius: 1rem 0 0 1rem;
	overflow: hidden;
}
#main .reason .imgBoxL .pho {
	border-radius: 0 1rem 1rem 0;
}
#main .reason .pho img {
	width: 100%;
}
#main .reason .imgInfo {
	max-width: 120rem;
	margin: 0 auto -5rem;
	padding-top: 1.6rem;
	align-items: flex-start;
	position: relative;
	z-index: 1;
}
#main .reason .textInfo {
	width: 72rem;
}
#main .reason .textInfo h3 {
	margin-bottom: 3rem;
	font-weight: 700;
	font-size: 2.8rem;
	text-indent: -1.2em;
	padding-left: 1.2em;
	letter-spacing: 0.28rem;
}
#main .reason .textInfo h3 span {
	color: #E96C12;
}
#main .reason .textInfo p {
	text-align: justify;
	line-height: 2;
	letter-spacing: 0.18rem;
}
#main .reason .textInfo p sup {
	font-size: 1rem;
}
#main .reason .textInfo p span {
	margin-top: 0.6rem;
	display: block;
	font-size: 1.4rem;
	letter-spacing: 0.14rem;
}
#main .reason .img {
	width: 50.2rem;
	margin: -5.8rem -3rem 0 0;
}
#main .implant {
	padding: 13.8rem 0 17rem;
	position: relative;
	background: url(../img/index/implant_bg01.webp) no-repeat top right;
	background-size: cover;
}
#main .implant .img {
	position: absolute;
	left: 0;
	bottom: 0;
	width: 38rem;
}
#main .implant .comArrow {
	bottom: -9.7rem;
}
#main .implant .content {
	max-width: 124rem;
}
#main .implant h2 {
	margin-bottom: 2.2rem;
	width: fit-content;
	color: #FFE9B1;
	text-align: center;
}
#main .implant h2 .en {
	margin-bottom: 1.3rem;
	display: block;
	font-weight: 500;
	letter-spacing: 0.972rem;
	font-family: "Oswald", sans-serif;
}
#main .implant h2 .jp {
	padding: 0.8rem 0;
	display: block;
	font-size: 2.8rem;
	font-weight: 700;
	letter-spacing: 0.392rem;
	border-top: 0.2rem solid #FFE9B1;
	border-bottom: 0.2rem solid #FFE9B1;
}
#main .what {
	margin-bottom: 10rem;
}
#main .what h3 {
	margin: 0 -0.7rem 1.1rem;
	color: #fff;
	font-size: 5.8rem;
	letter-spacing: -0.3rem;
}
#main .what h3 span {
	margin: -1.9rem -0.5rem 0;
	display: block;
	font-size: 9rem;
	letter-spacing: -1.4rem;
}
#main .what p {
	max-width: 70rem;
	text-align: justify;
	color: #fff;
	line-height: 2;
	letter-spacing: 0.18rem;
}
#main .what p span {
	color: #FFE9B1;
	font-weight: 700;
}
#main .advantage h2 {
	margin-bottom: 5rem;
}
#main .advantage h2 .en {
	letter-spacing: 0.738rem;
}
#main .advantage ul {
	margin-bottom: 10.8rem;
	position: relative;
}
#main .advantage ul::after {
	width: 29.2%;
	content: "";
}
#main .advantage li {
	width: 29.2%;
}
#main .advantage li .pho {
	margin-bottom: 2.1rem;
	overflow: hidden;
	border-radius: 1rem;
}
#main .advantage li img {
	width: 100%;
}
#main .advantage li h3 {
	margin-bottom: 1.7rem;
	text-align: center;
	color: #FFE9B1;
	font-size: 2.2rem;
	line-height: 1.55;
	font-weight: 700;
	letter-spacing: 0.22rem;
}
#main .advantage li p {
	text-align: justify;
	font-size: 1.6rem;
	line-height: 2;
	letter-spacing: 0.16rem;
	color: #fff;
}
#main .advantage .bgBox {
	padding: 5.5rem 2rem 6.2rem;
	color: #02718C;
	background: url(../img/index/implant_bg02.webp) no-repeat top center;
	background-size: cover;
	border-radius: 1rem;
}
#main .advantage .bgBox h3 {
	margin: 0 auto 3.5rem;
	width: fit-content;
	position: relative;
	text-align: center;
	font-size: 4rem;
	font-weight: 700;
}
#main .advantage .bgBox h3::before {
	position: absolute;
	left: 0;
	bottom: 0;
	right: 0;
	height: 2rem;
	background-color: #fff;
	border-radius: 1rem;
	content: "";
}
#main .advantage .bgBox h3 span {
	position: relative;
	z-index: 1;
}
#main .advantage .bgBox p {
	max-width: 80rem;
	margin: 0 auto;
	text-align: justify;
	line-height: 2;
	letter-spacing: 0.18rem;
}
#main .features {
	padding: 14rem 0 16.3rem;
	position: relative;
	z-index: 1;
}
#main .features .comArrow {
	bottom: -6.5rem;
}
#main .features .content {
	max-width: 128rem;
}
#main .features .headLine01 {
	margin-bottom: 8.4rem;
	letter-spacing: -0.2rem;
}
#main .features li {
	width: 22.6%;
	margin-right: 3.2%;
}
#main .features li:last-child {
	margin: 0 !important;
}
#main .features .pho {
	margin-bottom: 2.1rem;
	position: relative;
}
#main .features .pho span {
	position: absolute;
	left: -3rem;
	top: -3rem;
	width: 8rem;
	height: 8rem;
	padding: 1.3rem 0.2rem 0 0;
	color: #fff;
	font-size: 3.4rem;
	text-align: center;
	box-sizing: border-box;
	border-radius: 100%;
	background-color: #E96C12;
}
#main .features .pho img {
	width: 100%;
	border-radius: 1rem;
}
#main .features h3 {
	margin-bottom: 1.5rem;
	text-align: center;
	color: #E96C12;
	line-height: 1.55;
	font-size: 2.2rem;
	font-weight: 700;
	letter-spacing: 0.22rem;
}
#main .features li p {
	font-size: 1.6rem;
	line-height: 2;
	text-align: justify;
	letter-spacing: 0.16rem;
}
#main .case {
	padding: 13.9rem 0 16rem;
	position: relative;
	background-color: #F2F2F2;
}
#main .case .img {
	position: absolute;
	left: 0;
	top: -13rem;
	width: 43.5rem;
}
#main .case h2 {
	margin-bottom: 6.4rem;
	text-align: center;
	color: #12C3A3;
	font-size: 5rem;
	font-weight: 700;
	letter-spacing: 0.3rem;
}
#main .case h2 span {
	display: block;
	width: fit-content;
	position: relative;
	margin: 0.9rem auto;
	font-size: 7.4rem;
	line-height: 1;
	letter-spacing: 0.44rem;
}
#main .case h2 span::before {
	position: absolute;
	right: -3.6rem;
	top: -4.7rem;
	background: url(../img/common/icon19.webp) no-repeat;
	background-size: 6rem 7rem;
	width: 6rem;
	height: 7rem;
	content: "";
}
#main .case .topText {
	margin: 0 -7rem 3.8rem;
	text-align: center;
	font-size: 2.2rem;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.22rem;
}
#main .case .topText span {
	color: #12C3A3;
	letter-spacing: 0.22rem;
}
#main .case .whiteBg {
	padding: 5rem;
	max-width: 100rem;
	margin: 0 auto 8.5rem;
	background-color: #fff;
	border-radius: 1rem;
}
#main .case .imgList {
	margin-bottom: 4rem;
}
#main .case .imgList li {
	width: calc(50% - 5rem);
	position: relative;
}
#main .case .imgList li:first-child::before {
	position: absolute;
	right: -6.5rem;
	top: 50%;
	background: url(../img/common/icon20.webp) no-repeat;
	background-size: 100% 100%;
	width: 3rem;
	height: 3rem;
	content: "";
	transform: translateY(-50%);
}
#main .case .imgList li img {
	width: 100%;
	border-radius: 1rem;
}
#main .case .imgList li span {
	position: absolute;
	left: 2rem;
	top: 0.8rem;
	font-size: 2.6rem;
	color: #fff;
	font-weight: 500;
	font-family: "Oswald", sans-serif;
}
#main .case .whiteBg table {
	width: 100%;
	border-collapse: collapse;
	overflow: hidden;
	border-radius: 1rem;
}
#main .case .whiteBg th,
#main .case .whiteBg td {
	padding: 1.5rem;
	font-size: 1.8rem;
	font-weight: 400;
	line-height: 1.67;
	letter-spacing: 0.18rem;
	vertical-align: middle;
	text-align: left;
	box-sizing: border-box;
}
#main .case .whiteBg td {
	padding-left: 3.9rem;
}
#main .case .whiteBg th {
	width: 22.3%;
	font-weight: 700;
	text-align: center;
	position: relative;
}
#main .case .whiteBg th::before {
	position: absolute;
	right: 0;
	top: 1rem;
	width: 1px;
	bottom: 1rem;
	background-color: #444;
	content: "";
}
#main .case .whiteBg tr:nth-child(2n + 1) th,
#main .case .whiteBg tr:nth-child(2n + 1) td {
	background-color: #EFEFEF;
}
#main .case .whiteBg td ul {
	padding: 0.7rem 0 0.4rem;
}
#main .case .whiteBg td ul li:not(:last-child) {
	padding-bottom: 0.8rem;
}
#main .case .whiteBg td span {
	display: block;
	font-weight: 700;
}
#main .case .whiteBg .info:not(:last-child) {
	margin-bottom: 8rem;
}
#main .case .bgBox {
	max-width: 100rem;
	margin: 0 auto;
	padding: 5.5rem 8rem 7.6rem;
	position: relative;
	background: url(../img/index/case_bg.webp) repeat left top;
	background-size: 1.5rem auto;
	border-radius: 1rem;
}
#main .case .bgBox h3 {
	margin-bottom: 2.8rem;
	font-weight: 700;
	font-size: 3.4rem;
	line-height: 1.47;
	letter-spacing: 0.204rem;
}
#main .case .bgBox h3 span {
	color: #fff;
	font-size: 4.8rem;
	letter-spacing: 0.288rem;
}
#main .case .bgBox ul {
	width: 54rem;
}
#main .case .bgBox li {
	padding: 1.3rem 0 1.6rem 5.3rem;
	font-size: 2.6rem;
	font-weight: 700;
	letter-spacing: 0.26rem;
	border-bottom: 0.3rem dotted #fff;
	background: url(../img/common/icon21.webp) no-repeat left center;
	background-size: 3.9rem auto;
}
#main .case .bgBox li span {
	color: #fff;
	font-size: 3.2rem;
	letter-spacing: 0.32rem;
}
#main .case .bgBox .person {
	position: absolute;
	bottom: -16rem;
	right: -13.8rem;
	width: 47.6rem;
}
#main .price{
	background-color: #FFF9EA;
}
#main .price .bgBox{
	padding: 28rem 0 1rem;
	background: url("../img/index/pecie_bg01.webp") no-repeat center top / 100% ,url("../img/index/pecie_bg02.webp") no-repeat center bottom / 100% ;
}
#main .price .content {
	max-width: 94rem;
}
#main .price .headLine01 {
	margin-bottom: 4.1rem;
}
#main .price .dlText {
	margin-bottom: 3.2rem;
	padding: 2rem 0 1.8rem;
	display: flex;
	justify-content: space-between;
	align-items: center;
	color: #F3AF00;
	font-weight: 700;
	text-align: center;
	letter-spacing: 0.08rem;
	border-bottom: 0.2rem solid #F3AF00;
	border-top: 0.2rem solid #F3AF00;
}
#main .price .dlText dt {
	width: 30rem;
	padding-bottom: 0.3rem;
	font-size: 4rem;
	text-align: center;
}
#main .price .dlText .txt {
	margin-bottom: -0.1rem;
	display: block;
	color: #444;
	font-size: 3.6rem;
	letter-spacing: 0.216rem;
}
#main .price .dlText dd {
	width: calc(100% - 30rem);
	padding: 2.2rem 0 2.5rem 0rem;
	font-size: 4rem;
	border-left: 0.2rem solid #F3AF00;
}
#main .price .dlText dd .txt {
	letter-spacing: 0;
}
#main .price .dlText dd .tag {
	font-size: 2.4rem;
}
#main .price .txtArea {
	margin-bottom: 6.8rem;
	padding-bottom: 3.6rem;
	border-bottom: 0.2rem solid #F3AF00;
}
#main .price .txtArea h3 {
	margin-bottom: 0.4rem;
	text-align: center;
	font-size: 3.6rem;
}
#main .price .txtArea p {
	color: #F3AF00;
	font-weight: 700;
	line-height: 2;
	text-align: justify;
	letter-spacing: 0.18rem;
}
#main .price .priceBox {
	margin-bottom: -11rem;
	padding: 5.4rem 4rem 8rem;
	position: relative;
	border-radius: 1rem;
	background-color: #F3AF00;
}
#main .price .priceBox::before {
	position: absolute;
	width: 2.8rem;
	height: 1.6rem;
	top: -1.5rem;
	left: 50%;
	transform: translatex(-50%);
	background: #F3AF00;
	clip-path: polygon(0 100%, 100% 100%, 52% 1%);
	content: "";
  }
#main .price .priceBox h3 {
	margin-bottom: 2.6rem;
	text-align: center;
	letter-spacing: 0.216rem;
	font-size: 3.6rem;
	font-weight: 500;
}
#main .price .priceBox h3 .big {
	position: relative;
	display: inline-block;
	font-size: 4.4rem;
	font-weight: 700;
}
#main .price .priceBox h3 .big::before {
	position: absolute;
	height: 0.6rem;
	left: 0;
	right: 0;
	bottom: 0.1rem;
	border-radius: 2rem;
	background-color: #E96C12;
	content: "";
}
#main .price .priceBox h3 .num {
	font-weight: 700;
	font-size: 7rem;
	line-height: 1.2;
	vertical-align: -0.3rem;
	letter-spacing: 0.56rem;
}
#main .price .priceBox p {
	margin-bottom: 0;
	line-height: 2;
	text-align: justify;
	letter-spacing: 0.18rem;
}
#main .price .priceList li:first-child {
	border-top: 0.1rem solid #444;
}
#main .price .priceList li {
	padding: 1.1rem 0 1.2rem;
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	font-size: 2.2rem;
	font-weight: 700;
	letter-spacing: 0.132rem;
	justify-content: space-between;
	border-bottom: 0.1rem solid #444;
}
#main .price .priceList li .num {
	width: 30rem;
	display: block;
	text-align: right;
	font-size: 2.4rem;
	letter-spacing: 0.096rem;
}
#main .price .priceList li .num .tag {
	font-size: 1.4rem;
	letter-spacing: 0.056rem;
}
#main .price .priceList li .ttl {
	width: calc(100% - 30rem);
}
#main .price .priceList {
	margin-bottom: 2rem;
}
#main .price .priceBox .smlTxt {
	margin-bottom: 0.4rem;
	font-size: 1.4rem;
	letter-spacing: 0.14rem;
}
#main .price .priceBox .noteList {
	display: flex;
	flex-wrap: wrap;
}
#main .price .priceBox .noteList li {
	margin-right: 1rem;
	font-size: 1.4rem;
	letter-spacing: 0.14rem;
}
#main .price .bgiPhoto img {
	width: 100%;
}
#main .flow {
	padding: 15rem 0 13.4rem;
	background: url("../img/index/flow_bg.webp") no-repeat center bottom / cover;
}
#main .flow .content {
	max-width: 94.0rem;
}
#main .flow .flowList li {
	margin-bottom: 1.8rem;
	width: 100%;
	letter-spacing: 0.18rem;
}
#main .flow .flowList li:last-child {
	margin-bottom: 0;
}
#main .flow .flowList .step {
	margin-bottom: 2rem;
	display: flex;
	flex-wrap: wrap;
	justify-content: space-between;
	border-radius: 5.5rem;
	color: #FFF;
	font-size: 3rem;
	overflow: hidden;
	background-color: #E96C12;
}
#main .flow .flowList .step .num {
	padding: 0 0.7rem 0.2rem 0;
	width: 15rem;
	display: flex;
	justify-content: center;
	align-items: center;
	font-size: 2.2rem;
	letter-spacing: 0.22rem;
	background-color: #444;
	clip-path: polygon(0% 0%, 80% 0%, 100% 50%, 80% 100%, 0% 100%);
}
#main .flow .flowList .step .ttl {
	padding: 1.3rem 0 1.2rem;
	width: calc(100% - 18rem);
	font-weight: 700;
}
#main .flow .flowList .text {
	min-height: 7.2rem;
	letter-spacing: 0.18rem;
	line-height: 2;
	text-align: justify;
}
#main .flow .flowList .wid01 {
	width: 50%;
}
#main .flow .flowList .wid02 {
	width: 47.8%;
}
#main .flow .flowList .wid02 {
	padding-bottom: 1.9rem;
}
#main .doctor {
	padding: 14rem 0 18rem;
	background: url("../img/index/doctor_bg.webp") no-repeat center top / 100%;
}
#main .doctor .headLine01 {
	margin-bottom: -0.4rem;
	color: #FFF;
}
#main .doctor .pTop {
	margin-bottom: 7.1rem;
	color: #FFF;
	text-align: center;
	font-size: 2.6rem;
	font-weight: 700;
	line-height: 1.68;
	letter-spacing: 0.26rem;
}
#main .doctor .pTop .big {
	font-size: 3.6rem;
	color: #FFE9B1;
	letter-spacing: 0.36rem;
}
#main .doctor .imgBox {
	margin-bottom: 6rem;
	padding: 5rem 5rem 4.2rem;
	align-items: flex-start;
	border-radius: 1rem;
	background-color: #F2F2F2;
}
#main .doctor .imgBox:last-child {
	margin-bottom: 0;
} 
#main .doctor .imgBox .phoBox {
	width: 38%;
	order: 1;
	overflow: hidden;
	border-radius: 1rem;
}
#main .doctor .imgBox .phoBox img {
	width: 100%;
}
#main .doctor .imgBox .txtBox {
	margin-top: -0.6rem;
	width: 56%;
}
#main .doctor .imgBox .txtBox h3 {
	margin-bottom: 2rem;
	padding-bottom: 1.2rem;
	font-size: 5rem;
	letter-spacing: 0.2rem;
	border-bottom: 0.1rem solid #77A8CB;
}
#main .doctor .imgBox .txtBox h3 .blue {
	margin-bottom: 0.9rem;
	display: block;
	color: #77A8CB;
	font-size: 2.2rem;
	line-height: 1.6;
	font-weight: 500;
	letter-spacing: 0.22rem;
}
#main .doctor .imgBox .txtBox p {
	line-height: 2.11;
	letter-spacing: 0.108rem;
	text-align: justify;
}
#main .group {
	padding-top: 12rem;
}
#main .group .bgBox {
	position: relative;
	padding-bottom: 8.0rem;
}
#main .group .bgBox::before {
	position: absolute;
	left: 0;
	top: 8rem;
	bottom: 0;
	width: 100%;
	background: url("../img/index/group_bg.webp") repeat-y left top;
	background-size: 100%;
	content: "";
}
#main .group .content {
	max-width: 124rem;
}
#main .group .textBox {
	margin-top: 3.1rem;
	width: 50.75%;
	color: #FFF;
}
#main .group h2 {
	margin-bottom: 2.6rem;
	padding-bottom: 2rem;
	border-bottom: 0.1rem solid #FFF;
}
#main .group h2 .en {
	margin: 0 -3rem 8.4rem 0;
	display: block;
	color: #82B10F;
	font-size: 2.4rem;
	font-weight: 600;
	letter-spacing: 1.728rem;
}
#main .group h2 .jp {
	margin-bottom: 2.8rem;
	display: block;
	color: #FFE9B1;
	font-weight: 700;
	font-size: 2.4rem;
	letter-spacing: 0.144rem;
}
#main .group p {
	margin-bottom: 1.3rem;
	letter-spacing: 0.18rem;
	line-height: 1.55;
}
#main .group .site {
	margin-bottom: 2.5rem;
	padding-left: 2.9rem;
	background: url("../img/common/icon17.webp") no-repeat left 0.2rem / 1.8rem;
}
#main .group .tel a {
	max-width: 34rem;
	height: 6rem;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #82B10F;
	font-size: 3rem;
	font-weight: 700;
	border-radius: 1rem;
	letter-spacing: 0.06rem;
	background-color: #FFF;
}
#main .group .tel .ico {
	padding-left: 2.9rem;
	display: inline-block;
	background: url("../img/common/icon18.webp") no-repeat left center / 2.1rem;
}
#main .group .photoBox {
	width: 43.3%;
}
#main .group .photoBox img {
	width: 100%;
}
#main .group .photoBox .pho {
	border-radius: 1rem;
	overflow: hidden;
	box-shadow: 0 1rem 2rem 0 rgba(0, 0, 0, 0.20);
}
#main .group .photoBox .pho01 {
	margin-right: 6rem;
}
#main .group .photoBox .pho02 {
	margin: -6rem 0 0 auto;
	position: relative;
	width: 73.2%;
}
#main .group .bigPhoto img {
	width: 100%;
}
@media all and (max-width: 896px) {
	.mainVisual {
		height: 54.4rem;
		padding: 11.7rem 1rem 0;
		background-image: url(../img/index/main_visual_bg_sp.webp);
	}
	.mainVisual .textBox {
		max-width: inherit;
	}
	.mainVisual .en {
		margin-bottom: 0.4rem;
		font-size: 0.8rem;
		letter-spacing: 0.416rem;
	}
	.mainVisual .ttl {
		margin: 0 0 0.4rem -0.3rem;
		font-size: 2.6rem;
		line-height: 3rem;
		letter-spacing: -0.5rem;
	}
	.mainVisual .ttl .sml01 {
		font-size: 2rem;
	}
	.mainVisual .ttl .txt02 {
		margin-top: 0.9rem;
	}
	.mainVisual .ttl .big {
		font-size: 5rem;
	}
	.mainVisual .ttl .sml02 {
		margin-left: -1.3rem;
		font-size: 2.2rem;
	}
	.mainVisual .title {
		margin-bottom: 1.5rem;
		font-size: 1rem;
		letter-spacing: 0.08rem;
	}
	.mainVisual ul {
		margin-left: 0;
		width: 37rem;
	}
	.mainVisual li {
		width: 11rem;
		height: 10.8rem;
		margin-bottom: 0.9rem;
		padding-top: 3.6rem;
		font-size: 1rem;
		margin-right: -1.2rem;
	}
	.mainVisual li span {
		font-size: 1.55rem;
	}
	.mainVisual li:last-child {
		margin-bottom: 0;
	}
	.mainVisual .list03 {
		padding-top: 4rem;
	}
	.mainVisual .list03 span {
		font-size: 1.9rem;
	}
	.mainVisual .list02 {
		padding-top: 3.2rem;
	}
	.mainVisual .list02 span {
		font-size: 1.3rem;
	}
	.mainVisual .list02 span span {
		letter-spacing: -0.1rem;
	}
	.mainVisual .list01 {
		padding-top: 3.6rem;
	}
	.mainVisual .list01 span {
		margin-top: 0;
		font-size: 1.85rem;
	}
	.mainVisual .list01 .num {
		font-size: 1.5rem;
	}
	#main .anxiety {
		margin-top: -5.2rem;
		padding: 11.9rem 0 8.5rem;
		background-image: url(../img/index/anxiety_bg_sp.webp);
	}
	#main .anxiety .img {
		left: -1.9rem;
		bottom: auto;
		top: 8.7rem;
		width: 11rem;
	}
	#main .anxiety h2 {
		margin-bottom: 2.4rem;
		font-size: 2.4rem;
		line-height: 1.47;
		letter-spacing: 0.12rem;
	}
	#main .anxiety h2 span {
		font-size: 4rem;
	}
	#main .anxiety h2 span::before {
		top: 0.3rem;
		width: 0.6rem;
		height: 0.6rem;
	}
	#main .anxiety ul {
		width: auto;
		margin: 0 auto 3.4rem;
	}
	#main .anxiety li {
		margin-bottom: 1rem;
		height: 6rem;
		display: flex;
		align-items: center;
		padding: 0.4rem 1rem 0.6rem 5.3rem;
		font-size: 1.6rem;
		line-height: 1.37;
		letter-spacing: 0.128rem;
		background-position: left 1.2rem top 44%;
		background-size: 3.2rem auto;
	}
	#main .anxiety p {
		line-height: 1.9;
		font-size: 2rem;
		letter-spacing: 0.16rem;
	}
	#main .anxiety p span {
		font-size: 4rem;
		line-height: 1;
		letter-spacing: 0.32rem;
	}
	#main .never {
		padding-top: 6.1rem;
	}
	#main .never h2 {
		margin-bottom: 1rem;
		font-size: 2.4rem;
		letter-spacing: 0.056rem;
	}
	#main .never h2 span {
		margin-top: 0.2rem;
		font-size: 2.8rem;
		letter-spacing: -0.1rem;
	}
	#main .never .topText {
		margin-bottom: 3.4rem;
		font-size: 1.8rem;
		line-height: 1.66;
		letter-spacing: 0.144rem;
	}
	#main .never ul {
		display: block;
	}
	#main .never li {
		width: auto;
		margin-bottom: -1px;
	}
	#main .never li p {
		font-size: 1.8rem;
		line-height: 1.43;
		letter-spacing: 0.144rem;
		transform: translateY(-56%);
	}
	#main .never li p .big {
		font-size: 2.6rem;
		letter-spacing: 0.208rem;
	}
	#main .figures {
		padding: 7.8rem 0 8.7rem;
		background-size: 1.3rem auto,cover;
	}
	#main .figures h2 {
		margin-bottom: 2.4rem;
		font-size: 2.2rem;
		letter-spacing: 0.308rem;
	}
	#main .figures h2 .orage {
		margin-bottom: -0.5rem;
		font-size: 2.4rem;
		font-weight: 600;
		letter-spacing: -0.2rem;
	}
	#main .figures h2 .bgi01 {
		font-size: 3.6rem;
	}
	#main .figures h2 .bgi02 {
		font-size: 4.8rem;
	}
	#main .figures ul {
		display: block;
	}
	#main .figures li {
		width: auto !important;
		padding: 2.5rem 1rem;
		height: 26.5rem;
	}
	#main .figures ul li:first-child {
		border-bottom: 0.2rem solid #E96C12;
	  }
	#main .figures li:not(:last-child)::before {
		display: none;
	}
	#main .figures li .img {
		bottom: 2rem;
		right: -1rem;
		width: 23rem;
	}
	#main .figures li p {
		font-size: 2rem;
		line-height: 1.5;
		letter-spacing: 0.2rem;
	}
	#main .figures li .big {
		margin: -0.2rem 0 0;
		font-size: 2rem;
	}
	#main .figures li .num {
		font-size: 9rem;
	}
	#main .figures .list01 {
		padding: 1.8rem 1rem;
		height: 21.8rem;
	}
	#main .figures .list01 p {
		line-height: 1.35;
	}
	#main .figures .list01 .img {
		width: 16rem;
		right: 3rem;
		bottom: 1.9rem;
	}
	#main .figures .list01 .num {
		margin-bottom: 0.1rem;
		font-size: 9rem;
		display: block;
	}
	#main .figures .list03 {
		padding: 2.3rem 1rem;
		height: 30.1rem;
	}
	#main .figures .list03 .img {
		width: 20.4rem;
		right: -0.6rem;
		bottom: 3rem;
	}
	#main .figures .list03 .big {
		margin: 0;
		font-size: 2rem;
	}
	#main .figures .list03 .num {
		font-size: 8rem;
	}
	#main .figures .list04 {
		padding: 2.3rem 1rem;
		height: 24.1rem;
	}
	#main .figures .list04 .img {
		width: 16rem;
		right: 1.9rem;
		bottom: 2.6rem;
	}
	#main .figures .list04 .big {
		margin: -0.3rem -0.4rem 0;
		font-size: 2.8rem;
	}
	#main .figures .list04 .num {
		font-size: 9rem;
	}
	#main .figures .list04 .sml {
		font-size: 1.2rem;
		line-height: 1.5;
		letter-spacing: 0.096rem;
	}
	#main .life {
		padding: 5.9rem 0 0;
		background-size: 4.2rem auto,cover;
	}
	#main .life h2 {
		margin-bottom: 2.2rem;
		font-size: 2.2rem;
		letter-spacing: 0.308rem;
	}
	#main .life h2 .white {
		margin-bottom: 0.7rem;
		font-size: 3.7rem;
	}
	#main .life h2 .sml {
		font-size: 2.4rem;
		font-weight: 700;
		letter-spacing: -0.07rem;
	}
	#main .life h2 .big {
		margin-left: 0;
		font-size: 4.8rem;
		letter-spacing: -0.6rem;
	}
	#main .life .bgText {
		margin-bottom: 2rem;
		padding: 1.3rem 2rem 1.3rem;
		font-size: 1.6rem;
		letter-spacing: 0.16rem;
	}
	#main .life .img01 {
		margin-bottom: 2.5rem;
	}
	#main .life .img01 img {
		width: 100%;
	}
	#main .life ul {
		margin: 0 1rem 7rem;
		display: block;
	}
	#main .life li {
		width: auto;
		margin-bottom: 1.6rem;
	}
	#main .life li .bgBox {
		padding: 1.7rem 2.7rem 2.7rem;
	}
	#main .life li h3 {
		margin-bottom: 0.2rem;
		padding-bottom: 1rem;
		font-size: 2.6rem;
		letter-spacing: 0.26rem;
	}
	#main .life li .title {
		font-size: 3rem;
	}
	#main .life li .title .num {
		margin: 0 0.3rem;
		font-size: 5.6rem;
	}
	#main .life li .title .unit {
		font-size: 4rem;
	}
	#main .life li .text {
		font-size: 1.8rem;
		letter-spacing: 0.18rem;
	}
	#main .life li .note {
		margin-top: 0.6rem;
		font-size: 1.2rem;
		line-height: 1.65;
		letter-spacing: 0.096rem;
	}
	#main .life li:last-child .bgBox::before {
		bottom: -6rem;
	}
	#main .life .img02 {
		width: auto;
		margin: 0 1rem;
	}
	#main .life .img02 img {
		width: 100%;
	}
	#main .life .img02 span {
		margin: 1.7rem 0 0;
		font-size: 1.3rem;
		line-height: 1.53;
		letter-spacing: 0.078rem;
	}
	#main .life .pho {
		position: static;
		width: auto;
		text-align: center;
		margin: -3.6rem 0 0 3rem;
	}
	#main .life .pho img {
		width: 26.1rem;
	}
	#main .danger {
		padding: 6.1rem 0 7.7rem;
	}
	#main .danger h2 {
		margin-bottom: 2.3rem;
		font-size: 2.6rem;
		line-height: 1.35;
		letter-spacing: 0.26rem;
	}
	#main .danger h2 span {
		letter-spacing: 0.26rem;
	}
	#main .danger h2 .big {
		font-size: 4rem;
		letter-spacing: 0.4rem;
	}
	#main .danger p {
		max-width: inherit;
		line-height: 1.875;
		letter-spacing: 0.16rem;
	}
	#main .danger .comArrow {
		bottom: -4rem;
	}
	#main .reason {
		padding: 5.9rem 0 4rem;
	}
	#main .reason .comArrow {
		bottom: -7.7rem;
	}
	#main .reason h2 {
		padding-top: 4.8rem;
		margin-bottom: 2.8rem;
		font-size: 2.4rem;
		line-height: 1.4;
		letter-spacing: 0.144rem;
		background-size: 17.7rem auto;
	}
	#main .reason h2 > span {
		font-size: 4rem;
		margin-top: 0.8rem;
	}
	#main .reason h2 .num {
		margin: -1rem 0 0 0;
		font-size: 8rem;
	}
	#main .reason .bgBox::before {
		display: none;
	}
	#main .reason .imgBox {
		margin-bottom: 0;
		display: block;
	}
	#main .reason .textBox {
		margin: 0 !important;
		min-height: inherit;
		width: auto;
		padding: 4.9rem 2rem 5.4rem;
		border-radius: 0 !important;
	}
	#main .reason .widBox {
		max-width: inherit;
	}
	#main .reason .textBox .num {
		margin-bottom: 2.4rem;
		font-size: 2rem;
		letter-spacing: 0.2rem;
	}
	#main .reason .textBox .num::before {
		left: calc(100% + 1.1rem);
		top: 53%;
	}
	#main .reason .textBox h3 {
		font-size: 2.8rem;
		line-height: 1.5;
	}
	#main .reason .textBox h3 span {
		letter-spacing: 0;
	}
	#main .reason .textBox p {
		line-height: 1.875;
		letter-spacing: 0.16rem;
	}
	#main .reason .pho {
		width: auto;
		border-radius: 0 !important;
	}
	#main .reason .imgInfo {
		max-width: inherit;
		margin: 0;
		padding: 5.4rem 2rem 0.8rem;
		display: block;
		background-color: #FFEFE4;
	}
	#main .reason .textInfo {
		width: auto;
	}
	#main .reason .textInfo h3 {
		margin-bottom: 2.6rem;
		font-size: 2.2rem;
		line-height: 1.54;
		letter-spacing: 0.22rem;
	}
	#main .reason .textInfo p {
		line-height: 1.875;
		letter-spacing: 0.16rem;
	}
	#main .reason .textInfo p span {
		margin-top: 0;
		line-height: 2;
	}
	#main .reason .img {
		width: auto;
		margin: 3rem -0.5rem 0 -2.5rem;
	}
	#main .implant {
		padding: 28.7rem 0 20.8rem;
		background-image: url(../img/index/implant_bg01_sp.webp);
	}
	#main .implant .img {
		width: 18rem;
	}
	#main .implant .comArrow {
		bottom: -4rem;
	}
	#main .implant .content {
		margin: 0 -0.5rem;
	}
	#main .implant h2 {
		margin: 0 auto 2.1rem;
	}
	#main .implant h2 .en {
		margin-bottom: 1.1rem;
		font-size: 1.4rem;
		letter-spacing: 0.742rem;
	}
	#main .implant h2 .jp {
		padding: 1.2rem 0 1.3rem;
		font-size: 2.2rem;
		letter-spacing: 0.308rem;
	}
	#main .what {
		margin-bottom: 5.3rem;
	}
	#main .what h3 {
		margin: 0 0 1.3rem;
		font-size: 3.2rem;
		text-align: center;
		letter-spacing: 0;
	}
	#main .what h3 span {
		margin: -0.4rem 0 0;
		font-size: 4.2rem;
		letter-spacing: 0;
	}
	#main .what p {
		margin: 0 0.5rem;
		max-width: inherit;
		line-height: 1.93;
		letter-spacing: 0.16rem;
	}
	#main .advantage h2 {
		margin-bottom: 3rem;
	}
	#main .advantage h2 .en {
		letter-spacing: 0.546rem;
	}
	#main .advantage ul {
		margin: 0 0.5rem 2.1rem;
		display: block;
	}
	#main .advantage li {
		width: auto;
		padding-bottom: 3.4rem;
	}
	#main .advantage li .pho {
		margin-bottom: 2.1rem;
	}
	#main .advantage li h3 {
		margin-bottom: 1.4rem;
		line-height: 1.55;
	}
	#main .advantage li p {
		line-height: 1.875;
	}
	#main .advantage .bgBox {
		margin: 0 0.5rem;
		padding: 4.3rem 2rem 4.2rem;
		background: url(../img/index/implant_bg02.webp) no-repeat top center;
		background-size: cover;
		border-radius: 1rem;
	}
	#main .advantage .bgBox h3 {
		margin: 0 auto 3.3rem;
		font-size: 2.4rem;
	}
	#main .advantage .bgBox h3::before {
		height: 1.4rem;
	}
	#main .advantage .bgBox h3::after {
		position: absolute;
		left: 1.5rem;
		top: 2.2rem;
		right: 1.5rem;
		height: 1.4rem;
		background-color: #fff;
		border-radius: 1rem;
		content: "";
	}
	#main .advantage .bgBox p {
		max-width: inherit;
		line-height: 1.875;
		letter-spacing: 0.128rem;
	}
	#main .features {
		padding: 6rem 0 10rem;
	}
	#main .features .comArrow {
		bottom: -3.7rem;
	}
	#main .features .headLine01 {
		margin-bottom: 3.6rem;
	}
	#main .features ul {
		margin: 0 2rem;
		display: block;
	}
	#main .features li {
		width: auto;
		margin: 0 0 4.4rem;
	}
	#main .features .pho span {
		left: -2rem;
		top: -2rem;
		width: 7rem;
		height: 7rem;
		padding: 0.9rem 0.2rem 0 0;
	}
	#main .features li p {
		line-height: 1.875;
	}
	#main .case {
		padding: 6.9rem 0 9.1rem;
	}
	#main .case .img {
		left: -5.8rem;
		top: -6rem;
		width: 16.5rem;
	}
	#main .case h2 {
		margin-bottom: 4.1rem;
		font-size: 2.4rem;
		letter-spacing: 0.144rem;
	}
	#main .case h2 span {
		margin: 1rem auto;
		font-size: 3rem;
		letter-spacing: 0.18rem;
	}
	#main .case h2 span::before {
		right: -2.6rem;
		top: -3.1rem;
		background-size: 100% 100%;
		width: 4rem;
		height: 4.7rem;
	}
	#main .case .topText {
		margin: 0 -1rem 3.6rem;
		font-size: 1.8rem;
		line-height: 1.77;
		letter-spacing: 0.108rem;
	}
	#main .case .topText span {
		letter-spacing: 0.108rem;
	}
	#main .case .whiteBg {
		padding: 4rem 0;
		max-width: inherit;
		margin: 0 auto 6rem;
	}
	#main .case .imgList {
		margin: 0 2rem 4.1rem;
		display: block;
	}
	#main .case .imgList li {
		width: auto;
	}
	#main .case .imgList li:first-child {
		margin-bottom: 3.9rem;
	}
	#main .case .imgList li:first-child::before {
		right: 50%;
		top: auto;
		bottom: -2.9rem;
		width: 2rem;
		height: 2rem;
		margin-right: -1rem;
		transform: rotate(90deg);
	}
	#main .case .imgList li span {
		top:  1.2rem;
		font-size: 2rem;
	}
	#main .case .whiteBg table {
		border-radius: 0;
	}
	#main .case .whiteBg th,
	#main .case .whiteBg td {
		padding: 1.2rem 0.5rem 1.1rem;
		font-size: 1.3rem;
		height: 6rem;
		line-height: 1.4;
		letter-spacing: 0.13rem;
	}
	#main .case .whiteBg td {
		padding-left: 1.1rem;
	}
	#main .case .whiteBg th {
		width: 23.6%;
	}
	#main .case .whiteBg th::before {
		top: 1rem;
		bottom: 1rem;
	}
	#main .case .whiteBg td ul {
		padding: 0.4rem 0 0.4rem;
	}
	#main .case .whiteBg td ul li:not(:last-child) {
		padding-bottom: 1rem;
	}
	#main .case .whiteBg td span {
		margin-bottom: 0.2rem;
	}
	#main .case .whiteBg .info:not(:last-child) {
		margin-bottom: 6rem;
	}
	#main .case .bgBox {
		max-width: inherit;
		padding: 2.3rem 2rem 23.7rem;
	}
	#main .case .bgBox h3 {
		margin-bottom: 2.1rem;
		font-size: 2.2rem;
		line-height: 1.4;
		letter-spacing: 0.132rem;
	}
	#main .case .bgBox h3 span {
		font-size: 2.8rem;
		letter-spacing: 0.168rem;
	}
	#main .case .bgBox ul {
		width: auto;
	}
	#main .case .bgBox li {
		padding: 0.9rem 0 0.8rem 3.1rem;
		font-size: 1.6rem;
		letter-spacing: 0.096rem;
		background-size: 2.4rem auto;
	}
	#main .case .bgBox li span {
		font-size: 2rem;
		letter-spacing: 0.12rem;
	}
	#main .case .bgBox .person {
		bottom: -9.1rem;
		right: -2rem;
		width: 34.5rem;
	}
	#main .price .bgBox{
		padding: 9.5rem 0 1rem;
	}
	#main .price .headLine01 {
		margin-bottom: 3.4rem;
		letter-spacing: 0.228rem;
	}
	#main .price .dlText {
		margin-bottom: 2.3rem;
		padding: 0;
		display: block;
		letter-spacing: 0.056rem;
	}
	#main .price .dlText dt {
		width: auto;
		padding: 2rem 0 2.3rem;
		font-size: 2.8rem;
	}
	#main .price .dlText .txt {
		margin-bottom: -0.2rem;
		font-size: 2.8rem;
		letter-spacing: 0.168rem;
	}
	#main .price .dlText dd {
		width: auto;
		padding: 2.5rem 0 1.9rem;
		font-size: 3.2rem;
		border-left: none;
		border-top: 0.2rem solid #F3AF00;
	}
	#main .price .dlText dd .txt {
		margin-bottom: 0;
		letter-spacing: -0.13rem;
	}
	#main .price .dlText dd .tag {
		font-size: 2.2rem;
		letter-spacing: 0.044rem;
	}
	#main .price .dlText dd .sub {
		display: inline-block;
		text-align: left;
	}
	#main .price .dlText dd .num {
		margin-left: 1.3rem;
		display: inline-block;
		line-height: 1.25;
	}
	#main .price .txtArea {
		margin-bottom: 5.6rem;
		padding-bottom: 2.3rem;
	}
	#main .price .txtArea h3 {
		margin: 0 -0.5rem 1.1rem;
		font-size: 2.8rem;
	}
	#main .price .txtArea p {
		line-height: 1.88;		
		letter-spacing: 0.16rem;
	}
	#main .price .priceBox {
		margin-bottom: -8.5rem;
		position: relative;
		z-index: 1;
		padding: 5.4rem 2rem 5rem;
	}	
	#main .price .priceBox h3 {
		margin-bottom: 3.1rem;
		letter-spacing: 0.144rem;
		font-size: 2.4rem;
	}
	#main .price .priceBox h3 .big {
		display: inline-block;	
		font-size: 2.8rem;
	}
	#main .price .priceBox h3 .big::before {
		height: 0.5rem;		
		bottom: -0.4rem;
	}
	#main .price .priceBox h3 .num {
		font-size: 5rem;
		letter-spacing: 0.4rem;
		line-height: 1;
	}
	#main .price .priceBox p {
		margin-bottom: 0;
		line-height: 1.88;		
		letter-spacing: 0.16rem;
	}
	#main .price .priceList li {
		padding: 1.5rem 0 1.6rem;
		min-height: 6rem;
		font-size: 1.6rem;
		letter-spacing: 0.032rem;
	}
	#main .price .priceList li .num {
		width: 15rem;
		font-size: 2.2rem;
		line-height: 1.1;
		letter-spacing: 0.044rem;
	}
	#main .price .priceList li .num .tag {
		font-size: 1.2rem;
		letter-spacing: 0.024rem;
	}
	#main .price .priceList li .num .sub {
		display: inline-block;
		text-align: left;
	}
	#main .price .priceList li .ttl {
		margin-right: -1rem;
		width: calc(100% - 14rem);
	}
	#main .price .priceList {
		margin-bottom: 2rem;
	}
	#main .price .priceBox .smlTxt {
		margin-bottom: -0.1rem;
		font-size: 1.2rem;
		letter-spacing: 0.12rem;
	}
	#main .price .priceBox .noteList {
		display: block;
	}
	#main .price .priceBox .noteList li {
		margin-right: 0;
		padding-left: 1.1em;
		font-size: 1.2rem;
		line-height: 1.65;
		letter-spacing: 0.12rem;
		text-indent: -1.1em;
	}
	#main .flow {
		padding: 6rem 0 7rem;
		background-image: url("../img/index/flow_bg_sp.webp");
	}
	#main .flow .flowList li {
		margin-bottom: 2rem;
		width: 100% !important;
	}
	#main .flow .flowList .step {
		margin-bottom: 1rem;
		font-size: 3rem;
	}
	#main .flow .flowList .step .num {
		padding: 0 0rem 0rem 0;
		width: 11rem;
		font-size: 1.8rem;
		letter-spacing: 0.18rem;
		clip-path: polygon(0% 0%, 82% 0%, 100% 50%, 82% 100%, 0% 100%);
	}
	#main .flow .flowList .step .ttl {
		padding: 0.8rem 0 0.9rem;
		width: calc(100% - 12.3rem);
		font-size: 2.2rem;
		letter-spacing: 0.132rem;
	}
	#main .flow .flowList .text {
		min-height: inherit;
		letter-spacing: 0.16rem;
		line-height: 1.88;
	}
	#main .flow .flowList .wid02 {
		padding-bottom: 0;
	}
	#main .doctor {
		padding: 9.8rem 0 6rem;
		background-image: url("../img/index/doctor_bg_sp.webp");
	}
	#main .doctor .headLine01 {
		margin-bottom: 1.6rem;
	}
	#main .doctor .headLine01 .en {
		letter-spacing: 1.12rem;
	}
	#main .doctor .pTop {
		margin-bottom: 5.9rem;
		font-size: 2.2rem;
		line-height: 1.64;
		letter-spacing: 0.22rem;
	}
	#main .doctor .pTop .big {
		font-size: 3rem;
		line-height: 1.2;
		letter-spacing: 0.3rem;
	}
	#main .doctor .imgBox {
		margin-bottom: 2rem;
		padding: 2rem 2rem 3.2rem;
		display: block;
	}
	#main .doctor .imgBox .phoBox {
		width: auto;
		position: relative;
		padding-bottom: 95%;
	}
	#main .doctor .imgBox .phoBox img {
		position: absolute;
		left: 0;
		top: 0;
		height: 100%;
		object-fit: cover;
		object-position: center top;
	}
	#main .doctor .imgBox .txtBox {
		margin-top: 3.1rem;
		width: auto;
	}
	#main .doctor .imgBox .txtBox h3 {
		margin-bottom: 2.1rem;
		padding-bottom: 1.3rem;
		font-size: 3.4rem;
		letter-spacing: 0.136rem;
	}
	#main .doctor .imgBox .txtBox h3 .blue {
		margin-bottom: 0.8rem;
		font-size: 2rem;
		line-height: 1.6;
		letter-spacing: 0.2rem;
	}
	#main .doctor .imgBox .txtBox p {
		line-height: 1.875;
	}
	#main .group {
		padding-top: 4.7rem;
	}
	#main .group .bgBox {
		padding-bottom: 4.7rem;
	}
	#main .group .bgBox::before {
		top: 3rem;
		background-size: 120rem;
	}
	#main .group .imgBox {
		display: block;
	}
	#main .group .textBox {
		margin-top: 0;
		width: auto;
	}
	#main .group h2 {
		margin-bottom: 1.4rem;
		padding-bottom: 3.3rem;
	}
	#main .group h2 .en {
		margin: 0 -3rem 6.1rem 0;
		font-size: 1.4rem;
		letter-spacing: 0.868rem;
	}
	#main .group h2 .jp {
		margin-bottom: 1.7rem;
	}
	#main .group h2 .logoImg {
		max-width: 30rem;
		display: block;
	}
	#main .group p {
		margin-bottom: 1.3rem;
		letter-spacing: 0.16rem;
	}
	#main .group .site {
		margin-bottom: 3rem;
		padding-left: 2.9rem;
		line-height: 1.6;
		background-position: left 0.1rem;
	}
	#main .group .photoBox {
		width: auto;
		margin: 5rem 2rem 0;
	}
	#main .group .photoBox .pho01 {
		margin-right: 3.4rem;
	}
	#main .group .photoBox .pho02 {
		margin-top: -3.4rem;
	}
	#main .group .bigPhoto {
		position: relative;
		padding-bottom: 37.5%;
		overflow: hidden;
	}
	#main .group .bigPhoto img {
		position: absolute;
		left: 0;
		top: 0;
		height: 100%;
		object-fit: cover;
	}
}

.mainVisual .imgcan img{width: 58rem;margin: 2.4rem 0 0;}
@media (max-width: 896px) {
.mainVisual .imgcan img {width: 26rem;margin: 0;}
	}