@charset "UTF-8";

/*トップ
----------------------------------------------------*/
#intro .text {
	position: relative;
}

#intro p.catch {
	padding-bottom: 40px;
}

#intro p.concept {
	position: absolute;
	left: 0;
	top: 20px;
	font-size: 70px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	color: rgba(153, 142, 115, 0.2);
}

#intro p b {
	color: #72623b;
	font-size: 1.2em;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
}

#intro .img {
	position: relative;
	padding-bottom: 70px;
	max-width: 90%;
	margin: 1em auto 0;
	max-width: 400px;
}

#intro .img p {
	position: absolute;
	bottom: 40px;
	right: -4%;
	font-size: 45px;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	text-align: right;
	color: rgba(153, 142, 115, 0.7);
	line-height: 1.1;
}

#cases .banner a {
	display: flex;
	align-items: center;
	padding: 1.5em 40px 1.5em 1.5em;
	background: #fff;
	box-sizing: border-box;
	text-decoration: none;
	width: 100%;
	margin-bottom: 2em;
	color: #565565;
	font-size: 1.1em;
	font-family: 'Noto Serif JP', serif;
	position: relative;
	min-height: 80px;
	box-shadow: 2px 2px 8px rgba(0,0,0,0.1);
}

#cases .banner a::before {
	transform-origin: bottom;
	transform: scale(1, 0);
}

#cases .banner a:hover::before{
	transform: scale(1, 1);
	opacity: 1.0;
}

#cases .banner a p.num {
	position: absolute;
	bottom: -15px;
	right: 10px;
	font-size: 60px;
	font-size: 6.0rem;
	color: rgba(153, 142, 115, 0.6);
	line-height: 1;
	transition: 0.5s;
	text-align: right;
}

#cases .banner a:hover p.num {
	color: #fff;
}

#cases .banner a ul li {
	padding-left: 1em;
	position: relative;
}

#cases .banner a ul li::before {
	content: "";
	display: block;
	background: #998e73;
	width: 6px;
	height: 6px;
	position: absolute;
	top: 15px;
	left: 0;
}

#features li {
	position: relative;
	margin: 9em 0 0;
	background: rgba(153, 142, 115, 0.1);
	padding-top: 4em;
}

#features li .img {
	position: absolute;
	top: -5em;
	left: calc( 50% - 140px);
	margin: 0 auto 2em;
	text-align: center;
	width: 260px;
	z-index: 2;
}

#features li .img span.num {
	display: block;
	font-size: 100px;
	opacity: 0.6;
	color: #998e73;
	position: absolute;
	bottom: -30px;
	left: -20px;
	line-height: 1;
	font-family: 'Libre Caslon Display', serif;
}

#features .text {
	padding: 6em 1em 1em;
}

#features h3 {
	color: #72623b;
	font-family: 'Noto Serif JP', serif;
	margin: 0 0 0.5em;
	font-weight: 500;
	position: relative;
	font-size: 1.2em;
}

#prevention_top .text {
	margin-bottom: 4em;
}

#prevention_top .text a {
	width: 14em;
	margin: 2em auto 0;
	text-align: center;
}

#prevention_top .menu {
	position: relative;
	font-family: 'Noto Serif JP', serif;
}

#prevention_top .menu ul {
	display: flex;
	align-items: center;
	gap: 1.5em;
	justify-content: center;
	flex-wrap: wrap;
	margin: 0 auto;
	max-width: 350px;
}

#prevention_top .menu ul li {
	width: 130px;
	height: 130px;
	background: rgba(86, 85, 101, 0.7);
	border-radius: 50%;
	text-align: center;
	color: #fff;
	position: relative;
	font-size: 17px;
	font-size: 1.7rem;
}

#prevention_top .menu ul li p {
	width: 100%;
	padding: 0;
	margin: 0;
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
}

#prevention_top .menu ul li p span.big {
	font-size: 1.3em;
}

#prevention_top .menu ul li p span.space {
	letter-spacing: 0;
}

#news dt {
	color: #998e73;
}

#news dd {
	padding-bottom: 1.5em;
	margin-bottom: 1.5em;
	border-bottom: 1px solid #ccc;
}

#news dd a {
	color: #333;
}

#news p {
	text-align: center;
	font-size: 1.1em;
	border-bottom: 1px solid #ccc;
	padding: 1em 2em;
	width: fit-content;
	margin: 0 auto;
}

#calendar div.box {
	margin-bottom: 2em;
}

#calendar div.box div.caption {
	color	: #565565;
	text-align	: center;
	font-size: 1.4em;
	font-family: 'Noto Serif JP', serif;
	font-weight: 500;
	padding-bottom: 0.1em;
}

#calendar div.box table {
	width: 100%;
	background: #fff;
}

