@charset "UTF-8";
#contents {
  line-height: 1;
  -webkit-font-feature-settings: "palt";
          font-feature-settings: "palt";
}

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

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

#contents *::before, #contents *::after {
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

#contents ol, #contents ul {
  list-style: none;
  list-style-type: none;
}

#contents img {
  max-width: 100%;
  height: auto;
  display: block;
}

#contents svg {
  width: 100%;
  height: auto;
  display: block;
}

:root {
  --baseColor: #000;
  --mainColor: #b5010d;
  --subColor: #0e1968;
  --accentColor: #655507;
  --textColor: #fff;
  --container: 1340px;
}

html {
  scroll-behavior: auto;
}

#contents {
  font-size: 15px;
  font-weight: normal;
  font-family: "黎ミン M", "Reimin Medium", "Noto serif JP", "游明朝体", YuMincho, "游明朝", "Yu Gothic", sans-serif;
  line-height: 1.5;
  letter-spacing: 0.1em;
  color: var(--textColor);
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

@media screen and (max-width: 1360px) {
  #contents {
    font-size: 1.34vw;
  }
}

@media screen and (max-width: 800px) {
  #contents {
    font-size: max(2.8vw,12px);
  }
}

#contents a {
  color: inherit;
  text-decoration: none;
}

#contents input, #contents textarea, #contents select, #contents button {
  font-family: "黎ミン M", "Reimin Medium", "Noto serif JP", "游明朝体", YuMincho, "游明朝", "Yu Gothic", sans-serif;
  font-size: inherit;
  -webkit-box-sizing: border-box;
          box-sizing: border-box;
}

#contents button {
  -webkit-appearance: none;
     -moz-appearance: none;
          appearance: none;
  color: inherit;
  background: initial;
  border: initial;
  padding: 0;
  margin: 0;
  cursor: pointer;
}

#contents {
  /* Link Button */
  /* Block Link */
  /* Image Link */
}

#contents .c-btn a {
  font-size: 24px;
  font-weight: bold;
  text-align: center;
  letter-spacing: 0;
  width: 100%;
  max-width: 15.4em;
  min-height: 3em;
  color: #fff;
  background: var(--mainColor);
  border: 2px solid var(--mainColor);
  padding: 0.25em 1em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-transition: 0.2s;
  transition: 0.2s;
  position: relative;
}

#contents .c-btn a.fit {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  max-width: none;
}

#contents .c-btn a.left {
  margin-left: 0;
  margin-right: auto;
}

#contents .c-btn a.right {
  margin-left: auto;
  margin-right: 0;
}

#contents .c-btn a.center {
  margin-left: auto;
  margin-right: auto;
}

#contents .c-btn a.reverse {
  background: #fff;
  color: var(--mainColor);
}

#contents .c-btn a.reverse:hover {
  background: var(--mainColor);
  color: #fff;
}

#contents .c-btn a.skeleton {
  color: #fff;
  border: 1px solid #fff;
  background: transparent;
}

#contents .c-btn a.banner {
  min-height: 4.6em;
  padding-top: 1.5em;
  margin-top: 2em;
}

#contents .c-btn a.banner img {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 3em;
  margin: auto;
  width: 64%;
}

#contents .c-btn a:hover {
  background: #fff;
  color: var(--mainColor);
}

@media screen and (max-width: 1360px) {
  #contents .c-btn a {
    font-size: 1.8vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .c-btn a {
    font-size: 3vw;
  }
}

#contents .c-blocklink a {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  z-index: 1;
}

#contents .c-imglink.left {
  text-align: left;
}

#contents .c-imglink.center {
  text-align: center;
}

#contents .c-imglink.right {
  text-align: right;
}

#contents .c-imglink img {
  display: inline;
}

#contents :root {
  --c-flex-gap: 20px;
}

#contents .c-flex {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

#contents .c-flex.gap {
  gap: var(--c-flex-gap);
}

#contents .c-flex.gapLarge {
  gap: calc(var(--c-flex-gap) * 2);
}

#contents .c-flex--2 > * {
  width: calc(100% / 2);
}

#contents .c-flex--2.gap > * {
  width: calc(calc(100% - calc(var(--c-flex-gap) * calc(2 - 1))) / 2);
}

#contents .c-flex--3 > * {
  width: calc(100% / 3);
}

#contents .c-flex--3.gap > * {
  width: calc(calc(100% - calc(var(--c-flex-gap) * calc(3 - 1))) / 3);
}

#contents .c-flex--4 > * {
  width: calc(100% / 4);
}

#contents .c-flex--4.gap > * {
  width: calc(calc(100% - calc(var(--c-flex-gap) * calc(4 - 1))) / 4);
}

#contents .c-flex--5 > * {
  width: calc(100% / 5);
}

