/*
Theme Name: dcdohi
Author: Your Name
Description: A custom theme for Dohi Dental Clinic.
Version: 1.0
*/

* {
	box-sizing: border-box;
}

html,
body {
	overflow-x: hidden;
}

a:hover {
	opacity: 0.7;
}

p {
	margin: 0;
}

/*コンテンツフェードイン*/
.fadein-target {
	opacity: 0;
	transform: translateY(40px);
	transition: opacity 0.8s ease, transform 0.8s ease;
}

.fadein-target.visible {
	opacity: 1;
	transform: translateY(0);
}

.sp-only {
	display: none;
}

.pc-only {
	display: block;
}

body {
	font-family: 'Zen Old Mincho', serif;
	color: #3C3C3C;
	background-color: #FFFFFF;
	margin: 0 auto;
	max-width: 1440px;
}

.container {
	width: 100%;
	max-width: 1440px;
	margin: 0 auto;
	padding: 0 20px;
	box-sizing: border-box;
}

.site-header {
	position: relative;
	height: 545px;
	color: #3C3C3C;
}

.hero {
	position: relative;
	height: 100%;
	display: flex;
	align-items: center;
	justify-content: flex-start;
	overflow: hidden;
}

.hero-slider {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: -1;
}

.hero-slide {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background-size: cover;
	background-position: center;
	opacity: 0;
	animation: hero-fade 18s infinite;
}

.hero-slide-1 {
	background-image: url('img/hero-1.webp');
}

.hero-slide-2 {
	background-image: url('img/hero-2.webp');
}

.hero-slide-3 {
	background-image: url('img/hero-3.webp');
}

.hero-slide:nth-child(1) {
	animation-delay: 0s;
}

.hero-slide:nth-child(2) {
	animation-delay: 6s;
}

.hero-slide:nth-child(3) {
	animation-delay: 12s;
}

@keyframes hero-fade {
	0% {
		opacity: 0;
	}

	8.33% {
		opacity: 1;
	}

	33.33% {
		opacity: 1;
	}

	41.66% {
		opacity: 0;
	}

	100% {
		opacity: 0;
	}
}

.hero-content {
	position: absolute;
	top: 19%;
	left: 6.9%;
	z-index: 1;
	display: flex;
	flex-direction: column;
}

.logo-container {
	position: absolute;
	top: 2%;
	left: 2%;
	margin: 0;
}

.logo {
	width: 294px;
	height: 50px;
}


.subtitle {
	text-align: center;
	text-shadow:
		/* --- くっきり白い縁（太さ 2px / 白透過 0.75）--- */
		-2px -2px 0 rgba(255, 255, 255, 0.75),
		2px -2px 0 rgba(255, 255, 255, 0.75),
		-2px 2px 0 rgba(255, 255, 255, 0.75),
		2px 2px 0 rgba(255, 255, 255, 0.75),
		-2px 0 0 rgba(255, 255, 255, 0.75),
		2px 0 0 rgba(255, 255, 255, 0.75),
		0 -2px 0 rgba(255, 255, 255, 0.75),
		0 2px 0 rgba(255, 255, 255, 0.75),
		/* --- 外側にやさしい発光（ここが“ふわっと感”）--- */
		0 0 6px rgba(255, 255, 255, 0.50),
		0 0 14px rgba(255, 255, 255, 0.40),
		0 0 26px rgba(255, 255, 255, 0.30);
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 600;
	letter-spacing: 3px;
}

.subtitle span {
	color: #FF512F;
	background-clip: text;
	font-family: "Zen Old Mincho";
	font-size: 48px;
	font-style: normal;
	font-weight: 600;
	line-height: 140%;
}

.title {
	font-family: 'EB Garamond', serif;
	font-size: 200px;
	font-weight: normal;
	color: #E9396B;
	line-height: 0.8;
	margin: 0 0 20px 0;
	text-shadow: 3px 3px 0 #fff, -3px -3px 0 #fff, -3px 3px 0 #fff, 3px -3px 0 #fff;
}

.features {
	display: flex;
	gap: 10px;
	margin-top: 20px;
}

.feature-item {
	width: 146px;
	height: 146px;
	border-radius: 50%;
	color: white;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	font-size: 20px;
	font-family: "Zen Old Mincho";
}

