@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Noto+Serif+JP:wght@200..900&display=swap");
body {
  font-size: 16px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  line-height: 1.75em;
  color: #464646; }

h1,
h2,
h3,
h4,
h5,
h6,
input,
button {
  font-size: 18px;
  font-family: "Noto Serif JP", serif;
  font-weight: 500;
  line-height: 1.75em; }

.strong {
  font-size: 1.2em;
  line-height: 1.75em; }

.bld {
  font-weight: bold; }

.catch-head {
  font-size: 1.5em;
  line-height: 1.75em; }

#story .story-head {
  font-size: 2em; }
#story p {
  font-size: 1.2em; }

.how-head {
  font-size: 1.2em; }

.sche-head {
  font-size: 1.5em; }

.fee-strong {
  font-size: 1.8em; }

.pur-head {
  font-size: 1.5em; }

.ac-head {
  font-size: 1.5em; }

.btn-wh {
  font-size: 1.5em; }

.copy-text {
  font-size: .8em; }

table .min {
  font-size: 14px; }

.howto-in .min {
  font-size: .8em;
  line-height: 1.5; }

@media screen and (max-width: 540px) {
  body {
    font-size: 16px;
    font-family: "Noto Serif JP", serif;
    font-weight: 500;
    line-height: 1.75em; }

  .btn-wh {
    font-size: 1.2em; }

  .strong {
    font-size: 1.1em; }

  table {
    font-size: 14px; }
    table .min {
      font-size: 10px; }

  .sche-head {
    font-size: 1.3em; }

  .catch-head {
    font-size: 1.2em; }

  #story .story-head {
    font-size: 1.5em; }

  .fee-strong {
    font-size: 1.3em; }

  .pur-head {
    font-size: 1.2em; }

  .ac-head {
    font-size: 1.2em; }

  #story p {
    font-size: 1em; } }
@keyframes fadeUpAnime {
  0% {
    opacity: 0;
    transform: translateY(100px); }
  100% {
    opacity: 1;
    transform: translateY(0); } }
.fade {
  opacity: 0; }

.fadeUp {
  animation-name: fadeUpAnime;
  animation-duration: 1s;
  animation-fill-mode: forwards;
  opacity: 0; }

html,
body {
  width: 100%;
  overflow-x: hidden; }

.bg-wrap {
  background: linear-gradient(90deg, #c9d6eb 0%, #e6f1f7 10%, white 25%, white 50%, white 75%, #e6f1f7 90%, #c9d6eb 100%);
  padding-bottom: 120px;
  position: relative;
  z-index: 1; }

header {
  width: 100%;
  position: relative;
  z-index: 1; }

img {
  width: 100%;
  height: auto;
  display: block;
  margin: 0 auto; }

.inner-wrap {
  padding: 0 1em;
  width: calc(100% - 2em);
  max-width: 1200px;
  margin: 0 auto; }

section {
  padding: 120px 0 0;
  margin: 0 auto;
  position: relative;
  z-index: 0; }

.sns-btn {
  position: fixed;
  right: 1em;
  bottom: 250px;
  max-width: 40px;
  z-index: 10; }
  .sns-btn a {
    width: 40px;
    height: 40px;
    display: block;
    border: solid 1px #fff;
    border-radius: 40px;
    margin-bottom: .5em;
    transition-duration: .3s; }
    .sns-btn a.ico-x {
      background: #000; }
    .sns-btn a.ico-line {
      background: #00C300; }
    .sns-btn a.ico-fb {
      background: #1877F2; }
    .sns-btn a:hover.ico-x {
      background: rgba(0, 0, 0, 0); }
    .sns-btn a:hover.ico-line {
      background: rgba(0, 0, 0, 0); }
    .sns-btn a:hover.ico-fb {
      background: rgba(0, 0, 0, 0); }

.ti-fix-btn {
  position: fixed;
  right: .5em;
  bottom: .5em;
  max-width: 120px;
  z-index: 5;
  transition-duration: .3s; }
  .ti-fix-btn:hover {
    opacity: .8; }
  .ti-fix-btn .sp {
    display: none; }
  .ti-fix-btn .pc {
    filter: drop-shadow(0px 0px 4px #fff); }

.text-link {
  text-decoration: underline;
  color: #8d9bf7;
  cursor: pointer; }
  .text-link:hover {
    text-decoration: none; }

.head-box {
  max-width: 800px;
  margin: 0 auto; }

.fix-bg {
  background: #181942;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  pointer-events: none; }
  .fix-bg::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 500px;
    background: url(../images/bg-top.webp);
    background-position: center top;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1; }
  .fix-bg::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(../images/bg.webp);
    background-position: center top;
    background-repeat: repeat-y;
    background-size: 1920px 3426px;
    z-index: -1;
    mix-blend-mode: overlay;
    opacity: .5; }
  .fix-bg .fix-bg-bottom {
    position: absolute;
    left: 0;
    bottom: 0;
    width: 100%;
    height: 500px;
    background: url(../images/bg-bottom.webp);
    background-position: center bottom;
    background-repeat: no-repeat;
    background-size: cover;
    z-index: -1; }

.menu-btn {
  width: 120px;
  position: fixed;
  right: .5em;
  top: .5em;
  cursor: pointer;
  filter: drop-shadow(0px 0px 4px #1ed9f0);
  z-index: 21;
  transition-duration: .3s; }
  .menu-btn:hover {
    filter: drop-shadow(0px 0px 0 #1ed9f0); }

#menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 20;
  background: #0f1441;
  display: none; }
  #menu::after {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(../images/bg.webp);
    background-position: center top;
    background-repeat: repeat-y;
    background-size: 1920px 3426px;
    z-index: -1;
    mix-blend-mode: overlay;
    opacity: .5; }
  #menu .menu-list {
    position: absolute;
    max-width: 500px;
    width: calc(100% - 4em);
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%); }
    #menu .menu-list li {
      padding: 1em;
      margin-bottom: 1em;
      border-bottom: solid 1px #fff;
      position: relative;
      width: calc(100% - 2em); }
      #menu .menu-list li::before {
        content: "";
        position: absolute;
        width: 10px;
        height: 10px;
        border: solid 1px #fff;
        transform: rotate(45deg);
        left: 0;
        bottom: -6px;
        z-index: 1;
        background: #fff; }
      #menu .menu-list li::after {
        content: "";
        position: absolute;
        width: 10px;
        height: 10px;
        border: solid 1px #fff;
        transform: rotate(45deg);
        right: 0;
        bottom: -6px;
        z-index: 1;
        background: #fff; }
    #menu .menu-list a {
      color: #fff;
      display: block;
      text-align: center; }

#catch {
  text-align: center;
  padding-bottom: 120px; }
  #catch .head-box {
    max-width: 700px; }
  #catch .sp {
    display: none; }

