@charset "UTF-8";
/* CSS Document */

.pc-1000{
    display: block; }
@media (max-width: 950px) {
.pc-1000{
    display: none; }
}
.sp-1000{
    display: none; }
@media (max-width: 950px) {
.sp-1000{
    display: block; }
}

.ttl_setmeal {

    /*animationプロパティここから*/
    animation-name: tenmetsu;
    animation-duration: .5s;
    animation-direction: alternate;
    animation-iteration-count: 3;
}
@keyframes tenmetsu {
    0% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}

img{ width:100%;}


#nandomo .ttl_setmeal img.sp {
    width: 70%;
    margin: 0 auto;
}

#nandomo .ttl_setmealimg {
    width: 70%;
    margin: 0 auto;
}

p.caution {
    text-align: right;
}

div#eyecatch {
    position: relative;
    /*height: 640px;*/
}

div#main-eyecatch{
    display: flex;
    /*position: relative;
    width: 100%;*/
    height: 600px;
}
div#text-left{
    width:40%; 
}
div#text-right{
    /*width:60%;*/ 
}

/* 矢印調整 */
.slick-prev::before,
.slick-arrow:before{
    content:""!important;
    width: 100%!important;
    height: 100%!important;
    position: absolute;
    top: 0;
    left: 0;
}

.slick-next:before{
    background: url(img/arrow_r.png)!important;
    background-size: contain!important;
}

.slick-prev:before{
    background: url(img/arrow_l.png)!important;
    background-size: contain!important;
}

.copy {
  animation: fadeup-rl 0.5s ease-in-out 3s 1 forwards;
  opacity:0;
  margin-bottom: 10px;
}

@keyframes fadeup-rl {
  0% {
    opacity: 0;
    transform: translateX(100px);
  }

  100% {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes fadeup-lr {
  from {
    opacity: 0;
    transform: translateX(-150px);
    }
    to {
        opacity: 1;
    transform: translateX(0);
    }
}

@keyframes appearance {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

div#date {
    width: 100%;
    margin: 0 auto;
        text-align: center;
}
div#date img{
        padding:20px;
        max-width: 600px;
    width:90%;
}
@media screen and (max-width:900px) {
div#date img{    
    max-width:none;
}
}

.teishoku {
    position: absolute;
    max-width:260px;
    left: 30%;
    opacity:0;
    bottom: 8%;
    animation: appearance 1s ease-in-out 2.2s 1 forwards; 
}

@media screen and (max-width:900px) {
.teishoku {
    max-width: 270px;
    width: 25%;
    left: 5%;
    top: 38%;
}
p.caution {
    text-align: left;
}    
    
}    
@media screen and (max-width:640px) {
.teishoku {
    max-width: 200px;
    width: 40%;
    left:2%;
    top: 32%;
}
    
    .nandodemo{
        margin-bottom: 5px; 
    }    
    
}    
@media screen and (max-width:500px) {
.teishoku {
    left:5%;
    top: 32%;
}
} 
@media screen and (max-width:375px) {
.teishoku {
    top: 35%;
}
}  

#new_mugen{
    background-position: center;
    background-size: cover;
    background-repeat: no-repeat;
    background-image:url("../assets/images/eyecatch_bg.png");
    background-color: #f0d984;
    /*padding: 6rem 0;*/
    overflow: hidden;
    position: relative;
    min-height: 600px;
}

.nandomo_img {
    position: absolute;
    bottom: -10px;
    max-width:580px;
}

#new_mugen .inner {
    max-width: 1280px;
    margin: 0 auto;
    width: 100%;
}

#text-right{
    /*z-index:4;
    position: relative;
        display: flex;
    width: 60%;
    justify-content: flex-end;*/
}

.copy-box {
    position: absolute;
    width: 35%;
    top: 10%;
    right: 5%;
    /* max-width: 450px;
    margin-top: 50px; */
    
    /* margin: auto; */
    /* padding-top: 40px; */
    /*margin-right:10%;*/
}

.campain {
    /*position: absolute;
    width: 50%;
    display: flex;
    right: 0;
    bottom: 0;
    max-width: 310px;
    margin-right: 15%;*/
    position: absolute;
    max-width: 300px;
    width:70%;
    bottom: -2%;
    right: 10%;
    opacity: 1;
    animation: poyopoyo 1.5s ease-out 4.5s 1 forwards;
}

@keyframes poyopoyo {
  0%, 40%, 60%, 80% {
    transform: scale(1.0);
  }
  50%, 70% {
    transform: scale(0.95);
  }
}

