@charset "UTF-8";
@import url('https://fonts.googleapis.com/css2?family=Noto+Sans+JP:wght@300;400;500;700;900&display=swap');

*{
margin: 0;
padding: 0;
box-sizing: border-box;
}

html{
font-size: 62.5%;
/*\*/
_font-size: 62.5%;
/**/
}

::selection{
background: #231815;
color: #ffffff;
}

a{
color: #231815;
text-decoration: none;
}

a:hover, a:focus{text-decoration: none;}

a:hover,a:focus,
a:hover img,
a:focus img{
filter: alpha(opacity=9) !important;
-moz-opacity: 0.9 !important;
opacity: 0.9 !important;
}

img {
margin: 0;
padding: 0;
border: 0;
}

ul, ol {
list-style: none;
}

.clearfix:after {
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}
.clearfix { display: inline-block; }
/* exlude MacIE5 \*/
* html .clearfix { height: 1% }
.clearfix {display:block;}
/* end MacIE5 */

.embed{
width: 100%;
display: block;
position: relative;
background-color: #ffffff;
padding-bottom: 56.25%;
height: 0;
overflow: hidden;
}
.embed iframe{
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
}
.embed video{
width: 100%;
height: auto;
margin: 0;
padding: 0;
background-size: contain;
}
video::-internal-media-controls-download-button {
display:none;
}
video::-webkit-media-controls-enclosure {
overflow:hidden;
}
video::-webkit-media-controls-panel {
width: calc(100% + 30px);
}


body{
height: 100vh;
padding: 2.5vw 2.5vw 0 2.5vw;
background-color: #231815;
color: #231815;
font-family:'Noto Sans JP','ヒラギノ角ゴ Pro W6','Hiragino Kaku Gothic Pro','メイリオ',Meiryo,'ＭＳ Ｐゴシック',sans-serif;
font-size: 1.6rem;
font-weight: 400;
line-height: 1.8;
font-feature-settings: "palt";
overflow-y: scroll;
position: relative;
z-index: 0;
}
body.scroll-prevent{
overflow: hidden;
}

html:before{
content: "";
background-color: #231815;
position: fixed;
display: block;
z-index: 90000;
}
html:before{
width: 100vw;
height: 2.5vw;
left: 0;
top: 0;
}

body:before{
content:"";
display: block;
width: 50px;
height: 50px;
background: url(../img/radius_topleft.png) no-repeat center center;
position:fixed;
top: calc(2.5vw - 30px);
left: calc(2.5vw - 30px);
z-index: 90001;
}
body:after{
content:"";
display: block;
width: 150px;
height: 150px;
background: url(../img/radius_topright.png) no-repeat center center;
position:fixed;
top: calc(2.5vw - 30px);
right: calc(2.5vw - 30px);
z-index: 90002;
}

/* Layout */
section{
width:100%;
display:block;
}
#page{
display: block;
position: relative;
background-color: #fafaed;
border-top-left-radius:20px;
border-top-right-radius:20px;
}
.scroll-prevent #page{
overflow: hidden;
}
main{
display: block;
}
h2{
font-size: 4.8rem;
font-weight: 900;
line-height: 1;
letter-spacing: 0;
text-align: center;
}
h3{
margin: 64px 0 0 0;
font-size: 4.2rem;
font-weight: 900;
line-height: 1;
letter-spacing: 0;
letter-spacing: 1px;
}

.nolink{
color: #aaaaaa;
pointer-events: none;
cursor: default;
}

.pcHide{
display: none !important;
}
.spHide{
display: block !important;
}
.pc_br{
display: inline;
}
.sp_br{
display: none;
}

.col1{
max-width: 1000px;
display: block;
margin: 0 auto 0 auto;
}
.col1 li{
width: 46%;
display: block;
margin: 0 27% 0 27%;
}
.col2{
max-width: 1000px;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 0 auto 0 auto;
}
.col2 li{
width: 46%;
display: block;
margin: 0 2% 0 2%;
}
.col3{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
.col3 li{
width: 33.33%;
display: block;
}


#page:after{
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}

