@charset "utf-8";
/* CSS Document */
/*--------------------
loading
--------------------*/

#loading {
  position: fixed;
  inset: 0;               /* top:0 right:0 bottom:0 left:0 */
  background: var(--meweplus-color-base);/* 背景色 */
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 9999;
	
	img{
        width: 50%;
        max-width: 200px;
        z-index: 100;
        position: relative;
		
	}
}

.priority{
	opacity: 1!important;
}

/*--------------------
mewePlusページ共通部分
--------------------*/
#main,
body.view.sp #main{
	padding: 40px 4% 200px;
	    box-sizing: border-box;
}
.wide_only{
	display: none!important;
}


#main_header, div.footer, .bnrArea, .colGuide, footer, .main_banner_area {
  display: none;
}

.sp .pc_only,.pc .sp_only{
	display: none;
}

.pc .pc_only,.sp .sp_only{
	display: block;
}


figure {
  margin: 0;
}

#annotation {
	padding: 10px 4%;
	line-height: 1.3em;
	li{
		display: inline;
		font-size: 11px;
		
	&:before{
	content: "※";
}
}}

#questionnaire{
	margin: 20px 5%;
	padding:16px 5%;
	border: 2px solid var(--meweplus-color-questionnaire);
	box-sizing: border-box;
	font-size: 13px;
	dt{
		border-bottom: 1px solid var(--meweplus-color-txt);
		padding-bottom: 12px;
		margin-bottom: 10px;
		p{font-weight: bold;
			font-size: 1.3em;
			color: var(--meweplus-color-questionnaire);
		}
		em{font-weight: bold;
			color: #8c8c8d;
			
			font-family: var(--fontfamily-english);
		}
	}
	dd{
		strong{color: var(--meweplus-color-questionnaire);
		font-weight: bold;
			.pt{font-family: var(--fontfamily-english);
			font-weight: bold;
			font-size: 1.4em;padding: 0 2px;}}
	}
	
	dd.info{
		margin-top: 20px;
		img.qr{
			max-width: 160px;
			margin: 0 auto 10px;
		}
		a.link{
			display: block;
			width: 80%;
			max-width: 400px;
			background: var(--meweplus-color-questionnaire);
			text-align: center;
			padding: 10px 0 12px;
			margin: 10px auto;
			font-weight: bold;
			border-radius:var(--box-radius-small);
			color: #fff;
			&:after {
    font-family: var(--fontfamily-icon);
    content: "\e5cc";
    margin: 0;
    vertical-align: middle;
    position: absolute;
    top: calc(50% - 12px);
    right: 6px;
    line-height: 1em;
    font-size: 24px;
}

		}
		.annotation{
			    line-height: 1.3em;
			   li {
				   display: inline;
        font-size: 11px;
        &:before {
            content: "※";
        }
    }
			
		}
		.deadline{font-weight: bold;color: #8c8c8d;margin: 6px 0 0;}

	}
}

#footer{
	margin-top: 80px;
	text-align: center;
	.logo{
		font-size: 13px;
		margin-bottom: 20px;
		 img{
            width: 50%;
            max-width: 240px;
            margin: 0 auto 10px;
	}
	}
	.btn a{
		            display: block;
            width: 80%;
		
            max-width: 260px;
		
		margin: 0 auto;
		font-weight: bold;
		background: var(--meweplus-color-base);
		            padding: 14px 0 16px;
		            border-radius:var(--box-radius-small);
		position: relative;
	&:after {
    font-family: var(--fontfamily-icon);
    content: "\e5cc";
    margin: 0;
    vertical-align: middle;
    position: absolute;
    top: calc(50% - 12px);
    right: 6px;
    line-height: 1em;
    font-size: 24px;
		font-weight: normal;
}
	}

}

	.copyright {
    font-size: 0.7em;
    line-height: 1.2em;
    margin-top: 30px;
		padding: 0 8px;
		text-align: center;
}

/*デフォルト解除*/
.img_bg_css {
  border-radius: 0;
}
.meweplus #contents {
  max-width: 1560px;
  margin: auto;
  position: relative;
}
.meweplus.view.pc #contents h2 {
  width: auto;
  background: none;
}
.meweplus.view #contents h2 span {
  border-bottom: none;
}
body.meweplus #contents .inner {
  background: none;
}



/*商品説明文*/

figcaption{
    font-size: 13px;
	line-height: 1.6em;
	margin: 10px auto 0;
}

figcaption .shop_name{
	font-weight: bold;
	margin-top:0.5em;
	display: block;

.name{
	padding: 0 0.6em 0 0;
	font-weight: bold;
}
.place{
	display: inline-block;
	padding: 0 0.6em 0 0;
}

.tel{
	display: inline-block;
	&:before{
	font-family: var(--fontfamily-icon);
    font-variation-settings: 'FILL' 0;
    font-size: 1.2em;
    vertical-align: bottom;
    margin-right: 1px;
    display: inline;
	content: "\e0b0";
	position: relative;
	top: 1px;
}
}


}
figcaption .item_name{
	margin-top: 0.4em;
	em{
		font-weight: bold;
		display: inline-block;
		&:not(:last-of-type):after{
			content: "／";
			padding: 0 4px;
		}
	}
}

/*
-------------------------------------------------
-------------------------------------------------
スマホファースト
-------------------------------------------------
-------------------------------------------------
*/ :root {
  --color-001: #639bb8;
}
#contents {
  display: block;
  padding: 0;
	color: var(--meweplus-color-txt);
	a{
		color: var(--meweplus-color-txt);
	}

}

