@charset "utf-8";

header .logo {
	top: 74%;
}

@media screen and (max-width: 640px) {
	header .logo {
		top: 50%;
	}
}


/*============================
共通
============================*/
.title_wrap {
	text-align: center;
	padding-bottom: 0.30rem;
}

@media screen and (max-width: 640px) {
	.title_wrap {
		padding-bottom: 0;
	}
}

.title_wrap .en {
	font-size: 0.14rem;
	font-weight: 500;
	color: #FC6401;
	font-family: "Poppins", sans-serif;
	font-weight: 600;
	margin-bottom: 0.10rem;
}

@media screen and (max-width: 640px) {
	.title_wrap .en {
		font-size: 0.12rem;
		margin-bottom: 0.05rem;
	}
}

.title_wrap .jp {
	font-size: 0.26rem;
	font-weight: bold;
	margin-bottom: 0.10rem;
	line-height: 2;
}

@media screen and (max-width: 640px) {
	.title_wrap .jp {
		font-size: 0.2rem;
		line-height: 1.5;
		margin-bottom: 0.20rem;
	}
}


.title_wrap .jp .border {
	border-bottom: 3px solid #06C755;
	padding-bottom: 0.05rem;
}


/*============================
MV
============================*/
#mv {
	background: #06C755;
	padding: 0.80rem 0;
	position: relative;
	margin-top: 0.50rem;
}

@media screen and (max-width: 640px) {
	#mv {
		padding: 0.30rem 0 0;
		margin-top: 0;
	}
}


/* 背景写真 */
#mv .bg_wrap {
	position: absolute;
	width: 40%;
	height: 100%;
	right: 0;
	top: 0;
	border-left: 0.03rem solid #FFF;
}

@media screen and (max-width: 640px) {
	#mv .bg_wrap {
		position: static;
		width: 100%;
		height: auto;
		right: 0;
		border-left: none;
		margin-top: 0.6rem;
		border-top: 1px solid #fff;
	}
}

#mv .bg_wrap .pc_only {
	height: 100%;
}


#mv .bg_wrap img {
	width: 100%;
	height: 100%;
	object-fit: cover;
	object-position: left;
}

/* スマホ */
#mv .tel_wrap {
	width: 3.21rem;
	height: 6.53rem;
	position: absolute;
	top: -0.30rem;
	left: 63%;
	transform: translateX(-50%);
	background-image: url(../img/top/service_phone.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
}

@media screen and (max-width: 640px) {
	#mv .tel_wrap {
		width: 1.90rem;
		height: 3.86rem;
		top: auto;
		left: 50%;
		bottom: -0.50rem;
		transform: translateX(-50%);
	}
}


#mv .tel_wrap .screen {
	width: calc(100% - 0.32rem);
	height: calc(100% - 0.30rem);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border-radius: 0.30rem;
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	#mv .tel_wrap .screen {
		width: calc(100% - 0.16rem);
    height: calc(100% - 0.16rem);
		border-radius: 0.22rem;
	}
}


#mv .tel_wrap .screen video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}

#mv .left_wrap {
	width: calc(100% - 6rem);
}

@media screen and (max-width: 640px) {
	#mv .left_wrap {
		width: 100%;
		text-align: center;
	}
}


#mv .left_wrap .top_cont .title {
	margin-bottom: 0.26rem;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .top_cont .title {
		margin-bottom: 0.2rem;
	}

	#mv .left_wrap .top_cont .title img {
		width: 2.4rem;
	}
}


#mv .left_wrap .top_cont .lead {
	font-size: 0.26rem;
	font-weight: bold;
	color: #fff;
	line-height: 1.5;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .top_cont .lead {
		font-size: 0.20rem;
	}
}



#mv .left_wrap .bottom_cont {
	margin-top: 0.60rem;
	color: #fff;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont {
		margin-top: 0.20rem;
	}
}


