@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@400;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Limelight&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Shippori+Mincho&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Smokum&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Ranchers&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Plaster&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Libre+Bodoni:ital,wght@0,500;1,500&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Changa+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Righteous&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Poller+One&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Vast+Shadow&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Copse&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Slackey&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Anton&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Special+Elite&display=swap');

html,body,a,p,ul,li,h1,h2,h3,h4,h5,h6,figure,dl,dt,dd{margin:0;padding:0;}

*{
    box-sizing: border-box;
   
    -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
    tap-highlight-color: rgba(0, 0, 0, 0);
    outline: none;
    word-break: break-all;
}


@font-face {
	font-family: 'font';
	src: url(../font/font.ttf);
    
}


html{
    overflow-x:clip;
}
body{
    overflow-x: hidden;
    -webkit-touch-callout:none;
    background: url(../img/paper.jpg);
    background-size: 800px auto;
  font-family: "Libre Bodoni","fot-chiaro-std", sans-serif;
font-weight: 500;
font-style: normal;
    color: #000;
    font-feature-settings: "palt";
    overflow-x:clip;
  
}
body:after{
content: "";
display: block;
position: fixed;
top:0;
left:0;
width:100%;
height:100dvh;
border:solid 6px #9b1a00;
    pointer-events: none;
    z-index: 999999;
}
body:before{
content: "";
display: block;
position: fixed;
top:10px;
left:10px;
width:calc(100% - 20px);
height:calc(100dvh - 20px);
border:solid 3px #9b1a00;
    pointer-events: none;
    z-index: 999999;
}
img{
    width: 100%;
    height: auto;
    pointer-events: none;
    user-select: none;
    display: block;
    font-size: 0;
    
}

a{
    color: inherit;
    text-decoration: none;
}


li{
    list-style-type: none;
}


.youtube {
    position: relative;
    width: 100%;
    padding-top: 56.25%;

}

.youtube iframe {
    position: absolute;
    top: 0;
    right: 0;
    width: 100% !important;
    height: 100% !important;
}


.sp{
    display: none;
    
}


@media screen and (max-width: 896px){
    .pc{
        display: none;
    }
    
    .sp{
        display: block;
    }
}

.nav-btn{
    display: none;
}
nav{
    position: fixed;
    top: 48px;
    left: 0;
    width: 100%;
   z-index: 99999;
      font-family: "Limelight", sans-serif;
  font-weight: 400;
  font-style: normal;
    color: #cf2e0d;
    
}

.is-over-red nav{
    color: #fcefd9;
}
nav.open{
    display: block;
}
nav::-webkit-scrollbar{
  display:none;
}
.nav-inner{
    width: 100%;
     
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: column;
    
}

nav ul{
    display: flex;
    gap:40px;
    font-size: 20px;
}


@media screen and (max-width: 896px){
    
    .nav-btn {
    position: fixed;
        display: block;
        top: 28px;
        right: 24px;
        width: 40px;
        height: 24px;
        cursor: pointer;
        z-index: 999999;
    }

    .nav-btn span {
        position: absolute;
        right: 0;
        width: 40px;
        height: 3px;
         background: #9b1a00;
       
    }
    
    .nav-btn.close span{
        background: #fcefd9;
    }

    .nav-btn span:nth-of-type(1) {
        top: 0px;
    }

    .nav-btn.close span:nth-of-type(1) {
        top: calc(50% - 1.5px);
        transform: rotate(45deg);
    }

    .nav-btn span:nth-of-type(2) {
        top: 50%;
        margin-top: -1.5px;
    }

    .nav-btn.close span:nth-of-type(2) {
        opacity: 0;
        transform: translateX(-20%);

    }

    .nav-btn span:nth-of-type(3) {
        bottom: 0px;
    }

    .nav-btn.close span:nth-of-type(3) {
        bottom: calc(50% - 1.5px);
        transform: translateY(0) rotate(-45deg);
    }  

nav{
   position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow-y: scroll;
    overscroll-behavior-y: contain;
   -ms-overflow-style: none;
  scrollbar-width: none;
    background: #000;
    display: none;
    color: #fcefd9 !important;

}
    .nav-inner{
    width: 100%;
     min-height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    flex-flow: column;
     padding: 100px 0;
}

    nav.open{
        display: block;
    }
nav ul{
    display: block;
    justify-content: center;
    text-align: center;
}
nav li{
    margin: 20px 0;;
}
nav a{
   
    font-size: 18px;
    letter-spacing: 0.12em;
   
}
    
}
.wrap{
    
      
}

