html,body {
  position: fixed;
  overflow: hidden;
  width: 100%;
  height: 100vh;
  /*height: 100%;*/
  margin: 0;
}
html {
  background: #fff;
}
img {
  max-width: 100%;
}
body {
  background: #86c6dc url("/assets/img/bg.jpg") no-repeat;
  background-size: cover;
  background-position: center;
  animation: fadeIn 2s ease 0s 1 normal;
  -webkit-animation: fadeIn 2s ease 0s 1 normal;
}
@keyframes fadeIn {
  0% {opacity: 0}
  100% {opacity: 1}
}
@-webkit-keyframes fadeIn {
  0% {opacity: 0}
  100% {opacity: 1}
}
.main-wrapper {
  text-align: center;
  width: 100%;
  height: 100vh;
  /*height: 100%;*/
  margin: 0 auto;
  overflow: hidden;
  position: relative;
}
.start-area {
  width: 100%;
  height: 100vh;
  margin: 0 auto;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 2;
}
.start-area .logo {
  width: 17%;
  text-align: left;
  margin: 3% 0 0 4%;
}
.start-area .ttl-area {
  margin: 42% auto 0;
  text-align: center;
}
.start-area .ttl-area .main-ttl {
  width: 27%;
  margin: 0 auto;
}
.start-area .ttl-area .sub-ttl span {
  /*font-family: a-otf-ryumin-pr6n, serif;*/
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  font-weight: 300;
  font-style: normal;
  font-size: 120%;
  position: relative;
}
.start-area .ttl-area .sub-ttl span::before,
.start-area .ttl-area .sub-ttl span::after {
  display: block;
  content: "";
  width: 20%;
  height:1px;
  background: #000;
  position: absolute;
  top: 50%;
}
.start-area .ttl-area .sub-ttl span::before {
  left: -29%;
}
.start-area .ttl-area .sub-ttl span::after {
  right: -29%;
}

.start-area .ttl-area .text {
  /*font-family: eb-garamond, serif;*/
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;

  font-size: 300%;
  font-size: 350%;
  letter-spacing: 3px;
  margin: 0 auto;
}
.start-area .btn {
  width: 25%;
  height: 70px;
  line-height: 70px;
  background: #000;
  border-radius: 5px;
  color: #fff;
  font-size: 150%;
  /*font-family: eb-garamond, serif;*/
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;

  cursor: pointer;
  position: absolute;
  bottom: 53vw;
  left: 0;
  right: 0;
  margin: 0 auto;
  letter-spacing: 8px;
  -webkit-box-shadow: 3px 3px 6px rgba(75,110,126,0.5);
  box-shadow: 3px 3px 6px rgba(75,110,126,0.5);
}
.drag-area {
  width: 100%;
  height: 100vh;
  margin: 0 auto;
  /*position: relative;*/
}
.drag-and-drop {
  width: 20%;
  max-width: 200px;
  opacity: 0;
  height: auto;
  cursor: move;
  position: absolute;
  top: 50%;
	left: 50%;
  transform-origin: bottom;
	transform: translate(-50%, -50%);
  z-index: -1;
}
.drag-icon {
  opacity: 0;
  z-index: -1;
  position: absolute;
  bottom: 13%;
  margin: 0 auto;
  left: 0;
  right: 0;
  z-index: 1000;
}
.drag-icon img {
  width: 8%;
}
.drag-icon p span {
  background: #fff;
  padding: 6px 11px;
  font-size: 90%;
  border-radius: 3px;
  font-family: 游ゴシック体, 'Yu Gothic', YuGothic, 'ヒラギノ角ゴシック Pro', 'Hiragino Kaku Gothic Pro', メイリオ, Meiryo, Osaka, 'ＭＳ Ｐゴシック', 'MS PGothic', sans-serif
}

.bubble-area {
  width: 100%;
  height: 100vh; /* ホーム画面追加の場合 */
  background: #86c6dc url("/assets/img/bg_bottle.jpg") no-repeat;
  background-size: cover;
  position: absolute;
  opacity: 0;
  top: 0;
  left: 0;
  z-index: 1;
}
.bubble-area span {
  opacity: 0;
  position: absolute;
  z-index: 2;
}
.bubble-area #bubble-big01 { width: 77%; top: 0; left: 0; z-index: 3; }
.bubble-area #bubble-big02 { width: 37%; top: 27%; right: 0; z-index: 3; }
.bubble-area #bubble-big03 { width: 49%; bottom: 0; left: 0; z-index: 3; }
.bubble-area #bubble-small01 { width: 25%; top: 2%; left: 24%; }
.bubble-area #bubble-small02 { width: 22%; top: 18%; left: 2%; }
.bubble-area #bubble-small03 { width: 12%; top: 36%; left: 26%; }
.bubble-area #bubble-small04 { width: 25%; top: 44%; left: 2%; }
.bubble-area #bubble-small05 { width: 30%; top: 60%; left: 10%; }
.bubble-area #bubble-small06 { width: 22%; top: 18%; right: 17%; }
.bubble-area #bubble-small07 { width: 3.5%; top: 38%; right: 6%; }
.bubble-area #bubble-small08 { width: 19%; top: 43%; right: 5%; }
.bubble-area #bubble-small09 { width: 25%; top: 64%; right: 1%; }
.bubble-area #bubble-small10 { width: 22%; top: 84%; right: 6%; }