.c1 {
	background: -webkit-linear-gradient(top, #e99339, #ff512f);
}

.c2 {
	background: -webkit-linear-gradient(top, #3994E9, #205383);
}

.c3 {
	background: -webkit-linear-gradient(top, #E9396B, #f00);
}

.smile-catchphrase {
	position: relative;
	height: 356px;
	background-image: url('img/features-bg.webp');
	background-size: cover;
	background-position: center;
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	text-align: center;
}

.smile-catchphrase-content {
	position: relative;
	z-index: 1;
}

.phrase-line1 {
	font-family: 'Zen Old Mincho', serif;
	font-weight: bold;
	font-size: 40px;
	color: #ff512f;
	opacity: 0.8;
	margin: 0;
}

.phrase-line2 {
	font-family: 'Zen Old Mincho', serif;
	font-weight: bold;
	font-size: 40px;
	color: #3c3c3c;
	opacity: 0.8;
	margin: 0;
	display: flex;
	align-items: center;
}

.smile-highlight {
	font-size: 64px;
	background: -webkit-linear-gradient(top, #e9396b, #ff512f);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
	text-shadow: 0px 0px 8px rgba(255, 255, 255, 0.4);
	padding-right: 10px;
}

.concerns {
	background-color: #FFF9F6;
	padding: 80px 0;
	position: relative;
	background-image: url('img/concerns-bg.webp');
	background-size: cover;
	background-position: center;
}

.concerns-content {
	display: flex;
	max-width: 1100px;
	margin: 0 auto;
	align-items: flex-start;
	position: relative;
}

.concerns-left {
	flex: 1;
}

.concerns-title {
	margin: 0;
}

.concerns-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.concerns-list li {
	background-color: #fff;
	box-shadow: 0px 0px 12px 0px rgba(157, 157, 157, 0.22);
	padding: 15px 20px 15px 50px;
	margin-bottom: 18px;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-weight: bold;
	font-size: 16px;
	color: #3c3c3c;
	opacity: 0.8;
	position: relative;
	letter-spacing: 0.8px;
}

.check-icon {
	position: absolute;
	left: 15px;
	top: 50%;
	transform: translateY(-50%);
	width: 24px;
	height: 24px;
	background-image: url('img/check-icon.svg');
	background-size: contain;
	background-repeat: no-repeat;
}

.concerns-right {
	flex: 1;
	position: relative;
	height: 500px;
	/* Adjust as needed */
}

.concern-image-1 {
	position: absolute;
	top: -80px;
	right: 0;
	width: 589px;
}

.concern-image-2 {
	position: absolute;
	bottom: -150px;
	right: -100px;
	width: 330px;
}

.recommendation {
	height: 517px;
	background-image: url('img/recommendation-bg.webp');
	background-size: cover;
	background-position: center;
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: white;
}

.recommendation-content {
	position: relative;
}

.recommendation-subtitle {
	background-color: #ffffff;
	color: #E99339;
	padding: 5px 20px;
	font-size: 24px;
	font-weight: 700;
	display: inline-block;
	margin: 0;
}

.recommendation-title {
	font-family: 'Zen Old Mincho', serif;
	font-weight: 500;
	font-size: 36px;
	margin: 0 0 55px 0;
}

.recommendation-title .highlight-yellow {
	font-size: 64px;
	color: #FFF82F;
}

.recommendation-description {
	color: #3C3C3C;
	font-family: "Zen Old Mincho";
	font-size: 40px;
	font-style: normal;
	font-weight: 700;
	line-height: 180%;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.text-gradient {
	color: #FF512F;
	font-size: 64px;
}

.treatments {}

.treatment-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	margin: 0 auto;
}

.treatment-card {
	position: relative;
	color: white;
	overflow: hidden;
}

.treatment-card img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	position: absolute;
	top: 0;
	left: 0;
	z-index: -1;
}

.treatment-card-content {
	padding: 40px 40px 100px;
	position: relative;
	z-index: 1;
	height: 100%;
	text-align: center;
	background: rgba(0, 0, 0, 0.2);
}

.treatment-en {
	font-family: 'WindSong', cursive;
	font-size: 24px;
	margin: 0 0 10px 0;
	letter-spacing: 0.96px;
}

.treatment-title {
	font-family: 'Zen Old Mincho', serif;
	font-weight: bold;
	font-size: 32px;
	margin: 0 0 20px 0;
	border-bottom: 1px solid white;
	display: inline-block;
	padding-bottom: 10px;
}

.treatment-description {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 20px;
	line-height: 1.6;
	text-align: left;
	text-shadow: 0px 0px 6px rgba(66, 66, 66, 0.5);
}

/* Treatment Links */
.treatment-btn {
	display: flex;
	justify-content: center;
}

.treatment-link {
	position: absolute;
	bottom: 40px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: white;
	padding: 15px 25px;
	text-decoration: none;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	font-weight: bold;
	max-width: 280px;
	text-align: center;
	letter-spacing: 1.35px;
	transition: background-color 0.3s;
}

.bc1 {
	background: #FF5E3F;
}

.bc2 {
	background: #F09819;
}

.bc3 {
	background: #489FEF;
}

.arrow-down {
	width: 20px;
	height: 20px;
	background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='white'%3E%3Cpath d='M12 15.586l-4.293-4.293-1.414 1.414L12 18.414l5.707-5.707-1.414-1.414z'/%3E%3C/svg%3E");
	background-size: contain;
	background-repeat: no-repeat;
	margin-left: 10px;
}

/* Feature detail (メタルフリー / セレック) */
.feature-details {
	box-sizing: border-box;
}

.feature-detail-card {
	flex: 1;
	position: relative;
	padding: 40px;
	color: #3c3c3c;
	background-size: cover;
	background-position: center;
	min-height: 457px;
	overflow: hidden;
}

.feature-detail-card.metal-free {
	background-image: url('img/metal-free-bg.webp');
}

.feature-detail-card.cerec {
	background-image: url('img/cerec-bg.webp');
}

.feature-detail-card.cerec::before {
	content: "";
	position: absolute;
	inset: 0;
	background-image: url('img/cerec-img.webp');
	background-repeat: no-repeat;
}

.feature-detail-content {
	position: relative;
	display: flex;
	z-index: 2;
}

.reverse {
	flex-direction: row-reverse;
}

.feature-detail-text {
	position: relative;
	z-index: 2;
	max-width: 730px;
	padding: 10px 20px;
}

.feature-title-group {
	display: flex;
	align-items: center;
	gap: 30px;
}

.feature-number {
	position: relative;
	color: #fff;
	font-size: 24px;
}

.feature-number::before {
	content: "";
	position: absolute;
	top: -7px;
	left: -10px;
	border: 2px solid #0371A8;
	background: #007EBD;
	width: 47px;
	height: 47px;
	transform: rotate(45deg);
	flex-shrink: 0;
	z-index: -1;
}

.feature-title {
	color: #007EBD;
	font-size: 28px;
	margin: 0 0 10px 0;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.feature-subtitle {
	position: absolute;
	bottom: -14px;
	right: 50px;
	color: #3994E9;
	font-family: WindSong;
	font-size: 36px;
	font-style: normal;
	font-weight: 400;
	line-height: 200%;
	letter-spacing: 2.88px;
	margin: 0;
	opacity: 0.5;
}


.feature-number-r {
	position: relative;
	color: #fff;
	font-size: 24px;
}

.feature-number-r::before {
	content: "";
	position: absolute;
	top: -7px;
	left: -10px;
	border: 2px solid #FF512F;
	background: #FF5E3F;
	width: 47px;
	height: 47px;
	transform: rotate(45deg);
	flex-shrink: 0;
	z-index: -1;
}

.feature-title-r {
	color: #FF512F;
	font-size: 28px;
	margin: 0 0 10px 0;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.feature-subtitle-r {
	position: absolute;
	bottom: -14px;
	right: 50px;
	color: #FF512F;
	font-family: WindSong;
	font-size: 36px;
	font-style: normal;
	font-weight: 400;
	line-height: 200%;
	letter-spacing: 2.88px;
	margin: 0;
	opacity: 0.5;
}

.feature-description {
	position: relative;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 18px;
	line-height: 1.8;
	font-weight: 500;
	color: #333;
	background: #ffffff85;
	margin: 0;
	margin-top: -29px;
	padding: 50px 20px 50px;
	z-index: -2;
}

/* Enhance Smile Section */
.enhance-smile {
	height: 353px;
	background-image: url('img/features-bg.webp');
	text-align: center;
}

.enhance-white {
	height: 353px;
	background-image: url('img/Rectangle-13.webp');
	text-align: center;
}

.enhance-smile-content {
	padding: 50px 0;
}

.enhance-smile-subtitle {
	font-size: 40px;
	text-align: center;
	font-family: "Zen Old Mincho";
	font-style: normal;
	font-weight: 700;
	margin: 0;
}

.enhance-smile-subtitle span {
	color: #FF512F;
}

.enhance-smile-title {
	font-size: 40px;
	font-style: normal;
	font-weight: 700;
	line-height: 200%;
	margin: 0
}

.enhance-smile-title span {
	font-size: 48px;
	font-weight: bold;
	background: -webkit-linear-gradient(top, #e99339, #e9396b);
	-webkit-background-clip: text;
	background-clip: text;
	-webkit-text-fill-color: transparent;
}

/* Cerec Features Section */
.cerec-features {
	padding: 80px 20px;
	text-align: center;
	background-color: #FFF9F6;
	background-image: url('img/cerec-features-bg.webp');
	background-size: cover;
	background-position: center;
}

.cerec-features-content {
	max-width: 1083px;
	margin: 0 auto;
	background-image: url('img/bg-cerec-features-grid.webp');
	background-size: cover;
	padding: 50px;
}

.cerec-features-title {
	font-size: 36px;
	font-weight: bold;
	color: #3c3c3c;
	margin: 0;
}

.cerec-features-title span {
	font-size: 48px;
	color: #E99339;
	margin: 0;
}

.cerec-features-subtitle {
	font-size: 24px;
	color: #E99339;
	font-family: 'EB Garamond', serif;
}

.cerec-features-grid {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
}

.cerec-feature-item {
	position: relative;
	padding-top: 60px;
}

.cerec-features-grid .cerec-feature-item:nth-child(2) {
	margin-top: 20px;
}

.cerec-features-grid .cerec-feature-item:nth-child(5) {
	margin-top: -20px;
}

.cerec-feature-icon {}

.cerec-feature-number {
	position: absolute;
	top: -5px;
	left: 30px;
	font-family: WindSong;
	color: #E99339;
	font-size: 64px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	letter-spacing: 7.04px;
	text-transform: uppercase;
}

.cerec-feature-name {
	font-size: 24px;
	color: #E99339;
	font-family: "Zen Old Mincho";
	font-size: 24px;
	font-style: normal;
	font-weight: 900;
	line-height: 200%;
}

.cerec-feature-description {
	text-align: left;
	color: #3C3C3C;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	text-transform: uppercase;
}

/* Contact Section */
.contact {
	position: relative;
	padding: 30px 0;
	background-image: url('img/contact-bg.webp');
	background-size: cover;
	background-position: center;
	overflow: hidden;
}

.contact-content {
	position: relative;
	z-index: 2;
	max-width: 800px;
	margin: 0 auto;
	text-align: center;
	padding: 40px;
	border-radius: 10px;
}

.contact-subtitle {
	font-family: 'EB Garamond', serif;
	font-size: 64px;
	margin: 0 0 10px 0;
	background: linear-gradient(180deg, #FF512F 0%, #FFBDCD 100%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
	letter-spacing: 6.4px;
}

.contact-title {
	color: #3C3C3C;
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 600;
	line-height: 200%;
	letter-spacing: 2.56px;
	margin: 0 0 20px;
}

.contact-title span {
	color: #FF512F;
	font-family: "Zen Old Mincho";
	font-size: 36px;
	font-style: normal;
	font-weight: 600;
	line-height: 200%;
	letter-spacing: 2.88px;
}

.contact-btn {
	display: inline-block;
	margin: 0 auto;
}

.contact-phone {
	width: 354px;
	display: flex;
	align-items: center;
	gap: 10px;
	color: white;
	padding: 15px 40px;
	font-size: 28px;
	font-weight: bold;
	text-decoration: none;
	margin-bottom: 30px;
	border-radius: 7px;
	border: 4px solid #FFF;
	background: linear-gradient(90deg, #FF512F 0%, #F09819 100%);
	box-shadow: 0 4px 5.3px 0 #D0C6B6;
}

.contact-hours {
	width: 425px;
	font-size: 20px;
	font-family: "Zen Kaku Gothic Antique";
	text-align: left;
	line-height: 1.8;
	border-radius: 4px;
	margin: 0 auto;
	background: #fff;
}

.contact-hours-title {
	color: #fff;
	text-align: center;
	background: #E99339;
	margin: 0 !important;
}

.contact-hours p {
	margin: 5px 20px;
	font-style: normal;
	font-weight: 500;
}

.contact-images {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 1;
}

.contact-person-1 {
	position: absolute;
	bottom: 60px;
	left: 0;
	width: 30%;
	max-width: 400px;
}

.contact-person-2 {
	position: absolute;
	bottom: 0;
	right: 35px;
	width: 25%;
	max-width: 350px;
}


/* Material Types Section */
.material-types {
	padding: 50px 0;
	background-image: url('img/material-types-bg.webp');
	background-size: cover;
	background-position: center;
}

.material-types-content {
	max-width: 1151px;
	margin: 0 auto;
	text-align: center;
}

.material-types-subtitle {
	color: #FFDDAC;
	font-family: WindSong;
	font-size: 40px;
	font-style: normal;
	font-weight: 500;
	letter-spacing: 4.4px;
	text-transform: capitalize;
}

.material-types-title {
	font-size: 40px;
	font-weight: bold;
	color: #3c3c3c;
	margin: 0 0 60px 0;
	line-height: 1.6;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.material-types-title span {
	color: #E99339;
}

.material-cards {
	display: grid;
	gap: 30px;
}

.material-card {
	background-color: #FFFFFF;
	padding: 30px 40px;
	border-radius: 10px;
	box-shadow: 0px 4px 15px rgba(0, 0, 0, 0.05);
	text-align: left;
}

.material-card-title {
	display: flex;
	align-items: center;
	gap: 15px;
	font-family: 'Zen Old Mincho', serif;
	font-size: 24px;
	font-weight: bold;
	color: #E99339;
	margin: 0 0 20px 0;
	padding-bottom: 15px;
	border-bottom: 1px solid #F0EAE4;
}

.material-card-title img {
	width: 32px;
	height: auto;
}

.material-card-description {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	line-height: 1.8;
	color: #3c3c3c;
	margin: 0;
}

/* Flow Section */
.flow-section {
	padding: 120px 0;
	text-align: center;
	position: relative;
	background-image: url('img/bg-flow-section.webp');
	background-size: cover;
	background-position: center;
}

.flow-section .section-title {
	font-size: 48px;
	font-weight: bold;
	color: #3C3C3C;
	margin-bottom: 10px;
}

.flow-section .section-title .highlight {
	color: #E99339;
}

.flow-section .section-subtitle {
	font-family: 'EB Garamond', serif;
	font-size: 40px;
	color: #3C3C3C;
	opacity: 0.8;
	margin-bottom: 80px;
}

.flow-section .flow-steps {
	max-width: 960px;
	margin: 0 auto;
	position: relative;
}

.flow-section .step {
	background-color: white;
	border-radius: 4px;
	padding: 30px;
	margin: 15px auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	text-align: left;
	position: relative;
	padding-left: 60px;
	/* Space for the number */
	z-index: 2;
	box-shadow: 0 4px 15px rgba(0, 0, 0, 0.05);
}

.flow-section .arrow-down-step {
	width: 29px;
	height: 24px;
	margin: 0 auto;
}

.flow-section .step-number {
	position: absolute;
	left: -37px;
	top: 50%;
	transform: translateY(-50%);
	width: 74px;
	height: 74px;
	background: linear-gradient(114deg, #FF5E3F 51.41%, #FF3710 51.96%);
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	color: white;
	font-family: WindSong;
	font-size: 32px;
	font-weight: 500;
	letter-spacing: 4.4px;
	text-transform: capitalize;
	z-index: 3;
}

.flow-section .step-content {
	flex: 1;
}

.flow-section .step-content h3 {
	font-size: 28px;
	font-weight: bold;
	margin: 0 0 15px 0;
}

.flow-section .step-content p {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	margin: 0;
	max-width: 496px;
}

.flow-section .step-image {
	flex-shrink: 0;
	margin-left: 20px;
}

.flow-section .step-image img {
	width: 297px;
	height: 199px;
	border-radius: 4px;
	object-fit: cover;
}

.flow-section .step .contact-info {
	margin-top: 20px;
	display: flex;
	gap: 30px;
	align-items: baseline;
}

.flow-section .step .contact-info .contact-info-box {
	display: flex;
	flex-direction: column;
	gap: 20px;
}

.flow-section .step .contact-info .treatment-tel {
	border-radius: 4px;
	background: #FF512F;
	padding: 10px 50px;
	flex: 1;
	color: #FFF;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	letter-spacing: 1.6px;
}

.flow-section .step .contact-info .treatment-time {
	background-color: #E99339;
	padding: 8px 16px;
	text-align: center;
	border-radius: 4px;
	flex: 1;
	color: #FFF;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	letter-spacing: 1.6px;
}

.flow-section .step .contact-info .btn-tel {
	display: flex;
	align-items: center;
	justify-content: center;
	height: 65px;
	background: linear-gradient(to right, #ff512f, #f09819);
	color: white;
	padding: 12px 24px;
	border-radius: 6px;
	font-size: 28px;
	font-weight: bold;
	border: 3px solid white;
	box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2);
	flex: 1;
}

.flow-section .step .hours-details {
	line-height: 1.6;
	width: 425px;
	box-sizing: border-box;
	flex: 1;
}

.flow-section .step .hours-details p {
	margin: 0;
	font-size: 20px;
}



/* Treatment Options Section */
.treatment-options {
	position: relative;
	padding: 80px 20px;
	background-image: url('img/treatment-options-bg.webp');
	background-size: cover;
	background-position: center;
}

.treatment-options-content {
	display: flex;
	align-items: center;
	justify-content: center;
	max-width: 1200px;
	margin: 0 auto;
	gap: 20px;
}

.treatment-options-image {
	flex-basis: 43%;
}

.treatment-options-image img {
	width: 484px;
	height: auto;
	display: block;
}

.treatment-options-text {
	flex-basis: 45%;
	background-color: rgba(255, 255, 255, 0.65);
	padding: 30px 20px 0;
	position: relative;
	left: -80px;
}

.treatment-options-title {
	position: absolute;
	top: -25px;
	font-family: 'Zen Old Mincho', serif;
	font-size: 32px;
	font-weight: bold;
	color: #FF512F;
	margin: 0 0 25px 0;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.treatment-options-description {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	line-height: 2;
	color: #3c3c3c;
	margin: 0 0 30px 0;
}

.treatment-options-en {
	font-family: 'WindSong', cursive;
	font-size: 36px;
	color: #FF512F;
	text-align: right;
	margin: 0;
	letter-spacing: 2.88px;
}

/* Implant Section */
.implant-section {
	padding: 80px 0 0;
	background-image: url('img/implant-bg.webp');
	background-size: cover;
}

.implant-content {
	max-width: 1200px;
	margin: 0 auto;
}

.implant-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 40px;
	color: #3c3c3c;
	text-align: center;
	margin: 0 0 122px 0;
	font-weight: 500;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.implant-title::after {
	content: '';
	display: block;
	width: 40px;
	height: 1px;
	background-color: #3c3c3c;
	margin: 15px auto 0;
}

.implant-body {
	display: flex;
	align-items: center;
}

.implant-text {
	flex: 1;
	position: relative;
	flex-basis: 80%;
	background-color: rgba(255, 255, 255, 0.65);
	padding: 30px 20px 0;
	z-index: 1;
}

.implant-text p {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	line-height: 2.2;
	color: #3c3c3c;
	margin: 0 0 1.5em 0;
}

.implant-text p:last-child {
	margin-bottom: 0;
}

.implant-en-text {
	font-family: 'WindSong', cursive;
	font-size: 36px;
	color: #FF512F;
	position: absolute;
	bottom: -12px;
	right: 20px;
	opacity: 0.6;
}

.implant-image {
	position: relative;
	margin-left: -80px;
	margin-bottom: 130px;
}

.implant-image img {
	width: 100%;
	height: auto;
	display: block;
}

.implant-image2 {
	position: relative;
	max-width: 460px;
	margin-bottom: 130px;
}


/* Merit/Demerit Section */
.merit-demerit {
	padding: 80px 0;
	background-image: url('img/merit-demerit-bg.webp');
	background-size: cover;
}

.merit-demerit-content {
	max-width: 1080px;
	margin: 0 auto;
}

.merit-demerit-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 40px;
	color: #3c3c3c;
	text-align: center;
	margin: 0 0 150px 0;
	font-weight: 500;
	text-shadow: -2px -2px 0 rgba(255, 255, 255, 0.75), 2px -2px 0 rgba(255, 255, 255, 0.75), -2px 2px 0 rgba(255, 255, 255, 0.75), 2px 2px 0 rgba(255, 255, 255, 0.75), -2px 0 0 rgba(255, 255, 255, 0.75), 2px 0 0 rgba(255, 255, 255, 0.75), 0 -2px 0 rgba(255, 255, 255, 0.75), 0 2px 0 rgba(255, 255, 255, 0.75), 0 0 6px rgba(255, 255, 255, 0.50), 0 0 14px rgba(255, 255, 255, 0.40), 0 0 26px rgba(255, 255, 255, 0.30);
}

.merit-demerit-title::after {
	content: '';
	display: block;
	width: 40px;
	height: 1px;
	background-color: #3c3c3c;
	margin: 15px auto 0;
}

.merit-demerit-columns {
	display: flex;
	gap: 40px;
}

.merit-column,
.demerit-column {
	flex: 1;
}

.merit-title,
.demerit-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 24px;
	color: white;
	text-align: center;
	padding: 10px;
	margin: 0 0 20px 0;
	font-weight: normal;
}

.merit-title {
	background-color: #FF5E3F;
	/* Figmaから抽出 */
}

.demerit-title {
	background-color: #007EBD;
	/* Figmaから抽出 */
}

.merit-list,
.demerit-list {
	list-style: none;
	padding: 0;
	margin: 0;
}

.merit-list li,
.demerit-list li {
	background-color: white;
	padding: 15px 20px;
	margin-bottom: 10px;
	display: flex;
	align-items: center;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	color: #3c3c3c;
	box-shadow: 0 2px 5px rgba(0, 0, 0, 0.05);
}

.merit-list li img,
.demerit-list li img {
	width: 20px;
	height: 20px;
	margin-right: 10px;
}

/* Feature Section */
.feature-wrapper {
	margin-top: 120px;
}

.feature-top {
	position: relative;
	padding: 80px 0 60px;
	background-image: url('img/feature-bg-top.webp');
	background-size: cover;
	background-position: top center;
}

.feature-header {
	position: absolute;
	text-align: center;
	top: -43px;
	right: 0;
	left: 0;
	margin: 0 auto;
}

.feature-en-title {
	font-family: "EB Garamond";
	font-size: 64px;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 6.4px;
	background: linear-gradient(180deg, #FF512F 0%, #FFBDCD 100%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.feature-main-title {
	color: #3C3C3C;
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 500;
	margin-top: -18px;
}

.feature-card {
	max-width: 1151px;
	margin: 55px auto 0;
	text-align: center;
}

.feature-item-title-container {
	position: relative;
	margin-bottom: 30px;
}

.feature-item-number {
	position: absolute;
	top: -37px;
	right: 0;
	left: 0;
	margin: 0 auto;
	font-family: 'WindSong', cursive;
	font-size: 72px;
	color: #D9534F;
	opacity: 0.5;
	line-height: 1;
	letter-spacing: 7.68px;
}

.feature-item-number2 {
	position: absolute;
	top: -37px;
	left: 10px;
	font-family: 'WindSong', cursive;
	font-size: 72px;
	color: #D9534F;
	opacity: 0.5;
	line-height: 1;
	letter-spacing: 7.68px;
}

.feature-item-title {
	color: #3C3C3C;
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 500;
	margin: 0;
}

.feature-checklist-container {
	max-width: 700px;
	margin: 0 auto;
}

.feature-checklist-title {
	color: #FFF;
	font-family: "Zen Old Mincho";
	font-size: 24px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	border-radius: 84px;
	background: #F09819;
}

.feature-checklist {
	list-style: none;
	padding: 15px;
	margin: 0;
}

.feature-checklist li {
	display: flex;
	align-items: center;
	font-size: 17px;
	margin-bottom: 10px;
	letter-spacing: 2px;
}

.feature-checklist li span {
	color: #e99339
}

.feature-checklist li img {
	width: 18px;
	height: 18px;
}

.feature-item-content-flex {
	display: flex;
	align-items: center;
	gap: 40px;
}

.feature-item-content-flex.reverse {
	flex-direction: row-reverse;
}

.feature-item-text {
	flex: 1;
}

.feature-item-text p {
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 20px;
	line-height: 2;
	text-align: left;
}

.feature-item-image {
	flex: 1;
}

.feature-item-image img {
	width: 100%;
	height: auto;
	display: block;
}

.feature-buttons {
	display: flex;
	justify-content: center;
	gap: 30px;
	max-width: 1151px;
	margin: 40px auto 80px;
}

.feature-focus-items {
	flex: 1;
	text-align: center;
}

.focus-item {
	color: #FFF;
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	border-radius: 72px;
	background: linear-gradient(90deg, #FF512F 0%, #E9396B 100%);
}

.feature-button {
	display: block;
	padding: 20px;
	border-radius: 40px;
	text-decoration: none;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 20px;
	font-weight: bold;
	color: white;
	margin-bottom: 15px;
	transition: background-color 0.3s;
}

.feature-focus-items p {
	color: #3C3C3C;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	text-align: left;
	line-height: 200%;
	text-transform: uppercase;
	margin-top: 10px;
}

/* Greeting Section */
.feature-bottom {
	padding: 80px 20px;
	background-image: url('img/feature-bg-bottom.webp');
	background-size: cover;
	background-position: center;
}

.greeting-content {
	max-width: 1151px;
	margin: 55px auto 0;
}

.greeting-header {
	text-align: center;
	margin-bottom: 60px;
}

.greeting-en-title {
	font-family: WindSong;
	font-size: 64px;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 5.12px;
	opacity: 0.55;
	background: linear-gradient(180deg, #FF512F 33.85%, #FFBDCD 64.84%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.greeting-main-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 32px;
	color: #3c3c3c;
	margin-top: -40px;
	font-weight: 500;
}

.greeting-body {
	display: flex;
	align-items: flex-start;
	gap: 50px;
}

.greeting-text {
	flex: 1.2;
}

.greeting-subtitle {
	color: #3C3C3C;
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-style: normal;
	font-weight: 500;
	margin: 0 0 30px;
}

.greeting-text p {
	color: #3C3C3C;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	text-transform: uppercase;
}

.greeting-image {
	flex: 0.8;
	text-align: center;
}

.greeting-image img {
	width: 100%;
	max-width: 300px;
	height: auto;
	margin-bottom: 15px;
}

.director-name-plate {
	background-color: white;
	padding: 10px;
	display: inline-block;
	box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.director-title {
	font-size: 14px;
	display: block;
}

.director-name {
	font-size: 24px;
	font-weight: bold;
	display: inline-block;
	margin-right: 10px;
}

.director-name-en {
	font-size: 14px;
	color: #777;
}

/* FAQ Section */
.faq {
	padding: 80px 20px;
	background-image: url('img/faq-bg.webp');
	background-size: cover;
	background-position: center;
}

.faq-content {
	max-width: 900px;
	margin: 0 auto;
}

.faq-header {
	text-align: center;
	margin-bottom: 60px;
}

.faq-en-title {
	font-family: WindSong;
	font-size: 64px;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 7.68px;
	opacity: 0.55;
	background: linear-gradient(180deg, #FF512F 33.85%, #FFBDCD 64.84%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.faq-main-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 32px;
	color: #3c3c3c;
	margin-top: -40px;
	font-weight: 500;
}

.faq-item {
	margin-bottom: 50px;
	border-radius: 6px;
	background: #FFF;
}

.faq-question {
	position: relative;
	display: flex;
	align-items: center;
	gap: 20px;
	background-color: #FF5E3F;
	color: white;
	padding: 20px;
	border-radius: 8px;
	cursor: pointer;
	transition: background-color 0.3s;
}

.faq-question:hover {
	background-color: #E85235;
}

.faq-icon {
	position: absolute;
	left: -37px;
	top: 8px;
	transform: translateY(-50%);
	width: 74px;
	height: 74px;
	background: linear-gradient(114deg, #FF5E3F 51.41%, #FF3710 51.96%);
	border-radius: 50%;
	display: flex;
	justify-content: center;
	align-items: center;
	color: white;
	font-family: WindSong;
	font-size: 40px;
	font-weight: 500;
	letter-spacing: 4.4px;
	text-transform: capitalize;
}

.faq-question p {
	margin: 0;
	font-size: 20px;
	padding-left: 30px;
}

.faq-answer {}

.answer-content {
	display: flex;
	gap: 20px;
	padding: 30px;
}

.a-icon {
	background-color: #FF5E3F;
	color: white;
}

.answer-content p {
	margin: 0;
	font-family: 'Zen Kaku Gothic Antique', sans-serif;
	font-size: 16px;
	line-height: 2;
	color: #3c3c3c;
}

/* Entry Gallery Section */
.entry-gallery {
	padding: 80px 0;
	text-align: center;
}

.entry-header {
	margin-bottom: 40px;
}

.entry-en-title {
	font-family: WindSong;
	font-size: 96px;
	font-style: normal;
	font-weight: 400;
	letter-spacing: 7.68px;
	opacity: 0.55;
	background: linear-gradient(180deg, #FF512F 33.85%, #FFBDCD 64.84%);
	background-clip: text;
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}

.entry-main-title {
	font-family: 'Zen Old Mincho', serif;
	font-size: 32px;
	color: #3c3c3c;
	margin-top: -40px;
	font-weight: 500;
}

.photo-gallery-container {
	width: 100%;
	overflow: hidden;
	white-space: nowrap;
}

.photo-gallery-scroll {
	display: inline-block;
	animation: scroll-gallery 30s linear infinite;
}

.photo-gallery-scroll img {
	height: 250px;
	width: auto;
	margin: 0 3px;
}

@keyframes scroll-gallery {
	0% {
		transform: translateX(0);
	}

	100% {
		transform: translateX(-50%);
	}
}

/* Implant Banner Section */
.implant-banner-section {
	padding: 0 0 60px;
}

.implant-banner {
	display: flex;
	justify-content: center;
	margin: 0 auto;
	text-decoration: none;
	color: inherit;
	transition: box-shadow 0.3s;
	position: relative;
}

.implant-banner-image {
	flex-shrink: 0;
}

.implant-banner-image img {
	width: 100%;
	height: auto;
	display: block;
}

/*--------------------------------------------------------------
## Footer
--------------------------------------------------------------*/
.site-footer {
	background-color: #e89525;
	color: #fff;
	padding: 60px 0 0;
	font-family: "Zen Kaku Gothic Antique";
}

.site-footer .container {
	max-width: 1151px;
	margin: 0 auto;
	padding: 0 20px;
}

.footer-content {
	display: flex;
	justify-content: space-between;
	align-items: flex-start;
	padding-bottom: 40px;
}

.footer-info {
	flex-basis: 45%;
}

.footer-logo {
	text-align: center;
}

.footer-logo img {
	width: 280px;
}

.footer-address {
	color: #FFF;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 500;
	line-height: 200%;
	letter-spacing: 1.6px;
}

.footer-tel-container {
	width: 260px;
	border-top: solid 1px rgb(255, 255, 255);
	border-bottom: solid 1px rgb(255, 255, 255);
	margin: 20px auto;
	padding: 15px 0;
}

.footer-tel {
	font-family: "Zen Old Mincho";
	font-size: 32px;
	font-weight: 600;
	display: flex;
	align-items: center;
	justify-content: center;
}

.footer-hours {
	flex-basis: 50%;
}

.hours-table {
	background-color: #fff;
	color: #333;
	padding: 20px;
	margin-bottom: 15px;
}

.hours-header {
	font-size: 18px;
	font-weight: bold;
	text-align: center;
	margin-bottom: 15px;
	border-bottom: 1px solid #eee;
	padding-bottom: 10px;
}

.hours-body table {
	width: 100%;
	border-collapse: collapse;
	text-align: center;
}

.hours-body table thead {
	border-bottom: 1px solid;
}

.hours-body th,
.hours-body td {
	padding: 8px 0;
	font-size: 16px;
	width: 50px;
}

.hours-body th {
	font-weight: normal;
}

.hours-body td:first-child {
	font-weight: bold;
	width: 78px;
}

.hours-body td span {
	color: #F09819;
}

.hours-notes {
	color: #FFF;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 16px;
	font-style: normal;
	font-weight: 500;
	line-height: 160%;
}

.copyright {
	background-color: #ffffff;
	color: #3C3C3C;
	font-family: "Zen Kaku Gothic Antique";
	font-size: 20px;
	font-style: normal;
	font-weight: 400;
	text-align: center;
	line-height: 200%;
	padding: 10px 0;
}

.page-top-btn {
	position: fixed;
	bottom: 30px;
	right: 30px;
	width: 60px;
	height: 60px;
	background-color: #333;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	text-decoration: none;
	opacity: 0;
	visibility: hidden;
	transition: opacity 0.3s, visibility 0.3s;
}

.page-top-btn.show {
	opacity: 1;
	visibility: visible;
}

.page-top-btn::after {
	content: '';
	display: block;
	width: 12px;
	height: 12px;
	border-top: 3px solid #fff;
	border-left: 3px solid #fff;
	transform: rotate(45deg);
}

/*--------------------------------------------------------------
## Hamburger Menu
--------------------------------------------------------------*/
.hamburger-menu {
	position: absolute;
	top: 25px;
	right: 45px;
	z-index: 1000;
	background: #3c3c3c;
	border: none;
	cursor: pointer;
	width: 60px;
	height: 60px;
	display: flex;
	flex-direction: column;
	justify-content: center;
	align-items: center;
	gap: 6px;
}

.hamburger-menu-line {
	width: 30px;
	height: 3px;
	background-color: white;
	display: block;
}

.global-nav {
	position: fixed;
	top: 0;
	right: -100%;
	width: 400px;
	height: 100%;
	background-color: rgba(255, 255, 255, 0.95);
	z-index: 1100;
	transition: right 0.5s ease-in-out;
	padding: 100px 40px 40px;
	background-image: url('img/nav-bg.webp');
	background-size: cover;
	background-position: center;
}

.global-nav.active {
	right: 0;
}

.close-btn {
	position: absolute;
	top: 15px;
	right: 15px;
	background: #333;
	color: white;
	border: none;
	font-size: 30px;
	width: 60px;
	height: 60px;
	cursor: pointer;
	display: flex;
    align-items: center;
    justify-content: center;
}

.global-nav ul {
	list-style: none;
	padding: 0;
	margin: 0;
}

.global-nav li {
	margin-bottom: 20px;
}

.global-nav a {
	color: #333;
	text-decoration: none;
	font-size: 18px;
	font-weight: bold;
	display: block;
	padding: 15px 0;
	border-bottom: 1px solid #ddd;
	position: relative;
}

.global-nav a::after {
	content: '>';
	position: absolute;
	right: 10px;
	font-size: 20px;
	color: #888;
}

/*--------------------------------------------------------------
## Responsive Styles
--------------------------------------------------------------*/
@media (max-width: 768px) {

	.sp-only {
		display: block;
	}

	.pc-only {
		display: none;
	}

	body {
		max-width: 100%;
		font-size: 14px;
	}

	.container {
		padding: 0 15px;
	}

	.site-header {
		height: auto;
	}

	.hero {
		height: 850px;
		align-items: center;
		justify-content: center;
		text-align: center;
	}

	.hero-content {
		top: 39%;
		left: 0
	}

	.hero-slide-1 {
		background-image: url('img/hero-1-sp.webp');
	}

	.hero-slide-2 {
		background-image: url('img/hero-2-sp.webp');
	}

	.hero-slide-3 {
		background-image: url('img/hero-3-sp.webp');
	}

	.logo-container {
		left: 4%;
	}

	.logo {
		width: 230px;
		height: auto;
	}

	.title {
		font-size: 60px;
		margin: 0;
	}

	.subtitle {
		font-size: 32px;
	}

	.subtitle span {
		font-size: 40px;
	}

	.features {
		align-items: center;
		flex-wrap: wrap;
		justify-content: center;
	}

	.feature-item {
		width: 150px;
		height: 150px;
		font-size: 18px;
	}

	.smile-catchphrase {
		height: auto;
		padding: 30px 15px;
	}

	.phrase-line1,
	.phrase-line2 {
		font-size: 20px;
	}

	.smile-highlight {
		font-size: 32px;
	}

	.concerns {
		background-position: 65% center;
		padding: 30px 0;
	}

	.concerns-title img {
		width: 90%;
	}

	.concerns-list {
		padding: 0 5%;
	}

	.concerns-list li {
		font-size: 16px;
		padding: 12px 15px 12px 47px;
		margin-bottom: 10px;
	}

	.concerns-content,
	.treatment-options-content,
	.implant-body,
	.merit-demerit-columns,
	.feature-item-content-flex,
	.greeting-body,
	.footer-content {
		flex-direction: column;
		gap: 25px;
		align-items: center;
	}

	.treatment-options-content {
		gap: 50px;
	}

	.contact-person-1 {
		position: absolute;
		bottom: 0px;
		left: -24px;
		width: 200px;
	}

	.contact-person-2 {
		position: absolute;
		bottom: -43px;
		right: -2px;
		width: 153px;
	}

	.enhance-smile {
		height: auto;
	}

	.enhance-smile-content {
		padding: 20px 0;
	}

	.enhance-smile-content img {
		max-width: 250px;
	}

	.enhance-smile-subtitle {
		font-size: 24px;
	}

	.enhance-smile-title {
		font-size: 24px;
	}

	.enhance-smile-title span {
		font-size: 40px;
	}

	.recommendation {
		height: auto;
		padding: 15px 0 50px;
		background-image: url(img/recommendation-bg-sp.webp);
		background-position: top;
	}

	.recommendation-subtitle {
		font-size: 20px;
	}

	.recommendation-title {
		font-size: 20px;
		margin-bottom: 70px;
	}

	.text-gradient {
		font-size: 36px;
	}

	.recommendation-title .highlight-yellow {
		font-size: 36px;
	}

	.recommendation-description {
		font-size: 24px;
	}

	.treatment-grid,
	.cerec-features-grid {
		grid-template-columns: 1fr;
	}

	.treatment-card {
		height: 485px;
	}

	.treatment-card-content {
		padding: 25px;
	}

	.treatment-title {
		font-size: 24px;
	}

	.treatment-description {
		font-size: 14px;
	}

	.feature-detail-card {
		padding: 15px;
		background-position: 61% center;
	}

	.feature-detail-content {
		position: absolute;
		bottom: 0;
	}

	.feature-title,
	.feature-title-r {
		font-size: 22px;
	}

	.feature-description {
		font-size: 14px;
		padding: 40px 15px 30px;
	}

	.feature-detail-card.cerec::before {
		background-position: bottom right;
		opacity: 0.8;
	}

	.feature-detail-text {
		padding: 15px;
		left: 0;
	}

	.treatment-options-text {
		left: 0;
	}

	.feature-title-group {
		gap: 20px;
	}

	.feature-number,
	.feature-number-r {
		font-size: 20px;
	}

	.feature-number::before {
		content: "";
		position: absolute;
		top: -2px;
		left: -5px;
		width: 31px;
		height: 31px;
		transform: rotate(45deg);
		flex-shrink: 0;
		z-index: -1;
	}

	.feature-number-r::before {
		content: "";
		position: absolute;
		top: -2px;
		left: -5px;
		border: 2px solid #FF512F;
		background: #FF5E3F;
		width: 31px;
		height: 31px;
		transform: rotate(45deg);
		flex-shrink: 0;
		z-index: -1;
	}

	.cerec-features {
		padding: 30px 0;
	}

	.cerec-features-content {
		padding: 30px;
	}

	.cerec-features-title {
		font-size: 32px;
	}

	.cerec-features-subtitle {
		font-size: 20px;
	}

	.cerec-feature-item {
		padding-top: 30px;
	}

	.cerec-feature-number {
		font-size: 53px;
		top: -20px;
		left: 15px;
	}

	.cerec-feature-name {
		font-size: 24px;
		margin: 5px;
	}

	.cerec-features-grid .cerec-feature-item:nth-child(2) {
		margin-top: 0;
	}

	.cerec-features-grid {
		gap: 30px;
	}

	.cerec-feature-description {
		font-size: 14px;
	}

	.material-types-subtitle {
		font-size: 20px;
	}

	.material-card {
		padding: 30px 25px;
	}

	.enhance-white {
		height: auto;
	}

	.contact {
		height: 660px;
		padding: 30px 0;
	}

	.contact-content {
		padding: 15px;
	}

	.contact-subtitle {
		font-size: 48px;
	}

	.contact-title {
		font-size: 22px;
	}

	.contact-title span {
		font-size: 24px;
	}

	.contact-phone,
	.contact-hours {
		width: 100%;
		max-width: 425px;
	}

	.contact-phone {
		font-size: 22px;
		padding: 12px 20px;
	}

	.contact-hours {
		font-size: 14px;
	}

	.material-types {
		padding: 30px 15px;
	}

	.material-types-title {
		font-size: 28px;
		margin-bottom: 45px;
	}

	.material-card-title {
		font-size: 20px;
	}

	.material-card-description {
		font-size: 14px;
	}

	.implant-section {
		padding: 80px 0;
		background-position: center;
	}

	.implant-title,
	.merit-demerit-title {
		font-size: 28px;
		margin: 0 0 30px 0;
	}

	.implant-image,
	.implant-image2 {
		margin: 0;
		width: 85%;
	}

	.implant-image2 img {
		width: 100%;
		height: auto;
	}

	.implant-text {
		flex-basis: 100%;
		padding: 15px;
		margin: 0 15px;
	}

	.implant-text p {
		font-size: 14px;
	}

	.flow-section {
		padding: 30px 15px;
	}

	.flow-section .section-title {
		font-size: 32px;
	}

	.flow-section .section-subtitle {
		font-size: 24px;
		margin-bottom: 40px;
	}

	.flow-section .step {
		position: relative;
		flex-direction: column;
		padding: 25px 15px;
	}

	.flow-section .step-number {
		position: absolute;
		top: -28px;
		left: 5px;
		transform: none;
		margin: 0 auto 15px;
		width: 40px;
		height: 40px;
		font-size: 23px;
	}

	.flow-section .step-content h3 {
		font-size: 20px;
	}

	.flow-section .step-content p {
		font-size: 14px;
	}

	.flow-section .step-image {
		margin-top: 15px;
		margin-left: 0;
		width: 100%;
	}

	.flow-section .step-image img {
		width: 100%;
		height: auto;
	}

	.flow-section .step .contact-info {
		flex-direction: column;
		width: 100%;
		gap: 15px;
	}

	.flow-section .step .hours-details {
		width: 100%;
	}

	.flow-section .step .hours-details p {
		font-size: 14px;
	}

	.contact-info-box {
		width: 100%;
	}

	.merit-demerit-columns {
		flex-direction: column;
		gap: 25px;
		align-items: center;
		width: 90%;
		margin: 0 auto;
	}

	.feature-top,
	.feature-bottom,
	.faq,
	.entry-gallery,
	.implant-banner-section,
	.site-footer {
		padding: 30px 15px;
	}

	.feature-wrapper {
		margin-top: 0;
	}

	.feature-top {
		padding: 80px 0 60px;
		background-image: url(img/feature-bg-top-sp.webp);
	}

	.feature-header,
	.greeting-header,
	.faq-header,
	.entry-header {
		position: static;
		margin-bottom: 25px;
	}

	.feature-main-title,
	.greeting-main-title,
	.faq-main-title,
	.entry-main-title {
		margin-top: -22px;
		font-size: 24px;
	}

	.feature-en-title,
	.greeting-en-title,
	.faq-en-title,
	.entry-en-title {
		font-size: 40px;
	}

	.feature-item-title {
		font-size: 20px;
	}

	.feature-checklist-title {
		font-size: 16px;
	}

	.feature-item-content {
		padding: 0 15px;
	}

	.feature-checklist li {
		display: block;
		text-align: left;
	}

	.feature-item-number {
		position: absolute;
		top: -24px;
		font-size: 48px;
	}

	.feature-item-number2 {
		position: absolute;
		top: -24px;
		left: 0;
		right: 0;
		font-size: 48px;
	}

	.focus-item {
		font-size: 20px;
	}

	.sp-reverse {
		flex-direction: column-reverse;
	}

	.feature-focus-items p {
		font-size: 16px;
	}

	.feature-item-text p {
		font-size: 16px;
	}

	.feature-buttons {
		flex-direction: column;
	}

	.greeting-subtitle {
		font-size: 24px;
	}

	.greeting-text p {
		font-size: 16px;
	}

	.faq-question {
		padding: 12px;
		padding-left: 40px;
	}

	.faq-icon {
		top:-4px;
		left: -15px;
		width: 50px;
		height: 50px;
		font-size: 28px;
	}

	.faq-question p {
		font-size: 14px;
		padding-left: 5px;
	}

	.answer-content {
		flex-direction: column;
		padding: 15px;
	}

	.answer-content p {
		font-size: 14px;
	}

	.photo-gallery-scroll img {
		height: 117px !important;
		width: auto;
		margin: 0 3px;
	}

	.implant-banner {
		display: block;
	}

	.site-footer {
		padding: 30px 0px 0;
	}

	.site-footer .container {
		padding: 0 15px !important;
	}

	.footer-content {
		align-items: center;
		text-align: center;
	}

	.footer-address {
		font-size: 14px;
	}

	.footer-tel {
		font-size: 28px;
	}

	.footer-tel-container {
		width: 260px;
		margin: 20px auto;
		padding: 10px 0;
	}

	.hours-table {
		padding: 10px;
	}

	.hours-body th,
	.hours-body td {
		font-size: 14px;
	}

	.hours-body td:first-child {
		width: 85px;
	}

	.hours-notes {
		font-size: 16px;
		text-align: left;
	}

	.copyright {
		font-size: 12px;
	}

	.footer-hours {
		width: 100%;
	}

	.global-nav {
		width: 100%;
	}

	.global-nav a {
		font-size: 16px;
	}

	.hamburger-menu {
		top: 15px;
		right: 15px;
	}

	.page-top-btn {
		position: fixed;
		bottom: 20px;
		right: 15px;
		width: 45px;
		height: 45px;
	}
}