@charset "UTF-8";
/*
	Filename: page_lp
	Version: 1.0.1
*/
/*-----------------------------------------------------
	#mv
------------------------------------------------------*/
#mv {
	padding-top: 162px;
}
#mv img {
	width: 100%;
	height: auto;
}
@media screen and (max-width: 1000px) {
	#mv {
		padding-top: 98px;
	}
}
/*-----------------------------------------------------
	#campaign
------------------------------------------------------*/
#campaign {
	padding-top: 110px;
}
.campaign_box {
	justify-content: space-between;
}
.campaign_left {
	width: 34.6%;
}
.campaign_left img {
	width: 100%;
}
.campaign_right {
	width: 63.4%;
}
.campaign_right ul.flex {
	gap: 20px;
}
.campaign_right ul.flex li {
	position: relative;
	width: calc(50% - 10px);
	background: #D1CDB6;
	background: linear-gradient(90deg, rgba(209, 205, 182, 1) 0%, rgba(178, 174, 151, 1) 100%);
	text-align: center;
}
.campaign_right ul.flex li::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	width: 6px;
	height: 12px;
	background: url("../img/common/w_arrow.svg") no-repeat center center;
	background-size: cover;
}
.campaign_right ul.flex li a {
	display: block;
	position: relative;
	padding: 24px 26px;
	font-size: 24px;
	font-weight: 500;
	letter-spacing: 0.2em;
	color: #fff;
}
.campaign_right ul.flex li:nth-of-type(5) a {
	font-size: 18px;
}
.campaign_right ul.flex li a span {
	display: block;
	margin-top: 11px;
	font-size: 18px;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 1080px) {
	.campaign_right ul.flex {
		gap: 1.852vw;
	}
	.campaign_right ul.flex li a {
		padding: 2.222vw 2.407vw;
		font-size: 2.222vw;
	}
	.campaign_right ul.flex li:nth-of-type(5) a {
		font-size: 1.467vw;
	}
	.campaign_right ul.flex li a span {
		margin-top: 1.019vw;
		font-size: 1.467vw;
	}
}
@media screen and (max-width: 750px) {
	#campaign {
		padding-top: 40px;
	}
	#campaign h2 {
		margin-bottom: 35px;
		font-size: 20px;
		font-weight: 500;
		line-height: 1.6;
		letter-spacing: 0.2em;
		color: #B2AE97;
		text-align: center;
	}
	.campaign_left {
		width: 100%;
		margin-bottom: 60px;
	}
	.campaign_right {
		width: 100%;
	}
	.campaign_right ul.flex {
		gap: 10px;
	}
	.campaign_right ul.flex li {
		width: calc(50% - 5px);
	}
	.campaign_right ul.flex li::after {
		right: 6px;
		width: 4px;
		height: 8px;
	}
	.campaign_right ul.flex li a {
		padding: 18.5px 20px;
		font-size: 14px;
		line-height: 1.3;
	}
	.campaign_right ul.flex li:nth-of-type(5) a {
		padding: 18.5px 20px;
		font-size: 14px;
	}
	.campaign_right ul.flex li a span {
		display: none;
	}
}
/*-----------------------------------------------------
	#menu
------------------------------------------------------*/
#menu {
	padding-top: 60px;
}
#menu ul.flex {
	justify-content: center;
	gap: 10px;
}
#menu ul.flex li {
	width: calc(20% - 10px);
}
#menu ul.flex li a {
	display: block;
	position: relative;
	padding: 14px 20px;
	border: 1px solid #A6AEAB;
	border-radius: 30px;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.02em;
}
#menu ul.flex li a::after {
	content: "";
	display: block;
	position: absolute;
	top: 50%;
	right: 10px;
	transform: translateY(-50%);
	width: 6px;
	height: 12px;
	background: url("../img/common/b_arrow.svg") no-repeat center center;
	background-size: cover;
}
#menu ul.flex li.on a, #menu ul.flex li a:hover {
	opacity: 1;
	background: #A6AEAB;
	color: #fff;
}
#menu ul.flex li.on a::after, #menu ul.flex li a:hover::after {
	background: url("../img/common/w_arrow.svg") no-repeat center center;
	background-size: cover;
}
@media screen and (max-width: 1080px) {
	#menu ul.flex {
		justify-content: center;
	}
	#menu ul.flex li {
		flex: 0 1 calc(33.333% - 10px);
	}
}
@media screen and (max-width: 750px) {
	#menu ul.flex li {
		flex: 0 1 calc(49% - 10px);
	}
	#menu ul.flex li a {
		padding: 11px 10px;
		font-size: 12px;
	}
	#menu ul.flex li a::after {
		right: 5px;
		width: 4px;
		height: 8px;
	}
}
@media screen and (max-width: 414px) {
	#menu ul.flex {
		gap: 5px;
	}
	#menu ul.flex li a {
		font-size: 11px;
	}
}
/*-----------------------------------------------------
	#sec_01
------------------------------------------------------*/
#sec_01 {
	padding-top: 80px;
}
/*-----------------------------------------------------
	point_header
------------------------------------------------------*/
.point_header {
	padding: 97px 20px 100px;
	background: #F4F4F5;
	text-align: center;
}
.point_img {
	position: absolute;
	top: -145px;
	right: 0;
	width: 408px;
}
.point_num {
	margin-bottom: 45px;
}
.point_num span {
	padding: 3px 20px 5px;
	background: #D1CDB6;
	background: linear-gradient(90deg, rgba(209, 205, 182, 1) 0%, rgba(178, 174, 151, 1) 100%);
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.2em;
	color: #fff;
}
.point_header h3 {
	margin-bottom: 40px;
	font-family: "Noto Serif", serif;
	font-size: 32px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.2em;
}
.point_header p {
	font-size: 16px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
.point_04 {
	margin-top: 150px;
	margin-bottom: 100px;
}
.point_header .wrap {
	position: relative;
	padding-right: 430px;
}
@media screen and (max-width: 900px) {
	.point_04 {
		margin-top: 0;
		margin-bottom: 60px;
	}
	.point_header .wrap {
		width: 100%;
		padding-right: 0;
	}
	.point_img {
		position: static;
		top: auto;
		right: auto;
		width: 80%;
		margin: 40px auto 0;
		text-align: center;
	}
}
@media screen and (max-width: 750px) {
	.point_header {
		padding: 59px 20px 60px;
	}
	.point_img {
		width: 100%;
	}
	.point_num {
		margin-bottom: 43px;
	}
	.point_num span {
		padding: 1px 20px 3px;
	}
	.point_header h3 {
		font-size: 24px;
	}
	.point_header p {
		font-size: 14px;
	}
}
/*-----------------------------------------------------
	case
------------------------------------------------------*/
.case {
	justify-content: space-between;
	padding: 60px 0;
}
.case_l {
	width: 42%;
}
.case_l img {
	width: 100%;
}
.mov_mp {
	width: 100%;
	margin: 0 auto;
}
.mov_mp video {
	display: block;
	width: 100%;
	height: auto;
	margin-bottom: 10px;
}
.mov_mp video:hover {
	cursor: pointer;
}
.mov_mp video:last-of-type {
	margin-bottom: 0;
}
.case_arrow {
	width: 30px;
	height: 15px;
	margin-top: 10px;
	margin-bottom: 10px;
}
.case_r {
	width: 55%;
}
table.case_table {
	width: 100%;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
table.case_table tr th {
	width: 180px;
	padding: 23px 20px;
	background: #B2AE97;
	border: 1px solid #B2AE97;
	border-bottom: 1px solid #fff;
	font-weight: 400;
	color: #fff;
	vertical-align: middle;
}
table.case_table tr:last-of-type th {
	border-bottom: 1px solid #B2AE97;
}
table.case_table tr td {
	width: calc(100% - 180px);
	padding: 23px 20px;
	border: 1px solid #B2AE97;
}
@media screen and (max-width: 750px) {
	.case {
		padding: 30px 0;
	}
	.case_l {
		width: 100%;
		margin-bottom: 30px;
	}
	.case_arrow {
		width: 26px;
		height: 13px;
		margin-top: 9px;
		margin-bottom: 9px;
	}
	.case_r {
		width: 100%;
	}
	table.case_table tr th {
		display: block;
		width: 100%;
		padding: 12.5px;
		border: 1px solid #B2AE97;
	}
	table.case_table tr td {
		display: block;
		width: 100%;
		padding: 12.5px;
		font-size: 14px;
	}
}
/*-----------------------------------------------------
	comment
------------------------------------------------------*/
.comment {
	position: relative;
	margin-bottom: 100px;
	padding: 50px 135px;
	border: 1px solid #A6AEAB;
}
.comment::before {
  content: "";
  position: absolute;
  top: -1px;
  right: -1px;
  z-index: 1;
	width: 32px;
	height: 24px;
	background: url("../img/doubleeyelids/corner.jpg") center center no-repeat;
	background-size: cover;
}
.comment h4 {
	margin-bottom: 40px;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
	color: #A6AEAB;
	text-align: center;
}
.comment .flex {
	justify-content: space-between;
}
.comment_photo {
	width: 26.8%;
	text-align: center;
}
.comment_photo img {
	max-width: 100%;
}
.comment_text {
	width: 70%;
}
.comment_text p {
	font-size: 16px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 1080px) {
	.comment {
		margin-bottom: 100px;
		padding: 50px 20px;
	}
}
@media screen and (max-width: 750px) {
	.comment {
		margin-bottom: 60px;
		padding: 40px 25px;
	}
	.comment::before {
		content: "";
		position: absolute;
		top: -1px;
		right: -1px;
		z-index: 1;
		width: 32px;
		height: 24px;
		background: url("../img/doubleeyelids/corner.jpg") center center no-repeat;
		background-size: cover;
	}
	.comment h4 {
		margin-bottom: 30px;
		font-size: 20px;
		letter-spacing: 0.05em;
	}
	.comment_photo {
		width: 100%;
		margin-bottom: 30px;
	}
	.comment_text {
		width: 100%;
	}
	.comment_text p {
		font-size: 14px;
	}
}
/*-----------------------------------------------------
	item
------------------------------------------------------*/
.item {
	padding: 60px 0;
}
.item .wrap {
	justify-content: space-between;
	padding: 0 92px;
}
.item_child {
	width: 46%;
}
.item_child img {
	width: 100%;
	margin-bottom: 30px;
}
.item_child p {
	font-size: 14px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 1080px) {
	.item .wrap {
		padding: 0;
	}
	.item_child {
		width: 48%;
	}
}
@media screen and (max-width: 750px) {
	.item {
		padding: 30px 0;
	}
	.item_child {
		width: 100%;
		margin-bottom: 37px;
	}
}
/*-----------------------------------------------------
	variation
------------------------------------------------------*/
.variation .wrap {
	width: 1080px;
	margin: 0 auto;
}
@media screen and (max-width: 1120px) {
	.variation .wrap {
		width: calc(100% - 40px);
	}
}
.variation h3 {
	margin-bottom: 40px;
	font-size: 20px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
	color: #B2AE97;
	text-align: center;
}
.summary {
	margin-bottom: 60px;
	border: 1px solid #B2AE97;
}
.summary_inner_l {
	justify-content: center;
	width: 100%;
	padding: 20px;
	gap: 30px 2%;
}
.summary_child {
	width: 32%;
}
.summary_child.w23 {
	width: 23%;
}
.summary_inner_l img {
	width: 100%;
}
.summary_inner_l p {
	font-size: 18px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.summary_inner_r {
	width: 100%;
	padding: 40px;
}
.summary_inner_r p.gold_p {
	margin-bottom: 50px;
	font-size: 20px;
	font-weight: 700;
	line-height: 1.6;
	letter-spacing: 0.1em;
	color: #B2AE97;
}
.summary_inner_r h5 {
	margin-bottom: 40px;
}
.summary_inner_r h6 {
	margin-bottom: 20px;
}
.summary_inner_r h6 span {
	padding: 2px 10px 4px;
	background: #A6AEAB;
	font-size: 20px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #fff;
}
.summary_inner_r h6.gold span {
	background: #B2AE97;
}
.summary_inner_r dl {
	margin-bottom: 30px;
}
.summary_inner_r dl dt {
	margin-bottom: 20px;
	border-bottom: 1px solid #A6AEAB;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.summary_inner_r dl dd {
	margin-bottom: 20px;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 750px) {
	.summary {
		margin-bottom: 40px;
	}
	.summary_inner_l {
		width: 100%;
		margin-bottom: 30px;
		padding: 30px 25px 0;
	}
	.summary_child {
		width: 100%;
	}
	.summary_child.w23 {
		width: 100%;
	}
	.summary_inner_l p {
		margin-bottom: 30px;
	}
	.summary_inner_r {
		width: 100%;
		padding: 0 25px;
	}
	.summary_inner_r p.gold_p {
		margin-bottom: 30px;
		font-size: 16px;
	}
	.summary_inner_r h6 span {
		padding: 4px 10px 6px;
		font-size: 16px;
	}
	.summary_inner_r dl dt {
		font-size: 16px;
	}
	.summary_inner_r dl dd {
		font-size: 14px;
	}
}

/*-----------------------------------------------------
	#sec_02
------------------------------------------------------*/
#sec_02 {
	padding-top: 80px;
	padding-bottom: 145px;
	text-align: center;
}
#sec_02 p {
	font-size: 16px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 750px) {
	#sec_02 {
		padding-top: 0;
		padding-bottom: 60px;
	}
	#sec_02 h2 {
		margin-bottom: 60px;
	}
	#sec_02 p {
		font-size: 14px;
	}
}

