@charset "utf-8";
@font-face {
    font-family: 'BLG';
    src: url(../font/bleage_font.ttf);
    font-weight: normal;
}
@font-face {
  font-family: 'BN';
  src: url(../font/BebasNeue-Regular.ttf);
  font-weight: normal;
}
@font-face {
  font-family: 'GS';
  src: url(../font/GeneralSans-Semibold.ttf);
}
.zen-old-mincho-regular {
  font-family: "Zen Old Mincho", serif;
  font-weight: 400;
  font-style: normal;
}

.zen-old-mincho-medium {
  font-family: "Zen Old Mincho", serif;
  font-weight: 500;
  font-style: normal;
}

.zen-old-mincho-semibold {
  font-family: "Zen Old Mincho", serif;
  font-weight: 600;
  font-style: normal;
}

.zen-old-mincho-bold {
  font-family: "Zen Old Mincho", serif;
  font-weight: 700;
  font-style: normal;
}

.zen-old-mincho-black {
  font-family: "Zen Old Mincho", serif;
  font-weight: 900;
  font-style: normal;
}



img{
  vertical-align: bottom;
}
p,span,h1,h2,h3,h4,div,nav,li,ul{
  font-family: 'Noto Sans JP', sans-serif;
  font-style: normal;
  font-feature-settings: "palt";
  letter-spacing: 0.1rem;
}
html {
  scroll-padding-top: 0px; /* 固定ヘッダの高さ分 */
  font-size: 62.5%;
  overflow-x: hidden;
}
body {
  line-height: 1.6875;
  background: linear-gradient(180deg, #0d0d0d, #272727);
}
.module_title{
  display: none;
}
.blg-font{
  font-family: 'BLG';
  src: url(font/bleage_font.ttf);
}
.color-white{
  color: white;
}
@media (min-width: 700px) {
.sp-br{
  display: none;
}
}
.pc-br{
  display: none;
}
@media (min-width: 700px) {
.pc-br{
  display: block;
}
}
/* ---------------------------------------------------- */
/* スライダー*/
/* ---------------------------------------------------- */
.swipeBanner_spc {
	padding: 50px 0;
  z-index: 20;
  position: relative;
}

.swipeBanner_spc_wrap {
	max-width: 1080px;
	margin: 0 auto;
	/* padding: 18px 0; */
}

.swipeBanner_spc img {
	width: 100%;
	max-width: 100%;
}

/* general
--------------- */
.onlySP {display: block;}
.onlySP_il {display: inline;}
.onlyPC, .onlyPC_il {display: none;}

/* style.css終わり */

/* pc.css始まり */
@media screen and (min-width: 640px) {

  .wrap_swipeCards1 h3 {
    font-size: 2rem;
  }
  
  .spc_swipeCards1 {	
    overflow-x: visible;
  }
  
  .inner_swipeCards1 {
    width: 100%;
  }
  
  .swipeCard1 {
    width: calc(33.33% - 10px);
  }
  
  /* general PC
  ------------------ */
  
  .onlyPC {display: block;}
  .onlyPC_il {display: inline;}
  .onlySP, .onlySP_il {display: none;}
  
  }
  
  
  @media screen and (min-width: 980px) {
    
  .swipeCard1 {
    width: calc(20% - 10px);
  }
  
  .player_blk {
    width: calc(33.33% - 20px);
  }
  
  }
/* ---------------------------------------------------- */
/* KV */
/* ---------------------------------------------------- */
picture img{
  width: 100%;
  height: auto;
}
.kv-contents{
  position: relative;
}

.kv-dd-sp{
  position: absolute;
  bottom: 0;
  width: 75%;
  z-index: 5;
  left: 0;
  right: 0;
  top: 23%;
  margin: 0 auto;
}
.kv-dd-pc{
  display: none;
}
@media (min-width: 700px) {
.kv-dd-pc{
  display: block;
  position: absolute;
  bottom: 0;
  width: 45.1%;
  z-index: 4;
  right: 19%;
}
}
@media (min-width: 700px) {
  .kv-dd-sp,.kv-lh-sp,.kv-tg-sp,.kv-rg-sp,.kv-cj-sp{
    display: none;
  }
}

.kv-lh-sp{
  position: absolute;
  bottom: 0;
  width: 55%;
  top: 15.5%;
  z-index: 4;
  left: 0%;
}
.kv-lh-pc{
  display: none;
}
@media (min-width: 700px) {
  .kv-lh-pc{
    display: block;
    position: absolute;
    bottom: 0%;
    width: 42%;
    z-index: 4;
    right: 29%;
  }
}

.kv-rg-sp{
  position: absolute;
  z-index: 3;
  width: 40%;
  right: 0;
  top: 19%;
}
.kv-rg-pc{
  display: none;
}
@media (min-width: 700px) {
.kv-rg-pc{
  display: block;
  position: absolute;
  z-index: 3;
  width: 28%;
  right: 3%;
  top: 8%;
}
}

.kv-tg-sp{
  position: absolute;
  width: 52%;
  z-index: 2;
  top: 5%;
  left: 15%;
}

.kv-tg-pc{
  display: none;
}
@media (min-width: 700px) {
  .kv-tg-pc{
    display: block;
    position: absolute;
        width: 30%;
        z-index: 2;
        top: 4%;
        left: 29.5%;
  }
}
.kv-cj-sp{
  position: absolute;
  /* bottom: 0; */
  width: 40%;
  z-index: 1;
  top: 0;
  right: 0;
  left: 0;
  margin: 0 auto 0rem;
  padding-left: 5rem;
}
.kv-cj-pc{
  display: none;
}
@media (min-width: 700px) {
  .kv-cj-pc{
    display: block;
    position: absolute;
        width: 19%;
        z-index: 2;
        top: 0%;
        left: 45%;
  }
}

.kv-logo-left1-sp{
  width: 30%;
}
.kv-logo-sp{
position: absolute;
animation-delay: 4s;
width: 28%;
right: 0;
left: 0;
margin: 0 auto;
bottom: 4.8%;
}
@media (min-width: 700px) {
  .kv-logo-sp{
    width: 21%;
    left: 6%;
    margin: 0;
    bottom: 30%;
  }
}
.kv-logo-top-sp{
  position: absolute;
  width: 25.5%;
  right: 3.3%;
  top: 2%;
}
@media (min-width: 700px) {
  .kv-logo-top-sp{
    display: none;
  }
}
.kv-logo-top-pc{
  display: none;
}
@media (min-width: 700px) {
  .kv-logo-top-pc{
    position: absolute;
        width: 11.9%;
        right: 2.1%;
        top: 3.5%;
  }
}

.kv-logo-left1-sp {
  position: absolute;
  width: 28%;
  bottom: 18%;
  left: 5%;
}

.kv-logo-left2-sp {
  position: absolute;
    width: 23%;
    bottom: 11.5%;
    left: 6.7%;
}

.kv-logo-left3-sp{
  position: absolute;
  width: 25%;
  bottom: 4.5%;
  left: 5%;
}

/* .kv-logo-left3-sp {
  position: absolute;
    width: 27%;
    bottom: 4%;
    left: 3.2%;
} */

.kv-logo-right1-sp {
  position: absolute;
  width: 23.6%;
  bottom: 18%;
  right: 6.7%;
}

.kv-logo-right2-sp {
  position: absolute;
    width: 20%;
    bottom: 12%;
    right: 8.7%;
    opacity: 0.7;
}

.kv-logo-right3-sp {
  position: absolute;
    width: 23.6%;
    bottom: 4.5%;
    right: 6.4%;
}

@media (min-width: 700px) {
  .kv-logo-right1-sp,.kv-logo-right2-sp,.kv-logo-right3-sp{
    display: none;
  }
}
@media (min-width: 700px) {
  .kv-logo-left1-sp,.kv-logo-left2-sp,.kv-logo-left3-sp{
    display: none;
  }
}
.kv-club-logo-pc{
  display: none;
}
@media (min-width: 700px) {
.kv-club-logo-pc{
  display: block;
  position: absolute;
  width: 31.1%;
  bottom: 4.8%;
  left: 2.6%;
}
}


/* ---------------------------------------------------- */
/* about */
/* ---------------------------------------------------- */
.about-wrapper{
  position: relative;
  max-width: 1100px;
  margin: 0 auto;
}
  .about-item1{
    display: block;
    position: absolute;
    width: 100%;
    right: 0;
    bottom: 0%;
    opacity: 0.1;
    padding-bottom: 1rem;
  }


@media (min-width: 700px) {
.about-item1{
  display: block;
  position: absolute;
  width: 47%;
  right: 0;
  bottom: 0%;
  opacity: 0.7;
  padding-bottom: 2rem;
}
}

@media (min-width: 1000px) {
  .about-item1{
    opacity: 0.8;
  }
}

.wrapper{
  width: calc(100% - 50px);
  margin: 0 auto 8rem;
  padding: 30px 0 0px; 
  position: relative;

}
@media (min-width: 700px) {
  .wrapper{
    max-width: 900px;
    padding: 60px 0 0px; 
    width: calc(100% - 0px);
  }
}
.about-ttl{
  font-size: 1.8rem;
  padding-bottom: 5rem;
  letter-spacing: 0.4rem;
  font-family: "BN";
  color: #aba185;
  font-weight: normal;
}
@media (min-width: 700px) {
  .about-ttl{
    font-size: 3rem;
    letter-spacing:1rem;
  }
}

@media (min-width: 700px) {
  .about h2{
    font-size: 5rem;
    padding-bottom: 30px;
  }
}
.about-ttl-wrap img{
  width: 100%;
  padding-bottom: 3rem;

}
@media (min-width: 700px) {
  .about-ttl-wrap img{
    width: 100%;
  }
}
.about-ttl-wrap{
  display: flex;
  gap: 15px;
}
@media (min-width: 700px) {
  .about-ttl-wrap{
    gap: 20px;
    justify-content: baseline;
  }
}
.weight{
  font-weight: bold;
  letter-spacing: 0.8rem;
}
.about-txt{
  font-size: 1.5rem;
  line-height: 3.5rem;
  letter-spacing: 0.2rem;
  z-index: 2;
  position: relative;
  color: #d9cca8;
}
@media (min-width: 700px) {
  .about-txt{
    font-size: 1.6rem;
    line-height: 5rem;
    text-align: center;
  }
}
.about-container{
  color: #ffffff;
  background-repeat: no-repeat;
  background-size: cover;
}
/* ---------------------------------------------------- */
/* スライダー */
/* ---------------------------------------------------- */

.photo_scroll_spc {
	position: relative;
	background-color: #aba185;
  transform: rotate(-3.0deg) translateX(0);
}


.photo_scroll {
    position: relative;
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row nowrap;
    flex-flow: row nowrap;
    width: 100%;
    overflow: hidden;
}

.photo_scroll ul {
    display: -webkit-flex;
    display: flex;
    -webkit-flex-flow: row nowrap;
    flex-flow: row nowrap;
    /*width: 100%;*/
    margin: 0;
    padding: 0;
}

.photo_scroll li {
    display: inline-block;
    width: calc((100% + 80px) / 2);
    min-width: calc((100vw + 80px) / 2);
    margin: 0 -20px;
    list-style: none;
    text-align: center;
}

.photo_scroll li img {
    display: block;
    width: 100%;
    height: auto;
	
	filter: grayscale(77%) contrast(120%);
	
	clip-path: polygon(2px 2px, calc(100% - 40px - 2px) 2px, calc(100% - 2px) calc(100% - 2px), calc(0% + 40px + 2px) calc(100% - 2px));
}


.photo_scroll ul:first-child {
    -webkit-animation: loop 50s -25s linear infinite;
    animation: loop 50s -25s linear infinite;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    will-change: transform;
}

.photo_scroll ul + ul {
    -webkit-animation: loop2 50s linear infinite;
    animation: loop2 50s linear infinite;
}


@-webkit-keyframes loop {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
}

@keyframes loop {
    0% {
      -webkit-transform: translateX(100%);
      -ms-transform: translateX(100%);
      transform: translateX(100%);
    }
    to {
      -webkit-transform: translateX(-100%);
      -ms-transform: translateX(-100%);
      transform: translateX(-100%);
    }
}

@-webkit-keyframes loop2 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
}

