@charset "utf-8";
/* 共通部分　*/
body{
    font-size: 16px;
    line-height: 4rem;
    letter-spacing: 1.5px;
    background-color: #fff;
    font-family: 'Noto Sans JP', sans-serif;
    overflow-x: hidden;

    /*position: relative;*/
}

p{
    color: #333;
}

h2{
  color:#333;
    font-size: 3rem;
    text-transform: uppercase;
    text-align: center;
    padding: 0 0 3rem;
    margin: 40px 0;
    font-family: 'Lexend', sans-serif;
}
h3{
  padding: 20px;
  color: #333;


}

a{
    text-decoration: none;
    display: block;
    color: black;
}

a:hover{
    opacity: 0.5 ;
}

.sm{
    display: none;
}

.menu{
    display: none;
}

.item{
    display: flex;

}
/*　後方一致　除外 */
div[id$="-block"]:not(#main-block)  {
    margin: 200px auto 100px;
    width: 1024px;
}


/* メインビジュアル */
#main-block{
    width: 100%;
    height: calc(100vh - 100px);
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
/*ドット*/
    background-image: radial-gradient(#000 40%, transparent 0), radial-gradient(#000 20%, transparent 0);
    background-position: 0 0, 10px 10px;
    background-size: 3px 3px;
    background-color: rgba(0,0,0,0);
    background-blend-mode: lighten;
}

#main-block img {
    -webkit-animation: fadeIn 5s ease 0s 1 normal;
    animation: fadeIn 5s ease 0s 1 normal;
    vertical-align: bottom;
  }

  @keyframes fadeIn {
    0% {
      opacity: 0
    }

    100% {
      opacity: 1
    }
  }

  @-webkit-keyframes fadeIn {
    0% {
      opacity: 0
    }

    100% {
      opacity: 1
    }
  }
  .bgbiew{
    position: relative;
  }
  .h1logo{
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%,-50%);
  }

/*about*/

#about-block{
    width: 100%;
    /*height: calc(100vh - 200px);*/
    text-align: center;
  }

.bqimg{
    border-radius: 50%;
    margin-top: 100px;
  }
.blandlogo {
  width: 70%;
}
/* ボタン */
    *,
    *:before,
    *:after {
    -webkit-box-sizing: inherit;
    box-sizing: inherit;
}

html{
    -webkit-box-sizing: border-box;
    box-sizing: border-box;
    font-size: 62.5%;
}


.button-area{
    font-size: .9rem;
    text-align: center;
    padding:50px;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    width: 40%;
    margin: 0 auto;
    line-height: 2rem;
    font-family: 'Lexend', sans-serif;
}
.button-area a{
    border: 2px solid #333;
    color: #333;
    padding: 1rem 2rem;
    border-radius: 30px;
    text-decoration: none;

}
.button-area a img{
    width:1.5rem;
    vertical-align: middle;
}

.button-area a:hover{
    opacity: 0.5;
}

.bland-area{
    margin-top: 80px;
}

.bland-item{
    font-size: .9rem;
}

/* navi */
nav{
    width:100%;
    height: 100px;
    margin: 0 auto 100px;
    font-size: 1.8rem;
    text-transform: uppercase;
    background-color: #fff;
    color: #333;
    /*position: absolute;*/
    position: sticky;
    position: -webkit-sticky;/*safali*/
    top: 0;
    z-index: 10;
    font-family: 'Lexend', sans-serif;
}

nav ul{
    height: 100%;
    line-height: 100px;
    vertical-align: middle;
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -ms-flex-direction: row;
    flex-direction: row;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
}

nav li{
    padding-left: 25px;
}

nav img{
    width:2rem;
    vertical-align: middle;
    gap: auto;

}

/*nav snsアイコン*/
/* ボタン全体 */
.flowbtn9{
    display:inline-block;
    font-size:40px;
    text-decoration:none;
    transition:.5s;
}

