@charset "UTF-8";
/* CSS Document */
@import url(http://fonts.googleapis.com/earlyaccess/notosansjp.css);
/* ----------------------------------------------- FORMAT ---------- */

html {
  font-family: 'Noto Sans JP', "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium",
    "游ゴシック", "Yu Gothic", sans-serif;
  font-size: 10px;
  line-height: 1.8em;
  color: #221714;
  overflow-x: hidden;
  margin: 0;
  padding: 0;
}

body {
  margin: 0;
  background-color: #fff;
  text-align: center;
  overflow: hidden;
  width: 100%;
  max-width: 100%;
}

*,
*:before,
*:after {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -o-box-sizing: border-box;
  -ms-box-sizing: border-box;
  box-sizing: border-box;
}

p {
  text-align: justify;
  line-height: 1.8em;
  margin: 0;
}

img {
  border: 0;
  width: 100%;
  height: auto;
}

ul {
  margin: 0;
  padding: 0;
  text-indent: 0;
  list-style: none;
}

li {
  margin: 0;
  padding: 0;
}

a {
  color: inherit;
  text-decoration: none;
}

figure {
  margin: 0;
}

a *:hover {
  color: inherit;
  cursor: pointer;
}

p.u-link a {
  color: #ea5504;
}

a:hover {
  color: inherit;
  cursor: pointer;
}

a:hover img {
  opacity: 0.8;
  filter: alpha(opacity=80);
}

a:hover img.no_opacity {
  opacity: 1;
  filter: alpha(opacity=100);
}

.sp {
  display: none !important;
}
@media screen and (max-width: 640px) {
  .sp {
    display: block !important;
  }
  .pc {
    display: none !important;
  }
}
/* ----------------------------------------------- MV ---------- */
#mv{
  height:820px;
  background:#ffca4e;
  position:relative;
}
#mv #youtube{
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  opacity: 0.3;
  width: 100vw;
  height: 180vw;
  min-height: 150%;
  min-width: 460%;
}
#mv #youtube_pc{
  position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    opacity: 0.15;
    width: 100%;
    height: 60vw;
}
#mv #youtube{
  display: none;
}
#mv #youtube_pc{
  display: block;
}
#mv h1{
  font-size:66px;
  width:800px;
  text-align: center;
  margin: 0 0 80px;
  padding-top: 200px;
  color:#333;
  letter-spacing: 0.1em;
  font-weight:600;
  line-height: 1.5em;
  position:absolute;
  top:-50px;
  left:calc(50% - 400px);
}
#mv h1 + p{
  font-size:32px;
  width:100%;
  text-align: center;
  line-height:1.8em;
  margin-bottom: 40px;
  letter-spacing: 0.05em;
  font-weight:600;
  color:#333;
  position:absolute;
  top:0;
  left:calc(50% - 0);
}
#mv .logo{
  width:300px;
  margin: 0 auto 40px;
  position:absolute;
  top:50px;
  left:calc(50% - 150px);
}
#mv .cv{
  /*
  width:96%;
  max-width:460px;
  height:90px;
  border-radius: 20px;
  background:#333;
  color:#fff;
  font-size:30px;
  letter-spacing: 0.05em;
  font-weight:600;
  text-align: center;
  margin: 40px auto 80px;
  padding-top: 35px;
  position: relative;
  */
  width:90%;
  max-width:400px;
  height:80px;
  border-radius: 40px;
  text-align: center;
  margin: 0 auto;
  background:#333;/*fff*/
  border:none;
 /* border:4px solid #666;*/
  font-size:22px;
  color:#fff;
  padding-top: 28px;
  font-weight:600;
  letter-spacing: 0.1em;
  position:absolute;
  top:600px;
  left:calc(50% - 200px);

}
#mv .cv:hover{
  /*
  background:#555;
  */
  background:#333;
  color:#fff;
}
#mv .cv:after{
  content: "";
  position: absolute;
  top: calc(50% - 16px);
  left: calc(100% + 10px);
  margin-left: -15px;
  border: 15px solid transparent;
  border-left: 30px solid #333;  
}
#mv .cv a{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
}