/* 
.slid-box {

  .slide-swiper {
    padding-bottom: 50px;
  }

  .swiper-slide {
    padding: 12px 0;
    filter: drop-shadow(0px 4px 2px #dcdddd);
    transition-duration: .8s;

    .swiper-slide-in {
      border: solid #dcf6fb 1px;
    }
  }
} */
#about {
  text-align: center; }
  #about .whats-flex {
    display: flex;
    align-items: center;
    max-width: 1000px;
    margin: 40px auto; }
    #about .whats-flex .btn-wh {
      width: calc(48% - 2em - 2px);
      margin: 1%;
      cursor: pointer;
      filter: drop-shadow(4px 4px 4px rgba(0, 0, 0, 0.5));
      background: rgba(0, 75, 219, 0.5);
      padding: 1.5em 1em;
      color: #fff;
      border: solid 1px #fff;
      position: relative;
      transition-duration: .3s; }
      #about .whats-flex .btn-wh::after {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: url(../images/bg.webp);
        background-position: center top;
        background-repeat: repeat;
        background-size: 100%;
        z-index: -1;
        mix-blend-mode: overlay;
        opacity: .5; }
      #about .whats-flex .btn-wh:hover {
        filter: drop-shadow(0px 0px 0px rgba(0, 0, 0, 0.5)); }

#point {
  padding-top: 60px; }
  #point .point-flex {
    display: flex;
    align-items: center;
    text-align: center;
    max-width: 1000px;
    margin: 0 auto 20px; }
    #point .point-flex:nth-of-type(odd) {
      flex-direction: row-reverse; }
    #point .point-flex .col-l {
      width: 48%;
      margin: 1%; }
    #point .point-flex .col-r {
      width: 48%;
      margin: 1%; }
  #point .point-item {
    display: flex;
    max-width: 600px;
    justify-content: space-between;
    margin: 20px auto 80px; }
    #point .point-item picture {
      width: 28%;
      margin: 1%; }

#special .mv {
  display: flex; }
  #special .mv .yoko {
    width: 73%;
    margin: 1%; }
    #special .mv .yoko iframe {
      width: 100%;
      height: 100%;
      aspect-ratio: 16 / 9; }
    #special .mv .yoko.col-1 {
      width: 100%;
      margin: 0 auto;
      max-width: 700px; }
  #special .mv .tate {
    width: 23%;
    margin: 1%; }
    #special .mv .tate iframe {
      width: 100%;
      height: 100%;
      aspect-ratio: 9 / 16; }
#special .bnr-flex {
  display: flex;
  align-items: center; }
  #special .bnr-flex a {
    width: 48%;
    margin: 1%;
    display: block; }
  #special .bnr-flex.col-1 a {
    max-width: 500px;
    margin: 1em auto; }

#story {
  position: relative;
  max-width: 100%;
  padding-bottom: 240px;
  color: #fff;
  text-align: center; }
  #story p {
    margin-bottom: 2rem; }
  #story hr {
    border: 0;
    border-top: solid 1px #fff;
    margin-bottom: 2em;
    mix-blend-mode: overlay; }
  #story .story-text {
    display: none; }
  #story .more-btn {
    width: fit-content;
    margin: 0 auto;
    border-top: solid 1px #fff;
    width: 90%;
    max-width: 420px;
    cursor: pointer; }
    #story .more-btn legend {
      position: relative;
      padding: 0 3em 0; }
      #story .more-btn legend:after {
        content: "▼";
        width: 1em;
        height: 1em;
        position: absolute;
        right: 1em;
        top: 0;
        z-index: 1; }
      #story .more-btn legend.ac-active:after {
        content: "▲"; }
  #story .story-bg-bottom {
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 200px;
    background: url(../images/chara-top.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
    z-index: 3;
    pointer-events: none; }

#chara {
  background: #fff;
  padding-bottom: 0;
  padding-top: 0; }
  #chara .chara-box {
    position: relative;
    z-index: 1;
    padding: 0 1em;
    width: calc(100% - 2em); }
    #chara .chara-box::before {
      content: "";
      background: #c0f1f5;
      width: 100%;
      height: 50%;
      position: absolute;
      top: 50%;
      left: 0;
      transform: translateY(-50%);
      z-index: -1; }
    #chara .chara-box.chara-box2:before {
      background: #c2d5e1; }
    #chara .chara-box::after {
      content: "";
      position: absolute;
      top: 50%;
      left: 0;
      transform: translateY(-50%);
      width: 100%;
      height: 50%;
      background: url(../images/bg.webp);
      background-position: center;
      background-repeat: repeat;
      background-size: 50%;
      z-index: -1;
      mix-blend-mode: overlay;
      opacity: .5; }
  #chara .chara-flex {
    max-width: 1200px;
    display: flex;
    align-items: center;
    margin: 0 auto;
    position: relative;
    z-index: 2; }
    #chara .chara-flex .chara-item {
      width: 31%;
      margin: 1%;
      position: relative;
      cursor: pointer;
      transition-duration: .3s; }
      #chara .chara-flex .chara-item:hover {
        transform: scale(1.1); }
      #chara .chara-flex .chara-item .chara-name {
        position: absolute;
        width: 60%;
        left: 0;
        bottom: 5%;
        z-index: 1;
        cursor: pointer;
        transition-duration: .3s; }