.nandodemo {
    margin-bottom: 15px;
    opacity: 0;
    animation: fadeup-rl 0.5s ease-in-out 3.5s 1 forwards;
}

.waribiki {
    animation: zoomInAnime 0.5s ease 4s 1 normal backwards;  
    margin-bottom: 10px;
}

.ninkino-sp{
    animation: zoomInAnime 0.5s ease 4.5s 1 normal backwards;  
}


/* eye sp */ 

@media screen and (min-width:1500px) {
    
.copy-box {
    width: 25%;
    top:5%;
    right: 15%;
}
.campain {
    right: 17%;
}
}

@media screen and (max-width: 950px) {
    
div#main-eyecatch {
    display: block;
    /*min-height:1000px;*/
}
    
.nandomo_img {
        left:3%;
        bottom: -6%;
        max-width: 410px;
}
    
.copy-box {
    top: 6%;
    right: 0;
    bottom: 0;
    left: 0;
    margin: auto;
    width: 45%;
}
    
.campain {
    right: 15%;
}    
    
div#text-right{
    /*padding-top:50px;
    width: 80%;*/
    margin: 0 auto;
} 
    
div#text-left{
    width:85%; 
}
}


@media screen and (max-width:820px) {

#new_mugen{         
}
.copy-box {
    top: 5%;
}    
.nandomo_img {
}      
} 
@media screen and (max-width: 768px) {
    .nandomo_img {
        left: -5%;
    }
}

@media screen and (max-width:540px) {

#new_mugen {
        min-height: 550px;
    }
.copy-box {
    width: 60%;
}    
    .nandomo_img {
        left: -12%;
        max-width: 415px;
    }
.copy-box {
    width: 80%;
}
.campain {
    max-width: 180px;
    right: 3%;
}
}

@media screen and (max-width:375px) {
#main-eyecatch {
        height: 560px;
}    
.nandomo_img {
        left: -15%;
        max-width: 420px;
        bottom: -1%;
}
.copy-box {
    width: 80%;
}
.campain {
    max-width: 170px;
    right: 5%;
}
}

div#off{
    opacity:0;
    animation: appearance 1s ease-in-out 2.2s 1 forwards;    
}

div#off .base,
div#off .yen {
    position: absolute;
    width: 26.9%;
    bottom: -65px;
    right: 53%;
    max-width: 377px;
}

@media screen and (max-width:900px) {
div#off .base, div#off .yen {
    position: absolute;
    width: 45%;
    bottom: -50px;
    right: 5%;
    max-width: 377px;
}
}

@media screen and (max-width:650px) {
div#off .base, div#off .yen {
    bottom: -35px;
    width:48%;
    }
}


div#off .yen {
    z-index:3;
   animation: zoomInAnime2 0.8s ease 5s 1 normal backwards;      
}
div#off .base {
    z-index:2;
}

div#text-right {
    /*position: relative;
    width:50%;
    width: 37%;
    left: 45%;
    top: 50%;
    bottom: 50%;
    max-width: 600px;
    height:640px;
    padding-top: 60px;*/
}



/* 拡大 */
.zoomIn{
  animation-name:zoomInAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime{
  0% {
  opacity: 0;      
  transform: scale(1);
  }
    
50% {
  opacity: 0.5;      
  transform: scale(1.5);
  }    

  100% {
  opacity: 1;         
  transform: scale(1);
  }
    
}

.zoomIn2{
  animation-name:zoomInAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
}

@keyframes zoomInAnime2{
  0% {
  transform: scale(1);
  }

50% {
  transform: scale(1.2);
  }

  100% {     
  transform: scale(1);
  }
    
}

.ttl_setmeal {
    margin-bottom: 20px;
    max-width: 688px;
    margin: 0 auto 20px;
}

.ttl_setmeal.js-scroll-trigger.is-animated{
      /*animation: fadeup-rl 0.5s ease-in-out 0s 1 forwards;*/
}

.setmeal01 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal01{
      animation: fadeup-lr 0.5s ease-in-out 0.2s 1 forwards;
}
.setmeal02 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal02{
      animation: fadeup-lr 0.5s ease-in-out 0.4s 1 forwards;
}
.setmeal03 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal03{
      animation: fadeup-lr 0.5s ease-in-out 0.6s 1 forwards;
}
.setmeal04 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal04{
      animation: fadeup-lr 0.5s ease-in-out 0.8s 1 forwards;
}
.setmeal05 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal05{
      animation: fadeup-lr 0.5s ease-in-out 1s 1 forwards;
}
.setmeal06 {
    opacity: 0;  
}
.setmeal.js-scroll-trigger.is-animated .setmeal06{
      animation: fadeup-lr 0.5s ease-in-out 1.2s 1 forwards;
}

.gmap-wrap{
    position : relative;
    height : 0;
    padding-bottom : 100%; /* 縦横比の指定 */
    overflow : hidden;
}

.gmap-wrap iframe,
.gmap-wrap object,
.gmap-wrap embed{
    position : absolute;
    top : 0;
    left : 0;
    width : 100%;
    height : 100%;
}

section#new_app-2 {
    height: 600px;
    position: relative;
    margin-top:-150px;
}
/*
section#new_app-2:after {
		content: "";
		position: absolute;
		width: 100%;
		height: 100%;
		background-color: aqua;
		top: 3%;
		right: -3%;
		z-index: -1;
	}
*/

