@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Manrope:wght@800&family=Noto+Sans+JP:wght@400;500;700;900&display=swap");
@import url("https://cdn.jsdelivr.net/npm/yakuhanjp@3.4.1/dist/css/yakuhanjp-noto.min.css");
[data-simplebar] {
  position: relative;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: start;
      justify-content: flex-start;
  -ms-flex-line-pack: start;
      align-content: flex-start;
  -ms-flex-align: start;
      align-items: flex-start;
}

.simplebar-wrapper {
  overflow: hidden;
  width: inherit;
  height: inherit;
  max-width: inherit;
  max-height: inherit;
}

.simplebar-mask {
  direction: inherit;
  position: absolute;
  overflow: hidden;
  padding: 0;
  margin: 0;
  left: 0;
  top: 0;
  bottom: 0;
  right: 0;
  width: auto !important;
  height: auto !important;
  z-index: 0;
}

.simplebar-offset {
  direction: inherit !important;
  box-sizing: inherit !important;
  resize: none !important;
  position: absolute;
  top: 0;
  left: 0;
  bottom: 0;
  right: 0;
  padding: 0;
  margin: 0;
  -webkit-overflow-scrolling: touch;
}

.simplebar-content-wrapper {
  direction: inherit;
  box-sizing: border-box !important;
  position: relative;
  display: block;
  height: 100%;
  /* Required for horizontal native scrollbar to not appear if parent is taller than natural height */
  width: auto;
  max-width: 100%;
  /* Not required for horizontal scroll to trigger */
  max-height: 100%;
  /* Needed for vertical scroll to trigger */
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.simplebar-content-wrapper::-webkit-scrollbar,
.simplebar-hide-scrollbar::-webkit-scrollbar {
  width: 0;
  height: 0;
  display: none;
}

.simplebar-content:before,
.simplebar-content:after {
  content: ' ';
  display: table;
}

.simplebar-placeholder {
  max-height: 100%;
  max-width: 100%;
  width: 100%;
  pointer-events: none;
}

.simplebar-height-auto-observer-wrapper {
  box-sizing: inherit !important;
  height: 100%;
  width: 100%;
  max-width: 1px;
  position: relative;
  float: left;
  max-height: 1px;
  overflow: hidden;
  z-index: -1;
  padding: 0;
  margin: 0;
  pointer-events: none;
  -ms-flex-positive: inherit;
      flex-grow: inherit;
  -ms-flex-negative: 0;
      flex-shrink: 0;
  -ms-flex-preferred-size: 0;
      flex-basis: 0;
}

.simplebar-height-auto-observer {
  box-sizing: inherit;
  display: block;
  opacity: 0;
  position: absolute;
  top: 0;
  left: 0;
  height: 1000%;
  width: 1000%;
  min-height: 1px;
  min-width: 1px;
  overflow: hidden;
  pointer-events: none;
  z-index: -1;
}

.simplebar-track {
  z-index: 1;
  position: absolute;
  right: 0;
  bottom: 0;
  pointer-events: none;
  overflow: hidden;
}

[data-simplebar].simplebar-dragging .simplebar-content {
  pointer-events: none;
  -ms-user-select: none;
      user-select: none;
  -webkit-user-select: none;
}

[data-simplebar].simplebar-dragging .simplebar-track {
  pointer-events: all;
}

.simplebar-scrollbar {
  position: absolute;
  left: 0;
  right: 0;
  min-height: 10px;
}

.simplebar-scrollbar:before {
  position: absolute;
  content: '';
  background: rgba(0, 0, 0, 0.3);
  border-radius: 4px;
  left: 0px;
  right: 0px;
  transition: opacity 0.2s linear;
}

@media screen and (max-width: 768px) {
  .simplebar-scrollbar:before {
    border-radius: calc(2.5 / 10 * 1rem);
  }
}

.simplebar-scrollbar.simplebar-visible:before {
  /* When hovered, remove all transitions from drag handle */
  opacity: 1;
  transition: opacity 0s linear;
}

.simplebar-track.simplebar-vertical {
  top: 0;
  width: 8px;
  right: 0;
}

@media screen and (max-width: 768px) {
  .simplebar-track.simplebar-vertical {
    width: calc(5 / 10 * 1rem);
  }
}

.simplebar-track.simplebar-vertical .simplebar-scrollbar:before {
  top: 0px;
  bottom: 0px;
}

.simplebar-track.simplebar-horizontal {
  left: 0;
  height: 10px;
  background-color: #f3f3f5;
  border-radius: 5px;
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar:before {
  height: 100%;
  left: 0px;
  right: 0px;
}

.simplebar-track.simplebar-horizontal .simplebar-scrollbar {
  right: auto;
  left: 0;
  top: 0px;
  height: 10px;
  min-height: 0;
  min-width: 10px;
  width: auto;
}

@media screen and (max-width: 768px) {
  .simplebar-track.simplebar-horizontal .simplebar-scrollbar {
    height: calc(12 / 10 * 1rem);
  }
}

/* Rtl support */
[data-simplebar-direction='rtl'] .simplebar-track.simplebar-vertical {
  right: auto;
  left: 0;
}

.hs-dummy-scrollbar-size {
  direction: rtl;
  position: fixed;
  opacity: 0;
  visibility: hidden;
  height: 500px;
  width: 500px;
  overflow-y: hidden;
  overflow-x: scroll;
}

.simplebar-hide-scrollbar {
  position: fixed;
  left: 0;
  visibility: hidden;
  overflow-y: scroll;
  scrollbar-width: none;
  -ms-overflow-style: none;
}

.simplebar-scrollbar {
  opacity: 0;
  transition: opacity 0.3s ease 0.8s;
}

.simplebar-scrolling .simplebar-scrollbar {
  opacity: 1;
  transition: opacity 0s ease;
}

/* ==========================================================================
slick.js
========================================================================== */
.slick-slider {
  position: relative;
  display: block;
  box-sizing: border-box;
  -webkit-touch-callout: none;
  -webkit-user-select: none;
  -ms-user-select: none;
  user-select: none;
  -ms-touch-action: pan-y;
  touch-action: pan-y;
  -webkit-tap-highlight-color: transparent;
}

.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 {
  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 transparent;
}

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

@keyframes swing1 {
  0% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
  35% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: rotate(5deg) translateY(-10px);
  }
  50% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
  85% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: rotate(-5deg) translateY(-10px);
  }
  100% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
}

@keyframes swing2 {
  0% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
  35% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: rotate(-5deg) translateY(-10px);
  }
  50% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
  85% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: rotate(5deg) translateY(-10px);
  }
  100% {
    animation-timing-function: cubic-bezier(0.175, 0.885, 0.32, 1.275);
    transform: rotate(0deg) translateY(0);
  }
}

@keyframes bounce {
  from,
  20%,
  53%,
  80%,
  to {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: translate3d(0, 0, 0);
  }
  40%,
  43% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: translate3d(0, -30px, 0);
  }
  70% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: translate3d(0, -15px, 0);
  }
  90% {
    animation-timing-function: cubic-bezier(0.165, 0.84, 0.44, 1);
    transform: translate3d(0, -4px, 0);
  }
}

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

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

ol,
ul {
  list-style: none;
}

blockquote,
q {
  quotes: none;
}

blockquote:before,
blockquote:after,
q:before,
q:after {
  content: '';
  content: none;
}

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

img, svg {
  vertical-align: top;
}

button,
input,
textarea,
select {
  font-family: inherit;
}

html {
  font-size: 10px;
}

@media screen and (max-width: 868px) {
  html {
    font-size: 1.15207vw;
  }
}

@media screen and (max-width: 768px) {
  html {
    font-size: 2.66667vw;
  }
}

:root {
  --vh: 0;
  --vhin: 0;
  --vhkv: 0;
  --key-color: #db5425;
}

body {
  overflow: hidden;
  color: #161616;
  background: #fff;
  font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif;
  font-size: 1.4rem;
  letter-spacing: 0.1em;
  line-height: 2.14286;
  -webkit-font-smoothing: antialiased;
  hanging-punctuation: allow-end;
  line-break: strict;
  word-break: break-word;
  font-feature-settings: "palt";
}

@media screen and (max-width: 768px) {
  body {
    font-size: 1.2rem;
  }
}

body.is-loaded {
  overflow: auto;
}

body.is-show-modal {
  overflow: hidden;
}

body.is-show-nav {
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  body.is-show-nav, body.is-show-tel {
    overflow: hidden;
  }
}

.win body.is-show-nav {
  padding-right: 17px;
}

.android-app {
  margin-bottom: 92px;
}

a {
  outline: none;
  color: #161616;
  text-decoration: underline;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}

@media screen and (min-width: 769px) {
  a:hover, a:active {
    text-decoration: none;
  }
}

img {
  max-width: 100%;
  pointer-events: none;
}

@media screen and (max-width: 768px) {
  img {
    width: 100%;
  }
}

@media screen and (max-width: 768px) {
  img {
    touch-callout: none;
    -webkit-user-select: none;
        -ms-user-select: none;
            user-select: none;
  }
}

::selection {
  background: #000;
  color: #fff;
}

.center-inline {
  text-align: center;
}

.slide-up-in {
  opacity: 0;
  transform: translateY(4rem) translateZ(0);
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  will-change: opacity, transform;
  backface-visibility: hidden;
}