#contents .c-flex--5.gap > * {
  width: calc(calc(100% - calc(var(--c-flex-gap) * calc(5 - 1))) / 5);
}

#contents .c-flex--6 > * {
  width: calc(100% / 6);
}

#contents .c-flex--6.gap > * {
  width: calc(calc(100% - calc(var(--c-flex-gap) * calc(6 - 1))) / 6);
}

#contents .c-flex.--end {
  -webkit-box-pack: end;
      -ms-flex-pack: end;
          justify-content: flex-end;
}

#contents .c-flex.--center {
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
}

#contents .c-flex.--between {
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#contents .c-flex.--alignEnd {
  -webkit-box-align: end;
      -ms-flex-align: end;
          align-items: flex-end;
}

#contents .c-flex.--alignCenter {
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#contents .c-flex.--wrap {
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}

#contents .c-flex.--reverse {
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
      -ms-flex-direction: row-reverse;
          flex-direction: row-reverse;
}

#contents .c-flex.--column {
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
}

#contents .u-tal {
  text-align: left !important;
}

#contents .u-tac {
  text-align: center !important;
}

#contents .u-tar {
  text-align: right !important;
}

#contents .font-10 {
  font-size: 10px !important;
}

#contents .font-12 {
  font-size: 12px !important;
}

#contents .font-14 {
  font-size: 14px !important;
}

#contents .font-16 {
  font-size: 16px !important;
}

#contents .font-18 {
  font-size: 18px !important;
}

#contents .font-20 {
  font-size: 20px !important;
}

#contents .font-22 {
  font-size: 22px !important;
}

#contents .font-24 {
  font-size: 24px !important;
}

#contents .font-26 {
  font-size: 26px !important;
}

#contents .font-28 {
  font-size: 28px !important;
}

#contents .font-30 {
  font-size: 30px !important;
}

@media screen and (min-width: 801px) and (max-width: 1360px) {
  #contents .font-10 {
    font-size: 0.83333vw !important;
  }
  #contents .font-12 {
    font-size: 1vw !important;
  }
  #contents .font-14 {
    font-size: 1.16667vw !important;
  }
  #contents .font-16 {
    font-size: 1.33333vw !important;
  }
  #contents .font-18 {
    font-size: 1.5vw !important;
  }
  #contents .font-20 {
    font-size: 1.66667vw !important;
  }
  #contents .font-22 {
    font-size: 1.83333vw !important;
  }
  #contents .font-24 {
    font-size: 2vw !important;
  }
  #contents .font-26 {
    font-size: 2.16667vw !important;
  }
  #contents .font-28 {
    font-size: 2.33333vw !important;
  }
  #contents .font-30 {
    font-size: 2.5vw !important;
  }
}

@media screen and (max-width: 800px) {
  #contents .font-10 {
    font-size: 2.375vw !important;
  }
  #contents .font-12 {
    font-size: 2.7vw !important;
  }
  #contents .font-14 {
    font-size: 2.975vw !important;
  }
  #contents .font-16 {
    font-size: 3.2vw !important;
  }
  #contents .font-18 {
    font-size: 3.375vw !important;
  }
  #contents .font-20 {
    font-size: 3.5vw !important;
  }
  #contents .font-22 {
    font-size: 3.575vw !important;
  }
  #contents .font-24 {
    font-size: 3.6vw !important;
  }
  #contents .font-26 {
    font-size: 3.575vw !important;
  }
  #contents .font-28 {
    font-size: 3.5vw !important;
  }
  #contents .font-30 {
    font-size: 3.375vw !important;
  }
}

#contents .u-bg {
  background: #fffc01;
  padding: 0 0.2em;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}

#contents .u-marker {
  background: -webkit-gradient(linear, left top, left bottom, color-stop(50%, transparent), color-stop(50%, #F4DF42));
  background: linear-gradient(transparent 50%, #F4DF42 50%);
  padding-bottom: 0.3em;
}

#contents .u-bold {
  font-weight: bold;
}

#contents .u-mainColor {
  color: var(--mainColor);
}

#contents .u-subcolor {
  color: var(--subColor);
}

#contents .u-emp {
  color: #BD0010;
}

#contents .u-link {
  color: var(--mainColor);
  text-decoration: underline;
}

#contents .u-link:hover {
  text-decoration: none;
}

#contents .mt-5 {
  margin-top: 0.5em !important;
}

#contents .mt-10 {
  margin-top: 1em !important;
}

#contents .mt-15 {
  margin-top: 1.5em !important;
}

#contents .mt-20 {
  margin-top: 2em !important;
}

#contents .mt-25 {
  margin-top: 2.5em !important;
}

#contents .mt-30 {
  margin-top: 3em !important;
}

#contents .mt-35 {
  margin-top: 3.5em !important;
}

#contents .mt-40 {
  margin-top: 4em !important;
}

