@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700&display=swap");



html {
  scroll-behavior: smooth;
}
@media (max-width: 1024px) {
  img {
    width: 100%;
    height: auto;
  }
	
	
  .hover {
    transition: opacity 0.3s;
  }
  .hover:hover {
    opacity: 0.5;
  }
}
  @media (max-width: 1024px) {
    .hover:hover {
      opacity: 1;
    }
  }



  body {
    font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", -apple-system, BlinkMacSystemFont, Roboto, "Segoe UI", "Helvetica Neue", HelveticaNeue, Verdana, Meiryo, sans-serif;
    color: #000;
	background-color: #fef5e7;
    font-weight: 500;
    font-size: 18px;
    line-height: 28px;
    letter-spacing: 0.05em;
    word-break: break-word;
    font-feature-settings: "palt";
  }
	
	
	
	
	
  @media (max-width: 1024px) {
    body {
      font-weight: 400;
      font-size: 3.125vw !important;
      line-height: 4.792vw;
    }
  }

/*スマホのみ改行*/
.sp-br {
  display: none;
}

/*PCのみ改行*/
.pc-br {
	display: block;
	}

/* .contentsの背景装飾 */
.contents {
  position: relative; /* 疑似要素の基準にするために必要 */
  z-index: 10;
}

/* 左右の背景共通設定 */
.contents::before,
.contents::after {
  content: "";
  position: absolute;
  top: 0;
  width: 150px;
  height: 100%;
  background-repeat: repeat-y;
  background-size: 150px auto;
	z-index: -100;
 
}

/* 左側の背景 */
.contents::before {
  left: -90px; /* コンテンツの外に出す */
  background-image: url("../img/bg_left.png");
  background-position: left top;

}

/* 右側の背景 */
.contents::after {
  right: -90px; /* コンテンツの外に出す */
  background-image: url("../img/bg_right.png");
  background-position: right top;
}




/***各コンテンツ英字タイトル***/
.contents .deta h2,
.contents .news h2,
.contents .deta h2,
.contents .deta_stamp h2,
.contents .event h2,
.contents .bargain_top h2{
	width: 20%;
	padding: 1.5% 0 1.7% 0;
	box-sizing: border-box;
    font-size: 30px;
    font-weight: 600;
	margin: 0 auto 3%;
    color: #FFF;
	background-color: #0f5f44;
    font-family: "Oswald";
	border-radius: 10px;
}

.contents .movie h2{
	font-size: 30px;
    font-weight: 600;
	margin: 0 auto 3%;
    color: #FFF;
	background-color: #0f5f44;
    font-family: "Oswald";
	border-radius: 10px;
}

/***各コンテンツ一覧タイトル***/
.contents .title{
    width: 100%;
    margin-bottom: 4%;
    text-align: center;
    padding: 1.5% 0;
    font-family: "Oswald";
    font-size: 36px;
    font-weight: 800;
    letter-spacing: 0.08em;
    color: #FFF;
    background: #0f5f44;
}



/***ヘッダー***/
/***ロゴ***/
	#header_container{
		width:100%;
		
		padding: 10px 0;
	background: #000000;
	}
	
	#header_container #header_23toreve{
		width: 100%;
		max-width: 1000px;
		margin: 0 auto;
display: flex;
	justify-content:space-between;}

#header_container #header_23toreve .logos{
	width: 30%;
	display: flex;
	justify-content:space-between;
}

#header_container #header_23toreve .logos .img{
	max-width: 100%;
	
}

#header_container #header_23toreve .logos .opa{
	width: 20%;
	padding-top: 2px;
	margin-right: 14px;
	
}

#header_container #header_23toreve .logos .vivre{
	width: 26%;
	padding-top: 8px;
	margin-right: 14px;
}

#header_container #header_23toreve .logos .forus{
	width: 31%;
	padding-top: 13px;
}

/***SNS***/

#header_container #header_23toreve .sns{
	width: 10%;
	padding-top: 2px;
}


#header_container #header_23toreve .sns ul{
	width: 100%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	
}

#header_container #header_23toreve .sns ul li{
	width: 28%;
}

#header_container #header_23toreve .sns ul li img{
	width: 100%;
}





/***MV***/
#main{
	width: 100%;
}


#main img{
	width: 100%;
}



/***コンテンツ***/
.contents{
    width: 80%;
    background-size: 100% 100%;
	margin: 2% auto 0 auto;
    text-align: center;
	
}

.contents_body{
	padding: 1% 0 1% 0;
	background: rgba(255, 255, 255, 0.9);
	box-sizing: border-box;
}

