@charset "utf-8";
.fv {
    position: relative;
    min-height: clamp(420px, 47vw, 750px);
    overflow: hidden;
    clip-path: ellipse(95% 100% at 50% 0%);
    align-items: flex-end;
    justify-content: flex-start;
}
body.on .fv .fv_img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    object-position: center top;
    z-index: 1;
    animation: fvZoom 4s ease-out forwards;
}
.fv .txtbox{
	position: relative;
    z-index: 2;
    flex-direction: column;
    gap: 20px;
    align-items: flex-start;
}
.fv .txtbox .box{
	flex-direction: column;
	gap: 5px;
	align-items: flex-start;
}
.fv .txtbox .box > p{
	line-height: 1;
}


.fv .txtbox h1 {
    opacity: 0;
    transform: translateY(15px);
    animation: fvFadeUp 1s ease forwards;
}

.fv .txtbox .box .font-ephesis {
    opacity: 0;
    transform: translateY(15px);
    animation: fvFadeUp 1s ease 0.25s forwards;
}

.fv .txtbox .box .en_title {
    opacity: 0;
    transform: translateY(15px);
    animation: fvFadeUp 1s ease 0.5s forwards;
}

@keyframes fvFadeUp {
    0% {
        opacity: 0;
        transform: translateY(15px);
    }
    100% {
        opacity: 1;
        transform: translateY(0);
    }
}
.fv .txtbox {
    position: relative;
    z-index: 2;
}

@keyframes fvZoom {
    0% {
        transform: scale(1.08);
    }
    100% {
        transform: scale(1);
    }
}
/* ---------- cate2 ---------- */
.cate2.two_col .box_wrap {
    width: 100%;
    max-width: none;
    gap: 90px;
    align-items: flex-start;
}
.cate2.two_col .box_wrap .imgbox {
    position: relative;
    display: block; 
	align-self: flex-start;
}
.cate2 .img_deco::before {
    content: "";
    position: absolute;
    right: -10px;
    bottom: -380px; 
    width: clamp(60px, 10vw, 110px);
    aspect-ratio: 1 / 1;
    background: url("https://hairmakesnipsnap.jp/system_panel/uploads/images/leaf_deco3.svg") no-repeat center center / contain;
    z-index: 5;
    pointer-events: none;
}
.cate2 .img_deco::after {
    display: none;
}

.cate2.two_col .box_wrap .imgbox img {
    width: 90%;
    display: block;
    margin: 0;
}
.cate2 .two_col .box_wrap .imgbox img:nth-of-type(1) {
    margin-bottom: 0px;
}
/* ---------- cate3 ---------- */
.cate3 {
	flex-direction: column;
	gap: 60px;
}
.cate3 .box_wrap{
	flex-direction: column;
	gap: 10px;
	width: 100%;
}
.cate3 .box_wrap .boxitem{
	background-color: #fff;
	padding: 30px 40px 30px 50px;
	border-radius: 10px;
	gap: 40px;
	width: 100%;
}
.cate3 .box_wrap .boxitem .txtbox{
	width: calc(60% - 20px);
	gap: 10px;
	justify-content: flex-start;
}
.cate3 .box_wrap .boxitem .imgbox{
	position: relative;
	width: calc(40% - 20px);
}
.cate3 .box_wrap .boxitem .txtbox .topbox{
	gap: 30px;
}
.cate3 .box_wrap .boxitem .txtbox .topbox .icon{
	position: relative;
	width: 180px;
}

.cate3 .box_wrap .boxitem .txtbox .topbox .icon .num{
	position: absolute;
	top:0;
	left: -20px;
}
.cate3 .box_wrap .boxitem .txtbox .topbox .title{
	flex:1;
	flex-direction: column;
	align-items: flex-start;
}


.cate3 .box_wrap .boxitem .imgbox .more3 {
    position: absolute; 
    right: 0;
    bottom: 0;
    background-color: rgba(255, 255, 255, 0.6);
}

.cate3 .box_wrap .boxitem:hover .more3 > div::after {
    transform: translateY(-50%) scaleX(0);
}

/* ---------- newstop_b ---------- */
.newstop_b{
	flex-direction: column;
	gap: 60px;
}
.newstop_b .webgene-blog .webgene-item a .catelabel{
	border: none;
	border-radius: 50px;
	background-color: #D8EBE3;
}
.newstop_b .webgene-blog .webgene-item{
	padding-bottom: 20px;
	margin-bottom: 20px;
	border-bottom: 1px solid #E1E1E1;
}
.newstop_b .titlebox2,
.newstop_b .contents{
	max-width: 1400px;
	margin: 0 auto;
}
.newstop_b .more2{
	max-width: 1400px;
	width: 100%;
	justify-content: flex-end;
}
/* ---------- IEのみ ---------- */
@media all and (-ms-high-contrast: none) {
}
/* ---------- 1280px ~ ---------- */
@media screen and (max-width: 1280px){
}
/* ---------- 1080px ~ ---------- */
@media screen and (max-width: 1080px){
	.cate3 .box_wrap .boxitem {
		flex-direction: column;
	}
	.cate3 .box_wrap .boxitem .txtbox {
		width: 100%;
		gap: 0px;
	}
	.cate3 .box_wrap .boxitem .imgbox {
		width: 100%;
	}
	.cate3 .box_wrap .boxitem {
		width: 80%;
	}
	.cate3 .box_wrap .boxitem .txtbox .topbox .icon{
		width: 160px;
	}
}
/* ---------- 768px ~ ---------- */
@media screen and (max-width: 768px){

	.cate2 {
		padding-left: 50px;
	}
	.cate2.two_col .box_wrap {
		gap: 50px;
		flex-direction: column;
		align-items: center;
	}
	.cate2.two_col .box_wrap .imgbox {
		align-self: center;
	}
	.cate3 .box_wrap .boxitem {
		width: 90%;
	}
	.cate3 .box_wrap .boxitem .txtbox .topbox .icon{
		width: 100px;
	}
	.cate3 .box_wrap .boxitem .txtbox .topbox .icon .num {
		position: absolute;
		top: -20px;
		left: -0px;
	}
    .cate3 .box_wrap .boxitem .txtbox {
        gap: 20px;
    }

}
/* ---------- 576px ~ ---------- */
@media screen and (max-width: 576px){

	.cate2 .img_deco::before {
		right: -10px;
		bottom: -200px;
	}
	.cate2 {
		padding-left: 20px;
	}
	.cate2.two_col .box_wrap {
        gap: 30px;
    }
	.two_col .box_wrap {
        gap: 30px;
    }
	.cate3 .box_wrap .boxitem {
		width: 100%;
		padding: 30px 20px 30px 20px;
		gap: 20px;
	}
	.cate3 .box_wrap .boxitem .txtbox .topbox {
		gap: 10px;
	}
    .cate3 .box_wrap .boxitem .txtbox {
        gap: 10px;
    }
	.cate3 {
		gap: 40px;
	}
	.newstop_b {
		gap: 40px;
	}
}
/* ---------- 350px ~ ---------- */
@media screen and (max-width: 350px){
}

