/*! sanitize.css v4.1.0 | CC0 License | github.com/jonathantneal/sanitize.css */ article, aside, details, figcaption, figure, footer, header, main, menu, nav, section, summary {
  display: block
}
audio, canvas, progress, video {
  display: inline-block
}
audio:not([controls]) {
  display: none;
  height: 0
}
template, [hidden] {
  display: none
}
*, ::before, ::after {
  background-repeat: no-repeat;
  -webkit-box-sizing: inherit;
  box-sizing: inherit
}
::before, ::after {
  text-decoration: inherit;
  vertical-align: inherit
}
html {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  cursor: default;
  font-family: sans-serif;
  line-height: 1.5;
  -ms-text-size-adjust: 100%;
  -webkit-text-size-adjust: 100%
}
body {
  margin: 0
}
h1 {
  font-size: 2em;
  margin: .67em 0
}
code, kbd, pre, samp {
  font-family: monospace, monospace;
  font-size: 1em
}
hr {
  height: 0;
  overflow: visible
}
nav ol, nav ul {
  list-style: none
}
abbr[title] {
  border-bottom: 1px dotted;
  text-decoration: none
}
b, strong {
  font-weight: inherit
}
b, strong {
  font-weight: bolder
}
dfn {
  font-style: italic
}
mark {
  background-color: #ffff00;
  color: #000000
}
progress {
  vertical-align: baseline
}
small {
  font-size: 83.3333%
}
sub, sup {
  font-size: 83.3333%;
  line-height: 0;
  position: relative;
  vertical-align: baseline
}
sub {
  bottom: -.25em
}
sup {
  top: -.5em
}
::-moz-selection {
  background-color: #b3d4fc;
  color: #000000;
  text-shadow: none
}
::selection {
  background-color: #b3d4fc;
  color: #000000;
  text-shadow: none
}
audio, canvas, iframe, img, svg, video {
  vertical-align: middle
}
img {
  border-style: none
}
svg {
  fill: currentColor
}
svg:not(:root) {
  overflow: hidden
}
a {
  background-color: transparent;
  -webkit-text-decoration-skip: objects
}
a:hover {
  outline-width: 0
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
button, input, select, textarea {
  background-color: transparent;
  border-style: none;
  color: inherit;
  font-size: 1em;
  margin: 0
}
button, input {
  overflow: visible
}
button, select {
  text-transform: none
}
button, html [type="button"], [type="reset"], [type="submit"] {
  -webkit-appearance: button
}
::-moz-focus-inner {
  border-style: none;
  padding: 0
}
:-moz-focusring {
  outline: 1px dotted ButtonText
}
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: .35em .625em .75em
}
legend {
  display: table;
  max-width: 100%;
  padding: 0;
  white-space: normal
}
textarea {
  overflow: auto;
  resize: vertical
}
[type="checkbox"], [type="radio"] {
  padding: 0
}
::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
  height: auto
}
[type="search"] {
  -webkit-appearance: textfield;
  outline-offset: -2px
}
::-webkit-search-cancel-button, ::-webkit-search-decoration {
  -webkit-appearance: none
}
::-webkit-input-placeholder {
  color: inherit;
  opacity: .54
}
::-webkit-file-upload-button {
  -webkit-appearance: button;
  font: inherit
}
[aria-busy="true"] {
  cursor: progress
}
[aria-controls] {
  cursor: pointer
}
[aria-disabled] {
  cursor: default
}
a, area, button, input, label, select, textarea, [tabindex] {
  -ms-touch-action: manipulation;
  touch-action: manipulation
}
[hidden][aria-hidden="false"] {
  clip: rect(0, 0, 0, 0);
  display: inherit;
  position: absolute
}
[hidden][aria-hidden="false"]:focus {
  clip: auto
}
*, *:after, *:before {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;
  font-smoothing: antialiased;
  text-rendering: optimizeLegibility
}
a, abbr, acronym, address, applet, article, aside, audio, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  font-size: 100%;
  font: inherit;
  vertical-align: baseline
}
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section {
  display: block
}
html {
  line-height: 1;
  font-size: 1.21951vw;
  font-family: "Noto Serif JP", "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;
  line-break: strict;
  overflow-wrap: break-word
}
@media (max-width: 640px) {
  html {
    font-size: 4.268vw
  }
}
@media (min-width: 1312px) {
  html {
    font-size: 16px
  }
}
body {
  color: #000;
  position: relative;
  letter-spacing: .125rem;
  font-weight: 400;
  font-style: normal
}
@media (max-width: 640px) {
  body {
    width: 100%;
    min-width: initial;
    min-width: auto;
    font-size: .9375rem
  }
}
body.fixed {
  height: 100%;
  overflow: hidden
}
body.remodal-is-opened {
  overflow: hidden;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5)
}
ol, ul {
  list-style: none
}
blockquote, q {
  quotes: none
}
blockquote:after, blockquote:before, q:after, q:before {
  content: "";
  content: none
}
table {
  border-collapse: collapse;
  border-spacing: 0
}
table td {
  border: none
}
a {
  color: #000;
  text-decoration: none;
  -webkit-transition: .3s;
  transition: .3s
}
a:hover {
  text-decoration: underline
}
img {
  max-width: 100%;
  height: auto;
  vertical-align: bottom
}
a img:hover {
  opacity: 0.7;
  -webkit-transition: .3s;
  transition: .3s
}
strong {
  font-weight: bold
}
p {
  line-height: 1.8
}
@media (max-width: 640px) {
  .only-pc {
    display: none
  }
}
.only-sp {
  display: none
}
@media (max-width: 640px) {
  .only-sp {
    display: block
  }
}
.container {
  width: 65rem;
  padding: 0 1.25rem;
  margin: 0 auto
}
@media (max-width: 640px) {
  .container {
    width: 100%
  }
}
.s-container {
  width: 46.875rem;
  padding: 0 1.25rem;
  margin: 0 auto
}
@media (max-width: 640px) {
  .s-container {
    width: 100%
  }
}
.navToggle {
  display: none;
  margin: auto;
  width: 2.8125rem;
  height: 2.8125rem;
  position: fixed;
  top: 2.5rem;
  right: 1.25rem;
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  cursor: pointer;
  z-index: 10000;
  text-align: center;
  background: #fff
}
@media (max-width: 640px) {
  .navToggle {
    top: 1.25rem
  }
}
.navToggle span {
  display: block;
  position: absolute;
  margin: auto;
  top: 0;
  left: 0;
  right: 0;
  width: 1.25rem;
  height: 2px;
  background: #000;
  border-radius: 50px;
  -webkit-transition: .35s ease-in-out;
  transition: .35s ease-in-out
}
.navToggle span:nth-child(1) {
  top: 1rem
}
.navToggle span:nth-child(2) {
  top: 1.3125rem
}
.navToggle span:nth-child(3) {
  top: 1.625rem;
  width: .75rem;
  right: auto;
  left: .8125rem
}
.navToggle.active {
  background: #000
}
.navToggle.active:after {
  content: '';
  width: 2.8125rem;
  height: 2.8125rem;
  display: block;
  border-right: .375rem solid #333;
  border-bottom: .375rem solid #333;
  position: absolute;
  top: .375rem;
  left: .375rem;
  z-index: 1
}
.navToggle.active span {
  background: #fff
}
.navToggle.active span:nth-child(1) {
  top: 1.3125rem;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.navToggle.active span:nth-child(2) {
  top: 1.3125rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg)
}
.navToggle.active span:nth-child(3) {
  top: 1.3125rem;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  width: 1.25rem;
  left: 0;
  right: 0;
  opacity: 0
}
.nav-menu {
  display: none;
  opacity: 0;
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 1000;
  background: rgba(0, 0, 0, 0.8);
  /* -webkit-animation: fade-in .3s ease-in 0s forwards;
  animation: fade-in .3s ease-in 0s forwards */
}
.nav-menu.active {
  opacity: 1;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center
}
.nav-menu h1 {
  position: absolute;
  top: 1.875rem;
  left: 3.125rem
}
@media (max-width: 640px) {
  .nav-menu h1 {
    left: 1.25rem;
    width: 70%
  }
}
.nav-menu .nav-menuList {
  padding-top: 9.375rem;
  font-weight: 500;
  font-size: 1.375rem;
  text-align: center
}
.nav-menu .nav-menuList li {
  margin-bottom: 1.875rem;
  letter-spacing: 2px
}
.nav-menu .nav-menuList a {
  color: #FFF
}
.nav-menu .nav-menuList a:hover {
  text-decoration: none;
  opacity: 0.7
}
.nav-menu .nav-menuList a.btn-header {
  width: 13.75rem;
  height: 3.125rem;
  border: 2px solid #fff;
  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: 2.8125rem
}
.nav-menu .nav-menuList a.btn-header:hover {
  text-decoration: none;
  background: #000;
  color: #fff;
  opacity: 1
}
.btn-wb {
  width: 100%;
  height: 3.75rem;
  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;
  font-size: 1.125rem;
  font-weight: 700;
  cursor: pointer;
  -webkit-transition: .3s;
  transition: .3s;
  color: #FFF;
  border: 2px solid #fff
}
.btn-wb:hover {
  text-decoration: none;
  background: rgba(0, 0, 0, 0.8)
}
.pageHeader {
  width: 100%;
  padding: 2.8125rem 3.125rem;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 100
}
.pageHeader .pageHeader__inner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center
}
.pageHeader .pageHeader__inner h1 {
  width: 19.6875rem
}
@media (max-width: 640px) {
  .pageHeader .pageHeader__inner h1 {
    text-align: center;
    width: 100%
  }
}
.nav-global {
  margin: 0 0 0 auto
}
@media (max-width: 640px) {
  .nav-global {
    display: none
  }
}
.nav-global .globalNav {
  font-weight: 700;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  letter-spacing: 1px
}
.nav-global .globalNav li {
  margin: 0 1.25rem
}
.nav-global .globalNav a {
  color: #fff
}
.nav-global .globalNav a:hover {
  text-decoration: none;
  color: #000
}
.nav-global .globalNav a.btn-header {
  width: 13.75rem;
  height: 3.125rem;
  border: 2px solid #fff;
  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
}
.nav-global .globalNav a.btn-header:hover {
  text-decoration: none;
  background: #000;
  color: #fff
}
.commonBannar {
  background: #FFF;
  padding: 2.8125rem 0
}
.commonBannar .commonBannar__inner {
  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: 0 -.46875rem;
  width: 37.5rem;
  margin: 0 auto
}
@media (max-width: 640px) {
  .commonBannar .commonBannar__inner {
    width: 100%;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin: -1.25rem 0
  }
}
.commonBannar .commonBannar__inner li {
  width: 15rem;
  margin: 0 .46875rem
}
@media (max-width: 640px) {
  .commonBannar .commonBannar__inner li {
    width: 100%;
    margin: .9375rem 0
  }
}
.commonBannar .commonBannar__inner li a {
  background: #FFF;
  border: 1px solid #DBDBDB;
  width: 100%;
  height: 5rem;
  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
}
@media (max-width: 640px) {
  .commonBannar .commonBannar__inner li a img {
    width: auto;
    height: 1.625rem
  }
}
.pageFooter {
  background: #000;
  padding: 3.125rem 0 1.25rem 0;
  text-align: center;
  color: #FFF
}
@media (max-width: 640px) {
  .pageFooter {
    padding-top: 1.875rem
  }
}
.pageFooter .pageFooter__banner {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-bottom: 1.875rem
}
@media (max-width: 640px) {
  .pageFooter .pageFooter__banner {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
  }
}
.pageFooter .pageFooter__banner .banner-item {
  width: 15rem;
  margin: 0 .46875rem
}
@media (max-width: 640px) {
  .pageFooter .pageFooter__banner .banner-item {
    margin: .46875rem auto
  }
}
.pageFooter .pageFooter-mail {
  font-family: "EB Garamond", serif;
  font-size: 1.1875rem;
  font-weight: 500;
  margin-bottom: 1.875rem
}
.pageFooter .pageFooter-mail a {
  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;
  color: #FFF
}
.pageFooter .pageFooter-mail a:hover {
  text-decoration: none;
  opacity: 0.7
}
.pageFooter .pageFooter-mail a:before {
  content: '';
  background: url("/assets/img/icon-mail.svg") no-repeat;
  width: 1.3125rem;
  height: 1.125rem;
  background-size: cover;
  display: block;
  margin-right: .625rem;
  margin-top: .25rem
}
.copy {
  text-align: center;
  font-size: .625rem
}
@media (max-width: 640px) {
  .copy {
    letter-spacing: normal
  }
}
.pageLp .pageLp__movie {
  position: relative
}
.pageLp .pageLp__movie .movie-body {
  position: relative
}
.pageLp .pageLp__movie .movie-body img, .pageLp .pageLp__movie .movie-body video {
  width: 100%;
  height: 100vh;
  height: 100svh;
  -o-object-fit: cover;
  object-fit: cover
}
.pageLp .pageLp__movie .movie-body:before {
  content: '';
  background: rgba(0, 0, 0, 0.2);
  width: 100%;
  height: 100%;
  display: block;
  position: absolute;
  top: 0;
  left: 0
}
.pageLp .pageLp__movie .is-scroll {
  width: 1.375rem;
  height: 3.4375rem;
  position: absolute;
  bottom: 1.25rem;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 10;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
  -webkit-writing-mode: vertical-rl;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  font-size: .6875rem;
  font-family: "EB Garamond", serif
}
.pageLp .pageLp__movie .is-scroll a {
  color: #FFF;
  font-weight: 700;
  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;
  letter-spacing: .0625rem
}
.pageLp .pageLp__movie .is-scroll a:hover {
  text-decoration: none;
  opacity: 0.7
}
.pageLp .pageLp__movie .is-scroll:before {
  content: "";
  position: absolute;
  bottom: 0;
  left: -.34687rem;
  width: .3125rem;
  height: .3125rem;
  border-radius: 50%;
  background: #fff;
  -webkit-animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite;
  animation: circlemove 1.6s ease-in-out infinite, cirlemovehide 1.6s ease-out infinite
}
.pageLp .pageLp__about {
  padding: 7.5rem 0
}
.pageLp .pageLp__about h2 {
  text-align: center;
  margin-bottom: 3.75rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__about h2 {
    width: 17.5rem;
    margin: 0 auto 3.75rem auto
  }
}
.pageLp .pageLp__about p {
  font-size: 1.0625rem
}
.pageLp .pageLp__features .features-mv {
  width: 100%;
  height: 31.25rem;
  position: sticky;
  top: 0
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features-mv {
    height: 16.875rem
  }
}
.pageLp .pageLp__features .features-mv .mv-image {
  width: 100%;
  height: 31.25rem;
  top: 0;
  left: 0;
  position: relative;
  z-index: -1
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features-mv .mv-image {
    height: 16.875rem
  }
}
.pageLp .pageLp__features .features-mv .mv-image img {
  width: 100%;
  height: 31.25rem;
  -o-object-fit: cover;
  object-fit: cover
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features-mv .mv-image img {
    height: 16.875rem
  }
}
.pageLp .pageLp__features .features-mv figcaption {
  position: absolute;
  bottom: 1.5625rem;
  right: 1.5625rem;
  color: #FFF;
  font-size: .625rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif
}
.pageLp .pageLp__features .features__body {
  background: #fff url("/assets/img/bg-whitenoise.png");
  padding: 8.4375rem 0 5.3125rem;
  position: relative;
  z-index: 10
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features__body {
    padding: 3.75rem 0
  }
}
.pageLp .pageLp__features .features__body .features-sv {
  width: 35.625rem;
  margin: 0 auto
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features__body .features-sv {
    width: 100%;
    margin-bottom: 6.25rem
  }
}
.pageLp .pageLp__features .features__body .features-text {
  margin-top: 5.3125rem
}
.pageLp .pageLp__features .features__inner {
  background: #FFF;
  border-radius: 1.25rem;
  padding: 3.75rem 4.0625rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__features .features__inner {
    padding: 1.875rem 1.25rem
  }
}
.pageLp .pageLp__features h2 {
  margin-bottom: 3.125rem;
  font-weight: 700;
  font-size: 1.5rem;
  text-align: center
}
.pageLp .pageLp__features h2 span {
  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-bottom: 1.5625rem
}
.pageLp .pageLp__features h2 span img {
  margin-right: .625rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__features h2 span img {
    width: 13.75rem
  }
}
.pageLp .pageLp__features h2 label {
  font-weight: 400;
  font-family: "EB Garamond", serif;
  font-size: 1.25rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__features h2 label {
    font-size: 1.125rem
  }
}
.pageLp .pageLp__features h3 {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 1.875rem;
  text-align: center
}
@media (max-width: 640px) {
  .pageLp .pageLp__features h3 {
    font-size: 1.25rem;
    letter-spacing: normal
  }
}
.pageLp .pageLp__features h3 label {
  display: block;
  font-size: 1.125rem;
  margin-bottom: 1.25rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__features h3 label {
    font-size: 1rem;
    margin-bottom: 1.25rem
  }
}
.pageLp .pageLp__spec .spec__body {
  width: 100%;
  height: 36.875rem;
  position: relative;
  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;
  color: #FFF
}
@media (max-width: 640px) {
  .pageLp .pageLp__spec .spec__body {
    height: 31.25rem
  }
}
.pageLp .pageLp__spec .spec__body .spec-mv {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 36.875rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__spec .spec__body .spec-mv {
    height: 31.25rem
  }
}
.pageLp .pageLp__spec .spec__body .spec-mv .mv-image:after {
  content: '';
  background: rgba(0, 0, 0, 0.8);
  display: block;
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}
.pageLp .pageLp__spec .spec__body .spec-mv .mv-image img {
  width: 100%;
  height: 36.875rem;
  -o-object-fit: cover;
  object-fit: cover
}
@media (max-width: 640px) {
  .pageLp .pageLp__spec .spec__body .spec-mv .mv-image img {
    height: 31.25rem
  }
}
.pageLp .pageLp__spec .spec__body .spec-mv figcaption {
  position: absolute;
  bottom: 1.5625rem;
  right: 1.5625rem;
  color: #FFF;
  font-size: .625rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif
}
.pageLp .pageLp__spec .spec__body .spec-text {
  position: relative;
  padding: 0 1.25rem;
  text-align: center
}
.pageLp .pageLp__spec .spec__body .spec-text h2 {
  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;
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 2.1875rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__spec .spec__body .spec-text h2 {
    font-size: 1.375rem
  }
}
.pageLp .pageLp__spec .spec__body .spec-text h2 i {
  width: 2.75rem;
  display: block;
  margin-bottom: .9375rem
}
.pageLp .pageLp__spec .spec__body .spec-text h2 label {
  display: block;
  font-size: 1.125rem;
  font-weight: 400;
  font-family: "EB Garamond", serif;
  margin-top: 1.25rem
}
.pageLp .pageLp__spec .spec__body .spec-text .is-desc {
  margin-bottom: 3.125rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__spec .spec__body .spec-text .is-desc {
    letter-spacing: normal;
    font-size: .9375rem
  }
}
.pageLp .pageLp__spec .spec-btn {
  width: 16.25rem;
  margin: 0 auto
}
.pageLp .pageLp__style3 {
  padding: 5rem 0;
  text-align: center
}
.pageLp .pageLp__style3 h2 {
  font-weight: 700;
  font-size: 1.5rem;
  line-height: 1.5;
  text-align: center;
  margin-bottom: 3.75rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__style3 h2 {
    font-size: 1.375rem
  }
}
.pageLp .pageLp__style3 .spec-slider {
  margin: 0 -.625rem;
  position: relative;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex
}
.pageLp .pageLp__style3 .spec-slider .slider-item {
  width: 18.125rem;
  margin: 0 .625rem;
  -ms-flex-negative: 0;
  flex-shrink: 0
}
.pageLp .pageLp__style3 .spec-slider .slider-item .item-image img {
  width: 100%;
  height: 12.5rem;
  -o-object-fit: cover;
  object-fit: cover
}
.pageLp .pageLp__style3 .style3-text {
  margin-top: 5rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__style3 .style3-text {
    text-align: left;
    margin-top: 2.5rem
  }
}
.pageLp .pageLp__style3 h3 {
  font-weight: 400;
  font-size: .875rem;
  margin-bottom: 2.1875rem;
  text-align: center
}
.pageLp .pageLp__style3 h3 label {
  font-weight: 700;
  display: block;
  margin-bottom: .9375rem;
  font-family: "EB Garamond", serif;
  font-size: 1.5rem;
  letter-spacing: .1875rem
}
.pageLp .pageLp__movieof {
  padding-bottom: 5rem
}
.pageLp .pageLp__movieof h2 {
  font-size: 1.5rem;
  font-weight: 700;
  text-align: center;
  margin-bottom: 3.75rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__movieof h2 {
    font-size: 1.375rem
  }
}
.pageLp .pageLp__movieof h2 label {
  display: block;
  font-size: 1.25rem;
  font-family: "EB Garamond", serif;
  font-weight: 400;
  margin-top: .9375rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__movieof h2 label {
    font-size: 1.125rem
  }
}
.pageLp .pageLp__movieof .movieof-box {
  margin-bottom: 1.875rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif
}
@media (max-width: 640px) {
  .pageLp .pageLp__movieof .movieof-box {
    margin-bottom: 1.25rem
  }
}
.pageLp .pageLp__movieof .movieof-box:last-child {
  margin-bottom: 0
}
.pageLp .pageLp__movieof .movieof-box .is-movie {
  margin-bottom: 3.125rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__movieof .movieof-box .is-movie {
    margin-bottom: 1.875rem
  }
}
.pageLp .pageLp__movieof .movieof-box .is-movie video {
  width: 100%;
  height: auto;
  aspect-ratio: 16 / 9
}
.pageLp .pageLp__movieof h3 {
  font-weight: 700;
  line-height: 1.6;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: 0.625rem
}
.pageLp .pageLp__movieof h3:before {
  content: '■';
  font-size: .625rem
}
.pageLp .pageLp__movieof p {
  margin-bottom: 3.125rem
}
@media (max-width: 640px) {
  .pageLp .pageLp__movieof p {
    line-height: 1.5
  }
}
.pageLp .pageLp__movieof p:last-child {
  margin-bottom: 0
}
.pageLp .pageLp__movieof p small {
  font-size: 0.75rem
}
.pageLp .pageLp__theater {
  width: 100%;
  height: 52.1875rem;
  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;
  position: relative;
  color: #FFF
}
.pageLp .pageLp__theater .theater-mv {
  position: absolute;
  width: 100%;
  height: 52.1875rem;
  top: 0;
  left: 0
}
.pageLp .pageLp__theater .theater-mv img {
  width: 100%;
  height: 52.1875rem;
  -o-object-fit: cover;
  object-fit: cover
}
.pageLp .pageLp__theater .theater-mv:after {
  content: '';
  background: rgba(0, 0, 0, 0.6);
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0
}
.pageLp .pageLp__theater .theater__inner {
  position: relative
}
.pageLp .pageLp__theater .theater-box {
  margin-bottom: 2.8125rem;
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  font-weight: 700
}
.pageLp .pageLp__theater h2 {
  text-align: center;
  font-size: 1.5rem;
  margin-bottom: 3.125rem
}
.pageLp .pageLp__theater h3 {
  font-size: 1.125rem;
  padding-bottom: .9375rem;
  margin-bottom: .9375rem;
  border-bottom: 1px solid #fff
}
.pageLp .pageLp__theater p {
  line-height: 1.6;
  letter-spacing: normal;
  margin-bottom: 1.875rem
}
.pageLp .pageLp__theater p:last-child {
  margin-bottom: 0
}
.pageLp .pageLp__theater .theater-btn {
  width: 16.25rem;
  margin: 0 auto
}
.remodal {
  font-family: "Noto Sans JP", -apple-system, BlinkMacSystemFont, "Helvetica Neue", "Yu Gothic", YuGothic, "ヒラギノ角ゴ ProN W3", Hiragino Kaku Gothic ProN, Arial, "メイリオ", Meiryo, sans-serif;
  letter-spacing: normal;
  position: relative
}
.remodal .remodal-close {
  position: absolute;
  width: 1.125rem;
  height: 1.125rem;
  background: url("/assets/img/btn-close.svg") no-repeat;
  background-size: 1.125rem;
  top: 3.125rem;
  right: 2.5rem;
  cursor: pointer;
  z-index: 10;
  display: block
}
@media (max-width: 640px) {
  .remodal .remodal-close {
    top: 1.25rem;
    right: 1.25rem
  }
}
.remodal .remodal__inner {
  width: 38.75rem;
  margin: 0 auto;
  padding: 0 1.25rem
}
@media (max-width: 640px) {
  .remodal .remodal__inner {
    width: 100%
  }
}
.remodal .modalNav {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: .875rem;
  font-weight: 700;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  margin-bottom: -1.25rem
}
@media (max-width: 640px) {
  .remodal .modalNav {
    -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
  }
}
.remodal .modalNav a {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  padding: 0 .3125rem;
  border-right: 2px solid #000
}
@media (max-width: 640px) {
  .remodal .modalNav a {
    margin: .3125rem 0
  }
}
.remodal .modalNav a:last-child {
  border-right: 0
}
.remodal .modalBlock {
  margin-top: 3.75rem;
  text-align: left
}
.remodal .modalBlock h2 {
  font-weight: 700;
  border-bottom: 3px solid #000;
  padding-bottom: .625rem
}
.remodal .modalBlock .modalBlock__inner {
  margin-bottom: 2.5rem
}
.remodal .modalBlock .modalBlock__inner .block-col {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #000;
  padding: 2.1875rem 0
}
@media (max-width: 640px) {
  .remodal .modalBlock .modalBlock__inner .block-col {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column
  }
}
.remodal .modalBlock .modalBlock__inner .block-col:last-child {
  border-bottom: 0
}
.remodal .modalBlock .modalBlock__inner .block-col .block-image {
  width: 50%;
  text-align: center
}
@media (max-width: 640px) {
  .remodal .modalBlock .modalBlock__inner .block-col .block-image {
    width: 100%;
    margin-bottom: 3.125rem
  }
}
.remodal .modalBlock .modalBlock__inner .block-col .block-image h3 {
  margin-bottom: 1.25rem
}
.remodal .modalBlock .modalBlock__inner .block-col .block-text {
  width: 50%;
  padding: 0 .9375rem
}
@media (max-width: 640px) {
  .remodal .modalBlock .modalBlock__inner .block-col .block-text {
    width: 100%
  }
}
.remodal .modalBlock .modalBlock__inner .block-col .block-text label {
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  text-align: center;
  padding: .625rem 1.875rem;
  border: 1px solid #000
}
@media (max-width: 640px) {
  .remodal .modalBlock .modalBlock__inner .block-col .block-text label {
    padding: .4375rem 1.875rem
  }
}
.remodal .modalBlock .modalBlock__inner .block-col .block-text h4 {
  margin-top: .9375rem;
  font-weight: 700;
  font-size: .875rem;
  margin-bottom: .3125rem
}
.remodal .modalBlock .modalBlock__inner .block-col .block-text p {
  font-size: .875rem;
  line-height: 1.5
}
.remodal .modalBlock .modalBlock__inner .block-col .block-text p.is-att {
  margin-top: .625rem
}
.movie__btn {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  -webkit-justify-content: center;
          justify-content: center;
  position: absolute;
  bottom: 1.25rem;
  right: 1.25rem;
  z-index: 100;
  font-size: .875rem;
  width: 44px;
  height: 22px;
}
@media (max-width: 640px) {
  .movie__btn {
    right: 0;
    bottom: 0.625rem;
    width: 55px;
    height: 33px;
  }
}
/*
.movie__btn span {
  font-weight: 700;
  position: relative;
  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;
  -webkit-box-flex: 1;
  -ms-flex-positive: 1;
  flex-grow: 1
}

.movie__btn span:after {
  content: '\f6a9';
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
  font-size: 1.25rem
}
.movie__btn span.sound-off:after {
  content: '\f028';
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
  font-size: 1.25rem
}
.movie__btn span.sound-on:after {
  content: '\f6a9';
  font-weight: 900;
  font-family: "Font Awesome 5 Free";
  font-size: 1.25rem
}
*/
.movie__btn .js-video-button {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-inline-box;
  display: -ms-inline-flexbox;
  display: inline-flex;
  align-items: center;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  width: 44px;
  height: 22px;
  font-weight: 700;
  position: relative;
}
.movie__btn .js-video-button img{
  width: 22px !important;
  height: auto !important;
  filter: invert(100%);
}
@keyframes fade-in {
  0% {
    display: none;
    opacity: 0
  }
  1% {
    display: block;
    opacity: 0
  }
  100% {
    display: block;
    opacity: 1
  }
}
@-webkit-keyframes fade-in {
  0% {
    display: none;
    opacity: 0
  }
  1% {
    display: block;
    opacity: 0
  }
  100% {
    display: block;
    opacity: 1
  }
}
@-webkit-keyframes circlemove {
  0% {
    bottom: 45px
  }
  100% {
    bottom: -5px
  }
}
@keyframes circlemove {
  0% {
    bottom: 45px
  }
  100% {
    bottom: -5px
  }
}
@-webkit-keyframes cirlemovehide {
  0% {
    opacity: 0
  }
  50% {
    opacity: 1
  }
  80% {
    opacity: 0.9
  }
  100% {
    opacity: 0
  }
}
@keyframes cirlemovehide {
  0% {
    opacity: 0
  }
  50% {
    opacity: 1
  }
  80% {
    opacity: 0.9
  }
  100% {
    opacity: 0
  }
}
.clearfix::after {
  content: "";
  clear: both;
  display: block
}
/*# sourceMappingURL=../sourcemaps/style.css.map */