.chara-pop {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 25;
  display: none; }
  .chara-pop .pop-in {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 1;
    max-width: 600px;
    width: 90%; }
    .chara-pop .pop-in .close-btn {
      position: absolute;
      right: 0;
      top: -40px;
      width: 30px;
      height: 30px;
      cursor: pointer; }
    .chara-pop .pop-in:before {
      content: "";
      position: absolute;
      left: -5%;
      top: -25%;
      width: 55%;
      height: 150%;
      z-index: 5; }
    .chara-pop .pop-in.fern:before {
      background-image: url(../images/chara-1.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in.frieren:before {
      background: url(../images/chara-2.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in.stark:before {
      background: url(../images/chara-3.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in.heiter:before {
      background: url(../images/chara-4.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in.himmel:before {
      background: url(../images/chara-5.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in.eisen:before {
      background: url(../images/chara-6.webp);
      background-position: center;
      background-repeat: no-repeat;
      background-size: contain; }
    .chara-pop .pop-in .pop-box {
      border-radius: 16px;
      border: solid 1px #1ed9f0;
      overflow: hidden;
      background: #fff; }
    .chara-pop .pop-in .pop-desc {
      padding: 1em; }
      .chara-pop .pop-in .pop-desc .desc-in {
        width: 48%;
        margin-left: auto; }
    .chara-pop .pop-in .pop-head {
      padding: 1.5em;
      background: #004bdb;
      position: relative;
      z-index: 0; }
      .chara-pop .pop-in .pop-head .head-in {
        width: 48%;
        margin-left: auto; }
      .chara-pop .pop-in .pop-head span {
        filter: drop-shadow(0 0 2px #67d7ee);
        color: #fff;
        font-size: 1.5em; }
      .chara-pop .pop-in .pop-head::before {
        content: "";
        position: absolute;
        left: 0;
        top: 0;
        width: 100%;
        height: 100%;
        background: url(../images/bg.webp);
        background-position: center top;
        background-repeat: repeat;
        background-size: 50%;
        z-index: -1;
        mix-blend-mode: overlay;
        opacity: .5; }

#howtoplay {
  padding-top: 180px;
  position: relative; }
  #howtoplay::before {
    content: "";
    position: absolute;
    left: 0;
    top: -5px;
    width: 100%;
    height: 200px;
    background: url(../images/chara-bottom.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
    z-index: 3; }
  #howtoplay .how-wrap {
    padding: 0 40px;
    width: calc(100% - 80px);
    position: relative; }
    #howtoplay .how-wrap .how-swiper {
      padding: 40px 5px;
      overflow: hidden; }
  #howtoplay .swiper-slide {
    height: auto; }
  #howtoplay .howto-item {
    padding: 1em;
    border: solid 1px #67d7ee;
    position: relative;
    background: #fff;
    width: calc(100% - 2em - 2px);
    height: 100%;
    filter: drop-shadow(0 0px 4px #67d7ee); }
    #howtoplay .howto-item .step {
      position: absolute;
      left: -1em;
      top: calc(-50px - .5em);
      width: 200px; }
    #howtoplay .howto-item .howto-ima {
      margin: 20px auto;
      width: 80%; }
    #howtoplay .howto-item .how-head {
      margin: 2rem 0;
      padding-left: 2.25em;
      position: relative; }
      #howtoplay .howto-item .how-head:before {
        content: "";
        width: 2em;
        height: 2em;
        position: absolute;
        left: 0;
        top: -.25em;
        background: url(../images/ico-text.svg);
        background-repeat: no-repeat;
        background-size: contain;
        background-position: center; }
    #howtoplay .howto-item .ticket-link {
      background: #8d9bf7;
      border: solid 1px #8d9bf7;
      color: #fff;
      padding: 1em;
      display: block;
      margin: 1em auto;
      text-align: center;
      transition-duration: .3s; }
      #howtoplay .howto-item .ticket-link:hover {
        background: #fff;
        color: #8d9bf7; }
    #howtoplay .howto-item .howto-in .min {
      display: block;
      padding-left: 1em;
      position: relative; }
      #howtoplay .howto-item .howto-in .min::after {
        content: "※";
        position: absolute;
        left: 0;
        top: 0; }
  #howtoplay .swiper-btn {
    position: absolute;
    right: -5px;
    top: 50%;
    background: url(../images/arrow-rt.svg);
    background-size: contain;
    background-repeat: no-repeat;
    background-position: center;
    width: 35px;
    height: 35px;
    cursor: pointer;
    transition-duration: .3s; }
    #howtoplay .swiper-btn.swiper-prev {
      right: initial;
      left: -5px;
      transform: rotate(-180deg); }
    #howtoplay .swiper-btn.pc-no-active {
      opacity: 0;
      pointer-events: none; }
  #howtoplay .sankajyo {
    max-width: 680px;
    margin: 40px auto; }

#ticket {
  position: relative;
  max-width: 100%;
  padding-bottom: 240px;
  color: #fff;
  text-align: center; }
  #ticket .ti-head {
    max-width: 720px;
    margin: 40px auto; }
  #ticket .sche-head {
    background: #fff;
    position: relative;
    text-align: center;
    color: #464646;
    padding: .75em 2.5em;
    width: calc(100% - 5em);
    z-index: 0;
    max-width: 900px;
    margin: 0 auto 1em; }
    #ticket .sche-head::before {
      content: "";
      position: absolute;
      left: 0;
      top: 0;
      width: 1.5em;
      height: 100%;
      background: linear-gradient(90deg, #214ff5 0%, #00dfff 70%, #b1ffff 90%, white 100%); }
    #ticket .sche-head::after {
      content: "";
      position: absolute;
      right: 0;
      top: 0;
      width: 2em;
      height: 100%;
      background: linear-gradient(-90deg, #214ff5 0%, #00dfff 70%, #b1ffff 90%, white 100%); }
    #ticket .sche-head .sp {
      display: none; }
  #ticket .sche-item {
    max-width: 900px;
    margin: 80px auto 40px; }
    #ticket .sche-item .bnr-item {
      margin: 40px auto;
      max-width: 600px; }
      #ticket .sche-item .bnr-item p {
        margin-bottom: 1em; }
      #ticket .sche-item .bnr-item .fc-bnr {
        display: block;
        max-width: 480px;
        margin: 1em auto; }
  #ticket .fee-sel {
    display: flex;
    max-width: 450px;
    margin: 40px auto; }
    #ticket .fee-sel .fee-sel-btn {
      width: calc(44% - 2rem);
      padding: .5rem 1rem;
      border: solid 1px #fff;
      margin: 0 3%;
      position: relative;
      z-index: 0;
      cursor: pointer; }
      #ticket .fee-sel .fee-sel-btn.fee-active {
        background: #c1cbff;
        color: #464646; }
        #ticket .fee-sel .fee-sel-btn.fee-active::before {
          content: "";
          position: absolute;
          bottom: -42px;
          left: 50%;
          margin-left: -12px;
          border: 12px solid transparent;
          border-top: 32px solid #c1cbff;
          z-index: 2; }
        #ticket .fee-sel .fee-sel-btn.fee-active::after {
          content: "";
          position: absolute;
          bottom: -48px;
          left: 50%;
          margin-left: -14px;
          border: 14px solid transparent;
          border-top: 34px solid #fff;
          z-index: 1; }
  #ticket .fee-box {
    max-width: 900px;
    margin: 80px auto 40px;
    display: none; }
    #ticket .fee-box.fee-box1 {
      display: block; }
    #ticket .fee-box table {
      width: 100%;
      border-top: solid 1px #fff; }
      #ticket .fee-box table tr {
        border-bottom: solid 1px #fff; }
      #ticket .fee-box table th {
        border-right: solid 1px #fff;
        width: 33%;
        padding: 1em .5em;
        text-align: center; }
        #ticket .fee-box table th:last-child {
          border-right: 0; }
      #ticket .fee-box table td {
        border-right: solid 1px #fff;
        width: 33%;
        padding: 1em .5em;
        text-align: center; }
        #ticket .fee-box table td:last-child {
          border-right: 0; }
  #ticket .ti-notice-btn,
  #ticket .ti-btn {
    text-align: center;
    padding: .5em 1em;
    position: relative;
    background: #fff;
    border-radius: 50px;
    max-width: 520px;
    margin: 1em auto;
    color: #464646;
    cursor: pointer; }
    #ticket .ti-notice-btn:after,
    #ticket .ti-btn:after {
      content: "▼";
      position: absolute;
      right: 1em;
      top: 50%;
      transform: translateY(-50%);
      color: #c1cbff; }
    #ticket .ti-notice-btn.btn-active:after,
    #ticket .ti-btn.btn-active:after {
      content: "▲"; }
    #ticket .ti-notice-btn.ti-btn,
    #ticket .ti-btn.ti-btn {
      background: #8d9bf7;
      color: #fff; }
      #ticket .ti-notice-btn.ti-btn::after,
      #ticket .ti-btn.ti-btn::after {
        color: #fff; }
  #ticket .sp {
    display: none; }