/*-----------------------------------------------------
	#sec_03
------------------------------------------------------*/
#sec_03 {
	padding-top: 80px;
	background: #F4F4F5;
}
#sec_03 img {
	display: block;
	max-width: 100%;
	margin: 0 auto;
}
#sec_03 h2 {
	margin-bottom: 20px;
	font-family: "Noto Serif", serif;
	font-size: 24px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
	text-align: center;
}
#sec_03 p {
	margin-bottom: 80px;
	font-size: 15px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
.sec_03_inner {
	background: #fff;
}
.sec_03_inner a.link_more {
	margin-top: 80px;
	margin-bottom: 80px;
}
.sec_03_box {
	justify-content: space-between;
}
.sec_03_box h3 {
	margin-bottom: 30px;
	font-size: 20px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
	color: #B2AE97;
}
.sec_03_box p {
	font-size: 16px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
.merits_demerits {
	padding: 80px 0;
}
.merits_demerits h3 {
	margin-bottom: 50px;
	font-size: 24px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #B2AE97;
	text-align: center;
}
.merits_demerits .flex {
	justify-content: space-between;
}
.merits_demerits .flex .col_02 {
	padding: 50px 40px;
	background: #FFF0F0;
	border: 1px solid #EF8888;
}
.merits_demerits .flex .col_02 h4 {
	margin-bottom: 30px;
	font-size: 24px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #EF8888;
	text-align: center;
}
.merits_demerits .flex .col_02 p {
	margin-bottom: 0 !important;
	font-size: 16px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
}
.merits_demerits .flex .col_02:nth-of-type(2) {
	background: #F0F7FF;
	border: 1px solid #5083B6;
}
.merits_demerits .flex .col_02:nth-of-type(2) h4 {
	color: #5083B6;
}
.osusume {
	padding: 80px 0;
	background: #fff;
}
.osusume .wrap {
	padding: 60px 70px 40px;
	border: 1px solid #B2AE97;
}
.osusume .wrap:nth-of-type(2) {
	margin-top: 80px;
	padding: 0;
	border: 1px solid #A6AEAB;
}
.osusume .wrap:last-of-type {
	border: 1px solid #A6AEAB;
}
.osusume .wrap h3 {
	margin-bottom: 30px;
	font-size: 30px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
	color: #B2AE97;
	text-align: center;
}
.osusume .wrap h6 {
	padding: 18px 0;
	background: #A6AEAB;
	font-size: 20px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #fff;
	text-align: center;
}
.osusume .wrap h4 {
	margin-bottom: 30px;
	padding: 20px 0;
	border-top: 1px solid #B2AE97;
	border-bottom: 1px solid #B2AE97;
	font-size: 24px;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.2em;
	text-align: center;
}
.osusume .wrap h5 {
	position: relative;
	margin-bottom: 10px;
	padding-left: 32px;
	font-size: 24px;
	font-weight: 500;
	line-height: 1.8;
	letter-spacing: 0.2em;
}
.osusume .wrap h5::before {
	content: "";
	display: block;
	position: absolute;
	top: 12px;
	left: 0;
	width: 22px;
	height: 23px;
	background: url("../img/common/checkbox.svg") no-repeat center center;
	background-size: cover;
}
.osusume .wrap p {
	margin-bottom: 40px !important;
	font-size: 16px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
}
.type {
	padding: 80px 0;
}
.type h3 {
	margin-bottom: 60px;
	font-size: 30px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
	color: #B2AE97;
	text-align: center;
}
.type .wrap .flex {
	justify-content: space-between;
	margin-bottom: 30px;
}
.type .wrap .col_02 {
	padding: 60px 40px;
	background: #fff;
	text-align: center;
}
.type .wrap .col_02 h4 {
	margin-bottom: 30px;
	font-size: 24px;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.2em;
}
.type .wrap .col_02 img {
	width: 100%;
	margin: 0 auto 40px !important;
}
.type .wrap .col_02 p {
	margin-bottom: 0 !important;
	font-size: 16px !important;
	text-align: left;
}
@media screen and (max-width: 1080px) {
	.merits_demerits .flex .col_02 {
		padding: 40px 30px;
	}
}
@media screen and (max-width: 750px) {
	#sec_03 {
		padding-top: 60px;
	}
	#sec_03 h2 {
		margin-bottom: 40px;
		font-size: 20px;
		line-height: 1.6;
	}
	#sec_03 p {
		margin-bottom: 60px;
		font-size: 14px;
	}
	.sec_03_inner a.link_more {
		margin-top: 60px;
		margin-bottom: 60px;
	}
	.col_02 img {
		display: block;
		margin: 0 auto 30px;
	}
	.sec_03_box h3 {
		margin-bottom: 20px;
	}
	.sec_03_box p {
		font-size: 14px;
	}
	.merits_demerits {
		padding: 60px 0;
	}
	.merits_demerits h3 {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.merits_demerits .flex .col_02 {
		padding: 40px 25px 50px;
	}
	.merits_demerits .flex .col_02 h4 {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.merits_demerits .flex .col_02 p {
		margin-bottom: 0 !important;
		font-size: 14px;
	}
	.merits_demerits .flex .col_02:nth-of-type(2) {
		margin-top: 40px;
	}
	.osusume {
		padding: 60px 0;
	}
	.osusume .wrap {
		padding: 50px 20px 30px;
	}
	.osusume .wrap:nth-of-type(2) {
		margin-top: 60px;
	}
	.osusume .wrap h3 {
		margin-bottom: 20px;
		font-size: 19px;
		letter-spacing: 0.1em;
	}
	.osusume .wrap h4 {
		margin-bottom: 30px;
		padding: 20px 0;
		font-size: 18px;
	}
	.osusume .wrap h5 {
		padding-left: 26px;
		font-size: 18px;
	}
	.osusume .wrap h5::before {
		top: 11px;
		width: 16px;
		height: 17px;
	}
	.osusume .wrap p {
		margin-bottom: 20px !important;
		font-size: 14px;
	}
	.type {
		padding: 60px 0;
	}
	.type h3 {
		margin-bottom: 30px;
		font-size: 20px;
	}
	.type .wrap .col_02 {
		padding: 47px 40px;
	}
}
/*-----------------------------------------------------
	slide_list
------------------------------------------------------*/
.swiper-button-prev {
	left: -8px;
}
.swiper-button-next {
	right: -8px;
}
.swiper-button-prev::after, .swiper-button-next::after {
	width: 10px;
	height: 31px;
	background: url("../img/common/slider_arrow_l.svg") no-repeat center center;
	background-size: cover;
	font-size: 0;
}
.swiper-button-next::after {
	width: 10px;
	height: 31px;
	background: url("../img/common/slider_arrow_r.svg") no-repeat center center;
	background-size: cover;
	font-size: 0;
}
/*-----------------------------------------------------
	#sec_04
------------------------------------------------------*/
#sec_04 {
	padding-top: 80px;
	background: #F4F4F5;
}
#sec_04 img {
	display: block;
	max-width: 100%;
	margin: 0 auto;
}
#sec_04 h2 {
	margin-bottom: 20px;
	font-family: "Noto Serif", serif;
	font-size: 24px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
	text-align: center;
}
#sec_04 p.first_text {
	margin-bottom: 80px;
	font-size: 15px;
	font-weight: 400;
	line-height: 2;
	letter-spacing: 0.2em;
}
.sec_04_inner {
	padding-bottom: 80px;
	background: #fff;
}
.sec_04_inner .wrap h3 {
	margin-top: 80px;
	margin-bottom: 30px;
	font-size: 30px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
	color: #B2AE97;
	text-align: center;
}
.sec_04_inner .wrap p {
	margin-bottom: 30px;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.6;
	color: #A6AEAB;
	text-align: center;
}
.sec_04_inner .wrap h4 {
	margin-bottom: 80px;
	padding: 20px 0;
	border-top: 1px solid #B2AE97;
	border-bottom: 1px solid #B2AE97;
	font-size: 24px;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.2em;
	text-align: center;
}
.sec_04_inner .wrap .flex {
	justify-content: space-between;
	margin-bottom: 80px;
}
.sec_04_inner .wrap .col_02 {
	padding-bottom: 60px;
	background: #F4F4F5;
}
.sec_04_inner .wrap .col_02 img {
	margin-bottom: 40px;
}
.sec_04_inner .wrap .col_02 h5 {
	margin-bottom: 20px;
	text-align: center;
}
.sec_04_inner .wrap .col_02 h5 span {
	display: inline-block;
	padding: 3px 10px 5px;
	background: #5F6462;
	font-size: 16px;
	font-weight: 500;
	letter-spacing: 0.2em;
	color: #fff;
}
.sec_04_inner .wrap .col_02 p {
	margin-bottom: 0 !important;
	padding: 0 40px;
	font-size: 16px !important;
	font-weight: 500 !important;
	line-height: 2 !important;
	color: #5F6462 !important;
	text-align: left;
}
.sec_04_inner .wrap h3.midasi_01 {
	margin-bottom: 40px;
	font-size: 24px;
	line-height: 2;
	color: #A6AEAB;
	text-align: center;
}
table.price {
  width: 100%;
	margin-bottom: 80px;
}
table.price thead th {
	width: 33.33333333%;
  background: #fff;
	font-size: 16px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #fff;
}
table.price thead th:nth-of-type(2){
  background: #B2AE97;
	border-right: 1px solid #fff;
}
table.price thead th:nth-of-type(3){
  background: #A6AEAB;
}
table.price th {
	padding: 10px 20px;
	background: #FBFAF5;
  border: 1px solid #A6AEAB;
	font-size: 16px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #97947F;
	vertical-align: middle;
  text-align: center;
}
table.price td {
  border: 1px solid #A6AEAB;
  padding: 10px 20px;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.2em;
	vertical-align: middle;
  text-align: left;
}
table.price td ul li {
	margin-left: 20px;
	list-style-type: disc;
	font-size: 16px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.2em;
  text-align: left;
}
p.sec_04_text {
	font-size: 20px !important;
	line-height: 2 !important;
}
@media screen and (max-width: 750px) {
	#sec_04 {
		padding-top: 60px;
	}
	#sec_04 h2 {
		margin-bottom: 40px;
		font-size: 20px;
		line-height: 1.6;
	}
	#sec_04 p.first_text {
		margin-bottom: 60px;
		font-size: 14px;
	}
	.sec_04_inner {
		padding-bottom: 60px;
	}
	.sec_04_inner .wrap h3 {
		margin-bottom: 20px;
		font-size: 20px;
	}
	.sec_04_inner .wrap p {
		margin-bottom: 30px;
		font-size: 14px;
	}
	.sec_04_inner .wrap h4 {
		margin-bottom: 60px;
		padding: 20px 0;
		font-size: 18px;
	}
	.sec_04_inner .wrap .swiper-slide .col_02 {
		width: 80%;
		margin: 0 auto 60px;
	}
	.sec_04_inner .wrap .swiper-slide .col_02 p {
		font-size: 14px !important;
	}
	.sec_04_inner .wrap h3.midasi_01 {
		font-size: 20px;
	}
	table.price {
    display: block;
		margin-bottom: 60px;
  }
  table.price thead {
    display: none;
  }
  table.price tbody,
  table.price tr {
    display: block;
    width: 100%;
  }
  table.price tr {
		display: flex;
		flex-wrap: wrap;
    margin-bottom: 10px;
		border: 1px solid #A6AEAB;
  }
	table.price th {
		display: block;
		width: 100%;
		border: none;
	}
	table.price td {
		display: block;
		position: relative;
		width: 100%;
		padding: 0;
		padding-bottom: 15px;
		border: none;
		font-size: 14px;
	}
	table.price td.w50 {
		width: 50%;
		text-align: center;
	}
	table.price td.w50:first-of-type {
		border-right: 1px solid #A6AEAB;
  }
	.td_inner {
		padding-right: 20px;
		padding-left: 20px;
	}
	table.price td ul li {
		margin-left: 20px;
		font-size: 14px;
	}
  table.price td.sp_title_g::before {
    display: block;
		margin-bottom: 15px;
		background: #B2AE97;
		font-size: 16px;
    font-weight: 500;
		line-height: 2;
		letter-spacing: 0.2em;
    color: #fff;
		text-align: center;
  }
	table.price td.w50.sp_title_g::before {
		padding: 10px;
    border-right: 1px solid #fff;
  }
  table.price td.sp_title_s::before {
    display: block;
		margin-bottom: 15px;
		background: #A6AEAB;
		font-size: 16px;
    font-weight: 500;
		line-height: 2;
		letter-spacing: 0.2em;
    color: #fff;
		text-align: center;
  }
	table.price td.w50.sp_title_s::before {
    padding: 10px;
  }
	table.price td.title_01::before {
		content: "切開法";
	}
	table.price td.title_02::before {
		content: "埋没法";
	}
	table.price td.title_03::before {
		content: "モニター価格";
	}
	table.price td.title_04::before {
		content: "通常価格";
	}
	p.sec_04_text {
		font-size: 18px !important;
	}
}

