@charset "utf-8";
/* 治療方針 */
#policy .page_inner {
	padding: 0 0 80px;
}
.policy_lead_txt_wrap {
	text-align: center;
}
.policy_lead_txt {
	display: inline-block;
	font-size: 18px;
	line-height: 1.4;
	text-align: center;
	position: relative;
}
.policy_lead_txt span {
	color: #50B6BB;
}
.policy_lead_txt::before,
.policy_lead_txt::after {
	content: '';
	position: absolute;
	width: 12px;
	height: 12px;
}
.policy_lead_txt::before {
	border-left: #50B6BB solid 2px;
	border-top: #50B6BB solid 2px;
	top: 0;
	left: -22px;
}
.policy_lead_txt::after {
	border-right: #50B6BB solid 2px;
	border-bottom: #50B6BB solid 2px;
	bottom: 0;
	right: -22px;
}
.policy_list {
	margin: 30px 0 0;
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	gap: 16px 10px;
}
.policy_item {
	background: #FFF;
	border-radius: 50%;
	display: flex;
	align-items: center;
	justify-content: center;
	position: relative;
	width: 48.3%;
	max-width: 154px;
  aspect-ratio: 154 / 154;
	}
.policy_item_num {
	color: #50B6BB;
	font-size: 35px;
	line-height: 1.25;
	position: absolute;
	top: 0;
	left: 0;
}
.policy_item_txt {
	text-align: center;
	font-size: 14px;
}
.policy_item_txt span {
	color: #50B6BB;
}
@media only screen and (min-width: 768px) {
	.policy_lead_txt {
		font-size: clamp(18px, 2.34vw, 30px);
	}
	.policy_lead_txt br {
		display: none;
	}
	.policy_list {
		gap: 0 23px;
	}
	.policy_item {
		width: 22.5%;
		max-width: 240px;
	}
	.policy_item_num {
		font-size: clamp(35px, 4vw, 51px);
	}
	.policy_item_txt {
		font-size: clamp(14px, 1.56vw, 20px);
	}
}
@media only screen and (min-width: 1280px) {
	#policy .page_inner {
		padding: 0 0 160px;
	}
	.policy_lead_txt {
		font-size: 30px;
	}
	.policy_lead_txt::before,
	.policy_lead_txt::after {
		width: 17px;
		height: 17px;
	}
	.policy_lead_txt::before {
		border-left: #50B6BB solid 3px;
		border-top: #50B6BB solid 3px;
		left: -40px;
	}
	.policy_lead_txt::after {
		border-right: #50B6BB solid 3px;
		border-bottom: #50B6BB solid 3px;
		right: -40px;
	}
	.policy_list {
		margin: 60px 0 0;
	}
	.policy_item {
		width: 23.2%;
	}
	.policy_item_num {
		font-size: 51px;
	}
	.policy_item_txt {
		font-size: 20px;
		line-height: 1.7;
	}
}
@media only screen and (min-width: 1600px) {
	.policy_list {
		gap: 0 40px;
	}
	.policy_item {
		width: calc((100% - 120px) /4);
		max-width: unset;
	}
	.policy_item_txt {
		font-size: 24px;
	}
}
/* ウチダ歯科医院の４つのお約束 */
.promise_wrap {
	margin: 100px 0 0;
}
.promise_list {
	border-top: 1px solid #BFBFBF;
}
.promise_item {
	border-bottom: 1px solid #BFBFBF;
	padding: 30px 0;
	display: flex;
	flex-direction: column;
	align-items: center;
	gap: 20px 0;
	text-align: center;
}
.promise_word {
	color: #50B6BB;
	font-size: 19px;
	line-height: 1.4;
	display: inline-block;
	position: relative;
}
.promise_word::before,
.promise_word::after {
	position: absolute;
	content: '';
	width: 10px;
	height: 10px;
}
.promise_word::before {
	border-left: #50B6BB solid 2px;
	border-top: #50B6BB solid 2px;
	top: 0;
	left: -21px;
}
.promise_word::after {
	border-right: #50B6BB solid 2px;
	border-bottom: #50B6BB solid 2px;
	bottom: 0;
	right: -21px;
}
.promise_txt {
	font-weight: 400;
	line-height: 1.7;
}
@media only screen and (min-width: 768px) {
	.promise_wrap .sec_ttl br {
		display: none;
	}
	.promise_item {
		padding: 30px 20px;
		flex-direction: row;
		justify-content: space-between;
		gap: 0;
	}
	.promise_word {
		font-size: clamp(19px, 2.34vw, 30px);
		margin: 0 0 0 20px;
	}
	.promise_txt {
		width: 70%;
	}
}
@media only screen and (min-width: 1280px) {
	.promise_wrap {
		margin: 200px 0 0;
	}
	.promise_item {
		padding: 64px 40px;
	}
	.promise_word {
		font-size: 30px;
		margin: 0 0 0 40px;
	}
	.promise_word::before,
	.promise_word::after {
		width: 17px;
		height: 17px;
	}
	.promise_word::before {
		border-left: #50B6BB solid 3px;
		border-top: #50B6BB solid 3px;
		left: -40px;
	}
	.promise_word::after {
		border-right: #50B6BB solid 3px;
		border-bottom: #50B6BB solid 3px;
		right: -40px;
	}
}
@media only screen and (min-width: 1600px) {
	.promise_word {
		font-size: 36px;
	}
}
/* 当院で行っている診療 */
.treatment_box_wrap {
	margin: 40px 0 0;
}
.treatment_box {
	background: #FFF;
	border-radius: 10px;
	padding: 18px 20px 37px;
}
.treatment_box + .treatment_box {
	margin: 40px 0 0;
}
.treatment_box_ttl_area {
	display: flex;
	align-items: center;
	gap: 0 11px;
	border-bottom: 1px solid #50B6BB;
	padding: 0 0 7px;
	position: relative;
}
.treatment_box_ttl_img {
	border: 2px solid #EEEEEC;
	border-radius: 50%;
	width: 48px;
	height: 48px;
	display: flex;
	align-items: center;
	justify-content: center;
}
.treatment_box_ttl_img img {
	width: 50%;
}
.treatment_box_ttl_en {
	font-size: 13px;
	line-height: 1.25;
	color: #50B6BB;
}
.treatment_box_ttl_jp {
	margin: 3px 0 0;
	font-size: 20px;
	line-height: 1;
}
.treatment_cases_area {
	margin: 20px 0 0;
}
.treatment_cases_img {
	max-width: 420px;
	margin: auto;
}
.treatment_cases_list {
	margin: 20px auto 0;
	max-width: 420px;
}
.treatment_cases_list_box {
	background: #F5F5F3;
	padding: 20px;
}
.treatment_cases_txt + .treatment_cases_txt {
	margin: 18px 0 0;
}
.treatment_cases_txt {
	padding: 0 0 0 27px;
	position: relative;
}
.treatment_cases_txt::before {
	content: "";
	display: block;
	background: url(../images/treatment/check_icon.svg) no-repeat center / contain;
	position: absolute;
	left: 0;
	top: 16%;
	width: 16px;
	height: 16px;
}
.treatment_cases_txt_02 {
	margin: 9px 0 0;
}
.treatment_box_txt {
	font-weight: 400;
	line-height: 1.7;
	margin: 31px 0 0;
}
.treatment_box_txt p + p {
	margin: 15px 0 0;
}
.treatment_free_txt {
	background: #50B6BB;
	border-radius: 5px;
	color: #FFF;
	font-size: 14px;
	line-height: 1.25;
	width: 50px;
	height: 50px;
	display: flex;
	align-items: center;
	justify-content: center;
	position: absolute;
	right: 0;
}
@media only screen and (min-width: 768px) {
	.treatment_box_wrap {
		margin: 80px 0 0;
	}
	.treatment_box {
		border-radius: 20px;
		padding: 30px 40px 60px;
	}
	.treatment_box + .treatment_box {
		margin: 60px 0 0;
	}
	.treatment_box_ttl_area {
		gap: 0 30px;
		padding: 0 0 10px;
	}
	.treatment_box_ttl_img {
		width: 80px;
		height: 80px;
	}
	.treatment_box_ttl_en {
		font-size: clamp(13px, 1.56vw, 20px);
	}
	.treatment_box_ttl_jp {
		margin: 10px 0 0;
		font-size: clamp(20px, 3.12vw, 40px);
	}
	.treatment_box_ttl_jp br {
		display: none;
	}
	.treatment_cases_area {
		margin: 35px 0 0;
		display: flex;
		align-items: center;
		gap: 0 30px;
	}
	.treatment_cases_img {
		margin: 0;
		width: 50%;
	}
	.treatment_cases_list {
		margin: 0;
		width: 50%;
		max-width: 618px;
	}
	.treatment_cases_list_box {
		padding: 25px;
	}
	.treatment_cases_txt::before {
		top: 19%;
	}
	.treatment_free_txt {
		font-size: clamp(17px, 1.87vw, 24px);
		width: 70px;
		height: 70px;
	}
}
@media only screen and (min-width: 1024px) {
	.treatment_cases_txt {
		padding: 0 0 0 32px;
	}
	.treatment_cases_txt::before {
		width: 19px;
		height: 19px;
	}
	.treatment_free_txt {
		width: 85px;
		height: 85px;
	}
}
@media only screen and (min-width: 1280px) {
	.treatment_box_wrap {
		margin: 116px 0 0;
	}
	.treatment_box {
		padding: 50px 90px 80px;
	}
	.treatment_box + .treatment_box {
		margin: 80px 0 0;
	}
	.treatment_box_ttl_area {
		gap: 0 50px;
		padding: 0 0 26px;
	}
	.treatment_box_ttl_img img {
		width: unset;
	}
	.treatment_box_ttl_img {
		border: 5px solid #EEEEEC;
		width: 120px;
		height: 120px;
	}
	.treatment_box_ttl_en {
		font-size: 20px;
	}
	.treatment_box_ttl_jp {
		font-size: 40px;
	}
	.treatment_cases_area {
		margin: 50px 0 0;
		gap: 0 62px;
	}
	.treatment_cases_list {
		width: 100%;
	}
	.treatment_cases_list_box {
		padding: 29px 25px 28px 36px;
		display: flex;
		flex-direction: column;
		justify-content: center;
	}
	.treatment_cases_txt {
		padding: 0 0 0 39px;
	}
	.treatment_cases_txt::before {
		top: 12%;
		width: 23px;
		height: 23px;
	}
	.treatment_cases_txt_02 {
		margin: 13px 0 0;
	}
	.treatment_box_txt {
		margin: 35px 0 0;
	}
	.treatment_box_txt p + p {
		margin: 25px 0 0;
	}
	.treatment_free_txt {
		font-size: 24px;
		width: 100px;
		height: 100px;
	}
}