@charset "UTF-8";
/*リセット
--------------------------------------------*/
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline; }

html {
  line-height: 1; }

ol, ul {
  list-style: none; }

table {
  border-collapse: collapse;
  border-spacing: 0; }

caption, th, td {
  text-align: left;
  font-weight: normal;
  vertical-align: middle; }

q, blockquote {
  quotes: none; }
q:before, q:after, blockquote:before, blockquote:after {
  content: "";
  content: none; }

a img {
  border: none; }

article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, section, summary {
  display: block; }

/*フォント
---------------------------------------------*/
@font-face {
  font-family: "noto-sans";
  src: url("../fonts/NotoSansCJKjp-DemiLight.woff2") format("woff2"), url("../fonts/NotoSansCJKjp-DemiLight.woff") format("woff"), url("../fonts/NotoSansCJKjp-DemiLight.ttf") format("truetype");
  font-weight: 350;
  font-style: normal; }
@font-face {
  font-family: "noto-sans";
  src: url("../fonts/NotoSansCJKjp-Bold.woff2") format("woff2"), url("../fonts/NotoSansCJKjp-Bold.woff") format("woff"), url("../fonts/NotoSansCJKjp-Bold.ttf") format("truetype");
  font-weight: 700;
  font-style: normal; }
/*メディアクエリー
---------------------------------------------*/
/*変数
---------------------------------------------*/
/* コンテンツ
---------------------------------------------*/
html {
  font-family: 'Muli', 'noto-sans', sans-serif;
  font-weight: 350;
  line-height: 1.4;
  width: 100%; }

body {
  font-family: 'Muli', 'noto-sans', sans-serif;
  font-weight: 350;
  line-height: 1.4;
  width: 100%;
  height: 100%; }
@media screen and (min-width: 769px) {
  body {
    font-size: 14px; } }
@media screen and (max-width: 768px) {
  body {
    font-size: 12px; } }

img {
  width: 100%;
  height: auto;
  display: block; }

@media screen and (min-width: 769px) {
  .pcNone {
    display: none; } }
@media screen and (max-width: 768px) {
  .pcNone {
    display: block; } }

@media screen and (min-width: 769px) {
  .spNone {
    display: block; } }
@media screen and (max-width: 768px) {
  .spNone {
    display: none; } }

#mainArea {
  width: 100%; }
@media screen and (min-width: 769px) {
  #mainArea {
    height: 100vh; } }
@media screen and (max-width: 768px) {
  #mainArea {
    height: calc(100vh - 70px); } }
#mainArea div {
  background-size: cover;
  background-position: top center;
  width: 100%;
  height: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  position: relative; }
@media screen and (min-width: 769px) {
  #mainArea div {
    background-image: url(../images/main_pc.jpg); } }
@media screen and (max-width: 768px) {
  #mainArea div {
    background-image: url(../images/main.jpg); } }
@media screen and (min-width: 769px) {
  #mainArea div h1 {
    width: 40%;
    height: auto;
    margin: 5% auto 0; } }
@media screen and (max-width: 768px) {
  #mainArea div h1 {
    width: 75%;
    height: auto;
    margin: auto; } }
#mainArea div h1 + a {
  display: block;
  position: absolute; }
@media screen and (min-width: 769px) {
  #mainArea div h1 + a {
    bottom: 2%;
    right: 2%; } }
@media screen and (max-width: 768px) {
  #mainArea div h1 + a {
    bottom: 5%;
    right: 5%; } }
@media screen and (min-width: 769px) {
  #mainArea div h1 + a {
    width: 45px; } }
@media screen and (max-width: 768px) {
  #mainArea div h1 + a {
    width: 30px; } }

.block {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: -webkit-sticky;
  position: sticky;
  top: 0;
  height: 100vh; }
.block:last-child {
  flex-direction: column; }
.block div.bgCover {
  width: 100%;
  height: 100%;
  background-size: cover;
  background-position: top center;
  position: relarive; }
@media screen and (min-width: 769px) {
  .block div.bgCover div.detail {
    display: none; } }
@media screen and (max-width: 768px) {
  .block div.bgCover div.detail {
    width: 30px;
    position: absolute;
    bottom: 5%;
    right: 5%;
    display: block; } }
