@charset "utf-8";


* {
  box-sizing: border-box;
}

body {
  font-family: 'Noto Sans JP', "futura-pt", sans-serif, "游ゴシック体", YuGothic, "Yu Gothic Medium", 'ヒラギノ角ゴ ProN W3', 'Hiragino Kaku Gothic ProN', sans-serif;
  color: #211229;
  background: #FCF9EF;
  font-size: 14px;
  height: 100%;
}

a,
a::before,
a::after {
  transition: all .3s;
}

a.blank {
  pointer-events: none;
  color: #666;
}

ul,
li {
  list-style: none;
}

img {
  width: auto;
  max-width: 100%;
  image-rendering: -webkit-optimize-contrast;
  image-rendering: crisp-edges;
  -webkit-backface-visibility: hidden;
}

.bold {
  font-weight: bold;
}

.red {
  color: #B40019;
}

/* clearfix */
.clearfix:after,
.clearfix:before {
  display: table;
  content: " "
}

.clearfix:after {
  clear: both
}

/* btn */
.btn {
  text-align: center;
}

.btn a,
.btn input {
  -webkit-appearance: none;
  display: inline-block;
}

/* animation */
@keyframes fadeOut {
  100% {
    opacity: 0;
  }
}

@keyframes fadeIn {
  100% {
    opacity: 1;
  }
}

.container {
  z-index: 0;
  position: relative;
  overflow: hidden;
}

/* nav {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 100;
}

header > nav ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: flex-end;
    align-items: center;
    height: 60px;
    padding: 0 20px;
}
header > nav ul li{
    padding: 0 20px;
}
header > nav ul li a{
    color: #211229;
    text-decoration: none;
    letter-spacing: 1px;
    font-family: "futura-pt";
    font-size: 14px;
} */


header>nav ul {
  display: block;
  height: auto;
  padding: 0 5vw;
  /* position: relative;
  overflow-y: scroll;
  overflow-x: hidden;
  top: 20%;
  width: 100%;
  height: 100%; */
  position: relative;
  top: 50%;
  transform: translateY(-50%);
}

header>nav .navinner {
  overflow-y: scroll;
  margin: 0 auto;
  height: 100%;
  position: relative;
  -ms-overflow-style: none;
  scrollbar-width: none;
}

header>nav .navinner::-webkit-scrollbar {
  display: none;
  /*Google Chrome、Safari、Microsoft Edge対応のスクロールバー非表示コード*/
}

header h1 {
  width: 110px;
  left: 40px;
  top: 40px;
  position: relative;
  z-index: 100;
}

header h1 a {
  display: block;
}

.page--home header h1 {
  display: none;
}
.page--home .flex{
  overflow: hidden;
}
/* header>nav ul li a {
  font-size: 4.5vw;
} */

#navBtn {
  position: fixed;
  top: 4vh;
  right: 4vh;
  width: 45px;
  height: 60px;
  z-index: 120;
  cursor: pointer;
}

#navBtn::after {
  content: "menu";
  display: inline-block;
  position: absolute;
  font-family: "futura-pt";
  font-size: 18px;
  color: #000;
  font-weight: bold;
  bottom: -8px;
  right: 0px;
}

#navBtn span:nth-of-type(1) {
  top: -26px;
}

#navBtn span:nth-of-type(2) {
  top: -10px;
}

#navBtn span:nth-of-type(3) {
  bottom: 6px;
}

#navBtn span {
  display: inline-block;
  position: absolute;
  right: 24px;
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
  border-bottom: 34px solid #1A1311;
  border-left: 4px solid transparent;
  border-right: 4px solid transparent;
  border-radius: 2px;
  transform: translateY(10px) rotate(-90deg);
}

#navBtn span::after {
  content: "";
  display: inline-block;
  position: absolute;
  top: 12px;
  left: -3px;
  width: 10px;
  height: 10px;
  border-radius: 50px;
  background: #1A1311;
}

/* menuOpen */

.menuOpen #navBtn::after {
  content: "close";
  display: inline-block;
  position: absolute;
  font-family: "futura-pt";
  font-size: 18px;
  font-weight: bold;
  bottom: -8px;
  right: 4px;
}

/* .menuOpen #navBtn span {
  border-bottom: 45px solid #fff;
}

.menuOpen #navBtn span::after {
  background: #fff;
} */

.menuOpen #navBtn span:nth-of-type(1) {
  -webkit-transform: translateY(14px) rotate(-45deg);
  transform: translateY(14px) rotate(-45deg);
  top: -12px;
}

.menuOpen #navBtn span:nth-of-type(2) {
  left: 60%;
  opacity: 0;
  -webkit-animation: active-menu-bar02 .8s forwards;
  animation: active-menu-bar02 .8s forwards;
}

.menuOpen #navBtn span:nth-of-type(3) {
  -webkit-transform: translateY(-20px) rotate(45deg);
  transform: translateY(-20px) rotate(45deg);
  bottom: -9px;
  right: 13px;
}

nav {
  display: none;
  opacity: 0;
  width: 100%;
  height: 100%;
  background: #FCF9EF;
  /* background: -moz-linear-gradient(top, #990630 0%, #431274 100%);
  background: -webkit-linear-gradient(top, #990630 0%, #431274 100%);
  background: linear-gradient(to bottom, #990630 0%, #431274 100%);
  filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#990630', endColorstr='#431274', GradientType=0); */
  position: fixed;
  right: 0;
  top: 0;
  transition: all .3s ease;
  display: flex;
  align-items: center;
  text-align: center;
  z-index: -10;
}

nav ul {
  width: 100%;
}

.menuOpen nav {
  opacity: 1;
  z-index: 110;
}

nav ul li a {
    display: block;
    color: #1A1311;
    font-size: min(4vw, 8vh);
    line-height: 12vh;
    letter-spacing: 2px;
    text-decoration: none;
    font-family: "futura-pt";
    font-weight: bold;
}

nav li.cs::after {
  bottom: 2px;
  letter-spacing: 1px;
}

nav ul li {
  opacity: 0;
}

nav ul li.gry {
  display: block;
  color: #ccc;
  font-size: 4vw;
  line-height: 14vh;
  letter-spacing: 2px;
  text-decoration: none;
  font-family: "futura-pt";
  font-weight: bold;
}

.menuOpen nav ul li:nth-child(1) {
  animation: fadeIn 1s ease 0.1s 1 forwards;
}

.menuOpen nav ul li:nth-child(2) {
  animation: fadeIn 1s ease 0.2s 1 forwards;
}

.menuOpen nav ul li:nth-child(3) {
  animation: fadeIn 1s ease 0.3s 1 forwards;
}

.menuOpen nav ul li:nth-child(4) {
  animation: fadeIn 1s ease 0.4s 1 forwards;
}

.menuOpen nav ul li:nth-child(5) {
  animation: fadeIn 1s ease 0.5s 1 forwards;
}

.menuOpen nav ul li:nth-child(6) {
  animation: fadeIn 1s ease 0.6s 1 forwards;
}

.menuOpen nav ul li:nth-child(7) {
  animation: fadeIn 1s ease 0.7s 1 forwards;
}

.menuOpen nav ul li:nth-child(8) {
  animation: fadeIn 1s ease 0.8s 1 forwards;
}


.page--home .home {
  display: none;
}

#kv {
  line-height: 0;
  position: relative;
  height: 100vh;
}

#kv .inner {
  position: relative;
  max-width: 800px;
  margin: 0 auto;
  height: 100vh;
}

#kv .inner h1 {
  padding: 60px 0;
  text-align: center;
  position: relative;
  top: 50%;
  transform: translateY(calc(-50% - 7vh));
}

#kv .inner h1 div::before {
  content: "";
  display: block;
  background: center no-repeat url(/static/backnumber/fanclub-pc/feature/oneroom_vol7_mz77a2vm/img/keyhole.svg);
  position: absolute;
  background-size: contain;
  z-index: 0;
  -webkit-animation: key 3s alternate infinite ease-in-out;
  animation: key 3s alternate infinite ease-in-out;
  top: 13vh;
  left: 10.2vh;
  width: 3vh;
  height: 9vh;
  z-index: 2;
}

@keyframes key {
  0% {
    transform: translate(0%, 0%);
  }

  5% {
    transform: translate(10%, 0%) rotate(10deg);
  }

  25% {
    transform: translate(20%, 0%) rotate(20deg);
  }

  30% {
    transform: translate(-10%, 0%) rotate(-10deg);
  }

  35% {
    transform: translate(-15%, 0%) rotate(-15deg);
  }

  45% {
    transform: translate(10%, 0%) rotate(10deg);
  }

  50% {
    transform: translate(15%, 0%) rotate(15deg);
  }

  60% {
    transform: translate(-5%, 0%) rotate(-5deg);
  }

  65% {
    transform: translate(-7%, 0%) rotate(-7deg);
  }

  75% {
    transform: translate(0%, 0%) rotate(0deg);
  }

  100% {
    transform: translate(0%, 0%) rotate(0deg);
  }
}

/* #kv .inner h1 div::after {
  content: "";
  display: block;
  background: center no-repeat url(/static/backnumber/fanclub-pc/feature/oneroom_vol7_mz77a2vm/img/decoration.svg);
  position: absolute;
  background-size: contain;
  z-index: 0;
  -webkit-animation: flash 1s alternate infinite ease-in-out;
  animation: flash 1s alternate infinite ease-in-out;
  top: 1.3vh;
  left: 17.6vh;
  width: 10vh;
  height: 12vh;
} */



@keyframes flash {
  0%,
  25%,
  50%,
  80%,
  100% {
    opacity: 1;
  }

  35% {
    opacity: 0;
  }

  65% {
    opacity: 0;
  }
}

#kv .inner h1 div {
  /* margin: 0 auto;
  position: relative;
  width: 640px;
  height: 823px;
  animation: bounceIn .8s; */
  margin: 0 auto;
  position: relative;
  animation: bounceIn .6s;
  height: 70vh;
  width: 64vh;
}

@keyframes bounceIn {
  /* 0% {
    opacity: 0;
    -webkit-transform: scale(.3);
    -ms-transform: scale(.3);
    transform: scale(.3);
  }

  50% {
    opacity: 1;
    -webkit-transform: scale(1.50);
    -ms-transform: scale(1.50);
    transform: scale(1.50);
  }

  70% {
    -webkit-transform: scale(.9);
    -ms-transform: scale(.9);
    transform: scale(.9);
  }

  100% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  } */

  0% {
    opacity: 0;
    -webkit-transform: scale(.3);
    -ms-transform: scale(.3);
    transform: scale(.3);
  }

  30% {
    opacity: 1;
    -webkit-transform: scale(1.50);
    -ms-transform: scale(1.50);
    transform: scale(1.50);
  }

  60% {
    -webkit-transform: scale(.9);
    -ms-transform: scale(.9);
    transform: scale(.9);
  }

  85% {
    -webkit-transform: scale(1.20);
    -ms-transform: scale(1.20);
    transform: scale(1.20);
  }

  100% {
    -webkit-transform: scale(1);
    -ms-transform: scale(1);
    transform: scale(1);
  }
}

#kv .inner h1 img {
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

#kv .inner h1 img.logodeco {
  animation: Irregularflash linear 2s infinite;
}

@keyframes Irregularflash {
  0%,
  13%,
  17%,
  20%,
  25%,
  50%,
  80%,
  100% {
    opacity: 1;
  }

  15% {
    opacity: 0;
  }

  22% {
    opacity: 0;
  }
}

/* @keyframes Irregularflash {
  0%,
    18.18%,
    27.27%,
    45.45%,
    54.55%,
    72.73%,
    81.82%,
    100% {
    opacity: 1;
  }
    
    9.09%,
    36.36%,
    63.64%,
    90.91% {
    opacity: 0;
  }
} */

#kv .january-april {
  position: absolute;
  right: 2vh;
  top: calc(90px + 14vh);
  height: 50vh;
  animation: fade 2.4s ease;
}

#kv .tour24 {
  position: absolute;
  top: 4vh;
  left: 4vh;
  color: #B40019;
  font-family: "futura-pt";
  font-weight: bold;
  font-size: 4vh;
  line-height: 1;
  animation: fade 2.4s ease;
}

@keyframes fade {
  0% {
    opacity: 0;
  }

  100% {
    opacity: 1;
  }
}

