/*
Theme Name: Matsudo-dental Clinic
Theme URI: https://www.matsudo-dental.com/
Description: 松戸デンタルクリニック様 オリジナルテーマ
Version: 1.0 / 2026.03.30~
Author: 
Author URI: 
*/


body {
	font-family: "Shippori Mincho", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", Osaka, "ＭＳ Ｐゴシック", "MS PGothic";
	color:#222;
	font-size: 17px;
  	font-weight: 400;
  	font-style: normal;
	line-height: 2.4;
	letter-spacing:0.03em;
	text-align:justify;
}
a {
	color: #222;
	text-decoration: none;
	transition: 0.3s ease-out;
}
a:hover {
	color:#ec9d06;
}

::selection{background-color:#658e83; color: #FFF;}
::-moz-selection{background-color:#658e83; color: #FFF;}

body , header , footer{
	min-width: 1300px;
	max-width: 1920px;
	margin: auto;
}

@media screen and (max-width:640px) {
	body{font-size: 16px;}
	body,header,footer{min-width: 400px;}
}





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

	モーション　＊　文字が１文字ずつ出る

============================================================================*/
.eachTextAnime span{opacity: 0;}
.eachTextAnime.appeartext span{ animation:text_anime_on 2s ease-out forwards; }
@keyframes text_anime_on {
	0% {opacity:0;}
	100% {opacity:1;}
}



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

	モーション　＊　wowオリジナル　fadeInUpMin

============================================================================*/
.fadeInUpMin {
    animation-name: fadeInUpMin;
}
@keyframes fadeInUpMin {
    from { opacity: 0; transform: translate3d(0, 10%, 0);}
    to { opacity: 1; transform: none;}
}



#loftloader-wrapper {
	min-width: 400px !important;
}
#loftloader-wrapper .loader-section.section-fade {
	min-width: 400px !important;
}




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

	#mainvisual　＊　下層のMV

============================================================================*/
#mainvisual {
	position: relative;
	width: 100%;
	height: 400px;
	margin:auto;
	background: url("images/top/mv.jpg") center no-repeat;
  	background-size: cover;
  	z-index: 0;
  	overflow: hidden;
	display: flex;
	align-items: center;
	align-content: center;
	flex-wrap: wrap;
}
#mainvisual h2 , #mainvisual em {
	position: relative;
	width: 100%;
	text-align: center;
	color: #FFF;
	line-height: 1;
	letter-spacing: 5px;
	text-shadow: 0 0 5px #64370a, 0 0 10px #64370a, 0 0 30px #64370a;
	z-index: 5;
}
#mainvisual h2 {
	padding-top: 100px;
	font-size: 36px;
}
#mainvisual em {
	padding-top: 30px;
	font-size: 18px;
	font-family: "Cormorant Garamond", serif;
  	font-optical-sizing: auto;
}
#mainvisual::before {
	position: absolute; content: "";
	width: 100%; height: inherit;
	background: rgba(255,255,255,.3);
	top: 0; left: 0;
}
@media screen and (max-width:640px) {
	#mainvisual {
		height: 300px;
	}
	#mainvisual h2 , #mainvisual em {
		letter-spacing: 3px;
	}
	#mainvisual h2 {
		padding-top: 80px;
		font-size: 24px;
	}
	#mainvisual em {
		padding-top: 20px;
		font-size: 14px;
	}
}


