@charset "UTF-8";
/************************************************

@PC - style.css v5.0.0

(c) ULM Co.,Ltd. - https://www.ulm-design.com

構成（上から順）:
  サイト背景動画 / #main
  TOP以下：背景（.site-body / .site-body-cyan）
  トップ KV
  トップ下（.under-section）/ ニュース / トレーラ
  イントロダクション / コメント / 原作
  フッター（SHARE）
************************************************/
/************************************************

@PC - common.css v5.0.0

(c) ULM Co.,Ltd. - https://www.ulm-design.com
************************************************/
/* reset */
article, aside, details, figcaption, figure, footer, header, hgroup, hr, menu, nav, section {
  display: block;
}

a, hr {
  padding: 0;
}

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

ins, mark {
  background-color: #ff9;
  color: #000;
}

body {
  line-height: 1;
}

li, ol, ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

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

a {
  margin: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: 0 0;
}

ins {
  text-decoration: none;
}

mark {
  font-style: italic;
  font-weight: 700;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

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

hr {
  height: 1px;
  border: 0;
  border-top: 1px solid #ccc;
  margin: 1em 0;
}

input, select {
  vertical-align: middle;
}

/*-------------------------------

html

-------------------------------*/
html, body {
  font: 14px/1.7 "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 500;
  letter-spacing: 0.03em;
  word-break: normal;
  overflow-wrap: break-word;
  color: #1a1a1a;
  background: transparent;
  font-feature-settings: "palt";
  -webkit-text-size-adjust: 100%;
}
@media screen and (min-width: 960px) {
  html, body {
    font-size: 15px;
  }
}

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

.hover {
  -webkit-transition: all 0.2s ease;
  transition: all 0.2s ease;
}

.click {
  -webkit-transition: all 0.4s ease;
  transition: all 0.4s ease;
}

.click:active {
  -webkit-transition: all 0.1s ease;
  transition: all 0.1s ease;
  transform: scale(0.95);
}

.delayItem, .delayItem_sub {
  opacity: 0;
}

/*-------------------------------

#wrapper

-------------------------------*/
#wrapper {
  width: 100%;
  display: block;
  position: relative;
}
#wrapper > #main,
#wrapper > #footer {
  position: relative;
  z-index: 1;
  background: transparent;
}

/*-------------------------------

#header

-------------------------------*/
#header {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 56px;
  padding-top: env(safe-area-inset-top, 0);
  background: #4785ef;
  border: none;
  box-shadow: none;
  z-index: 1000;
}
@media screen and (min-width: 960px) {
  #header {
    display: none;
  }
}

.site-header-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 56px;
  padding: 0 16px;
}

.site-header-sns {
  flex: 1;
  min-width: 0;
}

#drawer-btn {
  position: relative;
  flex-shrink: 0;
  width: 44px;
  height: 44px;
  margin: 0;
  padding: 0;
  border: 0;
  background: transparent;
  cursor: pointer;
  color: #fff;
}
#drawer-btn.is-hidden, #drawer-btn[hidden] {
  display: none;
}

#drawer-txt {
  display: block;
  font-family: Arial, Helvetica, sans-serif;
  font-size: 9px;
  font-weight: 700;
  line-height: 1;
  text-align: center;
  color: #fff;
  padding: 4px 0 0;
  letter-spacing: 0.04em;
}

#drawer-line-box {
  display: block;
  width: 28px;
  height: 14px;
  margin: 0 auto;
  padding: 0;
}

.drawer-line {
  width: 28px;
  height: 2px;
  background: #fff;
  display: block;
  margin: 0 auto 5px;
  transition: transform 0.35s ease, opacity 0.35s ease;
  transform: rotate(0deg);
  border-radius: 2px;
}
.drawer-line:last-child {
  margin-bottom: 0;
}

.drawer-line.open:nth-child(1) {
  transform: translateY(3.5px) rotate(45deg);
}

.drawer-line.open:nth-child(2) {
  transform: translateY(-3.5px) rotate(-45deg);
}

.drawer-line.open:nth-child(3) {
  display: none;
}

/*-------------------------------

@nav

-------------------------------*/
.nav-btn {
  display: block;
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: #fff;
  border: 1px solid;
  border-radius: 8px;
  margin: 40px auto;
  padding: 20px 50px;
}
.nav-btn:hover {
  color: #e91e8c;
}

/*-------------------------------

#drawer-layer-container

-------------------------------*/
#drawer-container {
  width: 100%;
  height: 100%;
  position: fixed;
  z-index: 1100;
  top: 0px;
  left: 0px;
  overflow-y: scroll;
  -webkit-overflow-scrolling: touch;
  display: none;
  opacity: 0;
  background: #4785ef;
  padding: calc(56px + env(safe-area-inset-top, 0)) 0 0 0;
}

#drawer-container-inner {
  width: 100%;
  padding: 25% 0;
  position: relative;
  z-index: 1;
}

#drawer-nav-container {
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  width: 90%;
  margin: 0 auto;
}

.drawer-nav-box {
  display: block;
  margin: 0 0 3% 0;
}

.drawer-nav-box:last-child {
  margin: 0 auto;
}

.drawer-nav-btn {
  color: #fff;
  text-decoration: none;
  display: block;
  height: 80px;
  line-height: 80px;
  letter-spacing: 3px;
  border-radius: 5px;
  font-family: "Noto Serif JP", serif;
}

.drawer-nav-btn.selected {
  color: #fcf150;
  background: transparent;
  text-shadow: none;
}

/*-------------------------------

#footer

-------------------------------*/
/*-------------------------------

#main

-------------------------------*/
#main {
  display: block;
}

/*-------------------------------

#preloader

-------------------------------*/
#preloader {
  width: 100%;
  height: 100%;
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: 10000;
  background: #fff;
}
@media screen and (min-width: 960px) {
  #preloader {
    padding: 0;
  }
}

#preloader-inner {
  width: auto;
  height: auto;
  position: absolute;
  z-index: 1;
  top: calc(50% - 140px);
  left: calc(50% - 20px);
}
@media screen and (min-width: 960px) {
  #preloader-inner {
    top: calc(50% - 160px);
    left: calc(50% - 0px);
  }
}

#preloader-ttl {
  display: block;
  position: absolute;
  z-index: 3;
  top: 0;
  left: 0;
}

#preloader-txt {
  position: absolute;
  top: 50%;
  left: 50%;
  z-index: 2;
}

#preloader-anime {
  position: absolute;
  top: 115px;
  left: 310px;
  z-index: 3;
}

#progress-txt {
  width: 60px;
  display: block;
  font: 11px/1em Arial, Helvetica, sans-serif;
  color: #1eb9ee;
  text-align: center;
  position: absolute;
  top: 305px;
  left: 0;
  right: 0;
  margin: auto;
  z-index: 4;
}
#preloaderAnime {
  top: 365px;
  top: calc(50% - 8px);
  left: calc(50% - 8px);
}

.spinner {
  width: 40px;
  height: 40px;
  position: relative;
  margin: 100px auto;
}