.ti-notice {
  max-width: 900px;
  margin: 40px auto 0; }
  .ti-notice p {
    margin-bottom: 1em;
    border-bottom: solid 1px #fff;
    padding-bottom: 1em;
    text-align: left; }

.u22 {
  position: relative;
  background: #fff;
  color: #464646;
  max-width: 900px;
  margin: 160px auto 0;
  border-radius: 24px;
  padding: 1em; }
  .u22 .u22-ico {
    max-width: 200px;
    position: absolute;
    left: 0;
    right: 0;
    top: -70px;
    margin: 0 auto; }
  .u22 .u22-flex {
    display: flex;
    align-items: center; }
    .u22 .u22-flex .col-l {
      padding: 2em 1em;
      width: calc(80% - 2em - 1px);
      border-right: solid 1px #464646;
      text-align: left; }
    .u22 .u22-flex .col-r {
      padding: 2em 1em;
      width: calc(20% - 2em);
      text-align: center; }
      .u22 .u22-flex .col-r a {
        transition-duration: .3s; }
        .u22 .u22-flex .col-r a:hover {
          color: #8d9bf7; }

.forkids {
  position: relative;
  background: #fff;
  color: #464646;
  max-width: 900px;
  margin: 120px auto 0;
  border-radius: 24px;
  padding: 1em; }
  .forkids .kids-ico {
    max-width: 200px;
    position: absolute;
    left: 0;
    right: 0;
    top: -50px;
    margin: 0 auto; }
  .forkids .kids-flex {
    display: flex;
    align-items: center; }
    .forkids .kids-flex .col-l {
      padding: 2em 1em;
      width: calc(80% - 2em - 1px);
      border-right: solid 1px #464646;
      text-align: left; }
      .forkids .kids-flex .col-l p {
        margin-bottom: 1em; }
        .forkids .kids-flex .col-l p:last-of-type {
          margin-bottom: 0; }
    .forkids .kids-flex .col-r {
      padding: 2em 1em;
      width: calc(20% - 2em);
      text-align: center; }
      .forkids .kids-flex .col-r a {
        transition-duration: .3s; }
        .forkids .kids-flex .col-r a:hover {
          color: #8d9bf7; }

.bene-box {
  margin: 80px auto; }

.bene-item {
  max-width: 600px;
  background: #0f1441;
  padding: 1em;
  border-radius: 16px;
  margin: 40px auto;
  border: solid 1px #fff;
  position: relative;
  z-index: 1; }
  .bene-item::after {
    content: "";
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: url(../images/bene-bg.svg);
    background-size: contain;
    background-position: center;
    background-repeat: no-repeat;
    width: 75%;
    height: 75%;
    z-index: -1; }
  .bene-item .bene-ima {
    cursor: pointer;
    position: relative; }
    .bene-item .bene-ima:after {
      content: "";
      position: absolute;
      top: 5px;
      right: 5px;
      background: url(../images/scale.svg);
      background-repeat: no-repeat;
      background-size: contain;
      background-position: center;
      z-index: 5;
      width: 30px;
      height: 40px;
      transform: rotate(-45deg);
      transition-duration: .3s; }
    .bene-item .bene-ima:hover:after {
      transform: rotate(-45deg) scale(1.2); }
  .bene-item .bene-head {
    margin: 1em auto;
    max-width: 400px; }
  .bene-item .bene-text {
    text-align: left; }
    .bene-item .bene-text p {
      margin-bottom: 1em; }
      .bene-item .bene-text p:last-of-type {
        margin-bottom: 0; }

#ticket-fee {
  margin: 80px auto 0; }

.purchas-item .pur-head {
  padding: 1.5em;
  background: #004bdb;
  position: relative;
  z-index: 0; }
  .purchas-item .pur-head .sp {
    display: none; }
  .purchas-item .pur-head::before {
    content: "";
    position: absolute;
    left: 0;
    top: 0;
    width: 100%;
    height: 100%;
    background: url(../images/bg.webp);
    background-position: center top;
    background-repeat: repeat;
    background-size: 50%;
    z-index: -1;
    mix-blend-mode: overlay;
    opacity: .5; }
  .purchas-item .pur-head.badge::after {
    content: "";
    position: absolute;
    right: -1em;
    top: -2em;
    width: 200px;
    height: 230px;
    background: url(../images/badge-pur1.webp);
    background-position: center;
    background-repeat: no-repeat;
    background-size: contain;
    z-index: 1; }
  .purchas-item .pur-head span {
    filter: drop-shadow(0 0 2px #67d7ee); }
.purchas-item .pur-desc {
  padding: 1em;
  background: #fff;
  color: #464646; }
.purchas-item .pur-date {
  padding: 1em 0; }
.purchas-item .ti-ac-box {
  padding: 1em 0;
  display: none; }
  .purchas-item .ti-ac-box .ti-sche-box {
    margin-bottom: 20px; }
  .purchas-item .ti-ac-box .map-flex {
    display: flex;
    align-items: center;
    flex-direction: column; }
    .purchas-item .ti-ac-box .map-flex .col-l {
      width: 100%;
      margin: 1em auto; }
      .purchas-item .ti-ac-box .map-flex .col-l iframe {
        display: block;
        width: 100%;
        height: 500px;
        margin: 0 auto; }
    .purchas-item .ti-ac-box .map-flex .col-r {
      width: 100%;
      margin: 1em auto; }
  .purchas-item .ti-ac-box .access {
    margin: 40px auto; }
    .purchas-item .ti-ac-box .access .access-head {
      max-width: 140px;
      margin: 1em auto; }
  .purchas-item .ti-ac-box .contact {
    margin: 40px auto; }
    .purchas-item .ti-ac-box .contact .contact-head {
      width: calc(100% - 2em);
      background: #666;
      color: #fff;
      padding: 1em;
      margin: 1em auto; }

#goods {
  padding-bottom: 240px; }
  #goods .coming {
    max-width: 280px;
    margin: 1em auto; }
  #goods:after {
    content: "";
    position: absolute;
    left: 0;
    bottom: -5px;
    width: 100%;
    height: 200px;
    background: url(../images/chara-top.svg);
    background-size: cover;
    background-repeat: no-repeat;
    background-position: center top;
    z-index: 3; }

footer {
  padding: 60px 0 120px;
  background: #fff;
  position: relative;
  z-index: 1; }
  footer .logo-flex {
    display: flex;
    align-items: center;
    max-width: 540px;
    margin: 80px auto; }
    footer .logo-flex a {
      display: block;
      width: 48%;
      margin: 1%; }
  footer .ft-bnr {
    max-width: 800px;
    margin: 40px auto 0;
    display: flex;
    align-items: center; }
    footer .ft-bnr a {
      display: block;
      width: 48%;
      margin: 1%; }
  footer .copy-text {
    margin-top: 120px;
    position: relative;
    text-align: center; }
  footer .notice-box .ac-item {
    max-width: 900px;
    margin: 0 auto 40px; }
    footer .notice-box .ac-item .ac-head {
      text-align: center;
      padding-bottom: 1em;
      margin-bottom: 40px;
      border-bottom: solid 1px #464646;
      position: relative;
      width: calc(100% - 10px); }
      footer .notice-box .ac-item .ac-head::before {
        content: "";
        position: absolute;
        width: 10px;
        height: 10px;
        border: solid 1px #464646;
        transform: rotate(45deg);
        left: -5px;
        bottom: -6px;
        z-index: 1;
        background: #fff; }
      footer .notice-box .ac-item .ac-head::after {
        content: "";
        position: absolute;
        width: 10px;
        height: 10px;
        border: solid 1px #464646;
        transform: rotate(45deg);
        right: -5px;
        bottom: -6px;
        z-index: 1;
        background: #fff; }
      footer .notice-box .ac-item .ac-head span {
        display: block;
        width: calc(100% - 4em);
        position: relative;
        padding: 0 2em;
        cursor: pointer; }
        footer .notice-box .ac-item .ac-head span::after {
          content: "▼";
          position: absolute;
          right: 1em;
          top: 0;
          color: #9196c0; }
      footer .notice-box .ac-item .ac-head.btn-active span::after {
        content: "▲"; }
    footer .notice-box .ac-item .ac-box {
      display: none; }
  footer .notice-box .notice-head {
    background: #8d9bf7;
    padding: .5em 1em;
    margin-bottom: 1em;
    color: #fff;
    margin-top: 20px; }
  footer .notice-box .notice-list li {
    padding-left: 1em;
    position: relative;
    margin-bottom: 1em; }
    footer .notice-box .notice-list li:before {
      content: "・";
      position: absolute;
      left: 0;
      top: 0; }
  footer .ico-ft {
    max-width: 120px;
    margin: 60px auto; }

#rdg-pop,
#fr-pop {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 110;
  display: none;
  color: #1a1a1a; }
  #rdg-pop .close-bt,
  #fr-pop .close-bt {
    position: absolute;
    right: 0;
    top: -40px;
    width: 30px;
    height: 30px;
    cursor: pointer; }
  #rdg-pop p,
  #fr-pop p {
    margin-bottom: 1em; }
  #rdg-pop .rdg-in,
  #fr-pop .rdg-in {
    width: calc(90% - 2em - 6px);
    padding: 1em;
    border-radius: 16px;
    border: solid 1px #1ed9f0;
    max-width: 500px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    background: #fff; }
  #rdg-pop .youtube iframe,
  #fr-pop .youtube iframe {
    width: 100%;
    height: 100%;
    aspect-ratio: 16 / 9;
    display: block; }
  #rdg-pop .img,
  #fr-pop .img {
    width: 100%;
    height: auto; }
  #rdg-pop .rdg-text,
  #fr-pop .rdg-text {
    margin: 1em auto; }
  #rdg-pop .btn,
  #fr-pop .btn {
    max-width: 290px;
    text-align: center;
    padding: .5em;
    display: block;
    width: calc(100% - 3em - 4px);
    background: #1ed9f0;
    color: #fff;
    margin: 0 auto;
    transition-duration: .3s;
    border: solid 2px #1ed9f0;
    padding-right: 2.5em;
    position: relative; }
    #rdg-pop .btn:after,
    #fr-pop .btn:after {
      content: "";
      width: 1em;
      height: 1em;
      background-image: url(../images/tri.svg);
      background-repeat: no-repeat;
      background-size: contain;
      background-position: center;
      position: absolute;
      right: 1em;
      top: 50%;
      transform: translateY(-50%);
      transition-duration: .3s; }
    #rdg-pop .btn:hover,
    #fr-pop .btn:hover {
      background: rgba(0, 0, 0, 0);
      color: #1ed9f0; }
      #rdg-pop .btn:hover::after,
      #fr-pop .btn:hover::after {
        background-image: url(../images/tri-br.svg);
        right: .5em; }
  #rdg-pop .x-btn,
  #fr-pop .x-btn {
    max-width: 280px;
    text-align: center;
    padding: .5em;
    display: block;
    width: calc(100% - 3em - 4px);
    background: #000;
    color: #fff;
    margin: 0 auto;
    transition-duration: .3s;
    border: solid 2px #000;
    padding-right: 2.5em;
    position: relative;
    margin-top: 1em; }
    #rdg-pop .x-btn:after,
    #fr-pop .x-btn:after {
      content: "";
      width: 1.5em;
      height: 1.5em;
      background-image: url(../images/btn-x.svg);
      background-repeat: no-repeat;
      background-size: contain;
      background-position: center;
      position: absolute;
      right: 1em;
      top: 50%;
      transform: translateY(-50%);
      transition-duration: .3s; }
    #rdg-pop .x-btn:hover,
    #fr-pop .x-btn:hover {
      background: rgba(0, 0, 0, 0);
      color: #000; }
      #rdg-pop .x-btn:hover::after,
      #fr-pop .x-btn:hover::after {
        background-image: url(../images/btn-x-blk.svg); }
  #rdg-pop .pop-logo-box,
  #fr-pop .pop-logo-box {
    width: 50%;
    max-width: 280px;
    margin: 0 auto 1em; }

