@charset "UTF-8";
/*------------------------------------------------------------
	Reset
------------------------------------------------------------*/
* {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  box-sizing: border-box; }

article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
menu,
nav,
section,
main {
  display: block; }

html {
  font-size: 62.5%; }

body {
  -webkit-text-size-adjust: 100%; }

h1,
h2,
h3,
h4,
h5,
h6 {
  font-weight: bold; }

table,
input,
textarea,
select,
option {
  line-height: 1.1; }

ol,
ul {
  list-style: none; }

blockquote,
q {
  quotes: none; }

:focus {
  outline: 0; }

a,
ins {
  text-decoration: none; }

del {
  text-decoration: line-through; }

img {
  vertical-align: top; }

a {
  transition: 0.3s ease-in-out; }



@media (min-width: 768px) {
  .sp {
    display: none; } }

@media (min-width: 992px) {
  .tablet {
    display: none; } }

@media screen and (max-width: 767px) {
  .pc {
    display: none; } }

@media screen and (max-width: 991px) {
  .pc-tablet {
    display: none; } }

@media screen and (max-width: 1024px) {
  .pc-only {
    display: none; } }

@keyframes fade_in {
  0% {
    opacity: 0; }
  100% {
    opacity: 1; } }

@keyframes slide_y {
  0% {
    transform: translateY(1.4vw); }
  100% {
    transform: translateY(0); } }

@keyframes slide_x {
  0% {
    transform: translateX(-1.4vw); }
  100% {
    transform: translateX(0); } }

@keyframes move {
  0% {
    left: 0;
    opacity: 0; }
  35% {
    left: 41%;
    transform: rotate(0deg);
    opacity: 1; }
  65% {
    left: 59%;
    transform: rotate(0deg);
    opacity: 1; }
  100% {
    left: 100%;
    transform: rotate(-180deg);
    opacity: 0; } }

body {
  margin: 0;
  padding: 0;
  overflow-x: hidden;
  line-height: 1.6;
  letter-spacing: .5px;
  background: url(../img/bg.jpg);
  background-repeat: repeat-y;
  color: #141414;
  -webkit-font-smoothing: antialiased; 

}
 
.wrapper {
  max-width: 1000px;
  padding: 0 15px;
  margin: 0 auto; 
  background-image: url(../img/bg_waper.png); 
}
  @media screen and (max-width: 767px) {
    .wrapper {
      padding: 0 10px; 
    } 
}

