@charset "utf-8";

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

style.css

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



.headerLogoGroup{
    width: 50px;
    position: absolute;
    height: auto;
}

.headerLogoGd{
    margin-bottom: 5px;
}
.headerLogo{
    text-align: center;
    margin-top: 10px;
    margin-bottom: 20px;
}
.headerLogo img{
    max-width: 100px;
}

.gNav ul{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr;
    border: solid 1px #94ADE4;
}

.gNav ul li{
    border-right: solid 1px #94ADE4;

}
.gNav ul li:last-child{
    border-right: none;
}
.gNav ul li a{
    display: block;
    padding-top: 18px;
    padding-bottom: 18px;
    text-align: center;
}
.gNav ul li a span{
    font-family: 'Times New Roman';
    border-bottom: solid 1px #94ADE4;
    display: inline-block;
}
.gNav ul li a em{
    display: block;
    margin-top: 5px;
}
.gNav {
    margin-bottom: 60px;
}

.slide li{
    vertical-align: bottom;
}


section{
    padding-bottom: 90px;
}
.bannerBox {
    margin-bottom: 30px;
}

.bannerBox ul{
    display: grid;
    grid-template-columns: 45% 45%;
    column-gap: 10%;
    row-gap: 30px;
    width: 70%;
    margin-left: auto;
    margin-right: auto;
}
h2.svgL{
    text-align: center;
    position: relative;
}
h2.svgL::after {
    content: url(../images/borderL.svg);
    width: 51%;
    right: 36%;
    position: absolute;
    bottom: 2px;
}
h2.svgR{
    text-align: center;
    position: relative;
}
h2.svgR::after {
    content: url(../images/borderR.svg);
    width: 51%;
    left: 36%;
    position: absolute;
    bottom: 2px;
}
h2.svgL img{
    position: relative;
    height: 58px;
    z-index: 2;
}
h2.svgR img{
    position: relative;
    height: 58px;
    z-index: 2;
}

h2 {
    margin-bottom: 60px;
    text-align: center;
}

.btnBox {
    text-align: center;
}
.btnBox img{
    height: 36px;
    width: auto;    
}


.rankingBox ul{
    display: grid;
    grid-template-columns: 20% 20% 20% 20% 20%;
    row-gap: 30px;
    margin-bottom: 60px;
}
.rankingBox h3{
    font-size: 2rem;
}
.rankingBox ul li .imgBox{
    margin-bottom: 10px;
}
.rankingBox ul li .textBox{
    text-align: center;
}
.rankingBox ul li .textBox .position {
    font-size: 1.4rem;
    margin-bottom: 0;
    min-height: 1.8em;
}
.rankingBox ul li {
    position: relative;
    padding-bottom: 30px;
}
.salesIcon{
    min-height: 30px;
    text-align: right;
}

.salesIcon img{
    width: 140px;
}
.kumisuuIcon{
    min-height: 30px;
    text-align: left;
    bottom: 0;
    position: absolute;
}
.kumisuuIcon img {
    width: 140px;
}


.label{
    padding-left: 5px;
    padding-right: 5px;
    padding-top: 2px;
    padding-bottom: 2px;
    color: #FFF;
    text-align: center;
    font-size: 1.2rem;
    display: inline-block;
    min-width: 75px;
}
.label.special{
    background-color: #B386FF;
}
.label.ryusei{
    background-color: #7E8ADC;
}
.label.movie{
    background-color: #3DB0BE;
}
.label.info{
    background-color: #3A8CD9;
}
.label.media{
    background-color: #3DB0BE;
}



.informationTextList dl dt {
    font-size: 1.2rem;
    margin-bottom: 5px;
    font-weight: 200;
}
.informationTextList dl dt .label{
    margin-left: 10px;
}

.informationTextList dl dd{
    margin-bottom: 25px;
    font-size: 1.6rem;
}
section.bgLblue{
    padding-top: 90px;
}