#bene-pop {
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 110;
  color: #1a1a1a;
  display: none; }
  #bene-pop .close-bt {
    position: absolute;
    right: 0;
    top: -40px;
    width: 30px;
    height: 30px;
    cursor: pointer; }
  #bene-pop p {
    margin-bottom: 1em; }
  #bene-pop .bene-in {
    width: 90%;
    max-width: 900px;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%); }
  #bene-pop .img {
    width: 100%;
    height: auto; }

@media screen and (max-width: 900px) {
  #howtoplay .swiper-btn.pc-no-active {
    opacity: 1;
    pointer-events: auto; }
  #howtoplay .swiper-btn.sp-no-active {
    opacity: 0;
    pointer-events: none; } }
@media screen and (max-width: 540px) {
  .bg-wrap {
    padding-bottom: 60px; }

  .menu-btn {
    width: 80px; }

  section {
    padding: 60px 0 0; }

  .inner-wrap {
    padding: 0 1.5em;
    width: calc(100% - 3em); }

  .fix-bg::before {
    height: 150px; }
  .fix-bg:after {
    background-position: top;
    background-size: 100%; }
  .fix-bg .fix-bg-bottom {
    height: 150px; }

  .head-box {
    width: 120%;
    margin-left: -10%; }
    .head-box .catch-head {
      width: calc(100% - 2em);
      margin: 0 auto; }

  .ti-fix-btn {
    right: 0;
    max-width: 100%;
    bottom: 0;
    transition-duration: .3s; }
    .ti-fix-btn:hover {
      opacity: .8; }
    .ti-fix-btn .sp {
      display: block; }
    .ti-fix-btn .pc {
      display: none; }

  #catch {
    padding-bottom: 60px; }
    #catch .pc {
      display: none; }
    #catch .head-box {
      width: 100%;
      margin: 0 auto; }

  #about {
    padding-top: 0; }
    #about .whats-flex {
      flex-direction: column; }
      #about .whats-flex .btn-wh {
        flex-direction: column;
        margin: 1em auto;
        width: calc(100% - 2em - 2px); }

  #point {
    padding-top: 20px; }
    #point .point-flex {
      flex-direction: column;
      margin-bottom: 40px; }
      #point .point-flex .col-l,
      #point .point-flex .col-r {
        width: 100%; }
      #point .point-flex:nth-of-type(odd) {
        flex-direction: column; }
    #point .point-item picture {
      width: 31%; }

  #special .bnr-flex {
    flex-direction: column; }
    #special .bnr-flex a {
      width: 100%;
      margin: 1em auto; }

  #story {
    padding-bottom: 100px; }
    #story .story-bg-bottom {
      height: 30px; }

  #chara {
    padding-bottom: 60px;
    padding-top: 60px; }
    #chara .chara-flex {
      margin-bottom: 40px; }
      #chara .chara-flex .chara-item {
        transform: scale(1.2);
        width: 33%;
        margin: 0 auto; }
        #chara .chara-flex .chara-item .chara-name {
          width: 70%; }
        #chara .chara-flex .chara-item:hover {
          transform: scale(1.3); }

  #howtoplay {
    padding-top: 100px; }
    #howtoplay::before {
      height: 50px;
      top: -1px; }
    #howtoplay .how-wrap {
      padding: 0 20px;
      width: calc(100% - 40px); }
    #howtoplay .howto-item {
      height: auto; }
      #howtoplay .howto-item .step {
        width: 180px; }
    #howtoplay .swiper-btn {
      width: 25px;
      height: 25px; }

  #ticket {
    padding-bottom: 80px; }
    #ticket .fee-box {
      margin: 60px auto 40px; }
      #ticket .fee-box table th {
        padding: .5em; }
      #ticket .fee-box table td {
        padding: .5em; }
    #ticket .ti-notice-btn .sp,
    #ticket .ti-btn .sp {
      display: block; }
    #ticket .purchas-item .pur-head {
      text-align: left; }
      #ticket .purchas-item .pur-head .sp {
        display: block; }
      #ticket .purchas-item .pur-head::after {
        width: 120px;
        height: 140px; }
    #ticket .purchas-item .ti-ac-box .map-flex {
      flex-direction: column; }
      #ticket .purchas-item .ti-ac-box .map-flex .col-l {
        width: 100%;
        margin-bottom: 1em; }
        #ticket .purchas-item .ti-ac-box .map-flex .col-l iframe {
          height: 300px; }
      #ticket .purchas-item .ti-ac-box .map-flex .col-r {
        width: 100%; }

  .u22 {
    margin-top: 120px; }
    .u22 .u22-flex {
      flex-direction: column; }
      .u22 .u22-flex .col-l {
        width: calc(100% - 2em);
        border-right: 0;
        border-bottom: solid 1px #464646; }
      .u22 .u22-flex .col-r {
        width: calc(100% - 2em);
        padding: 1em;
        padding-bottom: 0; }

  .forkids {
    margin-top: 120px; }
    .forkids .kids-flex {
      flex-direction: column; }
      .forkids .kids-flex .col-l {
        width: calc(100% - 2em);
        border-right: 0;
        border-bottom: solid 1px #464646; }
      .forkids .kids-flex .col-r {
        width: calc(100% - 2em);
        padding: 1em;
        padding-bottom: 0; }

  .chara-pop .pop-in .pop-head span {
    font-size: 1.2em; }
  .chara-pop .pop-in .chara-desc {
    font-size: .8em; }

  #goods {
    padding-bottom: 150px; }

  footer {
    padding-top: 30px; }
    footer .ico-ft {
      max-width: 80px;
      margin: 20px auto; }
    footer .logo-flex {
      margin: 40px auto; }
    footer .copy-text {
      margin-top: 60px; }
    footer .ft-bnr {
      flex-direction: column; }
      footer .ft-bnr a {
        margin: 1em auto;
        width: 100%; }

  #rdg-pop .close-bt,
  #fr-pop .close-bt {
    right: -5px; }
  #rdg-pop .rdg-box,
  #fr-pop .rdg-box {
    max-height: 70dvh;
    overflow-x: auto; } }