/* Twitter */
.flowbtn9 .fa-twitter-square{
    color:#55acee;
}

/* Instagram */
.flowbtn9 .fa-instagram{
    color:#c6529a;
}

/* Facebook*/
.flowbtn9 .fa-facebook-square{
    color:#3b5998;
}

/* YouTube */
.flowbtn9 .fa-youtube-square{
    color:#fc0d1c;
}

/* ulタグの内側余白を０にする */
ul.snsbtniti{
    padding:0!important;
}

/* アイコン全体の位置 */
.snsbtniti{
    display:-webkit-box;
    display:-ms-flexbox;
    display:flex;
    -ms-flex-flow:nowrap;
    flex-flow:nowrap;
    -webkit-box-pack:justify;
    -ms-flex-pack:justify;
    justify-content:space-between;
    gap:10px;
}

/* アイコン同士の余白 */
.snsbtniti li{
    -webkit-box-flex:0;
    -ms-flex:0 0 33%;
    flex:0 0 33%;
    text-align:center!important;
}

/* アイコンにマウスを乗せた時 */
.flowbtn9:hover{
    -webkit-transform: translateY(-5px);
    -ms-transform: translateY(-5px);
    transform: translateY(-5px);
}

/* instagram */

/* infomation */
/*#infomation-block{
    width: 100%;
    text-align: center;
}*/
#sns ul{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
}


.infomation{
    display: -ms-grid;
    display: grid;
    grid-gap: 50px;
    -ms-grid-columns: minmax(240px,1fr) 50px minmax(240px,1fr);
    grid-template-columns: repeat(2,minmax(240px,1fr));
    line-height: 3rem;
    width:900px;
    margin: 40px auto;
}

.msk{
  font-size: .9rem;
}

.dojo{
  font-size:.9rem;
}

.sns-info{
  text-align: center;
  padding-bottom: 80px;

}
.sns-info a{
  text-decoration: underline;
}
.infomation p{
  padding:20px;
}


.topic span{
  font-size: .8rem;
}
.topic{
  background: #f0f0f0;
}
.msk span{
  color: #f00;
}



/* ボタン全体 */
.flowbtn9{
    display:inline-block;
    font-size:30px;
    text-decoration:none;
    transition:.5s;
}
/* Twitter */
.flowbtn9 .fa-twitter-square{
    color:#55acee;
}
/* Instagram */
.flowbtn9 .fa-instagram{
    color:#c6529a;
}
/* Facebook*/
.flowbtn9 .fa-facebook-square{
    color:#3b5998;
}
/* YouTube */
.flowbtn9 .fa-youtube-square{
    color:#fc0d1c;
}
/* ulタグの内側余白を０にする */
ul.snsbtniti{
    padding:0!important;
}
/* アイコン全体の位置 */
.snsbtniti{
    display:flex;
    flex-flow: nowrap;
    justify-content:space-between;
}
/* アイコン同士の余白 */
.snsbtniti li{
    flex:0 0 10%;
    text-align:center!important;
}
/* アイコンにマウスを乗せた時 */
.flowbtn9:hover{
    -webkit-transform: translateY(-5px);
    -ms-transform: translateY(-5px);
    transform: translateY(-5px);
}

/* access */
#access-block{
    width: 100%;
    /*height: calc(100vh - 200px);*/
}

address{
    font-style:normal;
    color:#333;

}
tel{
    color:#333;

}
.access-items{
    text-align: left;
    height: 341px;

}

.container{
    margin-bottom: 120px;
}
.address-area{
    text-align: center;
    margin: 100px auto;
    color: 333;
    /*font-size: .9rem;*/
}
.address-area img{
    border-radius: 10%;
}


.access-wrapper{
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: horizontal;
    -webkit-box-direction: normal;
    -webkit-box-pack: justify;
    -ms-flex-pack: justify;
    justify-content: space-between;
    -webkit-box-align: center;
    -ms-flex-align: center;
    align-items: center;
    margin-bottom: 50px;
    padding: 50px;
    gap: 40px;
}

