@charset "UTF-8";
:root {
	--c-pink: var(--color-pink);
	--c-pink-deep: var(--color-pink-deep);
	--c-pink-soft: var(--color-pink-soft);
	--c-cream: var(--color-bg-base);
	--c-leaf: var(--color-green);
	--c-leaf-deep: var(--color-green-deep);
	--c-num-pink: var(--color-pink);
	--c-num-green: var(--color-green);
	--c-num-blue: #8FBFD6
}
.hero-v2 {
	background: var(--c-cream);
	position: relative;
	overflow: hidden
}
.hero-v2-inner {
	position: relative;
	display: grid;
	grid-template-columns: 1fr;
	grid-template-areas: "photo" "text"
}
.hero-v2-text {
	grid-area: text;
	padding: 32px 20px 40px 24px;
	position: relative;
	z-index: 2
}
.hero-v2-photo {
	grid-area: photo
}
@media (max-width:767px) {
	.hero-v2-text {
		margin-top: -120px;
		padding-top: 0;
		padding-bottom: 80px;
		z-index: 10
	}
	.hero-v2-leaf-tall {
		top: -70px;
		z-index: 11
	}
	.hero-v2-leaf {
		bottom: 8px;
		left: 16px;
		width: 220px;
		z-index: 1;
		opacity: .8
	}
	.hero-v2-cta {
		position: relative;
		z-index: 4
	}
}
.hero-v2-headline {
	font-size: 26px;
	line-height: 1.6;
	color: var(--color-brown);
	font-weight: 600;
	margin: 0 0 24px;
	letter-spacing: .04em
}
.hero-v2-headline .em {
	font-size: 1.35em;
	font-weight: 700;
	letter-spacing: .03em;
	padding: 0 .02em
}
.hero-v2-headline .em-pink {
	color: var(--color-pink)
}
.hero-v2-headline .em-green {
	color: var(--color-green)
}
.hero-v2-desc {
	font-size: 14px;
	line-height: 1.9;
	color: var(--color-text-mute);
	margin: 0 0 24px
}
.features-3-list p strong, .topDoctor-text p strong {
	color: var(--color-main-deep);
	font-weight: 700;
	border-bottom: 2px solid var(--color-pink);
	padding-bottom: 1px
}
.hero-v2-desc .em-underline {
	display: inline;
	background-image: linear-gradient(transparent 62%, rgba(244, 141, 161, .35) 62%, rgba(244, 141, 161, .35) 94%, transparent 94%);
	background-repeat: no-repeat;
	background-size: 0 100%;
	padding: 0 .12em;
	font-weight: 600;
	color: var(--color-brown);
	animation: emUnderlineDraw 1.4s cubic-bezier(.22, .61, .36, 1) .6s forwards
}
@keyframes emUnderlineDraw {
	to {
		background-size: 100% 100%
	}
}
@media (prefers-reduced-motion:reduce) {
	.hero-v2-desc .em-underline {
		background-size: 100% 100%;
		animation: none
	}
}
.hero-v2-cta {
	display: inline-flex;
	align-items: center;
	gap: 10px;
	background: var(--color-pink-deep);
	color: #fff;
	padding: 14px 28px;
	border-radius: 9999px;
	font-size: 14px;
	font-weight: 700;
	text-decoration: none;
	letter-spacing: .08em;
	box-shadow: 0 4px 12px rgba(224, 143, 161, .3);
	transition: background .2s, transform .2s
}
.hero-v2-cta:hover {
	background: #c97388;
	transform: translateY(-2px);
	opacity: 1
}
.hero-v2-cta .arrow {
	display: inline-flex;
	width: 22px;
	height: 22px;
	border-radius: 50%;
	background: #fff;
	color: var(--color-pink-deep);
	align-items: center;
	justify-content: center;
	font-weight: 700
}
.hero-v2-leaf {
	position: absolute;
	left: 12px;
	bottom: -8px;
	width: 160px;
	opacity: .9;
	pointer-events: none;
	z-index: 3
}
.hero-v2-leaf-tall {
	position: absolute;
	top: 24px;
	right: 8px;
	width: 70px;
	opacity: .85;
	pointer-events: none;
	z-index: 3;
	transform: rotate(-20deg);
	transform-origin: center center
}
@media (min-width:768px) {
	.hero-v2-leaf-tall {
		width: 90px;
		top: 60px;
		right: 12px;
		transform: rotate(-22deg)
	}
}
@media (min-width:1024px) {
	.hero-v2-leaf-tall {
		width: 110px;
		top: 70px;
		right: 16px;
		transform: rotate(-25deg)
	}
}
.hero-v2-photo {
	position: relative;
	background: #e8ddd0;
	width: 100%;
	aspect-ratio: 4/5;
	min-height: 360px;
	overflow: hidden
}
.hero-v2-photo::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	height: 180px;
	background: linear-gradient(to bottom, rgba(255, 253, 247, 0) 0, var(--c-cream) 70%, var(--c-cream) 100%);
	pointer-events: none;
	z-index: 5
}
.hero-v2-photo img, .hero-v2-photo picture, .hero-v2-photo picture img, .hero-v2-photo svg {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover;
	object-position: center center
}
.hero-v2-photo[data-slider] {
	position: relative;
	isolation: isolate
}
.hero-v2-photo[data-slider] .hero-slide {
	position: absolute;
	inset: 0;
	width: 100%;
	height: 100%;
	object-fit: cover;
	opacity: 0;
	transition: opacity 1.2s ease;
	pointer-events: none
}
.hero-v2-photo[data-slider] .hero-slide.is-active {
	opacity: 1;
	z-index: 2
}
.hero-v2-photo::before {
	content: none
}
@media (min-width:768px) {
	.hero-v2-inner {
		grid-template-columns: 1fr 1.15fr;
		grid-template-areas: "text photo";
		align-items: stretch;
		min-height: 540px
	}
	.hero-v2-photo {
		aspect-ratio: auto;
		max-height: none;
		min-height: 540px
	}
	.hero-v2-photo::after {
		display: none
	}
	.hero-v2-text {
		padding: 56px 32px 64px 9%;
		display: flex;
		flex-direction: column;
		justify-content: center
	}
	.hero-v2-headline {
		font-size: 32px
	}
	.hero-v2-desc {
		font-size: 15px
	}
	.hero-v2-leaf {
		width: 220px;
		left: 16px;
		bottom: -10px
	}
	.hero-v2-photo {
		position: relative;
		overflow: hidden
	}
	.hero-v2-photo::before {
		content: "";
		position: absolute;
		top: 0;
		left: -1px;
		bottom: 0;
		width: 80px;
		background: var(--c-cream);
		border-radius: 0 100% 100% 0/0 50% 50% 0;
		z-index: 4;
		pointer-events: none
	}
}
@media (min-width:1024px) {
	.hero-v2-inner {
		min-height: 620px
	}
	.hero-v2-text {
		padding: 80px 40px 96px 13%
	}
	.hero-v2-headline {
		font-size: 38px
	}
	.hero-v2-photo::before {
		width: 110px
	}
}
.features-3 {
	background: 0 0;
	padding: 40px 8px 48px;
	position: relative;
	overflow: hidden
}
.features-3-inner {
	max-width: 1100px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 28px;
	align-items: center
}
.features-3-photo {
	background: var(--c-pink-soft);
	border-radius: 20px;
	padding: 18px;
	box-shadow: 0 4px 20px rgba(236, 129, 148, .15);
	max-width: 340px;
	margin-inline: auto
}
.features-3-photo img, .features-3-photo svg {
	width: 100%;
	height: auto;
	aspect-ratio: 3/4;
	display: block;
	object-fit: cover;
	object-position: center center;
	border-radius: 12px
}
.features-3-body {
	color: var(--color-brown)
}
.features-3-title {
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	margin: 0 0 24px;
	letter-spacing: .04em
}
.features-3-title .num {
	display: inline-block;
	font-size: 1.7em;
	color: var(--c-pink-deep);
	font-weight: 800;
	margin: 0 .15em;
	line-height: 1
}
.features-3-list {
	list-style: none;
	margin: 0 auto;
	max-width: 520px;
	padding: 0
}
.features-3-list li {
	padding: 16px 0;
	display: grid;
	grid-template-columns: 60px 1fr;
	gap: 14px;
	align-items: center;
	border-bottom: 1px dashed #e5c5cc
}
.features-3-list li:last-child {
	border-bottom: none
}
.features-3-list .num-big {
	font-size: 38px;
	font-weight: 700;
	line-height: 1;
	color: var(--c-num-pink);
	font-family: Georgia, serif
}
.features-3-list li:nth-child(2) .num-big {
	color: var(--c-num-green)
}
.features-3-list li:nth-child(3) .num-big {
	color: var(--c-num-blue)
}
.features-3-list h3 {
	font-size: 18px;
	margin: 0 0 6px;
	color: var(--color-brown);
	font-weight: 700;
	position: relative;
	display: inline-block
}
.features-3-list h3::after {
	content: "";
	display: block;
	width: 100%;
	height: 2px;
	background: var(--c-num-pink);
	margin-top: 4px;
	border-radius: 2px;
	opacity: .6
}
.features-3-list li:nth-child(2) h3::after {
	background: var(--c-num-green)
}
.features-3-list li:nth-child(3) h3::after {
	background: var(--c-num-blue)
}
.features-3-list p {
	font-size: 15px;
	line-height: 1.85;
	color: var(--color-text-mute);
	margin: 8px 0 0;
	line-height: 1.7
}
@media (min-width:768px) {
	.features-3 {
		padding: 64px 12px 72px
	}
	.features-3-inner {
		grid-template-columns: 0.7fr 1.4fr;
		gap: 36px
	}
	.features-3-title {
		font-size: 28px;
		margin-bottom: 32px
	}
	.features-3-list h3 {
		font-size: 20px;
		margin-bottom: 8px
	}
	.features-3-list p {
		font-size: 16px;
		line-height: 1.9
	}
	.features-3-list .num-big {
		font-size: 44px
	}
}
@media (min-width:1024px) {
	.features-3-title {
		font-size: 32px
	}
	.features-3-list h3 {
		font-size: 22px
	}
	.features-3-list p {
		font-size: 16px
	}
}
.clinic-gallery {
	background: #fff;
	padding: 40px 15px 56px
}
.cg-inner {
	max-width: 1200px;
	margin: 0 auto
}
.clinic-gallery .section-head {
	margin-bottom: 28px
}
.cg-slider {
	overflow: hidden;
	padding: 30px 0 40px;
	position: relative
}
.cg-track {
	display: flex;
	gap: 16px;
	align-items: center;
	list-style: none;
	margin: 0;
	padding: 0 8%;
	will-change: transform
}
.cg-slide {
	flex: 0 0 calc(50% - 8px);
	background: #f4ecdf;
	border-radius: 10px;
	overflow: hidden;
	aspect-ratio: 4/3;
	position: relative;
	transition: transform .7s cubic-bezier(.4, 0, .2, 1), box-shadow .7s ease;
	transform: scale(.92);
	opacity: .85
}
.cg-slide img, .cg-slide svg {
	width: 100%;
	height: 100%;
	display: block;
	object-fit: cover
}
.cg-cap {
	position: absolute;
	left: 12px;
	bottom: 12px;
	background: #fff;
	padding: 6px 12px;
	font-size: 13px;
	font-weight: 700;
	color: var(--color-brown);
	border-radius: 4px;
	box-shadow: 0 2px 8px rgba(0, 0, 0, .06);
	display: flex;
	flex-direction: column;
	line-height: 1.2
}
.cg-cap small {
	display: block;
	font-family: Lato, "Noto Sans JP", sans-serif;
	font-style: italic;
	font-size: 12px;
	color: var(--color-green-deep);
	font-weight: 400;
	letter-spacing: .08em;
	margin-top: 2px
}
.cg-slide.is-active {
	transform: scale(1.08);
	opacity: 1;
	box-shadow: 0 12px 30px rgba(0, 0, 0, .12);
	z-index: 2
}
.cg-more {
	text-align: right;
	margin-top: 20px;
	font-size: 13px
}
.cg-more a {
	color: var(--c-pink-deep);
	font-weight: 700;
	text-decoration: underline;
	text-underline-offset: 4px;
	text-decoration-thickness: 1.5px
}
.cg-more a:hover {
	text-decoration-thickness: 2px
}
.cg-more a::after {
	content: " →";
	text-decoration: none;
	display: inline-block
}
.cg-dots {
	display: none;
	justify-content: center;
	gap: 8px;
	margin-top: 16px
}
.cg-dot {
	width: 8px;
	height: 8px;
	border-radius: 50%;
	background: rgba(107, 74, 58, .25);
	transition: background .25s, transform .25s
}
.cg-dot.is-active {
	background: var(--c-pink-deep);
	transform: scale(1.3)
}
@media (max-width:767px) {
	.cg-dots {
		display: flex
	}
	.cg-slider {
		overflow-x: auto;
		overflow-y: hidden;
		scroll-snap-type: x mandatory;
		-webkit-overflow-scrolling: touch;
		scrollbar-width: none;
		padding: 20px 0 30px
	}
	.cg-slider::-webkit-scrollbar {
		display: none
	}
	.cg-track {
		transform: none!important;
		transition: none!important;
		padding: 0 7.5vw;
		gap: 12px
	}
	.cg-slide {
		flex: 0 0 85vw;
		width: 85vw;
		scroll-snap-align: center;
		scroll-snap-stop: always;
		transform: none!important;
		opacity: 1!important;
		box-shadow: 0 6px 16px rgba(0, 0, 0, .08)
	}
	.cg-slide.is-active {
		transform: none!important;
		box-shadow: 0 6px 16px rgba(0, 0, 0, .08)
	}
	.cg-cap {
		font-size: 14px;
		padding: 8px 14px
	}
}
@media (min-width:600px) {
	.cg-track {
		padding: 0 4%
	}
	.cg-slide {
		flex-basis: calc(33.333% - 11px)
	}
}
@media (min-width:768px) {
	.clinic-gallery {
		padding: 80px 24px 96px
	}
	.clinic-gallery .section-head {
		margin-bottom: 40px
	}
	.cg-slider {
		padding: 36px 0 48px
	}
	.cg-track {
		padding: 0 4%;
		gap: 18px
	}
	.cg-slide {
		flex-basis: calc(25% - 13.5px)
	}
	.cg-cap {
		font-size: 14px;
		padding: 8px 14px
	}
	.cg-cap small {
		font-size: 12px
	}
}
@media (min-width:1024px) {
	.clinic-gallery {
		padding: 96px 80px 112px
	}
	.cg-track {
		padding: 0 3%;
		gap: 20px
	}
	.cg-slide {
		flex-basis: calc(25% - 15px)
	}
	.cg-slide.is-active {
		transform: scale(1.12)
	}
}
@media (min-width:1200px) {
	.clinic-gallery {
		padding: 100px 100px 120px
	}
	.cg-inner {
		max-width: 1280px
	}
}
@media (min-width:1440px) {
	.clinic-gallery {
		padding: 100px 140px 120px
	}
}
.medical-menu-v2 {
	position: relative;
	overflow: hidden;
	padding: 56px 24px 64px;
	background: radial-gradient(circle at 20px 20px, rgba(115, 193, 26, .1) 1.5px, transparent 2px) 0 0/24px 24px, #fffcf1
}
.medical-menu-v2 .section-head {
	position: relative;
	z-index: 2;
	margin-bottom: 28px
}
.medical-menu-v2-inner {
	position: relative;
	z-index: 2;
	max-width: 1100px;
	margin: 0 auto;
	display: grid;
	grid-template-columns: 1fr;
	gap: 32px;
	align-items: center
}
@media (max-width:1023px) {
	.mm-right {
		order: 1
	}
	.mm-left {
		order: 2
	}
}
.mm-leaf {
	position: absolute;
	pointer-events: none;
	z-index: 0;
	opacity: .55
}
.mm-leaf-tl {
	top: 16px;
	left: 8px;
	width: 110px;
	transform: rotate(-12deg)
}
.mm-leaf-br {
	bottom: 16px;
	right: 8px;
	width: 130px;
	transform: rotate(165deg)
}
@media (min-width:768px) {
	.mm-leaf-tl {
		top: 28px;
		left: 24px;
		width: 150px
	}
	.mm-leaf-br {
		bottom: 28px;
		right: 24px;
		width: 170px
	}
}
@media (min-width:1024px) {
	.mm-leaf-tl {
		top: 36px;
		left: 40px;
		width: 180px
	}
	.mm-leaf-br {
		bottom: 36px;
		right: 40px;
		width: 200px
	}
}
.mm-cat-list {
	list-style: none;
	margin: 0 0 24px;
	padding: 0
}
.mm-cat-list li {
	display: flex;
	align-items: center;
	gap: 12px;
	font-size: 15px;
	font-weight: 500;
	color: var(--color-text);
	letter-spacing: .04em;
	padding: 10px 0;
	border-bottom: 1px dotted var(--color-line)
}
.mm-cat-list li:last-child {
	border-bottom: none
}
.mm-cat-mark {
	display: inline-block;
	width: 10px;
	height: 10px;
	border-radius: 50%;
	background: var(--color-green);
	box-shadow: 0 0 0 4px rgba(115, 193, 26, .18);
	flex-shrink: 0
}
.mm-cat-btn {
	display: inline-flex;
	align-items: center;
	gap: 8px;
	font-size: 14px;
	font-weight: 700;
	color: var(--color-green-deep);
	text-decoration: none;
	border-bottom: 1px solid var(--color-green);
	padding: 4px 2px;
	transition: color .2s, border-color .2s
}
.mm-cat-btn .arrow {
	transition: transform .2s
}
.mm-cat-btn:hover {
	color: var(--color-pink-deep);
	border-color: var(--color-pink)
}
.mm-cat-btn:hover .arrow {
	transform: translateX(4px)
}
.mm-circles {
	list-style: none;
	margin: 0;
	padding: 0;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 12px;
	justify-items: center;
	justify-content: end
}
.mm-circle {
	width: 100%;
	max-width: 160px
}
.mm-circle a {
	display: block;
	width: 100%;
	border-radius: 50%;
	text-decoration: none;
	transition: transform .25s ease, filter .25s ease
}
.mm-circle a:hover {
	transform: translateY(-3px);
	filter: drop-shadow(0 8px 16px rgba(0, 0, 0, .08))
}
.mm-circle img {
	display: block;
	width: 100%;
	height: auto;
	aspect-ratio: 1/1;
	object-fit: contain
}
@media (max-width:599px) {
	.mm-circles .mm-circle:nth-child(7) {
		grid-column: 1/3;
		justify-self: center
	}
}
@media (min-width:600px) {
	.mm-circles {
		grid-template-columns: repeat(4, 120px);
		grid-auto-rows: auto;
		gap: 12px 10px;
		justify-content: end
	}
	.mm-circle {
		max-width: 120px;
		width: 120px
	}
	.mm-circles .mm-circle:nth-child(n+5) {
		transform: translateX(65px)
	}
}
@media (min-width:768px) {
	.medical-menu-v2 {
		padding: 80px 48px 96px
	}
	.medical-menu-v2 .section-head {
		margin-bottom: 40px
	}
	.mm-cat-list li {
		font-size: 16px;
		padding: 12px 0
	}
	.mm-circles {
		grid-template-columns: repeat(4, 130px);
		gap: 14px 12px
	}
	.mm-circle {
		max-width: 130px;
		width: 130px
	}
	.mm-circles .mm-circle:nth-child(n+5) {
		transform: translateX(71px)
	}
}
@media (min-width:1024px) {
	.medical-menu-v2 {
		padding: 96px 140px 112px
	}
	.medical-menu-v2-inner {
		grid-template-columns: 240px 1fr;
		gap: 24px
	}
	.mm-circles {
		grid-template-columns: repeat(4, 120px);
		gap: 14px 10px;
		justify-content: end
	}
	.mm-circle {
		max-width: 120px;
		width: 120px
	}
	.mm-circles .mm-circle:nth-child(n+5) {
		transform: translateX(65px)
	}
}
@media (min-width:1200px) {
	.medical-menu-v2 {
		padding: 100px 180px 120px
	}
	.medical-menu-v2-inner {
		grid-template-columns: 240px 1fr;
		gap: 24px;
		max-width: 1280px
	}
	.mm-circles {
		grid-template-columns: repeat(4, 130px);
		gap: 16px 12px
	}
	.mm-circle {
		max-width: 130px;
		width: 130px
	}
	.mm-circles .mm-circle:nth-child(n+5) {
		transform: translateX(71px)
	}
}
@media (min-width:1440px) {
	.medical-menu-v2 {
		padding: 100px 220px 120px
	}
	.medical-menu-v2-inner {
		grid-template-columns: 260px 1fr;
		gap: 28px
	}
}