@charset "UTF-8";
/*$fontset_min: "游明朝", YuMincho, "Hiragino Mincho ProN W3", "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", serif;*/
ul {
  list-style: none;
}

img {
  border: none;
  vertical-align: bottom;
}

a {
  outline: none;
}

#gaCol {
  height: 0;
  overflow: hidden;
}

#sliderCol .slider-container {
  color: #999999;
  font-size: 0.8rem;
}
#sliderCol .slider-nav-container {
  padding: 10px 0;
}
@media (max-width: 414px) {
  #sliderCol .slider-container .slider {
    padding: 10px 0px;
  }
  #sliderCol .slider-container .slider .slick-slide img {
    width: 96%;
    height: auto;
    margin: 0 auto;
  }
}
@media (min-width: 415px) {
  #sliderCol .slider-container .slider {
    padding: 30px 0px;
  }
  #sliderCol .slider-container .slider .slick-slide img {
    width: 380px;
    height: 380px;
    margin: 0 5px;
  }
  #sliderCol .slider-arrow {
    position: absolute;
    z-index: 10;
  }
  #sliderCol .slider-prev {
    left: 0;
  }
  #sliderCol .slider-next {
    right: 0;
  }
}

.slick-dots {
  z-index: 6;
  font-size: 10px !important;
}
.slick-dots li {
  max-width: 6%;
  padding: 0;
  margin: 0;
}

.slick-active {
  color: #558822;
}

.prev-arrow,
.next-arrow {
  position: absolute;
  z-index: 5;
}

.slide-arrow,
.next-arrow {
  position: absolute;
  top: 50%;
  cursor: pointer;
}

@media (max-width: 768px) {
  .slide-arrow,
  .next-arrow {
    margin-top: -24px;
  }

  .prev-arrow {
    left: 10px;
    width: 20px !important;
    height: auto;
  }

  .next-arrow {
    right: 10px;
    width: 20px !important;
    height: auto;
  }

  #characterImg .prev-arrow {
    left: 0;
  }
  #characterImg .next-arrow {
    right: 0;
  }
}
@media (min-width: 769px) {
  .slide-arrow,
  .next-arrow {
    margin-top: -48px;
  }
  .slide-arrow:hover,
  .next-arrow:hover {
    filter: brightness(300%);
  }

  .prev-arrow {
    left: 10px;
  }

  .next-arrow {
    right: 10px;
  }

  #characterImg .prev-arrow {
    left: 20px;
  }
  #characterImg .next-arrow {
    right: 20px;
  }
}
#characterImg .slick-slide {
  opacity: 0.3;
  transition: 0.5s;
}
#characterImg .slick-current {
  opacity: 1;
}

/*本 ==============================================*/
.anniversaryIco {
  margin: 0 auto 20px;
  width: 40%;
  max-width: 231px;
}

#titlesBookBg {
  background: url(../images/top/titles/bg_book.png) center top no-repeat;
  background-size: 100% auto;
  filter: drop-shadow(0em 0.5em 1em rgba(51, 0, 0, 0.3));
}
@media (max-width: 1024px) {
  #titlesBookBg {
    width: 96%;
    height: 66vw;
    padding: 2% 0 0 0;
    margin: 0 auto 30px;
  }
}
@media (min-width: 1025px) {
  #titlesBookBg {
    width: 870px;
    height: 602px;
    padding: 14px 0 0 0;
    margin: 0 auto 30px;
  }
}

