@import url("https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;500;700;800;900&display=swap");

@font-face {
  font-family: "SUNROCKERS BOLD";
  src: url("./fonts/SUNROCKERSFONTBOLD-bold.otf?v=20260601") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "SUNROCKERS FAQ";
  src: url("./fonts/SUNROCKERSFONTBOLD-bold.otf?v=20260608-faq") format("opentype");
  font-weight: 700;
  font-style: normal;
  font-display: block;
}

@font-face {
  font-family: "Gothic MB101 Web";
  src: url("../fonts/A-OTF-GothicMB101Pro-Bold.otf?v=20260605-6") format("opentype");
  font-weight: 900;
  font-style: normal;
  font-display: swap;
}

@font-face {
  font-family: "Gothic MB101 Web";
  src: url("../fonts/A-OTF-GothicMB101Pro-DeBold.otf?v=20260605-6") format("opentype");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}

:root {
  --global-nav-height: 96px;
  --sr-violet: #392171;
  --sr-violet-dark: #230b52;
  --sr-yellow: #fed100;
  --sr-black: #050505;
  --sr-white: #fff;
  --sr-gray: #f1f1f4;
  --sr-text: #24212d;
  --font-base: "Gothic MB101 Web", "A-OTF Gothic MB101 Pro", "A-OTF ゴシックMB101 Pro", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
  --font-display: "SUNROCKERS BOLD", "Noto Sans JP", "Hiragino Kaku Gothic ProN", "Yu Gothic", Meiryo, sans-serif;
}


html { scroll-behavior: smooth; background: #000; }
body {
  position: relative;
  isolation: isolate;
  margin: 0;
  overflow-x: hidden;
  background: transparent;
  color: var(--sr-text);
  font-family: var(--font-base);
}
body::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background: linear-gradient(rgba(0, 0, 0, .34), rgba(0, 0, 0, .34)), url("/files/user/26-27_SEASON/lp/fc/img/background.jpg") center center / cover no-repeat;
}
button, input, select, textarea { font: inherit; }

.fc-lp br { display: inline; }
.fc-lp br.br-sp { display: none; }
.fc-lp br.br-pc { display: inline; }
section { scroll-margin-top: calc(var(--global-nav-height) + 18px); }

.fc-lp {
  position: relative;
  width: 100%;
  max-width: 760px;
  margin: 0 auto;
  min-height: 100vh;
  background: transparent;
  overflow: visible;
}

.global-nav {
  position: sticky;
  top: 0;
  z-index: 120;
  width: 100%;
  height: var(--global-nav-height);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  align-items: center;
  gap: 22px;
  box-sizing: border-box;
  padding: 0 26px;
  background: var(--sr-violet);
  color: var(--sr-white);
  border-bottom: 0;
  border-bottom: 4px solid var(--sr-yellow);
}
.global-nav__brand {
  min-width: 0;
  display: grid;
  grid-template-columns: 105px minmax(0, 1fr);
  grid-template-rows: auto auto;
  align-items: center;
  align-content: center;
  column-gap: 18px;
  row-gap: 0;
  color: inherit;
  text-decoration: none;
  white-space: nowrap;
}