#kv .tour24 span {
  font-size: 6vh;
  display: block;
  margin-top: 8px;
}

#kv .text {
  position: absolute;
  top: calc(68vh + 90px);
  right: 4.5vh;
  padding: 4vh 3vh;
  border: 1px solid #BDBBB3;
  text-align: center;
  border-radius: 100px;
  font-size: 3vh;
  font-family: "futura-pt";
  font-weight: bold;
  color: #000;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  animation: fade 2.4s ease;
}

#kv .text span {
  display: inline-block;
  position: relative;
  will-change: transform;
  animation: diffuseShadow 2.5s infinite ease-in;
}

#kv .text span:nth-child(1) {
  animation-delay: .0s;
}

#kv .text span:nth-child(2) {
  animation-delay: .100s;
}

#kv .text span:nth-child(3) {
  animation-delay: .200s;
}

#kv .text span:nth-child(4) {
  animation-delay: .300s;
}

#kv .text span:nth-child(5) {
  animation-delay: .400s;
}

#kv .text span:nth-child(6) {
  animation-delay: .500s;
}

@keyframes diffuseShadow {

  0%,
  10% {
    text-shadow: 0 0 0 transparent;
    transform: translate3d(4px, 0, 0);
  }

  50% {
    text-shadow: 0 20px 30px rgba(0, 0, 0, 0.1);
  }

  70%,
  100% {
    text-shadow: 0 0 0 rgba(0, 0, 0, 0.1);
    transform: translate3d(0, 0, 0);
  }
}

#kv .tp-btn {
  animation: fade 2.4s ease;
}

.tp-btn {
  position: absolute;
  bottom: 4vh;
  left: 4vh;
}

.tp-btn a {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  max-width: 330px;
  padding: 10px 25px;
  transition: 0.3s ease-in-out;
  font-weight: bold;
  z-index: 1;
  color: #24236f;
  height: 72px;
  font-size: 14px;
  text-decoration: none;
  margin-bottom: 20px;
  line-height: 1.2;
  text-align: center;
}
.tp-btn a:last-child{
  margin-bottom: 0;
}
.tp-btn a span {
  display: block;
  font-size: 12px;
  color: #C30E25;
  width: 100%;
}

.tp-btn a:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  background: #fff;
  z-index: -1;
  border: 2px solid #2F0A53;
  border-radius: 50px;
}

.tp-btn a:after {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  content: '';
  -webkit-transition: all .3s;
  transition: all .3s;
  -webkit-transform: translate3d(0, 0.40rem, -1rem);
  transform: translate3d(0, 0.2rem, -1rem);
  border: 2px solid #000;
  border-radius: inherit;
  z-index: -2;
  border-radius: 50px;
}


.tp-btn a:hover {
  opacity: 1;
}

.tp-btn a:hover:before {
  transform: translate3d(0, 0.3rem, -1rem);
}

@media screen and (min-width: 1px) and (max-width: 580px) {
  .tp-btn a:hover:before {
    transform: none;
  }

}

.delighter.started h2 img {
  animation: bounceIn .5s;
  transform: scale(1);
}

h2 {
  width: 50%;
  font-family: "futura-pt";
  font-size: 60px;
  padding: 0 0 60px;
  position: absolute;
  top: 40px;
  z-index: 100;
  /* left: 50%;
  transform: translateX(-50%); */
}

section {
  position: relative;
  padding: 0 0 350px 0;
}

section#schedule {
  padding: 0;
  max-width: 900px;
  /* margin: 0 auto; */
  margin: 180px auto 0;
  /* animation: fadeIn_l forwards 1s 1s; */
}

section#schedule .inner {
  margin: 0 auto;
  padding: 0;
  position: relative;
  max-width: 1060px;
  color: #211229;
  background: #431274;
  clip-path: polygon(calc(0% - -10px) 5%, calc(100% - 80px) 0%, 100% calc(100% - 180px), 0% calc(100% - 20px));
  width: 90vw;
}

section#schedule .inner .innerbox {
  clip-path: polygon(calc(0% - -32px) 5.9%, calc(100% - 102px) 1.1%, 98% calc(100% - 199px), 2% calc(100% - 46px));
  background: #fff;
}

section#schedule .inner .innerbox .inner_box {
  padding: 240px 100px 240px 70px;
}

section#schedule .link.arw {
  margin-right: 0;
}

.link.arw {
  text-align: right;
  margin-top: 24px;
  margin-right: 50px;
}

section#schedule .link.arw {
  margin-right: 0;
}

#schedule .inner .link.arw a {
  color: #211229;
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 40px;
  font-weight: bold;
  position: relative;
  font-family: "futura-pt";
}

.furikae {
  display: inline-block;
  background: #B40019;
  margin: 0 0 0 5px;
  font-size: 11px;
  padding: 4.5px 8px 5px;
  line-height: 1;
  letter-spacing: 2px;
  border-radius: 100px;
  font-weight: normal;
  color: #fff;
}


/* section:nth-of-type(2n + 1){
    padding: 0 10vw 330px 0;
} */
section>.inner {
  position: relative;
  padding: 80px 100px;
  max-width: 1060px;
  color: #211229;
  margin: 0 auto;
  background: #fff;
}

/* section:nth-of-type(2n + 1) > .inner{
    border-radius:0 80px 80px 0;
} */

.section--schedule .inner .scheduleList .time .sml {
  font-size: 80%;
}

.section--schedule .inner .scheduleList .venue .btn a {
  min-width: 60%;
  padding: 5px 13px 5px 15px;
  font-size: 12px;
  background: #B40019;
  color: #fff;
  line-height: 1;
  margin: 10px 0 0;
}


/* @media screen and (max-width: 960px){

  .section--schedule .inner .scheduleList tr td .btn a {
    min-width: 60%;
    padding: 3% 0;
    font-size: 2vw;
    background: #fff;
    color: #24236f;
    line-height: 1;
    margin: 3% 0 0;
    font-weight: bold;
  }

} */

@media screen and (min-width: 1px) and (max-width: 580px) {
  .section--schedule .inner .scheduleList tr td .btn a {
    min-width: 70%;
    padding: 4% 0;
    font-size: 3.5vw;
    margin: 5.5% 0 0;
  }
}


.delighter {
  opacity: 0;
  transform: translateX(10vw);
  transition: opacity .3s, transform .5s;
}

.delighter.started {
  opacity: 1;
  transform: translateX(0);
}

@keyframes fadeIn_r {
  0% {
    transform: translateX(100px);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

@keyframes fadeIn_l {
  0% {
    transform: translateX(-100px);
    opacity: 0;
  }

  100% {
    transform: translateX(0);
    opacity: 1;
  }
}

/* NEWS */
#news a {
  color: #211229;
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 16px;
}

/* #news .inner > ul li {
    padding: 0 0 30px;
} */
.page #news .inner>ul li:last-child {
  padding: 0;
}

#news .inner>ul li a {
  display: flex;
  word-break: break-all;
}

#news .inner>ul li a .date {
  font-family: "futura-pt";
  width: 130px;
  padding: 1px 0 0;
  min-width: 130px;
}

#news .inner>ul li.new a .tit::after {
  content: "NEW";
  font-family: "futura-pt";
  color: #B40019;
  margin: 0 0 0 20px;
}

#news .inner .link.arw {
  padding: 50px 0 0;
  margin-right: 0;
}

#news .inner .link.arw a {
  color: #211229;
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 40px;
  font-weight: bold;
  position: relative;
  font-family: "futura-pt";
}

.link.arw.back a {
  font-size: 24px !important;
}

section#news {
  padding: 0 0 80px;
  max-width: 900px;
  /* margin: -80px 20vw 0 auto; */
  margin: 60px 20vw 0 auto;
  height: 700px;
  /* animation: fadeIn_r forwards 1s 1s; */
}

section#news h2 {
  /* top: 58px;
  left: 8%; */
  top: -30px;
  left: -20px;
  /* -webkit-transform: rotate(-7deg);
  -moz-transform: rotate(-7deg);
  transform: rotate(-7deg); */
}

section#news .inner {
  padding: 0;
  position: relative;
  height: 800px;
  color: #211229;
  background: #B40019;
  clip-path: polygon(calc(0% - -68px) 12.9%, calc(100% - 90px) 2%, 100% calc(100% - 0px), 0% calc(100% - 144px));
}

section#news .inner .innerbox {
  clip-path: polygon(calc(0% - -88px) 15.2%, calc(100% - 111px) 5.4%, 97% calc(100% - 27px), 3% calc(100% - 164px));
  background: #fff;
  height: 800px;
}

section#news .inner .innerbox .inner_box {
  padding: 240px 140px 140px 130px;
}

section#news ul li {
  padding-bottom: 24px;
  margin-bottom: 24px;
  border-bottom: 1px solid #ccc;
  line-height: 1.6;
  font-weight: bold;
}

section#news ul li .tit {
  overflow: hidden;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;

}

section#news ul li .date {
  margin-bottom: 8px;
  font-family: "futura-pt";
  font-size: 16px;
  line-height: 1;
}

section#news ul li:last-child {
  margin-bottom: 0;
  border-bottom: none;
  padding-bottom: 0;
}

.page--news.detail .date {
  font-weight: bold;
}

.page--news.detail .tit {
  padding-bottom: 24px !important;
  font-size: 24px !important;
  border-bottom: 1px solid #ccc !important;
  font-family: 'Noto Sans JP' !important;
  font-weight: bold !important;
}

section#news .inner .text p a {
  color: #40a2ce;
}

/* section#twitter {
  max-width: 900px;
  margin: 60px auto 0 20vw;
  padding-bottom: 100px;
}
section#news.delighter{
  transform: translateX(-20vw);
}
section#news.delighter.started{
  transform: translateX(0);
}

section#twitter .inner {
  clip-path: polygon(calc(0% - -68px) 4.8%, calc(100% - 70px) 18.8%, 100% calc(100% - 34px), 0% calc(100% - 180px));
  background: #B40019;
  padding: 0;
}

section#twitter .inner .innerbox {
  clip-path: polygon(calc(0% - -88px) 7.6%, calc(100% - 91px) 21%, 96.8% calc(100% - 64px), 3% calc(100% - 199px));
  background: #FFF;
}

section#twitter .inner .innerbox .inner_box {
  padding: 250px 130px 200px 120px;
}

section#twitter>.inner>div {
  max-width: 1000px;
  margin: 0 auto;
}

section#twitter h2 {
  text-align: center;
  margin: 0 auto;
  top: -50px;
  left: 54px;
  transform: none;
  -webkit-transform: rotate(9deg);
  -moz-transform: rotate(9deg);
  transform: rotate(9deg);
}

#twitter .inner .link.arw {
  padding: 50px 0 0;
  margin-right: 0;
}

#twitter .inner .link.arw a {
  color: #211229;
  text-decoration: none;
  letter-spacing: 1px;
  font-size: 40px;
  font-weight: bold;
  position: relative;
  font-family: "futura-pt";
} */

/* sns x ig */
#sns {
  max-width: 1060px;
  margin: 0 auto;
  padding: 0;
  left: 75px;
  margin: 100px auto 200px;
}


#sns .tp-btn {
  position: initial;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}

#sns.delighter.started {
  animation: bounceIn .5s;
  margin: 120px auto 240px;
}

#sns .tp-btn a {
  width: 330px;
  font-family: "futura-pt";
  font-size: 30px;
  /* color: #211229; */
  color: #b40019;
}

#sns .tp-btn a:before,
#sns .tp-btn a:after {
  border: 3px solid #b40019;
}

#sns .tp-btn a.x {
  margin-right: 40px;
  margin-bottom: 0;
}

@media screen and (min-width: 1px) and (max-width: 580px) {
  #sns {
    max-width: initial;
    left: 0;
  }

  #sns.delighter.started {
    animation: bounceIn .5s;
    margin: 50px auto 190px;
  }

  #sns .tp-btn {
    position: absolute;
    width: 390px;
  }

#sns .tp-btn a.x {
    margin-right: 20px;
  }

  #sns .tp-btn a {
    width: 170px;
    max-width: 170px;
    font-size: 16px;
  }
}

@media screen and (min-width: 581px) and (max-width: 1000px) {
  #sns {
    left: 0;
  }
}



.sns-btn {
  position: absolute;
  bottom: 2vw;
  left: 19vw;
}