#titlesBook {
  position: absolute;
  top: 0;
  left: 0;
  margin: 0 auto;
  color: #180000;
}
@media (max-width: 1024px) {
  #titlesBook {
    height: 60vw !important;
  }
}
@media (min-width: 1025px) {
  #titlesBook {
    max-width: 790px;
    height: 544px !important;
  }
}
#titlesBook .even {
  background: url(../images/common/frame/bg_fr01_lt.png) left 2% top 2% no-repeat, url(../images/common/frame/bg_fr01_rt.png) right 3% top 1% no-repeat, url(../images/top/titles/bg_book_prev.png) left bottom no-repeat, url(../images/common/frame/bg_fr01_rb.png) right 3% bottom 4% no-repeat, url(../images/titles/bg_book_l.jpg) left top no-repeat;
}
#titlesBook .even .bookPage {
  box-sizing: border-box;
  text-align: center;
  width: 100%;
}
#titlesBook .even .bookPage img {
  width: 90%;
  height: auto;
}
@media (max-width: 1024px) {
  #titlesBook .even {
    background-size: 30px, 30px, 35px, 30px, cover;
  }
  #titlesBook .even .bookPage {
    box-sizing: border-box;
    padding: 0% 2% 4% 0;
    height: 100%;
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
  }
}
@media (min-width: 1025px) {
  #titlesBook .even {
    background-size: 65px, 65px, 75px, 65px, cover;
  }
  #titlesBook .even .bookPage {
    padding: 22% 3% 0;
  }
}
#titlesBook .odd {
  background: url(../images/common/frame/bg_fr01_lt.png) left 3% top 1% no-repeat, url(../images/common/frame/bg_fr01_rt.png) right 2% top 2% no-repeat, url(../images/common/frame/bg_fr01_lb.png) left 3% bottom 4% no-repeat, url(../images/top/titles/bg_book_next.png) right bottom no-repeat, url(../images/titles/bg_book_r.jpg) right top no-repeat;
  background-size: 65px, 65px, 65px, 75px, auto;
}
#titlesBook .odd .bookPage {
  box-sizing: border-box;
  text-align: center;
}
#titlesBook .odd .bookPage img {
  width: 90%;
  height: auto;
}
@media screen and (max-width: 480px) {
  #titlesBook .odd {
    background-size: 30px, 30px, 30px, 40px, cover;
  }
  #titlesBook .odd .bookPage {
    padding: 10% 5% 0;
  }
}
@media screen and (min-width: 481px) and (max-width: 768px) {
  #titlesBook .odd {
    background-size: 30px, 30px, 30px, 40px, cover;
  }
  #titlesBook .odd .bookPage {
    padding: 30% 5% 0;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  #titlesBook .odd {
    background-size: 30px, 30px, 30px, 40px, cover;
  }
  #titlesBook .odd .bookPage {
    padding: 30% 5% 0;
  }
}
@media (min-width: 1025px) {
  #titlesBook .odd {
    background-size: 65px, 65px, 65px, 75px, cover;
  }
  #titlesBook .odd .bookPage {
    padding: 28% 3% 0;
  }
}
#titlesBook .coverpage .bookPage {
  box-sizing: border-box;
  padding: 0% 1% 5% 0;
  height: 100%;
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
}
#titlesBook .coverpage .bookPage img {
  width: 60%;
  height: auto;
}
#titlesBook .lastpage {
  background: url(../images/common/frame/bg_fr01_lt.png) left 3% top 1% no-repeat, url(../images/common/frame/bg_fr01_rt.png) right 2% top 2% no-repeat, url(../images/common/frame/bg_fr01_lb.png) left 3% bottom 4% no-repeat, url(../images/common/frame/bg_fr01_rb.png) right 3% bottom 3% no-repeat, url(../images/titles/bg_book_r.jpg) right top no-repeat;
}
@media (max-width: 1024px) {
  #titlesBook .lastpage {
    background-size: 30px, 30px, 30px, 30px, cover;
  }
}
@media (min-width: 1025px) {
  #titlesBook .lastpage {
    background-size: 65px, 65px, 65px, 65px, cover;
  }
}

.bookYear {
  font-weight: bold;
  font-size: 1.5rem;
  width: 70%;
  margin: 0 auto 0.5em auto;
}
@media (min-width: 1025px) {
  .bookYear {
    background: url(../images/titles/bg_booktit_l.png) left 0 top 5px no-repeat, url(../images/titles/bg_booktit_r.png) right 0 top 5px no-repeat;
    margin: 0 auto 1em auto;
  }
}

.bookLogo {
  margin: 0 auto 0.5em auto;
  height: 15%;
}
@media (min-width: 1025px) {
  .bookLogo {
    margin: 0 auto 1em auto;
    height: 40%;
  }
}

.bookGenre {
  font-weight: bold;
  font-size: 1.2rem;
  line-height: 1.4em;
  margin: 1em auto;
}

.bookPlatform {
  word-break: normal;
  font-size: 1rem;
  line-height: 1.4em;
}

#newsCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  max-width: 1000px;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #newsCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#newsCol .snav ul {
  flex-wrap: nowrap;
}
@media (max-width: 768px) {
  #newsCol .snav .active {
    background-size: 40px auto;
  }
}

#search {
  background: #fffdf2;
  padding: 15px;
  border: 2px solid #f0e6c8;
  margin-bottom: 20px;
  text-align: center;
}

@media (min-width: 769px) {
  #search {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
}
@media (max-width: 768px) {
  #searchTxt select,
  #searchTxt input {
    width: 90%;
    text-align: center;
    margin-bottom: 10px;
  }
}
@media (min-width: 769px) {
  #searchTxt {
    width: calc( 100% - 180px);
  }
  #searchTxt select {
    width: 9em;
  }
  #searchTxt input {
    width: calc( 100% - 10em);
  }
}

#searchBtn img {
  height: 50px;
}
@media (min-width: 769px) {
  #searchBtn {
    width: 160px;
  }
}

#newsList li {
  background: rgba(150, 100, 0, 0.1);
  text-align: left;
  margin-bottom: 10px;
}
#newsList .pickup {
  background: url(../images/news/ico_pickup.png) no-repeat right 5px top 5px rgba(150, 100, 0, 0.1);
}
#newsList dl {
  display: flex;
  align-items: center;
  font-family: "Zen Old Mincho", serif;
}
#newsList dl a {
  color: #180000;
  display: block;
}
#newsList dl a:hover {
  color: #558822;
}
@media (max-width: 768px) {
  #newsList dl {
    padding: 10px;
  }
}
@media (min-width: 769px) {
  #newsList dl {
    padding: 15px;
  }
}

.topicsCtgry {
  padding: 0px 15px 0 5px;
}
@media (max-width: 768px) {
  .topicsCtgry {
    width: 60px;
    min-width: 60px;
  }
  .topicsCtgry img {
    max-width: 60px;
  }
}
@media (min-width: 769px) {
  .topicsCtgry {
    width: 80px;
    min-width: 80px;
  }
  .topicsCtgry img {
    width: 100%;
  }
}

.topicsDate {
  font-weight: normal;
}