/* 地図　*/

/* フッター */
footer{
    height: 200px;
    width: 100%;
    background-color: #f1f1f1;
    margin-top: 400px;
    padding: 5rem;
    text-align: center;
}

.footer-sns {
    display: flex;
    justify-content: center;
    list-style: none;

}
small{
    color: #606060;
    font-size: .9rem;
}

/* スクロールCSS */
.fade-in {
  opacity: 0;
  transition-duration: 1s;
  transition-property: opacity, transform;
}

.fade-in-up {
  transform: translate(0, 50px);
}

.fade-in-down {
  transform: translate(0, -50px);
}

.fade-in-left {
  transform: translate(-50px, 0);
}

.fade-in-right {
  transform: translate(50px, 0);
}

.scroll-in {
  opacity: 1;
  transform: translate(0, 0);
}

/*-----------------------モバイル版---------------------------------*/

@media (max-width: 900px)
{
    .sm{
        display: block;
    }

    .menu{
        display: block;
    }

    .pc{
        display: none;
    }

    html{
        overflow-x: hidden;
    }

    body{
        font-size: 15px;
    }

    h1 img{
        width:100px;
    }

    nav{
        position: absolute;
        height: 50px;
        width:100%;
        background-color:rgba(0,0,0,0.5);
    }
    nav li{
      padding-left: 0;
    }

    #main-block::before{
      background-image: url(../video/demo.jpg);
    }

    #main-block{
        height: 100vh;
        width: 100%;
        object-fit: cover;
        }

    div[id$="-block"]:not(#main-block)  {
        width: 80%;
        margin-top: 200px;
    }

    nav ul{
        display: block;
    }

    .button-area{
        width: 100%;
        margin: 0 auto;
        line-height: 1rem;
        text-align: center;
        padding:20px;
        justify-content: center;
        gap:10px;
    }

      .about p{
        text-align: left;
    }

    /*.info-item{
        display:block;
    }*/
    .bland-item{
      line-height: normal;
    }

    #infomation-block p{
      text-align: left;
    }

    .infomation{
      display:block;
    }

    .infomation {
      width: auto;
      line-height: normal;

    }

    .infomation img{
      width:  auto;
      height; auto;
    }

    .info-item{
      margin-bottom: 30px;
    }

    .youtube-container {
      position: relative;
      width: 100%;
      padding-top: 56.25%;
    }
    .youtube-item iframe {
      position: absolute;
      top: 0;
      right: 0;
      width: 100%;
      height: 100%;
    }

    .container{
        height: 0;
        overflow: hidden;
        padding-bottom: 56.25%;
        position: relative;
    }

    .access-wrapper {
        display: block;
    }

    .access-items{
        text-align: center;
        margin-bottom: 20px;
        height: auto;

    }

    .access-items p{
      text-align: left;
    }

    .access-items img{
        max-width: 100%;
        height: auto;
    }

    .address-area{
        text-align: center;
        margin: 0 auto;
    }

    .address-area img{
        width: 50px;
    }

    .access-wrapper{
        align-items: center;
        margin-bottom: 100px;
        padding: 10px;
        gap: 30px;
    }