/*------------------------------ ページごとにMV変更 ------------------------------
.page-template-blog #mainvisual {background: url(images/MV_01.jpg) center top no-repeat;}
.page-template-products #mainvisual {background: url(images/MV_02.jpg) center top no-repeat;}
.page-id-94 #mainvisual {background: url(images/MV_03.jpg) center top no-repeat;}
.page-id-169 #mainvisual {background: url(images/MV_04.jpg) center top no-repeat;}
.single #mainvisual {background: url(images/MV_01.jpg) center top no-repeat;}






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

	main

==================================================================*/
main {
	position: relative;
}
main::before {
	position: absolute; content: "";
	width: 100%;
	height: 600px;
	background: linear-gradient(to top, #FFF, #eaf4ef);
}




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

	 タイトル

==================================================================*/
h3 {
	position: relative;
	margin-bottom: 60px;
	text-align: center;
	line-height: 2.3;
}
h3 em {
	display: block;
	font-size: 15px;
	font-family: "Cormorant Garamond", serif;
  	font-optical-sizing: auto;
	color: #3a9a80;
	letter-spacing: 3px;
}
h3 p {
	position: relative;
	display: inline-block;
	padding: 0 60px;
	font-size: 30px;
	letter-spacing: 6px;
	z-index: 2;
}
h3::before {
	position: absolute; content: "";
	width: 287px;
	height: 287px;
	left: 0; right: 0; margin: auto;
	top: -90px;
	background: url("images/top/top04.png");
	background-size: cover;
}
@media screen and (max-width:640px) {
	h3 {
		margin-bottom: 40px;
	}
	h3 em {
		font-size: 14px;
		letter-spacing: 2px;
	}
	h3 p {
		padding: 0 40px;
		font-size: 24px;
		letter-spacing: 4px;
	}
}
#top_policy h2::before {
}




h4 {
	position: relative;
	margin-bottom: 60px;
	text-align: center;
	line-height: 2.3;
}
h4 em {
	display: block;
	font-size: 15px;
	font-family: "Cormorant Garamond", serif;
  	font-optical-sizing: auto;
	color: #3a9a80;
	letter-spacing: 3px;
}
h4 p {
	position: relative;
	display: inline-block;
	padding: 0 60px;
	font-size: 30px;
	letter-spacing: 6px;
	background: #FFF;
	z-index: 2;
}
h4::before {
	position: absolute; content: "";
	width: 100%;
	height: 1px;
	left: 0;
	top: 49%;
	background: #ddd;
}
@media screen and (max-width:640px) {
	h4 {
		margin-bottom: 40px;
	}
	h4 em {
		font-size: 14px;
		letter-spacing: 2px;
	}
	h4 p {
		padding: 0 40px;
		font-size: 24px;
		letter-spacing: 4px;
	}
}





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

	text

==================================================================*/
.text {
	position:relative;
	margin-bottom:50px;
}
.text p {
	margin-bottom:1em;
}
.text:last-child{
	margin-bottom:0;
}

@media screen and (max-width:640px) {
	main .text p {
		letter-spacing: 0.3px;
	}
}





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

	btn

==================================================================*/
.btn a {
	position: relative;
	transition: 0.3s ease-out;
	font-family: "Cormorant Garamond", serif;
  	font-optical-sizing: auto;
	letter-spacing: 3px;
	font-size: 16px;
	padding: 20px 60px 20px 20px;
}
.btn a::before {
	position: absolute; content: "";
	bottom: 27px;
  	right: -15px;
  	width: 8px;
  	height: 1px;
  	background: #000000;
  	transform: rotate(30deg);
	transition: 0.3s ease-out;
}
.btn a::after {
  	position: absolute; content: "";
  	bottom: 25px;
  	height: 1px;
  	width: 55px;
	margin-left: 20px;
  	background: #000000;
	transition: 0.3s ease-out;
}



.btn a:hover {
	letter-spacing: 5px;
}
.btn a:hover::before {
  	right: -30px;
	background: #ec9d06;
}
.btn a:hover::after {
  	width: 70px;
	margin-left: 20px;
	background: #ec9d06;
}






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

		$下層共通　＊　もくじ

==================================================================*/
#toc {
	position: relative;
	background: #FFF;
	z-index: 2;
}
#toc ul {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	padding: 25px 0 20px;
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
#toc ul li {
	position: relative;
	margin: 0 60px 1px 0;
}
#toc ul li::before {
	position: absolute; content: "";
	background: url("images/icon04.png") no-repeat ;
	background-size: 6px auto;
	width: 8px; height: 20px;
	transform: rotate(90deg);
	top: 12px; right: -15px;
	transition: 0.3s ease-out;
}
#toc ul li:hover::before {
	top: 14px;
}
@media screen and (max-width:640px) {
	#toc {
	}
	#toc ul {
		display: block;
		padding: 20px 10px 20px 10px;
	}
	#toc ul li {
		margin: 0;
		padding: 0 0 0 25px;
		font-size: 13px;
	}
	#toc ul li::before {
		top: 8px; right: auto; left: 0;
	}
	#toc ul li:hover::before {
		top: 8px;
	}
}



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

		スタッフ紹介ページ　＊　staff

