@charset "utf-8";
/* 元々あるやつ */
.block-category-list.container{
	width:100%;
}
.block-event-page--goods{
	margin:0 20px 10px;
}
.block-event-page--accessory{
	margin:0 20px;
}
.block-event-page--accessory > h2{
	width: calc(100% + 40px);
	margin-left: -20px;
	margin-bottom: 2vw;
}
.w100{
	width: calc(100% + 40px) !important;
	margin-left: -20px;
}

/* ============================================================
ベース
============================================================ */
.p-body{
	position: relative;
	overflow: hidden;
}

.p-body img{
	width: 100%;
	max-width: 100%;
}

/* ============================================================
ナビゲーション
============================================================ */
.p-lrummyNav{
	position: absolute;
	top: 0;
	/* width: 100%; */
	width: 1100px;
	margin: auto;
	z-index: 10;
}

.p-lrummyNav.is-fixed{
	position: fixed;
	top: 0;
	left: 0;
	right: 0;
	z-index: 100;
	transition: top 0.3s ease;
}

.p-lrummyNav__list{
	display: flex;
	justify-content: center;
	gap: 1px;
	padding-block: 8px;
	background-color: #3c2616;
}

.p-lrummyNav__item + .p-lrummyNav__item{
	border-left: 0.3px solid rgba(255,255,255,.5); ;
}

.p-lrummyNav__item + .p-lrummyNav__item .p-lrummyNav__link{
	/* padding-left: 48px; */
}

.p-lrummyNav__link{
	display: flex;
	justify-content: center;
	align-items: center;
	height: 100%;
	padding-inline: 45px;
	width: 100%;
	color: #fff;
	text-align: center;
	font-size: 14px;
	line-height: 1.25;
	cursor: pointer;
}

.p-lrummyNav__icon{
	display: block;
	padding-inline: 36px;
}

.p-lrummyNav__icon img{
	width: 30px;
	height: 30px;
}

.p-lrummyNav__before .p-lrummyNav__list{
	justify-content: space-around;
	padding-inline: 48px;
}

.p-lrummyNav__before .p-lrummyNav__item{
	width: 100%;
}

.p-lrummyNav__before .p-lrummyNav__link{
	padding: 0;
}

.p-lrummyNav__before .p-lrummyNav__icon{
	display: block;
	width: 100%;
	text-align: center;
	padding: 0;
}


.p-lrummyNav__before .p-lrummyNav__item + .p-lrummyNav__item .p-lrummyNav__link{
	padding-left: 0;
}


/* ============================================================
フローティングカート（ナビ下追従）
============================================================ */

.p-floating-cart {
	position: absolute;
	bottom: 3%;
	right: calc(50% - 1100px / 2 + 0px); /* ← 1100pxエリアの右端に合わせる */
	width: 83px;
	height: 113px; 
	z-index: 9;        
	display: flex;
	align-items: center;

	/* 表示切替するなら初期は非表示にしておく */
	opacity: 0;
	pointer-events: none;
  }

  .p-floating-cart img {
	width: auto !important;
	height: auto;
	max-width: 100%; /* 念のため入れておく */
	display: block;
  }
  
  .p-floating-cart.is-fixed {
	opacity: 1;
	pointer-events: auto;
	position: fixed;

  }
/* ============================================================
KV
============================================================ */
.p-hero{
	position: relative;
	margin-top: 45px;
}

.p-hero__movie{
	position: relative;
	aspect-ratio: 16/9;
	margin-top: 45px;
}

.p-hero__movie video{
	position: absolute;
	top:0;
	left: 0;
	width: 100%;
	height: 100%;
}

.p-pagetop{
	position: fixed;
	bottom:40px;
	left: calc(50% - 510px);
	width: 63px;
  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0.3s ease;
	z-index: 10;
	cursor: pointer;
}

.p-pagetop.is-show{
	opacity: 1;
	visibility: visible;
}

/* 余白の基準値（PC=45px） */
#Lrummyterrine { --hero-offset: 45px; }

