@import url("https://fonts.googleapis.com/css2?family=DM+Serif+Display:ital@1&family=Noto+Sans+TC:wght@100;200;300;400;500;600;700;800;900&display=swap");
body,
div,
dl,
dt,
dd,
ul,
ol,
li,
h1,
h2,
h3,
h4,
h5,
h6,
p,
table,
th,
td,
form,
fieldset,
legend,
textarea,
input,
select,
textarea,
button,
article,
aside,
dialog,
footer,
header,
section,
footer,
nav,
figure,
main {
  margin: 0;
  padding: 0;
}
* {
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}
* {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
article,
aside,
dialog,
footer,
header,
section,
footer,
nav,
figure,
main {
  display: block;
}
html,
body {
  height: 100%;
  -webkit-text-size-adjust: none;
  -ms-text-size-adjust: none;
}
img,
form,
fieldset,
li {
  border: 0;
  vertical-align: top;
}
ul,
ol {
  list-style: none;
}
button {
  overflow: visible;
  cursor: pointer;
  border: none;
  border-radius: 0;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
button:disabled {
  cursor: default;
}
button::-moz-focus-inner {
  padding: 0;
  border: 0;
}
input,
select,
textarea {
  width: 0;
  height: 0;
  border: none;
  border-radius: 0;
  background: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  appearance: none;
}
.pcimg {
  display: block;
}
.mbimg {
  display: none;
}
select {
  width: 100%;
  font-size: 1.2rem;
  font-family: Arial, "微軟正黑體", Helvetica, sans-serif;
  color: #735a32;
  height: 40px;
  line-height: 40px;
  border: 1px solid #cebea3;
  padding: 0 5px;
  margin: 5px 30px 5px 5px;
  border-radius: 5px;
  background-color: #cebea3;
  text-align-last: center;
  text-align: center;
  transition: all 0.5s;
  -moz-transition: all 0.5s;
  -webkit-transition: all 0.5s;
  -o-transition: all 0.5s;
}
select {
  outline: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  -ms-appearance: none;
  -o-appearance: none;
  appearance: none;
  background-image: url(../img/dwdw.png);
  background-size: 10% 30%;
  background-attachment: scroll;
  background-repeat: no-repeat;
  background-position: 100% 50%;
}
address,
caption,
em {
  font-style: normal;
}
a,
a:focus,
a:active,
a:hover {
  text-decoration: none;
}
table {
  border-collapse: collapse;
  border-spacing: 0;
}
#particles-js {
  width: 100%;
  height: 100%;
  position: absolute;
  display: block;
  /* z-index: 2; */
}
.bt:hover {
  transform: scale(0.98);
  transition: all 0.3s ease 0s;
  -moz-transition: all 0.3s ease 0s;
  -webkit-transition: all 0.3s ease 0s;
  filter: brightness(1.3);
  cursor: pointer;
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 300;
  src: url("../font/Pretendard-Light.woff") format("woff"),
    url("../font/Pretendard-Light.woff2") format("woff2");
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 400;
  src: url("../font/Pretendard-Regular.woff") format("woff"),
    url("../font/Pretendard-Regular.woff2") format("woff2");
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 500;
  src: url("../font/Pretendard-Medium.woff") format("woff"),
    url("../font/Pretendard-Medium.woff2") format("woff2");
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 600;
  src: url("../font/Pretendard-SemiBold.woff") format("woff"),
    url("../font/Pretendard-SemiBold.woff2") format("woff2");
}
body,
input,
select,
textarea,
button {
  font-weight: 400;
  font-family: Arial, "Noto Sans TC", "微軟正黑體", sans-serif;
}
.appbx {
  width: 60%;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
  margin: 1% auto;
}
.appbx div {
  width: 50%;
  margin: 0 1%;
}
.blind,
caption,
legend {
  overflow: hidden;
  position: absolute;
  top: 0;
  left: 0;
  width: 1px;
  height: 1px;
  font-size: 1px;
  line-height: 100px;
  white-space: nowrap;
}
.skip {
  height: 0;
}
.skip a {
  display: block;
  position: absolute;
  top: -100px;
  left: 0;
  width: 100%;
  height: 25px;
  text-align: center;
}
.skip a:focus,
#skip a:active {
  position: absolute;
  top: 0;
  z-index: 100;
  padding: 10px 0;
  background: #000;
  font-size: 20px;
  font-weight: 700;
  color: #fff;
  text-decoration: none;
}
button:disabled,
input:disabled {
  cursor: default;
  pointer-events: none;
}
.wrap {
  overflow: hidden;
}
.img_box {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.img_box_ico {
  display: inline-block;
  position: relative;
}
.img_box_ico::after,
.img_box_ico::before {
  position: absolute;
}
img {
  max-width: 100%;
  max-height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
.animate {
  opacity: 0.0001;
  -webkit-transition-delay: calc(var(--i) * 0.2s);
  transition-delay: calc(var(--i) * 0.2s);
  -webkit-transition-timing-function: cubic-bezier(0.39, 0.58, 0.57, 1);
  transition-timing-function: cubic-bezier(0.39, 0.58, 0.57, 1);
  -webkit-transition-duration: 0.7s;
  transition-duration: 0.7s;
  -webkit-transition-property: opacity, -webkit-transform;
  transition-property: opacity, -webkit-transform;
  transition-property: opacity, transform;
  transition-property: opacity, transform, -webkit-transform;
  -webkit-transform: translateY(40px);
  transform: translateY(40px);
}
.animate.is-show {
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
.animate-zoom {
  opacity: 0;
}
.animate-zoom.is-show {
  -webkit-animation: zoom-fade 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.22, 0.61, 0.36, 1);
  animation: zoom-fade 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.22, 0.61, 0.36, 1);
}
.animate-left.is-show {
  -webkit-animation: slideLeft 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.39, 0.58, 0.57, 1);
  animation: slideLeft 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.39, 0.58, 0.57, 1);
}
.animate-right.is-show {
  -webkit-animation: slideRight 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.39, 0.58, 0.57, 1);
  animation: slideRight 0.5s calc(var(--i) * 0.2s) forwards
    cubic-bezier(0.39, 0.58, 0.57, 1);
}
.only-pc {
  display: block;
}
.minbtbx {
  width: 400px;
  color: #948f74;
  font-size: 20px;
  font-weight: 400;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
}
.minbtbx div {
  margin: 0 3%;
}
.minbtbx div:hover {
  color: #ceceb5;
}
.foottl {
  width: 300px;
  position: relative;
  margin: 10px auto 0 auto;
  color: #fff;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
}
.foottl div {
  padding: 5px;
}
.twif {
  width: 50%;
  padding: 10px;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: flex-end;
}
.twil {
  width: 15%;
  margin-right: 0;
}
.twir {
  color: #666666;
  font-size: 12px;
}
.impbox {
  position: relative;
  background: url("../img/bg-inf.png");
  background-size: cover;
}
.ulibx {
  width: 50%;
  margin: 0 auto;
}
.ulibx ul li {
  list-style-type: decimal;
  text-align: left;
  line-height: 2em;
  color: #f8edda;
}
.appa {
  cursor: pointer;
  position: absolute;
  left: 50%;
  margin-left: -78px;
  width: 65px;
  height: 65px;

  bottom: 0;
  border-radius: 10px;
}
.appb {
  cursor: pointer;
  position: absolute;
  left: 50%;
  margin-left: 17px;
  width: 65px;
  height: 65px;

  bottom: 0;
  border-radius: 10px;
}
.appa:hover,
.appb:hover {
  background-color: rgba(254, 255, 239, 0.1);
}
@media (max-width: 767px) {
  .only-pc {
    display: none;
  }
}
.only-mo {
  display: none;
}
@media (max-width: 767px) {
  .only-mo {
    display: block;
  }
}
img.only-pc {
  display: inline-block;
}
@media (max-width: 767px) {
  img.only-pc {
    display: none;
  }
}
@media (max-width: 767px) {
  img.only-mo {
    display: inline-block;
  }
}
@-webkit-keyframes bouncing {
  0% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
}
@keyframes bouncing {
  0% {
    -webkit-transform: translateY(0);
    -moz-transform: translateY(0);
    -ms-transform: translateY(0);
    transform: translateY(0);
  }
  100% {
    -webkit-transform: translateY(15px);
    -moz-transform: translateY(15px);
    -ms-transform: translateY(15px);
    transform: translateY(15px);
  }
}
@-webkit-keyframes slideLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-40px);
    -moz-transform: translateX(-40px);
    -ms-transform: translateX(-40px);
    transform: translateX(-40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@keyframes slideLeft {
  0% {
    opacity: 0;
    -webkit-transform: translateX(-40px);
    -moz-transform: translateX(-40px);
    -ms-transform: translateX(-40px);
    transform: translateX(-40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@-webkit-keyframes slideRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -moz-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@keyframes slideRight {
  0% {
    opacity: 0;
    -webkit-transform: translateX(40px);
    -moz-transform: translateX(40px);
    -ms-transform: translateX(40px);
    transform: translateX(40px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateX(0);
    -moz-transform: translateX(0);
    -ms-transform: translateX(0);
    transform: translateX(0);
  }
}
@-webkit-keyframes cross-slide {
  0% {
    -webkit-clip-path: polygon(0% 100%, 0% 100%, 0% 100%);
    clip-path: polygon(0% 100%, 0% 100%, 0% 100%);
  }
  100% {
    -webkit-clip-path: polygon(0% 100%, 0% -100%, 200% 100%);
    clip-path: polygon(0% 100%, 0% -100%, 200% 100%);
  }
}
@keyframes cross-slide {
  0% {
    -webkit-clip-path: polygon(0% 100%, 0% 100%, 0% 100%);
    clip-path: polygon(0% 100%, 0% 100%, 0% 100%);
  }
  100% {
    -webkit-clip-path: polygon(0% 100%, 0% -100%, 200% 100%);
    clip-path: polygon(0% 100%, 0% -100%, 200% 100%);
  }
}
@-webkit-keyframes zoom-fade {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@keyframes zoom-fade {
  0% {
    opacity: 0;
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
  }
  100% {
    opacity: 1;
    -webkit-transform: scale(1);
    transform: scale(1);
  }
}
@-webkit-keyframes zoom-fade-bg {
  0% {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-filter: grayscale(0%);
    filter: grayscale(0%);
  }
}
@keyframes zoom-fade-bg {
  0% {
    -webkit-transform: scale(1.05);
    transform: scale(1.05);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-filter: grayscale(0%);
    filter: grayscale(0%);
  }
}
@-webkit-keyframes rolling-left {
  0% {
    opacity: 0.3;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}
@keyframes rolling-left {
  0% {
    opacity: 0.3;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
}
@-webkit-keyframes rolling-right {
  0% {
    opacity: 0.3;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
@keyframes rolling-right {
  0% {
    opacity: 0.3;
    -webkit-transform: rotate(180deg);
    transform: rotate(180deg);
  }
  100% {
    opacity: 1;
    -webkit-transform: rotate(0deg);
    transform: rotate(0deg);
  }
}
@-webkit-keyframes fadeInBlur {
  0% {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-filter: blur(100px);
    filter: blur(100px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
@keyframes fadeInBlur {
  0% {
    -webkit-transform: scale(1.1);
    transform: scale(1.1);
    -webkit-filter: blur(100px);
    filter: blur(100px);
  }
  100% {
    -webkit-transform: scale(1);
    transform: scale(1);
    -webkit-filter: blur(0);
    filter: blur(0);
  }
}
.indicator {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  position: fixed;
  top: 50%;
  /* left: 0px; */
  z-index: 4;
  margin-top: 78px;
  opacity: 0;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  -webkit-animation: fadeIndicator 0.5s forwards;
  animation: fadeIndicator 0.5s forwards;
  -webkit-animation-delay: 1.2s;
  animation-delay: 1.2s;
}
@media (max-width: 1550px) {
  .indicator {
    left: 54px;
    margin-top: 140px;
  }
}
@media screen and (max-width: 767px) {
  .indicator {
    left: 30px;
  }
}
@media (max-width: 767px) {
  .indicator {
    display: none;
  }
}
.indicator.is-show {
  opacity: 1;
  pointer-events: all;
}
.indicator-item:not(:first-child) {
  margin-top: 32px;
}
@media (max-width: 1550px) {
  .indicator-item:not(:first-child) {
    margin-top: 10px;
  }
}
@media (max-width: 1550px) {
  .indicator-item.is-active .indicator-link {
    background: url(../img/icon-indicator-active.png) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
}
.indicator-item.is-active .default {
  display: none;
}
.indicator-item.is-active .on {
  display: block;
}
.indicator-item:nth-child(3).is-active .indicator-children {
  display: block;
}
@media (max-width: 1550px) {
  .indicator-item:nth-child(3).is-active .indicator-children {
    display: none;
  }
}
.indicator-link {
  display: block;
  width: 250px;
}
@media (max-width: 1550px) {
  .indicator-link {
    width: 15px;
    height: 15px;
    background: url(../img/icon-indicator.png) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
  .indicator-link img {
    display: none !important;
  }
}
.indicator-children {
  display: none;
  margin-top: 11px;
}
.indicator-children .indicator-children-item:not(:first-child) {
  margin-top: 2px;
}
.indicator-children .indicator-children-item.is-active .children-default {
  display: none;
}
.indicator-children .indicator-children-item.is-active .children-on {
  display: block;
}
@media (max-width: 1550px) {
  .indicator-children .indicator-children-item.is-active .indicator-link {
    background: url(../img/icon-pagination-active.png) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
}
@media (max-width: 1550px) {
  .indicator-children .indicator-children-item .indicator-link {
    width: 12px;
    height: 12px;
    margin: 0 auto;
    background: url(../img/icon-pagination.png) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
}
.indicator-children .indicator-link {
  text-align: center;
}
.indicator-children .children-on {
  display: none;
  margin: 0 auto;
}
.indicator .on {
  display: none;
}
.header {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: fixed;
  top: 0;
  left: 50%;
  z-index: 99;
  width: 100%;
  max-width: 1920px;
  height: 80px;
  background-color: #000;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media (max-width: 767px) {
  .header {
    height: 64px;
  }
}
.header-gnb {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  width: 100%;
  padding: 0 60px;
}
@media (max-width: 767px) {
  .header-gnb {
    padding: 0 20px;
  }
}
.header-gnb .logo {
  -webkit-transition: 0.3s 0.4s;
  transition: 0.3s 0.4s;
}
.header-gnb .logo-link {
  display: block;
  width: 180px;
}
@media (max-width: 767px) {
  .header-gnb .logo-link {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    width: 90px;
  }
}
.header-gnb .logo-link img {
  display: block;
  width: 100%;
  -o-object-fit: inherit;
  object-fit: inherit;
}
.header-gnb .logo-mo-link {
  display: block;
}
@media screen and (max-width: 767px) {
  .header-gnb .box-right {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.header-gnb .box-right .item-share {
  width: 72px;
  height: 72px;
  margin-right: 32px;
  -webkit-transition: 0.3s 0.4s;
  transition: 0.3s 0.4s;
}
@media (max-width: 767px) {
  .header-gnb .box-right .item-share {
    width: 36px;
    height: 36px;
    margin-right: 10px;
    opacity: 0.6;
  }
}
.header-gnb .box-right .item-share img {
  width: 100%;
}
.header-gnb .box-right .item-link {
  display: block;
}
@media screen and (max-width: 767px) {
  .header-gnb.is-open .gnb {
    overflow: visible;
    overflow-y: auto;
    top: 0;
  }
  .header-gnb.is-open .logo,
  .header-gnb.is-open .item-share {
    overflow: visible;
    opacity: 0;
    -webkit-transition: none;
    transition: none;
    pointer-events: none;
  }
}
.header .btn-mobile {
  display: none;
  position: relative;
  top: 0;
  right: 0;
  z-index: 3;
  width: 52px;
  height: 52px;
  background: url(../img/svg/icon-menu.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transition: 0.2s linear;
  transition: 0.2s linear;
}
@media screen and (max-width: 767px) {
  .header .btn-mobile {
    display: block;
  }
}
@media (max-width: 767px) {
  .header .btn-mobile {
    width: 32px;
    height: 40px;
    background-position: center;
    -webkit-background-size: 28px 28px;
    background-size: 28px 28px;
  }
}
.header .btn-mobile.is-active {
  background: url(../img/svg/icon-menu-close.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media (max-width: 767px) {
  .header .btn-mobile.is-active {
    background-position: center;
    -webkit-background-size: 28px 28px;
    background-size: 28px 28px;
  }
}
.header .sns-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  opacity: 0.6;
}
@media screen and (max-width: 767px) {
  .header .sns-list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
  }
}
.header .sns-item {
  margin-left: 12px;
}
@media screen and (max-width: 767px) {
  .header .sns-item {
    width: 16.895%;
    margin: 0 2.705%;
  }
}
.header .sns-item:first-child {
  margin-left: 0;
}
@media screen and (max-width: 767px) {
  .header .sns-item:last-child {
    margin-right: 0;
  }
}
.header .sns-link {
  display: block;
  width: 48px;
}
@media screen and (max-width: 767px) {
  .header .sns-link {
    width: 100%;
  }
}
.header .sns-link img {
  display: block;
  width: 100%;
  height: 100%;
}
@media screen and (max-width: 767px) {
  .header .gnb-others {
    width: 100%;
    margin: auto auto 0;
    padding-top: 36px;
    border-top: 1px solid rgba(176, 156, 124, 0.4);
    max-width: 1184px;
    max-width: 82.22222vw;
  }
}
@media screen and (max-width: 767px) {
  .gnb {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    align-items: center;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    overflow: hidden;
    position: absolute;
    top: -100vh;
    right: 0;
    left: 0;
    z-index: -1;
    height: calc(var(--vh, 1vh) * 100);
    max-height: 100vh;
    padding: 106px 27px 65px;
    background-color: #000;
    -webkit-transition: top 0.6s;
    transition: top 0.6s;
  }
}
@media screen and (max-width: 767px) {
  .gnb-item {
    width: 403px;
  }
  .gnb-ben {
    width: 52.36111vw;
    margin-top: 7.77778vw;
  }
}
@media (max-width: 767px) {
  .gnb-item {
    width: 754px;
    width: 52.36111vw;
  }
}
.gnb-item:not(:first-child) {
  margin-top: 44px;
}
@media (max-width: 767px) {
  .gnb-item:not(:first-child) {
    margin-top: 112px;
    margin-top: 7.77778vw;
  }
}
.gnb-item.is-active .default {
  display: none;
}
.gnb-item.is-active .on {
  display: block;
}
.gnb-item:nth-child(3).is-active .gnb-item-children {
  display: block;
}
.gnb-item-children {
  display: none;
}
.gnb-item .on {
  display: none;
}
.gnb-link {
  display: block;
}
.gnb-link img {
  width: 100%;
}
@media screen and (max-width: 767px) {
  .gnb-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-flex: 1;
    -ms-flex-positive: 1;
    flex-grow: 1;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-top: -36px;
    padding: 45px 0 33px;
  }
}
@media (max-width: 767px) {
  .gnb .logo-mo-link {
    margin: 0 auto;
    width: 1028px;
    width: 71.38889vw;
  }
}
@media (max-width: 767px) {
  .gnb .children-item {
    width: 754px;
    width: 52.36111vw;
    margin-top: 16px;
    margin-top: 1.11111vw;
  }
}
@media (max-width: 767px) {
  .gnb .children-item:first-child {
    margin-top: 40px;
    margin-top: 2.77778vw;
  }
}
.gnb .children-item.is-active .children-default {
  display: none;
}
.gnb .children-item.is-active .children-on {
  display: block;
}
.gnb .children-item .children-on {
  display: none;
}
.footer {
  max-width: 1920px;
  margin: 0 auto;
  background-color: #000;
}
.footer-content {
  width: 70%;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
  align-content: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0px 0 34px;
  margin: 0 auto;
}
/* @media (max-width: 767px) {
  .footer-content {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: start;
    -ms-flex-align: start;
    align-items: flex-start;
    padding: 13px 20px 30px;
  }
} */
.footer .logo {
  width: 119px;
  margin-top: 9px;
}
@media (max-width: 767px) {
  .footer .logo {
    width: 80px;
  }
}
.footer .info {
  margin-left: 32px;
  width: 30%;
}
@media (max-width: 767px) {
  .footer .info {
    margin: 20px 0 0;
  }
}
.footer .info .text {
  display: block;
  margin-top: 6px;
  font-size: 14px;
  font-weight: 300;
  color: #666;
  line-height: 19px;
}
@media (max-width: 767px) {
  .footer .info .text {
    font-size: 12px;
  }
}
.footer .info .text.btn-policy {
  display: inline-block;
  margin: 0 0 0 2px;
  line-height: 32px;
}
@media (max-width: 767px) {
  .footer .info .text.btn-policy {
    margin-left: 0;
  }
}
.section {
  position: relative;
  width: 100%;
  max-width: 1920px;
  min-height: 100vh;
  margin: 0 auto;
  padding: 104px 0;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .section {
    height: auto;
    min-height: 100%;
    padding: 135px 0 115px;
  }
}
@media only screen and (min-width: 1201px) and (max-width: 1400px) {
  .section {
    zoom: 0.9;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .section {
    zoom: 0.8;
  }
}
@media only screen and (min-width: 880px) and (max-width: 1024px) {
  .section {
    zoom: 0.7;
  }
}
@media only screen and (min-width: 768px) and (max-width: 879px) {
  .section {
    zoom: 0.65;
  }
}
.section .head-sub-title,
.section .head-title,
.section .head-desc {
  display: block;
}
.section-name {
  display: block;
  margin-bottom: 51px;
}
@media (min-width: 768px) and (max-width: 768px) {
  .section-name {
    margin-bottom: 47px;
  }
}
@media (max-width: 767px) {
  .section-name {
    width: 85%;
    margin: 0 auto 30px;
  }
}
@media only screen and (min-width: 1201px) and (max-width: 1400px) {
  .popup {
    zoom: 0.9;
  }
}
@media only screen and (min-width: 1025px) and (max-width: 1200px) {
  .popup {
    zoom: 0.8;
  }
}
@media only screen and (min-width: 880px) and (max-width: 1024px) {
  .popup {
    zoom: 0.7;
  }
}
@media only screen and (min-width: 768px) and (max-width: 879px) {
  .popup {
    zoom: 0.65;
  }
}
.wrap {
  position: relative;
  background-color: #000;
}
.center {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  position: relative;
  padding: 0 20px;
}
@media (max-width: 767px) {
  .center {
    padding: 0 6.115%;
  }
}
.radio-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .radio-list {
    -ms-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-left: -2px;
  }
}
.radio-item:not(:last-child) {
  margin-right: 23px;
}
@media screen and (max-width: 767px) {
  .radio-item:not(:last-child) {
    margin-right: 15px;
  }
}
.radio-area input {
  display: none;
}
.radio-area input[type="radio"]:checked + .label .label-btn:after {
  opacity: 1;
}
.radio-area .label {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  cursor: pointer;
}
.radio-area .label-text {
  margin-left: 6px;
  font-size: 20px;
  font-weight: 500;
  color: #dabb8c;
}
@media (max-width: 767px) {
  .radio-area .label-text {
    margin-left: 7px;
    font-size: 15px;
  }
}
.radio-area .label-btn {
  display: inline-block;
  position: relative;
  width: 24px;
  height: 24px;
  background: url(../img/bg-radio.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media (max-width: 767px) {
  .radio-area .label-btn {
    width: 24px;
    height: 24px;
  }
}
.radio-area .label-btn:after {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background-color: #dabb8c;
  opacity: 0;
  -webkit-transition: opacity 0.1s;
  transition: opacity 0.1s;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  content: "";
}
@media screen and (max-width: 767px) {
  .radio-area .label-btn:after {
    border: 1px solid #000;
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
  }
}
@media (max-width: 767px) {
  .radio-area .label-btn:after {
    width: 9px;
    height: 9px;
  }
}
.checkbox-area {
  margin-top: 14px;
}
@media screen and (max-width: 767px) {
  .checkbox-area {
    margin-top: 11px;
    text-align: center;
  }
}
.checkbox-area .btn-more {
  -webkit-box-flex: 0;
  -ms-flex: none;
  flex: none;
  display: inline-block;
  margin-left: 10px;
  padding: 4px 12px;
  border: 1px solid #947b58;
  background: rgba(0, 0, 0, 0.1);
  font-size: 10px;
  font-weight: 400;
  color: #b09c7c;
  line-height: 10px;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .checkbox-area .btn-more {
    margin-left: 5px;
    padding: 4px 5px 4px 7px;
    font-size: 12px;
  }
}
.checkbox-area .btn-more:hover {
  color: #dabb8c;
}
.checkbox-list {
  text-align: left;
}
.checkbox-item {
  margin-top: 10px;
}
.checkbox-item:first-child {
  margin-top: 0;
}
@media (max-width: 767px) {
  .checkbox-item:last-child {
    margin-top: 11px;
  }
}
.checkbox-item input {
  display: none;
  width: initial;
  height: initial;
  margin-bottom: 0;
  padding: 0;
  cursor: pointer;
}
.checkbox-item input[type="checkbox"]:checked + .label:before {
  background: url(../img/svg/icon-checked.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .checkbox-item input[type="checkbox"]:checked + .label:before {
    background: url(../img/svg/icon-checked-mo.svg) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
}
.checkbox-item .label {
  position: relative;
  padding-left: 32px;
  font-size: 16px;
  font-weight: 400;
  color: #b09c7c;
  line-height: 20px;
  cursor: pointer;
  width: 330px;
}
@media (max-width: 767px) {
  .checkbox-item .label {
    padding-left: 27px;
    font-size: 12px;
    line-height: 19px;
    width: 240px;
    letter-spacing: -0.6px;
  }
}
.checkbox-item .label:before {
  position: absolute;
  top: 0;
  left: 0;
  width: 22px;
  height: 20px;
  background: url(../img/svg/icon-check.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  content: "";
}
@media screen and (max-width: 767px) {
  .checkbox-item .label:before {
    top: 50%;
    background: url(../img/svg/icon-check-mo.svg) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}
@media (max-width: 767px) {
  .checkbox-item .label:before {
    width: 23px;
    height: 19px;
  }
}
.checkbox-item .checkbox {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.input-area input {
  width: 100%;
  height: 68px;
  padding: 10px 33px;
  background-color: #cebea3;
  font-size: 18px;
  font-weight: 400;
  color: #816445;
  line-height: 20px;
  outline: 0;
}
@media (max-width: 767px) {
  .input-area input {
    height: 50px;
    padding: 20px 18px;
    font-size: 16px;
  }
}
.input-area input::-webkit-input-placeholder {
  color: #816445;
}
.input-area input::-moz-placeholder {
  color: #816445;
}
.input-area input:-ms-input-placeholder {
  color: #816445;
}
.input-area input::-ms-input-placeholder {
  color: #816445;
}
.input-area input::placeholder {
  color: #816445;
}
.input-area input:disabled {
  background: #847866;
  color: rgba(255, 243, 231, 0.2);
  pointer-events: none;
}
.input-area input:disabled::-webkit-input-placeholder {
  color: rgba(255, 243, 231, 0.2);
}
.input-area input:disabled::-moz-placeholder {
  color: rgba(255, 243, 231, 0.2);
}
.input-area input:disabled:-ms-input-placeholder {
  color: rgba(255, 243, 231, 0.2);
}
.input-area input:disabled::-ms-input-placeholder {
  color: rgba(255, 243, 231, 0.2);
}
.input-area input:disabled::placeholder {
  color: rgba(255, 243, 231, 0.2);
}
.input-area input:disabled + .count {
  display: none;
}
.input-area input::-webkit-outer-spin-button,
.input-area input::-webkit-inner-spin-button {
  margin: 0;
  -webkit-appearance: none;
}
.input-area input[type="number"] {
  -moz-appearance: textfield;
}
.input-area .input-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  position: relative;
  margin-top: 14px;
}
@media (max-width: 767px) {
  .input-area .input-button {
    margin-top: 11px;
  }
}
.input-area .input-button:first-child {
  margin-top: 0;
}
.input-area .input-button .btn-form {
  height: 100%;
  min-height: 68px;
  padding: 10px 48px 10px 47px;
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(#65441f),
    color-stop(170.59%, #ebc884)
  );
  background: linear-gradient(0deg, #65441f 0%, #ebc884 170.59%);
  font-size: 18px;
  font-weight: 600;
  color: #fff7e9;
  line-height: 20px;
  text-align: center;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
}
@media (max-width: 767px) {
  .input-area .input-button .btn-form {
    height: 50px;
    min-height: 34px;
    padding: 5px 17px;
    font-size: 12px;
  }
}
.input-area .input-button .btn-form:hover {
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(#4d300f),
    color-stop(170.59%, #b2945a)
  );
  background: linear-gradient(0deg, #4d300f 0%, #b2945a 170.59%);
}
@media (min-width: 768px) {
  .input-area .input-button-phone input {
    padding-left: 250px;
    font-size: 37px;
    line-height: 1;
  }
  .input-area .input-button-phone input::-webkit-input-placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .input-area .input-button-phone input::-moz-placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    transform: translate(-50%, -50%);
  }
  .input-area .input-button-phone input:-ms-input-placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    transform: translate(-50%, -50%);
  }
  .input-area .input-button-phone input::-ms-input-placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    transform: translate(-50%, -50%);
  }
  .input-area .input-button-phone input::placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
  .input-area .input-button-phone input::-webkit-input-placeholder {
    font-size: 18px;
    position: absolute;
    left: 50%;
    top: 50%;
    margin-left: 63px;
    -webkit-transform: translate(-50%, -50%);
    transform: translate(-50%, -50%);
  }
}
@media screen and (max-width: 767px) {
  .input-area .input-button-phone input {
    padding-left: 216px;
    padding-left: 47vw;
  }
}
.input-area .input-button-code input {
  padding-right: 90px;
}
@media screen and (max-width: 767px) {
  .input-area .input-button-code input {
    padding-right: 220px;
    padding-right: 15.27778vw;
    padding-left: 58px;
    padding-left: 4.02778vw;
  }
}
.input-area .input-button.is-disable .btn-form {
  background: #393023;
  color: #716555;
  pointer-events: none;
}
.input-area .input-item {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  position: relative;
}
.input-area .input-item .count {
  position: absolute;
  top: 50%;
  right: 33px;
  font-size: 18px;
  color: #fff;
  line-height: 20px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media (min-width: 768px) and (max-width: 768px) {
  .input-area .input-item .count {
    right: 39px;
    font-size: 24px;
  }
}
@media (max-width: 767px) {
  .input-area .input-item .count {
    right: 20px;
    font-size: 12px;
  }
}
.input-area .label-code {
  position: absolute;
  top: 50%;
  left: 33px;
  padding-right: 33px;
  font-size: 37px;
  font-weight: 400;
  color: #816445;
  line-height: 37px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .input-area .label-code {
    font-size: 14px;
    line-height: 20px;
    left: 58px;
    left: 4.02778vw;
    padding-right: 30px;
    padding-right: 2.08333vw;
  }
}
.input-area .label-code:after {
  position: absolute;
  top: 50%;
  right: 0;
  width: 1px;
  height: 30px;
  background-color: #b09c7c;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "";
}
@media screen and (max-width: 767px) {
  .input-area .label-code:after {
    height: 60px;
    height: 4.16667vw;
  }
}
@media (min-width: 768px) {
  .back-top {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .back-top {
    overflow: hidden;
    position: absolute;
    right: 20px;
    bottom: 13px;
    z-index: 98;
    width: 34px;
    height: 34px;
    background: url(../img/btn-top.png) no-repeat;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    opacity: 0;
    -webkit-transition: opacity 0.3s linear;
    transition: opacity 0.3s linear;
  }
  .back-top.is-show {
    overflow: visible;
    opacity: 1;
  }
  .back-top.is-fixed {
    position: fixed;
    bottom: 26px;
  }
}
.swiper-btn-next,
.swiper-btn-prev {
  width: 40px;
  height: 80px;
  margin-top: -6px;
}
@media (max-width: 767px) {
  .swiper-btn-next,
  .swiper-btn-prev {
    width: 31px;
    height: 62px;
    margin-top: -43px;
  }
}
.swiper-btn-next:after,
.swiper-btn-prev:after {
  content: "";
}
.swiper-btn-next {
  background: url(../img/svg/icon-bullet-right.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
.swiper-btn-prev {
  background: url(../img/svg/icon-bullet-left.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@-webkit-keyframes fadeIndicator {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@keyframes fadeIndicator {
  0% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
@-webkit-keyframes arrowEffect {
  0% {
    margin-top: 0;
  }
  50% {
    margin-top: 5px;
  }
  100% {
    margin-top: 0;
  }
}
@keyframes arrowEffect {
  0% {
    margin-top: 0;
  }
  50% {
    margin-top: 5px;
  }
  100% {
    margin-top: 0;
  }
}
@-webkit-keyframes progress {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
@keyframes progress {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}
@-webkit-keyframes fade {
  0% {
    opacity: 0;
    -webkit-transform: translateY(60px);
    transform: translateY(60px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
@keyframes fade {
  0% {
    opacity: 0;
    -webkit-transform: translateY(60px);
    transform: translateY(60px);
  }
  100% {
    opacity: 1;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
@-webkit-keyframes twinkle {
  50% {
    opacity: 0.5;
  }
}
@keyframes twinkle {
  50% {
    opacity: 0.5;
  }
}
@-webkit-keyframes blinker {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
  to {
    opacity: 1;
  }
}
@keyframes blinker {
  from {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
  to {
    opacity: 1;
  }
}
.section-key-visual {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-top: 80px;
  padding: 0;
  background-image: url(../img/bg-kv.jpg);
  background-position: center;
}
@media screen and (max-width: 767px) {
  .section-key-visual {
    margin-top: 64px;
    padding: 0 5% 8.89%;
    background-image: url(../img/bg-kv-mo.jpg);
    background-position: top;
  }
}
.section-key-visual .center {
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .section-key-visual .center {
    padding: 70.68% 0 0;
  }
}
.section-key-visual .key-visual-text {
  position: relative;
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 100%;
    margin-top: 0;
  }
}
.section-key-visual .key-visual-text .text-wrap {
  position: relative;
}
.section-key-visual .key-visual-text .effect1,
.section-key-visual .key-visual-text .effect2 {
  position: absolute;
  top: 15px;
  z-index: 2;
  height: 365px;
  -webkit-transition: 0.8s 0.5s;
  transition: 0.8s 0.5s;
  -webkit-transform: none;
  transform: none;
  -webkit-animation: twinkle 1s linear 1s infinite;
  animation: twinkle 1s linear 1s infinite;
  mix-blend-mode: screen;
  pointer-events: none;
}
.section-key-visual .key-visual-text .effect1 {
  left: -117px;
  width: 430px;
  background: url(../img/bg-kv-light01.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-animation-duration: 1s;
  animation-duration: 1s;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .effect1 {
    top: -14.2%;
    left: -23.5%;
    width: 66.26%;
  }
}
.section-key-visual .key-visual-text .effect2 {
  right: -67px;
  width: 368px;
  background: url(../img/bg-kv-light02.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-animation-duration: 1.2s;
  animation-duration: 1.2s;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .effect2 {
    top: -3%;
    right: -12%;
    width: 56.705%;
  }
}
.section-key-visual .key-visual-text .effect3 {
  position: absolute;
  bottom: 61px;
  left: 50%;
  z-index: 4;
  width: 342px;
  height: 58px;
  background: url(../img/btn-kv-effect.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transition: 0.5s 0.9s;
  transition: 0.5s 0.9s;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  mix-blend-mode: screen;
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .effect3 {
    width: 52.78%;
    height: 7.65%;
    bottom: 13.188%;
  }
  .appbx {
    width: 100%;
    margin: 56.175% auto 0;
  }
}
.section-key-visual .key-visual-text .sub-title {
  display: block;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .sub-title {
    max-width: 100%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .sub-title img.only-mo {
    width: 100%;
    margin-left: 1px;
  }
}
.section-key-visual .key-visual-text .text-title {
  margin-top: -4px;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .text-title {
    max-width: 100%;
    margin: 3.398% auto 0;
  }
}
.section-key-visual .key-visual-text .btn-kv {
  display: inline-block;
  position: relative;
  z-index: 4;
  margin-top: 21px;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-text .btn-kv {
    max-width: 90.745%;
    margin: 56.175% auto 0;
  }
}
.section-key-visual .key-visual-aside {
  position: absolute;
  top: 50%;
  right: 100px;
  z-index: 2;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-aside {
    top: 14px;
    right: 17px;
    -webkit-transform: translateY(0);
    transform: translateY(0);
  }
}
.section-key-visual .key-visual-aside .button-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-aside .button-wrap {
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    width: 170px;
    padding-bottom: 8px;
  }
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-aside .button-wrap {
    width: 85px;
  }
}
.section-key-visual .key-visual-aside .button-wrap .btn {
  display: block;
}
@media (min-width: 768px) {
  .section-key-visual .key-visual-aside .button-wrap .btn {
    width: 140px;
  }
}
@media (min-width: 768px) {
  .section-key-visual .key-visual-aside .btn-cafe-out {
    margin-top: 36px;
  }
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-aside .swiper-slide {
    width: 100%;
  }
}
.section-key-visual .key-visual-aside .swiper-pagination {
  bottom: 0;
  font-size: 0;
  line-height: normal;
}
.section-key-visual .key-visual-aside .swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  background-color: rgba(255, 223, 174, 0.4);
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .section-key-visual .key-visual-aside .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 4px 0 0;
  }
}
.section-key-visual .key-visual-aside .swiper-pagination-bullet-active {
  background-color: #dabb8c;
}
.section-key-visual .key-visual-aside .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
.section-pre-registration {
  padding: 96px 0 88px;
  /* background-image: url(../img/bg-pre-order.jpg);
  background-size: 100%;
  background-position: center center; */
}
@media screen and (max-width: 767px) {
  .section-pre-registration {
    padding: 67px 0 36px;
    background-image: url(../img/bg-pre-order-mo.jpg);
    background-position: top;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration .center {
    padding: 0 3.515%;
  }
}
.section-pre-registration .section-head {
  width: 100%;
}
.section-pre-registration .head-title {
  margin-top: 28px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .head-title {
    max-width: 94%;
    margin: 5.6% auto 0;
  }
}
.section-pre-registration .head-desc {
  display: block;
  margin-top: 20px;
}
.section-pre-registration .text-time {
  display: block;
  margin-top: 17px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .text-time {
    max-width: 90%;
    margin: 3.3% auto 0;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration .text-time img.only-mo {
    display: block;
  }
}
.section-pre-registration .text-note {
  display: block;
  margin: 33px 0 0 4px;
  font-size: 12px;
  font-weight: 400;
  color: #b09c7c;
  line-height: 20px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .text-note {
    margin: 34px 0 0 1px;
    font-size: 10px;
    line-height: 14px;
  }
}
.section-pre-registration .section-content {
  margin-top: 89px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .section-content {
    margin: 15.225% 10px 0;
  }
}
.section-pre-registration .col-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  max-width: 1164px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-wrap {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: 0 18px;
  }
}
@media (max-width: 767px) {
  .section-pre-registration .col-wrap {
    margin: 0;
  }
}
.section-pre-registration .col {
  position: relative;
}
.section-pre-registration .col-left {
  text-align: center;
}
@media (min-width: 768px) {
  .section-pre-registration .col-left {
    width: 457px;
  }
}
.section-pre-registration .col-left .text-head {
  display: block;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-left .text-head {
    max-width: 80%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-left .text-head img.only-mo {
    display: block;
  }
}
.section-pre-registration .col-left .image-ticket {
  margin: 25px 0 0 4px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-left .image-ticket {
    max-width: 84%;
    margin: 0 auto;
  }
}
.section-pre-registration .col-left .image-ticket.is-show + .effect {
  -webkit-animation: blinker 0.6s cubic-bezier(0.4, 0, 1, 1) 1s infinite;
  animation: blinker 0.6s cubic-bezier(0.4, 0, 1, 1) 1s infinite;
}
@media (min-width: 768px) {
  .section-pre-registration .col-right {
    -webkit-box-flex: 1;
    -ms-flex: 1;
    flex: 1;
    margin: -5px 0 0 61px;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-effect {
    margin-bottom: 4.45%;
  }
}
.section-pre-registration .col-effect .effect {
  position: absolute;
  top: 3px;
  left: 22px;
  z-index: 2;
  width: 417px;
  height: 424px;
  background: url(../img/bg-pre-oder-ticket-effect.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transition: 0.8s 6s;
  transition: 0.8s 6s;
  -webkit-transform: none;
  transform: none;
  mix-blend-mode: screen;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .col-effect .effect {
    top: 8%;
    left: 50%;
    width: 75%;
    height: 85%;
    -webkit-transform: translate(-50%, 0) rotate(7deg);
    transform: translate(-50%, 0) rotate(7deg);
  }
}
.section-pre-registration .store-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 0 -4px 0 0;
}
@media (max-width: 767px) {
  .store-wrap img {
    display: block;
    width: 100%;
  }
  .section-pre-registration .store-wrap {
    margin: 18px -8px -6px -12px;
    flex-wrap: nowrap;
    width: 50%;
    margin: 0 auto;
  }
}
.section-pre-registration .store-wrap .store {
  width: 153px;
  margin: 5px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .store-wrap .store {
    width: calc(50% - 32px);
    margin: 15px 8px;
  }
  .section-pre-registration .store-wrap .store img {
    width: 100%;
  }
}
@media (max-width: 767px) {
  .section-pre-registration .store-wrap .store {
    width: calc(50% - 16px);
    margin: 8px 4px 6px;
  }
}
@media (min-width: 767px) {
  .section-pre-registration .store-wrap .store:nth-child(4) {
    margin-right: 2px;
  }
}
.section-pre-registration .input-area {
  margin-top: 11px;
}
.section-pre-registration .btn-reservation {
  display: block;
  width: 100%;
  margin-top: 20px;
}
.section-pre-registration .btn-reservation.is-disable {
  pointer-events: none;
}
@media (max-width: 767px) {
  .section-pre-registration .btn-reservation {
    margin-top: 21px;
  }
}
.section-pre-registration .btn-reservation img {
  width: 100%;
}
.section-pre-registration .btn-reservation img.btn-disable {
  display: none;
}
@media (min-width: 767px) {
  .section-pre-registration
    .btn-reservation.is-disable
    img.only-pc.btn-disable {
    display: block;
  }
  .section-pre-registration .btn-reservation.is-disable img.only-pc.btn-active {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration
    .btn-reservation.is-disable
    img.only-mo.btn-disable {
    display: block;
  }
  .section-pre-registration .btn-reservation.is-disable img.only-mo.btn-active {
    display: none;
  }
}
.section-pre-registration .btn-cancel {
  position: absolute;
  top: 4px;
  right: 0;
  z-index: 2;
  font-size: 14px;
  font-weight: 400;
  color: #dab67f;
  line-height: 20px;
  text-decoration: underline;
  -webkit-transition: color 0.2s;
  transition: color 0.2s;
  text-underline-position: under;
}
@media (max-width: 767px) {
  .section-pre-registration .btn-cancel {
    top: 2px;
    right: -1px;
    font-size: 12px;
  }
}
.section-pre-registration .btn-cancel:hover {
  color: #b09c7c;
}
.section-pre-registration .btn-cancel-box {
  position: relative;
  z-index: 2;
}
.section-pre-registration .radio-area {
  padding-right: 95px;
}
@media (max-width: 767px) {
  .section-pre-registration .radio-area {
    padding-right: 70px;
  }
}
.section-pre-registration .more-info {
  margin-top: 46px;
  border-top: 1px solid rgba(197, 168, 114, 0.4);
}
@media screen and (max-width: 767px) {
  .section-pre-registration .more-info {
    margin-top: 8.545%;
  }
}
.section-pre-registration .more-info .text-reward {
  position: relative;
  display: block;
  margin: 40px 0 0 -3px;
}
@media screen and (max-width: 767px) {
  .section-pre-registration .more-info .text-reward {
    max-width: 95%;
    margin: 12.6% auto 0;
  }
}
@media screen and (max-width: 767px) {
  .section-pre-registration .more-info .text-reward img.only-mo {
    display: block;
  }
}
@media (min-width: 768px) {
  .section-pre-registration .more-info .col-right {
    margin: 0 0 0 60px;
  }
}
.section-event {
  padding: 0;
}
.section-event .part-event {
  padding: 104px 0;
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
}
.section-event .part-event .section-head {
  width: 100%;
}
.section-event .part-event .head-sub-title {
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .section-event .part-event .head-title {
    margin: 5% auto 0;
    width: 954px;
    width: 66.25vw;
  }
}
.section-event .part-event .event02 .head-title {
  width: 1164px;
  width: 80.83333vw;
}
.section-event .part-event .event03 .head-title {
  width: 930px;
  width: 64.58333vw;
}
.section-event .part-event .section-name {
  margin-bottom: 36px;
}
@media screen and (max-width: 767px) {
  .section-event .part-event .section-name {
    width: 70.5%;
    margin-bottom: 7.334%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .part-event .section-name img.only-mo {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .section-event .part-event .text-time {
    margin: 4.715% auto 5.225%;
  }
}
.section-event .event01 {
  padding-bottom: 198px;
  /* background-image: url(../img/bg-event-01.jpg); */
  background-image: url(../img/bg-pre-order.jpg);
}
@media screen and (max-width: 767px) {
  .section-event .event01 {
    padding: 68px 0 15.556%;
    background-image: url(../img/bg-pre-order-mo.jpg);
  }
}
.section-event .event02 .btn-pre-registration {
  display: inline-block;
  margin-top: 53px;
}
@media screen and (max-width: 767px) {
  .section-event .event01 .btn-pre-registration {
    margin-top: 32px;
  }
}
.section-event .event01 .text-note {
  margin: 15px 0 0 2px;
}
@media screen and (max-width: 767px) {
  .section-event .event01 .text-note {
    margin: 25px 0 0 1px;
    font-size: 12px;
    line-height: 14px;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event01 .head-title {
    width: 95.1%;
    margin-top: 5.75%;
  }
  .section-event .event01 .head-title img.only-mo {
    margin-left: -4px;
  }
}
@media (min-width: 768px) {
  .section-event .event01 .section-name {
    margin-bottom: 50px;
  }
}
.section-event .event01 .section-content {
  margin-top: 67px;
}
@media screen and (max-width: 767px) {
  .section-event .event01 .section-content {
    margin-top: 18px;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event01 .head-sub-title {
    max-width: 67.325%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event01 .text-time {
    width: 100%;
  }
}
.section-event .event02 {
  padding-bottom: 141px;
  background-image: url(../img/bg-event-01.jpg);
}
@media screen and (max-width: 767px) {
  .section-event .event02 {
    padding: 68px 0 18.335%;
    background-image: url(../img/bg-event-01-mo.jpg);
  }
}
@media screen and (max-width: 767px) {
  .section-event .event02 .head-sub-title {
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event02 .head-title {
    width: 90.7%;
    margin-top: 5.6%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event02 .text-time {
    width: 90%;
    margin-top: 4.315%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event02 .section-head {
    margin-left: -2px;
  }
}
.section-event .event02 .section-content {
  margin-top: 61px;
}
@media screen and (max-width: 767px) {
  .section-event .event02 .section-content {
    margin-top: 5.7%;
  }
}
@media (min-width: 768px) {
  .section-event .event02 .head-title {
    margin-top: 17px;
  }
}
@media (min-width: 768px) {
  .section-event .event02 .text-time {
    margin-top: 18px;
  }
}
.section-event .event03 .btn-invitation {
  margin-top: 62px;
}
@media screen and (max-width: 767px) {
  .section-event .event02 .btn-invitation {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    width: 100%;
    margin-top: 0;
  }
  .section-event .event02 .btn-invitation img {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event02 .note-n-button {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-top: 11.71%;
  }
}
.section-event .event03 {
  padding-bottom: 160px;
  background-image: url(../img/bg-event-02.jpg);
}
@media screen and (max-width: 767px) {
  .section-event .event03 {
    padding: 68px 0 80px;
    background-image: url(../img/bg-event-03-mo.jpg);
  }
}
.section-event .event03 .section-content {
  margin-top: 63px;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .section-content {
    width: 100%;
    margin-top: 9.815%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event03 .section-name {
    margin-bottom: 7.234%;
  }
}
.section-event .event03 .head-title {
  margin-top: 16px;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .head-title {
    margin: 5.9% auto 0;
    width: 912px;
    width: 80vw;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event03 .head-sub-title {
    width: 694px;
    width: 65vw;
  }
}
.section-event .event03 .text-note {
  margin: 94px 0 0 4px;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .text-note {
    margin: 16.3% auto 0;
    width: 832px;
    width: 57.77778vw;
  }
  .section-event .event03 .text-note img {
    margin-left: 2px;
  }
}
@media (min-width: 768px) {
  .section-event .event03 .text-time {
    margin-top: 22px;
  }
}
@media screen and (max-width: 767px) {
  .section-event .event03 .text-time {
    width: 90%;
  }
}
.section-event .event03 .swiper-event-wrap {
  position: relative;
  width: 1195px;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .swiper-event-wrap {
    width: auto;
  }
}
.section-event .event03 .swiper-event-pagination {
  bottom: 146px;
  font-size: 0;
  line-height: normal;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .swiper-event-pagination {
    bottom: 0;
  }
}
.section-event .event03 .swiper-pagination-bullet {
  width: 16px;
  height: 16px;
  margin: 0 2.5px;
  background-color: rgba(176, 156, 124, 0.4);
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .swiper-pagination-bullet {
    width: 2.225%;
    height: auto;
    padding-top: 2.225%;
  }
}
.section-event .event03 .swiper-pagination-bullet:first-child {
  margin-left: 0;
}
.section-event .event03 .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
.section-event .event03 .swiper-pagination-bullet-active {
  background-color: #dabb8c;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .swiper-event-navigation .swiper-button-next,
  .section-event .event03 .swiper-event-navigation .swiper-button-prev {
    width: 9.815%;
    height: auto;
    margin-top: -12.9%;
    padding-top: 19.625%;
  }
}
.section-event .event03 .swiper-event-navigation .swiper-button-next {
  right: 0;
}
.section-event .event03 .swiper-event-navigation .swiper-button-prev {
  left: 0;
}
@media screen and (max-width: 767px) {
  .section-event .event03 .swiper-event03 {
    padding-bottom: 3.385%;
  }
}
.section-event .section-content {
  margin-top: 55px;
}
.section-event .head-title {
  margin-top: 20px;
}
.section-event .head-desc {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .section-event .head-desc {
    margin-top: 26px;
  }
}
.section-event .text-note {
  display: block;
  font-size: 16px;
  color: #b09c7c;
  line-height: 20px;
}
.section-event .text-time {
  display: block;
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .section-event .text-time {
    width: 90%;
    margin: 5.5% auto;
  }
}
@media screen and (max-width: 767px) {
  .section-event .text-time img.only-mo {
    display: block;
  }
}
.section-event .list-invitation-note {
  margin: 10px 0 0 8px;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .section-event .list-invitation-note {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    margin: 5.7% 0 0;
  }
}
.section-event .list-invitation-note .text {
  position: relative;
  padding-left: 10px;
  font-size: 16px;
  font-weight: 400;
  color: #b09c7c;
  line-height: 20px;
}
@media screen and (max-width: 767px) {
  .section-event .list-invitation-note .text {
    padding-left: 13px;
    font-size: 16px;
    line-height: 20px;
  }
}
/* .section-event .list-invitation-note .text:before {
  position: absolute;
  top: 9px;
  left: 0;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background-color: rgba(176, 156, 124, 0.5);
  content: "";
} */
@media screen and (max-width: 767px) {
  .section-event .list-invitation-note .text:before {
    top: 7px;
    left: 4px;
    width: 2px;
    height: 2px;
    background-color: #b09c7c;
  }
}
.section-event .quest-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: start;
  -ms-flex-pack: start;
  justify-content: flex-start;
}
@media screen and (max-width: 767px) {
  .section-event .quest-list.swiper-wrapper {
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
  }
}
.section-event .quest-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: relative;
  width: calc((100% - 196px) / 4);
  margin: 0 33px;
}
@media screen and (max-width: 767px) {
  .section-event .quest-item {
    width: 100%;
    margin: 0;
  }
}
.section-event .quest-item:before {
  position: absolute;
  top: 0;
  left: -33px;
  width: 1px;
  height: 100%;
  background-color: rgba(176, 156, 124, 0.2);
  content: "";
}
.section-event .quest-item:first-child {
  margin-left: 0;
}
.section-event .quest-item:first-child:before {
  display: none;
}
.section-event .quest-item:first-child.is-complete:after {
  margin: 11px 0 0 1px;
}
.section-event .quest-item:nth-child(2).is-complete:after {
  margin-top: 7px;
}
.section-event .quest-item:nth-child(3).is-complete:after {
  margin: 7px 0 0 -1px;
}
@media (min-width: 768px) {
  .section-event .quest-item:nth-child(3) .thumb img.only-pc {
    margin-left: -2px;
  }
}
@media (min-width: 768px) {
  .section-event .quest-item:nth-child(3) .btn-quest {
    margin-left: -2px;
  }
}
.section-event .quest-item:last-child {
  margin-right: 0;
}
.section-event .quest-item:last-child.is-complete:after {
  margin: 12px 0 0 -3px;
}
@media (min-width: 768px) {
  .section-event .quest-item:last-child .thumb img.only-pc {
    margin-left: -2px;
  }
}
.section-event .quest-item .thumb {
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .section-event .quest-item .thumb {
    width: 250px;
  }
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .thumb {
    width: 1260px;
    width: 87.5vw;
  }
}
.section-event .quest-item .thumb:before {
  display: block;
  position: relative;
  padding-top: 134%;
  content: "";
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .thumb:before {
    padding-top: 128.93%;
  }
}
.section-event .quest-item .thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.section-event .quest-item .store-list {
  position: absolute;
  top: 121px;
  right: 42px;
  bottom: 100px;
  left: 42px;
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .store-list {
    top: 26%;
    right: 21%;
    bottom: 28%;
    left: 21%;
  }
}
.section-event .quest-item .store-item {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 3;
  width: 76px;
  height: 76px;
  font-size: 0;
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .store-item {
    top: 0;
    left: 0;
    width: 47%;
    height: 47%;
  }
}
.section-event .quest-item .store-item:nth-child(2) {
  top: 0;
  right: 0;
  left: auto;
}
.section-event .quest-item .store-item:nth-child(3) {
  top: auto;
  bottom: 0;
  left: 0;
}
.section-event .quest-item .store-item:nth-child(4) {
  top: auto;
  right: 0;
  bottom: 0;
  left: auto;
}
.section-event .quest-item .store-link {
  display: block;
  width: 100%;
  height: 100%;
}
.section-event .quest-item .text {
  margin-top: 19px;
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .text {
    position: absolute;
    bottom: 10.7%;
    left: 50%;
    z-index: 2;
    width: 594px;
    width: 41.25vw;
    margin-top: 0;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.section-event .quest-item .btn-quest {
  margin-top: 11px;
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .btn-quest {
    position: absolute;
    bottom: 25px;
    left: 0;
    z-index: 2;
    width: 1260px;
    width: 87.5vw;
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-event .quest-item .btn-quest img.only-mo {
    width: 100%;
  }
}
.section-event .quest-item .thumb.complete {
  display: none;
}
.section-event .quest-item .text.complete {
  display: none;
}
.section-event .quest-item .btn-quest.complete {
  display: none;
}
.section-event .quest-item.is-complete:after {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
  width: 118px;
  height: 118px;
  margin-top: 10px;
  background: url(../img/img-complete.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
  content: "";
}
@media screen and (max-width: 767px) {
  .section-event .quest-item.is-complete:after {
    margin-top: -6px;
    width: 472px;
    width: 32.77778vw;
    height: 472px;
    height: 32.77778vw;
  }
}
.section-event .quest-item.is-complete .thumb {
  display: none;
}
.section-event .quest-item.is-complete .thumb.complete {
  display: block;
}
.section-event .quest-item.is-complete .text {
  display: none;
}
.section-event .quest-item.is-complete .text.complete {
  display: block;
}
.section-event .quest-item.is-complete .store-list {
  display: none;
}
.section-event .quest-item.is-complete .btn-quest {
  display: none;
}
.section-event .quest-item.is-complete .btn-quest.complete {
  display: block;
}
.section-event .progress-wrap {
  position: relative;
}
@media (min-width: 768px) {
  .section-event .progress-wrap {
    max-width: 1164px;
    padding: 0 22px;
  }
}
@media (min-width: 768px) {
  .section-event .progress-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .progress-list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    max-width: 318px;
    margin: 0 auto;
  }
}
.section-event .progress-item {
  position: relative;
  text-align: center;
}
@media screen and (max-width: 767px) {
  .section-event .progress-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 0;
    margin-top: -95px;
  }
  .section-event .progress-item:first-child {
    margin-top: 0;
  }
  .section-event .progress-item:nth-child(3) {
    margin-top: -46px;
  }
  .section-event .progress-item:nth-child(odd) {
    margin-left: 2px;
  }
  .section-event .progress-item:nth-child(even) {
    -webkit-box-pack: end;
    -ms-flex-pack: end;
    justify-content: flex-end;
  }
  .section-event .progress-item:nth-child(even) .thumb img {
    right: 0;
    left: auto;
  }
  .section-event .progress-item .image-active.only-mo {
    display: none;
  }
  .section-event .progress-item.is-active img.only-mo {
    display: none;
  }
  .section-event .progress-item.is-active .image-active.only-mo {
    display: block;
  }
}
@media (min-width: 768px) {
  .section-event .progress-item .image-active.only-pc {
    display: none;
  }
  .section-event .progress-item.is-active img.only-pc {
    display: none;
  }
  .section-event .progress-item.is-active .image-active.only-pc {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .section-event .progress-item {
    margin-top: -48px;
  }
}
.section-event .progress-item:first-child:before {
  left: 2px;
}
@media screen and (max-width: 767px) {
  .section-event .progress-item:first-child:before {
    top: 3px;
    left: 50%;
  }
}
@media (min-width: 768px) {
  .section-event .progress-item .item-inner {
    margin: 0 35px;
  }
}
.section-event .progress-item .thumb {
  overflow: hidden;
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .section-event .progress-item .thumb:before {
    display: block;
    position: relative;
    padding-top: 72.18%;
    content: "";
  }
  .section-event .progress-item .thumb img {
    position: absolute;
    top: 0;
    left: 0;
    height: 100%;
  }
}
@media (min-width: 768px) {
  .section-event .progress-item .thumb {
    width: 100%;
  }
}
@media screen and (max-width: 767px) {
  .section-event .progress-item .thumb {
    width: 218px;
  }
}
.section-event .progress-bar {
  position: absolute;
  bottom: 37px;
  left: 0;
  z-index: 0;
  width: 100%;
  height: 10px;
  border: 2px solid #574b3a;
  background: #36322a;
}
@media screen and (max-width: 767px) {
  .section-event .progress-bar {
    top: 0;
    bottom: auto;
    left: 50%;
    width: 11px;
    height: 100%;
    margin-left: 0;
    border-width: 3px;
    -webkit-transform: translateX(-50%);
    transform: translateX(-50%);
  }
}
.section-event .progress-active {
  position: absolute;
  top: 1px;
  right: 1px;
  bottom: 1px;
  left: 1px;
  width: 0;
  height: calc(100% - 2px);
  background-color: #dcbf7d;
  -webkit-transition: width 0.5s, height 0.5s;
  transition: width 0.5s, height 0.5s;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
@media screen and (max-width: 767px) {
  .section-event .progress-active {
    width: calc(100% - 2px);
    height: 0;
  }
}
.invitation-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
@media screen and (max-width: 767px) {
  .invitation-list {
    -webkit-box-pack: start;
    -ms-flex-pack: start;
    justify-content: flex-start;
    margin: 0;
  }
}
.invitation-item {
  margin: 0 8px;
}
@media screen and (max-width: 767px) {
  .invitation-item {
    width: calc((100% / 2) - 4px);
    margin: 0;
  }
  .invitation-item:first-child {
    margin-right: 4px;
  }
  .invitation-item:nth-child(2) {
    margin-left: 4px;
  }
  .invitation-item:nth-child(3) {
    width: 49%;
    margin: 8px auto 0;
  }
  .invitation-item img {
    width: 100%;
  }
}
.section-story {
  padding-bottom: 230px;
  background-image: url(../img/bg-story-01.jpg);
  -webkit-transition: background 0.3s ease-in-out;
  transition: background 0.3s ease-in-out;
}
@media screen and (max-width: 767px) {
  .section-story {
    padding: 68px 0 65px;
    background-image: url(../img/bg-story-01-mo.jpg);
    -webkit-background-size: cover;
    background-size: 100% 100%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .section-head {
    width: 100%;
    margin-bottom: 5.38%;
  }
}
.section-story .section-name {
  margin-bottom: 36px;
}
@media screen and (max-width: 767px) {
  .section-story .section-name {
    width: 66%;
    margin: 0 auto;
  }
}
.section-story .section-content {
  position: relative;
  width: 929px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .section-story .section-content {
    width: 100%;
    padding-bottom: 8px;
  }
}
.section-story .swiper-story .thumb {
  display: inline-block;
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .thumb {
    display: none;
  }
}
.section-story .swiper-story .text-title {
  display: block;
  margin-top: 26px;
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .text-title {
    width: 72%;
    margin: 0 auto;
    min-height: auto;
  }
}
.section-story .swiper-story .text-desc {
  display: block;
  margin-top: 34px;
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .text-desc {
    width: 80%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .text-desc img.only-mo {
    display: block;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-wrapper {
    padding-bottom: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:first-child .text-title {
    margin-bottom: 287px;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:nth-child(2) .text-title {
    margin-bottom: 70px;
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:nth-child(2) .text-desc {
    width: 96%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:nth-child(3) .text-title {
    margin: -1px auto 70px;
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:nth-child(3) .text-desc {
    width: 96%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:last-child .text-title {
    margin-bottom: 70px;
    width: 80%;
  }
}
@media screen and (max-width: 767px) {
  .section-story .swiper-story .swiper-slide:last-child .text-desc {
    width: 98%;
  }
}
.section-story .swiper-pagination {
  bottom: -69px;
  font-size: 0;
}
@media screen and (max-width: 767px) {
  .section-story .swiper-pagination {
    bottom: -20px;
  }
}
.section-story .swiper-pagination .swiper-pagination-bullet {
  width: 14px;
  height: 14px;
  margin: 0 0 0 5px;
  border-radius: 0;
  background: url(../img/icon-pagination.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  opacity: 1;
}
@media screen and (max-width: 767px) {
  .section-story .swiper-pagination .swiper-pagination-bullet {
    width: 8px;
    height: 8px;
    margin: 0 2.5px;
    border-radius: 50%;
    background: #b09c7c;
    opacity: 0.4;
  }
}
.section-story .swiper-pagination .swiper-pagination-bullet:first-child {
  margin-left: 0;
}
.section-story .swiper-pagination .swiper-pagination-bullet:last-child {
  margin-right: 0;
}
.section-story
  .swiper-pagination
  .swiper-pagination-bullet.swiper-pagination-bullet-active {
  background: url(../img/icon-pagination-active.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .section-story
    .swiper-pagination
    .swiper-pagination-bullet.swiper-pagination-bullet-active {
    background: #dabb8c;
    opacity: 1;
  }
}
.section-story .swiper-pagination .swiper-button-next.swiper-button-disabled,
.section-story .swiper-pagination .swiper-button-prev.swiper-button-disabled {
  opacity: 0.5;
}
.section-story .swiper-button-next,
.section-story .swiper-button-prev {
  margin-top: -4px;
}
@media (min-width: 768px) and (max-width: 768px) {
  .section-story .swiper-button-next,
  .section-story .swiper-button-prev {
    margin-top: -65px;
  }
}
@media (max-width: 767px) {
  .section-story .swiper-button-next,
  .section-story .swiper-button-prev {
    margin-top: -130px;
    width: 31px;
  }
}
.section-story .swiper-button-next {
  right: -123px;
}
@media (min-width: 768px) and (max-width: 768px) {
  .section-story .swiper-button-next {
    right: 25px;
  }
}
@media (max-width: 767px) {
  .section-story .swiper-button-next {
    right: 4px;
  }
}
.section-story .swiper-button-prev {
  left: -123px;
}
@media (min-width: 768px) and (max-width: 768px) {
  .section-story .swiper-button-prev {
    left: 25px;
  }
}
@media (max-width: 767px) {
  .section-story .swiper-button-prev {
    left: 4px;
  }
}
.section-character {
  padding-bottom: 0;
  background-image: url(../img/bg-character.jpg);
}
@media screen and (max-width: 767px) {
  .section-character {
    padding-top: 32px;
    background-image: url(../img/bg-character-mo.jpg);
  }
}
.section-character .section-name {
  margin-bottom: 0;
}
@media screen and (max-width: 767px) {
  .section-character .section-name {
    width: 56.115%;
  }
}
.section-character .character-item {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: start;
  -ms-flex-align: start;
  align-items: flex-start;
  -webkit-box-pack: end;
  -ms-flex-pack: end;
  justify-content: flex-end;
  position: relative;
  margin: 0;
}
@media screen and (max-width: 767px) {
  .section-character .character-item {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
  }
}
.section-character .character-item-info {
  position: absolute;
  z-index: 3;
  opacity: 0;
}
@media screen and (max-width: 767px) {
  .section-character .character-item-info {
    top: 0.845%;
    left: 4.035%;
    z-index: -1;
  }
}
.section-character .character-item-info.is-active {
  -webkit-animation-name: fade;
  animation-name: fade;
  -webkit-animation-duration: 0.6s;
  animation-duration: 0.6s;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}
.section-character .character-item-info.is-show {
  opacity: 1;
}
.section-character .character-item-image {
  position: relative;
  z-index: 2;
}
@media screen and (max-width: 767px) {
  .section-character .character-item-image:before,
  .section-character .character-item-image:after {
    position: absolute;
    top: 0;
    z-index: 2;
    width: 100%;
    height: 100%;
    background: -webkit-gradient(
      linear,
      left top,
      left bottom,
      color-stop(43.69%, rgba(0, 0, 0, 0)),
      color-stop(75.36%, rgba(0, 0, 0, 0.8))
    );
    background: linear-gradient(
      180deg,
      rgba(0, 0, 0, 0) 43.69%,
      rgba(0, 0, 0, 0.8) 75.36%
    );
    content: "";
  }
  .section-character .character-item-image:before {
    left: -50%;
  }
  .section-character .character-item-image:after {
    right: -50%;
  }
}
.section-character .character-name {
  display: block;
  margin-top: 0;
  opacity: 1;
  -webkit-transform: translateY(0);
  transform: translateY(0);
}
@media screen and (max-width: 767px) {
  .section-character .character-name {
    position: relative;
    z-index: -1;
  }
  .section-character .character-name img {
    height: 260px;
    height: 18.05556vw;
  }
}
.section-character .character-desc {
  display: block;
}
.section-character .character-quote {
  display: block;
  margin-top: 24px;
}
.section-character .character-text {
  text-align: left;
}
@media screen and (max-width: 767px) {
  .section-character .character-text-mo {
    position: absolute;
    bottom: 26.6%;
    left: 0;
    z-index: 4;
    width: 100%;
    padding: 0 7.315% 0 7.515%;
    text-align: center;
  }
  .section-character .character-text-mo .character-quote {
    margin-top: 4.75%;
  }
  .section-character .character-text-mo .character-quote img {
    display: block;
    margin: 0 auto;
    height: 40px;
    height: 2.77778vw;
  }
}
.section-character .character-control {
  width: 70%;
}
@media screen and (max-width: 767px) {
  .section-character .character-control {
    width: 100%;
  }
}
.section-character .character-control .swiper-character-control {
  overflow: unset;
}
.section-character .skill-control {
  position: absolute;
  top: 372px;
  right: 378px;
  right: 19.6875vw;
  z-index: 3;
  width: 264px;
  margin-left: auto;
  text-align: left;
}
@media (min-width: 1920px) {
  .section-character .skill-control {
    right: 378px;
  }
}
@media only screen and (min-width: 768px) and (max-width: 1400px) {
  .section-character .skill-control {
    right: 200px;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-control {
    top: 50%;
    right: 6.115%;
    left: 6.615%;
    width: auto;
    margin: 1.845% auto 0;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-control .skill-name {
    display: none;
  }
}
.section-character .skill-list {
  margin-top: 24px;
}
@media screen and (max-width: 767px) {
  .section-character .skill-list {
    margin-top: 0;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-item {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    position: relative;
  }
}
.section-character .skill-item:not(:first-child) {
  margin-top: 20px;
}
@media screen and (max-width: 767px) {
  .section-character .skill-item:not(:first-child) {
    margin-top: 4px;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-item:nth-child(4) {
    margin-top: 8px;
  }
}
.section-character .skill-progress {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  position: relative;
  width: 100%;
  height: 4px;
  margin-top: 4px;
  border-radius: 4px;
  background: -webkit-gradient(
      linear,
      left bottom,
      left top,
      from(rgba(0, 0, 0, 0.2)),
      to(rgba(0, 0, 0, 0.2))
    ),
    #5a4623;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.2), rgba(0, 0, 0, 0.2)),
    #5a4623;
}
@media screen and (max-width: 767px) {
  .section-character .skill-progress {
    position: absolute;
    top: 57.65%;
    right: 0;
    left: 12.03%;
    width: auto;
    height: auto;
    border-radius: 8px;
  }
}
.section-character .skill-progress-bar {
  display: block;
  position: relative;
  height: 4px;
  border-top-left-radius: 4px;
  border-bottom-left-radius: 4px;
  background: url(../img/bg-progress-bar-active.png) no-repeat;
  -webkit-background-size: 100% 100%;
  background-size: 100% 100%;
  -webkit-transition: 0.25s;
  transition: 0.25s;
}
@media screen and (max-width: 767px) {
  .section-character .skill-progress-bar {
    border-top-left-radius: 8px;
    border-bottom-left-radius: 8px;
  }
}
.section-character .skill-progress-bar .progress-line {
  position: absolute;
  top: 0;
  left: 0;
  height: 100%;
}
.section-character .skill-progress-bar .progress-effect {
  position: absolute;
  top: -2px;
  right: -8px;
  width: 30px;
  height: 12px;
  background: url(../img/bg-progress-bar-effect.png) no-repeat;
  -webkit-background-size: 100% 100%;
  background-size: 100%;
}
@media screen and (max-width: 767px) {
  .section-character .skill-progress-bar .progress-effect {
    top: -3px;
    right: -11px;
    width: 34px;
    height: 11px;
  }
}
.section-character .skill-progress-bar.is-active .progress-line {
  -webkit-animation-name: progress;
  animation-name: progress;
  -webkit-animation-duration: 0.25s;
  animation-duration: 0.25s;
  -webkit-animation-delay: 0.1s;
  animation-delay: 0.1s;
  -webkit-animation-fill-mode: backwards;
  animation-fill-mode: backwards;
}
.section-character .skill-name {
  display: block;
  position: relative;
  z-index: 2;
}
@media (min-width: 768px) {
  .section-character .skill-name {
    margin-left: -3px;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-name-mo {
    position: absolute;
    z-index: 5;
    width: 400px;
    width: 27.77778vw;
    top: 180px;
    top: 12.5vw;
    right: 108px;
    right: 7.5vw;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-text {
    width: 340px;
    width: 23.61111vw;
  }
}
@media screen and (max-width: 767px) {
  .section-character .skill-text img.only-mo {
    display: block;
  }
}
.section-character .pagination-control {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  position: absolute;
  bottom: 221px;
  left: 50%;
  z-index: 2;
  width: 100%;
  max-width: 1178px;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
}
@media screen and (max-width: 767px) {
  .section-character .pagination-control {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    bottom: 4.346%;
    z-index: 3;
  }
}
.section-character .pagination-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-list {
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    margin-left: 4px;
  }
}
.section-character .pagination-item {
  margin-left: 2px;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-item {
    width: 20.6%;
    height: 20.6%;
    margin-left: 4px;
  }
  .section-character .pagination-item img {
    display: block;
    width: 100%;
  }
}
.section-character .pagination-item:first-child {
  margin-left: 0;
}
.section-character .pagination-item.is-active {
  pointer-events: none;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-item.is-active {
    display: block;
  }
}
.section-character .pagination-item.is-active .default {
  display: none;
}
.section-character .pagination-item.is-active .on {
  display: block;
}
.section-character .pagination-link {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  cursor: pointer;
}
.section-character .pagination-link .on {
  display: none;
}
.section-character .pagination-fraction {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: end;
  -ms-flex-align: end;
  align-items: flex-end;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 40px 4px 0 0;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction {
    margin: 6.3% auto 0;
  }
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-list {
    margin-left: 12px;
  }
}
.section-character .pagination-fraction-item {
  display: none;
  margin-right: 16px;
}
@media (min-width: 768px) {
  .section-character .pagination-fraction-item:nth-child(1) {
    margin-right: 20px;
  }
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-item {
    line-height: 0;
    margin-right: 32px;
    margin-right: 2.22222vw;
  }
}
.section-character .pagination-fraction-item.is-active {
  display: block;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-item img {
    height: 36px;
    height: 2.5vw;
  }
}
.section-character .pagination-fraction-total {
  display: block;
  position: relative;
  margin: 0 3px -5px 0;
  padding-left: 37px;
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-total {
    margin: 0 10px 0 0;
    line-height: 0;
    padding-left: 140px;
    padding-left: 9.72222vw;
  }
}
.section-character .pagination-fraction-total:before {
  position: absolute;
  top: 7px;
  left: 1px;
  width: 23px;
  height: 1px;
  background-color: #b09c7c;
  -webkit-transform: rotate(119deg);
  transform: rotate(119deg);
  content: "";
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-total:before {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .section-character .pagination-fraction-total img {
    height: 36px;
    height: 2.5vw;
  }
}
.section-character .pagination-fraction-line {
  position: absolute;
  left: -1px;
  top: 16px;
  top: 1.11111vw;
  width: 114px;
  width: 7.91667vw;
  height: 8px;
  height: 0.55556vw;
  background-color: #816445;
}
.section-character .pagination-fraction-progress {
  position: absolute;
  left: 0;
  width: 33.33%;
  height: 100%;
  background-color: #b09c7c;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}
@media (min-width: 769px) {
  .section-character #character-item-01 .character-item-info {
    top: 126px;
    left: 284px;
  }
}
@media (min-width: 769px) and (max-width: 1550px) {
  .section-character #character-item-01 .character-item-info {
    left: 100px;
  }
}
.section-character #character-item-01 .character-item-info.is-delay {
  -webkit-animation-duration: 0.8s;
  animation-duration: 0.8s;
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
}
@media (min-width: 769px) {
  .section-character #character-item-01 .character-text {
    margin-top: 45px;
    padding-left: 93px;
  }
}
.section-character #character-item-01 .character-item-image {
  margin: -6px -11px 0 0;
}
@media (min-width: 769px) and (max-width: 1550px) {
  .section-character #character-item-01 .character-item-image {
    margin-right: -11px;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-01 .character-item-image {
    margin: -55px 0 0 0;
  }
}
@media (min-width: 769px) {
  .section-character #character-item-02 .character-item-info {
    top: 140px;
    left: 333px;
  }
}
@media (min-width: 769px) and (max-width: 1550px) {
  .section-character #character-item-02 .character-item-info {
    left: 100px;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-02 .character-item-info {
    top: 1.345%;
    left: 6.535%;
  }
}
.section-character #character-item-02 .character-item-info.is-delay {
  -webkit-animation-duration: 0.8s;
  animation-duration: 0.8s;
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
}
@media (min-width: 769px) {
  .section-character #character-item-02 .character-text {
    margin-top: 63px;
    padding-left: 43px;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-02 .character-text-mo {
    bottom: 25.8%;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-02 .character-name img {
    height: 214px;
    height: 14.86111vw;
  }
}
.section-character #character-item-02 .character-item-image {
  margin: 40px -31px 0 0;
}
@media screen and (max-width: 767px) {
  .section-character #character-item-02 .character-item-image {
    margin: -55px 0 0 0;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-02 .skill-name-mo {
    top: 196px;
    top: 13.61111vw;
    right: 124px;
    right: 8.61111vw;
  }
}
@media (min-width: 769px) {
  .section-character #character-item-03 .character-item-info {
    top: 140px;
    left: 345px;
  }
}
@media (min-width: 769px) and (max-width: 1550px) {
  .section-character #character-item-03 .character-item-info {
    left: 100px;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-03 .character-item-info {
    top: 32px;
    top: 2.22222vw;
    left: 84px;
    left: 5.83333vw;
  }
}
.section-character #character-item-03 .character-item-info.is-delay {
  -webkit-animation-duration: 0.8s;
  animation-duration: 0.8s;
  -webkit-animation-delay: 0.4s;
  animation-delay: 0.4s;
}
@media (min-width: 769px) {
  .section-character #character-item-03 .character-text {
    margin-top: 55px;
    padding-left: 30px;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-03 .character-text-mo {
    bottom: 25.8%;
    padding: 0 11.415% 0 11.615%;
  }
}
.section-character #character-item-03 .character-item-image {
  margin: 79px 51px 0 0;
}
@media screen and (max-width: 767px) {
  .section-character #character-item-03 .character-item-image {
    margin: -55px 0 0 0;
  }
}
@media screen and (max-width: 767px) {
  .section-character #character-item-03 .skill-name-mo {
    top: 9.604%;
    right: 6.315%;
    width: 34.035%;
  }
}
.section-media {
  padding: 0;
  background-image: url(../img/bg-media.jpg);
}
@media screen and (max-width: 767px) {
  .section-media {
    padding: 9.17% 0 24.445%;
    background-image: url(../img/bg-media-mo.jpg);
  }
}
.section-media .center {
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  height: 100vh;
}
@media (min-width: 768px) {
  .section-media .center {
    height: auto;
  }
}
@media screen and (max-width: 767px) {
  .section-media .center {
    height: auto;
    padding: 0 5.556%;
  }
}
@media screen and (max-width: 767px) {
  .section-media .section-head {
    width: 100%;
  }
}
.section-media .section-name {
  margin: 18px 0 0;
}
@media screen and (max-width: 767px) {
  .section-media .section-name {
    max-width: 64.375%;
    margin: 0 auto;
  }
}
.section-media .section-content {
  margin-top: 313px;
}
@media screen and (max-width: 767px) {
  .section-media .section-content {
    width: 100%;
    margin-top: 90px;
  }
}
@media screen and (max-width: 767px) {
  .section-media .section-content {
    margin-top: 14%;
  }
}
.section-media .media-info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -ms-flex-pack: justify;
  justify-content: space-between;
  padding-bottom: 182px;
}
@media screen and (max-width: 767px) {
  .section-media .media-info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    padding-bottom: 0;
  }
}
.section-media .media-info .text {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-right: 224px;
  text-align: left;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text {
    -webkit-box-flex: 1;
    -ms-flex: auto;
    flex: auto;
    width: 100%;
    margin-right: 0;
    text-align: center;
  }
}
.section-media .media-info .text-sub {
  display: block;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-sub {
    max-width: 49%;
    margin: 0 auto;
  }
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-sub img.only-mo {
    display: block;
    margin-left: 2px;
  }
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-sub {
    width: 75%;
    margin: 0 auto;
  }
}
.section-media .media-info .text-title {
  display: block;
  margin-left: -2px;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-title {
    max-width: 75.625%;
    margin: 4.69% auto 0;
  }
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-title {
    width: 976px;
    width: 67.77778vw;
    margin: 6px auto 0;
  }
  .section-media .media-info .text-title img {
    margin-left: 3px;
  }
}
.section-media .media-info .text-desc {
  display: block;
  margin: 43px 0 0 -2px;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .text-desc {
    max-width: 75%;
    margin: 7.015% auto 0;
  }
}
.section-media .media-info .video-area {
  position: relative;
  width: 503px;
  margin-top: 83px;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .video-area {
    width: 100%;
    margin-top: 15.075%;
  }
}
.section-media .media-info .video-area:before {
  display: block;
  position: relative;
  padding-top: 56.46%;
  content: "";
}
@media screen and (max-width: 767px) {
  .section-media .media-info .video-area:before {
    padding-top: 59.53%;
  }
}
.section-media .media-info .video-area .thumb {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
}
@media screen and (max-width: 767px) {
  .section-media .media-info .video-area .thumb img {
    width: 100%;
    height: 100%;
  }
}
.section-media .media-info .video-area .btn-play {
  position: absolute;
  top: 50%;
  left: 50%;
  width: 95px;
  height: 94px;
  background: url(../img/icon-play.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}
@media (min-width: 768px) and (max-width: 768px) {
  .section-media .media-info .video-area .btn-play {
    width: 120px;
    height: 120px;
    margin: -2px 0px 0 -1px;
  }
}
@media screen and (max-width: 767px) {
  .section-media .media-info .video-area .btn-play {
    width: 60px;
    height: 60px;
  }
}
.error-page {
  overflow: auto;
}
.error-page .container {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  max-width: 1920px;
  min-height: 100vh;
  margin: 0 auto;
  padding-top: 80px;
  background: url(../img/bg-error.jpg) top no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .error-page .container {
    background: url(../img/bg-error-mo-01.jpg) center no-repeat;
    padding-top: 256px;
    padding-top: 17.77778vw;
    -webkit-background-size: cover;
    background-size: cover;
  }
}
@media screen and (max-width: 767px) and (orientation: landscape) {
  .error-page .container {
    overflow-y: scroll;
  }
}
.error-page .content {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding-bottom: 57px;
}
@media screen and (max-width: 767px) {
  .error-page .content {
    padding-bottom: 63px;
  }
}
.error-page .content .icon {
  display: block;
  width: 134px;
  width: 6.97917vw;
  height: 134px;
  height: 6.97917vw;
}
@media (min-width: 1920px) {
  .error-page .content .icon {
    width: 134px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .icon {
    height: 134px;
  }
}
@media (min-width: 280px) and (max-width: 768px) {
  .error-page .content .icon {
    width: 448px;
    width: 31.11111vw;
    height: 448px;
    height: 31.11111vw;
  }
}
.error-page .content .icon img {
  width: 100%;
}
.error-page .content .text-title {
  display: block;
  font-weight: 700;
  color: #d0b070;
  line-height: 29px;
  margin-top: 24px;
  margin-top: 1.25vw;
  font-size: 24px;
  font-size: 1.25vw;
}
@media (min-width: 1920px) {
  .error-page .content .text-title {
    margin-top: 24px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .text-title {
    font-size: 24px;
  }
}
@media (min-width: 280px) and (max-width: 768px) {
  .error-page .content .text-title {
    margin-top: 80px;
    margin-top: 5.55556vw;
    font-size: 80px;
    font-size: 5.55556vw;
    line-height: 96px;
    line-height: 6.66667vw;
  }
}
.error-page .content .text-desc {
  display: block;
  color: #d3c5ae;
  line-height: 20px;
  text-align: center;
  margin-top: 24px;
  margin-top: 1.25vw;
  font-size: 14px;
  font-size: 0.72917vw;
}
@media (min-width: 1920px) {
  .error-page .content .text-desc {
    margin-top: 24px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .text-desc {
    font-size: 14px;
  }
}
@media (min-width: 280px) and (max-width: 768px) {
  .error-page .content .text-desc {
    margin-top: 80px;
    margin-top: 5.55556vw;
    font-size: 48px;
    font-size: 3.33333vw;
    line-height: 64px;
    line-height: 4.44444vw;
  }
}
.error-page .content .btn-goto {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(#65441f),
    color-stop(170.59%, #ebc884)
  );
  background: linear-gradient(0deg, #65441f 0%, #ebc884 170.59%);
  font-weight: 700;
  color: #fff7e9;
  width: 302.4px;
  width: 15.75vw;
  height: 57.6px;
  height: 3vw;
  margin-top: 24px;
  margin-top: 1.25vw;
  font-size: 17px;
  font-size: 0.88542vw;
}
@media (min-width: 1920px) {
  .error-page .content .btn-goto {
    width: 302.4px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .btn-goto {
    height: 57.6px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .btn-goto {
    margin-top: 24px;
  }
}
@media (min-width: 1920px) {
  .error-page .content .btn-goto {
    font-size: 17px;
  }
}
@media (min-width: 280px) and (max-width: 768px) {
  .error-page .content .btn-goto {
    width: 1008px;
    width: 70vw;
    height: 192px;
    height: 13.33333vw;
    margin-top: 80px;
    margin-top: 5.55556vw;
    font-size: 56px;
    font-size: 3.88889vw;
  }
}
@media screen and (max-width: 767px) {
  .error-page-500 .container {
    background: url(../img/bg-error-mo-02.jpg) center no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
  }
}
.layer {
  display: none;
  position: fixed;
  bottom: 0;
  left: 0;
  z-index: 9999;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.6);
}
.layer.is-show {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
}
.popup {
  display: none;
  position: relative;
  background-image: url(../img/bg-popup-default.jpg);
  -webkit-background-size: cover;
  background-size: cover;
  background-repeat: no-repeat;
}
@media screen and (max-width: 767px) {
  .popup {
    width: 100%;
    margin: auto 30px;
    background-image: url(../img/bg-popup-default-mo.jpg);
  }
}
.popup .btn-close {
  position: absolute;
  top: 12px;
  right: 12px;
  width: 29px;
  height: 29px;
  background: url(../img/svg/icon-close.svg) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transition: 0.2s ease-in-out;
  transition: 0.2s ease-in-out;
}
@media screen and (max-width: 767px) {
  .popup .btn-close {
    top: 5%;
    right: 3.3%;
    width: 8%;
  }
}
.popup .popup-body {
  padding: 62px 28px 60px;
  border: 1px solid #7e7057;
}
@media screen and (max-width: 767px) {
  .popup .popup-body {
    overflow-y: auto;
    max-height: calc(var(--vh, 1vh) * 100 - 10vh);
    padding-right: 24px;
    padding-bottom: 40px;
    padding-left: 24px;
  }
}
.popup .popup-body .box-head {
  text-align: center;
}
.popup .popup-body .box-head + .button-wrap {
  margin-top: 50px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .box-head + .button-wrap {
    margin-top: 25px;
  }
}
.popup .popup-body .box-content {
  margin-top: 41px;
  /* word-break: keep-all; */
}
@media screen and (max-width: 767px) {
  .popup .popup-body .box-content {
    margin-top: 30px;
  }
}
.popup .popup-body .text-title {
  display: block;
  font-size: 23px;
  font-weight: 700;
  color: #d0b070;
  line-height: 28px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-title {
    font-size: 20px;
    line-height: 25px;
  }
}
.popup .popup-body .text-title-small {
  font-size: 22px;
  line-height: 30px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-title-small {
    font-size: 18px;
    line-height: 25px;
  }
}
.popup .popup-body .text-desc {
  display: block;
  margin-top: 23px;
  font-size: 14px;
  font-weight: 400;
  color: #d3c5ae;
  letter-spacing: 0px;
  line-height: 20px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-desc {
    margin-top: 8px;
    font-size: 12px;
    line-height: 17px;
  }
}
.popup .popup-body .text-sub {
  display: inline-block;
  position: relative;
  margin-top: 14px;
  padding: 0 79px;
  font-size: 16px;
  font-weight: 700;
  color: #d0b070;
  line-height: 22px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-sub {
    margin-top: 10px;
    padding: 0px 33px;
    font-size: 12px;
    line-height: 17px;
  }
}
.popup .popup-body .text-sub:before,
.popup .popup-body .text-sub:after {
  position: absolute;
  top: 50%;
  width: 34px;
  height: 16px;
  -webkit-transform: translateY(-50%);
  transform: translateY(-50%);
  content: "";
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-sub:before,
  .popup .popup-body .text-sub:after {
    width: 25px;
    height: 12px;
  }
}
.popup .popup-body .text-sub:before {
  left: 33px;
  background: url(../img/img-bullet-left.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-sub:before {
    left: 0;
  }
}
.popup .popup-body .text-sub:after {
  right: 35px;
  background: url(../img/img-bullet-right.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .text-sub:after {
    right: 0;
  }
}
.popup .popup-body .button-wrap {
  margin-top: 21px;
  text-align: center;
}
.popup .popup-body .button-wrap .btn + .btn {
  margin-top: 16px;
}
.popup .popup-body .btn {
  display: block;
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(#65441f),
    color-stop(170.59%, #ebc884)
  );
  background: linear-gradient(0deg, #65441f 0%, #ebc884 170.59%);
  color: #fff7e9;
  -webkit-transition: background 0.2s;
  transition: background 0.2s;
}
.popup .popup-body .btn:hover {
  background: -webkit-gradient(
    linear,
    left bottom,
    left top,
    from(#4d300f),
    color-stop(170.59%, #b2945a)
  );
  background: linear-gradient(0deg, #4d300f 0%, #b2945a 170.59%);
}
.popup .popup-body .btn-pop {
  width: 100%;
  padding: 18px 20px 20px;
  font-size: 17px;
  font-weight: 700;
  line-height: 20px;
}
@media screen and (max-width: 767px) {
  .popup .popup-body .btn-pop {
    padding: 15px 0 16px;
    font-size: 14px;
    line-height: 17px;
  }
}
.popup .popup-body .btn.is-disable {
  background: #393023;
  color: #716555;
  pointer-events: none;
}
.popup.popup-sm {
  width: 360px;
}
@media screen and (max-width: 767px) {
  .popup.popup-sm {
    width: 100%;
    max-width: 300px;
  }
}
@media (min-width: 768px) {
  .popup.popup-sm .popup-body {
    padding: 54px 28px;
  }
  .popup.popup-sm .popup-body .text-desc {
    margin-top: 9px;
  }
}
@media (min-width: 768px) {
  .popup.popup-sm .popup-body .box-head + .button-wrap {
    margin-top: 30px;
  }
}
.popup.popup-cancel .popup-body {
  padding: 55px 28px 57px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .popup-body {
    padding: 45px 23px 46px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .popup-body .box-content {
    margin-top: 32px;
  }
}
.popup.popup-cancel .input-area input {
  height: 48px;
  padding: 13px 13px 13px 11px;
  font-size: 13px;
  font-weight: 400;
  color: #816445;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-area input {
    height: 40px;
    padding: 12px 8px 12px 41px;
    font-size: 12px;
    line-height: 1;
  }
}
.popup.popup-cancel .input-area input::-webkit-input-placeholder {
  margin-left: 18px;
  font-size: 12px;
}
.popup.popup-cancel .input-area input::-moz-placeholder {
  margin-left: 18px;
  font-size: 12px;
}
.popup.popup-cancel .input-area input:-ms-input-placeholder {
  margin-left: 18px;
  font-size: 12px;
}
.popup.popup-cancel .input-area input::-ms-input-placeholder {
  margin-left: 18px;
  font-size: 12px;
}
.popup.popup-cancel .input-area input::placeholder {
  margin-left: 18px;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-area input::-webkit-input-placeholder {
    position: static;
    margin-left: 0;
    font-size: 10px;
    line-height: 14px;
  }
  .popup.popup-cancel .input-area input::-moz-placeholder {
    position: static;
    margin-left: 0;
    font-size: 10px;
    line-height: 14px;
  }
  .popup.popup-cancel .input-area input:-ms-input-placeholder {
    position: static;
    margin-left: 0;
    font-size: 10px;
    line-height: 14px;
  }
  .popup.popup-cancel .input-area input::-ms-input-placeholder {
    position: static;
    margin-left: 0;
    font-size: 10px;
    line-height: 14px;
  }
  .popup.popup-cancel .input-area input::placeholder {
    position: static;
    margin-left: 0;
    font-size: 10px;
    line-height: 14px;
  }
}
.popup.popup-cancel .input-area .label-code {
  left: 11px;
  padding-right: 7px;
  font-size: 14px;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-area .label-code {
    padding-right: 7px;
    font-size: 12px;
    left: 36px;
    left: 2.5vw;
  }
}
.popup.popup-cancel .input-area .label-code:after {
  height: 13px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-area .label-code:after {
    height: 42px;
    height: 2.91667vw;
  }
}
.popup.popup-cancel .input-button {
  margin-top: 6px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-button:first-child {
    margin-top: 0;
  }
}
.popup.popup-cancel .input-button .btn-form {
  min-height: 48px;
  padding: 18px 11px 17px 14px;
  font-size: 13px;
  font-weight: 400;
  line-height: 1;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-button .btn-form {
    height: 40px;
    min-height: 40px;
    padding: 14px 9px 15px;
    font-size: 11px;
  }
}
.popup.popup-cancel .input-button .count {
  right: 13px;
  font-size: 12px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-button .count {
    right: 11px;
    font-size: 10px;
  }
}
.popup.popup-cancel .input-button-code input {
  padding-right: 45px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .input-button-code input {
    padding-right: 40px;
    padding-left: 10px;
  }
}
.popup.popup-cancel .input-item.is-disable input {
  background-color: #847866;
  color: #fff3e7;
  pointer-events: none;
}
.popup.popup-cancel .input-item.is-disable .count {
  display: none;
}
.popup.popup-cancel .btn-close {
  top: 11px;
  right: 11px;
}
.popup.popup-cancel .text-title {
  margin-left: -6px;
}
.popup.popup-cancel .text-desc {
  margin-left: -2px;
  letter-spacing: 0.3px;
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .text-desc {
    margin: 20px 0 0 -2px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-cancel .button-wrap {
    margin-top: 18px;
  }
  .popup.popup-cancel .button-wrap .btn-pop {
    padding: 13px 0 18px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-get-verify .popup-body {
    padding: 36px 24px 36px;
  }
}
.popup.popup-invite-friend {
  max-width: 790px;
  background: url(../img/bg-popup-invite.jpg) no-repeat;
  -webkit-background-size: cover;
  background-size: cover;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend {
    overflow-y: auto;
    width: 90%;
    max-width: 360px;
    background: url(../img/bg-popup-default-mo.jpg) no-repeat;
    -webkit-background-size: cover;
    background-size: cover;
  }
  .popup.popup-invite-friend .form-n-button {
    margin-top: 19px;
  }
}
.popup.popup-invite-friend .popup-body {
  padding: 44px 65px 42px 39px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .popup-body {
    padding: 45px 22px 47px 23px;
  }
}
@media (min-width: 768px) {
  .popup.popup-invite-friend .box-head {
    margin-top: -2px;
  }
}
.popup.popup-invite-friend .box-content {
  max-width: 328px;
  margin: 22px auto 0;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .box-content {
    margin-top: 20px;
  }
}
.popup.popup-invite-friend .box-content .input-area input {
  height: 62px;
  font-size: 16px;
  color: #7c5b30;
  line-height: 19px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .box-content .input-area input {
    height: 48px;
    padding: 10px 18px;
    font-size: 12px;
  }
}
.popup.popup-invite-friend
  .box-content
  .input-area
  input::-webkit-input-placeholder {
  text-align: center;
}
.popup.popup-invite-friend .box-content .input-area input::-moz-placeholder {
  text-align: center;
}
.popup.popup-invite-friend
  .box-content
  .input-area
  input:-ms-input-placeholder {
  text-align: center;
}
.popup.popup-invite-friend
  .box-content
  .input-area
  input::-ms-input-placeholder {
  text-align: center;
}
.popup.popup-invite-friend .box-content .input-area input::placeholder {
  text-align: center;
}
.popup.popup-invite-friend .text-title {
  font-size: 28px;
  line-height: 34px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .text-title {
    font-size: 20px;
    line-height: 25px;
  }
}
.popup.popup-invite-friend .text-desc {
  font-size: 16px;
  line-height: 22px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .text-desc {
    margin-top: 18px;
    font-size: 12px;
    line-height: 17px;
  }
}
.popup.popup-invite-friend .button-wrap {
  margin-top: 18px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .button-wrap {
    margin-top: 11px;
  }
}
@media (min-width: 768px) {
  .popup.popup-invite-friend .btn-pop {
    padding: 21px 20px 20px;
    font-size: 18px;
    line-height: 21px;
  }
}
.popup.popup-invite-friend .col-wrap {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
}
.popup.popup-invite-friend .col-left {
  width: 328px;
  margin-left: -1px;
}
.popup.popup-invite-friend .col-right {
  -webkit-box-flex: 1;
  -ms-flex: 1;
  flex: 1;
  margin-left: 103px;
}
.popup.popup-invite-friend .invitation-list {
  margin: -4px -4px -4px -22px;
}
.popup.popup-invite-friend .invitation-item {
  position: relative;
  width: 132px;
  margin: 4px;
}
.popup.popup-invite-friend .invitation-item:before {
  display: block;
  position: relative;
  padding-top: 136.4%;
  content: "";
}
.popup.popup-invite-friend .invitation-item:after {
  display: none;
  position: absolute;
  top: -2px;
  right: 0;
  z-index: 2;
  width: 42px;
  height: 35px;
  background: url(../img/event-invitation-label.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  content: "";
}
.popup.popup-invite-friend .invitation-item img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.popup.popup-invite-friend .invitation-item:nth-child(3) {
  width: 272px;
}
.popup.popup-invite-friend .invitation-item:nth-child(3):before {
  padding-top: 66.18%;
}
.popup.popup-invite-friend .invitation-item.is-badge:after {
  display: block;
}
.popup.popup-invite-friend .invitation-item:last-child.is-badge:after {
  top: 0;
}
.popup.popup-invite-friend .swiper-invite {
  padding-top: 10px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .swiper-invite {
    padding-top: 0;
  }
}
.popup.popup-invite-friend .swiper-invite .thumb {
  display: block;
  position: relative;
  width: 275px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .swiper-invite .thumb {
    width: 54.7%;
  }
}
.popup.popup-invite-friend .swiper-invite .thumb:before {
  display: block;
  position: relative;
  padding-top: 136.4%;
  content: "";
}
.popup.popup-invite-friend .swiper-invite .thumb img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
.popup.popup-invite-friend .swiper-invite-item .thumb:after {
  display: none;
  position: absolute;
  top: 0;
  right: 0;
  z-index: 2;
  width: 39px;
  height: 32px;
  background: url(../img/event-invitation-label-mo.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  content: "";
}
.popup.popup-invite-friend .swiper-invite-item.is-badge .thumb:after {
  display: block;
}
.popup.popup-invite-friend .swiper-button-next,
.popup.popup-invite-friend .swiper-button-prev {
  width: 76px;
  height: 76px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .swiper-button-next,
  .popup.popup-invite-friend .swiper-button-prev {
    width: 38px;
    height: 38px;
    margin-top: -17px;
  }
}
.popup.popup-invite-friend .swiper-button-next:after,
.popup.popup-invite-friend .swiper-button-prev:after {
  content: "";
}
.popup.popup-invite-friend .swiper-button-prev {
  left: 0;
  background: url(../img/icon-btn-next.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.popup.popup-invite-friend .swiper-button-prev.swiper-button-disabled {
  background: url(../img/icon-btn-prev.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  opacity: 1;
  -webkit-transform: rotate(0);
  transform: rotate(0);
}
.popup.popup-invite-friend .swiper-button-next {
  right: 0;
  background: url(../img/icon-btn-next.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
.popup.popup-invite-friend .swiper-button-next.swiper-button-disabled {
  background: url(../img/icon-btn-prev.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  opacity: 1;
  -webkit-transform: rotate(180deg);
  transform: rotate(180deg);
}
.popup.popup-invite-friend .btn-close {
  top: 20px;
  right: 19px;
}
@media screen and (max-width: 767px) {
  .popup.popup-invite-friend .btn-close {
    top: 2%;
    right: 3.4%;
    height: 4.3%;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed {
    width: 90%;
  }
}
.popup.popup-booking-completed .popup-body {
  padding: 54px 28px;
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .popup-body {
    padding: 45px 24px;
  }
}
@media (min-width: 768px) {
  .popup.popup-booking-completed .popup-body .text-desc {
    margin-top: 20px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .popup-body .text-desc {
    margin-top: 17px;
  }
}
@media (min-width: 768px) {
  .popup.popup-booking-completed .popup-body .btn + .btn {
    margin-top: 10px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .popup-body .btn + .btn {
    margin-top: 8px;
  }
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .popup-body .button-wrap {
    margin-top: 20px;
  }
}
.popup.popup-booking-completed .box-content {
  position: relative;
  margin: 24px 0 26px;
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .box-content {
    overflow: hidden;
    margin: 20px 0 0;
  }
}
.popup.popup-booking-completed .box-content .effect {
  position: absolute;
  top: 0;
  left: 50%;
  z-index: 2;
  width: 209px;
  height: 170px;
  margin-left: -3px;
  background: url(../img/ticket-effect-popup.png) no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
  -webkit-transform: translateX(-50%);
  transform: translateX(-50%);
  pointer-events: none;
  mix-blend-mode: screen;
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .box-content .effect {
    width: 70.4%;
    height: 116.95%;
    margin-top: 0;
  }
}
.popup.popup-booking-completed .thumb {
  width: 211px;
  margin: 0 auto;
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .thumb {
    width: 70.4%;
  }
}
.popup.popup-booking-completed .thumb img {
  display: block;
  width: 100%;
}
@media screen and (max-width: 767px) {
  .popup.popup-booking-completed .btn-close {
    top: 2%;
    height: 4.8%;
  }
}
.popup.popup-receive-advertise .text-list {
  margin-bottom: 4px;
}
@media screen and (max-width: 767px) {
  .popup.popup-receive-advertise .text-list {
    margin-bottom: 0;
  }
}
.popup.popup-scroll {
  max-width: 360px;
  max-height: 446px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll {
    width: 90%;
    max-width: 400px;
  }
}
.popup.popup-scroll .popup-body {
  padding: 54px 28px 57px;
}
.popup.popup-scroll .box-content {
  overflow-y: auto;
  max-height: 200px;
  margin-top: 22px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content {
    padding-right: 4px;
  }
}
.popup.popup-scroll .box-content::-webkit-scrollbar {
  width: 5px;
  background-color: #4e4c4a;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content::-webkit-scrollbar {
    width: 5px;
  }
}
.popup.popup-scroll .box-content::-webkit-scrollbar-thumb {
  background-color: #e2ceb1;
}
.popup.popup-scroll .box-content > * {
  font-size: 14px;
  font-weight: 400;
  color: #d3c5ae;
  line-height: 20px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content > * {
    margin: 5px 0;
    font-size: 12px;
    line-height: 18px;
  }
}
.popup.popup-scroll .box-content > ol {
  padding-left: 24px;
  list-style: decimal;
}
.popup.popup-scroll .box-content > ol .text-list > span {
  display: block;
  margin-left: 0;
}
.popup.popup-scroll .box-content > table {
  width: 289px;
  margin-top: 15px;
  border: 1px solid #d3c5ae;
  border-collapse: collapse;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
}
.popup.popup-scroll .box-content > table:not(:first-of-type) {
  margin-bottom: 15px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content > table {
    width: 100%;
  }
}
.popup.popup-scroll .box-content > table th,
.popup.popup-scroll .box-content > table td {
  padding: 3px;
  border: 1px solid #d3c5ae;
  font-weight: 400;
  text-align: left;
  word-break: break-all;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content > table th,
  .popup.popup-scroll .box-content > table td {
    padding: 2px;
  }
}
.popup.popup-scroll .box-content .text > a {
  color: #dabb8c;
  text-decoration: underline;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  text-underline-position: under;
}
.popup.popup-scroll .box-content .text > a:hover {
  color: #dfa346;
}
.popup.popup-scroll .box-content .text-bold {
  font-weight: 700;
}
.popup.popup-scroll .box-content .text-color {
  color: #dabb8c;
}
.popup.popup-scroll .box-content .text-list > span {
  display: block;
  position: relative;
  margin-left: 10px;
  text-indent: 12px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content .text-list > span {
    margin-left: 7px;
    padding-left: 10px;
    text-indent: 0;
  }
}
.popup.popup-scroll .box-content .text-list > span:before {
  position: absolute;
  top: 10px;
  left: 0;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background-color: #d3c5ae;
  content: "";
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .box-content .text-list > span:before {
    top: 9px;
  }
}
.popup.popup-scroll .button-wrap {
  margin-top: 29px;
}
@media screen and (max-width: 767px) {
  .popup.popup-scroll .button-wrap {
    margin-top: 30px;
  }
}
.popup.popup-collect-use table tr:first-child th,
.popup.popup-collect-use table tr:first-child td {
  background-color: #715028;
  font-weight: 700;
}
.popup.popup-collect-use table tr:first-child .no_bg {
  background-color: transparent;
}
.popup.popup-collect-use table tr:first-child .text_normal {
  font-weight: 400;
}
.popup.popup-collect-use table .has_bg {
  background-color: #715028;
}
.popup.popup-personal-info .box-content .text-list > span {
  padding-left: 10px;
  text-indent: 0;
}
.popup.popup-personal-info .box-content table tr:first-child th,
.popup.popup-personal-info .box-content table tr:first-child td {
  background-color: #715028;
  font-weight: 700;
}
.popup.popup-personal-info .box-content table tr:first-child .no_bg {
  background-color: transparent;
}
.popup.popup-personal-info .box-content table tr:first-child .text_normal {
  font-weight: 400;
}
.popup.popup-pre-bookers .popup-body {
  padding: 43px 28px 42px;
}
@media screen and (max-width: 767px) {
  .popup.popup-pre-bookers .popup-body {
    padding: 11.7% 8% 11.7%;
  }
}
@media (min-width: 767px) {
  .popup.popup-pre-bookers .popup-body .text-desc {
    margin-top: 9px;
  }
}
@media (min-width: 767px) {
  .popup.popup-pre-bookers .popup-body .button-wrap {
    margin-top: 30px;
  }
}
.popup.popup-video {
  width: 76vw;
  height: 42.75vw;
  background-color: transparent;
}
.tbt1,
.tbt2,
.tbt3 {
  color: #f7dfb9;
  padding: 0 10px;
}

@media screen and (max-width: 767px) {
  .mbimg {
    display: none;
  }
  .popup.popup-video {
    width: 100%;
    height: 56.25vw;
  }
}
.popup.popup-video .popup-body {
  overflow-y: visible;
  position: relative;
  height: 100%;
  padding: 0;
  border: 0;
}
.popup.popup-video .popup-body img {
  width: 100%;
}
.popup.popup-video .video-box {
  position: relative;
  width: 100%;
  height: 100%;
}
.popup.popup-video .video-box .video {
  width: 100%;
  height: 100%;
}
.popup.popup-video .btn-close {
  top: -15px;
  right: -55px;
  width: 50px;
  height: 50px;
  background: url(../img/svg/icon-menu-close.svg) center no-repeat;
  -webkit-background-size: 100% auto;
  background-size: 100% auto;
}
@media screen and (max-width: 767px) {
  .popup.popup-video .btn-close {
    top: -40px;
    right: 0;
    bottom: 0;
    left: inherit;
    width: 40px;
    height: 40px;
    -webkit-transform: none;
    transform: none;
  }
}
.popup.is-show {
  display: block;
}
@media only screen and (max-width: 760px) {
  .pcimg {
    display: none;
  }
  .mbimg {
    display: block;
  }
}
@media only screen and (max-width: 1200px) {
  .footer-content {
    width: 90%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    align-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0px 66px 34px;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 1000px) {
  .footer-content {
    width: 100%;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    align-items: center;
    align-content: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    padding: 0px 0px 34px;
    margin: 0 auto;
  }
}
@media only screen and (max-width: 767px) {
  .section-event .text-note,
  .section-event .list-invitation-note .text {
    font-size: 12px;
  }
  .sns-item:nth-child(1),
  .sns-item:nth-child(2),
  .sns-item:nth-child(3) {
    display: none;
  }
  .section-story .swiper-story .swiper-slide:nth-child(5) .text-title {
    margin: -1px auto 70px;
    width: 80%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(5) .text-desc {
    width: 96%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(4) .text-title {
    margin: -1px auto 100px;
    width: 80%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(4) .text-desc {
    width: 96%;
  }
  .mimg {
    padding-top: 20%;
  }
  .ulibx {
    width: 80%;
    margin: 0 auto;
  }
  .footer .info {
    width: 60%;
  }
  .footer .logo {
    width: 25%;
    padding: 10px;
  }
  .twif {
    width: 95%;
    display: flex;
    align-items: center;
    align-content: center;
    justify-content: center;
  }
  .footer-content {
    width: 100%;

    flex-wrap: wrap;
  }
  .minbtbx {
    display: none;
  }
  .section-story .swiper-story .swiper-slide:nth-child(1) .text-title,
  .bntl {
    margin-bottom: 70px;
    width: 80%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(1) .text-desc,
  .bntx {
    width: 98%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(4) .text-title,
  .bntl {
    margin-bottom: 70px;
    width: 80%;
  }
  .section-story .swiper-story .swiper-slide:nth-child(4) .text-desc,
  .bntx {
    width: 98%;
  }
}
@media only screen and (max-width: 767px) {
  .appa {
    cursor: pointer;
    position: absolute;
    left: 0;
    margin-left: 141px;
    width: 60px;
    height: 60px;

    bottom: 5px;
    border-radius: 10px;
  }
  .appb {
    cursor: pointer;
    position: absolute;
    left: 0;
    margin-left: 236px;
    width: 60px;
    height: 60px;

    bottom: 6px;
    border-radius: 10px;
  }
}
@media only screen and (max-width: 530px) {
  .appa {
    cursor: pointer;
    position: absolute;
    left: 50%;
    margin-left: -18%;
    width: 14%;
    height: 11vw;

    bottom: 5px;
    border-radius: 10px;
  }
  .appb {
    cursor: pointer;
    position: absolute;
    left: 50%;
    margin-left: 4%;
    width: 14%;
    height: 11vw;

    bottom: 6px;
    border-radius: 10px;
  }
}