.bg-hands_new {
    position: relative;
}
.hand-bg01,.hand-bg02 {
    position: absolute;
    width: 100%;
    z-index: -2;
}
.hand-bg01{
    background: url(../assets/images/yayoiken_app_t1_15.gif?20231212)no-repeat, url(../assets/images/bg-gif.png) ;
    height: 600px;
    background-size: inherit;
    background-position: 50% 20%;
    opacity: 0;
	animation-name: hand01;    
    animation-delay: 0s;
    animation-iteration-count:1;
    animation-duration: 1.5s;
}
.hand-bg02{
    background: url(../assets/images/yayoiken_app_t2_15.gif?20231212) no-repeat, url(../assets/images/bg-gif.png) ;
    height: 600px;
    background-size: inherit;
    background-position: 50% 20%;;
    opacity: 0;
	animation-name: hand02;  
    animation-delay: 1.5s;
    animation-iteration-count: infinite;
    animation-duration: 2s;
}

@keyframes hand01{
	0%{ opacity: 0;}
	10%{ opacity: 1;}
	90%{ opacity: 1;}
	100%{ opacity: 1;}
}
@keyframes hand02{
	0%{ opacity: 1;}
	10%{ opacity: 1;}
	90%{ opacity: 1;}
	100%{ opacity: 1;}
}

.eye-text h2
{ 
    animation-delay:1.3s;
}
.eye-text p
{ 
    animation-delay:1.6s;
}




/* 下から */
.fadeUp{
animation-name:fadeUpAnime;
animation-duration:1s;    
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(20px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}

.slide-in {
    -webkit-transition: 0.8s ease-in-out;
    -moz-transition: 0.8s ease-in-out;
    -o-transition: 0.8s ease-in-out;
    transition: 0.8s ease-in-out;
    transform: translateX(-30px);
    opacity: 0;
    filter: alpha(opacity=0);
    -moz-opacity: 0;
}
.slide-in.on {
    opacity: 1.0;
    filter: alpha(opacity=100);
    -moz-opacity: 1.0;
    transform: translateX(0);
}
.inner {
    max-width: 900px;
    margin: 0 auto;
    width: 90%;
}

.text img{
    max-width: 150px;
}
@media screen and (max-width:900px) {
.text img{
    max-width: 120px;
}
}
@media screen and (max-width: 800px) {
    
div#main-eyecatch {
    /*min-height:550px;*/
}
}

@media screen and (max-width:650px) {
.text img{
    max-width: 100px;
}
}

@keyframes fadeLeftAnime{
  from {
    opacity: 0;
	transform: translateX(-100px);
  }

  to {
    opacity: 1;
	transform: translateX(0);
  }
}

.text {
    display: flex;
    justify-content: center;
    align-items: center;
}
.text.btn-coupon{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay: 1s;
}
.text.btn-game{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay: 1.2s;
}
.text.btn-new{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay: 1.4s;
}
.text.btn-campain{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay: 1.6s;
}
.text.btn-menu{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay: 1.8s;
}
.text.btn-shop{
    animation-name:fadeLeftAnime;
    animation-duration:0.5s;
    animation-fill-mode:forwards;
    opacity:0;
    animation-delay:2s;
}

.hand{
    position: relative;
   }
 
.bg-hands {
    height: 400px;
    position: relative;
    z-index: -100000;
}