/*-----------------------------------------------------
	#sec_05
------------------------------------------------------*/
#sec_05 {
	padding: 80px 0 50px;
}
.sec_05_osusume {
	justify-content: space-between;
	align-items: center;
	margin-bottom: 80px;
	padding: 60px 115px;
	border: 1px solid #B2AE97;
}
.sec_05_osusume_l {
	width: 240px;
	text-align: center;
}
.sec_05_osusume_l h2 {
	width: 240px;
	height: 240px;
	padding: 72px 0;
	background: #B2AE97;
	border-radius: 50%;
	font-size: 24px;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #fff;
}
.sec_05_osusume_r {
	width: calc(100% - 320px);
}
.sec_05_osusume_r ul li {
	position: relative;
	padding-left: 32px;
	font-size: 24px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.2em;
}
.sec_05_osusume_r ul li::before {
	content: "";
	display: block;
	position: absolute;
	top: 14px;
	left: 0;
	width: 22px;
	height: 23px;
	background: url("../img/common/checkbox.svg") no-repeat center center;
	background-size: cover;
}
@media screen and (max-width: 1080px) {
	.sec_05_osusume {
		padding: 60px 30px;
	}
	.sec_05_osusume_r {
		width: calc(100% - 280px);
	}
}
@media screen and (max-width: 750px) {
	#sec_05 {
		padding: 60px 0 20px;
	}
	.sec_05_osusume {
		margin-bottom: 60px;
		padding: 60px 32px;
	}
	.sec_05_osusume_l {
		width: 100%;
		margin-bottom: 40px;
	}
	.sec_05_osusume_l h2 {
		width: 180px;
		height: 180px;
		margin: 0 auto;
		padding: 53px 0;
		font-size: 18px;
	}
	.sec_05_osusume_r {
		width: 100%;
	}
	.sec_05_osusume_r ul li {
		padding-left: 26px;
		font-size: 15px;
	}
	.sec_05_osusume_r ul li::before {
		top: 7px;
		width: 16px;
		height: 17px;
	}
}

