@charset "UTF-8";
@keyframes scroll-hint-appear {
  0% {
    transform: translateX(40px);
    opacity: 0;
  }
  10% {
    opacity: 1;
  }
  50%,
  100% {
    transform: translateX(-40px);
    opacity: 0;
  }
}
.scroll-hint-icon {
  position: absolute;
  top: calc(50% - 25px);
  left: calc(50% - 60px);
  box-sizing: border-box;
  width: 120px;
  height: auto;
  border-radius: 5px;
  transition: opacity 0.3s;
  opacity: 0;
  background: rgba(0, 0, 0, 0.7);
  text-align: center;
  padding: 20px 10px 10px 10px;
}

.scroll-hint-icon-wrap {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  max-height: 100%;
  pointer-events: none;
}

.scroll-hint-text {
  font-size: 10px;
  color: #fff;
  margin-top: 5px;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon {
  opacity: 0.8;
}

.scroll-hint-icon:before {
  display: inline-block;
  width: 40px;
  height: 40px;
  color: #fff;
  vertical-align: middle;
  text-align: center;
  content: "";
  background-size: contain;
  background-position: center center;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDM8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIiBmaWxsPSIjZmZmIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon:after {
  content: "";
  width: 34px;
  height: 14px;
  display: block;
  position: absolute;
  top: 10px;
  left: 50%;
  margin-left: -20px;
  background-repeat: no-repeat;
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDE8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIiBmaWxsPSIjZmZmIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIgZmlsbD0iI2ZmZiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIgZmlsbD0iI2ZmZiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiIGZpbGw9IiNmZmYiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiIGZpbGw9IiNmZmYiLz48L2c+PC9nPjwvc3ZnPg==);
  opacity: 0;
  transition-delay: 2.4s;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:after {
  opacity: 1;
}

.scroll-hint-icon-wrap.is-active .scroll-hint-icon:before {
  animation: scroll-hint-appear 1.2s linear;
  animation-iteration-count: 2;
}

.scroll-hint-icon-white {
  background-color: #fff;
  box-shadow: 0 4px 5px rgba(0, 0, 0, 0.4);
}

.scroll-hint-icon-white:before {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIyNS43NyIgaGVpZ2h0PSIzMC41MiIgdmlld0JveD0iMCAwIDI1Ljc3IDMwLjUyIj48dGl0bGU+44Ki44K744OD44OIIDQ8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxwYXRoIGQ9Ik0yMS4zMywzMC41Mkg3Ljg1QTEuNTUsMS41NSwwLDAsMSw2LjMsMjlhMTIuNDYsMTIuNDYsMCwwLDAtLjYzLTQuNDIsMjUuMTYsMjUuMTYsMCwwLDAtNC4yNS01bC0uMDYtLjA2QTUsNSwwLDAsMSwwLDE1Ljg2YTMuNjQsMy42NCwwLDAsMSwxLjE3LTIuNjIsMy42MywzLjYzLDAsMCwxLDUuMTQuMDdWMy43N2EzLjc3LDMuNzcsMCwxLDEsNy41NCwwVjguMzNhMy4zNSwzLjM1LDAsMCwxLDEuMjYsMCwzLDMsMCwwLDEsMiwxLjIyLDMuNSwzLjUsMCwwLDEsMi0uMDYsMy4yMSwzLjIxLDAsMCwxLDIsMS41NCwzLjc0LDMuNzQsMCwwLDEsMywuNDdBNC4yMSw0LjIxLDAsMCwxLDI1Ljc0LDE1YzAsLjExLDAsLjI3LDAsLjQ2YTE5LjI2LDE5LjI2LDAsMCwxLS44NCw3Yy0uMTQuMzgtLjM2LjgxLS41NiwxLjIybC0uMTEuMjJjMCwuMDctLjA5LjE0LS4xNC4yMWE3LjEzLDcuMTMsMCwwLDAtMS4xNywyLjE3Yy0uMDYuNTYtLjA2LDIuMTUtLjA1LDIuNzFBMS41NSwxLjU1LDAsMCwxLDIxLjMzLDMwLjUyWk04LjYxLDI4LjIxaDEyYzAtLjcxLDAtMS43MS4wNy0yLjIzYTguNzQsOC43NCwwLDAsMSwxLjU5LTMuMjVsLjA2LS4xMmExMCwxMCwwLDAsMCwuNDYtMSwxNi44LDE2LjgsMCwwLDAsLjctNi4xMmMwLS4yMywwLS40MSwwLS41NGgwYTIsMiwwLDAsMC0uNjQtMS41MiwxLjMzLDEuMzMsMCwwLDAtMS41NS4wOCwxLjEzLDEuMTMsMCwwLDEtMS4xOC4yOCwxLjE1LDEuMTUsMCwwLDEtLjc4LS45NCwxLjI2LDEuMjYsMCwwLDAtLjc1LTEuMTEsMSwxLDAsMCwwLTEuMTEuMjhsLS4xLjFhMS4xNSwxLjE1LDAsMCwxLTEuMTkuMjksMS4xNiwxLjE2LDAsMCwxLS43OC0uOTVjLS4wOS0uNjgtLjIxLS43Ny0uNy0uODdhLjgyLjgyLDAsMCwwLTEsLjQ4LDEuMTYsMS4xNiwwLDAsMS0yLjE2LS41OFYzLjc3YTEuNDYsMS40NiwwLDEsMC0yLjkyLDB2Ny44NWwwLDQuMzNhMS4xNywxLjE3LDAsMCwxLS44MywxLjExLDEuMTUsMS4xNSwwLDAsMS0xLjItLjM1bC0xLS45MWMtLjQ3LS40Mi0uNzMtLjY2LS44NC0uNzdhMS4zNSwxLjM1LDAsMCwwLTItLjEyTDIuNywxNWExLjMyLDEuMzIsMCwwLDAtLjM5LDFBMi41NywyLjU3LDAsMCwwLDMsMTcuODVsMCwwYTI3LjI0LDI3LjI0LDAsMCwxLDQuNyw1LjYyQTEyLjYzLDEyLjYzLDAsMCwxLDguNjEsMjguMjFaTTIzLjIsMjMuMzVaTTYuNTEsMTYuNTlaIi8+PC9nPjwvZz48L3N2Zz4=);
}

.scroll-hint-icon-white:after {
  background-image: url(data:image/svg+xml;base64,PHN2ZyB4bWxucz0iaHR0cDovL3d3dy53My5vcmcvMjAwMC9zdmciIHdpZHRoPSIzMy4yOSIgaGVpZ2h0PSIxMi4wMiIgdmlld0JveD0iMCAwIDMzLjI5IDEyLjAyIj48dGl0bGU+44Ki44K744OD44OIIDI8L3RpdGxlPjxnIGlkPSLjg6zjgqTjg6Tjg7xfMiIgZGF0YS1uYW1lPSLjg6zjgqTjg6Tjg7wgMiI+PGcgaWQ9IuODrOOCpOODpOODvF8xLTIiIGRhdGEtbmFtZT0i44Os44Kk44Ok44O8IDEiPjxsaW5lIHgxPSIxLjg1IiB5MT0iNi4wMSIgeDI9IjEwLjQiIHkyPSI2LjAxIi8+PHBhdGggZD0iTTEwLjQsNy4xN0gxLjg1YTEuMTYsMS4xNiwwLDEsMSwwLTIuMzFIMTAuNGExLjE2LDEuMTYsMCwxLDEsMCwyLjMxWiIvPjxwYXRoIGQ9Ik03LjQsMTJhMS4xNSwxLjE1LDAsMCwxLS43Mi0uMjVsLTYuMjUtNUExLjIsMS4yLDAsMCwxLDAsNS44NywxLjE0LDEuMTQsMCwwLDEsLjQ2LDVMNi43LjIzQTEuMTYsMS4xNiwwLDAsMSw4LjEsMi4wOEwzLDUuOTEsOC4xMiwxMEExLjE2LDEuMTYsMCwwLDEsNy40LDEyWiIvPjxsaW5lIHgxPSIzMS40NSIgeTE9IjYuMDEiIHgyPSIyMi44OSIgeTI9IjYuMDEiLz48cGF0aCBkPSJNMzEuNDUsNy4xN0gyMi44OWExLjE2LDEuMTYsMCwxLDEsMC0yLjMxaDguNTZhMS4xNiwxLjE2LDAsMCwxLDAsMi4zMVoiLz48cGF0aCBkPSJNMjUuOSwxMmExLjE4LDEuMTgsMCwwLDEtLjkxLS40M0ExLjE3LDEuMTcsMCwwLDEsMjUuMTcsMTBsNS4wOS00LjA1TDI1LjIsMi4wOEExLjE2LDEuMTYsMCwwLDEsMjYuNTkuMjNMMzIuODQsNWExLjE2LDEuMTYsMCwwLDEsLjQ1LjkxLDEuMTQsMS4xNCwwLDAsMS0uNDMuOTJsLTYuMjQsNUExLjE3LDEuMTcsMCwwLDEsMjUuOSwxMloiLz48L2c+PC9nPjwvc3ZnPg==);
}

.scroll-hint-icon-white .scroll-hint-text {
  color: #000;
}

.scroll-hint-shadow-wrap {
  position: relative;
}

.scroll-hint-shadow-wrap::after {
  content: "";
  width: 20px;
  height: 100%;
  background: linear-gradient(
    270deg,
    rgba(0, 0, 0, 0.15) 0,
    rgba(0, 0, 0, 0) 16px,
    rgba(0, 0, 0, 0)
  );
  position: absolute;
  top: 0;
  right: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
}

.scroll-hint-shadow-wrap::before {
  content: "";
  width: 20px;
  height: 100%;
  background: linear-gradient(
    90deg,
    rgba(0, 0, 0, 0.15) 0,
    rgba(0, 0, 0, 0) 16px,
    rgba(0, 0, 0, 0)
  );
  position: absolute;
  top: 0;
  left: 0;
  pointer-events: none;
  z-index: 1;
  opacity: 0;
  visibility: hidden;
}

.scroll-hint-shadow-wrap:has(.scroll-hint.is-right-scrollable)::after,
.scroll-hint-shadow-wrap.is-right-scrollable::after {
  opacity: 1;
  visibility: visible;
}

.scroll-hint-shadow-wrap:has(.scroll-hint.is-left-scrollable)::before,
.scroll-hint-shadow-wrap.is-left-scrollable::before {
  opacity: 1;
  visibility: visible;
}

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

:where([hidden]:not([hidden="until-found"])) {
  display: none !important;
}

:where(html) {
  -webkit-text-size-adjust: none;
  color-scheme: dark light;
  tab-size: 2;
  scrollbar-gutter: stable;
}

:where(html:has(dialog:modal[open])) {
  overflow: clip;
}

:where(body) {
  line-height: 1.5;
  font-family: system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
}

:where(button) {
  all: unset;
}

:where(input, button, textarea, select) {
  font: inherit;
  color: inherit;
}

:where(textarea) {
  resize: vertical;
  resize: block;
}

:where(button, label, select, summary, [role="button"], [role="option"]) {
  cursor: pointer;
}

:where(:disabled) {
  cursor: not-allowed;
}

:where(label:has(> input:disabled), label:has(+ input:disabled)) {
  cursor: not-allowed;
}

:where(a) {
  color: inherit;
  text-underline-offset: 0.2ex;
}

:where(ul, ol) {
  list-style: none;
}

:where(img, svg, video, canvas, audio, iframe, embed, object) {
  display: block;
}

:where(img, picture, svg, video) {
  max-inline-size: 100%;
  block-size: auto;
}

:where(p, h1, h2, h3, h4, h5, h6) {
  overflow-wrap: break-word;
}

:where(h1, h2, h3) {
  line-height: calc(1em + 0.5rem);
}

:where(hr) {
  border: none;
  border-block-start: 1px solid;
  color: inherit;
  block-size: 0;
  overflow: visible;
}

:where(dialog) {
  border: none;
  background: none;
  inset: unset;
  max-width: unset;
  max-height: unset;
}

:where(dialog:not([open])) {
  display: none !important;
}

:where(:focus) {
  outline: none;
}

:where(:focus-visible) {
  outline: none;
}

:where(:focus-visible):is(button, a, input, textarea, [tabindex="0"]) {
  outline: 2px solid CanvasText;
  box-shadow: 0 0 0 2px Canvas;
  outline-offset: 2px;
}

:where(:focus-visible, :target) {
  scroll-margin-block: 8vh;
}

:where(.visually-hidden:not(:focus-within, :active)) {
  clip-path: inset(50%) !important;
  height: 1px !important;
  width: 1px !important;
  overflow: hidden !important;
  position: absolute !important;
  white-space: nowrap !important;
  border: 0 !important;
}

:root {
  --white: #ffffff;
  --black: #000000;
  --brown: #301e06;
  --beige: #fef9e9;
  --gold: #d0c399;
  --gold-mid: #b3904f;
  --gold-dark: #866201;
  --yellow: #feb606;
  --font-size-base: 1rem;
  --line-height-base: 1.5;
  --font-family-base: "Noto Sans JP", sans-serif;
  --font-family-serif: "Noto Serif JP", serif;
  --container-width: 1190px;
}

html,
body {
  font-size: var(--font-size-base);
  line-height: var(--line-height-base);
  font-family: var(--font-family-base);
  color: var(--white);
  background-color: var(--black);
}

body.is-loading {
  overflow: hidden;
}

.pcbr {
  display: none;
}

.spbr {
  display: block;
}

.js-fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
}
.js-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.section {
  padding: 6.6666666667vw 4.1666666667vw 8.3333333333vw;
}
.section-title {
  height: 12.8125vw;
  width: fit-content;
  margin-inline: auto;
}
.section-title img {
  width: auto;
  height: 100%;
}

