/*resetcss----------------*/
/*
  Josh's Custom CSS Reset
  https://www.joshwcomeau.com/css/custom-css-reset/
*/
*, *::before, *::after {
  box-sizing: border-box;
}
* {
  margin: 0;
}
html, body {
  height: 100%;
}
body {
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
}
img, picture, video, canvas, svg {
  display: block;
  max-width: 100%;
}
input, button, textarea, select {
  font: inherit;
}
p, h1, h2, h3, h4, h5, h6 {
  overflow-wrap: break-word;
}

a {
  text-decoration: none;
}

/*content------------------*/
body{
background:#fff;
color:#000;
font-weight:400;
line-height:1.8;
margin:0;
overflow-wrap: anywhere;
word-break: normal;
line-break: strict;
}



.lpwrapper {
  position: relative;
  max-width: 500px;
  margin: 0 auto;
  overflow: hidden;
  aspect-ratio: 500 / 870;
}

@media (max-width: 768px) {
  .lpwrapper {
 width: 100%;
 height: auto;
}
}

/* header */
.header {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  z-index: 10;
  pointer-events: none;
}

.header-menu {
  display: flex;
  justify-content: center;
  gap: 10px;
  padding: 12px;
  pointer-events: auto; 
}

.header-menu a {
  text-decoration: none;
  color: #333;
  font-weight: bold;
  font-size: 12px;
}

.header-menu a.is-active {
  border-bottom: 2px solid #e2470f;
  color: #e2470f;
}

/* footer */
.footer-menu {
  max-width: 500px;
  margin: 0 auto;
  height: 30px;
  background: #333;
}

.footer-nav {
  display: flex;
  height: 100%;
  gap: 20px;
  justify-content: center;
}

.footer-nav a {
  display: flex;
  align-items: center;
  font-size: 10px;
  font-weight: bold;
  color: #fff;
}


/* Swiper共通 */
.cate-swiper,
.contents-swiper {
  width: 100%;
  height: 100%;
}

.swiper {
  width: 100%;
  height: 100%;
}

.swiper-slide {
  display: flex;
  align-items: center;
  justify-content: center;
}

.img-wrap {
  position: relative;
  width: 100%;
  aspect-ratio: 500 / 870;
}

.mainimg {
  width: 100%;
  height: auto;
  display: block;
}


.swiper-slide.top {
  position: relative;
  width: 100%;
  height: 100%;
  overflow: hidden;
}

.bg-movie {
  position: absolute;
  inset: 0;
  z-index: 1;
}

.bg-movie__video {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.topimgwrapper {
  position: relative; 
  z-index: 10;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items:center;
  justify-content: flex-start; 
}

.topbtwrapper {
  display: flex;
  gap: 6.96%;
  margin-top: 20px;
  width: 86.2%;
}

.topbtwrapper a img {
  display: block;
  width: 100%;
}


.salesbtwrapper {
  position: absolute;
  bottom: 11%;
  z-index: 10;
  pointer-events: auto;
  padding-right: 8%;
}

.salesbtwrapper a {
  width: 50.8%;
  margin: 0 auto;
  display: block;
}

.purchase-wrapper {
  background: url(../images/purchase_bg.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.purchase-wrapper h2{
  width: 32.5%;
  margin-top: 12%;
}

.purchase-txt {
  width: 83%;
  margin: 3.3% auto 0;
  padding-right: 8%;
}

.purchase-links {
  margin: 3% auto 0;
  width: 86%;
  display: flex;
  flex-wrap: wrap;
  gap: 5.71%;
  padding-right: 8%;
}

.purchase-links a{
  margin-bottom: 2.565%;
  width: 47.145%;
}

.purchase-links a img{
  height: auto;
  display: block;
}

#purchase-links-bt01 img{
  width: 87.88%;
}

#purchase-links-bt02 img{
  width: 103.03%;
}
#purchase-links-bt03 img{
  width: 94.85%;
}
#purchase-links-bt04 img{
  width: 94.55%;
}

#purchase-links-bt05{
  width: 60.86%;
  margin-bottom: 0;
}

.purchase-txt02 {
  width: 55.4%;
  margin: 3% auto;
  padding-right: 8%;
}

.purchase-sns {
  margin: 0 auto 0;
  padding-right: 8%;
  width: 60.4%;
}

.purchase-sns a img{
  margin-bottom: 3.82%;
}

.purchasebtwrapper{
  position: absolute;
  bottom: 11%;
  z-index: 10;
  padding-left: 4%;
}

.purchasebtwrapper a {
  width: 42.4%;
  display: block;
  margin: 0 auto;
}

.first-wrapper {
  background: url(../images/first_img02_bg.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.first-txt {
  width: 78.2%;
  margin-top: 12%;
}

.first-links {
  width: 92%;
  padding-right: 8%;
  margin: 0 auto ;
}

#first-links-bt01 {
  width: 28.9%;
  display: block;
  margin: 15px auto 15px;
}

#first-links-bt02 {
  width: 38.75%;
  display: block;
  margin: 0 auto 15px;
}