==================================================================*/
.staff {
	position: relative;
}
.staff .inner {
	width: calc( 100% - 200px );
	margin: auto;
	display: flex;
}
.staff .left {
	width: 650px;
	margin-right: 3%;
}
.staff .left figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
.staff .left dl {
	position: relative;
	top: -20px;
	display: flex;
	align-items: center;
	justify-content: space-between;
	color: #074635;
}
.staff .left dl dd em {
	font-size: 21px;
}
.staff .left dl dd br {
	display: none;
}
.staff .text {
	flex: 1;
	margin-right: 3%;
	text-align: center;
	line-height: 2.3;
}
.staff .br02 {
	display: none;
}

@media screen and (max-width:1750px) {
	.staff .left {
		width: 600px;
	}
	.staff .left figure {
		height: 440px;
	}
}
@media screen and (max-width:1690px) {
	.staff .left {
		width: 550px;
		margin-right: 0;
	}
}
@media screen and (max-width:1590px) {
	.staff .left {
		width: 480px;
	}
	.staff .left figure {
		height: 400px;
	}
	
	.staff .left figure img {
		object-position: 80% center;
	}
	.staff .left dl dd {
		line-height: 2;
		margin-top: 35px;
		text-align: right;
		margin-right: 10px;
	}
	.staff .left dl dd br {
		display: block;
	}
}
@media screen and (max-width:1510px) {
	.staff .left {
		width: 32%;
	}
}
@media screen and (max-width:1430px) {
	.staff .left {
		width: 30%;
	}
}
@media screen and (max-width:1390px) {
	.staff .left {
		width: 35%;
	}
	.staff .left figure {
		height: 440px;
	}
	.staff .br01 {
		display: none;
	}
	.staff .br02 {
		display: block;
	}
}
@media screen and (max-width:640px) {
	.staff .inner {
		width: 90%;
		flex-direction: column-reverse;
	}
	.staff .left {
		width: 100%;
	}
	.staff .left figure {
		height: 280px;
		overflow: hidden;
	}
	.staff .text {
		margin-right: 0;
		text-align: left;
		margin-top: 10px;
		margin-bottom: 10px;
	}
	.staff .br01,
	.staff .br02 {
		display: none;
	}
}


.staff .inner dl.career {
	width: 90%;
	margin: auto;
	display: grid;
	grid-template-columns: repeat(2, 1fr);
	gap: 0 40px;
}
.staff .inner dl.career dt {
	grid-column: 1 / -1;
	font-size: 24px;
	letter-spacing: 3px;
	padding-bottom: 5px;
	margin-bottom: 20px;
	border-bottom: 1px solid #406c60;
	color: #074635;
}
.staff .inner dl.career dd {
	display: flex;
	align-items: baseline;
	padding: 16px 0;
	border-bottom: 1px dashed #ddd;
	line-height: 1.8;
}
.staff .inner dl.career dd span {
	min-width: 90px;
	font-family: "EB Garamond", serif;
	font-size: 18px;
	color: #406c60;
	letter-spacing: 2px;
	white-space: nowrap;
}
@media screen and (max-width:640px) {
	.staff .inner dl.career {
		width: 100%;
		grid-template-columns: repeat(1, 1fr);
	}
	.staff .inner dl.career dt {
		font-size: 22px;
		letter-spacing: 2px;
	}
	.staff .inner dl.career dd span {
		min-width: 80px;
	}
	.staff .inner dl.career dd span {
		font-size: 17px;
	}
}




/*------------------------------勤務医紹介は微修正------------------------------*/
#staff02.staff h3 {
	margin-bottom: 30px;
}
#staff02.staff .inner {
	align-items: center;
}
#staff02.staff .inner dl.career dd span {
	min-width: 130px;
}
@media screen and (max-width:640px) {
	#staff02.staff .inner dl.career dd span {
		min-width: 120px;
	}
}