.global-nav__title--path,
.global-nav__subtitle--path {
  display: none;
}
.global-nav__mobile-line {
  display: none;
}
.global-nav__title-image {
  display: block;
  grid-column: 2;
  grid-row: 1 / 3;
  width: min(365px, 100%);
  height: auto;
  align-self: center;
}
.global-nav__title--path {
  transform: translateY(8px);
  transform-origin: center;
}
.nav-path-svg { display: block; width: 100%; height: auto; overflow: visible; }
.global-nav__title--path { grid-column: 2; display: block; width: min(150px, 100%); color: var(--sr-white); }
.global-nav__subtitle--path { grid-column: 2; display: block; width: min(340px, 100%); margin-top: -50px; color: var(--sr-white); }
.global-nav__logo { grid-row: 1 / 3; display: block; width: 98px; height: 98px; object-fit: contain; }
@media (min-width: 768px) {
.global-nav__logo {
    transform: translateY(13px);
  }
}
.global-nav__title, .global-nav__subtitle, .global-nav__menu a, .eyebrow, .goods-tab { font-family: var(--font-display) !important; }
h1, h2, .btn, .global-nav__cta, .grade-card span, .grade-card strong { font-family: var(--font-base) !important; }
.global-nav__title { color: var(--sr-white); font-size: 18px; }
.global-nav__divider { display: none; }
.global-nav__subtitle { overflow: hidden; text-overflow: ellipsis; font-size: 12px; color: var(--sr-white); }
.global-nav__cta {
  min-width: 190px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  box-sizing: border-box;
  /* padding: 0 24px; */
  background: var(--sr-yellow);
  color: var(--sr-violet);
  text-decoration: none;
  font-size: 18px;
  font-weight: 500;
  line-height: 1;
}
.global-nav__cta--mobile {
  display: none;
}
.global-nav__toggle {
  width: 58px;
  height: 58px;
  display: grid;
  place-items: center;
  gap: 9px;
  border: 0;
  background: transparent;
  padding: 8px;
  cursor: pointer;
}
.global-nav__toggle span { width: 46px; height: 4px; background: var(--sr-yellow); border-radius: 999px; transition: transform .22s ease, opacity .22s ease, top .22s ease; }
.global-nav.is-open .global-nav__toggle span:nth-child(1) { transform: translateY(15px) rotate(45deg); }
.global-nav.is-open .global-nav__toggle span:nth-child(2) { opacity: 0; }
.global-nav.is-open .global-nav__toggle span:nth-child(3) { transform: translateY(-15px) rotate(-45deg); }
.global-nav__menu { position: absolute; top: var(--global-nav-height); right: 18px; width: min(320px, calc(100vw - 36px)); display: grid; background: var(--sr-violet-dark); opacity: 0; pointer-events: none; transform: translateY(-8px); transition: opacity .22s ease, transform .22s ease; box-shadow: 0 20px 50px rgba(0,0,0,.38); }
.global-nav.is-open .global-nav__menu { opacity: 1; pointer-events: auto; transform: translateY(0); }
.global-nav__menu a { display: flex; align-items: center; justify-content: space-between; min-height: 48px; padding: 0 18px; color: #fff; text-decoration: none; border-bottom: 1px solid rgba(255,255,255,.16); font-size: 15px; }
.global-nav__menu a::after { color: var(--sr-yellow); }
.global-nav__menu a:last-child { border-bottom: 0; }
.global-nav__menu-cta { display: none !important; }

.kv { position: relative; height: 100svh; min-height: 0; padding: 0 34px; box-sizing: border-box; display: grid; place-items: center; background: transparent; color: #fff; overflow: visible; }
.kv__bg { position: absolute; inset: 0; background: linear-gradient(rgba(57, 33, 113, 10), rgba(57, 33, 113, 10)); overflow: hidden; }
.kv__bg::before {
  content: "";
  position: absolute;
  inset: 0;
  background: url("/files/user/26-27_SEASON/lp/fc/img/kv--composite.png") center center / cover no-repeat;
  opacity: .48;
}
.kv__inner { position: relative; z-index: 1; width: min(100%, 620px); margin: 0 auto; display: grid; justify-items: center; align-content: center; text-align: center; }
.kv__logo { display: block; width: clamp(92px, 14vw, 132px); height: auto; margin: 0px auto 70px; }
.eyebrow { margin: 0 0 8px; color: var(--sr-yellow); font-size: 12px; font-weight: 900; letter-spacing: .08em; text-transform: uppercase; }
.eyebrow--dark { color: var(--sr-violet); }
h1 { margin: 0; color: #fff; font-size: clamp(42px, 9vw, 76px); line-height: .9; letter-spacing: 0; }
h1 small { display: block; margin-top: 0; color: var(--sr-yellow); font-size: 15px; letter-spacing: .08em; }

.kv {
  position: relative;
}

.kv__bg::after { content: none; }
@media (min-width: 768px) {
  .kv__bg::after { content: none; }
}

.kv-path-text { display: flex; justify-content: center; color: currentColor; }
.kv-path-svg { display: block; width: 100%; height: auto; overflow: visible; margin-top: -17px; }
.kv-path-heading { display: grid; justify-items: center; margin: 0 auto; width: min(520px, 100%); color: #fff; }
.kv-title-image { display: block; width: min(520px, 100%); height: auto; }
.kv-path-text--title { width: min(499px, 100%); color: #fff; }


.kv-path-text--subtitle { width: min(490px, 100%); color: #fff; }
.kv__lead { margin: 44px 0 0; color: #fff; font-weight: 900; font-size: clamp(15px, 2.8vw, 18px); letter-spacing: .03em; }
.kv .btn { width: min(400px, 86vw); min-height: 81px; margin-top: 104px; background: #fed100; color: var(--sr-violet); font-size: 18px; box-shadow: none; }
.btn { width: min(400px, 100%); min-height: 81px; display: inline-flex; align-items: center; justify-content: center; gap: 8px; box-sizing: border-box; border: 0; border-radius: 40px; background: #fff; color: var(--sr-violet); padding: 0 32px; text-decoration: none; cursor: pointer; }
.compare-detail::after { content: ">"; }
.btn--narrow { margin: 70px auto 0; display: flex; width: min(400px, 100%); }

.intro__label { height: 36px; display: flex; align-items: center; justify-content: center; margin: 0 -36px 22px; background: var(--sr-yellow); color: var(--sr-violet-dark); font-family: var(--font-base) !important; font-size: 13px; }
.intro__card { margin-top: -40px; margin-bottom: 0; padding: 120px; background: url("/files/user/26-27_SEASON/lp/fc/img/content_bg.jpg") center center / cover no-repeat; text-align: center; border: 1px solid #ded8e8; box-shadow: none; }
.intro__card h2 { margin: 0 0 18px; color: var(--sr-violet); font-size: clamp(34px, 7vw, 56px); line-height: .98; }
.intro__card .intro-path-heading { display: block; margin: 0 auto 26px; color: var(--sr-violet); line-height: 1; text-align: center; }
.intro-path-svg { display: block; width: 100%; height: auto; margin-inline: auto; overflow: visible; }
.intro__card p { margin: 0 auto 50px; max-width: 560px; line-height: 2; font-weight: 500; font-size: 15px; }
.intro__card strong { display: block; margin-top: 18px; color: var(--sr-violet); font-size: 27px; font-weight: 900; }

.reveal-on-scroll.is-visible {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
  filter: blur(0) !important;
}

@media (min-width: 768px) {
  .intro__card .intro-path-heading {
    width: 128%;
    margin: 0 auto 26px;
    position: relative;
    left: 50%;
    transform: translateX(-50%);
  }

  .intro__card strong {
    font-size: 36px;
  }

}

@media (max-width: 767px) {
  html,
  body {
    overflow-x: hidden;
  }

  .fc-lp,
  .global-nav,
  .global-nav__inner,
  .black-message,
  .black-message__band,
  .footer,
  .footer__main,
  .footer__brand,
  .club-band,
  .club-band__track {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    box-sizing: border-box;
  }

  .global-nav,
  .black-message,
  .footer,
  .footer__main,
  .footer__brand {
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  .global-nav__inner,
  .footer__main,
  .footer__brand {
    padding-left: 16px !important;
    padding-right: 16px !important;
  }

  .footer__cta {
    width: min(344px, 100%) !important;
  }

  .club-band__track {
    left: 0 !important;
    transform: none !important;
  }
}

.club-band {
  --club-band-item-width: 110px;
  --club-band-gap: 24px;
  --club-band-duration: 32s;
  position: relative;
  z-index: 2;
  width: 100%;
  height: 48px;
  display: flex;
  align-items: center;
  overflow: hidden;
  background: var(--sr-violet);
  background-color: var(--sr-violet);
  color: #fff;
  isolation: isolate;
}
.club-band__track {
  --club-band-base: -18px;
  --club-band-loop: 0px;
  min-width: max-content;
  height: 100%;
  display: flex;
  align-items: center;
  gap: var(--club-band-gap);
  transform: translate3d(var(--club-band-base), 0, 0);
  animation: club-band-slide var(--club-band-duration) linear infinite;
  will-change: transform;
}
.club-band__item {
  flex: 0 0 auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: var(--club-band-item-width);
  height: 100%;
  color: #fff;
}
.club-band__svg { display: block; width: 100%; height: auto; overflow: visible; transform: translateY(4px); }

@keyframes club-band-slide {
  from { transform: translate3d(var(--club-band-base), 0, 0); }
  to { transform: translate3d(calc(var(--club-band-base) - var(--club-band-loop)), 0, 0); }
}

@media (prefers-reduced-motion: reduce) {
  .club-band__track { animation: none; }
  .grades-sideword { --grade-sideword-y: 0px; --grade-sideword-opacity: .10; --grade-sideword-scale: 1; }
}
.club-band + .points { padding-top: 48px !important; margin-top: 0; }
.club-band + .points .points-heading { margin-top: 0; }

.section { padding: 76px 36px; }
.section-heading { margin: 0 auto 34px; text-align: center; }
.section-heading__logo { display: block; width: 90px; height: 90px; margin-inline: auto; object-fit: contain; }
.section-heading .section-heading__logo { margin-bottom: 18px; }
.section-heading h2 { margin: 0 0 10px; color: var(--sr-black); font-size: clamp(28px, 4.4vw, 38px); line-height: 1.5; font-weight: 900; letter-spacing: 0; }
.section-heading__en { display: flex; justify-content: center; width: 86px; margin: 0 auto; color: var(--sr-violet); line-height: 1; text-align: center; }
.section-heading__svg { display: block; width: 100%; height: auto; margin-inline: auto; overflow: visible; }
.section-heading--light h2 { color: #fff; }
.section-heading--light .section-heading__en { color: var(--sr-yellow); }
.section-heading--yellow h2, .section-heading--yellow .section-heading__en { color: var(--sr-violet); }
.section-heading--dark h2 { color: var(--sr-black); }

.section-heading__en[aria-label="GRADE"] { width: 82px; }
.section-heading__en[aria-label="FOR BEGINNERS"] { width: 199px; }
.section-heading__en[aria-label="TICKET"] { width: 75px; }
.section-heading__en[aria-label="GOODS"] { width: 64px; }
.section-heading__en[aria-label="BENEFITS"] { width: 98px; }
.section-heading__en[aria-label="ABOUT POINT SYSTEM"] { width: 233px; }
.section-heading__en[aria-label="FAQ"] { width: 50px; }
.grade-compare .section-heading { margin-bottom: 14px; }
.grade-compare .section-copy.section-copy--dark { margin-top: 10px; margin-bottom: 10px; }
.grade-compare > .section-copy { margin-bottom: 22px; }
.reveal-on-scroll {
  opacity: 0;
  transform: translate3d(0, 18px, 0);
  filter: blur(0.5px);
  transition:
    opacity .72s ease,
    transform .72s cubic-bezier(.22, 1, .36, 1),
    filter .72s ease;
  transition-delay: var(--reveal-delay, 0s);
  will-change: opacity, transform, filter;
}

.reveal-on-scroll.is-visible {
  opacity: 1;
  transform: translate3d(0, 0, 0);
  filter: blur(0);
}

@media (prefers-reduced-motion: reduce) {
  .reveal-on-scroll,
  .reveal-on-scroll.is-visible {
    opacity: 1;
    transform: none;
    filter: none;
    transition: none;
  }
}

.section-logo { width: 42px; height: 42px; display: inline-grid; place-items: center; margin: 0 auto 14px; border-radius: 50%; background: var(--sr-yellow); color: var(--sr-violet); font-family: var(--font-display); font-size: 24px; font-weight: 900; line-height: 1; }
.section-copy { max-width: 560px; margin: 0 auto 50px; color: #fff; text-align: center; font-size: 15px; line-height: 1.8; }

@media (min-width: 768px) {
  .section-copy {
    text-align: center;
}
}

@media (max-width: 767px) {
  .points-program .section-copy {
    text-align: left;
  }
}

.section-copy--dark {
  color: var(--sr-black);
  margin-top: 17px;
  font-size: 15px;
  font-weight: 500;
  line-height: 1.8;
}
.points-program .section-copy { color: var(--sr-black); }

.points { background: #fff; color: var(--sr-black); padding-top: 48px; padding-bottom: 78px; }
.points-heading { margin: 0 auto 34px; text-align: center; }
.points-heading__logo { display: block; width: 90px; height: 90px; margin: 0 auto 18px; object-fit: contain; }
.points-heading h2 { margin: 0 0 10px; color: var(--sr-black); font-size: clamp(28px, 4.4vw, 38px); line-height: 1.18; font-weight: 900; letter-spacing: 0; }
.points-heading__en { display: flex; justify-content: center; width: 188px; margin: 0 auto; color: var(--sr-violet); line-height: 1; text-align: center; }
.points-heading__svg { display: block; width: 100%; height: auto; margin-inline: auto; overflow: visible; }
.point-list { display: grid; grid-template-columns: repeat(3, 1fr); gap: 18px; max-width: 860px; margin: 0 auto; }
.point-card { min-width: 0; padding: 0; border: 0; border-radius: 0; background: #fff; text-align: left; }
.point-card__image { display: block; width: 100%; aspect-ratio: 1.52 / 1; object-fit: cover; margin: 0 0 18px; border-radius: 8px; }
.point-card h3 { margin: 0 0 12px; color: var(--sr-black); font-size: 20px; line-height: 1.65; font-weight: 800; }
.point-card p { margin: 0; color: var(--sr-black); font-size: 13px; line-height: 2; font-weight: 500; }

.grades, .goods, .benefit-scroll, .faq { background: rgba(57,33,113,.9); color: #fff; }
.grade-compare, .ticket, .points-program { background: #fff; color: var(--sr-black); }
.grades { position: relative; overflow: hidden; }
.grades > :not(.grades-sideword) { position: relative; z-index: 1; }
.grades-sideword { --grade-sideword-y: 0px; --grade-sideword-opacity: .10; --grade-sideword-scale: 1; position: absolute; left: 14px; top: 22px; bottom: 22px; z-index: 0; width: clamp(72px, 12vw, 180px); color: rgba(255,255,255,var(--grade-sideword-opacity)); pointer-events: none; transform: translate3d(0, var(--grade-sideword-y), 0) scale(var(--grade-sideword-scale)); transform-origin: left center; will-change: transform, color; }
.grades-sideword__svg { display: block; width: 100%; height: 100%; overflow: visible; }
.grade-main-title { display: flex; justify-content: center; width: 155px; max-width: 72%; margin: -12px auto 18px; color: #fff; line-height: 1; text-align: center; }
.grade-main-title__svg { display: block; width: 100%; height: auto; margin-inline: auto; overflow: visible; }
.grade-option-plus { margin: 18px auto 4px; color: #fff; text-align: center; font-size: 34px; line-height: 1; font-weight: 900; }
.grade-option-title { width: 200px; margin-top: 6px; }
.grade-option-note { max-width: 700px; margin: 0 auto 18px; color: rgba(255,255,255,.96); font-size: 12px; line-height: 1.8; font-weight: 500; text-align: center; }
.grade-list { display: grid; gap: 10px; max-width: 700px; margin: 0 auto; }
.grade-card { position: relative; display: grid; grid-template-columns: 240px 1fr; gap: 18px; align-items: center; min-height: 118px; padding: 12px 18px 12px 58px; background: #fff; color: var(--sr-text); --grade-strip-color: var(--sr-yellow); --grade-strip-text: var(--sr-violet); }
.grade-card::before { content: ""; position: absolute; left: 5px; top: 0; bottom: 0; width: 43px; box-sizing: border-box; background: var(--grade-strip-color); border: 0; }
.grade-card::after { content: attr(data-ribbon); position: absolute; left: 5px; top: 0; bottom: 0; width: 35px; display: grid; place-items: center; color: var(--grade-strip-text); font-size: 15px; font-weight: 900; line-height: 1.08; text-align: center; writing-mode: vertical-rl; text-orientation: upright; letter-spacing: .02em; pointer-events: none; }
.grade-card::after {
  left: 5px;
  width: 43px;
  justify-content: center;
  align-items: center;
}
.grade-card__meta { display: grid; gap: 8px; }
.grade-card__name { display: flex; align-items: center; gap: 8px; min-width: 0; color: var(--sr-violet); }
.grade-card__note { color: var(--sr-text); font-size: 15px; line-height: 1.2; font-weight: 500; }
.grade-name { display: block; width: 76px; color: var(--sr-violet); line-height: 1; }
.grade-name__svg { display: block; width: 100%; height: auto; overflow: visible; }
.grade-name--royal { width: 98px; }
.grade-name--advanced { width: 128px; }
.grade-name--advanced .grade-name__svg { display: block; }
.goods-tab-path--advanced { display: block; width: 100%; text-align: center; }
.goods-tab-path--advanced .goods-tab-path__svg { display: block; margin-inline: auto; }
.ticket-tab .goods-tab-path--advanced .goods-tab-path__svg,
.goods-tab .goods-tab-path--advanced .goods-tab-path__svg { margin-inline: auto; }
.grade-name--basic { width: 80px; }
.grade-name--light { width: 80px; }
.grade-name--sundy { width: 98px; }
.grade-name-ja { color: var(--sr-violet); font-size: 15px; line-height: 1; font-weight: 900; white-space: nowrap; }
.grade-card strong { color: var(--sr-violet); font-size: 18px; }
.grade-card__u18 { color: #ff2b1f; font-size: 12px; line-height: 1.35; font-weight: 900; }
.grade-popular-badge { position: absolute; right: 14px; top: 16px; z-index: 2; width: 58px; height: 58px; display: grid; place-items: center; border-radius: 50%; border: 3px solid var(--sr-yellow); background: var(--sr-violet); color: var(--sr-yellow); font-size: 15px; line-height: 1.05; font-weight: 900; text-align: center; }
.grade-benefits { display: grid; grid-template-columns: 30px 1fr; align-items: center; gap: 14px; min-width: 0; }
.grade-benefits__label { display: grid; place-items: center; justify-self: end; width: 35px; min-height: 95px; padding: 8px 4px; box-sizing: border-box; background: #000; color: #fff; font-size: 15px; font-weight: 900; line-height: 1.05; letter-spacing: .08em; writing-mode: vertical-rl; text-orientation: upright; }
.grade-benefits ul { display: grid; gap: 6px; margin: 0; padding: 0; list-style: none; color: var(--sr-violet); font-size: 16px; line-height: 1.5; font-weight: 500; }
.grade-benefits li { position: relative; padding-left: 16px; }
.grade-benefits li::before { content: ""; position: absolute; left: 0; top: .42em; width: 10px; height: 10px; border-radius: 50%; background: var(--sr-violet); }
.grade-card--royal { --grade-strip-color: #000; --grade-strip-text: #fff; }
.grade-card.is-sold-out { background: #777; overflow: hidden; }
.grade-card.is-sold-out::before, .grade-card.is-sold-out::after { opacity: .42; }
.grade-card.is-sold-out > :not(.grade-card__soldout) { filter: grayscale(1); opacity: .32; }
.grade-card__soldout { position: absolute; left: 50%; top: 50%; z-index: 5; width: min(190px, 32%); color: #fff; line-height: 1; pointer-events: none; opacity: 0; visibility: hidden; transform: translate(-50%, -50%) rotate(-10deg); filter: none; }
.grade-card.is-sold-out .grade-card__soldout { opacity: 1; visibility: visible; }
.grade-card__soldout-svg { display: block; width: 100%; height: auto; overflow: visible; }
.grade-card--advanced { --grade-strip-color: var(--sr-violet); --grade-strip-text: #fff; }
.grade-card--basic { --grade-strip-color: var(--sr-yellow); --grade-strip-text: var(--sr-violet); }
.grade-card--light { --grade-strip-color: #b8b8b8; --grade-strip-text: var(--sr-violet); }
.grade-card--option { --grade-strip-color: #fff; --grade-strip-text: var(--sr-violet); }
.grade-card--option::before { border-right: 1px solid var(--sr-violet); border-left: 1px solid var(--sr-violet); }
.grade-card--option {
  grid-template-columns: 240px minmax(0, 1fr) 126px;
  grid-template-rows: 1fr;
  align-items: center;
  gap: 18px;
  padding-top: 12px;
  overflow: hidden;
}
.grade-card--option .grade-card__meta {
  grid-column: 1;
  grid-row: 1;
  padding-right: 0;
}
.grade-card--option .grade-benefits {
  grid-column: 2;
  grid-row: 1;
  margin-top: 0;
}
.grade-card__sundy-figure {
  grid-column: 3;
  grid-row: 1;
  align-self: end;
  justify-self: end;
  width: min(112px, 100%);
  height: auto;
  margin-top: 0;
  margin-bottom: -5px;
  pointer-events: none;
}
.grade-card__detail { position: absolute; top: 0; right: 0; z-index: 3; min-width: 132px; min-height: 38px; display: flex; align-items: center; justify-content: center; padding: 0 5px 0 28px; box-sizing: border-box; background: var(--sr-yellow); color: #000; font-size: 15px; font-weight: 900; line-height: 1; text-decoration: none; clip-path: polygon(0 0, 100% 0, 100% 100%,17% 100%); }

.compare-table { max-width: 700px; margin: 0 auto; background: #fff; color: var(--sr-text); border: 1px solid #d8d8dd; }
.compare-row { display: grid; grid-template-columns: 1.45fr .82fr .82fr; border-bottom: 1px solid #e4e1ea; }
.compare-row:not(.compare-row--head) { width: 100%; margin-inline: auto; }
.compare-row:last-child { border-bottom: 0; }
.compare-row--head { position: sticky; top: var(--global-nav-height); z-index: 20; border-bottom: 0; box-shadow: none; border-bottom: 3px solid var(--sr-yellow);}
.compare-row > div { display: flex; align-items: center; justify-content: center; gap: 10px; min-width: 0; min-height: 44px; padding: 6px 8px; box-sizing: border-box; text-align: left; font-size: 16px; line-height: 1.28; font-weight: 700; border-right: 2px solid #fff; }
.compare-row > div:last-child { border-right: 0; }
.compare-row > div:first-child { justify-content: flex-start; padding-left: 20px; background: #fff; color: #000; }
.compare-row > div:nth-child(2), .compare-row > div:nth-child(3) { color: #000; }
.compare-row.compare-row--head > div { min-height: 150px; padding: 10px 8px; background: var(--sr-violet); color: #fff; border-right: 2px solid #140833; font-family: var(--font-base) !important; }
.compare-row.compare-row--head > div { position: relative; }
.compare-row.compare-row--head > div:nth-child(2)::before,
.compare-row.compare-row--head > div:nth-child(3)::before { content: none; }
.compare-row.compare-row--head > div:last-child { border-right: 0; }
.compare-row:not(.compare-row--head):not(.compare-row--category) > div:not(:last-child) { border-right: 1px solid #e4e1ea; }
.compare-row--category > div { justify-content: center !important; padding-left: 8px !important; text-align: center; }
.compare-plan { flex-direction: column; justify-content: flex-start !important; gap: 8px !important; }
.compare-row--head .compare-plan { align-items: center; justify-content: flex-start !important; padding-top: 22px; padding-bottom: 0; }
.compare-row--head .compare-plan:nth-child(2) .compare-plan__u18 { max-width: 150px; }

.compare-plan__name { display: flex; align-items: center; justify-content: center; gap: 8px; min-height: 32px; color: #fff; line-height: 1; }
.compare-plan-path { display: block; color: #fff; line-height: 1; }
.compare-row--head .compare-plan:nth-child(2) .compare-plan-path,
.compare-row--head .compare-plan:nth-child(2) .compare-plan__ja { color: #fed100; }
.compare-row--head .compare-plan:nth-child(3) .compare-plan-path,
.compare-row--head .compare-plan:nth-child(3) .compare-plan__ja { color: #e6e6e6; }
.compare-plan-path--basic, .compare-plan-path--light { width: auto; }
.compare-plan-path__svg { display: block; width: auto; height: 34px; overflow: visible; }
.compare-plan__ja { color: #fff; font-family: var(--font-base); font-size: 15px; line-height: 1; letter-spacing: 0; }
.compare-plan b { display: inline-flex; align-items: center; justify-content: center; min-height: 28px; padding: 0 6px; box-sizing: border-box; background: var(--sr-yellow); color: #000; font-family: var(--font-base); font-size: 17px; line-height: 1; }
.compare-plan__u18 { width: 100%; min-height: 28px; display: flex; align-items: center; justify-content: center; margin-top: 2px; padding-top: 8px; border-top: 1px solid #fff; color: #fff; font-family: var(--font-base); font-size: 15px; line-height: 1; font-weight: 500; }
.compare-plan small { color: #fff; font-family: var(--font-base); font-size: 16px; line-height: 1; }
.compare-row--category { grid-template-columns: 1fr; }
.compare-row--category > div { grid-column: 1 / -1; min-height: 44px; background: #f1f1f4 !important; color: var(--sr-violet) !important; font-size: 18px; border-right: 0; }
.compare-check { color: var(--sr-violet); font-size: 26px; line-height: .7; font-weight: 900; }
.compare-detail { min-height: 28px; border: 0; border-radius: 999px; background: var(--sr-violet); color: #fff; padding: 0 10px; font-size: 10px; font-weight: 900; cursor: pointer; }

.goods, .ticket { }
.goods-tabs { display: grid; grid-template-columns: repeat(auto-fit, minmax(0, 1fr)); max-width: 700px; margin: 0 auto 22px; border: 2px solid var(--sr-violet); }
.goods-tab,
.ticket-tab { position: relative; min-height: 56px; display: flex; align-items: center; justify-content: center; border: 0; cursor: pointer; border-radius: 10px 10px 0 0; transition: filter .2s ease, box-shadow .2s ease, transform .2s ease, opacity .2s ease; }
.goods-tab { border-right: 1px solid var(--sr-violet); border-bottom: 2px solid var(--sr-violet); font-size: 11px; }
.goods-tab:last-child { border-right: 0; }
.ticket-tabs { display: grid; grid-template-columns: repeat(4, 1fr); max-width: 700px; margin: 0 auto; border-bottom: 0; }
.ticket-tab { color: var(--sr-violet); }
.ticket-tab:last-child { border-right: 0; }
.goods-tab:not(.is-active),
.ticket-tab:not(.is-active) {
  opacity: .76;
  filter: saturate(.92);
}

.goods-tab[data-tab="royal"],
.ticket-tab[data-ticket-tab="ticket-royal"] { background: #010501; color: #fffffb; }

.goods-tab[data-tab="advanced"],
.ticket-tab[data-ticket-tab="ticket-advanced"] { background: #392171; color: #fffffb; }
.goods-tab[data-tab="advanced"] { position: relative; }
.goods-tab[data-tab="advanced"]::before { content: ""; position: absolute; inset: 0 0 2px; border: 0.5px solid rgba(255,255,255,.92); border-bottom: 0; border-radius: 10px 10px 0 0; pointer-events: none; }

.goods-tab[data-tab="basic"],
.ticket-tab[data-ticket-tab="ticket-basic"] { background: #fed100; color: #010501; }

.goods-tab[data-tab="light"],
.ticket-tab[data-ticket-tab="ticket-light"] { background: #e6e6e6; color: var(--sr-violet); }

.goods-tab[data-tab="sundy"] { position: relative; overflow: hidden; isolation: isolate; background: #fffffb; color: var(--sr-violet); }
.goods-tab[data-tab="sundy"]::before { content: ""; position: absolute; inset: 0; background-image: url("/files/user/26-27_SEASON/lp/fc/img/sundy_grade.png"); background-repeat: no-repeat; background-position: center -6px; background-size: 84% auto; opacity: .6; pointer-events: none; z-index: 0; }
.goods-tab[data-tab="sundy"].is-active::before { inset: 0 0 5px; }
.goods-tab[data-tab="sundy"] .goods-tab-path,
.goods-tab[data-tab="sundy"] .goods-tab-path__svg { position: relative; z-index: 1; }

.goods-tab.is-active,
.ticket-tab.is-active {
  z-index: 2;
  opacity: 1;
  filter: none;
  transform: translateY(-4px);
  box-shadow: none;
}

.ticket-panel { display: none; }
.ticket-panel.is-active { display: block; }
.ticket-panel__summary { width: 100%; max-width: 700px; min-height: 72px; display: flex; align-items: center; justify-content: center; margin: 22px auto 10px; padding: 14px 20px; box-sizing: border-box; background: var(--sr-violet); color: #fff; text-align: center; font-size: 20px; line-height: 1.45; font-weight: 500; }
.ticket-panel__note { width: 100%; max-width: 700px; margin: 18px auto 30px; color: var(--sr-black); font-size: 13px; line-height: 1.7; font-weight: 500; text-align: left; }
.ticket-tab .goods-tab-path__svg { height: 26px; max-width: 150px; }
.ticket-comingsoon { max-width: 700px; margin: 0 auto; padding: 22px; box-sizing: border-box; background: #f1f1f4; border: 1px solid #d8d8dd; }
.ticket-comingsoon img { display: block; width: 100%; height: auto; }
.ticket-seat-labels { padding: 28px 16px 8px; text-align: center; }
.ticket-seat-labels__title { margin: 0 0 14px; color: var(--sr-black); font-size: 16px; font-weight: 700; }
.ticket-seat-labels__grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px 22px; max-width: 520px; margin: 0 auto; }
.ticket-seat-label { min-height: 38px; display: flex; align-items: center; justify-content: center; border-radius: 999px; color: #fff; font-size: 16px; font-weight: 700; line-height: 1; }
.ticket-seat-label--vip { background: var(--sr-violet); }
.ticket-seat-label--arena { background: #2846b8; }
.ticket-seat-label--court { background: #f00; }
.ticket-seat-label--reserved { background: #159326; }


.goods-tab-path { display: block; color: currentColor; line-height: 1; }
.goods-tab-path__svg { display: block; width: auto; height: 26px; max-width: 150px; overflow: visible; }
.goods-panel { display: none; }
.goods-panel.is-active { display: block; }
.goods-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; max-width: 700px; margin: 0 auto; }
.goods-card { display: grid; grid-template-rows: auto 1fr auto; padding: 0; border: 0; background: #fff; color: #000; text-align: left; cursor: pointer; }
.goods-card img { width: 100%; aspect-ratio: 16 / 10; object-fit: cover; display: block; }
.goods-card__title { padding: 14px 14px 8px; font-weight: 900; line-height: 1.6;}
.goods-card__more { justify-self: end; display: inline-flex; align-items: center; justify-content: center; min-height: 22px; margin: 0 14px 18px; padding: 0 10px; background: #000; color: var(--sr-yellow); font-size: 11px; font-weight: 500; }

.black-message { min-height: 360px; display: flex; flex-direction: column; justify-content: flex-end; padding: 200px 0 0; box-sizing: border-box; background: rgba(0,0,0,.78); color: #fff; text-align: center; overflow: hidden; }
.black-message__copy { margin: auto 24px 200px; font-size: 25px; line-height: 1.4; }
.black-message__band { flex: 0 0 auto; height: 44px; background: transparent; color: var(--sr-yellow); --club-band-item-width: 108px; --club-band-gap: 26px; }
.black-message__band .club-band__track { --club-band-base: -22px; }
.black-message__band .club-band__item { color: var(--sr-yellow); }
.court-card { max-width: 540px; margin: 0 auto; padding: 18px; background: #f2f2f4; border: 1px solid #ddd; }
.court-card__tabs { display: grid; grid-template-columns: repeat(4, 1fr); margin-bottom: 18px; background: var(--sr-violet); color: #fff; font-family: var(--font-base) !important; font-size: 12px; text-align: center; }
.court-card__tabs span { padding: 10px 4px; border-right: 1px solid rgba(255,255,255,.3); }
.court { height: 220px; display: flex; align-items: center; justify-content: space-between; padding: 0 26px; background: #f7e0ba; border: 12px solid #fff; box-shadow: inset 0 0 0 2px #c9ad7f; color: var(--sr-violet); font-family: var(--font-base) !important; }
.ticket-legend { display: grid; grid-template-columns: repeat(4, 1fr); gap: 8px; margin-top: 18px; }
.ticket-legend span { padding: 8px 4px; border-radius: 999px; background: var(--sr-violet); color: #fff; text-align: center; font-size: 11px; font-weight: 900; }

.benefit-scroll { color: var(--sr-text); border-top: 6px solid var(--sr-violet); }
.benefit-scroll .section-heading--light h2 { color: #fff; }
.benefit-scroll .section-heading--light .section-heading__en { color: var(--sr-yellow); }
.benefit-scroll__lead { color: #fff; margin: -10px auto 28px; text-align: center; font-size: 15px; font-weight: 800; }
.scroll-container { max-width: 820px; margin: 0 auto; overflow-x: auto; overflow-y: hidden; padding: 0 0 14px; scrollbar-width: none; scroll-snap-type: x proximity; scroll-padding-inline-start: 0; -webkit-overflow-scrolling: touch; overscroll-behavior-inline: contain; }
.scroll-container::-webkit-scrollbar { display: none; }
.scroll-list { width: max-content; min-width: 100%; display: flex; justify-content: flex-start; gap: 18px; margin: 0; padding: 0 120px 0 0; box-sizing: border-box; }
.scroll-item { flex: 0 0 286px; display: flex; flex-direction: column; align-items: stretch; scroll-snap-align: start; scroll-snap-stop: always; background: #fff; border: 1px solid #e2e2e2; box-shadow: 0 0 0 1px rgba(61,32,119,.05); color: var(--sr-text); }
.scroll-item img { width: 100%; aspect-ratio: 4 / 2.7; object-fit: cover; display: block; }
.scroll-item__grades { display: flex; flex-wrap: wrap; gap: 6px; margin: 12px 18px 0; }
.scroll-item__grade { display: inline-flex; align-items: center; justify-content: center; min-height: 24px; padding: 0 9px; font-size: 10px; font-weight: 900; line-height: 1; letter-spacing: .04em; }
.scroll-item__grade--royal { background: #010501; color: #fff; }
.scroll-item__grade--advance { background: #392171; color: #fff; }
.scroll-item__grade--basic { background: #fed100; color: #010501; }
.scroll-item__grade--light { background: #e6e6e6; color: var(--sr-violet); }
.scroll-item__grade--sundy { background: #fffffb; color: var(--sr-violet); border: 1px solid var(--sr-violet); }
.scroll-item h3 { margin: 12px 18px 10px; color: #000; font-size: 18px; line-height: 1.35; text-align: left; }
.scroll-item p { margin: 0 18px 18px; font-size: 14px; line-height: 1.85; font-weight: 500; flex: 1 1 auto; }
@media (max-width: 767px) {
  .scroll-item__grades { gap: 5px; margin: 10px 14px 0; }
  .scroll-item__grade { min-height: 22px; padding: 0 8px; font-size: 9px; }
}
.scroll-item__more { display: grid; place-items: center; min-height: 48px; background: var(--sr-yellow); color: #000; font-weight: 500; }
.scroll-hint { margin: 16px auto 0; text-align: center; color: #fff; font-size: 15px; font-weight: 500; }

.point-tabs { display: grid; grid-template-columns: repeat(2, 1fr); max-width: 700px; margin: 0 auto 22px; }
.point-tab { min-height: 40px; display: flex; align-items: center; justify-content: center; border: 0; border-right: 1px solid #fff; background: #eee; color: var(--sr-violet); font-size: 18px; font-weight: 900; cursor: pointer; border-radius: 10px 10px 0 0; }
.point-tab:last-child { border-right: 0; }
.point-tab.is-active { background: var(--sr-yellow); color: var(--sr-violet-dark); }
.point-panel { display: none; max-width: 700px; margin: 0 auto; }
.point-panel.is-active { display: block; }
.point-panel__image { display: block; width: 100%; height: auto; background: #f2f2f4; border: 1px solid #ddd; object-fit: contain; }
.faq-list { max-width: 700px; margin: 0 auto 70px; display: grid; gap: 12px; }
.faq-item { background: #fff; color: var(--sr-text); border-radius: 6px; overflow: hidden; }
.faq-item summary { position: relative; display: grid; grid-template-columns: 38px 1fr; align-items: center; gap: 12px; padding: 16px 48px 16px 18px; color: var(--sr-violet); font-size: 16px; font-weight: 900; line-height: 1.5; cursor: pointer; list-style: none; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::before,
.faq-answer::before { display: block; width: 38px; color: var(--sr-violet); font-family: "SUNROCKERS FAQ", "SUNROCKERS BOLD", sans-serif; font-size: 34px; font-weight: 700; line-height: .9; letter-spacing: .02em; font-synthesis: none; }
.faq-item summary::before { content: "Q."; }
/* .faq-item summary::after { content: "+"; position: absolute; right: 18px; top: 50%; transform: translateY(-50%); color: var(--sr-violet); font-size: 24px; } */
/* .faq-item[open] summary::after { content: "ー"; } */
.faq-answer { display: grid; grid-template-columns: 38px 1fr; gap: 12px; font-size: 16px; padding: 0 35px 30px 18px; line-height: 1.8; }
.faq-answer::before { content: "A."; margin-top: 2px; }
.faq-answer p { margin: 0; font-size: 14px; }
.faq > .btn { font-weight: 900; display: flex; width: min(560px, 100%); margin-inline: auto; background: var(--sr-yellow); color: var(--sr-violet-dark); }
.faq-actions { display: grid; grid-template-columns: repeat(1, minmax(0, 1fr)); justify-items: center; gap: 18px; max-width: 560px; margin: 36px auto 0; }
.faq-action { width: 100%; min-height: 58px; display: inline-flex; align-items: center; justify-content: center; gap: 10px; box-sizing: border-box; padding: 0 18px; color: #000; text-decoration: none; font-size: 14px; font-weight: 500; line-height: 1.25; }
.faq-actions .faq-action:only-child { justify-self: center; width: min(344px, 100%); }
.faq-action::before { content: "▶"; font-size: 16px; line-height: 1; }
.faq-action--line { background: #00d757; }
.faq-action--app { background: #fff; }
.footer { position: relative; display: grid; justify-items: center; gap: 0; padding: 0; background: var(--sr-violet); color: #fff; text-align: center; font-size: 10px; overflow: visible; }
.footer > .section-heading__logo { display: none; }
.footer__band { width: 100%; background: var(--sr-yellow); border-top: 1px solid rgba(255,255,255,.7); }
.footer-menu { width: min(100%, 960px); display: grid; grid-template-columns: repeat(5, minmax(0, 1fr)); margin: 0 auto; }
.footer-menu__link { position: relative; min-height: 42px; display: flex; align-items: center; justify-content: space-between; gap: 12px; padding: 0 20px; color: var(--sr-violet); text-decoration: none; font-size: 12px; font-weight: 900; line-height: 1.2; text-align: left; border-right: 1px solid rgba(57,33,113,.28); transition: opacity .2s ease; }
.footer-menu__link::after { content: ""; flex: 0 0 auto; width: 0; height: 0; border-top: 7px solid transparent; border-bottom: 7px solid transparent; border-left: 11px solid currentColor; }
.footer-menu__link:last-child { border-right: 0; }
.footer__main {
  position: relative;
  width: 100%;
  display: grid;
  justify-items: center;
  gap: 10px;
  padding: 0 0 34px;
  background: var(--sr-violet);
  border-top: 0;
}
.footer__main::before {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 3px;
  background: var(--sr-yellow);
}
.footer__logo {
  position: relative;
  z-index: 1;
  width: 112px;
  height: auto;
  margin-top: -40px;
  margin-bottom: 40px;
}
.footer__cta {
  width: min(344px, calc(100% - 56px));
  min-height: 50px;
  display: grid;
  grid-template-columns: 1fr auto;
  align-items: center;
  column-gap: 14px;
  padding: 0 18px 0 24px;
  border-radius: 0 14px 0 14px;
  background: linear-gradient(90deg, #ffd400 0%, #ffc800 52%, #ffbd00 100%);
  color: #392171;
  text-decoration: none;
  font-size: 14px;
  font-weight: 900;
  line-height: 1;
  text-align: left;
  box-sizing: border-box;
}
.footer__cta span {
  font-size: 24px;
  line-height: 1;
  transform: translateY(-1px);
}
.footer__follow { display: block; width: min(120px, 42vw); height: auto; margin: 20px 0 0; }
.footer-social { display: flex; align-items: center; justify-content: center; gap: 14px; }
.footer-social__link { width: 24px; height: 24px; display: grid; place-items: center; color: #fff; text-decoration: none; transition: opacity .2s ease; }
.footer-social__link svg { display: block; width: 100%; height: 100%; }
.footer-social__link--line {
  background: transparent;
  border-radius: 0;
  font-size: 0;
}

.footer-social__link--line img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.footer-social__link--line { width: 22px; height: 22px; border-radius: 50%; color: var(--sr-violet); font-size: 9px; font-weight: 900; line-height: 1; }
.footer__brand { width: 100%; display: grid; justify-items: center; gap: 12px; margin: 0 50px 50px; }
.footer__brand-logo { display: block; width: min(150px, 72vw); height: auto; }
.footer-social__link:hover,
.footer-menu__link:hover,
.footer__cta:hover,
.footer-subnav__link:hover { opacity: .78; }
.footer-subnav { display: flex; flex-wrap: wrap; justify-content: center; gap: 6px 18px; }
.footer-subnav__link { color: rgba(255,255,255,.9); text-decoration: none; font-size: 11px; line-height: 1.5; }
.footer small { color: rgba(255,255,255,.72); font-size: 10px; line-height: 1.4; }

.faq-item summary::before {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  background: url("/files/user/26-27_SEASON/lp/fc/img/faq-q.svg") center center / contain no-repeat;
}

.faq-answer::before {
  content: "";
  display: block;
  flex-shrink: 0;
  width: 30px;
  height: 30px;
  margin-top: 2px;
  background: url("/files/user/26-27_SEASON/lp/fc/img/faq-a.svg") center center / contain no-repeat;
}

.faq-item summary::after {
  content: "";
  position: absolute;
  right: 24px;
  top: 50%;
  width: 12px;
  height: 12px;
  border-right: 4px solid var(--sr-violet);
  border-bottom: 4px solid var(--sr-violet);
  transform: translateY(-70%) rotate(45deg);
  transition: transform .3s ease;
}

.faq-item[open] summary::after {
  transform: translateY(-30%) rotate(-135deg);
}

.modal { position: fixed; inset: 0; z-index: 999; display: none; align-items: center; justify-content: center; padding: 20px; box-sizing: border-box; }
.modal.is-open { display: flex; }
.modal__overlay { position: absolute; inset: 0; background: rgba(0,0,0,.72); }
.modal__content { position: relative; z-index: 1; width: 100%; max-width: 520px; max-height: calc(100dvh - 40px); padding: 28px 24px 30px; box-sizing: border-box; overflow-y: auto; overscroll-behavior: contain; background: #fff; color: var(--sr-text); }
.modal__image { display: block; width: 100%; height: auto; margin: 0 0 22px; object-fit: contain; background: var(--sr-gray); }
.modal__content h3 { margin: 0 0 12px; color: var(--sr-violet); font-size: 24px; line-height: 1.35; overflow-wrap: anywhere; }
.modal__content p { margin: 0; line-height: 1.8; }
.modal__close { position: absolute; top: 10px; right: 10px; z-index: 2; width: 38px; height: 38px; display: grid; place-items: center; padding: 0; border: 0; border-radius: 50%; background: #fff; color: var(--sr-violet); box-shadow: 0 2px 10px rgba(0,0,0,.2); font-size: 28px; line-height: 1; cursor: pointer; }
.modal__content--announcement { max-width: min(920px, calc(100vw - 32px)); padding: 18px 18px 20px; background: transparent; box-shadow: none; }
.modal__image--announcement { max-height: min(78dvh, 920px); margin: 0; background: transparent; object-fit: contain; }
.announcement-modal__lead { margin: 0 0 14px; color: #fff; text-align: center; font-size: clamp(22px, 3vw, 34px); line-height: 1.35; font-weight: 900; text-shadow: 0 4px 14px rgba(0,0,0,.32); }

@media (min-width: 1200px) { .fc-lp { max-width: 960px; width: 960px; } }
@media (max-width: 767px) {
  body.has-nav-open::before {
    content: "";
    position: fixed;
    inset: 0;
    z-index: 79;
    background: rgba(0,0,0,.58);
  }

  body,
  .fc-lp,
  .fc-lp *,
  .fc-lp button,
  .fc-lp input,
  .fc-lp select,
  .fc-lp textarea {
    font-family: var(--font-base) !important;
  }

  .grades-sideword { display: none; }


  .fc-lp br.br-sp { display: inline; }
  .fc-lp br.br-pc { display: none; }
  :root { --global-nav-height: 88px; }
  .fc-lp { max-width: none; padding-top: var(--global-nav-height); box-sizing: border-box; box-shadow: none; }
  .global-nav { position: fixed; top: 0; left: 0; z-index: 80; grid-template-columns: minmax(0, 1fr) auto auto; gap: 8px; width: 100%; padding: 10px 12px 8px; border-top-width: 4px; }
  .global-nav__brand { grid-column: 1; grid-template-columns: 48px minmax(0, 1fr); grid-template-rows: auto; column-gap: 10px; row-gap: 0; justify-self: start; align-items: center; align-content: center; max-width: calc(100vw - 164px); overflow: visible; }
  .global-nav__logo { grid-row: 1; width: 48px; height: 48px; }
  .global-nav__title-image { display: block; grid-column: 2; width: min(100px, calc(100vw - 96px)); height: auto; align-self: center; }
  .global-nav__title--path,
  .global-nav__subtitle--path,
  .global-nav__mobile-line { display: none; }
  .global-nav__cta--mobile { grid-column: 2; min-width: 94px; min-height: 36px; padding: 0 12px; display: inline-flex; align-self: center; justify-self: end; border-radius: 0; font-size: 14px; font-weight: 900; line-height: 1; white-space: nowrap; }
  .global-nav__toggle { position: relative; grid-column: 3; justify-self: end; width: 36px; height: 38px; display: block; padding: 4px 1px; align-self: center; }
  .global-nav__toggle span { position: absolute; left: 50%; width: 28px; height: 3px; margin-left: -14px; border-radius: 999px; transform-origin: center; }
  .global-nav__toggle span:nth-child(1) { top: 8px; }
  .global-nav__toggle span:nth-child(2) { top: 17px; }
  .global-nav__toggle span:nth-child(3) { top: 26px; }
  .global-nav.is-open .global-nav__toggle span:nth-child(1) { top: 17px; transform: rotate(45deg); }
  .global-nav.is-open .global-nav__toggle span:nth-child(2) { opacity: 0; }
  .global-nav.is-open .global-nav__toggle span:nth-child(3) { top: 17px; transform: rotate(-45deg); }
  .global-nav__menu { top: var(--global-nav-height); right: 8px; width: calc(100vw - 16px); }
  .global-nav__menu a { font-family: var(--font-base) !important; }
  .global-nav__menu .global-nav__menu-cta { display: none !important; }
  .kv { height: calc(100svh - var(--global-nav-height)); min-height: 520px; padding-inline: 22px; overflow: visible; }
  .kv__inner { width: min(100%, 520px); }
  .kv__logo { display: none; }
  .kv-path-heading { width: min(520px, 100%); }
  .kv-title-image { width: min(430px, 100%); }
  .kv-path-text--title { width: min(430px, 100%); }
  .kv-path-text--subtitle { width: min(430px, 100%); margin-top: 8px; }
  .kv__lead { font-size: 25px; line-height: 1.5; margin-top: 80px; }
  .kv .btn { margin-top: 82px; min-height: 81px; }
  .kv__inner { padding-top: 0; }
  .intro__label { margin-left: -18px; margin-right: -18px; }
  .intro__card { padding: 100px 20px; }
  .club-band { height: 40px; --club-band-item-width: 92px; --club-band-gap: 18px; --club-band-duration: 18s; }
  .club-band__track { --club-band-base: -14px; }
  .black-message { min-height: 300px; padding-top: 92px; }
  .black-message__copy { margin: auto 18px 88px; font-size: 19px; }
  .black-message__band { height: 55px; --club-band-item-width: 92px; --club-band-gap: 18px; }
  .black-message__band .club-band__track { --club-band-base: -16px; }
  .point-list, .goods-grid { grid-template-columns: 1fr; }
  .points { padding-top: 38px; padding-bottom: 56px; }
  .points-heading { margin-bottom: 26px; }
  .points-heading__logo { width: 70px; height: 70px; margin-bottom: 14px; }
  .section-heading__logo { width: 70px; height: 70px; }
  .point-list { gap: 18px; max-width: 100%; }
  .point-card { display: grid; grid-template-columns: 112px minmax(0, 1fr); gap: 0 14px; align-items: start; }
  .point-card__image { grid-column: 1; grid-row: 1 / span 2; margin: 0; aspect-ratio: 1 / 1; border-radius: 8px; }
  .point-card h3 { margin: 0 0 8px; font-size: 18px; line-height: 1.45; }
  .point-card p { font-size: 12px; line-height: 1.75; }
  .grade-card { grid-template-columns: 1fr; gap: 14px; min-height: 104px; padding-left: 52px; }
  .grade-card__soldout { width: min(180px, 48%); transform: translate(-50%, -50%) rotate(-10deg); }
  .grade-benefits { grid-template-columns: 32px 1fr; gap: 10px; }
  .grade-popular-badge { right: 10px; top: 10px; width: 70px; height: 70px; border-width: 3px; font-size: 18px; }
  .grade-card__u18 { font-size: 11px; }
  .grade-benefits__label { width: 26px; min-height: 78px; font-size: 12px; letter-spacing: .06em; }
  .grade-benefits ul { font-size: 13px; font-weight: 800; gap: 5px; }
  .grade-benefits li { padding-left: 14px; }
  .grade-benefits li::before { width: 8px; height: 8px; }
  .grade-card::before, .grade-card::after { width: 35px; }
  .grade-card::after { font-size: 12px; line-height: 1.05; }
  .grade-card__detail { min-width: 104px; min-height: 32px; padding-left: 22px; font-size: 12px; }
  .grade-card--option {
    grid-template-columns: minmax(0, 1fr) 168px;
    grid-template-rows: auto auto;
    align-items: start;
    gap: 14px 12px;
    padding-top: 38px;
  }
  .grade-card--option .grade-card__meta {
    grid-column: 1;
    grid-row: 1;
    padding-right: 0;
  }
  .grade-card--option .grade-benefits {
    grid-column: 1;
    grid-row: 2;
    margin-top: 0;
  }
  .grade-card__sundy-figure {
    grid-column: 2;
    grid-row: 1 / span 2;
    align-self: end;
    justify-self: center;
    width: min(150px, 100%);
    margin-top: 8px;
  }
  .grade-option-plus { margin-top: 14px; font-size: 28px; }
  .grade-option-note { margin: 0 auto 14px; font-size: 13px; line-height: 1.7; }
  .goods-tabs { grid-template-columns: repeat(2, 1fr); max-width: 540px; gap: 8px 0; }
  .goods-tab { grid-column: auto; }
  .ticket-tabs { grid-template-columns: repeat(2, 1fr); max-width: 540px; gap: 8px 0; }
  .point-tabs { grid-template-columns: repeat(2, minmax(0, 1fr)); max-width: 540px; }
  .point-tab { min-height: 46px; padding: 0 8px; font-size: 13px; line-height: 1.25; }
  .ticket-tab .goods-tab-path__svg { height: 20px; max-width: 118px; }
  .ticket-panel__summary { min-height: 58px; margin: 10px 0 5px; padding: 10px 12px; font-size: 15px; line-height: 1.4; }
  .ticket-panel__note { margin: 25px 0 25px; font-size: 11px; line-height: 1.6; }
  .ticket-comingsoon { padding: 12px; }
  .ticket-seat-labels { padding: 20px 0 4px; }
  .ticket-seat-labels__grid { gap: 10px; }
  .ticket-seat-label { min-height: 32px; font-size: 14px; }


  .goods-tab-path__svg { height: 20px; max-width: 118px; }
  .compare-table { max-width: 100%; }
  .compare-row { grid-template-columns: 1.2fr .82fr .82fr; }
  .compare-row:not(.compare-row--head) { width: 100%; }
  .compare-row > div { min-height: 38px; padding: 5px 5px; gap: 6px; font-size: 15px; line-height: 1.22; }
  .compare-row.compare-row--head > div { min-height: 116px; padding: 8px 5px; }
  
  .compare-row--head .compare-plan { padding-top: 18px; padding-bottom: 0; }
  
  .compare-plan__name { flex-direction: column; gap: 5px; min-height: 42px; }
  .compare-plan-path--basic, .compare-plan-path--light { width: auto; }
  .compare-plan-path__svg { height: 30px; }
  .compare-plan__ja { display: none; }
  .compare-plan b { width: 100%; min-width: 0; min-height: 25px; padding: 0 3px; font-size: 14px; white-space: nowrap; }
  .compare-plan__u18 { min-height: 22px; padding-top: 6px; font-size: 11px; text-align: center; }
  .compare-plan small { font-size: 11px; }
  .compare-row--category > div { min-height: 38px; font-size: 15px; }
  .compare-check { font-size: 23px; }
  .ticket-legend { grid-template-columns: repeat(2, 1fr); }
  .benefit-scroll__lead { margin-bottom: 22px; font-size: 13px; }
  .section-copy { font-size: 13px; }
  .scroll-container { max-width: none; margin-inline: -20px; padding-inline: 20px; padding-right: 20px; scroll-padding-inline: 20px; }
  .scroll-list { justify-content: flex-start; gap: 14px; padding: 0 42px 0 0; }
  .scroll-item { flex-basis: min(74vw, 286px); }
  .scroll-item h3 { margin: 16px 14px 8px; font-size: 16px; }
  .scroll-item p { margin-inline: 14px; font-size: 13px; }
  .scroll-hint { font-size: 13px; }
  .faq-actions { grid-template-columns: 1fr; gap: 12px; margin-top: 28px; }
  .faq-action { min-height: 52px; font-size: 15px; }
  .faq-actions .faq-action:only-child { justify-self: center; width: min(320px, 100%); }
  .footer__band { border-top-width: 1px; }
  .footer-menu { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer-menu__link { min-height: 40px; gap: 10px; padding: 0 14px; font-size: 11px; }
  .footer-menu__link::after { border-top-width: 6px; border-bottom-width: 6px; border-left-width: 10px; }
  .footer-menu__link:nth-child(odd) { border-right: 1px solid rgba(57,33,113,.28); }
  .footer-menu__link:nth-child(even) { border-right: 0; }
  .footer-menu__link:last-child { grid-column: 1 / -1; border-top: 1px solid rgba(57,33,113,.28); }
  .footer__main { gap: 18px; padding: 48px 16px 26px; border-top-width: 0; }
  .footer__main::before { top: 28px; height: 2px; }
  .footer__logo { width: 88px; margin-top: -42px; }
  .footer__cta {
    width: min(344px, calc(100% - 32px));
    min-height: 58px;
    grid-template-columns: 1fr auto;
    column-gap: 14px;
    padding: 0 18px 0 24px;
    border-radius: 14px;
    font-size: 14px;
    text-align: left;
  }
  .footer__cta span { font-size: 24px; transform: translateY(-1px); }
  .footer__follow { width: min(122px, 40vw); }
  .footer-social { gap: 12px; }
  .footer-social__link { width: 24px; height: 24px; }
  .footer-social__link--line { width: 26px; height: 26px; font-size: 10px; }
  .footer__brand { gap: 10px; padding: 18px 16px 16px; }
  .footer__brand-logo { width: min(150px, 72vw); }
  .footer-subnav { flex-direction: column; gap: 3px; }
  .footer-subnav__link { font-size: 10px; }
  .modal { padding: 12px; }
  .modal__content { max-height: calc(100dvh - 24px); padding: 22px 16px 24px; }
  .modal__image { max-height: 38dvh; margin-bottom: 18px; }
  .modal__content h3 { font-size: 19px; }
  .modal__content p { font-size: 13px; line-height: 1.7; }
  .modal__close { top: 8px; right: 8px; width: 34px; height: 34px; font-size: 24px; }
  .modal__content--announcement { max-width: calc(100vw - 24px); padding: 12px 12px 16px; }
  .modal__image--announcement { max-height: 68dvh; }
  .announcement-modal__lead { margin-bottom: 12px; font-size: 22px; line-height: 1.4; }
}

@media (min-width: 768px) {
  .global-nav__brand { grid-template-rows: auto; align-items: center; }
  .global-nav__title-image { display: block; grid-column: 2; grid-row: 1 / 3; width: min(150px, 100%); height: auto; align-self: center; }
  .global-nav__title--path,
  .global-nav__subtitle--path { display: none !important; }
}

.reveal-on-scroll {
  opacity: 0 !important;
  transform: translate3d(0, 18px, 0) !important;
  filter: blur(0.5px) !important;
  transition: opacity .72s ease, transform .72s cubic-bezier(.22, 1, .36, 1), filter .72s ease !important;
  will-change: opacity, transform, filter;
}

.reveal-on-scroll.is-visible {
  opacity: 1 !important;
  transform: translate3d(0, 0, 0) !important;
  filter: blur(0) !important;
}

@media (prefers-reduced-motion: reduce) {
  .reveal-on-scroll {
    opacity: 0 !important;
    transform: translate3d(0, 18px, 0) !important;
    filter: blur(0.5px) !important;
    transition: opacity .72s ease, transform .72s cubic-bezier(.22, 1, .36, 1), filter .72s ease !important;
  }

  .reveal-on-scroll.is-visible {
    opacity: 1 !important;
    transform: translate3d(0, 0, 0) !important;
    filter: blur(0) !important;
  }
}