.inner {
  width: 100%;
  margin-top: 6.6666666667vw;
}

.attention-list {
  margin-top: 3.3333333333vw;
}
.attention-text {
  font-size: 0.875rem;
}
.attention-text::before {
  content: "※";
}

.button {
  --corner-x: calc(34 / 960 * 100vw);
  --corner-y: calc(46 / 960 * 100vw);
  --corner-weight: calc(4 / 960 * 100vw);
  --corner-color: var(--gold-dark);
  --corner-offset: calc(-16 / 960 * 100vw);
}
.button {
  background-image: url(../images/bg_button.png);
  background-size: cover;
  color: var(--black);
  display: flex;
  justify-content: center;
  gap: 1.25vw;
  width: 100%;
  max-width: 69.7916666667vw;
  padding: 4.1666666667vw 1.6666666667vw;
  border: none;
  font-size: 3.5416666667vw;
  font-weight: 700;
  letter-spacing: 0.08em;
  text-decoration: none;
  position: relative;
  margin-inline: auto;
}
.button::before {
  content: "";
  position: absolute;
  inset: var(--corner-offset);
  pointer-events: none;
  background:
    linear-gradient(var(--corner-color), var(--corner-color)) top
      left/var(--corner-x) var(--corner-weight) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) top
      left/var(--corner-weight) var(--corner-y) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) top
      right/var(--corner-x) var(--corner-weight) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) top
      right/var(--corner-weight) var(--corner-y) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) bottom
      left/var(--corner-x) var(--corner-weight) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) bottom
      left/var(--corner-weight) var(--corner-y) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) bottom
      right/var(--corner-x) var(--corner-weight) no-repeat,
    linear-gradient(var(--corner-color), var(--corner-color)) bottom
      right/var(--corner-weight) var(--corner-y) no-repeat;
}