.sns-btn .fab {
  font-size: 24px;
  color: #211229;
}

.sns-btn ul {
  position: relative;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  width: 246px;
  padding: 10px 25px;
  font-weight: bold;
  z-index: 1;
  height: 72px;
  font-size: 14px;
  text-decoration: none;
}

.sns-btn ul:before {
  content: "";
  width: 100%;
  height: 100%;
  position: absolute;
  background: #fff;
  z-index: -1;
  border: 2px solid #2F0A53;
  border-radius: 50px;
}

.sns-btn ul:after {
  position: absolute;
  top: 0;
  bottom: 0;
  width: 100%;
  height: 100%;
  content: '';
  -webkit-transition: all .3s;
  transition: all .3s;
  -webkit-transform: translate3d(0, 0.40rem, -1rem);
  transform: translate3d(0, 0.2rem, -1rem);
  border: 2px solid #000;
  border-radius: inherit;
  z-index: -2;
  border-radius: 50px;
}

.sns-btn ul li {
  font-family: "futura-pt";
  font-size: 30px;
  color: #211229;
  font-weight: bold;
  margin-right: 16px;
}

.sns-btn ul li .twitterLink {
  margin-right: 8px;
}

/* 下層ページpc 共通 */
.page--schedule .container,
.page--news .container,
.page--goods .container,
.page--ticket .container,
.page--admissionnotice .container,
.page--qa .container {
  padding: 0 40px 40px;
}

.page--schedule footer ul,
.page--news footer ul,
.page--goods footer ul,
.page--ticket footer ul,
.page--admissionnotice footer ul,
.page--qa footer ul {
  bottom: 0;
  left: 0;
  position: relative;
  max-width: 960px;
  margin: 0 auto;
}

.page--schedule footer .copyright,
.page--news footer .copyright,
.page--goods footer .copyright,
.page--ticket footer .copyright,
.page--admissionnotice footer .copyright,
.page--qa footer .copyright {
  bottom: 0;
  left: 0;
  position: relative;
  max-width: 960px;
  /*margin: 35px auto 0;*/
}

.page--schedule .sns-btn,
.page--news .sns-btn,
.page--goods .sns-btn,
.page--ticket .sns-btn,
.page--admissionnotice .sns-btn,
.page--qa .sns-btn {
  position: initial;
  max-width: 960px;
  margin: 0 auto;
}

/* .page--schedule 下層ページpc */
.page--schedule section#schedule {
  /* margin: 0 auto 40px; */
  margin: 100px auto 40px;
  padding: 0 0 80px;
  max-width: 960px;
  height: auto;
  /*margin-bottom: 1600px;*/
  margin-bottom: 80px;
}

.page--schedule section#schedule h2 {
  top: -100px;
  /* -webkit-transform: rotate(-5deg);
  -moz-transform: rotate(-5deg);
  transform: rotate(-5deg); */
}

.page--schedule section#schedule .inner {
  /* clip-path: polygon(0px 4%, 100% 0%, 100% 96%, 0 100%); */
  clip-path: none;
  background: none;
}

.page--schedule section#schedule .innerbox {
  /* clip-path: polygon(2% 4.8%, 98% 1%, 98% 95.2%, 2% 99%); */
  clip-path: none;
  height: auto;
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #431274;
}

.page--schedule section#schedule .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}


/* .page--news 下層ページpc */
.page--news section#news {
  max-width: 960px;
  margin: 100px auto 0;
  height: auto;
  margin-bottom: 160px;
}

.page--news section#news h2 {
  text-align: center;
  left: -90px;
  top: -50px;
  /* -webkit-transform: rotate(-5deg);
  -moz-transform: rotate(-5deg);
  transform: rotate(-5deg); */
}

.page--news section#news .inner {
  /* clip-path: polygon(0px 4%, 100% 0%, 100% 96%, 0 100%); */
  height: auto;
  clip-path: none;
  background: none;
}

.page--news section#news .innerbox {
  /* clip-path: polygon(2% 4.8%, 98% 1%, 98% 95.2%, 2% 99%);
  height: auto; */
  clip-path: none;
  height: auto;
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #B40019;
}

.page--news section#news .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}


/* goods */
.yel {
  color: #fef000;
}

.page--goods section {
  padding: 0 0 80px;
  max-width: 960px;
  margin: 100px auto 0;
  height: auto;
  margin-bottom: 160px;
}

.page--goods section h2 {
  margin: 0 auto;
  /* top: 0; */
  top: -70px;
  left: -70px;
  /* -webkit-transform: rotate(-2deg);
  -moz-transform: rotate(-2deg);
  transform: rotate(-2deg); */
}

.page--goods section>.inner {
  font-size: 16px;
  letter-spacing: 1px;
  line-height: 1.6;
  background: none;
  padding: 0;
}

.page--goods section .innerbox {
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #431274;
}

.page--goods section .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}

.page--goods .tp-btn {
  text-align: center;
  margin-bottom: 40px;
  position: initial;
}

.page--goods .tp-btn a {
  margin: 0 auto;
}

.page--goods section>.inner .goodsInfo {
  /* max-width: 1000px; */
  margin: 0 auto;
}

.page--goods section .lead {
  padding: 0 0 60px;
}

.page--goods section .lead p:not(:last-child) {
  padding: 0 0 15px;
}

.page--goods section>.inner .ph {
  line-height: 0;
  padding: 0 0 80px;
}

.page--goods table.list {
  width: 100%;
  border: 1px solid #ccc;
  font-size: 16px;
  letter-spacing: 2px;
  margin: 0 0 50px;
}

.page--goods table.list tr {
  display: block;
  padding: 20px 0;
  border-bottom: 1px solid #ccc;
  width: 100%;
}

.page--goods table.list tr:last-child {
  border-bottom: none;
}

.page--goods table.list tr th {
  width: 240px;
  padding: 5px;
  border-right: 1px solid #ccc;
  text-align: center;
  font-weight: bold;
  vertical-align: middle;
}

.page--goods table.list tr td {
  padding: 0 45px;
  text-align: left;
  line-height: 1.8;
  vertical-align: middle;
  font-weight: 500;
}

.page--goods .notice li {
  font-weight: 400;
  font-size: 13px;
  text-indent: -1em;
  line-height: 1.4;
  padding: 5px 0 0 1em;
}

.page--goods h3 {
  font-size: 28px;
  letter-spacing: 3px;
  font-weight: bold;
  padding: 0 0 30px;
}

.page--goods .atend {
  padding: 20px 25px;
  background: rgba(255, 255, 255, 0.05);
}

.page--goods .atend .tit {
  font-weight: bold;
  letter-spacing: 2px;
  padding: 0 0 5px;
}

.sml {
  font-size: 80%;
}

@media screen and (max-width: 960px) {
  .page--goods table.list tr {
    padding: 0;
  }

  .page--goods table.list tr th,
  .page--goods table.list tr td {
    width: 100%;
    display: block;
    border: none;
    text-align: left;
    padding: 3%;
  }

  .page--goods table.list tr th {
    background: #431274;
    color: #fff;
  }

  .page--goods table.list tr td {
    line-height: 1.4;
  }
}

@media screen and (min-width: 581px) and (max-width: 1000px) {
  .page--goods section {
    margin: 80px auto 120px;
    padding: 0 !important;
  }

  .page--goods section .innerbox .inner_box {
    padding: 120px 40px;
  }

  .page--goods section h2 {
    /* top: 0; */
    top: -65px;
    left: -55px;
  }
}

@media screen and (min-width: 1px) and (max-width: 580px) {
  .page.page--goods section {
    width: 100%;
    padding: 0 !important;
    margin-top: 50px;
  }

  .page--goods section>.inner {
    font-size: 3.6vw;
    padding: 0 !important;
    border-radius: 0 !important;
  }

  .page--goods section .innerbox {
    border: 10px solid #431274;
  }

  .page--goods section .innerbox .inner_box {
    padding: 60px 24px;
  }

  .page--goods section h2 {
    /* top: -10px; */
    top: -75px;
    left: 50%;
    transform: translateX(-50%);
  }

  .page--goods .tp-btn {
    width: 270px;
    transform: none;
  }

  .page--goods section .lead {
    padding: 0 0 6vw;
  }

  .page--goods section>.inner .ph {
    padding: 0 0 8vw;
  }

  .page--goods h3 {
    font-size: 5vw;
    padding: 0 0 4vw;
  }

  .page--goods table.list tr th,
  .page--goods table.list tr td {
    padding: 4%;
  }

  .page--goods table.list {
    font-size: 3.6vw;
    margin: 0 0 6vw;
  }

  .page--goods .notice li {
    font-size: 12px;
    line-height: 1.3;
  }

  .page--goods .btn a {
    padding: 20px 15px;
    font-size: 3.4vw;
    min-width: 100%;
  }

  h2+.btn,
  .page.page--goods table.list+.btn {
    padding: 0 0 8vw;
  }

  .page--goods .atend {
    padding: 4% 4.5%;
  }
}

.section--schedule .inner .scheduleList .date p+span {
  margin: 0 0 0 -5px;
  /* font-size: 85%; */
  letter-spacing: 1px;
}

.btn a {
  background: #24236f;
  color: #fff;
  min-width: 420px;
  box-sizing: border-box;
  margin: 0 auto;
  line-height: 1.4;
  text-decoration: none;
  padding: 25px 20px;
  font-size: 18px;
  letter-spacing: 2px;
  font-weight: 500;
  border-radius: 50px;
}

h2+.btn,
.page--goods table.list+.btn {
  padding: 0 0 60px;
}

/* footer */
footer {
  background: #FCF9EF;
  padding: 0 0 130px;
  position: relative;
  /* position: absolute;
    bottom: 0; */
}

.copyright {
  margin-top: 35px;
  margin-left: 19vw;
  letter-spacing: 1px;
  color: #000;
  font-family: "futura-pt";
  font-size: 16px;
  font-weight: bold;
}

footer .list--bnr {
  text-align: left;
  padding: 0;
  margin-left: 19vw;
}

footer .list--bnr li {
  display: inline-block;
  width: 180px;
  margin: 5px;
}

footer .list--bnr li:nth-child(1),
footer .list--bnr li:nth-child(4),
footer .list--bnr li:nth-child(8) {
  margin-left: 0;
}

footer .list--bnr li a {
  display: block;
  line-height: 0;
}

.block--sns {
  text-align: center;
  padding: 100px 0 150px;
}

.block--sns>div {
  display: inline-block;
}

.block--sns>div ul {
  display: flex;
  font-size: 20px;
  padding: 40px 60px;
  border-radius: 100px;
  border: 1px solid;
  justify-content: space-between;
  letter-spacing: 1px;
  line-height: 1;
  align-items: center;
}

.block--sns>div ul li:first-child {
  padding: 0 100px 0 0;
  font-family: "futura-pt";
}

.block--sns>div a {
  color: #fff;
  margin: 0 0 0 30px;
  font-size: 24px;
}