/* header */
header{
display: block;
padding: 20px 2.5vw 0 2.5vw;
}
header .headInfo{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}
header.second .headInfo{
display: block;
text-align: right;
}
header .headInfo .pickup{
width: 55%;
display: block;
}
header .headInfo .gNav{
width: 45%;
display: block;
padding: 0 100px 0 0;
text-align: right;
box-sizing: border-box;
}
header.second .headInfo .gNav{
width: 100%;
}
header .headInfo .pickup a{
height: 42px;
display: inline-block;
padding: 7px 62px 7px 10px;
background: url(../img/arr_r.svg) no-repeat right 18px center;
background-size: 22px auto;
background-color: #ffffff;
border: 2px solid #e94630;
border-radius: 10px;
line-height: 22px;
}
header .headInfo .pickup a span:before{
content: "PICKUP";
display: inline-block;
height: 22px;
margin-right: 10px;
padding: 0 7px 0 7px;
background-color: #e94630;
color: #ffffff;
border-radius: 11px;
font-size: 1.1rem;
}
header .headInfo .pickup a:hover{
color: #e94630;
transition: all 0.2s;
}

header .headInfo .pickup.osaka a{
height: 42px;
display: inline-block;
padding: 7px 62px 7px 10px;
background: url(../img/arr_r.svg) no-repeat right 18px center;
background-size: 22px auto;
background-color: #ffffff;
border: 2px solid #0079ad;
border-radius: 10px;
line-height: 22px;
}
header .headInfo .pickup.osaka a span:before{
content: "PICKUP";
display: inline-block;
height: 22px;
margin-right: 10px;
padding: 0 7px 0 7px;
background-color: #0079ad;
color: #ffffff;
border-radius: 11px;
font-size: 1.1rem;
}
header .headInfo .pickup.osaka a:hover{
color: #0079ad;
transition: all 0.2s;
}

header .headInfo .gNav ul{
display: inline-block;
font-style: italic;
line-height: 1;
}
header .headInfo .gNav ul li{
display: inline-block;
margin-left: 18px;
}
header .headInfo .gNav ul li:first-child{
margin-left: 0;
}
header .headInfo .gNav ul li.navb{
display: block;
margin-top: 10px;
margin-left: 0;
background: url(../img/bar_viewing.png) no-repeat left center;
background-size: 100% auto;
}
header .headInfo .gNav ul li.navb a{
padding: 0 0 0 15px;
background-color: #fafaed;
}
header .headInfo .gNav ul li a:hover{
color: #e94630;
transition: all 0.2s;
}
header.second .headInfo .gNav ul li a{
color: #ffffff;
text-shadow:2px 2px 8px #231816,
-2px 2px 8px #231816,
2px -2px 8px #231816,
-2px -2px 8px #231816;
}
header.second .headInfo .gNav ul li.navb{
padding: 0 0 0 15px;
background: url(../img/bar_viewing.png) no-repeat right 80px center;
background-size: calc(100% - 80px) auto;
background-color: transparent;
}
header.second .headInfo .gNav ul li.navb a{
background-color: transparent;
}
header .headInfo .ticketInfo:after{
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}

header h1{
width: 124px;
display: none;
position: fixed;
top: calc( 2.5vw + 10px);
left: calc( 2.5vw + 10px);
z-index: 88000;
}
header.second h1{
display: block;
}
header h1 a{
width: 124px;
height: 0;
display: block;
padding-top: 86px;
background: url(../img/logo.svg) no-repeat center center;
background-size: contain;
overflow: hidden;
}
#top header h1 a{
cursor: default;
pointer-events: none;
}

header h1.on{
display: block;
}
#top header h1.on a{
cursor: pointer;
pointer-events: inherit;
}
#top header.second h1.on a{
cursor: pointer;
pointer-events: inherit;
filter: drop-shadow(0px 0px 5px rgba(255, 255, 255, 0.7));
}

header h1{
animation: h1-out .5s forwards;
}
header h1.on{
animation: h1-in .5s forwards;
}

@keyframes h1-out {
0% {
transform: translateY(0);
}
100% {
transform: translateY(-300px);
}
}
@keyframes h1-in {
0% {
transform: translateY(-300px);
}
100% {
transform: translateY(0);
}
}