.block:nth-child(even) {
  flex-direction: column; }
.block:nth-child(even) p.sub {
  font-style: italic; }
@media screen and (min-width: 769px) {
  .block:nth-child(even) p.sub {
    font-size: 18px; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) p.sub {
    font-size: 18px; } }
@media screen and (min-width: 769px) {
  .block:nth-child(even) p.sub span {
    font-size: 32px;
    display: inline-block; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) p.sub span {
    font-size: 32px;
    display: inline-block; } }
.block:nth-child(even) h2 {
  position: relative; }
@media screen and (min-width: 769px) {
  .block:nth-child(even) h2 {
    font-size: 22px;
    margin-bottom: 18px; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) h2 {
    font-size: 22px;
    margin-bottom: 18px; } }
.block:nth-child(even) h2::after {
  content: "";
  display: block;
  width: 100%;
  background: -webkit-linear-gradient(rgba(255, 255, 255, 0) 60%, #b0cecc 0%);
  background: linear-gradient(rgba(255, 255, 255, 0) 60%, #b0cecc 0%);
  transform: skewX(30deg);
  position: absolute;
  bottom: 1px;
  height: 22px;
  z-index: -1; }
@media screen and (min-width: 769px) {
  .block:nth-child(even) p.price {
    margin-top: 18px;
    margin-bottom: 18px; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) p.price {
    margin-top: 18px;
    margin-bottom: 18px; } }
@media screen and (min-width: 769px) {
  .block:nth-child(even) p.price span.medium {
    font-size: 18px; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) p.price span.medium {
    font-size: 18px; } }
@media screen and (min-width: 769px) {
  .block:nth-child(even) p.price span.small {
    font-size: 12px; } }
@media screen and (max-width: 768px) {
  .block:nth-child(even) p.price span.small {
    font-size: 12px; } }

.block-01, .block-03, .block-05, .block-07, .block-09, .block11 {
  background-color: #fff; }

div#content {
  width: 100%; }
@media screen and (min-width: 769px) {
  div#content {
    display: flex;
    flex-wrap: wrap; } }

.block-01 {
  z-index: 100; }
@media screen and (min-width: 769px) {
  .block-01 {
    width: 70%; } }

.block-02 {
  z-index: 150; }
@media screen and (min-width: 769px) {
  .block-02 {
    width: 30%;
    background: #fff; } }
@media screen and (max-width: 768px) {
  .block-02 {
    width: 100%;
    background: rgba(255, 255, 255, 0.9); } }

.block-03 {
  z-index: 200; }
@media screen and (min-width: 769px) {
  .block-03 {
    width: 70%; } }

.block-04 {
  z-index: 250;
  background: #fff; }
@media screen and (min-width: 769px) {
  .block-04 {
    width: 30%; } }
@media screen and (max-width: 768px) {
  .block-04 {
    width: 100%;
    background: rgba(255, 255, 255, 0.9); } }

.block-05 {
  z-index: 300; }
@media screen and (min-width: 769px) {
  .block-05 {
    width: 70%; } }

.block-06 {
  z-index: 350;
  background: #fff; }
@media screen and (min-width: 769px) {
  .block-06 {
    width: 30%; } }
@media screen and (max-width: 768px) {
  .block-06 {
    width: 100%;
    background: rgba(255, 255, 255, 0.9); } }

.block-07 {
  z-index: 350; }
@media screen and (min-width: 769px) {
  .block-07 {
    width: 70%; } }

.block-08 {
  z-index: 400;
  background: #fff; }
@media screen and (min-width: 769px) {
  .block-08 {
    width: 30%; } }
@media screen and (max-width: 768px) {
  .block-08 {
    width: 100%;
    background: rgba(255, 255, 255, 0.9); } }

.block-09 {
  z-index: 450;
  background: #fff;
  width: 100%;
  height: 100vh; }

div#footer {
  width: 100%;
  padding: 0 0 10px 0; }
div#footer a {
  display: block; }
@media screen and (min-width: 769px) {
  div#footer a {
    width: 180px;
    height: auto;
    margin: 0 auto 80px; } }
@media screen and (max-width: 768px) {
  div#footer a {
    width: 35%;
    height: auto;
    margin: 0 auto 50px; } }
div#footer p {
  text-align: center; }
@media screen and (min-width: 769px) {
  div#footer p {
    font-size: 12px; } }