.double-bounce1,
.double-bounce2 {
  width: 100%;
  height: 100%;
  border-radius: 50%;
  background-color: #1eb9ee;
  opacity: 0.6;
  position: absolute;
  top: 0;
  left: 0;
  -webkit-animation: sk-bounce 2s infinite ease-in-out;
  animation: sk-bounce 2s infinite ease-in-out;
}

.double-bounce2 {
  -webkit-animation-delay: -1s;
  animation-delay: -1s;
}

@-webkit-keyframes sk-bounce {
  0%, 100% {
    -webkit-transform: scale(0);
  }
  50% {
    -webkit-transform: scale(1);
  }
}
@keyframes sk-bounce {
  0%, 100% {
    transform: scale(0);
    -webkit-transform: scale(0);
  }
  50% {
    transform: scale(1);
    -webkit-transform: scale(1);
  }
}
/*-------------------------------

@banner

-------------------------------*/
.banner-item {
  margin: 0 10px 0 0;
  -webkit-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.banner-item:hover {
  opacity: 0.6;
}

.banner-img {
  width: 180px;
  height: auto;
}

/*-------------------------------

@SNS

-------------------------------*/
#social-container {
  margin: 20px;
  align-items: baseline;
  justify-content: center;
}

.sns-btn:nth-last-child(1) {
  padding: 0;
}

.sns-btn {
  margin: 0 8px;
}

.share-link-btn {
  display: block;
  color: #1a1a1a;
  font-size: 20px;
  opacity: 0.85;
  transition: all 0.2s ease;
}
.share-link-btn:hover {
  opacity: 1;
  color: #e91e8c;
}

.custom-facebook-btn {
  font-size: 25px;
}

.custom-line-btn {
  font-size: 25px;
}

/*--------------------------------------------------
リマケタグの隙間対策
--------------------------------------------------*/
iframe[name=google_conversion_frame] {
  height: 0 !important;
  width: 0 !important;
  line-height: 0 !important;
  font-size: 0 !important;
  margin-top: -13px;
}

/*--------------------------------------------------------------

@modules

--------------------------------------------------------------*/
/*-------------------------------

a

-------------------------------*/
a {
  text-decoration: none;
  display: inline-block;
  transition: all 0.4s ease;
}

/*-------------------------------

@flex

-------------------------------*/
.flex {
  display: -webkit-flex;
  display: flex;
}

.flex-wrap {
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}

.flex-center {
  -webkit-justify-content: center;
  justify-content: center;
}

.flex-left {
  -webkit-justify-content: flex-start;
  justify-content: flex-start;
}

.flex-right {
  -webkit-justify-content: flex-end;
  justify-content: flex-end;
}

/*-------------------------------

font-weight

-------------------------------*/
.bold {
  font-weight: bold;
}

/*-------------------------------

font-style

-------------------------------*/
.italic {
  font-style: italic;
}

/*-------------------------------

display

-------------------------------*/
.none {
  display: none;
}

.block {
  display: block;
}

/*-------------------------------

position

-------------------------------*/
.relative {
  position: relative;
}

.margin-auto {
  margin: 0 auto;
}

/*-------------------------------

guard

-------------------------------*/
.guard {
  position: absolute;
  display: block;
  width: 100%;
  height: 100%;
  top: 0;
  left: 0;
  background-image: url(../common/img/spacer.gif);
  background-repeat: repeat;
}

.protect {
  -moz-user-select: none;
  -khtml-user-select: none;
  -webkit-user-select: none;
  user-select: none;
  -khtml-user-drag: none;
  -webkit-user-drag: none;
}

img {
  width: 100%;
  vertical-align: middle;
}

.h100 {
  width: auto !important;
  height: 100%;
}

.jpn {
  display: block;
  font-size: xx-small;
  text-align: center;
  padding: 10px 0 0 0;
  color: #999;
}

/*-------------------------------

animation

-------------------------------*/
.fade {
  opacity: 0;
}

.fadein {
  opacity: 0;
  transform: translate(0px, 20px);
  transition: all 2s ease;
}

.fadein.fadein-anime {
  animation: fadein 2s ease forwards;
}

@keyframes fadein {
  0% {
    opacity: 0;
    transform: translate(0px, 20px);
  }
  100% {
    opacity: 1;
    transform: translate(0px, 0px);
  }
}
.fade-up {
  transition: all 2s ease;
}

/*-------------------------------

サイト背景動画

-------------------------------*/
.site-bg-video {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.site-bg-video.is-paused .site-bg-video__item {
  visibility: hidden;
}

.site-bg-video__item {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  opacity: 1;
  border: 0;
}

.site-bg-video__item--pc {
  display: none;
}

.site-bg-video__item--sp {
  display: block;
}

@media screen and (min-width: 960px) {
  .site-bg-video__item--pc {
    display: block;
  }
  .site-bg-video__item--sp {
    display: none;
  }
}
/*-------------------------------

#main

-------------------------------*/
#main {
  opacity: 0;
  background: transparent;
}
@media screen and (max-width: 960px) {
  #main {
    padding-top: calc(56px + env(safe-area-inset-top, 0));
  }
}

/*-------------------------------

TOP以下：背景

-------------------------------*/
.site-body {
  position: relative;
  z-index: 1;
  isolation: isolate;
}
.site-body::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.52;
  background: radial-gradient(ellipse 95% 75% at 12% 38%, rgba(90, 172, 232, 0.55) 0%, rgba(90, 172, 232, 0.18) 50%, transparent 72%), radial-gradient(ellipse 90% 70% at 88% 12%, rgba(233, 30, 140, 0.5) 0%, rgba(233, 30, 140, 0.16) 46%, transparent 68%), radial-gradient(ellipse 85% 68% at 68% 88%, rgba(255, 136, 32, 0.48) 0%, rgba(255, 136, 32, 0.14) 44%, transparent 66%), radial-gradient(ellipse 80% 65% at 16% 92%, rgba(152, 204, 24, 0.38) 0%, transparent 58%), linear-gradient(125deg, rgba(60, 160, 232, 0.42) 0%, rgba(224, 24, 144, 0.36) 40%, rgba(255, 136, 32, 0.34) 100%);
}
.site-body::after {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.07;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.45' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 240px 240px;
}
.site-body > * {
  position: relative;
  z-index: 1;
}

.site-body-cyan {
  position: relative;
  z-index: 2;
  padding-bottom: 80px;
}
@media screen and (max-width: 960px) {
  .site-body-cyan {
    padding-bottom: 40px;
  }
}
.site-body-cyan::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  background: rgba(71, 133, 239, 0.7490196078);
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 80px), 0 100%);
}
@media screen and (max-width: 960px) {
  .site-body-cyan::before {
    clip-path: polygon(0 0, 100% 0, 100% calc(100% - 40px), 0 100%);
  }
}
.site-body-cyan > * {
  position: relative;
  z-index: 2;
}

.pc {
  display: none;
}

.sp {
  display: block;
}