@keyframes loop2 {
    0% {
      -webkit-transform: translateX(0);
      -ms-transform: translateX(0);
      transform: translateX(0);
    }
    to {
      -webkit-transform: translateX(-200%);
      -ms-transform: translateX(-200%);
      transform: translateX(-200%);
    }
}
@media screen and (min-width: 640px) {
  .photo_scroll li {
    /*min-width: 25vw;*/
  min-width: calc((100vw + 160px) / 4);
  }
  }
  .photo_scroll{
  /* transform: rotate(-1.5deg) translateX(0); */
}
/* ---------------------------------------------------- */
/* news */
/* ---------------------------------------------------- */
.ttl-big{
  font-size: 10rem;
  font-family: "BN";
  letter-spacing: 0.8rem;
  line-height: 10rem;
  color: #aba185;
  font-weight: normal;
}
@media (min-width: 700px) {
  .ttl-big{
    font-size: 10rem;
    line-height: 8rem;
    letter-spacing: 1rem;
  }
}
.ttl-small-wrap{
  display: flex;
  gap: 10px;
  align-items: center;
  color: #aba185;
}
.ttl-small1{
  font-size: 2.3rem;
  font-weight: bold;
  letter-spacing: 0.6rem;
}
@media (min-width: 700px) {
  .ttl-small1{
    font-size: 2.8rem;
    letter-spacing: 0.7rem;
  }
}