/*ハンバーガーメニュー*/
/* メニューボタン【通常時】 */
.menu{
  /* 右上に固定 */
  position: fixed;
  /* 上から10px */
  top: 30px;
  /* 右から10px */
  right: 10px;
  /* 重なり順（優先順位）を変更 */
  z-index: 3;
  /* 横幅 */
  width: 50px;
  /* 高さ */
  height: 50px;
  /* 上から10px */
  cursor: pointer;
  /* 背景色 */
  background-color: rgba(102, 102, 102, 0.7);
  /* 正円 */
  border-radius: 50%;
  /* ボタンの罫線を削除 */
  border: none;
  /* 余白込み */
  box-sizing: border-box;
}
/* マウスオーバーした場合 */
.menu:hover{
  /* 背景色を変更 */
  background-color: rgba(102, 102, 102, 1);
}
/* フォーカス（タブ移動）した場合 */
.menu:focus{
  /* 背景色を変更 */
  background-color: rgba(102, 102, 102, 1);
  /* 罫線を削除 */
  outline: 0;
  -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
}
/* 3本線の基本設定 */
.menu__line{
  /* spanはinlineが初期値なのでblockに変更 */
  display: block;
  /* それぞれの位置を設定するためにabsoluteに変更 */
  position: absolute;
  /* 右から12px */
  right: 12px;
  /* 線の横幅 */
  width: 25px;
  /* 線の高さ */
  height: 2px;
  /* 線の色（背景色で設定） */
  background-color: #FFF;
  /* 四つ角の丸み */
  border-radius: 4px;
  /* 0.5秒で変化 */
  transition: all .5s;
}
/* 1本目の線 */
.menu__line:nth-child(1){
  /* 上から17px */
  top: 17px;
}
/* 2本目の線 */
.menu__line:nth-child(2){
  /* 上から25px */
  top: 25px;
}
/* 3本目の線 */
.menu__line:nth-child(3){
  /* 上から33px */
  top: 33px;
}
/* メニューボタン【クリック時】 */
/* 1本目の線 */
.active .menu__line:nth-child(1){
  /* 8px下にズラし-45度傾ける */
  transform: translateY(8px) rotate(-45deg);
}
/* 2本目の線 */
.active .menu__line:nth-child(2){
  /* 透明化して見えなくする */
  opacity: 0;
}
/* 3本目の線 */
.active .menu__line:nth-child(3){
  /* 8px上にズラし45度傾ける */
  transform: translateY(-8px) rotate(45deg);
}

/* メニュー画面【通常時】 */
.nav{
  /* 画面を固定 */
  position: fixed;
  /* 上にくっつける */
  top: 0;
  /* 横幅の分だけ画面の外にズラす */
  left: -100vw;
  /* 重なり順（優先順位）を変更 */
  z-index: 2;
  /* 横幅 */
  width: 100vw;
  /* 高さ */
  height: 100vh;
  /* 背景色 */
    background-color: #fff;
  /* 0.5秒で変化 */
  transition: all .5s;
}
.nav__list{
  /* ul/liのマーカーを削除 */
  list-style: none;
}
.nav__link{
  /* リンクの文字色 */
  color: #000;
  /* リンクの下線を削除 */
  text-decoration: none;
}
.nav__link:hover{
  /* リンクがマウスオーバーした時に文字の透明度が70％に変化 */
  opacity: .7;
}
/* メニュー画面【クリック時】 */
.nav.active {
  /* ズラしていた分を戻して画面に表示させる */
  left: 0;
}

nav ul{
    line-height: 60px;
    margin-top: 30px;
    text-align: center;
   }
 ul .snsbtniti{
    margin: 80px auto 0;
    width: 40%;
    text-align: center;
    justify-content: center;
    }

nav{
    text-align: center;
    }

/*戻るボタン*/
#page_top{
  width: 50px;
  height: 50px;
  position: fixed;
  right: 0;
  bottom: 50px;
  background: #000;
  opacity: 0.6;
  z-index: 999;
}
#page_top a{
  position: relative;
  display: block;
  width: 50px;
  height: 50px;
  text-decoration: none;
}
#page_top a::before{
  font-family: 'Font Awesome 5 Free';
  font-weight: 900;
  content: '\f062';
  font-size: 25px;
  color: #fff;
  position: absolute;
  width: 25px;
  height: 25px;
  top: 0;
  /*bottom: 0;*/
  right: 0;
  left: 0;
  margin: auto;
  text-align: center;
  line-height: 2;

}

}