/* 1) ナビが“隠れている”とき（JSが inline style で translateY(-100%) を付与）→ 余白を0に */
#Lrummyterrine:has(.js-fixedNav[style*="translateY(-100%"] ) {
  --hero-offset: 0px;
}

/* 2) ヒーローは常にこのオフセット分だけ下げる（見えている時だけ45px、隠れたら0） */
.js-hero.p-hero {
  margin-top: var(--hero-offset);
}

/* 3) アンカーリンクで見出しが隠れないように（必要なセクションを列挙） */
#concept, #features, #voice, #products {
	scroll-margin-top: var(--hero-offset);
  }


/* ============================================================
キャンペーン
============================================================ */
.p-campaign{
	position: relative;
	background-color: #332b23;
	padding: 30px 0;
}

.p-campaign__image{
	width: 863.23px;
	margin: auto;
	filter: drop-shadow(1.80952381vw 1.80952381vw 1vw rgba(35, 24, 21, 1));
	cursor: pointer;
}

/* ============================================================
コンセプト
============================================================ */
.p-concept{
	position: relative;
	background: url("/img/event_L/eLcheeseterrine2510/concept-bg.png")
				no-repeat center top / cover; /
				padding: ;
	z-index: 0;
	padding: 56px 0 26px;
}

.p-concept__read{
	width: 390px;
	margin: auto;
}

.p-concept__label{
	width: 480px;
	margin: 20px auto 0;
}

.p-concept__text{
	margin: 22px 0 430px;
	color: #fff;
	text-align: center;
	font-size: 20px;
	line-height: 1.8;
	letter-spacing: 0.01em;
	font-weight: 400;
}

.p-concept__read.is-show {
	transition-delay: 0s; /* 1番目 */
  }
  
  .p-concept__label.is-show {
	transition-delay: 0.5s; /* 2番目 */
  }
  
  .p-concept__text.is-show {
	transition-delay: 0.8s; /* 3番目 */
  }

.p-concept__text_sup{
  position: absolute;
  bottom: 3%;
  left: 50%;
  transform: translateX(-50%);
  width: 100%;
  font-size: 14px;
  color: #fff;
  text-align: center;
  pointer-events: none;
}

/* ============================================================
製品
============================================================ */
/* レイアウト（既存） */
.p-products{
  position: relative;
  padding: 80px 0 200px;
  margin-top: -1px;
  background: #332b23 url("/img/event_L/eLcheeseterrine2510/products-bg.png")
              no-repeat center top / cover;
  z-index: 0;
}
.p-products__item{ margin-bottom:55px; padding:0 48px; }
.p-products__item:last-child{ margin-bottom:0; }




/* 画像の層：白版 < メイン < 覆い */
.p-prodImg{ display:block; width:100%; height:auto; }
.p-prodImg--matte{
  position:absolute; inset:0; z-index:0;
  width:100%; height:100%;
  object-fit:contain;                /* 実寸差があっても綺麗に合わせる */
  opacity:1 !important;
  pointer-events:none;
  mix-blend-mode:normal !important;
}
.p-prodImg--main{
  position:relative; z-index:1;
  mix-blend-mode:normal !important;
  transition: transform .2s ease;    /* 好みで演出 */
}


/* この領域だけ、グローバルの a:hover {opacity:.8} 等を無効化 */
.p-products a,
.p-products a:hover,
.p-products a img{
  opacity:1 !important;
  transition: none !important;
}


/* そのうえで“メイン画像だけ”薄くする */
.p-products a:hover .p-prodImg--main,
.p-products a:focus-visible .p-prodImg--main{
  opacity: .88 !important;
}
  

/* ============================================================
特長
============================================================ */
.p-features {
	position: relative;
	width: 100%;
	min-height: 3860px; 
	background: url("/img/event_L/eLcheeseterrine2510/features-bg.png") no-repeat center top;
	background-size: contain;   
	z-index: 1;
	margin-top: -100px; 
  }


.p-features__label{
	width: 390px;
	margin-top: -140px;
	margin-inline: auto 0;
}