.ttl-small2{
  font-family: "GS";
  font-size: 1.2rem;
  line-height: 1.3rem;
  letter-spacing: 0.3rem;
}
@media (min-width: 700px) {
  .ttl-small2{
    font-size: 1.4rem;
    letter-spacing: 0.5rem;
    line-height: 1.5rem;
  }
}

.accordion {
  max-width: 900px;
  margin: 0 auto 7rem;
  width: calc(100% - 50px);
}
.accordion-item {
  margin-top: 10px;
  cursor: pointer;
}
.accordion-title {
  position: relative;
  padding: 15px 60px 15px 20px;
  font-weight: bold;
  cursor: pointer;
  background-color: #111;
  font-size: 1.5rem;
  font-weight: normal;
  border: 0.5px solid #aba185;
  color: #aba185;
}

.accordion-title::before,
.accordion-title::after {
  content: "";
  position: absolute;
  right: 20px;
  top: 0;
  bottom: 0;
  margin: auto 0;
  background-image: url(../img/icon_arrowR3.svg);
  width: 20px;
  height: 20px;
  transition: all 0.3s;
}

.accordion-content {
  padding: 0 20px 15px 20px;
  display: none;
  cursor: pointer;
  background-color: #ffffff;
}
.accordion-content img{
  padding: 50px 0;
  width: 100%;
}
.accordion-txt2{
  padding: 50px 0;
}
.accordion-txt{
  font-size: 1.5rem;
  padding:30px 0 50px;
  color: black;
}
.accordion-content.is-open {
  display: block;
}