/* Btn */
.covidBtn{
display: inline-block;
position: fixed;
bottom: 20px;
left: 0;
z-index: 81000;
}
.covidBtn2{
display: inline-block;
position: fixed;
bottom: 132px;
left: 0;
z-index: 81000;
}
.covidBtn a{
display: inline-block;
padding: 18px 15px 18px 2.5vw;
background-color: #231815;
color: #ffffff;
border-top-right-radius: 20px;
border-bottom-right-radius: 20px;
z-index: 1000;
}
.covidBtn a span{
display: inline-block;
padding: 0 0 20px 0;
background: url(../img/arr_r_w.svg) no-repeat center bottom;
background-size: auto 11px;
}
.covidBtn2 a{
display: inline-block;
padding: 10px 15px 10px 2.5vw;
background-color: #231815;
color: #ffffff;
border-top-right-radius: 20px;
border-bottom-right-radius: 20px;
z-index: 1000;
}
.covidBtn2 a span{
display: inline-block;
padding: 0 25px 0 0;
background: url(../img/arr_r_w.svg) no-repeat right center;
background-size: auto 7px;
}

.covidBtn,
.covidBtn2{
animation: covid-btn-01 .5s forwards;
}
.covidBtn.outpos,
.covidBtn2.outpos{
animation: covid-btn-01-out .5s forwards;
}

@keyframes covid-btn-01 {
0% {
transform: translateX(-200px);
}
100% {
transform: translateX(0);
}
}
@keyframes covid-btn-01-out {
0% {
transform: translateX(0);
}
100% {
transform: translateX(-200px);
}
}


.snsBtn{
width: 40px;
display: block;
position: fixed;
top: calc(50% - 50px);
right: calc(2.5vw - 20px);
}
.snsBtn ul{
display: block;
position: relative;
z-index: 70000;
}
.snsBtn ul li{
display: block;
margin: 20px 0 0 0;
}
.snsBtn ul li:first-child{
margin: 0 0 0 0;
}
.snsBtn ul li a{
width: 40px;
height: 36px;
display: block;
background-color: #ffffff;
border: 2px solid #231815;
border-radius: 20px;
box-sizing: border-box;
}
.snsBtn ul li.in a{
width: 40px;
height: 0;
display: block;
padding-top: 36px;
background: url(../img/ico_in.svg) no-repeat center center;
background-color: #ffffff;
background-size: 20px auto;
overflow: hidden;
}
.snsBtn ul li.tw a{
width: 40px;
height: 0;
display: block;
padding-top: 36px;
background: url(../img/ico_tw.svg) no-repeat center center;
background-color: #ffffff;
background-size: 21px auto;
overflow: hidden;
}



/* menu */
#menu{
width: 62px;
height: 56px;
display: block;
position: fixed;
top: calc( 2.5vw + 8px );
right: calc( 2.5vw + 8px );
transition: all 0.5s;
z-index: 90100;
cursor: default;
pointer-events: inherit;
cursor: pointer;
overflow: hidden;
}
#menu.on{
display: block;
}
#menu span {
width: 62px;
height: 8px;
display: inline-block;
transition: all .4s;
box-sizing: border-box;
background-color: #ffffff;
border-radius: 4px;
position: absolute;
right: 0;
}

#menu p{
width: 62px;
display: block;
color: #ffffff;
font-size: 1.8rem;
font-weight: 700;
line-height: 1;
position: absolute;
right: 0;
text-align: center;
}

#menu span:nth-of-type(1) {
top: 0;
}
#menu span:nth-of-type(2) {
top: 20px;
}
#menu p{
top: 38px;
}

#menu span:nth-of-type(1) {
animation: menu-bar01 .5s forwards;
}
#menu span:nth-of-type(2) {
animation: menu-bar01 .75s forwards;
}


@keyframes menu-bar01 {
0% {
transform: translateX(60px);
}
100% {
transform: translateX(0);
}
}

#menu.active{
mix-blend-mode:normal;
}
#menu.active span{
}
#menu.active p{
display: none;
}

#menu.active span:nth-of-type(1) {
animation: active-menu-bar01 .5s forwards;
}
@keyframes active-menu-bar01 {
0% {
}
50% {
opacity: 0;
}
51% {
transform: translate(0,19px) rotate(-45deg);
opacity: 0;
background: #ffffff;
}
100% {
transform: translate(0,19px) rotate(-45deg);
opacity: 1;
background: #ffffff;
}
}