#mv .left_wrap .bottom_cont .title {
	font-size: 0.18rem;
	font-weight: 700;
	display: flex;
	align-items: center;
	margin-bottom: 0.20rem;
	position: relative;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .title {
		font-size: 0.14rem;
	}
}


#mv .left_wrap .bottom_cont .title span {
	display: inline-block;
	padding-right: 0.15rem;
	background-color: #06C755;
	position: relative;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .title span {
		padding-right: 0;
		border-bottom: 1px solid #fff;
		margin: auto;
		padding-bottom: 0.1rem;
	}
}


#mv .left_wrap .bottom_cont .title::after {
	content: '';
	width: 100%;
	height: 1px;
	background: #fff;
	position: absolute;
	left: 0;
	top: 50%;
	z-index: 0;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .title::after {
		content: none;
	}
}

#mv .left_wrap .bottom_cont .list .item {
	font-size: 0.18rem;
	font-weight: 700;
	line-height: 1.6;
	text-indent: -0.28rem;
	margin-left: 0.28rem;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .list .item {
		font-size: 0.12rem;
		margin-left: 0.42rem;
		margin-bottom: 0.10rem;
		text-align: left;
		display: inline-block;
		width: 2rem;
	}
}

#mv .left_wrap .bottom_cont .list .item::before {
	content: "";
	width: 0.28rem;
	height: 0.15rem;
	display: inline-block;
	background-image: url(../img/top/mv_check.svg);
	background-position: left center;
	background-repeat: no-repeat;
	background-size: contain;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .list .item::before {
		content: "";
		width: 0.13rem;
		height: 0.11rem;
		padding-right: 0.10rem;
	}
}


#mv .left_wrap .bottom_cont .company {
	width: 100%;
	max-width: 3.00rem;
	font-size: 0.18rem;
	font-weight: bold;
	display: inline-block;
	border: 2px solid #fff;
	border-radius: 0.50rem;
	box-sizing: border-box;
	padding: 0.10rem 0 0.12rem;
	margin-top: 0.30rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#mv .left_wrap .bottom_cont .company {
		width: 100%;
		max-width: 2.00rem;
		font-size: 0.12rem;
		margin-top: 0.10rem;
	}
}


/*============================
INTRODUCTION
============================*/
#intro {
	padding: 1.2rem 0;
	position: relative;
}

@media screen and (max-width: 640px) {
	#intro {
		padding-bottom: 0.65rem;
	}
	#intro .title_wrap .jp {
		line-height: 2;
	}
}

#intro .lead {
	font-size: 0.18rem;
	line-height: 2;
	letter-spacing: 0.03em;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#intro .lead {
		font-size: 0.15rem;
		text-align: left;
	}
}

/* バッチ */
#intro .prize_seal_wrap {
	margin-top: 0.50rem;
	display: flex;
	justify-content: center;
	align-items: center;
}

@media screen and (max-width: 640px) {
	#intro .prize_seal_wrap {
		flex-wrap: wrap;
		gap: 0.20rem;
		margin-top: 0.30rem;
	}
}

#intro .prize_seal_wrap .seal {
	padding: 0 0.15rem;
}

@media screen and (max-width: 640px) {
	#intro .prize_seal_wrap .seal {
		padding: 0;
	}
}

#intro .prize_seal_wrap .seal img {
	display: block;
	height: 1.30rem;
}

@media screen and (max-width: 640px) {
	#intro .prize_seal_wrap .seal img {
		height: 0.75rem;
	}
}

#intro .btn {
	text-align: center;
}

@media screen and (max-width: 640px) {
	#intro .btn a {
		margin-top: 0.40rem;
	}
}

#intro .btn a span::after {
	background: url(../img/top/link_icon.svg) no-repeat center;
	background-size: cover;
	width: 0.16rem;
	height: 0.13rem;
}

/* 装飾 */
#intro .deco01 {
	position: absolute;
	top: 1.13rem;
	left: -1.50rem;
}

@media screen and (max-width: 640px) {
	#intro .deco01 {
		top: -0.6rem;
		left: -0.80rem;
		z-index: -1;
	}
}


