@charset "utf-8";

/**************************************
        マウスピース矯正 20220121 add
**************************************/

.ortho-mouthpiecePage {
	background: url(../img/child/page_title_bg.webp) no-repeat center center;
	background-size: cover;
}

#conts .mouthpiece * {
	box-sizing: border-box;
}

#conts .mouthpiece .txt01 {
	margin-bottom: 16px;
}

#conts .mouthpiece .txt02 {
	margin-bottom: 24px;
}

#conts .mouthpiece .txt03 {
	margin-bottom: 88px;
}

#conts .mouthpiece .picture img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}

#conts .mouthpiece .flexBox li .photoBox {
	width: 236px;
}

#conts .mouthpiece .flexBox li .textBox {
	flex: 1;
}

@media (max-width: 767px) {
	.ortho-mouthpiecePage {
		background: url(../img/child/sp_page_title_bg.webp) no-repeat center center;
		background-size: cover;
	}


	#conts .mouthpiece .flexBox li .photoBox {
		width: 100%;
	}

	#conts .mouthpiece .flexBox li .textBox {
		flex: none;
	}
}

@media (max-width: 767px) {
	#conts .mouthpiece .headLine01 {
		margin-bottom: 44px;
	}

	#conts .mouthpiece .txt03 {
		margin-bottom: 57px;
	}
}

#conts .mouthpiece .mt {
	margin-top: 35px;
}

#conts .mouthpiece .photoBox img {
	width: 100%;
	height: auto;
	vertical-align: middle;
}

@media (max-width: 767px) {
	#conts .mouthpiece .comInner {
		margin-bottom: 35px;
	}
}

#conts .mouthpiece .comInner .photoBox {
	width: 250px;
}

@media (max-width: 767px) {
	#conts .mouthpiece .comInner .photoBox {
		width: 125px;
	}
}

#conts .mouthpiece .comInner .textBox {
	width: 430px;
	float: left;
}

@media (max-width: 767px) {
	#conts .mouthpiece .comInner .textBox {
		width: 340px;
	}
}

#conts .mouthpiece .comInner .textBox p {
	font-size: 15px;
	line-height: 2.0;
	color: #323232;
}

#conts .mouthpiece .tableContents {
	background-color: #FFF0E0;
	padding: 20px 25px;
}

#conts .mouthpiece .tableContents li {
	border-bottom: 1px dotted #AFAFAF;
	padding: 16px 0;
}

#conts .mouthpiece .tableContents li:first-child {
	padding-top: 0;
}

#conts .mouthpiece .tableContents li:last-child {
	padding-bottom: 0;
	border-bottom: none;
}

#conts .mouthpiece .tableContents li a .headLine02 {
	font-size: 15px;
	line-height: 2;
	text-decoration: underline;
	margin-bottom: 0;
}

@media (max-width: 767px) {
	#conts .mouthpiece .m-width {
		width: 100% !important;
	}

	#conts .mouthpiece .tableContents {
		padding: 20px 18px;
		margin: 0 auto;
		margin-bottom: 38px;
		width: 100%;
	}

	#conts .mouthpiece .tableContents li a .headLine02 {
		font-size: 11px;
		letter-spacing: -0.5px;
	}
}

#conts .mouthpiece .point .comInner {
	padding-bottom: 60px;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .point .bg {
	background: url(../img/mouthpiece/bg.webp) no-repeat center center;
	width: 426px;
	height: 327px;
	padding: 30px 21px;
}

#conts .mouthpiece .point .bg .pointBox {
	background-color: #FFF;
	padding: 0 30px 24px;
}

#conts .mouthpiece .point .bg .pointBox li p {
	padding: 14px 0 14px 0;
	border-bottom: 1px dotted #C4C4C4;
}

#conts .mouthpiece .point .bg .pointBox li p:before {
	content: "";
	background: url(../img/mouthpiece/check01.webp) no-repeat center center;
	background-size: contain;
	width: 25px;
	height: 20px;
	vertical-align: middle;
	padding-right: 30px;
	display: inline-block;
}