@media screen and (min-width: 960px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
}
/* ページ全体リビール（#wrapper 直下の z-index 指定より優先） */
#wrapper > .page-reveal-overlay {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 9999;
}
#wrapper > .page-reveal-overlay::before, #wrapper > .page-reveal-overlay::after {
  content: "";
  position: absolute;
  inset: 0;
  transform: translateY(-100%);
  animation: none;
}
#wrapper > .page-reveal-overlay::before {
  background: rgba(90, 172, 232, 0.58);
  z-index: 2;
}
#wrapper > .page-reveal-overlay::after {
  background: rgba(233, 30, 140, 0.45);
  z-index: 1;
}

.reveal-started #wrapper > .page-reveal-overlay {
  animation: reveal-overlay-hide 0s linear 1.6s forwards;
}

.reveal-started #wrapper > .page-reveal-overlay::before {
  animation: top-reveal-slide 1.2s ease 0s forwards;
}

.reveal-started #wrapper > .page-reveal-overlay::after {
  animation: top-reveal-slide 1.2s ease 0.4s forwards;
}

@keyframes top-reveal-slide {
  from {
    transform: translateY(0);
  }
  to {
    transform: translateY(100%);
  }
}
@keyframes reveal-overlay-hide {
  to {
    visibility: hidden;
  }
}
/* トップリビール */
.top-section .top-reveal-wrap .top-slideshow {
  opacity: 0;
  transform: scale(1.2);
  transform-origin: center top;
  animation: top-reveal-img 1.2s cubic-bezier(0.785, 0.135, 0.15, 0.86) 0.6s forwards;
  animation-play-state: paused;
}

.reveal-started .top-section .top-reveal-wrap .top-slideshow {
  animation-play-state: running;
}

.top-section .top-reveal-wrap .top-logo,
.top-section .top-reveal-wrap .top-roadshow,
.top-section .top-reveal-wrap .top-catchcopy,
.top-section .top-reveal-wrap .top-kabo,
.top-section .top-reveal-wrap .official-sns-wrap--top {
  opacity: 0;
  transform: translateY(20px);
  animation: top-reveal-content 1.2s ease 0.9s forwards;
  animation-play-state: paused;
}

.reveal-started .top-section .top-reveal-wrap .top-logo,
.reveal-started .top-section .top-reveal-wrap .top-roadshow,
.reveal-started .top-section .top-reveal-wrap .top-catchcopy,
.reveal-started .top-section .top-reveal-wrap .top-kabo,
.reveal-started .top-section .top-reveal-wrap .official-sns-wrap--top {
  animation-play-state: running;
}