#mv2{
  width:100%;
  height:600px;
  position:relative;
  margin-bottom: 80px;
  background-size: cover;
  background-image:url(img/mv2.jpg);
  background-position: center center;
}
#mv2 .mock{
  position:absolute;
  bottom:-30px;
  right:20px;
  width:500px;
}
@media screen and (max-width: 640px) {
  #mv{
    height:660px;
  }
  #mv #youtube{
    display: block;
  }
  #mv #youtube_pc{
    display: none;
  }
  #mv h1{
    font-size:40px;
    margin: 0 0 40px;
    padding-top: 100px;
    top:30px;
    left:5%;
    width:90%;
  }
  #mv h1 + p{
    font-size:14px;
    line-height:1.5em;
    margin-bottom: 40px;
    top:310px;
    left:0
  }
  #mv .logo{
    top:50px;
  }
  #mv .cv{
    /*
    width:80%;
    height:60px;
    border-radius: 20px;
    font-size:20px;
    margin: 40px auto 0;
    padding-top: 20px;
    */
    width:80%;
    height:60px;
    border-radius: 30px;
    font-size:18px;
    padding-top: 18px;
    font-weight:600;
    letter-spacing: 0.1em;
    top:340px;
    left:10%;
  }
  #mv .cv:after{
    content: "";
    position: absolute;
    top: 100%;
    left: 80%;
    margin-left: -15px;
    border: 15px solid transparent;
    border-top: 15px solid #333;  
  }
  #mv .cv a{
    position:absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
  }
  
  #mv2{
    height:400px;
    margin-bottom: 80px;
    background-position: left center;
  }
  #mv2 .mock{
    bottom:120px;
    right:calc(50% - 140px);
    width:280px;
  }
}
/* ----------------------------------------------- MERIT ---------- */
#merit{
  width:90%;
  max-width:1200px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 80px;
}
#merit p.h2_sub{
  width:100%;
  font-size:16px;
  color:#ffca4e;
  text-align: center;
  font-weight:600;
  margin: 0 0 40px;
}
#merit h2{
  width:100%;
  font-size:44px;
  text-align: center;
  margin:0 0 30px;
  color:#333;
  font-weight:600;
  line-height:1.5em;
}
#merit h2 + p{
  font-size:30px;
  width:100%;
  text-align: center;
  color:#333;
  font-weight:600;
  margin-bottom: 60px;
}
#merit article{
  width:32%;
}
#merit article h3{
  text-align: left;
  font-size:28px;
  font-weight:600;
  line-height: 1.5em;
  margin-bottom: 20px;
  color:#333;
}
#merit article p{
  text-align: justify;
  font-size:16px;
  line-height: 1.8em;
}
@media screen and (max-width: 640px) {
  #merit{
    margin: 0 auto 40px;
  }
  #merit p.h2_sub{
    font-size:14px;
    margin: 0 0 10px;
  }
  #merit h2{
    font-size:32px;
    margin:0 0 10px;
  }
  #merit h2 + p{
    font-size:18px;
    margin-bottom: 40px;
  }
  #merit article{
    width:100%;
    margin-bottom: 40px;
  }
  #merit article h3{
    font-size:24px;
    line-height: 1.5em;
    margin-bottom: 10px;
  }
  #merit article p{
    text-align: justify;
    font-size:14px;
  }
}
/* ----------------------------------------------- ABOUT ---------- */
#about{
  width:100%;
  margin: 0 auto 80px;
  background: #fff9ea;
  padding: 80px 0;
}
#about .about_wrap{
  width:96%;
  max-width: 1200px;
  margin: 0 auto 40px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#about figure{
  width:40%
}
#about div{
  width:56%;
}
#about p.h2_sub{
  width:100%;
  font-size:16px;
  color:#ffca4e;
  text-align: left;
  font-weight:600;
  margin: 0 0 20px;
}
#about h2{
  width:100%;
  font-size:44px;
  text-align: left;
  margin:0 0 40px;
  color:#333;
  font-weight:600;
}
#about p{
  font-size:16px;
  line-height:1.8em;
}
#about .btn_bp_wrap{
  width:100%;
  margin: 60px 0;
}
#about .btn_bp{
  width:90%;
  max-width:400px;
  height:80px;
  border-radius: 40px;
  text-align: center;
  margin: 0 auto;
  background:#fff;
  border:2px solid #333;
  font-size:18px;
  color:#333;
  padding-top: 30px;
  font-weight:600;
  letter-spacing: 0.1em;
  position:relative;
}
#about .btn_bp:hover{
  background:#333;
  color:#fff;
}
#about .btn_bp a{
  position:absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
}
#about .yt{
  width:100%;
}
@media screen and (max-width: 640px) {
  #about{
    margin: 0 auto 80px;
    padding: 80px 0 0;
  }
  #about .about_wrap{
    width:90%;
    margin: 0 auto 40px;
  }
  #about figure{
    width:100%;
    margin-bottom:20px;
  }
  #about div{
    width:100%;
  }
  #about p.h2_sub{
    font-size:14px;
    text-align: center;
    margin: 0 0 10px;
  }
  #about h2{
    font-size:32px;
    margin:0 0 40px;
    text-align: center;
  }
  #about p{
    font-size:14px;
    text-align: justify;
  }
  #about .btn_bp_wrap{
    width:100%;
    margin: 60px 0;
  }
  #about .btn_bp{
    width:80%;
    height:60px;
    border-radius: 30px;
    font-size:18px;
    padding-top: 20px;
    font-weight:600;
    letter-spacing: 0.1em;
  }
  #about .yt{
    width:100vw;
  }
  #about .yt iframe{
    width:100vw;
    height:56.25vw;
  }
}