.wrapper__in{
  max-width: 968px;
  padding: 0 6px;
  border-right: 6px solid;
  border-left: 6px solid;
  border-image: linear-gradient(to bottom, #dea25c 0%, #facb64 25%, #dea25c 50%, #facb64 75%, #dea25c 100%);
  border-image-slice: 1;  
  margin: 0 auto;
  overflow: hidden;
}

@media (max-width: 768px) {
.wrapper__in{
max-width: 656px;
}
}
/*--------------------------------------------------------------
 c-loading
--------------------------------------------------------------*/
.c-loading {
  width: 100%;
  height: 100vh;
  background: #99b4cf;/*background: #421f1b;*/
  position: fixed;
  top: 0;
  left: 0;
  z-index: 9999; 
}
.c-loading__inner {
    user-select: none;
    cursor: default;
    width: 400px;
    height: 36px;
    position: absolute;
    left: calc(50% - 200px);
    top: calc(50% - 18px);
    overflow: visible; 
}
.c-loading__inner div {
      position: absolute;
      width: 20px;
      height: 36px;
      opacity: 0;
      font-family: Helvetica, Arial, sans-serif;
      animation: move 2s linear infinite;
      transform: rotate(180deg);
      color: #fff;
      font-weight: bold;
}
.c-loading__inner div:nth-child(2) {
        animation-delay: 0.2s; 
}
.c-loading__inner div:nth-child(3) {
        animation-delay: 0.4s; 
}
.c-loading__inner div:nth-child(4) {
        animation-delay: 0.6s; 
}
.c-loading__inner div:nth-child(5) {
        animation-delay: 0.8s; 
}
.c-loading__inner div:nth-child(6) {
        animation-delay: 1s; 
}
.c-loading__inner div:nth-child(7) {
        animation-delay: 1.2s; 
}
.c-loading__line {
    display: block;
    width: 0;
    height: 2px;
    position: absolute;
    left: 0;
    bottom: -8px;
    background: rgba(255, 255, 255, 0.5); 
}



/*--------------------------------------------------------------
 cafe-mv
--------------------------------------------------------------*/
.camera-mv {
  position: relative;
  text-align: center;
  padding-top: 50px;
}
.camera-mv__ttl {
  margin: auto;
  }
@media (max-width: 414px) {
  .camera-mv {
    padding-top: 20px;
}
}
/*--------------------------------------------------------------
lead
--------------------------------------------------------------*/
.lead{
  padding:0px 0 20px;
  text-align: center;
}
.lead h1{
  margin: 20px 0 20px;
  letter-spacing: -.005em;
}
.lead h2{
  font-weight: normal;
  letter-spacing: -.005em;
}
@media (max-width: 414px) {
.lead{
  padding: 0px 0 10px;
  text-align: center;
}
.lead h1{
  font-size:18px ;
}
.lead h2{
  font-size:14px ;
}
}
@media (max-width: 320px) {
.lead h1{
  font-size:16px ;
}
.lead h2{
  font-size: 12px;
}
}
/*--------------------------------------------------------------
 product01-03
--------------------------------------------------------------*/
.product{
  padding: 50px 0 0 ;
}
.product01, .product02, .product03{
  position: relative;
  margin: auto;
}

.product .product01 img, .product .product02 img, .product .product03 img{
  position: absolute;
}

.product img.item{
  width: 480px;
  height: auto;
  left: 50%;
  top: 0px;
   z-index: 30;
   transform: translate(-50%, 0);
}

.product img.kira_left{
  width: 148px;
  left: 10%;
  top: -100px;
   z-index: 10;
}

.product img.kira_right{
  width: 148px;
  right: 10%;
  top: -100px;
   z-index: 10;
}
.product img.fukidashi_left{
  width: 200px;
  left: 10%;
  top: 0px;
  z-index: 10;
}
.product img.fukidashi_right{
  width: 200px;
  right: 10%;
  top: 0px;
  z-index: 10;
}
.camera_go{
  padding-top: 500px;
}

.product p{
  font-weight: bold;
  font-size: 16px;
  margin-bottom: 12px;
  text-align: center;
}

.product .on_camera_btn:hover{
  opacity: .6;
}

@media (max-width: 414px) {
.product{
  padding: 20px 0 30px;
}

.product img.item{
  width: 300px;
}
.product img.kira_left {
    width: 120px;
    left: 0%;
    top: -20px;
    z-index: 10;
}
.product img.kira_right {
    width: 120px;
    right: 0%;
    top: -20px;
    z-index: 10;
}
.product img.fukidashi_left{
  width: 120px;
  left: 0%;
  top: -30px;
  z-index: 10;  
}
.product img.fukidashi_right{
  width: 120px;
  right: 5%;
  top: 0px;
  z-index: 10;  
}
.camera_go{
  padding-top: 300px;
}
}

@media (max-width: 320px) {
.product img.fukidashi_left {
    width: 120px;
    left: 0%;
    top: -45px;
    z-index: 10;
}
.product img.fukidashi_right{
  width: 120px;
  right: 0%;
  top: 0px;
  z-index: 10;  
}
  }

/*--------------------------------------------------------------
 howto
--------------------------------------------------------------*/
.howto{
padding: 50px 0 60px ;
}
.howto h2{
  text-align: center;
  padding: 0 10px;
}
.mainvisual{
  overflow-x: hidden;
  padding: 0px 10px 70px;
}
@media(min-width: 769px){
  .swiper-slide{
    width: 33.3%;
  }
  .swiper-button-prev,.swiper-button-next,.swiper-pagination{
    display: none;
  }
}

.howto_massage{
  position: relative;
  margin: auto;
  width: 100%;
}
.howto_massage img{
  position: absolute;
}

.howto_massage p{
  padding-top: 40px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.8;
  z-index: 1;
}
.howto_massage p span{
  color: #a06e32;
}
.howto_massage img.kira_left{
  width: 120px;
  left: 10%;
  top: -10px;
   z-index: 10;
}
.howto_massage img.kira_right{
  width: 120px;
  right: 10%;
  top: 10px;
   z-index: 10;
}


.howto_point{
  position: relative;
  margin: auto;
  width: 100%;
  padding-top: 80px;
}
.howto_point h3{
  text-align: center;
}
.howto_point ul{
  width:60%;
  margin: auto;
}
.howto_point ul{
  padding-left: 20px;
}
.howto_point ul li{
  list-style: disc;
}

@media (max-width: 414px) {
.howto{
  padding: 20px 0 ;
}
.howto_massage p{
  padding-top: 0px;
  text-align: center;
  font-size: 16px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: -.05em;
}
.howto_massage img.kira_left{
  width: 60px;
  left: 0%;
  top: -20px;
}
.howto_massage img.kira_right{
  width: 60px;
  right: 0%;
  top: 40px;
}
.howto_point{
  padding-top: 20px;
}
.howto_point ul{
  width:95%;
}
}

@media (max-width: 320px) {
  .howto_massage p{
  padding-top: 0px;
  text-align: center;
  font-size: 14px;
  font-weight: bold;
  line-height: 1.8;
  letter-spacing: -.05em;
}
  }
/*--------------------------------------------------------------
 guide
--------------------------------------------------------------*/
.guide{
padding: 50px 0 50px;
}
.guide h3{
  text-align: center;
}
.guide ul, .guide p{
  width:60%;
  margin: auto;
}
.guide ul{
  padding-left: 20px;
}
.guide ul li{
  list-style: disc;
}

@media (max-width: 414px) {
.guide{
  padding: 20px 0 ;
}
.guide ul, .guide p{
  width:95%;
}
}
/*--------------------------------------------------------------
 footer
--------------------------------------------------------------*/
#footer{
  text-align: center;
  padding: 20px 30% 0;
}
#footer img:hover{
  opacity: .8;
}

#footer .copyright{
  font-size: 1rem;
  padding: 20px 10px 20px;
}
@media (max-width: 414px) {
#footer{
  text-align: center;
  padding: 20px 10% 0;
}
}

/*--------------------------------------------------------------
  swiper
--------------------------------------------------------------*/
@media (max-width: 768px) {
.swiper-slide {
  pointer-events: none;
  opacity: 1;
}
.swiper-slide-next, .swiper-slide-prev {
  pointer-events: auto; 
  opacity: .5;
  -webkit-transition: opacity .5s;
  -moz-transition: opacity .5s;
  -ms-transition: opacity .5s;
  -o-transition: opacity .5s;
  transition: opacity .5s;
}
}
/*--------------------------------------------------------------
  animation
--------------------------------------------------------------*/
.js-view-y {
  opacity: 0;
  transform: translateY(1.4vw); }
  .js-view-y.is-view-y {
    animation: 1s cubic-bezier(0.215, 0.61, 0.355, 1) both;
    animation-name: fade_in, slide_y; }

.js-view-x {
  opacity: 0;
  transform: translatex(-1.4vw); }
  .js-view-x.is-view-x {
    animation: 1s cubic-bezier(0.215, 0.61, 0.355, 1) both;
    animation-name: fade_in, slide_x; }