/*-----------------------------------------------------
	#sec_06
------------------------------------------------------*/
#sec_06 {
	padding: 140px 0 45px;
}
#sec_06 h2 {
	margin-bottom: 80px;
}
.bunki {
	margin-bottom: 80px;
	padding: 68px 0;
	background: #F3F3EA;
}
.bunki img {
	max-width: 100%;
}
table.type {
  width: 100%;
	margin-bottom: 80px;
}
table.type thead th {
	width: 20%;
  background: #B2AE97;
	border: 1px solid #5F6462;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: 0.2em;
	color: #fff;
}
table.type thead th:first-of-type {
  background: #fff;
}
table.type th {
	padding: 10px;
	background: #FFEFEF;
  border: 1px solid #5F6462;
	font-size: 16px;
	font-weight: 500;
	line-height: 1.2;
	letter-spacing: 0.2em;
	color: #EF8888;
	vertical-align: middle;
  text-align: center;
}
.bg_w {
	background: #fff !important;
}
table.type td {
  border: 1px solid #5F6462;
  padding: 10px;
	font-size: 14px;
	font-weight: 400;
	line-height: 1.2;
	letter-spacing: 0.2em;
	vertical-align: middle;
  text-align: center;
}
@media screen and (max-width: 750px) {
	#sec_06 {
		padding: 60px 0 15px;
	}
	#sec_06 h2 {
		margin-bottom: 40px;
	}
	.bunki {
		margin-bottom: 40px;
		padding: 0;
	}
	table.type {
		width: 80%;
		margin: 0 auto 40px;
	}
	table.type thead th {
		display: block;
		width: 100%;
		padding: 15px 10px;
		border-bottom: none;
	}
	table.type thead th:first-of-type {
		background: #B2AE97;
	}
	table.type th {
		display: block;
		width: 100%;
		padding: 15px 10px;
		border-bottom: none;
	}
	table.type td {
		display: block;
		width: 100%;
		padding: 15px 10px;
		border-bottom: none;
	}
	table.type tr:last-of-type td {
		border-bottom: 1px solid #5F6462;
	}
}
/*-----------------------------------------------------
	#flow
------------------------------------------------------*/
#flow {
	padding: 80px 0;
	background: #F4F4F5;
}
#flow .wrap {
	width: 1080px;
	margin: 0 auto;
}
#flow .wrap .flex {
	gap: 30px;
}
.flow_child {
	position: relative;
	width: calc(33.333% - 20px);
}
.flow_num {
	display: inline-block;
	position: absolute;
	top: 0;
	left: 0;
	padding: 8px 10px;
	background: #B2AE97;
	font-size: 15px;
	font-weight: 500;
	letter-spacing: 0.1em;
	color: #fff;
	text-align: center;
}
.flow_child img {
	width: 100%;
}
.flow_child_text {
	padding: 20px;
	background: #fff;
}
.flow_child h3 {
	margin-bottom: 20px;
	font-size: 20px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
	color: #B2AE97;
}
.flow_child p {
	font-size: 15px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
@media screen and (max-width: 1120px) {
	#flow .wrap {
		width: calc(100% - 40px);
	}
	.flow_child {
		width: calc(50% - 15px);
	}
}
@media screen and (max-width: 750px) {
	#flow {
		padding: 60px 0;
	}
	.flow_child {
		width: 80%;
		margin-right: auto;
		margin-left: auto;
	}
	.flow_child p {
		font-size: 14px;
	}
}