.button-arrow {
  width: 5.2083333333vw;
  height: 5vw;
  transition: transform 0.3s ease;
}
.button-arrow.is-rotated {
  transform: rotate(180deg);
}

.is-loading #wrapper {
  opacity: 0;
  visibility: hidden;
  height: 0;
  overflow: hidden;
}

.is-loaded #wrapper {
  opacity: 1;
  visibility: visible;
  height: inherit;
  overflow: inherit;
  transition: all 0.1s;
}

.loading {
  position: fixed;
  inset: 0;
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  background-color: var(--black);
  transition:
    opacity 0.6s ease,
    visibility 0.6s ease;
}
.is-loaded .loading {
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
}
.loading__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.loading__dots {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 24px;
}
.loading__dots span {
  display: block;
  width: 12px;
  height: 12px;
  border-radius: 50%;
  background-color: #eddca6;
  animation: loadingDot 1.2s infinite ease-in-out;
}
.loading__dots span:nth-child(1) {
  animation-delay: -0.32s;
}
.loading__dots span:nth-child(2) {
  animation-delay: -0.16s;
}
.loading__dots span:nth-child(3) {
  animation-delay: 0s;
}
.loading__text {
  color: var(--white);
  font-family: var(--font-family-serif);
  font-size: 1.25rem;
  letter-spacing: 0.06em;
}

@keyframes loadingDot {
  0%,
  80%,
  100% {
    opacity: 0.5;
    transform: scale(0.5);
  }
  40% {
    opacity: 1;
    transform: scale(1);
  }
}
.header {
  position: sticky;
  top: 0;
  z-index: 100;
  height: min(13.5416666667vw, 88px);
}
.header__top {
  height: 100%;
  background-color: var(--black);
  padding-inline: 16px;
}
.header__top-inner {
  display: flex;
  justify-content: center;
  height: 100%;
  align-items: center;
  position: relative;
  z-index: 100;
}
.header__logo {
  height: 100%;
}
.header__logo a {
  display: block;
  height: inherit;
}
.header__logo img {
  height: inherit;
  width: auto;
  transition: 0.25s;
}
.header__nav-button {
  width: 6.6666666667vw;
  height: 4.5833333333vw;
  position: absolute;
  background:
    linear-gradient(var(--white), var(--white)) no-repeat center/100%
      0.4166666667vw,
    rgba(0, 0, 0, 0.7490196078);
  transition: all 0.25s;
  inset: 0 0 0 auto;
  margin-block: auto;
  z-index: 102;
  box-shadow: 0 0 10px 10px rgba(0, 0, 0, 0.7490196078);
  border-radius: 1.0416666667vw;
}
.header__nav-button::before,
.header__nav-button::after {
  content: "";
  position: absolute;
  width: 6.6666666667vw;
  height: 0.4166666667vw;
  background: var(--white);
  transition: all 0.3s ease;
  margin-inline: auto;
  display: block;
}
.header__nav-button::before {
  inset: 0 0 auto;
}
.header__nav-button::after {
  inset: auto 0 0;
}
.header__nav-button:has(+ .header__nav-box[aria-hidden="false"]) {
  background:
    linear-gradient(transparent, transparent), rgba(0, 0, 0, 0.7490196078);
}
.header__nav-button:has(+ .header__nav-box[aria-hidden="false"])::before {
  transform: rotate(30deg);
  top: calc(50% - 0.2083333333vw);
}
.header__nav-button:has(+ .header__nav-box[aria-hidden="false"])::after {
  transform: rotate(-30deg);
  bottom: calc(50% - 0.2083333333vw);
}
.header__nav__list {
  height: 100%;
}
.header__nav__anchor {
  text-decoration: none;
  font-family: var(--font-family-serif);
  font-size: clamp(14px, 0.9375vw, 18px);
  display: flex;
  align-items: center;
  justify-content: center;
  height: 100%;
  position: relative;
}
.header__nav img {
  width: auto;
  height: 2.0833333333vw;
}
.header__bottom {
  background-color: #3a3a3a;
  color: var(--white);
  overflow: clip;
  padding-inline: 16px;
}
.header__bottom-inner {
  padding-block: 2.5vw;
}
.header__title {
  font-size: 0.8125rem;
  line-height: 1;
  font-weight: 700;
  letter-spacing: 0.06em;
}

.deco__inner {
  border: min(0.4545454545vw, 4px) solid var(--gold-mid);
  box-shadow:
    0 0 40px 20px rgba(0, 0, 0, 0.2),
    0 0 0 min(1.0416666667vw, 10px) inset #f8ecd7,
    0 0 0 min(1.25vw, 12px) inset var(--gold-mid);
  color: var(--brown);
  position: relative;
}
.deco__inner::before,
.deco__inner::after {
  content: "";
  width: 86.6666666667vw;
  height: 10.8333333333vw;
  background: url(../images/common_deco_sp.svg) no-repeat top center/contain;
  position: absolute;
  left: 0;
  right: 0;
  margin-inline: auto;
}
.deco__inner::before {
  top: 2.5vw;
}
.deco__inner::after {
  bottom: 2.5vw;
  transform: rotate(180deg);
}

.morebox {
  overflow-y: hidden;
  transition: all 0.75s ease-in-out;
  margin-inline: -2.0833333333vw;
  padding-inline: 2.0833333333vw;
  padding-bottom: min(1.0416666667vw, 20px);
}
.morebox.is-open {
  max-height: 5000px !important;
}

.js-more-button {
  margin-top: 32px;
}