/***キャッチコピー***/
.contents .catch_top{
	width: 90%;
	max-width: 1000px;
	margin: 70px auto 70px auto;
	text-align: center;
	font-size: 32px;
	color: #0f5f44;
	line-height: 170%;
	font-weight: 700;
	padding: 3% 0;
	border-top: #0f5f44 solid 2px;
	border-bottom: #0f5f44 solid 2px;
	box-sizing: border-box;

}

.contents .catch{
	width: 90%;
	max-width: 1000px;
	margin: 70px auto 20px auto;
	text-align: center;
	font-size: 18px;
	font-weight: 600;

}



/***期間***/
.contents .deta{
	width: 100%;
	max-width: 1000px;
	margin: 70px auto 90px auto;
	text-align: center;
}


.contents .deta p{
    font-weight: 700;
    font-size: 24px;
    margin-bottom: 3%;
}

 img{
	width: 100%;
}



.contents .deta p.deta_no{
    font-size: 34px;
    color: #0f5f44;
    font-family: "Oswald";
}

/***期間スタンプ***/
.contents .deta_stamp{
	width: 100%;
	max-width: 1000px;
	margin: 30px auto 0 auto;
	text-align: center;
}


.contents .deta_stamp p{
    font-weight: 700;
    font-size: 24px;
    margin-bottom: 3%;
}




.contents .deta_stamp p.deta_no{
    font-size: 34px;
    color: #0f5f44;
    font-family: "Oswald";
}






/*一覧下日付*/
.new_data{
	margin-top: 1%;
	text-align: right;
	font-size: 16px;
}


/***NEWS***/
.contents .news{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 50px auto;
	

}