.bg-hands figure img.hand01 {
    position: absolute;
    width: 16%;
    bottom: 0;
    left: 18%;
    z-index: -100;
    animation: anime 1s 2s, .6s bound-anim 2s ease-in alternate;

}
.bg-hands figure img.hand02 {
    position: absolute;
    width: 16%;
    bottom: 0;
    z-index: -100;
    left: 0;
    right: 0;
    margin: auto;
    animation: anime 1s 1s, .6s bound-anim 1s ease-in alternate;
}
.bg-hands figure img.hand03 {
    position: absolute;
    width: 16%;
    bottom: 0;
    right: 18%;
    animation: anime 1s 3s, .6s bound-anim 3s ease-in alternate;
}
@keyframes anime {
    0% {
     opacity: 0;
     transform: translateY(50px);
    }
      100%{
        opacity: 1;
        transform: translateY(-100);
     } 
}

@keyframes bound-anim {
  0%{transform:translateY(0px);}
  100%{transform: translateY(6px);
        opacity:1;}
}

@media screen and (max-width:900px) { 
.bg-hands {
    height: 500px;  
}
    
.bg-hands figure img.hand01 {
    width: 115px;
    left:10%;  
    }
.bg-hands figure img.hand02 {
    width: 115px;
    }    
.bg-hands figure img.hand03 {
    width: 120px;
    right:10%; 
    }      

}

@media screen and (max-width:479px) { 
.bg-hands {
    height: 500px;  
}
    
.bg-hands figure img.hand01 {
    width: 115px;
    left:0%;  
    }
.bg-hands figure img.hand02 {
    width: 115px;
    }    
.bg-hands figure img.hand03 {
    width: 120px;
    right:0%; 
    }      

}

.button-area {
    /*margin-top: 350px;*/
    position: absolute;
    max-width:1000px;
    bottom:30px;
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    -webkit-transform: translateX(-50%);
    -ms-transform: translateX(-50%);
    z-index:1;
}

.button-area .flex6 div  {
    /*position:relative;
    background: #8f2029;
    border-radius: 8px;
    height: 70px;*/
}

.button-area .text {
    background: #E60012;
    border-radius: 8px;
    animation-name:fadeInAnime;
    animation-duration:1s;
    animation-fill-mode:forwards;
    opacity:0;
}
@keyframes fadeInAnime{
  from {
    opacity: 0;
  }

  to {
    opacity: 1;
  }
}

@media screen and (max-width:1090px) {
.button-area {
    width:90%;
}
}
p.read {
    font-size: 25px;
    font-weight: 600;
    line-height: 1.5em;
    text-align: center;
    margin-top: 10px;
    background: none;
}
.c-page-home__btn {
  background: transparent;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
    width:100%;
  max-width: 314px;
  position: relative;
  margin: 0 auto;
  text-align: center;
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color:#333;
  font-size: 1.2rem;
  font-weight: bold;
  letter-spacing: 0.1em;
  text-decoration: none;
      padding: 14px 0px 13px 0px;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  border: 2px solid #bcce19;
  /*background:#9a6d23;*/
  -webkit-transition: 300ms;
  transition: 300ms;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  cursor: pointer;
  border-radius: 0;
}
@media (-ms-high-contrast: none) {
  .c-page-home__btn {
    padding-top: 16px;
    padding-bottom: 11px;
  }
}

.c-page-home__btn::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 50%;
  margin-top: -5px;
  width: 9px;
  height: 9px;
  border-top: 2px solid #333;
  border-right: 2px solid #333;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
  -webkit-transition: 300ms;
  transition: 300ms;
}
.c-page-home__btn::after {
    right: 15px;
    top: 52%;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
}
.c-page-home__btn:hover{
    background:#bcce19;
    color:#333;
}
.c-page-home__btn:hover::after {
    right: 15px;
    top: 52%;
    border-top: 2px solid #333;
    border-right: 2px solid #333;
}
@media screen and (max-width:900px) {
    .c-page-home__btn{
        background:#bcce19;
        color:#333;
        font-size: 1.5rem;
        max-width: none; 
        padding: 18px 0px 16px 0px;
        margin-top:15px;
    }
    .c-page-home__btn::after {
    border-top: 2px solid #333;
    border-right: 2px solid #333;
}
}
@media screen and (max-width:540px) {
    .c-page-home__btn{
        font-size: 1.6rem;
    }
}
@media screen and (max-width:280px) {
.c-page-home__btn {
    padding: 10px 50px;
    line-height: 1.25em;
}
}