@media screen and (min-width: 961px) {
  .sp { display: none !important; }
  a:hover { opacity: 0.6; }


  /* schedule
  --------------------------------- */

  .section--schedule .inner .scheduleList {
    max-width: 1000px;
  }

  #schedule h2 {
    /* left: 10%; */
    left: 0;
    transform: translate(0, 0);
    top: -60px;
    /* -webkit-transform: rotate(-7deg);
    -moz-transform: rotate(-7deg);
    transform: rotate(-7deg); */
  }

  .section--schedule .inner .scheduleList {
    width: 100%;
    border-bottom: 1px solid #cccccc;
    margin: 0 auto;
    font-size: 14px;
    text-align: left;
    color: #211229;
    margin-bottom: 20px;
  }

  .section--schedule .inner .scheduleList .DisContinue .date p,
  .section--schedule .inner .scheduleList .DisContinue .date span,
  .section--schedule .inner .scheduleList .DisContinue .time,
  .section--schedule .inner .scheduleList .DisContinue .area,
  .section--schedule .inner .scheduleList .DisContinue .venue {
    text-decoration: line-through;
  }

  .section--schedule .inner .scheduleList .thead th {
    font-size: 16px;
    line-height: 19px;
    padding: 20px 0;
    font-weight: normal;
    letter-spacing: 1px;
    /* border-right: 1px solid #cccccc; */
    border-top: none;
    text-align: center;
    font-weight: bold;
  }

  .section--schedule .inner .scheduleList .thead th.date {
    /* padding-left: 5px; */
  }

  .section--schedule .inner .scheduleList .thead th.time {
    padding: 0 0 10px;
    border-right: none;
  }

  .section--schedule .inner .scheduleList .thead th.area {
    /* padding-left: 50px; */
  }

  .section--schedule .inner .scheduleList tr:not(.thead) {
    border-top: 1px solid #CCCCCC;
    font-size: 16px;
  }

  /* .section--schedule .inner .scheduleList .dayTwo .date {
    border-top: none;
} */

  .section--schedule .inner .scheduleList .dayOne .time {
    border-bottom: 1px solid #ccc;
    border-top: 1px solid #ccc;
  }

  .section--schedule .inner .scheduleList .dayTwo .date,
  .section--schedule .inner .scheduleList .dayTwo .time {
    position: relative;
  }

  .section--schedule .inner .scheduleList .dayTwo .time {
    padding: 14px 0;
  }

  .section--schedule .inner .scheduleList .dayTwo .daytwo-time {
    padding: 8px 0 24px;
  }

  .section--schedule .inner .scheduleList td {
    vertical-align: middle;
    padding: 24px 0;
    border-right: 1px solid #cccccc;
    /* border-top: 1px solid #cccccc; */
    text-align: center;
  }

  .section--schedule .inner .scheduleList .date {
    width: 76px;
    border-bottom: 1px solid #ccc;
  }

  .section--schedule .inner .scheduleList .area.lastdate,
  .section--schedule .inner .scheduleList .date.lastdate {
    border-bottom: none;
  }

  .section--schedule .inner .scheduleList .date p {
    display: inline-block;
    font-size: 14px;
    margin: 0 5px;
  }

  .section--schedule .inner .scheduleList .area {
    width: 97px;
    border-bottom: 1px solid #cccccc;
  }

  .section--schedule .inner .scheduleList .venue {
    width: 170px;
    font-size: 14px;
    vertical-align: middle;
    box-sizing: border-box;
    padding: 50px 0;
    letter-spacing: 1px;
    line-height: 1.5;
    border-top: 1px solid #CCCCCC;
  }

  .section--schedule .inner .scheduleList .venue a {
    color: #211229;
  }

  .section--schedule .inner .scheduleList .venue a i {
    font-size: 12px;
    position: relative;
    bottom: 2px;
    margin-left: 6px;
  }

  .section--schedule .inner .scheduleList .dayTwo {
    border: none;
  }

  .section--schedule .inner .scheduleList .dayTwo {
    border: none;
  }

  .section--schedule .inner .scheduleList .holding {
    width: 100px;
    color: #ff0000;
    line-height: 100%;
    letter-spacing: 2px;
    padding: 25px 0 25px 10px;
    text-decoration: none;
  }

  .section--schedule .inner .scheduleList .time {
    width: 150px;
    font-size: 16px;
    line-height: 100%;
    letter-spacing: 0.05em;
    padding: 14px 0;
    border-right: none;
    text-align: center;
  }

  /* .section--schedule .inner .scheduleList .time:last-of-type {
  border-bottom: 1px solid #ccc;
} */

  .section--schedule .inner .scheduleList .info {
    width: 250px;
    font-size: 12px;
    vertical-align: middle;
    padding: 40px 20px 40px 20px;

  }

  .scheduleList .ticket {
    width: 230px;
    letter-spacing: 0.05em;
    line-height: 200%;
    vertical-align: middle;
    box-sizing: border-box;
    padding: 10px 0 10px 15px;
  }

  .scheduleList .ticket span {
    font-size: 10px;
  }

  .scheduleList td.time span {
    display: block;
    text-align: center;
    margin: 5px 0 0;
  }

  .scheduleList .subTxt {
    display: block;
    font-size: 10px;
    line-height: 1.7em;
  }

  .scheduleList .pc {
    /* display: table-cell !important; */
  }
  footer{
    display: flex;
    align-items: stretch;
    justify-content: space-between;
    padding: 0 5vw 5vw;
  }
  footer .list--bnr{
    margin-left: 0;
    display: flex;
    flex-wrap: wrap;
    width: 50%;
    gap: 5px
  }
  footer .list--bnr li{
    width: 11vw ;
    margin: 0;
  }
  footer .block--right{
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    justify-content: flex-end;
  }
  footer .block--right .sns-btn{
    width: 100%;
    position: relative;
    left: unset;
    bottom: unset;
  }
  footer .sns-btn ul{
    margin: 0 0 30px auto;
  }
  footer .copyright{
    margin-top: 0;
    margin-left: 0;
  }
}


@media screen and (max-width: 960px) {

  .pc {
    display: none !important;
  }

  /* #kv .inner {
    width: 70vw;
    top: 20%;
  } */

  /* #kv .inner + img{
    width: 130%;
    max-width: 130%;
    margin: 0 0 0 -15%;
  } */

  /* section {
    padding: 0 0 200px 10vw;
  } */
  /* section#schedule {
    padding-bottom: 200px;
  } */
  /* section#twitter {
    padding-bottom: 200px;
  } */
  section>.inner {
    padding: 10vw;
  }

  h2 {
    font-size: 55px;
  }

  .block--sns {
    padding: 50px 0 150px;
  }


  /* schedule
  --------------------------------- */
  .section--schedule .inner .scheduleList * {
    box-sizing: border-box;
  }

  .section--schedule .inner .scheduleList {
    width: 100%;
    margin-bottom: 20px;
  }

  .section--schedule .inner .scheduleList .DisContinue .date p,
  .section--schedule .inner .scheduleList .DisContinue .date span,
  .section--schedule .inner .scheduleList .DisContinue .time span,
  .section--schedule .inner .scheduleList .DisContinue .area,
  .section--schedule .inner .scheduleList .DisContinue .venue {
    text-decoration: line-through;
  }

  .section--schedule .inner .scheduleList .thead {
    display: none;
  }

  .section--schedule .inner .scheduleList tbody {
    display: block;
  }

  .section--schedule .inner .scheduleList .dayOne {
    padding: 4% 0 0;
  }

  .section--schedule .inner .scheduleList .dayTwo {
    padding: 5px 0;
  }

  .section--schedule .inner .scheduleList .dayTwo+.dayTwo {
    padding: 0 0 4%;
  }

  .section--schedule .inner .scheduleList .dayOne,
  .section--schedule .inner .scheduleList .dayTwo {
    display: block;
    position: relative;
  }

  .section--schedule .inner .scheduleList .dayTwo+.dayTwo:not(:last-of-type)::after {
    content: '';
    display: block;
    width: 100%;
    height: 1px;
    background: #fff;
    position: absolute;
    bottom: 0;
  }

  .section--schedule .inner .scheduleList td {
    display: block;
    word-break: break-all;
    margin-bottom: 5px;
  }

  .section--schedule .inner .scheduleList td::before {
    display: block;
    font-size: 13px;
    line-height: 100%;
    margin-bottom: 2px;
  }

  .section--schedule .inner .scheduleList .date {
    float: left;
    font-size: 16px;
    line-height: 1;
    font-weight: 500;
    padding: 0;
    margin: 0 10px 6px 0;
  }

  .section--schedule .inner .scheduleList .area {
    float: left;
    font-size: 18px;
    margin: 2px 5px 0 -10px;
  }

  .section--schedule .inner .scheduleList .date p {
    float: left;
    display: inline-block;
    font-size: 16px;
  }

  .section--schedule .inner .scheduleList .venue a {
    margin: 0 0 0 10px;
    vertical-align: 1px;
  }

  .section--schedule .inner .scheduleList .date p:last-of-type {
    position: relative;
  }

  .section--schedule .inner .scheduleList .date p+span {
    margin: 0;
    font-size: 12px;
    width: 55px;
    display: inline-block;
    letter-spacing: 0;
    vertical-align: -2px;
  }

  .section--schedule .inner .scheduleList .venue {
    font-size: 16px;
    font-weight: bold;
    line-height: 1.5;
    margin: 0 0 2%;
    padding: 0 0 0 70px;
  }

  .section--schedule .inner .scheduleList .time {
    text-align: left;
    font-size: 12px;
    line-height: 1.4;
    letter-spacing: 0.05em;
  }

  .section--schedule .inner .scheduleList .offTxt {
    font-size: 15px;
    color: #ff0000;
    text-decoration: none !important;
    letter-spacing: 1px;
  }

  .section--schedule .inner .scheduleList td.replace.sp {
    margin: 10px 0 0;
  }


  .section--schedule .inner .scheduleList .dayTwo .time {
    margin: 0;
  }

  .section--schedule .inner .scheduleList tr.holiday .date {
    width: 100px;
    margin-right: 0;
  }

  .section--schedule .inner .scheduleList .info {
    vertical-align: middle;
    padding-left: 0px;
    line-height: 1.8;
  }

  .section--schedule .inner .scheduleList .ticket {
    margin-bottom: 0;
  }

  .section--schedule .inner .scheduleList .ticket span {
    font-size: 10px;
  }

  .section--schedule .inner .scheduleList td.info {
    font-size: 11px;
  }

  .section--schedule .inner .scheduleList td.info a {
    color: #333;
    text-decoration: none;
  }

  .section--schedule .inner .scheduleList .subTxt {
    display: block;
    font-size: 10px;
    line-height: 1.7em;
  }

  footer {
    padding: 12vw 0;
  }

  footer>dl {
    display: block;
  }

  footer>dl dd {
    padding: 10vw 0 0;
    text-align: center;
  }

}

/* #navBtn, .bgSp{ display: none; } */

