@charset "utf-8";

.img_bg_block {
	padding: 150px 0;
}
.under_page_wrap #wrapper {
	padding-top: 162px;
}
/*その他の追加変更 ここから*/
.m_ttl01 {
	margin-bottom: 50px;
}

.m_ttl01 span {
	font-size: 7.4rem;
	letter-spacing: 0.2em;
	padding-left: 0.2em;
}

.m_ttl01 em {
	font-size: 2.3rem;
	margin-top: 16px;
}

.m_txt p {
	line-height: 1.875;
}

.m_txt p+p {
	margin-top: 1em;
}

.btn01 {
	--btn-height: 70px;
	--btn-width: 380px;
	--icon-right: 20px;
	--icon-size: 28px;
	--border-radius: 10px;
	font-size: 1.7rem;
	padding: 10px 55px 10px;
	width: fit-content;
}

.implant_bnr img {
	width: 250px;
}

.fixed_implant {
	bottom: 10px;
	left: auto;
	right: 66px;
	width: 250px;
}

.fixed_implant_close {
	top: -1.1rem;
	right: -0.9rem;
	padding: 0 0 0.1rem;
	width: 2rem;
	font-size: 1.2rem;
	cursor: pointer;
}


/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
m_mv
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/

.m_mv:before {
	height: 190px;
	z-index: 1;
	z-index: 10;
	background: linear-gradient(180deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 50%,rgba(255, 255, 255, 0) 100%);
}

.m_mv_inner {
	position: relative;
}

.m_mv_main {
	position: relative;
	z-index: 1;
		height: 100vh;
		min-height: 750px;
}

.m_mv_main .oft {
	height: 100vh;
	min-height: 640px;
}

.m_mv_txt {
	top: 50%;
	left: auto;
	right: -40px;
	width: 961px;
	aspect-ratio: 1922/494;
	height: auto;
	transform: translateY(-50%);
}

.m_mv_en {
	bottom: 11px;
	left: -13px;
	color: #fff;
	opacity: 0.3;
	line-height: 1.02;
	letter-spacing: 0.05em;
	font-size: 17.8rem;
}

.m_mv_implant {
	bottom: 10px;
	right: 10px;
	left: auto;
	width: 250px;
}

/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_clinic
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/

.t_clinic .img_bg_block {
	padding: 100px 0 0;
}

.t_clinic_block {
	gap: 20px;
	grid-template-columns: repeat(2, 1fr);
}

.t_clinic_item {
	padding: 59px 50px;
}

.t_clinic_item:before,
.t_clinic_item:after {
	width: 222px;
}

.t_clinic_ttl {
	font-size: 3.2rem;
	letter-spacing: 0.15em;
	line-height: 1;
	margin-bottom: 35px;
}

.m_newslist_item_in {
	padding: 22px 0 25px;
}

.m_newslist_item_in .date {
	margin-right: 0;
	font-size: 1.5rem;
}

.m_newslist_item_in em {
	text-overflow: initial;
	overflow: hidden;
	white-space: wrap;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 3;
	overflow: hidden;
	line-height: 1.76;
}

.t_clinic_btn {
	margin-top: 46px;
}

.t_clinic_hosoku {
	margin-top: 13px;
	font-size: 1.5rem;
	letter-spacing: 0.03em;
	line-height: 1.6;
}

.t_clinic_hosoku+.t_clinic_hosoku {
	margin-top: 11px;
}

.t_clinic_access {
	background: url(../images/top/clinic_icon_pin.png) left top 6px / 10px no-repeat;
	padding-left: 23px;
	margin-top: 38px;
	font-size: 1.6rem;
}

.t_clinic_points {
	gap: 20px;
	margin-top: 13px;
}

.t_clinic_point {
	background: #e3f5f9 var(--icon) center top 25px / auto 37px no-repeat;
	border-radius: 5px;
	font-size: 1.8rem;
	padding-top: 71px;
}



/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_life
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
.t_life .img_bg_block {
	padding: 140px 0 0;
}

