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

.kv__slider{ position:relative; height:763px;}
.kv__slide{ position:absolute; inset:0; opacity:0; transition:opacity .8s ease; }
.kv__slide.is-active{ opacity:1; }
.kv__slide img{
    width:100%;
    height:  auto;
}
@media (max-width: 600px) {
   .kv__slider{ 
    height: 140vw;
    }
}

.chara-about,.chara-goods,.chara-event,.chara-ticket{
    position:relative;
    z-index: 0;
}
.chara-about:before{
        position: absolute;
    content: "";
    background: url(../img/chara/chara2.png);
    background-size: contain;
    background-position: top left;
    background-repeat: no-repeat;
    width: 200px;
    height: 200px;
    right: -10px;
    top: -50px;
    z-index: 2;
}
.chara-event:before{
        position: absolute;
    content: "";
    background: url(../img/chara/chara3.png);
    background-size: contain;
    background-position: bottom left;
    background-repeat: no-repeat;
    width: 260px;
    height: 240px;
    left: -20px;
    top: -80px;
}

.chara-ticket:before{
        position: absolute;
    content: "";
    background: url(../img/chara/chara4.png);
    background-size: contain;
    background-position: bottom left;
    background-repeat: no-repeat;
    width: 240px;
    height: 240px;
    right: -80px;
    top: -80px;
}
.chara-goods:after{
        position: absolute;
    content: "";
    background: url(../img/chara/chara5.png);
    background-size: contain;
    background-position: bottom left;
    background-repeat: no-repeat;
    width: 200px;
    height: 240px;
       left: 0;
    top: -60px;
}

@media (max-width: 500px) {
    .chara-about:before {
    right: -40px;
    top: -60px;
}
    .chara-event:before {
    left: -40px;
}
    .chara-ticket:before {
    right: inherit;
    left: 0;
}
    
.chara-goods:after{
    top: -80px;
       left: -20px;
}

}
/* NEWS */

.top-sns-news-container{
        background-color: #fff2f7;
    margin: 80px auto 0;
    padding: 40px;
    border-radius: 30px;
    color:#000;
}

.top-sns-heading{
    margin: -65px 0 0;
    text-align: left;
    font-size: 30px;
    font-weight: 800;
    
}
.top-sns-heading .red{
    color:#e50013;
}
.top-news{
        height: 220px;
    overflow-y: auto;
}
.top-news-lists{}
.top-news-list{

    padding-top: 15px;
    padding-bottom: 15px;
}
.top-news-list:first-child{

    padding-top: 0;
    padding-bottom: 15px;
}
.top-news-list:last-child{
       border-bottom: 0;
    padding-bottom: 0;
}
.top-news-list-day{
        line-height: calc(28 / 16);
    font-size: 14px;
    color:#e50013;
}
.top-news-list-text{
    background-color:#fff;
    padding: 5px;
}

/* ABOUT */
.top-about-section{
  padding: 60px 0 80px;
}
/*
.top-about-section .inner,
.top-goods-section .inner,
.top-event-section .inner,
.top-ticket-section .inner{
    padding-top: 120px;
    margin-top: -120px;
}
*/
.top-about-list{
        display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    padding-top: 15px;
    padding-bottom: 15px;
    flex-direction: column;
    border:none;
}
.top-about-list:last-child{
    border-bottom: none;
}
.top-about-list-heading{
    width: 100%;
    padding: 0 15px;
    letter-spacing: 0.08em;
    line-height: calc(28 / 16);
    font-size: 15px;
    border-bottom:1px solid #e50013;
    color: #fff;
    position: relative;
    font-weight: 800;
    }
.top-about-list-heading:before{
    content:"";
    position: absolute;
    bottom:0;
    left: 0;
       height: 2em;
    width: 10em;
    background-color: #e50013;
    z-index: -1;
}
.top-about-list-data{
    line-height: calc(28 / 16);
    font-size: 15px;
    width: 100%;
    padding-top: 5px;
}
.top-about-list-data .small{
    line-height: calc(21 / 12);
    font-size: 12px;
}
@media (max-width: 799px) {
    
.top-about-section{
    padding-top:100px;
}
    .top-about-list-heading {

        font-size: 14px;
    }
       .top-about-list-data {
      
        font-size: 14px;
    }
}

/***********************************************
***  EVENT
***********************************************/