/* ----------------------------------------------- FEATURE ---------- */
#feature{
  width:90%;
  max-width:1200px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  margin: 0 auto 80px;
}
#feature p.h2_sub{
  width:100%;
  font-size:16px;
  color:#ffca4e;
  text-align: center;
  font-weight:600;
  margin: 0 0 40px;
}
#feature h2{
  width:100%;
  font-size:44px;
  text-align: center;
  margin:0 0 80px;
  color:#333;
  font-weight:600;
}
#feature article{
  display: flex;
  flex-wrap:wrap;
  justify-content: space-between;
  width:96%;
  max-width: 1200px;
  margin-bottom: 60px;
}
#feature article:nth-child(2n){
  flex-direction: row-reverse;
}
#feature article figure{
  width:42%;
}
#feature article div{
  width:54%;
}
#feature article div h3{
  font-size:28px;
  line-height:1.5em;
  font-weight:600;
  text-align: left;
  margin: 20px 0;
  color:#333;
}
#feature article div p{
  font-size:16px;
  line-height:1.8em;
  text-align: justify;
}
@media screen and (max-width: 640px) {
  #feature{
    margin: 0 auto 0;
  }
  #feature p.h2_sub{
    font-size:14px;
    margin: 0 0 10px;
  }
  #feature h2{
    font-size:32px;
    margin:0 0 40px;
  }
  #feature article{
    width:100%;
    margin-bottom: 60px;
  }
  #feature article:nth-child(2n){
    flex-direction: row-reverse;
  }
  #feature article figure{
    width:100%;
  }
  #feature article div{
    width:100%;
  }
  #feature article div h3{
    font-size:20px;
    margin: 20px 0 10px;
  }
  #feature article div p{
    font-size:14px;
  }
}
/* ----------------------------------------------- SHOP ---------- */