.hero{
    width: 90%;
    height: 100dvh;
    min-height: 680px;
    max-width: 1600px;
    margin: 0 auto;
    z-index: 9999;
    position: relative;
   
   
}
.hero .kv{
    position: absolute;
    top: calc(50% - 20px);
    left: 50%;
    transform: translate(-50%, -50%);
    width:  calc(100% - 40px);
    height: calc(100% - 220px);
    object-fit: contain;
}

.scroll-down{
    position:fixed;
    bottom: 28px;
    left: calc(50% - 40px);
    width: 80px;
    height: 80px;
    border-radius: 10000px;
    display: flex;
    justify-content: center;
    align-items: center;
    background: #cf2e0d;
    overflow: hidden;
     box-shadow: 0 3px 4px rgba(0,0,0,.3);
     animation: fluffy 2.4s infinite ease;
    pointer-events: none;
    transition-duration: 0.2s;
}

.scroll-down.hide{
    opacity: 0;
    
}
@keyframes fluffy {
  0%, 100% {
    transform: translateY(5px);
  }
  50% {
    transform: translateY(-5px);
  }
}
.scroll-down:after{
    content: "";
    display: block;
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:url(../img/texture.jpg);
    background-size: 400px auto;
    z-index: 8;
    mix-blend-mode: screen;
    pointer-events: none;
    opacity: 0.3;
   
}
.scroll-down img{
    width: 45%;
}
section{
   padding: 80px 0;
    position: relative;
    color: #cf2e0d;
}


section:after{
    content: "";
    display: block;
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:url(../img/texture.jpg);
    background-size: 400px auto;
    z-index: 8;
    mix-blend-mode: screen;
    pointer-events: none;
    opacity: 0.6;
}
section.red{
    background: url(../img/paper-red.jpg);
    background-size: 800px auto;
    color: #fcefd9;
}
section.red:after{
    content: "";
    display: block;
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:url(../img/texture-red.jpg);
    background-size: 600px auto;
    z-index: 8;
    mix-blend-mode:darken;
    pointer-events: none;
    opacity: 0.4;
}

.inner{
    width: 80%;
    max-width: 1000px;
    margin: 0 auto;
}
h2{
   
    text-align: center;
    color: #cf2e0d;
    font-size: 60px;
    position: relative;
    margin-bottom: 40px;
      font-family: "Limelight", sans-serif;
  font-weight: 400;
  font-style: normal;
    transform: rotate(-5deg) skewX(-15deg);
   
}
section.red h2{
    color: #fcefd9;
}
.wrap{
    position: relative;
    height: auto;
}

.schedule{
   padding-top: 0;
    position: relative;
}

.trigger{
    position: absolute;
    top: -80px;
}
.schedule h2{
    font-family: "Poller One", sans-serif;
  font-weight: 400;
  font-style: normal;
}
#ticket h2{
   font-family: "Vast Shadow", serif;
  font-weight: 400;
  font-style: normal;
    letter-spacing: -0.08em;
}
#ticket h2 span{
    font-size: 100%;
}
.schedule-txt{
    font-size: 60px;
    text-align: center;
    font-weight: 400;
    margin-bottom: 28px;
}

.schedule-txt span{
    display: block;
}
.schedule-txt small{
    font-size: 50%;
    display: inline-block;
}
.schedule-txt span:nth-child(1){
    letter-spacing: 0.02em;
    
    
    
}
.schedule-txt span:nth-child(2){
    font-size: 160%;
}
.schedule-txt span:nth-child(3){
    font-size: 54%;
    
}

.schedule-info{
    text-align: center;
    font-size: 18px;
}
.schedule-info span{
    font-size: 80%;
    display: block;
    margin-top: 12px;
    line-height: 1.4;
}
.schedule-info span a{
    text-decoration: underline;
}
.ticket-price{
    text-align: center;
    font-size: 60px;
    margin-bottom: 40px;
}
.ticket-price span{
    font-size: 70%;
    display: block;
}
.ticket-price small{
    font-size: 50%;
    margin: 0 0.2em;
}