/*-----------------------------------------------------
	#price
------------------------------------------------------*/
#price {
	padding-top: 120px;
}
#price h3, #sec_06 h3 {
	margin-bottom: 20px;
	font-size: 20px;
	font-weight: 700;
	line-height: 2;
	letter-spacing: 0.2em;
	color: #B2AE97;
}
#price table.price {
	margin-bottom: 40px;
}
#price table.price tr td {
	text-align: center;
}
#price table.price tr th.w_half, #price table.price tr td.w_half {
	width: 50%;
	text-align: center;
}
@media screen and (max-width: 750px) {
	#price {
		padding-top: 80px;
	}
	.mb0 {
		margin-bottom: 0 !important;
		border-bottom: none !important;
	}
	#price table.price tr th.w_half, #price table.price tr td.w_half {
		width: 100%;
	}
	#price table.price tr th.w_half {
		border-top: none;
	}
	#price table.price tr td.w_half {
		width: 100%;
		padding-top: 15px;
		border-top: 1px solid #A6AEAB;
	}
}

/*-----------------------------------------------------
	#case_movie
------------------------------------------------------*/
#case_movie {
	padding: 80px 0 120px;
}
#case_movie .wrap {
	width: 840px;
}
#case_movie .wrap h2 {
	margin-bottom: 60px;
}
#case_movie .wrap .flex {
	gap: 40px;
}
.case_movie_child {
	width: calc(50% - 20px);
	border: 1px solid #B2AE97;
}
.case_movie_child img, .case_img_child img {
	width: 100%;
}
.case_movie_child video {
	width: 100%;
	height: auto;
}
.case_movie_child h3, .case_img_child h3 {
	padding: 5px;
	background: #B2AE97;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
	color: #fff;
	text-align: center;
}
.case_movie_child p, .case_img_child p {
	padding: 20px;
	font-size: 15px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.2em;
}
@media screen and (max-width: 880px) {
	#case_movie .wrap {
		width: calc(100% - 40px);
	}
}
@media screen and (max-width: 750px) {
	#case_movie {
		padding: 20px 0 60px;
	}
	#case_movie .wrap h2 {
		margin-bottom: 40px;
	}
	.case_movie_child {
		width: 80%;
		margin-right: auto;
		margin-left: auto;
		border: none;
	}
	.case_movie_child img, .case_img_child img {
		margin-bottom: 30px;
	}
	.case_movie_child h3, .case_img_child h3 {
		padding: 5px;
		border: 1px solid #B2AE97;
		font-size: 16px;
	}
	.case_movie_child p, .case_img_child p {
		border: 1px solid #B2AE97;
		font-size: 14px;
	}
}

