@charset "UTF-8";
@import url("base.css");
/* CSS Document */


#aboutCc{
	padding-top: 48%;
	margin: 50px auto;
	position: relative;
}

@media screen and (min-width: 768px){
	#aboutCc{
		display: flex;
		padding: 0;
		justify-content: center;
		gap: 8%;
		width: 84.38%;
	}
}

.ccImg{
	width: calc(152 / 375 * 100%);
	height: auto;
	border-radius: 80px 0 80px 0;
	position: absolute;
	top: 0;
	left: 5%;
}

@media screen and (min-width: 768px){
	.ccImg{
		width: calc(359 / 1440 * 100%);
		max-width: 300px;
		position: static;
	}
}

.ccImg img{
	width: 100%;
	height: auto;
	border-radius: 50%;
	border-top-right-radius: 0;
	border-bottom-left-radius: 0;
	box-shadow: 20px 20px 0 0 rgba(186,216,110,0.5);
}

.ccWrapper{
	margin-left: auto;
	width: 88%;
}

@media screen and (min-width: 768px){
	.ccWrapper{
		width: 61.9%;
		max-width: 600px;
		margin: 0;
	}
}

.ccContainer{
	background: #F5F4E4;
	margin-right: 0;
}

.cc{
	padding: 8%;
	
}

.cc h2{
	font-size: clamp(14px, 14 / 375 * 100vw, 18px);
	color: #5C6C34;
	white-space: nowrap;
}

@media screen and (min-width: 600px){
	.cc h2{
		white-space: normal;
	}
}

.cc h2 span{
	display: block;
	margin-bottom: 1em;
}

@media screen and (min-width: 600px){
	.cc h2 span{
		display: inline-block;
	}
}

.cc p{
	font-size: clamp(13px, 13 / 375 * 100vw, 16px);
	line-height: 2;
}

.ccWrapper .detailBtn{
	margin: 10px 0;
}

#message{
	margin: 50px 0;
	
}

#message .sectionTitle{
	margin-bottom: 2.5em;
}

.messageWrapper{
	width: 76.8%;
	margin: 0 auto;
}

@media screen and (min-width: 768px){
	.messageWrapper{
		width: 90%;
		max-width: 1100px;
		margin: 0 auto;
		display: flex;
		flex-direction: row-reverse;
		justify-content: space-between;
		align-items: flex-start;
	}
}

.messageWrapper img{
	width: 69.44%;
	height: auto;
	display: block;
	margin: 30px auto;
	border-radius: 10px
}

@media screen and (min-width: 768px){
	.messageWrapper img{
		width: calc(352 / 1009 * 100%);
		margin: 0;
	}
}

.greet{
	width: 100%;
}

@media screen and (min-width: 768px){
	.greet{
		width: calc(577 / 1009 * 100%);
	}
}

.greet h3{
	color: #869C51;
	margin-bottom: 15px;
	font-size: clamp(16px, 16 / 375 * 100vw, 20px);
	white-space: nowrap;
}

.greet p{
	font-size: clamp(13px, 13 / 375 * 100vw, 16px);
	line-height: 2;
}

.greet span{
	color: #869C51;
}

.dtName{
	margin: 20px 0;
}

.dtName p{
	line-height: 1.5;
	font-size: clamp(15px, 15 / 375 * 100vw, 18px);
}

#hour{
	background: url("../img/abBg.svg") no-repeat center;
	background-size: contain;
	padding-bottom: clamp(50px, 100 / 375 * 100vw, 130px);
	padding-top: clamp(20px, 50 / 375 * 100vw, 80px);
	width: 90%;
	margin: 0 auto;
}

@media screen and (min-width: 1025px){
	#hour{
		background: none;
		padding: 0;
		width: auto;
		margin: 0;
	}
}

#hour .sectionTitle{
	margin-bottom: 2em;
}

@media screen and (min-width: 1025px){
	#hour .sectionTitle{
		margin-bottom: 4em;
	}
}

#hour .hourWrapper{
	background: #FFFFFE;
	border-radius: 20px;
	border: 1px solid #869C51;
	width: calc(350 / 371 * 100%);
	max-width: 500px;
	padding: 15px 20px;
}

.mapWrapper{
	width: calc(270 / 375 * 100%);
	margin: 20px auto;
}

@media screen and (min-width: 1025px){
	.mapWrapper{
		margin: 0 auto;
		width: auto;
	}
	
}

.mapWrapper iframe{
	width: 100%;
	height: auto;
	aspect-ratio: 270 / 170;
}

.accessW{
	display: flex;
	gap: 1em;
}

.accessC{
	width: 50%;
}


.accessC p{
	font-size: clamp(13px, 13 / 375 * 100vw, 16px);
	margin-bottom: 5px;
}


.accessC p:first-child{
	display: inline-block;
	font-size: clamp(14px, 14 / 375 * 100vw, 18px);
	font-weight: 600;
	border-bottom: 1px solid #655638;
	margin: 10px 0;
}

@media screen and (min-width: 1025px){
	
	.haFlex section{
		margin: 0;
	}
	
	.haFlex{
		display: flex;
		justify-content: center;
		align-items: baseline;
		background: url("../img/abBg.svg") no-repeat top;
		background-size: cover;
		flex-direction: row-reverse;
		width: 100%;
		column-gap: 5%;
		padding: 10%;
		padding-bottom: 15%;
	}
}

#Overview{
	background: #FEFDF2;
	border: 1px solid #655638;
	border-radius: 30px 30px 0 0;
	padding: 10% 0;
}

@media screen and (min-width: 1025px){
	#Overview{
		margin-top: -5%;
	}
}

#Overview .sectionTitle{
	width: calc(302 / 375 * 100%);
	max-width: 710px;
	text-align: left;
	margin: 0 auto;
	margin-bottom: 2em;
}

.clinicDetails{
	width: calc(302 / 375 * 100%);
	max-width: 710px;
	margin: 0 auto;
}

.clinicDetails > div{
	display: flex;
	align-items: baseline;
	border-bottom: 1px dotted #655638;
	padding: 5% 5%;
	gap: 5%;
}

.clinicDetails dt{
	font-size: clamp(14px, 14 / 375 * 100vw, 18px);
	width: 80px;
	flex-shrink: 0;
}

.clinicDetails dd{
	font-size: clamp(12px, 12 / 375 * 100vw, 16px);
}
