@charset "utf-8";
/* CSS Document */


/*============================================================================

	#visit-intro　お口と肌の悩みを一箇所で

============================================================================*/
#visit-intro {
	padding: 100px 0 80px;
}
#visit-intro .inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
	line-height: 2.2;
}
#visit-intro .box {
	display: flex;
	align-items: stretch;
	gap: 80px;
}
#visit-intro .box figure {
	flex: 0 0 45%;
	overflow: hidden;
	border-radius: 80px 10px 10px 10px;
}
#visit-intro .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
#visit-intro .box .text {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin-bottom: 0;
}
@media screen and (max-width: 640px) {
	#visit-intro {
		padding: 60px 0 40px;
	}
	#visit-intro .box {
		flex-direction: column !important;
		gap: 30px;
	}
	#visit-intro .box figure {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 9;
		border-radius: 10px 60px 10px 10px !important;
	}
}



/*============================================================================

	#visit-symptoms　どちらを受診すべきか

============================================================================*/
#visit-symptoms {
	padding: 100px 0;
	background: linear-gradient(to bottom, #f4f3f0, #fff);
}
#visit-symptoms .inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
}
#visit-symptoms h3 {
	margin-bottom: 60px;
}
@media screen and (max-width: 640px) {
	#visit-symptoms {
		padding: 60px 0;
	}
	#visit-symptoms h3 {
		margin-bottom: 40px;
	}
}

/* ---------- box ---------- */
#visit-symptoms .box {
	display: flex;
	align-items: stretch;
	gap: 80px;
	margin-bottom: 40px;
}
#visit-symptoms .box:nth-child(even) {
	flex-direction: row-reverse;
}
@media screen and (max-width: 640px) {
	#visit-symptoms .box {
		flex-direction: column !important;
		gap: 30px;
		margin-bottom: 40px;
	}
}

/* ---------- figure ---------- */
#visit-symptoms .box figure {
	flex: 0 0 45%;
	overflow: hidden;
	border-radius: 80px 10px 10px 10px;
}
#visit-symptoms .box:nth-child(even) figure {
	border-radius: 10px 80px 10px 10px;
}
#visit-symptoms .box figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media screen and (max-width: 640px) {
	#visit-symptoms .box figure {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 9;
		border-radius: 10px 60px 10px 10px !important;
	}
}

/* ---------- テキストエリア ---------- */
#visit-symptoms .box .text {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
	margin-bottom: 0;
}
#visit-symptoms .box h4 {
	margin-bottom: 10px;
}
#visit-symptoms .box dl dt {
	font-size: 20px;
	font-family: "Shippori Mincho B1", serif;
	color: var(--color-green-light);
	letter-spacing: 1px;
	margin-bottom: 14px;
	line-height: 1.6;
}
@media screen and (max-width: 640px) {
	#visit-symptoms .box dl dt {
		font-size: 17px;
		line-height: 2;
	}
}


/*------------------------------ 医科歯科連携 ------------------------------*/
.visit-cooperation {
	margin-top: 80px;
}
@media screen and (max-width: 640px) {
	.visit-cooperation {
		margin-top: 50px;
	}
}

/* ---------- タイトル ---------- */
.visit-cooperation > h4 {
	font-size: 44px;
	text-align: center;
	color: var(--color-gold);
	letter-spacing: 4px;
}
.visit-cooperation > h4 span {
	display: block;
	font-size: 24px;
}
@media screen and (max-width: 640px) {
	.visit-cooperation > h4 {
		font-size: 28px;
		letter-spacing: 2px;
	}
	.visit-cooperation > h4 span {
		display: block;
		font-size: 18px;
		letter-spacing: 1px;
	}
}

/* ---------- リード ---------- */
.visit-cooperation > dl {
	text-align: center;
	margin-bottom: 40px;
}
.visit-cooperation > dl dt {
	font-size: 25px;
	font-family: "Shippori Mincho B1", serif;
	color: var(--color-green);
	margin-bottom: 10px;
	letter-spacing: 2px;
}
.visit-cooperation > dl dd {
	line-height: 2;
}
@media screen and (max-width: 640px) {
	.visit-cooperation > dl dt {
		font-size: 22px;
		letter-spacing: 1px;
	}
}

/* ---------- 2列リスト ---------- */
.visit-cooperation ul {
	display: flex;
	gap: 60px;
}
.visit-cooperation ul li {
	flex: 1;
}
.visit-cooperation ul li figure {
	width: 100%;
	aspect-ratio: 16 / 9;
}
.visit-cooperation ul li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 60px 10px;
}
.visit-cooperation ul li dl dt {
	font-size: 24px;
	font-family: "Shippori Mincho B1", serif;
	color: var(--color-green);
	letter-spacing: 1px;
	margin-top: 20px;
	margin-bottom: 12px;
}
@media screen and (max-width: 640px) {
	.visit-cooperation ul {
		flex-direction: column;
		gap: 40px;
	}
	.visit-cooperation ul li figure img {
		border-radius: 10px;
	}
	.visit-cooperation ul li dl dt {
		font-size: 22px;
		margin-top: 15px;
		margin-bottom: 8px;
	}
}