@media screen and (max-width:900px) {
    
section#new_app-2 {
    /*height: 650px;
    margin-top:-120px;*/
    height: 650px;
}     
.hand-bg01,.hand-bg02{
    height: 650px;
    background-size: cover;
}
p.read {
    font-size: 16px;} 
iframe {
    border-radius: 20px;
}
}

@media screen and (max-width:650px) {
p.read {
    font-size: 15px;
}
section#new_app-2 {
    height: 400px;
    margin-top:-100px;
}    
.hand-bg01, .hand-bg02 {
    height: 400px;
    background-size: 700px auto;    } 
.button-area{
    bottom: 10px; 
} 
    
} 
@media screen and (max-width:450px) {
.hand-bg01, .hand-bg02 {    
    background-size: 550px auto;
    background-position: 50% bottom;
} 
}

.an4-fadeleft {
    animation-name: fadeleft;
    animation-duration: 1.2s;
    animation-delay: 0.2s;
    animation-iteration-count: 1;
}
@keyframes fadeleft {
from {
    opacity: 0;
     transform: translateX(500px);
}
to {
    opacity: 1;
    transform: translateX(0);
}
}

.parts figure img{opacity: 0;}

img.fukidashi01 {
    width: 13%;
    position: absolute;
    bottom: 340px;
    left: 12%;
}
img.fukidashi02 {
    width: 20px;
    position: absolute;
    top: 23%;
    left:30%;
    animation: poyoyon2 1s ease-in-out 1 forwards, example 0.5s ease 2s 1 forwards;
}
@keyframes poyoyon2 {
  0%  {
    transform: scale(1.0, 1.0) translate(0, 0);
  }
  15% {
    transform: scale(0.98, 0.9) translate(0, 5px);
  }
  30% {
    transform: scale(1.02, 1.0) translate(0, 8px);
  }
  50% {transform: scale(0.98, 1.05) translate(0, -8px);
  }
  70% {
    transform: scale(1.0, 0.9) translate(0, 5px);
  }
  100% {
    transform: scale(1.0, 1.0) translate(0, 0);
  }
  0%, 100% {
    opacity: 1;
  }
}

img.fukidashi03 {
    width: 8%;
    position: absolute;
    top: 20%;
    right: 31%;
}
img.fukidashi04 {
    width: 5%;
    position: absolute;
    top: 8%;
    right: 24%;
}
img.fukidashi05 {
    width: 3%;
    position: absolute;
    top: 26%;
    right: 15%;
}



.parts figure img.fukidashi01 {
  animation-name:example;    
  -webkit-animation: example 0.5s ease 5s 1 forwards;
  animation: example 0.5s ease 1.8s 1 forwards;
}
.parts figure img.fukidashi02 {
  
}

.parts figure img.fukidashi03 {
  -webkit-animation: example 0.5s ease 1.5s 1 forwards;
  animation: example 0.5s ease 1.5s 1 forwards;
}
.parts figure img.fukidashi04 {
  -webkit-animation: example 0.5s ease 1.5s 1 forwards;
  animation: example 0.5s ease 1.5s 1 forwards;
}
.parts figure img.fukidashi05 {
  -webkit-animation: example 0.5s ease 1.5s 1 forwards;
  animation: example 0.5s ease 1.5s 1 forwards;
}
@keyframes example {
  100% {
    opacity: 1;
  }
}


@media screen and (max-width:900px) {
    
}

.move{
animation-name:move;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes move{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}
.move-trigger{
    opacity: 0;
}

@media screen and (max-width:900px) {
    
.slider.slick-initialized.slick-slider {
    max-width:350px;
    margin: 0 auto;
    width:90%;
}

.main-contents .inner div:nth-child(2) {
  margin-bottom: 15px;
}
#sec_menu .scroll-box{
  max-width: 350px;
  width:90%;
  margin: 0 auto;
  margin-bottom: 15px;
}
    
}
    