@media (max-width: 767px) {
	#conts .mouthpiece .point {
		padding-top: 25px;
		border-top: 1px solid rgba(170, 170, 170, 0.25);
	}

	#conts .mouthpiece .point .textBox {
		width: 100%;
	}

	#conts .mouthpiece .point .bg {
		background: url(../img/mouthpiece/bg_sp.webp) no-repeat center center;
		width: 100%;
		height: 205px;
		padding: 14px 15px;
	}

	#conts .mouthpiece .point .bg .pointBox {
		padding: 0 15px;
	}

	#conts .mouthpiece .point .bg .pointBox li p {
		font-size: 12px;
		padding: 10px 0 !important;
	}

	#conts .mouthpiece .point .bg .pointBox li p:before {
		width: 14px;
		height: 12px;
		padding-right: 26px;
	}
}

@media (max-width: 767px) {
	#conts .mouthpiece .invisaline .headLine02 {
		margin-bottom: 30px !important;
	}
}

#conts .mouthpiece .invisaline .flexBox li {
	display: flex;
	align-items: center;
	justify-content: center;
}

#conts .mouthpiece .invisaline .flexBox li .photoBox {
	margin-right: 18px;
}

@media (max-width: 767px) {
	#conts .mouthpiece .invisaline .flexBox li {
		flex-direction: column;
	}

	#conts .mouthpiece .invisaline .flexBox li .photoBox {
		margin-bottom: 34px;
		margin-right: 0;
	}
}

#conts .mouthpiece .invisaline .headLine02 {
	margin-top: 50px;
	margin-bottom: 68px;
}

#conts .mouthpiece .invisaline .comInner {
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

@media (max-width: 767px) {
	#conts .mouthpiece .invisaline .comInner {
		margin-bottom: 70px;
	}
}

#conts .mouthpiece .invisaline .comInner .feature li h5 {
	color: #EE7173;
	font-weight: bold;
	margin-bottom: 24px;
}

@media(max-width:767px) {
	#conts .mouthpiece .invisaline .comInner .feature li h5 {
		font-size: 13px;
	}
}

#conts .mouthpiece .invisaline .comInner .feature li p {
	padding-bottom: 36px;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
	margin-bottom: 50px;
}

#conts .mouthpiece .invisaline .comInner .feature li:last-child p {
	border-bottom: none;
}

@media (max-width: 767px) {
	#conts .mouthpiece .invisaline .comInner .feature li p {
		margin-bottom: 40px;
		font-size: 12px;
	}

	#conts .mouthpiece .invisaline .comInner .feature li:last-child p {
		margin-bottom: 0;
	}
}

#conts .mouthpiece .strong {
	margin-bottom: 60px;
}

#conts .mouthpiece .strong .flexBox li {
	display: flex;
	align-items: center;
	justify-content: center;
	padding: 60px 0;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .strong .flexBox li:first-child {
	padding-top: 0;
}

#conts .mouthpiece .strong .flexBox li .photoBox {
	margin-right: 18px;
}

#conts .mouthpiece .strong .flexBox li .textBox .headLine04 {
	font-size: 19px;
	background: linear-gradient(transparent 60%, #ff6 60%);
	display: inline-block;
	margin-bottom: 16px;
}

#conts .mouthpiece .strong .flexBox li .textBox p span {
	color: #EE7173;
}

#conts .mouthpiece .strong .flexBox li .textBox .checkPoint {
	margin-top: 24px;
	padding: 0 78px;
	display: flex;
	flex-direction: column;
	align-items: flex-start;
}

#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li {
	padding: 18px 0;
	border-bottom: 1px dashed rgba(170, 170, 170, 0.25);
	text-align: left;
}

#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li p {
	padding-left: 36px;
	position: relative;
}

#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li p:before {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	background: url(../img/mouthpiece/check01.webp) no-repeat center center;
	background-size: contain;
	content: "";
	width: 25px;
	height: 22px;
	padding-right: 0;
	vertical-align: middle;
	display: inline-block;
}

