@charset "UTF-8";
.healthcare {
	position: relative;
	font-family: "Noto Sans JP", serif;
	font-feature-settings: "palt";
	color: #000;
}
.healthcare * {
	box-sizing: border-box;
}
.healthcare_faq .img, 
.healthcare_faq figure {
	text-align: center;
	line-height: 0;
}




.healthcare .hero {
	position: relative;
	background: url("healthcare_bg01.png") repeat-x center center / 100% auto;
}
.healthcare .hero::after {
	content: "";
	position: absolute;
	left: 0;
	right: 0;
	bottom: 0;
	width: 100%;
	height: 83px;
	margin: auto;
	background: url("healthcare_bg02.png") repeat-x center center / 1400px 83px;
	display: block;
}
.healthcare .hero_inner {
	padding: 55px 20px 120px;
	text-align: center;
}
.healthcare .hero h1 {
	text-align: center;
}
.healthcare .outline {
	padding: 26px 20px 0;
	background: url("healthcare_bg03.png") repeat-x center top / 1px 738px;
}
.healthcare .outline_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .movie {
	max-width: 600px;
	margin: 0 auto 80px;
	text-align: center;
}
.healthcare .movie iframe {
	width: 100%;
	height: 100%;
	aspect-ratio: 200 / 99;
}
.healthcare .outline h2 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 30px;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	color: #FFF;
}
.healthcare .outline h2 b {
	font-size: 150%;
	font-weight: 700;
}
.healthcare .outline .heart_line {
	margin-bottom: 40px;
	text-align: center;
	line-height: 0;
}
.healthcare .outline .points {
	margin: 0 calc(25px / 2 * -1);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.healthcare .outline .point {
	width: calc(33.3333% - 25px);
	margin: 0 calc(25px / 2);
	padding: 40px 15px;
	text-align: center;
	background-color: #FFF;
	border-radius: 10px;
}
.healthcare .outline .point03 {
	padding: 25px 15px 40px;
}
.healthcare .outline .point h3 {
	position: relative;
	margin-bottom: 35px;
	padding-left: 55px;
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 20px;
	text-align: center;
	color: #20B799;
	display: inline-block;
	text-align: left;
}
.healthcare .outline .point03 h3 {
	margin-bottom: 25px;
}
.healthcare .outline .point h3::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 50px;
	height: 48px;
	margin: auto 0;
	background-repeat: no-repeat;
	background-position: center center;
	background-size: contain;
	display: block;
}
.healthcare .outline .point01 h3::before {
	background-image: url("healthcare_ico01.png");
}
.healthcare .outline .point02 h3::before {
	background-image: url("healthcare_ico02.png");
}
.healthcare .outline .point03 h3::before {
	background-image: url("healthcare_ico03.png");
}
.healthcare .outline .point figure {
	margin-bottom: 10px;
	text-align: center;
}
.healthcare .outline .point .txt {
	max-width: 255px;
	margin-left: auto;
	margin-right: auto;
	font-size: 18px;
	text-align: left;
	line-height: 1.78;
}
.healthcare .outline .point .notes {
	padding-left: 1.0em;
	text-indent: -1.0em;
	display: block;
}
.healthcare .outline .point .notes2 {
	padding-left: 2.5em;
	text-indent: -2.5em;
	display: block;
}

.healthcare .faq {
	padding: 90px 20px 80px;
}
.healthcare .faq_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;

}
.healthcare .faq h2 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 60px;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	color: #34B49B;
}
.healthcare .faq_pickup {
	margin-top: -1px;
	padding-top: 30px;
	padding-right: 50px;
	padding-bottom: 30px;
	border-top: 1px solid #AFAFAF;
	border-bottom: 1px solid #AFAFAF;



}
.healthcare .faq_pickup dt {
	position: relative;
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 15px;
	padding-left: 66px;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.5;

}
.healthcare .faq_pickup dt::before {
	content: "";
	position: absolute;
	top: 0;
	left: 12px;
	width: 41px;
	height: 39px;
	background: url("faq_ico06.png") no-repeat center center / contain;
}