@media screen and (max-width: 768px) {
  .slide-up-in {
    transform: translateY(2rem);
  }
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(1):before {
  transition-delay: 0.44s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(2):before {
  transition-delay: 0.58s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(3):before {
  transition-delay: 0.72s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(4):before {
  transition-delay: 0.86s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(5):before {
  transition-delay: 1s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(6):before {
  transition-delay: 1.14s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(7):before {
  transition-delay: 1.28s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(8):before {
  transition-delay: 1.42s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(9):before {
  transition-delay: 1.56s;
}

.slide-up-in.js-inview-first.is-inview-first:nth-of-type(10):before {
  transition-delay: 1.7s;
}

.slide-up-in.is-inview {
  opacity: 1;
  transform: translateY(0) translateZ(0);
}

.slide-up-in-top {
  opacity: 0;
  transform: translateY(4rem);
  transition: opacity 0s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .slide-up-in-top {
    transform: translateY(2rem);
  }
}

@media screen and (min-width: 769px) {
  .is-loaded .is-inview .slide-up-in-top {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  }
}

@media screen and (max-width: 768px) {
  .is-loaded .slide-up-in-top.is-inview {
    opacity: 1;
    transform: translateY(0);
    transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  }
}

.slide-right-in {
  opacity: 0;
  transform: translateX(4rem);
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}

@media screen and (max-width: 768px) {
  .slide-right-in {
    transform: translateX(1.5rem);
  }
}

.slide-right-in.is-inview {
  opacity: 1;
  transform: translateX(0);
}

.slide-right-in-item .js-inview-item {
  opacity: 0;
  transform: translateX(4rem);
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
}

@media screen and (max-width: 768px) {
  .slide-right-in-item .js-inview-item {
    transform: translateX(1.5rem);
  }
}

.slide-right-in-item .js-inview-item:nth-of-type(1) {
  transition-delay: 0s;
}

.slide-right-in-item .js-inview-item:nth-of-type(2) {
  transition-delay: 0.1s;
}

.slide-right-in-item .js-inview-item:nth-of-type(3) {
  transition-delay: 0.2s;
}

.slide-right-in-item .js-inview-item:nth-of-type(4) {
  transition-delay: 0.3s;
}

.slide-right-in-item .js-inview-item:nth-of-type(5) {
  transition-delay: 0.4s;
}

.slide-right-in-item .js-inview-item:nth-of-type(6) {
  transition-delay: 0.5s;
}

.slide-right-in-item .js-inview-item:nth-of-type(7) {
  transition-delay: 0.6s;
}

.slide-right-in-item.is-inview .js-inview-item {
  opacity: 1;
  transform: translateX(0);
}

.slide-up-back-in {
  opacity: 0;
  transform: translateY(6rem);
  transition: opacity 0.6s cubic-bezier(0.39, 0.575, 0.565, 1), transform 1s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}

@media screen and (max-width: 768px) {
  .slide-up-back-in {
    transform: translateY(3rem);
  }
}

.slide-up-back-in.is-inview {
  opacity: 1;
  transform: translateY(0);
}

@media screen and (max-width: 768px) {
  .pcdisp {
    display: none !important;
  }
}

@media screen and (min-width: 769px) {
  .spdisp {
    display: none !important;
  }
}

.fit-image {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

.is-disabled {
  pointer-events: none;
  opacity: 0.3;
}

.is-hide {
  pointer-events: none;
  opacity: 0;
}

.en-sans {
  font-family: "Manrope", sans-serif;
  font-weight: 800;
}

.layout-container {
  position: relative;
  padding-top: 0;
}

@media screen and (max-width: 768px) {
  .layout-container {
    padding-top: 5.3rem;
  }
}

@media screen and (max-width: 768px) {
  #home .layout-container {
    padding-top: 8.9rem;
  }
}

@media screen and (min-width: 769px) {
  .layout-container.is-hidden-sponsor_header {
    padding-top: 7rem;
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .layout-container {
    margin-top: 14rem;
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .layout-container.is-hidden-sponsor_header {
    margin-top: 7rem;
  }
}

.layout-content > * {
  position: relative;
  z-index: 99;
}

#home .layout-content {
  position: relative;
  z-index: 99;
  background: #fff;
}

.layout-footer {
  background: #fff;
  position: relative;
}

.layout-footer__sponsorship {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 5rem 0;
}

@media screen and (max-width: 768px) {
  .layout-footer__sponsorship {
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-pack: start;
        justify-content: flex-start;
    -ms-flex-align: center;
        align-items: center;
    height: auto;
    padding: 3.6rem 1.6rem 0;
  }
}

.layout-footer__sponsorship-inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 1px 3rem;
  border: solid #A0A0A0;
  border-width: 0 1px;
}

@media screen and (max-width: 768px) {
  .layout-footer__sponsorship-inner {
    -ms-flex-direction: column;
        flex-direction: column;
    padding: 0 0 5rem;
    border: none;
  }
}

.layout-footer__sns {
  background: #000000;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  padding: 5rem 0 0;
}

@media screen and (max-width: 768px) {
  .layout-footer__sns {
    background: #000000;
    padding: 4rem 0 0;
  }
}

.layout-footer__inner {
  background: #000000;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 4rem 0 5rem;
}

@media screen and (max-width: 768px) {
  .layout-footer__inner {
    height: auto;
    padding: 3rem 0 4.5rem;
  }
}

.layout-footer-nav {
  color: #fff;
  font-size: 1.2rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  margin-bottom: 1rem;
}

@media screen and (max-width: 768px) {
  .layout-footer-nav {
    font-size: 1rem;
    -ms-flex-wrap: wrap;
        flex-wrap: wrap;
  }
}

.layout-footer-nav__item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

.layout-footer-nav__item a {
  font-size: 1.2rem;
  letter-spacing: 0.02em;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .layout-footer-nav__item a {
    font-size: 1rem;
  }
}

.layout-footer-nav__item:nth-of-type(n + 2):before {
  content: '｜';
  display: inline-block;
  margin-right: 0.2rem;
  margin-left: 0.35rem;
}

.layout-header {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 7rem;
  z-index: 999;
}

@media screen and (min-width: 769px) {
  .layout-header {
    position: sticky;
  }
}

@media screen and (max-width: 768px) {
  .layout-header {
    background: #000000;
    height: 5.3rem;
  }
}

.layout-header__inner {
  position: relative;
  z-index: 2;
  background: #000000;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 100%;
  height: 100%;
  border-bottom: 1px solid #707070;
}

@media screen and (max-width: 768px) {
  .layout-header:before {
    position: fixed;
    top: -10px;
    left: 0;
    width: 100%;
    height: 5.3rem;
    z-index: 1;
    content: '';
    background: #000000;
    opacity: 1;
  }
}

@media screen and (min-width: 769px) {
  .is-hidden-sponsor_header .layout-header {
    position: fixed;
    top: 0;
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .layout-header {
    position: fixed;
    top: 7rem;
    transition: transform 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .is-hidden-sponsor_header .layout-header {
    top: 0;
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .is-header-scrolled .layout-header {
    transform: translate(0, -7rem);
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .is-header-scrolled .is-hidden-sponsor_header .layout-header {
    transform: translate(0, 0);
  }
}

.js-toggle-accordion {
  cursor: pointer;
}

.js-toggle-accordion-content {
  display: none;
}

.anchor-nav {
  margin-top: 3.8rem;
}

@media screen and (max-width: 768px) {
  .anchor-nav {
    margin-top: 3rem;
  }
}

.anchor-nav:first-child {
  margin-top: 0;
}

.anchor-nav__list {
  border: 0.2rem solid var(--key-color);
  border-radius: 0.4rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .anchor-nav__list {
    border-radius: 0.5rem;
  }
}

.anchor-nav__item a {
  color: #505050;
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  min-height: 4.4rem;
  padding: 1rem 2rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .anchor-nav__item a {
    padding: 1.4rem 2.2rem;
  }
}

.anchor-nav__item a:after {
  content: "";
  display: inline-block;
  width: 2.1rem;
  height: 2.1rem;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
  background: var(--key-color);
  -webkit-mask-image: url("../img/common/icn_arrow_notice.svg");
          mask-image: url("../img/common/icn_arrow_notice.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
}

@media screen and (max-width: 768px) {
  .anchor-nav__item a:after {
    width: 2.6rem;
    height: 2.6rem;
    margin-left: 3rem;
  }
}

.anchor-nav__item a.is-on {
  opacity: 0.6;
}

.anchor-nav__item:nth-of-type(2n) a {
  background-color: #f5f5f5;
}

.anchor-nav--large .anchor-nav__item a {
  font-size: 1.7rem;
}

.app-link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin: 3rem auto 0;
}

@media screen and (max-width: 768px) {
  .app-link {
    margin-top: 1.2rem;
  }
}

.app-link--margin-top-small {
  margin-top: 1.8rem;
}

@media screen and (max-width: 768px) {
  .app-link--margin-top-small {
    margin-top: 1.2rem;
  }
}

.app-link a {
  position: relative;
  color: #e1230f;
  font-size: 1.5rem;
  line-height: 21 / 15;
  font-weight: 700;
  letter-spacing: 0.02em;
  white-space: nowrap;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  width: 22rem;
  height: 4rem;
  padding: 0 0.9rem;
  border-radius: 1rem;
  border: 0.2rem solid #e1230f;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .app-link a {
    border-radius: 0.5rem;
    border-width: 0.2rem;
  }
}

.app-link a.is-on {
  opacity: 0.6;
}

.app-link a:before {
  content: '';
  display: block;
  background: url(../img/common/icn_app.png) no-repeat center center;
  background-size: contain;
  width: 2.5rem;
  height: 2.5rem;
  margin-right: 0.8rem;
}

.app-link a:after {
  content: '';
  position: absolute;
  right: -1.2rem;
  top: calc(50% - 2.3rem / 2);
  display: block;
  background: #e1230f url(../img/common/icn_arrow_app.svg) no-repeat;
  background-position: left 50% bottom 1rem;
  background-size: 1.4rem 0.6rem;
  width: 2.3rem;
  height: 2.3rem;
  border-radius: 50%;
}

.emphasis-frame {
  margin: 0 auto;
  padding: 1.5rem 1.8rem;
  border-radius: 0.5rem;
  border: 0.2rem solid var(--key-color);
  border-radius: 0.4rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .emphasis-frame {
    border-radius: 0.5rem;
  }
}

.emphasis-frame__text {
  font-size: 2rem;
  font-weight: 700;
  line-height: 1.45;
  letter-spacing: -0.02em;
  display: inline;
  border-bottom: 0.2rem solid var(--key-color);
  border-bottom-width: 1px;
}

.link-common {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 3rem;
  padding-bottom: 2rem;
}

.link-common + .link-common {
  margin-top: 0;
}

.link-common a {
  color: #161616;
  background: #fff;
  position: relative;
  font-size: 1.5rem;
  line-height: 1.2;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-align: center;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 22rem;
  min-height: 4rem;
  padding: 0.7rem 0 0.8rem;
  border-radius: 0.4rem;
  border: 1px solid #A0A0A0;
  transition: color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .link-common a {
    min-height: 4rem;
    padding: 0.7rem 0 0.8rem;
  }
}

.link-common a em {
  font-family: "Manrope", sans-serif;
  font-size: 1.8rem;
  margin-right: 0.1em;
}

.link-common a small {
  font-size: 1.2rem;
  line-height: 1.33333;
  display: inline-block;
}

.link-common a.is-on {
  color: #fff;
  background: #161616;
}

.link-common a.is-on .link-common__arrow {
  border-color: #fff;
}

.link-common a[target='_blank'] {
  color: #fff;
  overflow: visible;
  text-align: left;
  background: #0c0c0c;
  letter-spacing: 0.08em;
}

.link-common a[target='_blank'] .link-common__arrow {
  position: absolute;
  right: -1.2rem;
  top: calc(50% - 2.3rem / 2);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: end;
      align-items: flex-end;
  background-color: #fff;
  width: 2.3rem;
  height: 2.3rem;
  border-radius: 50%;
  border-width: 1px;
  transform: none;
  padding: 0;
  padding-bottom: 0.8rem;
  margin: 0;
  transition: border-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), box-shadow 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.link-common a[target='_blank'] .link-common__arrow:before {
  content: '';
  display: block;
  background: url(../img/common/icn_arrow_blank.svg) no-repeat;
  background-size: contain;
  width: 1.4rem;
  height: 0.6rem;
  transition: filter 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  filter: invert(1);
}

.link-common a[target='_blank'].is-on {
  color: #0c0c0c;
  background: #fff;
}

.link-common a[target='_blank'].is-on .link-common__arrow {
  background-color: #0c0c0c;
}

.link-common a[target='_blank'].is-on .link-common__arrow:before {
  filter: invert(0);
}

.link-common__text {
  position: relative;
  z-index: 1;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
}

.link-common__arrow {
  position: relative;
  z-index: 1;
  display: inline-block;
  box-sizing: border-box;
  width: 0.45em;
  height: 0.45em;
  border: solid #161616;
  border-width: 1px 1px 0 0;
  margin-left: 0.3em;
  margin-right: -0.3em;
  margin-top: 0.1em;
  transform: rotate(45deg);
  transition: border-color 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
  filter: drop-shadow(0 0 0 var(--key-color));
}

.link-common__icon {
  width: 2.2rem;
  height: 2.2rem;
  margin-right: 0.3rem;
  transition: filter 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.link-common__note {
  position: absolute;
  left: calc(50% - 22rem / 2);
  bottom: -0.5em;
  font-size: 1.2rem;
  line-height: 1.33333;
  letter-spacing: 0.04em;
  display: inline-block;
  min-width: 22rem;
}

.link-common--margin-top-large {
  margin-top: 5rem;
}

.link-common--padding-bottom-0 {
  padding-bottom: 0;
}

@media screen and (max-width: 768px) {
  .link-common--padding-bottom-0 {
    padding-bottom: 1rem;
  }
}

.link-common--padding-bottom-0 .link-common__note {
  bottom: -2.2em;
}

@media screen and (max-width: 768px) {
  .link-common--padding-bottom-0 .link-common__note {
    bottom: -1.4em;
  }
}

.link-common--large a {
  width: 28rem;
}

.link-common--2line a {
  line-height: 1.46667;
  width: 28rem;
  height: 6rem;
}

.link-common--text-center a {
  text-align: center;
}

.link-common--text-center a[target='_blank'] {
  text-align: center;
}

.link-common--text-narrow a {
  letter-spacing: 0.02em;
}

.link-common--text-narrow a[target='_blank'] {
  letter-spacing: 0.02em;
}

.link-common--faq a {
  letter-spacing: 0.08em;
}

.link-common--faq a em {
  letter-spacing: 0.04em;
}

.link-common--faq a .link-common__icon {
  filter: invert(0.9);
}

.link-common--faq a.is-on .link-common__icon {
  filter: invert(0);
}

.link-common--end a {
  color: #fff;
  background: #808080;
  border-color: #808080;
}

.link-common--end a small {
  font-size: 1.1rem;
}

.link-common--end a .link-common__arrow {
  border-color: #fff;
  margin-left: 0.4em;
  margin-right: -0.1em;
}

.link-common--end a.is-on {
  color: #595959;
  background: #fff;
}

.link-common--end a.is-on .link-common__arrow {
  border-color: #595959;
}

.link-common--end a[target='_blank'] {
  background: #808080;
  border-color: #808080;
}

.link-common--end a[target='_blank'] .link-common__arrow {
  background-color: #595959;
  border-color: #595959;
}

.link-common--end a[target='_blank'] .link-common__arrow:before {
  filter: invert(0);
}

.link-common--end a[target='_blank'].is-on {
  color: #595959;
  background: #fff;
}

.link-common--end a[target='_blank'].is-on .link-common__arrow {
  background-color: #808080;
}

.link-common--before a {
  color: #a6a6a6;
  background: #e6e6e6;
  border-color: #e6e6e6;
  pointer-events: none;
}

.link-common--before a .link-common__arrow {
  border-color: #a6a6a6;
  margin-left: 0.4em;
  margin-right: -0.1em;
}

.link-common--before a[target='_blank'] {
  color: #a6a6a6;
  background: #e6e6e6;
  border-color: #e6e6e6;
}

.link-common--before a[target='_blank'] .link-common__arrow {
  background-color: #a6a6a6;
  border-color: #a6a6a6;
}

.link-common--before a[target='_blank'] .link-common__arrow:before {
  filter: invert(0);
}

.link-common--active a {
  color: #fff;
  background: var(--key-color);
  border-color: var(--key-color);
}

.link-common--active a .link-common__arrow {
  border-color: #fff;
}

.link-common--active a.is-on {
  color: var(--key-color);
  background: #fff;
}

.link-common--active a.is-on .link-common__arrow {
  border-color: var(--key-color);
}

.link-common--active a[target='_blank'] {
  background: var(--key-color);
  border-color: var(--key-color);
}

.link-common--active a[target='_blank'] .link-common__arrow {
  border-color: var(--key-color);
}

.link-common--active a[target='_blank'] .link-common__arrow:before {
  background-image: url(../img/common/icn_arrow_blank_orange.svg);
  filter: invert(0);
}

.link-common--active a[target='_blank'].is-on {
  color: var(--key-color);
  background: #fff;
}

.link-common--active a[target='_blank'].is-on .link-common__arrow {
  background-color: var(--key-color);
}

.link-common--active a[target='_blank'].is-on .link-common__arrow:before {
  filter: brightness(100);
}

.section--bg-black .link-common a {
  color: #fff;
  background: #0c0c0c;
}

.section--bg-black .link-common a .link-common__arrow {
  border-color: #fff;
}

.section--bg-black .link-common a.is-on {
  color: #0c0c0c;
  background: #fff;
}

.section--bg-black .link-common a.is-on .link-common__arrow {
  border-color: #0c0c0c;
}

.list-banner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  width: 100%;
  max-width: 98rem;
  padding: 0 1rem 6rem;
  margin: 5.5rem auto 0;
}

@media screen and (max-width: 768px) {
  .list-banner {
    width: 34.3rem;
    margin: 3.6rem auto 0;
    padding: 0 0 4rem;
  }
}

.list-banner__item {
  transition-delay: 0.1s;
}

.list-banner__item:nth-of-type(n + 2) {
  margin-top: 3.1rem;
}

@media screen and (max-width: 768px) {
  .list-banner__item:nth-of-type(n + 2) {
    margin-top: 2.5rem;
  }
}

.list-banner__item a {
  display: block;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.list-banner__item a.is-on {
  opacity: 0.6;
}

.list-message__item {
  position: relative;
}

.list-message__item:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
  transform: scale(0, 1);
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.list-message__item:last-of-type:before {
  display: none;
}

.list-message__item a {
  position: relative;
  color: #444;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  padding: 3.5rem 0 3.7rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .list-message__item a {
    padding: 2.3rem 0 2.7rem;
  }
}

.list-message__item a.is-on {
  opacity: 0.6;
}

.list-message__item.is-inview-first:nth-of-type(1) {
  transition-delay: 0.26s;
}

.list-message__item.is-inview-first:nth-of-type(1):before {
  transition-delay: 0.38s;
}

.list-message__item.is-inview-first:nth-of-type(2) {
  transition-delay: 0.42s;
}

.list-message__item.is-inview-first:nth-of-type(2):before {
  transition-delay: 0.66s;
}

.list-message__item.is-inview-first:nth-of-type(3) {
  transition-delay: 0.58s;
}

.list-message__item.is-inview-first:nth-of-type(3):before {
  transition-delay: 0.94s;
}

.list-message__item.is-inview-first:nth-of-type(4) {
  transition-delay: 0.74s;
}

.list-message__item.is-inview-first:nth-of-type(4):before {
  transition-delay: 1.22s;
}

.list-message__item.is-inview-first:nth-of-type(5) {
  transition-delay: 0.9s;
}

.list-message__item.is-inview-first:nth-of-type(5):before {
  transition-delay: 1.5s;
}

.list-message__item.is-inview-first:nth-of-type(6) {
  transition-delay: 1.06s;
}

.list-message__item.is-inview-first:nth-of-type(6):before {
  transition-delay: 1.78s;
}

.list-message__item.is-inview-first:nth-of-type(7) {
  transition-delay: 1.22s;
}

.list-message__item.is-inview-first:nth-of-type(7):before {
  transition-delay: 2.06s;
}

.list-message__item.is-inview-first:nth-of-type(8) {
  transition-delay: 1.38s;
}

.list-message__item.is-inview-first:nth-of-type(8):before {
  transition-delay: 2.34s;
}

.list-message__item.is-inview-first:nth-of-type(9) {
  transition-delay: 1.54s;
}

.list-message__item.is-inview-first:nth-of-type(9):before {
  transition-delay: 2.62s;
}

.list-message__item.is-inview-first:nth-of-type(10) {
  transition-delay: 1.7s;
}

.list-message__item.is-inview-first:nth-of-type(10):before {
  transition-delay: 2.9s;
}

.list-message__item.is-inview:before {
  transform: scale(1, 1);
}

.list-message__date {
  color: var(--key-color);
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.83333;
  letter-spacing: 0.03em;
  white-space: nowrap;
  width: 10rem;
}

@media screen and (max-width: 768px) {
  .list-message__date {
    letter-spacing: -0.01em;
    width: 7rem;
  }
}

.list-message__inner {
  width: calc(100% - 10rem);
}

@media screen and (max-width: 768px) {
  .list-message__inner {
    width: calc(100% - 7rem);
  }
}

.list-message__heading, .list-message__text {
  font-size: 1.5rem;
  line-height: 1.6;
  letter-spacing: 0.01em;
  padding-right: 1rem;
}

.list-message__heading {
  font-weight: 700;
}

.list-message__text {
  margin-top: 1.6rem;
  text-align: left;
  display: -webkit-box;
  overflow: hidden;
  -webkit-line-clamp: 2;
  /*! autoprefixer: ignore next */
  -webkit-box-orient: vertical;
}

@media screen and (max-width: 768px) {
  .list-message__text {
    margin-top: 0.8rem;
    -webkit-line-clamp: 6;
  }
}

.list-message__more {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
      justify-content: flex-end;
  margin-top: 1.6rem;
}

@media screen and (max-width: 768px) {
  .list-message__more {
    margin-top: 1.2rem;
  }
}

.list-message__more span {
  color: var(--key-color);
  font-size: 1.2rem;
  line-height: 1.33333;
  font-weight: 700;
  letter-spacing: 0em;
}

.list-message__more span:after {
  content: '';
  display: inline-block;
  border: solid;
  border-color: transparent transparent transparent var(--key-color);
  border-width: 0.4rem 0 0.4rem 0.5rem;
  margin-left: 0.5rem;
}

@media screen and (max-width: 768px) {
  .list-message__more span:after {
    border-width: 0.4rem 0 0.4rem 0.5rem;
    margin-left: 0.4rem;
  }
}

.list-news__item {
  position: relative;
}

.list-news__item:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
  transform: scale(0, 1);
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.list-news__item.is-new .list-news__text:after {
  content: "NEW!";
  font-family: "Manrope", sans-serif;
  color: var(--key-color);
  display: inline-block;
  margin-left: 0.6rem;
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 700;
  font-style: italic;
  letter-spacing: 0.02em;
}

@media screen and (max-width: 768px) {
  .list-news__item.is-new .list-news__text:after {
    font-size: 1.1rem;
  }
}

.list-news__item:last-of-type:before {
  display: none;
}

.list-news__item a {
  position: relative;
  color: #444;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  padding: 3.5rem 0;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .list-news__item a {
    padding: 1.65rem 0;
  }
}

.list-news__item a.is-on {
  opacity: 0.6;
}

.list-news__item a:before {
  content: '';
  position: absolute;
  top: 0;
  right: 0;
  width: 1.8rem;
  height: 100%;
  z-index: 1;
  background: var(--key-color);
  -webkit-mask-image: url("../img/common/icn_arrow.svg");
          mask-image: url("../img/common/icn_arrow.svg");
  -webkit-mask-size: 0.8rem 1.4rem;
          mask-size: 0.8rem 1.4rem;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: center center;
          mask-position: center center;
}

@media screen and (max-width: 768px) {
  .list-news__item a:before {
    width: 1rem;
    -webkit-mask-size: 0.5rem 0.9rem;
            mask-size: 0.5rem 0.9rem;
  }
}

.list-news__item a[target='_blank']:before {
  -webkit-mask-image: url("../img/common/icn_blank.svg");
          mask-image: url("../img/common/icn_blank.svg");
  -webkit-mask-size: 1.8rem 1.8rem;
          mask-size: 1.8rem 1.8rem;
}

@media screen and (max-width: 768px) {
  .list-news__item a[target='_blank']:before {
    -webkit-mask-size: 1rem 1rem;
            mask-size: 1rem 1rem;
  }
}

.list-news__item.is-inview-first:nth-of-type(1) {
  transition-delay: 0.26s;
}

.list-news__item.is-inview-first:nth-of-type(1):before {
  transition-delay: 0.26s;
}

.list-news__item.is-inview-first:nth-of-type(2) {
  transition-delay: 0.42s;
}

.list-news__item.is-inview-first:nth-of-type(2):before {
  transition-delay: 0.42s;
}

.list-news__item.is-inview-first:nth-of-type(3) {
  transition-delay: 0.58s;
}

.list-news__item.is-inview-first:nth-of-type(3):before {
  transition-delay: 0.58s;
}

.list-news__item.is-inview-first:nth-of-type(4) {
  transition-delay: 0.74s;
}

.list-news__item.is-inview-first:nth-of-type(4):before {
  transition-delay: 0.74s;
}

.list-news__item.is-inview-first:nth-of-type(5) {
  transition-delay: 0.9s;
}

.list-news__item.is-inview-first:nth-of-type(5):before {
  transition-delay: 0.9s;
}

.list-news__item.is-inview-first:nth-of-type(6) {
  transition-delay: 1.06s;
}

.list-news__item.is-inview-first:nth-of-type(6):before {
  transition-delay: 1.06s;
}

.list-news__item.is-inview-first:nth-of-type(7) {
  transition-delay: 1.22s;
}

.list-news__item.is-inview-first:nth-of-type(7):before {
  transition-delay: 1.22s;
}

.list-news__item.is-inview-first:nth-of-type(8) {
  transition-delay: 1.38s;
}

.list-news__item.is-inview-first:nth-of-type(8):before {
  transition-delay: 1.38s;
}

.list-news__item.is-inview-first:nth-of-type(9) {
  transition-delay: 1.54s;
}

.list-news__item.is-inview-first:nth-of-type(9):before {
  transition-delay: 1.54s;
}

.list-news__item.is-inview-first:nth-of-type(10) {
  transition-delay: 1.7s;
}

.list-news__item.is-inview-first:nth-of-type(10):before {
  transition-delay: 1.7s;
}

.list-news__item.is-inview:before {
  transform: scale(1, 1);
}

.list-news__date {
  color: var(--key-color);
  display: inline-block;
  font-size: 1.5rem;
  line-height: 1.53333;
  letter-spacing: 0.03em;
  width: 12.8rem;
}

@media screen and (max-width: 768px) {
  .list-news__date {
    font-size: 1rem;
    line-height: 1.8;
    font-weight: 500;
    width: 6.7rem;
  }
}

.list-news__text {
  display: inline-block;
  font-size: 1.6rem;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.01em;
  width: calc(100% - 19.6rem);
}

@media screen and (max-width: 768px) {
  .list-news__text {
    font-size: 1.2rem;
    line-height: 1.5;
    width: calc(100% - 10.5rem);
  }
}

.local-nav {
  padding-top: 1.9rem;
  position: sticky;
  top: 6.05rem;
  z-index: 998;
  background: #fff;
  padding-bottom: 0.95rem;
}

.local-nav::-webkit-scrollbar {
  display: none;
}

@media screen and (max-width: 768px) {
  .local-nav {
    padding-top: 1.2rem;
    top: 4.7rem;
    padding-bottom: 0.6rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll {
    overflow: auto;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__inner {
    display: -ms-inline-flexbox;
    display: inline-flex;
    padding: 0 3rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__item {
    padding: 0 1.4rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__item:first-of-type {
    padding-left: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__item:nth-of-type(n + 2) {
    margin-left: 0;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__item:last-of-type {
    padding-right: 1rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav--sp-scroll .local-nav__item a {
    padding-top: 0.6em;
    padding-bottom: 0.6em;
  }
}

.local-nav__inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  min-width: 100%;
}

@media screen and (max-width: 768px) {
  .local-nav__inner {
    -ms-flex-pack: center;
        justify-content: center;
    padding: 0 1.6rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav__item {
    display: inline-block;
    -ms-flex: 0 0 auto;
        flex: 0 0 auto;
  }
}

@media screen and (min-width: 769px) {
  .local-nav__item:nth-of-type(n + 2) {
    margin-left: 7.2rem;
  }
}

@media screen and (max-width: 768px) {
  .local-nav__item:nth-of-type(n + 2) {
    margin-left: 1.8rem;
  }
}

.local-nav__item a {
  color: #505050;
  font-size: 1.6rem;
  line-height: 2.25;
  font-weight: 700;
  letter-spacing: 0.02em;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
  text-decoration: none;
  text-underline-offset: 0.45em;
  text-decoration-thickness: 0.2rem;
}

@media screen and (max-width: 768px) {
  .local-nav__item a {
    display: block;
    font-size: 1.5rem;
    line-height: 1.2;
    white-space: nowrap;
    padding-bottom: 0.45em;
  }
}

.local-nav__item a.is-on {
  text-decoration: underline;
  text-decoration-thickness: 0.2rem;
  opacity: 0.7;
}

.local-nav__item.is-current a {
  text-decoration: underline;
  text-underline-offset: 0.45em;
  text-decoration-thickness: 0.2rem;
  -webkit-text-decoration-color: var(--key-color);
          text-decoration-color: var(--key-color);
}

.local-nav__item.is-disabled a {
  text-decoration: none;
}

.mt0 {
  margin-top: 0 !important;
}

.mt1 {
  margin-top: 1rem !important;
}

.mt2 {
  margin-top: 2rem !important;
}

.mt3 {
  margin-top: 3rem !important;
}

.mt4 {
  margin-top: 4rem !important;
}

.mt5 {
  margin-top: 5rem !important;
}

.mt6 {
  margin-top: 6rem !important;
}

.mb0 {
  margin-bottom: 0 !important;
}

.mb1 {
  margin-bottom: 1rem !important;
}

.mb2 {
  margin-bottom: 2rem !important;
}

.mb3 {
  margin-bottom: 3rem !important;
}

.mb4 {
  margin-bottom: 4rem !important;
}

.mb5 {
  margin-bottom: 5rem !important;
}

.mb6 {
  margin-bottom: 6rem !important;
}

.modal {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  background-repeat: no-repeat;
  background-position: center center;
  background-size: cover;
  z-index: 99999;
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .modal {
    min-height: 66.7rem;
  }
}

.modal.is-show {
  opacity: 1;
  pointer-events: auto;
}

.modal.is-show .modal__body .player-movie iframe.is-show {
  pointer-events: auto;
  display: block;
}

.modal__overlay {
  background-color: #000000;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  opacity: 0.8;
}

.modal__body {
  position: relative;
}

.modal__body .player-movie {
  width: 90rem;
  height: 54.1rem;
}

@media screen and (max-width: 768px) {
  .modal__body .player-movie {
    width: 34.9rem;
    height: 23rem;
  }
}

.modal__body .player-movie iframe {
  display: block;
  line-height: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  display: none;
}

.modal__close {
  position: fixed;
  top: 5rem;
  right: 5rem;
}

@media screen and (max-width: 768px) {
  .modal__close {
    top: 6.8rem;
    right: 1.5rem;
  }
}

.modal__close button {
  background-color: transparent;
  border: none;
  cursor: pointer;
  outline: none;
  padding: 0;
  appearance: none;
  display: block;
  width: 5rem;
  height: 5rem;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .modal__close button {
    width: 2.2rem;
    height: 1.4rem;
  }
}

.modal__close button.is-on {
  opacity: 0.7;
}

.modal__close button:before, .modal__close button:after {
  content: '';
  position: absolute;
  top: calc(50% - 1px / 2);
  left: calc(50% - 4rem / 2);
  background: #fff;
  display: block;
  width: 4rem;
  height: 0.2rem;
}

@media screen and (max-width: 768px) {
  .modal__close button:before, .modal__close button:after {
    position: absolute;
    top: calc(50% - 1px / 2);
    left: calc(50% - 2.4rem / 2);
    width: 2.4rem;
  }
}

.modal__close button:before {
  transform: rotate(45deg);
}

.modal__close button:after {
  transform: rotate(-45deg);
}

.modal--goods .modal__inner {
  background: #fff;
}

.page-header {
  transform: translateZ(0);
  will-change: filter;
}

.page-header__en, .page-header__ja {
  opacity: 0;
}

.page-header__en-off, .page-header__en-on {
  transform: translate(0, 100%);
  transition: transform 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  will-change: transform, filter;
}

.page-header__en-off span, .page-header__en-on span {
  transform: translate(0, 110%);
  transition: transform 1s cubic-bezier(0.165, 0.84, 0.44, 1);
  will-change: transform, filter;
}

.page-header__en-off span:nth-of-type(1), .page-header__en-on span:nth-of-type(1) {
  transition-delay: 0s;
}

.page-header__en-off span:nth-of-type(2), .page-header__en-on span:nth-of-type(2) {
  transition-delay: 0.035s;
}

.page-header__en-off span:nth-of-type(3), .page-header__en-on span:nth-of-type(3) {
  transition-delay: 0.07s;
}

.page-header__en-off span:nth-of-type(4), .page-header__en-on span:nth-of-type(4) {
  transition-delay: 0.105s;
}

.page-header__en-off span:nth-of-type(5), .page-header__en-on span:nth-of-type(5) {
  transition-delay: 0.14s;
}

.page-header__en-off span:nth-of-type(6), .page-header__en-on span:nth-of-type(6) {
  transition-delay: 0.175s;
}

.page-header__en-off span:nth-of-type(7), .page-header__en-on span:nth-of-type(7) {
  transition-delay: 0.21s;
}

.page-header__en-off span:nth-of-type(8), .page-header__en-on span:nth-of-type(8) {
  transition-delay: 0.245s;
}

.page-header__en-off span:nth-of-type(9), .page-header__en-on span:nth-of-type(9) {
  transition-delay: 0.28s;
}

.page-header__en-off span:nth-of-type(10), .page-header__en-on span:nth-of-type(10) {
  transition-delay: 0.315s;
}

.page-header__en-off span:nth-of-type(11), .page-header__en-on span:nth-of-type(11) {
  transition-delay: 0.35s;
}

.page-header__en-off span:nth-of-type(12), .page-header__en-on span:nth-of-type(12) {
  transition-delay: 0.385s;
}

.page-header__en-off span:nth-of-type(13), .page-header__en-on span:nth-of-type(13) {
  transition-delay: 0.42s;
}

.page-header__en-off span:nth-of-type(14), .page-header__en-on span:nth-of-type(14) {
  transition-delay: 0.455s;
}

.page-header__en-off span:nth-of-type(15), .page-header__en-on span:nth-of-type(15) {
  transition-delay: 0.49s;
}

.page-header__en-off span:nth-of-type(16), .page-header__en-on span:nth-of-type(16) {
  transition-delay: 0.525s;
}

.page-header__en-off span:nth-of-type(17), .page-header__en-on span:nth-of-type(17) {
  transition-delay: 0.56s;
}

.page-header__en-off span:nth-of-type(18), .page-header__en-on span:nth-of-type(18) {
  transition-delay: 0.595s;
}

.page-header__en-off span:nth-of-type(19), .page-header__en-on span:nth-of-type(19) {
  transition-delay: 0.63s;
}

.page-header__en-on {
  clip-path: inset(0 100% 0 0);
  opacity: 0;
  transition: clip-path 0.6s cubic-bezier(0.215, 0.61, 0.355, 1) 0.65s, opacity 0.8s cubic-bezier(0.075, 0.82, 0.165, 1) 0.65s, transform 1.2s cubic-bezier(0.23, 1, 0.32, 1);
  will-change: clip-path, -webkit-clip-path, opacity, transform, filter;
}

.page-header__en-on span {
  text-shadow: 0.025em -0.025em 0 #fff, 0.025em 0.025em 0 #fff, -0.025em -0.025em 0 #fff, -0.025em 0.025em 0 #fff;
}

.page-header__ja {
  transform: translate(0, 100%);
  transition: color 0.4s cubic-bezier(0.215, 0.61, 0.355, 1) 0.85s, transform 1s cubic-bezier(0.23, 1, 0.32, 1) 0.1s;
  will-change: transform, filter;
}

.page-header__ja-text {
  transform: translate(0, 110%);
  transition: transform 0.75s cubic-bezier(0.165, 0.84, 0.44, 1) 0.4s, opacity 0.3s cubic-bezier(0.23, 1, 0.32, 1) 0.2s;
  will-change: opacity, transform, filter;
}

.page-header:after {
  transform: scale(0, 1);
  transition: transform 0.75s cubic-bezier(0.86, 0, 0.07, 1) 0.5s;
  will-change: transform, filter;
}

.is-loaded .page-header__en, .is-loaded .page-header__ja {
  opacity: 1;
}

.is-loaded .page-header__en-off, .is-loaded .page-header__en-on {
  transform: translate(0, 0);
}

.is-loaded .page-header__en-off span, .is-loaded .page-header__en-on span {
  transform: translate(0, 0);
}

.is-loaded .page-header__en-on {
  clip-path: inset(0 0 0 0);
  opacity: 1;
}

.is-loaded .page-header__ja {
  color: #161616;
  transform: translate(0, 0);
}

.is-loaded .page-header__ja-text {
  transform: translate(0, 0);
}

.is-loaded .page-header:after {
  transform: scale(1, 1);
}

.page-header {
  color: #161616;
  text-align: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  width: 119rem;
  max-width: 100%;
  margin: 0 auto;
  padding: 4.5rem 0 4.2rem;
}

@media screen and (max-width: 768px) {
  .page-header {
    width: 34.4rem;
    padding: 1.6rem 0 1.7rem;
  }
}

.page-header:before, .page-header:after {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 0.2rem;
  z-index: 1;
  transform-origin: left center;
}

@media screen and (max-width: 768px) {
  .page-header:before, .page-header:after {
    height: 0.15rem;
  }
}

.page-header:after {
  background: #161616;
  z-index: 2;
}

.page-header__en {
  position: relative;
  font-family: "Manrope", sans-serif;
  font-size: 4.2rem;
  line-height: 1;
  display: inline-block;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .page-header__en {
    font-size: 2.5rem;
  }
}

.page-header__en-off, .page-header__en-on {
  position: relative;
  display: inline-block;
  overflow: hidden;
}

.page-header__en-off span, .page-header__en-on span {
  display: inline-block;
}

.page-header__en-off {
  color: var(--key-color);
  z-index: 0;
}

.page-header__en-on {
  position: absolute;
  left: 0;
  top: 0;
  z-index: 1;
  width: 100%;
}

.page-header__ja {
  color: var(--key-color);
  font-size: 1.3rem;
  line-height: 1;
  font-weight: 500;
  letter-spacing: 0.02em;
  display: inline-block;
  margin-top: 0.5rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .page-header__ja {
    font-size: 1rem;
    margin-top: 0.4rem;
  }
}

.page-header__ja-text {
  display: inline-block;
}

.section {
  color: #505050;
  padding-bottom: 4.5rem;
  counter-reset: number-heading-second;
}

.section:first-of-type {
  padding-top: 3.5rem;
}

.section--padding-top-0 {
  padding-top: 0;
}

.section--padding-top-0 .section__inner:first-child > .section__heading-third:first-child {
  margin-top: 0;
}

.section--padding-bottom-0 {
  padding-bottom: 0;
}

.section--padding-top {
  padding-top: 4rem;
}

.section--padding-top:first-of-type {
  padding-top: 4rem;
}

.section--banner {
  padding-bottom: 0;
}

.section--notfound {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  min-height: calc(100vh - 14rem - 18.5rem);
}

@media screen and (max-width: 768px) {
  .section--notfound {
    min-height: calc(100vh - 5.3rem - 14.8rem);
  }
}

.section__inner {
  width: 100%;
  max-width: 98rem;
  padding: 0 1rem;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .section__inner {
    width: 34.3rem;
    padding: 0;
  }
}

@media screen and (max-width: 768px) {
  .section__inner .section__text--center {
    padding: 0;
  }
}

.section__heading {
  font-size: 2.4rem;
  line-height: 1.25;
  font-weight: 700;
  text-align: center;
}

.section__heading + .section__inner {
  margin-top: 3rem;
}

.section__heading--small {
  font-size: 2.2rem;
  line-height: 1.31818;
}

.section__heading-second {
  position: relative;
  color: var(--key-color);
  font-size: 2rem;
  line-height: 1.45;
  font-weight: 700;
  letter-spacing: 0.02em;
  width: 100%;
  max-width: 96rem;
  margin: 0 auto;
  padding-bottom: 1.4rem;
  margin-bottom: 2rem;
}

@media screen and (max-width: 960px) {
  .section__heading-second {
    width: calc(100% - 10px * 2);
  }
}

@media screen and (max-width: 768px) {
  .section__heading-second {
    width: 34.3rem;
  }
}

.section__heading-second:nth-of-type(n + 2) {
  margin-top: 5.5rem;
}

.section__heading-second:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
  transform: scale(0, 1);
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.section__heading-second.is-inview-first:nth-of-type(1):before {
  transition-delay: 0.38s;
}

.section__heading-second.is-inview-first:nth-of-type(2):before {
  transition-delay: 0.66s;
}

.section__heading-second.is-inview-first:nth-of-type(3):before {
  transition-delay: 0.94s;
}

.section__heading-second.is-inview-first:nth-of-type(4):before {
  transition-delay: 1.22s;
}

.section__heading-second.is-inview-first:nth-of-type(5):before {
  transition-delay: 1.5s;
}

.section__heading-second.is-inview-first:nth-of-type(6):before {
  transition-delay: 1.78s;
}

.section__heading-second.is-inview-first:nth-of-type(7):before {
  transition-delay: 2.06s;
}

.section__heading-second.is-inview-first:nth-of-type(8):before {
  transition-delay: 2.34s;
}

.section__heading-second.is-inview-first:nth-of-type(9):before {
  transition-delay: 2.62s;
}

.section__heading-second.is-inview-first:nth-of-type(10):before {
  transition-delay: 2.9s;
}

.section__heading-second.is-inview-first:nth-of-type(11):before {
  transition-delay: 3.18s;
}

.section__heading-second.is-inview-first:nth-of-type(12):before {
  transition-delay: 3.46s;
}

.section__heading-second.is-inview-first:nth-of-type(13):before {
  transition-delay: 3.74s;
}

.section__heading-second.is-inview-first:nth-of-type(14):before {
  transition-delay: 4.02s;
}

.section__heading-second.is-inview-first:nth-of-type(15):before {
  transition-delay: 4.3s;
}

.section__heading-second.is-inview-first:nth-of-type(16):before {
  transition-delay: 4.58s;
}

.section__heading-second.is-inview-first:nth-of-type(17):before {
  transition-delay: 4.86s;
}

.section__heading-second.is-inview-first:nth-of-type(18):before {
  transition-delay: 5.14s;
}

.section__heading-second.is-inview-first:nth-of-type(19):before {
  transition-delay: 5.42s;
}

.section__heading-second.is-inview-first:nth-of-type(20):before {
  transition-delay: 5.7s;
}

.section__heading-second.is-inview-first:nth-of-type(21):before {
  transition-delay: 5.98s;
}

.section__heading-second.is-inview-first:nth-of-type(22):before {
  transition-delay: 6.26s;
}

.section__heading-second.is-inview-first:nth-of-type(23):before {
  transition-delay: 6.54s;
}

.section__heading-second.is-inview-first:nth-of-type(24):before {
  transition-delay: 6.82s;
}

.section__heading-second.is-inview-first:nth-of-type(25):before {
  transition-delay: 7.1s;
}

.section__heading-second.is-inview-first:nth-of-type(26):before {
  transition-delay: 7.38s;
}

.section__heading-second.is-inview-first:nth-of-type(27):before {
  transition-delay: 7.66s;
}

.section__heading-second.is-inview-first:nth-of-type(28):before {
  transition-delay: 7.94s;
}

.section__heading-second.is-inview-first:nth-of-type(29):before {
  transition-delay: 8.22s;
}

.section__heading-second.is-inview-first:nth-of-type(30):before {
  transition-delay: 8.5s;
}

.section__heading-second.is-inview:before {
  transform: scale(1, 1);
}

.section__heading-second--margin-top-short:nth-of-type(n + 2) {
  margin-top: 4rem;
}

.section__heading-second--history {
  margin-top: 1.5rem;
  margin-bottom: 1.8rem;
}

@media screen and (max-width: 768px) {
  .section__heading-second--history {
    margin-top: 2.7rem;
    margin-bottom: 1.5rem;
  }
}

.section__heading-second--history:nth-of-type(n + 2) {
  margin-top: 2.2rem;
}

.section__heading-second--number {
  color: #505050;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  counter-increment: number-heading-number 1;
}

.section__heading-second--number:after {
  content: counter(number-heading-number);
  color: #fff;
  background-color: var(--key-color);
  -ms-flex-order: -1;
      order: -1;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
  margin-right: 1rem;
}

.section__heading-second--number .icon-text {
  background-color: #505050;
  font-size: 1.1rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.01em;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  height: 2.4rem;
  border-radius: 0.5rem;
  padding: 0 0.6rem 0.1rem;
  margin: 0.2rem 0 0 0.8rem;
}

@media screen and (max-width: 768px) {
  .section__heading-second--number .icon-text {
    margin-left: 1.2rem;
  }
}

.section__heading-second--number .icon-text--end {
  color: #fff;
  background: #808080;
}

.section__heading-second--number .icon-text--before {
  color: #a6a6a6;
  background: #e6e6e6;
}

.section__heading-second--number .icon-text--active {
  color: #fff;
  background: var(--key-color);
}

.section__heading-second--disc {
  color: #505050;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.section__heading-second--disc:after {
  content: '・';
  color: var(--key-color);
  -ms-flex-order: -1;
      order: -1;
  font-weight: 700;
  display: inline-block;
  margin-right: 0.5em;
}

.section__heading-second--disc .icon-text {
  background-color: #505050;
  font-size: 1.1rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.01em;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  height: 2.4rem;
  border-radius: 0.5rem;
  padding: 0 0.6rem 0.1rem;
  margin: 0.2rem 0 0 0.8rem;
}

@media screen and (max-width: 768px) {
  .section__heading-second--disc .icon-text {
    margin-left: 1.2rem;
  }
}

.section__heading-second--disc .icon-text--end {
  color: #fff;
  background: #808080;
}

.section__heading-second--disc .icon-text--before {
  color: #a6a6a6;
  background: #e6e6e6;
}

.section__heading-second--disc .icon-text--active {
  color: #fff;
  background: var(--key-color);
}

.section__heading-second .icon-image {
  display: inline-block;
  vertical-align: bottom;
  height: 1.8em;
}

.section__heading-second .icon-image--ticket {
  width: 4.2rem;
  height: auto;
  margin-right: 1.2rem;
  vertical-align: middle;
}

.section__heading-second .icon-image--phone {
  width: 2.3rem;
  margin: 0 0.8rem 0 0.4rem;
}

.section__heading-second .icon-image--pay {
  width: 3.5rem;
  margin: 0 0.8rem 0 0.2rem;
}

.section__heading-second .icon-image--time {
  width: 3.2rem;
  margin: 0 0.8rem -0.4rem 0.2rem;
}

.section__heading-second .icon-image--food {
  width: 2.2rem;
  margin: 0 1.4rem -0.4rem 0.6rem;
}

.section__heading-third {
  font-size: 2rem;
  line-height: 1.45;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-top: 3.5rem;
}

@media screen and (max-width: 768px) {
  .section__heading-third + .section__text {
    margin-top: 0.8rem;
  }
}

.section__heading-third--small {
  font-size: 1.8rem;
  line-height: 1.44444;
}

.section__heading-third--center {
  text-align: center;
}

.section__heading-third--margin-top0 {
  margin-top: 0;
}

.section__heading-third--history {
  color: #707070;
  font-size: 1.8rem;
  line-height: 1.22222;
  margin-top: calc(-2rem + 1.5rem);
}

@media screen and (max-width: 768px) {
  .section__heading-third--history {
    margin-top: calc(-1.5rem + 1.5rem);
  }
}

.section__heading-third--history:nth-of-type(n + 2) {
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .section__heading-third--history + .section__text {
    margin-top: 1.2rem;
  }
}

.section__heading-fourth {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  font-weight: 700;
  margin-top: 3rem;
}

@media screen and (min-width: 769px) {
  .section__heading-fourth--pc-center {
    text-align: center;
  }
}

.section__heading-fourth--center {
  text-align: center;
}

@media screen and (max-width: 768px) {
  .section__heading-fourth + .section__text {
    margin-top: 0.8rem;
  }
}

.section__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  text-align: left;
  margin-top: 1.2rem;
}

.section__text:first-child {
  margin-top: 0;
}

.section__text strong {
  font-weight: 700;
}

@media screen and (min-width: 769px) {
  .section__text--center {
    text-align: center;
  }
}

@media screen and (max-width: 768px) {
  .section__text--center {
    padding: 0 1.6rem;
  }
}

.section__text--letter-spacing-wide {
  letter-spacing: 0.05em;
}

.section__text + .section__text {
  margin-top: 1.2rem;
}

.section__text.bg-gray {
  border-radius: 0.5rem;
}

@media screen and (max-width: 768px) {
  .section__text.bg-gray {
    border-radius: 0.4rem;
  }
}

.section__text li {
  padding-left: 1.94em;
  text-indent: -1.94em;
  text-align: left;
  font-feature-settings: normal;
}

.section__term {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 1.2rem;
}

.section__term:first-child {
  margin-top: 0;
}

.section__term strong {
  font-weight: 700;
}

.section__term + .section__term {
  margin-top: 2.2rem;
}

.section__note {
  margin-top: 1rem;
  font-size: 1.2rem;
  line-height: 1.6;
  letter-spacing: 0.02em;
}

@media screen and (max-width: 768px) {
  .section__note {
    margin-top: 2rem;
  }
}

.section__note--red {
  color: red;
}

.section__note--indent {
  padding-left: 1.2em;
  text-indent: -1.2em;
}

.section__note--margin-top-small {
  margin-top: 0.4rem;
}

@media screen and (max-width: 768px) {
  .section__note--margin-top-small {
    margin-top: 1rem;
  }
}

.section__note li {
  font-size: 1.2rem;
  line-height: 1.7;
  padding-left: 1.3em;
  text-indent: -1.3em;
  text-align: left;
  font-feature-settings: normal;
}

.section__note li:before {
  content: '※ ';
}

.section__note small {
  font-size: 1.1rem;
  line-height: 1.54545;
}

@media screen and (max-width: 768px) {
  .section__note small {
    display: inline-block;
    padding-left: 1em;
    text-indent: -1em;
  }
}

.section__note strong {
  font-weight: 700;
}

.section__note p:nth-child(n + 2) {
  margin-top: 1em;
}

.section__note a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.section__note a.color-key {
  color: var(--key-color);
}

.section__note a.color-app {
  color: #e1230f;
}

.section__note + .section__text {
  margin-top: 2.4rem;
}

.section__note-disc li, .section__note--disc li {
  padding-left: 1.55em;
  text-indent: -1.55em;
  margin-top: 0.7em;
}

.section__note-disc li:before, .section__note--disc li:before {
  content: '・　';
}

.section__note--small li {
  font-size: 1.1rem;
  line-height: 1.63636;
  padding-left: 1.275em;
  text-indent: -1.275em;
}

.section__note.bg-gray {
  margin-top: 2rem;
}

.section__note.bg-gray .js-toggle-accordion {
  position: relative;
  z-index: 2;
  background: #fff;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  margin: -1.5rem -2.2rem;
  padding: 1.5rem 2.2rem;
}

@media screen and (max-width: 768px) {
  .section__note.bg-gray .js-toggle-accordion {
    margin: -1.5rem -1.8rem;
    padding: 1.5rem 1.8rem;
    padding-right: 5rem;
  }
}

.section__note.bg-gray .js-toggle-accordion:after {
  border-color: transparent transparent #505050 transparent;
}

.section__note.bg-gray .js-toggle-accordion:before {
  content: '';
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background-color: #efefef;
  border-radius: 0.5rem;
  transition: border-radius 0.1s cubic-bezier(0.39, 0.575, 0.565, 1) 0.3s;
}

@media screen and (max-width: 768px) {
  .section__note.bg-gray .js-toggle-accordion:before {
    border-radius: 0.4rem;
  }
}

.section__note.bg-gray .js-toggle-accordion.is-show:before {
  border-radius: 0.5rem 0.5rem 0 0;
  transition-delay: 0s;
}

@media screen and (max-width: 768px) {
  .section__note.bg-gray .js-toggle-accordion.is-show:before {
    border-radius: 0.4rem 0.4rem 0 0;
  }
}

.section__note.bg-gray .js-toggle-accordion-content:before {
  content: '';
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  background-color: #efefef;
  border-radius: 0 0 0.5rem 0.5rem;
}

@media screen and (max-width: 768px) {
  .section__note.bg-gray .js-toggle-accordion-content:before {
    border-radius: 0 0 0.4rem 0.4rem;
  }
}

@media screen and (max-width: 768px) {
  .section__note.bg-gray + .bg-gray {
    margin-top: -1rem;
  }
}

.section__note.bg-gray.section__note--red {
  color: red;
}

.section__note.bg-white {
  color: #505050;
  background: #fff;
  margin-top: 1.8rem;
}

.section__note.bg-white.section__note--red {
  color: red;
}

.section__note .js-toggle-accordion {
  position: relative;
  background: #fff;
  margin: -1.5rem -2.2rem;
  padding: 1.5rem 2.2rem;
}

@media screen and (max-width: 768px) {
  .section__note .js-toggle-accordion {
    margin: -1.5rem -1.8rem;
    padding: 1.5rem 1.8rem;
    padding-right: 5rem;
  }
}

.section__note .js-toggle-accordion:after {
  content: '';
  position: absolute;
  z-index: 1;
  right: 2.8rem;
  top: calc(50% - 0.9rem / 2);
  display: block;
  border: solid;
  border-width: 0 0.8rem 0.9rem 0.8rem;
  border-color: transparent transparent #505050 transparent;
  transform: rotate(180deg);
}

@media screen and (max-width: 768px) {
  .section__note .js-toggle-accordion:after {
    right: 1.6rem;
  }
}

.section__note .js-toggle-accordion.is-show:after {
  transform: rotate(0deg);
}

.section__note .js-toggle-accordion-content {
  position: relative;
  z-index: 1;
  background: #fff;
  margin: 0 -2.2rem -1.5rem;
  padding: 1.5rem 2.2rem;
}

@media screen and (max-width: 768px) {
  .section__note .js-toggle-accordion-content {
    margin: 0 -1.8rem -1.5rem;
    padding: 1.5rem 1.8rem;
  }
}

.section__note .js-toggle-accordion-content p:first-child {
  margin-top: 1em;
}

.section__list {
  margin-top: 1.5rem;
  margin-bottom: 3rem;
  font-size: 1.2rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  border: 1px solid var(--key-color);
  padding: 1.5rem 2.4rem 1.5rem 2rem;
}

@media screen and (max-width: 768px) {
  .section__list {
    margin-top: 1.6rem;
  }
}

.section__list > li {
  font-size: 1.5rem;
  line-height: 1.6875;
  padding-left: 1.3em;
  text-indent: -1.3em;
  text-align: left;
  font-feature-settings: normal;
}

@media screen and (max-width: 768px) {
  .section__list > li {
    padding-left: 1.1em;
    text-indent: -1.1em;
  }
}

.section__list > li:before {
  content: '';
  background: var(--key-color);
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  margin: 0 1rem 0.2rem 0.2rem;
}

@media screen and (max-width: 768px) {
  .section__list > li:before {
    width: 0.6rem;
    height: 0.6rem;
  }
}

.section__list > li strong {
  font-weight: 700;
}

.section__list > li a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.section__list > li a.color-key {
  color: var(--key-color);
}

.section__list > li a.color-app {
  color: #e1230f;
}

.section__list > li .text-nowrap {
  white-space: nowrap;
}

.section__list > li small {
  font-size: 1.2rem;
  line-height: 1.5;
}

.section__list > li + li {
  margin-top: 2.3rem;
}

.section__list > li ul,
.section__list > li ol {
  margin-top: 1rem;
}

.section__list > li ul li + li,
.section__list > li ol li + li {
  margin-top: 0.6rem;
}

@media screen and (max-width: 768px) {
  .section__list > li ul li + li,
  .section__list > li ol li + li {
    margin-top: 0.4rem;
  }
}

.section__list--disc {
  padding: 0;
  border: none;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .section__list--disc {
    margin-top: 1.6rem;
  }
}

.section__list--disc > li {
  padding-left: 1.55em;
  text-indent: -1.55em;
}

.section__list--disc > li:before {
  content: '・　';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .section__list--disc > li:before {
    width: auto;
    height: auto;
  }
}

.section__list--disc > li + li {
  margin-top: 1.2rem;
}

.section__list--note {
  padding: 0;
  border: none;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .section__list--note {
    margin-top: 1.6rem;
  }
}

.section__list--note > li {
  padding-left: 1.35em;
  text-indent: -1.35em;
}

.section__list--note > li:before {
  content: '※ ';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .section__list--note > li:before {
    width: auto;
    height: auto;
  }
}

.section__list--note > li + li {
  margin-top: 1.2rem;
}

.section__list--key-color > li:before {
  color: var(--key-color);
}

.section__list--number {
  padding: 0;
  border: none;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .section__list--number {
    margin-top: 1.6rem;
  }
}

.section__list--number > li {
  padding-left: 1.55em;
  text-indent: -1.55em;
}

.section__list--number > li:before {
  content: '・　';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0;
}

@media screen and (max-width: 768px) {
  .section__list--number > li:before {
    width: auto;
    height: auto;
  }
}

.section__list--number > li + li {
  margin-top: 1.2rem;
}

.section__list--number > li:nth-child(1):before {
  content: "1　";
}

.section__list--number > li:nth-child(2):before {
  content: "2　";
}

.section__list--number > li:nth-child(3):before {
  content: "3　";
}

.section__list--number > li:nth-child(4):before {
  content: "4　";
}

.section__list--number > li:nth-child(5):before {
  content: "5　";
}

.section__list--number > li:nth-child(6):before {
  content: "6　";
}

.section__list--number > li:nth-child(7):before {
  content: "7　";
}

.section__list--number > li:nth-child(8):before {
  content: "8　";
}

.section__list--number > li:nth-child(9):before {
  content: "9　";
}

.section__list--number > li:nth-child(10):before {
  content: "10　";
}

.section__list--number > li:nth-child(11):before {
  content: "11　";
}

.section__list--number > li:nth-child(12):before {
  content: "12　";
}

.section__list--number > li:nth-child(13):before {
  content: "13　";
}

.section__list--number > li:nth-child(14):before {
  content: "14　";
}

.section__list--number > li:nth-child(15):before {
  content: "15　";
}

.section__list--number > li:nth-child(16):before {
  content: "16　";
}

.section__list--number > li:nth-child(17):before {
  content: "17　";
}

.section__list--number > li:nth-child(18):before {
  content: "18　";
}

.section__list--number > li:nth-child(19):before {
  content: "19　";
}

.section__list--number > li:nth-child(20):before {
  content: "20　";
}

.section__list--large-number {
  padding: 0;
  border: none;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .section__list--large-number {
    margin-top: 1.6rem;
  }
}

.section__list--large-number > li {
  padding-left: 1.1em;
  text-indent: -1.1em;
}

.section__list--large-number > li:before {
  content: '・　';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0;
  color: var(--key-color);
  font-weight: 900;
}

@media screen and (max-width: 768px) {
  .section__list--large-number > li:before {
    width: auto;
    height: auto;
  }
}

.section__list--large-number > li + li {
  margin-top: 1.2rem;
}

.section__list--large-number > li:nth-child(1):before {
  content: "1";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(2):before {
  content: "2";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(3):before {
  content: "3";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(4):before {
  content: "4";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(5):before {
  content: "5";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(6):before {
  content: "6";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(7):before {
  content: "7";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(8):before {
  content: "8";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(9):before {
  content: "9";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(10):before {
  content: "10";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(11):before {
  content: "11";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(12):before {
  content: "12";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(13):before {
  content: "13";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(14):before {
  content: "14";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(15):before {
  content: "15";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(16):before {
  content: "16";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(17):before {
  content: "17";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(18):before {
  content: "18";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(19):before {
  content: "19";
  padding-right: 0.5em;
}

.section__list--large-number > li:nth-child(20):before {
  content: "20";
  padding-right: 0.5em;
}

.section__list--margin-bottom-0 {
  margin-bottom: 0;
}

.section__flow {
  counter-reset: number-flow 0;
}

.section__flow > li {
  position: relative;
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.02em;
  display: -ms-flexbox;
  display: flex;
  counter-increment: number-flow 1;
  padding-top: calc(3.25rem / 2 - 1.5rem * 1.5 / 2);
}

.section__flow > li + li {
  margin-top: 4.5rem;
}

.section__flow > li:last-of-type:after {
  display: none;
}

.section__flow > li:before {
  content: counter(number-flow);
  color: #fff;
  background-color: var(--key-color);
  -ms-flex-order: -1;
      order: -1;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
  width: 3.25rem;
  height: 3.25rem;
  border-radius: 100%;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
  margin-right: 1rem;
  margin-top: calc((3.25rem / 2 - 1.5rem * 1.5 / 2) * -1);
}

.section__flow > li:after {
  content: '';
  background: #efefef;
  position: absolute;
  top: 0;
  left: calc(3.25rem / 2 - 0.3rem / 2);
  width: 0.3rem;
  height: calc(100% + 4.5rem);
  z-index: 0;
}

.section__image {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: start;
      align-items: flex-start;
  margin-top: 1.6rem;
  padding-bottom: 1rem;
}

.section__image:first-child {
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  .section__image img {
    width: auto;
  }
}

@media screen and (min-width: 769px) {
  .section__image--small img {
    width: 45.73333rem;
  }
}

.section__image--width100 {
  width: 100%;
}

.section__image--width100 img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section__image--width90 {
    width: 90%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section__image--width90 img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section__image--width80 {
    width: 80%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section__image--width80 img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section__image--width70 {
    width: 70%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section__image--width70 img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section__image--width60 {
    width: 60%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section__image--width60 img {
  width: 100%;
}

@media screen and (min-width: 769px) {
  .section__image--width50 {
    width: 50%;
    margin-left: auto;
    margin-right: auto;
  }
}

.section__image--width50 img {
  width: 100%;
}

.section__image--padding-top-bottom {
  padding-top: 2.5rem;
  padding-bottom: 2.5rem;
}

@media screen and (max-width: 768px) {
  .section__image--padding-top-bottom {
    padding-top: 1.5rem;
    padding-bottom: 1.5rem;
  }
}

@media screen and (min-width: 769px) {
  .section__image-with-text {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
        align-items: center;
    margin-top: 1rem;
  }
  .section__image-with-text > * {
    margin-top: 0;
    padding-bottom: 0;
  }
  .section__image-with-text .section__image {
    margin-right: 3rem;
    margin-left: 0;
  }
}

.section__map {
  width: 100%;
  height: 30rem;
  margin-top: 2.4rem;
}

@media screen and (max-width: 768px) {
  .section__map {
    height: 26rem;
  }
}

.section__map iframe {
  display: block;
  width: 100%;
  height: 100%;
}

.section p a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.section p a.color-key {
  color: var(--key-color);
}

.section p a.color-app {
  color: #e1230f;
}

.section .bg-white {
  color: #505050;
  background: #fff;
  padding: 1.6rem 1.8rem;
}

.section .bg-gray {
  background-color: #efefef;
  padding: 1.5rem 2.2rem;
  margin-bottom: 1.5rem;
}

@media screen and (max-width: 768px) {
  .section .bg-gray {
    padding: 1.5rem 1.8rem;
    margin-bottom: 3rem;
  }
}

.section .bg-gray:last-child {
  margin-bottom: 0;
}

.section .frame-color {
  padding: 1.5rem 2.2rem;
  margin-bottom: 1.5rem;
  border: 1px solid var(--key-color);
}

@media screen and (max-width: 768px) {
  .section .frame-color {
    padding: 1.5rem 1.8rem;
    margin-bottom: 3rem;
  }
}

.section .frame-color:last-child {
  margin-bottom: 0;
}

.section .frame-gray {
  padding: 1.5rem 2.2rem;
  margin-bottom: 1.5rem;
  border: 1px solid #e5e5e5;
}

@media screen and (max-width: 768px) {
  .section .frame-gray {
    padding: 1.5rem 1.8rem;
    margin-bottom: 3rem;
  }
}

.section .frame-gray:last-child {
  margin-bottom: 0;
}

.section--bg-black {
  color: #fff;
  background: #505050;
  padding-top: 4rem;
}

@media screen and (max-width: 768px) {
  .section--bg-black {
    padding-bottom: 5rem;
  }
}

.section--bg-black .section__heading {
  color: #fff;
}

.section--bg-black .section__heading-third {
  color: #fff;
}

.section--bg-black .section__note.bg-gray {
  color: #505050;
}

.section--bg-black + .section {
  padding-top: 4rem;
}

.section--bg-black + .section--padding-top-0 {
  padding-top: 4rem;
}

.section--bg-black + .section--padding-top-0.section--bg-black, .section--bg-black + .section--padding-top-0.section--bg-light-gray {
  padding-top: 0;
}

@media screen and (max-width: 768px) {
  .section--bg-black + .section--banner {
    padding-top: 3.4rem;
  }
}

.section--bg-light-gray {
  background: #f5f5f5;
  padding-top: 4rem;
}

@media screen and (max-width: 768px) {
  .section--bg-light-gray {
    padding-bottom: 4.2rem;
  }
}

.section--bg-light-gray .section__heading-second:before {
  background-color: #e5e5e5;
}

.section--bg-light-gray + .section {
  padding-top: 4rem;
}

.section--bg-light-gray + .section--padding-top-0 {
  padding-top: 0;
}

@media screen and (max-width: 768px) {
  .section--bg-light-gray + .section--banner {
    padding-top: 3.4rem;
  }
}

.section--bg-light-gray .bg-gray {
  background-color: #e5e5e5;
}

.section--border-bottom {
  padding-bottom: 0;
}

.section--border-bottom .section__inner:last-of-type {
  padding-bottom: 5.2rem;
  border-bottom: 1px solid #eee;
}

@media screen and (max-width: 768px) {
  .section--border-bottom .section__inner:last-of-type {
    padding-bottom: 3.2rem;
  }
}

.section--border-bottom + .section {
  padding-top: 4.5rem;
}

@media screen and (max-width: 768px) {
  .section--border-bottom + .section--banner {
    padding-top: 3.4rem;
  }
}

.section.section--main-index {
  padding-top: 0;
}

.frame-notice {
  margin-top: 3rem;
  padding: 0 2.2rem;
  border: 1px solid #e5e5e5;
}

.frame-notice__item {
  padding: 3rem 0;
}

.frame-notice__item > *:first-child {
  margin-top: 0;
}

.frame-notice__item + .frame-notice__item {
  border-top: 1px solid #e5e5e5;
}

.color-key {
  color: var(--key-color);
}

.color-red {
  color: #f00;
}

.text-align-right {
  text-align: right;
}

.text-underline-normal,
.text-underline-keycolor,
.text-underline-yellow {
  display: inline;
  border-bottom: 0.2rem solid #505050;
  line-height: 1.2;
}

.text-underline-keycolor {
  border-bottom-color: var(--key-color);
}

.text-underline-yellow {
  border-bottom-color: #ece692;
}

.sp-view-height {
  position: fixed;
  z-index: -1;
  opacity: 0;
  pointer-events: none;
  height: -webkit-fill-available;
  height: fill-available;
  max-height: -webkit-fill-available;
  max-height: fill-available;
}

@media screen and (min-width: 769px) {
  .sp-view-height {
    display: none;
  }
}

.svg-color {
  fill: var(--key-color);
}

.text-countdown {
  position: absolute;
  z-index: 2;
  right: 0;
  top: 0;
  font-size: 1.3rem;
  line-height: 1;
  letter-spacing: 0.02em;
  font-weight: 700;
  padding: 3rem 3rem 0 0;
}

@media screen and (max-width: 768px) {
  .text-countdown {
    color: #fff;
    padding: 1.3rem 1.3rem 0 0;
  }
}

.text-countdown__date {
  font-size: 3.6rem;
  padding: 0 0.15em;
}

@media screen and (max-width: 768px) {
  .text-countdown__date {
    font-size: 2.2rem;
  }
}

.button-pagetop {
  position: sticky;
  z-index: 99;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
      justify-content: flex-end;
  padding-right: 3rem;
  right: 0;
  bottom: 5.5rem;
  height: 0;
}

@media screen and (max-width: 768px) {
  .button-pagetop {
    padding-right: 1rem;
    bottom: 3.7rem;
  }
}

.button-pagetop a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  background: rgba(68, 68, 68, 0.75);
  width: 5rem;
  height: 5rem;
  padding-top: 0.8rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
  margin: -2.5rem 0;
}

.button-pagetop a.is-on {
  opacity: 0.6;
}

.button-pagetop a:before {
  content: '';
  display: block;
  width: 1.4rem;
  height: 1.4rem;
  border: solid #fff;
  border-width: 0.2rem 0.2rem 0 0;
  box-sizing: border-box;
  transform: rotate(-45deg);
}

.button-pagetop {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.is-scrolled .button-pagetop {
  opacity: 1;
  pointer-events: auto;
}

.button-tickets {
  position: sticky;
  z-index: 99;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
      justify-content: flex-end;
  padding-right: 3rem;
  right: 0;
  bottom: 8.65rem;
  height: 0;
}

@media screen and (max-width: 768px) {
  .button-tickets {
    padding-right: 1rem;
    bottom: 5.35rem;
  }
}

.button-tickets a {
  position: relative;
  display: block;
  width: 11.3rem;
  height: 11.3rem;
  border-radius: 50%;
  margin: -5.65rem 0;
}

@media screen and (max-width: 768px) {
  .button-tickets a {
    width: 8.3rem;
    height: 8.3rem;
    margin: -4.15rem 0;
  }
}

.button-tickets a img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

.button-tickets a.is-on .button-tickets__shadow {
  animation: shadow-hover 1.8s cubic-bezier(0.39, 0.575, 0.565, 1) infinite;
}

@keyframes shadow-hover {
  0% {
    transform: scale(1);
    opacity: 0.1;
  }
  5% {
    transform: scale(1);
    opacity: 0.9;
  }
  90% {
    transform: scale(1.1);
    opacity: 0.0;
  }
  100% {
    transform: scale(1.1);
    opacity: 0.0;
  }
}

.button-tickets__shadow {
  position: absolute;
  z-index: -1;
  left: 0;
  top: 0;
  display: block;
  width: 100%;
  height: 100%;
  background: #0050F0;
  border-radius: 50%;
  opacity: 0;
  box-shadow: 0 0 1.5rem rgba(255, 255, 255, 0.7);
  animation: shadow 1.8s cubic-bezier(0.39, 0.575, 0.565, 1) infinite;
}

@keyframes shadow {
  0% {
    transform: scale(1);
    opacity: 0;
  }
  5% {
    transform: scale(1);
    opacity: 0.6;
  }
  60% {
    transform: scale(1.3);
    opacity: 0;
  }
  100% {
    transform: scale(1.3);
    opacity: 0;
  }
}

@media screen and (max-width: 768px) {
  .button-tickets__shadow {
    animation-name: shadow-sp;
  }
}

@keyframes shadow-sp {
  0% {
    transform: scale(1);
    opacity: 0;
  }
  5% {
    transform: scale(1);
    opacity: 0.6;
  }
  60% {
    transform: scale(1.25);
    opacity: 0;
  }
  100% {
    transform: scale(1.25);
    opacity: 0;
  }
}

.button-tickets {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.is-scrolled .button-tickets {
  opacity: 1;
  pointer-events: auto;
}

.text-copyright {
  color: #fff;
  font-size: 1rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.01em;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .text-copyright {
    font-size: 0.9rem;
  }
}

.banner-header {
  width: 100%;
}

.banner-header a {
  display: block;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.banner-header a.is-on {
  opacity: 0.5;
}

.button-hamburger {
  position: absolute;
  top: 0;
  left: 0;
  padding: 0;
  outline: none;
  border: none;
  background: transparent;
  cursor: pointer;
  background: #000000;
  display: block;
  width: 8.5rem;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .button-hamburger {
    background: #000000;
    display: block;
    width: 6rem;
    height: 100%;
  }
}

.button-hamburger__line {
  position: absolute;
  top: calc(50% - 0.2rem / 2);
  left: calc(50% - 2.5rem / 2);
  width: 2.5rem;
  height: 0.2rem;
  background: #fff;
  border-radius: 2px;
  transition: top 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, left 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, width 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, transform 0.1s cubic-bezier(0.39, 0.575, 0.565, 1), opacity 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s;
}

.button-hamburger__line:nth-of-type(1) {
  top: calc(50% - 0.2rem / 2 - 0.9rem);
}

.button-hamburger__line:nth-of-type(3) {
  top: calc(50% - 0.2rem / 2 + 0.9rem);
}

.is-show-nav .button-hamburger__line {
  position: absolute;
  top: calc(50% - 0.2rem / 2);
  left: calc(50% - 3.6rem / 2);
  width: 3.6rem;
  height: 0.2rem;
  transition: top 0.1s cubic-bezier(0.39, 0.575, 0.565, 1), left 0.1s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, width 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, transform 0.18s cubic-bezier(0.39, 0.575, 0.565, 1) 0.1s, opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.is-show-nav .button-hamburger__line:nth-of-type(1) {
  top: 50%;
  transform: rotate(45deg);
}

.is-show-nav .button-hamburger__line:nth-of-type(2) {
  opacity: 0;
}

.is-show-nav .button-hamburger__line:nth-of-type(3) {
  top: 50%;
  transform: rotate(-45deg);
}

.link-ticket {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
}

.link-ticket a {
  position: relative;
  color: #fff;
  background-color: #000000;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  height: 100%;
  padding: 0 2.8rem;
  overflow: hidden;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .link-ticket a {
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-pack: center;
        justify-content: center;
    padding: 0 1.1rem;
  }
}

.link-ticket a.is-on {
  opacity: 0.5;
}

.link-ticket__text {
  position: relative;
  font-size: 1.3rem;
  line-height: 1;
  font-weight: 500;
}

@media screen and (max-width: 768px) {
  .link-ticket__text {
    -ms-flex-order: 1;
        order: 1;
    font-size: 0.8rem;
    letter-spacing: 0.06em;
    margin-top: 0.6rem;
  }
}

.link-ticket__icon {
  position: relative;
  display: inline-block;
  width: 3.8rem;
  height: 2.5rem;
}

@media screen and (min-width: 769px) {
  .link-ticket__icon {
    margin-left: 1.3rem;
  }
}

@media screen and (max-width: 768px) {
  .link-ticket__icon {
    width: 2.2rem;
    height: 1.5rem;
  }
}

.link-ticket__icon svg path {
  fill: #fff;
}

.logo-header {
  position: relative;
  line-height: 0;
  z-index: 1;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .logo-header {
    max-width: 50%;
  }
}

.logo-header a {
  display: block;
  width: 100%;
  height: 100%;
  text-decoration: none;
  transition: opacity 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.logo-header a.is-on {
  opacity: 0.7;
}

#home .logo-header {
  opacity: 0;
  pointer-events: none;
}

#home.is-scrolled .logo-header {
  opacity: 1;
  pointer-events: auto;
}

.nav-global {
  position: absolute;
  top: 7rem;
  left: 0;
  width: 100%;
  height: calc(var(--vhin, 1vh) * 100 - 7rem);
  transition: height 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
  overflow: auto;
}

@media screen and (max-width: 768px) {
  .nav-global {
    top: 5.3rem;
    height: calc(var(--vh, 1vh) * 100 - 5.3rem);
  }
}

.nav-global .simplebar-content {
  min-height: 100%;
}

.nav-global__body {
  position: relative;
  z-index: 1;
  width: 100%;
  min-height: calc(var(--vhin, 1vh) * 100 - 7rem);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

@media screen and (max-width: 768px) {
  .nav-global__body {
    width: 100%;
    min-height: calc(var(--vh, 1vh) * 100 - 5.3rem);
  }
}

.nav-global__body:before {
  content: '';
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: #fff;
}

.nav-global__inner {
  position: relative;
  z-index: 1;
  width: 78.8rem;
  height: 100%;
}

@media screen and (max-width: 768px) {
  .nav-global__inner {
    width: 100%;
    min-height: 100%;
  }
}

.nav-global {
  opacity: 0;
  pointer-events: none;
  transition: opacity 0.01s linear 0.7s, background-color 0.2s linear 0s;
}

.nav-global__body:before {
  transform: scale(0, 1);
  transform-origin: left center;
  transition: transform 0.6s cubic-bezier(0.19, 1, 0.22, 1) 0.1s;
}

.nav-global__inner {
  opacity: 0;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.is-show-nav .nav-global {
  opacity: 1;
  pointer-events: auto;
  background-color: #fff;
  transition: opacity 0.01s linear 0s, background-color 0.01s linear 0.3s;
}

.is-show-nav .nav-global__body:before {
  transform: scale(1, 1);
  transition-delay: 0s;
}

.is-show-nav .nav-global__inner {
  opacity: 1;
  transition-delay: 0.1s;
}

.nav-menu-sub {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: calc(var(--vhin, 1vh) * 100 / 800 * 35) 0;
  border: solid #707070;
  border-width: 1px 0;
}

@media screen and (max-width: 768px) {
  .nav-menu-sub {
    width: 34.3rem;
    padding: calc(var(--vh, 1vh) * 100 / 800 * 34) 0;
    margin: 0 auto;
  }
}

.nav-menu-sub__item:nth-of-type(n +  2) {
  margin-left: 14.4rem;
}

@media screen and (max-width: 768px) {
  .nav-menu-sub__item:nth-of-type(n +  2) {
    margin-left: 3.5rem;
  }
}

.nav-menu-sub__item a {
  font-size: 1.6rem;
  line-height: 1.375;
  font-weight: 700;
  text-decoration: none;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .nav-menu-sub__item a {
    font-size: 1.3rem;
    line-height: 1.69231;
  }
}

.nav-menu-sub__item a.is-on {
  opacity: 0.5;
}

.nav-menu {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  padding: calc(var(--vhin, 1vh) * 100 / 800 * 64) 0 calc(var(--vhin, 1vh) * 100 / 800 * 68);
}

@media screen and (max-width: 768px) {
  .nav-menu {
    padding: calc(var(--vh, 1vh) * 100 / 696 * 32) calc((100% - 12.8rem - 11.5rem - 4rem) / 2) calc(var(--vh, 1vh) * 100 / 696 * 35);
  }
}

.nav-menu__item {
  position: relative;
}

@media screen and (max-width: 768px) {
  .nav-menu__item {
    width: 12.8rem;
    white-space: nowrap;
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item:nth-of-type(4n - 3) {
    width: 21rem;
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item:nth-of-type(4n - 2) {
    width: 21rem;
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item:nth-of-type(4n - 1) {
    width: 22.7rem;
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item:nth-of-type(n + 5) {
    margin-top: calc(var(--vhin, 1vh) * 100 / 800 * 50);
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item:nth-of-type(4n) {
    width: calc(100% - 64.7rem);
  }
}

@media screen and (max-width: 768px) {
  .nav-menu__item:nth-of-type(2n) {
    width: 11.5rem;
    margin-left: 4rem;
  }
}

@media screen and (max-width: 768px) {
  .nav-menu__item:nth-of-type(n + 3) {
    margin-top: calc(var(--vh, 1vh) * 100 / 800 * 31);
  }
}

.nav-menu__item > a,
.nav-menu__item > span {
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  height: 100%;
  font-size: 1.6rem;
  line-height: 1.375;
  font-weight: 700;
  text-align: left;
  white-space: nowrap;
  text-decoration: none;
  cursor: pointer;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .nav-menu__item > a,
  .nav-menu__item > span {
    display: -ms-inline-flexbox;
    display: inline-flex;
    font-size: 1.3rem;
    line-height: 1.69231;
  }
}

@media screen and (min-width: 769px) {
  .nav-menu__item > a.narrow,
  .nav-menu__item > span.narrow {
    letter-spacing: -0.08em;
  }
}

.nav-menu__item > a.is-on,
.nav-menu__item > span.is-on {
  opacity: 0.5;
}

.nav-menu__item > a.is-current,
.nav-menu__item > span.is-current {
  color: #000000;
}

.nav-menu__icon {
  width: 3.6rem;
  height: 3.6rem;
  margin-right: 0.6rem;
}

@media screen and (max-width: 768px) {
  .nav-menu__icon {
    width: 2.48276rem;
    height: 2.48276rem;
    margin-right: 0.9rem;
  }
}

.nav-quick {
  display: none;
}

.nav-quick::-webkit-scrollbar {
  display: none;
}

@media screen and (max-width: 768px) {
  .nav-quick {
    background: #000000;
    display: -ms-flexbox;
    display: flex;
    width: 100%;
    height: 3.6rem;
    overflow: auto;
    transform: translateZ(0);
    will-change: opacity, transform, filter;
    -webkit-overflow-scrolling: touch;
  }
}

.nav-quick__list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 1.3rem;
  opacity: 0;
}

.nav-quick__item {
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
  will-change: padding-right, transform, filter;
}

.nav-quick__item:nth-of-type(n + 2) {
  margin-left: 2.3rem;
}

.nav-quick__item:last-of-type {
  padding-right: 100vw;
}

.nav-quick__item a {
  font-family: "Manrope", sans-serif;
  color: #fff;
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 900;
  letter-spacing: 0.02em;
  text-decoration: none;
}

.is-loaded .nav-quick__list {
  opacity: 1;
}

.is-loaded .nav-quick__item:last-of-type {
  padding-right: 1.3rem;
  transition: padding-right 0.4s linear 1.05s;
}

.sns-header {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  padding: calc(var(--vhin, 1vh) * 100 / 800 * 40) 0;
}

@media screen and (max-width: 768px) {
  .sns-header {
    padding: calc(var(--vh, 1vh) * 100 / 800 * 36) 0;
  }
}

.sponsorship-header {
  background: #fff;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
      justify-content: flex-end;
  -ms-flex-align: center;
      align-items: center;
  width: 100%;
  height: 7rem;
  padding: 0 1.6rem;
}

@media screen and (max-width: 768px) {
  .sponsorship-header {
    display: none;
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .sponsorship-header {
    position: fixed;
    z-index: 999;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #fff;
    transition: transform 0.4s cubic-bezier(0.39, 0.575, 0.565, 1);
  }
}

@media screen and (min-width: 769px) {
  .mac.safari .is-header-scrolled .sponsorship-header {
    transform: translate(0, -7rem);
  }
}

.sns-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.sns-content__heading {
  font-family: "Manrope", sans-serif;
  font-size: 1.5rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.05em;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 768px) {
  .sns-content__heading {
    letter-spacing: 0.03em;
  }
}

.sns-content__heading:after {
  content: '';
  background: #000000;
  display: inline-block;
  width: 4rem;
  height: 1px;
  margin-left: 2.2rem;
}

@media screen and (max-width: 768px) {
  .sns-content__heading:after {
    width: 2.4rem;
    margin-left: 1.2rem;
  }
}

.sns-content .list-sns {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.sns-content .list-sns__item {
  margin-left: 2rem;
}

@media screen and (max-width: 768px) {
  .sns-content .list-sns__item {
    margin-left: 1.2rem;
  }
}

.sns-content .list-sns__item:nth-of-type(n + 2) {
  margin-left: 2.8rem;
}

@media screen and (max-width: 768px) {
  .sns-content .list-sns__item:nth-of-type(n + 2) {
    margin-left: 1.4rem;
  }
}

.sns-content .list-sns__item a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 3.9rem;
  height: 3.5rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .sns-content .list-sns__item a {
    width: 2.6rem;
    height: 2.3rem;
  }
}

.sns-content .list-sns__item a img {
  max-height: 100%;
}

@media screen and (max-width: 768px) {
  .sns-content .list-sns__item a img {
    width: auto;
  }
}

.sns-content .list-sns__item a.is-on {
  opacity: 0.5;
}

.sns-content--footer .sns-content__heading {
  display: none;
}

.sns-content--footer .list-sns__item {
  margin-left: 0;
}

.sponsorship-content {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 768px) {
  .sponsorship-content {
    -ms-flex-direction: column;
        flex-direction: column;
  }
}

@media screen and (min-width: 769px) {
  .sponsorship-content:nth-of-type(n + 2) {
    margin-left: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content:nth-of-type(n + 2) {
    margin-top: 2.8rem;
  }
}

@media screen and (min-width: 769px) {
  .sponsorship-content:nth-of-type(n + 2) .sponsorship-content__heading {
    padding-left: 2.8rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content:nth-of-type(n + 2) .sponsorship-content__heading {
    width: 100%;
    padding-top: 3.8rem;
  }
}

.sponsorship-content:nth-of-type(n + 2) .sponsorship-content__heading:before {
  content: '';
  background: #A0A0A0;
  position: absolute;
  left: 0;
  top: calc(50% - 4.5rem / 2);
  width: 1px;
  height: 4.5rem;
}

@media screen and (max-width: 768px) {
  .sponsorship-content:nth-of-type(n + 2) .sponsorship-content__heading:before {
    top: 0;
    width: 100%;
    height: 1px;
  }
}

.sponsorship-content__heading {
  position: relative;
  font-size: 1.2rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.01em;
}

@media screen and (min-width: 769px) {
  .sponsorship-content__heading {
    margin-right: 0.5rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content__heading {
    font-size: 1.1rem;
    text-align: center;
    margin-bottom: 1rem;
  }
}

.sponsorship-content .list-sponsorship {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (min-width: 769px) {
  .sponsorship-content .list-sponsorship {
    margin-left: 2.9rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship {
    width: 100%;
    -ms-flex-pack: center;
        justify-content: center;
    margin-top: 1.8rem;
  }
}

.sponsorship-content .list-sponsorship__item:nth-last-of-type(n + 2) {
  margin-right: 2.9rem;
}

.sponsorship-content .list-sponsorship__item figure {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.sponsorship-content .list-sponsorship__item a {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--kirin {
    width: 9.8rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--redbull {
    width: 5.1rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--pocari {
    width: 4.5rem;
  }
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--coolish {
    width: 6.2rem;
  }
}

.sponsorship-content .list-sponsorship__item--nonvirus {
  width: 7.2rem;
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--nonvirus {
    width: 8rem;
  }
}

.sponsorship-content .list-sponsorship__item--icheck {
  width: 7.2rem;
}

@media screen and (max-width: 768px) {
  .sponsorship-content .list-sponsorship__item--icheck {
    width: 7.9rem;
  }
}

.access-railway {
  font-size: 1.4rem;
  line-height: 1.28571;
  font-weight: 400;
  letter-spacing: 0.02em;
  margin-left: 2rem;
}

@media screen and (max-width: 768px) {
  .access-railway {
    font-size: 1.2rem;
    display: block;
    margin-left: 0;
    margin-top: 1em;
    padding-bottom: 0.8em;
  }
}

.access-railway span {
  margin-right: 0.1em;
}

.artist-header,
.date-header {
  padding-bottom: 0;
}

@media screen and (max-width: 768px) {
  .artist-header:first-of-type,
  .date-header:first-of-type {
    padding-top: 2.6rem;
  }
}

.artist-header-nav,
.date-header-nav {
  position: sticky;
  z-index: 990;
  left: 0;
  top: 6.9rem;
  display: -ms-flexbox;
  display: flex;
  width: 100%;
  max-width: 96rem;
  margin: 4.5rem auto 0;
  min-height: 5.4rem;
}

@media screen and (max-width: 768px) {
  .artist-header-nav,
  .date-header-nav {
    top: 5.3rem;
    width: 100%;
    min-height: 5rem;
    margin-top: 3rem;
  }
}

.artist-header-nav--fixed,
.date-header-nav--fixed {
  position: relative;
  top: auto;
  left: auto;
  transform: none;
  transition-duration: 0s;
  transition-delay: 0s;
  will-change: auto;
  backface-visibility: visible;
}

@media screen and (max-width: 768px) {
  .artist-header-nav--fixed,
  .date-header-nav--fixed {
    top: auto;
    left: auto;
  }
}

.artist-header-nav--fixed.is-inview,
.date-header-nav--fixed.is-inview {
  transform: none;
}

.artist-header-nav.is-fixed .artist-header-nav__inner,
.artist-header-nav.is-fixed .date-header-nav__inner,
.date-header-nav.is-fixed .artist-header-nav__inner,
.date-header-nav.is-fixed .date-header-nav__inner {
  position: fixed;
  left: calc(50% - 96rem / 2);
  top: 6.9rem;
  width: 96rem;
}

@media screen and (max-width: 768px) {
  .artist-header-nav.is-fixed .artist-header-nav__inner,
  .artist-header-nav.is-fixed .date-header-nav__inner,
  .date-header-nav.is-fixed .artist-header-nav__inner,
  .date-header-nav.is-fixed .date-header-nav__inner {
    top: 5.3rem;
    left: 0;
    width: 100%;
  }
}

.artist-header-nav__inner,
.date-header-nav__inner {
  display: -ms-flexbox;
  display: flex;
  width: 100%;
}

.artist-header-nav__item,
.date-header-nav__item {
  width: 100%;
}

.artist-header-nav__item:nth-of-type(n + 2),
.date-header-nav__item:nth-of-type(n + 2) {
  border-left: 1px solid #fff;
}

.artist-header-nav__item a,
.date-header-nav__item a {
  font-family: "Manrope", sans-serif;
  color: #fff;
  background-color: #a0a0a0;
  font-size: 1.2rem;
  line-height: 1.1;
  letter-spacing: 0;
  text-align: center;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 100%;
  height: 5.4rem;
  padding-top: 0.1rem;
  padding-left: 0.1rem;
  transition: background-color 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .artist-header-nav__item a,
  .date-header-nav__item a {
    font-size: 1rem;
    height: 5rem;
  }
}

.artist-header-nav__item a strong,
.date-header-nav__item a strong {
  font-size: 2rem;
  margin-left: -0.1rem;
}

@media screen and (max-width: 768px) {
  .artist-header-nav__item a strong,
  .date-header-nav__item a strong {
    font-size: 1.8rem;
  }
}

.artist-header-nav__item a.is-on,
.date-header-nav__item a.is-on {
  background-color: var(--key-color);
}

.artist-header-nav__item.is-current a,
.date-header-nav__item.is-current a {
  background-color: var(--key-color);
}

@media screen and (max-width: 768px) {
  .artist {
    padding-bottom: 1.5rem;
  }
}

.artist__date {
  position: relative;
  font-family: "Manrope", sans-serif;
  font-size: 1.4rem;
  line-height: 1.1;
  letter-spacing: 0;
  text-align: center;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  width: 100%;
  padding: 4rem 0 1.4rem 0.1rem;
}

@media screen and (max-width: 768px) {
  .artist__date {
    font-size: 1.2rem;
    padding: 2.4rem 0 1rem 0.1rem;
  }
}

.artist__date strong {
  font-size: 3rem;
  margin-left: -0.1rem;
}

@media screen and (max-width: 768px) {
  .artist__date strong {
    font-size: 2.7rem;
  }
}

.artist__date:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
}

@media screen and (max-width: 768px) {
  .artist__date:before {
    height: 0.15rem;
  }
}

.artist-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .artist-list {
    -ms-flex-pack: justify;
        justify-content: space-between;
    margin-top: 2rem;
  }
}

.artist-list__item {
  position: relative;
  width: 30rem;
}

@media screen and (max-width: 960px) and (min-width: 769px) {
  .artist-list__item {
    width: calc(300vw / 960 * 100);
  }
}

@media screen and (max-width: 768px) {
  .artist-list__item {
    width: 16.5rem;
    transition: opacity 0.5s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  }
}

@media screen and (min-width: 769px) {
  .artist-list__item:nth-of-type(3n), .artist-list__item:nth-of-type(3n - 1) {
    margin-left: calc((100% - 30rem * 3) / 2);
  }
}

@media screen and (max-width: 960px) and (min-width: 769px) {
  .artist-list__item:nth-of-type(3n), .artist-list__item:nth-of-type(3n - 1) {
    margin-left: calc((100% - (300vw / 960 * 100) * 3) / 2);
  }
}

@media screen and (min-width: 769px) {
  .artist-list__item:nth-of-type(3n) {
    transition-delay: 0.14s;
  }
}

@media screen and (min-width: 769px) {
  .artist-list__item:nth-of-type(3n - 1) {
    transition-delay: 0.07s;
  }
}

@media screen and (max-width: 768px) {
  .artist-list__item:nth-of-type(2n) {
    transition-delay: 0.07s;
  }
}

.artist-list__item.is-new {
  overflow: hidden;
}

.artist-list__item.is-new:before {
  content: 'NEW!';
  position: absolute;
  z-index: 9;
  left: -1.7rem;
  top: 0.7rem;
  font-family: "Manrope", sans-serif;
  color: #fff;
  background: #e1230f;
  font-size: 1.1rem;
  font-weight: 700;
  letter-spacing: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 6.6rem;
  height: 1.8rem;
  transform: rotate(-45deg);
}

@media screen and (max-width: 768px) {
  .artist-list__item.is-new:before {
    left: -1.15rem;
    top: 0.45rem;
    font-size: 0.75rem;
    width: 4.4rem;
    height: 1.2rem;
  }
}

.artist-list__image {
  background: #f4f4f4;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 30rem;
  height: 20rem;
}

@media screen and (max-width: 768px) {
  .artist-list__image {
    width: 16.5rem;
    height: 11rem;
  }
}

.artist-list__image img {
  display: block;
  max-height: 100%;
  will-change: opacity, transform, filter;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .artist-list__image img {
    width: auto;
  }
}

.artist-list__text {
  font-size: 1.5rem;
  line-height: 1.4;
  font-weight: 700;
  letter-spacing: 0.02em;
  padding: 0.4rem 0 2.3rem;
}

@media screen and (max-width: 768px) {
  .artist-list__text {
    font-size: 1.2rem;
    line-height: 1.5;
    text-align: left;
    padding: 0.4rem 0 2rem;
  }
}

.artist-list__cat {
  background: #e8e8eb;
  font-family: "Manrope", sans-serif;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.3rem;
  line-height: 1.7rem;
  font-weight: 700;
  letter-spacing: 0;
  height: 1.7rem;
  padding: 0 0.6rem;
  margin-right: 0.6rem;
  transform: translate(0, -0.2rem);
}

@media screen and (max-width: 768px) {
  .artist-list__cat {
    font-size: 0.9rem;
    line-height: 1.3rem;
    height: 1.3rem;
    padding: 0 0.4rem;
    margin-right: 0.4rem;
    transform: translate(0, -0.1rem);
  }
}

.artist-list__cat--dj {
  color: #fff;
  background-color: #4086e8;
}

.artist-list__cat--sp {
  color: #eb6100;
  background-color: #ffec1a;
  font-size: 1.1rem;
  padding: 0 0.4rem;
}

@media screen and (max-width: 768px) {
  .artist-list__cat--sp {
    font-size: 0.9rem;
    padding: 0 0.2rem;
  }
}

.artist-button {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 4.2rem;
}

@media screen and (max-width: 768px) {
  .artist-button {
    margin-top: 0;
  }
}

.artist-button a {
  color: var(--key-color);
  background-color: #fbeee9;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 40rem;
  height: 4rem;
  border-radius: 0.5rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .artist-button a {
    width: 28rem;
  }
}

.artist-button a.is-on {
  opacity: 0.6;
}

.artist-button a span {
  margin-left: 0.8rem;
}

.artist-button a:after {
  content: '';
  display: inline-block;
  width: 1.8rem;
  height: 1.8rem;
  margin-left: 1.2rem;
  margin-right: -1.2rem;
  background: var(--key-color);
  -webkit-mask-image: url("../img/common/icn_arrow_circle.svg");
          mask-image: url("../img/common/icn_arrow_circle.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
}

@media screen and (max-width: 768px) {
  .artist-button a:after {
    margin-left: 1rem;
    margin-right: -1rem;
  }
}

.artist-special {
  color: #fff;
  background-color: #1f1f1f;
  position: relative;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  padding: 4.5rem 8.6rem 4.3rem;
  margin-top: 9rem;
}

@media screen and (max-width: 768px) {
  .artist-special {
    padding: 3rem 2rem 2.5rem;
    margin-top: 4.5rem;
  }
}

.artist-special.is-new {
  overflow: hidden;
}

.artist-special.is-new:before {
  content: 'NEW!';
  position: absolute;
  left: -2.8rem;
  top: 1.5rem;
  font-family: "Manrope", sans-serif;
  color: #fff;
  background: #e1230f;
  font-size: 1.6rem;
  font-weight: 700;
  letter-spacing: 0;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 11.6rem;
  height: 3rem;
  transform: rotate(-45deg);
}

@media screen and (max-width: 768px) {
  .artist-special.is-new:before {
    left: -1.4rem;
    top: 0.75rem;
    font-size: 0.9rem;
    width: 5.8rem;
    height: 1.5rem;
  }
}

.artist-special:after {
  content: 'SPECIAL';
  position: absolute;
  right: 0;
  top: 0;
  color: #eb6100;
  background-color: #ffec1a;
  font-family: "Manrope", sans-serif;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.5rem;
  line-height: 2.7rem;
  font-weight: 700;
  letter-spacing: 0;
  height: 2.7rem;
  padding: 0 0.6rem;
}

@media screen and (max-width: 768px) {
  .artist-special:after {
    font-size: 0.8rem;
    line-height: 1.3rem;
    text-align: left;
    height: 1.3rem;
    padding: 0 0.4rem;
  }
}

.artist-special__image {
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .artist-special__image {
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
        justify-content: center;
    -ms-flex-align: center;
        align-items: center;
    height: 15.5rem;
  }
}

@media screen and (max-width: 768px) {
  .artist-special__image img {
    display: block;
    width: auto;
    max-height: 100%;
  }
}

.artist-special__heading {
  font-size: 1.8rem;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-top: 2.5rem;
}

@media screen and (max-width: 768px) {
  .artist-special__heading {
    font-size: 1.5rem;
    line-height: 1.7;
    margin-top: 1.6rem;
  }
}

.artist-special__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 1.4rem;
}

.artist-special + .artist-special {
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .artist-special + .artist-special {
    margin-top: 2rem;
  }
}

.nav-faq,
.accordion-nav {
  color: #505050;
  margin-top: 3.8rem;
}

@media screen and (max-width: 768px) {
  .nav-faq,
  .accordion-nav {
    margin-top: 3rem;
  }
}

.nav-faq__list,
.accordion-nav__list {
  border: 0.2rem solid var(--key-color);
  border-radius: 0.4rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .nav-faq__list,
  .accordion-nav__list {
    border-radius: 0.5rem;
  }
}

.nav-faq__item,
.accordion-nav__item {
  border-bottom: 1px solid #eeeeee;
}

.nav-faq__item:nth-of-type(2n),
.accordion-nav__item:nth-of-type(2n) {
  background-color: #f5f5f5;
}

.nav-faq__item:last-of-type,
.accordion-nav__item:last-of-type {
  border-bottom: none;
}

.nav-faq__heading,
.accordion-nav__heading {
  position: relative;
  color: #505050;
  font-size: 1.5rem;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  min-height: 4.4rem;
  padding: 1rem 2rem;
  padding-right: 6rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .nav-faq__heading,
  .accordion-nav__heading {
    padding: 1.5rem 2.2rem;
    padding-right: 6rem;
  }
}

.nav-faq__heading:before, .nav-faq__heading:after,
.accordion-nav__heading:before,
.accordion-nav__heading:after {
  content: '';
  background: var(--key-color);
  position: absolute;
  right: 2rem;
  top: calc(50% - 0.2rem / 2);
  display: block;
  width: 1.4rem;
  height: 0.2rem;
}

.nav-faq__heading:after,
.accordion-nav__heading:after {
  transform: rotate(90deg);
  transition: transform 0.2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.nav-faq__heading.is-on,
.accordion-nav__heading.is-on {
  opacity: 0.6;
}

.nav-faq__heading.is-show:after,
.accordion-nav__heading.is-show:after {
  transform: rotate(0deg);
}

.nav-faq-links,
.accordion-nav-links {
  border-top: 1px solid #eeeeee;
  padding: 0 2rem;
}

.nav-faq-links li,
.accordion-nav-links li {
  display: -ms-flexbox;
  display: flex;
  border-bottom: 1px solid #eeeeee;
}

.nav-faq-links li:last-of-type,
.accordion-nav-links li:last-of-type {
  border-bottom: none;
}

.nav-faq-links li:before,
.accordion-nav-links li:before {
  content: 'Q';
  font-family: "Manrope", sans-serif;
  color: var(--key-color);
  font-size: 1.2rem;
  line-height: 1.5;
  display: inline-block;
  width: 1.8rem;
  padding: 1.4rem 0 0;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
}

@media screen and (max-width: 768px) {
  .nav-faq-links li:before,
  .accordion-nav-links li:before {
    width: 1.6rem;
    padding-top: 1.8rem;
  }
}

.nav-faq-links li a,
.accordion-nav-links li a {
  color: #505050;
  font-size: 1.2rem;
  line-height: 1.5;
  font-weight: 700;
  letter-spacing: 0.04em;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  -ms-flex-align: center;
      align-items: center;
  min-height: 4.4rem;
  padding: 1rem 0;
  text-underline-offset: 0.25em;
}

@media screen and (max-width: 768px) {
  .nav-faq-links li a,
  .accordion-nav-links li a {
    min-height: 5rem;
    padding: 1.7rem 0 1.6rem;
  }
}

.accordion-nav-links li:before {
  content: '・';
  font-family: YakuHanJP_Noto, "Noto Sans JP", sans-serif;
  color: #505050;
  padding-left: 0.5em;
  width: 1.4rem;
}

@media screen and (max-width: 768px) {
  .accordion-nav-links li:before {
    width: 1.2rem;
  }
}

.list-description,
.list-faq {
  color: #505050;
  margin-top: -2rem;
}

.list-description__heading,
.list-faq__heading {
  font-size: 1.5rem;
  line-height: 1.46667;
  font-weight: 700;
  letter-spacing: 0.02em;
  display: -ms-flexbox;
  display: flex;
  padding: 1.7rem 0;
  padding-right: 2.2rem;
}

.list-description__heading:nth-of-type(n + 2),
.list-faq__heading:nth-of-type(n + 2) {
  margin-top: 1rem;
}

@media screen and (max-width: 768px) {
  .list-description__heading:nth-of-type(n + 2),
  .list-faq__heading:nth-of-type(n + 2) {
    margin-top: 0.9rem;
  }
}

.list-description__detail,
.list-faq__detail {
  background: #f5f5f5;
  padding: 1.7rem 2.2rem;
}

@media screen and (max-width: 768px) {
  .list-description__detail,
  .list-faq__detail {
    padding: 1.7rem 1.8rem;
  }
}

.list-description__text,
.list-faq__text {
  font-size: 1.5rem;
  line-height: 1.6;
  text-align: left;
  letter-spacing: 0.02em;
}

@media screen and (max-width: 768px) {
  .list-description__text,
  .list-faq__text {
    font-size: 1.5rem;
    line-height: 1.6;
  }
}

.list-description__text small,
.list-faq__text small {
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.5;
}

@media screen and (max-width: 768px) {
  .list-description__text small,
  .list-faq__text small {
    margin-top: 1.2rem;
  }
}

.list-faq__heading:before {
  content: 'Q';
  font-family: "Manrope", sans-serif;
  color: var(--key-color);
  font-size: 1.8rem;
  line-height: 1;
  display: inline-block;
  width: 2.2rem;
  padding-top: 0.1rem;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
}

@media screen and (max-width: 768px) {
  .list-faq__heading:before {
    width: 2.2rem;
  }
}

.list-faq__detail {
  position: relative;
  padding-left: 4.4rem;
}

@media screen and (max-width: 768px) {
  .list-faq__detail {
    padding-left: 4rem;
  }
}

.list-faq__detail:before {
  content: 'A';
  font-family: "Manrope", sans-serif;
  color: #707070;
  font-size: 1.8rem;
  line-height: 1;
  display: inline-block;
  width: 2.2rem;
  padding-top: 0.3rem;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
  position: absolute;
  left: 2.2rem;
  top: 1.7rem;
}

@media screen and (max-width: 768px) {
  .list-faq__detail:before {
    left: 1.8rem;
  }
}

.list-description__item.slide-up-in,
.list-faq__item.slide-up-in {
  opacity: 1;
  transform: translateY(0) translateZ(0);
}

@media screen and (max-width: 768px) {
  .list-description__item.slide-up-in,
  .list-faq__item.slide-up-in {
    transform: translateY(0) translateZ(0);
  }
}

.list-description__item.slide-up-in.is-inview .list-description__heading, .list-description__item.slide-up-in.is-inview .list-description__detail,
.list-description__item.slide-up-in.is-inview .list-faq__heading,
.list-description__item.slide-up-in.is-inview .list-faq__detail,
.list-faq__item.slide-up-in.is-inview .list-description__heading,
.list-faq__item.slide-up-in.is-inview .list-description__detail,
.list-faq__item.slide-up-in.is-inview .list-faq__heading,
.list-faq__item.slide-up-in.is-inview .list-faq__detail {
  opacity: 1;
  transform: translateY(0) translateZ(0);
}

.list-description__heading, .list-description__detail,
.list-faq__heading,
.list-faq__detail {
  opacity: 0;
  transform: translateY(4rem) translateZ(0);
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1), transform 0.8s cubic-bezier(0.19, 1, 0.22, 1);
  will-change: opacity, transform, filter;
  backface-visibility: hidden;
}

@media screen and (max-width: 768px) {
  .list-description__heading, .list-description__detail,
  .list-faq__heading,
  .list-faq__detail {
    transform: translateY(2rem);
  }
}

.list-description__detail .section__list,
.list-faq__detail .section__list {
  margin-bottom: 2rem;
}

.list-description__detail .section__list > li + li,
.list-faq__detail .section__list > li + li {
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  .list-description__detail .section__list > li + li,
  .list-faq__detail .section__list > li + li {
    margin-top: 0;
  }
}

.list-description__detail .section__list--disc > li + li,
.list-faq__detail .section__list--disc > li + li {
  margin-top: 0;
}

@media screen and (max-width: 768px) {
  .list-description__detail .section__list--disc > li + li,
  .list-faq__detail .section__list--disc > li + li {
    margin-top: 0;
  }
}

.nav-food {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .nav-food {
    margin-top: 2rem;
  }
}

.nav-food__item:nth-of-type(n + 2) {
  margin-left: 1.2rem;
}

@media screen and (max-width: 768px) {
  .nav-food__item:nth-of-type(n + 2) {
    margin-left: calc((100% - 33rem) / 2);
  }
}

@media screen and (max-width: 768px) {
  .nav-food__item:nth-of-type(n + 4) {
    margin-top: 0.9rem;
  }
}

.nav-food__item a {
  overflow: hidden;
  display: block;
  width: 16rem;
  height: 9.2rem;
  border-radius: 0.5rem;
}

@media screen and (max-width: 768px) {
  .nav-food__item a {
    width: 11rem;
    height: 6.4rem;
  }
}

.time-food {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .time-food {
    display: block;
    margin-top: 2rem;
  }
}

.time-food__item {
  font-size: 1.5rem;
  line-height: 1.5;
  width: 30rem;
}

@media screen and (max-width: 768px) {
  .time-food__item {
    width: 100%;
    font-weight: 500;
  }
}

@media screen and (min-width: 769px) {
  .time-food__item:nth-of-type(3n), .time-food__item:nth-of-type(3n - 1) {
    margin-left: calc((100% - 30rem * 3) / 2);
  }
}

@media screen and (min-width: 769px) {
  .time-food__item:nth-of-type(n + 4) {
    margin-top: 1.5rem;
  }
}

@media screen and (max-width: 768px) {
  .time-food__item:nth-of-type(n + 2) {
    margin-top: 2rem;
  }
}

.time-food__item > *:first-child {
  padding-top: 0;
}

.time-food__heading {
  font-weight: bold;
  margin-bottom: 1rem;
}

.time-food__group {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  padding: 0.5rem 0 0.4rem;
  border-bottom: 1px solid #707070;
}

.food-heading {
  width: 36rem;
  margin: 1.5rem auto 0;
  padding-top: 2rem;
}

@media screen and (max-width: 768px) {
  .food-heading {
    width: 34.3rem;
    margin-top: 0;
    padding-top: 1.5rem;
  }
}

.list-food {
  margin-top: 3rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -ms-flex-pack: justify;
      justify-content: space-between;
}

.list-food__item {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  width: 45.5rem;
  counter-increment: number-food 1;
}

@media screen and (max-width: 768px) {
  .list-food__item {
    width: 100%;
  }
}

@media screen and (min-width: 769px) {
  .list-food__item:nth-of-type(n + 3) {
    margin-top: 3rem;
  }
}

@media screen and (max-width: 768px) {
  .list-food__item:nth-of-type(n + 2) {
    margin-top: 3rem;
  }
}

.list-food__image {
  width: 22.5rem;
  height: 21.5rem;
  overflow: hidden;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
}

@media screen and (max-width: 768px) {
  .list-food__image {
    width: 11.5rem;
    height: 11rem;
  }
}

.list-food__box {
  width: 21.3rem;
}

.list-food__heading {
  font-size: 1.5rem;
  line-height: 1.5;
  font-weight: 700;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
      align-items: center;
}

.list-food__heading span {
  color: #fff;
  background-color: var(--key-color);
  -ms-flex-order: -1;
      order: -1;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0;
  position: relative;
  z-index: 1;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 100%;
  -ms-flex: 0 0 auto;
      flex: 0 0 auto;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
  margin-right: 0.6rem;
  box-sizing: border-box;
}

.list-food-detail {
  margin-top: 0.6rem;
}

.list-food-detail__item {
  font-size: 1rem;
  line-height: 1.5;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
      justify-content: space-between;
  padding: 0.6rem 0;
  border-bottom: 1px solid #707070;
}

.list-food-detail__item dt {
  width: 100%;
}

.goods-carousel,
.item-carousel {
  width: 100%;
  margin-top: 2.6rem;
  padding-left: 1rem;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
}

@media screen and (max-width: 768px) {
  .goods-carousel,
  .item-carousel {
    margin-left: 1.6rem;
    width: calc(100% - 1.6rem);
  }
}

.goods-carousel__image,
.item-carousel__image {
  width: 24.6rem;
  height: 24.6rem;
  margin-right: 1rem;
}

@media screen and (max-width: 768px) {
  .goods-carousel__image,
  .item-carousel__image {
    width: 15.1rem;
    height: 15.1rem;
    margin-right: 0.75rem;
    transition: margin-left 0s ease;
  }
}

.goods-carousel__image img,
.item-carousel__image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  font-family: 'object-fit: cover;';
}

.goods-carousel.slick-slider,
.item-carousel.slick-slider {
  padding-left: 0;
}

.goods-carousel .slick-slide,
.item-carousel .slick-slide {
  line-height: 0;
}

.goods-list {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  text-align: center;
  counter-reset: number 0;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .goods-list {
    margin-top: 3rem;
  }
}

.goods-list.json-number .goods-list__item:before {
  display: none;
}

.goods-list.json-number .goods-list__number {
  color: #fff;
  background-color: var(--key-color);
  position: absolute;
  top: 3.5rem;
  left: 0;
  z-index: 1;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
}

@media screen and (max-width: 768px) {
  .goods-list.json-number .goods-list__number {
    top: 1.8rem;
  }
}

.goods-list__item {
  position: relative;
  width: 30rem;
  cursor: pointer;
}

@media screen and (max-width: 768px) {
  .goods-list__item {
    width: 50%;
    padding: 1.8rem 0 0.6rem;
  }
}

.goods-list__item:before {
  counter-increment: number 1;
  content: counter(number);
  color: #fff;
  background-color: var(--key-color);
  position: absolute;
  top: 3.5rem;
  left: 0;
  z-index: 1;
  font-size: 1.3rem;
  font-weight: 700;
  letter-spacing: 0;
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
}

@media screen and (max-width: 768px) {
  .goods-list__item:before {
    top: 1.8rem;
  }
}

@media screen and (min-width: 769px) {
  .goods-list__item:nth-of-type(3n), .goods-list__item:nth-of-type(3n - 1) {
    margin-left: calc((100% - 90rem) / 2);
  }
}

@media screen and (min-width: 769px) {
  .goods-list__item:nth-of-type(3n) {
    transition-delay: 0.14s;
  }
}

@media screen and (min-width: 769px) {
  .goods-list__item:nth-of-type(3n - 1) {
    transition-delay: 0.07s;
  }
}

@media screen and (max-width: 768px) {
  .goods-list__item:nth-of-type(2n) {
    transition-delay: 0.07s;
  }
}

.goods-list__image {
  height: 30rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .goods-list__image {
    width: 14rem;
    height: 14rem;
    margin: 0 auto;
  }
}

.goods-list__image img {
  width: 100%;
}

.goods-list__text {
  font-size: 1.2rem;
  line-height: 1.41667;
  letter-spacing: 0.03em;
  margin-top: 0.5rem;
  padding: 0 1em;
}

@media screen and (max-width: 768px) {
  .goods-list__text {
    margin-top: 0;
  }
}

.goods-list__price {
  font-size: 1.4rem;
  line-height: 1.28571;
  letter-spacing: 0.01em;
  font-weight: 700;
  margin-top: 0.3rem;
}

.carousel-modal-goods {
  width: 72rem;
  counter-reset: number-carousel 0;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods {
    width: 34.3rem;
  }
}

.carousel-modal-goods__inner {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-align: center;
      align-items: center;
  padding: 4rem 0;
  text-align: center;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods__inner {
    padding: 3rem 4rem;
  }
}

.carousel-modal-goods__image {
  width: 49rem;
  height: 49rem;
  overflow: hidden;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods__image {
    width: 21rem;
    height: 21rem;
    margin: 0 auto;
  }
}

.carousel-modal-goods__image img {
  width: 100%;
}

.carousel-modal-goods.json-number .slick-slide:not(.slick-cloned) .carousel-modal-goods__inner:before {
  display: none;
}

.carousel-modal-goods.json-number .carousel-modal-goods__number {
  color: #fff;
  background-color: var(--key-color);
  position: absolute;
  top: 2rem;
  left: 2rem;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0;
  width: 4rem;
  height: 4rem;
  border-radius: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods.json-number .carousel-modal-goods__number {
    position: absolute;
    top: 1.8rem;
    left: 1.8rem;
    font-size: 1.3rem;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 100%;
    padding: 0 0 0.05rem 0.05rem;
  }
}

.carousel-modal-goods__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.03em;
  margin-top: 0.2rem;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods__text {
    margin-top: 0.8rem;
  }
}

.carousel-modal-goods__price {
  font-size: 2rem;
  line-height: 1.45;
  letter-spacing: 0.01em;
  font-weight: 700;
  margin-top: 0.4rem;
}

.carousel-modal-goods__size {
  font-size: 1.2rem;
  line-height: 1.41667;
  letter-spacing: 0.03em;
  margin-top: 0.8rem;
}

.carousel-modal-goods__detail {
  font-size: 1.2rem;
  line-height: 1.41667;
  letter-spacing: 0.03em;
  margin-top: 2.2rem;
}

.carousel-modal-goods__share {
  font-size: 1.2rem;
  line-height: 1.41667;
  letter-spacing: 0.03em;
  margin-top: 1.4rem;
}

.carousel-modal-goods__share a {
  color: #1DA1F2;
  font-size: 1.2rem;
  line-height: 1.41667;
  text-decoration: none;
  letter-spacing: 0.04em;
  display: -ms-inline-flexbox;
  display: inline-flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  transition: opacity 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.carousel-modal-goods__share a:before {
  content: '';
  background: url(../img/common/icn_twitter.svg) no-repeat center center;
  background-size: contain;
  display: inline-block;
  width: 1em;
  height: 1.41667em;
  margin-right: 0.3em;
}

.carousel-modal-goods__share a.is-on {
  opacity: 0.6;
}

.carousel-modal-goods .slick-arrow {
  position: absolute;
  top: 50%;
  width: 5rem;
  height: 6rem;
  cursor: pointer;
  z-index: 1;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  transition: opacity 0.3s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods .slick-arrow {
    width: 3rem;
    height: 5rem;
  }
}

.carousel-modal-goods .slick-arrow__inner {
  width: 2.4rem;
  height: 2.4rem;
  border: solid #fff;
  border-width: 0.4rem 0.4rem 0 0;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods .slick-arrow__inner {
    width: 1.8rem;
    height: 1.8rem;
    border-color: #707070;
  }
}

.carousel-modal-goods .slick-arrow--prev {
  left: -5rem;
  transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods .slick-arrow--prev {
    left: 0;
    padding-left: 0.8rem;
  }
}

.carousel-modal-goods .slick-arrow--prev .slick-arrow__inner {
  transform: rotate(-135deg);
}

.carousel-modal-goods .slick-arrow--next {
  right: -5rem;
  transform: translateY(-50%);
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods .slick-arrow--next {
    right: 0;
    padding-right: 0.8rem;
  }
}

.carousel-modal-goods .slick-arrow--next .slick-arrow__inner {
  transform: rotate(45deg);
}

.carousel-modal-goods .slick-arrow.slick-disabled .slick-arrow__inner {
  border-color: #e8e8eb;
  pointer-events: none;
}

.carousel-modal-goods .slick-arrow.is-on {
  opacity: 0.5;
}

.carousel-modal-goods .slick-slide:not(.slick-cloned) {
  counter-increment: number-carousel 1;
}

.carousel-modal-goods .slick-slide:not(.slick-cloned) .carousel-modal-goods__inner {
  position: relative;
}

.carousel-modal-goods .slick-slide:not(.slick-cloned) .carousel-modal-goods__inner:before {
  content: counter(number-carousel);
  color: #fff;
  background-color: var(--key-color);
  position: absolute;
  top: 2rem;
  left: 2rem;
  font-size: 1.8rem;
  font-weight: 700;
  letter-spacing: 0;
  width: 4rem;
  height: 4rem;
  border-radius: 100%;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  padding: 0 0 0.05rem 0.05rem;
}

@media screen and (max-width: 768px) {
  .carousel-modal-goods .slick-slide:not(.slick-cloned) .carousel-modal-goods__inner:before {
    position: absolute;
    top: 1.8rem;
    left: 1.8rem;
    font-size: 1.3rem;
    width: 2.5rem;
    height: 2.5rem;
    border-radius: 100%;
    padding: 0 0 0.05rem 0.05rem;
  }
}

.heading-history {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: start;
      align-items: flex-start;
  height: 13rem;
}

.heading-history span {
  display: inline-block;
  max-width: 35rem;
  height: 100%;
}

.heading-history img {
  max-height: 100%;
}

@media screen and (max-width: 768px) {
  .heading-history img {
    width: auto;
  }
}

@media screen and (max-width: 768px) {
  .message-detail:first-of-type {
    padding-top: 0;
  }
}

.message-detail__inner {
  width: 86rem;
  margin: 0 auto;
}

@media screen and (max-width: 768px) {
  .message-detail__inner {
    width: 34.3rem;
  }
}

.message-detail__date {
  color: var(--key-color);
  font-size: 1.5rem;
  line-height: 1.6;
  padding-top: 1.3rem;
}

@media screen and (max-width: 768px) {
  .message-detail__date {
    font-size: 1.2rem;
    line-height: 1.16667;
    letter-spacing: 0.02em;
    padding-top: 2.8rem;
  }
}

.message-detail__heading {
  position: relative;
  font-size: 1.8rem;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.04em;
  margin-top: 2.8rem;
  padding-bottom: 3.4rem;
}

@media screen and (max-width: 768px) {
  .message-detail__heading {
    letter-spacing: 0.02em;
    margin-top: 1.8rem;
    padding-bottom: 2.6rem;
  }
}

.message-detail__heading:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
  transform: scale(0, 1);
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.message-detail__heading.is-inview-first:before {
  transition-delay: 0.38s;
}

.message-detail__heading.is-inview:before {
  transform: scale(1, 1);
}

.message-detail__content {
  position: relative;
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.04em;
  margin-top: 3.6rem;
  padding-bottom: 9rem;
}

@media screen and (max-width: 768px) {
  .message-detail__content {
    margin-top: 2.6rem;
    padding-bottom: 3rem;
  }
}

.message-detail__content p + p {
  margin-top: 1.46667em;
}

.message-detail__content p:nth-of-type(n + 2) {
  margin-top: 1.46667em;
}

.message-detail__content p + img {
  margin-top: 8.4rem;
}

@media screen and (max-width: 768px) {
  .message-detail__content p + img {
    margin-top: 4rem;
  }
}

.message-detail__content .alignright {
  float: right;
  margin-left: 1em;
}

.message-detail__content .alignleft {
  float: left;
  margin-right: 1em;
}

.message-detail__content .aligncenter {
  display: block;
  margin-left: auto;
  margin-right: auto;
}

.message-detail__content img:nth-of-type(n + 2) {
  margin-top: 1.46667em;
}

.message-detail__content img + p {
  margin-top: 1.46667em;
}

.message-detail__content strong {
  font-weight: 700;
}

.message-detail__content a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.message-detail__content a.color-key {
  color: var(--key-color);
}

.message-detail__content a.color-app {
  color: #e1230f;
}

.message-detail__content small {
  font-size: 1.2rem;
  line-height: 1.5;
}

.message-detail__bottom {
  position: relative;
  width: 100%;
  height: 1px;
}

.message-detail__bottom:before {
  content: '';
  position: absolute;
  left: 0;
  bottom: 0;
  background: #eeeeee;
  display: block;
  width: 100%;
  height: 1px;
  z-index: 1;
  transform-origin: left center;
  transform: scale(0, 1);
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

.message-detail__bottom.is-inview-first:before {
  transition-delay: 0.38s;
}

.message-detail__bottom.is-inview:before {
  transform: scale(1, 1);
}

.ticket-icon {
  display: inline-block;
  vertical-align: bottom;
  height: 1.8em;
}

.ticket-icon--ticket {
  width: 4.2rem;
  height: auto;
  margin-right: 1.2rem;
  vertical-align: middle;
}

.ticket-icon--phone {
  width: 2.3rem;
  margin: 0 0.8rem 0 0.4rem;
}

.ticket-icon--pay {
  width: 3.5rem;
  margin: 0 0.8rem 0 0.2rem;
}

.ticket-icon--time {
  width: 3.2rem;
  margin: 0 0.8rem -0.4rem 0.2rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.about {
    padding-top: 2.4rem;
  }
}

.ticket-section.flow .flow-list {
  margin-top: 1.2rem;
  margin-bottom: -2.8rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list {
    margin-top: 1.6rem;
    margin-bottom: -2.4rem;
  }
}

.ticket-section.flow .flow-list__item {
  position: relative;
  padding-left: 5rem;
  padding-bottom: 2.8rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__item {
    padding-left: 4rem;
    padding-bottom: 2.4rem;
  }
}

.ticket-section.flow .flow-list__item:first-of-type .flow-list__heading:before {
  display: none;
}

.ticket-section.flow .flow-list__item:before {
  content: '';
  position: absolute;
  z-index: 1;
  top: 3rem;
  left: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--key-color);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  padding-left: 0.1em;
  box-sizing: border-box;
  color: #fff;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__item:before {
    top: 2.4rem;
  }
}

.ticket-section.flow .flow-list__item:nth-child(1):before {
  content: "1";
}

.ticket-section.flow .flow-list__item:nth-child(2):before {
  content: "2";
}

.ticket-section.flow .flow-list__item:nth-child(3):before {
  content: "3";
}

.ticket-section.flow .flow-list__item:nth-child(4):before {
  content: "4";
}

.ticket-section.flow .flow-list__item:nth-child(5):before {
  content: "5";
}

.ticket-section.flow .flow-list__item:nth-child(6):before {
  content: "6";
}

.ticket-section.flow .flow-list__item:nth-child(7):before {
  content: "7";
}

.ticket-section.flow .flow-list__item:nth-child(8):before {
  content: "8";
}

.ticket-section.flow .flow-list__item:nth-child(9):before {
  content: "9";
}

.ticket-section.flow .flow-list__item:nth-child(10):before {
  content: "10";
}

.ticket-section.flow .flow-list__item:nth-child(11):before {
  content: "11";
}

.ticket-section.flow .flow-list__item:nth-child(12):before {
  content: "12";
}

.ticket-section.flow .flow-list__item:nth-child(13):before {
  content: "13";
}

.ticket-section.flow .flow-list__item:nth-child(14):before {
  content: "14";
}

.ticket-section.flow .flow-list__item:nth-child(15):before {
  content: "15";
}

.ticket-section.flow .flow-list__item:nth-last-of-type(n + 2):after {
  content: '';
  position: absolute;
  z-index: 0;
  top: 3rem;
  left: 1.5rem;
  display: block;
  width: 1px;
  height: 100%;
  background: var(--key-color);
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__item:nth-last-of-type(n + 2):after {
    top: 2.4rem;
  }
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(1) .flow-list__heading:before {
  transition-delay: 0.38s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(2) .flow-list__heading:before {
  transition-delay: 0.66s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(3) .flow-list__heading:before {
  transition-delay: 0.94s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(4) .flow-list__heading:before {
  transition-delay: 1.22s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(5) .flow-list__heading:before {
  transition-delay: 1.5s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(6) .flow-list__heading:before {
  transition-delay: 1.78s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(7) .flow-list__heading:before {
  transition-delay: 2.06s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(8) .flow-list__heading:before {
  transition-delay: 2.34s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(9) .flow-list__heading:before {
  transition-delay: 2.62s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(10) .flow-list__heading:before {
  transition-delay: 2.9s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(11) .flow-list__heading:before {
  transition-delay: 3.18s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(12) .flow-list__heading:before {
  transition-delay: 3.46s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(13) .flow-list__heading:before {
  transition-delay: 3.74s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(14) .flow-list__heading:before {
  transition-delay: 4.02s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(15) .flow-list__heading:before {
  transition-delay: 4.3s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(16) .flow-list__heading:before {
  transition-delay: 4.58s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(17) .flow-list__heading:before {
  transition-delay: 4.86s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(18) .flow-list__heading:before {
  transition-delay: 5.14s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(19) .flow-list__heading:before {
  transition-delay: 5.42s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(20) .flow-list__heading:before {
  transition-delay: 5.7s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(21) .flow-list__heading:before {
  transition-delay: 5.98s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(22) .flow-list__heading:before {
  transition-delay: 6.26s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(23) .flow-list__heading:before {
  transition-delay: 6.54s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(24) .flow-list__heading:before {
  transition-delay: 6.82s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(25) .flow-list__heading:before {
  transition-delay: 7.1s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(26) .flow-list__heading:before {
  transition-delay: 7.38s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(27) .flow-list__heading:before {
  transition-delay: 7.66s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(28) .flow-list__heading:before {
  transition-delay: 7.94s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(29) .flow-list__heading:before {
  transition-delay: 8.22s;
}

.ticket-section.flow .flow-list__item.is-inview-first:nth-of-type(30) .flow-list__heading:before {
  transition-delay: 8.5s;
}

.ticket-section.flow .flow-list__item.is-inview .flow-list__heading:before {
  transform: scale(1, 1);
}

.ticket-section.flow .flow-list__heading {
  position: relative;
  font-size: 2rem;
  line-height: 1.45;
  font-weight: 700;
  margin: 0 0 -2.8rem -5rem;
  padding: 2.8rem 0 2.8rem 5rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__heading {
    margin: 0 0 -2.4rem -4rem;
    padding: 2.4rem 0 2.4rem 4rem;
  }
}

.ticket-section.flow .flow-list__heading:after {
  content: '';
  position: absolute;
  z-index: 1;
  right: 0.9rem;
  top: calc(50% - 1rem / 2);
  display: block;
  border: solid;
  border-width: 0 0.9rem 1rem 0.9rem;
  border-color: transparent transparent var(--key-color) transparent;
  transform: rotate(180deg);
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__heading:after {
    right: 0;
  }
}

.ticket-section.flow .flow-list__heading:before {
  content: '';
  position: absolute;
  z-index: 1;
  right: 0;
  width: calc(100% - 5rem);
  height: 1px;
  top: 0;
  display: block;
  border-top: 0.2rem solid #707070;
  pointer-events: none;
  transform: scale(0, 1);
  transform-origin: left center;
  transition: transform 2s cubic-bezier(0.785, 0.135, 0.15, 0.86);
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__heading:before {
    width: calc(100% - 4rem);
    border-top-width: 1px;
  }
}

.ticket-section.flow .flow-list__heading.is-show:after {
  transform: rotate(0deg);
}

.ticket-section.flow .flow-list__heading--no-content:after {
  display: none;
}

.ticket-section.flow .flow-list__subheading {
  font-size: 1.5rem;
  line-height: 1.7;
  font-weight: 700;
  letter-spacing: 0.02em;
  margin-top: 1rem;
}

.ticket-section.flow .flow-list__subheading:nth-of-type(n + 2) {
  margin-top: 1.6rem;
}

.ticket-section.flow .flow-list__subheading + .flow-list__text {
  margin-top: 0.4rem;
}

.ticket-section.flow .flow-list__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  text-align: left;
  margin-top: 1rem;
}

.ticket-section.flow .flow-list__text .nowrap {
  display: inline-block;
}

.ticket-section.flow .flow-list__text em {
  display: inline-block;
  border-bottom: 0.2rem solid #ece692;
  line-height: 1.2;
}

.ticket-section.flow .flow-list__note {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 0.6rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__note {
    font-size: 1.2rem;
    line-height: 1.7;
    margin-top: 1.2rem;
  }
}

.ticket-section.flow .flow-list__detail {
  letter-spacing: 0.02em;
  padding: 1.1rem 2.4rem;
  border: 1px solid var(--key-color);
  margin-top: 1.6rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__detail {
    padding: 1.1rem 1.6rem;
  }
}

.ticket-section.flow .flow-list__detail-heading {
  font-size: 1.8rem;
  line-height: 1.22222;
  font-weight: 700;
}

.ticket-section.flow .flow-list__detail-text {
  font-size: 1.5rem;
  line-height: 1.7;
  margin-top: 1.2rem;
  text-align: left;
}

.ticket-section.flow .flow-list__detail-text strong {
  color: #ff0000;
}

.ticket-section.flow .flow-list__detail-text:first-child {
  margin-top: 0;
}

.ticket-section.flow .flow-list__detail-list {
  font-size: 1.5rem;
  line-height: 1.7;
  margin-top: 0.4rem;
}

.ticket-section.flow .flow-list__detail-list li {
  padding-left: 1.2em;
  text-indent: -1.2em;
  margin-top: 0.7em;
  text-align: left;
  font-feature-settings: normal;
}

.ticket-section.flow .flow-list__detail-list li:before {
  content: '';
  background: var(--key-color);
  display: inline-block;
  width: 0.6rem;
  height: 0.6rem;
  margin: 0 1rem 0.2rem 0.2rem;
}

.ticket-section.flow .flow-list__detail-list li strong {
  font-weight: 700;
}

.ticket-section.flow .flow-list__detail-list li a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.ticket-section.flow .flow-list__detail-list li .nowrap {
  display: inline-block;
}

.ticket-section.flow .flow-list__detail-links {
  font-size: 1.5rem;
  line-height: 1.7;
  margin-top: 1.2rem;
}

.ticket-section.flow .flow-list__detail-links li {
  padding-left: 0.8em;
  text-indent: -0.8em;
  margin-top: 0.175em;
  text-align: left;
  font-feature-settings: normal;
}

.ticket-section.flow .flow-list__detail-links li:before {
  color: #4694ff;
  content: '・ ';
}

.ticket-section.flow .flow-list__detail-links li strong {
  font-weight: 700;
}

.ticket-section.flow .flow-list__detail-links li a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.ticket-section.flow .flow-list__detail-links li .nowrap {
  display: inline-block;
}

.ticket-section.flow .flow-list__detail--white {
  padding: 1.6rem 2.4rem;
  border-color: #fff;
}

@media screen and (max-width: 768px) {
  .ticket-section.flow .flow-list__detail--white {
    padding: 1.6rem 1.6rem;
  }
}

.ticket-section.flow .flow-list__detail--white .flow-list__detail-list li {
  margin-top: 0.9em;
  letter-spacing: 0.02em;
  padding-left: 1em;
  text-indent: -1em;
}

.ticket-section.flow .flow-list__detail--white .flow-list__detail-list li:before {
  content: ' ・ ';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0 0.2em 0 0;
}

.ticket-section.flow .flow-list__detail--white .flow-list__detail-list li em {
  color: #ece692;
  font-weight: 700;
}

.ticket-section.flow .flow-list__detail--white .flow-list__detail-list li em:before {
  content: ' ・ ';
  background: transparent;
  display: inline;
  width: auto;
  height: auto;
  margin: 0 0.2em 0 -1em;
}

.ticket-section.attention .attention__app {
  width: 60rem;
  margin: 3rem auto 0;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app {
    width: 34.3rem;
    margin-top: 4.5rem;
  }
}

.ticket-section.attention .attention__app .app-flow {
  margin-top: 4rem;
  padding-bottom: 2rem;
}

.ticket-section.attention .attention__app .app-flow__item {
  position: relative;
  padding-left: 4.2rem;
}

.ticket-section.attention .attention__app .app-flow__item:nth-last-of-type(n + 2) {
  padding-bottom: 3rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__item:nth-last-of-type(n + 2) {
    padding-bottom: 4.3rem;
  }
}

.ticket-section.attention .attention__app .app-flow__item:before {
  content: '';
  position: absolute;
  z-index: 1;
  top: 0;
  left: 0;
  width: 3rem;
  height: 3rem;
  border-radius: 50%;
  background: var(--key-color);
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  font-size: 1.5rem;
  font-weight: 700;
  padding-left: 0.1em;
  box-sizing: border-box;
  color: #fff;
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(1):before {
  content: "1";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(2):before {
  content: "2";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(3):before {
  content: "3";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(4):before {
  content: "4";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(5):before {
  content: "5";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(6):before {
  content: "6";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(7):before {
  content: "7";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(8):before {
  content: "8";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(9):before {
  content: "9";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(10):before {
  content: "10";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(11):before {
  content: "11";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(12):before {
  content: "12";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(13):before {
  content: "13";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(14):before {
  content: "14";
}

.ticket-section.attention .attention__app .app-flow__item:nth-child(15):before {
  content: "15";
}

.ticket-section.attention .attention__app .app-flow__item:nth-last-of-type(n + 2):after {
  content: '';
  position: absolute;
  z-index: 0;
  top: 0;
  left: 1.4rem;
  display: block;
  width: 0.3rem;
  height: 100%;
  background: #dbdbdb;
}

.ticket-section.attention .attention__app .app-flow__heading {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.08em;
  font-weight: 700;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__heading {
    display: -ms-flexbox;
    display: flex;
    text-align: left;
  }
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__heading-icon {
    height: 100%;
  }
}

.ticket-section.attention .attention__app .app-flow__heading-icon:before {
  content: '';
  display: inline-block;
  background: url(../img/common/icn_app.png) no-repeat center center;
  background-size: contain;
  width: 2.6rem;
  height: 2.6rem;
  margin-right: 1.2rem;
  vertical-align: middle;
}

.ticket-section.attention .attention__app .app-flow__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 1rem;
}

.ticket-section.attention .attention__app .app-flow__note {
  font-size: 1.2rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 2.8rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__note {
    margin-top: 2.4rem;
  }
}

.ticket-section.attention .attention__app .app-flow__app-link {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 3.5rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__app-link {
    -ms-flex-direction: column;
        flex-direction: column;
    -ms-flex-align: center;
        align-items: center;
    margin-top: 2.5rem;
  }
}

@media screen and (min-width: 769px) {
  .ticket-section.attention .attention__app .app-flow__app-link li:nth-of-type(n + 2) {
    margin-left: 2rem;
  }
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__app-link li:nth-of-type(n + 2) {
    margin-top: 1rem;
  }
}

.ticket-section.attention .attention__app .app-flow__app-link li a {
  display: block;
}

@media screen and (min-width: 769px) {
  .ticket-section.attention .attention__app .app-flow__app-link li a {
    height: 5rem;
  }
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__app-link li a {
    width: 15rem;
  }
}

@media screen and (min-width: 769px) {
  .ticket-section.attention .attention__app .app-flow__app-link li a img {
    height: 100%;
  }
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention__app .app-flow__app-link li a img {
    width: 100%;
  }
}

.ticket-section.attention .attention-detail {
  border: 0.2rem solid var(--key-color);
  border-radius: 0.5rem;
  min-height: 6rem;
  margin-top: 2rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention-detail {
    min-height: 7rem;
    border-width: 0.2rem;
    border-radius: 0.5rem;
  }
}

.ticket-section.attention .attention-detail__heading {
  position: relative;
  font-size: 2rem;
  line-height: 1.4;
  font-weight: 700;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  padding: 1.3rem 1.8rem 1rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention-detail__heading {
    text-align: left;
    padding: 1.3rem 5rem 1.3rem 1.4rem;
  }
}

.ticket-section.attention .attention-detail__heading small {
  font-size: 1.1rem;
  line-height: 1;
  letter-spacing: 0.01em;
}

.ticket-section.attention .attention-detail__heading i {
  color: #ff0000;
}

.ticket-section.attention .attention-detail__heading:before {
  content: '';
  position: absolute;
  z-index: 1;
  background: var(--key-color);
  right: 2.5rem;
  top: calc(50% - 2.5rem / 2);
  width: 2.5rem;
  height: 2.5rem;
  border-radius: 50%;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention-detail__heading:before {
    right: 1.2rem;
  }
}

.ticket-section.attention .attention-detail__heading:after {
  content: '';
  position: absolute;
  z-index: 1;
  right: calc(2.5rem + 1.25rem - 0.4rem);
  top: calc(50% - 0.4rem / 2);
  display: block;
  border: solid;
  border-width: 0 0.4rem 0.4rem 0.4rem;
  border-color: transparent transparent #fff transparent;
  transform: rotate(180deg) translate(0, -0.1rem);
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention-detail__heading:after {
    right: calc(1.2rem + 1.25rem - 0.4rem);
  }
}

.ticket-section.attention .attention-detail__heading.is-show:after {
  transform: rotate(0deg);
}

.ticket-section.attention .attention-detail__content {
  padding: 0 1.8rem 1.6rem;
}

.ticket-section.attention .attention-detail__subheading {
  font-size: 2rem;
  line-height: 1.4;
  font-weight: 700;
  margin-top: 0.4rem;
}

.ticket-section.attention .attention-detail__subheading:nth-of-type(n + 2) {
  margin-top: 4rem;
}

.ticket-section.attention .attention-detail__text {
  font-size: 1.5rem;
  line-height: 1.7;
  letter-spacing: 0.02em;
  margin-top: 1rem;
}

.ticket-section.attention .attention-detail__list {
  font-size: 1.5rem;
  line-height: 1.7;
}

.ticket-section.attention .attention-detail__list:nth-child(n + 2) {
  margin-top: 1.6rem;
}

.ticket-section.attention .attention-detail__list > li {
  padding-left: 0.9em;
  text-indent: -0.9em;
  text-align: left;
  font-feature-settings: normal;
}

.ticket-section.attention .attention-detail__list > li:nth-of-type(n + 2) {
  margin-top: 0.5em;
}

.ticket-section.attention .attention-detail__list > li:before {
  content: '・ ';
}

.ticket-section.attention .attention-detail__list > li strong {
  font-weight: 700;
}

.ticket-section.attention .attention-detail__list > li > i {
  color: #ff0000;
}

.ticket-section.attention .attention-detail__list > li > a {
  color: #4694ff;
  text-underline-offset: 0.25em;
}

.ticket-section.attention .attention-detail__list > li .nowrap {
  display: inline-block;
}

.ticket-section.attention .attention-detail__list > li .section__note {
  margin-top: 0.5rem;
}

@media screen and (max-width: 768px) {
  .ticket-section.attention .attention-detail__list > li .section__note {
    margin-top: 1rem;
  }
}

.ticket-section.attention .attention-detail__list--bg-gray {
  background: #efefef;
  padding: 1.6rem 1.2rem;
  border-radius: 0.8rem;
}

.about-span {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 4.2rem;
}

@media screen and (max-width: 768px) {
  .about-span {
    margin-top: 3.6rem;
  }
}

.about-span__item {
  color: var(--key-color);
  font-size: 2rem;
  line-height: 1.45;
  font-weight: 700;
  text-align: center;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-direction: column;
      flex-direction: column;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 34.3rem;
  height: 12rem;
  border-radius: 0.8rem;
  border: 0.2rem solid var(--key-color);
}

@media screen and (max-width: 768px) {
  .about-span__item {
    border-radius: 0.4rem;
    border-width: 1px;
  }
}

.about-span__text {
  font-size: 2rem;
  line-height: 1.45;
  letter-spacing: -0.02em;
  border-bottom: 0.2rem solid var(--key-color);
}

@media screen and (max-width: 768px) {
  .about-span__text {
    border-bottom-width: 1px;
  }
}

.about-span__text-small {
  font-size: 1.7rem;
  line-height: 1.61111;
  letter-spacing: -0.02em;
  margin-top: 1.2rem;
}

@media screen and (max-width: 768px) {
  .timetable + .timetable .timetable__image {
    margin-top: 1.5rem;
  }
}

.timetable__image {
  width: 80rem;
  margin: 4.5rem auto 0;
}

@media screen and (max-width: 768px) {
  .timetable__image {
    width: 34.5rem;
    margin-top: 3rem;
  }
}

.timetable__image img {
  pointer-events: auto;
}

@media screen and (max-width: 768px) {
  .timetable__image img {
    touch-callout: default;
    -webkit-user-select: auto;
        -ms-user-select: auto;
            user-select: auto;
    height: auto;
  }
}

.timetable-button {
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  margin-top: 3rem;
}

@media screen and (max-width: 768px) {
  .timetable-button {
    margin-top: 2rem;
  }
}

.timetable-button a {
  color: var(--key-color);
  background-color: #fbeee9;
  font-size: 1.5rem;
  font-weight: 700;
  letter-spacing: 0;
  text-decoration: none;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
      justify-content: center;
  -ms-flex-align: center;
      align-items: center;
  width: 40rem;
  height: 4rem;
  border-radius: 0.5rem;
  transition: opacity 0.1s cubic-bezier(0.39, 0.575, 0.565, 1);
}

@media screen and (max-width: 768px) {
  .timetable-button a {
    width: 28rem;
  }
}

.timetable-button a.is-on {
  opacity: 0.6;
}

.timetable-button a span {
  margin-left: 0.8rem;
}

.timetable-button a:after {
  content: '';
  display: inline-block;
  width: 1.8rem;
  height: 1.8rem;
  margin-left: 1.2rem;
  margin-right: -1.2rem;
  background: var(--key-color);
  -webkit-mask-image: url("../img/common/icn_arrow_circle.svg");
          mask-image: url("../img/common/icn_arrow_circle.svg");
  -webkit-mask-size: 100% 100%;
          mask-size: 100% 100%;
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
}

@media screen and (max-width: 768px) {
  .timetable-button a:after {
    margin-left: 1rem;
    margin-right: -1rem;
  }
}

.link-common--active a[target='_blank'] .link-common__arrow:before {
  background: var(--key-color);
  -webkit-mask-image: url(../img/common/icn_arrow_blank.svg);
          mask-image: url(../img/common/icn_arrow_blank.svg);
  -webkit-mask-repeat: no-repeat;
          mask-repeat: no-repeat;
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
  filter: invert(0);
  margin: 0 0 0.1rem 0;
  transition: background-color 0.2s cubic-bezier(0.39, 0.575, 0.565, 1);
}

.link-common--active a[target='_blank'].is-on .link-common__arrow:before {
  filter: invert(0);
  background: #fff;
}