.contents .news .news_area{
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contents .news .news_data{
	width: 44%;
	text-align: right;
	font-weight: 600;
	color: #0f5f44;
}

.contents .news .txt{
	width:54%;
	text-align: left;
}



.contents .news p{
	margin-bottom: 3%;
}


/***コンテンツ-キャッチコピー第二階層***/

.contents .catch_second,
.contents .catch_second_center{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
	font-size: 20px;
	font-weight: 600;
}

.contents .catch_second img{
	width: 60%;
}





/***MOVIE***/
.contents .movie{
	width: 100%;
	padding: 5% 0 5% 0;
	box-sizing: border-box;
	margin: 70px auto auto;
	color: #FFF;
	background: #0f5f44;
}



.contents .movie iframe{
	width: 700px;
	height: 450px;
	margin-top: 0;
}

.contents .movie .coming{
	width: 700px;
	height: 450px;
	margin: 0 auto;
}

.contents .movie .coming img{
	width: 100%;
}



/***EVENT***/
.contents .event{
	width: 90%;
	margin: 100px auto 0 auto;
	text-align: center;
	
}


.contents .event .banner_area{
	width: 100%;
	margin: 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contents .event .banner_area .banner_big{
	width: 100%;
	font-weight: 600;
	margin-bottom: 2%;
}

.contents .event .banner_area .banner{
	width: 47%;
	font-weight: 600;
	margin-bottom: 2%;
}

.contents .event .banner_area .banner img{
		margin-bottom: -1%;
	}


/***ロゴ***/
.contents .logo_area{
	width: 50%;
	margin: 5% auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;


}



.contents .logo_area .sesami{
	width: 30%;
	
}

.contents .logo_area .line{
	width: 7%;

}


.contents .logo_area .opa{
	width: 9%;
}


.contents .logo_area .vivre{
	width: 16%;
	margin: 0 3%;


}


.contents .logo_area .forus{
	width: 22%;
	padding-top: 1%;
	box-sizing: border-box;

}

.contents .logo_area img{
	width: 100%;

}


/***バナーエリア***/
.contents .foot_banner{
	width: 80%;
	margin: 50px auto 100px auto;
	text-align: left;
	font-size: 14px;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.contents .foot_banner .banner{
	width: 32%;
}

.contents .foot_banner img{
	width: 100%;
}



/***セサミコピーライト***/
.contents .wh_copy{
	width: 80%;
	margin: 50px auto 100px auto;
	text-align: left;
	font-size: 14px;
	line-height: 150%;
}


/***バーゲン***/
.contents .bargain_title{
	width: 90%;
	margin: 3% auto 2%  auto;
font-family: "Oswald";
	font-size: 42px;
	font-weight: 800;}

.contents .bargain_title02{
	width: 90%;
	margin: 3% auto 2%  auto;
	font-size: 18px;
	font-weight: 700;
line-height: 170%;}

.contents .bargain{
	width: 90%;
	margin: 3% auto 6%  auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	text-align: left;
	
}

.contents .bargain::after{
  content:"";
  display: block;
  width:33%;
}



.contents .bargain .shop{
	width: 33%;
	padding: 2%;
	margin-bottom: 1%;
}



.contents .bargain .shop p.shopname{
	font-size: 24px;
	font-weight: 600;
	margin-bottom: -4%;
}

.contents .bargain .shop p.data{
    font-family: "Oswald";
    font-size: 20px;
    font-weight: 800;
    color: #1d2088;
    letter-spacing: 0.08em;
    margin-bottom: -4%;
}

.contents .bargain .shop p.offpar{
	font-size: 25px;
	font-weight: 800;
	color: #2db7d3;
	margin-bottom: 2%;
}

.contents .bargain .shop p.other{
	font-weight: 600;
}

.contents .bargain .shop .btn_bargain{
	width: 210px;
	margin-bottom: 5%;
}

.contents .bargain .shop .btn_bargain img{
	width: 100%;
}

.contents .bargain .shop a.shopname {
  color: #000000;
  text-decoration: none;
  
}

.contents .bargain .shop a.shopname:hover {
  color: #000000;
	text-decoration: underline;
	transition: color 0.5s;
	opacity: 0.5 ;
}

.contents .bargain .shop a {
  color: #000;
  text-decoration: underline;
  
}

.contents .bargain .shop a:hover {
  color: #000;
	transition: color 0.5s;
	opacity: 0.5 ;
}


/***XフォローCPリンク***/
a.xfollow {
  color: #c9151e;
  
}

a.xfollow:hover {
  text-decoration: underline;
}

.contents .bargain .shop a:hover {
  color: #000;
	transition: color 0.5s;
	opacity: 0.5 ;
}

/***アプリダウンロードキャンペーン***/
.appdl_cp{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
}

.appdl_cp img{
	width: 500px;
}

.appdl_cp .btn_all{
	width: 590px;
	margin: 5% auto 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.appdl_cp .btn{
	width: 285px;
	border: none;
}

.appdl_cp .btn img{
	width: 100%;
	
}

.appdl_cp_shop{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 1% auto;
	background: #FFF;
	padding: 1% 3% 2% 3%;
	box-sizing: border-box;
	border-radius: 20px;
	border: #000 1px solid;
	text-align: left;
}

.appdl_cp_shop_midashi{
	text-align: center;
	font-size: 24px;
	font-weight: 700;
	color: #2db7d3;
}

.appdl_cp_shop_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

/***買い回りWEEK***/
.kaimawari{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
}

.kaimawari img{
	width: 500px;
}

.kaimawari .btn_all{
	width: 590px;
	margin: 2% auto 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.kaimawari .btn{
	width: 285px;
	border: none;
}

.kaimawari .btn img{
	width: 100%;
	
}

.kaimawari_shop{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 1% auto;
	background: #FFF;
	padding: 1% 3% 2% 3%;
	box-sizing: border-box;
	border-radius: 20px;
	border: #000 1px solid;
	text-align: left;
}

.kaimawari_shop_midashi{
	text-align: center;
	font-size: 24px;
	font-weight: 700;
	color: #2db7d3;
}

.kaimawari_shop_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

/***限定トーク***/
.talk{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
}


.talk_shop{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 1% auto;
	background: #FFF;
	padding: 1% 3% 2% 3%;
	box-sizing: border-box;
	border-radius: 20px;
	border: #000 1px solid;
	text-align: left;
}

.talk_shop_midashi{
    text-align: center;
    font-size: 24px;
    font-weight: 700;
    color: #1d2088;
}


.talk_shop_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

/***お笑いLIVE***/

.live{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
}


.live_btn{
	width: 100%;
	max-width: 600px;
	margin: 3% auto 3% auto;
}

.live_btn img{
	width: 100%;
}

.live_shosai {
	width: 100%;
	max-width: 1000px;
	margin-bottom: 2%;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.live_shosai .midashi {
	width: 26%;
	padding: 1% 0;
	background-color: #2db7d3;
	color: #fff;
	display: flex;
	justify-content: center;
	font-size: 22px;
	text-align: center;
}

.live_shosai .txt {
	width: 72%;
	color: black;
	font-size: 18px;
	padding: 1% 0;
	text-align: left;
}

.live_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}


/***メタバース***/

.metaverse_pickup{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 0 auto;
	padding: 0% 0 3% 0;
	box-sizing: border-box;
	display: flex;
	align-items: center;  /* 縦方向中央 */
	justify-content: center;  /* 横方向中央 */
	font-size: 3vw;
	font-weight: 700;
	color: #1d2088;
	background: #faf6b1;
	text-align: center;
	height: 120px; /* 高さを指定（必要に応じて調整） */
	line-height: 110%;
}

.dainidan{
	font-size: 2.3vw;
}

.metaverse_shop{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 5% auto;
	padding: 1% 3% 2% 3%;
	box-sizing: border-box;
	border-radius: 20px;
	border: #000 1px solid;
	text-align: cener;
}



.metaverse_btn{
	width: 420px;
	border: none;
	margin: 2% auto 6% auto;
}

.metaverse_img{
	width: 100%;
	max-width: 1000px;
	border: none;
	margin: 2% auto 6% auto;
}

.metaverse_btn img,
.metaverse_img img{
	width: 100%;
}

.metaverse_shop_midashi{
	text-align: center;
	font-size: 24px;
	font-weight: 700;
	line-height: 130%;
	
}

.metaverse_shop_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

/***Xフォローキャンペーン***/
.x_follow_btn{
	width: 320px;
	border: none;
	margin: 4% auto 6% auto;
}

.x_follow_btn img{
	width: 100%;
}

.x_follow_attention{
	width: 100%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

/***プレゼントCP***/
.present{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
	text-align: center;
}


.present_shop{
	width: 50%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
}

.present_item{
	width: 100%;
	max-width: 1000px;
	margin: 3% auto 3% auto;
}

.present_shop img
.present_item img{
	width: 100%;
}

/*抽選会説明*/
.chusen_img_pc{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	display: block;

}

.chusen_img_pc img{
	width: 100%;
}

.chusen_img_sp{
	display: none;

}

/*オーナメント*/
.ornament_img_pc{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	display: block;

}

.ornament_img_pc img{
	width: 100%;
}

.ornament_img_sp{
	display: none;

}

/*ツリー写真*/
.tree_img{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto; 
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
}

.tree_img::after {
	content: "";
	display: block;
	width: 31%;  /* .photoと同じ幅を指定 */
}

.tree_img .photo{
	width: 31%;
	margin-bottom: 4%;
}

.tree_img .photo img{
	width: 100%;
}


/*キャッチコピー部分共通*/
.present_shop_deta,
.stamp_shop_deta,
.x_shop_deta,
.tree_shop_deta{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 20px;
	font-weight: 600;
}

.stamp_shop_deta{
	margin: 0 auto 5% auto;
}



.present_shop_deta img,
.stamp_shop_deta img,
.x_shop_deta img,
.tree_shop_deta img{
	width: 50%;
}

.x_info{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	text-align: left;
}

.present_shop_deta_attention,
.stamp_shop_deta_attention{
	font-size: 18px;
	line-height: 160%;
}

.present_shop_attention,
.stamp_shop_attention{
	width: 90%;
	max-width: 1000px;
	margin: 0 auto 3% auto;
	font-size: 16px;
	font-weight: 700;
}


/***リスト-プレゼント枠***/
.contents .title_deta{
	width: 90%;
	margin: 0 auto;
	padding: 2.4% 0 2% 0;
	background: #c9151e;
	border-radius:20px 20px 0px 0px ;
	font-size:40px;
	font-weight: 700;
	color: #FFFFFF;
	
}

.contents .present_list_area{
	width: 90%;
	margin: 0 auto 5% auto;
	box-sizing: border-box;
	border: #c9151e 2px solid;
	border-radius: 0px 0px 20px 20px;
}

.contents .present_list_area .present_img{
	width: 100%;
	margin: 3% 0;
}


.contents .present_list_area .present_img img{
	width: 80%;
}

.txt_coming{
	font-size:40px;
	color: #595959;
	font-weight: 700;
}



/***リスト***/
.contents .list_area{
	width: 90%;
	margin: 0 auto 5% auto;
}





/**アコーディオン**/

.p-accordion {
  max-width: 100%;
	margin-top: 2%;
  margin-inline: auto;
	text-align: left;
}

.p-accordion img{
	width: 50%;
}

.p-accordion-desc {
  font-size: 28px;
  font-weight: 600;
}
.p-accordion__head {
  cursor: pointer;
  background: #fff2ad;
	color: #000;
  display: block;
  padding: 2%;
  margin-top: 10px;
	font-size: 22px;
  font-weight: 600;
}

.p-accordion__head a{
	color: #000;
}

.p-accordion__head-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.p-accordion__icon {
  display: block;
  position: relative;
  width: 24px;
  transition: transform 0.25s;
}
.p-accordion__icon:before {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 2px;
  background-color: #000;
}
.p-accordion__icon:after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 2px;
  background-color: #000;
}
.p-accordion__icon:before {
  left: 0;
  transform: rotate(45deg);
}
.p-accordion__icon:after {
  right: 0;
  transform: rotate(-45deg);
}
.p-accordion__input input[name=p-accordion__block] {
  display: none;
}
.p-accordion__input .p-accordion__block {
  cursor: pointer;
}
.p-accordion__input .p-accordion__content {
  height: 0;
  padding: 0 20px;
  overflow: hidden;
  opacity: 0.5;
  background-color: #fff;
  transition: padding 0.25s ease, opacity 0.3s ease 0s;
}

.p-accordion__input .p-accordion__content p{
	margin-bottom: 1%;
}

.p-accordion__input .p-accordion__content a {
    color: #000;
    font-weight: 600;
    text-decoration: none;  
}

.p-accordion__input .p-accordion__content a:hover {
	text-decoration: underline;
	transition: color 0.5s;
	opacity: 0.5 ;
}

.p-accordion__input input[name=p-accordion__block]:checked + .p-accordion__head > .p-accordion__head-inner .p-accordion__icon {
  transform: rotate(-180deg);
}
.p-accordion__input input[name=p-accordion__block]:checked + .p-accordion__head + .p-accordion__content {
  /*開閉時*/
  height: auto;
  opacity: 1;
  padding: 20px;
}

/***アプリダウンロード***/

.contents .appdl_btn{
	width: 400px;
	margin: 0 auto;
		margin-top: 4%;
	padding-bottom: 3%;
}


.contents .appdl_bt img{
	width: 100%;
}

/***トップへ戻る***/

.contents .gotop{
	width: 300px;
	margin: 0 auto;

}

/***リスト背景***/
.bg_white{
	background: #FFFFFF;
}

.bg_beige{
	background: #fef3ee;
}

.contents .gotop img{
	width: 100%;
}

/**注釈**/
	.attention_txt{
		font-size: 16px;
	}

/**右寄せ**/
.align_right{
	text-align: right;
}

/**太字**/
.txt_bold{
	font-weight: 600;
}

/**文字大**/
	.txt_big{
		font-size: 20px;
	}

/**文字小**/
	.txt_small{
		font-size: 16px;
	}

/**文字色変更**/
.txt_red{
	color: #CC0000;
}

.txt_red_wh{
	color: #c9151e;
}

.txt_blue{
	color: #1d2088;
}


.txt_green{
	color: #0f5f44;
}

@media (max-width: 1024px) {
	
/*スマホのみ改行*/
.sp-br {
	display: block;
	}
	
/*PCのみ改行*/
.pc-br {
	display: none;
	}

	
/***ヘッダー***/

    #header_container #header_23toreve{
		width: 90%;
		margin: 0 auto;}

/***ロゴ***/
#header_container #header_23toreve .logos{
	width: 52%;
	margin: 2% 0 0 1%;
	
	
}
	
	#header_container #header_23toreve .logos .opa,
	#header_container #header_23toreve .logos .opa02,
	#header_container #header_23toreve .logos .vivre,
	#header_container #header_23toreve .logos .forus{
	margin-right: 0;
	
}
	
#header_container #header_23toreve .logos .opa{
	padding-top: 1%;
	
}

#header_container #header_23toreve .logos .vivre{
	padding-top: 3%;
}

#header_container #header_23toreve .logos .forus{
	padding-top: 4%;
	width: 34%;

}

	
/***SNS***/