#intro .deco01 img {
	max-width: 3.40rem;
}



#intro .deco02 {
	position: absolute;
	top: 0.40rem;
	right: -0.70rem;
}

@media screen and (max-width: 640px) {
	#intro .deco02 {
		z-index: -1;
	}
}

#intro .deco01 img {
	max-width: 2.80rem;
}

@media screen and (max-width: 640px) {
	#intro .deco01 img {
		max-width: 1.40rem;
	}

	#intro .deco02 img {
		max-width: 1.50rem;
	}
}

/*============================
HISTORY
============================*/
#history {
	/* background: url(../img/top/history_bg.jpg) no-repeat center; */
	/* background-size: cover; */
	padding: 1.10rem 0;
	background-color: #FFF6F0;
}

@media screen and (max-width: 640px) {
	#history {
		padding: 0.30rem 0;
	}
}


#history .in {
	background: #fff;
	padding: 0.37rem 0 0.72rem;
	border-radius: 0.10rem;
	max-width: 12.00rem;
}

@media screen and (max-width: 640px) {
	#history .in {
		width: calc(100% - 0.40rem);
		margin: 0 auto;
		padding: 0.30rem 0.20rem;
	}
}


#history .list_wrap {
	display: flex;
}

@media screen and (max-width: 640px) {
	#history .list_wrap {
		flex-wrap: wrap;
	}
}

#history .list_wrap .list {
	width: 50%;
	padding-left: 0.45rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#history .list_wrap .list {
		width: 100%;
		padding-left: 0;
	}
}

#history .list_wrap .list:first-child {
	border-right: 1px solid #06C755;
}

@media screen and (max-width: 640px) {
	#history .list_wrap .list:first-child {
		border-right: none;
		margin-bottom: 0.30rem;
	}
}


#history .list_wrap .list .item {
	display: flex;
	margin-bottom: 0.30rem;
}

@media screen and (max-width: 640px) {
	#history .list_wrap .list .item {
		flex-wrap: wrap;
	}
}


#history .list_wrap .list .item:last-child {
	margin-bottom: 0;
}

#history .list_wrap .list .item .year {
	font-size: 0.26rem;
	color: #06C755;
	font-family: "Inter", sans-serif;
	padding-top: 0.03rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#history .list_wrap .list .item .year {
		font-size: 0.20rem;
		position: relative;
		width: 100%;
	}

	#history .list_wrap .list .item .year::after {
		width: 2.35rem;
		height: 1px;
		background: #21ab3d;
		content: '';
		display: block;
		position: absolute;
		top: 50%;
		right: 0;
		transform: translateY(-50%);
	}
}


#history .list_wrap .list .item .text {
	font-size: 0.14rem;
	line-height: 2;
	padding-left: 0.20rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#history .list_wrap .list .item .text {
		font-size: 0.13rem;
		padding-left: 0;
		padding-top: 0.06rem;
	}
}


#history .ph_wrap {
	box-sizing: border-box;
	padding: 0.20rem 0.50rem 0;
	margin: 0.5rem 0.5rem 0;
	border-radius: 0.10rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#history .ph_wrap {
		padding: 0;
		margin: 0.30rem 0 0;
	}
}


#history .ph_wrap img {
	width: 100%;
}



/*============================
VOICE
============================*/
@media screen and (max-width: 640px) {
		#voice .list .item {
		width: 2.40rem !important;
	}
}


/*============================
FUNCTION & SERVICE
============================*/
#service {
	padding: 1rem 0;
	background: rgba(45, 177, 99, 0.1);
	position: relative;
}

@media screen and (max-width: 640px) {
	#service {
		padding: 0.5rem 0 1rem;
	}
}


#service .cont_wrap {
	display: flex;
}

/* スライドコンテンツ */
.slick-list {
	overflow: unset;
}

#service .cont_wrap .slider {
	width: 8.40rem;
}