.bg .bg-wrap {
  position: relative;
  display: inline-block;
      width: 100%;
}
.bg.is-animated .bg-wrap::before {
  animation: bg 2.6s cubic-bezier(0.22, 1, 0.36, 1) forwards;
  background: linear-gradient(to right,  #E60012 0%,#E60012 100%);
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  transform-origin: left center;
  border-radius: 12px;
}

.bg .bg-wrap .inn {
    opacity: 0;
}
.bg.is-animated .bg-wrap .inn {
  color: #fff;
  display: inline-block;
  font-weight: bold;
  position: relative;
  z-index: 1;
  opacity: 1;    
}
 
@keyframes bg {
  0% {
    opacity: 0;
    transform: scaleX(0) translateX(-5%);
  }
  30% {
    transform: scaleX(1) translateX(0);
  }
  100% {
    transform: scaleX(1) translateX(0);
  }
  30%, 100% {
    opacity: 1;
  }
}

#sec_coupon .inner div.img-box{
    position: relative;
    display: inline-block;
}
#sec_coupon .inner div.img-box span{
    position: absolute;
    right:5%;
    bottom:15px;
    font-weight:bold;
    text-shadow:1px 1px 0 #FFF, -1px -1px 0 #FFF,
              -1px 1px 0 #FFF, 1px -1px 0 #FFF,
              0px 1px 0 #FFF,  0-1px 0 #FFF,
              -1px 0 0 #FFF, 1px 0 0 #FFF;
}


#sec_shop .map-wrapper {
  position: relative;
  width: 100%;
  padding-top: 100%;
  margin:0 auto;    
}
iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}


@media screen and (max-width:450px) {
#sec_coupon .inner div.img-box span{
    right:8%;
    font-size: 12px;
}
}

.br-14{border-radius:20px;}

@media screen and (max-width:900px) {
#sec_shop .map-box{
  /*position: absolute;*/
  max-width: 350px;
  width:90%;
  margin:0 auto 15px;
}
}

#sec_coupon:before,
#sec_game:before,
#sec_new:before,
#sec_campaign:before,
#sec_menu:before,
#sec_shop:before
{
    content: "";
    display: inline-block;
    height: 500px;
    margin-top: -500px;
    vertical-align: top;
    visibility: hidden;
}
@media screen and (max-width:900px) {
#sec_coupon:before,
#sec_game:before,
#sec_new:before,
#sec_campaign:before,
#sec_menu:before,
#sec_shop:before
{
    height: 40px;
    margin-top: -40px;
}
}    

/*--------------------
GRID
--------------------*/
.grid,
.flex2,
.flex2-2,
.flex3,
.flex4,
.flex5,
.flex6{
	display: -webkit-box;
	display: -ms-flexbox;
	display: -webkit-flex;
	display: flex;
	-webkit-box-pack: justify;
	-ms-flex-pack: justify;
	-webkit-justify-content: space-between;
	justify-content: space-between;
	-webkit-align-items: stretch;
	/*   Safari etc. */
	-ms-align-items: stretch;
	/*  IE10        */
	align-items: stretch;
	-webkit-flex-wrap: wrap;
	/* Safari6.1以降 */
	-ms-flex-wrap: wrap;
	/*IE10*/
	flex-wrap: wrap;
}

/* 最終行の間隔調整 */
.flex4:before,
.flex5:before,
.flex6:before{
	content: "";
	display: block;
	order: 1;
}

.flex3:after,
.flex4:after,
.flex5:after,
.flex6:after{
	content: "";
	display: block;
}

.grid3-2 {
	width: 65.667%;
}

.grid4-3 {
	width: 74.25%;
}

.grid4-2,
.flex2>*,
.flex2-2>* {
	width: 48.5%;
}

.grid3-1,
.flex3>*,
.flex3:after {
	width: 31.333%;
}

.grid4-1,
.flex4>*,
.flex4:before,
.flex4:after {
	width: 22.75%;
}

.flex5>*,
.flex5:before,
.flex5:after {
	width: 17.6%;
}

.flex6>*,
.flex6:before,
.flex6:after {
	width: 15.8333%;
}

.grid>*,
.flex2>*,
.flex2-2>*,
.flex3>*,
.flex4>*,
.flex5>*,
.flex6>*{
	margin-bottom: 10px;
}

/*--------------------
GRID - 640px
--------------------*/
@media screen and (max-width:900px) {
	.grid3-1,
	.grid3-2,
	.grid4-1,
	.grid4-2,
	.grid4-3,
	.flex2>*,
	.flex5>*,
	.flex5:before,
	.flex5:after{
		width: 100%;
	}

	.flex2-2>*,
	.flex4>*,
	.flex4:before,
	.flex4:after {
		width: 47%;
	}
	
	.flex6>*,
	.flex6:before,
	.flex6:after {
		width: 31.33%;
	}    
	 
    
.flex4>*, .flex4:before, .flex4:after {
    width: 100%;
}
}

@media screen and (max-width:640px) {
.flex3 > div{
    width:48%;
}
}
    
    
.sample_main{
    width:100%;
    margin:0 auto;
}