#header_container #header_23toreve .sns{
	width: 25%;
	margin: 0;
	padding-top: 1%;
}



#header_container #header_23toreve .sns ul li{
	width: 28%;
}

	
/***MV***/
#main{
	width: 100%;
}
	

/***背景***/

/* 左右の背景共通設定 */
.contents::before,
.contents::after {
  width: 70px;
  background-size: 70px auto;
}
	
/* 左側の背景 */
.contents::before {
  left: -26px; /* コンテンツの外に出す */
}

/* 右側の背景 */
.contents::after {
  right: -26px; /* コンテンツの外に出す */
}

	
/***コンテンツ***/
.contents{
	width: 88%;
	margin: 0 auto;
	background: none;
	background: #FFF;

}
	

	
/***各コンテンツ英字タイトル***/
.contents .deta h2,
.contents .news h2,
.contents .deta h2,
.contents .deta_stamp h2,
.contents .event h2,
.contents .bargain_top h2{
	width: 70%;
	padding: 3% 0 3.5% 0;
	box-sizing: border-box;
    font-size: 5vw;
	margin: 0 auto 4%;
	border-radius: 6px;
}
	
/***キャッチコピー***/
.contents .catch_top{
	width: 100%;
	max-width: 90%;
	margin: 8% auto 2% auto;
	font-size: 4.2vw;
	line-height: 170%;
	padding: 3% 0;


}	
	
	
.contents .catch{
	width: 90%;
	font-size: 3.2vw;
	margin:7% auto 6% auto;
	text-align: left;
}
	

	br.catch{
		display: none;
	}