#shop p.h2_sub{
  width:100%;
  font-size:16px;
  color:#ffca4e;
  text-align: center;
  font-weight:600;
  margin: 0 0 40px;
}
#shop h2{
  width:100%;
  font-size:44px;
  text-align: center;
  margin:0 0 30px;
  color:#333;
  font-weight:600;
}
#shop h2 + p{
  font-size:30px;
  width:100%;
  text-align: center;
  color:#333;
  font-weight:600;
  margin-bottom: 60px;
}
#shop{
  width:100%;
  margin: 0 auto;
  background: #fff9ea;
  padding: 80px 0;
}
#shop .shop_wrap{
  width:90%;
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#shop article{
  width:32%;
  margin-bottom: 40px;
}
#shop article h3{
  font-size:18px;
  line-height: 1.5em;
  margin-bottom: 5px;
  text-align: left;
}
#shop article p{
  font-size:12px;
  line-height: 1.5em;
  text-align: left;
  margin-bottom: 20px;
}
#shop article .btn_shop_detail{
  width:100%;
  height:40px;
  border-radius: 20px;
  text-align: center;
  font-size:14px;
  font-weight:600;
  color:#fff;
  position: relative;
  background:#333;
  padding-top: 10px;
}
#shop article .btn_shop_detail:hover{
  background:#555;
}
#shop article .btn_shop_detail a{
  position:absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
}
@media screen and (max-width: 640px) {
  #shop p.h2_sub{
    font-size:14px;
    margin: 0 0 10px;
  }
  #shop h2{
    font-size:32px;
    margin:0 0 30px;
  }
  #shop h2 + p{
    font-size:18px;
    margin-bottom: 40px;
  }
  #shop{
    width:100%;
    margin: 0 auto;
    background: #fff9ea;
    padding: 80px 0;
  }
  #shop .shop_wrap{
    margin: 0 auto;
  }
  #shop article{
    width:48%;
    margin-bottom: 40px;
  }
  #shop article h3{
    font-size:13px;
  }
  #shop article p{
    font-size:10px;
    margin-bottom: 10px;
  }
  #shop article .btn_shop_detail{
    width:100%;
    height:30px;
    border-radius: 15px;
    text-align: center;
    font-size:10px;
    padding-top: 5px;
  }
}
/* ----------------------------------------------- STORY ---------- */

#story{
  width:100%;
  padding: 80px 0;
  background:#ffca4e;
}
#story .story_wrap{
  width:90%;
  max-width:1200px;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}
#story figure{
  width:48%;
}
#story .cv{
  /*
  width:96%;
  max-width:460px;
  height:90px;
  border-radius: 20px;
  background:#333;
  color:#fff;
  font-size:30px;
  letter-spacing: 0.05em;
  font-weight:600;
  text-align: center;
  margin: 40px auto 0;
  padding-top: 35px;
  position: relative;
  */
  width:90%;
  max-width:400px;
  height:80px;
  border-radius: 40px;
  text-align: center;
  margin: 0 auto;
  background:#fff;
  border:2px solid #333;
  font-size:18px;
  color:#333;
  padding-top: 30px;
  font-weight:600;
  letter-spacing: 0.1em;
  position:relative;
}
#story .cv:hover{
  /*
  background:#555;
  */
  background:#333;
  color:#fff;
}
#story .cv a{
  position: absolute;
  width:100%;
  height:100%;
  top:0;
  left:0;
}
@media screen and (max-width: 640px) {
  #story figure{
    width:100%;
  }
  #story .cv{
    /*
    width:80%;
    height:60px;
    border-radius: 20px;
    font-size:20px;
    margin: 40px auto 0;
    padding-top: 20px;
  */
  width:80%;
  height:60px;
  border-radius: 30px;
  font-size:18px;
  padding-top: 20px;
  font-weight:600;
  letter-spacing: 0.1em;
}
}
.copyright{
  text-align: center;
  margin: 20px 0;
  font-size:12px;
  color:#333;
}