/*------------------------------院長先生の下にインスタグラム------------------------------*/
.staff_insta {
	position: relative;
	display: flex;
	justify-content: center;
	margin: 70px auto 0;
	width: 90%;
	max-width: 1280px;
}
@media screen and (max-width:640px) {
	.staff_insta {
		margin: 50px auto 0;
		width: 100%;
	}
}




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

		アクセス　＊　clinic

==================================================================*/
#access01 {
	position: relative;
}
#access01 ul {
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 30px 20px;
	width: 90%;
	max-width: 1280px;
	margin: 0 auto;
}
#access01 ul li figure {
	margin-bottom: 10px;
}
#access01 ul li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
#access01 ul li figcaption {
	text-align: center;
	line-height: 1.8;
	letter-spacing: 0;
}
@media screen and (max-width:640px) {
	#access01 ul {
		grid-template-columns: repeat(2, 1fr);
		gap: 15px;
	}
}


/*------------------------------アクセス案内動画------------------------------*/
#access02 .inner {
	position: relative;
	display: flex;
	justify-content: center;
	margin: auto;
	width: 90%;
	max-width: 1280px;
}


/*------------------------------Googleマップ------------------------------*/
#access03 {
	position: relative;
}
#access03 .inner {
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
.access03_access_info {
	margin-bottom: 30px;
}
.access03_access_info li {
	display: flex;
	align-items: center;
	gap: 12px;
	justify-content: center;
	text-align: center;
	line-height: 1.8;
	margin-bottom: 20px;
}
.access03_access_map {
	position: relative;
	width: 100%;
	aspect-ratio: 16 / 6;
	margin-bottom: 30px;
}
.access03_access_map iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
}
@media screen and (max-width:640px) {
	.access03_access_info li {
		align-items: flex-start;
		text-align: left;
		justify-content: flex-start;
	}
	.access03_access_info li img {
		margin-top: 6px;
	}
	.access03_access_map {
		aspect-ratio: 4 / 3;
	}
}





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

		初診の方へ　＊　first-visit

==================================================================*/
#first-visit01 .btn a { letter-spacing: 2px;}
#first-visit01 .btn a:hover { letter-spacing: 3px;}
#first-visit02 h3 p  , #first-visit03 h3 p {
	letter-spacing: 2px;
}
#first-visit08 img { margin-top: 20px;}
#first-visit08 h5 { color: #406c60; font-size: 20px;}


@media screen and (max-width:640px) {
	#first-visit01 .btn a { letter-spacing: 1px;}
	#first-visit01 .btn a:hover { letter-spacing: 2px;}
	#first-visit06 h3 p { letter-spacing: 2px; font-size: 23px; padding: 0;}
}


.textarea {
	position: relative;
}
.textarea .inner {
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
.textarea h4 {
	font-size: 22px;
	letter-spacing: 3px;
	line-height: 1.8;
	padding: 12px 30px;
	margin: 50px 0 25px;
	background: #edf3f0;
	text-align: left;
}
.textarea h4::before { display: none;}
@media screen and (max-width:640px) {
	.textarea .inner {
		letter-spacing: 0px;
        line-height: 2;
	}
	.textarea h4 {
		font-size: 18px;
		letter-spacing: 0px;
		padding: 10px 15px;
		margin: 35px 0 10px;
	}
	
}




        

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

		クリニック紹介ページ　＊　clinic

==================================================================*/
@media screen and (max-width:640px) {
	#clinic01 h3 p {
		line-height: 1.7;
	}
}

/*------------------------------03＊医院紹介------------------------------*/
#clinic03 ul {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 15px;
	width: 90%;
	max-width: 1280px;
	margin: 0 auto;
}
#clinic03 ul li img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
#clinic03 ul li {
	aspect-ratio: 4 / 3;
	overflow: hidden;
}
@media screen and (max-width:640px) {
	#clinic03 ul {
		grid-template-columns: repeat(2, 1fr);
		gap: 8px;
	}
	#clinic03 ul li:nth-child(1) {
		grid-column: 1 / -1;
		aspect-ratio: 16 / 9;
	}
}