#menu.active span:nth-of-type(2) {
animation: active-menu-bar02 .5s forwards;
}
@keyframes active-menu-bar02 {
0% {
}
50% {
opacity: 0;
}
51% {
transform: translate(0,0) rotate(45deg);
opacity: 0;
background: #ffffff;
}
100% {
transform: translate(0,0) rotate(45deg);
opacity: 1;
background: #ffffff;
}
}

#menu.active p {
animation: active-menu-txt .5s forwards;
}
@keyframes active-menu-txt {
0% {
opacity: 1;
}
100% {
opacity: 1;
}
}


/* nav */
nav{
width: 100vw;
height: 100vh;
display: none;
position: fixed;
top: 0;
left: 0;
z-index: 90000;
}
nav.active{
display: block;
background-color: #231815;
z-index: 90000;
}

.naviBox{
height: 70vh;
margin: 11vh 10vw 0 10vw;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.naviBox div{
width:30%;
display: block;
background-color:#fafaed;
border-radius: 20px;
}

.naviBox div ul{
display: block;
padding: 4vh 10px 4vh 10px;
}
.naviBox div ul.menuall{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
padding: 4vh 10px 4vh 10px;
}
.naviBox div ul li{
height: calc( (70vh - 8vh - 36vh)/4 );
display: block;
margin: 0 2vw 0 2vw;
border-top: 1px solid #e94630;
}
.naviBox div ul li:first-child{
height: 36vh;
margin: 0 0 0 0;
border-top: none;
}
.naviBox div ul li:last-child{
border-bottom: 1px solid #e94630;
}

.naviBox div ul.menuall li{
width: 48%;
height: calc( (70vh - 8vh - 36vh)/5 );
display: block;
margin: 0;
border-top: 1px solid #e94630;
}
.naviBox div ul.menuall li:first-child{
width: 100%;
height: 36vh;
margin: 0 0 0 0;
border-top: none;
}
.naviBox div ul.menuall.pat2 li{
width: 48%;
height: calc( (70vh - 8vh - 28vh)/8 );
display: block;
margin: 0;
border-top: 1px solid #e94630;
}
.naviBox div.osakaNavi  ul.menuall.pat2 li{
border-top: 1px solid #1578aa;
}
.naviBox div.fukuokaNavi  ul.menuall.pat2 li{
border-top: 1px solid #57ac6f;
}
.naviBox div ul.menuall.pat2 li:first-child{
width: 100%;
height: 28vh;
margin: 0 0 0 0;
border-top: none;
}

.naviBox div ul.menuall.pat2 li.ttable,
.naviBox div ul.menuall.pat2 li.tticket{
width: 100%;
text-align: center;
}
.naviBox div ul.menuall.pat2 li.ttable{
height: calc( (70vh - 8vh - 28vh)/4 );
}
.naviBox div ul.menuall.pat2 li.tticket{
border-top: none;
}
.naviBox div ul.menuall li:nth-last-child(2){
border-bottom: 1px solid #e94630;
}
.naviBox div.osakaNavi ul.menuall li:nth-last-child(2){
border-bottom: 1px solid #1578aa;
}
.naviBox div.fukuokaNavi ul.menuall li:nth-last-child(2){
border-bottom: 1px solid #57ac6f;
}

.naviBox div.osakaNavi ul li{
border-top: 1px solid #1578aa;
}
.naviBox div.osakaNavi ul li:first-child{
border-top: none;
}
.naviBox div.osakaNavi ul li:last-child{
border-bottom: 1px solid #1578aa;
}
.naviBox div.fukuokaNavi ul li{
border-top: 1px solid #57ac6f;
}
.naviBox div.fukuokaNavi ul li:first-child{
border-top: none;
}
.naviBox div.fukuokaNavi ul li:last-child{
border-bottom: 1px solid #57ac6f;
}

.naviBox div ul li a{
display: block;
font-size: 2rem;
font-weight: 500;
text-align: center;
line-height: 6.5vh;
}
.naviBox div ul.menuall li a{
font-size: 1.5rem;
}
.naviBox div ul li a.nolink{
color: #cccccc;
}
.naviBox div ul.menuall li a{
line-height: 5.2vh;
}
.naviBox div ul.menuall.pat2 li a{
font-size: 1.4rem;
line-height: 3.6vh;
}
.naviBox div ul.menuall.pat2 li.ttable a span{
display: inline-block;
}
.naviBox div ul.menuall.pat2 li a.sub{
width: 30%;
display: inline-block;
background-color: #231815;
color: #ffffff;
border-radius: 1.8vh;
}

.naviBox div ul.menuall.pat2 li.tticket a{
width: 100%;
height: calc( (70vh - 8vh - 28vh)/8 - 5px);
display: block;
background-color: #e94630;
color: #ffffff;
border-radius: 10px;
line-height: calc( (70vh - 8vh - 28vh)/8 - 5px);
}
.naviBox div.osakaNavi ul.menuall.pat2 li.tticket a{
background-color: #1578aa;
}
.naviBox div.fukuokaNavi ul.menuall.pat2 li.tticket a{
background-color: #57ac6f;
}

.naviBox div.tokyoNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../tokyo/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 35vh;
}
.naviBox div.osakaNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../osaka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 35vh;
}
.naviBox div.fukuokaNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../fukuoka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 35vh;
}