.contents .catch h2{
font-size: 3.8vw;
	margin-bottom: 2%;
}
	
/***期間***/
.contents .deta{
	width: 90%;
	margin: 8% auto 12% auto;
	text-align: center;
}


.contents .deta p{
    font-size: 3.4vw;
    margin-bottom: 3%;
}



.contents .deta p.deta_no{
    font-size: 5vw;
}
	
	
/*ツリー写真*/
.tree_img{
	width: 90%;
	margin: 8% auto 6% auto;
}

.tree_img .photo{
	width: 48%;
	margin-bottom: 8%;
}


	
/*抽選会説明*/
.chusen_img_pc{
	display: none;
	

}


.chusen_img_sp{
	width: 90%;
	margin: 8% auto 6% auto;
	display: block;
}	
	
/*オーナメント*/
.ornament_img_pc{
	display: none;
	

}


.ornament_img_sp{
	width: 90%;
	margin: 8% auto 6% auto;
	display: block;
}	
	
	
/***期間スタンプ***/
.contents .deta_stamp{
	width: 90%;
	margin: 8% auto 6% auto;
	text-align: center;
}


.contents .det_stampa p{
    font-size: 3.4vw;
    margin-bottom: 3%;
}



.contents .deta_stamp p.deta_no{
    font-size: 5vw;
}
	