#service .cont_wrap .slider .cont_box {
	background: #fff;
	box-sizing: border-box;
	padding: 0.50rem 0.50rem 0;
	position: relative;
	height: 4.85rem;
	border-radius: 0.10rem;
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slider .cont_box {
		height: auto;
		padding: 0;
		margin-bottom: 0.20rem;
	}
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slider .cont_box .cont_wrap {
		display: none;
		box-sizing: border-box;
		padding: 0 0.20rem 0.20rem;
	}
}

#service .cont_wrap .slider .cont_box .cont_title {
	font-size: 0.26rem;
	font-weight: 500;
	color: #06C755;
	position: relative;
	z-index: 10;
	display: flex;
	align-items: center;
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slider .cont_box .cont_title {
		font-size: 0.18rem;
		display: block;
		background: #06C755;
		color: #fff;
		box-sizing: border-box;
		padding: 0.20rem;
		border-radius: 0.10rem;
		position: relative;
	}

	#service .cont_wrap .slider .cont_box .cont_title::before {
		content: '';
		width: 0.07rem;
		height: 0.125rem;
		background: url(../img/top/service_arrow.svg) no-repeat center;
		background-size: contain;
		position: absolute;
		right: 0.17rem;
		top: 50%;
		transform: translateY(-50%);
	}


	#service .cont_wrap .slider .cont_box .cont_title.open {
		border-radius: 0.10rem 0.10rem 0 0;
	}

	#service .cont_wrap .slider .cont_box .cont_title.open::before {
		transform: translateY(-50%) rotate(-180deg);
	}
}

#service .cont_wrap .slider .cont_box .cont_title::after {
	background-color: #06C755;
	/* 横線の色 */
	content: "";
	flex-grow: 1;
	/* 横幅いっぱい */
	height: 1px;
	/* 横線の高さ */
	margin-left: 0.10rem;
}

#service .cont_wrap .slider .cont_box .text_wrap {
	max-width: 4.00rem;
	width: 100%;
}

#service .cont_wrap .slider .cont_box .img_wrap {
	padding-top: 0.20rem;
	max-width: 4.00rem;
}

/* スクショ画像がないとき */
#service .cont_wrap .slider .cont_box .text_wrap.full {
	max-width: 100%;
}

#service .cont_wrap .slider .cont_box .text_wrap .text {
	font-size: 0.14rem;
	line-height: 2;
	margin-top: 0.23rem;
}

#service .cont_wrap .slider .cont_box .text_wrap .point_wrap {
	margin-top: 0.40rem;
	background-color: #F2F2F2;
	padding: 0.20rem 0.20rem 0.30rem;
	display: none;
}

#service .cont_wrap .slider .cont_box .text_wrap .point_wrap .point_title {
	font-size: 0.14rem;
	font-weight: 500;
	color: #FC6401;
	margin-top: -0.27rem;
}

#service .cont_wrap .slider .cont_box .text_wrap .point_wrap .point_text {
	font-size: 0.13rem;
	line-height: 2;
	margin-top: 0.15rem;
	letter-spacing: 0.04em;
}

#service .cont_wrap .slider .cont_box .ph_wrap {
	width: 2.63rem;
	height: 5.41rem;
	background-image: url(../img/top/service_phone.png);
	background-position: center;
	background-repeat: no-repeat;
	background-size: contain;
	position: absolute;
	right: 0.30rem;
	top: -0.30rem;
	z-index: 10;
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slider .cont_box .ph_wrap {
		width: 1.50rem;
		height: 3.06rem;
		position: relative;
		top: 0.2rem;
		right: auto;
		left: 50%;
		transform: translateX(-50%);
	}
}

#service .cont_wrap .slider .cont_box .ph_wrap .screen {
	width: calc(100% - 0.22rem);
	height: calc(100% - 0.20rem);
	position: absolute;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	border-radius: 0.30rem;
	overflow: hidden;
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slider .cont_box .ph_wrap .screen {
		border-radius: 0.10rem;
	}
}