.t_life_block {
	display: grid;
	gap: 0;
	margin-top: 191px;
	grid-template-columns: repeat(5, 1fr);
}

.t_life_item {
	position: relative;

}

.t_life_item_img {
	top: -120px;
	height: 120px;
}


.t_life_item_in {
	padding: 19px 30px 46px;
	border-top: 4px solid #79ccf2;
	border-bottom: 4px solid #79ccf2;
	height: 100%;
}

.t_life_item_in:before {
	width: 18px;
	border-width: 4px;
}


.t_life_item_ttl {
	font-size: 2.3rem;
	padding-left: 0.16em;
}

.t_life_btns {
	margin-top: 19px;
}

.t_life_btn {
	--btn-height: 50px;
	--btn-width: 100%;
	--icon-right: 9px;
	--icon-size: 13px;
	position: relative;
	font-size: 1.6rem;
	padding: 5px 23px 6px;
	border-radius: 10px;
	letter-spacing: 0.02em;
	min-width: auto;
	width: 100%;
}

.t_life_btn span:before {
	border-radius: 10px;
}

.t_life_btn+.t_life_btn {
	margin-top: 10px;
}



/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_medical
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
.t_medical {
	position: relative;
	isolation: isolate;
}

.t_medical:before {
	width: max(1600px, 100%);
	background: url(../images/top/medical_bg01.jpg) left top / 600px no-repeat;
}

.t_medical:after {
	width: max(1600px, 100%);
	background: url(../images/top/medical_bg02.jpg) right top / 600px no-repeat;
}

.t_medical .img_bg_block {
	padding: 138px 0 150px;
}

.t_medical_pickups {
	margin: 70px 0 0;
	grid-template-columns: repeat(3, 1fr);
}

.t_medical_block {
	gap: 30px;
	grid-template-columns: repeat(3, 1fr);
	margin-top: 50px;
}

.t_medical_item {
	border-radius: 10px;
	background: #FFF var(--icon-url) 20px center / 50px no-repeat;
	box-shadow: 7px 7px 0 0 rgba(0,0,0,0.05);
	min-height: 100px;
	padding: 16px 38px 20px 86px;
}

.t_medical_item:before {
	right: 13px;
	width: 20px;
}

.t_medical_item_ttl span {
	font-size: 2.2rem;
}

.t_medical_item_ttl em {
	margin-top: 1px;
	font-size: 1.3rem;
}

/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_feature
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/

.t_feature:before {
	width: 1480px;
}

.t_feature:after {
	width: calc(100vw - 1300px);
	min-width: 600px;
	aspect-ratio: auto;
	height: 360px;
}

.t_feature .img_bg_block {

padding: 139px 0 217px;
}


.t_feature .img_bg_block:before {
	width: 1400px;
}

.t_feature .img_bg_block:after {
	width: 400px;
}

.t_feature_ttl:before {
	top: -134px;
	left: 193px;
	width: 381px;
}

.t_feature_ttl span {
	font-size: 7.4rem;
	padding-left: 0.2em;
	text-shadow: 1px 1px 0 #7bcbdc;
}

.t_feature_ttl span::first-letter {
	text-shadow: 1px 1px 0 #fff;
}

.t_feature_ttl em {
	background: #fff;
	padding: 7px 30px 9px;
	color: #00a0e9;
	letter-spacing: 0.16em;
	margin-top: 16px;
	font-size: 1.8rem;
}


.t_feature_item {
	--img-gutter: -170px;
	--body-gutter: -70px;
	--bg-gutter: 110px;
	--bg-height: 564px;
	margin-top: 110px;
	display: flex;
	gap: 40px;
}

.t_feature_block {
	margin-top: 80px;
}

.t_feature_item:before {
	content: '';
	display: block;
	position: absolute;
	bottom: -77px;
	top: auto;
	right: calc(-1 * var(--bg-gutter));
	left: auto;
	width: calc(100% + var(--bg-gutter) - var(--over-margin));
	height: var(--bg-height);
}


.t_feature_item_img_mini img,
.t_feature_item_img img {
	border-radius: 10px;

}

