@charset "UTF-8";

@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@100..900&display=swap');


br.pc-none,
#half-parfait-peach .sp{
    display: none;
}
/*#half-parfait-peach ul, #half-parfait-peach p, #half-parfait-peach dl{ margin-bottom: 0;}
#half-parfait-peach dd{ margin-left: 0;}*/

#half-parfait-peach #intro,
#half-parfait-peach #contents {
    width: 100%;
    overflow: hidden;
    position: relative;
    color: #491b02;
    font-family: "Noto Sans JP", sans-serif;
    font-weight: 500;
    font-size: 15px;
}

/* モーダルリセット */
#half-parfait-peach .modal-contents {
    color: initial;
    font-family: initial;
    font-size: initial;
}

#half-parfait-peach img{ 
    width: 100%; 
    vertical-align: bottom; 
    -webkit-backface-visibility: hidden; 
    backface-visibility: hidden;
}

#half-parfait-peach .deco{
    position: absolute;
}


.pc-only { display: block; }
.sp-only { display: none; }

/*--- mv ---*/
#half-parfait-peach #mv{
	width: 100%;
	aspect-ratio: 1500 / 850;
	position: relative;
}

#half-parfait-peach #mv .mvInner{
    position: relative;
    display: flex;
    justify-content: space-between;
    height: 100%;
}
#half-parfait-peach #mv .mvInner .menuImage{
    width: 50%;
    height: 100%;
    position: relative;
}    
#half-parfait-peach #mv .mvInner .menuImage.peach{
    background: url("../images/menu/half-parfait-peach/mvBg_peach.jpg") center bottom / cover no-repeat;
}
#half-parfait-peach #mv .mvInner .menuImage.choco{
    background: url("../images/menu/half-parfait-peach/mvBg_choco.jpg") center bottom / cover no-repeat;
}

#half-parfait-peach #mv .mvInner .menuImage .detail {
    width: 53.3%;
    margin-top: 70%;
    left: 6%;
}

#half-parfait-peach #mv .mvInner .menuImage .detail2 {
    width: 53.3%;
    margin-top: 70%;
	right: 6%;
}

#half-parfait-peach #mv .title {
    width: 61.4%;
    left: 19%;
    top: 0.5%;
}

#half-parfait-peach #mv .title .date {
    width: 22.3%;
    left: 39%;
    top: 137%;
}

#half-parfait-peach #mv .half-parfait2Logo {
    width: 32%;
    left: 34%;
    margin-top: 25.5%;
}

#half-parfait-peach #mv .colabo{
    width: 27.8%;
    left: 36.1%;
    margin-top: 43.4%;
}

/*--- intro ---*/

#intro {
	position: relative;
	background: url(../images/menu/half-parfait-peach/introBg.jpg) center top / 1500px auto repeat;
	padding: clamp(30px, 4vw, 60px);
}

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

#intro .introCopy img {
  width: clamp(420px, 42vw, 570px);
}

#intro .note {
    text-align: center;
	font-size: clamp(12.5px, 1.4vw, 16px);
}

#intro .shopBtn a {
	display: flex;
	justify-content: center;
	align-items: center;
	font-weight: 600;
	max-width: 390px;
	width: 90%;
	padding: 22px;
	margin: 30px auto 25px;

	color: #fff;
	background-color: #e2272d;
	border-radius: 40px;

	box-shadow: 0 7px 5px rgba(255, 103, 0, 0.5);

	text-shadow: none;
	-webkit-font-smoothing: antialiased;
	backface-visibility: hidden;
	-webkit-backface-visibility: hidden;
	transform: translateZ(0);
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

#intro .shopBtn a:hover {
    transform: translate3d(0, 2px, 0);
    box-shadow: 0 4px 3px rgba(255, 103, 0, 0.0);
}

/*--- contents ---*/

#half-parfait-peach #contents {
    position: relative;
}

#half-parfait-peach #contents .contentsBg {
    position: absolute;
    inset: 0;
    z-index: 0;

    background:
        url(../images/menu/half-parfait-peach/bg_peach.jpg)
        left top / 50% 100% no-repeat,

        url(../images/menu/half-parfait-peach/bg_choco.jpg)
        right top / 50% 100% no-repeat;
}

#half-parfait-peach #contents .contentsInr {
    position: relative;
    z-index: 1;
    max-width: 1500px;
    width: 100%;
    margin: 0 auto;
}