@keyframes top-reveal-img {
  from {
    opacity: 0;
    transform: scale(1.2);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes top-reveal-content {
  to {
    opacity: 1;
    transform: translateY(0);
  }
}
.reveal-started .top-visual-inner::before, .reveal-started .top-visual-inner::after {
  animation: top-visual-line-in 0.5s ease 1.8s forwards;
}

@keyframes top-visual-line-in {
  to {
    opacity: 1;
  }
}
/*-------------------------------

トップ

-------------------------------*/
.top-section {
  padding: 0;
  background: transparent;
}

.top-visual {
  position: relative;
  width: 100%;
}

.top-visual-inner {
  position: relative;
  overflow: hidden;
  background: transparent;
  height: auto;
}
.top-visual-inner::before, .top-visual-inner::after {
  content: "";
  position: absolute;
  top: 0;
  bottom: 0;
  width: min(3.5vw, 14px);
  z-index: 4;
  pointer-events: none;
  background: color-mix(in srgb, #1215ff 60%, transparent);
  opacity: 0;
}
.top-visual-inner::before {
  left: 0;
  clip-path: polygon(0 0, 100% 0, 12% 100%, 0 100%);
}
.top-visual-inner::after {
  right: 0;
  clip-path: polygon(90% 0, 100% 0, 100% 100%, 10% 100%);
}

.top-slideshow {
  position: relative;
  width: 100%;
  height: auto;
  z-index: 1;
}

.top-copy {
  position: absolute;
  inset: 0;
  z-index: 5;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: flex-end;
  padding: 0 20px 40px;
  pointer-events: none;
}

.top-logo {
  display: none;
  position: relative;
  top: auto;
  left: auto;
  z-index: 1;
  width: 78%;
  max-width: 400px;
  margin: 0 auto 10px;
  pointer-events: auto;
}

.top-roadshow {
  display: none;
  position: relative;
  bottom: auto;
  right: auto;
  z-index: 1;
  width: 62%;
  max-width: 280px;
  margin: 0 auto;
  pointer-events: auto;
}

.top-catchcopy,
.top-kabo {
  display: none;
  position: absolute;
  z-index: 5;
  margin: 0;
  pointer-events: none;
}

.top-catchcopy img,
.top-kabo img {
  display: block;
  width: 100%;
  height: auto;
}

.slideshow-container {
  position: relative;
  width: 100%;
  height: auto;
  overflow: hidden;
}
.slideshow-container::before {
  content: "";
  position: absolute;
  inset: 0;
  z-index: 0;
  background: #fff;
  opacity: 0;
  pointer-events: none;
}

.reveal-started .top-reveal-wrap .slideshow-container::before {
  animation: kv-slideshow-bg 0s linear 1.8s forwards;
}

@keyframes kv-slideshow-bg {
  to {
    opacity: 1;
  }
}
.slideshow-pc,
.slideshow-sp {
  position: relative;
  width: 100%;
  overflow: hidden;
}

.slideshow-sizer {
  display: none;
}

.slideshow-sp .slideshow-sizer {
  display: block;
  visibility: hidden;
  width: 100%;
  height: auto;
}

.slideshow-pc {
  display: none;
}
@media screen and (min-width: 960px) {
  .slideshow-pc {
    display: block;
    height: 100%;
  }
}

.slideshow-sp {
  display: block;
  height: auto;
}
@media screen and (min-width: 960px) {
  .slideshow-sp {
    display: none;
  }
}

@keyframes kv-fade {
  0%, 40% {
    opacity: 1;
  }
  50%, 90% {
    opacity: 0;
  }
  100% {
    opacity: 1;
  }
}
.slide-item {
  position: absolute;
  inset: 0;
  z-index: 1;
  width: 100%;
  height: 100%;
  opacity: 0;
  animation: kv-fade 10s ease-in-out infinite;
}
.slide-item:nth-child(2) {
  animation-delay: 0s;
}
.slide-item:nth-child(3) {
  animation-delay: -5s;
}
.slide-item img {
  width: 100%;
  height: auto;
  object-fit: cover;
  object-position: top center;
  display: block;
}

@media screen and (min-width: 960px) {
  .top-section {
    background: transparent;
  }
  .top-visual-inner {
    height: min(100vh, 1280px);
    background: transparent;
  }
  .top-visual-inner::before, .top-visual-inner::after {
    width: min(6.2vw, 32px);
  }
  .top-slideshow {
    height: 100%;
    overflow: hidden;
  }
  .slideshow-container {
    height: 100%;
  }
  .slideshow-pc,
  .slideshow-sp {
    height: 100%;
  }
  .slideshow-sp .slideshow-sizer {
    display: none;
  }
  .slide-item img {
    height: 100%;
    object-fit: cover;
  }
  .top-copy {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: flex-start;
    inset: auto auto 36% 2.5%;
    width: 40%;
    max-width: 500px;
    height: auto;
    padding: 0;
  }
  .top-logo {
    display: block;
    position: relative;
    width: 100%;
    max-width: none;
    margin: 0 0 28px;
  }
  .top-roadshow {
    display: block;
    position: relative;
    width: 52%;
    max-width: 200px;
    margin: 0;
  }
  .top-roadshow img {
    transform: rotate(-12deg);
    transform-origin: center center;
  }
  .top-catchcopy {
    display: block;
    top: 3%;
    right: 3.5%;
    width: 6%;
    max-width: 60px;
  }
  .top-kabo {
    display: block;
    bottom: 3%;
    left: 0;
    right: 0;
    width: 12%;
    max-width: 120px;
    margin: 0 auto;
  }
  .official-sns-wrap--top {
    position: absolute;
    top: 2vw;
    left: 4.5vw;
    z-index: 10;
    margin: 0;
    padding: 0;
    max-width: none;
    pointer-events: auto;
  }
  .official-sns-wrap--top .official-sns {
    justify-content: flex-start;
    gap: 14px;
  }
  .official-sns-wrap--top .official-sns a {
    width: 54px;
    height: 54px;
    font-size: 22px;
    transition: background 0.25s ease, color 0.25s ease, box-shadow 0.25s ease;
  }
  .official-sns-wrap--top .official-sns a:hover {
    transform: none;
    background: #1215ff;
    color: #fff;
    box-shadow: 0 4px 14px rgba(12, 26, 66, 0.14);
  }
}
/*-------------------------------

トップ下

-------------------------------*/
.under-section {
  position: relative;
  z-index: 1;
  padding: 40px 0 60px;
  background: transparent;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .under-section {
    padding: 60px 0 30px;
  }
}

.under-roadshow {
  width: 50%;
  max-width: 280px;
  margin: 0 auto 40px;
}
.under-roadshow img {
  display: block;
  width: 100%;
  height: auto;
}

.billing {
  max-width: 720px;
  margin: 0 auto 32px;
  padding: 0 15px 0;
  text-align: center;
  background: transparent;
  border: none;
  box-shadow: none;
}

.billing-cast {
  margin: 0 0 6px;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.88em;
  font-weight: 700;
  line-height: 1.55;
  color: rgba(255, 255, 255, 0.88);
  text-shadow: none;
}
.billing-cast--lead {
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 1.35em;
  letter-spacing: 0.12em;
  color: #fff;
  line-height: 1.35;
  text-shadow: none;
}
.billing-cast--lead ruby {
  ruby-align: center;
}
.billing-cast--lead rt {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.42em;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: none;
  opacity: 0.92;
  padding-bottom: 0.2em;
}
@media screen and (min-width: 960px) {
  .billing-cast--lead {
    font-size: 1.5em;
    letter-spacing: 0.14em;
  }
}

.billing-staff {
  margin: 10px 0 0;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 1em;
  font-weight: 700;
  line-height: 1.9;
  color: rgba(255, 255, 255, 0.9);
  text-shadow: none;
}
.billing-staff + .billing-staff {
  margin-top: 6px;
}

.billing-staff-sub {
  font-size: 0.78em;
  font-weight: 500;
}

.billing-credit {
  margin: 22px 0 0;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.7em;
  font-weight: 500;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.75);
  text-shadow: none;
}

.billing-copy {
  margin: 5px 0 0;
  padding-top: 0;
  border-top: none;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.62em;
  font-weight: 500;
  line-height: 1.65;
  letter-spacing: 0.02em;
  color: rgba(255, 255, 255, 0.65);
  text-shadow: none;
}

.official-sns-wrap {
  max-width: 720px;
  margin: 0 auto;
  padding: 0 28px;
  background: transparent;
  border: none;
  box-shadow: none;
}
@media screen and (min-width: 960px) {
  .official-sns-wrap {
    padding: 0;
  }
}

@media screen and (min-width: 960px) {
  .official-sns-wrap--under {
    display: none;
  }
}

.official-sns-ttl {
  text-align: center;
  margin: 0 auto 24px;
}

.official-sns {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 20px;
  margin: 0;
}
.official-sns a {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 56px;
  height: 56px;
  background: #fff;
  color: #1a1a1a;
  font-size: 22px;
  border-radius: 50%;
  border: none;
  box-shadow: 0 4px 14px rgba(12, 26, 66, 0.14);
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.official-sns a:hover {
  opacity: 1;
  transform: translateY(-3px);
  box-shadow: 0 8px 20px rgba(12, 26, 66, 0.18);
}
.official-sns li:nth-child(1) a {
  color: #1a1a1a;
}
.official-sns li:nth-child(2) a {
  color: #e91e8c;
}
.official-sns li:nth-child(3) a {
  color: #1a1a1a;
}

.official-sns--header {
  justify-content: flex-start;
  gap: 18px;
}
.official-sns--header a {
  width: auto;
  height: auto;
  padding: 4px;
  background: transparent;
  color: #fff;
  font-size: 20px;
  border-radius: 0;
  box-shadow: none;
  transition: opacity 0.25s ease;
}
.official-sns--header a:hover {
  transform: none;
  opacity: 0.7;
  box-shadow: none;
}
.official-sns--header li:nth-child(1) a,
.official-sns--header li:nth-child(2) a,
.official-sns--header li:nth-child(3) a {
  color: #fff;
}

/*-------------------------------

イントロダクション・コメント・原作

-------------------------------*/
.introduction-section {
  position: relative;
  z-index: 1;
  margin-top: -40px;
  padding: 80px 0 80px;
  background: transparent;
}
.introduction-section::before, .introduction-section::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
  clip-path: polygon(0 40px, 100% 0, 100% 100%, 0 calc(100% - 40px));
}
@media screen and (min-width: 960px) {
  .introduction-section::before, .introduction-section::after {
    clip-path: polygon(0 80px, 100% 0, 100% 100%, 0 calc(100% - 80px));
  }
}
.introduction-section::before {
  z-index: -2;
  opacity: 0.52;
  background: radial-gradient(ellipse 90% 70% at 88% 22%, rgba(233, 30, 140, 0.5) 0%, rgba(233, 30, 140, 0.16) 46%, transparent 68%), radial-gradient(ellipse 95% 75% at 12% 78%, rgba(90, 172, 232, 0.55) 0%, rgba(90, 172, 232, 0.18) 50%, transparent 72%), radial-gradient(ellipse 80% 65% at 84% 92%, rgba(152, 204, 24, 0.38) 0%, transparent 58%), radial-gradient(ellipse 85% 68% at 32% 88%, rgba(255, 136, 32, 0.48) 0%, rgba(255, 136, 32, 0.14) 44%, transparent 66%), linear-gradient(135deg, rgba(224, 24, 144, 0.36) 0%, rgba(60, 160, 232, 0.42) 50%, rgba(255, 136, 32, 0.34) 100%);
}
.introduction-section::after {
  z-index: -1;
  opacity: 0.07;
  mix-blend-mode: soft-light;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.45' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 240px 240px;
}
.introduction-section .section-inner {
  position: relative;
  z-index: 1;
}
@media screen and (min-width: 960px) {
  .introduction-section {
    margin-top: -80px;
    padding: 160px 0 160px;
  }
  .introduction-section::before {
    clip-path: polygon(0 80px, 100% 0, 100% 100%, 0 calc(100% - 80px));
  }
}

.introduction-body {
  max-width: 1000px;
  margin: 0 auto;
  position: relative;
  padding: 44px 28px 40px;
  background: rgba(255, 255, 255, 0.72);
  border: 1px solid rgba(93, 197, 255, 0.28);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 20px 48px rgba(12, 26, 66, 0.1), 0 4px 12px rgba(12, 26, 66, 0.04);
}
.introduction-body::after {
  content: "";
  position: absolute;
  inset: 14px;
  pointer-events: none;
  background: linear-gradient(#5dc5ff, #5dc5ff) left top/36px 2px no-repeat, linear-gradient(#5dc5ff, #5dc5ff) left top/2px 36px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/36px 2px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/2px 36px no-repeat;
  transition: opacity 0.35s ease;
}
@media screen and (min-width: 960px) {
  .introduction-body {
    padding: 56px 48px 52px;
  }
}

.introduction-head {
  margin-bottom: 15px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .introduction-head {
    margin-bottom: 44px;
  }
}

.introduction-tag {
  display: block;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  color: #4785EF;
  font-weight: 800;
  font-size: 1.05em;
  line-height: 1.5;
  padding: 0;
  margin-bottom: 0;
  transform: none;
  text-align: center;
  word-break: auto-phrase;
  letter-spacing: 0.04em;
}
@media screen and (min-width: 960px) {
  .introduction-tag {
    font-size: 1.15em;
    margin-bottom: 0px;
    letter-spacing: 0.06em;
  }
}

.introduction-lead {
  display: block;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  margin-top: 0;
  margin-bottom: 8px;
  font-weight: 800;
  font-size: 1.6em;
  line-height: 1.4;
  letter-spacing: 0.04em;
  color: #333;
  text-align: center;
  padding: 0 10px;
}
@media screen and (min-width: 960px) {
  .introduction-lead {
    font-size: 2em;
    margin-bottom: 12px;
    letter-spacing: 0.08em;
  }
}

.introduction-quote-band {
  margin: 0;
  text-align: center;
}

.introduction-quote-band__text {
  display: inline-block;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  padding: 6px 16px;
  color: #4785EF;
  font-weight: 800;
  font-size: 1.6em;
  line-height: 1.6;
  letter-spacing: 0.04em;
  text-align: center;
  box-shadow: none;
  transform: skewX(-12deg);
}
.introduction-quote-band__text span {
  display: block;
  transform: skewX(12deg);
}
@media screen and (min-width: 960px) {
  .introduction-quote-band__text {
    font-size: 2em;
    padding: 0px 5px;
    line-height: 1.5;
    letter-spacing: 0.08em;
  }
}

.introduction-lead-accent {
  color: #fff;
}

.introduction-text {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-weight: 700;
  font-size: 0.95em;
  line-height: 2;
  letter-spacing: 0.04em;
  text-align: justify;
  color: #333;
}
@media screen and (min-width: 960px) {
  .introduction-text {
    font-size: 1em;
  }
}
.introduction-text p + p {
  margin-top: 0.95em;
}

.comment-section {
  position: relative;
  z-index: 1;
  margin-top: 0;
  padding: 24px 0 72px;
  background: transparent;
}
@media screen and (min-width: 960px) {
  .comment-section {
    padding: 48px 0 96px;
  }
}

.original-section {
  position: relative;
  z-index: 1;
  padding: 10px 0 60px;
  background: transparent;
}
@media screen and (min-width: 960px) {
  .original-section {
    padding: 96px 0 120px;
  }
}

.section-inner {
  position: relative;
  z-index: 1;
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0 20px;
}
@media screen and (min-width: 960px) {
  .section-inner {
    padding: 0 40px;
  }
}

.contents-ttl {
  text-align: center;
  margin: 0 0 28px;
  isolation: isolate;
}
@media screen and (min-width: 960px) {
  .contents-ttl {
    margin-bottom: 44px;
  }
}
.contents-ttl::after {
  display: none;
  content: none;
}

.site-body-cyan .contents-ttl-label {
  color: #fcf150;
}
.site-body-cyan .contents-ttl-label::before {
  border-color: transparent transparent rgba(255, 255, 255, 0.22) transparent;
}
.site-body-cyan .contents-ttl-label::after {
  border-color: transparent transparent rgba(240, 216, 48, 0.5) transparent;
}

.contents-ttl-label {
  display: inline-block;
  position: relative;
  margin-bottom: 0;
  padding: 50px 40px 18px;
  text-align: center;
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 1.65em;
  line-height: 1;
  color: #5dc5ff;
  text-transform: uppercase;
  letter-spacing: 7px;
}
@media screen and (min-width: 960px) {
  .contents-ttl-label {
    font-size: 2.3em;
    letter-spacing: 9px;
    padding: 50px 52px 20px 40px;
  }
}
.contents-ttl-label::before {
  content: "";
  position: absolute;
  z-index: -1;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 110px 80px;
  border-color: transparent transparent rgba(233, 30, 140, 0.32) transparent;
  transform: rotate(30deg);
  top: -20px;
  left: 30px;
  pointer-events: none;
}
.contents-ttl-label::after {
  content: "";
  position: absolute;
  z-index: -1;
  width: 0;
  height: 80px;
  border-style: solid;
  border-width: 80px 0 30px 50px;
  border-color: transparent transparent rgba(90, 172, 232, 0.38) transparent;
  transform: rotate(40deg);
  bottom: 0;
  right: 30px;
  left: auto;
  top: auto;
  margin: auto;
  pointer-events: none;
}

.contents-ttl-label--sub {
  font-size: 0.78em;
  letter-spacing: 0.06em;
  padding: 36px 36px 14px 28px;
}
@media screen and (min-width: 960px) {
  .contents-ttl-label--sub {
    font-size: 0.82em;
    letter-spacing: 0.08em;
    padding: 38px 40px 16px 28px;
  }
}
.contents-ttl-label--sub::before {
  border-width: 0 0 80px 58px;
  top: -14px;
  left: 22px;
  transform: rotate(30deg);
}
.contents-ttl-label--sub::after {
  height: 58px;
  border-width: 58px 0 22px 36px;
  border-color: transparent transparent rgba(90, 172, 232, 0.38) transparent;
  bottom: 0;
  right: 22px;
  left: auto;
  top: auto;
  transform: rotate(40deg);
}

.comment-item {
  position: relative;
  border: 1px solid rgba(93, 197, 255, 0.24);
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 20px 48px rgba(12, 26, 66, 0.1), 0 4px 12px rgba(12, 26, 66, 0.04);
  transition: transform 0.4s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.35s ease;
  max-width: none;
  margin: 0 auto 28px;
  padding: 44px 28px 40px;
}
.comment-item:nth-of-type(1) {
  border-color: rgba(93, 197, 255, 0.28);
}
.comment-item:nth-of-type(2) {
  border-color: rgba(233, 30, 140, 0.2);
}
.comment-item:nth-of-type(3) {
  border-color: rgba(240, 216, 48, 0.28);
}
.comment-item::after {
  content: "";
  position: absolute;
  inset: 14px;
  pointer-events: none;
  background: linear-gradient(#5dc5ff, #5dc5ff) left top/36px 2px no-repeat, linear-gradient(#5dc5ff, #5dc5ff) left top/2px 36px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/36px 2px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/2px 36px no-repeat;
  transition: opacity 0.35s ease;
}
@media screen and (min-width: 960px) {
  .comment-item {
    padding: 56px 48px 52px;
    margin-bottom: 32px;
  }
  .comment-item:hover {
    transform: translateY(-2px);
    border-color: rgba(93, 197, 255, 0.38);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 28px 56px rgba(12, 26, 66, 0.13), 0 8px 18px rgba(12, 26, 66, 0.06);
  }
  .comment-item:hover::after {
    background: linear-gradient(#5dc5ff, #5dc5ff) left top/40px 2px no-repeat, linear-gradient(#5dc5ff, #5dc5ff) left top/2px 40px no-repeat, linear-gradient(rgba(233, 30, 140, 0.68), rgba(233, 30, 140, 0.68)) right bottom/40px 2px no-repeat, linear-gradient(rgba(233, 30, 140, 0.68), rgba(233, 30, 140, 0.68)) right bottom/2px 40px no-repeat;
  }
}
.comment-item:last-child {
  margin-bottom: 0;
}

.comment-name {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 1.25em;
  font-weight: 800;
  text-align: center;
  margin: 0 0 20px;
  padding: 0 0 16px;
  border-bottom: dotted 2px #4785EF;
  color: #4785EF;
  line-height: 1.5;
}
.comment-name ruby {
  ruby-align: center;
}
.comment-name rt {
  font-size: 0.45em;
  font-weight: 700;
  letter-spacing: 0.04em;
  opacity: 0.92;
  padding-bottom: 0.2em;
}
@media screen and (min-width: 960px) {
  .comment-name {
    font-size: 1.35em;
    text-align: center;
  }
}

.comment-name-sub {
  font-size: 0.78em;
  font-weight: 700;
}

.original-section .original-info {
  margin-top: 0;
}

.original-info-main {
  position: relative;
  display: flex;
  flex-direction: column;
  background: rgba(254, 252, 232, 0.7019607843);
  border: 1px solid rgba(93, 197, 255, 0.24);
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 20px 48px rgba(12, 26, 66, 0.1), 0 4px 12px rgba(12, 26, 66, 0.05);
  padding: 40px 24px 36px;
  overflow: visible;
  transition: box-shadow 0.4s cubic-bezier(0.22, 1, 0.36, 1), border-color 0.35s ease;
}
.original-info-main::after {
  content: "";
  position: absolute;
  inset: 14px;
  pointer-events: none;
  background: linear-gradient(#5dc5ff, #5dc5ff) left top/36px 2px no-repeat, linear-gradient(#5dc5ff, #5dc5ff) left top/2px 36px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/36px 2px no-repeat, linear-gradient(rgba(233, 30, 140, 0.5), rgba(233, 30, 140, 0.5)) right bottom/2px 36px no-repeat;
  transition: opacity 0.35s ease;
}
@media screen and (min-width: 960px) {
  .original-info-main {
    display: grid;
    grid-template-columns: 280px 1fr;
    grid-template-rows: auto auto;
    column-gap: 52px;
    row-gap: 36px;
    align-items: center;
    padding: 52px 44px 48px;
    background: #fefce8;
    border: 1px solid rgba(93, 197, 255, 0.24);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 20px 48px rgba(12, 26, 66, 0.1);
    overflow: visible;
  }
  .original-info-main:hover {
    border-color: rgba(93, 197, 255, 0.38);
    box-shadow: 0 1px 0 rgba(255, 255, 255, 0.95) inset, 0 28px 56px rgba(12, 26, 66, 0.13), 0 8px 18px rgba(12, 26, 66, 0.06);
  }
  .original-info-main:hover::after {
    background: linear-gradient(#5dc5ff, #5dc5ff) left top/40px 2px no-repeat, linear-gradient(#5dc5ff, #5dc5ff) left top/2px 40px no-repeat, linear-gradient(rgba(233, 30, 140, 0.68), rgba(233, 30, 140, 0.68)) right bottom/40px 2px no-repeat, linear-gradient(rgba(233, 30, 140, 0.68), rgba(233, 30, 140, 0.68)) right bottom/2px 40px no-repeat;
  }
}

.original-info-book {
  display: flex;
  flex-direction: column;
  align-items: center;
  order: -1;
  margin: 0 0 24px;
}
@media screen and (min-width: 960px) {
  .original-info-book {
    order: 0;
    grid-column: 1;
    grid-row: 1;
    margin: 0;
    align-items: center;
    align-self: center;
    justify-content: center;
  }
}

.original-info-content {
  display: flex;
  flex-direction: column;
}
@media screen and (min-width: 960px) {
  .original-info-content {
    grid-column: 2;
    grid-row: 1;
    align-self: center;
    justify-content: center;
    min-width: 0;
  }
}

.original-info-text {
  max-width: 520px;
  margin: 0 auto;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-weight: 700;
  font-size: 0.95em;
  line-height: 2.05;
  text-align: justify;
}
@media screen and (min-width: 960px) {
  .original-info-text {
    max-width: none;
    margin: 0 0 30px;
    font-size: 0.96em;
    line-height: 1.85;
    color: #2a2a2a;
  }
}

.original-info-cover {
  max-width: 200px;
  margin: 0 auto;
  width: 100%;
}
@media screen and (min-width: 960px) {
  .original-info-cover {
    max-width: none;
    width: 280px;
    margin: 0;
    position: relative;
    z-index: 1;
  }
}
.original-info-cover img {
  display: block;
}
@media screen and (min-width: 960px) {
  .original-info-cover img {
    transition: box-shadow 0.35s ease;
  }
}

.original-info-copyright {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.68em;
  font-weight: 500;
  text-align: center;
  margin: 10px 0 0;
  color: #5c5c5c;
}
@media screen and (min-width: 960px) {
  .original-info-copyright {
    width: 100%;
    margin-top: 8px;
    font-size: 0.62em;
    color: #737373;
  }
}

.original-info-meta {
  width: 100%;
  margin: 0 0 18px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .original-info-meta {
    margin: 0 0 14px;
    text-align: left;
  }
}

.original-info-label {
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.72em;
  font-weight: 800;
  letter-spacing: 0.14em;
  margin: 0 0 4px;
  color: #737373;
}
@media screen and (min-width: 960px) {
  .original-info-label {
    margin-bottom: 6px;
    color: #737373;
  }
}

.original-info-title {
  margin: 0 0 8px;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 1.05em;
  font-weight: 800;
  line-height: 1.45;
  color: #1a1a1a;
}
@media screen and (min-width: 960px) {
  .original-info-title {
    margin-bottom: 10px;
    font-size: 1.12em;
    color: #1a1a1a;
  }
}
.original-info-title a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: inherit;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: all 0.2s ease;
}
.original-info-title a i {
  font-size: 0.8em;
  text-decoration: none;
}
.original-info-title a:hover {
  color: #e91e8c;
  opacity: 1;
}

.original-info-details {
  display: flex;
  flex-direction: column;
  gap: 0;
}
@media screen and (min-width: 960px) {
  .original-info-details {
    flex-direction: row;
    flex-wrap: wrap;
    gap: 4px 20px;
  }
}

.original-info-detail {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.82em;
  font-weight: 700;
  line-height: 1.65;
  margin: 0;
  color: #1a1a1a;
}
@media screen and (min-width: 960px) {
  .original-info-detail {
    font-size: 0.8em;
    font-weight: 500;
    line-height: 1.6;
    color: #333;
  }
}

.original-info-cta {
  text-align: center;
  margin: 24px 0 0;
}
@media screen and (min-width: 960px) {
  .original-info-cta {
    margin: 0;
    text-align: center;
  }
}

.original-info-trial-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  max-width: 420px;
  padding: 16px 36px;
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 1em;
  font-weight: 800;
  letter-spacing: 0.08em;
  line-height: 1.4;
  color: #fff;
  background: #4785EF;
  text-decoration: none;
  transition: all 0.35s ease;
}
@media screen and (min-width: 960px) {
  .original-info-trial-link {
    width: auto;
    min-width: 260px;
    max-width: 380px;
    padding: 12px 40px;
    font-size: 0.9em;
    letter-spacing: 0.06em;
  }
}
.original-info-trial-link i {
  margin-left: 8px;
  font-size: 0.78em;
  opacity: 0.7;
}
.original-info-trial-link:hover {
  color: #1a1a1a;
  filter: brightness(1.04);
  background: #fcf150;
}

.comment-text {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-weight: 700;
  font-size: 0.92em;
  line-height: 2.05;
  text-align: justify;
  color: #333;
}
@media screen and (min-width: 960px) {
  .comment-text {
    font-size: 0.98em;
    line-height: 2;
  }
}
.comment-text p + p {
  margin-top: 0.65em;
}

.original-info {
  width: 100%;
  max-width: 1000px;
  margin: 0 auto;
  padding: 0;
  background: rgba(255, 255, 255, 0.8);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  box-shadow: none;
}

.original-info-comment {
  margin-top: 28px;
  padding-top: 24px;
}
@media screen and (min-width: 960px) {
  .original-info-comment {
    grid-column: 1/-1;
    grid-row: 2;
    align-self: stretch;
    width: 100%;
    margin-top: 0;
    padding-top: 28px;
  }
}
.original-info-comment .comment-name {
  margin-bottom: 0;
  padding-bottom: 12px;
  text-align: center;
}
@media screen and (min-width: 960px) {
  .original-info-comment .comment-text {
    color: #333;
  }
}

.original-comment-label {
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  margin: 20px 0 12px;
  font-size: 1.15em;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #4686ef;
}

/*-------------------------------

#footer

-------------------------------*/
#footer {
  position: relative;
  z-index: 1;
  padding: 40px 20px 48px;
  background: #4785ef;
  border-top: none;
}
@media screen and (min-width: 960px) {
  #footer {
    padding: 48px 20px 56px;
  }
}

.share-ttl {
  margin: 0 0 20px;
}
.share-ttl.contents-ttl {
  margin: 0 0 20px;
}
.share-ttl::after {
  display: none;
  content: none;
}
.share-ttl .contents-ttl-label {
  font-size: 1.2em;
  letter-spacing: 9px;
  padding: 50px 40px 18px;
  color: #fff;
}
@media screen and (min-width: 960px) {
  .share-ttl .contents-ttl-label {
    font-size: 1.2em;
    letter-spacing: 9px;
    padding: 50px 52px 20px 40px;
  }
}
.share-ttl .contents-ttl-label::before {
  border-width: 0 0 110px 80px;
  top: -20px;
  left: 30px;
  transform: rotate(30deg);
  border-color: transparent transparent rgba(255, 255, 255, 0.2) transparent;
}
.share-ttl .contents-ttl-label::after {
  height: 80px;
  border-width: 80px 0 30px 50px;
  bottom: 0;
  right: 30px;
  left: auto;
  top: auto;
  transform: rotate(40deg);
  border-color: transparent transparent rgba(240, 216, 48, 0.45) transparent;
}

#footer #social-container {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  gap: 28px;
  margin: 0 auto;
  max-width: none;
  padding: 0;
  background: transparent;
  border: none;
  box-shadow: none;
}
#footer #social-container .share-link-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: auto;
  height: auto;
  color: #fff;
  background: transparent;
  font-size: 26px;
  border: none;
  border-radius: 0;
  box-shadow: none;
  opacity: 1;
  transition: opacity 0.25s ease;
}
#footer #social-container .share-link-btn:hover {
  color: #fff;
  background: transparent;
  opacity: 0.7;
  filter: none;
  box-shadow: none;
  transform: none;
}
#footer #social-container .share-link-btn.custom-facebook-btn {
  font-size: 28px;
}
#footer #social-container .share-link-btn.custom-line-btn {
  font-size: 30px;
}

