@charset "UTF-8";
html {
  box-sizing: border-box;
  -webkit-text-size-adjust: 100%;
  word-break: normal;
  scroll-behavior: smooth;
}

html, body {
  height: 100%;
  height: 100svh;
}

section {
  overflow-x: hidden;
}

*,
::before,
::after {
  background-repeat: no-repeat;
  box-sizing: border-box;
}

::before,
::after {
  text-decoration: inherit;
  vertical-align: inherit;
}

* {
  padding: 0;
  margin: 0;
}

hr {
  overflow: visible;
  height: 0;
}

details,
main {
  display: block;
}

summary {
  display: list-item;
}

small {
  font-size: 80%;
}

[hidden] {
  display: none;
}

abbr[title] {
  border-bottom: none;
  text-decoration: underline;
  text-decoration: underline dotted;
}

a {
  background-color: transparent;
  color: inherit;
  cursor: pointer;
  text-decoration: none;
}

a:active,
a:hover {
  outline-width: 0;
}

code,
kbd,
samp {
  font-family: monospace, monospace;
}

pre {
  white-space: -moz-pre-wrap;
  white-space: -pre-wrap;
  white-space: -o-pre-wrap;
  white-space: pre-wrap;
}

b,
strong {
  font-weight: bolder;
}

sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline;
}

sub {
  bottom: -0.25em;
}

sup {
  top: -0.5em;
}

input {
  border-radius: 0;
}

[disabled] {
  cursor: default;
}

[type=number]::-webkit-inner-spin-button,
[type=number]::-webkit-outer-spin-button {
  height: auto;
}

[type=search] {
  -webkit-appearance: textfield;
  outline-offset: -2px;
}

[type=search]::-webkit-search-decoration {
  -webkit-appearance: none;
}

textarea {
  overflow: auto;
  resize: vertical;
}

button,
input,
optgroup,
select,
textarea {
  font: inherit;
}

optgroup {
  font-weight: bold;
}

button {
  overflow: visible;
}

button,
select {
  text-transform: none;
}

button,
[type=button],
[type=reset],
[type=submit],
[role=button] {
  cursor: pointer;
  color: inherit;
}

button::-moz-focus-inner,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

button:-moz-focusring,
[type=button]::-moz-focus-inner,
[type=reset]::-moz-focus-inner,
[type=submit]::-moz-focus-inner {
  outline: 1px dotted ButtonText;
}

button,
html [type=button],
[type=reset],
[type=submit] {
  -webkit-appearance: button;
}

button,
input,
select,
textarea {
  background-color: transparent;
  border-style: none;
}

button, input[type=submit] {
  appearance: none;
  cursor: pointer;
}

select {
  -moz-appearance: none;
  -webkit-appearance: none;
}

select::-ms-expand {
  display: none;
}

select::-ms-value {
  color: currentColor;
}

legend {
  border: 0;
  color: inherit;
  display: table;
  max-width: 100%;
  white-space: normal;
  max-width: 100%;
}

::-webkit-file-upload-button {
  -webkit-appearance: button;
  color: inherit;
  font: inherit;
}

img {
  border-style: none;
  display: block;
  max-width: 100%;
  height: auto;
}

progress {
  vertical-align: baseline;
}

ul, ol {
  list-style: none;
}

@media screen {
  [hidden~=screen] {
    display: inherit;
  }
  [hidden~=screen]:not(:active):not(:focus):not(:target) {
    position: absolute !important;
    clip: rect(0 0 0 0) !important;
  }
}
[aria-busy=true] {
  cursor: progress;
}

[aria-controls] {
  cursor: pointer;
}

[aria-disabled] {
  cursor: default;
}

html {
  font-size: 100%;
  position: relative;
}