#half-parfait-peach #contents .contentsInr {
    max-width: 1200px;
    margin: 0 auto;
	padding: 140px 0;
}

#half-parfait-peach #contents .titleGroup {
    text-align: center;
    margin-bottom: 10px;
}

#half-parfait-peach #contents .bodyCopy {
    width: clamp(320px, 66.7vw, 1000px);
    display: block;
    margin: 0 auto 10px;
}

#half-parfait-peach #contents .bodyTitle {
	width: clamp(320px, 78vw, 1170px);
	display: block;
	margin: 0 auto;
}

#half-parfait-peach #contents .bodyArea {
    position: relative;
    display: flex;
    justify-content: center;
    align-items: flex-start;
    overflow: visible;
}

#half-parfait-peach #contents .bodyGroup {
    width: clamp(260px, 37.2vw, 558px);
    flex-shrink: 0;

    position: relative;
    z-index: 2;

    display: flex;
    flex-direction: column;
    align-items: center;
}

#half-parfait-peach #contents .bodyImg1 {
    margin-bottom: 20px;
}

#half-parfait-peach #contents .bodyImg2 {
    margin-bottom: 40px;
}

#half-parfait-peach #contents .bodyImg3 {
    margin-bottom: 40px;
}

#half-parfait-peach #contents .bodyText {
	color: #fff;
	font-size: clamp(15px, 1.3vw, 18px);
	line-height: 1.9;
	text-align: justify;
	position: relative;
	z-index: 10;
}

#half-parfait-peach #contents .leftImg,
#half-parfait-peach #contents .rightImg {
    position: absolute;
	top: -2%;
    width: clamp(280px, 35vw, 570px);
    z-index: 1;
    pointer-events: none;
}

#half-parfait-peach #contents .leftImg {
    left: 50%;
    transform: translateX(calc(-100% - 135px));
}

#half-parfait-peach #contents .rightImg {
    left: 50%;
    transform: translateX(185px);
}

#half-parfait-peach #contents img {
    max-width: 100%;
    height: auto;
}


#half-parfait-peach #contents .linkArea {
    display: flex;
    justify-content: center;
    align-items: flex-start;
    max-width: 1500px;
    margin: clamp(60px, 12vw, 180px) auto 0;
    gap: clamp(20px, 12.3vw, 185px);
    position: relative;
    z-index: 10;
}

/* 左右バナー（1500px時560px基準） */
#half-parfait-peach #contents .linkLeft,
#half-parfait-peach #contents .linkRight {
    flex: 0 1 clamp(260px, 37.3vw, 560px);
    display: block;
}

/* バナー本体 */
#half-parfait-peach #contents .bannerWrap {
    position: relative;
}

/* 画像 */
#half-parfait-peach #contents .bannerWrap img {
    width: 100%;
    display: block;
    transition: .3s ease;
}

#half-parfait-peach #contents .bannerWrap img:hover {
    transform: scale(1.1);
}

/* 吹き出し */
#half-parfait-peach #contents .bannerWrap .bubble {
    position: absolute;
    top: -19%;
    left: 50%;
    transform: translateX(-50%);
    width: 95%;
    pointer-events: none;
}


#btnArea .linkBtn a {
	display: flex;
	justify-content: center;
	align-items: center;

	max-width: 390px;
	width: 90%;
    padding: 22px;
	margin: 80px auto;

    color: #fff;
    background-color: #e2272d;
    border-radius: 40px;

    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);

    text-shadow: none;
    -webkit-font-smoothing: antialiased;
    backface-visibility: hidden;
    -webkit-backface-visibility: hidden;
    transform: translateZ(0);
	text-decoration: none;
	transition: transform 0.15s ease, box-shadow 0.15s ease;
}

#btnArea .linkBtn a:hover {
    transform: translate3d(0, 2px, 0);
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.0);
}

#btnArea .linkBtn .text {
	font-weight: 600;
	font-size: clamp(14px, 1.1vw, 18px);
}



/*-------------------------------------------
Animation
-------------------------------------------*/

#half-parfait-peach .topToBottom,
#half-parfait-peach .bottomToTop,
#half-parfait-peach .leftToRight,
#half-parfait-peach .rightToLeft,
#half-parfait-peach .fadein,
#half-parfait-peach .slideIn{
	opacity: 0;
}