.copyright {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  font-size: 0.68em;
  font-weight: 500;
  text-align: center;
  margin: 16px auto 0;
  color: #4d4d4d;
  line-height: 1.45;
}

/*-------------------------------

#news

-------------------------------*/
.news-section {
  position: relative;
  z-index: 1;
  padding: 0 0 48px;
  background: transparent;
}

.news-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 36px;
  margin-bottom: 0;
  padding: 0;
}

.news-feed {
  flex: 1;
  min-width: 0;
  margin: 0;
  padding: 0;
  list-style: none;
  border-top: 1px solid rgba(252, 241, 80, 0.65);
}

.news-item {
  display: block;
  position: relative;
  padding: 22px 0;
  color: #fff;
  line-height: 1.65;
  text-decoration: none;
  border-bottom: 1px solid rgba(252, 241, 80, 0.65);
  transition: opacity 0.25s ease;
}
.news-item:hover {
  opacity: 0.88;
}

.news-meta-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 10px 14px;
  margin-bottom: 12px;
}

.news-date {
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  flex-shrink: 0;
  margin: 0;
  padding: 0;
  font-size: 0.78em;
  font-weight: 700;
  letter-spacing: 0.06em;
  color: rgba(252, 241, 80, 0.92);
  background: transparent;
}

.news-cat {
  font-family: "Noto Sans JP", "源ノ角ゴシック", "Hiragino Sans", "Hiragino Kaku Gothic ProN", "Yu Gothic Medium", "游ゴシック Medium", Meiryo, sans-serif;
  font-weight: 700;
  display: inline-block;
  margin: 0;
  padding: 4px 10px;
  font-size: 0.68em;
  font-weight: 700;
  line-height: 1.4;
  letter-spacing: 0.04em;
  color: #fff;
  background: #0c1a42;
  display: none;
}