.topicsTit {
  font-size: 1.2rem;
  line-height: 1.6em;
  font-weight: bold;
}
.topicsTit li {
  background: none !important;
  margin-bottom: 0.2em !important;
}

.topicsDateBlog {
  text-align: center;
}
@media (max-width: 768px) {
  .topicsDateBlog {
    padding: 0 10px 0 0;
    width: 5em;
    min-width: 5em;
  }
}
@media (min-width: 769px) {
  .topicsDateBlog {
    padding: 0 15px 0 0;
    width: 6em;
    min-width: 6em;
  }
}
.topicsDateBlog span {
  font-size: 2.4rem;
  line-height: 0.8em;
}

.topicsIco {
  display: flex;
  flex-wrap: wrap;
}
.topicsIco span {
  font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
  font-weight: normal;
  background: rgba(150, 100, 0, 0.5);
  color: #FFF;
  font-size: 0.8rem;
  line-height: 1em;
  padding: 5px 8px;
  margin: 0 0.5em;
  border-radius: 3px;
}
@media (max-width: 768px) {
  .topicsIco span {
    margin-bottom: 0.5rem;
  }
}

.goodsList {
  font-family: "Hiragino Sans W3", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ ProN W3", "メイリオ", Meiryo, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif !important;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
}
@media (max-width: 768px) {
  .goodsList {
    font-size: 1.0rem;
    line-height: 1.6em;
  }
}
@media (min-width: 769px) {
  .goodsList {
    font-size: 12px;
    line-height: 1.6em;
  }
}
.goodsList dt {
  margin-bottom: 10px;
}
.goodsList dd {
  margin-bottom: 10px;
  text-align: center;
}
.goodsList span {
  display: block;
  text-align: center;
}
.goodsList .goodsItem dt {
  width: 100%;
  height: auto;
  padding-top: 100%;
  position: relative;
  background: #FFF;
}
.goodsList .goodsItem dt a {
  display: block;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: 100%;
  height: 100%;
}
.goodsList .goodsItem dt img {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  max-width: 100%;
  max-height: 100%;
}
@media (max-width: 768px) {
  .goodsList {
    padding: 0 0.5%;
  }
  .goodsList .goodsItem {
    width: 32%;
    margin: 0 0.6% 10px;
  }
  .goodsList .goodsIco {
    height: 30px;
  }
}
@media (min-width: 769px) {
  .goodsList .goodsItem {
    width: 15.5%;
    margin: 0 0.5%;
  }
  .goodsList .goodsItem dt a:hover {
    opacity: 0.7;
  }
  .goodsList .goodsItem dt img:hover {
    opacity: 1;
  }
  .goodsList .goodsIco {
    height: 30px;
  }
}