#half-parfait-peach #mv .slideIn,
#half-parfait-peach .in .slideIn,
#half-parfait-peach .in.slideIn{
	animation: slideIn 1s ease forwards;
}

#half-parfait-peach .in .topToBottom{
	animation: topToBottom .25s ease forwards;
}
#half-parfait-peach .in .bottomToTop{
	animation: bottomToTop .25s ease forwards;
}
#half-parfait-peach .in .leftToRight{
	animation: leftToRight .25s ease forwards;
}
#half-parfait-peach .in .rightToLeft{
	animation: rightToLeft .25s ease forwards;
}
#half-parfait-peach .in .fadein{
	animation: fadein .25s ease forwards;
}

@keyframes blurIn {
	0% { transform: translate(0,50%); opacity: 0; -ms-filter: blur(6px); filter: blur(6px); }
	100% { transform: translate(0,0); opacity: 1; -ms-filter: blur(0); filter: blur(0); }
}
@keyframes slideIn {
	0% { transform: translate(0,10%); opacity: 0;}
	100% { transform: translate(0,0); opacity: 1;}
}
@keyframes fadein {
	0% { opacity: 0; }
	100% { opacity: 1; }
}
@keyframes topToBottom {
	0% { transform: translate(0, -10%); opacity: 0;}
	100% { transform: translate(0, 0); opacity: 1;}
}
@keyframes bottomToTop {
	0% { transform: translate(0, 10%); opacity: 0;}
	100% { transform: translate(0, 0); opacity: 1;}
}
@keyframes leftToRight {
	0% { transform: translate(-10%, 0); opacity: 0;}
	100% { transform: translate(0, 0); opacity: 1;}
}
@keyframes rightToLeft {
	0% { transform: translate(10%, 0); opacity: 0;}
	100% { transform: translate(0, 0); opacity: 1;}
}
@keyframes boxin{
    0%{ transform: translate(0,25%); opacity: 0; }
    100%{  transform: translate(0,0%);opacity: 1;}
}

@keyframes leftToRight02 {
	0% { transform: translate(-10%, -50%); opacity: 0;}
	100% { transform: translate(0, -50%); opacity: 1;}
}

#mv .clipAnimationLtoR,
.clipAnimationLtoR {
    clip-path: inset(0 100% 0 0);
}

#mv .clipAnimationLtoR,
.in .clipAnimationLtoR,
.in.clipAnimationLtoR{
    animation: clipAnimationLtoR .4s ease-in-out forwards;
}

@keyframes clipAnimationLtoR {
	0% { clip-path: inset(0 100% 0 0);}
	100% { clip-path: inset(0 0 0 0); }
}

#mv .clipAnimationRtoL,
.clipAnimationRtoL {
    clip-path: inset(0 0 0 100%);
}
#mv .clipAnimationRtoL,
.in .clipAnimationRtoL,
.in.clipAnimationRtoL {
    animation: clipAnimationRtoL .4s ease-in-out forwards;
}

@keyframes clipAnimationRtoL {
    0%   { clip-path: inset(0 0 0 100%); }
    100% { clip-path: inset(0 0 0 0); }
}

#mv .clipAnimationTtoB,
.in .clipAnimationTtoB,
.in.clipAnimationTtoB {
    animation: clipAnimationTtoB .4s ease-in-out forwards;
}
@keyframes clipAnimationTtoB {
	0% { clip-path: inset(0 0 100% 0); }
	100% { clip-path: inset(0 0 0 0); }
}

#mv .pon {
	animation: pon .4s ease-in-out forwards;
}

#mv .pon {
    opacity: 0;
    transform: scale(0.8);
}

#mv.pon.in {
    animation: pon 0.8s ease forwards;
}

#half-parfait-peach .pon {
    opacity: 0;
    transform: scale(0.8);
}

#half-parfait-peach .pon.in {
    animation: pon 0.6s ease forwards;
}

@keyframes pon {
  0% { transform: scale(0.8); opacity: 0;}
  50% { transform: scale(1.1); opacity: 1;}
  100% { transform: scale(1); opacity: 1;}
}