#service .cont_wrap .slider .cont_box .ph_wrap .screen img,
#service .cont_wrap .slider .cont_box .ph_wrap .screen video {
	display: block;
	width: 100%;
	height: 100%;
	object-fit: cover;
}


/* ボタン */
#service .cont_wrap .slide_btn {
	width: calc(100% - 8.40rem);
	margin-left: 0.80rem;
}

@media screen and (max-width: 640px) {
	#service .cont_wrap .slide_btn {
		display: none;
	}
}

#service .cont_wrap .slide_btn .slick-slide {
	float: none;
	width: 100% !important;
}

#service .cont_wrap .slide_btn .slick-track {
	width: 100% !important;
}

#service .cont_wrap .slide_btn .slick-current {
	color: #06C755;
}

#service .cont_wrap .slide_btn p {
	font-size: 0.13rem;
	font-weight: 500;
	margin-bottom: 0.21rem;
	position: relative;
	padding-left: 0.30rem;
}

#service .cont_wrap .slide_btn p::before {
	content: '●';
	font-size: 0.12rem;
	position: absolute;
	left: 0.01rem;
	z-index: 2;
}

#service .cont_wrap .slide_btn p::after {
	content: '';
	width: 1px;
	height: 0.3rem;
	background: #06C755;
	position: absolute;
	top: 0.1rem;
	left: 0.06rem;
	z-index: 1;
}

#service .cont_wrap .slide_btn p.last::after {
	content: none;
}


#service .cont_wrap .slide_btn .slick-current p::before {
	color: #06C755;
	font-size: 0.15rem;
	left: 0;
}

/* 下部ボタン */
#service .btn {
	text-align: center;
	position: absolute;
	bottom: -0.25rem;
	left: 50%;
	transform: translateX(-50%);
	z-index: 10;
}

#service .btn a {
	background-color: #FC6401;
	box-shadow: 0px 0px 15px -5px #FC6401
}

@media screen and (max-width: 640px) {
	#service .btn a {
		width: 3.1rem;
	}
}



#service .btn a span::after {
	background: url(../img/top/btn_arrow_wh.svg) no-repeat center;
	background-size: cover;
	width: 0.07rem;
	height: 0.11rem;
}

@media screen and (max-width: 640px) {
	#service .btn a span::after {
		right: -0.6rem;
	}
}


/* 下部テキスト */
.bottom_text {
	font-family: "Poppins", sans-serif;
	font-size: 0.90rem;
	font-weight: 500;
	color: rgba(6, 199, 85, 0.1);
	position: absolute;
	bottom: 0;
	left: 0.20rem;
	z-index: 1;
}

@media screen and (max-width: 640px) {
	.bottom_text {
		font-size: 0.70rem;
		position: absolute;
		bottom: auto;
		top: 0.3rem;
		left: -0.10rem;
		z-index: -1;
		writing-mode: vertical-rl;
	}
}

/*============================
USE MORE
============================*/
#use {
	padding: 1rem 0 0;
}

#use .title_wrap {
	padding-bottom: 0;
}

#use .lead {
	font-size: 0.20rem;
	font-weight: bold;
	margin-bottom: 0.55rem;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#use .lead {
		font-size: 0.16rem;
		margin-bottom: 0.25rem;
		line-height: 1.6;
	}
}

#use .lead span {
	font-size: 0.25rem;
	color: #06C755;
	border-bottom: 3px solid #06C755;
	text-align: center;
}

@media screen and (max-width: 640px) {
	#use .lead span {
		font-size: 0.16rem;
	}
}


#use .bottom_wrap {
	background: #F2F2F2;
	padding-bottom: 0.50rem;
	margin-top: 1.05rem;
}

#use .bottom_wrap .cont_wrap {
	max-width: 10rem;
	margin: 0 auto;
	background: #fff;
	border: 3px solid #06C755;
	border-radius: 0.10rem;
	position: relative;
	top: -0.50rem;
	padding: 0.35rem 0.85rem 0.65rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap {
		margin: 0 0.2rem;
		padding: 0.30rem 0.20rem;
	}
}