/*header ==============================================*/
#membersCol {
  background: url(../images/common/frame/bg_fr01_lt.png) left 5px top 5px no-repeat, url(../images/common/frame/bg_fr01_rt.png) right 5px top 5px no-repeat, url(../images/common/frame/bg_fr01_lb.png) left 5px bottom 5px no-repeat, url(../images/common/frame/bg_fr01_rb.png) right 5px bottom 5px no-repeat rgba(150, 100, 0, 0.1);
  box-sizing: border-box;
  width: 96%;
  max-width: 1200px;
  margin: 0 auto;
  text-align: center;
  /*
  ul {
    display: flex;
    justify-content: center;    
  }
  
  .membersList {
    li {
      background: $bg03;
      box-sizing: border-box;
      position: relative;
    }
    @include sp {
      flex-wrap: wrap;
      li {
        &:first-of-type {
          width: 100%;
          margin-bottom: 10px;
        }
        width: 49%;
        padding: 20px 10px 80px;
        &:nth-of-type(2) {
          margin: 0 1% 10px 0;
          dd {
            &:first-of-type {
              min-height: 7em;
            }
          }
        }
        &:nth-of-type(3) {
          margin: 0 0 10px 1%;
          dd {
            &:first-of-type {
              min-height: 7em;
            }
          }
        }
        a {
          display: block;
          max-width: 140px;
          margin: 0 auto;
        }
      }        
    }
    @include pc {
      flex-wrap: nowrap;
      li {
        //width: 25%;
        width: 33%;
        padding: 30px 10px 8em;
        margin: 0 10px 50px 0;
        &:last-child {
          margin-right: 0;
        }        
      } 
    }
    dt {
      background: url(../images/top/members/bg_tit.png) center bottom no-repeat;
      font-size: 1.5rem;
      line-height: 1.6em;
      font-weight: bold;
      padding-bottom: 1em;
      margin-bottom: 0.5em;
      @include sp {
        background-size: 7em auto;
      }
      @include pc {
        background-size: auto;
      }
      
    }
    dd {
      font-size: 1rem;
      line-height: 1.6em;      
      span {
        font-weight: bold;
        color: #780000;
        font-size: 1.2rem;
      }
           
      &:last-of-type {
        position: absolute;
        left: 10px;
        bottom:20px;
        width: calc(100% - 20px);
      }
    }
    
    @include pc {
      dd {
        &:first-of-type {
          min-height: 5em;
        }
      }
    }
  }*/
}
@media (max-width: 768px) {
  #membersCol {
    background-size: 60px;
  }
}
@media (max-width: 768px) {
  #membersCol {
    margin-top: -20px;
    padding: 60px 10px;
  }
}
@media (min-width: 769px) {
  #membersCol {
    margin-top: -50px;
    padding: 100px 30px;
  }
}
#membersCol ul {
  display: flex;
  justify-content: center;
}
#membersCol .membersList {
  flex-wrap: wrap;
}
#membersCol .membersList li {
  background: rgba(255, 253, 242, 0.7);
  box-sizing: border-box;
  position: relative;
}
@media (max-width: 768px) {
  #membersCol .membersList {
    flex-wrap: wrap;
  }
  #membersCol .membersList li {
    width: 46%;
    margin: 0 2% 10px;
    padding: 20px 10px 90px;
    /*&:nth-of-type(2) {
      margin: 0 1% 10px 0;
      dd {
        &:first-of-type {
          min-height: 7em;
        }
      }
    }
    &:nth-of-type(3) {
      margin: 0 0 10px 1%;
      dd {
        &:first-of-type {
          min-height: 7em;
        }
      }
    }*/
    /*&:first-of-type {
      width: 100%;
      margin-bottom: 10px;
    }
    width: 49%;
    padding: 20px 10px 80px;
    
    &:nth-of-type(2) {
      margin: 0 1% 10px 0;
      dd {
        &:first-of-type {
          min-height: 7em;
        }
      }
    }
    &:nth-of-type(3) {
      margin: 0 0 10px 1%;
      dd {
        &:first-of-type {
          min-height: 7em;
        }
      }
    }*/
  }
  #membersCol .membersList li.episodeBox {
    width: 100%;
  }
  #membersCol .membersList li img {
    margin: 10px auto;
  }
  #membersCol .membersList li a {
    display: block;
    max-width: 140px;
    margin: 0 auto;
  }
}
@media (min-width: 769px) {
  #membersCol .membersList {
    display: flex;
    justify-content: center;
  }
  #membersCol .membersList .episodeBox {
    display: flex;
    justify-content: center;
    padding-bottom: 30px;
  }
  #membersCol .membersList .episodeBox div {
    width: 50%;
    padding: 0px 20px;
  }
  #membersCol .membersList .episodeBox dl {
    width: 50%;
  }
  #membersCol .membersList .episodeBox dl dd:first-of-type {
    min-height: 6em;
  }
  #membersCol .membersList li {
    width: 31%;
    padding: 30px 10px 8em;
    margin: 0 1.5% 50px 0;
    /*&:nth-of-type(3) {
      margin-left: 2%;
      margin-right: 2%;          
    }*/
    /*&:last-child {
      margin-right: 0;
    }*/
  }
  #membersCol .membersList li.episodeBox {
    width: 96%;
  }
}
#membersCol .membersList dt {
  background: url(../images/top/members/bg_tit.png) center bottom no-repeat;
  font-size: 1.5rem;
  line-height: 1.6em;
  font-weight: bold;
  padding-bottom: 1em;
  margin-bottom: 0.5em;
}
@media (max-width: 768px) {
  #membersCol .membersList dt {
    background-size: 7em auto;
  }
}
@media (min-width: 769px) {
  #membersCol .membersList dt {
    background-size: auto;
  }
}
#membersCol .membersList dd {
  font-size: 1rem;
  line-height: 1.6em;
}
#membersCol .membersList dd span {
  font-weight: bold;
  color: #780000;
  font-size: 1.2rem;
}
#membersCol .membersList dd:last-of-type {
  position: absolute;
  left: 10px;
  bottom: 20px;
  width: calc(100% - 20px);
}
@media (min-width: 769px) {
  #membersCol .membersList dd:first-of-type {
    min-height: 5em;
  }
  #membersCol .membersList .episodeBox dd:last-of-type {
    position: relative;
  }
}
#membersCol .membersBtn {
  flex-wrap: nowrap;
}
@media (max-width: 768px) {
  #membersCol .membersBtn {
    padding-top: 30px;
  }
  #membersCol .membersBtn li {
    margin: 0 1% 30px 0;
  }
  #membersCol .membersBtn li:last-child {
    margin-right: 0;
  }
}
@media (min-width: 769px) {
  #membersCol .membersBtn li {
    margin: 0 10px 50px 0;
  }
  #membersCol .membersBtn li:last-child {
    margin-right: 0;
  }
}