.delay01{ animation-delay: 0.1s!important;}
.delay02{ animation-delay: 0.2s!important;}
.delay03{ animation-delay: 0.3s!important;}
.delay04{ animation-delay: 0.4s!important;}
.delay05{ animation-delay: 0.5s!important;}
.delay06{ animation-delay: 0.6s!important;}
.delay07{ animation-delay: 0.7s!important;}
.delay08{ animation-delay: 0.8s!important;}
.delay09{ animation-delay: 0.9s!important;}
.delay10{ animation-delay: 1.0s!important;}
.delay11{ animation-delay: 1.1s!important;}
.delay12{ animation-delay: 1.2s!important;}
.delay13{ animation-delay: 1.3s!important;}
.delay14{ animation-delay: 1.4s!important;}
.delay15{ animation-delay: 1.5s!important;}
.delay16{ animation-delay: 1.6s!important;}
.delay17{ animation-delay: 1.7s!important;}
.delay18{ animation-delay: 1.8s!important;}
.delay19{ animation-delay: 1.9s!important;}
.delay20{ animation-delay: 2.0s!important;}
.delay21{ animation-delay: 2.1s!important;}
.delay22{ animation-delay: 2.2s!important;}
.delay23{ animation-delay: 2.3s!important;}
.delay24{ animation-delay: 2.4s!important;}
.delay25{ animation-delay: 2.5s!important;}
.delay26{ animation-delay: 2.6s!important;}
.delay27{ animation-delay: 2.7s!important;}
.delay28{ animation-delay: 2.8s!important;}
.delay29{ animation-delay: 2.9s!important;}
.delay30{ animation-delay: 3.0s!important;}
.delay31{ animation-delay: 3.1s!important;}
.delay32{ animation-delay: 3.2s!important;}
.delay33{ animation-delay: 3.3s!important;}
.delay34{ animation-delay: 3.4s!important;}
.delay35{ animation-delay: 3.5s!important;}
.delay36{ animation-delay: 3.6s!important;}
.delay37{ animation-delay: 3.7s!important;}
.delay38{ animation-delay: 3.8s!important;}
.delay39{ animation-delay: 3.9s!important;}
.delay40{ animation-delay: 4.0s!important;}


/*-------------------------------------------
ONLY PC
-------------------------------------------*/
@media only screen and (min-width: 769px){
	#half-parfait-peach img,
	#half-parfait-peach #mv .inr{
		-webkit-backface-visibility: hidden;
		backface-visibility: hidden;
		image-rendering: crisp-edges;
		image-rendering: -webkit-optimize-contrast;
	}
}

/*-------------------------------------------
Under 900px
-------------------------------------------*/
@media only screen and (max-width: 900px){
    
    /*--- last ---*/
#half-parfait-peach #contents .contentsInr {
	padding: 80px 0;
}
	
#half-parfait-peach #contents .leftImg {
    transform: translateX(calc(-100% - 94px));
}
	
#half-parfait-peach #contents .rightImg {
    transform: translateX(135px);
}
	

#half-parfait-peach #contents .linkArea {
    margin: 90px auto 0;
}
    
}

/*-------------------------------------------
Tablet
-------------------------------------------*/

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

    .pc-only { display: none; }
    .sp-only { display: block; }

	.spImgRow {
		display: flex;
		justify-content: center;
		gap: 90px;
		margin-top: 20px;
		width: 40%;
	}

	.spImgRow img {
		width: 45%;
		max-width: 180px;
	}

	#half-parfait-peach #contents .bodyGroup {
		width: 68%;
	}
	

}