.news-body-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.news-txt {
  flex: 1;
  min-width: 0;
  margin: 0;
  color: #fff;
  font-size: 0.95em;
  font-weight: 700;
  line-height: 1.7;
}
@media screen and (min-width: 960px) {
  .news-txt {
    font-size: 1rem;
  }
}

.news-arrow {
  flex-shrink: 0;
  display: block;
  width: 0;
  height: 0;
  margin-top: 2px;
  border-style: solid;
  border-width: 6px 0 6px 10px;
  border-color: transparent transparent transparent #fcf150;
  transition: transform 0.25s ease;
}
.news-item:hover .news-arrow {
  transform: translateX(4px);
}

.news-btn {
  font-family: "Rubik", sans-serif;
  font-weight: 800;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  font-size: 0.75em;
  font-weight: 700;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  background: transparent;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: auto;
  min-width: 180px;
  border: 1px solid #fcf150;
  border-radius: 0;
  margin: 0 auto;
  padding: 12px 24px;
  color: #fcf150;
  text-align: center;
  text-decoration: none;
  flex-shrink: 0;
  align-self: center;
  box-shadow: none;
  outline: none;
  transition: background 0.25s ease, color 0.25s ease, border-color 0.25s ease;
}
@media screen and (min-width: 960px) {
  .news-btn {
    min-width: 200px;
    padding: 14px 28px;
  }
  .news-btn:hover {
    background: #fcf150;
    color: #0c1a42;
    border-color: #fcf150;
  }
}