.txt_center{
		text-align: center;
	}
	
.contents .catch_second{
	width: 90%;
	margin: 7% auto 7% auto;
	font-size: 3.8vw;
	line-height: 180%;
	text-align: left;
}
	
.contents .catch_second img{
	width: 100%;
}
	
.contents .catch_second_center{
	width: 90%;
	margin: 7% auto 7% auto;
	font-size: 3.8vw;
	line-height: 180%;
	font-weight: 700;
}
	


/***NEWS***/
.contents .news{
	width: 90%;
	margin: 0 auto 0% auto;
}
	

.contents .news .news_data{
	width: 100%;
	text-align: left;

}

.contents .news .txt{
	width:100%;

}
	

.contents .news p{
	margin-bottom: 0%;
}
	
/***BARGAIN***/
.contents .bargain_top{
	width: 90%;
	margin: 70px auto auto;
	
}

.contents .bargain_top .banner{
	width: 100%;
	margin: 0 auto;
}

/***MOVIE***/
.contents .movie{
	width: 100%;
	margin: 12% auto;
}

.contents .movie h2{
	margin: 3% 0 3% 0;
}

.contents .movie p{
	margin-bottom: 3%;
}
	
.contents .movie iframe{
	width:90%;
height: 260px;
	margin: 2% 0 3% 0;}
	

	


/***EVENT***/
.contents .event{
	width: 90%;
	margin: 16% auto;
	text-align: center;
	
}


.contents .event .banner_area .banner{
	width: 48%;
	margin-bottom: 1%;
}

	.contents .event .banner_area .banner p{
		margin-bottom: 0%;
	}	
	
.contents .event .banner_area .banner img{
		margin-bottom: -3%;
	}
	
	
	
/***ロゴ***/
.contents .logo_area{
	width: 80%;
	margin: 5% auto 0 auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: center;


}






.contents .logo_area .opa{
	padding-top: 2%;
	box-sizing: border-box;
}


.contents .logo_area .vivre{
	padding-top: 2.5%;
	box-sizing: border-box;

}


.contents .logo_area .forus{
	padding-top: 3.5%;
	box-sizing: border-box;

}
	

/***バナーエリア***/
.contents .foot_banner{
	width: 90%;
	margin: 16% auto;
}

.contents .foot_banner .banner{
	width: 70%;
	margin:0 auto 5% auto;
}
	
	

/***セサミコピーライト***/
.contents .wh_copy{
	width: 90%;
	margin: 16% auto;
	font-size: 2vw;
}	
	

.contents .title,
.contents .title_iryohinkaishu{
		width: 100%;
	margin: 3% auto 2%  auto;
	padding: 3%;
	font-size: 6vw;}	
	




.contents .bargain .shop p.shopname{
	font-size: 3.5vw;
	margin-bottom: -3%;
}

.contents .bargain .shop p.data{
	font-size: 3.8vw;
	font-weight: 800;
	margin-bottom: -3%;
}
	
.contents .bargain .shop p.offpar{
	font-size: 5vw;
	margin-bottom: 3%;
}


.contents .bargain .shop .btn_bargain{
	width: 50%;
	margin-bottom: 5%;
}
	
	
/***バーゲン***/
.contents .bargain_title{
	width: 90%;
	margin: 3% auto 5%  auto;
font-size: 6.5vw;}

.contents .bargain_title02{
	width: 90%;
	margin: 3% auto 2%  auto;
	font-size: 3vw;
	}
	
	
	