/*============================================================================

	#visit-style　診療スタイルと受診の流れ

============================================================================*/
#visit-style {
	padding: 80px 0;
	background: #f4f3f0;
}
#visit-style .inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
}
#visit-style > .inner > .text {
	text-align: center;
	margin-bottom: 50px;
}
@media screen and (max-width: 640px) {
	#visit-style {
		padding: 60px 0;
	}
	#visit-style > .inner > .text {
		margin-bottom: 40px;
	}
}

/* ---------- 3列リスト ---------- */
#visit-style ul {
	display: flex;
	gap: 40px;
}
#visit-style ul li {
	flex: 1;
}
#visit-style ul li figure {
	width: 100%;
	aspect-ratio: 8 / 5;
}
#visit-style ul li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	border-radius: 60px 10px;
}
#visit-style ul li dl {
	margin-top: 20px;
}
#visit-style ul li dt {
	font-size: 23px;
	font-family: "Shippori Mincho B1", serif;
	color: var(--color-green);
	letter-spacing: 1px;
	margin-bottom: 12px;
}
@media screen and (max-width: 640px) {
	#visit-style ul {
		flex-direction: column;
		gap: 20px;
	}
	#visit-style ul li figure {
		aspect-ratio: 16 / 9;
	}
	#visit-style ul li dl {
		margin-top: 15px;
	}
	#visit-style ul li dt {
		font-size: 22px;
		margin-bottom: 8px;
	}
}






/*============================================================================

	#visit-reason　選ばれる理由

============================================================================*/
#visit-reason {
	padding-top: 100px;
	background: url("../images/bg_01.jpg") center top -2px no-repeat;
}
#visit-reason .inner {
	width: 90%;
	max-width: 1300px;
	margin: 0 auto;
}
#visit-reason > .inner > p {
	text-align: center;
	line-height: 2.2;
	margin-bottom: 60px;
}
@media screen and (max-width: 640px) {
	#visit-reason {
		padding-top: 60px;
	}
	#visit-reason > .inner > p {
		margin-bottom: 40px;
		text-align: left;
		line-height: 2;
	}
}

/* ---------- リスト ---------- */
#visit-reason ul {
	display: flex;
	flex-direction: column;
	gap: 40px;
}
#visit-reason ul li {
	display: flex;
	align-items: stretch;
	gap: 80px;
}
#visit-reason ul li:nth-child(even) {
	flex-direction: row-reverse;
}
@media screen and (max-width: 640px) {
	#visit-reason ul {
		gap: 40px;
	}
	#visit-reason ul li {
		flex-direction: column !important;
		gap: 24px;
	}
}

/* ---------- figure ---------- */
#visit-reason ul li figure {
	flex: 0 0 45%;
	overflow: hidden;
	aspect-ratio: 8 / 5;
	border-radius: 80px 10px 10px 10px;
}
#visit-reason ul li:nth-child(even) figure {
	border-radius: 10px 80px 10px 10px;
}
#visit-reason ul li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media screen and (max-width: 640px) {
	#visit-reason ul li figure {
		flex: 0 0 auto;
		width: 100%;
		aspect-ratio: 16 / 9;
		border-radius: 10px 60px 10px 10px !important;
	}
}

/* ---------- dl ---------- */
#visit-reason ul li dl {
	flex: 1;
	display: flex;
	flex-direction: column;
	justify-content: center;
}
#visit-reason ul li dt {
	display: flex;
	align-items: center;
	gap: 25px;
	font-size: 26px;
	font-family: "Shippori Mincho B1", serif;
	color: var(--color-green);
	font-weight: 500;
	letter-spacing: 2px;
	line-height: 1.7;
	margin-bottom: 10px;
}
#visit-reason ul li dt i {
	font-style: normal;
	font-size: 110px;
	font-family: "Cormorant Infant", serif;
	color: var(--color-gold-light);
	font-weight: 300;
	letter-spacing: 0;
	line-height: 1;
	flex-shrink: 0;
}
#visit-reason ul li dd {
	line-height: 2.2;
}
@media screen and (max-width: 640px) {
	#visit-reason ul li dt {
		font-size: 19px;
		gap: 16px;
		line-height: 1.6;
		letter-spacing: 0.5px;
	}
	#visit-reason ul li dt i {
		font-size: 76px;
	}
	#visit-reason ul li dd {
		line-height: 2;
	}
}