#mvColInner #mvColBox #logo25th {
  display: none;
}
@media (max-width: 768px) {
  #mvColInner #mvColBox #logo25th {
    width: 143px;
  }
}
@media (min-width: 769px) {
  #mvColInner #mvColBox #logo25th {
    width: 287px;
  }
}
#mvColInner #mvColBox #logo25th #logotxt {
  position: relative;
}
#mvColInner #mvColBox #logo25th #logotxt .logoBg {
  position: absolute;
}
@media (max-width: 768px) {
  #mvColInner #mvColBox #logo25th #logotxt .logoBg {
    top: -40px;
    left: 0;
    width: 143px;
    height: 81px;
  }
}
@media (min-width: 769px) {
  #mvColInner #mvColBox #logo25th #logotxt .logoBg {
    background-position: center top;
    top: -81px;
    left: 0;
    width: 287px;
    height: 162px;
  }
}
#mvColInner #mvColBox #logo25th #logotxt .logoBg.bg01 {
  opacity: 0;
  background: url(../images/top/logo_25th_bg1.png) no-repeat;
  animation: logoBgAnime 2s linear 0s 1 none running;
}
#mvColInner #mvColBox #logo25th #logotxt .logoBg.bg02 {
  opacity: 0;
  background: url(../images/top/logo_25th_bg2.png) no-repeat;
  animation: logoBgAnime 2s linear 0.7s 1 none running;
}
#mvColInner #mvColBox #logo25th #logotxt .logoBg.bg03 {
  opacity: 0;
  background: url(../images/top/logo_25th_bg3.png) no-repeat;
  animation: logoBgAnime 3s linear 1.2s 1 none running;
}
#mvColInner #mvColBox #logo25th #logotxt .logoBg.bg04 {
  opacity: 0;
  background: url(../images/top/logo_25th_bg4.png) no-repeat;
  animation: logoBgAnime 3s linear 2.6s 1 none running;
  filter: brightness(1.3);
}
@media (max-width: 768px) {
  #mvColInner #mvColBox #logo25th #logotxt .logoBg.bg01, #mvColInner #mvColBox #logo25th #logotxt .logoBg.bg02, #mvColInner #mvColBox #logo25th #logotxt .logoBg.bg03, #mvColInner #mvColBox #logo25th #logotxt .logoBg.bg04 {
    background-size: 143px 81px;
  }
}
#mvColInner #mvColBox #logo25th #logotxt .logoImg {
  position: absolute;
  animation: logoImgAnime 6s ease-in 3.6s 1 none running;
  opacity: 0;
}
@media all and (-ms-high-contrast: none) {
  #mvColInner #mvColBox #logo25th #logotxt .logoImg {
    opacity: 1;
  }
}
@media (max-width: 768px) {
  #mvColInner #mvColBox #logo25th #logotxt .logoImg {
    top: -40px;
    left: 0;
    width: 143px;
    height: 81px;
  }
}
@media (min-width: 769px) {
  #mvColInner #mvColBox #logo25th #logotxt .logoImg {
    background-position: center top;
    top: -81px;
    left: 0;
    width: 287px;
    height: 162px;
  }
}
@keyframes logoBgAnime {
  0% {
    opacity: 0;
  }
  50% {
    opacity: 1;
  }
  80% {
    opacity: 1;
  }
  100% {
    opacity: 0;
  }
}
@keyframes logoImgAnime {
  0% {
    opacity: 0;
    filter: brightness(1.3);
  }
  30% {
    opacity: 1;
    filter: brightness(1.3);
  }
  100% {
    opacity: 0;
    filter: brightness(1);
  }
}
#titlesCol .anniversaryico {
  margin: 0 auto 2em;
  display: block;
  position: relative;
  opacity: 0;
  transition: .3s;
}
@media (max-width: 768px) {
  #titlesCol .anniversaryico {
    height: 27px;
    width: 150px;
  }
}
@media (min-width: 769px) {
  #titlesCol .anniversaryico {
    height: 41px;
    width: 231px;
  }
}
#titlesCol .anniversaryico.dispAnniversary {
  opacity: 1;
}
#titlesCol .anniversaryico.isAnimate .anniversaryicoBg {
  animation: annivIcoBg 1s ease-in 0s 1 none running;
}
@media all and (-ms-high-contrast: none) {
  #titlesCol .anniversaryico.isAnimate .anniversaryicoBg {
    opacity: 1;
  }
}
#titlesCol .anniversaryico.isAnimate .anniversaryicoImg {
  animation: annivIcoImg 1s ease-in 0.3s 1 none running;
  animation-fill-mode: forwards;
}
@media all and (-ms-high-contrast: none) {
  #titlesCol .anniversaryico.isAnimate .anniversaryicoImg {
    opacity: 1;
  }
}
#titlesCol .anniversaryicoBg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  background: url(../images/top/ic_anniversary_bg1.png) no-repeat center top;
}
@media (max-width: 768px) {
  #titlesCol .anniversaryicoBg {
    height: 28px;
    width: 150px;
    background-size: 150px 27px;
  }
}
@media (min-width: 769px) {
  #titlesCol .anniversaryicoBg {
    height: 41px;
    width: 231px;
  }
}
#titlesCol .anniversaryicoImg {
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  opacity: 0;
  animation-fill-mode: forwards;
}
@media (max-width: 768px) {
  #titlesCol .anniversaryicoImg {
    height: 27px;
  }
  #titlesCol .anniversaryicoImg img {
    width: 150px;
    max-width: 150px;
  }
}
@media (min-width: 769px) {
  #titlesCol .anniversaryicoImg {
    height: 41px;
  }
  #titlesCol .anniversaryicoImg img {
    width: 231px;
    max-width: 231px;
  }
}
@keyframes annivIcoBg {
  0% {
    opacity: 0;
    filter: brightness(1);
  }
  50% {
    opacity: 1;
    filter: brightness(1.3);
  }
  100% {
    opacity: 0;
    filter: brightness(1);
  }
}
@keyframes annivIcoImg {
  0% {
    opacity: 0;
    filter: brightness(1.3) hue-rotate(180deg);
  }
  100% {
    filter: brightness(1) hue-rotate(0deg);
    opacity: 1;
  }
}
body {
  background-color: #000;
}