#calendar div.box table th {
	margin		: 0;
	padding		: 6px 0 6px 0;
	border: 1px solid #565565;
	background	: #f5f3f1;
	text-align	: center;
	font-weight	: normal;
	font-size	: 85%;
}

#calendar div.box table td {
	margin		: 0;
	padding		: 2px 0;
	border: 1px solid #565565;
	text-align	: center;
	font-weight	: normal;
}

#calendar div.box table td.sun,
#calendar div.box table td.wed,
#calendar div.box table td.holiday {
	background	: rgba(86, 85, 101, 0.5);
	color		: #fff !important;
}

#calendar ul.note {
	width: fit-content;
	margin: 0 auto;
}

#calendar ul.note li {
	display: inline-block;
	padding-left: 0.4em;
}

#calendar ul.note li.close {
	border-left: 2em solid rgba(86, 85, 101, 0.5);
	margin-right: 1em;
} 

#calendar ul.note li.half {
	border-left: 2em solid rgba(153, 142, 115, 0.5);
} 

/* #blog ul li {
	display: flex;
	margin-bottom: 1em;
	justify-content: space-between;
	align-items: center;
	background: #fff;
	padding: 1em;
	box-sizing: border-box;
	box-shadow: 2px 2px 8px rgba(0,0,0,0.1);
}

#blog ul li .text {
	width: calc( 100% - 120px);
}

#blog ul li img {
	width: 100px;
	height: 100px;
	object-fit: cover;
	border: 1px solid #e2e2e2;
}

#blog .blog_list a {
	width: 14em;
	margin: 2em auto 0;
	text-align: center;
} */


/*医院紹介 
----------------------------------------------------*/
#photo .photoslide {
	margin-bottom: 1em;
	box-sizing: border-box;
	max-width: 940px;
	width: 100%;
}

#photo .swiper-button-next, #photo .swiper-button-prev {
	color: #998e73;
}

#photo .photo-thumbnail {
	max-width: 800px;
}

#photo .slider-thumbnail .swiper-slide {
	opacity: .5;
	transition: opacity .5s;
	width: calc(100% / 3);
}

#photo .slider-thumbnail .swiper-slide.swiper-slide-thumb-active {
	opacity: 1;
}

#photo .swiper-slide img {
	height: auto;
	width: 100%;
}

#photo .photo-thumbnail .swiper-slide-thumb-active {
	opacity: 0.3;
}

#access .gmap {
	position: relative;
	padding: 0 0 70%;
	height: 0;
	overflow: hidden;
	margin-bottom: 2em;
}

#access .gmap iframe {
	position: absolute;
	top: 0;
	left: 0;
	width: 100% !important;
	height: 100% !important;
}

#access ul {
	width: fit-content;
	margin: 0 auto;
}


/*院長紹介 
----------------------------------------------------*/
#director .photo_name {
	text-align: center;
}

#director .photo_name h3 {
	margin: 1em 0 0;
	font-size: 40px;
	font-size: 4.0rem;
	font-family: 'Noto Serif JP', serif;
	font-weight: 400;
	line-height: 1.4;
}

#director .photo_name h3 .en {
	font-size: 0.6em;
}

#director .message {
	margin-top: 8%;
	padding: 3%;
	background: rgba(153, 142, 115, 0.1);
	line-height: 2.2;
}


/*診療案内 
----------------------------------------------------*/
article.treat h3.title03 {
	margin-top: 2em;
}

#tooth_decay ul.treat_flow li,
#about_stuffing ul.stuffing_type li {
	background: rgba(153, 142, 115, 0.1);
	padding: 1em;
	margin-bottom: 1em;
	border: 1px solid rgba(114, 98, 59, 0.5);
}

#tooth_decay ul.treat_flow li h4,
#about_stuffing ul.stuffing_type li h4 {
	background: #fff;
	text-align: center;
	color: #72623b;
	font-size: 1.2em;
	padding: 0.2em 1em;
	width: fit-content;
	font-family: 'Noto Serif JP', serif;
	margin: 0 auto 1em;
}

#tooth_decay ul.treat_flow li .cover,
#about_stuffing ul.stuffing_type li .cover {
	display: flex;
	justify-content: space-around;
	align-items: center;
}

#tooth_decay ul.treat_flow li p,
#about_stuffing ul.stuffing_type li p {
	width: 65%;
}

#tooth_decay ul.treat_flow li .img,
#about_stuffing ul.stuffing_type li .img {
	text-align: center;
	width: 30%;
	max-width: 170px;
}

#prevention_menu .pro_care {
	background: rgba(255, 255, 255, 0.7);
	padding: 1% 3% 3%;
	margin-top: 4%;
}

#prevention_menu .pro_care dt {
	font-weight: 700;
	color: #998e73;
	font-size: 1.1em;
	margin: 1em 0 0.3em;
	font-family: 'Noto Serif JP', serif;
}