.naviBox div.tokyoNavi ul.menuall.pat2 li:first-child a{
height: 0;
display: block;
padding-top: 26vh;
background: url(../tokyo/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 28vh;
}
.naviBox div.osakaNavi ul.menuall.pat2 li:first-child a{
height: 0;
display: block;
padding-top: 26vh;
background: url(../osaka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 28vh;
}
.naviBox div.fukuokaNavi ul.menuall.pat2 li:first-child a{
height: 0;
display: block;
padding-top: 26vh;
background: url(../fukuoka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 28vh;
}

.naviCommon{
display: block;
margin: 3vh 10vw 0 10vw;
text-align: center;
}
.naviCommon ul{
width: 500px;
display: inline-block;
text-align: center;
}
.naviCommon ul li{
display: block;
float: left;
margin: 0 0 0 5%;
padding: 0 15px 0 15px;
line-height: 6.5vh;
background-color: #fafaed;
border-radius: 20px;
}
.naviCommon ul li a{
font-size: 2rem;
font-weight: 500;
}
.naviCommon ul li:first-child{
margin: 0 0 0 0;
}
.naviCommon ul li.in,
.naviCommon ul li.tw{
display: inline-block;
margin: 0 0 0 3%;
padding: 0;
line-height: 6.5vh;
background-color:transparent;
}
.naviCommon ul li.in{
margin: 0 0 0 5%;
}
.naviCommon ul li.in a{
width: 40px;
height: 0;
display: block;
padding-top: 6.5vh;
background: url(../img/ico_in_w.svg) no-repeat center center;
background-size: contain;
overflow: hidden;
}
.naviCommon ul li.tw a{
width: 40px;
height: 0;
display: block;
padding-top: 6.5vh;
background: url(../img/ico_tw_w.svg) no-repeat center center;
background-size: contain;
overflow: hidden;
}

.naviCommon ul:after{
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}


/* footerCovid */
#footerCovid{
display: block;
background-color: #231815;
}
#footerCovid .btn a{
display: block;
background-color: #e94630;
color: #ffffff;
border-bottom-left-radius: 20px;
border-bottom-right-radius: 20px;
font-size: 2.4rem;
font-weight: 700;
line-height: 100px;
text-align: center;
}
#footerCovid .btn a span{
display: inline-block;
padding-right: 55px;
background: url(../img/arr_r_w.svg) no-repeat right 5px center;
background-size: auto 14px;
}
#footerCovid .btn a:hover span{
background: url(../img/arr_r_w.svg) no-repeat right center;
background-size: auto 14px;
transition: all 0.2s;
}


/* footer */
footer{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
padding: 20px 5vw 42px 5vw;
background-color: #231815;
color: #ffffff;
font-size: 1.4rem;
}
footer a{
color: #ffffff;
}
footer a:hover{
text-decoration: underline;
}
.footer_left{
width: 80%;
display: block;
text-align: left;
}
.footer_right{
width: 20%;
display: block;
text-align: right;
}
.footer_left ul{
display: block;
}
.footer_left li{
display: inline-block;
margin: 0 0 0 18px;
}
.footer_left li:first-child{
margin: 0 0 0 0;
}
#copyright{
display: inline-block;
}



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