#contents .mt-45 {
  margin-top: 4.5em !important;
}

#contents .mt-50 {
  margin-top: 5em !important;
}

#contents .mt-55 {
  margin-top: 5.5em !important;
}

#contents .mt-60 {
  margin-top: 6em !important;
}

:root {
  --bgScrollW: 250vw;
}

@media screen and (max-width: 800px) {
  :root {
    --bgScrollW: 250vw;
  }
}

#contents {
  /* modal */
  /* Animation */
}

#contents .js-loading {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  z-index: 9999;
  background: #000;
}

#contents .js-loading .logo {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 250px;
  max-width: 20%;
  aspect-ratio: 1 / 1;
  -webkit-mask-image: linear-gradient(-45deg, transparent 49%, #000 50%);
          mask-image: linear-gradient(-45deg, transparent 49%, #000 50%);
  -webkit-mask-size: 300% 100%;
          mask-size: 300% 100%;
  -webkit-mask-position: 100% 0;
          mask-position: 100% 0;
  -webkit-animation: loadingLogo 1s linear 0.5s 1 normal forwards running;
          animation: loadingLogo 1s linear 0.5s 1 normal forwards running;
}

@-webkit-keyframes loadingLogo {
  0% {
    opacity: 0.5;
    -webkit-mask-position: 100% 0;
            mask-position: 100% 0;
  }
  25% {
    opacity: 0.5;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
  }
  100% {
    opacity: 1;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
  }
}

@keyframes loadingLogo {
  0% {
    opacity: 0.5;
    -webkit-mask-position: 100% 0;
            mask-position: 100% 0;
  }
  25% {
    opacity: 0.5;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
  }
  100% {
    opacity: 1;
    -webkit-mask-position: 0 0;
            mask-position: 0 0;
  }
}

#contents .js-loading.is-loaded {
  -webkit-transition: 0.5s ease 0.5s;
  transition: 0.5s ease 0.5s;
  opacity: 0;
  pointer-events: none;
}

@media screen and (max-width: 800px) {
  #contents .js-loading .logo {
    max-width: 32%;
  }
}

#contents .parallaxWrapper {
  position: relative;
}

#contents .parallax {
  position: absolute;
  width: 100%;
  height: 100%;
  -webkit-clip-path: inset(0);
          clip-path: inset(0);
  z-index: -1;
  pointer-events: none;
}

#contents .parallax .bg {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: url(../img/body_bg.jpg) no-repeat center/cover;
}

#contents .parallax .bg:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100vh;
  background: #000;
  opacity: 0.3;
  -webkit-transition: 0.5s;
  transition: 0.5s;
}

.is-scrolled #contents .parallax .bg:after {
  opacity: 0.7;
}

#contents .parallax.--body .scrollWrapper {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100vw;
  aspect-ratio: 16 / 9;
  -webkit-perspective: 60vw;
          perspective: 60vw;
  -webkit-perspective-origin: center 40%;
          perspective-origin: center 40%;
  -webkit-transform-style: preserve-3d;
          transform-style: preserve-3d;
  -webkit-transform: rotate(15deg);
          transform: rotate(15deg);
}

#contents .parallax.--body .scrollWrapper.--bgScroll .scroll {
  width: var(--bgScrollW);
  aspect-ratio: 1 / 0.108173;
  -webkit-animation: bgScroll 9s linear 0s infinite normal forwards running;
          animation: bgScroll 9s linear 0s infinite normal forwards running;
}

#contents .parallax.--body .scrollWrapper.--bgScroll .scroll.--top {
  background: url(../img/line01.jpg) repeat-x 0 top/contain;
}

#contents .parallax.--body .scrollWrapper.--bgScroll .scroll.--right {
  background: url(../img/line02.jpg) repeat-x 0 top/contain;
  animation-direction: reverse;
}

#contents .parallax.--body .scrollWrapper.--bgScroll .scroll.--left {
  background: url(../img/line03.jpg) repeat-x 0 top/contain;
}

#contents .parallax.--body .scrollWrapper.--bgScroll .scroll.--bottom {
  background: url(../img/line04.jpg) repeat-x 0 top/contain;
}

@-webkit-keyframes bgScroll {
  0% {
    background-position: var(--bgScrollW) top;
  }
  100% {
    background-position: 0 top;
  }
}

@keyframes bgScroll {
  0% {
    background-position: var(--bgScrollW) top;
  }
  100% {
    background-position: 0 top;
  }
}