.healthcare .faq_pickup dd {
	padding-left: 66px;
	font-size: 14px;
	line-height: 1.78;
}
.healthcare .faq_btn {
	margin-top: 80px;
	max-width: 455px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .faq_btn a {
	padding: 20px 10px;
	text-align: center;
	color: #FFF;
	background-color: #F76085;
	border-radius: 5px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare .faq_btn a:hover {
	padding-left: 15px;
	padding-right: 5px;
}
.healthcare .faq_btn span {
	position: relative;
	padding-right: 30px;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.4;
	display: inline-block;
}
.healthcare .faq_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 20px;
	height: 20px;
	margin: auto;
	background: url("faq_ico11.png") no-repeat center center / contain;
	display: block;
}
.healthcare .bg_pic {
	text-align: center;
}

.healthcare .merit {
	padding: 60px 20px 40px;
}
.healthcare .merit_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .merit h2 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 60px;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	color: #34B49B;
}
.healthcare .merit .points {
	margin: 0 calc(25px / 2 * -1);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.healthcare .merit .point {
	width: calc(33.3333% - 25px);
	margin: 0 calc(25px / 2);
	padding: 1px 15px 20px;
	text-align: center;
	background-color: #2DB698;
	border-radius: 10px;
}
.healthcare .merit .point .label {
	margin-top: -20px;
	margin-bottom: 15px;
	line-height: 0;
}
.healthcare .merit .point h3 {
	margin-bottom: 20px;
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 22px;
	font-weight: 700;
	text-align: center;
	color: #FFF;
}
.healthcare .merit .point figure {
	margin-bottom: 15px;
}
.healthcare .merit .point h4 {
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 17px;
	font-weight: 900;
	text-align: left;
	line-height: 1.23;
	color: #FFF;
}
.healthcare .merit .point .balloon {
	text-align: center;
	line-height: 0;
}
.healthcare .merit .point .txt {
	margin-top: 10px;
	font-size: 14px;
	text-align: left;
	line-height: 1.57;
	color: #FFF;
}
.healthcare .merit .point .notes {
	padding-left: 1.0em;
	text-indent: -1.0em;
	display: block;
}
.healthcare .merit .point .notes a,
.healthcare .merit .point .notes a:visited, 
.healthcare .merit .point .notes a:focus,
.healthcare .merit .point .notes a:active {
	color: #FFFFFF;
	font-weight: bold;
	text-decoration: underline;
}
.healthcare .merit .point .notes a:hover {
	text-decoration: none;
}
.healthcare .online_box {
	margin-top: 45px;
	padding: 35px 50px;
	text-align: center;
	border: 1px solid #AFAFAF;
	border-radius: 10px;
}
.healthcare .doctor_img {
	margin-bottom: 20px;
}
.healthcare .prices {
	margin-bottom: 30px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.healthcare .online_box .txt {
	text-align: left;
}
.healthcare .online_box .txt .notes {
	padding-left: 1.0em;
	text-indent: -1.0em;
	display: block;
}
.healthcare .plan {
	padding: 30px 20px 80px;
}
.healthcare .plan_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .plan h2 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 60px;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	color: #34B49B;
}

.healthcare .plan .monthly_box {
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 60px;
	padding: 1px 15px 20px;
	text-align: center;
	border: 1px solid #AFAFAF;
}
.healthcare .plan .monthly_box h3 {
	margin-top: -15px;
	margin-bottom: 25px;
	text-align: center;
	line-height: 1.2;
}
.healthcare .plan .monthly_box h3 span {
	padding-left: 15px;
	padding-right: 15px;
	font-size: 20px;
	font-weight: 700;
	display: inline-block;
	background-color: #FFF;
}
.healthcare .plan .plan_list {
	text-align: center;
}
.healthcare .family {
	padding: 70px 20px 80px;
	background: url("healthcare_bg05.png") no-repeat center center / cover;
}
.healthcare .family_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .family .family_box {
	max-width: 450px;
	margin-left: auto;
	margin-right: auto;
	padding: 30px 20px 35px;
	background-color: rgba(45,182,151,0.9);
	border-radius: 10px;
}
.healthcare .family h2 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 20px;
	font-size: 24px;
	font-weight: 700;
	text-align: center;
	line-height: 1.2;
	color: #FFF;
}
.healthcare .family .family_btn {
	max-width: 195px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .family .family_btn a {
	padding: 10px 10px;
	text-align: center;
	color: #000;
	background-color: #F0F0F0;
	border-radius: 30px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare .family .family_btn a:hover {
	padding-left: 15px;
	padding-right: 5px;
}
.healthcare .family .family_btn span {
	position: relative;
	padding-right: 20px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.4;
	letter-spacing: 2px;
	display: inline-block;
}
.healthcare .family .family_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 8px;
	height: 13px;
	margin: auto;
	background: url("healthcare_ico07.png") no-repeat center center / contain;
	display: block;
}
.healthcare .terms_btn {
	max-width: 325px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .terms_btn a {
	padding: 15px 10px;
	text-align: center;
	color: #000;
	background-color: #E2E2E2;
	border-radius: 50px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare .terms_btn a:hover {
	padding-left: 15px;
	padding-right: 5px;
}
.healthcare .terms_btn span {
	position: relative;
	padding-right: 30px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.4;
	display: inline-block;
}
.healthcare .terms_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 19px;
	height: 19px;
	margin: auto;
	background: url("healthcare_ico08.png") no-repeat center center / contain;
	display: block;
}

.healthcare .terms {
	padding: 60px 20px;
}
.healthcare .terms_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .terms .privacy_box {
	max-width: 845px;
	margin-top: 70px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 45px;
	padding: 1px 15px 30px;
	text-align: center;
	border: 1px solid #AFAFAF;
}
.healthcare .terms .privacy_box h3 {
	margin-top: -20px;
	margin-bottom: 30px;
	text-align: center;
	line-height: 1.2;
}
.healthcare .terms .privacy_box h3 span {
	padding-left: 15px;
	padding-right: 15px;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 2px;
	display: inline-block;
	background-color: #FFF;
}
.healthcare .terms .privacy_box .txt {
	margin-bottom: 20px;
	font-size: 14px;
	font-weight: 400;
}
.healthcare .terms .law_btn {
	max-width: 425px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .terms .law_btn a {
	
	padding: 20px 10px;
	font-size: 18px;
	font-weight: 500;
	text-decoration: none;
	text-align: center;
	color: #000;
	border: 1px solid #C6C6C6;
	display: block;

}
.healthcare .terms .law_btn a:hover {
	background-color: #E2E2E2;
}

@media screen and (max-width: 767px) {
.healthcare .hero {
	background-image: url("healthcare_bg01_sp.png");
}
.healthcare .hero::after {
	height: 64px;
	background-image: url("healthcare_bg02_sp.png");
	background-size: 375px 64px;
}
.healthcare .hero_inner {
	padding: 90px 35px;
}
.healthcare .outline {
	padding: 30px 20px 0;
	background-size: 1px 738px;
}
.healthcare .movie {
	margin: 0 auto 50px;
}
.healthcare .movie iframe {
	width: 100%;
	height: 100%;
	aspect-ratio: 200 / 99;
}
.healthcare .outline h2 {
	margin-bottom: 20px;
	font-size: 20px;
}
.healthcare .outline h2 b {
	font-size: 150%;
	font-weight: 700;
}
.healthcare .outline .heart_line {
	max-width: calc(174px * 0.75);
	margin: 0 auto 30px;
}
.healthcare .outline .points {
	margin: 0 10px;
	display: block;
}
.healthcare .outline .point {
	width: 100%;
	margin: 0;
	padding: 20px 10px;
}
.healthcare .outline .point h3 {
	margin-bottom: 20px;
	padding-left: calc(55px * 0.6);
	font-size: 17px;
}
.healthcare .outline .point h3::before {
	width: calc(50px * 0.6);
	height: calc(48px * 0.6);
}
.healthcare .outline .point figure {
	margin-bottom: 10px;
}
.healthcare .outline .point .txt {
	font-size: 15px;
	line-height: 1.53;
}

.healthcare .faq {
	padding: 80px 20px 60px;
}
.healthcare .faq h2 {
	margin-bottom: 30px;
	font-size: 22px;
}
.healthcare .faq_pickup {
	margin-top: -1px;
	padding-top: 10px;
	padding-right: 0;
	padding-bottom: 10px;
	border-top: 1px solid #C1C1C1;
	border-bottom: 1px solid #C1C1C1;



}
.healthcare .faq_pickup dt {
	margin-bottom: 5px;
	padding-left: calc(66px * 0.6);
	font-size: 15px;
}
.healthcare .faq_pickup dt::before {
	left: 5px;
	width: calc(41px * 0.6);
	height: calc(39px * 0.6);
}
.healthcare .faq_pickup dd {
	padding-left: calc(66px * 0.6);
	font-size: 12px;
	line-height: 1.78;
}
.healthcare .faq_btn {
	margin-top: 40px;
	max-width: 320px;
}
.healthcare .faq_btn a {
	padding-top: 15px;
	padding-bottom: 15px;
}
.healthcare .faq_btn span {
	padding-right: calc(30px * 0.75);
	font-size: 14px;
}
.healthcare .faq_btn span::before {
	width: calc(20px * 0.75);
	height: calc(20px * 0.75);
}
.healthcare .bg_pic {
	text-align: center;
}

.healthcare .merit {
	padding: 40px 20px 25px;
}
.healthcare .merit h2 {
	margin-bottom: 40px;
	font-size: 20px;
}
.healthcare .merit .points {
	margin: 0;
	display: block;
}
.healthcare .merit .point {
	width: 100%;
	margin: 0;
	padding: 1px 15px 30px;
}
.healthcare .merit .point + .point {
	margin-top: 30px;
}
.healthcare .merit .point .label {
	width: calc(54px * 0.75);
	margin-top: -15px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
	line-height: 0;
}
.healthcare .merit .point h3 {
	margin-bottom: 15px;
	font-size: 17px;
}
.healthcare .merit .point figure {
	margin-bottom: 15px;
}
.healthcare .merit .point h4 {
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
	font-size: 16px;
	line-height: 1.4;
}
.healthcare .merit .point .balloon {
	text-align: center;
	line-height: 0;
}
.healthcare .merit .point .txt {
	max-width: 280px;
	margin-top: 10px;
	margin-left: auto;
	margin-right: auto;
	font-size: 12px;
	text-align: left;
	line-height: 1.57;
	color: #FFF;
}
.healthcare .merit .point .notes {
	padding-left: 1.0em;
	text-indent: -1.0em;
	display: block;
}

.healthcare .online_box {
	margin-top: 30px;
	padding: 20px 20px;
	text-align: center;
	border: 1px solid #AFAFAF;
	border-radius: 10px;
}
.healthcare .doctor_img {
	max-width: 426px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 5px;
}
.healthcare .prices {
	margin-bottom: 10px;
	display: block;
}
.healthcare .price {
	text-align: center;
}
.healthcare .price + .price {
	margin-top: 10px;
}
.healthcare .online_box .txt {
	max-width: 426px;
	margin-left: auto;
	margin-right: auto;
	font-size: 12px;
}
.healthcare .plan {
	padding: 25px 20px 60px;
}
.healthcare .plan h2 {
	margin-bottom: 40px;
	font-size: 20px;
}

.healthcare .plan .monthly_box {
	margin-bottom: 30px;
	padding: 1px 20px 15px;
}
.healthcare .plan .monthly_box h3 {
	margin-top: -15px;
	margin-bottom: 15px;
}
.healthcare .plan .monthly_box h3 span {
	padding-left: 5px;
	padding-right: 5px;
	font-size: 18px;
}
.healthcare .plan .monthly_box figure {
	max-width: calc(519px * 0.5);
	margin-left: auto;
	margin-right: auto;
}
.healthcare .plan .plan_list figure {
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .family {
	padding: 50px 40px 50px;
}
.healthcare .family .family_box {
	padding: 20px;
}
.healthcare .family h2 {
	margin-bottom: 15px;
	font-size: 18px;
}
.healthcare .family .family_btn {
	max-width: 180px;
}
.healthcare .family .family_btn a {
	padding: 8px 10px;
}
.healthcare .family .family_btn span {
	padding-right: calc(20px * 0.8);
	font-size: 14px;
}
.healthcare .family .family_btn span::before {
	width: calc(8px * 0.8);
	height: calc(13px * 0.8);
}
.healthcare .terms_btn {
	max-width: 280px;
}
.healthcare .terms_btn a {
	padding: 10px 10px;
}
.healthcare .terms_btn span {
	padding-right: calc(30px * 0.75);
	font-size: 14px;
}
.healthcare .terms_btn span::before {
	width: calc(19px * 0.75);
	height: calc(19px * 0.75);
}
.healthcare .terms {
	padding: 40px 20px 60px;
}
.healthcare .terms_inner {
	max-width: 980px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare .terms .privacy_box {
	max-width: 845px;
	margin-top: 60px;
	margin-bottom: 30px;
	padding: 1px 15px 25px;
	text-align: center;
	border: 1px solid #AFAFAF;
}
.healthcare .terms .privacy_box h3 {
	margin-top: -20px;
	margin-bottom: 20px;
}
.healthcare .terms .privacy_box h3 span {
	padding-left: 5px;
	padding-right: 5px;
	font-size: 20px;
	font-weight: 500;
	letter-spacing: 2px;
	display: inline-block;
	background-color: #FFF;
}
.healthcare .terms .privacy_box .txt {
	margin-bottom: 15px;
	font-size: 13px;
}
.healthcare .terms .law_btn {
	max-width: inherit;
}
.healthcare .terms .law_btn a {
	padding: 10px 10px;
	font-size: 16px;
}
}

/* フローティングバナー */
.main_inner.full_width > * {
	-webkit-transform: none;
}
.healthcare .floating {
	position: fixed;
	left: 0;
	right: 0;
	bottom: 0;
	background-color: #FFF;
	transition: 0.5s;
	z-index: 10;
}
.healthcare .floating dl {
	padding: 15px 20px 10px;
  	display: -webkit-box;
  	display: -ms-flexbox;
  	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.healthcare .floating dt, 
.healthcare .floating dd {
	line-height: 0;
	margin: 0 10px;
}

.healthcare .floating a {
	position: relative;
	display: block;
}
.healthcare .is_hidden {
	visibility: hidden;
	opacity: 0;
}

@media screen and (max-width: 767px) {
.healthcare .floating {
	left: 0;
	right: 0;
	bottom: 0;
}
.healthcare .floating dl {
	max-width: 375px;
	margin-left: auto;
	margin-right: auto;
	padding: 15px 20px;
  	-ms-flex-wrap: wrap;
  	flex-wrap: wrap;
}
.healthcare .floating dl.pre {
	max-width: auto;
}
.healthcare .floating dl::after {
	content: "";
	width: 100%;
	height: 1;
	display: block;
}
.healthcare .floating dt {
	width: 100%;
	margin: 0 auto 15px;
	padding-left: 70px;
	padding-right: 70px;
	text-align: center;
}
.healthcare .floating dd {
	width: calc(50% - 40px);
	margin: 0 20px;
}
.healthcare .floating .pre dd {
	width: calc(100% - 40px);
	margin: 20px 0;
	text-align: center;
}

.healthcare .is_hidden {
	visibility: hidden;
	opacity: 0;
}
}

/* よくあるご質問 */
.healthcare_faq {
	margin-top: 50px;
	margin-bottom: 70px;
	font-family: "Noto Sans JP", serif;
	font-feature-settings: "palt";
	color: #000;
}
.healthcare_faq * {
	box-sizing: border-box;
}
.healthcare_faq h1 {
	text-align: center;
}
.healthcare_faq h2 {
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 30px;
	font-weight: 700;
	text-align: center;
	color: #34b49b;
	margin-top: 10px;
}
.healthcare_faq .img, 
.healthcare_faq figure {
	text-align: center;
	line-height: 0;
}
.healthcare_faq .inner {
	max-width: 1020px;
	margin: 0 auto;
	padding: 0 20px;
}
.healthcare_faq .faq_row {
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	justify-content: space-between;
}
.healthcare_faq .faq_col {
	width: calc(50% - 10px);
}
.healthcare_faq .faq_col h3 {
	margin-top: 60px;
	margin-bottom: 40px;
	padding: 10px 10px;
	border: 1px solid #C6C6C6;
	border-radius: 10px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	-webkit-box-pack: center;
	-ms-flex-pack: center;
	justify-content: center;
	-webkit-box-align: center;
	-ms-flex-align: center;
	align-items: center;
}
.healthcare_faq .faq_col h3 span {
	margin-right: 15px;
	line-height: 0;
}
.healthcare_faq .faq_col h3 em {
	font-size: 22px;
	font-weight: 700;
	line-height: 1.2;
}
.healthcare_faq .acdn-title {
	position: relative;
	margin-top: 30px;
	padding-left: 40px;
	padding-right: 25px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.75;
	transition: ease-in-out .5s;
    cursor: pointer;
}
.healthcare_faq .acdn-title::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	width: 31px;
	height: 30px;
	background: url("faq_ico06.png") no-repeat center center / contain;
	border-radius: 50%;
}
.healthcare_faq .acdn-title span {
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 19px;
	height: 19px;
	margin: auto 0;
}
.healthcare_faq .acdn-title span:before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	width: 19px;
	height: 19px;
	background: url("faq_ico07.png") no-repeat center center / contain;
}
.healthcare_faq .acdn-title span.active:before {
	background-image: url("faq_ico08.png");
}
.healthcare_faq .acdn-content-wp, 
.healthcare_faq .acdn-content {
	display: none;
}
.healthcare_faq .acdn-content {
	margin-top: 15px;
	margin-bottom: 50px;
	padding-left: 10px;
	font-size: 13px;
	font-weight: 400;
	line-height: 1.76;
}
.healthcare_faq .acdn-title-wp {
	width: 145px;
	margin-top: 50px;
	margin-left: auto;
	margin-right: auto;
	text-align: center;
	background-color: #F0F0F0;
	transition: ease-in-out .5s;
    cursor: pointer;
}
.healthcare_faq .acdn-title-wp .more {
	position: relative;
	padding: 10px 10px;
	text-align: center;
	padding-left: 35px;
	font-size: 14px;
	font-weight: 500;
	color: #000;
	display: inline-block;
}
.healthcare_faq .acdn-title-wp .more::before {
	content: "";
	position: absolute;
	top: 0;
	left: 10px;
	bottom: 0;
	width: 19px;
	height: 19px;
	margin: auto 0;
	background: url("faq_ico09.png") no-repeat center center / contain;
	display: block;
}
.healthcare_faq .acdn-title-wp .more.active::before {
	background-image: url("faq_ico10.png");
}
.healthcare_faq .acdn-title-wp .more::after {
	content: "さらに確認する"
}
.healthcare_faq .acdn-title-wp .more.active::after {
	content: "閉じる"
}
.healthcare_faq .contact_btn {
	margin-top: 100px;
	max-width: 520px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare_faq .contact_btn a {
	padding: 20px 10px;
	text-align: center;
	color: #FFF;
	background-color: #F76085;
	border-radius: 5px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare_faq .contact_btn a:hover {
	padding-left: 15px;
	padding-right: 5px;
}
.healthcare_faq .contact_btn span {
	position: relative;
	padding-right: 30px;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.4;
	display: inline-block;
}
.healthcare_faq .contact_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	right: 0;
	bottom: 0;
	width: 20px;
	height: 20px;
	margin: auto;
	background: url("faq_ico11.png") no-repeat center center / contain;
	display: block;
}
.healthcare_faq .return_btn {
	margin-top: 60px;
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare_faq .return_btn a {
	padding: 15px 10px;
	text-align: center;
	color: #000;
	background-color: #F0F0F0;
	border-radius: 5px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare_faq .return_btn a:hover {
	padding-left: 5px;
	padding-right: 15px;
}
.healthcare_faq .return_btn span {
	position: relative;
	padding-left: 15px;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.4;
	display: inline-block;
}
.healthcare_faq .return_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 6px;
	height: 10px;
	margin: auto;
	background: url("faq_ico12.png") no-repeat center center / contain;
	display: block;
}

@media screen and (max-width: 767px) {
.healthcare_faq {
	margin-top: 30px;
	margin-bottom: 60px;
}
.healthcare_faq h1 {
	max-width: calc(518px * 0.55);
	margin-left: auto;
	margin-right: auto;
}
.healthcare_faq h2 {
	font-size: 22px;
}
.healthcare_faq .faq_row {
	display: block;
}
.healthcare_faq .faq_col {
	width: 100%;
}
.healthcare_faq .faq_col h3 {
	margin-top: 40px;
	margin-bottom: 20px;
	padding: 8px 5px;
}
.healthcare_faq .faq_col h3 .logo {
	max-width: calc(225px * 0.75);
	margin-right: 10px;
}
.healthcare_faq .faq_col h3 .ico {
	max-width: calc(57px * 0.75);
	margin-right: 10px;
}
.healthcare_faq .faq_col h3 em {
	font-size: 18px;
}
.healthcare_faq .acdn-title {
	position: relative;
	margin-top: 20px;
	padding-left: 30px;
	padding-right: 25px;
	font-size: 15px;
}
.healthcare_faq .acdn-title::before {
	top: 5px;
	width: calc(31px * 0.75);
	height: calc(30px * 0.75);
}

.healthcare_faq .acdn-content {
	margin-top: 15px;
	margin-bottom: 40px;
	font-size: 13px;
}
.healthcare_faq .acdn-title-wp {
	margin-top: 30px;
	margin-bottom: 60px;
}
.healthcare_faq .contact_btn {
	margin-top: 80px;
	max-width: inherit;
}
.healthcare_faq .contact_btn a {
	padding: 10px 20px;
}
.healthcare_faq .contact_btn span {
	padding-right: 22px;
	font-size: 16px;
}
.healthcare_faq .contact_btn span::before {
	width: calc(20px * 0.75);
	height: calc(20px * 0.75);
}
.healthcare_faq .return_btn {
	margin-top: 40px;
	max-width: 280px;
}
.healthcare_faq .return_btn a {
	padding: 15px 20px;
}
.healthcare_faq .return_btn span {
	padding-left: 15px;
	font-size: 14px;
}
}

@media screen and (max-width: 375px) {
.healthcare_faq .faq_col h3 em {
	font-size: 16px;
}
}


/* メンバーを追加すると */

.healthcare_family {
	margin-top: 50px;
	margin-bottom: 70px;
	font-family: "Noto Sans JP", serif;
	font-feature-settings: "palt";
	color: #000;
}
.healthcare_family * {
	box-sizing: border-box;
}
.healthcare_family h1 {
	text-align: center;
}
.healthcare_family h2 {
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 30px;
	font-weight: 700;
	text-align: center;
	color: #34b49b;
	margin-top: 10px;
}
.healthcare_family .img, 
.healthcare_family figure {
	text-align: center;
	line-height: 0;
}
.healthcare_family .inner {
	max-width: 1020px;
	margin: 0 auto;
	padding: 0 20px;
}


.healthcare_family .abouts {
	margin-top: 60px;
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
	border: 1px solid #C6C6C6;
	border-radius: 10px;
}
.healthcare_family .about {
	position: relative;
	width: 33.33%;
	padding: 25px 0;
	text-align: center;
}
.healthcare_family .about::after {
	content: "";
	position: absolute;
	top: 25px;
	right: -1px;
	bottom: 25px;
	width: 2px;
	background: url("member_line01.png") repeat-y center center / 5px 5px;
}
.healthcare_family .about:last-of-type::after {
	display: none;
}
.healthcare_family .about figure {
	margin-bottom: 10px;
	text-align: center;
}
.healthcare_family .about p {
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 17px;
	font-weight: 700;
	line-height: 1.64;
}
.healthcare_family .about p strong {
	color: #20b799;
}
.healthcare_family .about p.notes {
	font-family: "Zen Kaku Gothic New", serif;
	font-size: 14px;
	font-weight: 500;
	margin-top: 20px;
	line-height: 1.64;
	padding: 0 25px 0 35px;
	text-indent: -1.0em;
	text-align: left;
}


.healthcare_family .steps {
	margin: 70px calc(25px / 2 * -1);
	display: -webkit-box;
	display: -ms-flexbox;
	display: flex;
}
.healthcare_family .step {
	position: relative;
	width: calc(33.3333% - 25px);
	margin: 0 calc(25px / 2);
	padding: 1px 20px 20px; 
	text-align: center;
	background-color: #2DB697;
	border-radius: 10px;


	display: flex;
	flex-flow: column;
	justify-content: space-between;

}
.healthcare_family .step::after {
	content: "";
	position: absolute;
	top: 0;
	right: -16px;
	bottom: 0;
	width: 16px;
	height: 32px;
	margin: auto;
	background: url("member_bg01.png") no-repeat center center / contain;
	display: block;
}
.healthcare_family .step:last-of-type::after {
	display: none;
}

.healthcare_family .step p.label {
	margin-top: -20px;
	margin-bottom: 25px;
	line-height: 0;
	text-align: center;
}
.healthcare_family .step h3 {
	font-family: "Zen Kaku Gothic New", serif;
	margin-bottom: 10px;
	font-size: 19px;
	font-weight: 900;
	color: #FFF;
}
.healthcare_family .step .txt {
	height: 170px;
}
.healthcare_family .step p {
	font-size: 16px;
	text-align: left;
	line-height: 1.375;
	color: #FFF;
}
.healthcare_family .step p.notes {
	margin-top: 10px;
	font-size: 14px;
	text-align: left;
	line-height: 1.42;
	padding-left: 1.0em;
	text-indent: -1.0em;
}
.healthcare_family .step p.notes a,
.healthcare_family .step p.notes a:visited,
.healthcare_family .step p.notes a:focus,
.healthcare_family .step p.notes a:active {
	color: #FFFFFF;
	font-weight: bold;
	text-decoration: underline;
}
.healthcare_family .step p.notes a:hover {
	text-decoration: none;
}
.healthcare_family .step figure {
	margin-top: 20px;
	flex-grow: 1;
	justify-content: start;
}
.healthcare_family .return_btn {
	margin-top: 60px;
	max-width: 280px;
	margin-left: auto;
	margin-right: auto;
}
.healthcare_family .return_btn a {
	padding: 15px 10px;
	text-align: center;
	color: #000;
	background-color: #F0F0F0;
	border-radius: 5px;
	display: block;
	transition: .2s cubic-bezier(0.45, 0, 0.55, 1);
}
.healthcare_family .return_btn a:hover {
	padding-left: 5px;
	padding-right: 15px;
}
.healthcare_family .return_btn span {
	position: relative;
	padding-left: 15px;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.4;
	display: inline-block;
}
.healthcare_family .return_btn span::before {
	content: "";
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	width: 6px;
	height: 10px;
	margin: auto;
	background: url("faq_ico12.png") no-repeat center center / contain;
	display: block;
}
@media screen and (max-width: 767px) {
.healthcare_family {
	margin-top: 30px;
	margin-bottom: 60px;
}
.healthcare_family h1 {
	max-width: calc(518px * 0.55);
	margin-left: auto;
	margin-right: auto;
}
.healthcare_family h2 {
	font-size: 22px;
}

.healthcare_family .abouts {
	margin-top: 40px;
	padding: 0 0 10px;
	display: block;
}
.healthcare_family .about {
	position: relative;
	width: 100%;
	padding: 20px;
	text-align: center;
}
.healthcare_family .about::after {
	top: auto;
	left: 20px;
	right: 20px;
	bottom: 0;
	width: auto;
	height: 2px;
	background-repeat: repeat-x;
}
.healthcare_family .about:last-of-type::after {
	display: none;
}
.healthcare_family .about figure {
	max-width: calc(275px * 0.75);
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 10px;
	text-align: center;
}
.healthcare_family .about p {
	font-family: "Noto Sans JP", serif;
	font-size: 15px;
	line-height: 1.33;
}
.healthcare_family .about p strong {
	font-size: 110%;
}
.healthcare_family .about p.notes {
	padding: 0 15px 0 25px;
}

.healthcare_family .steps {
	margin: 50px 0;
	display: block;
}
.healthcare_family .step {
	width: 100%;
	margin: 0;
	padding: 1px 20px 20px; 
	text-align: center;
	background-color: #2DB697;
	border-radius: 10px;
}
.healthcare_family .step::after {
	top: auto;
	left: 0;
	right: 0;
	bottom: -16px;
	width: 33px;
	height: 16px;
	margin: 0 auto;
	background-image: url("member_bg01_sp.png");
}
.healthcare_family .step:last-of-type::after {
	display: none;
}
.healthcare_family .step + .step {
	margin-top: 50px;
}
.healthcare_family .step p.label {
	max-width: calc(160px * 0.75);
	margin-top: -14px;
	margin-left: auto;
	margin-right: auto;
	margin-bottom: 15px;
	line-height: 0;
	text-align: center;
}
.healthcare_family .step h3 {
	margin-bottom: 10px;
	font-size: 17px;
}
.healthcare_family .step .txt {
	height: auto;
}
.healthcare_family .step p {
	max-width: 320px;
	margin-left: auto;
	margin-right: auto;
	font-size: 16px;
}
.healthcare_family .step p.notes {
	margin-top: 10px;
	font-size: 12px;
}
.healthcare_family .step figure {
	margin-top: 15px;
}
.healthcare_family .step figure img {
	width: 100%;
	max-width: 320px;
	height: auto;
}
.healthcare_family .return_btn {
	margin-top: 40px;
	max-width: 280px;
}
.healthcare_family .return_btn a {
	padding: 15px 20px;
}
.healthcare_family .return_btn span {
	padding-left: 15px;
	font-size: 14px;
}

}




@media print {
  body {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
  .sp_menu_panel,
  .floating,
  .page_top {
    display: none;
  }
}