/*------------------------------04＊設備紹介------------------------------*/
#clinic04 ul {
	width: 90%;
	max-width: 1280px;
	margin: 0 auto 40px;
}
#clinic04 ul li figcaption {
	text-align: center;
	margin-top: 10px;
}
#clinic04 ul li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	display: block;
}
#clinic04 ul:nth-of-type(1) , #clinic04 ul:nth-of-type(4) { /* 1列目・4列目：4アイテム横並び */
	display: grid;
	grid-template-columns: repeat(4, 1fr);
	gap: 20px;
}
#clinic04 ul:nth-of-type(2) li , #clinic04 ul:nth-of-type(3) li { /* 2列目・3列目：写真3枚＋キャプション1つ */
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	gap: 0 20px;
}
#clinic04 ul:nth-of-type(2) li figcaption , #clinic04 ul:nth-of-type(3) li figcaption {
	grid-column: 1 / -1;
}
@media screen and (max-width:640px) {
	#clinic04 ul {
		margin-bottom: 25px;
		line-height: 1.6;
	}
	#clinic04 ul:nth-of-type(1) , #clinic04 ul:nth-of-type(4) {
		grid-template-columns: repeat(2, 1fr);
		gap: 10px;
	}
	#clinic04 ul:nth-of-type(2) li , #clinic04 ul:nth-of-type(3) li {
		grid-template-columns: repeat(1, 1fr);
		gap: 10px;
	}
}


/*------------------------------05＊初めて来院いただく方はこちらをチェック------------------------------*/
#clinic05 {
	width: 90%;
	max-width: 1280px;
	margin: 0 auto 40px;
}
#clinic05 .btn {
	width: 350px;
	margin: 50px auto 0;
	box-sizing: border-box;
	border: 1px solid #ddd;
	background: #FFF;
	transition: 0.3s ease-out;
	text-align: center;
}
#clinic05 .btn a {
	display: block;
	width: 100%;
	padding: 10px 0;
}
#clinic05 .btn a::before ,#clinic05 .btn a::after {
	display: none;
}
#clinic05 .btn:hover {
	background: #f2efea;
}
@media screen and (max-width:640px) {
	#clinic05 h4 p {
		padding: 0 15px;
        letter-spacing: 3px;
	}
	#clinic05 .btn {
		width: 100%;
		margin: 30px auto 0;
	}
}





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

		お知らせページ

==================================================================*/
.page-id-41 main::before {
	display: none;
}


#news {
	position: relative;
	padding: 80px 0 100px;
}
#news .inner {
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
@media screen and (max-width:640px) {
	#news {
		padding: 60px 0 40px;
	}
}
 
 
/*------------------------------お知らせ一覧------------------------------*/
#news_list {
	margin-bottom: 60px;
}
#news_list li {
	display: block;
	padding: 30px 20px;
	border-bottom: 1px solid #ddd;
}
#news_list li:first-child {
	border-top: 1px solid #ddd;
}
#news_list li dl dt {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 8px 0;
	margin-bottom: 12px;
}
#news_list li dl dt .date {
}
#news_list li dl dt .cate {
	font-size: 16px;
	padding: 8px 0px 9px;
	margin: 0 20px;
	letter-spacing: 1px;
	line-height: 1;
	white-space: nowrap;
}
#news_list li dl dt .title {
	font-size: 20px;
	line-height: 1.7;
}
#news_list li dl dd {
	color: #555;
}
@media screen and (max-width:640px) {
	#news_list li {
		padding: 22px 0;
	}
	#news_list li dl dt {
		margin-bottom: 8px;
	}
	#news_list li dl dt .date {
	}
	#news_list li dl dt .cate {
		padding: 0 20px;
		margin: 0 25px;
		line-height: 1.6;
	}
	#news_list li dl dt .title {
		font-size: 18px;
		letter-spacing: 1px;
		width: 100%;
    	white-space: normal !important;
    	overflow: visible !important;
    	text-overflow: unset !important;
	}
	#news_list li dl dd {
		font-size: 15px;
		line-height: 1.9;
	}
}
 

 /*------------------------------ページネーション＊お知らせ・ブログ共通------------------------------*/