.ticket-info li{
    border: double 3px #fcefd9;
    text-align: center;
}
.ticket-info li h3{
    
    padding: 8px 0;
    font-size: 24px;
   
}
.ticket-info li div{
    border-top: double 3px #fcefd9;
    display: flex;
    justify-content: space-between;
    padding: 24px;
    align-items: center;
}
.ticket-info li .term{
    font-size: 18px;
    text-align: left;
    line-height: 1.4;
}

.ticket-info li a{
    width: 280px;
    height: 40px;
    display: flex;
    justify-content: center;
    align-items:center;
    background: #fcefd9;
    border-radius: 100px;
    color: #cf2e0d;
    border: solid 1px #fcefd9;
}
.ticket-info li a.hover{
    background: none;
    color: #fcefd9;
}
#goods h2{
    font-family: "Smokum", serif;
  font-weight: 400;
  font-style: normal;
    letter-spacing: 0.04em;
}
#goods h2 span{
    font-size: 140%;
}
.goods-txt{
    text-align: center;
    font-size: 24px;
    padding: 40px 0;
    letter-spacing: 0.1em;
}


#special h2{
    font-family: "Anton", sans-serif;
  font-weight: 400;
  font-style: normal;
    letter-spacing: 0.06em;
}


#special a{
    display: block;
    max-width: 480px;
    margin: 0 auto;
    filter: drop-shadow(0px 6px 3px rgba(0,0,0,0.3));
    position: relative;
    z-index: 9;
    transition-duration: 0.1s;
    
}
#special a.hover{
    filter: drop-shadow(0px 1px 1px rgba(0,0,0,0.9));
    transform: scale(0.98);
}

#movie h2{
    font-family: "Slackey", sans-serif;
  font-weight: 400;
  font-style: normal;
    
}


ul.movie-list{
    position: relative;
    z-index: 9;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap:20px;
    
}

ul.movie-list li{
    aspect-ratio: 16 / 9;
}

ul.movie-list li iframe{
    width: 100%;
    height: 100%;
}


footer{
   padding-bottom: 60px;
    text-align: center;
     color: #cf2e0d;
    font-family: "Special Elite", system-ui;
  font-weight: 400;
  font-style: normal;
}

