@charset "UTF-8";
/************************************************
reset
************************************************/
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,picture,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, dialog, figure, footer, header,
hgroup, menu, nav, section,
time, mark, audio, video {
  margin:0;
  padding:0;
  border:0;
  outline:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}
body {
  background: rgb(178,178,178,0.2);
  box-sizing: border-box;
}
article, aside, dialog, figure, footer, header,
hgroup, nav, section {
  display:block;
}

*, *::before, *::after {
  box-sizing: border-box;
}
a {
  margin:0;
  padding:0;
  border:0;
  font-size:100%;
  vertical-align:baseline;
  background:transparent;
}
a:active, a:hover {
    outline-width: 0;
}
ul,ol {
  list-style: none;
}
picture {
  display: block;
}

html{
    font-size: 62.5%;
}

a{
    display: block;
    color: #6b6b6a;
    text-decoration: none;
}

.sp{
	display:none !important;
}

body{
  width: 100%;
  font-family: "游ゴシック", YuGothic, "メイリオ", Meiryo, "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", sans-serif;
  color: #333333;
  line-height: 1.6;
  text-align: left;
  text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
}

@media only screen and (max-width: 750px) {
    img,video { max-width: 100%; }
}
img,video {
  vertical-align: bottom;
}

.wrapper {
  width: min(100%,750px);
  margin: 0 auto;
  background: #fff;
}

.couponBox {
  margin-bottom: 4em;
}

.cv_btn {
  width: min(calc(630/750*100%),630px);
  margin: 1em auto 0;
}

.notes {
  font-size: 14px;
  text-align: center;
  margin-top: 1em;
}
@media only screen and (max-width: 750px) {
  .notes {
    font-size: 10px;
  }
}
/*-----------------------------------
FOOTER
-----------------------------------*/
footer {
  font-size: 2.604167vw;
  padding-top: 3vw;
  padding-bottom: 3vw;
  text-align: center;
  background: #fff;
  font-weight: 500;
  color: #535353;
}
footer * {
  letter-spacing: 0;
}
footer .linkBlock li {
  display: inline-block;
  line-height: 2;
}
footer .linkBlock li a {
  color: #535353;
}
footer .shareBlock li {
  display: inline-block;
  width: 6.512vw;
  margin: 5vw 2.4vw;
}


@media screen and (min-width: 769px) {
  footer {
    font-size: 14px;
    padding-top: 40px;
    padding-bottom: 40px;
  }
  footer .shareBlock li {
    width: 40px;
    margin: 35px 15px 40px;
  }

  footer .linkBlock li a{
	font-size: 14px;
  }

  footer .textCopy {
    font-size: 14px;
  }
}

.lineupArea {
  background: #f7efe2;
  padding: 6em 0 2em;
  margin-bottom: 6em;
}
.h3-ttl {
  width: min(calc(266/750*100%),266px);
  margin: 0 auto;
}
.relativ {
  position: relative;
}

.swiper-container {
  width: min(calc(670/750*100%),670px);
  overflow: hidden;
  margin: 2em auto 6em;
  position: relative;
  box-sizing: border-box;
}
.swiper-button-next, .swiper-button-prev {
  width: calc(100vw *(34 / 750));
  height: calc(100vw *(34 / 750));
  top: 58%
  
}
.swiper-button-next {
  right: 5%;
}

.swiper-button-prev {
  left: 5%;
}

.swiper-button-next:after, .swiper-button-prev:after,
.swiper-navigation-icon{
  display: none;
  content: "";
}


.pcOnly {
  display: none !important;
}
.spOnly {
  display: block !important;
}
@media screen and (min-width: 769px) {
  .pcOnly {
    display: block !important;
  }
  .spOnly {
    display: none !important;
  }
}



/*-----COUPON-----*/
.couponBox {
  position: relative;
  width: min(calc(690/750*100%),690px);
  margin-left: auto;
  margin-right: auto;
  border-radius: 12px;
  margin-top: 10%;
  overflow: hidden;
  background-size: 100%;
}
@media screen and (min-width: 769px) {
  .couponBox {
    border-radius: 22px;
  }
}
.couponBox .note {
  position: absolute;
  font-size: 2.604167vw;
  font-weight: normal;
  color: #ffffff;
  line-height: 1.3;
  width: 100%;
  top: 71.5%;
}
@keyframes HorizontalShake {
0% {
  transform:translateX(0px);
}

85% {
  transform:translateX(0px);
}

88% {
  transform:translateX(7px);
}

91% {
  transform:translateX(-7px);
}

94% {
  transform:translateX(7px);
}
97% {
  transform:translateX(-7px);
}
100% {
  transform:translateX(0px);
}
}