.txt_left{
		text-align: left;
	}
	
br.no-wrap {
    display: none;
  }


.txt_skyblue01{
	font-size: 3.1vw;
	margin-bottom: -6%;
}

.txt_skyblue02{
	font-size: 6.5vw;
	margin-bottom: 2%;
}

.txt_skyblue03{
	line-height: 160%;
	
}

.no-wrap {
  white-space: nowrap;
}
	
.contents .catch_second_iryohinkaishu .illust01,
	.contents .catch_second_iryohinkaishu .illust02,
	.contents .catch_second_iryohinkaishu .illust03{
display: none;
}
	
.txt_about{
	margin-bottom: -3%;
}

.contents .catch_second_iryohinkaishu .btn{
	width: 80%;
	margin: 8% auto 0 auto;
	border: 0;
}
	

/***アプリダウンロードキャンペーン***/
.appdl_cp{
	width: 80%;
	margin: 3% auto 3% auto;

}

.appdl_cp img{
	width: 80%;
}

.appdl_cp .btn_all{
	width: 100%;
	margin: 5% auto 10% auto;
}

.appdl_cp .btn{
	width: 49%;
}


.appdl_cp_shop{
	width: 90%;
	margin: 3% auto 1% auto;
	padding: 1% 4% 4% 4%;
	border-radius: 20px;
	font-size: 3.1vw;
}

.appdl_cp_shop_midashi{
	font-size: 4vw;

}

.appdl_cp_shop_attention{
	width: 90%;
	margin: 3% auto 10% auto;
	font-size: 3.1vw;
}
	
/***買い回りWEEK***/
.kaimawari{
	width: 80%;
	margin: 3% auto 3% auto;

}

.kaimawari img{
	width: 80%;
}

.kaimawari .btn_all{
	width: 100%;
	margin: 2% auto 10% auto;
}

.kaimawari .btn{
	width: 49%;
}


.kaimawari_shop{
	width: 90%;
	margin: 3% auto 1% auto;
	padding: 1% 4% 4% 4%;
	border-radius: 20px;
	font-size: 3.1vw;
}

.kaimawari_shop_midashi{
	font-size: 4vw;

}

.kaimawari_shop_attention{
	width: 90%;
	margin: 3% auto 10% auto;
	font-size: 3.1vw;
}
	
/***限定トーク***/
.talk{
	width: 80%;
	margin: 3% auto 3% auto;
}

.talk_shop{
	width: 90%;
	margin: 3% auto 1% auto;
	padding: 1% 4% 4% 4%;
	border-radius: 20px;
	font-size: 3.1vw;
}

.talk_shop_midashi{
	font-size: 4vw;

}

.talk_shop_attention{
	width: 90%;
	margin: 3% auto 10% auto;
	font-size: 3.1vw;
}
	
/***お笑いLIVE***/
.live{
	width: 90%;
	margin: 3% auto 3% auto;
}
	
.live_btn{
	width: 90%;
	margin: 3% auto 8% auto;
}	
	
	
.live_shosai{
	width: 100%;
	margin: 3% auto 1% auto;

}
	
.live_shosai .midashi {
	width: 22%;
	padding: 2% 0;
	font-size: 3.1vw;
}

.live_shosai .txt {
	width: 76%;
	font-size: 3.1vw;
	padding: 2% 0;
}
	
.live_attention{
	width: 90%;
	margin: 3% auto 10% auto;
	font-size: 3.1vw;
}	
	
	
	
/***メタバース***/

	
.metaverse_pickup{
		width: 90%;
	height: 70px;
	margin: 5% auto 0% auto;
	padding: 1% 4% 6% 4%;
	font-size: 4.5vw;
		
	}
	
.dainidan{
	font-size: 3.6vw;
}	
	

.metaverse_shop_midashi{
	font-size: 4vw;

}
	
	.metaverse_shop{
	width: 80%;
	margin: 3% auto 1% auto;
	padding: 1% 4% 4% 4%;
	border-radius: 20px;
	font-size: 3.1vw;
}

.metaverse_shop_attention{
	width: 80%;
	margin: 3% auto 10% auto;
	font-size: 3.1vw;
}
	
.metaverse_btn{
	width: 80%;
	border: none;
	margin: 5% auto 8% auto;
}

.metaverse_img{
	width: 90%;
	border: none;
	margin: 5% auto 8% auto;
}
	
/***Xフォローキャンペーン***/
.x_follow_btn{
	width: 60%;
	border: none;
	margin: 4% auto 6% auto;
}

.x_follow_attention{
	width: 90%;
	margin: 0 auto 8% auto;
	font-size: 3.1vw;
}
	