#contents section.split_box.right_cnt{
	position: relative;
	background: #fff;
	z-index: 3;
	padding-bottom: 10px;    max-width: 740px;
    margin: 0 auto;
}

#contents section.split_box.left_nav {
  display: block;
  width: 100%;
	z-index: 3;
	h1{
        width: 50%;
        max-width: 280px;
        margin: 50px auto 50px;
        position: relative;
	}
	
#nav{
        position: fixed;
        top: 40px;
        right: 0;
        width: 60px;
               padding: 17px 4px 16px;
        background: var(--meweplus-color-sub2);
        border-top-left-radius: var(--box-radius-small);
	border-bottom-left-radius: var(--box-radius-small);
        z-index: 101;
        display: flex;
        font-size: 0;
        cursor: pointer;
  &::before{
    content: "";
    display: block;
    width: 66%;
    margin: 0 auto;
    aspect-ratio: 35 / 23;
    background: url("2603/nav.svg") no-repeat center / contain;
  }
	&.active::before{
		background: url("2603/nav_close.svg") no-repeat center / contain;
	}
}
	
	#nav,
#scroll_index_box{
  opacity:0;
  pointer-events:none;
  transition:0.3s;
}

#nav.show{
  opacity:1;
  pointer-events:auto;
}
	
.index_box{
        background: #fff;
        padding: 30px 7%;
        margin: 0 auto 100px;
        box-sizing: border-box;
        height: auto;
        width: 90%;
	max-width: 740px;
        z-index: 100;
        position: relative;
		li{
		margin-bottom: 20px;
		&:last-of-type{
			margin-bottom: 0;
		}
		
		
		a{display: block;
			position: relative;
			padding-left: 16px;
			line-height: 1.5em;
			
		&::before{
			content: "";
			width: 1px;
			height: 100%;
			background: var(--meweplus-color-sub2);
			display: block;
			position: absolute;
			left: 0;
		}
			          em {
            display: block;
			  color: var(--meweplus-color-sub2);
          }
			}
		

		
	}
}
	
	#scroll_index_box{
		background:none;
		  opacity: 0;
  visibility: hidden;
  transition: opacity 0.3s ease, visibility 0s linear 0.3s;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
		max-width: 100%;
  height: 100vh;
  display: flex;
  z-index: 100;
  justify-content: center;
  align-items: center;
		  &.active{
    opacity: 1;
    visibility: visible;
    pointer-events: auto;
    transition: opacity 0.3s ease;
	  &::before{
		  content: "";
		  width: 100%;
		  height: 100vh;
		  z-index: 1;
		  position: fixed;
		  top: 0;
		  left: 0;
	  }
	  ul{
                        background: #fff;
                width: 90%;
                padding: 40px 5%;
                font-size: 13px;
                box-sizing: border-box;
                box-shadow: 0px 5px 15px 0px rgba(0, 0, 0, 0.2);
                position: relative;
                z-index: 100;
                border: 1px solid var(--meweplus-color-sub2);
		  	
	li{
		margin-bottom: 20px;
		&:last-of-type{
			margin-bottom: 0;
		}
		
		
		a{display: block;
			position: relative;
			padding-left: 16px;
			line-height: 1.5em;
			
		&::before{
			content: "";
			width: 1px;
			height: 100%;
			background: var(--meweplus-color-sub2);
			display: block;
			position: absolute;
			left: 0;
		}
			          em {
            display: block;
			  color: var(--meweplus-color-sub2);
          }
			}
		

		
	}
	}
  }
	}
	

	
}

/*
-------------------------------------------------
-------------------------------------------------
1024px以上
-------------------------------------------------
-------------------------------------------------
*/
/*default幅リセット*/
@media (max-width: 1020px) and (min-width: 768px) {
    .pc #main {
        width: 100%;
    }
}

@media screen and (min-width: 1024px) {
	.narrow_only{
	display: none!important;
}

	
		.wide_only{
	display: block!important;
}
	
	    .pc #main {
        width: 100%;
    }
	
	#main{
		padding: 0;
	}
	
	
  .meweplus #contents {
    display: flex;
  }
  #contents section.split_box.left_nav {
	  
	  >div{
		  width: 60%;
		  min-width: 340px;
		  max-width: 380px;
	  }
	  	h1{
		width: 90%;
	}
	  
    display: flex;
    justify-content: center;
    align-items: center;
    position: fixed;
    top: 0;
    left: 0;
    height: 100vh;
    width: 45%;
    .index_box {

    }
	  

    #scroll_index_box {  
	  display: none;
	  
	  }
	  
	  
  }
  #contents section.split_box.right_cnt::-webkit-scrollbar {
    display: none;
  }
  #contents section.split_box.right_cnt {
    position: absolute;
    top: 0;
    right: 0;
    overflow-y: scroll;
    width: 55%;
    min-height: 100vh;
    -ms-overflow-style: none;
    scrollbar-width: none;
    background: #fff;
	  


  }
	

	
}
/*スクロールダウン*/
body.pc #contents section.split_box.right_cnt .scroll {
  display: block;
  height: 400px;
  background-color: #fff;
  position: absolute;
  width: 20px;
  right: 1.5%;
  bottom: 0;
}

@keyframes liner {
  0% {
    transform: scale(1, 0);
    transform-origin: 0 0;
  }
  30% {
    transform: scale(1, 1);
    transform-origin: 0 0;
  }
  70% {
    transform: scale(1, 1);
    transform-origin: 0 100%;
  }
  100% {
    transform: scale(1, 0);
    transform-origin: 0 100%;
  }
}