#contents .parallax.--body .scroll {
  position: absolute;
  top: -200%;
  left: -200%;
  right: -200%;
  bottom: -200%;
  margin: auto;
  -webkit-mask-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(5%, #000), color-stop(95%, #000), to(transparent));
  -webkit-mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
          mask-image: -webkit-gradient(linear, left top, right top, from(transparent), color-stop(5%, #000), color-stop(95%, #000), to(transparent));
          mask-image: linear-gradient(90deg, transparent, #000 5%, #000 95%, transparent);
}

#contents .parallax.--body .scroll.--top {
  -webkit-transform: rotateY(-90deg) rotateX(-90deg) translateZ(-20vw);
          transform: rotateY(-90deg) rotateX(-90deg) translateZ(-20vw);
}

#contents .parallax.--body .scroll.--right {
  -webkit-transform: rotateY(-80deg) translateZ(-40vw);
          transform: rotateY(-80deg) translateZ(-40vw);
}

#contents .parallax.--body .scroll.--left {
  -webkit-transform: rotateY(80deg) translateZ(-40vw);
          transform: rotateY(80deg) translateZ(-40vw);
}

#contents .parallax.--body .scroll.--bottom {
  -webkit-transform: rotateY(-90deg) rotateX(90deg) translateZ(-20vw);
          transform: rotateY(-90deg) rotateX(90deg) translateZ(-20vw);
}

#contents .parallax.--body .scroll .swiper-wrapper {
  -webkit-transition-timing-function: linear !important;
          transition-timing-function: linear !important;
  scroll-behavior: auto !important;
}

#contents .parallax.--body .scroll .swiper-slide {
  width: 60vw;
  padding: 0 2vw;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  -webkit-box-align: center;
      -ms-flex-align: center;
          align-items: center;
}

#contents .parallax.--body .scroll .swiper-slide img {
  width: 100%;
  max-width: none;
}

@media screen and (max-width: 800px) {
  #contents .parallax.--body .scrollWrapper {
    -webkit-perspective: 120vw;
            perspective: 120vw;
  }
  #contents .parallax.--body .scrollWrapper.--bgScroll .scroll {
    -webkit-animation-duration: 9s;
            animation-duration: 9s;
  }
}

#contents h2.heading {
  font-size: 80px;
  text-align: center;
  letter-spacing: 0;
  background: -webkit-gradient(linear, left top, left bottom, from(#7a7412), to(#c2bc62));
  background: linear-gradient(#7a7412, #c2bc62);
  -webkit-filter: drop-shadow(0 0.05em 0 #000);
          filter: drop-shadow(0 0.05em 0 #000);
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

#contents h2.heading.js-scroll {
  -webkit-transition: 0.8s ease 0.3s;
  transition: 0.8s ease 0.3s;
  opacity: 0;
  letter-spacing: -0.2em;
}

#contents h2.heading.is-scroll {
  opacity: 1;
  letter-spacing: 0;
}

@media screen and (max-width: 1360px) {
  #contents h2.heading {
    font-size: 6vw;
  }
}

@media screen and (max-width: 800px) {
  #contents h2.heading {
    font-size: 10vw;
  }
}

#contents h3.heading {
  font-size: 50px;
  text-align: center;
  line-height: 1.2;
  letter-spacing: 0.09em;
  color: #fff;
  background: #000;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  min-width: 18.5em;
  padding: 0 0.3em;
  margin: 0 auto;
  -webkit-transform: skewX(-30deg);
          transform: skewX(-30deg);
}

#contents h3.heading > * {
  display: block;
  -webkit-transform: skewX(30deg);
          transform: skewX(30deg);
}

#contents h3.heading.--red {
  background: var(--mainColor);
}

@media screen and (max-width: 1360px) {
  #contents h3.heading {
    font-size: 3.8vw;
  }
}

@media screen and (max-width: 800px) {
  #contents h3.heading {
    font-size: 4.2vw;
  }
}

#contents .c-iframeWrapper {
  width: 100%;
  aspect-ratio: 16 / 9;
  overflow: hidden;
  position: relative;
}

#contents .c-iframeWrapper > iframe {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
}

#contents .c-sectionBg {
  position: absolute;
  top: -4vw;
  left: 0;
  width: 100%;
  height: 75%;
  background: #2a292e;
  -webkit-transform-origin: left top;
          transform-origin: left top;
  -webkit-transform: skewY(15deg);
          transform: skewY(15deg);
  z-index: -1;
}

#contents .c-sectionBg.--red {
  background: var(--mainColor);
}

#contents .c-sectionBg.--blue {
  background: var(--subColor);
}

#contents .c-sectionBg.--gold {
  background: var(--accentColor);
}

@media screen and (max-width: 800px) {
  #contents .c-sectionBg {
    top: 2vw;
    height: 85%;
  }
}

#contents .p-kv {
  width: 100%;
  aspect-ratio: 1 / 0.5067;
  position: relative;
}

#contents .p-kv .logo {
  position: absolute;
  top: 21%;
  left: 0;
  right: 0;
  margin: auto;
  width: 27.265625%;
  aspect-ratio: 1 / 1;
}