.top-event-section{
    background-color:#fff2f7;
    padding: 60px 0 80px;
}
.top-event-map-container{
    margin-bottom:40px;
}


.top-event-area-section{
    margin-bottom:60px;
}
/*
.top-event-area-lists{
    margin-bottom:40px;
}
.top-event-area-list{
    background-color: #fff;
    box-shadow: 0 0 3px rgba(0, 0, 0, 0.40);
    position: relative;
    margin-bottom: 20px;
    }
.top-event-area-list:after{
    position: absolute;
    content: "";
    background:url(../img/top/event/arrow-bottom.svg);
    background-size: contain;
    background-repeat: no-repeat;
    width: 30px;
    height: 20px;
    left: 0;
    right: 0;
    text-align: center;
    margin: auto;
    bottom: -24px;
    z-index: 10;
}
.top-event-area-list:last-child:after{
    content:"";
    background:none;
}
.top-event-area-list a{
    display: flex;
    align-items: center;
       justify-content: space-between;
    pointer-events: none;
    cursor: default;
}

.top-event-area-name {
  text-align: center;
    width: 50%;
    font-weight: 800;
    font-size: 18px;
    background-color: #e50013;
    color: #fff;

}
*/
@media (max-width: 799px) {
    
/*
.top-event-area-name {
    font-size: 15px;

}
*/
}
/*
.top-event-area-list.no-image .top-event-area-name{
    width: 100%;
    font-size: 16px;
    font-weight: normal;
    background-color: #fff;
    color: #000;
}
.top-event-area-chara {
    width: 50%;
}
*/
.top-event-space-image-container{
    margin-top:20px;
}
.top-event-space-image-caption{
    line-height:1.3;
    margin-top: 10px;
}
.top-event-novelty-image-container{
    margin-bottom:20px;
}
@media (max-width: 500px) {
    .top-event-lead br{
        display:none;
    }
}
/***********************************************
***  TICKET
***********************************************/
.top-notice-heading{
    font-weight:700;
    text-decoration: underline;
}
.top-ticket-section{
    padding: 60px 0 80px;
    
}
.top-ticket-date{
       border: 2px solid #e50013;
    padding: 5px 20px;
    text-align: left;
    margin: -20px auto 40px;
    width:fit-content;
    font-weight: 800;
}
.top-ticket-price-section,
.top-ticket-tokuten-section,
.top-ticket-voice-section{
    margin-bottom:60px;
}
.top-ticket-lead{
      background: #fff2f7;
    width: fit-content;
    margin: 0 auto 40px;
    box-shadow: 0 0 20px #fff2f7;
}
.ticket-price-container{
  display: grid;
grid-template-columns: 40px 1fr;
grid-column-gap: 0px;
grid-row-gap: 0px;
    margin-bottom:20px;
}
.ticket-price-container.first{
    margin-bottom:30px;
}
.ticket-price-box1{
        grid-area: 1 / 1 / 2 / 3;
}
.ticket-price-box2{
        grid-area: 2 / 1 / 3 / 2;
    border:1px solid #eee;
}
.ticket-price-box3{
        grid-area: 2 / 2 / 3 / 3;
}
.ticket-price-box4{
        grid-area: 3 / 1 / 4 / 2;
background-color: #fff9f2;
    border:1px solid #eee;

}
.ticket-price-box5{
       grid-area: 3 / 2 / 4 / 3;
    background-color: #fff9f2;
}

.ticket-price-category{
    background-color: #e50013;
    text-align: center;
    color: #fff;
    font-weight: 800;
    font-size: 18px;
}

.ticket-price-category2{
        writing-mode: vertical-rl;
    text-orientation: upright;
    margin:auto;
        text-align: center;
    height: 90px;
}
.ticket-price-item{
    display:flex;
    font-size: 14px;
    border:1px solid #eee;
}
.ticket-price-type{
    padding:10px 20px;
    width: calc(100% - 8em);
}
.ticket-price-price{
    padding:10px 20px;
}
.ticket-tokuten-image-container{
    margin-bottom:20px;
}
/***********************************************
***  GOODS
***********************************************/

.top-goods-section{
    background-color:#fff2f7;
    padding: 60px 0 80px;
}
.top-goods-image{
    margin:0 auto 40px;
}
.top-goods-present-section{
    margin-top:60px;
}