@charset "UTF-8";
.c-mv-title{
	position: absolute;
	top: 52%;
	left: 50%;
	transform: translate(-50%, -50%);
}
/* .c-mv-title span{
	font-size: clamp(4.5rem, 4.14rem + 1.125vw, 6.3rem);
} */
.c-mv.is-anim .video-wrapper img{
      animation-delay: 0s;
}
@media screen and (max-width: 767px) {
	/* .c-mv{
		aspect-ratio: 750 / 1625;
		.mov{
			height: 100%;
		}
		.video-wrapper{
			height: 100%;
			figure{
				height: 100%;
				img{
					object-fit: cover;
				}
			}
		}
	} */
}
.general-section .inner-small{
	padding: 48px 6%;
}
.area1-img1{
	margin-bottom: clamp(28px, 7vw, 90px);
}
.area1{
	padding-bottom: clamp(24px, 6vw, 120px);
	position: relative;
	background-color: #ebece7;
	overflow: hidden;
	&::before{
		content: "";
		width: 100%;
		height: 100%;
		position: absolute;
		top: 0;
		left: calc(10 / 1440 * -100%);
		background: url(../img/position/bg1.svg) no-repeat top left/ 60%;
		z-index: 0;
	}
}
.area1-flex{
	align-items: flex-end;
	gap: 40px;
	& > .col-2{
		width: calc(50% - 20px);
	}
	.note{
		margin-bottom: 0;
	}
}
.area1-flex2{
	gap: clamp(60px, 6.8vw, 68px);
}
.area1-img2{
    margin-inline: auto 30px;
	width: 82%;
}
.tertiary-heading + .note{
	margin-top: 0;
}
@media screen and (max-width: 767px) {
	.general-section .inner-small{
		padding-inline: 4.5%;
	}
	/* .secondary-heading + .note{
		padding-inline: 10%;
	} */
	.area1{
		&::before{
			top: 18px;
        	left: calc(8 / 375 * 100%);
			background-size: 72%;
		}
	}
	.general-section .inner-small {
		padding-block: 120px 10px;
	}
	.area1-flex{
		& > .col-2{
			width: 100%;
		}
	}
	.area1-img1{
        margin-inline: auto calc(50% - 50vw);
        width: calc(100vw - 32px);
	}
	.area1-img2{
		margin-inline: calc(50% - 50vw) auto;
		width: 80%;
	}
}
.area2{
	/* padding-bottom: 60px; */
	padding-bottom: clamp(24px, 6vw, 60px);
	position: relative;
	overflow: hidden;
	&::before{
		content: "";
		width: 100%;
		height: 100%;
		position: absolute;
		top: 12px;
		left: calc(16 / 1440 * -100%);
		background: url(../img/position/bg2.svg) no-repeat top left/ 60%;
		mix-blend-mode: multiply;
		z-index: 0;
	}
	&.general-section .inner{
		position: relative;
		z-index: 2;
	}
	&.general-section .inner-small{
		padding-bottom: 140px;
	}
}
.alignitems-center{
	align-items: center;
}
.area2-img1{
	margin-bottom: clamp(48px, 8vw, 80px);
}
.area2-flex{
	/* margin-bottom: clamp(80px, 15vw, 150px); */
	gap: clamp(24px, 7.2vw, 72px);
	.contents-l{
		width: calc(55% - 36px);
	}
	.contents-r{
		width: calc(45% - 36px);
	}
}
.position-grid{
	margin-bottom: 56px;
	gap: clamp(24px, 4.8vw, 48px) 36px;
	.grid-item{
		figure{
			margin-bottom: clamp(8px, 1.2vw, 12px);
		}
		.note{
			margin: 0;
			font-size: clamp(1.3rem, 1.6vw, 1.6rem);
			letter-spacing: .3rem;
		}
	}
}
.note2{
	margin-top: 10px;
	font-size: clamp(1.3rem, 1.5vw, 1.5rem);
	letter-spacing: .4rem;
	color: #fff;
	&:has(span){
		display: inline-flex;
		align-items: center;
	}
	.material-symbols-outlined{
		font-size: clamp(18px, 2vw, 20px);
	}
}
.dummy{
	position: relative;
	&::before{
		content: "ダミー";
		padding: 4px;
		width: 200px;
		position: absolute;
		top: 50%;
		left: 50%;
		transform: translate(-50%, -50%);
		color: #fff;
		background-color: #000;
		border: 1px solid #fff;
		font-size: clamp(2.4rem, 3vw, 3rem);
		text-align: center;
	}
}
.area3{
	background-color: #ebece7;
	.position-grid{
		margin-bottom: 0;
	}
	.grid-item{
		.caption{
			font-size: clamp(1.2rem, 1.4vw, 1.4rem);
		}
	}
	.general-section .inner-small{
		padding-top: clamp(70px, 12vw, 120px);
	}
    .inner.inner-wide{
        max-width: 1100px;
    }
}
.area3-img1{
	margin: 0 auto clamp(68px, 14vw, 140px);
	max-width: 700px;
}
@media screen and (max-width: 767px) {
	.area2 {
		&::before {
			top: 24px;
			left: calc(8 / 375 * 100%);
			background-size: 70%;
		}
		&.general-section .inner-small {
			padding-block: 132px 40px;
		}
	}
	.area2-img1{
		margin-inline: calc(50% - 50vw);
		width: 100vw;
	}
	.area2-flex{
		padding-inline: 6%;
		.contents-l,
		.contents-r{
			width: 100%;
		}
	}
	.area3{
		padding-bottom: 32px;
		&.general-section .inner-small{
			padding-top: 80px;
		}
	}
	.area3-img1{
		margin-inline: calc(50% - 50vw);
		width: 100vw;
	}
}