.p-features__point01{
	position: absolute;
	top: 353px;
	left: 50%;
	width: 864px;
	transform: translateX(-50%) !important;
}

.p-features__point_rummy {
	position: absolute;
	top: 2570px;  
	left: 38px ;       
	width: 441px;   
	
  }

.p-features__point02{
	position: absolute;
	top: 3000px;  
	left: 88px;      
	width: 938px;
}

/* ============================================================
 製品内容（ingredients）
============================================================ */
.p-ingredients {
	position: relative;
	width: 100%;
	background-color: #332b23;
padding: 70px 0 240px;
	margin-top: -10%;
	z-index: 0;
  }
  
  .p-ingredients__inner {
	text-align: center;
  }
  
 
  .p-ingredients__title {
	width: 624px; 
	margin: 0 auto 68px;
  }
  .p-ingredients__title img {
	width: 100%;
	height: auto;
	display: block;
  }

  .p-ingredients__list {
	padding: 0 68px;
	margin: 0 auto;
	display: flex;
	flex-direction: column;   
	align-items: center;
	list-style: none;

  }
  
  .p-ingredients__item {
	width: 100%;   
	margin-top: 34px;        
  }
  

  .p-ingredients__item img {
	width: 100%;           
	height: auto;
	display: block;
  }
    
  .p-ingredients__item + .p-ingredients__item::before {
	content: "";
	display: block;
	height: 1.19px;
	background-color: #a18253;
	margin: 0 auto 5vw; 
  }

  /* ============================================================
ギフト
============================================================ */

.p-gift {
	position: relative;
	width: 100%;
	min-height: 2150px;   
	margin-top: -160px; 
	background: url("/img/event_L/eLcheeseterrine2510/gift-bg.png") no-repeat center top;
	background-size: contain; 

  }

.p-gift__title{
	width: 756px;
	margin: 40px auto 0;
	padding: 212px 0 0;
}

.p-gift__text{
	width: 790px;
	margin: 40px auto 0;
}

.p-gift__box{
	width: 100%;
}



/* ============================================================
レビュー
============================================================ */
.p-voice{
	background-color: #fff;
	padding-top: 100px;
}

.p-voice__title{
	width: 594px;
	margin: auto;
}

.p-voice__item{
	width: 802px;
	margin: 62px auto 0;
}

.p-voice__item + .p-voice__item{
	margin-top: 50px;
}

.p-voice__block{
	margin-top:67px;
}

.p-voice__accButton{
	width: 187px;
	margin: auto;
	cursor: pointer;
}

.p-voice__contents{
	display: none;
}

/* ============================================================
レビコ
============================================================ */
#revico .block-goods-user-review {
  color:#504741;
  font-family:"メイリオ", Meiryo, "ヒラギノ角ゴ Pro W6", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  text-align:left;
}
#revico .revico-multicomment-top .revico-starability-result {
    background-image: url(https://show.revico.jp/img/star_yellow.png);
}
.revico-modal-state{
  display:none !important;
}

/* ============================================================
その他
============================================================ */
.p-other{
	background-color: #32271d;
	margin-top: -234px;
    padding-top: 200px;
}

.p-other__title{
	width:590px;
	margin: auto;
}

.p-other__item{
	width: 867px;
	margin: 74px auto 0;
}

.p-other__item a{
	display: block;
}

/* ============================================================
sns
============================================================ */
.p-sns{
	padding-block: 124px;
	background-color: #32271d;
}

.p-sns__title{
	width: 422px;
	margin: auto;
}

.p-sns__list{
	display: flex;
	justify-content: center;
	gap: 38px;
	margin-top: 38px;
}

.p-sns__lotte-icon{
	width: 96px;
}



/* ============================================================
パララックス
============================================================ */
.p-fadeIn{
	opacity: 0;
	transform: translateY(20px);
	transition: all 1s ease;
	visibility: hidden;
	transition-delay: 0.1s;
}

.p-fadeIn.is-show{
	opacity: 1;
	transform: translateY(0);
	visibility: visible;
}