.accordion-item.is-active .accordion-title::before {
  transform: rotate(90deg);
}

.accordion-item.is-active .accordion-title::after {
  transform: rotate(90deg);
  opacity: 0;
}

.news-btn{
  position: relative;
  padding: 13px 50px;
  color: #ffffff;
  background-color: #000000;
  text-decoration: none;
  font-size: 1.5rem;
  display: block;
  margin: 0 auto;
  max-width: 300px;
  letter-spacing: 0.2rem;
  text-align: center;
}

.news-btn::after {
  content: '';
  position: absolute;
  right: 20px;
  top: 30%;
  width: 15px;
  height:18px;
  background-image: url(../img/icon_arrowR1.svg);
  transform: translate(0, 0%) rotate(0deg);
}

/*==================================
動きの設定
===================================*/

/* fadeup */
.fadeUp{
  animation-name:fadeUpAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
  opacity:0;
  }
  
  @keyframes fadeUpAnime{
    from {
      opacity: 0;
    transform: translateY(100px);
    }
  
    to {
      opacity: 1;
    transform: translateY(0);
    }
  }
  .fadeUpTrigger{
      opacity: 0;
  }

  /* 左から */
.fadeLeft{
  animation-name:fadeLeftAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
  opacity:0;
  }
  
  @keyframes fadeLeftAnime{
    from {
      opacity: 0;
    transform: translateX(-100px);
    }
  
    to {
      opacity: 1;
    transform: translateX(0);
    }
  }
  

/* 上から */

.fadeDown{
  animation-name:fadeDownAnime;
  animation-duration:0.5s;
  animation-fill-mode:forwards;
  opacity:0;
  }
  
  @keyframes fadeDownAnime{
    from {
      opacity: 0;
    transform: translateY(-100px);
    }
  
    to {
      opacity: 1;
    transform: translateY(0);
    }
  }



  /* タイトル用の動き */
  span.smoothText {
    overflow: hidden;
    display: block;
  }
  
  span.smoothTextTrigger{
    transition: .8s ease-in-out;
    transform: translate3d(0,100%,0) skewY(12deg);
    transform-origin: left;
    display: block;
  }
  span.smoothTextTrigger.smoothTextAppear{
      transform: translate3d(0,0,0) skewY(0);
  }
  
  footer{
    position: relative;
  }



  /* 選手周りの情報とフッターのCSS */
    .abou-player2{
      position: absolute;
    width: 90%;
    left: 0;
    top: -7%;
    opacity: 0.15;
    max-width: 500px;
    }
  
  @media (min-width: 700px) {
  .abou-player2{
    display: block;
    position: relative;
    width: 90%;
    left: 0;
    opacity: 1;
  }
}

.footer-contents-top{
  padding-top: 7rem;
}
@media (min-width: 700px) {
  .footer-contents-top{
    padding-top: 5rem;
  }
}

.wht_bg{
  background-color: white !important;
}

.sponser1{
  max-width: 180px;
  display: block;
  margin:  5rem auto;
}
@media (min-width: 700px) {
  .sponser1{
  max-width: 200px;
  }
}