body {
  padding-top: var(--header-height);
  position: relative;
  font-family: "Zen Maru Gothic", "Hiragino Maru Gothic ProN", "Hiragino Kaku Gothic Pro", メイリオ, Meiryo, sans-serif;
  font-weight: 400;
  vertical-align: baseline;
  line-height: 1.5;
  -webkit-text-size-adjust: 100%;
  overflow-x: hidden;
}
@media screen and (min-width: 769px) {
  body {
    --header-height: 100px;
    font-size: 20px;
  }
  body .spOnly {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  body {
    --header-height: 64px;
    font-size: 14px;
  }
  body .pcOnly {
    display: none;
  }
}
@media screen and (max-width: 389px) {
  body {
    --vw1px: 0.2564102564102564vw;
    --header-height: calc(var(--vw1px) * 64);
    font-size: calc(var(--vw1px) * 14);
  }
}

.js-pagetop {
  position: fixed;
  z-index: 2;
  opacity: 0;
  visibility: hidden;
  pointer-events: none;
  transition: opacity 0.5s ease, visibility 0.5s ease, transform 0.5s ease;
  transform: translateY(5%);
}
.js-pagetop.is-show {
  opacity: 1;
  visibility: visible;
  pointer-events: auto;
  transform: translateY(0);
}
@media (hover: hover) and (pointer: fine) {
  .js-pagetop:hover {
    opacity: 0.8;
  }
}
@media screen and (min-width: 769px) {
  .js-pagetop {
    width: 119px;
    right: 20px;
    bottom: 8px;
  }
}
@media screen and (max-width: 768px) {
  .js-pagetop {
    width: 74px;
    right: 8px;
    bottom: 9px;
  }
}
@media screen and (max-width: 389px) {
  .js-pagetop {
    width: calc(var(--vw1px) * 74);
    right: calc(var(--vw1px) * 8);
    bottom: calc(var(--vw1px) * 9);
  }
}

.ComBtnLay {
  background: #fff;
  border-radius: var(--btnH);
  color: #060766;
  display: flex;
  justify-content: center;
  align-items: center;
  font-weight: 900;
  line-height: 1;
  transition: all 0.3s ease;
  max-width: var(--btnW);
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .ComBtnLay:hover {
    opacity: 0.8;
    transform: scale(0.95);
  }
}
@media screen and (min-width: 769px) {
  .ComBtnLay {
    --btnH: 60px;
    --btnW: 304px;
    font-size: 32px;
    padding: 12px 20px 14px;
  }
  .ComBtnLay.Lowercase {
    padding: 8px 20px 18px;
  }
}
@media screen and (max-width: 768px) {
  .ComBtnLay {
    --btnH: 40px;
    --btnW: 135px;
    font-size: 20px;
    padding: 10px;
  }
  .ComBtnLay.Lowercase {
    padding: 8px 10px 12px;
  }
}
@media screen and (max-width: 389px) {
  .ComBtnLay {
    --btnH: calc(var(--vw1px) * 40);
    --btnW: calc(var(--vw1px) * 135);
    font-size: calc(var(--vw1px) * 20);
    padding: calc(var(--vw1px) * 10);
  }
  .ComBtnLay.Lowercase {
    padding: calc(var(--vw1px) * 8) calc(var(--vw1px) * 10) calc(var(--vw1px) * 12);
  }
}

.ComContentContainer {
  padding: 0 16px;
  max-width: calc(1200px + 32px);
  width: 100%;
  margin: 0 auto;
  position: relative;
}
.ComContentContainer h2 {
  color: #fff;
  font-family: "Luckiest Guy", cursive;
  font-weight: 400;
  text-align: center;
  line-height: 1;
}
.ComContentContainer h2.shadow span {
  background-image: url(../images/titleBG-shadow.png);
}
.ComContentContainer h2:not(.shadow) span {
  background-image: url(../images/titleBG.png);
}
.ComContentContainer h2 span {
  background-repeat: no-repeat;
  background-position: center bottom;
  background-size: auto var(--borderH);
  display: inline-block;
  position: relative;
  letter-spacing: 3%;
}
@media screen and (min-width: 769px) {
  section:not(.Section-KV):not(.Section-INTRODUCTION) .ComContentContainer h2 {
    margin-bottom: 112px;
  }
  .ComContentContainer h2 {
    font-size: 72px;
  }
  .ComContentContainer h2.shadow {
    min-width: 552px;
    --borderH: 57px;
    text-shadow: 0px 0px 24px rgba(6, 70, 153, 0.8);
  }
  .ComContentContainer h2.shadow span {
    height: 106px;
    width: 100%;
  }
  .ComContentContainer h2:not(.shadow) {
    --borderH: 15px;
  }
  .ComContentContainer h2:not(.shadow) span {
    height: 86px;
  }
}
@media screen and (max-width: 768px) {
  section:not(.Section-KV):not(.Section-INTRODUCTION) .ComContentContainer h2 {
    margin-bottom: 40px;
  }
  .ComContentContainer h2 {
    font-size: 36px;
  }
  .ComContentContainer h2.shadow {
    --borderH: calc(57px / 2);
    text-shadow: 0px 0px 12px rgba(6, 70, 153, 0.8);
  }
  .ComContentContainer h2.shadow span {
    padding-bottom: 23px;
  }
  .ComContentContainer h2:not(.shadow) {
    --borderH: calc(15px / 2);
  }
  .ComContentContainer h2:not(.shadow) span {
    padding-bottom: calc(4px + var(--borderH));
  }
}
@media screen and (max-width: 389px) {
  section:not(.Section-KV):not(.Section-INTRODUCTION) .ComContentContainer h2 {
    margin-bottom: calc(var(--vw1px) * 40);
  }
  .ComContentContainer h2 {
    font-size: calc(var(--vw1px) * 36);
  }
  .ComContentContainer h2.shadow {
    --borderH: calc((var(--vw1px) * 57) / 2);
  }
  .ComContentContainer h2.shadow span {
    padding-bottom: calc(var(--vw1px) * 23);
  }
  .ComContentContainer h2:not(.shadow) {
    --borderH: calc((var(--vw1px) * 15) / 2);
  }
  .ComContentContainer h2:not(.shadow) span {
    padding-bottom: calc(var(--vw1px) * 4 + var(--borderH));
  }
}

.ComTextureBGBox {
  position: relative;
  width: 100%;
  z-index: 1;
}
.ComTextureBGBox::before, .ComTextureBGBox::after, .ComTextureBGBox > *:not(.new)::before, .ComTextureBGBox > *:not(.new)::after {
  content: "";
  position: absolute;
  width: 50%;
  background-image: url(../images/BG-Txture.png);
  background-repeat: no-repeat;
  background-size: 1200px auto;
  z-index: -1;
  display: block;
}
.ComTextureBGBox::before, .ComTextureBGBox::after {
  top: 0;
  height: 50%;
}
.ComTextureBGBox > *:not(.new)::before, .ComTextureBGBox > *:not(.new)::after {
  bottom: 0;
  height: calc(50% + 3px);
}
.ComTextureBGBox::after, .ComTextureBGBox > *:not(.new)::after {
  width: calc(50% + 3px);
}
.ComTextureBGBox::before {
  background-position: left top;
  left: 0;
}
.ComTextureBGBox::after {
  background-position: right top;
  right: 0;
}
.ComTextureBGBox > *:not(.new)::before {
  background-position: left bottom;
  left: 0;
}
.ComTextureBGBox > *:not(.new)::after {
  background-position: right bottom;
  right: 0;
}

.ComModalWrap {
  display: flex;
  justify-content: center;
  align-items: center;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10;
  transition: all 0.5s ease;
}
.ComModalWrap:not(.is-open) {
  opacity: 0;
  visibility: hidden;
}
.ComModalWrap.is-open {
  opacity: 1;
  visibility: visible;
}
.ComModalWrap .ComModalBg {
  background: rgba(0, 0, 0, 0.7);
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: -1;
}

/* ======== スクロールフェードイン共通スタイル */
.js-scrollfade {
  --fadeDelay: 0.2s;
  --scrollfadeTranslateY: 30px;
  opacity: 0;
  transform: translateY(var(--scrollfadeTranslateY));
  transition: all 0.7s ease-in-out;
}

.js-scrollfade.js-scrollfade--show {
  opacity: 1;
  transform: translateY(0);
}

header {
  background: #060766;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  z-index: 10;
}
header::after {
  background: url(../images/headerBorder.png) repeat-x center center/auto 11px;
  content: "";
  display: block;
  height: 11px;
  position: absolute;
  bottom: calc((11px - 1px) * -1);
  left: 0;
  right: 0;
}
header .ComContentContainer {
  display: grid;
  grid-auto-flow: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
}
header h1 {
  line-height: 1;
  position: relative;
  z-index: 2;
  transition: all 0.5s ease;
}
header h1 svg {
  width: 100%;
  height: auto;
  fill: #fff;
}
@media (hover: hover) and (pointer: fine) {
  header h1:hover {
    cursor: pointer;
    opacity: 0.8;
    transform: scale(0.95);
  }
}
header nav ul {
  display: flex;
  flex-flow: column nowrap;
}
header nav a {
  cursor: pointer;
  color: #fff;
  font-family: "Luckiest Guy", cursive;
  font-weight: 400;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  header nav a:hover {
    opacity: 0.8;
    transition: all 0.3s ease;
  }
}
header Menu-toggle {
  display: none;
}
@media screen and (min-width: 769px) {
  header {
    padding: 30px 0;
  }
  header h1 {
    width: 197px;
  }
  header nav ul {
    flex-flow: row nowrap;
  }
  header nav ul li + li {
    margin-left: 24px;
  }
}
@media screen and (max-width: calc(1200px + 32px)) {
  header {
    padding: 17px 0;
  }
  header h1 {
    width: 168px;
  }
  header nav {
    background: #060766;
    min-height: calc(100svh - (var(--header-height) - 17px));
    height: -webkit-fill-available;
    padding-top: 42px;
    position: absolute;
    top: calc(var(--header-height) - (17px + 11px / 2));
    width: 100%;
    z-index: 1;
    transition: all 0.5s ease;
    overflow-y: auto;
  }
  header nav:not(.active) {
    transform: translateX(100%);
  }
  header nav.active {
    transform: translateX(0);
  }
  header nav ul {
    grid-auto-flow: row;
  }
  header nav ul li {
    text-align: center;
  }
  header nav ul li + li {
    margin-top: 32px;
  }
  header nav a {
    font-size: 30px;
    line-height: 1;
  }
  header .Menu-toggle {
    display: block;
    cursor: pointer;
    width: 30.88px;
    height: 23.88px;
    position: relative;
    margin: 0 0 0 auto;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    right: 14px;
    z-index: 3;
  }
  header .Menu-toggle span {
    display: block;
    background: #fff;
    height: 2.88px;
    border-radius: 2px;
    position: absolute;
    left: 0;
    right: 0;
    transition: all 0.5s ease;
  }
  header .Menu-toggle span:nth-child(1) {
    top: 0;
  }
  header .Menu-toggle span:nth-child(2) {
    top: 50%;
    transform: translateY(-50%);
  }
  header .Menu-toggle span:nth-child(3) {
    bottom: 0;
  }
  header .Menu-toggle.active span:nth-child(1) {
    transform: translateY(-1px) rotate(45deg);
    top: 50%;
  }
  header .Menu-toggle.active span:nth-child(2) {
    opacity: 0;
  }
  header .Menu-toggle.active span:nth-child(3) {
    transform: translateY(2px) rotate(135deg);
    bottom: 50%;
  }
}
@media screen and (max-width: 389px) {
  header nav {
    --header-height389: calc(var(--vw1px) * var(--header-heightNum));
    padding-top: calc(var(--vw1px) * 42);
    padding-bottom: calc(var(--vw1px) * 42);
    min-height: calc(100svh - (var(--header-height389) - calc(var(--vw1px) * 17)));
    top: calc(var(--header-height389) - (calc(var(--vw1px) * 17) + calc(var(--vw1px) * 11) / 2));
  }
  header nav ul + li {
    margin-top: calc(var(--vw1px) * 28);
  }
  header nav a {
    font-size: calc(var(--vw1px) * 30);
  }
}

.Section-KV {
  position: relative;
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-flow: column nowrap;
}
.Section-KV .ComContentContainer {
  display: flex;
  justify-content: flex-start;
  align-items: center;
  flex-flow: column nowrap;
}
.Section-KV .ComContentContainer > h2:only-child {
  margin-top: 180px;
}
.Section-KV h2 {
  width: 100%;
  line-height: 1;
}
.Section-KV h2 svg {
  width: 100%;
  height: auto;
  fill: #fff;
  filter: drop-shadow(2px 3px 0px rgba(0, 0, 0, 0.4));
}
.Section-KV .ComTextureBGBox {
  font-weight: 900;
  text-align: center;
}
.Section-KV .ComTextureBGBox > dl, .Section-KV .ComTextureBGBox h3.titleOnly {
  color: #060766;
  line-height: 1.28;
}
@media screen and (min-width: 768px) {
  .Section-KV {
    background: url(../images/StraySheep-KVPC.jpg) no-repeat center center/cover;
    height: 52.4305555556vw;
    min-height: 755px;
  }
  .Section-KV h2 {
    max-width: 754px;
    margin-top: 40px;
  }
  .Section-KV .ComTextureBGBox {
    margin-top: 32px;
    padding: 24px 32px;
  }
  .Section-KV .ComTextureBGBox h3.titleOnly, .Section-KV .ComTextureBGBox > dl > dt {
    font-size: 32px;
  }
  .Section-KV .ComTextureBGBox > dl > dd {
    font-size: 24px;
  }
  .Section-KV .ComTextureBGBox br {
    display: none;
  }
}
@media screen and (max-width: 1200px) {
  .Section-KV {
    background: url(../images/StraySheep-KVSP.jpg) no-repeat center center/cover;
  }
}
@media screen and (max-width: 1200px) and (min-width: 768px) {
  .Section-KV {
    --vw1px: 0.08333333333333334vw;
  }
  .Section-KV h2 {
    max-width: calc(var(--vw1px) * 754);
  }
  .Section-KV .ComTextureBGBox h3.titleOnly, .Section-KV .ComTextureBGBox dl > dt {
    font-size: calc(var(--vw1px) * 32);
  }
  .Section-KV .ComTextureBGBox > dl > dd {
    font-size: calc(var(--vw1px) * 24);
  }
  .Section-KV .ComTextureBGBox br {
    display: none;
  }
}
@media screen and (max-width: 767px) {
  .Section-KV {
    height: 177.9487179487vw;
    margin-top: -3px;
  }
  .Section-KV h2 {
    max-width: 310px;
    margin-top: 45px;
  }
  .Section-KV .ComTextureBGBox {
    margin-top: 30px;
    max-width: 80.2564102564vw;
    padding: 20px 0px;
  }
  .Section-KV .ComTextureBGBox h3.titleOnly, .Section-KV .ComTextureBGBox > dl > dt {
    font-size: 22px;
  }
  .Section-KV .ComTextureBGBox h3.titleOnly span, .Section-KV .ComTextureBGBox > dl > dt span {
    font-size: 20px;
  }
  .Section-KV .ComTextureBGBox > dl > dd {
    font-size: 16px;
    margin-top: 16px;
  }
}
@media screen and (max-width: 389px) {
  .Section-KV .ComContentContainer > h2:only-child {
    margin-top: calc(var(--vw1px) * 180);
  }
  .Section-KV h2 {
    max-width: calc(var(--vw1px) * 310);
    margin-top: calc(var(--vw1px) * 45);
  }
  .Section-KV .ComTextureBGBox {
    margin-top: calc(var(--vw1px) * 30);
  }
  .Section-KV .ComTextureBGBox h3.titleOnly, .Section-KV .ComTextureBGBox > dl > dt {
    font-size: calc(var(--vw1px) * 22);
  }
  .Section-KV .ComTextureBGBox h3.titleOnly span, .Section-KV .ComTextureBGBox > dl > dt span {
    font-size: calc(var(--vw1px) * 20);
  }
  .Section-KV .ComTextureBGBox > dl > dd {
    font-size: calc(var(--vw1px) * 16);
    margin-top: calc(var(--vw1px) * 16);
  }
}

.Section-Movie .MovieListConatienr {
  display: grid;
  position: relative;
}
.Section-Movie .MovieListConatienr li {
  opacity: 1;
  visibility: visible;
  transform: translateY(0) scale(1);
  transition: all 0.5s ease;
  position: relative;
}
.Section-Movie .MovieListConatienr li span.new {
  --iconW: 98px;
  --iconH: 104px;
  --top: -48px;
  --left: -30px;
  display: block;
  height: var(--iconH);
  width: var(--iconW);
  position: absolute;
  top: var(--top);
  left: var(--left);
}
.Section-Movie .MovieListConatienr li > div {
  display: grid;
  grid-auto-flow: row;
}
.Section-Movie .MovieListConatienr li.is-hidden {
  display: none;
}
.Section-Movie .MovieListConatienr li figure {
  width: 100%;
}
.Section-Movie .MovieListConatienr li h3 {
  color: #060766;
  font-weight: bold;
}
@keyframes flickUp {
  0% {
    opacity: 0;
    transform: translateY(30px);
  }
  100% {
    opacity: 1;
    transform: translateY(0);
  }
}
.Section-Movie .MovieListConatienr li.is-animating {
  animation: flickUp 0.5s ease forwards;
}
@media (hover: hover) and (pointer: fine) {
  .Section-Movie .MovieListConatienr li:hover {
    cursor: pointer;
    transform: scale(1.05);
  }
}
.Section-Movie .MovieBtnContainer {
  display: flex;
  justify-content: center;
  align-items: center;
  width: 100%;
}
.Section-Movie .MovieModalWrap {
  padding: var(--ModalWrapPaddingTB) var(--ModalWrapPaddingLR);
}
.Section-Movie .MovieModalWrap .MovieModalClose {
  border-radius: var(--closeSize);
  background: #fff;
  position: absolute;
  top: calc(var(--ModalWrapPaddingTB) * -1);
  height: var(--closeSize);
  width: var(--closeSize);
  transition: all 0.3s ease;
}
.Section-Movie .MovieModalWrap .MovieModalClose img {
  width: 100%;
}
@media (hover: hover) and (pointer: fine) {
  .Section-Movie .MovieModalWrap .MovieModalClose:hover {
    background: #ccc;
    transition: all 0.3s ease;
  }
}
.Section-Movie .MovieModalWrap .MovieModalContent {
  display: flex;
  justify-content: center;
  align-items: center;
  max-width: 1125px;
  position: relative;
  width: 100%;
  aspect-ratio: 16/9;
}
.Section-Movie .MovieModalWrap .MovieModalContent::after {
  content: "";
  display: block;
  width: 100%;
  padding-top: 56.25%;
}
.Section-Movie .MovieModalWrap .MovieModalContent .PlayerContainer {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  border-radius: 5px;
  background-color: #fff;
  padding: 5px;
  width: 100%;
}
.Section-Movie .MovieModalWrap iframe {
  height: 100%;
  width: 100%;
  max-width: 100%;
}
@media screen and (min-width: 769px) {
  .Section-Movie {
    background: url(../images/MOVIE-BGPC.jpg) no-repeat center center/cover;
    padding: 136px 0;
  }
  .Section-Movie .MovieListConatienr {
    gap: 24px;
    grid-template-columns: repeat(4, 1fr);
  }
  .Section-Movie .MovieListConatienr li {
    padding: 24px;
  }
  .Section-Movie .MovieListConatienr li span.new {
    --iconW: 98px;
    --iconH: 104px;
    --top: -48px;
    --left: -30px;
  }
  .Section-Movie .MovieListConatienr li > div {
    gap: 16px;
  }
  .Section-Movie .MovieListConatienr li h3 {
    font-size: 20px;
  }
  .Section-Movie .MovieBtnContainer {
    margin-top: 72px;
  }
  .Section-Movie .MovieModalWrap {
    --closeSize: 56px;
    --ModalWrapPaddingTB: var(--closeSize);
    --ModalWrapPaddingLR: var(--closeSize);
  }
  .Section-Movie .MovieModalWrap .MovieModalClose {
    right: calc(var(--closeSize) * -1);
  }
  .Section-Movie .MovieModalWrap .MovieModalContent {
    max-height: calc(100vh - var(--ModalWrapPaddingTB) * 2);
  }
}
@media screen and (max-width: 768px) {
  .Section-Movie {
    background: url(../images/MOVIE-BGSP.jpg) no-repeat center center/cover;
    padding: 104px 0;
  }
  .Section-Movie .MovieListConatienr {
    gap: 14px;
    grid-template-columns: repeat(2, 1fr);
  }
  .Section-Movie .MovieListConatienr li {
    padding: 14px;
  }
  .Section-Movie .MovieListConatienr li span.new {
    --iconW: 73px;
    --iconH: 77px;
    --top: -27px;
    --left: -12px;
  }
  .Section-Movie .MovieListConatienr li > div {
    gap: 4px;
  }
  .Section-Movie .MovieListConatienr li h3 {
    font-size: 14px;
  }
  .Section-Movie .MovieBtnContainer {
    margin-top: 32px;
  }
  .Section-Movie .MovieModalWrap {
    --closeSize: 40px;
    --ModalWrapPaddingTB: calc(var(--closeSize) + 8px);
    --ModalWrapPaddingLR: $contentPadding;
  }
  .Section-Movie .MovieModalWrap .MovieModalClose {
    right: 0;
  }
}
@media screen and (max-width: 768px) and (orientation: landscape) {
  .Section-Movie .MovieModalWrap .MovieModalContent {
    max-width: 72vw;
  }
}
@media screen and (max-width: 389px) {
  .Section-Movie {
    padding: calc(var(--vw1px) * 104) 0;
  }
  .Section-Movie .MovieListConatienr {
    gap: calc(var(--vw1px) * 14);
  }
  .Section-Movie .MovieListConatienr li {
    padding: calc(var(--vw1px) * 14);
  }
  .Section-Movie .MovieListConatienr li span.new {
    --iconW: calc(var(--vw1px) * 73);
    --iconH: calc(var(--vw1px) * 77);
    --top: calc(var(--vw1px) * -27);
    --left: calc(var(--vw1px) * -12);
  }
  .Section-Movie .MovieListConatienr li > div {
    gap: calc(var(--vw1px) * 5);
  }
  .Section-Movie .MovieListConatienr li h3 {
    font-size: calc(var(--vw1px) * 14);
  }
  .Section-Movie .MovieBtnContainer {
    margin-top: calc(var(--vw1px) * 32);
  }
  .Section-Movie .MovieModalWrap {
    --closeSize: calc(var(--vw1px) * 40);
    --ModalWrapPaddingTB: calc(var(--closeSize) + 8px);
    --ModalWrapPaddingLR: calc(var(--vw1px) * 16);
  }
}

.Section-INTRODUCTION .ComContentContainer {
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-items: center;
}
.Section-INTRODUCTION p {
  color: #fff;
  font-weight: bold;
  text-align: center;
}
@media screen and (min-width: 769px) {
  .Section-INTRODUCTION {
    background: url(../images/INTRODUCTION-BGPC.jpg) no-repeat center center/cover;
    height: 67.7777777778vw;
    max-height: 977px;
    padding: 143px 0;
  }
  .Section-INTRODUCTION .ComContentContainer h2 {
    margin-bottom: 71px;
  }
  .Section-INTRODUCTION p {
    font-size: 32px;
    line-height: 64px;
    text-shadow: 0px 0px 24px rgba(6, 70, 153, 0.8);
  }
}
@media screen and (max-width: 768px) {
  .Section-INTRODUCTION {
    background: url(../images/INTRODUCTION-BGSP.jpg) no-repeat center center/cover;
    padding: 64px 0 104px;
  }
  .Section-INTRODUCTION .ComContentContainer h2 {
    margin-bottom: 18px;
  }
  .Section-INTRODUCTION p {
    font-size: 16px;
    line-height: 36px;
    text-shadow: 0px 0px 16px rgba(6, 70, 153, 0.8);
  }
}
@media screen and (max-width: 389px) {
  .Section-INTRODUCTION {
    padding: calc(var(--vw1px) * 64) 0 calc(var(--vw1px) * 104);
  }
  .Section-INTRODUCTION .ComContentContainer h2 {
    margin-bottom: calc(var(--vw1px) * 18);
  }
  .Section-INTRODUCTION p {
    font-size: calc(var(--vw1px) * 16);
    line-height: calc(var(--vw1px) * 36);
  }
}

.Section-CHARACTER .ComContentContainer {
  max-width: 1043px;
  display: flex;
  flex-flow: column nowrap;
  justify-content: flex-start;
  align-items: center;
}
.Section-CHARACTER .CHARACTERContaiuer {
  display: grid;
}
.Section-CHARACTER .CHARACTERContaiuer h3 {
  font-weight: 900;
  line-height: 1;
}
.Section-CHARACTER .CHARACTERContaiuer dl {
  display: grid;
  grid-template-columns: auto 1fr;
  font-weight: bold;
}
.Section-CHARACTER .CHARACTERContaiuer dl dt::after {
  content: "：";
  margin-left: 0.33em;
}
@media screen and (min-width: 769px) {
  .Section-CHARACTER {
    background: url(../images/CHARACTER-BGPC.jpg) no-repeat center center/cover;
    padding: 144px 0 136px;
  }
  .Section-CHARACTER .CHARACTERContaiuer {
    padding: 57px 56px;
    gap: 0 48px;
    grid-template-columns: auto 1fr;
    grid-template-areas: "img h3" "img dl";
  }
  .Section-CHARACTER .CHARACTERContaiuer figure {
    width: 283px;
    grid-area: img;
  }
  .Section-CHARACTER .CHARACTERContaiuer h3 {
    grid-area: h3;
    font-size: 40px;
    margin-bottom: 16px;
  }
  .Section-CHARACTER .CHARACTERContaiuer dl {
    grid-area: dl;
    font-size: 20px;
    gap: 6px 0;
  }
}
@media screen and (max-width: 768px) {
  .Section-CHARACTER {
    background: url(../images/CHARACTER-BGSP.jpg) no-repeat center center/cover;
    padding: 64px 0 104px;
  }
  .Section-CHARACTER .ComContentContainer {
    --paddingLR: 24px;
    padding-left: var(--paddingLR);
    padding-right: var(--paddingLR);
  }
  .Section-CHARACTER .CHARACTERContaiuer {
    grid-auto-flow: row;
    justify-content: center;
    gap: 24px;
    padding: 32px 24px;
  }
  .Section-CHARACTER .CHARACTERContaiuer figure {
    width: 103px;
    margin: 0 auto;
  }
  .Section-CHARACTER .CHARACTERContaiuer h3 {
    font-size: 24px;
    text-align: center;
  }
  .Section-CHARACTER .CHARACTERContaiuer dl {
    font-size: 14px;
    gap: 4px 0;
  }
}
@media screen and (max-width: 389px) {
  .Section-CHARACTER {
    padding: calc(var(--vw1px) * 64) 0 calc(var(--vw1px) * 104);
  }
  .Section-CHARACTER .ComContentContainer {
    --paddingLR: calc(var(--vw1px) * 24);
  }
  .Section-CHARACTER .CHARACTERContaiuer {
    gap: calc(var(--vw1px) * 24);
    padding: calc(var(--vw1px) * 32) calc(var(--vw1px) * 24);
  }
  .Section-CHARACTER .CHARACTERContaiuer figure {
    width: calc(var(--vw1px) * 103);
  }
  .Section-CHARACTER .CHARACTERContaiuer h3 {
    font-size: calc(var(--vw1px) * 24);
  }
  .Section-CHARACTER .CHARACTERContaiuer dl {
    font-size: calc(var(--vw1px) * 14);
    gap: calc(var(--vw1px) * 4) 0;
  }
}

.Section-GALLERY {
  background: #5598CC url(../images/GALLERY-BG.jpg) repeat-x center bottom;
}
.Section-GALLERY .SwiperGALLERY {
  width: 100%;
  height: auto;
  position: relative;
  margin: auto;
}
.Section-GALLERY .SwiperGALLERY .swiper-wrapper {
  display: flex;
  align-items: center;
  z-index: 1;
}
.Section-GALLERY .SwiperGALLERY .swiper-slide {
  display: flex;
  justify-content: center;
  flex-shrink: 0;
  width: -webkit-fit-content;
  width: -moz-fit-content;
  width: fit-content;
  height: 100%;
  position: relative;
  padding-left: var(--swiperSlidePaddingLR);
  padding-right: var(--swiperSlidePaddingLR);
  transition: all 0.5s ease;
}
.Section-GALLERY .SwiperGALLERY .swiper-slide:not(.swiper-slide-active) {
  opacity: 0.5;
}
.Section-GALLERY .SwiperGALLERY .swiper-slide img {
  display: block;
  height: 100%;
  width: auto;
  object-fit: contain;
}
.Section-GALLERY .SwiperGALLERY .swiper-button-prev {
  left: calc((var(--iconSW) - var(--swiperSlidePaddingLR) / 2) * -1);
}
.Section-GALLERY .SwiperGALLERY .swiper-button-next {
  right: calc((var(--iconSW) - var(--swiperSlidePaddingLR) / 2) * -1);
}
@media screen and (min-width: 769px) {
  .Section-GALLERY {
    padding: 144px 0 348px;
    background-size: auto 348px;
  }
  .Section-GALLERY .SwiperGALLERY,
  .Section-GALLERY .SwiperGALLERY img {
    max-height: 386px;
  }
  .Section-GALLERY .SwiperGALLERY {
    --swiperSlidePaddingLR: 32px;
    max-width: calc(563px + var(--swiperSlidePaddingLR) * 2);
  }
}
@media screen and (max-width: 768px) {
  .Section-GALLERY {
    padding: 64px 0 94px;
    background-size: auto 94px;
  }
  .Section-GALLERY .SwiperGALLERY,
  .Section-GALLERY .SwiperGALLERY img {
    max-height: 51.2820512821vw;
  }
  .Section-GALLERY .SwiperGALLERY {
    --swiperSlidePaddingLR: 20px;
    max-width: calc(73.3333333333vw + var(--swiperSlidePaddingLR) * 2);
  }
}
@media screen and (max-width: 389px) {
  .Section-GALLERY {
    padding: calc(var(--vw1px) * 64) 0 calc(var(--vw1px) * 94);
  }
  .Section-GALLERY .SwiperGALLERY,
  .Section-GALLERY .SwiperGALLERY .swiper-slide {
    --swiperSlidePaddingLR: calc(var(--vw1px) * 20);
  }
}

*[class^=swiper-button-] {
  width: var(--iconSW);
  height: var(--iconSW);
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: all 0.3s ease;
}
*[class^=swiper-button-]::after {
  background: url(../images/icon-arrow.png) no-repeat center center/100% auto;
  content: "";
  display: block;
  width: 100%;
  height: 100%;
}
@media (hover: hover) and (pointer: fine) {
  *[class^=swiper-button-]:hover {
    opacity: 0.8;
    transform: translateY(-50%) scale(0.95);
  }
}
@media screen and (min-width: 769px) {
  *[class^=swiper-button-] {
    --iconSW: 53px;
  }
}
@media screen and (max-width: 768px) {
  *[class^=swiper-button-] {
    --iconSW: 28px;
  }
}
@media screen and (max-width: 389px) {
  *[class^=swiper-button-] {
    --iconSW: calc(var(--vw1px) * 28);
  }
}

.swiper-button-next::after {
  transform: rotate(180deg);
}

.swiper-pagination {
  display: grid;
  grid-auto-flow: column;
  justify-content: center;
  grid-template-columns: repeat(auto-fit, var(--iconS));
}
.swiper-pagination .swiper-pagination-bullet {
  background: url(../images/icon-Poe.svg) no-repeat center center/100% auto;
  height: var(--iconS);
  width: var(--iconS);
}
.swiper-pagination .swiper-pagination-bullet:not(.swiper-pagination-bullet-active) {
  opacity: 0.6;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .swiper-pagination .swiper-pagination-bullet:not(.swiper-pagination-bullet-active):hover {
    opacity: 1;
  }
}
@media screen and (min-width: 769px) {
  .swiper-pagination {
    --iconS: 32px;
    gap: 16px;
    margin-top: 32px;
  }
}
@media screen and (max-width: 768px) {
  .swiper-pagination {
    --iconS: 16px;
    gap: 8px;
    margin-top: 11px;
    margin-bottom: 40px;
  }
}
@media screen and (max-width: 389px) {
  .swiper-pagination {
    --iconS: calc(var(--vw1px) * 16);
    gap: calc(var(--vw1px) * 8);
    margin-top: calc(var(--vw1px) * 11);
    margin-bottom: calc(var(--vw1px) * 40);
  }
}

.Section-NEWS {
  background: #060766;
  overflow: visible;
  position: relative;
}
.Section-NEWS::before, .Section-NEWS::after {
  background: #060766;
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  position: absolute;
  z-index: 0;
}
.Section-NEWS::before {
  top: -5px;
}
.Section-NEWS::after {
  bottom: -5px;
}
.Section-NEWS .NewsListContainer {
  display: grid;
  grid-auto-flow: row;
  margin: 0 auto;
  max-width: 769px;
  width: 100%;
}
.Section-NEWS .NewsListContainer li {
  border-bottom: 2px solid #fff;
  color: #fff;
  font-weight: bold;
  display: grid;
  grid-auto-flow: row;
  line-height: 1;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .Section-NEWS .NewsListContainer li:hover {
    cursor: pointer;
    border-color: #96B1FC;
    color: #96B1FC;
    transition: all 0.3s ease;
  }
}
.Section-NEWS .NewsListContainer h3 {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.Section-NEWS .NewsListContainer .ModalParts {
  display: none;
}
@media screen and (min-width: 769px) {
  .Section-NEWS {
    padding: 0px 0 136px;
  }
  .Section-NEWS .NewsListContainer {
    gap: 32px;
  }
  .Section-NEWS .NewsListContainer li {
    gap: 16px;
    padding-bottom: 8px;
  }
  .Section-NEWS .NewsListContainer time {
    font-size: 24px;
  }
  .Section-NEWS .NewsListContainer h3 {
    font-size: 24px;
  }
}
@media screen and (max-width: 768px) {
  .Section-NEWS {
    padding: 32px 0 104px;
  }
  .Section-NEWS .NewsListContainer {
    gap: 16px;
  }
  .Section-NEWS .NewsListContainer li {
    gap: 8px;
    padding-bottom: 4px;
  }
  .Section-NEWS .NewsListContainer time {
    font-size: 14px;
  }
  .Section-NEWS .NewsListContainer h3 {
    font-size: 16px;
  }
}
@media screen and (max-width: 389px) {
  .Section-NEWS {
    padding: calc(var(--vw1px) * 32) 0 calc(var(--vw1px) * 104);
  }
  .Section-NEWS .NewsListContainer {
    gap: calc(var(--vw1px) * 16);
  }
  .Section-NEWS .NewsListContainer li {
    gap: calc(var(--vw1px) * 8);
    padding-bottom: calc(var(--vw1px) * 4);
  }
  .Section-NEWS .NewsListContainer time {
    font-size: calc(var(--vw1px) * 14);
  }
  .Section-NEWS .NewsListContainer h3 {
    font-size: calc(var(--vw1px) * 16);
  }
}

.NewsModalWrap .NewsModalContent {
  border-radius: 24px;
  background: #fff;
  color: #060766;
  display: flex;
  flex-flow: column nowrap;
  max-height: 100%;
  max-width: 1043px;
  height: auto;
  width: 100%;
  padding: var(--paddingTB) calc(var(--paddingLR) / 2) var(--paddingTB) var(--paddingLR);
  overflow: hidden;
}
.NewsModalWrap .NewsModalContent .NewsModalArticle {
  font-weight: bold;
  display: flex;
  flex-flow: column;
  min-height: 0;
  height: 100%;
  flex: 1;
}
.NewsModalWrap .NewsModalContent .NewsModalArticle > * {
  padding-right: calc(var(--paddingLR) / 2);
}
.NewsModalWrap .NewsModalContent .NewsModalArticle a:not(.ComBtnLay) {
  color: #5598CC;
  text-decoration: underline;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .NewsModalWrap .NewsModalContent .NewsModalArticle a:not(.ComBtnLay):hover {
    opacity: 0.8;
  }
}
.NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain {
  overflow-y: auto;
  min-height: 0;
}
.NewsModalWrap .ComBtnLay {
  background: #060766;
  color: #fff;
  margin: var(--ComBtnLayMarginT) auto 0;
}
@media screen and (min-width: 769px) {
  .NewsModalWrap {
    padding: 16px;
  }
  .NewsModalWrap .NewsModalContent {
    --paddingTB: 56px;
    --paddingLR: 72px;
    --NewsModalHeaderMB: 42px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader {
    margin-bottom: var(--NewsModalHeaderMB);
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader time {
    font-size: 24px;
    line-height: 1;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader h2 {
    font-size: 32px;
    margin-top: 4px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain > p {
    font-size: 20px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain > p + P {
    margin-top: 1em;
  }
  .NewsModalWrap .ComBtnLay {
    --ComBtnLayMarginT: 48px;
  }
}
@media screen and (max-width: 768px) {
  .NewsModalWrap {
    padding: 32px 24px;
  }
  .NewsModalWrap .NewsModalContent {
    --paddingTB: 32px;
    --paddingLR: 24px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader {
    margin-bottom: 24px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader time {
    font-size: 14px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader h2 {
    font-size: 16px;
    margin-top: 6px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain > p {
    font-size: 14px;
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain > p + P {
    margin-top: 1em;
  }
  .NewsModalWrap .NewsModalContent .ComBtnLay {
    --ComBtnLayMarginT: 32px;
  }
}
@media screen and (max-width: 389px) {
  .NewsModalWrap .NewsModalContent {
    --paddingTB: calc(var(--vw1px) * 32);
    --paddingLR: calc(var(--vw1px) * 24);
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader {
    margin-bottom: calc(var(--vw1px) * 24);
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader time {
    font-size: calc(var(--vw1px) * 14);
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalHeader h2 {
    font-size: calc(var(--vw1px) * 16);
    margin-top: calc(var(--vw1px) * 6);
  }
  .NewsModalWrap .NewsModalContent .NewsModalArticle .NewsModalMain > p {
    font-size: calc(var(--vw1px) * 14);
  }
  .NewsModalWrap .NewsModalContent .ComBtnLay {
    --ComBtnLayMarginT: calc(var(--vw1px) * 32);
  }
}

.Section-CREATOR {
  background: linear-gradient(to bottom, #060766 0%, #060766 35%, #6b62d0 75%, #6b62d0 100%);
  position: relative;
}
.Section-CREATOR::before, .Section-CREATOR::after {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center top;
  display: block;
}
.Section-CREATOR .ComContentContainer {
  background: #E8E0D2;
  max-width: 100%;
}
.Section-CREATOR .ComContentContainer h2 {
  color: #4D2A7C;
}
.Section-CREATOR .ComContentContainer h2 span {
  background-image: url(../images/titleBG-CREATOR.png);
}
.Section-CREATOR .CREATORContainer {
  margin: 0 auto;
  max-width: 1043px;
  width: 100%;
}
.Section-CREATOR .CREATORContainer .CreatorArticle {
  font-weight: 900;
  display: flex;
  flex-flow: column nowrap;
}
.Section-CREATOR .CREATORContainer .CreatorArticle figure {
  margin: 0 auto;
}
.Section-CREATOR .CREATORContainer .CreatorArticle h3 {
  display: flex;
  flex-flow: column nowrap;
  text-align: center;
  line-height: 1;
}
.Section-CREATOR .CREATORContainer .CreatorArticle p {
  font-weight: bold;
  line-height: 1.7;
}
.Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: center;
}
.Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li {
  line-height: 1;
}
.Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li a {
  line-height: 1;
  display: inline-block;
  height: var(--logoS);
  width: var(--logoS);
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li a:hover {
    opacity: 0.8;
    transform: scale(0.95);
  }
}
@media screen and (min-width: 769px) {
  .Section-CREATOR {
    padding: 160px 0;
  }
  .Section-CREATOR::before, .Section-CREATOR::after {
    background-image: url(../images/CREATOR-BGPC.png);
    position: absolute;
    height: 160px;
    left: 0;
    right: 0;
    z-index: 0;
  }
  .Section-CREATOR::before {
    top: 0;
  }
  .Section-CREATOR::after {
    bottom: 0;
    transform: rotate(180deg);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle {
    padding: 56px 72px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle figure img {
    max-width: 202px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 {
    font-size: 40px;
    margin-top: 48px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span:first-of-type {
    font-size: 24px;
    margin-bottom: 16px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span > span {
    font-size: 24px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle p {
    font-size: 20px;
    margin-top: 48px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS {
    margin-top: 48px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li + li {
    margin-left: 34px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li a {
    --logoS: 56px;
  }
}
@media screen and (max-width: 768px) {
  .Section-CREATOR {
    padding: 0px 0;
  }
  .Section-CREATOR::before, .Section-CREATOR::after {
    background-image: url(../images/CREATOR-BGSP.png);
    height: 11.0256410256vw;
    width: 100%;
  }
  .Section-CREATOR::after {
    transform: rotate(180deg);
  }
  .Section-CREATOR .ComContentContainer {
    --paddingLR: 24px;
    background: #E8E0D2;
    padding-left: var(--paddingLR);
    padding-right: var(--paddingLR);
  }
  .Section-CREATOR .ComContentContainer::before, .Section-CREATOR .ComContentContainer::after {
    background: #E8E0D2;
    content: "";
    display: block;
    left: calc(var(--paddingLR) * -1);
    right: calc(var(--paddingLR) * -1);
    height: 10px;
    position: absolute;
    z-index: 0;
  }
  .Section-CREATOR .ComContentContainer::before {
    top: -5px;
  }
  .Section-CREATOR .ComContentContainer::after {
    bottom: -5px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle {
    padding: 32px 24px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle figure img {
    max-width: 103px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 {
    font-size: 24px;
    margin-top: 24px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span:first-of-type {
    font-size: 14px;
    margin-bottom: 8px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span > span {
    font-size: 14px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle p {
    font-size: 14px;
    margin-top: 26px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS {
    margin-top: 32px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li + li {
    margin-left: 30px;
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li a {
    --logoS: 48px;
  }
}
@media screen and (max-width: 389px) {
  .Section-CREATOR .ComContentContainer {
    --paddingLR: calc(var(--vw1px) * 24);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle {
    padding: calc(var(--vw1px) * 32) calc(var(--vw1px) * 24);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle figure img {
    max-width: calc(var(--vw1px) * 103);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 {
    font-size: calc(var(--vw1px) * 24);
    margin-top: calc(var(--vw1px) * 24);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span:first-of-type {
    font-size: calc(var(--vw1px) * 14);
    margin-bottom: calc(var(--vw1px) * 8);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle h3 > span > span {
    font-size: calc(var(--vw1px) * 14);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle p {
    font-size: calc(var(--vw1px) * 14);
    margin-top: calc(var(--vw1px) * 32);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS {
    margin-top: calc(var(--vw1px) * 32);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li + li {
    margin-left: calc(var(--vw1px) * 30);
  }
  .Section-CREATOR .CREATORContainer .CreatorArticle .CreatorSNS li a {
    --logoS: calc(var(--vw1px) * 48);
  }
}

.Section-STAFFCAST {
  background: #6B62D0 url(../images/STAFF-BG.jpg) repeat-x center bottom;
  background-size: auto var(--bgH);
  position: relative;
  overflow: visible;
  padding: var(--paddingSec);
}
.Section-STAFFCAST::before, .Section-STAFFCAST::after {
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  position: absolute;
  z-index: 0;
}
.Section-STAFFCAST::before {
  background: #6B62D0;
  top: -5px;
}
.Section-STAFFCAST::after {
  background: #E8E0D2;
  bottom: -5px;
}
.Section-STAFFCAST .StaffCastList {
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;
  text-align: center;
}
.Section-STAFFCAST .StaffCastList li {
  color: #fff;
  font-weight: bold;
}
@media screen and (min-width: 769px) {
  .Section-STAFFCAST {
    --bgH: 348px;
    --paddingSec: 144px 0 var(--bgH);
  }
  .Section-STAFFCAST .StaffCastList {
    line-height: 1;
  }
  .Section-STAFFCAST .StaffCastList li {
    font-size: 32px;
  }
  .Section-STAFFCAST .StaffCastList li + li {
    margin-top: 1em;
  }
  .Section-STAFFCAST .StaffCastList li.mt1em {
    margin-top: 2em;
  }
}
@media screen and (max-width: 768px) {
  .Section-STAFFCAST {
    --bgH: 94px;
    --paddingSec: 64px 0 calc(var(--bgH) + 40px);
  }
  .Section-STAFFCAST .StaffCastList {
    line-height: 1.7;
  }
  .Section-STAFFCAST .StaffCastList li {
    font-size: 16px;
  }
  .Section-STAFFCAST .StaffCastList li.mt1em {
    margin-top: 1em;
  }
}
@media screen and (max-width: 389px) {
  .Section-STAFFCAST .StaffCastList li {
    font-size: calc(var(--vw1px) * 16);
  }
}

.Section-INFORMATION {
  background: #E8E0D2;
  overflow: visible;
  position: relative;
}
.Section-INFORMATION::before {
  background: #E8E0D2;
  content: "";
  display: block;
  width: 100%;
  height: 10px;
  position: absolute;
  z-index: 0;
}
.Section-INFORMATION::before {
  top: -5px;
}
.Section-INFORMATION .ComContentContainer h2 {
  color: #060766;
}
.Section-INFORMATION .ComContentContainer h2 span {
  background-image: url(../images/titleBG-INFORMATION.png);
}
.Section-INFORMATION dl.InformationListContainer {
  display: grid;
  grid-auto-flow: row;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock {
  --LinkBlockPadding: 24px;
  --LinkListMarginTB: 10px;
  --LinkListMarginLR: 8px;
  background: #fff;
  border-radius: 24px;
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
  justify-content: center;
  padding: var(--LinkBlockPadding) calc(var(--LinkBlockPadding) - var(--LinkListMarginLR) / 2) calc(var(--LinkBlockPadding) - var(--LinkListMarginTB) / 2);
  width: 100%;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > * {
  width: 100%;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dt {
  color: #fff;
  display: flex;
  justify-content: center;
  text-align: center;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dt > span {
  background: #060766;
  border-radius: 48px;
  font-weight: 900;
  line-height: 1;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd {
  color: #060766;
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  text-align: center;
  font-weight: bold;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd p.kome::before {
  content: "※";
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList {
  display: flex;
  flex-flow: row wrap;
  justify-content: center;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList li {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  margin: calc(var(--LinkListMarginTB) / 2) calc(var(--LinkListMarginLR) / 2);
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a {
  color: #fff;
  background: #4D2A7C;
  border-radius: 8px;
  line-height: 1;
  transition: all 0.3s ease;
}
.Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a.disabled {
  pointer-events: none;
  opacity: 0.8;
}
@media (hover: hover) and (pointer: fine) {
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a:hover {
    opacity: 0.8;
  }
}
@media screen and (min-width: 769px) {
  .Section-INFORMATION {
    padding: 0px 0 132px;
  }
  .Section-INFORMATION dl.InformationListContainer {
    gap: 48px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dt > span {
    font-size: 30px;
    padding: 16px 48px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd {
    margin-top: 12px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 {
    font-size: 32px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 + .kome {
    margin-top: 8px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd p.kome {
    font-size: 24px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList {
    margin-top: calc(18px - var(--LinkListMarginTB) / 2);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a {
    font-size: 24px;
    padding: 12px 24px;
  }
}
@media screen and (max-width: 768px) {
  .Section-INFORMATION {
    padding: 32px 0 104px;
  }
  .Section-INFORMATION dl.InformationListContainer {
    gap: 24px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dt > span {
    font-size: 16px;
    padding: 8px 32px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd {
    margin-top: 10px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 {
    font-size: 16px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 + .kome {
    margin-top: 8px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd p.kome {
    font-size: 12px;
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList {
    margin-top: calc(12px - var(--LinkListMarginTB) / 2);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a {
    font-size: 14px;
    padding: 8px 16px;
  }
}
@media screen and (max-width: 389px) {
  .Section-INFORMATION {
    padding: calc(var(--vw1px) * 32) 0 calc(var(--vw1px) * 104);
  }
  .Section-INFORMATION dl.InformationListContainer {
    gap: calc(var(--vw1px) * 24);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock {
    --LinkBlockPadding: 24;
    --LinkListMarginTB: 10;
    --LinkListMarginLR: 8;
    padding: calc(var(--vw1px) * var(--LinkBlockPadding)) calc(var(--vw1px) * (var(--LinkBlockPadding) - var(--LinkListMarginLR) / 2)) calc(var(--vw1px) * (var(--LinkBlockPadding) - var(--LinkListMarginTB) / 2));
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dt > span {
    font-size: calc(var(--vw1px) * 16);
    padding: calc(var(--vw1px) * 8) calc(var(--vw1px) * 32);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd {
    margin-top: calc(var(--vw1px) * 10);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 {
    font-size: calc(var(--vw1px) * 16);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd h3 + .kome {
    margin-top: calc(var(--vw1px) * 8);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd p.kome {
    font-size: calc(var(--vw1px) * 12);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList {
    margin-top: calc(var(--vw1px) * (12 - var(--LinkListMarginTB) / 2));
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList li {
    margin: calc(var(--vw1px) * var(--LinkListMarginTB) / 2) calc(var(--vw1px) * var(--LinkListMarginLR) / 2);
  }
  .Section-INFORMATION dl.InformationListContainer .InformationListBlock > dd .InformationLinkList a {
    font-size: calc(var(--vw1px) * 14);
    padding: calc(var(--vw1px) * 8) calc(var(--vw1px) * 16);
  }
}

.Section-LINK {
  background: #E8E0D2;
  position: relative;
}
.Section-LINK::before {
  content: "";
  background-repeat: no-repeat;
  background-size: 100% 100%;
  background-position: center top;
  display: block;
}
.Section-LINK .ComContentContainer {
  background: #5598CC;
  max-width: 100%;
  display: flex;
  flex-flow: column nowrap;
  align-items: center;
}
.Section-LINK .ComContentContainer h2 {
  color: #060766;
}
.Section-LINK .ComContentContainer h2 span {
  background-image: url(../images/titleBG-INFORMATION.png);
}
.Section-LINK .LinkLinksList {
  display: flex;
  flex-flow: row nowrap;
  align-items: center;
  justify-content: center;
}
.Section-LINK .LinkLinksList li a {
  width: 100%;
}
.Section-LINK .LinkLinksList li a img {
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  .Section-LINK .LinkLinksList li a:hover img {
    opacity: 0.8;
    transform: scale(0.95);
  }
}
.Section-LINK .LinkBtnContainer {
  display: grid;
  line-height: 1;
}
.Section-LINK .LinkBtnContainer li {
  flex: 1;
  display: flex;
  line-height: 1;
}
.Section-LINK .LinkBtnContainer li a {
  border-radius: 60px;
  background: #060766;
  color: #fff;
  font-weight: bold;
  transition: all 0.3s ease;
  text-align: center;
  width: 100%;
  white-space: nowrap;
}
@media (hover: hover) and (pointer: fine) {
  .Section-LINK .LinkBtnContainer li a:hover {
    opacity: 0.8;
    transform: scale(0.95);
  }
}
@media screen and (min-width: 769px) {
  .Section-LINK {
    padding: 160px 0 0;
  }
  .Section-LINK::before {
    background-image: url(../images/LINK-BGPC.png);
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    height: 160px;
    width: 100%;
    z-index: 0;
  }
  .Section-LINK .ComContentContainer {
    padding-bottom: 160px;
  }
  .Section-LINK .LinkLinksList li {
    width: 152px;
  }
  .Section-LINK .LinkLinksList li:not(:last-of-type) {
    margin-right: 28px;
  }
  .Section-LINK .LinkBtnContainer {
    grid-auto-flow: column;
    grid-template-columns: repeat(2, 1fr);
    gap: 24px;
    margin-top: 32px;
  }
  .Section-LINK .LinkBtnContainer a {
    font-size: 24px;
    padding: 18px 35px;
  }
}
@media screen and (max-width: 768px) {
  .Section-LINK {
    padding: 0px 0;
  }
  .Section-LINK::before {
    background-image: url(../images/LINK-BGSP.png);
    height: 11.0256410256vw;
    width: 100%;
  }
  .Section-LINK .ComContentContainer {
    --paddingLR: 24px;
    padding: 0 var(--paddingLR) 104px;
  }
  .Section-LINK .ComContentContainer::before {
    background: #5598CC;
    content: "";
    display: block;
    left: calc(var(--paddingLR) * -1);
    right: calc(var(--paddingLR) * -1);
    height: 10px;
    position: absolute;
    z-index: 0;
  }
  .Section-LINK .ComContentContainer::before {
    top: -5px;
  }
  .Section-LINK .LinkLinksList li {
    width: 79px;
  }
  .Section-LINK .LinkLinksList li:not(:last-of-type) {
    margin-right: 8px;
  }
  .Section-LINK .LinkBtnContainer {
    grid-auto-flow: row;
    grid-template-rows: repeat(2, 1fr);
    gap: 10px;
    margin-top: 24px;
  }
  .Section-LINK .LinkBtnContainer a {
    font-size: 16px;
    padding: 16px 32px;
  }
}
@media screen and (max-width: 389px) {
  .Section-LINK .ComContentContainer {
    --paddingLR: calc(var(--vw1px) * 24);
    padding: 0 var(--paddingLR) calc(var(--vw1px) * 104);
  }
  .Section-LINK .LinkLinksList li {
    width: calc(var(--vw1px) * 79);
  }
  .Section-LINK .LinkLinksList li:not(:last-of-type) {
    margin-right: calc(var(--vw1px) * 8);
  }
  .Section-LINK .LinkBtnContainer {
    gap: calc(var(--vw1px) * 10);
    margin-top: calc(var(--vw1px) * 24);
  }
  .Section-LINK .LinkBtnContainer a {
    font-size: calc(var(--vw1px) * 16);
    padding: calc(var(--vw1px) * 16) calc(var(--vw1px) * 32);
  }
}

footer {
  background: #060766;
  color: #fff;
  text-align: center;
}
footer .ComContentContainer {
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;
}
footer .footerSNSShareContainer {
  display: flex;
  flex-flow: column nowrap;
  justify-content: center;
  align-items: center;
}
footer .footerSNSShareContainer > dt {
  line-height: 1;
  font-weight: bold;
}
footer .footerSNSShareContainer .footerSNSShare {
  display: flex;
  flex-flow: row nowrap;
  justify-content: center;
  align-items: center;
  margin-top: var(--ShareMarginT);
}
footer .footerSNSShareContainer .footerSNSShare li:not(:last-of-type) {
  margin-right: var(--ShareMarginR);
}
footer .footerSNSShareContainer .footerSNSShare a {
  transition: all 0.3s ease;
}
footer .footerSNSShareContainer .footerSNSShare a img {
  width: 100%;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  footer .footerSNSShareContainer .footerSNSShare a:hover img {
    opacity: 0.8;
    transform: scale(0.95);
  }
}
footer .privacy {
  font-weight: bold;
}
footer .privacy a {
  color: #5598CC;
  transition: all 0.3s ease;
}
@media (hover: hover) and (pointer: fine) {
  footer .privacy a:hover {
    opacity: 0.8;
  }
}
footer .copyright {
  font-weight: bold;
  line-height: 1;
}
@media screen and (min-width: 769px) {
  footer {
    padding: 24px 0;
  }
  footer .footerSNSShareContainer > dt {
    font-size: 24px;
  }
  footer .footerSNSShareContainer .footerSNSShare {
    --ShareMarginT: 24px;
    --ShareMarginR: 40px;
  }
  footer .footerSNSShareContainer .footerSNSShare a img {
    max-width: 75px;
  }
  footer .privacy {
    font-size: 16px;
    margin-top: 21px;
  }
  footer .copyright {
    font-size: 16px;
    margin-top: 18px;
  }
}
@media screen and (max-width: 768px) {
  footer {
    padding: 16px 0;
  }
  footer .footerSNSShareContainer > dt {
    font-size: 12px;
  }
  footer .footerSNSShareContainer .footerSNSShare {
    --ShareMarginT: 10px;
    --ShareMarginR: 15px;
  }
  footer .footerSNSShareContainer .footerSNSShare a img {
    max-width: 28px;
  }
  footer .privacy {
    font-size: 10px;
    margin-top: 8px;
  }
  footer .copyright {
    font-size: 10px;
    margin-top: 12px;
  }
}
@media screen and (max-width: 389px) {
  footer {
    padding: calc(var(--vw1px) * 16) 0;
  }
  footer .footerSNSShareContainer > dt {
    font-size: calc(var(--vw1px) * 12);
  }
  footer .footerSNSShareContainer .footerSNSShare {
    --ShareMarginT: calc(var(--vw1px) * 10);
    --ShareMarginR: calc(var(--vw1px) * 15);
  }
  footer .footerSNSShareContainer .footerSNSShare a img {
    max-width: calc(var(--vw1px) * 28);
  }
  footer .privacy {
    font-size: calc(var(--vw1px) * 10);
    margin-top: calc(var(--vw1px) * 8);
  }
  footer .copyright {
    font-size: calc(var(--vw1px) * 10);
    margin-top: calc(var(--vw1px) * 12);
  }
}