#use .bottom_wrap .cont_wrap .sub_title_wrap {
	text-align: center;
}

#use .bottom_wrap .cont_wrap .sub_title_wrap span {
	font-size: 0.25rem;
	font-weight: bold;
	position: relative;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .sub_title_wrap span {
		font-size: 0.2rem;
	}
}


#use .bottom_wrap .cont_wrap .sub_title_wrap span::before {
	content: '';
	display: block;
	width: 0.15rem;
	height: 0.23rem;
	background: url(../img/top/use_sarani_deco_01.svg) no-repeat center;
	position: absolute;
	left: -0.30rem;
	bottom: 0.05rem;
}

#use .bottom_wrap .cont_wrap .sub_title_wrap span::after {
	content: '';
	display: block;
	width: 0.15rem;
	height: 0.23rem;
	background: url(../img/top/use_sarani_deco_02.svg) no-repeat center;
	position: absolute;
	right: -0.30rem;
	bottom: 0.05rem;
}

#use .bottom_wrap .cont_wrap .sub_title_wrap .tit_wrap {
	display: flex;
	justify-content: center;
	align-items: center;
	text-align: left;
	padding-top: 0.20rem;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .sub_title_wrap .tit_wrap {
		flex-wrap: wrap;
		flex-flow: column-reverse;
		padding-top: 0.1rem;
	}
}

#use .bottom_wrap .cont_wrap .sub_title_wrap .tit_wrap .icon {
	width: 2.50rem;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .sub_title_wrap .tit_wrap .icon {
		width: 100%;
		max-width: 2.20rem;
		margin: auto;
	}
}


#use .bottom_wrap .cont_wrap .sub_title_wrap .tit_wrap .icon img {
	width: 100%;
}

#use .bottom_wrap .cont_wrap .sub_title_wrap .title {
	font-size: 0.26rem;
	margin-left: 0.20rem;
	font-weight: bold;
	color: #06C755;
	line-height: 1.4;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .sub_title_wrap .title {
		width: 100%;
		font-size: 0.18rem;
		margin-left: 0;
		text-align: center;
		margin-bottom: 0.15rem;
	}
}

#use .bottom_wrap .cont_wrap .bottom_lead {
	font-size: 0.16rem;
	line-height: 2;
	margin-top: 0.20rem;
	margin-bottom: 0.30rem;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .bottom_lead {
		font-size: 0.14rem;
		margin-top: 0.10rem;
		margin-bottom: 0.25rem;
	}
}


#use .bottom_wrap .cont_wrap .list {
	display: flex;
	gap: 0 0.40rem;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .list {
		flex-wrap: wrap;
		gap: 0.20rem 0;
	}
}


#use .bottom_wrap .cont_wrap .list .item {
	width: calc(100% / 3);
	background: #E5F9ED;
	border-radius: 0.10rem;
	padding: 0.20rem 0.3rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#use .bottom_wrap .cont_wrap .list .item {
		width: 100%;
		padding: 0.20rem 0.3rem;
	}
}


#use .bottom_wrap .cont_wrap .list .item:nth-child(2) {
	background: #E5F1F9;
}

#use .bottom_wrap .cont_wrap .list .item .ph_wrap {
	text-align: center;
	margin-bottom: 0.15rem;
}

#use .bottom_wrap .cont_wrap .list .item .list_title {
	text-align: center;
	font-size: 0.16rem;
	font-weight: bold;
	margin-bottom: 0.10rem;
}

#use .bottom_wrap .cont_wrap .list .item .text {
	font-size: 0.12rem;
	line-height: 1.6;
}

/*============================
Advertising
============================*/
#advertising {
	padding: 1rem 0 0;
}

@media screen and (max-width: 640px) {
	#advertising {
		padding: 0.5rem 0;
	}
}