/*-----------------------------------------------------
	#case_img
------------------------------------------------------*/
#case_img {
	padding: 100px 0;
	background: #F4F4F5;
}
#case_img .wrap {
	width: 1080px;
}
#case_img .wrap h2 {
	margin-bottom: 60px;
}
#case_img .wrap .flex {
	gap: 30px;
}
.case_img_child {
	width: calc(33.333% - 20px);
	border: 1px solid #B2AE97;
}
@media screen and (max-width: 1120px) {
	#case_img .wrap {
		width: calc(100% - 40px);
	}
}
@media screen and (max-width: 750px) {
	#case_img {
		padding: 60px 0;
	}
	#case_img .wrap h2 {
		margin-bottom: 40px;
	}
	.case_img_child {
		width: 80%;
		margin-right: auto;
		margin-left: auto;
		border: none;
	}
}

/*-----------------------------------------------------
	#faq
------------------------------------------------------*/
#faq {
	padding: 120px 0;
}
#faq .wrap {
	width: 750px;
}
.accordion-header {
  position: relative;
  margin: 10px 0 0;
  padding: 20px 70px 20px 70px;
	background: #FBFAF5;
  border: 1px solid #B2AE97;
  transition: background .3s ease;
  cursor: pointer;
	font-size: 18px;
	font-weight: 500;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.accordion-header.active {
  border-bottom: none;
}
.accordion-header:hover {
  background: #F4F4F5;
}
.accordion-header::before {
  content: "Q";
  position: absolute;
  top: 12px;
  left: 20px;
  font-size: 24px;
	font-weight: 500;
  color: #B2AE97;
}
.accordion-header::after {
  content: "";
  position: absolute;
  top: 28px;
  right: 20px;
  width: 30px;
  height: 16px;
	background: url("../img/common/top_arrow.svg") no-repeat center center;
	background-size: cover;
  transition: transform 0.3s;
	transform: rotate(180deg);
}
.accordion-header.active::after {
	transform: rotate(0);
}
.accordion-content {
  display: none;
	position: relative;
  padding: 25px 70px;
	border: 1px solid #B2AE97;
	border-top: none;
	font-size: 15px;
	font-weight: 400;
	line-height: 1.6;
	letter-spacing: 0.1em;
}
.accordion-content::before{
  content: "A";
  position: absolute;
	top: 50%;
  left: 20px;
	transform: translateY(-50%);
  font-size: 24px;
	font-weight: 500;
  color: #B2AE97;
}
@media screen and (max-width: 790px) {
	#faq .wrap {
		width: calc(100% - 40px);
	}
}
@media screen and (max-width: 750px) {
	#faq {
		padding: 60px 0;
	}
	.accordion-header {
		padding: 13px 70px;
		font-size: 14px;
	}
	.accordion-header::before {
		top: 50%;
		transform: translateY(-50%);
	}
	.accordion-header::after {
		top: 50%;
		transform: translateY(-50%) rotate(180deg);
	}
	.accordion-header.active::after {
		top: 36%;
	}
	.accordion-content {
		padding: 20px 70px;
		font-size: 14px;
	}
}