a:hover,a:focus,
a:hover img,
a:focus img{
filter: alpha(opacity=1) !important;
-moz-opacity: 1 !important;
opacity: 1 !important;
}


body{
padding: 2.5vw 2.5vw 0 2.5vw;
font-size: 1.4rem;
line-height: 1.7;
}
body.scroll-prevent{
overflow: hidden;
}

html:before{
}
html:before{
}

body:before{
content:"";
display: block;
width: 25px;
height: 25px;
background: url(../img/radius_topleft.png) no-repeat center center;
background-size: 25px auto;
position:fixed;
top: calc(2.5vw - 15px);
left: calc(2.5vw - 15px);
z-index: 90001;
}
body:after{
content:"";
display: block;
width: 75px;
height: 75px;
background: url(../img/radius_topright.png) no-repeat center center;
background-size: 75px auto;
position:fixed;
top: calc(2.5vw - 15px);
right: calc(2.5vw - 15px);
z-index: 90002;
}

/* Layout */
section{
}
#page{
background-color: #fafaed;
border-top-left-radius:10px;
border-top-right-radius:10px;
}
.scroll-prevent #page{
}
main{
}

h2{
font-size: 3.4rem;
}
h3{
margin: 54px 0 0 0;
font-size: 4.2rem;
}

.nolink{
}

.pcHide{
display: block !important;
}
.spHide{
display: none !important;
}
.pc_br{
display: none;
}
.sp_br{
display: inline;
}

.col1{
max-width: 100%;
}
.col1 li{
width: 86%;
margin: 0 7% 0 7%;
}
.col2{
max-width: 100%;
display: block;
}
.col2 li{
width: 86%;
margin: 16px 7% 0 7%;
}
.col2 li:first-child{
margin-top:0;
}
.col3{
}
.col3 li{
width: 50%;
}


/* header */
header{
padding: 20px 2.5vw 0 2.5vw;
}
header .headInfo{
display: flex;
justify-content: space-between;
flex-wrap: wrap;
margin: 0 2.5vw 0 2.5vw;
position: absolute;
top: 10px;
left: 0;
z-index:88100;
}

header .headInfo .pickup{
width: 100%;
padding: 0 0 0 0;
}
header .headInfo .gNav{
display: none;
}

header .headInfo .pickup a{
height: auto;
display: block;
padding: 7px 32px 7px 10px;
background: url(../img/arr_r.svg) no-repeat right 10px center;
background-size: 16px auto;
background-color: #ffffff;
border: 2px solid #e94630;
border-radius: 10px;
line-height: 22px;
}
header .headInfo .pickup a span:before{
content: "PICKUP";
display: inline-block;
height: 22px;
margin-right: 10px;
padding: 0 7px 0 7px;
background-color: #e94630;
color: #ffffff;
border-radius: 11px;
font-size: 1.1rem;
}


header h1{
width: 92px;
}
header h1 a{
width: 92px;
padding-top: 64px;
background: url(../img/logo.svg) no-repeat center center;
}
#top header h1 a{
}

header h1.on{
display: block;
}

header h1{
animation: h1-out .5s forwards;
}
header h1.on{
animation: h1-in .5s forwards;
}

@keyframes h1-out {
0% {
transform: translateY(0);
}
100% {
transform: translateY(-300px);
}
}
@keyframes h1-in {
0% {
transform: translateY(-300px);
}
100% {
transform: translateY(0);
}
}

/* Btn */
.covidBtn{
width: calc(100% - 10vw);
bottom: 5px;
left: 5vw;
}
.covidBtn2{
bottom: auto;
top: calc(100vh - 318px);
}
.covidBtn a{
width: 100%;
display: block;
padding: 15px 0 15px 0;
border-top-left-radius: 10px;
border-bottom-left-radius: 10px;
border-top-right-radius: 10px;
border-bottom-right-radius: 10px;
z-index: 1000;
text-align: center;
}
.covidBtn a span{
display: inline-block;
padding: 0 40px 0 0;
background: url(../img/arr_r_w.svg) no-repeat right center;
background-size: auto 10px;

}

