@charset "utf-8";

/*======= common =======*/
img {
    vertical-align: bottom; 
    max-width: 100%;
}
body {
    font-family: "Hiragino Kaku Gothic ProN", 'ヒラギノ角ゴ ProN W3', Meiryo, メイリオ, Osaka, 'MS PGothic', arial, helvetica, sans-serif;
    font-size: 10px;
}
.main_wrap {
  max-width: 750px;
  margin: 0 auto;
}

/*======= fv =======*/
.fv .fv_movie{
  position: absolute;
  top: 0;
  z-index: -1;
  max-width: 750px;
}

/*======= cta =======*/
.cta{ 
  position: relative;
}
.cta .btn_cart.teiki{
  position: absolute;
  left: 5%;
  width: 90%;
}
.cta .btn_cart.teiki.lightbrown{
  top: 25%;
}
.cta .btn_cart.teiki.naturalbrown{
  top: 29.5%;
}
.cta .btn_cart.teiki.darkbrown{
  top: 33.5%;
}
.cta .btn_cart.teiki.black{
  top: 38.5%;
}

.cta .btn_cart.teiki.lightbrown2{
  top: 41%;
}
.cta .btn_cart.teiki.naturalbrown2{
  top: 48.5%;
}
.cta .btn_cart.teiki.darkbrown2{
  top: 55%;
}
.cta .btn_cart.teiki.black2{
  top: 63.5%;
}

.cta.short .btn_cart.teiki{
  top: 74.5%
}
.btn_cart.anime {
  display: inline-block;
  vertical-align: middle;
  -webkit-transform: perspective(1px) translateZ(0);
  transform: perspective(1px) translateZ(0);
  -webkit-animation-name: hvr-pop;
  animation-name: hvr-pop;
  -webkit-animation-duration: 1.25s;
  animation-duration: 1.25s;
  -webkit-animation-timing-function: linear;
  animation-timing-function: linear;
  -webkit-animation-iteration-count: infinite;
  animation-iteration-count: infinite;
}
@-webkit-keyframes hvr-pop {
  50% {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
}
@keyframes hvr-pop {
	10% {
    -webkit-transform: scale(1.04);
    transform: scale(1.04);
	}
	30% {
    -webkit-transform: scale(1);
    transform: scale(1);
	}
  40% {
    -webkit-transform: scale(1.02);
    transform: scale(1.02);
  }
	50% {
    -webkit-transform: scale(1);
    transform: scale(1);
	}
	100% {
    -webkit-transform: scale(1);
    transform: scale(1);
	}
}

.cta.float_bnr.is-hidden {
	visibility: hidden;
	opacity: 0;
}

/*======= フローティングバナー =======*/
.cta.float_bnr{
  position: fixed;
  bottom: 0;
  width: 100%;
  max-width: 750px;
  z-index: 1;
  /*transform: none;*/
  /*-webkit-transform: none;*/
  -ms-transform: none;
  transition: all 1s;
}
.cta.float_bnr .btn_cart{
  position: absolute;
  text-align: center;
  width: 40%;
  height: auto;
  bottom: 0;
  right: 3%;
}

/*======= movie =======*/
.movie {
  position: relative;
}
.movie video {
  position: absolute;
  left: 50%;
  width: 80%;
  transform: translateX(-50%);
}
.movie.logic video {
  bottom: 10%;
  border: solid 10px #fff;
}
.movie.foam video {
  bottom: 17%;
  width: 90%;
}

/*======= footer =======*/
.footer{
  font-size: 12px;
  line-height: 1.5;
  color: #333333;
  text-align: center;
  padding: 30px 0;
}
.footer ul{
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 20px;
  line-height: 2;
}
.footer li{
  margin: 0 10px;
  width: 40%;
  white-space: nowrap;
}
.footer li a{
  text-decoration: underline;
}
.footer .copy{
  font-size: 10px;
}


@media screen and (min-width: 481px) {
	/* 481px以上に適用されるCSS（タブレット用） */
  .main_wrap {
    max-width: 750px;
    margin: 0 auto;
  }
  .cta.float_bnr{
    max-width: 750px;
  }
}
@media screen and (min-width: 960px) {
	/* 960px以上に適用されるCSS（PC用） */
  
  /*======= common =======*/
  .main_wrap {
    max-width: 750px;
    margin: 0 auto;
    box-shadow: 0 2px 1em rgba(0,0,0,.3);
  }
  /*======= cta =======*/
  .cta .btn_cart:hover { 
    opacity: 0.7;
  }
  /*======= フローティングバナー =======*/
  .cta.float_bnr{
    max-width: 750px;
  }
  .cta.float_bnr .btn_cart{
    right: 20px;
    width: 300px;
    bottom: 2px;
  }
}