.slide-box {
  position: relative;
  width: 100vw;
  height: 0;
  display: flex;
  justify-content: center;
  align-items: center;
  overflow: visible;
  pointer-events: none;
  padding-bottom: 380px; }
  @media (max-width: 768px) {
    .slide-box {
      padding-bottom: 250px; } }
  .slide-box .container {
    position: absolute;
    width: 100%;
    height: 100%;
    display: flex;
    justify-content: center;
    align-items: center;
    perspective: 1200px; }
    @media (max-width: 768px) {
      .slide-box .container {
        perspective: 800px; } }
  .slide-box .item {
    position: absolute;
    background: #fff;
    border-radius: 8px;
    will-change: transform;
    box-shadow: 0 10px 10px rgba(0, 0, 0, 0.2);
    user-select: none;
    border: solid #d5f6fb 1px;
    width: 380px;
    aspect-ratio: 16 / 9;
    overflow: hidden; }
    @media (max-width: 768px) {
      .slide-box .item {
        width: 65vw;
        max-width: 280px; } }

/*=========ticketapi===========*/
.ticketWrap {
  margin: 0 auto;
  padding: 20px 6%;
  position: relative;
  width: 88%;
  transition: height 0.7s;
  background: #ebf1f5; }

.ticketWrap .naviBox {
  height: 80px;
  margin: 0;
  padding: 0 0 0 0;
  overflow: hidden; }

.ticketWrap .naviBox .prevBtn {
  width: 50px;
  height: 84px;
  background: #181942;
  z-index: 5;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  cursor: pointer;
  position: absolute;
  top: 40px;
  left: 0%; }

.ticketWrap .naviBox .prevBtn:after {
  content: "";
  width: 12px;
  height: 12px;
  border: 0;
  border-top: solid 3px #fff;
  border-right: solid 3px #fff;
  top: 50%;
  left: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0);
  -webkit-transform: rotate(-135deg);
  transform: rotate(-135deg);
  margin: -8px 0 0 -3px;
  position: absolute; }