/* modal */
.modalOverlay {
  height: 100vh;
  opacity: 0;
  visibility: hidden;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  /*background-color: rgba(0, 0, 0, .45);*/
  overflow: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 1002;
  transition: .5s;
}
.modalWrap {
  display: table;
  width: 100%;
  height: 100vh;
}
.modalWrapInner {
  text-align: center;
  box-sizing: border-box;
  display: table-cell;
  position: relative;
  vertical-align: top;
}
.modalContent {
  /*width: 85%;
  max-width: 700px;
  height: 80vh;
  background: rgba(255, 255, 255, 0.7);
  */
  width: 100%;
  height: auto;
  position: relative;
  vertical-align: middle;
  margin: 0 auto;
  padding-bottom: 0px;
  text-align: center;
  z-index: -1;
  color: #3a3a3a;
  opacity: 0;
  visibility: hidden;
}
.result-area {
  width: 100%;
  height: 100vh;
  font-size: 10vw;
  /*padding: 25vh 0 0;*/
}
.result-area .result-bg {
  width: 100%;
  position: absolute;
  top: 11%;
  left: 0;
  right: 0;
  transform: matrix(0, 0, 0, 0, 0, 0);
}
.result-area .result-label {
  position: absolute;
  width: 37%;
  top: 15%;
  left: 13%;
}
.result-area .result-product {
  position: absolute;
  width: 56%;
  top: 24%;
  left: 32%;
}
.result-area.js-sClass .result-product {
  width: 52%;
  top: 27%;
  left: 26%;
}
.modalContent .result-txt {
  position: absolute;
  width: auto;
  top: 79%;
  left: 0;
  right: 0;
  margin: 0 auto;
  opacity: 0;
  visibility: hidden;
  font-family: YuMincho,'Yu Mincho', serif;
  font-size: 100%;
}
.modalContent .result-txt span {
  font-weight: 600;
  font-size: 150%;
  display: block;
  margin: 1% auto ;
}
.staggerTo {
  opacity: 0;
  visibility: hidden;
}
.btn {
  width: 100px;
  height: 30px;
  line-height: 30px;
  margin: 0 auto;
  background: #ddd;
  cursor: pointer;
  position: absolute;
  bottom: 8vw;
  left: 0;
  right: 0;
}
.closeBtn {
  width: 50px;
  height: 50px;
  line-height: 46px;
  margin: 0 auto;
  background: #000;
  border-radius: 50%;
  cursor: pointer;
  position: absolute;
  bottom: 6%;
  right: 4%;
  z-index: 1046;
  color: #fff;
  font-size: 5vw;
  font-family: serif;
  opacity: 0;
  visibility: hidden;
}

.errorModalOverlay {
  width: 100%;
  height: 100vh;
  opacity: 0;
  visibility: hidden;
  display: table;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: rgba(0, 0, 0, .45);
  overflow: hidden;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  z-index: 1002;
  transition: .5s;
}
.errorModalWrapInner {
  text-align: center;
  box-sizing: border-box;
  display: table-cell;
  position: relative;
  vertical-align: middle;
}
.errorModalContent {
  /*width: 85%;
  max-width: 700px;
  height: 80vh;
  background: rgba(255, 255, 255, 0.7);
  */
  width: 40%;
  height: auto;
  position: relative;
  vertical-align: middle;
  margin: 0 auto;
  padding: 20px;
  text-align: center;
  z-index: -1;
  background: #fff;
  border-radius: 3px;
  color: #3a3a3a;
  opacity: 0;
  visibility: hidden;
}
.errorModalContent .errorTxt {
  font-size: 90%;
  border-bottom: 1px solid #ccc;
  padding-bottom: 1em;
}
.errorModalContent .errorBtnClose {
  width: 35%;
  margin: 20px auto 0;
  background: #000;
  border-radius: 5px;
  height: 40px;
  line-height: 40px;
  font-family: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  color: #fff;
  letter-spacing: 5px;
  cursor: pointer;
}
.js-itemHidden {
  display: none;
}
.js-drag {
  z-index: 1001 !important;
}
.js-modal-acrtive {
  overflow: hidden;
}
.js-hidden {
  transition: opacity 0.5s, visibility 0.5s;
  opacity: 0;
  visibility: hidden;
}
.js-show {
  transition: opacity 0.5s, visibility 0.5s;
  opacity: 1;
  visibility: visible;
}
.bubble-elm {
  position: absolute;
}
.bubble {
    display: block;
    width: 70px;
    height: 70px;
    border-radius: 100%;
    box-shadow: 0px 0px 15px 0px rgba(255, 255, 255, 0.6) inset;
    -webkit-box-shadow: 0px 0px 15px 0px rgba(255, 255, 255, 0.6) inset;
    position: relative;
}
.bubble:after {
    content: "";
    display: block;
    width: 20%;
    height: 20%;
    border-radius: 100%;
    background: rgba(255, 255, 255, 0.8);
    position: absolute;
    right: 15%;
    top: 15%;
    filter: blur(2px);
    -webkit-filter: blur(2px);
    transform: rotateZ(45deg) scaleY(0.8);
    -webkit-transform: rotateZ(45deg) scaleY(0.8);
}