@media screen and (min-width: 1px) and (max-width: 580px) {

  /* .bgPc{ display: none; }
  .bgSp{ display: block; } */

  header h1 {
    width: 60px;
    left: 24px;
    top: 24px;
  }

  #kv {
    height: 100vh;
  }

  #kv .inner {
    width: 100%;
    /* position: static; */
    padding: 0;
    height: 100%;
  }

  #kv .inner h1 {
    transform: translate(-50%, -50%);
    left: 50%;
    top: calc(50% - 5vh);
    position: absolute;
    padding: 0;
  }

  #kv .tour24 {
    font-size: 30px;
    top: 20px;
    left: 20px;
    font-size: 3.5vh;
  }

  #kv .tour24 span {
    font-size: 46px;
    margin-top: 0px;
    font-size: 5.5vh;
  }

  /* #navBtn {
    top: 20px;
    right: 20px;
  } */
  #navBtn{
    transform: scale(0.75);
    top: 2vh;
    right: 2vh;
  }
  #navBtn span:nth-of-type(1) {
    top: -26px;
  }

  #navBtn span:nth-of-type(2) {
    top: -10px;
  }

  #navBtn span:nth-of-type(3) {
    bottom: 6px;
  }

  #kv .inner h1 div {
    width: 38vh;
    height: 49vh;
  }

  #kv .inner h1 img {
    width: 38vh;
    height: 49vh;
  }

  #kv .inner h1 div::after {
    width: 6vh;
    height: 6.5vh;
    top: 1.2vh;
    left: 10.4vh;
  }

  #kv .inner h1 div::before {
    width: 2vh;
    height: 6vh;
    top: 7.5vh;
    left: 5.8vh;
  }

  #kv .january-april {
    width: 13vh;
    left: 12vh;
    bottom: 0;
    top: inherit;
    right: inherit;
    transform: rotate(-90deg);
  }

  #kv .text {
    bottom: calc(72px + 8vh);
    top: initial;
    padding: 4vh 2.5vh;
    font-size: 2.5vh;
  }

  .tp-btn {
    margin: 0 auto;
    left: 50%;
    transform: translateX(-50%);
    /* width: 330px; */
    width: 80vw;
    bottom: -50px;
    position: absolute;
  }

  nav ul li a {
    font-size: 24px;
    line-height: 68px;
  }

  nav ul li.gry {
    font-size: 24px;
    line-height: 80px;
  }

  section,
  section:nth-of-type(2n + 1) {
    padding: 0 5vw 40vw;
  }

  section>.inner,
  section:nth-of-type(2n + 1)>.inner,
  section#twitter>.inner {
    padding: 12vw 6vw;
    border-radius: 40px;
  }

  h2 {
    font-size: 7.5vw;
    padding: 0 0 8vw;
    text-align: center;
    width: 75%;
  }

  h2 img{
    /* height: 63px; */
    width: 100%;
  }

  section#schedule {
    padding-bottom: 0;
    margin-top: 20px;
  }

  section#schedule h2 {
    top: -10px;
    left: 28px;
    /* -webkit-transform: rotate(-15deg);
    -moz-transform: rotate(-15deg);
    transform: rotate(-15deg); */
  }

  section#schedule .inner {
    width: 120%;
    margin-left: 20px;
    clip-path: polygon(calc(0% - -10px) 4%, calc(100% - 80px) 2%, 100% calc(100% - 186px), 0% calc(100% - 32px));
  }

  section#schedule .inner .innerbox {
    clip-path: polygon(calc(0% - -20px) 4.4%, calc(100% - 90px) 2.5%, 96.8% calc(100% - 192px), 2.2% calc(100% - 46px));
  }

  section#schedule .inner .innerbox .inner_box {
    padding: 200px 35vw 200px 13vw;
  }

  .section--schedule .inner .scheduleList .date p {
    font-size: 14px;
    font-weight: normal;
    font-weight: bold;
  }

  .section--schedule .inner .scheduleList .date p+span {
    vertical-align: 0;
    font-weight: bold;
  }

  .section--schedule .inner .scheduleList tr td .btn a {
    min-width: 100%;
    padding: 16px 10px;
    font-size: 12px;
    background: #B40019;
    color: #fff;
    line-height: 1;
    margin: 10px 0 0;
  }

  .section--schedule .inner .scheduleList .dayTwo {
    padding: 4% 0 10%;
    border-bottom: 1px solid #ccc;
  }

  #schedule .inner .link.arw {
    margin-right: 0;
  }

  #schedule .inner .link.arw a {
    font-size: 24px;
  }

  .section--schedule .inner .scheduleList {
    border-top: none;
    border-bottom: none;
    margin-bottom: 20px;
  }

  .section--schedule .inner .scheduleList .area,
  .section--schedule .inner .scheduleList .venue,
  .section--schedule .inner .scheduleList .date {
    font-size: 16px;
  }

  .section--schedule .inner .scheduleList .venue a {
    margin: 0 0 0 6px;
  }

  .section--schedule .inner .scheduleList .dayOne {
    padding: 6% 0 0;
  }

  .section--schedule .inner .scheduleList .dayTwo+.dayTwo {
    padding: 0 0 7%;
    border-bottom: 1px solid #ccc;
  }

  .section--schedule .inner .scheduleList .venue {
    margin: 0 0 3%;
    padding: 0 0 0 45px;
    color: #b40019;
  }

  .section--schedule .inner .scheduleList .date span {
    margin-left: 0;
    font-size: 3vw;
  }

  .section--schedule .inner .scheduleList .date {
    margin: 0 5px 3% 0;
    float: none;
    margin: 0 0 5px;
  }

  .section--schedule .inner .scheduleList .time {
    font-size: 13px;
  }

  .section--schedule .inner .scheduleList .area {
    margin: 4px 0 0 -8px;
    font-weight: bold;
    color: #b40019;
  }

  section#news {
    /* margin: -80px auto 0 -80px; */
    margin: 120px auto 0 -80px;
    width: 100%;
  }

  section#news h2 {
    /* top: 65px;
    left: 28%; */
    top: -16px;
    left: 48px;
    /* -webkit-transform: rotate(-17deg);
    -moz-transform: rotate(-17deg);
    transform: rotate(-17deg) */
  }

  section#news .inner {
    clip-path: polygon(calc(0% - -70px) 10.4%, calc(100% - 60px) 3%, 99% calc(100% - 22px), 0% calc(100% - 150px));
    width: 120%;
    height: 700px;
  }

  section#news .inner .innerbox {
    clip-path: polygon(calc(0% - -79px) 11.6%, calc(100% - 69px) 4.8%, 96.5% calc(100% - 37px), 3% calc(100% - 158px));
    height: 700px;
  }

  section#news .inner .innerbox .inner_box {
    padding: 150px 70px 140px 104px;
  }

  #news .inner>ul li a {
    display: block;
    line-height: 1.5;
    font-size: 12px;
    letter-spacing: 2px;
  }

  section#news ul li .date {
    margin-bottom: 8px;
    font-family: "futura-pt";
    font-size: 16px;
    line-height: 1;
  }

  #news a {
    font-size: 14px;
  }


  #news .inner>ul li.new a .tit::after {
    margin: 0 0 0 3%;
  }

  #news .inner .link.arw {
    padding: 0;
  }

  #news .inner .link.arw a {
    font-size: 32px;
  }

  section#twitter {
    width: 100%;
    /* margin: -134px auto 0 8px; */
    margin: 0 auto 0 8px;
    padding: 0;
  }

  section#twitter h2 {
    /* top: 115px;
    left: 17%; */
    top: 8px;
    left: 34px;
  }

  section#twitter .inner {
    width: 120%;
    border-radius: 0;
    clip-path: polygon(calc(0% - -40px) 8.8%, calc(100% - 60px) 18.8%, 100% calc(100% - 36px), 1% calc(100% - 130px));
    padding: 0;
  }

  section#twitter .inner .innerbox {
    clip-path: polygon(calc(0% - -49px) 10.4%, calc(100% - 69px) 19.5%, 96.8% calc(100% - 50px), 3.4% calc(100% - 139px));
  }

  section#twitter .inner .innerbox .inner_box {
    padding: 220px 104px 220px 58px;
    margin-bottom: 80px;
  }

  #twitter .inner .link.arw {
    padding: 0;
  }

  #twitter .inner .link.arw a {
    font-size: 32px;
  }

  .block--sns {
    padding: 0 10vw 22vw;
  }

  .block--sns>div {
    display: block;
  }

  .block--sns>div ul {
    font-size: 3.5vw;
    padding: 6.5vw 9vw;
  }

  .block--sns>div ul li:first-child {
    padding: 0;
  }

  .block--sns>div a {
    margin: 0 0 0 6vw;
    font-size: 5.5vw;
  }

  footer {
    padding: 4vh 2vh;
  }

  footer .list--bnr {
    display: flex;
    flex-wrap: wrap;
    justify-content: space-between;
    padding: 0;
    margin-left: 0;
  }

  footer .list--bnr li {
    width: 48.5%;
    margin: 0 0 3%;
  }

  .copyright {
    font-size: 10px;
    margin: 0;
  }

  .sns-btn {
    position: relative;
    /*bottom: 2vw;
    margin-left: 20px;
    z-index: 100;*/
    left: 2vh;
  }

  /* 下層sp共通 */
  .page--schedule .container,
  .page--news .container,
  .page--goods .container,
  .page--ticket .container,
  .page--admissionnotice .container,
  .page--qa .container {
    padding: 50px 24px 24px;
  }

  .page--schedule footer,
  .page--news footer,
  .page--goods footer,
  .page--ticket footer,
  .page--admissionnotice footer,
  .page--qa footer {
    padding: 0 20px 8vw;
  }


  /* page--schedule 下層sp
--------------------------------- */

  .page--schedule section#schedule {
    width: 100%;
    padding: 0 !important;
    margin-top: 50px;
  }

  .page--schedule section#schedule h2 {
    /* top: -14px; */
    top: -80px;
    left: 50%;
    transform: translateX(-50%);
  }

  .page--schedule section#schedule .inner {
    border-radius: 0;
    /* clip-path: polygon(0px 2%, 100% 0%, 100% 98%, 0 100%); */
    clip-path: none;
    width: 100%;
    margin: 0 auto;
  }

  .page--schedule section#schedule .inner .innerbox {
    /* clip-path: polygon(3% 2.3%, 97% 0.5%, 97% 97.7%, 3% 99.6%); */
    clip-path: none;
    margin-bottom: 40px;
    border: 10px solid #431274;
  }

  .page--schedule section#schedule .inner .innerbox .inner_box {
    padding: 60px 24px;
  }


  /* page--news 下層sp
    --------------------------------- */

  .page--news section#news {
    width: 100%;
    padding: 0 !important;
    margin-top: 50px;
  }

  .page--news section#news h2 {
    top: -50px;
    left: 50%;
    transform: translateX(-50%);
  }

  .page--news section#news .inner {
    border-radius: 0;
    width: 100%;
    clip-path: none;
    width: 100%;
    margin: 0 auto;
  }

  .page--news section#news .inner .innerbox {
    clip-path: none;
    margin-bottom: 40px;
    border: 10px solid #B40019;
    height: auto;
  }

  .page--news section#news .inner .innerbox .inner_box {
    padding: 60px 24px;
  }

  .page--news.detail .tit {
    font-size: 16px !important;
  }

}

@media screen and (min-width: 581px) and (max-width: 1000px) {

  /* #kv {
    padding-bottom: 80px;
  } */

  /* #kv .inner {
    height: 100vh;
  }

  #kv .inner h1 {
    top: 50%;
    transform: translateY(calc(-50% - 7vh));
  } */

  #kv .inner h1 div {
    width: 400px;
    height: 515px;
    margin: 0 auto;
  }

  #kv .inner h1 div::after {
    width: 65px;
    height: 80px;
    top: 5px;
    left: 108px;
  }

  #kv .inner h1 div::before {
    width: 20px;
    height: 57px;
    top: 83px;
    left: 63px;
  }
  #kv .tour24 span {
    font-size: 5vh;
  }

  #navBtn {
    top: 2vh;
    right: 2vh;
  }

  #kv .tour24 {
    top: 2vh;
    left: 2vh;
  }

  #kv .january-april {
    position: absolute;
    width: 16vh;
    left: 12vh;
    bottom: 2vh;
    top: inherit;
    right: inherit;
    transform: rotate(-90deg);
  }

  .tp-btn {
    left: 2vh;
    bottom: 4vh;
  }

  #kv .text {
    top: 69vh;
    right: 2vh;
    padding: 4vh 3vh;
    font-size: 3vh;
  }

  section#schedule {
    margin-top: 180px;
  }

  section#schedule h2 {
    transform: none;
    /* top: 38px;
    left: 13%; */
    top: -60px;
    left: 50px;
    /* -webkit-transform: rotate(-9deg);
    -moz-transform: rotate(-9deg);
    transform: rotate(-9deg); */
  }

  section#schedule .inner .innerbox .inner_box {
    padding: 23vw 17vw 33vw 12vw;
  }

  .section--schedule .inner .scheduleList .dayTwo {
    padding: 5px 0 4%;
    border-bottom: 1px solid #ccc;
  }

  .section--schedule .inner .scheduleList .date p+span {
    vertical-align: 0px;
  }

  section#schedule .inner {
    clip-path: polygon(calc(0% - -10px) 5%, calc(100% - 80px) 1%, 100% calc(100% - 180px), 0% calc(100% - 20px));
  }

  section#schedule .inner .innerbox {
    clip-path: polygon(calc(0% - -31px) 5.8%, calc(100% - 102px) 2.1%, 97.5% calc(100% - 200px), 2% calc(100% - 47px));
  }

  .section--schedule .inner .scheduleList .dayTwo+.dayTwo {
    padding: 0 0 7%;
    border-bottom: 1px solid #ccc;
  }

  .section--schedule .inner .scheduleList .venue .btn a {
    min-width: 50%;
    padding: 16px;
    font-size: 12px;
    background: #B40019;
    color: #fff;
    line-height: 1;
    margin: 16px 0 0;
  }

  section#news {
    /* margin: -6vw 11vw 0 auto; */
    margin: 4vw 11vw 0 auto;
  }

  section#news h2 {
    top: -10px;
    left: -10px;
    transform: none;
    /* -webkit-transform: rotate(-9deg);
    -moz-transform: rotate(-9deg);
    transform: rotate(-9deg); */
  }

  section#twitter {
    margin: 6vw 3vw 0 11vw;
  }
  section#twitter h2 { 
    /* top: 10vw; */
    top: -50px;
  }
  section#twitter .inner .innerbox .inner_box {
    padding: 25vw 13vw 16vw 11vw;
  }

  .section--schedule .inner .scheduleList tr td .btn a {
    min-width: 50%;
    padding: 16px 13px 16px 15px;
    font-size: 12px;
    background: #B40019;
    color: #fff;
    line-height: 1;
    margin: 24px 0 0;
  }

  .sns-btn {
    position: relative;
    left: 40px;
  }

  footer {
    padding: 6vw 4vw 10vw 5vw;
  }

  footer .list--bnr {
    margin-left: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
  }
  .copyright {
    margin-top: 7vw;
    margin-left: 0;
    font-size: 13px;
  }
  .page--schedule section#schedule {
    margin-top: 0;
  }

  .page--schedule .container,
  .page--news .container,
  .page--goods .container,
  .page--ticket .container,
  .page--admissionnotice .container,
  .page--qa .container {
    padding: 40px 40px 20px;
  }

  .page--schedule footer,
  .page--news footer,
  .page--goods footer,
  .page--ticket footer,
  .page--admissionnotice footer,
  .page--qa footer {
    padding: 0 5vw 6vw;
  }

  /* .page--schedule 下層ページtablet */
  .page--schedule section#schedule {
    margin: 80px auto 120px;
    padding: 0 !important;
  }

  .page--schedule section#schedule h2 {
    /* top: 10px;
    left: 9%; */
    /* left: 50%;
    transform: translateX(-50%); */
    top: -85px;
    left: 0;
  }

  .page--schedule section#schedule .innerbox {
    /* clip-path: polygon(3% 4.8%, 97% 1%, 97% 95.2%, 3% 99%); */
    clip-path: none;
  }

  .page--schedule section#schedule .innerbox .inner_box {
    padding: 180px 40px;
  }

  /* .page--news 下層ページtablet */
  .page--news section#news {
    margin: 80px auto 120px;
    padding: 0 !important;
  }

  .page--news section#news h2 {
    top: -38px;
    left: -70px;
  }

  .page--news section#news .innerbox {
    /* clip-path: initial !important; */
    /* clip-path: polygon(3% 4.8%, 97% 1%, 97% 95.2%, 3% 99%); */
    clip-path: none;
  }

  .page--news section#news .innerbox .inner_box {
    padding: 120px 40px;
  }

}