#contents .p-kv .logo:before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.6);
  border-radius: 50%;
  -webkit-filter: blur(10px);
          filter: blur(10px);
  z-index: -1;
}

#contents .p-kv .ad {
  position: absolute;
  top: 109%;
  left: -100%;
  right: -100%;
  margin: auto;
  width: 9.65em;
  font-size: 4.67vw;
  font-style: italic;
  color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-pack: justify;
      -ms-flex-pack: justify;
          justify-content: space-between;
}

#contents .p-kv .ad:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0.1em;
  right: 0;
  bottom: 0;
  margin: auto;
  background: #fff;
  width: calc(100% - 5.4em);
  height: 2px;
}

#contents .p-kv.js-scroll .logo {
  -webkit-transition: 1.5s cubic-bezier(0.33, 0.2, 0.33, 1) 0.3s;
  transition: 1.5s cubic-bezier(0.33, 0.2, 0.33, 1) 0.3s;
  opacity: 0;
  -webkit-transform: scale(0.7);
          transform: scale(0.7);
}

#contents .p-kv.js-scroll .ad {
  -webkit-transition: 1.5s ease 1s;
  transition: 1.5s ease 1s;
  width: 7em;
  opacity: 0;
}

#contents .p-kv.is-scroll .logo {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contents .p-kv.is-scroll .ad {
  width: 9.65em;
  opacity: 1;
}

@media screen and (max-width: 800px) {
  #contents .p-kv {
    aspect-ratio: initial;
    height: 100dvh;
  }
  #contents .p-kv .logo {
    top: 30%;
    width: 80%;
    max-width: 40vh;
  }
  #contents .p-kv .ad {
    font-size: 8vw;
  }
}

#contents .p-introduction {
  padding: 10px 0 80px;
}

#contents .p-introduction .block1 {
  font-size: 24px;
  text-align: center;
  line-height: 2.08;
  letter-spacing: 0.1em;
  text-shadow: 0 0 0.2em #000,0 0 0.2em #000;
}

#contents .p-introduction .block1.js-scroll {
  -webkit-transition: 3s linear 0.3s;
  transition: 3s linear 0.3s;
  -webkit-mask-image: -webkit-gradient(linear, left top, left bottom, color-stop(48%, #000), color-stop(52%, transparent));
  -webkit-mask-image: linear-gradient(#000 48%, transparent 52%);
          mask-image: -webkit-gradient(linear, left top, left bottom, color-stop(48%, #000), color-stop(52%, transparent));
          mask-image: linear-gradient(#000 48%, transparent 52%);
  -webkit-mask-size: 100% 250%;
          mask-size: 100% 250%;
  -webkit-mask-position: 0% 100%;
          mask-position: 0% 100%;
}

#contents .p-introduction .block1.is-scroll {
  -webkit-mask-position: 0% 0%;
          mask-position: 0% 0%;
}

@media screen and (max-width: 1360px) {
  #contents .p-introduction {
    padding: 1% 0 6%;
  }
  #contents .p-introduction .block1 {
    font-size: 2vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-introduction {
    padding: 2% 0 12%;
  }
  #contents .p-introduction .block1 {
    font-size: 3vw;
  }
}

#contents .p-news {
  padding: 53px 0 80px;
  position: relative;
}

#contents .p-news .c-sectionBg {
  top: -6.5vw;
  height: 145%;
}

#contents .p-news_list {
  font-family: "Noto sans JP", "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", sans-serif;
  max-width: 1120px;
  margin: 30px auto 0;
}

#contents .p-news_list .img {
  width: 100%;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
}

#contents .p-news_list .img > img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 0.2s cubic-bezier(0, 0.5, 0.5, 1);
  transition: 0.2s cubic-bezier(0, 0.5, 0.5, 1);
}

#contents .p-news_list .content {
  padding: 1em 0.25em 0 1.4em;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
      -ms-flex-direction: column;
          flex-direction: column;
  height: 13em;
}

#contents .p-news_list .cat {
  font-size: 86.7%;
  text-align: center;
  color: #000;
  background: #fff;
  border: 0.17em solid #ccc;
  border-radius: 3em;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  padding: 0em 1em;
}

#contents .p-news_list .title {
  margin-top: 1.25em;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 4;
  overflow: hidden;
}

#contents .p-news_list .date {
  font-size: 87.5%;
  letter-spacing: 0;
  margin-top: auto;
}

#contents .p-news_list a[target="_blank"] {
  position: relative;
}

#contents .p-news_list a[target="_blank"]:after {
  content: '';
  position: absolute;
  right: 0;
  bottom: 0;
  width: 1.125em;
  aspect-ratio: 9 / 8;
  background: url(../img/icon_blank.svg) no-repeat center/contain;
  -webkit-filter: contrast(0) brightness(2);
          filter: contrast(0) brightness(2);
}

