@charset "utf-8";


/* ---------------------------------------
* common
------------------------------------------ */

.btn.sp,.sp{
	display: none;
}

svg{
	width: 100%;
	height: 100%;
}

:root {
	--primary: #1A73F0;
	--secondary: #091A52;
	--thirdry: #003FAB;
	--accent: #FF550D;
	--accent: #FF550D;
	--font-b: #091A52;
	--font-gray: #999999;
	--border: #EEF3FC;
}

.tac{
	text-align: center;
}

/* ---------------------------------------
* TOP
------------------------------------------ */

.fv{
	position: relative;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	background-image: url(../img/top/fvbg.png);
}

.fvBottom{
	position: absolute;
	left:0 ;
	bottom: 0;
}

.fvWrap{
	padding: 16rem 4rem 22rem 18rem;
}

.fvTxtWrap{
	width: 34.4%;
}

.fvTtl>p{
	padding-bottom: 1rem;
	font-size: clamp(12px,2rem,24px);
}

.fvTtl h2 p{
	font-size: clamp(40px,5.6rem,64px);
	line-height: 1.4;
}

.fvTxtWrap>p{
	padding-top: 1.6rem;
	font-size: clamp(10px,1.4rem,16px);
}

.fvImg{
	width: 59.6%;
}

.fvBtn-list{
	column-gap: 1rem;
}

.fvBtn-listItem{
	width: fit-content;
}

.fvBtn-listItem a{
	padding: .8rem 1rem .8rem 2rem;
	border-radius: 5px;
	background-color: var(--accent);
	border: solid 1px var(--accent);
	transition: all .3s;
}

.fvBtn-listItem:last-of-type a{
	background-color: var(--primary);
	border: solid 1px var(--primary);
}

.fvBtn-listItem a:hover{
	background-color: #fff;
}

.fvBtn-listItem a p{
	color: #fff;
	font-size: clamp(10px,1.4rem, 16px);
	padding-right: 6rem;
	transition: all .3s;
}

.fvBtn-listItem a:hover p{
	color: var(--accent);
}

.fvBtn-listItem:last-of-type a:hover p{
	color: var(--primary);
}

.fvBtn-listItem a:hover rect,.fvBtn-listItem a:hover path{
	fill: var(--accent);
}


.fvBtn-listItem:last-of-type a:hover rect,.fvBtn-listItem:last-of-type a:hover path{
	fill: var(--primary);
}


.problem-l{
	width: 45%;
}

.problem-l h2{
	position: sticky;
	top: 10rem;
}

.problem-r{
	width: 54.5%;
}

.problem-listItem{
	padding: 6rem 4rem 0;
	border-top: solid 1px var(--border);
}

.problem-listItem:not(:last-of-type){
	margin-bottom: 6rem;
}

.problem-listTxt>p{
	padding-bottom: 0.8rem;
	font-size: clamp(10px,1.4rem,16px);
	color: var(--font-gray);
}

.problemImg{
	width: 56.25%;
	padding: 3rem 0 2.4rem;
}

.problem-listDetail p{
	width: 78.125%;
}

.aboutWrap{
	padding-right: 14rem;
}

.about-l{
	padding-top: 1rem;
	font-size: clamp(10px,1.4rem,16px);
	color: var(--thirdry);
}

.about-r{
	width: 65.5%;
}

.aboutVideo{
	width: 100%;
	padding-top: 56.25%;
	position: relative;
	margin: 3rem 0 2.4rem;
}

