@charset "UTF-8";
/* CSS Document */
/*========= 基本設定 ===============*/
body {
  background: #333;
  font-family: "游ゴシック体", YuGothic, "游ゴシック Medium", "Yu Gothic Medium", "游ゴシック", "Yu Gothic", "メイリオ", sans-serif;
  color: #333;
  font-size: 1rem;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  -webkit-text-size-adjust: 100%;
  word-wrap: break-word;
  /*背景に映像を設定する際は下4つのbackground~のコードは削除でOK*/
  background-image: url('../images/background.webp');
  background-position: center;
  background-size: auto;
  background-attachment: fixed;
  
}
body.appear {
  background: #FFFFFF;
}
@media screen and (max-width:768px) {
  body {
    font-size: 0.8rem;
  }
}
h2, h3, h4, h5 {
  text-align: center;
  line-height: 1.2;
  margin-top: 20px;
  margin-bottom: 5px;
  color: #FFFFFF;
  text-shadow:
    1px 0 4px #000000, 1px 1px 4px #000000, 0 1px 4px #000000, -1px 1px 4px #000000, -1px 0 4px #000000, -1px -1px 4px #000000, 0 -1px 4px #000000, 1px -1px 4px #000000;
}

a {
  text-decoration: none;
}
/*========= TOP画像用のCSS ===============*/
/* 画面幅の100%の幅で画像を表示 */
.image-vw {
  width: 100vw;
  margin: 0 auto;
}

/* ===パソコンで見たときは"pc"のclassがついた画像が表示される=== */
.pc {
  display: block !important;
}
.sp {
  display: none !important;
}
/* ===スマートフォンで見たときは"sp"のclassがついた画像が表示される=== */
@media only screen and (max-width: 768px) {
  .pc {
    display: none !important;
  }
  .sp {
    display: block !important;
  }
}
#logo {
  width: 100%;
  height: 40px;
  background-color: #000000;
  position: fixed;
  z-index: 999;
  box-shadow: 5px 5px 20px;
}
#logo img {
  display: block;
  padding: 6px;
  margin: 0 auto;
}
#main-area {
  margin: 0;
  padding: 0;
}

.bunner_sp {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 0 2vw;
}
.bunner_sp img {
  height: auto;
  margin: 1vw;
  width: 40vw;
  border-radius: 8px;
  border: solid 2px #FFFFFF;
}
@media screen and (max-width:768px) {
  .bunner_sp img {
    height: auto;
    margin: 2vw;
    width: 60vw;
    border: solid 1.5px #FFFFFF;
  }
}
.tenpobunner {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 0 0 2vw;
}
.tenpobunner img {
  height: auto;
  margin: 0 2vw;
  width: 40vw;
  border-radius: 8px;
  border: solid 2px #FFFFFF;
  transition: opacity 0.3s ease, transform 0.3s ease; /* アニメーションを設定 */
}
.tenpobunner img:hover {
  opacity: 0.9; /* マウスが乗ったときの透明度 */
  transform: scale(1.02); /* マウスが乗ったときのサイズ変更 */
}
@media screen and (max-width:768px) {
  .tenpobunner img {
    height: auto;
    margin: 0 2vw;
    width: 43vw;
  }
}
@media screen and (max-width:414px) {
  .tenpobunner img {
    height: auto;
    margin: 0 2vw;
    width: 45vw;
    border: solid 1px #FFFFFF;
  }
}
.kenrogo {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 2vh;
  margin-bottom: 1vh;
}
.kenrogo img {
  height: auto;
  ;
  width: 50vw;
  margin: 2vw 0;
}
@media screen and (max-width:768px) {
  .kenrogo img {
    height: auto;
    margin: 0 2px;
    width: 60vw;
  }
}
@media screen and (max-width:414px) {
  .kenrogo img {
    height: auto;
    margin: 0 2px;
    width: 70vw;
  }
}
.zengamen img {
  position: relative;
  text-align: center;
  align-items: center;
  display: flex;
  justify-content: center;
  width: 100vw;
  margin: 0;
}
.pict_main {
  margin-top: 7vh;	
  display: flex;
  justify-content: center;
}
.pict_main img {
  width: 100vw;
  margin: 0;
}
@media screen and (max-width:768px) {
  .pict_main img {
    height: auto;
    width: 100vw;
  }
}
.pict_sub {
  margin-top: 5vh;
  display: flex;
  justify-content: center;
}
.pict_sub img {
  width: 75vw;
  margin: 0;
}