#contents .p-news_list a:hover .img img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

#contents .p-news_list a:hover .title {
  text-decoration: underline;
}

@media screen and (max-width: 1360px) {
  #contents .p-news {
    padding: 4% 0 6%;
  }
  #contents .p-news_list {
    margin-top: 2.3vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-news {
    padding: 8% 0 12%;
  }
  #contents .p-news .c-sectionBg {
    top: -2vw;
  }
}

#contents .p-banner_slider .swiper {
  position: relative;
}

#contents .p-banner_slider .swiper-slide {
  width: 100%;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

#contents .p-banner_slider .swiper-slide img {
  width: 100%;
  max-width: none;
}

#contents .p-banner_slider .swiper-slide:not(.swiper-slide-active) {
  -webkit-filter: brightness(0.5);
          filter: brightness(0.5);
}

#contents .p-banner_slider .swiper-arrow {
  position: absolute;
  top: 0;
  bottom: 0;
  margin: auto;
  font-size: 34px;
  color: #fff;
  width: 1em;
  height: 1em;
  z-index: 2;
  -webkit-transition: 0.2s;
  transition: 0.2s;
}

#contents .p-banner_slider .swiper-arrow.--prev {
  left: 15%;
  border-bottom: 0.25em solid currentColor;
  border-left: 0.25em solid currentColor;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

#contents .p-banner_slider .swiper-arrow.--next {
  right: 15%;
  border-top: 0.25em solid currentColor;
  border-right: 0.25em solid currentColor;
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

#contents .p-banner_slider .swiper-arrow:hover {
  color: var(--mainColor);
}

#contents .p-banner .c-btn {
  margin-top: 100px;
}

@media screen and (max-width: 1360px) {
  #contents .p-banner_slider .swiper-arrow {
    font-size: 2.5vw;
  }
  #contents .p-banner .c-btn {
    margin-top: 7.5vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-banner_slider .swiper-arrow {
    font-size: 4.25vw;
  }
  #contents .p-banner_slider .swiper-arrow.--prev {
    left: 4%;
  }
  #contents .p-banner_slider .swiper-arrow.--next {
    right: 4%;
  }
  #contents .p-banner .c-btn {
    margin-top: 12.5vw;
  }
}

#contents .p-topics {
  padding: 110px 0 70px;
  position: relative;
}

#contents .p-topics .c-sectionBg {
  height: 71%;
}

#contents .p-topics_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 45px 20px;
  margin-top: 80px;
}

#contents .p-topics_list > li {
  width: calc(calc(100% - 80px) / 5);
}

#contents .p-topics_list a {
  -webkit-transition: 0.15s;
  transition: 0.15s;
}

#contents .p-topics_list a:hover {
  -webkit-filter: drop-shadow(0 0 0.3em rgba(255, 255, 255, 0.3));
          filter: drop-shadow(0 0 0.3em rgba(255, 255, 255, 0.3));
}

#contents .p-topics_list .name {
  font-size: 20px;
  text-align: center;
  margin-top: 0.5em;
}

#contents .p-topics .block1 {
  font-size: 40px;
  text-align: center;
  line-height: 1.3;
  max-width: 960px;
  margin: 120px auto 0;
  padding: 0.35em 1em 0.6em;
  background: url(../img/topics_bnrBg.png) no-repeat right -10% bottom -10px/44.0625%, -webkit-gradient(linear, left top, right top, from(#7a7412), color-stop(68%, #000));
  background: url(../img/topics_bnrBg.png) no-repeat right -10% bottom -10px/44.0625%, linear-gradient(90deg, #7a7412, #000 68%);
  border: 0.15em solid #000;
  -o-border-image: linear-gradient(135deg, #5551a1, #1c9fab, #f5ae41, #b863a3) 2;
     border-image: linear-gradient(135deg, #5551a1, #1c9fab, #f5ae41, #b863a3) 2;
}

#contents .p-topics .block1 .date {
  font-family: "din-2014", sans-serif;
  font-size: 150%;
  margin-top: 0.3em;
}

#contents .p-topics .block1 .comingsoon {
  font-family: "din-2014", sans-serif;
  font-size: 175%;
  margin-top: 0.15em;
  color: #756511;
}

@media screen and (max-width: 1360px) {
  #contents .p-topics {
    padding: 8% 0 5%;
  }
  #contents .p-topics_list {
    gap: 3.4vw 1.5vw;
    margin-top: 6vw;
  }
  #contents .p-topics_list > li {
    width: calc(calc(100% - 6vw) / 5);
  }
  #contents .p-topics_list .name {
    font-size: 1.5vw;
  }
  #contents .p-topics .block1 {
    font-size: 4.17vw;
    margin-top: 9vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-topics {
    padding: 16% 0 10%;
  }
  #contents .p-topics .c-sectionBg {
    height: 85%;
  }
  #contents .p-topics_list > li {
    width: calc(calc(100% - 3vw) / 3);
  }
  #contents .p-topics_list .name {
    font-size: 2.8vw;
  }
}