.aboutVideo video{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.t-example{
	overflow: hidden;
}

.exampleCont{
	position: relative;
	overflow: hidden;
}

.exampleSwiper{
	overflow: visible;
}

.exttlWrap>p{
	padding-top: 2rem;
}

.ex-listItem{
	width: 67rem!important;
	padding: 4rem 4rem 3rem;
	background-color: #fff;
	border-radius: 10px;
}

.ex-listItem>p{
	font-size: clamp(10px,1.8rem,20px);
	padding-bottom: 1.6rem;
	margin-bottom: 2rem;
	border-bottom: solid 1px var(--border);
}

.exdetail p{
	padding-left: 4.4rem;
	position: relative;
}

.exdetail p::before{
	content: "";
	display: block;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(../img/top/icon.svg);
	width: 3.6rem;
	height: 3.6rem;
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}

.exdetail p span{
	display: inline-block;
	background-color: var(--secondary);
	padding: .2rem 1rem;
	border-radius: 100px;
	color: #fff;
}

.exImg{
	padding: 2.4rem 0 3rem;
}

.exeffort{
	position: relative;
	padding: 0 3rem;
	align-items: flex-end;
}

.exeffort::after{
	content: "";
	display: block;
	width: 8rem;
	height: .5rem;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(../img/top/arrow.png);
	position: absolute;
	left: 50%;
	bottom: 1.2rem;
	transform: translateX(-50%);
}

.exeffortdetail{
	column-gap: 1rem;
	align-items: flex-end;
}

.exeffortdetail p:first-of-type{
	color: var(--font-gray);
	font-size: clamp(10px,1.2rem,14px);
	padding-bottom: 0.6rem;
}

.exeffortdetail p:last-of-type{
	font-size: clamp(10px,1.8rem,20px);
}

.exeffortdetail p:last-of-type span{
	font-size: clamp(12px,2rem,22px);
	padding: 0 .4rem;
	line-height: 1;
}

.exeffortdetail p:last-of-type span.large{
	font-size: clamp(24px,4rem,48px);
	padding: 0 .4rem;
}

/* progress bar */
.exampleProgress.swiper-pagination-progressbar{
	position: relative;
	left: auto;
	top: auto;
	bottom: auto;
	width: 100%;
	height: 1px;
	margin-top: 3rem;
	background-color: var(--border);
}

.exampleProgress.swiper-pagination-progressbar .swiper-pagination-progressbar-fill{
	background-color: var(--primary);
	height: 3px;
}

.t-feature{
	background-color: var(--primary);
}

.featureTxtWrap>p,.howTxtWrap>p{
	padding-top: 2rem;
}

.feature-list{
	padding-left: 14rem;
}

.feature-listImg{
	width: 44.26%;
}

.feature-listTxt{
	width: 45.9%;
}

.feature-listTtl>p{
	display: inline-block;
	margin-bottom: 1.6rem;
	padding-bottom: 0.1rem;
	border-bottom: solid 1px #fff;
}

.feature-listTxt>p{
	padding: 2.4rem 0 4rem;
}

.f-effort>p{
	font-size: clamp(10px,1.8rem,20px);
	line-height: 1;
	padding-bottom: 2rem;
}

.f-effort>p span{
	padding: 0 .2rem;
	font-size: clamp(20px,3.2rem,40px);
}

.f-effort>p span.sans-en{
	font-size: clamp(24px,4rem,48px);
	letter-spacing: -0.06em;
	font-weight: 100;
}

.f-effort-list{
	width: 65%;
}

.f-effort-listItem{
	padding: 1.2rem 2rem;
	border-radius: 100px;
	background-color: var(--secondary);
}

.f-effort-listItem:not(:last-of-type){
	margin-bottom: 1rem;
}

.f-effort-listItem p{
	padding-left: 3.2rem;
	position: relative;
}

.f-effort-listItem p::before{
	content: "";
	display: block;
	width: 2.4rem;
	height: 2.4rem;
	background-repeat: no-repeat;
	background-size: 100% 100%;
	background-image: url(../img/top/check.svg);
	position: absolute;
	left: 0;
	top: 50%;
	transform: translateY(-50%);
}

.howWrap{
	width: 100%;
	max-width: 106rem;
	margin: 0 auto;
}

.how-list{
	border-radius: 10px;
	padding: 6rem 0;
	position: relative;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	background-image: url(../img/top/howbg.png);
}

.how-list::after{
	content: "";
	display: block;
	width: calc(100% - 4rem);
	height: 100%;
	background-color: var(--primary);
	position: absolute;
	left: 0;
	right: 0;
	bottom: -2rem;
	border-radius: 10px;
	margin: 0 auto;
	z-index: -1;
}

.howImg{
	width: 60%;
	margin: 3rem auto 0;
	border-radius: 20px;
	border: solid 10px var(--primary);
	box-shadow: 15px 15px var(--secondary);
}

.howVideo{
	position: relative;
	padding-top: 32.375%;
}

.howVideo video{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
	-o-object-fit: cover;
	object-fit: cover;
}

.howImg img{
	border-radius: 12px;
}

.howStep {
	display: grid;
	grid-template-columns: repeat(3, 1fr);
	width: 100%;
	margin: 0 auto 4rem;
	padding: 0 .7rem;
	position: relative;
	background-color: var(--secondary);
	border-radius: 5px;
}

.howStepItem {
	appearance: none;
	border: none;
	background-color: transparent;
	color: var(--primary);
	font: inherit;
	cursor: pointer;
	position: relative;
	height: 4.8rem;
	padding: 0 2.4rem;
	border-radius: 5px;
	background-color: #fff;
	border-top: solid 5px var(--secondary);
	border-bottom: solid 5px var(--secondary);
	display: flex;
	align-items: center;
	justify-content: center;
	overflow: hidden;
	clip-path: polygon(
		0 0,
		calc(100% - 2rem) 0,
		100% 50%,
		calc(100% - 2rem) 100%,
		0 100%,
		2rem 50%
	);
	margin-left: -1.2rem;
	transition: color 0.3s ease;
}

.howStepItem:first-of-type {
	margin-left: 0;
}


/* 完了・アクティブの背景 */
.howStepItem::before {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	background-color: var(--primary);
	position: absolute;
	left: 0;
	top: 0;
	z-index: 1;
	opacity: 0;
	transition: opacity 0.25s ease;
}

/* アクティブタブ内の進行バー */
.howStepItem::after {
	content: "";
	display: block;
	width: calc(var(--how-progress, 0) * 100%);
	height: 0.3rem;
	background-color: #fff;
	position: absolute;
	left: 0;
	bottom: 0;
	z-index: 3;
	opacity: 0;
	transition: width 0.05s linear;
}

.howStepItem.is-active,
.howStepItem.is-done {
	color: #fff;
}

.howStepItem.is-active::before,
.howStepItem.is-done::before {
	opacity: 1;
}

.howStepItem.is-active::after {
	opacity: 1;
}

.howStepItem span {
	position: relative;
	z-index: 2;
	font-size: clamp(10px, 1.4rem, 16px);
	line-height: 1.4;
	white-space: nowrap;
}

/* slide area */
.how-list {
	display: grid;
	position: relative;
	/* overflow: hidden; */
}

/* 全スライドを同じグリッド位置に重ねる */
.how-listItem {
	grid-area: 1 / 1;
	width: 100%;
	opacity: 0;
	visibility: hidden;
	pointer-events: none;
	transform: translate3d(0, 4rem, 0) scale(0.985);
	will-change: opacity, transform;
}

/* visibility:hidden なので非表示でも高さ計算には含まれる */
.how-listItem.is-active {
	opacity: 1;
	visibility: visible;
	pointer-events: auto;
	transform: translate3d(0, 0, 0) scale(1);
	z-index: 2;
}

.how-listItem.is-entering {
	visibility: visible;
	z-index: 3;
}

.how-listItem.is-leaving {
	visibility: visible;
	z-index: 1;
}

.howImg {
	margin-top: 3rem;
}

.howImg img {
	width: 100%;
	height: auto;
	display: block;
}


.t-benefit{
	overflow: hidden;
	background-color: var(--primary);
}

.benefit-l,.benefit-r{
	width: 50%;
}

.benefitVoice {
	overflow: hidden;
}

.benefit-listItem{

	padding-top: 1.6rem;
	border-top: solid 1px #fff;
	width: calc(50% - 1rem);
}

.benefit-listItem:not(:last-of-type){
	margin-bottom: 2rem;
}

.benefit-listItem:nth-of-type(2){
	margin-left: auto;
	margin-bottom: 3rem;
}

.benefit-listItem p:first-of-type span{
	display: inline-block;
	line-height: 1;
	font-size: clamp(24px,3.2rem,40px);
}

.benefit-listItem p:first-of-type span:first-of-type{
	font-size: clamp(64px,8rem,88px);
}

.benefit-listItem p:last-of-type{
	padding-top: 0.8rem;
	font-size: clamp(10px,1.4rem,16px);
}

.benefitVoice-list{
	width: max-content;
	flex-wrap: nowrap;
	column-gap: 2rem;
	will-change: transform;
	animation: benefitVoiceLoop var(--benefit-voice-duration, 70s) linear infinite;
}

.benefitVoice-listItem{
	border-radius: 10px;
	background-color: var(--thirdry);
	padding: 4rem 3rem;
	flex: 0 0 33rem;
}

.benefitVoice-list:hover {
	animation-play-state: paused;
}

@keyframes benefitVoiceLoop {
	from {
		transform: translate3d(0, 0, 0);
	}

	to {
		transform: translate3d(calc(var(--benefit-voice-distance, 0px) * -1), 0, 0);
	}
}


.benefitVoiceInfo{
	padding: 2rem 0;
}

.benefitVoiceInfo p:first-of-type{
	padding-bottom: 0.4rem;
}

.benefitVoiceInfo p span{
	font-size: clamp(10px,1.2rem,14px);
}

.benefitVoiceInfo p span:first-of-type{
	opacity: .6;
}

.benefitVoice-listItem>p{
	font-size: clamp(10px,1.4rem,16px);
}

.t-cv{
	padding: 10rem 8rem;
	background-repeat: no-repeat;
	background-size: cover;
	background-position: center;
	background-image: url(../img/common/cvbg.png);
}

.t-cv-l{
	width: 50%;
}

.t-cv-r{
	position: relative;
	width: 43.75%;
}

.t-cvIcon{
	width: 25%;
	position: absolute;
	right: -4rem;
	top: -6rem;
}

.t-cv-r a{
	display: block;
	padding: 4rem 3rem 3rem;
	background: #EFF6FE;
	background: linear-gradient(90deg, rgba(239, 246, 254, 1) 0%, rgba(249, 251, 254, 1) 52%, rgba(239, 246, 254, 1) 100%);
}

.t-cvcont{
	padding-top: 3rem;
	align-items: flex-end;
}

.t-cvImg{
	width: 32%;
}

.t-cvArrow{
	display: inline-block;
	border-radius: 3px;
	padding: .8rem 2.4rem;
	background-color: var(--secondary);
}

.t-cvArrow span{
	display: block;
	width: 1.2rem;
	height: 1.2rem;
	position: relative;
}

.t-cvArrow span svg{
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}

.t-case{
	background-repeat: no-repeat;
	background-size: cover;
	background-image: url(../img/top/casebg.png);
}

.priceWrap{
	padding: 0 4rem;
}

.priceCont>p,.planCompare p{
	padding-top: 1rem;
	color: var(--font-gray);
	font-size: clamp(10px,1.2rem,1.4rem);
}

.pricehead{
	padding: 2rem 0;
	background-color: var(--primary);
	margin-bottom: 2.4rem;
	justify-content: center;
	border-radius: 5px;
}

.pricehead p{
	font-size: clamp(16px,2.4rem,28px);
	line-height: 1;
}

.pricehead p:first-of-type{
	padding-top: 2.1rem;
}

.pricehead p:last-of-type{
	padding: 0  0 1.6rem 3rem;
	margin-left: 3rem;
	border-left: solid 1px #fff;
}

.pricehead p span{
	display: inline-block;
	line-height: 1;
	padding: .3rem .2rem 0;
	font-size: clamp(32px,4.8rem,46px);
}

.price-list{
	column-gap: 4rem;
}

.price-listItem{
	width: calc((100% - (4rem * 1)) / 2);
	background-color: #fff;
	padding: 6rem 6rem 4rem;
	border-radius: 5px;
}

.price-listItem:last-of-type{
	position: relative;
	border: solid 1px var(--primary);
}

.recommend{
	position: absolute;
	left: 0;
	top: -1px;
	width: 100%;
	background-color: var(--primary);
	padding: 1rem 0;
	line-height: 1;
	border-radius: 5px 5px 0 0;
	font-weight: 600;
}

.price-listTtl p:first-of-type{
	color: var(--primary);
	font-size: clamp(10px,1.8rem,2rem);
	padding-bottom: 1rem;
}

.price{
	justify-content: center;
	align-items: flex-end;
}

.price span{
	display: inline-block;
	line-height: 1;
	padding-bottom: 0.2rem;
}

.price span:first-of-type{
	font-size: clamp(16px,3.2rem,36px);
}

.price span:nth-of-type(2){
	font-size: clamp(24px,4.8rem,56px);
	padding: 0 .2rem 0;
}

.price span:last-of-type{
	font-size: clamp(10px,2rem,34px);
}

.priceShoki{
	padding-top: 1.6rem;
	font-size: clamp(10px,1.4rem,16px);
	color: var(--font-gray);
}

.priceBtn{
	margin: 2rem 0 3rem;
	display: block;
	text-align: center;
	color: #fff;
	padding: 2rem 0;
	background-color: var(--primary);
	border: solid 1px var(--primary);
	font-size: clamp(10px,1.6rem,18px);
	border-radius: 5px;
	transition: all .3s;
}

.priceBtn.trial{
	background-color: var(--accent);
	border: solid 1px var(--accent);
}

.priceBtn:hover{
	color: var(--primary);
	background-color: #fff;
}

.priceBtn.trial:hover{
	color: var(--accent);
	background-color: #fff;
}

.priceOther{
	column-gap: 2rem;
}

.priceFunction{
	width: calc((100% - (2rem * 1)) / 2);
}

.priceFunction>p{
	font-weight: 600;
	font-size: clamp(10px,1.4rem,16px);
	border-bottom: solid 1px #EEF3FC;
	color: var(--font-gray);
	padding-bottom: 1rem;
	margin-bottom: 1.6rem;
}

.function-listItem:not(:last-of-type){
	margin-bottom: 1.6rem;
}

.function-listIcon{
	width: 1.8rem;
	height: 1.8rem;
	position: relative;
}

.function-listIcon svg{
	width: 100%;
	height: 100%;
	position: absolute;
	left: 0;
	top: 0;
}

.function-listItem p{
	font-size: clamp(10px,1.4rem,16px);
	color: var(--font-gray);
	padding-left: 1rem;
}

.faq-l{
	width: 40%;
}

.faq-r{
	width: 58.8%;
}

.faq-defList{
	padding: 3rem;
	background-color: #fff;
	border-radius: 10px;
}

.faq-defList:not(:last-of-type){
	margin-bottom: 1rem;
}

.faq-defTtl{
	column-gap: 1rem;
	padding-bottom: 1.6rem;
	margin-bottom: 1.6rem;
	border-bottom: solid 1px var(--border);
}

.faq-defTtl p{
	font-weight: 400;
}

.faq-defTtl p:first-of-type{
	padding-top: 0.3rem;
	line-height: 1;
	font-size: clamp(10px,1.8rem,20px);
	color: var(--primary);
}	

.faq-defDesc{
	font-size: clamp(10px,1.4rem,16px);
}

@media screen and (max-width:768px) {

	/* ---------------------------------------
	* common
	------------------------------------------ */

	.btn.sp,.sp{
		display: block;
	}

	.btn.pc,.pc{
		display: none;
	}

	/* ---------------------------------------
	* TOP
	------------------------------------------ */

	.fv{
		background-image: url(../img/top/fvbg-sp.png);
	}

	.fvBottom{
		position: absolute;
		left:0 ;
		bottom: 0;
	}

	.fvWrap{
		padding: 10rem 2rem 10rem;
	}

	.fvTxtWrap{
		text-align: center;
		width: 100%;
	}

	.fvTtl>p{
		padding-bottom: 1rem;
		font-size: 1.4rem;
	}

	.fvTtl h2 p{
		font-size: 3.2rem;
	}

	.fvTxtWrap>p{
		padding-top: 1.6rem;
		font-size: 1.2rem;
	}

	.fvImg{
		width: 100%;
		padding-top: 3rem;
	}

	.fvBtn-list{
		column-gap: 1rem;
	}


	.fvBtn-listItem a{
		padding: .8rem .8rem .8rem 1.6rem;
	}

	.fvBtn-listItem a p{
		font-size: 1.4rem;
		padding-right: 6rem;
	}

	.fvBtn-listItem a:hover p{
		color: var(--accent);
	}

	.fvBtn-listItem:last-of-type a:hover p{
		color: var(--primary);
	}

	.fvBtn-listItem a:hover rect,.fvBtn-listItem a:hover path{
		fill: var(--accent);
	}


	.fvBtn-listItem:last-of-type a:hover rect,.fvBtn-listItem:last-of-type a:hover path{
		fill: var(--primary);
	}


	.problem-l{
		width: 100%;
		text-align: center;
	}

	.problem-l h2{
		position: unset;
	}

	.problem-r{
		padding-top: 3rem;
		width: 100%;
	}

	.problem-listItem{
		position: relative;
		padding: 1.6rem 0 0;
	}

	.problem-listItem:not(:last-of-type){
		margin-bottom: 4rem;
	}

	.problem-listTxt>p {
		font-size: 1rem;
	}

	.problem-listTxt .mainTtl02{
		margin-top: 10rem;
	}

	/* .problem-listTxt .mainTtl02 p{
	font-size: 2rem;
} */

	.problem-listDetail{
		padding-top: 1.6rem;
	}

	.problem-listDetail p{
		font-size: 1.2rem;
	}
	.problemImg{
		width: 50%;
		position: absolute;
		right: 0;
		top: 2rem;
		padding: 0;
	}

	.problem-listDetail p{
		width: 100%;
		font-size: 1.2rem;
	}

	.aboutWrap{
		padding-right: 0;
		text-align: center;
	}

	.about-l{
		padding-top: 0;
		font-size: 1rem;
		padding-bottom: 0.8rem;
		/* text-align: center; */
	}

	.about-r{
		width: 100%;
	}

	/* .about-r .mainTtl02{
	text-align: center;
} */

	.aboutVideo{
		width: 100%;
	}

	.about-r>p{
		font-size: 1.2rem;
	}

	.exttlWrap>p{
		padding-top: 2rem;
		font-size: 1.2rem;
	}

	.ex-listItem{
		width: 100%!important;
		padding: 3rem 2rem 2rem;
	}

	.ex-listItem>p{
		font-size: 1.6rem;
		padding-bottom: 1.6rem;
		margin-bottom: 2rem;
	}

	.exdetail p{
		padding-left: 3.8rem;
	}

	.exdetail p::before{
		width: 3rem;
		height: 3rem;
	}

	.exdetail p span{
		font-size: 1rem;
		padding: .4rem 1.6rem;
	}

	.exImg{
		padding: 2.4rem 0 3rem;
	}

	.exeffort{
		position: relative;
		padding: 0 0;
	}

	.exeffort::after{
		content: "";
		display: block;
		width: .3rem;
		height: 3rem;
		background-repeat: no-repeat;
		background-size: 100% 100%;
		background-image: url(../img/top/arrow02.png);
		position: absolute;
		left: 50%;
		top: 50%;
		bottom: unset;
		transform: translateY(-60%) translateX(-50%);
	}

	.exeffortdetail{
		column-gap: 1rem;
		align-items: flex-end;
		justify-content: center;
	}

	.exeffortdetail:first-of-type{
		padding-bottom: 4rem;
	}

	.exeffortdetail p:first-of-type{
		font-size: 1rem;
		padding-bottom: 0.4rem;
	}

	.exeffortdetail p:last-of-type{
		font-size: 1.4rem;
	}

	.exeffortdetail p:last-of-type span{
		font-size: 1.8rem;
		padding: 0 .4rem;
		line-height: 1;
	}

	.exeffortdetail p:last-of-type span.large{
		font-size: 3.2rem;
		padding: 0 .4rem;
	}

	/* .t-feature{
	background-image: url(../img/top/featurebg.png);
} */

	.featureTxtWrap>p,.howTxtWrap>p{
		padding-top: 2rem;
		font-size: 1.2rem;
	}

	.feature-list{
		padding-left: 0;
		padding: 4rem 2rem 0;
	}

	.feature-listItem:not(:last-of-type){
		margin-bottom: 6rem;
	}

	.feature-listImg{
		width: 100%;
	}

	.feature-listTxt{
		width: 100%;
		padding: 2.4rem 1.6rem 0;
	}

	.feature-listTxt>p{
		padding: 2rem 0 3.2rem;
	}

	.f-effort>p{
		font-size: 1.4rem;
		line-height: 1;
		padding-bottom: 2rem;
	}

	.f-effort>p span{
		font-size: 2rem;
	}

	.f-effort>p span.sans-en{
		font-size: 4rem;
	}

	.f-effort-list{
		width: 100%;
	}

	.f-effort-listItem{
		padding: 1.2rem 2rem;
	}

	.f-effort-listItem:not(:last-of-type){
		margin-bottom: 1rem;
	}

	.f-effort-listItem p{
		padding-left: 2.4rem;
		position: relative;
		font-size: 1.2rem;
	}

	.f-effort-listItem p::before{
		width: 1.6rem;
		height: 1.6rem;
	}

	.benefit-l,.benefit-r{
		width: 100%;
	}

	.benefit-l{
		text-align: center;
	}

	.benefit-r{
		padding-top: 4rem;
	}

	.benefit-listItem{
		padding-top: 1.6rem;
	}

	.benefit-listItem:not(:last-of-type){
		margin-bottom: 2rem;
	}

	.benefit-listItem:nth-of-type(2){
		margin-bottom: 3rem;
	}

	.benefit-listItem p:first-of-type span{
		font-size: 2.4rem;
	}

	.benefit-listItem p:first-of-type span:first-of-type{
		font-size: 6.4rem;
	}

	.benefit-listItem p:last-of-type{
		font-size: 1.2rem;
	}
	.benefitVoice-listItem{
		padding: 3rem 2.4rem;
		flex: 0 0 32.5rem;
	}

	.benefitVoiceInfo{
		padding: 2rem 0;
	}

	.benefitVoiceInfo p:first-of-type{
		padding-bottom: 0.4rem;
	}

	.benefitVoice-listItem h4{
		font-size: 1.6rem;
	}

	.benefitVoiceInfo p span{
		font-size: 1.2rem;
	}

	.benefitVoice-listItem>p{
		font-size: 1.4rem;
	}

	.t-cv{
		padding: 8rem 2rem;
		background-image: url(../img/top/fvbg-sp.png);
	}

	.t-cv-l{
		width: 100%;
		text-align: center;
	}

	.t-cv-r{
		padding-top: 6rem;
		width: 100%;
	}

	.t-cvIcon{
		width: 30%;
		right: -2rem;
		top: 2rem;
	}

	.t-cv-r a{
		display: block;
		padding: 4rem 2.4rem 2rem;
	}

	.t-cvcont{
		padding-top: 3rem;
	}

	.t-cvImg{
		width: 55%;
	}

	.t-cvArrow{
		padding: .8rem 1.6rem;
	}

	.t-cvArrow span{
		width: 1rem;
		height: 1rem;
	}

	.t-case{
		background-image: url(../img/top/casebg.png);
	}

	.priceWrap{
		padding: 0;
	}

	.priceCont>p,.planCompare p{
		font-size: 1rem;
	}

	.pricehead{
		text-align: center;
		padding: 2.4rem 2rem;
		margin-bottom: 2.4rem;
		justify-content: center;
	}

	.pricehead p{
		font-size: 1.4rem;
	}

	.pricehead p:first-of-type{
		padding-top: 0;
	}

	.pricehead p:last-of-type{
		padding: 0 ;
		margin-left: 0;
		padding-top: .6rem;
		margin-top: 1.8rem;
		border-left: unset;
		border-top: solid 1px rgba(255,255,255,.2);
	}

	.pricehead p span{
		padding: .3rem .2rem;
		font-size: 3.2rem;
	}

	.price-listItem{
		width: 100%;
		padding: 4rem 2.4rem 3rem;
	}

	.price-listItem:not(:last-of-type){
		margin-bottom: 2.4rem;
	}

	.recommend{
		padding: .8rem 0;
	}

	.price-listTtl p:first-of-type{
		font-size: 1.4rem;
		padding-bottom: 1rem;
	}

	.price span{
		padding-bottom: 0.2rem;
	}

	.price span:first-of-type{
		font-size: 1.6rem;
	}

	.price span:nth-of-type(2){
		font-size: 3.2rem;
		padding: 0 .2rem 0;
	}

	.price span:last-of-type{
		font-size: 1.4rem;
	}

	.priceBtn{
		padding: 1.2rem 0;
		font-size: 1.4rem;
	}

	.priceOther{
		column-gap: 2rem;
	}

	.priceFunction{
		width: 100%;
	}

	.priceFunction:not(:last-of-type){
		margin-bottom: 1.6rem;
	}

	.priceFunction>p{
		font-weight: 600;
		font-size: clamp(10px,1.4rem,16px);
		border-bottom: solid 1px #EEF3FC;
		color: var(--font-gray);
		padding-bottom: 1rem;
		margin-bottom: 1.6rem;
	}

	.function-listItem:not(:last-of-type){
		margin-bottom: 1rem;
	}

	.function-listIcon{
		width: 1.6rem;
		height: 1.6rem;
	}

	.function-listItem p{
		font-size: 1.4rem;
		padding-left: .8rem;
	}

	.planCompare{
		overflow-x: scroll;
	}

	.planCompare .compareDetail{
		width: 220%;
	}

	.faq-l{
		width: 100%;
	}

	.faq-r{
		width: 100%;
		padding-top: 4rem;
	}

	.faq-defList{
		padding: 1.6rem 2rem;
	}

	.faq-defList:not(:last-of-type){
		margin-bottom: 1rem;
	}

	.faq-defTtl{
		padding-bottom: 1.6rem;
		margin-bottom: 1.6rem;
	}

	.faq-defTtl p{
		font-weight: 400;
		font-size: 1.4rem;
	}

	.faq-defTtl p:first-of-type{
		padding-top: 0.2rem;
		font-size: 1.6rem;
	}	

	.faq-defDesc{
		font-size: 1.2rem;
	}


}


.feature-list {
	display: grid;
	align-items: center;
	height: min-content;
}
.feature-listItem {
	grid-row: 1;
	grid-column: 1;
	position: relative;
}
.feature-listItem:nth-child(1) { z-index: 1; }
.feature-listItem:nth-child(2) { z-index: 2; }
.feature-listItem:nth-child(3) { z-index: 3; }
.feature-listItem:nth-child(4) { z-index: 4; }
.feature-listImg {
	overflow: hidden;
	border-radius: 16px;
}
.feature-listImg img {
	width: 100%;
	display: block;
}

@media screen and (max-width:768px) {
	.feature-list { 
		display: block;
		height: 100%;
		padding: 4rem 0 0; 
	}
	.feature-listItem { 
		display: block;
		flex-direction: column; 
		gap: 3rem; 
	}
	.feature-listItem:not(:last-child) {
		margin-bottom: 4rem; 
	}

	.how-list{
		padding: 4rem 2rem;
		background-image: url(../img/top/howbg-sp.png);
	}

	.how-list::after{
		width: calc(100% - 2rem);
		bottom: -1.6rem;
	}

	.howImg{
		width: 100%;
		margin: 2rem auto 0;
		border-radius: 10px;
		border: solid 5px var(--primary);
		box-shadow: 10px 10px var(--secondary);
	}

	.howImg img{
		border-radius: 12px;
	}

	.howStep {
		display: grid;
		/* 		grid-template-columns: repeat(2, 1fr); */
		width: 100%;
		margin: 0 auto 2rem;
		padding: .6rem 1rem;
	}

	.howStepItem {
		height: 5rem;
		padding: 0 2rem;
		margin-left: -1.2rem;
		text-align: center;
	}

	.howStepItem:first-of-type {
		margin-left: 0;
	}

	.howStepItem span {
		font-size: 1rem;
	}

	.howVideo{
		position: relative;
		padding-top: 54.375%%;
	}


}