main {
  padding: 20px 0 0 0;
  background: url(../images/common/bg_main.jpg) center top repeat-y;
  background-size: 100% auto;
}

section {
  position: relative;
  text-align: center;
}

#mvCol {
  position: relative;
  background: #000;
  z-index: -5;
  width: 100%;
  min-width: 100%;
  overflow: hidden;
}
@media (max-width: 1700px) {
  #mvCol {
    top: 45px;
    height: calc(56.4vw + 40px);
  }
}
@media (min-width: 1701px) {
  #mvCol {
    top: 0px;
    height: 100vh;
  }
}

.bg {
  background: url(../images/top/bg_mv.jpg) no-repeat center center #000;
  background-size: auto 100%;
  position: relative;
  z-index: -2;
  margin: 0 auto;
  width: 100%;
}
.bg .bg-wrap {
  position: relative;
  top: 0px;
  left: 0;
  z-index: -1;
  min-width: 100%;
  min-height: 100%;
  overflow: hidden;
}
.bg .bg-wrap .background-movie {
  position: relative;
  display: flex;
  justify-content: center;
}
.bg .bg-wrap #bg-movie-player {
  flex: none;
  width: 100%;
}
@media (max-width: 1700px) {
  .bg .bg-wrap #bg-movie-player {
    height: 56.4vw;
  }
}
@media (min-width: 1401px) {
  .bg .bg-wrap #bg-movie-player {
    height: 56.4vw;
  }
}

#mvColBg {
  min-width: 100%;
  min-height: 100%;
  width: auto;
  height: auto;
  z-index: 0;
  top: 0px;
}
@media (max-width: 1700px) {
  #mvColBg {
    height: 56.4vw;
  }
}
@media (min-width: 1701px) {
  #mvColBg {
    height: 100vh;
  }
}

#mvColInner {
  width: 100%;
  position: absolute;
  top: 0px;
  left: 0;
  text-align: center;
  z-index: 0;
  animation: bgAnime 3s linear 0s 1 none running;
}
@media (max-width: 1700px) {
  #mvColInner {
    height: 56.4vw;
  }
}
@media (min-width: 1701px) {
  #mvColInner {
    height: 100vh;
  }
}
@keyframes bgAnime {
  0% {
    background: #000;
  }
  /*90% {
    background: #000;
  }
  80% {
    background: #000;
  }*/
  100% {
    background: none;
  }
}
#mvColInner #mvColBox {
  width: 100%;
  text-align: center;
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1;
}
@media (max-width: 1700px) {
  #mvColInner #mvColBox {
    height: 80%;
  }
}
@media (min-width: 1701px) {
  #mvColInner #mvColBox {
    height: 100%;
  }
}

#twCol {
  background: rgba(24, 0, 0, 0.3);
  color: #fffdf2;
  width: 96%;
  max-width: 1200px;
  margin: 0 auto;
  text-align: left;
  overflow: hidden;
  border-radius: 3px;
  position: absolute;
  right: 0;
  left: 0;
  z-index: 200;
}
#twCol .twNews {
  display: flex;
  flex-wrap: nowrap;
}
#twCol .twIco {
  position: relative;
  z-index: 300;
  padding: 5px 0px 5px 5px;
  height: 60px;
  width: 60px;
  margin: 0;
}
#twCol .twIco img {
  width: 100%;
  height: auto;
  border-radius: 50%;
  vertical-align: top;
}
#twCol .twTxt {
  position: relative;
  z-index: 299;
  max-width: 300em;
  overflow: hidden;
}
#twCol .twTxt p {
  overflow: hidden;
  width: 150em;
  word-break: keep-all;
  text-indent: 1em;
}
#twCol .twTxt p a {
  color: #fffdf2;
}
#twCol .twTxt p a:hover {
  text-decoration: underline;
}
@media (max-width: 768px) {
  #twCol {
    top: calc(56.4vw - 5px);
    line-height: 40px;
    height: 40px;
  }
  #twCol .twIco {
    height: 30px;
    width: 30px;
  }
  #twCol .twTxt {
    width: calc(100% - 30px);
  }
  #twCol .twTxt p {
    animation: scrollAnime 33s linear infinite;
  }
}
@media (min-width: 768px) and (max-width: 1700px) {
  #twCol {
    font-size: 1rem;
    top: calc(56vw - 35px);
    line-height: 70px;
    height: 70px;
  }
  #twCol .twIco {
    font-size: 1rem;
    height: 60px;
    width: 60px;
  }
  #twCol .twTxt {
    width: calc(100% - 60px);
  }
  #twCol .twTxt p {
    animation: scrollAnime 20s linear infinite;
  }
}
@media (min-width: 1701px) {
  #twCol {
    top: calc(100vh - 90px);
    font-size: 1rem;
    line-height: 70px;
    height: 70px;
  }
  #twCol .twIco {
    font-size: 1rem;
    height: 60px;
    width: 60px;
  }
  #twCol .twTxt {
    width: calc(100% - 60px);
  }
  #twCol .twTxt p {
    animation: scrollAnime 20s linear infinite;
  }
}
@keyframes scrollAnime {
  0% {
    opacity: 0;
    transform: translateX(0%);
  }
  5% {
    opacity: 1;
    transform: translateX(0%);
  }
  10% {
    opacity: 1;
    transform: translateX(0%);
  }
  100% {
    transform: translateX(-100%);
  }
}
#information {
  background: rgba(150, 100, 0, 0.1);
  box-sizing: border-box;
  border-radius: 3px;
  width: 100%;
  max-width: 1200px;
  margin: 0 auto 10px;
}
#information a {
  color: #180000 !important;
  text-decoration: underline;
}
#information a:hover {
  color: #558822 !important;
}
#information h2 {
  text-align: left;
  box-sizing: border-box;
  padding: 0 1em 0 0;
  width: 100%;
}
#information h2:before {
  content: '';
  display: inline-block;
  width: 1.5em;
  height: 1em;
  background: url(../images/top/ic_information.png) center top no-repeat;
  background-size: contain;
  vertical-align: top;
}
#information dl {
  text-align: left;
  width: 100%;
  margin: 0 auto;
}
@media (max-width: 768px) {
  #information {
    padding: 20px 3%;
  }
  #information h2 {
    width: 96%;
    margin: 0 auto;
    text-align: center;
    line-height: 1em;
    margin-bottom: 1em;
    text-indent: 1em;
  }
  #information dd {
    margin-bottom: 1em;
    line-height: 1.4em;
  }
  #information dd:last-child {
    margin-bottom: 0;
  }
}
@media (min-width: 769px) {
  #information {
    display: flex;
    align-items: center;
    padding: 10px;
  }
  #information h2 {
    font-size: 1rem;
    line-height: 1.6em;
    width: 12em;
    margin-bottom: 0;
  }
  #information h2:before {
    margin-top: 4px;
  }
  #information dl {
    display: flex;
    flex-wrap: wrap;
    font-size: 1rem;
    line-height: 1.6em;
  }
  #information dl dt {
    width: 6rem;
  }
  #information dl dd {
    padding: 0 0em 0 1em;
    width: calc(100% - 8rem);
  }
}