.octagon-slider {
  filter: drop-shadow(0px 0px 40px rgba(0, 0, 0, 0.2));
  clip-path: polygon(
    16px 0%,
    calc(100% - 16px) 0%,
    100% 16px,
    100% calc(100% - 16px),
    calc(100% - 16px) 100%,
    16px 100%,
    0% calc(100% - 16px),
    0% 16px
  );
  background: var(--gold-mid);
  height: auto;
  margin-inline: auto;
  position: relative;
}
.octagon-slider::before {
  content: "";
  display: block;
  position: absolute;
  clip-path: polygon(
    12px 0%,
    calc(100% - 12px) 0%,
    100% 12px,
    100% calc(100% - 12px),
    calc(100% - 12px) 100%,
    12px 100%,
    0% calc(100% - 12px),
    0% 12px
  );
  width: calc(100% - 16px);
  max-width: 800px;
  height: calc(100% - 16px);
  background: linear-gradient(to bottom, var(--white), #fff0cd);
  inset: 0;
  margin: auto;
}
.octagon-slider .swiper-slide {
  position: relative;
  z-index: 5;
  display: block;
}
.octagon-slider img {
  position: absolute;
  inset: 0;
  margin: auto;
  width: calc(100% - 16px);
  height: calc(100% - 16px);
  object-fit: contain;
}

.js-slider-mainbox {
  position: relative;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
}
.js-slider-thumbs {
  overflow: initial;
  width: 100%;
  padding-top: 2.0833333333vw;
}
.js-slider-thumbs .swiper-wrapper {
  justify-content: center;
}
.js-slider-thumbs .swiper-slide {
  position: relative;
  z-index: 2;
}
.js-slider-thumbs .swiper-slide.swiper-slide-thumb-active {
  filter: drop-shadow(0px 0px 8px #eb6a06);
  z-index: 1;
}
.js-slider-thumbs .swiper-slide.swiper-slide-thumb-active::after {
  content: "";
  position: absolute;
  display: block;
  inset: 0;
  margin: auto;
  background: #fff;
  -webkit-mask: url(../images/common_thumbs-mask.svg);
  mask: url(../images/common_thumbs-mask.svg);
  -webkit-mask-size: cover;
  mask-size: cover;
}
.js-slider-thumbs .swiper-slide.swiper-slide-thumb-active img {
  display: block;
  clip-path: polygon(
    8px 0%,
    calc(100% - 8px) 0%,
    100% 8px,
    100% calc(100% - 8px),
    calc(100% - 8px) 100%,
    8px 100%,
    0% calc(100% - 8px),
    0% 8px
  );
  position: relative;
}
.js-slider-prev,
.js-slider-next {
  margin: initial;
  transition: 0.3s;
}
.js-slider-prev .swiper-navigation-icon,
.js-slider-next .swiper-navigation-icon {
  display: none;
}
.js-slider-prev {
  background: url(../images/common_ui-prev.svg) no-repeat center center/contain;
  left: 0;
}
.js-slider-prev:hover {
  left: -4px;
}
.js-slider-next {
  background: url(../images/common_ui-next.svg) no-repeat center center/contain;
  right: 0;
}
.js-slider-next:hover {
  right: -4px;
}

.mv {
  color: var(--black);
  overflow: hidden;
}
.mv__inner {
  position: relative;
  height: 100%;
}
.mv__features {
  display: flex;
  height: min(11.6666666667vw, 88px);
  padding-top: min(2.5vw, 24px);
  gap: min(2.5vw, 24px);
  width: fit-content;
}
.mv__feature {
  height: 100%;
}
.mv__feature img {
  width: auto;
  height: 100%;
}
.mv__logo {
  margin-inline: auto;
  text-align: center;
  z-index: 10;
}
.mv__label {
  color: inherit;
  font-size: 3.3333333333vw;
  font-family: var(--font-family-serif);
  letter-spacing: 0.2em;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: min(1.6666666667vw, 16px);
  white-space: nowrap;
  text-align: center;
  margin-bottom: min(3.3333333333vw, 32px);
}
.mv__label::before,
.mv__label::after {
  content: "";
  display: block;
  width: 7.3958333333vw;
  height: 1px;
  background-color: currentColor;
}
.mv__visual {
  width: 100%;
  max-width: 1920px;
  margin-inline: auto;
  inset: auto 0;
  position: absolute;
}
.mv__character {
  position: absolute;
}
.mv__roxy {
  z-index: 3;
}
.mv__rudeus {
  z-index: 5;
}
.mv__paul {
  z-index: 4;
}
.mv__elinalise {
  z-index: 2;
}
.mv__beginner {
  z-index: 10;
  position: absolute;
}
.mv__movie-box {
  position: absolute;
  z-index: 10;
  display: flex;
  justify-content: center;
  inset: auto 0;
  margin-inline: auto;
  gap: min(3.3333333333vw, 48px);
}
.mv-fade-in {
  opacity: 0;
  transform: translateY(20px);
  transition:
    opacity 0.8s ease,
    transform 0.8s ease;
}
.mv-fade-in.is-visible {
  opacity: 1;
  transform: translateY(0);
}

.banner-area {
  background: linear-gradient(to top, #000, #2a1f00);
}
.banner-area__inner {
  padding: min(4.1666666667vw, 40px);
}
.banner-area__contents {
  display: flex;
  gap: min(4.1666666667vw, 20px);
}

.concept {
  background: url(../images/concept_bg_sp.jpg) no-repeat center center/cover;
}
.concept__inner {
  display: flex;
  align-items: center;
}
.concept__image {
  width: 52.9166666667vw;
}
.concept__contents {
  display: flex;
  flex-direction: column;
  font-size: clamp(10px, 3.75vw, 36px);
}
.concept__lead {
  font-family: var(--font-family-serif);
  font-weight: bold;
  font-size: clamp(12px, 3.9583333333vw, 40px);
}
.concept__text {
  line-height: 2;
}

.point {
  background: url(../images/point_bg_sp.jpg) no-repeat center center/cover;
}
.point__inner {
  background: var(--beige);
  display: flex;
  align-items: center;
}
.point__contents {
  display: flex;
  flex-direction: column;
  letter-spacing: 0.025em;
}
.point__list {
  position: relative;
}
.point__list:not(:last-of-type)::after {
  content: "";
  width: 100%;
  height: 1px;
  background: var(--gold-mid);
  display: block;
  position: absolute;
  bottom: 0;
}
.point__detail {
  display: flex;
  align-items: center;
  position: relative;
}
.point__image {
  width: min(73.8541666667vw, 709px);
}
.point__description {
  display: flex;
  flex-direction: column;
  gap: 2.5vw;
}
.point__lead img {
  width: initial;
  height: 100%;
}
.point__text {
  line-height: 2;
}
.gameflow {
  background: url(../images/gameflow_bg_sp.jpg) no-repeat center center/cover;
}

.story {
  background: url(../images/story_bg_sp.jpg) no-repeat top center/cover;
  color: var(--brown);
  font-family: var(--font-family-serif);
  line-height: 2;
  letter-spacing: 0.025em;
  overflow: hidden;
}
.story__inner {
  position: relative;
}
.story__character--sylphy {
  z-index: 1;
}
.story__character--roxy {
  z-index: 3;
  left: 0;
}
.story__character--eris {
  z-index: 2;
}
.story__character--rudeus {
  z-index: 6;
}
.story__contentsbg {
  position: relative;
  width: 91.875vw;
}
.story__contentsbg img {
  width: 100%;
}
.story__contents {
  position: absolute;
  z-index: 5;
  margin-inline: auto;
}
.story__copy {
  font-weight: bold;
}
.story__text + .story__text {
  margin-top: 0.75em;
}
.story__copy + .story__text {
  margin-top: 1em;
}
.story__text + .story__copy {
  margin-top: 0.35em;
}

.character {
  background: url(../images/character_bg_sp.jpg) no-repeat top center/cover;
  color: var(--brown);
  font-family: var(--font-family-serif);
  line-height: 2;
  letter-spacing: 0.025em;
}
.character__image img {
  clip-path: polygon(
    12px 0%,
    calc(100% - 12px) 0%,
    100% 12px,
    100% calc(100% - 12px),
    calc(100% - 12px) 100%,
    12px 100%,
    0% calc(100% - 12px),
    0% 12px
  );
  object-fit: initial;
}
.character__banner-box {
  margin-top: min(14.1666666667vw, 104px);
}
.character__banner {
  aspect-ratio: 580/305;
  max-width: 580px;
  margin-inline: auto;
}
.character__banner a {
  display: block;
  width: 100%;
  height: 100%;
  background: #aaa;
}

.gallery {
  background: url(../images/gallery_bg_sp.jpg) no-repeat top center/cover;
  color: var(--black);
}
.gallery .js-slider-mainbox::before,
.gallery .js-slider-mainbox::after {
  content: "";
  position: absolute;
  z-index: 10;
  left: 0;
  right: 0;
  margin-inline: auto;
}
.gallery .js-slider-mainbox::before {
  top: 16px;
}
.gallery .js-slider-mainbox::after {
  transform: rotate(180deg);
  bottom: 16px;
}

.gin-repo {
  background: url(../images/character_bg_sp.jpg) no-repeat top center/cover;
  color: var(--black);
}
.gin-repo__step-cont {
  position: relative;
  border: 4px solid var(--gold-mid);
  background: var(--beige);
  box-shadow: 0 0 min(2.0833333333vw, 40px) min(1.0416666667vw, 20px)
    rgba(0, 0, 0, 0.2);
}
.gin-repo__step-cont:not(:last-of-type)::after {
  content: "";
  display: block;
  position: absolute;
  inset: 0 max(-2.2916666667vw, -44px) 0 auto;
  margin-block: auto;
  width: min(1.6666666667vw, 32px);
  height: min(3.5416666667vw, 68px);
  background: var(--gold-mid);
  clip-path: polygon(0 0, 0 100%, 100% 50%);
}
.gin-repo__step-cont__image {
  position: relative;
  height: 100%;
  width: 100%;
}
.gin-repo__step-cont__image::before,
.gin-repo__step-cont__image::after {
  content: "";
  width: 86.6666666667vw;
  height: 10.8333333333vw;
  background: url(../images/common_deco-mini_sp.svg) no-repeat top
    center/contain;
  position: absolute;
  inset: 0;
  margin-inline: auto;
}
.gin-repo__step-cont__image::before {
  top: 2.5vw;
}
.gin-repo__step-cont__image::after {
  bottom: 2.5vw;
  transform: rotate(180deg);
}
.gin-repo__step-cont__image img {
  aspect-ratio: 30/23;
  background: aliceblue;
}
.gin-repo__sample {
  background: var(--beige);
}
.gin-repo__sample__list {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
.gin-repo__sample__button {
  width: 100%;
  height: 100%;
}

.music {
  background: url(../images/music_bg_sp.jpg) no-repeat top center/cover;
}
.music__inner {
  position: relative;
}

.spec {
  background: url(../images/spec_bg_sp.jpg) no-repeat top center/cover;
}
.spec__inner {
  position: relative;
}

.footer {
  background: linear-gradient(to bottom, #262000, var(--black));
  padding-inline: 1.6666666667vw;
}
.footer__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding-block: 7.2916666667vw;
}
.footer__spec {
  background-color: var(--gold-dark);
  color: var(--white);
  padding: 2.5vw 5vw;
  text-align: center;
  font-size: 4.1666666667vw;
  font-weight: 700;
  letter-spacing: 0.06em;
  line-height: 1;
}
.footer__credits {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-wrap: wrap;
  margin-top: 5.4166666667vw;
  gap: 3.8541666667vw;
}
.footer__copyright {
  text-align: center;
}
.footer__copyright-img {
  width: 75.4166666667vw;
}
.footer__logos {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 2.6041666667vw 1.6666666667vw;
  flex-wrap: wrap;
  max-width: 42.7083333333vw;
}
.footer__newgin-group-logo {
  width: 23.75vw;
}
.footer__fields-logo {
  width: 16.7708333333vw;
  margin-top: -1.875vw;
}
.footer__sumapachi-logo {
  width: 12.1875vw;
}
.footer__lt-30-plus {
  width: 18.5416666667vw;
}
.footer__warning {
  color: var(--white);
  font-size: 2.7083333333vw;
  text-align: center;
  line-height: 2;
  letter-spacing: 0.03em;
  margin-top: 7.0833333333vw;
}

.modal {
  display: none;
}
.modal[aria-hidden="true"] .modal-overlay {
  animation: mmfadeOut 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.modal[aria-hidden="false"] .modal-overlay {
  animation: mmfadeIn 0.3s cubic-bezier(0, 0, 0.2, 1);
}
.modal.is-open {
  display: block;
}
.modal-overlay {
  align-items: center;
  background: rgba(0, 0, 0, 0.8);
  bottom: 0;
  display: flex;
  justify-content: center;
  left: 0;
  position: fixed;
  right: 0;
  top: 0;
  z-index: 999;
}
.modal-dialog {
  max-width: 1280px;
  padding: 40px;
  margin-inline: auto;
}
.modal-contents {
  max-width: 1200px;
  width: 100vw;
  aspect-ratio: 16/9;
  position: relative;
}
.modal-contents iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: none;
}
.modal-close {
  position: absolute;
  width: 62px;
  height: 62px;
  top: 10px;
  right: 10px;
}
.modal-close::before,
.modal-close::after {
  content: "";
  display: block;
  position: absolute;
  width: 32px;
  height: 2px;
  background: var(--gold-mid);
  left: 14px;
  top: 50%;
  transform: rotate(45deg);
}
.modal-close::after {
  transform: rotate(-45deg);
}

@keyframes mmfadeOut {
  from {
    opacity: 1;
  }
  to {
    opacity: 0;
  }
}
@keyframes mmfadeIn {
  from {
    opacity: 0;
  }
  to {
    opacity: 1;
  }
}
@media (min-width: 768px) {
  .pcbr {
    display: block;
  }
  .spbr {
    display: none;
  }
  .js-fade-in[data-delay="1"] {
    transition-delay: 0s;
  }
  .js-fade-in[data-delay="2"] {
    transition-delay: 0.2s;
  }
  .js-fade-in[data-delay="3"] {
    transition-delay: 0.4s;
  }
  .js-fade-in[data-delay="4"] {
    transition-delay: 0.6s;
  }
  .js-fade-in[data-delay="5"] {
    transition-delay: 0.8s;
  }
  .js-fade-in[data-delay="6"] {
    transition-delay: 1s;
  }
  .js-fade-in[data-delay="7"] {
    transition-delay: 1.2s;
  }
  .js-fade-in[data-delay="8"] {
    transition-delay: 1.4s;
  }
  .js-fade-in[data-delay="9"] {
    transition-delay: 1.6s;
  }
  .js-fade-in[data-delay="10"] {
    transition-delay: 1.8s;
  }
  .js-fade-in[data-delay="11"] {
    transition-delay: 2s;
  }
  .js-fade-in[data-delay="12"] {
    transition-delay: 2.2s;
  }
  .js-fade-in[data-delay="13"] {
    transition-delay: 2.4s;
  }
  .js-fade-in[data-delay="14"] {
    transition-delay: 2.6s;
  }
  .js-fade-in[data-delay="15"] {
    transition-delay: 2.8s;
  }
  .js-fade-in[data-delay="16"] {
    transition-delay: 3s;
  }
  .js-fade-in[data-delay="17"] {
    transition-delay: 3.2s;
  }
  .js-fade-in[data-delay="18"] {
    transition-delay: 3.4s;
  }
  .js-fade-in[data-delay="19"] {
    transition-delay: 3.6s;
  }
  .js-fade-in[data-delay="20"] {
    transition-delay: 3.8s;
  }
  .section {
    padding: 72px 0;
  }
  .section-title {
    height: 80px;
  }
  .inner {
    max-width: 1190px;
    width: calc(100% - 4.1666666667vw);
    margin: 40px auto 0;
  }
  .attention-list {
    display: flex;
    flex-wrap: wrap;
    gap: 1em;
    margin-top: 16px;
  }
  .button {
    --corner-x: 19px;
    --corner-y: 25px;
    --corner-weight: 2px;
    --corner-offset: -7px;
  }
  .button {
    gap: 12px;
    max-width: 360px;
    padding: 24px 16px;
    font-size: 1.25rem;
  }
  .button-arrow {
    width: 28px;
    height: 27px;
  }
  .header__top {
    padding-inline: 24px;
  }
  .header__top-inner {
    justify-content: space-between;
    max-width: 1190px;
    margin-inline: auto;
  }
  .header__logo {
    margin-left: min(2.0833333333vw, 40px);
    padding-block: min(0.625vw, 12px);
    height: initial;
  }
  .header__logo:hover img {
    opacity: 0.7;
  }
  .header__logo img {
    width: min(13.3333333333vw, 164px);
  }
  .header__nav-button {
    display: none;
  }
  .header__nav-box {
    height: 100%;
  }
  .header__nav {
    height: 100%;
  }
  .header__nav__list {
    display: flex;
    gap: min(2.0833333333vw, 40px);
    height: inherit;
  }
  .header__nav__anchor {
    flex-direction: column;
  }
  .header__nav__anchor::before {
    content: "";
    transition: all 0.25s;
    width: 100%;
    height: 0;
    inset: 0 0 auto;
    display: block;
    margin-inline: auto;
    position: absolute;
  }
  .header__nav__anchor:hover::before {
    height: min(0.2604166667vw, 5px);
    background: var(--gold);
  }
  .header__nav img {
    height: min(2.0833333333vw, 8px);
  }
  .header__bottom {
    padding-inline: 24px;
  }
  .header__bottom-inner {
    padding-block: 16px;
    max-width: 1185px;
    margin-inline: auto;
  }
  .header__title {
    margin-left: 44px;
    padding-left: 20px;
    font-size: 1.5rem;
    position: relative;
  }
  .header__title::before {
    position: absolute;
    content: "";
    right: 100%;
    height: 20px;
    width: 100vw;
    margin-block: auto;
    top: 0;
    bottom: 0;
    background: url("../images/line_01.png") repeat-x right center;
  }
  .deco__inner {
    box-shadow:
      0 0 40px 20px rgba(0, 0, 0, 0.2),
      0 0 0 min(0.5186721992vw, 10px) inset #f8ecd7,
      0 0 0 min(0.622406639vw, 12px) inset var(--gold-mid);
  }
  .deco__inner::before,
  .deco__inner::after {
    width: calc(100% - 1.867219917vw);
    max-width: 1152px;
    background: url(../images/common_deco_pc.svg) no-repeat top center/contain;
  }
  .deco__inner::before {
    top: min(1.0373443983vw, 20px);
  }
  .deco__inner::after {
    bottom: min(1.0373443983vw, 20px);
  }
  .morebox {
    max-height: calc(200px + 4.1666666667vw);
  }
  .octagon-slider {
    aspect-ratio: 816/567;
    width: 81.6%;
    max-width: 816px;
  }
  .js-slider-thumbs .swiper-wrapper {
    gap: min(1.0416666667vw, 20px);
  }
  .js-slider-thumbs .swiper-slide,
  .js-slider-thumbs .swiper-slide img {
    width: 100px !important;
    height: 100px !important;
  }
  .js-slider-thumbs .swiper-slide.swiper-slide-thumb-active::after {
    width: 100px;
    height: 100px;
  }
  .js-slider-thumbs .swiper-slide.swiper-slide-thumb-active img {
    width: 100px;
    height: 100px;
  }
  .js-slider-ui {
    display: contents;
  }
  .js-slider-prev,
  .js-slider-next {
    width: 64px;
    height: 90px;
  }
  .mv {
    background: url(../images/mv_bg_pc.jpg) no-repeat top center/cover;
    height: min(60.7291666667vw, 1166px);
  }
  .mv__features {
    margin-left: min(1.6666666667vw, 32px);
  }
  .mv__logo {
    position: absolute;
    inset: min(2.8125vw, 54px) 0 auto 0;
    width: min(28.90625vw, 555px);
  }
  .mv__label {
    font-size: 1.25rem;
  }
  .mv__label::before,
  .mv__label::after {
    width: 48px;
    height: 2px;
  }
  .mv__roxy {
    top: 0;
    left: max(-2.0833333333vw, -40px);
    width: min(52.0833333333vw, 1000px);
  }
  .mv__rudeus {
    top: min(12.9166666667vw, 248px);
    left: min(7.5vw, 144px);
    width: min(55.3125vw, 1062px);
  }
  .mv__paul {
    top: min(10vw, 192px);
    right: min(2.9166666667vw, 56px);
    width: min(57.9166666667vw, 1112px);
  }
  .mv__elinalise {
    top: max(-1.0416666667vw, -20px);
    right: max(-4.1666666667vw, -80px);
    width: min(40.1041666667vw, 770px);
  }
  .mv__beginner {
    width: min(8.3333333333vw, 160px);
    top: min(0.4166666667vw, 8px);
    right: clamp(0px, 50vw - 595px, 365px);
  }
  .mv__movie-box {
    bottom: min(2.5vw, 48px);
  }
  .mv__movie {
    width: min(20.46875vw, 393px);
  }
  .banner-area__inner {
    padding-inline: 0;
    margin-block: 0;
  }
  .banner-area__contents {
    overflow: hidden !important;
  }
  .concept {
    background: url(../images/concept_bg_pc.jpg) no-repeat center center/cover;
  }
  .concept__inner {
    padding: min(7.3949579832vw, 88px) min(4.7058823529vw, 56px)
      min(7.3949579832vw, 88px) min(7.3949579832vw, 88px);
    background: url(../images/concept_contentsbg_pc.jpg) no-repeat center
      center/cover;
    gap: min(3.734439834vw, 72px);
  }
  .concept__image {
    width: min(50%, 394px);
    flex-shrink: 0;
  }
  .concept__contents {
    gap: min(2.0746887967vw, 40px);
    font-size: 1rem;
  }
  .concept__lead {
    font-size: min(2.1848739496vw, 26px);
  }
  .point {
    background: url(../images/point_bg_pc.jpg) no-repeat center center/cover;
  }
  .point__inner {
    padding: min(4.0336134454vw, 48px) min(4.7058823529vw, 56px)
      min(2.6890756303vw, 32px) min(4.7058823529vw, 56px);
    gap: min(2.489626556vw, 48px);
    box-shadow:
      0 0 40px 20px rgba(0, 0, 0, 0.2),
      0 0 0 min(0.5186721992vw, 10px) inset var(--beige),
      0 0 0 min(0.622406639vw, 12px) inset var(--gold-mid);
  }
  .point__contents {
    gap: min(0.8298755187vw, 16px);
    font-size: 1rem;
    margin-bottom: min(0.8298755187vw, 16px);
  }
  .point__list:not(:last-of-type) {
    padding-bottom: min(0.8298755187vw, 16px);
  }
  .point__list:not(:last-of-type)::after {
    height: 2px;
  }
  .point__detail {
    gap: min(1.244813278vw, 24px);
  }
  .point__list:nth-of-type(even) .point__detail {
    flex-direction: row-reverse;
    justify-content: space-between;
    gap: initial;
  }
  .point__image {
    width: min(50%, 418px);
    flex-shrink: 0;
  }
  .point__description {
    gap: min(1.244813278vw, 24px);
    max-width: 578px;
  }
  .point__lead {
    margin-left: -0.5em;
    height: clamp(54px, 7.03125vw, 85px);
  }
  .point__lead__1line {
    height: clamp(25px, 3.125vw, 40px);
  }
  .gameflow {
    background: url(../images/gameflow_bg_pc.jpg) no-repeat center center/cover;
  }
  .gameflow__inner {
    margin-top: 24px;
  }
  .character {
    text-align: center;
    background: url(../images/character_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: 56px;
  }
  .character__contents {
    aspect-ratio: 816/656;
  }
  .gallery {
    background: url(../images/gallery_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: 56px;
  }
  .gallery .js-slider-mainbox::before,
  .gallery .js-slider-mainbox::after {
    width: min(77.6%, 776px);
    max-width: 816px;
    height: min(14.4620811287%, 82px);
    background: url(../images/gallery_deco_pc.svg) no-repeat center top/contain;
  }
  .gin-repo {
    text-align: center;
    background: url(../images/character_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: 56px;
  }
  .gin-repo__step {
    display: flex;
    justify-content: space-between;
  }
  .gin-repo__step-cont {
    width: min(30.4166666667vw, 368px);
  }
  .gin-repo__step-cont__title {
    width: 160px;
    position: absolute;
    inset: -24px 0 auto 0;
    margin: auto;
  }
  .gin-repo__step-cont__image {
    padding: 48px min(1.25vw, 24px) min(2.5vw, 48px) min(1.25vw, 24px);
  }
  .gin-repo__step-cont__image::before,
  .gin-repo__step-cont__image::after {
    width: calc(100% - 1.867219917vw);
    max-width: 1152px;
    background: url(../images/common_deco-mini_pc.svg) no-repeat top
      center/contain;
  }
  .gin-repo__step-cont__image::before {
    top: min(1.0373443983vw, 20px);
  }
  .gin-repo__step-cont__image::after {
    bottom: min(1.0373443983vw, 20px);
  }
  .gin-repo__step-cont__text {
    margin-top: 24px;
    text-align: left;
  }
  .gin-repo__sample {
    margin-top: min(6.6666666667vw, 128px);
    padding-bottom: min(3.3333333333vw, 64px);
  }
  .gin-repo__sample__head {
    margin-bottom: min(1.25vw, 24px);
  }
  .gin-repo__sample__title {
    margin-bottom: min(2.0833333333vw, 40px);
  }
  .gin-repo__sample__list {
    gap: min(1.25vw, 24px);
  }
  .gin-repo__sample__list.morebox {
    max-height: 300px;
  }
  .gin-repo__sample__image {
    width: 168px;
    background: pink;
    aspect-ratio: 168/224;
  }
  .music {
    background: url(../images/music_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: 56px;
  }
  .music__inner {
    width: fit-content;
    margin-top: min(0.8333333333vw, 16px);
  }
  .spec {
    text-align: center;
    background: url(../images/spec_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: 56px;
  }
  .spec__inner {
    width: fit-content;
    margin-top: min(0.8333333333vw, 16px);
  }
  .footer {
    padding-inline: 24px;
  }
  .footer__inner {
    padding-block: 24px;
  }
  .footer__spec {
    padding: 16px 28px;
    font-size: 1.5rem;
  }
  .footer__credits {
    margin-top: 16px;
    gap: 10px;
  }
  .footer__copyright-img {
    width: 379px;
  }
  .footer__logos {
    gap: 14px;
    flex-wrap: nowrap;
    max-width: unset;
  }
  .footer__newgin-group-logo {
    width: 152px;
  }
  .footer__fields-logo {
    width: 107px;
    margin-top: -12px;
  }
  .footer__sumapachi-logo {
    width: 53px;
  }
  .footer__lt-30-plus {
    width: 81px;
  }
  .footer__warning {
    margin-top: 16px;
    font-size: 0.875rem;
  }
  .footer__warning br {
    display: none;
  }
}
@media (min-width: 1200px) {
  .story {
    text-align: center;
    background: url(../images/story_bg_pc.jpg) no-repeat top center/cover;
    padding-bottom: clamp(16px, 5vw, 96px);
  }
  .story__inner {
    width: min(100%, 1432px);
    max-width: 1432px;
  }
  .story__character {
    position: absolute;
  }
  .story__character-box {
    display: contents;
  }
  .story__character--sylphy {
    left: min(2.0833333333vw, 40px);
    top: max(-1.25vw, -24px);
    width: min(22.5vw, 298px);
  }
  .story__character--roxy {
    bottom: clamp(0px, 5.5555555556vw - 106.6666666667px, 40px);
    left: clamp(-40px, 5.5555555556vw - 106.6666666667px, 0px);
    width: min(30.8333333333vw, 400px);
  }
  .story__character--eris {
    right: clamp(0px, 7.7777777778vw - 149.3333333333px, 56px);
    top: max(-2.0833333333vw, -40px);
    width: min(18.3333333333vw, 248px);
  }
  .story__character--rudeus {
    right: clamp(-32px, 4.4444444444vw - 85.3333333333px, 0px);
    bottom: max(-3.75vw, -72px);
    width: min(24.1666666667vw, 325px);
  }
  .story__contentsbg {
    left: 20px;
    margin-inline: auto;
    width: 69.3333333333vw;
    max-width: 832px;
    z-index: 4;
  }
  .story__contents {
    left: 40px;
    right: 0;
    top: 64px;
    width: fit-content;
  }
  .story__copy {
    font-size: 1.875rem;
  }
  .story__text {
    font-size: 1.125rem;
  }
  .story .pcbr {
    display: block;
  }
  .story .spbr {
    display: none;
  }
}
@media (max-width: 1199.98px) {
  .story {
    padding-bottom: 74.7916666667vw;
  }
  .story__inner {
    margin-top: 0;
    display: flex;
    flex-direction: column-reverse;
  }
  .story__character {
    position: absolute;
  }
  .story__character-box {
    display: flex;
    position: relative;
    z-index: 2;
  }
  .story__character--sylphy {
    width: 31.0416666667vw;
    order: 2;
    top: -8.9583333333vw;
    left: 16.0416666667vw;
  }
  .story__character--roxy {
    width: 41.6666666667vw;
    order: 1;
    top: 13.3333333333vw;
  }
  .story__character--eris {
    width: 25.8333333333vw;
    order: 3;
    right: 18.75vw;
    top: -10vw;
  }
  .story__character--rudeus {
    width: 33.8541666667vw;
    order: 4;
    right: 0.8333333333vw;
    top: 5vw;
  }
  .story__contents {
    width: 78.125vw;
    top: 18.75vw;
    left: 0;
    left: clamp(
      -3.3333333333vw,
      -0.625vw + (100vw - 767.5px) * -9999,
      1.0416666667vw
    );
    right: 0;
    text-align: center;
  }
  .story__copy {
    font-size: clamp(12px, 4.375vw, 42px);
  }
  .story__text {
    font-size: clamp(10px, 2.9166666667vw, 30px);
  }
  .story .pcbr {
    display: none;
  }
  .story .spbr {
    display: block;
  }
}
@media (max-width: 767.98px) {
  .header__top-inner {
    padding-block: 1.6666666667vw;
  }
  .header__nav-box {
    width: 100vw;
    background: var(--black);
    position: fixed;
    inset: 0 0;
    height: 100lvh;
    display: none;
    z-index: 99;
  }
  .header__nav {
    height: 100%;
  }
  .header__nav__list {
    padding: 15vw 4.1666666667vw 4.1666666667vw;
    overflow-y: scroll;
  }
  .header__nav__text {
    border-bottom: 1px solid var(--beige);
  }
  .header__nav__text:first-of-type {
    border-top: 1px solid var(--beige);
  }
  .header__nav__anchor {
    flex-direction: row-reverse;
    justify-content: space-between;
    padding: 4.1666666667vw;
  }
  .header__nav span {
    font-size: max(5vw, 16px);
  }
  .morebox {
    max-height: 58.125vw;
  }
  .octagon-slider {
    aspect-ratio: 882/613;
  }
  .js-slider-thumbs .swiper-wrapper {
    gap: 2.7083333333vw;
  }
  .js-slider-thumbs .swiper-slide,
  .js-slider-thumbs .swiper-slide img {
    width: 16.0416666667vw !important;
    height: 16.0416666667vw !important;
  }
  .js-slider-thumbs .swiper-slide.swiper-slide-thumb-active::after {
    width: 16.1458333333vw;
    height: 16.1458333333vw;
  }
  .js-slider-ui {
    display: flex;
    width: 46.0416666667vw;
    position: relative;
    justify-content: space-between;
    margin: 2.5vw auto 6.6666666667vw;
  }
  .js-slider-prev,
  .js-slider-next {
    position: static;
    width: 9.6875vw;
    height: 13.75vw;
  }
  .mv {
    background: url(../images/mv_bg_sp.jpg) no-repeat top center/cover;
    height: 254.1666666667vw;
  }
  .mv__features {
    margin-inline: auto;
    margin-bottom: 4.1666666667vw;
  }
  .mv__logo {
    width: 76.25vw;
    position: relative;
  }
  .mv__visual {
    bottom: 102.0833333333vw;
  }
  .mv__roxy {
    bottom: 31.25vw;
    left: -23.75vw;
    width: 89.0625vw;
  }
  .mv__rudeus {
    bottom: 0;
    left: -20.8333333333vw;
    width: 102.0833333333vw;
  }
  .mv__paul {
    bottom: 0;
    right: -38.5416666667vw;
    width: 115.4166666667vw;
  }
  .mv__elinalise {
    bottom: 46.6666666667vw;
    right: -11.0416666667vw;
    width: 68.3333333333vw;
  }
  .mv__beginner {
    width: 23.75vw;
    bottom: 118.75vw;
    left: 4.1666666667vw;
  }
  .mv__movie-box {
    flex-direction: column;
    bottom: 7.5vw;
    justify-content: center;
    align-items: center;
  }
  .mv__movie {
    width: 78.125vw;
  }
  .banner-area {
    overflow-x: auto;
  }
  .banner-area__list {
    width: 83.3333333333vw;
    flex-shrink: 0;
  }
  .concept__inner {
    padding: 6.6666666667vw 5vw min(12.5vw, 120px) 5vw;
    background: url(../images/concept_contentsbg_sp.jpg) no-repeat center
      center/cover;
    flex-direction: column;
    gap: 5.8333333333vw;
  }
  .concept__contents {
    gap: 6.6666666667vw;
  }
  .concept__text {
    padding-right: 0.5em;
  }
  .point__inner {
    flex-direction: column;
    padding: 6.6666666667vw 5vw 8.3333333333vw 5vw;
    gap: 5.8333333333vw;
    box-shadow:
      0 0 40px 20px rgba(0, 0, 0, 0.2),
      0 0 0 min(1.0416666667vw, 10px) inset var(--beige),
      0 0 0 min(1.25vw, 12px) inset var(--gold-mid);
  }
  .point__contents {
    gap: 5.8333333333vw;
    font-size: clamp(10px, 3.3333333333vw, 32px);
  }
  .point__list:not(:last-of-type) {
    padding-bottom: 5vw;
  }
  .point__detail {
    justify-content: center;
    flex-direction: column;
    gap: 2.5vw;
  }
  .point__lead {
    height: 12.9166666667vw;
  }
  .point__lead__1line {
    height: 6.25vw;
  }
  .character__contents {
    aspect-ratio: 880/708;
  }
  .music__inner {
    margin-top: 0.8333333333vw;
  }
  .spec__inner {
    margin-top: 0.8333333333vw;
  }
  .modal-dialog {
    padding: 0;
  }
}
