@charset "utf-8";

/*コンテンツ
----------------------*/
main > *:first-child{padding-top: 85px;}

/*#inner-title
----------------------*/
#inner-title{
	padding: 120px 0 clamp(130px,10vw,170px);
	background: url("../images/inner_bg.png") center bottom / contain no-repeat,linear-gradient(to bottom,#fff,#ffe1e4);
}
#inner-title > div{
	max-width: 1500px;
	width: 85%;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.page_title > *{line-height: 1em;}
.page_title p{
	font-size: 50px;
	color: #a67c52;
	margin-bottom: 15px;
}
.page_title span{
	font-size: 25px;
	font-weight: lighter;
	background: linear-gradient(to bottom,#e9898a,#fff);
	-webkit-background-clip: text;
	-webkit-text-fill-color: transparent;
}
#pankuzu,#pankuzu li:not(:last-child){display: flex;}
#pankuzu{
	flex-wrap: wrap;
	justify-content: flex-end;
	width: 39%;
}
#pankuzu li,#pankuzu li a{color: #a67c52;}
#pankuzu li:not(:last-child){
	align-items: center;
	margin-right: 15px;
}
#pankuzu li:not(:last-child)::after{
	content: "";
	background: #a67c52;
	width: 15px;
	height: 1px;
	margin-left: 15px;
}
#pankuzu li a{transition: 0.3s;}
#pankuzu li:hover a{opacity: 0.7;}

/*コンテンツ
----------------------*/
/*タイトル
----------------------*/
.s_line_title::before,.s_line_title::after,.b_line_title::after{
	content: '';
	height: 1px;
	background-color: #E9898A;
}

/* s_line_title */
.s_line_title{
	display: flex;
	align-items: center;
	justify-content: center;
	text-align: center;
	color: #D37175;
	font-weight: bold;
}
.s_line_title::before,.s_line_title::after{width: 40px;}
.s_line_title::before{margin-right: 10px;}
.s_line_title::after{margin-left: 10px;}

/* b_line_title */
.b_line_title{
	text-align: center;
	font-weight: bold;
}
.b_line_title::after{
	width: 60px;
	display: block;
	margin: 10px auto 0;
}

/* circle_title */
.circle_title{
	color: #D37175;
	padding-left: 40px;
	position: relative;
}
.circle_title::before{
	content: '';
	width: 60px;
	height: 60px;
	background-color: rgba(255,148,153,0.1);
	border-radius: 50%;
	position: absolute;
	top:  -25px;
	left: 0;
}