#newsCol {
  margin-top: -40px;
  padding: 60px 0 20px;
}
@media (min-width: 769px) {
  #newsCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}

#aboutCol {
  margin-top: -40px;
  padding: 60px 0 20px;
}
@media (min-width: 769px) {
  #aboutCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#aboutCol li {
  background: #FFF;
}
#aboutCol .aboutTxt01 {
  font-size: 1.5rem;
  line-height: 1.6em;
  font-weight: bold;
  margin-bottom: 1em;
}
#aboutCol .aboutTxt02 {
  font-size: 1.5rem;
  line-height: 1.6em;
  font-weight: bold;
  margin-bottom: 2em;
}
#aboutCol .aboutTxt03 {
  font-size: 1.4rem;
  line-height: 1.6em;
}
#aboutCol #aboutImg {
  width: 100%;
  overflow: hidden;
}
@media (max-width: 768px) {
  #aboutCol #aboutImg {
    margin-bottom: 20px;
  }
}
@media (min-width: 769px) {
  #aboutCol #aboutImg {
    margin-bottom: 50px;
  }
}
#aboutCol #aboutImg .imgWrap1 ul,
#aboutCol #aboutImg .imgWrap2 ul {
  opacity: 0;
  transition: opacity .3s linear;
}
#aboutCol #aboutImg .imgWrap1 ul.slick-initialized,
#aboutCol #aboutImg .imgWrap2 ul.slick-initialized {
  opacity: 1;
}
#aboutCol #aboutImg .imgWrap2 {
  margin-top: -2px;
}

#pickupCol {
  margin-top: -40px;
  padding: 60px 0 20px;
}
@media (min-width: 769px) {
  #pickupCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#pickupCol #pickupList li:nth-child(odd) {
  background: url(../images/top/pickup/bg_pickup_01.png) no-repeat center top;
  background-size: contain;
  box-sizing: border-box;
}
#pickupCol #pickupList li:nth-child(odd) img {
  width: 100%;
  height: auto;
  margin: 0 auto;
}
#pickupCol #pickupList li:nth-child(even) {
  background: url(../images/top/pickup/bg_pickup_02.png) no-repeat center top;
  background-size: contain;
  box-sizing: border-box;
}
#pickupCol #pickupList li:nth-child(even) img {
  width: 100%;
  height: auto;
  margin: 0 auto;
}
@media (max-width: 768px) {
  #pickupCol #pickupList li {
    width: 96%;
    max-width: 800px;
  }
  #pickupCol #pickupList li:nth-child(odd) {
    padding: 4% 4% 10% 10%;
    margin: 0 auto 0px;
  }
  #pickupCol #pickupList li:nth-child(even) {
    padding: 7% 10% 7% 4%;
    margin: 0 auto 6%;
  }
}
@media (min-width: 769px) {
  #pickupCol #pickupList {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  #pickupCol #pickupList li {
    width: 800px;
    height: 342px;
    margin: 0 10px 10px;
  }
  #pickupCol #pickupList li:nth-child(odd) {
    padding: 30px 25px 0px 85px;
  }
  #pickupCol #pickupList li:nth-child(even) {
    padding: 55px 85px 0px 25px;
    margin-bottom: 3%;
  }
}

#titlesCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  position: relative;
}
@media (min-width: 769px) {
  #titlesCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}

#snsCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  /*.snsBox {
    width: 100%;
    //PCの場合
    @include pc {
      dl {
        width: 14.2%;
        padding-bottom: 30px;
      }
    }
  }*/
}
@media (min-width: 769px) {
  #snsCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#snsCol #snsInner {
  display: flex;
  justify-content: center;
  margin: 0 auto;
  flex-wrap: wrap;
}
#snsCol #snsInner dl dt img {
  width: 100%;
  border-radius: 50%;
  margin-bottom: 10px;
}
@media (max-width: 768px) {
  #snsCol #snsInner dl {
    box-sizing: border-box;
    width: 33%;
    padding: 0 10px;
    margin-bottom: 30px;
  }
  #snsCol #snsInner dl dd {
    font-size: 0.8rem;
    line-height: 1.6em;
  }
}
@media (min-width: 769px) and (max-width: 1024px) {
  #snsCol #snsInner dl {
    box-sizing: border-box;
    width: 20%;
    padding: 0 10px;
    margin-bottom: 30px;
  }
  #snsCol #snsInner dl dd {
    font-size: 0.8rem;
    line-height: 1.6em;
  }
}
@media (min-width: 769px) {
  #snsCol #snsInner {
    max-width: 1200px;
    padding: 0 30px;
  }
  #snsCol #snsInner dl {
    box-sizing: border-box;
    width: 16.6%;
    padding: 0 10px 30px;
  }
  #snsCol #snsInner dl dd {
    font-size: 14px;
    line-height: 1.4em;
  }
}

#musicCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  max-width: 1000px;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #musicCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}

#blogCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  max-width: 1000px;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #blogCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}

#aboutmemberCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  max-width: 1080px;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #aboutmemberCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#aboutmemberCol p {
  font-weight: bold;
  margin-bottom: 2rem;
}
#aboutmemberCol ul {
  padding: 20px 0;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #aboutmemberCol ul {
    padding: 30px 0;
  }
}
@media (max-width: 768px) {
  #aboutmemberCol ul li {
    margin-bottom: 10px;
  }
}
@media (min-width: 769px) {
  #aboutmemberCol p {
    font-size: 1.5rem;
    line-height: 1.6em;
  }
  #aboutmemberCol ul {
    display: flex;
    flex-wrap: wrap;
    justify-content: center;
  }
  #aboutmemberCol ul li {
    box-sizing: border-box;
    width: 50%;
    margin-bottom: 20px;
  }
  #aboutmemberCol ul li:nth-child(odd) {
    padding-right: 10px;
  }
  #aboutmemberCol ul li:nth-child(even) {
    padding-left: 10px;
  }
}

#membersCol {
  margin: 0 auto;
}
@media (max-width: 768px) {
  #membersCol {
    margin-top: 20px;
    padding: 60px 10px;
  }
}
@media (min-width: 769px) {
  #membersCol {
    margin-top: 0px;
    padding: 100px 30px;
  }
}

#goodsCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  max-width: 1080px;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #goodsCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#goodsCol h4 {
  font-weight: bold;
  font-size: 1.5rem;
  margin-bottom: 1em;
}

#eventCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #eventCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
#eventCol .eventBnr2 {
  margin: 0 auto 30px;
}
#eventCol .frm1 {
  padding: 2em;
}
@media (max-width: 768px) {
  #eventCol li {
    margin: 0 0 10px 0;
  }
  #eventCol li:last-child {
    margin-bottom: 0;
  }
}
@media (min-width: 769px) {
  #eventCol .eventBnr {
    display: flex;
    justify-content: center;
    flex-wrap: wrap;
  }
  #eventCol .eventBnr li {
    width: 50%;
  }
  #eventCol .eventBnr li img {
    width: 98%;
  }
}

#vivaCol {
  margin-right: 10px;
}

#youtubeCol {
  margin-top: -40px;
  padding: 60px 0 20px;
  width: 94%;
  margin: 0 auto;
}
@media (min-width: 769px) {
  #youtubeCol {
    margin-top: -50px;
    padding: 100px 0 40px;
  }
}
@media (max-width: 768px) {
  #youtubeCol .btn {
    margin: 0 auto 20px;
  }
}
@media (min-width: 769px) {
  #youtubeCol .btn {
    margin: 0 auto 30px;
    width: 90%;
  }
}
#youtubeCol #youtubeInner dt {
  font-weight: bold;
}
#youtubeCol #youtubeInner .movieWrap {
  position: relative;
  padding-bottom: 56.25%;
  /*アスペクト比 16:9の場合の縦幅*/
  height: 0;
  overflow: hidden;
}
#youtubeCol #youtubeInner .movieWrap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}
@media (max-width: 768px) {
  #youtubeCol #youtubeInner dt {
    font-size: 1.5rem;
    line-height: 1.6em;
    margin: 20px auto;
  }
}
@media (min-width: 769px) {
  #youtubeCol #youtubeInner {
    display: flex;
    width: 100%;
    justify-content: center;
    align-items: center;
  }
  #youtubeCol #youtubeInner .movie {
    width: 50%;
    padding-right: 20px;
  }
  #youtubeCol #youtubeInner dl {
    width: 50%;
    padding-left: 20px;
    max-width: 400px;
  }
  #youtubeCol #youtubeInner dt {
    font-size: 1.3rem;
    line-height: 1.6em;
    margin-bottom: 1em;
  }
}