@media (max-width: 767px) {
	#conts .mouthpiece .strong .flexBox li {
		flex-direction: column;
		padding: 40px 0 45px;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .head__wrap {
		margin: 36px auto 24px;
		display: flex;
		justify-content: center;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .head__wrap h4 {
		font-size: 13px;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .head__wrap h4 span {
		margin: 0 auto;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .checkPoint {
		align-items: center;
		padding: 0;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li {
		display: flex;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li p {
		padding-left: 24px;
	}

	#conts .mouthpiece .strong .flexBox li .textBox .checkPoint li p::before {
		width: 14px;
		height: 12px;
		padding-right: 0;
	}
}

#conts .mouthpiece .dentition {
	margin-bottom: 60px;
}

#conts .mouthpiece .dentition .flexBox li {
	display: flex;
	justify-content: center;
	padding: 60px 0;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .dentition .flexBox li:first-child {
	padding-top: 0;
}

#conts .mouthpiece .dentition .flexBox li .photoBox {
	margin-right: 18px;
}

#conts .mouthpiece .dentition .flexBox li .textBox .headLine04 {
	font-size: 19px;
	display: inline-block;
	margin-bottom: 16px;
}

#conts .mouthpiece .dentition .flexBox li .textBox p span {
	color: #EE7173;
}

#conts .mouthpiece .dentition .flexBox li .textBox .checkPoint {
	margin-top: 24px;
	padding: 0 78px;
}

#conts .mouthpiece .dentition .flexBox li .textBox .checkPoint li {
	padding: 18px 0;
	border-bottom: 1px dashed rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .dentition .flexBox li .textBox .checkPoint li p:before {
	background: url(../img/mouthpiece/check01.png) no-repeat center center;
	background-size: contain;
	content: "";
	width: 25px;
	height: 22px;
	vertical-align: middle;
	display: inline-block;
}

@media (max-width: 767px) {
	#conts .mouthpiece .dentition .flexBox li {
		flex-direction: column;
		padding: 30px 0 40px;
	}

	#conts .mouthpiece .dentition .flexBox li .photoBox {
		margin-bottom: 28px;
		margin-right: 0;
	}

	#conts .mouthpiece .dentition .flexBox li .textBox .headLine04 {
		font-size: 13px;
	}
}

#conts .mouthpiece .flow {
	margin-bottom: 60px;
}

@media (max-width: 767px) {
	#conts .mouthpiece .flow {
		margin-bottom: 34px;
	}
}

#conts .mouthpiece .flow .flowBox {
	padding-bottom: 60px;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .flow .flowBox li {
	display: flex;
	flex-direction: column;
	align-items: center;
	justify-content: center;
	border: 1px solid rgba(170, 170, 170, 0.25);
	padding: 0 28px;
	counter-increment: title;
}

#conts .mouthpiece .flow .flowBox li .headLine05 {
	width: 100%;
	font-size: 19px;
	font-weight: bold;
	padding: 40px 0 30px;
	text-align: center;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .flow .flowBox li .headLine05::before {
	color: #F57173;
	content: counter(title);
	display: inline-block;
	width: 30px;
	height: 24px;
	padding: 2px 4px;
	text-align: center;
	border: 3px solid #FFEBEB;
	border-radius: 20%;
	margin-right: 12px;
}

#conts .mouthpiece .flow .flowBox li p {
	padding: 24px 0;
}

#conts .mouthpiece .flow .flowBox img {
	display: block;
	margin: 12px auto;
}

@media (max-width: 767px) {
	#conts .mouthpiece .flow .flowBox {
		padding-bottom: 35px;
	}

	#conts .mouthpiece .flow .flowBox li .headLine05 {
		padding: 20px 0;
		font-size: 13px;
	}

	#conts .mouthpiece .flow .flowBox li .headLine05:before {
		width: 23px;
		height: 18px;
	}

	#conts .mouthpiece .flow .flowBox li p {
		padding: 20px 0 16px;
	}

	#conts .mouthpiece .flow .flowBox img {
		width: 15px;
		height: 15px;
	}
}

#conts .mouthpiece .faq {
	margin-bottom: 60px;
}

#conts .mouthpiece .faq .faqList li dl {
	padding-top: 56px;
	padding-bottom: 46px;
	border-bottom: 1px solid rgba(170, 170, 170, 0.25);
}

#conts .mouthpiece .faq .faqList li dl dt {
	font-weight: bold;
	position: relative;
	padding-left: 42px;
	line-height: 30px;
	margin-bottom: 24px;
	font-size: 19px;
}

#conts .mouthpiece .faq .faqList li dl dt::before {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	content: "Q";
	vertical-align: super;
	width: 30px;
	height: 30px;
	color: #FFF;
	background-color: #F57173;
	border-radius: 50%;
	text-align: center;
}