#contents .p-blog {
  padding: 70px 0;
  position: relative;
}

#contents .p-blog .c-sectionBg {
  height: 73%;
}

#contents .p-blog_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 30px;
  margin-top: 70px;
}

#contents .p-blog_list > li {
  width: 280px;
  aspect-ratio: 1 / 1;
  overflow: hidden;
  position: relative;
}

#contents .p-blog_list > li.comingsoon {
  background: #000;
}

#contents .p-blog_list > li.comingsoon:after {
  content: 'COMING SOON…';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  font-family: "din-2014", sans-serif;
  font-weight: 600;
  font-size: 30px;
  letter-spacing: 0;
  text-align: center;
  color: var(--accentColor);
}

#contents .p-blog_list > li img {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 100%;
  -o-object-fit: cover;
     object-fit: cover;
  -webkit-transition: 0.2s cubic-bezier(0, 0.5, 0.5, 1);
  transition: 0.2s cubic-bezier(0, 0.5, 0.5, 1);
}

#contents .p-blog_list > li a:hover img {
  -webkit-transform: scale(1.05);
          transform: scale(1.05);
}

#contents .p-blog .c-btn {
  margin-top: 120px;
}

@media screen and (max-width: 1360px) {
  #contents .p-blog {
    padding: 5% 0;
  }
  #contents .p-blog_list {
    gap: 2.2vw;
    margin-top: 5.2vw;
  }
  #contents .p-blog_list > li {
    width: 21vw;
  }
  #contents .p-blog_list > li.comingsoon:after {
    font-size: 2.2vw;
  }
  #contents .p-blog .c-btn {
    margin-top: 9vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-blog {
    padding: 10% 0;
  }
  #contents .p-blog .c-sectionBg {
    height: 80%;
  }
  #contents .p-blog_list > li {
    width: calc(calc(100% - 4.4vw) / 3);
  }
  #contents .p-blog_list > li.comingsoon:after {
    font-size: 3.5vw;
  }
}

#contents .p-movie {
  padding: 80px 0 110px;
  position: relative;
}

#contents .p-movie .c-sectionBg {
  height: 77%;
}

#contents .p-movie_list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
  -webkit-box-pack: center;
      -ms-flex-pack: center;
          justify-content: center;
  gap: 60px;
  margin-top: 60px;
}

#contents .p-movie_list > li {
  width: calc(calc(100% - 60px) / 2);
}

@media screen and (max-width: 1360px) {
  #contents .p-movie {
    padding: 6% 0 8%;
  }
  #contents .p-movie_list {
    gap: 4.5vw;
    margin-top: 4.5vw;
  }
  #contents .p-movie_list > li {
    width: calc(calc(100% - 4.5vw) / 2);
  }
}

@media screen and (max-width: 800px) {
  #contents .p-movie {
    padding: 12% 0 16%;
  }
  #contents .p-movie .c-sectionBg {
    height: 85%;
  }
  #contents .p-movie_list > li {
    width: 100%;
  }
}

#contents .p-event {
  padding: 120px 0 70px;
  position: relative;
}

#contents .p-event .c-sectionBg {
  top: -2vw;
  height: 74%;
}

#contents .p-event h3.heading {
  font-size: 40px;
  letter-spacing: 0;
  line-height: 1.5;
}

#contents .p-event .block1 {
  margin-top: 70px;
}

#contents .p-event .block1 .img {
  margin: 0 auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
}

#contents .p-event .block1 .detail {
  font-size: 24px;
  line-height: 1.7;
  width: -webkit-max-content;
  width: -moz-max-content;
  width: max-content;
  margin: 2.25em auto 0;
}

#contents .p-event .c-btn {
  margin-top: 100px;
}

@media screen and (max-width: 1360px) {
  #contents .p-event {
    padding: 9% 0 5%;
  }
  #contents .p-event h3.heading {
    font-size: 3vw;
  }
  #contents .p-event .block1 {
    margin-top: 5.2vw;
  }
  #contents .p-event .block1 .detail {
    font-size: 1.8vw;
  }
  #contents .p-event .c-btn {
    margin-top: 7.5vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-event {
    padding: 18% 0 10%;
  }
  #contents .p-event .c-sectionBg {
    top: 6vw;
    height: 80%;
  }
  #contents .p-event h3.heading {
    font-size: 3.5vw;
    padding: 0 0.8em;
  }
  #contents .p-event .block1 .detail {
    width: auto;
    font-size: 3.34vw;
  }
  #contents .p-event .c-btn {
    margin-top: 10vw;
  }
}