/*-------------------------------------------
SP
-------------------------------------------*/
@media only screen and (max-width: 600px){
	 
     br.pc-none {
        display: inline;
    }
	#half-parfait-peach .sp { display: block;}
	#half-parfait-peach .pc { display: none;}
    
    #half-parfait-peach .check_red,
    #half-parfait-peach .check_yellow{ background-size: 20px 20px;}
	    
	/*--- mv ---*/ 
    #half-parfait-peach #mv {
        height: 150vw;
    }
    #half-parfait-peach #mv::before, #half-parfait-peach #mv::after {
        height: 3.125vw;
    }
    #half-parfait-peach #mv .mvInner .menuImage.peach{
        background: url("../images/menu/half-parfait-peach/mvBg_peach_sp.jpg") center bottom / cover no-repeat;
    }
    #half-parfait-peach #mv .mvInner .menuImage.choco{
        background: url("../images/menu/half-parfait-peach/mvBg_choco_sp.jpg") center bottom / cover no-repeat;
    }
	
    #half-parfait-peach #mv .title {
        width: 100%;
        left: 0%;
        top: 2%;
    }
	
    #half-parfait-peach #mv .title .date {
        width: 26%;
        left: 37.125%;
        margin-top: 12%;
    }
	
    #half-parfait-peach #mv .half-parfait2Logo {
        width: 60%;
        left: 19.55%;
        margin-top: 46%;
    }
    #half-parfait-peach #mv .colabo {
        width: 70%;
        left: 14.5%;
        margin-top: 0;
        margin-bottom: 50%;
        bottom: 0;
    }

    #half-parfait-peach #mv .mvInner .menuImage .detail {
        width: 93%;
        margin-top: 0;
        margin-bottom: 4%;
        top: auto;
        bottom: 0;
    }
	
	    #half-parfait-peach #mv .mvInner .menuImage .detail2 {
        width: 93%;
        margin-top: 0;
        margin-bottom: 4%;
        top: auto;
        bottom: 0;
    }
	
	#intro {
		padding: clamp(40px, 5vw, 60px) clamp(20px, 4vw, 60px);
	}
	
	#intro .shopBtn a {
    max-width: 320px;
    width: 90%;
	padding: 15px 0 18px;
	}
	
	#half-parfait-peach #contents .contentsInr {
		padding: 60px 0;
	}
	
	
	#half-parfait-peach #contents .bodyCopy {
		width: 90%;
	}

	#half-parfait-peach #contents .bodyTitle {
		width: 95%;
	}

	#half-parfait-peach #contents .bodyGroup {
			width: 80%;
	}

	#half-parfait-peach #contents .bodyText {
		font-size: clamp(15px, 1.3vw, 18px);
	margin-bottom: 20px;
	}
	
    #half-parfait-peach #contents .linkArea {
        margin: clamp(40px, 7vw, 60px) clamp(16px, 3vw, 30px);
    }
	
	#half-parfait-peach #contents .linkArea {
        flex-direction: column;
        align-items: center;
        gap: clamp(70px, 11vw, 90px);
    }

    #half-parfait-peach #contents .linkLeft,
    #half-parfait-peach #contents .linkRight {
        width: 100%;
        max-width: 420px;
        flex: none;
    }
	
	.spImgRow {
		gap: 30px;
	}
	
}

/*---------------------------------------------------


movie

---------------------------------------------------*/

/*--- movie ---*/
#half-parfait-peach #movie{
    background: linear-gradient(165deg, rgba(245, 200, 95, .7) 0%, rgba(255, 0, 0, .7) 30%, rgba(240, 30, 120, .7) 100%);
    max-width: 1310px;
    margin: 100px auto;
	width: 90%;
}

#half-parfait-peach #movie .movieInner{
    width: min(85%, 800px);
    margin: 0 auto;
    padding: 120px 0 150px;
    position: relative;
}

#half-parfait-peach #movie .mainTitle{
    margin-bottom: 50px;
}

#half-parfait-peach #movie .movie{
    margin-bottom: 40px;
    transition: ease .3s;
}

#half-parfait-peach #movie .movie:hover{
    transform: scale(1.1);
}

#half-parfait-peach #movie .enTitle{
    width: 38%;
    margin: 0 auto;
}

#half-parfait-peach #movie .bnrBox{
    margin-top: 120px;
}

#half-parfait-peach #movie .bnrBox .title{
    width: 57%;
    margin: 0 auto 30px;
}

#half-parfait-peach #movie .bnrBox .bnr{
    width: 82%;
    margin: 0 auto;
    transition: ease .3s;
}

#half-parfait-peach #movie .bnrBox .bnr:hover{
    transform: scale(1.1);
}



/*-------------------------------------------
SP
-------------------------------------------*/
@media only screen and (max-width: 600px){

    #half-parfait-peach #movie{
        margin: 50px auto;
    }

    #half-parfait-peach #movie .movieInner{
        padding: 60px 0;
    }

    #half-parfait-peach #movie .mainTitle{
        margin-bottom: 30px;
    }

    #half-parfait-peach #movie .movie{
        margin-bottom: 20px;
    }

    #half-parfait-peach #movie .bnrBox{
        margin-top: 60px;
    }

    #half-parfait-peach #movie .bnrBox .title{
        width: 80%;
        margin: 0 auto 20px;
    }

    #half-parfait-peach #movie .bnrBox .bnr{
        width: 100%;
    }
 
}

	