.covidBtn{
animation: covid-btn-01 .5s forwards;
}
.covidBtn.outpos{
animation: covid-btn-01-out .5s forwards;
}

@keyframes covid-btn-01 {
0% {
transform: translateX(-100vw);
}
100% {
transform: translateX(0);
}
}
@keyframes covid-btn-01-out {
0% {
transform: translateX(0);
}
100% {
transform: translateX(100vw);
}
}

.covidBtn2{
animation: covid-btn-02 .5s forwards;
}
.covidBtn2.outpos{
animation: covid-btn-02-out .5s forwards;
}

@keyframes covid-btn-02 {
0% {
transform: translateX(-200px);
}
100% {
transform: translateX(0);
}
}
@keyframes covid-btn-02-out {
0% {
transform: translateX(0);
}
100% {
transform: translateX(-200px);
}
}

/* SNS Btn */
.snsBtn{
width: 32px;
top: calc(50% - 40px);
right: 3vw;
}
.snsBtn ul{
}
.snsBtn ul li{
margin: 16px 0 0 0;
}
.snsBtn ul li:first-child{
margin: 0 0 0 0;
}
.snsBtn ul li a{
width: 32px;
height: 28px;
border: 2px solid #231815;
border-radius: 16px;
box-sizing: border-box;
}
.snsBtn ul li.in a{
width: 32px;
padding-top: 28px;
background: url(../img/ico_in.svg) no-repeat center center;
background-color: #ffffff;
background-size: 18px auto;
}
.snsBtn ul li.tw a{
width: 32px;
padding-top: 28px;
background: url(../img/ico_tw.svg) no-repeat center center;
background-color: #ffffff;
background-size: 19px auto;
}



/* menu */
#menu{
width: 36px;
height: 36px;
top: calc( 2.5vw + 4px );
right: calc( 2.5vw + 4px );
}
#menu.on{
}
#menu span {
width: 32px;
height: 5px;
border-radius: 3px;
background-color: #ffffff;
}
#menu span:nth-child(3) {
width: 22px;
height: 2px;
}
#menu p{
width: 32px;
display: block;
color: #ffffff;
font-size: 1rem;
font-weight: 700;
line-height: 1;
position: absolute;
right: 0;
text-align: center;
}

#menu span:nth-of-type(1) {
top: 0;
}
#menu span:nth-of-type(2) {
top: 12px;
}
#menu p{
top: 22px;
}

#menu span:nth-of-type(1) {
animation: menu-bar01 .5s forwards;
}
#menu span:nth-of-type(2) {
animation: menu-bar01 .75s forwards;
}

@keyframes menu-bar01 {
0% {
transform: translateX(50px);
}
100% {
transform: translateX(0);
}
}

#menu.active{
mix-blend-mode:normal;
}
#menu.active span{
}
#menu.active p{
display: none;
}

#menu.active span:nth-of-type(1) {
animation: active-menu-bar01 .5s forwards;
}
@keyframes active-menu-bar01 {
0% {
}
50% {
opacity: 0;
}
51% {
transform: translate(0,12px) rotate(-45deg);
opacity: 0;
background: #ffffff;
}
100% {
transform: translate(0,12px) rotate(-45deg);
opacity: 1;
background: #ffffff;
}
}

#menu.active span:nth-of-type(2) {
animation: active-menu-bar02 .5s forwards;
}
@keyframes active-menu-bar02 {
0% {
}
50% {
opacity: 0;
}
51% {
transform: translate(0,0) rotate(45deg);
opacity: 0;
background: #ffffff;
}
100% {
transform: translate(0,0) rotate(45deg);
opacity: 1;
background: #ffffff;
}
}

#menu.active p {
animation: active-menu-txt .5s forwards;
}
@keyframes active-menu-txt {
0% {
opacity: 1;
}
100% {
opacity: 1;
}
}


/* nav */
nav{
width: 100vw;
height: 100vh;
display: none;
position: fixed;
top: 0;
left: 0;
z-index: 90000;
overflow-y: scroll;
}
nav.active{
display: block;
background-color: #231815;
}