#first-links-bt03 {
  width:54.3%;
  display: block;
  margin: 0 auto 15px;
}

#first-links-bt04 {
  width:39.8%;
  display: block;
  margin: 0 auto 15px;
}

#first-links-bt05 {
  width:18%;
  display: block;
  margin: 0 auto 0;
}

#first-links-bt06 {
   width:12.15%;
  display: block;
  margin: 6.02% auto 0; 
}

.first-txt02 {
  width: 68.3%;
  padding-right: 8%;
  margin: 6.02% auto 0;
}

@media (max-width: 430px) {
#first-links-bt06 {
  margin: 3.02% auto 0; 
}

.first-txt02 {
  margin: 3.02% auto 0;
}
}

.first-links-box {
  display: flex;
  justify-content: center;
  gap: 4%;
  width: 65.2%;
  margin-left: auto;
  margin-right: auto;
  padding-right: 8%;
}

.first-links-box .first-links-box-in {
  width: 30%;
  display: flex;
  flex-direction: column;
  gap: 10px; 
}

.first-links-box .first-links-box-in a {
  display: block;
}

.first-links-box .first-links-box-in img {
  width: 100%;
  height: auto;
  display: block;
}

#first-links-bt07 {
  width: 20.92%;
}

#first-links-bt08 {
  width: 26.41%;
  margin-left: 5%;
}

#first-links-bt09 {
  width: 19.88%;
  margin-left: 5%;
}

#first-links-bt10 {
  width: 20.92%;
}

#first-links-bt11 {
  width: 10.24%;
  margin-left: 5%;
}


#first-links-bt12 {
  width: 24.93%;
  margin-left: 5%;
}

.first-txt03 {
  width: 68.3%;
  padding-right: 8%;
  margin: 6.02% auto 0;
}

@media (max-width: 430px) {
.first-txt03 {
  margin: 3.02% auto 0;
}  
}

.first-links-box-second {
  width: 100%;
  margin-top: 1.72%;
}

.first-links-box-second .first-links-box-second-in {
  width: 75.4%;
  padding-right: 8%;
  margin-left: auto;
  margin-right: auto;
  text-align: center;
}

.first-links-box-second .first-links-box-second-in a {
  display:inline-block;
}

.first-links-box-second .first-links-box-second-in img {
  width: 100%;
  height: auto;
  display:inline-block;
}

#first-links-bt13 {
  width: 17.95%;
}

#first-links-bt14 {
  width: 19.73%;
  margin-left: 5%;
}

#first-links-bt15 {
  width: 43.77%;
  margin-left: 5%;
}

#first-links-bt16 {
  width: 20.77%;
}

#first-links-bt17 {
  width: 8.01%;
  margin-left: 5%;
}

#first-links-bt18 {
  width: 20.18%;
  margin-left: 5%;
}

img#first-links-bt19 {
  width: 6.23%;
  margin-top: auto;
  margin-left: 5%;
}

@media (max-width: 321px) {
#first-links-bt01,
#first-links-bt02,
#first-links-bt03,
#first-links-bt04,
#first-links-bt05{
margin: 5.02% auto 0;
}

.first-txt03 {
        margin: 1.02% auto 0;
    }

.first-links-box-second{
  margin-top: 0;
}
}


.firstbtwrapper{
  position: absolute;
  bottom: 11%;
  z-index: 10;
  pointer-events: auto;
  padding-left: 4%;
}

@media (max-width: 768px) {
  .purchasebtwrapper,
  .firstbtwrapper{
  padding-left: 0;
  padding-right: 8%;
}
}

.firstbtwrapper.qa {
  bottom: 8%;
}

.firstbtwrapper a{
  width: 42.4%;
  margin: 0 auto;
  display: block;
}

.firstbtwrapper_second {
  position: absolute;
  bottom: 11%;
  z-index: 10;
  pointer-events: auto;
  display: flex;
  justify-content: center;
  gap: 3%;
  padding-right: 8%;
}


.firstbtwrapper_second a{
  width: 50.8%;
}

.firstbtwrapper_second a:last-child{
  width: 30%;
}