#advertising .lead {
	font-size: 0.16rem;
	line-height: 2;
	text-align: center;
	margin-bottom: 0.40rem;
}

@media screen and (max-width: 640px) {
	#advertising .lead {
		font-size: 0.14rem;
		margin-bottom: 0.10rem;
		text-align: left;
	}
}


#advertising .ph_wrap {
	max-width: 10.00rem;
	width: 100%;
	margin: 0 auto;
}

#advertising .btn {
	text-align: center;
}

#advertising .btn a {
	background-color: #FC6401;
	box-shadow: 0px 0px 15px -5px #FC6401
}

@media screen and (max-width: 640px) {
	#advertising .btn a {
		margin-top: 0.30rem;
	}
}

#advertising .btn a span::after {
	background: url(../img/top/btn_arrow_wh.svg) no-repeat center;
	background-size: cover;
	width: 0.07rem;
	height: 0.11rem;
}

/* 広告 */
#advertising .koukoku {
	background: url(../img/top/advertising_back.png) no-repeat center;
	background-size: cover;
	padding: 0.95rem 0;
	box-sizing: border-box;
	margin-top: 1.00rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku {
		padding: 0.5rem 0;
		box-sizing: border-box;
		margin-top: 0.5rem;
	}
}


#advertising .koukoku .list {
	display: flex;
	gap: 0 0.40rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list {
		display: block;
	}
}

#advertising .koukoku .list .item {
	width: calc(100% / 3);
	background: #fff;
	box-sizing: border-box;
	padding: 0 0.30rem;
	height: 4.8rem;
	border-radius: 0.10rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list .item {
		padding: 0 0.20rem;
		height: 5rem;
		max-width: 3.15rem;
		margin: 0 0.10rem;
	}
}


#advertising .koukoku .list .item .title {
	max-width: 3rem;
	text-align: center;
	color: #fff;
	background-color: #06C755;
	border-radius: 0.3rem;
	font-size: 0.22rem;
	font-weight: bold;
	box-sizing: border-box;
	padding: 0.15rem 0;
	display: block;
	margin: -0.20rem auto 0;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list .item .title {
		max-width: 2.6rem;
		font-size: 0.18rem;
		letter-spacing: 0;
	}
}

#advertising .koukoku .list .item .ph_wrap {
	text-align: center;
	margin-top: 0.40rem;
}

#advertising .koukoku .list .item .ph_wrap img {
	height: 1.77rem;
	width: auto;
	margin: auto;
}

#advertising .koukoku .list .item .text {
	font-size: 0.16rem;
	line-height: 2;
	margin-top: 0.40rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list .item .text {
		font-size: 0.14rem;
		margin-top: 0.20rem;
	}
}


#advertising .koukoku .list .item .btn_common {
	position: absolute;
	bottom: 0.40rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list .item .btn_common {
		bottom: 0.20rem;
	}
}

#advertising .koukoku .list .item .btn_common a {
	width: 3.05rem;
}

@media screen and (max-width: 640px) {
	#advertising .koukoku .list .item .btn_common a {
		width: 2.7rem;
	}
}

#advertising .slider .slick-slide {
	margin-right: 0.2rem !important;
	margin-left: 0.2rem !important;
}

/* slick */
#advertising .slick-slider .slick-track, .slick-slider .slick-list {
	padding: 0 !important;
}

#advertising .slick-dots {
	bottom: -0.35rem;
}

#advertising .slick-dots li.slick-active button:before {
	color: #06C755;
}


/*============================
PLANS
============================*/
#plans {
	padding: 1rem 0;
}

@media screen and (max-width: 640px) {
	#plans {
		padding: 0.5rem 0 0.20rem;
	}
}

#plans .lead {
	text-align: center;
	font-size: 0.16rem;
}

#plans .btn_common {
	text-align: center;
}

#plans .btn_common a {
	margin-top: 0.20rem;
}

.plan_table {
	text-align: center;
	font-size: 0.15rem;
	line-height: 1.6;
	background: #CCC;
}