@media screen and (max-width: 768px) {
  div#footer p {
    font-size: 10px; } }

a.buyBtn {
  display: block;
  text-align: center;
  box-sizing: border-box;
  border: 1px solid #000;
  color: #000;
  line-height: 1.0;
  transition: 1s;
  text-decoration: none;
  font-weight: 700; }
@media screen and (min-width: 769px) {
  a.buyBtn {
    width: 250px;
    padding: 10px 0; } }
@media screen and (max-width: 768px) {
  a.buyBtn {
    width: 60%;
    padding: 10px 0; } }
a.buyBtn:hover {
  border: 1px solid #b0cecc;
  background: #b0cecc;
  color: #fff; }
a.buyBtn.hover {
  border: 1px solid #b0cecc;
  background: #b0cecc;
  color: #fff; }

@media screen and (min-width: 769px) {
  .flexslider {
    width: 300px;
    height: 300px;
    margin: auto; } }

#page-top {
  background: #222;
  position: fixed;
  bottom: 0;
  right: 5px;
  z-index: 999;
  border-radius: 5px 5px 0 0; }
#page-top a {
  color: #fff;
  text-decoration: none;
  width: 100%;
  box-sizing: border-box;
  padding: 3px 12px;
  display: block; }
@media screen and (min-width: 769px) {
  #page-top a span {
    font-size: 14px; } }
@media screen and (max-width: 768px) {
  #page-top a span {
    font-size: 12px; } }

ul.colorvarious {
  display: flex; }
@media screen and (min-width: 769px) {
  ul.colorvarious li {
    margin: 5px; } }
@media screen and (max-width: 768px) {
  ul.colorvarious li {
    margin: 5px; } }
ul.colorvarious li a {
  display: block;
  border-radius: 100%;
  border: 1px solid #ccc; }
@media screen and (min-width: 769px) {
  ul.colorvarious li a {
    width: 20px;
    height: 20px; } }
@media screen and (max-width: 768px) {
  ul.colorvarious li a {
    width: 35px;
    height: 35px; } }

#item01-1 {
  background: #fef7e7; }

#item01-2 {
  background: #131416; }

#item02-1 {
  background: #131313; }

#item02-2 {
  background: #ac233f; }

#item02-3 {
  background: #d2ccb4; }

#item02-4 {
  background: #333f4b; }

#item03-1 {
  background: #cdb398; }

#item04-1 {
  background: #ece6da; }

#item04-2 {
  background: #242f41; }

/* ANIMATION
--------------------------------------*/
.fuwatAnime {
  -webkit-animation-fill-mode: both;
  -ms-animation-fill-mode: both;
  animation-fill-mode: both;
  -webkit-animation-duration: 1.5s;
  -ms-animation-duration: 1.5s;
  animation-duration: 1.5s;
  -webkit-animation-name: fuwatAnime;
  -ms-animation-name: fuwatAnime;
  animation-name: fuwatAnime;
  visibility: visible !important; }

@-webkit-keyframes fuwatAnime {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0); } }
@keyframes fuwatAnime {
  0% {
    opacity: 0;
    -webkit-transform: translateY(20px);
    -ms-transform: translateY(20px);
    transform: translateY(20px); }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0); } }
/* loading
--------------------------------------*/
#loader-bg {
  position: fixed;
  width: 100%;
  height: 100vh;
  top: 0px;
  left: 0px;
  background: #FFF;
  z-index: 1;
  z-index: 99999; }
#loader-bg #loading {
  display: flex;
  align-items: center;
  justify-content: center; }
@media screen and (min-width: 769px) {
  #loader-bg #loading {
    width: 100%;
    margin: auto;
    height: 100%; } }
@media screen and (max-width: 768px) {
  #loader-bg #loading {
    width: 100%;
    margin: auto;
    height: 100%; } }
@media screen and (min-width: 769px) {
  #loader-bg #loading div {
    width: 20%;
    margin: auto; } }
@media screen and (max-width: 768px) {
  #loader-bg #loading div {
    width: 40%;
    margin: auto; } }