.ticketWrap .naviBox .nextBtn {
  width: 50px;
  height: 84px;
  background: #181942;
  z-index: 5;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  cursor: pointer;
  position: absolute;
  top: 40px;
  right: 0%; }

.ticketWrap .naviBox .nextBtn:after {
  content: "";
  width: 12px;
  height: 12px;
  border: 0;
  border-top: solid 3px #fff;
  border-right: solid 3px #fff;
  top: 50%;
  left: 50%;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin: -8px 0 0 -10px;
  position: absolute; }

.ticketWrap .naviBox .prevBtn:hover,
.ticketWrap .naviBox .nextBtn:hover {
  opacity: 0.7; }

.ticketWrap .naviBox .prevBtn span,
.ticketWrap .naviBox .nextBtn span {
  display: none; }

.ticketWrap .naviBox .comm {
  width: 100%;
  top: 25px;
  font-size: 14px;
  color: #ffffff;
  text-align: center;
  font-weight: bold;
  position: relative;
  display: none; }

.ticketWrap .naviBox ul {
  background: rgba(0, 0, 0, 0.2);
  height: 80px;
  list-style: none;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  /* overflow-x: scroll; */
  width: 100%;
  margin: 0;
  padding: 0;
  z-index: 3;
  position: relative; }

.ticketWrap .naviBox ul::-webkit-scrollbar {
  height: 0; }

.ticketWrap .naviBox ul li {
  margin: 0 2px 0 0;
  position: relative;
  cursor: pointer;
  opacity: 0.85;
  width: 80px;
  height: 80px; }

.ticketWrap .naviBox ul li .scheduleBox {
  background: #ffffff;
  display: block;
  width: 80px;
  height: 80px;
  text-align: center;
  cursor: pointer;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  position: relative;
  color: #676767;
  text-align: center;
  display: -webkit-flex;
  display: flex;
  -webkit-flex-direction: column;
  flex-direction: column;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: center;
  align-items: center; }

.ticketWrap .naviBox ul li.cr {
  opacity: 1; }