section.bgLblue{
   background-color: #DBE5EF
}
.movie3cBox{
    margin-bottom: 40px;
}
.movie3cBox.indexTop ul{
    display: block;
}
.movie3cBox ul{
    display: grid;
    grid-template-columns: 30% 30% 30%;
    column-gap: 5%;
    row-gap: 40px;
}
.movie3cBox ul li{
    padding: 3%;
}
.movie3cBox .imgBox{
    margin-bottom: 8px;
}
.movie3cBox h3{
    width: 100%;
    overflow: hidden;
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
.media3cBox h3{
    width: 100%;
    overflow: hidden;
    display: -webkit-box;
    text-overflow: ellipsis;
    -webkit-box-orient: vertical;
    -webkit-line-clamp: 2;
}
.movie3cBox .label{
    margin-right: 5px;
}
.date {
    margin-bottom: 8px;
    font-size: 1.2rem;
    font-weight: 200;
}
.media3cBox.indexTop ul{
    display: block;
}
.media3cBox ul{
    display: grid;
    grid-template-columns: 30% 30% 30%;
    column-gap: 5%;
}
.media3cBox ul li{
    padding: 3%;
}
.media3cBox .imgBox{
    margin-bottom: 8px;
}
.media3cBox .date{
    margin-bottom: 8px;
}
.media3cBox{
    margin-bottom: 40px;
}
.scheduleTextList dl{
    display: grid;
    grid-template-columns: 120px 1fr;
    column-gap: 30px;
    row-gap: 30px;
}
.scheduleTextList {
    margin-bottom: 40px;
    font-weight: 200;
}
.scheduleTextList dt{
    display: flex;
    align-items: center;
}
.scheduleTextList dd{
    font-size: 2rem;
}

section.bgLblue + section{
    padding-top: 90px;
}
.aboutLogo{
    text-align: center;
    margin-bottom: 20px;
}
.aboutLogo img{
    max-width: 100px;
}

.aboutImg{
    max-width: 480px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
}
.aboutText{
    max-width: 680px;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 30px;
    font-weight: 200;
}
.accessBox{
    margin-top: 40px;
}
.accessBox .mapBox{
    margin-bottom: 20px;
}
.access2c{
    display: grid;
    grid-template-columns: 40% 60%;
    width: 60%;
    margin-left: auto;
    margin-right: auto;
    column-gap: 30px;
}
.mapBox iframe{
    width: 100%;
    min-height: 500px;
}
.access2c .aboutText{
    margin-bottom: 0;
    display: flex;
    align-items: center;
}


.pagetop {
    position: fixed;
    bottom: 20px;
    right: 20px;
    z-index: 100;
}
.pagetop img{
    width: 20px;
}


.snsBox{
    background-color: #DBE5EF;
    padding-top: 20px;
    padding-bottom: 20px;
    text-align: center;
}
.snsBox .ttl{
    font-size: 22px;
    font-weight: bold;
    display: inline-block;
    letter-spacing: 3px;
    color: #404040;
}
.snsBox .snsLogo{
    margin-left: 20px;
    width: 40px;
    height: auto;
    display: inline-block;
}
.footerCopyright{
    background-color: #0F2D64;
    text-align: center;
    color: #fff;
    padding: 10px;
    font-size: 1.1rem;
}





.staffProfileBox{
    display: grid;
    grid-template-columns: 48% 48%;
    column-gap: 4%;
    max-width: 80%;
    margin-left: auto;
    margin-right: auto;
    margin-bottom: 20px;
}
.position{
    font-size: 1.4rem;
    margin-bottom: 10px;
    font-weight: 200;
}
.name{
    font-size: 2.6rem;
    margin-bottom: 10px;
}
.nameEn{
    font-size: 1.6rem;
    margin-bottom: 20px;
}
.basicInfo{
    margin-bottom: 30px;
    font-size: 1.4rem;
}
.staffProfileBox .snsList img{
    width: 38px;
}
.staffProfileBox .snsList ul{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr;
    width: 60%;
    row-gap: 20px;
}
.staffProfileBox .snsList ul li{
    display: flex;
    align-items: center;
}
.photoSlide ul li{
    padding-left: 10px;
    padding-right: 10px;
}
.basicInfo span{
    padding-right: 20px;
    position: relative;
    display: inline-block;
    margin-right: 20px;
}
.basicInfo span::after{
    content: '/';
    position: absolute;
    right: 0;
    top: 0;
}
.basicInfo span:last-child::after{
    display: none;
}
.slick-prev{
    background-image: url(../images/prev.svg);
    background-size: contain;
    width: 40px;
    height: 40px;
    top: calc( 50% - 20px );
    position: absolute;
    left: -40px;
    z-index: 1;
    font-size: 0;
}
.slick-next{
    background-image: url(../images/next.svg);
    background-size: contain;
    width: 40px;
    height: 40px;
    top: calc( 50% - 20px );
    right: -40px;
    position: absolute;
    z-index: 1;
    font-size: 0;
}



.profileContents .salesIcon{
    text-align: left;
    display: inline-block;
    width: auto;
}
.profileContents .salesIcon img{
    width: auto;
    height: 37px;
    vertical-align: bottom;
}
.profileContents .kumisuuIcon{
    position: relative;
    text-align: left;
    display: inline-block;
    width: auto;
}
.profileContents .kumisuuIcon img{
    width: auto;
    height: 40px;
    vertical-align: bottom;
}
.profileContents .icons{
    margin-bottom: 30px;
    display: grid;
    grid-template-columns: 1fr 1fr;
    column-gap: 20px;
}

.specialLabel ul{
    display: grid;
    grid-template-columns: 24% 24% 24% 24%;
    column-gap: 1.3333333%;
    width: 100%;
    row-gap: 15px;
}
.specialLabel ul li{
    padding: 15px;
    background-color: #004B96;
    color: #FFF;
    text-align: center;
    display: flex;
    align-items: center;
    justify-content: center;
}
.photoSlide{
    margin-bottom: 40px;
}
.modaal-gallery-item img{
    max-height: 85vh;
    max-width: 60vh;
    width: auto !important;
}
.modaal-gallery-item{
    max-height: 85vh;
}

.modaal-overlay{
    background-color: #FFF !important;
}
.modaal-close:before, .modaal-close:after{
    background-color: #000;
}
.modaal-gallery-control:before, .modaal-gallery-control:after{
    background-color: #000;
    border-radius: 0;
}
.modaal-gallery-control:before{

}
.modaal-container{
    box-shadow: none;
}

.movieBox {
    width: 100%;
    aspect-ratio: 16 / 9;
}
.movieBox iframe {
    width: 100%;
    height: 100%;
}

.mediaThumBox{
    margin-bottom: 40px;
}

h3.mediaTitle{
    font-size: 2.2rem;
    padding-bottom: 10px;
    margin-bottom: 15px;
    border-bottom: #404040 solid 1px;
}

.scheduleCallenderBox{
    display: grid;
    grid-template-columns: 1fr 1fr 1fr 1fr 1fr 1fr 1fr;
    width: 100%;
    column-gap: 3px;
    row-gap: 3px;
}
.scheduleCallenderBox .youbi{
    text-align: center;
    font-weight: bold;
    margin-bottom: 10px;
    font-size: 18px;
}


.scheduleCallenderBox .box{
    background-color: #FFF;
    border: solid 1px #555;
}
.scheduleCallenderBox .boxInner{
    display: flex;
    align-items: center;
    padding: 60px 10px 10px 10px;
    position: relative;
    
}
.scheduleCallenderBox .box.off{
    background-color: #E5E5E5;
}
.scheduleCallenderBox a{
    display: block;
}
.scheduleCallenderBox .day{
    position: absolute;
    top: 10px;
    left: 10px;
    font-size: 2rem;
}
.scheduleCallenderBox .box.event{
    background-color: #003292;

}
.scheduleCallenderBox .box.event a{
    color: #FFF;
}
.scheduleCallenderBox .box.event p{
    color: #FFF;
}
.scheduleCallenderBox .box.event .day{
    color: #fff;
}
.scheduleCallenderBox .box.prev_month{
    opacity: 0.3;
}
.scheduleCallenderBox .box.next_month{
    opacity: 0.3;
}
.scheduleBannerSlide ul li{
    padding: 15px;
}
.scheduleBannerSlide {
    margin-bottom: -30px;
    clear: both;
}
.scheduleBannerSlide .slick-prev{
    left: -35px;
    background-image: url(../images/prev_chev.svg);
    background-size: 15px;
    background-repeat: no-repeat;
}
.scheduleBannerSlide .slick-next{
    right: -35px;
    background-image: url(../images/next_chev.svg);
    background-size:15px;
    background-repeat: no-repeat;
}

.slick-disabled{
    display: none !important;
}

.nextMonthLink{
    max-width: 100px;
    float: right;
}
.nextMonthLink img{
    width: 100%;
    height: auto;
}
.prevMonthLink{
    max-width: 60px;
    float: right;
    margin-right: 30px;
}
.prevMonthLink img{
    width: 100%;
    height: auto;
}

.aboutDetailImg{
    margin-bottom: 40px;
}
.aboutSection{
    margin-bottom: 30px;
}
.aboutSection .lead{
    font-size: 1.8rem;
}
h3.aboutH{
    font-size: 2.2rem;
    padding-bottom: 10px;
    margin-bottom: 15px;
    border-bottom: #404040 solid 1px;
}
.aboutSection h4{
    font-size: 1.8rem;
}
.aboutSection p{
    font-size: 1.4rem;
}

.photoSlide .slick-track{
    height: 370px;
}
.photoSlide .slick-slide > div{
    height: 100%;
    display: flex;
    align-items: center;
}

.mediaCatBox{
    margin-bottom: 20px;
}
.mediaCatBox ul {
    text-align: center;
}
.mediaCatBox ul li{
    display: inline-block;
    margin: 20px;
}

.mediaCatBox ul li a {
    padding: 5px 40px;
    display: block;
    background-color: #DBE5EF;
    color: #0F2D64;
    border-radius: 100px;
    min-width: 140px;
}
.mediaCatBox ul li.current a{
    background-color: #0F2D64;
    color: #DBE5EF;
}

.pagerBox{
    text-align: center;
}
.pagerBox .prev{
    display: inline-block;
    margin-left: 10px;
    margin-right: 10px;
    height: 30px;
    width: 30px;
}
.pagerBox .next{
    display: inline-block;
    margin-left: 10px;
    margin-right: 10px;
    height: 30px;
    width: 30px;
}
.pagerBox .pager {
    display: inline-block;
}
.pagerBox .pager li{
    display: inline-block;
    margin-left: 10px;
    margin-right: 10px;
}
.pagerBox .pager li a{
    display: flex;
    height: 30px;
    width: 30px;
    border-radius: 100px;
    background-color: #DBE5EF;
    text-align: center;
    align-items: center;
    justify-content: center;
    color: #0F2D64;
}
.pagerBox .pager li a.current{
    background-color: #0F2D64;
    color: #fff;
}
.pagerBox .pager li .prev a,
.pagerBox .pager li .next a{
    background: transparent !important;
}
.media3cBox li.off{
    display: none;
}
.pagerBox .pager li a.disable{
    cursor: default;
    pointer-events: none;
}
#listControll{
    overflow: hidden;
}

.castNewIcon{
    background-image: url(/common/images/icon_new_pink.svg);
    width: 26%;
    height: 24px;
    background-repeat: no-repeat;
    background-size: contain;
    position: absolute;
    left: 0;
    top: auto;
}