/*-----------------------------------------------------
	footer
------------------------------------------------------*/
.lp_footer {
	background: #F4F4F5;
}
.lp_footer_inner {
	justify-content: space-between;
	width: 1170px;
	margin: 0 auto;
	padding: 80px 0;
}
.lp_footer_inner_child {
	width: 33.333%;
	padding: 0 25px;
}
.lp_footer_inner_child h2 {
	margin-bottom: 35px;
}
.lp_footer_inner_child h2 img {
	width: 246px;
	height: auto;
}
.lp_footer_inner_child address {
	font-size: 14px;
	font-weight: 500;
	font-style: normal;
	line-height: 2;
	letter-spacing: 0.1em;
}
.lp_footer_inner_child h3 {
	margin-top: 25px;
	margin-bottom: 35px;
	font-family: "Noto Serif", serif;
	font-size: 18px;
	font-weight: 600;
	line-height: 2;
	letter-spacing: 0.1em;
	color: #B2AE97;
	text-align: center;
}
.lp_footer_inner_child p {
	margin-bottom: 35px;
	font-size: 14px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
}
.lp_footer_inner_child:not(:first-of-type) a {
	display: block;
	max-width: 330px;
	margin: 0 auto;
	padding: 20px 10px;
	background: #5F6462;
	border-radius: 30px;
	font-size: 14px;
	font-weight: 500;
	color: #fff;
	text-align: center;
}
.lp_footer_inner_child:last-of-type a {
	background: #6EC46F;
}
.lp_footer small {
	display: block;
	padding: 15px;
	background: #fff;
	font-size: 11px;
	font-weight: 500;
	line-height: 2;
	letter-spacing: 0.1em;
	color: #A6AEAB;
	text-align: center;
}
@media screen and (max-width: 1210px) {
	.lp_footer_inner {
		width: calc(100% - 40px);
	}
}
@media screen and (max-width: 850px) {
	.lp_footer_inner {
		padding: 30px 0 0;
	}
	.lp_footer_inner_child {
		width: 100%;
		padding-bottom: 30px;
		border-bottom: 1px solid #A6AEAB;
	}
	.lp_footer_inner_child:last-of-type {
		border-bottom: none;
	}
	.lp_footer_inner_child h2 {
		text-align: center;
	}
	.lp_footer_inner_child h3 {
		margin-top: 30px;
		margin-bottom: 30px;
	}
	.lp_footer small {
		padding: 0;
		background: #F4F4F5;
	}
}
@media screen and (max-width: 750px) {
	.lp_footer {
		padding-bottom: 54px;
	}
	.lp_footer small {
		padding-bottom: 30px;
		border-bottom: 1px solid #A6AEAB;
	}
}