/*-------------------------------

#trailer

-------------------------------*/
#trailer {
  padding: 0 0 50px 0;
  position: relative;
  z-index: 2;
  text-align: center;
}
#trailer #movie-nav {
  justify-content: center;
}
@media screen and (min-width: 960px) {
  #trailer {
    padding: 30px 0;
  }
}

#trailer .ttl {
  color: #ffffff;
  text-align: center;
  text-shadow: 0 0 10px rgba(122, 226, 255, 0.8), 0 0 20px rgba(122, 226, 255, 0.4), 2px 2px 4px rgba(0, 0, 0, 0.8);
}
#trailer .ttl .jp-ttl {
  color: #ffffff;
}

.pc-modal-movie, .pc {
  display: none;
}

.sp {
  display: block;
}

#movie-container {
  width: 100%;
  margin: 0 auto;
  padding: 0 0 30px;
  opacity: 0;
  transition: opacity 0.6s ease;
}
#movie-container.swiper-container-horizontal {
  opacity: 1;
}

.movie-thumb-box {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border: 1px solid rgba(252, 240, 80, 0.6431372549);
}
.movie-thumb-box img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

.youtube {
  width: 100%;
  height: auto;
  aspect-ratio: 16/9;
}
.movie-thumb-list li {
  width: 100%;
  padding: 0 10px;
}