.t_feature_item_img img {
	z-index: 1;
}

.t_feature_item01 {
	--feature-bg: url(../images/top/feature01_bg.jpg);
	margin-top: 0;
}

.t_feature_item01 .t_feature_item_img:before {
	top: -9px;
	left: -9px;
	width: 999px;
}

.t_feature_item01 .t_feature_item_img_mini {
	width: 300px;
	top: 480px;
	right: auto;
	left: -121px;
}

.t_feature_item01 .t_feature_item_img_mini:before {
	top: -59px;
	right: -170px;
	width: 219px;
	aspect-ratio: 219/149;
}

.t_feature_item02 {
	flex-direction: row-reverse;
	margin-top: 126px;


	.t_feature_item_ttl span {
		margin-right: 25px;
	}

	.t_feature_item_body {
		margin-right: 0;
		margin-left: var(--body-gutter);
	}


	.t_feature_item_img {
		margin-right: var(--img-gutter);
		margin-left: 0;
	}

	&:before {
		left: calc(-1 * var(--bg-gutter));
		right: auto;
	}

	.t_feature_item_img:before {
		top: -153px;
		left: -84px;
		width: 390px;
	}

}

.t_feature_item03 {
	.t_feature_item_ttl span {
		margin-right: 25px;
	}

	.t_feature_item_img:before {
		top: -107px;
		right: -152px;
		width: 206px;
	}

	margin-top: 124px;--bg-height: 594px;
}

.t_feature_row {
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0;
	margin-top: 130px;
}

.t_feature_item04 {
	padding-right: 20px;
	gap: 20px;
	margin-top: 0;
	

	.t_feature_item_ttl {
		margin-bottom: 15px;
	}

	.t_feature_item_ttl span {
		margin-right: 24px;
	}

	.t_feature_item_body {
		margin-right: 0;
		margin-left: 0;
	}

	&:before {
		right: 0;
		left: auto;
		width: calc(100% - var(--over-margin));
		height: 575px;
		bottom: -65px;
	}

	.t_feature_item_img_mini {
		width: 160px;
		top: -147px;
		left: -3px;
	}


	.t_feature_item_img_mini:before {
		top: -45px;
		right: -16px;
		width: 219px;
	}
}

.t_feature_item05 {
	position: relative;
	top: -34px;
	padding-left: 20px;
	gap: 20px;
	flex-direction: row-reverse;
	margin-top: 0;


	.t_feature_item_ttl {
		margin-bottom: 15px;
	}

	.t_feature_item_body {
		margin-right: 0;
		margin-left: 0;
	}

	.t_feature_item_img {
		margin-right: var(--img-gutter);
		margin-left: 0;
		position: relative;
		bottom: -160px;
	}

	&:before {
		left: 0;
		right: auto;
		bottom: -65px;
		width: calc(100% - var(--over-margin));
		height: 575px;
	}

	.t_feature_item_img:before {
		top: -10px;
		left: -39px;
		width: 369px;
		aspect-ratio: 369/549;
		background: url(../images/top/feature_square07.png) center / 100% no-repeat;
	}
}

.t_feature_item_head {
	flex: 1;
}

.t_feature_item_img {
	margin-left: var(--img-gutter);
}

.t_feature_item_body {
	margin-top: 0;
	/* flex: 1; */
	width: 420px;
	margin-right: var(--body-gutter);
	padding-top: 19px;
}

.t_feature_item_ttl {
	margin-bottom: 22px;
}

.t_feature_item_ttl span {
	font-size: 9.5rem;
	margin-right: 30px;
}

.t_feature_item_ttl em {
	font-size: 2.5rem;
}

.t_feature_item_txt {
	letter-spacing: 0.05em;
}

.t_feature_item_content {
	padding: 34px 40px 68px;
	flex-direction: column;
	display: flex;
	min-height: 430px;
	justify-content: center;
}

.t_feature_item_catch {
	font-size: 2.3rem;
	padding-bottom: 22px;
	margin-bottom: 22px;
}