.pagination {
	text-align: center;
	margin-top: 60px;
}
.pagination ul {
	display: inline-flex;
	align-items: center;
	gap: 8px;
}
.pagination ul li a , .pagination ul li span {
	display: flex !important;
	align-items: center;
	justify-content: center;
	width: 44px;
	height: 44px;
	padding: 0 !important;
	font-family: "EB Garamond", serif;
	letter-spacing: 1px;
	border: 1px solid #ddd !important;
	transition: .3s ease-out !important;
}
.pagination ul li span.current {
	background: #406c60;
	color: #FFF;
	border-color: #406c60;
}
.pagination ul li span.dots {
	color: #ccc;
	border-color: #eee;
	cursor: default;
}
.pagination ul li a.prev , .pagination ul li a.next {
	background: none;
	border-color: #878787;
	color: #406c60;
}
.pagination ul li a:hover {
	background: #dbe8e1;
	border-color: #406c60;
	color: #406c60;
}
@media screen and (max-width:640px) {
	.pagination ul li a , .pagination ul li span {
		width: 38px;
		height: 38px;
	}
}



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

		医院ブログページ

==================================================================*/
.page-id-18 main::before { 
	display: none;
}
#blog {
	position: relative;
	padding: 80px 0 100px;
}
#blog .inner {
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
@media screen and (max-width:640px) {
	#blog {
		padding: 60px 0 40px;
	}
}


/*------------------------------ブログ一覧------------------------------*/
#blog_list {
	margin-bottom: 60px;
}
#blog_list li a {
	display: flex;
	align-items: center;
	padding: 30px 20px;
	border-bottom: 1px solid #ddd;
	gap: 40px;
	transition: .3s ease-out;
}
#blog_list li:first-child a {
	border-top: 1px solid #ddd;
}
@media screen and (max-width:640px) {
	#blog_list li a {
		flex-direction: column;
		gap: 15px;
		padding: 25px 0;
	}
}


#blog_list li figure {
	width: 250px;
	min-width: 250px;
	height: 180px;
	overflow: hidden;
}
#blog_list li figure img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	transition: .3s ease-out;
}
@media screen and (max-width:640px) {
	#blog_list li figure {
		width: 100%;
		min-width: 100%;
		height: 200px;
	}
}


#blog_list li dl {
	flex: 1;
	min-width: 0;
}
#blog_list li dl dt {
	display: flex;
	align-items: center;
	flex-wrap: wrap;
	gap: 5px 0;
	margin-bottom: 7px;
}
#blog_list li dl dt .date {
}
#blog_list li dl dt .cate {
	font-size: 16px;
	padding: 8px 0px 9px;
	margin: 0 20px;
	letter-spacing: 1px;
	line-height: 1;
	white-space: nowrap;
}
#blog_list li dl dt .title {
	font-size: 20px;
	line-height: 1.7;
}
#blog_list li dl dd {
	color: #555;
	line-height: 1.9;
	display: -webkit-box;
	-webkit-box-orient: vertical;
	-webkit-line-clamp: 2;
	overflow: hidden;
}
@media screen and (max-width:640px) {
	#blog_list li dl dt {
		margin-bottom: 8px;
	}
	#blog_list li dl dt .date {
	}
	#blog_list li dl dt .cate {
		padding: 0 20px;
		margin: 0 25px;
		line-height: 1.6;
	}
	#blog_list li dl dt .title {
		font-size: 18px;
		letter-spacing: 0px;
		width: 100%;
    	white-space: normal !important;
		display: -webkit-box;
		-webkit-box-orient: vertical;
		-webkit-line-clamp: 1;
		overflow: hidden;
	}
}


/* hover */
#blog_list li a:hover {
	background: rgba(219,232,225,.3);
	color: #406c60;
}
#blog_list li a:hover figure img {
	transform: scale(1.04);
}
#blog_list li a:hover dl dd {
	color: #406c60;
}





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

		$投稿ページ(single.php)

==================================================================*/
#single {
	position: relative;
	padding: 80px 0 100px;
}
#single .inner {
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
@media screen and (max-width:640px) {
	#single {
		padding: 60px 0 40px;
	}
}


/*------------------------------記事本体------------------------------*/
#single article {
	max-width: 900px;
	margin: 0 auto 60px;
}


