﻿.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -khtml-user-select: none;
  -moz-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0)
}

.slick-list {
  position: relative;
  overflow: hidden;
  display: block;
  margin: 0;
  padding: 0
}

.slick-list:focus {
  outline: none
}

.slick-list.dragging {
  cursor: pointer;
  cursor: hand
}

.slick-slider .slick-track, .slick-slider .slick-list {
  -webkit-transform: translate3d(0, 0, 0);
  -moz-transform: translate3d(0, 0, 0);
  -ms-transform: translate3d(0, 0, 0);
  -o-transform: translate3d(0, 0, 0);
  transform: translate3d(0, 0, 0)
}

.slick-track {
  position: relative;
  left: 0;
  top: 0;
  display: block;
  margin-left: auto;
  margin-right: auto
}

.slick-track:before, .slick-track:after {
  content: "";
  display: table
}

.slick-track:after {
  clear: both
}

.slick-loading .slick-track {
  visibility: hidden
}

.slick-slide {
  float: left;
  height: 100%;
  min-height: 1px;
  display: none
}

[dir=rtl] .slick-slide {
  float: right
}

.slick-slide img {
  display: block
}

.slick-slide.slick-loading img {
  display: none
}

.slick-slide.dragging img {
  pointer-events: none
}

.slick-initialized .slick-slide {
  display: block
}

.slick-loading .slick-slide {
  visibility: hidden
}

.slick-vertical .slick-slide {
  display: block;
  height: auto;
  border: 1px solid rgba(0, 0, 0, 0)
}

.slick-arrow.slick-hidden {
  display: none
}


/*!
	Modaal - accessible modals - v0.4.4
	by Humaan, for all humans.
	http://humaan.com
 */

.modaal-noscroll {
  overflow: hidden
}

.modaal-accessible-hide {
  position: absolute !important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0 !important;
  border: 0 !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden
}

.modaal-overlay {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 999;
  opacity: 0
}

.modaal-wrapper {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  overflow: auto;
  opacity: 1;
  box-sizing: border-box;
  -webkit-overflow-scrolling: touch;
  transition: all 0.3s ease-in-out
}

.modaal-wrapper * {
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-backface-visibility: hidden
}

.modaal-wrapper .modaal-close {
  border: none;
  background: rgba(0, 0, 0, 0);
  padding: 0;
  -webkit-appearance: none
}

.modaal-wrapper.modaal-start_none {
  display: none;
  opacity: 1
}

.modaal-wrapper.modaal-start_fade {
  opacity: 0
}

.modaal-wrapper *[tabindex="0"] {
  outline: none !important
}

.modaal-wrapper.modaal-fullscreen {
  overflow: hidden
}

.modaal-outer-wrapper {
  display: table;
  position: relative;
  width: 100%;
  height: 100%
}

.modaal-fullscreen .modaal-outer-wrapper {
  display: block
}

.modaal-inner-wrapper {
  display: table-cell;
  width: 100%;
  height: 100%;
  position: relative;
  vertical-align: middle;
  text-align: center;
  padding: 80px 25px
}

.modaal-fullscreen .modaal-inner-wrapper {
  padding: 0;
  display: block;
  vertical-align: top
}

.modaal-container {
  position: relative;
  display: inline-block;
  width: 100%;
  margin: auto;
  text-align: left;
  color: #fff;
  max-width: 1000px;
  border-radius: 0px;
  background: #000;
  box-shadow: 0 4px 15px rgba(0, 0, 0, .2);
  cursor: auto;
  border: 1px solid
}

.modaal-container.is_loading {
  height: 100px;
  width: 100px;
  overflow: hidden
}

.modaal-fullscreen .modaal-container {
  max-width: none;
  height: 100%;
  overflow: auto
}

.modaal-container>.modaal-close {
  display: none
}

.modaal-close {
  position: fixed;
  right: 20px;
  top: 20px;
  color: #fff;
  cursor: pointer;
  opacity: 1;
  width: 50px;
  height: 50px;
  background: rgba(0, 0, 0, 0);
  border-radius: 100%;
  transition: all 0.2s ease-in-out
}

.modaal-close:focus, .modaal-close:hover {
  outline: none;
  background: #fff
}

.modaal-close:focus:before, .modaal-close:focus:after, .modaal-close:hover:before, .modaal-close:hover:after {
  background: #b93d0c
}

.modaal-close span {
  position: absolute !important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0 !important;
  border: 0 !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden
}

.modaal-close:before, .modaal-close:after {
  display: block;
  content: " ";
  position: absolute;
  top: 14px;
  left: 23px;
  width: 4px;
  height: 22px;
  border-radius: 4px;
  background: #fff;
  transition: background 0.2s ease-in-out
}

.modaal-close:before {
  transform: rotate(-45deg)
}

.modaal-close:after {
  transform: rotate(45deg)
}

.modaal-fullscreen .modaal-close {
  background: #afb7bc;
  right: 10px;
  top: 10px
}

.modaal-content-container {
  padding: 30px
}

.modaal-confirm-wrap {
  padding: 30px 0 0;
  text-align: center;
  font-size: 0
}

.modaal-confirm-btn {
  font-size: 14px;
  display: inline-block;
  margin: 0 10px;
  vertical-align: middle;
  cursor: pointer;
  border: none;
  background: rgba(0, 0, 0, 0)
}

.modaal-confirm-btn.modaal-ok {
  padding: 10px 15px;
  color: #fff;
  background: #555;
  border-radius: 3px;
  transition: background 0.2s ease-in-out
}

.modaal-confirm-btn.modaal-ok:hover {
  background: #2f2f2f
}

.modaal-confirm-btn.modaal-cancel {
  text-decoration: underline
}

.modaal-confirm-btn.modaal-cancel:hover {
  text-decoration: none;
  color: #2f2f2f
}

@keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

@-o-keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

@-moz-keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

@-webkit-keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

