@charset "utf-8";

.Keyvisual:has(.Keyvisual__image)::before{
	opacity: .3;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1120px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.main{
		padding-top: 0;
	}

}



/*-------------------------------
	料金ベース
-------------------------------*/

.Plan-price{
	padding: 4.5rem;
	border: 1px solid #bbb;
}
.Plan-price__header{
	width: 100%;
	margin-bottom: 2.5rem;
	display: flex;
	align-items: baseline;
	justify-content: flex-start;
	flex-wrap: wrap;
}
.Plan-price__header-price{
	font-size: 2.4rem;
	margin-right: 1rem;
	font-weight: 700;
	line-height: 1;
	display: flex;
	align-items: baseline;
	justify-content: flex-start;
}
.Plan-price__header-price strong{
	font-family: var(--en);
	font-size: 7.8rem;
	transform: translateY(.04em);
	font-weight: 400;
	margin-right: .5rem;
	line-height: 1;
	display: block;
}
.Plan-price__item-wrap{
	width: 100%;
	display: flex;
	align-items: stretch;
	justify-content: space-between;
	flex-wrap: wrap;
}
.Plan-price__item{
	width: calc((100% - (5.8rem * 3)) / 4);
	position: relative;
}
.Plan-price__item:not(:last-child)::after{
	content: "";
	display: block;
	width: 1px;
	height: 100%;
	position: absolute;
	right: calc((5.8rem / 2) * -1);
	top: 0;
	bottom: 0;
	background: #bbb;
}
.Plan-price__item-title{
	width: 100%;
	height: 2.6rem;
	margin-bottom: 1.2rem;
	font-weight: 500;
	letter-spacing: .05em;
	display: flex;
	align-items: center;
	justify-content: center;
	background: #ddd;
}
.Plan-price__item-text{
	width: 100%;
	font-size: 1.4rem;
	line-height: 1;
	letter-spacing: 0;
	display: flex;
	align-items: flex-start;
	justify-content: flex-start;
}
.Plan-price__item-text:not(:last-child){
	margin-bottom: .8rem;
}
.Plan-price__item-text::before{
	content: "〇";
	font-size: 1.4rem;
	line-height: 1;
	display: block;
}
.Plan-price__item-text.-ng{
	color: #bbb;
}
.Plan-price__item-text.-ng::before{
	content: "×";
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1120px) and (min-width: 769px){

	.Plan-price{
		padding: 3.5rem 2.5rem;
	}
	.Plan-price__item{
		width: calc((100% - (3rem * 3)) / 4);
	}
	.Plan-price__item:not(:last-child)::after{
		right: calc((3rem / 2) * -1);
	}

}
@media screen and (max-width:960px) and (min-width: 769px){

	.Plan-price__header{
		justify-content: center;
	}
	.Plan-price__header-hosoku{
		width: 100%;
		margin-top: .5rem;
		text-align: center;
	}

	.Plan-price__item{
		width: calc((100% - (5rem * 1)) / 2);
	}
	.Plan-price__item:not(:nth-last-of-type(-n+2)){
		margin-bottom: 2.5rem;
	}
	.Plan-price__item:not(:last-child)::after{
		right: calc((5rem / 2) * -1);
	}
	.Plan-price__item:nth-of-type(2n)::after{
		display: none;
	}

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

	.Plan{
		margin-bottom: 11rem;
	}
	.Plan-price{
		padding: 3.5rem 5rem;
	}
	.Plan-price__header{
		margin-bottom: 3.8rem;
		flex-direction: column;
	}
	.Plan-price__header-price{
		margin-right: 0;
	}
	.Plan-price__header-price strong{
		font-size: 9.6rem;
		margin-right: 0;
	}
	.Plan-price__header-hosoku{
		font-size: 2.2rem;
		line-height: calc(2.4 / 2.2);
		margin-top: 1rem;
	}
	.Plan-price__item{
		width: calc((100% - (8rem * 1)) / 2);
	}
	.Plan-price__item:not(:nth-last-of-type(-n+2)){
		margin-bottom: 3.5rem;
	}
	.Plan-price__item:not(:last-child)::after{
		right: calc((8rem / 2) * -1);
	}
	.Plan-price__item:nth-of-type(2n)::after{
		display: none;
	}
	.Plan-price__item-title{
		height: 4.2rem;
		margin-bottom: 1.8rem;
		letter-spacing: 0;
	}
	.Plan-price__item-text{
		font-size: 2.2rem;
		line-height: calc(3 / 2.2);
	}
	.Plan-price__item-text:not(:last-child){
		margin-bottom: .6rem;
	}
	.Plan-price__item-text::before{
		font-size: 2.2rem;
		line-height: calc(3 / 2.2);
	}

}



/*-------------------------------
	導入
-------------------------------*/

.Plan-prologue{
	margin-bottom: 5.5rem;
}
.Plan-prologue__text{
	line-height: calc(3.2 / 1.6);
	letter-spacing: .05em;
	font-weight: 700;
	text-align: justify;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1120px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.Plan-prologue{
		margin-bottom: 6rem;
	}
	.Plan-prologue__text{
		line-height: calc(5.6 / 2.8);
		letter-spacing: 0;
	}

}



/*-------------------------------
	動画制作料金の構成要素
-------------------------------*/

.Detail-price:not(:last-child){
	margin-bottom: 7.8rem;
}
.Detail-price__title{
	font-family: var(--en);
	font-size: 4rem;
	margin-bottom: 2.2rem;
	font-weight: 700;
	line-height: calc(6.2 / 4);
	letter-spacing: .05em;
}
.Detail-price__item:not(:first-child){
	padding-top: 2.5rem;
}
.Detail-price__item:not(:last-child){
	padding-bottom: 2.8rem;
	border-bottom: 1px solid #ddd;
}
.Detail-price__item-title{
	font-size: 2.2rem;
	margin-bottom: 1.2rem;
	font-weight: 700;
	line-height: calc(3.85 / 2.2);
	letter-spacing: .05em;
}
.Detail-price__item-text{
	/* font-size: 1.4rem; */
	font-size: 1.5rem;
	line-height: calc(2.8 / 1.4);
	letter-spacing: .05em;
	text-align: justify;
}

@media screen and (min-width:769px) , print{

}
@media screen and (max-width:1240px) and (min-width: 769px){

}
@media screen and (max-width:1120px) and (min-width: 769px){

}
@media screen and (max-width:960px) and (min-width: 769px){

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

	.Detail-price:not(:last-child){
		margin-bottom: 7.8rem;
	}
	.Detail-price__title{
		font-size: 4.6rem;
		margin-bottom: 2.5rem;
		line-height: calc(5 / 4.6);
		letter-spacing: 0;
	}
	.Detail-price__item:not(:first-child){
		padding-top: 3rem;
	}
	.Detail-price__item:not(:last-child){
		padding-bottom: 3.5rem;
	}
	.Detail-price__item-title{
		font-size: 3.6rem;
		line-height: calc(6.3 / 3.6);
		letter-spacing: 0;
	}
	.Detail-price__item-text{
		font-size: 3.2rem;
		line-height: calc(5.4 / 2.8);
		letter-spacing: 0;
	}

}