/***プレゼントCP***/
.present{
	width: 80%;
	margin: 3% auto 3% auto;
}

.present_shop{
	width: 90%;
	margin: 3% auto 10% auto;
}
	
.present_shop_deta,
.stamp_shop_deta,
.x_shop_deta,
.tree_shop_deta{
	width: 90%;
	margin: 0 auto 3% auto;
	font-size: 3.6vw;
	text-align: left;
}
	
.x_info{
	width: 90%;
	margin: 0 auto 3% auto;
	font-size: 3vw;
}	
	
.stamp_shop_deta,
.x_shop_deta,
.tree_shop_deta{
	margin: 0 auto 10% auto;

}
	
	

.present_shop_deta img,
.stamp_shop_deta img,
.x_shop_deta img,
.tree_shop_deta img{
	width: 100%;
}

.present_shop_deta_attention{
	font-size: 2.8vw;
	
}
	
.present_item{
	width: 90%;
	margin: 3% auto 10% auto;
}
	

	
.present_shop_deta_attention,
.stamp_shop_deta_attention{
	font-size: 3.1vw;
}

.present_shop_attention,
.stamp_shop_attention{
	width: 90%;
	margin: 3% auto 6% auto;
	font-size: 3.1vw;
	text-align: left;
}
	
	
/***リスト-プレゼント枠***/
.contents .title_deta{
	padding: 3% 0 2% 0;
	border-radius:10px 10px 0px 0px ;
	font-size:5vw;
	
}

.contents .present_list_area{
	margin: 0 auto 10% auto;
	border-radius: 0px 0px 10px 10px;
}



.contents .present_list_area .present_img img{
	width: 90%;
}

.txt_coming{
	font-size:5vw;
	color: #595959;
	font-weight: 700;
}	


/***リスト***/
.contents .list_area{
	width: 90%;
	margin: 0 auto 15% auto;
}
	



	
/***アコーディオン***/

.p-accordion {
  max-width: 100%;
	margin-top: 2%;
  margin-inline: auto;
	
}
	
.p-accordion img{
	width: 100%;
}


.p-accordion__head {
  cursor: pointer;
  display: block;
  padding: 4%;
  margin-top: 3%;
	font-size: 3.8vw;
}
.p-accordion__head-inner {
  display: flex;
  justify-content: space-between;
  align-items: center;
}
.p-accordion__icon {
  display: block;
  position: relative;
  width: 24px;
  transition: transform 0.25s;
}
.p-accordion__icon:before {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 2px;
}
.p-accordion__icon:after {
  content: "";
  position: absolute;
  display: block;
  width: 15px;
  height: 2px;
}
.p-accordion__icon:before {
  left: 0;
  transform: rotate(45deg);
}
.p-accordion__icon:after {
  right: 0;
  transform: rotate(-45deg);
}
.p-accordion__input input[name=p-accordion__block] {
  display: none;
}
.p-accordion__input .p-accordion__block {
  cursor: pointer;
}
.p-accordion__input .p-accordion__content {
  height: 0;
  padding: 0 20px;
  overflow: hidden;
  opacity: 0.5;
  background-color: #fff;
  transition: padding 0.25s ease, opacity 0.3s ease 0s;
}

.p-accordion__input .p-accordion__content p{
	margin-bottom: 2%;
}

.p-accordion__input .p-accordion__content a {
	font-weight: 600;
  text-decoration: none;
  
}

.p-accordion__input .p-accordion__content a:hover {
	text-decoration: underline;
	transition: color 0.5s;
	opacity: 0.5 ;
}

.p-accordion__input input[name=p-accordion__block]:checked + .p-accordion__head > .p-accordion__head-inner .p-accordion__icon {
  transform: rotate(-180deg);
}
.p-accordion__input input[name=p-accordion__block]:checked + .p-accordion__head + .p-accordion__content {
  /*開閉時*/
  height: auto;
  opacity: 1;
  padding: 20px;
}


/***各コンテンツトップへ***/

.contents .go_conttop{
	width: 80%;
	padding-bottom: 10%;
}
	
/***トップへ戻る***/

.contents .gotop{
	width: 60%;
	padding-bottom: 18%;
}
	
/***アプリダウンロード***/

.contents .appdl_btn{
	width: 90%;
	margin-top: 8%;
	padding-bottom: 10%;
}


/**注釈**/
	.attention_txt{
		font-size: 3vw;
		line-height: 140%;
		font-weight: 400;
	}
	
/**文字大**/
	.txt_big{
		font-size: 3.8vw;
		line-height: 170%;
		margin-bottom: 6%;
	}
	
/**文字小**/
	.txt_small{
		font-size: 3.1vw;
	}
	
}





	