@-ms-keyframes instaReveal {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

.modaal-instagram .modaal-container {
  width: auto;
  background: rgba(0, 0, 0, 0);
  box-shadow: none !important
}

.modaal-instagram .modaal-content-container {
  padding: 0;
  background: rgba(0, 0, 0, 0)
}

.modaal-instagram .modaal-content-container>blockquote {
  width: 1px !important;
  height: 1px !important;
  opacity: 0 !important
}

.modaal-instagram iframe {
  opacity: 0;
  margin: -6px !important;
  border-radius: 0 !important;
  width: 1000px !important;
  max-width: 800px !important;
  box-shadow: none !important;
  animation: instaReveal 1s linear forwards
}

.modaal-image .modaal-inner-wrapper {
  padding-left: 140px;
  padding-right: 140px
}

.modaal-image .modaal-container {
  width: auto;
  max-width: 100%
}

.modaal-gallery-wrap {
  position: relative;
  color: #fff
}

.modaal-gallery-item {
  display: none
}

.modaal-gallery-item img {
  display: block
}

.modaal-gallery-item.is_active {
  display: block
}

.modaal-gallery-label {
  position: absolute;
  left: 0;
  width: 100%;
  margin: 20px 0 0;
  font-size: 18px;
  text-align: center;
  color: #fff
}

.modaal-gallery-label:focus {
  outline: none
}

.modaal-gallery-control {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  opacity: 1;
  cursor: pointer;
  color: #fff;
  width: 50px;
  height: 50px;
  background: rgba(0, 0, 0, 0);
  border: none;
  border-radius: 100%;
  transition: all 0.2s ease-in-out
}

.modaal-gallery-control.is_hidden {
  opacity: 0;
  cursor: default
}

.modaal-gallery-control:focus, .modaal-gallery-control:hover {
  outline: none;
  background: #fff
}

.modaal-gallery-control:focus:before, .modaal-gallery-control:focus:after, .modaal-gallery-control:hover:before, .modaal-gallery-control:hover:after {
  background: #afb7bc
}

.modaal-gallery-control span {
  position: absolute !important;
  clip: rect(1px 1px 1px 1px);
  clip: rect(1px, 1px, 1px, 1px);
  padding: 0 !important;
  border: 0 !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden
}

.modaal-gallery-control:before, .modaal-gallery-control:after {
  display: block;
  content: " ";
  position: absolute;
  top: 16px;
  left: 25px;
  width: 4px;
  height: 18px;
  border-radius: 4px;
  background: #fff;
  transition: background 0.2s ease-in-out
}

.modaal-gallery-control:before {
  margin: -5px 0 0;
  transform: rotate(-45deg)
}

.modaal-gallery-control:after {
  margin: 5px 0 0;
  transform: rotate(45deg)
}

.modaal-gallery-next-inner {
  left: 100%;
  margin-left: 40px
}

.modaal-gallery-next-outer {
  right: 45px
}

.modaal-gallery-prev:before, .modaal-gallery-prev:after {
  left: 22px
}

.modaal-gallery-prev:before {
  margin: 5px 0 0;
  transform: rotate(-45deg)
}

.modaal-gallery-prev:after {
  margin: -5px 0 0;
  transform: rotate(45deg)
}

.modaal-gallery-prev-inner {
  right: 100%;
  margin-right: 40px
}

.modaal-gallery-prev-outer {
  left: 45px
}

.modaal-video-wrap {
  margin: auto 50px;
  position: relative
}

.modaal-video-container {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  max-width: 100%;
  box-shadow: 0 0 10px rgba(0, 0, 0, .3);
  background: #000;
  max-width: 1300px;
  margin-left: auto;
  margin-right: auto
}

.modaal-video-container iframe, .modaal-video-container object, .modaal-video-container embed {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}

.modaal-iframe .modaal-content {
  width: 100%;
  height: 100%
}

.modaal-iframe-elem {
  width: 100%;
  height: 100%;
  display: block
}

@media only screen and (min-width: 1400px) {
  .modaal-video-container {
    padding-bottom: 0;
    height: 1031px
  }
}

@media only screen and (max-width: 1140px) {
  .modaal-image .modaal-inner-wrapper {
    padding-left: 25px;
    padding-right: 25px
  }
  .modaal-gallery-control {
    top: auto;
    bottom: 20px;
    transform: none;
    background: rgba(0, 0, 0, .7)
  }
  .modaal-gallery-control:before, .modaal-gallery-control:after {
    background: #fff
  }
  .modaal-gallery-next {
    left: auto;
    right: 20px
  }
  .modaal-gallery-prev {
    left: 20px;
    right: auto
  }
}

@media screen and (max-width: 900px) {
  .modaal-instagram iframe {
    width: 500px !important
  }
}

@media screen and (max-height: 1100px) {
  .modaal-instagram iframe {
    width: 700px !important
  }
}

@media screen and (max-height: 1000px) {
  .modaal-inner-wrapper {
    padding-top: 60px;
    padding-bottom: 60px
  }
  .modaal-instagram iframe {
    width: 600px !important
  }
}

@media screen and (max-height: 900px) {
  .modaal-instagram iframe {
    width: 500px !important
  }
  .modaal-video-container {
    max-width: 900px;
    max-height: 510px
  }
}

@media only screen and (max-width: 600px) {
  .modaal-instagram iframe {
    width: 280px !important
  }
}

@media only screen and (max-height: 820px) {
  .modaal-gallery-label {
    display: none
  }
}

.modaal-loading-spinner {
  background: none;
  position: absolute;
  width: 200px;
  height: 200px;
  top: 50%;
  left: 50%;
  margin: -100px 0 0 -100px;
  transform: scale(0.25)
}

@-ms-keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -o-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
  }
}

@-moz-keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -o-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
  }
}

@-webkit-keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -o-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
  }
}

@-o-keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -o-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
  }
}

@keyframes modaal-loading-spinner {
  0% {
    opacity: 1;
    -ms-transform: scale(1.5);
    -moz-transform: scale(1.5);
    -webkit-transform: scale(1.5);
    -o-transform: scale(1.5);
    transform: scale(1.5)
  }
  100% {
    opacity: .1;
    -ms-transform: scale(1);
    -moz-transform: scale(1);
    -webkit-transform: scale(1);
    -o-transform: scale(1);
    transform: scale(1)
  }
}

.modaal-loading-spinner>div {
  width: 24px;
  height: 24px;
  margin-left: 4px;
  margin-top: 4px;
  position: absolute
}

.modaal-loading-spinner>div>div {
  width: 100%;
  height: 100%;
  border-radius: 15px;
  background: #fff
}

.modaal-loading-spinner>div:nth-of-type(1)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: 0s;
  -moz-animation-delay: 0s;
  -webkit-animation-delay: 0s;
  -o-animation-delay: 0s;
  animation-delay: 0s
}

.modaal-loading-spinner>div:nth-of-type(2)>div, .modaal-loading-spinner>div:nth-of-type(3)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}