.ticketWrap .naviBox ul li.cr .scheduleBox {
  background: #fbe663; }

.ticketWrap .naviBox ul li .scheduleBox:hover {
  opacity: 0.7; }

.ticketWrap .naviBox ul li .scheduleBox .date {
  width: 100%;
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  top: 28px; }

.ticketWrap .naviBox ul li .scheduleBox .state {
  bottom: 10px;
  width: 100%;
  font-size: 10px;
  font-weight: 500;
  line-height: 1;
  color: #676767;
  margin-top: 10px; }

.ticketWrap .naviBox ul li .scheduleBox .state span {
  font-size: 10px;
  font-weight: 500; }

.ticketWrap .naviBox ul li .scheduleBox.present .state span {
  color: #32b16c; }

.ticketWrap .naviBox ul li .scheduleBox.present .state span:before {
  content: "○"; }

.ticketWrap .naviBox ul li .scheduleBox.sold .state {
  color: #9d9d9d; }

.ticketWrap .naviBox ul li .scheduleBox.sold .state span:before {
  content: "✕"; }

.ticketWrap .naviBox ul li .scheduleBox.few .state {
  color: #960b0b; }

.ticketWrap .naviBox ul li .scheduleBox.few .state span:before {
  content: "△"; }

.ticketWrap .detailsWrap {
  overflow: hidden;
  opacity: 1;
  transition: opacity 0.7s 0.2s; }

.ticketWrap .detailsWrap.loading {
  opacity: 0;
  transition-duration: 0s;
  transition-delay: 0s; }

.ticketWrap .detailsBox .tit {
  margin: 0;
  padding: 20px 0 20px 0;
  font-size: 20px;
  letter-spacing: 0.1em;
  line-height: 1;
  color: #8d9bf7;
  font-weight: 500;
  text-align: center;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: center;
  justify-content: center;
  -webkit-align-items: flex-end;
  align-items: flex-end;
  -webkit-box-align: baseline;
  -ms-flex-align: baseline;
  align-items: baseline; }
  .ticketWrap .detailsBox .tit p {
    margin-bottom: 0; }

.ticketWrap .detailsBox .tit .tit01 {
  font-size: 25px;
  margin-right: 5px;
  padding-bottom: 2px; }

.ticketWrap .detailsBox .details {
  background: #181942;
  padding: 2%;
  color: #fff; }
  .ticketWrap .detailsBox .details h4:after {
    display: none; }

.ticketWrap .detailsBox .details h4 {
  margin: 0 0 0 0;
  padding: 0 0 5px 0;
  font-size: 15px;
  letter-spacing: 0;
  line-height: 1;
  border-bottom: 2px solid #bfbfbf;
  position: relative; }

.ticketWrap .detailsBox .details a.scrap {
  position: absolute;
  top: 0;
  right: 0;
  padding-right: 15px;
  color: #FFE200;
  font-size: 15px; }

.ticketWrap .detailsBox .details .no_events {
  text-align: center;
  margin: 50px auto;
  opacity: 0.5; }

/*===================sp=*/
@media screen and (max-width: 860px) {
  .ticketWrap .naviBox ul li .scheduleBox:hover {
    opacity: 1; }

  .ticketWrap .detailsBox .details h4 {
    margin: 0 0 0 0;
    padding: 0 0 5px 0;
    font-size: 15px;
    letter-spacing: 0;
    line-height: 1;
    border-bottom: 2px solid #bfbfbf;
    position: relative;
    line-height: 2; }

  .ticketWrap .detailsBox .details a.scrap {
    position: relative;
    right: 0;
    text-align: right; }

  .ticketWrap .naviBox .prevBtn:hover,
  .ticketWrap .naviBox .nextBtn:hover {
    opacity: 1; } }
/*====================*/
.ticketWrap .detailsBox .details a.scrap:after {
  content: "";
  width: 8px;
  height: 8px;
  border: 0;
  border-top: solid 2px #FFE200;
  border-right: solid 2px #FFE200;
  top: 50%;
  right: 0;
  -webkit-transform: translate3d(-50%, -50%, 0);
  transform: translate3d(-50%, -50%, 0);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
  margin: -5px 0 0 0px;
  position: absolute; }

.ticketWrap .detailsBox .details a.scrap:hover {
  text-decoration: none;
  opacity: 0.7; }

.ticketWrap .detailsBox .details ul {
  /*
                          margin-left: -15px;
                          margin-right: -15px;
                          list-style: none;
                          display: block;
                          margin: 0 -5px;
                          padding: 0;
                          margin-bottom: 50px;
  */
  width: 102%;
  list-style: none;
  display: block;
  margin-bottom: 50px;
  margin-top: 2%; }

.ticketWrap .detailsBox .details ul:before,
.ticketWrap .detailsBox .details ul:after {
  content: " ";
  display: table; }

.ticketWrap .detailsBox .details ul:after {
  clear: both; }

.ticketWrap .detailsBox .details ul li {
  /*
                          position: relative;
                          float: left;
                          width: 23%;
                          min-height: 1px;
                          padding-left: 15px;
                          padding-right: 15px;
                          padding: 0 0 0 5px;
                          margin: 15px 10px 0 0;
  */
  position: relative;
  float: left;
  width: 23%;
  min-height: 1px;
  margin-right: 2%;
  margin-top: 2%; }

/*===================sp=*/
@media screen and (max-width: 860px) {
  .ticketWrap .detailsBox .details ul li {
    position: relative;
    float: left;
    width: 94%;
    min-height: 1px;
    padding-left: 3%;
    padding-right: 3%;
    margin: 15px auto 0 auto; }

  .ticketWrap .detailsBox .details a.scrap:hover {
    text-decoration: none;
    opacity: 1; } }
/*====================*/
.ticketWrap .detailsBox .details ul li .scheduleBox {
  position: relative;
  padding: 1em 8%;
  background: #fff;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
  z-index: 1;
  color: #ffffff;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -webkit-align-items: center;
  align-items: center; }

.ticketWrap .detailsBox .details ul li .scheduleBox a {
  position: absolute;
  width: 100%;
  height: 100%;
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  color: #ffffff; }

.ticketWrap .detailsBox .details ul li .scheduleBox .time {
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  margin-right: 10px; }

.ticketWrap .detailsBox .details ul li .scheduleBox .state {
  font-size: 14px;
  font-weight: 500;
  line-height: 1;
  /* 							margin-left: 10px; */ }

.ticketWrap .detailsBox .details ul li .scheduleBox:hover {
  opacity: 0.7; }

.ticketWrap .detailsBox .details ul li .scheduleBox.present {
  background: #32b16c; }

.ticketWrap .detailsBox .details ul li .scheduleBox.present .state span:before {
  content: "○"; }

.ticketWrap .detailsBox .details ul li .scheduleBox.sold {
  background: #969696; }

.ticketWrap .detailsBox .details ul li .scheduleBox.sold .state span:before {
  content: "✕"; }

.ticketWrap .detailsBox .details ul li .scheduleBox.few {
  background: #960b0b; }

.ticketWrap .detailsBox .details ul li .scheduleBox.few .state span:before {
  content: "△"; }

.ticketWrap .detailsBox .details ul li .scheduleBox.remaining {
  color: #f84141; }

.ticketWrap .detailsBox .details .buyWrap {
  width: 100%;
  margin: 20px auto 0 auto;
  display: -webkit-flex;
  display: flex;
  -webkit-justify-content: space-between;
  justify-content: space-between; }

.ticketWrap .detailsBox .details .buyWrap .ticketBox {
  width: 48%; }

/*===================sp=*/
@media screen and (max-width: 860px) {
  .ticketWrap .detailsBox .details .buyWrap {
    width: 100%;
    margin: 20px auto 0 auto;
    display: block; }

  .ticketWrap .detailsBox .details .buyWrap .ticketBox {
    width: 100%;
    margin: 0 0 0 0; }

  .ticketWrap .detailsBox .details ul li .scheduleBox:hover {
    opacity: 1; } }
/*====================*/
.ticketWrap .detailsBox .details .ticketBox {
  margin-left: -15px;
  margin-right: -15px;
  margin: 0 -7px 0 -7px; }

.ticketWrap .detailsBox .details .ticketBox:before,
.ticketWrap .detailsBox .details .ticketBox:after {
  content: " ";
  display: table; }

.ticketWrap .detailsBox .details .ticketBox:after {
  clear: both; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem {
  position: relative;
  min-height: 1px;
  padding-left: 15px;
  padding-right: 15px;
  margin: 0 0 15px;
  padding: 0 7px 0 7px; }

.ticketWrap .detailsBox .details .ticketBox .ticket-item:last-child {
  margin-bottom: 0; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem:nth-of-type(2n) + div.ticketItem {
  clear: left; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem p {
  font-size: 10px;
  margin: 0; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket {
  display: block;
  margin: 0 0 15px 0;
  padding: 10px 2% 10px 2%;
  width: 96%;
  color: #fff;
  font-size: 12px;
  font-weight: 500;
  line-height: 1;
  text-align: center;
  text-decoration: none;
  border: none;
  background: #ffffff; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket:hover {
  opacity: 0.7; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.scrap {
  background: #f34f49; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.scrap:hover {
  opacity: 0.7; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.eplus {
  background: #e85298; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.eplus:hover {
  opacity: 0.7; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.pia {
  background: #36c; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.pia:hover {
  opacity: 0.7; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.lawson {
  background: #1a9fdd; }

.ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.lawson:hover {
  opacity: 0.7; }

._scheduler_container ._description_container ._description_item {
  padding: 0 0.7em; }

._scheduler_container ._scheduler_event_wrapper ._scheduler_event_timeBox_text ._timeBox_symbol {
  margin: initial !important; }

/*===================sp=*/
@media screen and (max-width: 860px) {
  .ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket:hover,
  .ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.scrap:hover,
  .ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.eplus:hover,
  .ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.pia:hover,
  .ticketWrap .detailsBox .details .ticketBox .ticketItem a.ticket.lawson:hover {
    opacity: 1; } }
/*====================*/
@media screen and (max-width: 540px) {
  .ticketWrap .naviBox {
    width: calc(100% - 60px);
    margin: 0 auto; } }

/*# sourceMappingURL=style.css.map */