@media screen and (max-width: 640px) {
	.plan_table {
		font-size: 0.14rem;
	}
}




.plan_table table {
	width: 100%;
}

@media screen and (max-width: 640px) {
	.plan_table table {
		width: 100%;
	}

	.plan_table {
		overflow: auto;
		white-space: nowrap;
	}

	.plan_table::-webkit-scrollbar {
		height: 4px;
	}

	.plan_table::-webkit-scrollbar-track {
		background: #F1F1F1;
	}

	.plan_table::-webkit-scrollbar-thumb {
		background: #BCBCBC;
	}
}

.plan_table tr {
	background: #fff;
}

.plan_table th {
	background: #F1F1F1;
	text-align: left;
}

.plan_table .plan_title th {
	background: #21ab3d;
	color: #fff;
}

.plan_table th,
.plan_table td {
	padding: 0.1rem;
	font-weight: normal;
}

.plan_table th.plan_th {
	text-align: center;
	width: 19%;
}

.plan_table span {
	font-size: 0.12rem;
}

.plan_table strong {
	font-size: 0.2rem;
}

/* テーブル下の注意書き */
.plan_table_caption {
	padding-top: 0.1rem;
}

.plan_table_caption .title {
	font-size: 0.16rem;
	font-weight: bold;
	margin: 0.15rem 0;
}

@media screen and (max-width: 640px) {
	.plan_table_caption .title {
		font-size: 0.14rem;
	}
}

.plan_table_caption li {
	font-size: 0.13rem;
}

@media screen and (max-width: 640px) {
	.plan_table_caption li {
		font-size: 0.11rem;
	}
}

ul.caption {
	font-size: 0.14rem;
	line-height: 1.7;
	margin-left: 0.2rem;
	padding-bottom: 0.2rem;
}

ul.caption li {
	padding-bottom: 0.1rem;
}

ul.caption li::before {
	content: "※";
	padding-right: 0.04rem;
	margin-left: -0.18rem;
	text-indent: -0.12rem;
}


/*============================
QUESTIONS & ANSWERS
============================*/
#faq {
	padding: 0.60rem 0 0.40rem;
	background-color: #FFF6F0;
}

@media screen and (max-width: 640px) {
	#faq {
		padding: 0.50rem 0;
	}
}

#faq .faq_wrap dl {
	background-color: #fff;
	margin-bottom: 0.30rem;
}

#faq .faq_wrap dt {
	position: relative;
	font-size: 0.18rem;
	line-height: 1.75;
	font-weight: 500;
	padding: 0.20rem;
	position: relative;
	cursor: pointer;
	transition: all 0.3s;
	border-bottom: 1px solid #FC6401;
	padding-left: 0.50rem;
}

@media screen and (max-width: 640px) {
	#faq .faq_wrap dt {
		font-size: 0.15rem;
	}
}

#faq .faq_wrap dt::before {
	content: "Q.";
	font-size: 0.18rem;
	font-weight: 400;
	display: inline-block;
	padding-right: 0.10rem;
	color: #FC6401;
	position: absolute;
	left: 0.2rem;
	top: 0.19rem;

}

#faq .faq_wrap dd {
	position: relative;
	margin-top: 0.02rem;
	padding: 0.20rem;
	padding-left: 0.16rem;
	font-size: 0.16rem;
	line-height: 2;
	margin-left: 0.3rem;
	box-sizing: border-box;
}

@media screen and (max-width: 640px) {
	#faq .faq_wrap dd {
		font-size: 0.14rem;
	}
}


#faq .faq_wrap dd::before {
	content: "A.";
	font-size: 0.18rem;
	font-weight: 400;
	display: inline-block;
	padding-right: 0.10rem;
	color: #06C755;
	position: absolute;
	left: -0.1rem;
	top: 0.19rem;
}

#faq .faq_wrap dd a {
	text-decoration: underline;
	color: #FC6401;
	word-break: break-all;
}