.modaal-loading-spinner>div:nth-of-type(1) {
  -ms-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(45deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(45deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(2)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .12s;
  -moz-animation-delay: .12s;
  -webkit-animation-delay: .12s;
  -o-animation-delay: .12s;
  animation-delay: .12s
}

.modaal-loading-spinner>div:nth-of-type(2) {
  -ms-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(90deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(90deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(3)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .25s;
  -moz-animation-delay: .25s;
  -webkit-animation-delay: .25s;
  -o-animation-delay: .25s;
  animation-delay: .25s
}

.modaal-loading-spinner>div:nth-of-type(4)>div, .modaal-loading-spinner>div:nth-of-type(5)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}

.modaal-loading-spinner>div:nth-of-type(3) {
  -ms-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(135deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(135deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(4)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .37s;
  -moz-animation-delay: .37s;
  -webkit-animation-delay: .37s;
  -o-animation-delay: .37s;
  animation-delay: .37s
}

.modaal-loading-spinner>div:nth-of-type(4) {
  -ms-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(180deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(180deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(5)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .5s;
  -moz-animation-delay: .5s;
  -webkit-animation-delay: .5s;
  -o-animation-delay: .5s;
  animation-delay: .5s
}

.modaal-loading-spinner>div:nth-of-type(6)>div, .modaal-loading-spinner>div:nth-of-type(7)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite
}

.modaal-loading-spinner>div:nth-of-type(5) {
  -ms-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(225deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(225deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(6)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .62s;
  -moz-animation-delay: .62s;
  -webkit-animation-delay: .62s;
  -o-animation-delay: .62s;
  animation-delay: .62s
}

.modaal-loading-spinner>div:nth-of-type(6) {
  -ms-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(270deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(270deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(7)>div {
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .75s;
  -moz-animation-delay: .75s;
  -webkit-animation-delay: .75s;
  -o-animation-delay: .75s;
  animation-delay: .75s
}

.modaal-loading-spinner>div:nth-of-type(7) {
  -ms-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(315deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(315deg) translate(70px, 0)
}

.modaal-loading-spinner>div:nth-of-type(8)>div {
  -ms-animation: modaal-loading-spinner 1s linear infinite;
  -moz-animation: modaal-loading-spinner 1s linear infinite;
  -webkit-animation: modaal-loading-spinner 1s linear infinite;
  -o-animation: modaal-loading-spinner 1s linear infinite;
  animation: modaal-loading-spinner 1s linear infinite;
  -ms-animation-delay: .87s;
  -moz-animation-delay: .87s;
  -webkit-animation-delay: .87s;
  -o-animation-delay: .87s;
  animation-delay: .87s
}

.modaal-loading-spinner>div:nth-of-type(8) {
  -ms-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  -moz-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  -webkit-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  -o-transform: translate(84px, 84px) rotate(360deg) translate(70px, 0);
  transform: translate(84px, 84px) rotate(360deg) translate(70px, 0)
}

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box
}

html, body {
  height: 100%
}

body {
  font-feature-settings: "palt";
  letter-spacing: .05em;
  line-height: 1.6
}

header, main, footer {
  display: block
}

main{
  position: relative;
  z-index: 2;
}

footer{
  position: relative;
  z-index: 1;
}

img {
  max-width: 100%;
  height: auto;
  backface-visibility: hidden;
  line-height: 1
}

figure img {
  display: block;
  margin: auto
}

button, select, input[type=text], input[type=email], input[type=tel], textarea {
  font-family: inherit;
  font-size: inherit
}

textarea {
  display: block;
  resize: vertical
}

button, input[type=button], input[type=submit] {
  font-weight: inherit
}

label {
  cursor: pointer
}

select::-ms-expand {
  display: none
}

a {
  display: inline-block;
  backface-visibility: hidden;
  will-change: transform
}

html {
  overflow-x: hidden
}

body {
  width: 100%;
  min-height: 100%;
  background: #000;
  color: #fff;
  font-family: "Zen Old Mincho", serif;
  font-size: clamp(12px, 1.3671875vw, 16px)
}

@media only screen and (max-width: 750px) {
  body {
    overflow-x: hidden
  }
}

p {
  margin-bottom: 2em;
  line-height: 1.75
}

p:first-child {
  margin-top: 0
}

p:last-child {
  margin-bottom: 0
}

ul, ol {
  list-style-type: none
}

a {
  color: #fff;
  text-decoration: none
}

button, input[type=button], input[type=submit] {
  appearance: none;
  background: rgba(0, 0, 0, 0);
  border: none;
  border-radius: 0;
  cursor: pointer;
  transition: all .3s cubic-bezier(0.39, 0.575, 0.565, 1)
}

@media only screen and (max-width: 750px) {
  .sp_none {
    display: none
  }
}

.tb_none {
  display: none
}

@media only screen and (max-width: 750px) {
  .tb_none {
    display: block
  }
}

.pc_none {
  display: none
}

@media only screen and (min-width: 751px) {
  .pc_none {
    display: block
  }
}

@media only screen and (max-width: 750px) {
  .sp_block {
    display: block
  }
}

@media only screen and (max-width: 750px) {
  .sp_inlineBlock {
    display: inline-block
  }
}

.sp_only {
  display: none
}

@media only screen and (max-width: 750px) {
  .sp_only {
    display: inline-block
  }
}

.hp_alignC {
  text-align: center
}

.hp_alignL {
  text-align: left
}

.hp_alignR {
  text-align: right
}

.hp_floatL {
  float: left
}

.hp_floatR {
  float: right
}

.hp_smaller {
  font-size: .8em
}

.hp_bold {
  font-weight: bold
}

.hp_cf::after {
  content: "";
  display: block;
  clear: both
}

.hp_noShrink {
  flex-shrink: 0
}

@media(hover: hover) {
  .hp_tel {
    pointer-events: none
  }
}

.hp_uppercase {
  text-transform: uppercase
}

.ly_wrap {
  background: #000 url(../img/bg_body.jpg) no-repeat center bottom;
  background-size: 100%
}

@media only screen and (max-width: 750px) {
  .ly_wrap {
    background-image: url(../img/bg_body_sp.jpg)
  }
}

@media only screen and (max-width: 750px) {
  .ly_main {
    background: url(../img/bg_back_sp.jpg) no-repeat center top/100%
  }
}

.ly_header {
  width: 100%;
  height: 120px;
  padding-top: 15px;
  position: fixed;
  top: 0;
  right: 0;
  left: 0;
  z-index: 5;
  background-color: rgba(0, 0, 0, 0)
}

@media only screen and (max-width: 750px) {
  .ly_header {
    height: auto
  }
}

.ly_header.scrolled {
  background: rgba(0, 0, 0, .3);
  background: linear-gradient(0deg, rgba(0, 0, 0, 0) 0%, rgba(0, 0, 0, 0.2) 20%, rgba(0, 0, 0, 0.3) 100%)
}

.ly_hero {
  padding-top: 117px;
  min-height: 1435px;
  text-align: center;
  background: url(../img/bg_hero.jpg) no-repeat center top;
  position: relative
}

@media only screen and (max-width: 750px) {
  .ly_hero {
    padding-top: 79px;
    padding-bottom: 0;
    min-height: auto;
    background-image: url(../img/bg_hero_sp.jpg);
    background-size: 100%;
    background: none
  }
}

.ly_point {
  background: url(../img/bg_point.jpg) no-repeat center top;
  min-height: 1977px
}

@media only screen and (max-width: 750px) {
  .ly_point {
    margin-top: -15px;
    min-height: auto;
    padding: 13.3333333333vw 10px 0;
    background-image: url(../img/bg_point_sp.jpg);
    background-size: 100%;
    background: none
  }
}

.ly_movie {
  padding-top: 100px;
  min-height: 1632px;
  background: url(../img/bg_movie.jpg) no-repeat center top
}

@media only screen and (max-width: 750px) {
  .ly_movie {
    min-height: auto;
    background-size: cover
  }
}

.ly_card {
  position: relative;
  max-width: 1200px;
  margin: -80px auto 0;
  background: #000 url(../img/bg_card.jpg) no-repeat center top;
  background-size: 100% 100%
}

@media only screen and (max-width: 750px) {
  .ly_card {
    margin-top: 0;
    background: #000
  }
}

@media only screen and (max-width: 750px) {
  .ly_card::before {
    content: "";
    position: absolute;
    top: 80px;
    height: calc(100% - 80px);
    left: 0;
    right: 0;
    background: #000 url(../img/bg_card_sp.jpg) no-repeat center top;
    background-size: 100% 100%
  }
}

.ly_cardInner {
  position: relative;
  overflow: hidden;
  height: 0;
  opacity: 0;
  min-height: 0;
  padding: 0
}

.ly_cardInner.is-show {
  overflow: visible;
  height: auto;
  opacity: 1;
  transition: opacity .3s ease-in;
  min-height: 4356px;
  padding: 120px 60px
}

@media only screen and (max-width: 750px) {
  .ly_cardInner.is-show {
    min-height: auto;
    padding: 180px 20px 130px
  }
}

.ly_spec {
  margin: 80px 0 0;
  min-width: 1024px
}

@media only screen and (max-width: 750px) {
  .ly_spec {
    min-width: auto;
    margin-top: 20px
  }
}

.ly_aside {
  max-width: 1220px;
  margin: 20px auto 0;
  padding: 0 10px;
  display: flex;
  flex-wrap: wrap;
  align-items: stretch;
  gap: 20px
}

@media only screen and (max-width: 750px) {
  .ly_aside {
    margin-top: 40px;
    flex-direction: column;
    gap: 30px
  }
}

.ly_footer {
  padding: 80px 0;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .ly_footer {
    padding: 40px 0 140px
  }
}

.ly_pageTop {
  position: fixed;
  right: 40px;
  bottom: 40px
}

@media only screen and (max-width: 750px) {
  .ly_pageTop {
    right: 20px
  }
}

.bl_logo{
  position: absolute;
  top: 30px;
  left: 24px;
  display: flex;
  align-items: center;
}

@media only screen and (max-width: 1000px) {
  .bl_logo{
    top: 20px;
  }
}

.lg_ns{
  width: 60px;
}

.lg_sm{
  width: 112px;
  margin-left: 20px;
}
.lg_ps5{
  width: 100px;
  margin-left: 20px;
}
.lg_ps4{
  width: 100px;
  margin-left: 20px;
}

@media only screen and (max-width: 750px) {
  .bl_logo{
    left: 16px;
    height: 50px;
  }
  .lg_ns{
    width: clamp(30px,8vw,60px);
  }

  .lg_sm{
    width: clamp(60px,14.9vw,112px);
    margin-left: clamp(10px,2.6vw,20px);
  }
  .lg_ps5{
    width: clamp(56px,13.3vw,100px);
    margin-left: clamp(10px,2.6vw,20px);
  }
  .lg_ps4{
    width: clamp(56px,13.3vw,100px);
    margin-left: clamp(10px,2.6vw,20px);
  }
}

.ly_navArea {
  position: absolute;
  top: 15px;
  left: 0;
  right: 0
}

@media only screen and (max-width: 1520px) {
  .ly_navArea {
    top: 34px;
    height: 90px;
    padding: 0 20px 0 0;
    justify-content: center;
    flex-direction: column;
  }
}

@media only screen and (min-width: 1001px) {
  .ly_navArea {
    display: flex !important;
  }
}

@media only screen and (max-width: 1000px) {
  .ly_navArea {
    display: none;
    position: fixed;
    top: 0;
    width: 100%;
    height: 100%;
    z-index: 50;
    overflow: auto;
    padding: 90px 50px 0;
    background: #030000
  }
  .ly_navArea.menuOpen {
    display: block
  }
}

@media only screen and (min-width: 1521px) {
  .ly_navArea {
    display: block !important
  }
}

.ly_globalNav {
  height: clamp(50px, 6.4285714286vw, 90px);
  display: flex;
  align-items: center;
  justify-content: center;
  margin: auto
}

@media only screen and (max-width: 1520px) {
  .ly_globalNav {
    height: auto;
    justify-content: flex-end;
    margin: 0 0 0 auto;
  }
}

@media only screen and (max-width: 1000px) {
  .ly_globalNav {
    display: flex;
    flex-direction: column;
    height: auto;
    margin: auto;
  }
}

@media only screen and (max-width: 750px) {
  .ly_globalNav {
    align-items: flex-start;
  }
}

.bl_menuList {
  display: flex;
  gap: 2.1428571429vw;
  padding: 0 45px
}

@media only screen and (max-width: 1000px) {
  .bl_menuList {
    margin-bottom: 30px;
    padding: 0;
    flex-direction: column;
    gap: 20px
  }
}

.bl_menuListItem a {
  display: inline-block;
  padding: 0 15px;
  white-space: nowrap
}

@media only screen and (max-width: 1620px) {
  .bl_menuListItem a {
    padding: 0;
  }
}

@media only screen and (max-width: 1000px) {
  .bl_menuListItem a {
    font-size: 24px
  }
}

.el_langSelect {
  display: block;
  width: 110px;
  height: 25px;
  padding-left: 10px;
  position: relative;
  appearance: none;
  background: url(../img/bg_langSelect.png) no-repeat left top;
  border: none;
  color: #fff;
  line-height: 25px
}

@media only screen and (max-width: 1000px) {
  .el_langSelect {
    margin-bottom: 50px;
    width: 177.5px;
    height: 40px;
    background-image: url(../img/bg_langSelect_sp.png);
    background-size: cover;
    font-size: 24px
  }
}

.el_langSelect option{
  color: #000;
}

.ly_shareMenuArea {
  position: absolute;
  top: 0;
  right: 60px;
  height: clamp(50px, 6.4285714286vw, 90px);
  display: flex;
  align-items: center
}

@media only screen and (max-width: 1520px) {
  .ly_shareMenuArea {
    position: relative;
    right: 0;
    height: auto;
    justify-content: flex-end;
    margin-top: 20px;
  }
}

@media only screen and (max-width: 1000px) {
  .ly_shareMenuArea {
    position: relative;
    right: auto;
    height: auto;
    margin-top: 0;
    justify-content: center;
  }
}

@media only screen and (max-width: 750px) {
  .ly_shareMenuArea {
    justify-content: flex-start;
  }
}

.bl_shareMenuList {
  display: flex;
  align-items: center;
  gap: 10px
}

@media only screen and (max-width: 1000px) {
  .bl_shareMenuList {
    margin-top: 0;
    flex-direction: column;
    align-items: flex-start;
    gap: 15px
  }
}

.bl_shareMenuList li {
  height: 20px
}

.bl_shareMenuList li .fb_iframe_widget span {
  vertical-align: top !important
}

.bl_shareMenuList li .el_lineBtn {
  width: 80px
}

.el_menuBtn {
  width: 50px;
  height: 50px;
  padding: 10px;
  background: #fff;
  border-radius: 50%;
  position: absolute;
  top: 15px;
  right: 15px;
  display: flex;
  gap: 7px;
  flex-direction: column;
  justify-content: center;
  z-index: 100
}

@media only screen and (max-width: 1000px) {
  .el_menuBtn{
    top: 20px;
  }
}

.el_menuBtn span {
  display: block;
  width: 30px;
  height: 1px;
  background-color: #030000;
  transition: all .3s ease
}

.el_menuBtn span:last-child {
  width: 15px
}

.el_menuBtn.active span:first-child {
  transform-origin: left;
  transform: rotate(45deg) translate(1px, -5px)
}

.el_menuBtn.active span:nth-child(2) {
  transform-origin: left;
  transform: rotate(-45deg) translate(-4px, 11px)
}

.el_menuBtn.active span:last-child {
  opacity: 0
}

@media only screen and (min-width: 1001px) {
  .el_menuBtn {
    display: none
  }
}

.bl_switchIframeWrap {
  margin-top: -180px;
  margin-bottom: 377px;
  padding: 46px;
  margin-left: auto;
  margin-right: auto;
  position: relative;
  background: url(../img/img_switchBody.png) no-repeat center top;
  width: 895px;
  height: 466px;
  margin-top: -230px;
  margin-bottom: 320px;
  padding: 0
}

@media only screen and (max-width: 750px) {
  .bl_switchIframeWrap {
    width: auto;
    height: auto;
    margin: -75px 0 180px;
    background-size: 90%;
    padding: 52.0670391061% 0 0 0
  }
}

.bl_switchIframeWrap iframe, .bl_switchIframeWrap img, .bl_switchIframeWrap video {
  position: absolute;
  top: 46px;
  left: 178px;
  aspect-ratio: 16/9;
  top: 99px;
  left: 206px
}

@media only screen and (max-width: 750px) {
  .bl_switchIframeWrap iframe, .bl_switchIframeWrap img, .bl_switchIframeWrap video {
    height: auto;
    left: 50%;
    transform: translateX(-50%);
    top: 19%;
    width: 49%
  }
}

.bl_txtShinka, .bl_txtRelease {
  margin-bottom: 0;
  position: relative;
  z-index: 2
}

@media only screen and (max-width: 750px) {
  .bl_txtShinka, .bl_txtRelease {
    padding: 0 20px
  }
}

.bl_siteTitle {
  margin-top: -180px;
  margin-top: max(-12.8571428571vw, -180px);
  position: relative;
  z-index: 1
}

@media only screen and (max-width: 750px) {
  .bl_siteTitle {
    margin: -20.5333333333vw -30px 0
  }
}

.bl_txtRelease {
  position: relative
}

.bl_txtRelease p {
  margin: 0
}

.bl_txtRelease img {
  display: block;
  margin: auto;
  line-height: 1
}

.bl_txtRelease img.el_txtPrice {
  margin-top: -5px
}

@media only screen and (max-width: 750px) {
  .bl_txtRelease img.el_txtPrice {
    width: 75%;
    max-width: 345px
  }
}

.el_btnBadge {
  cursor: pointer;
  width: 161px
}

@media only screen and (max-width: 750px) {
  .el_btnBadge {
    width: 90px
  }
}

@media only screen and (max-width: 750px) {
  .bl_linkKiyaku, .bl_linkUpdate {
    display: inline-block;
    margin: 0 7px
  }
}

.bl_linkKiyaku {
  position: absolute;
  top: 40px;
  left: calc(50% + min(50vw - 161px, 272.5px));
  z-index: 3
}

@media only screen and (max-width: 750px) {
  .bl_linkKiyaku {
    position: relative;
    top: 0;
    left: 0;
    padding-top: 10px
  }
}

.bl_linkUpdate {
  position: absolute;
  top: 40px;
  right: calc(50% + min(50vw - 161px, 272.5px));
  z-index: 3
}

@media only screen and (max-width: 750px) {
  .bl_linkUpdate {
    position: relative;
    top: 0;
    left: 0;
    padding-top: 10px
  }
}

.bl_txtShinka, .bl_siteTitle, .bl_switchIframeWrap, .bl_txtRelease {
  opacity: 0;
  animation: fadeAnime .5s linear forwards
}

.bl_txtShinka {
  animation-delay: .8s
}

.bl_siteTitle {
  animation-delay: 1s
}

.bl_switchIframeWrap {
  animation-delay: 1.4s
}

.bl_txtRelease {
  animation-delay: 2s
}

@keyframes fadeAnime {
  0% {
    opacity: 0
  }
  100% {
    opacity: 1
  }
}

.bl_pointSec {
  max-width: 1200px;
  height: 553px;
  margin: 0 auto;
  padding-right: min(5.7142857143vw, 100px);
  padding-left: min(5vw, 70px);
  background: url(../img/border_point.png) no-repeat center top
}

.bl_pointSec:not(:last-child) {
  margin-bottom: 100px
}

@media only screen and (max-width: 750px) {
  .bl_pointSec:not(:last-child) {
    margin-bottom: 60px
  }
}

@media only screen and (max-width: 750px) {
  .bl_pointSec {
    padding: 0 25px 0 20px;
    max-width: 356px;
    height: 606px;
    background-image: url(../img/border_point_sp.png);
    background-size: 100%
  }
}

.bl_pointSec.bl_pointSec3 {
  height: 626px;
  background: url(../img/border_point_l.png) no-repeat center top
}

@media only screen and (max-width: 750px) {
  .bl_pointSec.bl_pointSec3 {
    height: 702px;
    background-image: url(../img/border_point_l_sp.png);
    background-size: 100%
  }
}

.bl_pointTitle {
  height: 99px;
  padding-top: 18px;
  position: relative;
  top: -20px;
  background: url(../img/bg_pointTitle.png) no-repeat center top;
  color: #4e452d;
  font-size: 32px;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_pointTitle {
    padding-top: 9px;
    width: 262.5px;
    height: 60px;
    margin: auto;
    left: 3px;
    background-image: url(../img/bg_pointTitle_sp.png);
    background-size: 100%;
    font-size: 19px
  }
}

.bl_pointTitle .el_pointNum {
  display: block;
  font-size: 18px;
  line-height: 1;
  text-indent: .5em
}

@media only screen and (max-width: 750px) {
  .bl_pointTitle .el_pointNum {
    font-size: 12px
  }
}

@media only screen and (max-width: 750px) {
  .bl_pointTitle.bl_playerTitle {
    font-size: 16px
  }
  .bl_pointTitle.bl_playerTitle .el_pointNum {
    margin-bottom: 4px
  }
}

.ly_pointBody {
  display: flex;
  flex-direction: row-reverse;
  align-items: center;
  justify-content: space-between;
  margin-top: 10px
}

@media only screen and (max-width: 750px) {
  .ly_pointBody {
    flex-direction: column-reverse;
    margin-top: -8px
  }
}

.bl_pointText {
  width: 46%
}

@media only screen and (max-width: 750px) {
  .bl_pointText {
    width: auto;
    margin-top: 10px;
    padding: 0 20px
  }
}

.bl_pointText p {
  text-align: justify;
  letter-spacing: 0
}

.bl_pointSubTitle {
  margin-bottom: 20px;
  font-size: 28px;
  text-indent: -0.5em
}

@media only screen and (max-width: 750px) {
  .bl_pointSubTitle {
    margin-bottom: 11px;
    font-size: 18px;
    letter-spacing: 0;
    text-align: center
  }
}

.bl_pointImg {
  width: 500px;
  height: 343px;
  background: url(../img/border_pointImg.png) no-repeat left top/100%;
  position: relative;
  flex-shrink: 0
}

@media only screen and (max-width: 750px) {
  .bl_pointImg {
    width: 310px;
    height: 210px
  }
}

.bl_pointImg>.bl_pointSlider {
  opacity: 0;
  position: absolute;
  top: 53px;
  left: 46px;
  width: 84%
}

@media only screen and (max-width: 750px) {
  .bl_pointImg>.bl_pointSlider {
    top: 33px;
    left: 29px
  }
}

.bl_pointImg>.bl_pointSlider.slick-initialized {
  opacity: 1
}

.bl_pointImg>.bl_pointSlider .slick-slide {
  transition: opacity .2s
}

.bl_pointThumb {
  display: flex;
  gap: 10px
}

.bl_pointThumb>div {
  max-width: 115px;
  border: 3px solid #d9bf5b
}

@media only screen and (max-width: 750px) {
  .bl_pointThumb>div {
    border-width: 1.5px
  }
}

.bl_pointThumb>div img {
  display: block;
  transition: filter .2s
}

.bl_pointThumb>div.current img {
  filter: brightness(0.4)
}

.bl_appendix {
  margin-top: 20px;
  letter-spacing: .02em;
  line-height: 1.4;
  text-align: justify
}

@media only screen and (max-width: 750px) {
  .bl_appendix {
    margin-top: 15px;
    padding: 0 20px;
    line-height: 1.2
  }
}

.bl_movieTitle {
  width: 580px;
  height: 100px;
  margin: auto;
  background: url(../img/bg_movieTitle.png) no-repeat center top;
  font-size: 32px;
  display: flex;
  align-items: center;
  justify-content: center
}

@media only screen and (max-width: 750px) {
  .bl_movieTitle {
    width: auto;
    width: 289.5px;
    height: 50px;
    background-size: 100%;
    font-size: 18px
  }
}

.ly_movieWrap {
  max-width: 1202px;
  margin: auto;
  padding-top: 220px;
  padding-bottom: 200px;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  background: url(../img/bg_movieCircle.png) no-repeat center top
}

@media only screen and (max-width: 750px) {
  .ly_movieWrap {
    padding-top: 60px;
    padding-bottom: 60px;
    background-image: url(../img/bg_movieCircle_sp.png);
    background-position: center -40px;
    background-size: 665px auto
  }
}

.bl_movieItem {
  position: relative;
  padding-bottom: 80px;
  margin: auto;
  max-width: 600px;
  width: 100%;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_movieItem {
    padding-bottom: 30px
  }
}

.bl_movieItem:first-child {
  max-width: none
}

.bl_movieItem::after {
  content: "";
  display: block;
  background: url(../img/bg_movieShadow.png) no-repeat center bottom 40px;
  mix-blend-mode: multiply;
  width: 600px;
  height: 246px;
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto
}

@media only screen and (max-width: 750px) {
  .bl_movieItem::after {
    background: none;
    background-image: radial-gradient(closest-side, rgba(0, 0, 0, 0.6), rgba(255, 255, 255, 0));
    width: 320px;
    height: 50px;
    top: 80px
  }
}

.bl_movieItem iframe {
  display: block;
  margin: auto;
  max-width: 480px;
  width: 100%;
  height: auto;
  position: relative;
  border: 1px solid #000;
  border-radius: 3px;
  aspect-ratio: 16/9;
  z-index: 1
}

@media only screen and (max-width: 750px) {
  .bl_movieItem iframe {
    width: 240px
  }
}

.bl_movieItem img {
  max-width: 480px;
  width: 100%;
  height: auto;
  position: relative;
  border: 1px solid #000;
  border-radius: 3px;
  aspect-ratio: 16/9;
  z-index: 1
}

@media only screen and (max-width: 750px) {
  .bl_movieItem img {
    width: 240px
  }
}

.bl_movieItem p {
  position: relative;
  margin: 10px 0 0;
  z-index: 1;
  font-size: 24px
}

@media only screen and (max-width: 750px) {
  .bl_movieItem p {
    margin-top: 7px;
    font-size: 12px
  }
}

.bl_cardTitle {
  width: 600px;
  height: 100px;
  margin: auto;
  background: url(../img/bg_cardTitle.png) no-repeat center top;
  font-size: 32px;
  display: flex;
  align-items: center;
  justify-content: center
}

@media only screen and (max-width: 750px) {
  .bl_cardTitle {
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    width: 300px;
    height: 49px;
    margin: auto;
    background-size: 100%;
    font-size: 18px
  }
}

.bl_cardTitle span {
  display: inline-block;
  margin-left: .5em;
  font-size: 24px;
  text-transform: lowercase
}

@media only screen and (max-width: 750px) {
  .bl_cardTitle span {
    font-size: 12px
  }
}

.bl_cardTab {
  display: block;
  position: absolute;
  top: -1px;
  right: 0;
  width: 465px;
  height: 405px;
  background: url(../img/bg_cardTab.png) no-repeat
}

@media only screen and (max-width: 750px) {
  .bl_cardTab {
    width: 227px;
    height: 227px;
    top: 79px;
    background-size: 100%
  }
}

.bl_cardTab .bl_cardTabBtn {
  position: absolute;
  top: 0;
  right: 0;
  width: 226px;
  height: 226px;
  margin: 0 0 0 auto;
  opacity: 1;
  z-index: 1
}

@media only screen and (max-width: 750px) {
  .bl_cardTab .bl_cardTabBtn {
    width: 113px;
    height: 113px
  }
}

.bl_cardTab .bl_cardTabBtn.active {
  opacity: 0;
  z-index: -1
}

.bl_cardTab .bl_tabList {
  position: absolute;
  top: 75px;
  right: 25px;
  color: #4e452d;
  font-size: 24px;
  line-height: 1.4;
  transform: rotate(45deg);
  transform-origin: left top;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_cardTab .bl_tabList {
    top: 38px;
    right: 14px;
    font-size: 11px
  }
}

.bl_cardTab .bl_tabList span {
  display: block;
  font-size: 18px;
  text-transform: lowercase
}

@media only screen and (max-width: 750px) {
  .bl_cardTab .bl_tabList span {
    font-size: 9px
  }
}

.bl_cardTab .bl_tabTxt {
  position: absolute;
  top: 25px;
  right: 35px;
  width: 82px;
  padding: 0 2px;
  padding-bottom: 5px;
  background: url(../img/arrow_next.svg) no-repeat center bottom;
  color: #fff5ab;
  font-size: 31px;
  letter-spacing: .06em
}

@media only screen and (max-width: 750px) {
  .bl_cardTab .bl_tabTxt {
    top: 10px;
    right: 15px;
    width: 41px;
    background-size: 100%;
    font-size: 15px
  }
}

.bl_cardTab .bl_tabTxtPrev {
  transform: scale(-1, 1)
}

.bl_cardTab .bl_tabTxtPrev span {
  display: block;
  transform: scale(-1, 1)
}

.bl_cardTab .bl_tabTxt.comingsoon {
  right: 20px;
  width: auto;
  background: none;
  line-height: 1;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_cardTab .bl_tabTxt.comingsoon {
    right: 8px
  }
}

.ly_cardList {
  max-width: 1000px;
  margin: 50px auto;
  display: flex;
  flex-wrap: wrap;
  gap: 10px
}

@media only screen and (max-width: 750px) {
  .ly_cardList {
    margin-top: 0;
    margin-bottom: 30px;
    display: block
  }
}

.bl_cardItem {
  flex-basis: calc(50% - 5px);
  margin-bottom: 90px
}

@media only screen and (max-width: 750px) {
  .bl_cardItem {
    margin: 0;
    overflow: hidden;
    height: 0;
    opacity: 0;
    min-height: 0;
    padding: 0
  }
}

@media only screen and (max-width: 750px) {
  .bl_cardItem.is-show {
    overflow: visible;
    height: auto;
    opacity: 1;
    transition: opacity .3s ease-in;
    margin: 0 0px 50px
  }
}

.el_cardImg {
  position: relative;
  z-index: 1
}

@media only screen and (max-width: 750px) {
  .el_cardImg {
    max-width: 225px;
    margin: auto
  }
}

.bl_cardDesc {
  min-height: 230px;
  margin-top: -3px;
  padding-top: 10px;
  position: relative;
  background: url(../img/bg_cardItemTxt_02.png) repeat-y center 50px;
  background-size: 100%;
  color: #4e452d
}

@media only screen and (max-width: 750px) {
  .bl_cardDesc {
    width: 289px;
    min-height: auto;
    margin: -7px auto;
    padding-bottom: 5px;
    background-size: 100%
  }
}

.bl_cardDesc::before {
  content: "";
  display: block;
  width: 100%;
  height: 50px;
  position: absolute;
  top: -50px;
  background: url(../img/bg_cardItemTxt_01.png) no-repeat center top;
  background-size: 100% 100%
}

@media only screen and (max-width: 750px) {
  .bl_cardDesc::before {
    top: -30px;
    height: 30px;
    background-size: 100%
  }
}

.bl_cardDesc::after {
  content: "";
  display: block;
  width: 100%;
  height: 50px;
  position: absolute;
  bottom: -50px;
  background: url(../img/bg_cardItemTxt_03.png) no-repeat center top;
  background-size: 100% 100%
}

@media only screen and (max-width: 750px) {
  .bl_cardDesc::after {
    bottom: -30px;
    height: 30px;
    background-size: 100%
  }
}

.el_cardName {
  height: 48px;
  line-height: 48px;
  background: url(../img/bg_cardItemTitle.png) no-repeat center;
  font-size: 24px;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .el_cardName {
    width: 197px;
    height: 35px;
    margin: auto;
    line-height: 35px;
    background-size: 100%;
    font-size: 18px
  }
}

.bl_cardText {
  padding: 0 30px
}

.bl_cardText .el_cardEffect {
  margin: 14px 0 3px;
  font-size: 18px;
  letter-spacing: -0.01em;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_cardText .el_cardEffect {
    margin: 1em 0 8px;
    font-size: 13.5px
  }
}

.bl_cardText .bl_cardTextBody {
  margin: 0;
  padding: 0 45px;
  letter-spacing: -0.01em;
  line-height: 1.5;
  text-align: justify
}

@media only screen and (max-width: 750px) {
  .bl_cardText .bl_cardTextBody {
    padding: 0 30px;
    font-size: 12px
  }
}

.bl_cardListMore {
  width: 217.5px;
  margin: auto
}

@media only screen and (min-width: 751px) {
  .bl_cardListMore {
    display: none
  }
}

.bl_sellLink {
  position: fixed;
  right: 60px;
  bottom: 40px;
  z-index: 10
}

@media only screen and (max-width: 750px) {
  .bl_sellLink {
    right: 0;
    left: 0;
    bottom: -10px;
    text-align: center
  }
}

.bl_sellLink a {
  font-size: 0;
  width: 333px;
  height: 124px;
  margin: auto;
  display: block;
  background: url(../img/btn_buy.png) no-repeat center
}

@media only screen and (max-width: 750px) {
  .bl_sellLink a {
    width: auto;
    max-width: 367px;
    min-height: 89px;
    background-size: contain
  }
}

.ly_asideItem {
  flex: 1;
  width: 500px
}

@media only screen and (max-width: 750px) {
  .ly_asideItem {
    width: auto
  }
}

.bl_asideTitle {
  height: 48px;
  position: relative;
  z-index: 1;
  line-height: 48px;
  background: url(../img/bg_asideTitle.png) no-repeat center center;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_asideTitle {
    width: 198px;
    height: 36.5px;
    line-height: 36.5px;
    margin: auto;
    background-image: url(../img/bg_asideTitle_sp.png);
    background-size: 100%;
    font-size: 18px
  }
}

.bl_asideBody {
  margin-top: -28px;
  padding: 50px 32px 30px 26px;
  background: url(../img/bg_asideBody.png) no-repeat center top;
  background-size: 100% 100%
}

@media only screen and (max-width: 750px) {
  .bl_asideBody {
    width: 341.5px;
    height: 360px;
    margin: -20px auto 0;
    background-image: url(../img/bg_asideBody_sp.png);
    background-size: 100%
  }
}

.bl_asideBody a {
  display: flex;
  align-items: center;
  gap: 16px
}

@media only screen and (max-width: 750px) {
  .bl_asideBody a {
    flex-direction: column;
    gap: 24px
  }
}

.bl_asideImg {
  width: 45.3488372093%;
  flex-shrink: 0
}

@media only screen and (max-width: 750px) {
  .bl_asideImg {
    max-width: 260px;
    width: 100%
  }
}

.bl_asideText {
  font-size: 22px
}

@media only screen and (max-width: 750px) {
  .bl_asideText {
    text-align: center;
    font-size: 18px
  }
}

.bl_asideText dt {
  display: flex;
  align-items: center;
  margin-bottom: 18px;
  letter-spacing: 0;
  line-height: 1;
  text-indent: -0.5em
}

@media only screen and (max-width: 750px) {
  .bl_asideText dt {
    justify-content: center
  }
}

.bl_asideText dt span {
  margin-left: 1em;
  font-size: 16px
}

@media only screen and (max-width: 750px) {
  .bl_asideText dt span {
    font-size: 14px
  }
}

.bl_asideText dd {
  font-size: 14px;
  letter-spacing: -0.02em;
  line-height: 1.4;
  text-align: justify
}

@media only screen and (max-width: 750px) {
  .bl_asideText dd {
    font-size: 12px;
    line-height: 1.6
  }
}

.ly_specInner {
  max-width: 1236px;
  height: 525px;
  margin: auto;
  padding: 60px;
  background: url(../img/bg_spec.png) no-repeat center top;
  background-size: 100% 100%
}

@media only screen and (max-width: 750px) {
  .ly_specInner {
    max-width: none;
    width: 100%;
    height: auto;
    padding: 40px 25px 20px;
    background-image: url(../img/bg_spec_sp.png)
  }
}

.bl_specTitle {
  background: url(../img/bg_specTitle.png) no-repeat center center;
  font-size: 36px;
  text-align: center
}

@media only screen and (max-width: 750px) {
  .bl_specTitle {
    background-image: url(../img/bg_specTitle_sp.png);
    background-size: 100%;
    font-size: 27px
  }
}

.bl_specList {
  max-width: 1000px;
  margin: 50px auto;
  columns: 2;
  column-gap: 0;
  border-bottom: 1px solid #898989
}

@media only screen and (max-width: 750px) {
  .bl_specList {
    columns: 1
  }
}

.bl_spedcListItem {
  display: flex;
  padding: 18px 0 18px 20px;
  border-top: 1px solid #898989
}

@media only screen and (max-width: 750px) {
  .bl_spedcListItem {
    padding: 13px 10px
  }
}

.bl_spedcListItem::before {
  content: "";
  display: inline-block;
  background: url(../img/ico_crown.png) no-repeat;
  background-size: contain;
  margin-top: 3px;
  margin-right: 1.25em;
  width: 21px;
  height: 17px;
  flex-shrink: 0
}

@media only screen and (max-width: 750px) {
  .bl_spedcListItem::before {
    width: 15px !important;
    height: auto !important;
    flex-shrink: 0
  }
}

.bl_spedcListItem small {
  display: inline-block;
  line-height: 1.6;
  margin-top: .5em
}

.bl_notice {
  font-family: sans-serif;
  font-size: 12px
}

@media only screen and (max-width: 750px) {
  .bl_notice {
    font-size: 9px
  }
}

.bl_footerBody {
  display: flex;
  justify-content: center;
  column-gap: 30px;
  font-family: sans-serif;
  text-align: left
}

@media only screen and (max-width: 750px) {
  .bl_footerBody {
    flex-direction: column;
    align-items: center
  }
}

.bl_furyuLogo {
  margin-top: 5px
}

.bl_furyuLogo a {
  display: block
}

.bl_footerMenu {
  margin-bottom: 5px;
  display: flex
}

.bl_footerMenu li {
  line-height: 1
}

.bl_footerMenu li:not(:last-child)::after {
  content: "|";
  margin: 0 1em;
  padding: 2px 0;
  display: inline-block;
  vertical-align: top
}

.bl_footerMenu a {
  padding: 5px 0;
  display: inline-block;
  font-size: 14px
}

@media only screen and (max-width: 750px) {
  .bl_footerMenu a {
    font-size: 11px
  }
}

.bl_credit {
  font-size: 12px;
  line-height: 1.6
}

@media only screen and (max-width: 750px) {
  .bl_credit {
    font-size: 9px
  }
}

.ly_guideWrap {
  max-width: 680px;
  margin: auto;
  padding-top: 3.8571428571vw;
  padding-bottom: 1.4285714286vw;
  box-sizing: content-box;
  background-color: #000;
  color: #fff
}

.bl_guideTitle {
  font-size: 18px;
  text-align: center;
  margin-bottom: 2em
}

.bl_guideSecTitle {
  font-size: 16px
}

.bl_guideList {
  margin-bottom: 2em
}

.bl_guideList li::before {
  content: "・"
}

.bl_guideList p {
  margin: 2em 0
}

.el_close {
  display: none
}

.modaal-container .el_close {
  display: inline-block;
  line-height: 1;
  position: relative;
  top: 0;
  right: auto;
  width: auto;
  height: auto;
  border-radius: 0
}

.modaal-container .el_close::before, .modaal-container .el_close::after {
  content: none
}

.modaal-container .el_close:hover, .modaal-container .el_close:focus {
  background-color: rgba(0, 0, 0, 0);
  opacity: .7
}