.naviBox{
height: auto;
margin: 11vh 5vw 0 5vw;
display: block;
}

.naviBox div{
width:auto;
border-radius: 10px;
margin-top: 20px;
}
.naviBox div:nth-of-type(1){
margin-top: 0;
}

.naviBox div ul{
display: block;
padding: 4vh 10px 4vh 10px;
}
.naviBox div ul li{
height: auto;
display: block;
margin: 0 5vw 0 5vw;
border-top: 1px solid #e94630;
}
.naviBox div ul li:first-child{
height: 35vh;
margin: 0 0 0 0;
border-top: none;
}
.naviBox div ul li:last-child{
border-bottom: 1px solid #e94630;
}

.naviBox div.osakaNavi ul li{
border-top: 1px solid #1578aa;
}
.naviBox div.osakaNavi ul li:first-child{
border-top: none;
}
.naviBox div.osakaNavi ul li:last-child{
border-bottom: 1px solid #1578aa;
}
.naviBox div.fukuokaNavi ul li{
border-top: 1px solid #57ac6f;
}
.naviBox div.fukuokaNavi ul li:first-child{
border-top: none;
}
.naviBox div.fukuokaNavi ul li:last-child{
border-bottom: 1px solid #57ac6f;
}

.naviBox div ul li a{
font-size: 1.6rem;
line-height: 4.8vh;
}
.naviBox div ul li a.nolink{
color: #cccccc;
}

.naviBox div.tokyoNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../tokyo/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 32vh;
}
.naviBox div.osakaNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../osaka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 35vh;
}
.naviBox div.fukuokaNavi ul li:first-child a{
height: 0;
display: block;
padding-top: 32vh;
background: url(../fukuoka/img/main_sp.svg) no-repeat center top;
background-size: contain;
overflow: hidden;
line-height: 35vh;
}

.naviCommon{
margin: 6vh 5vw 10vh 5vw;
text-align: center;
}
.naviCommon ul{
width: auto;
display: block;
}
.naviCommon ul li{
display: block;
float: none;
margin: 3vh 0 0 0;
padding: 0;
line-height: 6.5vh;
background-color: #fafaed;
border-radius: 10px;
}
.naviCommon ul li a{
font-size: 1.6rem;
}
.naviCommon ul li:first-child{
margin: 0 0 0 0;
}
.naviCommon ul li.in,
.naviCommon ul li.tw{
display: inline-block;
margin: 3vh 0 0 5vw;
padding: 0;
line-height: 6.5vh;
background-color:transparent;
}
.naviCommon ul li.in{
margin: 3vh 0 0 0;
}
.naviCommon ul li.in a{
width: 40px;
height: 0;
display: block;
padding-top: 6.5vh;
background: url(../img/ico_in_w.svg) no-repeat center center;
background-size: contain;
overflow: hidden;
}
.naviCommon ul li.tw a{
width: 40px;
height: 0;
display: block;
padding-top: 6.5vh;
background: url(../img/ico_tw_w.svg) no-repeat center center;
background-size: contain;
overflow: hidden;
}

.naviCommon ul:after{
content: "";
display: block;
clear: both;
height: 0;
visibility: hidden;
}


/* footerCovid */
#footerCovid{
}
#footerCovid .btn a{
border-bottom-left-radius: 10px;
border-bottom-right-radius: 10px;
font-size: 1.8rem;
line-height: 80px;
}
#footerCovid .btn a span{
display: inline-block;
padding-right: 46px;
background: url(../img/arr_r_w.svg) no-repeat right center;
background-size: auto 12px;
}


/* footer */
footer{
display: block;
padding: 20px 5vw 42px 5vw;
font-size: 1.2rem;
}
footer a{
}
.footer_left{
width: auto;
text-align: left;
}
.footer_right{
width: auto;
margin: 24px 0 0 0;
text-align: left;
}
.footer_left ul{
}
.footer_left li{
display: block;
margin: 0 0 12px 0;
}
.footer_left li:first-child{
margin: 0 0 12px 0;
}
.footer_left li:before{
content:"-";
display: inline-block;
margin-right: 6px;
}
#copyright{
}



/* */
/* */
}
/* -- */
/* -- */
/* SP */
/* -- */
/* -- */