/* 
================================= */

/* .page section#schedule, .page section.section--ticket{
    padding: 200px 10vw 200px 0;
} */
/* .page section#schedule > .inner, .page section.section--ticket > .inner{
    border-radius: 0 80px 80px 0;
} */

/* .page section#news, .page section.section--qa{
    padding: 200px 0 200px 10vw;
}
.page section#news > .inner, .page section.section--qa > .inner{
    border-radius: 80px 0 0 80px;
}
.page section.section--qa {
} */


.page div.detail {
  word-break: break-all;
  letter-spacing: 1px;
  line-height: 1.6;
}

.page div.detail .date {
  font-size: 18px;
  font-family: "futura-pt";
  letter-spacing: 2px;
}

.page div.detail .tit {
  font-size: 30px;
  line-height: 1.6;
  margin: 0 0 30px;
}

/* ticket
--------------------------------- */
.page--ticket .section--ticket {
  padding: 0 0 80px;
  max-width: 960px;
  margin: 100px auto 160px;
  height: auto;
}

.page--ticket h2 {
  top: -70px;
  left: -90px;
  /* -webkit-transform: rotate(-5deg);
  -moz-transform: rotate(-5deg);
  transform: rotate(-5deg); */
}

.page--ticket .inner {
  padding: 0;
  background: none;
}

.page--ticket .tp-btn {
  text-align: center;
  margin-bottom: 40px;
  position: initial;
  display: flex;
  flex-wrap: wrap;
}
.page--ticket .tp-btn.none a{
  pointer-events: none;
  filter: contrast(0.5) grayscale(1);
  opacity: 0.4;
}
.page--ticket .tp-btn a {
  margin: 0 auto;
  color: #24236f !important;
}

.page--ticket .tp-btn a:hover {
  opacity: 1 !important;
  color: #24236f !important;
}

.page--ticket .section--ticket .page--ticket .inner {
  padding: 0;
  position: relative;
  background: none;
}

.page--ticket .inner .innerbox {
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #B40019;
}

.page--ticket .inner .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}

.page--ticket div.detail {
  max-width: 1000px;
  margin: 0 auto;
}

.page--ticket .section--ticket .block--ticket:not(:last-of-type) {
  padding: 0 0 80px;
  margin: 0 0 80px;
  border-bottom: 1px solid;
}

.page--ticket .section--ticket .block--ticket.ticket-detail {
  margin: 0;
  padding: 35px;
}

.page--ticket .section--ticket a {
  color: #40a2ce;
  text-decoration: none;
}

.page--ticket .section--ticket .block--ticket.ticket-detail .block-tit {
  margin: 0;
  text-align: center;
}

.page--ticket .section--ticket .block--ticket .block-tit {
  font-size: 24px;
  margin: 0 0 30px;
}

.page--ticket .section--ticket .block--ticket .list--caption li {
  margin: 0 0 15px;
  line-height: 1.8;
  text-indent: -1em;
  padding: 0 0 0 0.7em;
}

.page--ticket .section--ticket .block--ticket .list--caption li .txt--sub {
  padding-top: 3px;
  display: block;
  font-size: 12px;
}

.page--ticket .section--ticket .block--ticket .list--caption li:last-child {
  margin-bottom: 0;
}

.page--ticket .section--ticket .ticket-info {
  line-height: 1.5;
}

.page--ticket .section--ticket .ticket-info dt {
  text-align: left;
  clear: left;
  float: left;
  padding: 30px 40px;
  letter-spacing: 2px;
  font-weight: bold;
}

.page--ticket .section--ticket .ticket-info dd {
  text-align: left;
  padding: 30px 40px 30px 200px;
  border-bottom: 1px solid #CCCCCC;
}

.page--ticket .section--ticket .ticket-info dd .entry {
  display: inline-block;
}

.page--ticket .section--ticket .ticket-info dd .entry a {
  -webkit-transition: all .3s ease;
  transition: all .3s ease;
}

.page--ticket .section--ticket .ticket-info dd .entry a:hover {
  opacity: 0.7;
}

.page--ticket .section--ticket .ticket-info dd .conditions {
  padding-top: 10px;
  margin: 0 0 15px;
}

.page--ticket .section--ticket .ticket-info dd .conditions>li {
  margin: 0 0 15px;
}

.page--ticket .section--ticket .ticket-info dd .conditions .list--sub li {
  text-indent: -1em;
  font-size: 12px;
  padding: 5px 0 0 1em;
}

.page--ticket .section--ticket .ticket-info dd .txt--sub {
  padding-top: 3px;
  font-size: 12px;
  display: block;
}

.page--ticket .section--ticket .list--ticket li th {
  width: 200px;
  font-weight: bold;
  text-align: right;
  padding: 15px;
  border: 1px solid #bbb;
  background: #f1f0f0;
}

.page--ticket .section--ticket .list--ticket li td {
  border: 1px solid #bbb;
  padding: 20px;
  line-height: 1.8;
}

.page--ticket .section--ticket .list--ticket li td .list--sub {
  font-size: 12px;
  padding-top: 10px;
}

.page--ticket .section--ticket .list--ticket li td .list--sub li {
  line-height: 1.3;
  margin: 0 0 5px;
}

.page--ticket .ticketType {
  /* padding: 80px 0 0; */
  margin: 80px 0 0;
  /* border-top: 1px solid #211229; */
}

.page--ticket .ticketType .tp-btn a {
  padding: 10px 65px;
}

.page--ticket .ticketType>dt {
  font-size: 24px;
  margin: 0 0 30px;
}

.page--ticket .length {
  border: 2px solid #ccc;
  line-height: 1;
  margin: 0 0 40px;
  font-size: 18px;
}

.page--ticket .length dt,
.length dd {
  font-weight: 500;
}

.page--ticket .length dt {
  /* background: rgba(255,255,255,0.2); */
  width: 200px;
  float: left;
  text-align: center;
  padding: 22px 0 22px 10px;
  letter-spacing: 6px;
  font-weight: bold;
}

.page--ticket .length dd {
  padding: 22px 0 22px 230px;
}

.page--ticket table.liveInfo {
  width: 100%;
  border: 2px solid #ccc;
  color: #211229;
  font-size: 16px;
  letter-spacing: 2px;
}

.page--ticket table.liveInfo tr {
  display: block;
  padding: 20px 0;
  border-bottom: 1px solid #ccc;
  width: 100%;
}

.page--ticket table.liveInfo tr:last-child {
  border-bottom: none;
}

.page--ticket table.liveInfo tr th {
  width: 240px;
  padding: 5px;
  border-right: 1px solid #ccc;
  text-align: center;
  font-weight: bold;
}

.page--ticket table.liveInfo tr th {
  width: 160px;
}

.page--ticket table.liveInfo tr td {
  padding: 0 45px;
  text-align: left;
  line-height: 1.8;
  vertical-align: middle;
  font-weight: 500;
}

.page--ticket table.liveInfo .notice li {
  font-weight: 400;
  font-size: 13px;
  text-indent: -1em;
  line-height: 1.4;
  padding: 5px 0 0 1em;
}

.page--ticket .ticketType.ac {
  margin: 80px 0 0;
  border: 1px solid #CCCCCC;
  padding: 25px 30px;
}

.page--ticket .ticketType.ac .length dt {
  width: 160px;
}

.page--ticket .ticketType.ac .length dd {
  padding: 22px 24px 22px 210px;
}

.page--ticket .ticketType.ac>dt {
  margin: 0;
  position: relative;
  padding: 0 30px 0 0;
}

.page--ticket .ticketType.ac>dt::before,
.page--ticket .ticketType.ac>dt::after {
  content: ' ';
  display: block;
  background: #211229;
  width: 16px;
  height: 2px;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transition: .3s;
  transition: .3s;
  margin-top: -1px;
  visibility: visible;
}

.page--ticket .ticketType.ac>dt::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.page--ticket .ticketType.ac>dt.open::before {
  -webkit-transform: rotate(180deg) !important;
  transform: rotate(180deg) !important;
}

.page--ticket .ticketType.ac>dt.open::after {
  /* -webkit-transform: rotate(45deg) !important;
  transform: rotate(45deg) !important; */
  display: none;
}

.page--ticket .ticketType.ac>dd {
  display: none;
  padding: 25px 0 10px;
}

.page--ticket .ticketType.ac>dd .length {
  margin: 0 0 30px;
}

@media screen and (max-width: 960px) {
  .page--ticket table.liveInfo tr th {
    width: 150px;
  }

  .page--ticket .length {
    font-size: 16px;
  }

  .page--ticket .length dt {
    width: 100%;
    float: none;
    text-align: left;
    padding: 20px;
  }

  .page--ticket .length dd {
    padding: 20px;
  }
}

@media screen and (max-width: 960px) {
  .page--ticket .ticketType>dt {
    font-size: 4.5vw;
    margin: 0 0 6%;
    font-weight: bold;
  }

  .page--ticket .length {
    font-size: 3.5vw;
  }

  .page--ticket .length dt,
  .page--ticket .length dd {
    padding: 5%;
  }

  .page--ticket table.liveInfo tr {
    padding: 5%;
  }

  .page--ticket table.liveInfo tr th,
  .page--ticket table.liveInfo tr td {
    width: 100%;
    display: block;
    border: none;
    text-align: left;
    font-size: 3.5vw;
    padding: 0;
  }

  .page--ticket table.liveInfo tr th {
    padding: 0 0 3%;
    font-weight: bold;
  }

  .page--ticket table.liveInfo tr td {
    line-height: 1.4;
  }

  .page--ticket table.liveInfo .notice li {
    font-size: 3vw;
  }

  .page--ticket .ticketType>dt {
    font-size: 3.5vw;
  }

  .page--ticket .length {
    font-size: 3vw;
  }

  .page--ticket table.liveInfo tr th,
  .page--ticket table.liveInfo tr td {
    font-size: 3vw;
  }

  .page--ticket table.liveInfo .notice li {
    font-size: 2.5vw;
  }

}

@media screen and (min-width: 581px) and (max-width: 1000px) {
  /* .page--ticket h2 {
    top: -10px;
  } */

  .page--ticket section#ticket .innerbox .inner_box {
    padding: 120px 40px;
  }

  .page--ticket .section--ticket {
    padding: 0;
    margin: 80px auto 120px;
  }

  .page--ticket .section--ticket h2 {
    top: -55px;
    left: -70px;
  }

  .tp-btn a:first-child {
    margin-bottom: 20px;
  }

  .page--ticket .inner .innerbox .inner_box {
    padding: 120px 40px;
  }
  .page--ticket .ticketType.ac>dt {
    font-size: 24px;
  }
  .page--ticket .ticketType.ac .length dt {
    width: 140px;
    padding: 30px;
    font-size: 14px;
  }

  .page--ticket .ticketType.ac .length dd {
    /* padding: 30px 30px 30px 140px; */
    font-size: 14px;
    padding: 0 5% 5%;
  }

  .page--ticket table.liveInfo tr th,
  .page--ticket table.liveInfo tr td {
    font-size: 14px;
  }
  .page--ticket table.liveInfo .notice li {
    font-size: 12px;
  }
}