.movie-cap {
  padding: 15px 0 5px;
  text-align: center;
  color: #fff;
  font-size: 0.95em;
  font-weight: bold;
}

.play-icon {
  color: #e60027;
  width: 52px;
  height: 58px;
  font-size: 60px;
  position: absolute;
  top: 0px;
  left: 0px;
  right: 0px;
  bottom: 0px;
  margin: auto;
  display: block;
  line-height: 1em;
}

.movie-thumb-box:hover .play-icon {
  opacity: 0.8;
}

.movie-thumb-list .slider-arrow {
  position: absolute;
  top: 50%;
  height: 60px;
  margin-top: -50px;
  color: #aaa;
  line-height: 36px;
  font-size: 28px;
  cursor: pointer;
  width: 30px;
  z-index: 10;
}
.movie-thumb-list .slider-arrow img {
  width: 100%;
}
.movie-thumb-list .slider-prev {
  left: 0;
}
.movie-thumb-list .slider-next {
  right: 0;
}

#trailer-play {
  padding: 30px;
}
#trailer-play a {
  transition: opacity 0.2s ease;
  opacity: 0.7;
}
#trailer-play a:hover {
  opacity: 1;
}

.btn-container li {
  position: relative;
  border: 1px solid #7f1e1e;
  border-radius: 50px;
  margin: 0 0 10px;
  padding: 7px 15px;
  text-align: center;
}
.btn-container li.new::after {
  content: "New";
  font-size: 0.8em;
  background: #7f1e1e;
  position: absolute;
  top: -4px;
  left: -4px;
  padding: 2px;
}
.btn-container li a {
  display: block;
  color: #fff;
  font-size: 20px;
  text-decoration: none;
  transition: color 0.3s ease;
}
.btn-container li a:hover {
  color: #7f1e1e;
}

.swiper-container {
  padding: 0 0 20px;
}

.swiper-pagination-bullet {
  opacity: 0.5;
  background: #ff639e;
}

.swiper-pagination-bullet-active {
  opacity: 1;
}

.swiper-button-next.swiper-button-white, .swiper-button-prev.swiper-button-white {
  --swiper-navigation-color: #ff639e;
}

.screen-container {
  width: 85%;
  margin: 0 auto;
  border: 1px solid #7ae2ff;
}
@media screen and (min-width: 960px) {
  .screen-container {
    width: 85%;
    max-width: 900px;
  }
}

#movie-nav {
  width: 88%;
  margin: 10px auto 0;
  justify-content: center;
  display: flex;
  flex-wrap: wrap;
}
@media screen and (min-width: 960px) {
  #movie-nav {
    max-width: 930px;
    margin: 20px auto 40px;
  }
}

.movie-nav-box {
  width: 45.5% !important;
  border: solid 1px #19c5c0;
  margin: 0.8% 1.5%;
  text-align: center;
  cursor: pointer;
  background: #fff;
  border-radius: 2px;
  display: flex;
  align-items: center;
  justify-content: center;
}
@media screen and (max-width: 960px) {
  .movie-nav-box:first-child {
    width: 94% !important;
  }
}
.movie-nav-box a {
  display: block;
  color: #19c5c0;
  padding: 7px;
  font-size: 0.9em;
  line-height: 1.5;
}
@media screen and (min-width: 960px) {
  .movie-nav-box a {
    font-size: 0.75em;
    padding: 10px 5px;
  }
}
@media screen and (min-width: 960px) {
  .movie-nav-box {
    width: 23% !important;
    margin: 6px;
  }
  .movie-nav-box:hover a {
    color: #19c5c0;
  }
}

.movie-nav-box.selected {
  background: #19c5c0;
}
.movie-nav-box.selected a {
  color: #fff;
  font-weight: bold;
}

#cboxOverlay {
  background: rgb(71, 133, 239);
}

/* PC */
@media screen and (min-width: 1024px) {
  .pc {
    display: block;
  }
  .sp {
    display: none;
  }
  #trailer {
    margin: 0 auto;
    padding: 60px 0;
    width: 90%;
    max-width: 1440px;
  }
  .pc-modal-movie {
    content: "";
    position: absolute;
    display: block;
    width: 100%;
    height: 100%;
  }
}/*# sourceMappingURL=style.css.map */