@media screen and (max-width:768px) {
  .pict_sub img {
    height: auto;
    width: 100vw;
  }
}
.title {
  text-align: center;
}
.title img {
  border: none;
  max-width: 80vw;
  margin: 2vw 0;
}
.main-kisyu {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 10;
}
.main-kisyu img {
  width: 45vw;
  height: auto;
  margin: 0 5px;
}
@media screen and (max-width:768px) {
  .main-kisyu img {
    height: auto;
    margin: 0 2px;
    width: 85vw;
  }
}

.tenpocard {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}
.tenpocard img {
  height: auto;
  margin: 0 1vw 1vh 1vw;
  width: 42vw;
  transition: opacity 0.3s ease, transform 0.3s ease; /* アニメーションを設定 */
	}

.tenpocard img:hover {
  opacity: 0.95; /* マウスが乗ったときの透明度 */
  transform: scale(1.02); /* マウスが乗ったときのサイズ変更 */
}
@media screen and (max-width:768px) {
  .tenpocard img {
    height: auto;
    margin: 0;
    margin-bottom: 0.6vh;
    width: 92vw;
  }
}
.top_movie {
  text-align: center;
  width: auto
}
.top_movie video {
  text-align: center;
  width: 75vw;
  height: auto;
  padding-top: 3vh;
	padding-bottom: 3vh;
}
@media screen and (max-width:768px) {
  .top_movie video {
    height: auto;
    margin: 0;
    width: 100vw;
  }
}

.movie_thum {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin: 3px;
  padding-bottom: 10px;
}
.movie_thum img {
  cursor: pointer;
  height: auto;
  width: 30vw;
	margin: 2vw;
  transition: opacity 0.3s ease, transform 0.3s ease; /* アニメーションを設定 */
}
.movie_thum img:hover {
  opacity: 0.9; /* マウスが乗ったときの透明度 */
  transform: scale(1.02); /* マウスが乗ったときのサイズ変更 */
}
@media screen and (max-width:767px) {
  .movie_thum img {
    height: auto;
    width: 65vw;
  }
}

.SP-title {
  padding-top: 5vh;
  margin-bottom: 1vh;
}
@media screen and (max-width:767px) {
  .SP-title {
    margin-top: 2vh;
  }
}
.SP-title img {
  width: 60vw;
  height: auto;
  display: block;
  margin: 0 auto;
}
@media screen and (max-width:767px) {
  .SP-title img {
    width: 85vw;
  }
}
/*フッター設定
---------------------------------------------------------------------------*/
footer {
  clear: both;
  text-align: center;
  color: #fff; /*文字色*/
  font-size: 100%; /*文字サイズ*/
  padding-bottom: 6vh;
}
@media screen and (max-width: 767px) {
  footer {
    font-size: 80%; /*文字サイズ*/
    padding-bottom: 7vh;
  }
}
/*========= 背景動画設定のCSS ===============*/
/*container設定*/
#container {
  position: relative; /*h1の中央寄せ配置の起点とするためのrelative*/
  height: 100vh; /*高さを全画面にあわせる*/
}
#video-area {
  position: fixed;
  z-index: -999; /*最背面に設定*/
  top: 0;
  right: 0;
  left: 0;
  bottom: 0;
  overflow: hidden;
}
#video {
  /*天地中央配置*/
  position: absolute;
  z-index: -999;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  /*縦横幅指定*/
  width: 177.77777778vh; /* 16:9 の幅→16 ÷ 9＝ 177.77% */
  height: 56.25vw; /* 16:9の幅 → 9 ÷ 16 = 56.25% */
  min-height: 100%;
  min-width: 100%;
}

/* youtube関連 */
#video-overlay {
  display: none;
  position: fixed;
  top: 0;
  left: 0;
  width: 100vw;
  height: 100vh;
  background: rgba(0, 0, 0, 0.8);
  justify-content: center;
  align-items: center;
  overflow: hidden;
  z-index: 100
}
#video-player-container {
  position: relative;
}
#video-player {
  width: 70vw;
  height: 39.375vw; /* 16:9のアスペクト比に基づく計算（70 * 9 / 16） */
  max-width: 100%;
}
@media screen and (max-width: 767px) {
  #video-player {
    width: 95vw;
    height: 53.4375vw; /* 16:9のアスペクト比に基づく計算（95 * 9 / 16） */
  }
}
.dashed-line {
  width: 90%;
  height: 3px; /* 線の高さ */
  border-top: 3px dashed rgba(255, 165, 0, 0.4); /* 透明度を指定 */
}