/* ボタン
----------------------*/
a.btn_bgp,a.btn_bgb{
	display: block;
	max-width: 360px;
	width: 100%;
	margin: 0 auto;
	font-size: 20px;
	font-weight: bold;
	color: #fff;
	text-align: center;
	padding: 15px 0;
	border-radius: 80px;
	transition: 0.3s;
}
a.btn_bgp{background-color: #E9898A;}
a.btn_bgb{background-color: #E8AB89;}
a.btn_bgp:hover,a.btn_bgb:hover{opacity: 0.8;}
a.btn_bgp.arrow{background: #E9898A url("../images/w_arrow.png") 95% center / 15px 12px no-repeat;}
a.btn_bgb.download_icon{background: #E8AB89 url("../images/download_icon.png") 95% center / 23px 18px no-repeat;}
a.btn_bgp.arrow:hover,a.btn_bgb.download_icon:hover{background-position: 96% center;}
.btn_flex{
	display: flex;
	justify-content: center;
}
.btn_flex.c2{
	max-width: 750px;
	width: 100%;
	margin: 0 auto;
}
.btn_flex a.btn_bgp,.btn_flex a.btn_bgb{margin: inherit;}
.btn_flex > li:not(:last-child){margin-right: 2.5%;}

/* ページ内リンク */
.page_link{
	max-width: 900px;
	width: 100%;
	margin: 0 auto;
}
.page_link li{width: 31%;}
.page_link li a{
	display: block;
	font-size: 18px;
	color: #D37175;
	text-align: center;
	border: 1px #D37175 solid;
	background-color: #fff;
	border-radius: 80px;
	padding: 15px 0;
	transition: 0.3s;
}
.page_link li a:hover{
	background-color: #D37175;
	color: #fff;
}

/* accordion
----------------------*/
.accordion dt{
	display: flex;
	align-items: center;
	position: relative;
	cursor: pointer;
}
.accordion dt::before,.accordion dt::after{
	content: '';
	width: 20px;
	height: 3px;
	background-color: #E9898A;
	position: absolute;
	right: 0;
	margin: 0 auto;
	transition: .5s cubic-bezier(0.2, 1, 0.3, 1);
}
.accordion dt::after{transform: rotate(90deg);}
.accordion dt.active::after{transform: rotate(180deg);}
.accordion dt p,.accordion.faq dd > div{
	width: 100%;
	display: flex;
	align-items: flex-start;
}
.accordion dt p{padding-right: 30px;}
.accordion dd{
	display: none;
	padding-top: 25px;
}
.accordion.faq > div{
	border-bottom: 1px #E9898A dashed;
	padding-bottom: 35px;
}
.accordion.faq > div:not(:last-child){margin-bottom: 35px;}
.accordion.faq dt p::before,.accordion.faq dd > div::before{
	font-size: 30px;
	font-family: "Merriweather";
	color: #C49874;
	line-height: 1;
	flex-shrink: 0;
	margin-right: 20px;
}
.accordion.faq dt p::before{content: 'Q.';}
.accordion.faq dd > div::before{content: 'A.';}

/* side_flower
----------------------*/
.side_flower{
	display: flex;
	align-items: center;
	justify-content: center;
}
.side_flower::before,.side_flower::after{
	content: '';
	width: 64px;
	height: 511px;
	background: url("../images/vertical_decoration.png") no-repeat center / contain;
}
.side_flower::after{transform: scale(-1,-1);}
.w800{
	max-width: 800px;
	width: 100%;
	margin: 0 auto;
}
.side_flower .w800{width: 80%;}

/* お役立ち情報
----------------------*/
.useful_box{
	border: 1px #C49874 solid;
	background-color: rgba(255,255,255,0.3);
	border-radius: 30px;
	padding: 60px 40px;
}
.useful_box > ul{margin-bottom: 45px;}
.useful_box > ul > li{
	border-bottom: 1px #E9898A dashed;
	padding-bottom: 30px;
}
.useful_box > ul > li:not(:last-child){margin-bottom: 30px;}
.useful_box > ul > li a{
	display: flex;
	align-items: flex-start;
	background: url("../images/circle_arrow.png") no-repeat right center / 25px;
}
.useful_box > ul > li a p.fs18{
	width: 100%;
	padding: 0 45px 0 20px;
	transition: 0.3s;
}
.useful_box > ul > li a:hover p.fs18{color: #E9898A;}

/* 料金表
----------------------*/
.fee_box{
	background-color: #fff;
	border-radius: 20px;
	padding: 50px 35px;
}
.fee_con > div{
	display: flex;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	border-bottom: 1px rgba(199,178,153,0.5) solid;
	padding-bottom: 20px;
}
.fee_con > div:not(:last-child){margin-bottom: 35px;}
.fee_con > div dt{
	width: 55%;
	line-height: 1.2;
}
.fee_con > div dt span{font-size: 16px;}
.fee_con > div dd{
	width: 40%;
	text-align: right;
}

/* 料金表(テーブル)
----------------------*/
.fee_table{
	max-width: 750px;
	margin: 0 auto;
}
.fee_table,.fee_table table{width: 100%;}
.fee_table th,.table td{width: 50%;}
.fee_table th{background-color: #FFF3F3;}
.fee_table th,.fee_table td{
	border: 1px #E6E6E6 solid;
	vertical-align: middle;
}
.fee_table th,.fee_table td{padding: 20px;}

/* img_box
----------------------*/
.img_box_l,.img_box_r{
	display: flex;
	align-items: center;
}
.img_box_l > img,.img_box_r > img{
	display: block;
	flex-shrink: 0;
}
.img_box_l > img{margin-right: 70px;}
.img_box_r > img{margin-left: 70px;}
.img_box_l > div{width: 100%;}
.br20{border-radius: 20px;}

/* Prescription
----------------------*/
.side_flower > .w800 ul{
	max-width: 690px;
	width: 100%;
	margin: 0 auto;
}

/* 1025px以下から
------------------------------------------------------------*/
@media only screen and (max-width:1025px){
	
	/*#inner-title
	----------------------*/
	#inner-title{padding: 80px 0 90px;}
	.page_title p{
		font-size: 30px;
		margin-bottom: 10px;
	}
	.page_title span{font-size: 18px;}
	#pankuzu li,#pankuzu li a{font-size: 14px;}
	#pankuzu li:not(:last-child){margin-right: 10px;}
	#pankuzu li:not(:last-child)::after{
		width: 10px;
		margin-left: 10px;
	}
	
	/*コンテンツ
	----------------------*/
	main > *:first-child{padding-top: 55px;}
	
	/* タイトル */
	.s_line_title::before,.s_line_title::after{width: 30px;}
	.circle_title{padding-left: 15px;}
	.circle_title::before{
		width: 40px;
		height: 40px;
		top:  -15px;
	}
	
	/* ボタン */
	a.btn_bgp,a.btn_bgb{
		max-width: 280px;
		font-size: 16px;
		padding: 13px 0;
	}
	a.btn_bgb.download_icon{background-size: 18px auto;}
	.btn_flex.c2{max-width: 570px;}
	.btn_flex > li:not(:last-child){margin-right: 1.5%;}
	
	/* ページ内リンク */
	.page_link li a{
		font-size: 16px;
		padding: 10px 0;
	}
	
	/* accordion */
	.accordion dt::before,.accordion dt::after{
		width: 15px;
		height: 2px;
	}
	.accordion dt p{padding-right: 25px;}
	.accordion.faq > div{padding-bottom: 25px;}
	.accordion.faq > div:not(:last-child){margin-bottom: 25px;}
	.accordion.faq dt p::before,.accordion.faq dd > div::before{
		font-size: 25px;
		margin-right: 10px;
	}
	.accordion.faq dd{padding: 15px 0 10px;}
	
	/* side_flower */
	.side_flower::before,.side_flower::after{
		width: 40px;
		height: 319px;
	}
	
	/* お役立ち情報 */
	.useful_box{
		border-radius: 20px;
		padding: 45px 30px;
	}
	.useful_box > ul{margin-bottom: 30px;}
	.useful_box > ul > li{padding-bottom: 25px;}
	.useful_box > ul > li:not(:last-child){margin-bottom: 25px;}
	.useful_box > ul > li a{background-size: 20px;}
	.useful_box > ul > li a p.fs18{padding: 0 30px 0 15px;}
	
	/* 料金表 */
	.fee_box{
		border-radius: 15px;
		padding: 30px 20px 40px;
	}
	.fee_con > div{padding-bottom: 25px;}
	.fee_con > div:not(:last-child){margin-bottom: 25px;}
	
	/* 料金表(テーブル) */
	.fee_table th,.fee_table td{padding: 15px;}

	
	/* img_box */
	.img_box_l > img,.img_box_r > img{width: 300px;}
	.img_box_l > img{margin-right: 40px;}
	.img_box_r > img{margin-left: 40px;}
}

/* 750px以下から
------------------------------------------------------------*/
@media only screen and (max-width:750px){
	
	/*#inner-title
	----------------------*/
	#inner-title{padding: 70px 0;}
	
	/*コンテンツ
	----------------------*/
	/* side_flower */
	.side_flower::before,.side_flower::after{content: none;}
	.side_flower .w800{width: 100%;}
	
	/* ページ内リンク */
	.page_link li{width: 49%;}
	.page_link li:not(:last-child){margin-bottom: 13px!important;}
	
	/* 料金表 */
	.fee_con > div dt,.fee_con > div dd{width: 100%;}
	.fee_con > div dt{margin-bottom: 3px;}
	.fee_con > div dd{text-align: inherit;}
	
	/* img_box */
	.img_box_l,.img_box_r{flex-wrap: wrap;}
	.img_box_l > img,.img_box_r > img{margin: 0 auto 30px;}
	.img_box_r > img{order: 1;}
	.img_box_r > div{order: 2;}
	.img_box_r .title.mb40{margin-bottom: 20px!important;}
}

/* 500px以下から
------------------------------------------------------------*/
@media only screen and (max-width:500px){
	
	/*#inner-title
	----------------------*/
	#inner-title{background-image: url("../images/inner_bgSP.png"),linear-gradient(to bottom,#fff,#ffe1e4);}
	#inner-title > div{flex-wrap: wrap;}
	.page_title{
		width: 100%;
		margin-bottom: 20px;
	}
	#pankuzu{
		width: 100%;
		justify-content: flex-start;
	}
	
	/*コンテンツ
	----------------------*/
	/* ボタン */
	.btn_flex{display: block;}
	.btn_flex > li{margin: 0 auto;}
	.btn_flex > li:not(:last-child){margin-bottom: 10px;}
	.btn_flex a.btn_bgp,.btn_flex a.btn_bgb{margin: 0 auto;}
	
	/* ページ内リンク */
	.page_link li{width: 100%;}

	/* お役立ち情報 */
	.useful_box{padding: 30px 20px 35px;}
	.useful_box > ul > li a{display: block;}
	.useful_box > ul > li a p.fs18{
		padding-left: 0;
		margin-top: 5px;
	}
}