#conts .mouthpiece .faq .faqList li:nth-child(4) dd {
	padding-bottom: 46px;
}

#conts .mouthpiece .faq .faqList li:first-child dl {
	padding-top: 0;
}

#conts .mouthpiece .faq .faqList li .linkBtn {
	width: 280px;
	height: 45px;
	position: relative;
	background-color: #F57173;
	margin: 0 auto;
}

#conts .mouthpiece .faq .faqList li .linkBtn a {
	width: 100%;
	height: 100%;
	color: #FFF;
	display: flex;
	align-items: center;
	justify-content: center;
}

#conts .mouthpiece .faq .faqList li .linkBtn img {
	position: absolute;
	top: 50%;
	right: 16px;
	transform: translateY(-50%);
	width: 5px;
	height: 10px;
}

#conts .mouthpiece .faq .faqList li p span {
	color: #F57173;
}

@media (max-width: 767px) {
	#conts .mouthpiece .faq .faqList li dl {
		padding: 30px 25px;
	}

	#conts .mouthpiece .faq .faqList li dl dt {
		font-size: 13px;
		line-height: 20px;
	}

	#conts .mouthpiece .faq .faqList li dl dt::before {
		width: 20px;
		height: 20px;
	}

	#conts .mouthpiece .faq .faqList li .linkBtn {
		width: 225px;
		height: 36px;
	}

	#conts .mouthpiece .faq .faqList li:nth-child(4) dd {
		padding-bottom: 23px;
	}
}

#conts .mouthpiece .caution .headLine01 {
	margin-bottom: 34px;
}

#conts .mouthpiece .caution .cautionBox li p {
	position: relative;
	padding-left: 45px;
	border-bottom: 1px dotted #AFAFAF;
	line-height: 3rem;
}

#conts .mouthpiece .caution .cautionBox li p::before {
	position: absolute;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	content: "";
	display: inline-block;
	background: url(../img/mouthpiece/check01.webp) no-repeat center center;
	background-size: contain;
	width: 25px;
	height: 22px;
}

@media (max-width: 767px) {
	#conts .mouthpiece .caution {
		margin-bottom: 90px;
	}

	#conts .mouthpiece .caution .cautionBox li {
		padding: 8px 0 10px;
		border-bottom: 1px solid rgba(170, 170, 170, 0.25);
	}

	#conts .mouthpiece .caution .cautionBox li p {
		line-height: 1rem;
		border-bottom: none;
		padding-left: 22px;
		letter-spacing: -0.2px;
	}

	#conts .mouthpiece .caution .cautionBox li p::before {
		width: 14px;
		height: 12px;
	}
}

/* マウスピース矯正 end */




.typeBox {
	width: 100%;
	margin: 40px 0;
	padding: 24px;
	border: 1px solid rgba(170, 170, 170, 0.25);
}

.typeBoxUl:not(.flexBox) {
	margin-top: 24px;
}

.typeBoxUl li:not(.flexBox li)  {
	position: relative;
	padding: 8px 0 8px 32px;
}

.typeBoxUl li::before {
	content: "・";
	position: absolute;
	color: #EE7173;
	font-size: 25px;
	left: 0;
	top: 0;
}

.typeBoxTtl {
	color: #EE7173;
    font-weight: bold;
    margin-bottom: 24px;
}

.txtSmall {
	margin-top: 16px;
	font-size: 13px;
}

.typeBoxItem {
	margin-bottom: 16px;
	display: flex;
    align-items: center;
}

.typeBoxItem span {
	display: inline-block;
	color: #EE7173;
	font-size: 25px;
	margin: 2px 8px 0 0;
}

.mb16 {
	margin-bottom: 16px;
}

.typeBox02 {
	width: 100%;
	margin: 24px 0;
	padding: 16px 0 0 16px;
	border: 1px solid rgba(170, 170, 170, 0.25);
}




@media all and (min-width: 0) and (max-width: 767px) {

	.typeBox02 {
		padding: 8px 0 8px 16px;
	}

	.typeBoxItem {
		padding: 0;
		margin-bottom: 0;
	}

	.typeBoxItem span {
		margin: 2px 0 0 0;
	}
}