.hp-link{
    font-size: 18px;
   
}
.sns{
    width: 260px;
    margin: 28px auto 36px;
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.sns li a{
    display: block;
    width: 34px;
    aspect-ratio: 1 / 1;
}
.sns li a.hover{
    opacity: 0.5;
}
.sns li a img{
    width: 100%;
    height: 100%;
    object-fit: contain;
}

footer small{
    font-size: 10px;
    line-height: 1;
    display: block;
}



@media screen and (max-width: 896px){
    .hero{
        min-height: 480px;
    }
   .hero .kv{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width:  calc(100% - 20px);
    height: calc(100% - 160px);
    object-fit: contain;
}
    .scroll-down{
        bottom: 24px;
    left: calc(50% - 30px);
        width: 60px;
        height: 60px;
    }
section{
   padding: 60px 0;
    position: relative;
    color: #cf2e0d;
}



h2{
   font-size: 40px;
    margin-bottom: 28px;
   
}
section.red h2{
    color: #fcefd9;
}


.schedule-txt{
    font-size: 36px;
}
.schedule-info{
    font-size: 16px;
}

.ticket-price{
    text-align: center;
    font-size: 36px;
    margin-bottom: 28px;
}


.ticket-info li h3{
    
    font-size: 18px;
   
}
.ticket-info li div{
    flex-flow: column;
    padding: 20px 16px;
}
.ticket-info li .term{
    font-size: 16px;
    text-align: center;
    margin-bottom: 16px;
    line-height: 1.4;
}

.ticket-info li a{
    width: 200px;
    height: 36px;
   font-size: 14px;
}


.goods-txt{
    font-size: 18px;
    padding: 20px 0;
}





ul.movie-list{
    position: relative;
    z-index: 9;
    display: grid;
    grid-template-columns: 1fr;
    gap:20px;
    
}

ul.movie-list li{
    aspect-ratio: 16 / 9;
}

ul.movie-list li iframe{
    width: 100%;
    height: 100%;
}


footer{
    
    text-align: center;
}

.hp-link{
    font-size: 18px;
    
}
.sns{
    width: 200px;
    margin: 20px auto 28px;
}
.sns li a{
    display: block;
    width: 24px;
    aspect-ratio: 1 / 1;
}
    
    
}



.specialpage{
    background: url(../img/paper-blue.jpg);
    background-size: 800px auto;
}
body.specialpage:after{
border:solid 6px #fcefd9;
}
body.specialpage:before{
border:solid 3px #fcefd9;
}
.specialpage nav{
    color: #fcefd9;
}
.specialpage section{
   padding: 160px 0 80px;
    position: relative;
    color: #fcefd9;
}


.specialpage section:after{
   content: "";
    display: block;
    position: absolute;
    top:0;
    left:0;
    width:100%;
    height:100%;
    background:url(../img/texture-blue.jpg);
    background-size: 600px auto;
    z-index: 8;
    mix-blend-mode:darken;
    pointer-events: none;
    opacity: 0.4;
}

.specialpage h2{
    color: #fcefd9;
     font-family: "Anton", sans-serif;
  font-weight: 400;
  font-style: normal;
    letter-spacing: 0.06em;
}

.special-intro{
    text-align: center;
    margin-bottom: 40px;
}
.special-nav{
    display: flex;
    justify-content: center;
    gap:20px;
    font-family: "Limelight", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 24px;
    margin-bottom: 40px;
}

.special-contents{
    border: double 6px #fcefd9;
    padding: 40px 100px 60px;
    text-align: center;
    min-height: 300px;
    position: relative;
}
.special-contents h3{
    font-size: 60px;
    margin-bottom: 40px;
}
.special-contents h3 span{
    display: block;
}
.special-contents h3 span:nth-child(1){
    font-family: "Limelight", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 36px;
    margin-bottom: 12px;
}
.special-contents h3 span:nth-child(3){
    font-size: 20px;
    margin-top: 8px;
}
.special-contents figure{
    width: 80%;
    max-width: 320px;
    margin: 0 auto 40px;
}
.special-contents p{
    text-align: justify;
    line-height: 2.2;
    font-size: 20px;
    letter-spacing: 0.04em;
}
.special-contents p span{
        display: block;
        height: 1em;
    }
.specialpage footer{
    color: #fcefd9;
}

.song-info{
    border: solid 1px;
    max-width: 640px;
    margin: 40px auto 60px;
    padding: 28px 40px;
    line-height: 1.6;
    display: flex;
    align-items: center;
    justify-content: space-between;
    text-align: left;
}
.song-info div span{
    border: solid 1px;
    display: inline-block;
    padding: 0.1em 1em 0;
    margin-bottom: 8px;
    
}
.song-info div:nth-child(1){
    margin-right: 20px;
    line-height: 1.8;
}
.song-info div:nth-child(2){
    width: 200px;
}
.song-info strong{
    font-size: 32px;
}
.song-info a{
    text-decoration: underline;
}
@media screen and (max-width: 896px){
    .specialpage .nav-btn span{
        background: #fcefd9;
    }
    .specialpage section{
        padding: 120px 0 40px;
    }
    .special-intro{
        margin-bottom: 24px;
        font-size: 14px;
    }
    .special-nav{
        font-size: 18px;
        margin-bottom: 28px;
    }
    .special-contents{
    border: double 6px #fcefd9;
    padding: 28px 20px;
}
.special-contents h3{
    font-size: 32px;
    margin-bottom: 20px;
}
.special-contents h3 span{
    display: block;
}
.special-contents h3 span:nth-child(1){
    font-family: "Limelight", sans-serif;
    font-weight: 400;
    font-style: normal;
    font-size: 18px;
    margin-bottom: 12px;
}
.special-contents h3 span:nth-child(3){
    font-size: 14px;
    margin-top: 8px;
}
.special-contents p{
    text-align: justify;
    line-height: 2.2;
    font-size: 14px;
}
    
.song-info{
    padding: 20px 12px;
   font-size: 14px;
    margin-top: 40px;
    margin-bottom: 40px;
    flex-flow: column;
    flex-direction: column-reverse;
    text-align: center;
    font-size: 12px;
}
    .song-info div:nth-child(1){
        margin-right: 0;
        margin-top: 28px;
    }
.song-info strong{
    font-size: 20px;
}
    
}