.blog_eyecatch {
	width: 100%;
	height: 460px;
	overflow: hidden;
	margin-bottom: 40px;
}
.blog_eyecatch img {
	width: 100%;
	height: 100%;
	object-fit: cover;
}
@media screen and (max-width:640px) {
	.blog_eyecatch {
		height: 220px;
		margin-bottom: 25px;
	}
}


.blog_meta {
	display: flex;
	align-items: center;
	margin-bottom: 20px;
}
.blog_meta .date {
}
.blog_meta .cate {
	font-size: 16px;
	padding: 8px 0px 9px;
	margin: 0 20px;
	letter-spacing: 1px;
	line-height: 1;
	white-space: nowrap;
}
@media screen and (max-width:640px) {
	.blog_meta .date {
	}
	.blog_meta .cate {
		padding: 0 20px;
		margin: 0 25px;
		line-height: 1.6;
	}
}


.blog_title {
	font-size: 26px;
	letter-spacing: 3px;
	line-height: 1.8;
	padding-bottom: 30px;
	margin-bottom: 40px;
	border-bottom: 1px solid #ddd;
}
@media screen and (max-width:640px) {
	.blog_title {
		font-size: 20px;
		letter-spacing: 1px;
		padding-bottom: 20px;
		margin-bottom: 30px;
	}
}


/*------------------------------記事装飾------------------------------*/
#single .text img {
	max-width: 100%;
	height: auto;
	margin: 30px 0;
}
#single .text h1 {
	font-size: 24px;
	letter-spacing: 3px;
	line-height: 1.8;
	padding: 12px 30px;
	margin: 60px 0 25px;
	background: #406c60;
	color: #FFF;
}
#single .text h2 {
	font-size: 24px;
	letter-spacing: 3px;
	line-height: 1.8;
	padding-bottom: 12px;
	margin: 60px 0 25px;
	border-bottom: 2px solid #406c60;
}
#single .text h3 {
	font-size: 22px;
	letter-spacing: 3px;
	line-height: 1.8;
	padding: 12px 30px;
	margin: 50px 0 25px;
	background: #edf3f0;
	text-align: left;
}
#single .text h3::before { display: none;}
#single .text h4 {
	font-size: 20px;
	letter-spacing: 2px;
	line-height: 1.8;
	padding-bottom: 10px;
	margin: 40px 0 20px;
	border-bottom: 1px solid #ddd;
	color: #406c60;
	text-align: left;
}
#single .text h4::before { display: none;}
#single .text h5 {
	font-size: 18px;
	letter-spacing: 2px;
	line-height: 1.8;
	margin: 30px 0 15px;
	color: #406c60;
}
@media screen and (max-width:640px) {
	#single .text p {
		line-height: 2;
	}
	#single .text img {
		margin: 20px 0;
	}
	#single .text h1 {
		font-size: 19px;
		letter-spacing: 2px;
		padding: 10px 20px;
		margin: 45px 0 20px;
	}
	#single .text h2 {
		font-size: 19px;
		letter-spacing: 2px;
		margin: 45px 0 20px;
	}
	#single .text h3 {
		font-size: 18px;
		letter-spacing: 2px;
		padding: 10px 20px;
		margin: 35px 0 20px;
	}
	#single .text h4 {
		font-size: 18px;
		letter-spacing: 1px;
		margin: 30px 0 15px;
	}
	#single .text h5 {
		font-size: 16px;
		letter-spacing: 1px;
		margin: 25px 0 12px;
	}
}


/*------------------------------btn------------------------------*/
#single .btn {
	max-width: 900px;
	margin: auto;
	text-align: center;
	border-top: 1px solid #ddd;
	margin-top: 50px;
	padding-top: 50px;
}







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

		.price_content　＊　治療費

==================================================================*/
#price {
	position: relative;
	width: 90%;
	max-width: 1280px;
	margin: auto;
}
.price_section {
	margin-bottom: 80px;
	padding-bottom: 80px;
}
#price h3 { z-index: 3;}
#price h3 span {
	display: block;
	font-size: 20px;
	color: #3a9a80;
}
#price h4 {
	margin-bottom: 30px;
}
#price h4 p {
	font-size: 26px;
	padding: 0 45px;
	letter-spacing: 2px;
}
@media screen and (max-width:640px) {
	#price h4 {
		margin-bottom: 25px;
	}
	#price h4 p {
		font-size: 20px;
		padding: 0 25px;
		letter-spacing: 1px;
	}
}