.storebg01 {
  background: url(../images/store_bg01.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.storebg02 {
  background: url(../images/store_bg02.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.storebg03 {
  background: url(../images/store_bg03.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.storebg04 {
  background: url(../images/store_bg04.webp) left top no-repeat;
  background-size:contain;
  aspect-ratio: 500 / 870;
  width: 100%;
}

.storetitle {
  margin-top:12%;
}

.storeswiper {
  width: 100%;
  overflow: hidden;
  height: 30%;
  padding: 0 4%;
}

.storeswiper .swiper-slide {
  width: 100%;
}

.swiper-button-prev.storeswiper-prev,
.swiper-button-next.storeswiper-next {
  width: 23px;
  height: 23px;
  margin-top: -10px;
  border-radius: 50%;
  background: #fff;
  color: #3c2a1b;
  font-weight: bold;
}

.swiper-button-prev.storeswiper-prev::after,
.swiper-button-next.storeswiper-next::after {
  display: none;
}

.swiper-button-prev.storeswiper-prev::before {
  content: "←";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  font-size: 13px;
  line-height: 1;
}

.swiper-button-next.storeswiper-next::before {
  content: "→";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -55%);
  font-size: 13px;
  line-height: 1;
}

.storetxt {
  color: #fff;
  font-size: 14px;
  position: absolute;
  top: 60.68%;
  width: 42%;
  right: 50%;
  left: 4%;
}

@media (max-width: 767px) {
 .storetxt {
  font-size: 11px;
} 
}

@media (max-width: 320px) {
 .storetxt {
  font-size: 9px;
} 
}


.storebtwrapper {
  position: absolute;
  top: 60.68%;
  right: 4%;
  z-index: 10;
  left: 50%;
  pointer-events: auto;
}

@media (max-width: 768px) {
.storebtwrapper {
  bottom: 10%;
}
}

.storebtwrapper a img {
display: block;
width: 45vw;
margin-bottom: 10px;
}

.swiper-nav-pc {
  position: fixed;
  right: 30px;
  bottom: 30px;
  z-index: 1000;
  width: 100px;
  height: 100px;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0;
  border-radius: 50%;
}

.swiper-nav-box {
  padding: 20px;
  background: rgba(0,0,0,0.4);
  border-radius: 50%;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.swiper-nav-pc .lr {
  display: flex;
  gap: 40px;
}

.swiper-nav-pc button {
  width: 30px;
  height: 30px;
  padding: 0;
  cursor: pointer;
  font-size: 12px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  border: 1px solid #fff;
  color: #555;
}

@media (max-width: 768px) {
  .swiper-nav-pc {
    display: none;
  }
}

.modal {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 1000;
}

.modal.is-active {
  display: block;
}

.modal-bg {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,.6);
}

.modal-content {
  position: relative;
  background: #fff;
  width: 90%;
  max-width: 600px;
  margin: 10vh auto;
  padding: 20px;
  border-radius: 10px;
}

.modal-tabs {
  display: flex;
  gap: 8px;
  margin-bottom: 16px;
}

.modal-tabs button {
  cursor: pointer;
  background: none;
  border: none;
  font-size: 12px;
  border-bottom: 2px solid #fff;
}

.modal-tabs button.is-active {
  border-bottom: 2px solid #000;
}

.tab-content {
  display: none;
}

.tab-content.is-active {
  display: block;
}

.tab-content p{
  font-size: 12px;
}

.tab-content p a{
  text-decoration: underline;
}

@media (max-width: 430px) {
.modal-tabs button {
  font-size: 10px;}

  .tab-content p{
  font-size: 10px;
}
}

/*追加Link*/

.logolink {
  width: 32.5%;
  height: 4.66%;
  display: inline-block;
  top:6.9%;
  left: 0;
  position: absolute;
  z-index: 10;
}

.titlelink {
  width: 60%;
  height: 8.05%;
  display: inline-block;
  top:14.25%;
  left: 16%;
  position: absolute;
  z-index: 10;
}

.purchasetitlelink {
  width: 65%;
  height: 9.05%;
  display: inline-block;
  top: 13.25%;
  left: 14%;
  position: absolute;
  z-index: 10; 
}

.shoptitlelink {
  width: 65%;
  height: 9.05%;
  display: inline-block;
  top: 13.25%;
  left: 14%;
  position: absolute;
  z-index: 10; 
}

.next-area {
  position: absolute;
  width: 8%;
  height: 100%;
  right: 0;
  top:0;
  background: transparent;
  cursor: pointer;
  z-index: 10;
  touch-action: manipulation;
}

/*お知らせモーダル*/
.modal-atten {
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}

.modal-atten.is-active {
  display: block;
}

.modal-overlay-atten {
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.6);
}

.modal-content-atten {
  position: absolute;
  top: 48%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: rgba(255,255,255,0.8);
  width: 80%;
  max-width: 400px;
  padding: 30px;
  border-radius: 5px;
  z-index: 2;
}

.modal-close-atten {
  position: absolute;
  top: -15px;
  right: -15px;
  background: #000;
  border: none;
  border-radius: 50%;
  width: 40px;
  height: 40px;
  border: 1px solid #fff;
  cursor: pointer;
  color: #fff;
  font-size: 18px;
  font-weight: 600;
}

.modal-body-atten h2 {
  font-size: 14px;
  margin-bottom: 20px;
  text-align: center;
}

.modal-body-atten p {
  font-size: 12px;
  margin-bottom: 20px;
    text-align: center;
}

.modal-body-atten p:last-child {
  margin-bottom: 0;
}

.modal-body-atten p a{
  border-bottom: 1px solid #000;
  color: #000;
}


.modal-body-atten p a::after {
  content: "";
  padding-left: 10px;
  background-image: url(../images/arrow.svg);
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center center;
  width: 16px;
  height: 12px;
  filter: brightness(0);
}