@media screen and (min-width: 1px) and (max-width: 580px) {
  .page--ticket .section--ticket {
    width: 100%;
    padding: 0 !important;
    margin-top: 50px;
  }

  .page--ticket h2 {
    /* top: -10px; */
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
  }

  .page--ticket .inner {
    border-radius: 0 !important;
    width: 100%;
    margin: 0 auto;
    padding: 0 !important;
  }

  .page--ticket .inner .innerbox {
    border: 10px solid #B40019;
  }

  .page--ticket .inner .innerbox .inner_box {
    padding: 60px 24px;
  }

  .page--ticket .tp-btn {
    width: 270px;
    transform: none;
  }
  
  .tp-btn a:first-child {
    margin-bottom: 20px;
  }

  .tp-btn a {
    font-size: 13px;
  }

  .page--ticket .ticketType {
    padding: 8vw 0 0;
    margin: 10vw 0 0;
  }

  .page--ticket .length {
    margin: 0 0 6vw;
  }

  .page--ticket .ticketType.ac {
    margin: 8vw 0 0;
    padding: 5%;
  }

  .page--ticket .ticketType.ac>dt {
    padding: 0 20px 0 0;
  }

  .page--ticket .ticketType.ac>dt::before,
  .page--ticket .ticketType.ac>dt::after {
    width: 15px;
    right: 0;
  }

  .page--ticket .ticketType.ac>dd {
    padding: 4vw 0 0;
  }

  .page--ticket .ticketType.ac>dd .length {
    margin: 0 0 6vw;
  }

  .page--ticket .ticketType .tp-btn a {
    width: 90%;
    margin: 0;
    padding: 10px 25px;
  }

  .page--ticket .ticketType.ac .length dd {
    padding: 0 5% 5%;
    line-height: 1.4;
  }
}

/* faq
--------------------------------- */
.page--qa section.section--qa {
  padding: 0 0 80px;
  max-width: 960px;
  margin: 100px auto 0;
  height: auto;
  margin-bottom: 160px;
}

.page--qa h2 {
  top: -70px;
  margin: 0 auto;
  left: -100px;
  /* -webkit-transform: rotate(-5deg);
  -moz-transform: rotate(-5deg);
  transform: rotate(-5deg); */
}

.page--qa .inner {
  padding: 0;
  background: none;
}

.page--qa .inner .innerbox {
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #B40019;
}

.page--qa .inner .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}

.page--qa .section--qa .list--qa {
  /* max-width: 1000px; */
  margin: 0 auto;
}

.page--qa a {
  color: #40a2ce;
}

.page--qa nav a {
  color: #1A1311;
}

.page--qa a:hover {
  text-decoration: none;
}

.page--qa .section--qa .list--qa li {
  border: 1px solid #ccc;
  margin: 0 0 24px;
}

.page--qa .section--qa .list--qa li .tit .icon--q,
.page--qa .section--qa .list--qa li .icon--a {
  font-family: "futura-pt";
  font-size: 24px;
  float: left;
  margin: 0;
  color: #431274;
}

.page--qa .section--qa .list--qa li .icon--a {
  margin: 18px 0 0 40px;
  color: #B40019;
}

.page--qa .section--qa .list--qa li .tit {
  font-size: 16px;
  padding: 35px 90px 35px 40px;
  font-weight: bold;
  letter-spacing: 2px;
  position: relative;
  cursor: pointer;
}

.page--qa .section--qa .list--qa li .tit p {
  padding-left: 40px;
  line-height: 1.6;
}

.page--qa .section--qa .list--qa li .text {
  padding: 20px 40px 50px 80px;
  line-height: 1.6;
  white-space: pre;
    /* CSS 2.0 */
    white-space: pre-wrap;
    /* CSS 2.1 */
    white-space: pre-line;
    /* CSS 3.0 */
    white-space: -pre-wrap;
    /* Opera 4-6 */
    white-space: -o-pre-wrap;
    /* Opera 7 */
    white-space: -moz-pre-wrap;
    /* Mozilla */
    white-space: -hp-pre-wrap;
    /* HP Printers */
    word-wrap: break-word;
}

.list--accordion li:not(.current) .tit::before,
.list--accordion li:not(.current) .tit::after {
  content: ' ';
  display: block;
  background: #211229;
  width: 16px;
  height: 2px;
  position: absolute;
  top: 50%;
  right: 40px;
  -webkit-transition: .3s;
  transition: .3s;
  margin-top: -1px;
  visibility: visible;
}

.list--accordion li:not(.current) .tit::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.list--accordion li:not(.current) .tit.open::before {
  -webkit-transform: rotate(180deg) !important;
  transform: rotate(180deg) !important;
}

.list--accordion li:not(.current) .tit.open::after {
  -webkit-transform: rotate(45deg) !important;
  transform: rotate(45deg) !important;
  display: none;
}

.list--accordion li:not(.current) .accordion-detail {
  display: none;
}


@media screen and (min-width: 961px) {
  .page--ticket .section--ticket a:hover {
    /* color: #fff; */
    text-decoration: none;
    opacity: 0.6;
  }

  .page--qa a:hover {
    text-decoration: none;
  }
}


@media screen and (max-width: 960px) {

  /* .page section#schedule, .page section.section--ticket{
      padding: 15vw 10vw 20vw 0;
  } */
  /* .page .block--sns {
    padding: 0 0 150px;
  } */
  /* .page section#news, .page section.section--qa{
    padding: 15vw 0 20vw 10vw;
  } */
  .page--ticket .section--ticket .block--ticket:not(:last-of-type) {
    padding: 0 0 60px;
    margin: 0 0 60px;
  }

  .page--ticket .section--ticket .ticket-info dt {
    padding: 30px;
  }

  .page--ticket .section--ticket .ticket-info dd {
    padding: 30px 30px 30px 170px;
  }

}

@media screen and (min-width: 581px) and (max-width: 1000px) {

  .page--qa section.section--qa {
    padding-bottom: 0;
    margin: 100px auto 160px;
  }

  .page--qa h2 {
    top: -65px;
    left: -75px;
  }

  .page--qa .inner .innerbox {
    width: 100%;
    background: #fff;
    transform: skewY(-5deg);
    transform-origin: top right;
    border: 20px solid #B40019;
  }

  .page--qa .inner .innerbox .inner_box {
    padding: 120px 40px;
  }

  .page--qa .section--qa .list--qa li .tit .icon--q,
  .page--qa .section--qa .list--qa li .icon--a {
    margin: 0
  }

  .page--qa .section--qa .list--qa li .icon--a {
    margin: 18px 0 0 40px;
  }
}

@media screen and (min-width: 1px) and (max-width: 580px) {

  /* .page section#schedule, .page section#news, .page section.section--ticket, .page section.section--qa{
    padding: 15vw 5vw 20vw;
  } */

  /* .page section#schedule > .inner, .page section#news > .inner, .page section.section--ticket > .inner, .page section.section--qa > .inner{
    border-radius:40px;
  } */

  .page #news .inner>ul li {
    padding: 0 0 6vw;
  }

  .page #news .inner>ul li:last-child {
    padding: 0;
  }

  .page #news .inner .link.arw {
    padding: 8vw 0 0;
  }

  .page .block--sns {
    padding: 5vw 10vw 22vw;
  }


  .page div.detail .date {
    font-size: 4vw !important;
  }

  .page div.detail .tit {
    font-size: 6vw;
    margin: 0 0 7vw;
  }

  .page div.detail .text {
    font-size: 3.5vw;
  }

  /* ticket
  --------------------------------- */
  .ticket-banner {
    display: block;
    padding: 3% 0 10%;
  }

  .ticket-banner a {
    width: 100%;
    display: block;
    margin: 0 0 3%;
  }

  .page--ticket .section--ticket .block--ticket .block-tit {
    font-size: 4.5vw;
    margin: 0 0 6%;
    font-weight: bold;
  }

  .page--ticket .section--ticket .block--ticket:not(:last-of-type) {
    padding: 0 0 12%;
    margin: 0 0 12%;
    font-size: 3.5vw;
  }

  .page--ticket .section--ticket .ticket-info dt {
    float: none;
    padding: 5% 5% 3%;
    font-size: 3.5vw;
    border-right: 1px solid rgba(255, 255, 255, 0.5);
  }

  .page--ticket .section--ticket .ticket-info dd {
    text-align: left;
    padding: 0 5% 5%;
    font-size: 3.5vw;
  }

  .page--ticket .section--ticket .ticket-info dd span.txt--sub {
    display: inherit;
    font-size: 3vw;
    padding: 5px 0 0;
  }


  /* page--qa sp*/

  .page--qa .section--qa .list--qa li {
    margin: 0 0 4vw;
  }

  .page--qa .section--qa .list--qa li .tit {
    font-size: 3.5vw;
    padding: 6vw 8vw 6vw 4vw;
  }

  .page--qa .section--qa .list--qa li .tit .icon--q,
  .page--qa .section--qa .list--qa li .icon--a {
    font-size: 5vw;
    margin: 0;
  }

  .page--qa .section--qa .list--qa li .tit p {
    padding-left: 25px;
    line-height: 1.4;
  }

  .list--accordion li:not(.current) .tit::before,
  .list--accordion li:not(.current) .tit::after {
    width: 10px;
    right: 19px;
  }

  .page--qa .section--qa .list--qa li .icon--a {
    margin: 0 0 0 16px;
  }

  .page--qa .section--qa .list--qa li .text {
    padding: 0 5vw 5vw 40px;
    line-height: 1.6;
    font-size: 3.5vw;
  }

  .page--qa section.section--qa {
    padding: 0;
    margin-bottom: 80px;
    margin-top: 50px;
  }

  .page--qa h2 {
    /* top: -10px; */
    top: -60px;
    left: 50%;
    transform: translateX(-50%);
  }

  .page--qa .inner {
    width: 100%;
    padding: 0 !important;
  }

  .page--qa .inner .innerbox {
    border: 10px solid #B40019;
  }

  .page--qa .inner .innerbox .inner_box {
    padding: 60px 24px;
  }

}


/* popup */
#popupInfotop {
  display: block;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.5);
  z-index: 10010;
}

.popupBox {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.85);
  z-index: 10010;
  text-align: left;
}

.popupBox .closeBg {
  display: block;
  position: fixed;
  top: 0;
  width: 100%;
  height: 100%;
  z-index: 1001;
}

.popupBox .block {
  position: absolute;
  top: 49%;
  left: 50%;
  width: 90%;
  max-width: 800px;
  z-index: 1100;
  -webkit-transform: translate(-50%, -50%);
  transform: translate(-50%, -50%);
}

.popupBox .block {
  top: 55%;
}

.popupBox {
  overflow: scroll;
}

.popupBox .block {
  position: absolute;
  top: 10%;
  left: 50%;
  width: 90%;
  max-width: 800px;
  z-index: 1100;
  -webkit-transform: translate(-50%, 0);
  transform: translate(-50%, 0);
  margin: 0 0 60px;
}


.popupBox .close .top {
  position: absolute;
  -moz-transform: rotate(-45deg);
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
}

.popupBox .close .bottom {
  position: absolute;
  -moz-transform: rotate(45deg);
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}


.popupBox .inner {
  background: #fff;
  line-height: 1.5;
  font-size: 14px;
  letter-spacing: 1px;
  color: #222;
}

.popupBox .inner .tit {
  font-weight: bold;
  font-size: 17px;
  text-align: center;
  padding: 0 0 25px;
}

.popupBox .inner .titSub {
  font-size: 15px;
  text-align: center;
  font-weight: bold;
  padding: 0 0 20px;
}

.popupBox .inner .tit+.text {
  padding: 10px 0 20px;
}

.popupBox .inner .lead p,
.popupBox .inner .text>p {
  padding: 0 0 20px;
}