#price table {
	position: relative;
	width: 100%;
	border-collapse: collapse;
	line-height: 1.8;
	margin: 30px 0;
	z-index: 6;
}
#price table {
	table-layout: fixed;
	width: 100%;
}
#price table thead th {
	padding: 14px 20px;
	background: #406c60;
	color: #FFF;
	font-weight: normal;
	text-align: left;
	border-right: 1px solid #5aa28e;
}
#price table thead th:last-child {
	border-right: none;
}
#price table tbody tr {
	border-bottom: 1px solid #ddd;
	transition: .3s ease-out;
}
#price table tbody tr:nth-child(even) {
	background: rgba(237, 243, 240, 0.7);
}
#price table tbody td {
	padding: 16px 20px;
	border-right: 1px solid #ddd;
	vertical-align: center;
	line-height: 1.8;
}
#price table tbody td:last-child {
	border-right: none;
}
#price table tbody td img {
	width: 180px;
	height: 120px;
	object-fit: cover;
	display: block;
}
#price table tbody td.price_num {
	text-align: right !important;
	white-space: nowrap;
	font-family: "EB Garamond", serif;
	font-size: 16px;
	letter-spacing: 1px;
}

@media screen and (max-width:640px) {
	#price table {
		font-size: 14px;
	}
	#price table thead th {
		padding: 8px 10px;
		font-size: 12px;
		letter-spacing: 0;
	}
	#price table tbody td {
		padding: 8px 10px;
		letter-spacing: 0;
	}
	#price table tbody td img {
		width: 80px;
		height: 60px;
	}
	#price table tbody td.price_num {
		font-size: 14px;
		white-space: normal;
	}
}
@media screen and (max-width:640px) {
	#price .table_wrap {
		overflow-x: auto;
		-webkit-overflow-scrolling: touch;
		margin: 30px 0;
	}
	#price .table_wrap table {
		min-width: 750px;
		margin: 0;
	}
}

/*------------------------------幅の設定------------------------------*/
#price table th:nth-child(1),
#price table td:nth-child(1) { width: 20%; }
#price table th:nth-child(2),
#price table td:nth-child(2) { width: 180px; }
#price table th:nth-child(3),
#price table td:nth-child(3) { width: auto; }
#price table th:nth-child(4),
#price table td:nth-child(4) { width: 15%; }
@media screen and (max-width:640px) {
	#price table th:nth-child(1),
	#price table td:nth-child(1) { width: 22%; }
	#price table th:nth-child(2),
	#price table td:nth-child(2) { width: 90px; }
	#price table th:nth-child(3),
	#price table td:nth-child(3) { width: auto; }
	#price table th:nth-child(4),
	#price table td:nth-child(4) { width: 18%; }
}


/*------------------------------メンテナンスだけ------------------------------*/
#price08 table th:nth-child(1),
#price08 table td:nth-child(1) { width: 25%; }
#price08 table th:nth-child(2),
#price08 table td:nth-child(2) { width: auto; }
#price08 table th:nth-child(3),
#price08 table td:nth-child(3) { width: 18%; }
@media screen and (max-width:640px) {
	#price08 .table_wrap table {
		min-width: 500px;
	}
	#price08 table th:nth-child(1),
	#price08 table td:nth-child(1) { width: 28%; }
	#price08 table th:nth-child(2),
	#price08 table td:nth-child(2) { width: auto; }
	#price08 table th:nth-child(3),
	#price08 table td:nth-child(3) { width: 22%; }
}



/*------------------------------注意書きリスト------------------------------*/
#price .note {
	margin-top: 25px;
	color: #ec9d06;
}
@media screen and (max-width:640px) {
	#price .note {
		font-size: 14px;
	}
}



/*------------------------------分割払いについて------------------------------*/
#price09 {
	position: relative;
	display: flex;
	flex-direction: column;
	align-items: center;
	margin: 70px auto;
	width: 90%;
	max-width: 1280px;
	text-align: center;
}
@media screen and (max-width:640px) {
	#price09 {
		margin: 50px auto 0;
		width: 100%;
	}
}