.t_feature_item_btn {
	position: absolute;
	bottom: -35px;
	left: 50%;
	transform: translateX(-50%);
	margin-top: 0;
}

.t_feature_item_btn .btn {
	--btn-width: 290px;
}

.t_feature_btn {
	margin-top: 190px;
}



/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_concept
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
.t_concept {
	background: #87a1b2;
	padding-top: 0;
}

.t_concept:before {
	top: 0;
	left: calc(50% - 320px);
	width: 1500px;
	aspect-ratio: 1500/789;
	z-index: -2;
	background: url(../images/top/concept_img01.jpg) center top / 100% no-repeat;
}
.t_concept:after {
	content: '';
display: block;
position: absolute;
top: 0;
left: 50%;
width: 100%;
height: 100%;
z-index: -3;
	background: #e6edf3;
}


.t_concept .img_bg_block {
	padding: 70px 0;
	min-height: 789px;
	display: flex;
	align-items: center;
}

.t_concept .img_bg_block:before {
	top: 0;
	left: 50%;
	transform: translateX(-50%);
	width: max(1600px,100%);
	height: 100%;
	background: url(../images/top/concept_bg01.png) left center / auto 100% no-repeat;
	z-index: -1;
}

.t_concept_block {
    width: 680px;
}

.t_concept_ttl {
	text-align: left;
	margin-bottom: 50px;
	width: fit-content;
}

.t_concept_ttl span {

color: #fff;

padding-left: 0;

font-size: 5.9rem;

letter-spacing: 0.13em;
}

.t_concept_ttl span:first-letter {
	color: #fff;
}

.t_concept_ttl em {
	gap: 22px;
	letter-spacing: 0.1em;
}

.t_concept_ttl em:after {
	top: 1px;
	background: linear-gradient(90deg, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 1) 65%, rgba(0, 0, 0, 0) 100%);
}

.t_concept_btn {
	margin-top: 50px;
}

.t_concept_btn .btn {
	margin: 0;
}

/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_other
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/
.t_other {
	background: url(../images/top/other_bg.jpg) center / cover no-repeat;
}

.t_other .img_bg_block {
    padding: 80px 0;
}

.t_other_block {
	display: flex;
	align-items: center;
	gap: 60px;
}

.t_other_insta {
	width: 490px;
}

.t_other_insta .t_other_ttl span {
	font-size: 3.4rem;
	letter-spacing: 0.2em;
}

.t_other_insta_head a {
	--icon-right: 12px;
	--icon-size: 18px;
	--border-radius: 5px;
	--border-width: 0px;
	font-size: 1.4rem;
	padding: 11px 40px 10px 27px;
	width: 110px;
	min-height: 40px;
	text-align: left;
}

.t_other_insta_body {
	margin-top: 40px;
}

.t_other_insta_body .t_other_insta_btn {
	width: 104px;
}

.t_other_recruit {
	padding: 50px 30px 183px;
	border-radius: 10px;
	margin-top: 0;
	flex: 1;
}

.t_other_recruit .t_other_ttl {
	gap: 30px;
	padding-left: 0;
}

.t_other_recruit .t_other_ttl span {
	font-size: 3.4rem;
	letter-spacing: 0.2em;
}

.t_other_recruit .t_other_ttl em {
	padding: 0px 0px 1px 2px;
	width: 100px;
	height: 30px;
	display: flex;
	align-items: center;
	justify-content: center;
}


.t_other_txt {
	margin-top: 30px;
	text-align: center;
}

.t_other_btn {
	margin-top: 30px;
}

/*______________________________________________________________________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
t_column
______________________________
^^^^^^^^^^^^^^^^^^^^^^^^^^^^*/

.t_column_ttl span {
	font-size: 3.4rem;
	letter-spacing: 0.2em;
}

.t_column_head a {
	--icon-right: 12px;
	--icon-size: 18px;
	--border-radius: 5px;
	--border-width: 0px;
	font-size: 1.4rem;
	padding: 11px 40px 10px 27px;
	width: 110px;
	min-height: 40px;
	text-align: left;
}

.t_column_block {
	margin-top: 37px;
}