.popupBox .inner a {
  color: #000;
  text-decoration: underline;
}

.popupBox .inner .lead {
  padding: 20px 0;
  border-bottom: 2px solid #ccc;
  margin: 0 0 40px;
}

.popupBox .inner .notice {
  margin: 0 0 0 -5px;
}

.popupBox .inner .notice li {
  text-indent: -1em;
  padding: 0 0 8px 1em;
}

.popupBox .inner .notice li span.indent {
  display: inherit;
  padding: 0 0 0 1em;
}

.popupBox .inner .notice+.text {
  padding: 10px 0 0;
}

.popupBox .inner #guideLines dl dt {
  padding: 0 0 35px;
  margin: 0 0 40px;
  border-bottom: 1px solid #ccc;
}

.popupBox .inner #guideLines dl dd:not(:last-child) {
  padding: 0 0 25px;
  margin: 0 0 40px;
  border-bottom: 1px solid #ccc;
}

.popupBox .inner #guideLines .appBtn {
  text-align: center;
}

.popupBox .inner #guideLines .appBtn a {
  margin: 15px;
  display: inline-block;
  line-height: 0;
  text-decoration: none;
  text-indent: 0;
}

.popupBox .inner #guideLines .appBtn a:hover {
  opacity: 0.6;
}

.popupBox .inner #guideLines .appBtn a img {
  height: 60px;
  width: auto;
}

@media screen and (min-width: 961px) {
  .popupBox .close {
    position: absolute;
    width: 40px;
    height: 40px;
    top: -50px;
    right: 0;
    cursor: pointer;
    -webkit-transition: .3s;
    transition: .3s;
    text-align: left;
  }

  .popupBox .close span {
    top: 20px;
    width: 40px;
    height: 2px;
    position: absolute;
    background: #fff;
  }

  .popupBox .close:hover {
    -moz-transform: rotate(90deg);
    -webkit-transform: rotate(90deg);
    transform: rotate(90deg);
  }

  .popupBox .inner a:hover {
    color: #000;
    text-decoration: none;
  }
}

@media screen and (max-width: 960px) {
  .popupBox .close {
    position: absolute;
    width: 30px;
    height: 30px;
    top: -40px;
    right: -3px;
  }

  .popupBox .close span {
    top: 20px;
    width: 30px;
    height: 2px;
    position: absolute;
    background: #fff;
  }

  .popupBox .block {
    top: 10%;
    transform: translate(-50%, 0);
  }

  .popupBox .inner {
    margin: 0 0 20px;
  }

}


/* admissionnotice
--------------------------------- */

.page--admissionnotice section {
  font-size: 16px;
  line-height: 1.5;
  padding: 0 0 80px;
  max-width: 960px;
  margin: 0 auto;
  height: auto;
  margin-bottom: 160px;
}
.page--admissionnotice section .indent{
  display: block;
  text-indent: -15px;
  padding-left: 15px;
}

.page--admissionnotice .inner {
  background: none;
  padding: 0;
}

.page--admissionnotice .inner .innerbox {
  width: 100%;
  background: #fff;
  transform: skewY(-5deg);
  transform-origin: top right;
  border: 20px solid #431274;
}

.page--admissionnotice .inner .innerbox .inner_box {
  padding: 120px 80px;
  transform: skewY(5deg);
}

.page--admissionnotice section h3 {
  font-size: 22px;
  font-weight: bold;
  letter-spacing: 1px;
  padding: 0 0 30px;
}

.page--admissionnotice .lead {
  padding: 0 0 30px;
}

.page--admissionnotice .lead p:not(:last-of-type),
.page--admissionnotice .text p:not(:last-of-type) {
  padding: 0 0 12px;
}

.page--admissionnotice .block--attention dt {
  font-weight: bold;
}

.page--admissionnotice .block--attention dt:before,
.page--admissionnotice .block--attention dd li:before {
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.page--admissionnotice .block--attention dt:before {
  content: "\f071";
}

.page--admissionnotice .block--attention dd .list--attention>li:before {
  content: "\f00c";
}

.page--admissionnotice .block--attention dd .list--attention>li:last-child {
  margin-bottom: 0;
}

.page--admissionnotice .block--attention dd .list--attention>li .document {
  display: block;
  text-indent: 0;
  /*border: 1px solid #431274;*/
  background: #f0f0f0;
}

.page--admissionnotice .block--ticket-type .ticket-type {
  text-align: center;
}

.page--admissionnotice .block--ticket-type .ticket-type:last-of-type {
  margin-bottom: 0;
}

.page--admissionnotice .block--ticket-type .ticket-type dt {
  font-weight: bold;
}

.page--admissionnotice .block--ticket-type .ticket-type dt span {
  display: block;
  font-weight: 400;
}

.page--admissionnotice .block--attention {
  padding: 30px 40px;
  margin: 0 0 30px;
  border: 1px solid #431274;
}

.page--admissionnotice .block--attention:last-of-type {
  margin: 0;
}

.page--admissionnotice .block--attention dt {
  font-size: 18px;
  margin: 0 0 15px;
}

.page--admissionnotice .block--attention dt:before {
  margin-right: 10px;
}

.page--admissionnotice .block--attention dd .list--attention {
  padding: 0;
}

.page--admissionnotice .block--attention dd .list--attention>li {
  margin: 0 0 10px;
  padding-left: 1.6em;
  text-indent: -1.6em;
  line-height: 1.6;
}

.page--admissionnotice .block--attention dd .list--attention>li:before {
  margin-right: 8px;
}

.page--admissionnotice .block--attention dd .list--attention>li .txt--sub {
  padding-top: 5px;
}

.page--admissionnotice .block--attention dd .list--attention>li .document {
  padding: 15px 20px;
  margin-top: 10px;
  line-height: 2;
}

.page--admissionnotice .block--attention dd .list--attention li .document li {
  margin: 0 10px 0 0;
  display: inline-block;
}

.page--admissionnotice .block--ticket-type {
  margin: 0 0 70px;
  padding-top: 30px;
}

.page--admissionnotice .block--ticket-type .ticket-type {
  margin: 0 0 50px;
}

.page--admissionnotice .block--ticket-type .ticket-type dt {
  font-size: 17px;
  margin: 0 0 15px;
}

.page--admissionnotice .block--ticket-type .ticket-type dt span {
  font-size: 14px;
  padding: 20px 0 10px;
  letter-spacing: 1px;
  text-align: left;
}

.page--admissionnotice .block--ticket-type .ticket-type.paper dt span {
  font-size: 12px;
}

.page--admissionnotice .block--ticket-type .ticket-type dt i {
  margin-right: 10px;
}

.page--admissionnotice .block--ticket-type .ticket-type dt svg {
  width: 23px;
  height: 14px;
  margin-right: 10px;
  position: relative;
  top: 2px;
}

.page--admissionnotice .block--ticket-type .ticket-type dd p {
  padding: 8px;
}

.page--admissionnotice .block--ticket-type .ticket-type dd .thumb {
  padding: 25px 0;
}

.page--admissionnotice .block--ticket-type .ticket-type dd .thumb img {
  width: 100%;
  max-width: 300px;
}

.page--admissionnotice .block--ticket-type .ticket-type.paper dd .thumb {
  padding: 18px 0;
}

.page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dt {
  font-size: 26px;
  margin: 0 0 18px;
}

.page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dd {
  border: 1px solid #431274;
}

.page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dd p {
  font-size: 18px;
  padding: 12px;
  background: #431274;
  color: #fff;
}

.page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dd .thumb img {
  max-width: 520px;
}

.page--admissionnotice .block--attention.ac {
  margin: 0 0 30px;
  border: 1px solid #431274;
  padding: 25px 30px;
}

/* .page--ticket .ticketType.ac .length dt {
  width: 210px;
}

.page--ticket .ticketType.ac .length dd {
  padding: 22px 24px 22px 210px;
} */


.page--admissionnotice .block--attention dt .acicon {
  position: relative;
  font-size: 18px;
}

.page--admissionnotice .block--attention dt .acicon:before {
  content: "\f071";
  margin-right: 10px;
  font-family: "Font Awesome 5 Free";
  font-weight: 900;
}

.page--admissionnotice .block--attention.ac>dt {
  margin: 0;
  position: relative;
  padding: 0 30px 0 0;
}

.page--admissionnotice .block--attention.ac>dt::before,
.page--admissionnotice .block--attention.ac>dt::after {
  content: ' ';
  display: block;
  background: #211229;
  width: 16px;
  height: 2px;
  position: absolute;
  top: 50%;
  right: 0;
  -webkit-transition: .3s;
  transition: .3s;
  margin-top: -1px;
  visibility: visible;
  margin-right: 0;
}

.page--admissionnotice .block--attention.ac>dt::before {
  -webkit-transform: rotate(90deg);
  transform: rotate(90deg);
}

.page--admissionnotice .block--attention>dt.open::before {
  -webkit-transform: rotate(180deg) !important;
  transform: rotate(180deg) !important;
}

.page--admissionnotice .block--attention.ac>dt.open::after {
  /* -webkit-transform: rotate(45deg) !important;
  transform: rotate(45deg) !important; */
  display: none;
}

.page--admissionnotice .block--attention.ac>dd {
  display: none;
  padding: 25px 0 10px;
}

.page--admissionnotice .block--attention.ac>dd .length {
  margin: 0 0 30px;
}

@media screen and (min-width: 581px) and (max-width: 1000px) {
  .page--admissionnotice section {
    margin: 0 auto 120px;
    padding: 0 !important;
  }

  .page--admissionnotice section .inner .innerbox .inner_box {
    padding: 120px 40px;
  }
}

@media screen and (min-width: 1px) and (max-width: 580px) {
  .page--admissionnotice section {
    font-size: 3.6vw;
    width: 100%;
    padding: 0 !important;
  }

  .page--admissionnotice section>.inner {
    padding: 0;
    border-radius: 0;
  }

  .page--admissionnotice section .inner .innerbox .inner_box {
    padding: 60px 24px;
  }

  .page--admissionnotice section .inner .innerbox {
    border: 10px solid #431274;
  }

  .page--admissionnotice section h3 {
    font-size: 5vw;
    padding: 0 0 6vw;
  }

  .page--admissionnotice .block--attention {
    padding: 16px;
    margin: 0 0 6vw;
  }

  .page--admissionnotice .block--attention.ac {
    margin: 0 0 6vw;
    border: 1px solid #431274;
    padding: 16px;
  }

  .page--admissionnotice .block--attention dt .acicon {
    font-size: 3.6vw;
  }

  .page--admissionnotice .block--attention dt::before {
    margin-right: 5px;
  }

  .page--admissionnotice .lead+.block--attention dt::before {
    margin-right: 0;
  }

  .page--admissionnotice .lead+.block--attention dt {
    font-size: 3.6vw;
    margin: 0 0 4vw;
    text-indent: -2em;
    padding: 0 0 0 2em;
  }

  .page--admissionnotice .lead {
    padding: 0 0 6vw;
  }

  .page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dt {
    font-size: 5vw;
    margin: 0 0 5vw;
  }

  .page--admissionnotice .block--ticket-type .ticket-type dt span {
    font-size: 3.2vw;
    padding: 4vw 0 0;
    letter-spacing: 1px;
    text-align: left;
  }

  .page--admissionnotice .block--ticket-type .ticket-type:not(.paper) dd p {
    font-size: 3.6vw;
    padding: 3vw;
    letter-spacing: 2px;
    font-weight: bold;
  }

  .page--admissionnotice .block--ticket-type .ticket-type dd .thumb {
    padding: 4vw 3vw;
    line-height: 0;
  }

  .page--admissionnotice .block--ticket-type {
    margin: 0 0 8vw;
    padding-top: 0.5vw;
  }

  .page--admissionnotice .block--attention dt {
    font-size: 3.6vw;
    margin: 0 0 3vw;
    letter-spacing: 1px;
  }

  .page--admissionnotice .block--attention dd .list--attention>li .document {
    padding: 3vw;
    margin: 10px 0 18px;
    line-height: 2;
  }

  .page--admissionnotice .block--attention dd .list--attention li .document li {
    margin: 0;
    display: inline-block;
    text-indent: -1em;
    padding: 0 0 5px 0.7em;
    font-size: 3.2vw;
    line-height: 1.4;
    letter-spacing: 0.5px;
  }
}