#contents .p-links {
  padding: 70px 0 70px;
  position: relative;
}

#contents .p-links .c-sectionBg {
  height: 120%;
}

#contents .p-links_list {
  margin-top: 90px;
}

#contents .p-links_list > li {
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  margin: 0 auto;
}

#contents .p-links_list > li + li {
  margin-top: 5em;
}

#contents .p-links_list a {
  -webkit-transition: 0.15s;
  transition: 0.15s;
}

#contents .p-links_list a:hover {
  -webkit-filter: brightness(1.1) drop-shadow(0 0 1em #fff);
          filter: brightness(1.1) drop-shadow(0 0 1em #fff);
}

@media screen and (max-width: 1360px) {
  #contents .p-links {
    padding: 5% 0 5%;
  }
  #contents .p-links_list {
    margin-top: 6.8vw;
  }
  #contents .p-links_list > li + li {
    margin-top: 5.6vw;
  }
}

@media screen and (max-width: 800px) {
  #contents .p-links {
    padding: 10% 0 10%;
  }
}

#contents .c-modal {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: -webkit-fit-content;
  height: -moz-fit-content;
  height: fit-content;
  opacity: 0;
  pointer-events: none;
  z-index: 502;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contents .c-modalTrigger {
  cursor: pointer;
}

#contents .c-modal.is-open {
  opacity: 1;
  pointer-events: auto;
}

#contents .c-modal_close {
  position: absolute;
  top: -3em;
  right: 0;
  width: 2.5em;
  height: 2.5em;
  cursor: pointer;
  z-index: 503;
}

#contents .c-modal_close:before, #contents .c-modal_close:after {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  width: 100%;
  height: 0.15em;
  background: #fff;
}

#contents .c-modal_close:before {
  -webkit-transform: rotate(45deg);
          transform: rotate(45deg);
}

#contents .c-modal_close:after {
  -webkit-transform: rotate(-45deg);
          transform: rotate(-45deg);
}

#contents #is-cover {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vh;
  background: rgba(0, 0, 0, 0.9);
  z-index: 501;
  -webkit-transition: 0.3s;
  transition: 0.3s;
}

#contents .js-scroll.fadeInUp {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

#contents .js-scroll.fadeInLeft {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: translateX(-30px);
          transform: translateX(-30px);
}

#contents .js-scroll.fadeInRight {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: translateX(30px);
          transform: translateX(30px);
}

#contents .js-scroll.fadeInZoom {
  opacity: 0;
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  -webkit-transform: scale(0.9);
          transform: scale(0.9);
}

#contents .js-scroll.fadeInPop {
  -webkit-transition: 0.4s cubic-bezier(0.2, 0, 0.2, 1.6) 0.3s;
  transition: 0.4s cubic-bezier(0.2, 0, 0.2, 1.6) 0.3s;
  opacity: 0;
  -webkit-transform: scale(0.5);
          transform: scale(0.5);
}

#contents .js-scroll.fadeInMask {
  -webkit-transition: 1.5s ease 0.3s;
  transition: 1.5s ease 0.3s;
  -webkit-mask-image: linear-gradient(-45deg, transparent 45%, #000 55%);
          mask-image: linear-gradient(-45deg, transparent 45%, #000 55%);
  -webkit-mask-size: 300% 300%;
          mask-size: 300% 300%;
  -webkit-mask-position: 100% 100%;
          mask-position: 100% 100%;
}

#contents .js-scroll.fadeInUpOrder > * {
  -webkit-transition: 0.6s ease 0.3s;
  transition: 0.6s ease 0.3s;
  opacity: 0;
  -webkit-transform: translateY(30px);
          transform: translateY(30px);
}

#contents .js-scroll.is-scroll.fadeInUp, #contents .js-scroll.is-scroll.fadeInLeft, #contents .js-scroll.is-scroll.fadeInRight, #contents .js-scroll.is-scroll.fadeInZoom, #contents .js-scroll.is-scroll.fadeInPop {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contents .js-scroll.is-scroll.fadeInMask {
  -webkit-mask-position: 0 0;
          mask-position: 0 0;
}

#contents .js-scroll.is-scroll.fadeInUpOrder > * {
  opacity: 1;
  -webkit-transform: none;
          transform: none;
}

#contents {
  /* container */
  /* PC/SP */
  /* clearfix */
}

#contents .l-container {
  width: 100%;
  max-width: var(--container);
  margin: 0 auto;
}

@media screen and (max-width: 1360px) {
  #contents .l-container {
    padding-left: 4%;
    padding-right: 4%;
  }
}

@media screen and (min-width: 801px) {
  #contents .sp {
    display: none !important;
  }
}

@media screen and (max-width: 800px) {
  #contents .pc {
    display: none !important;
  }
}

#contents .clearfix:after {
  content: '';
  display: block;
  clear: both;
}