.couponBox .code-wrapper {
  background: url("../img/couponcode_bg.png") ;
  background-size: contain; 
/*  background: #29407b;*/
  display: flex;
  justify-content: center;
  gap: 10px;
}

.couponBox .code-wrapper .code {
    width: 66.52%;
}

@media screen and (min-width: 769px) {
  .couponBox .code-wrapper .code {
    max-width: 464px;
  }
}

.couponBox .code-wrapper .btn {
    width: 16.08%;
}

@media screen and (min-width: 769px) {
  .couponBox .code-wrapper .btn {
    max-width: 111px;
  }
}

.couponBox .code-wrapper .btn button{
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

.couponBox .code-wrapper.bg_cta {
  display: flex;
  justify-content: center;
  gap: 10px;
}

.couponBox .code-wrapper .code {
    width: 66.521739%;
}

@media screen and (min-width: 769px) {
  .couponBox .code-wrapper .code {
    max-width: 464px;
  }
}

.couponBox .code-wrapper .btn {
    width: 16.0869565%;
}

@media screen and (min-width: 769px) {
  .couponBox .code-wrapper .btn {
    max-width: 111px;
  }
}

.couponBox .code-wrapper .btn button{
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
}

.couponBox .coupon_notes {
  width: 85.5%;
  margin: 3% auto 5%;
}

.couponBox .pb3 {
  padding-bottom: 3%;
}
.couponBox .okome_notes {
  padding: 1.5em;
  font-size: min(calc(15/750*100vw),12px);
  line-height: 1.5;
  text-align: left;
}

.dropDown {
  position: relative;
  cursor: pointer;
}

.dropDown::after {
  content: "";
  position: absolute;
  top: 50%;
  right: 5.38%;
  transform: translate(0, -50%);
  width: 21px;
  height: 19px;
  background: url(../img/icon_dropdown.webp) no-repeat;
  background-size: cover;
  transition: .3s;
}

.dropDown.active::after {
  transform: translate(0, -50%) rotate(180deg);
}



/*-----------------------------------
fixed cv
-----------------------------------*/

.fixed_btn ul {
  display: flex;
  justify-content: center;
}
.fixed_btn ul li {
  width: calc(350/750*100%);
  padding: 0 1%;
}
.fixed_btn ul li img {
  width: 100%;
}
@media screen and (min-width: 769px) {
  .fixed_btn ul {
    display: flex;
    justify-content: center;
    margin-top: 3.2%;
    margin-left: auto;
    margin-right: auto;
  }
  .fixed_btn ul li {
    width: calc(350/750*100%);
    padding: 0 1%;
  }

}
.cv_fixed {
  margin-bottom: 0;
  padding-bottom: min(14px,1.866vw);
  width: min(100%,750px);
  background: #f7eddf;
  position: fixed;
  left: 50%;
  bottom: 0;
  visibility: hidden;
  opacity: 0;
  transform: translateY(2rem)translateX(-50%);
  z-index: 999;
}
.cv_fixed.is-active {
  visibility: visible;
  opacity: 1;
  transform: translateY(0)translateX(-50%);
}

.cv_fixed .fixed_btn ul {
  margin-top: min(10px,1.333vw);
}

.cv_fixed .fixed_btn ul li:first-of-type a {
  display: inline-block;
  animation-name: HorizontalShake;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-duration: 4000ms;
  animation-timing-function: linear;
}
.cv_fixed .fixed_btn ul li:nth-of-type(2) a {
  display: inline-block;
  animation-name: HorizontalShake;
  animation-iteration-count: infinite;
  animation-direction: normal;
  animation-duration: 4000ms;
  animation-timing-function: linear;
  animation-delay: 2000ms;
}

/*-----ANIMATION-----*/
@keyframes HorizontalShake {
0% {
  transform:translateY(0px);
}
85% {
  transform:translateY(0px);
}
88% {
  transform:translateY(7px);
}
91% {
  transform:translateY(-7px);
}
94% {
  transform:translateY(7px);
}
97% {
  transform:translateY(-7px);
}
100% {
  transform:translateY(0px);
}
}