#tooth_decay a.button {
	border: 1px solid #998e73;
	width: fit-content;
	text-decoration: none;
	color: #998e73;
	position: relative;
	display: inline-block;
	padding: 0.2em 1em 0.2em 2em;
	white-space: nowrap;
	font-size: 1.1em;
	margin-top: 1em;
}

#tooth_decay a.button::before {
	content: "";
	display: block;
	width: 0.4em;
	height: 0.4em;
	border-top: 1px solid #998e73;
	border-right: 1px solid #998e73;
	transform: rotate(45deg);
	position: absolute;
	top: 43%;
	left: 0.7em;
}

#fs h3.title03,
#privacy h3.title03 {
	margin-top: 2em;
}

#fs ol {
	padding: 0;
}

#recruit_flow ul li {
	background: rgba(153, 142, 115, 0.1);
	padding: 1em;
	margin-bottom: 4em;
	position: relative;
}

#recruit_flow ul li:not(:last-child)::after {
	content: "";
	display: block;
	position: absolute;
	bottom: -2.7em;
	left: calc( 50% - 20px);
	border-top: solid 20px #998e73;
	border-left: solid 20px transparent;
	border-right: solid 20px transparent;
}

#recruit_flow ul li h4 {
	background: #fff;
	text-align: center;
	color: #72623b;
	font-size: 1.2em;
	padding: 0.2em 1em;
	width: fit-content;
	font-family: 'Noto Serif JP', serif;
	margin: 0 auto 1em;
}




/*media Queries
----------------------------------------------------*/
@media only screen and (min-width: 860px) {
	#intro .inner {
		display: flex;
		justify-content: space-between;
		align-items: center;
		gap: 5%;
	}

	#intro p.concept {
		font-size: 80px;
	}

	#intro .inner .img {
		max-width: none;
		margin: 0;
	}
	
	#cases .banner {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-around;
    	align-items: stretch;
	}
	
	#cases .banner a {
		width: 49%;
	}
	
	#features ul {
		display: flex;
		flex-wrap: wrap;
		justify-content: space-between;
	}
	
	#features li {
		width: 38%;
	}

	#features li {
		margin: 0 0 5em 10%;
		padding: 0;
	}

	#features li .img {
		top: -1em;
		left: -25%;
		width: 40%;
	}

	#features li .text {
		padding: 1em 1.5em 1em 20%;
	}

	#prevention_top .cover {
		display: flex;
		justify-content: space-between;
		align-items: center;
	}

	#prevention_top .menu {
		width: 400px;
	}

	#prevention_top .text {
		width: calc( 90% - 400px);
		margin: 0;
	}

	#news dl {
		max-width: 1000px;
		margin: 0 auto;
	}

	#news dt {
		clear: both;
		float: left;
		padding-bottom: 1.5em;
		margin-bottom: 1.5em;
	}
	
	#news dd {
		padding-left: 15em;
	}

	#calendar .cover {
		display: flex;
		justify-content: space-between;
	}

	#calendar .cover .box {
		width: 48%;
	}

/* 	#blog ul {
		display: flex;
		justify-content: space-between;
		flex-wrap: wrap;
		max-width: 1000px;
		margin: 0 auto;
	}

	#blog ul li {
		width: 48%;
	}

	#blog ul li p.date {
		text-align: center;
	} */

	#photo .photoslide {
		padding: 0 70px;
	}

	#access .gmap {
		padding: 0 0 45%;
	}

	#director .photo_name {
		text-align: center;
		display: flex;
		gap: 7%;
		align-items: center;
		flex-direction: row-reverse;
		justify-content: center;
	}

	#director .photo_name h3 {
		text-align: right;
	}

	#recruit_flow ul li {
		text-align: center;
	}

}

/*media Queries
----------------------------------------------------*/
@media only screen and (min-width: 1200px) {

	#intro p.concept {
		font-size: 90px;
	}

	#cases .banner a {
		width: 31%;
	}

	#calendar div.box table th,
	#calendar div.box table td {
		padding		: 10px 0;
	}

/* 	#blog ul li {
		display: block;
		width: 24%;
	}

	#blog ul li .text {
		width: 100%;
	}

	#blog ul li .img {
		text-align: center;
		margin-bottom: 1em;
	}
	
	#blog ul li img {
		width: 230px;
		height: 180px;
	  } */

	#prevention_top .menu ul li {
		width: 160px;
		height: 160px;
		font-size: 19px;
		font-size: 1.9rem;
	}

	#director .photo_name h3 {
		font-size: 60px;
		font-size: 6.0rem;
	}


}


/*media Queries
----------------------------------------------------*/
@media only screen and (min-width: 1400px) {

	#intro p.concept {
		top: 40px;
		font-size: 110px;
	}

	#cases .banner a {
		width: 24%;
	}

}


