@charset "utf-8";


    /* ＝＝＝＝＝＝＝＝＝＝
    --mainの指定-- 
    ＝＝＝＝＝＝＝＝＝＝＝*/
.main-wraper{
  position: relative;
}



    .main_imgBox {
      height: 680px;
      overflow: hidden;
      position: relative; }


    .main_img {
      z-index:10;
      opacity: 0;
      width: 100%;
      height: 680px;
      background-position: center center;
      background-repeat: no-repeat;
      background-size: cover;
      background-size: auto 120%;
      position: absolute;
      left: 0;
      top: 0;
      -webkit-animation: anime 18s forwards;
      animation: anime 18s forwards; 
    }


      .main_img:nth-of-type(2)  {
        -webkit-animation-delay: 6s;
        animation-delay: 6s;
        z-index: 20;
      }
  
      .main_img:nth-of-type(3)
     {
        -webkit-animation-delay: 12s;
        animation-delay: 12s;
        z-index: 30;
      }

        @keyframes anime {
          0% {
            opacity: 0;
          }
          20% {
            opacity: 1;
          }
          100% {
              opacity: 1;
              background-size: auto 100%;
          }
        }

.mainTxt {
    position: absolute; 
    top: 40%; 
    left: 50%; 
    transform: translate(-50%, -50%); 
    font-family: "Zen Old Mincho";
    color:var(--primary-cream);
    text-align: center;
    font-size: 2.8vw;
    font-weight: 300;
    line-height: 160%;
}

.mainTxt--last {
  top: auto;
  bottom: 250px;
  left: 100px;
  width: 0;
  transform: translate(0);
  white-space: nowrap;
  overflow: hidden;
  font-family: "Cormorant Garamond";
  text-shadow: 0px 2px 2px rgba(87,53,37 0.25);
  font-size: 5.0vw;
  animation: textanime 5s 16s forwards;
  text-align: left;
}

@keyframes textanime {
  0% {
    width: 0;
  }
  100% {
    width: 100%;
  }
}

.main_imgBoxsp{
  display: none;
}



/* ======== */
@media (max-width: 768px) {
.main_imgBox{
  display: none;
}

.main_imgBoxsp {
  display: block;
  height: 680px;
  overflow: hidden;
  position: relative; }


.main_imgsp {
  z-index:10;
  opacity: 0;
  width: 100%;
  height: 680px;
  background-position: center center;
  background-repeat: no-repeat;
  background-size: cover;
  background-size: auto 120%;
  position: absolute;
  left: 0;
  top: 0;
  -webkit-animation: anime 18s forwards;
  animation: anime 18s forwards; 
}


  .main_imgsp:nth-of-type(2)  {
    -webkit-animation-delay: 6s;
    animation-delay: 6s;
    z-index: 20;
  }

  .main_imgsp:nth-of-type(3)
 {
    -webkit-animation-delay: 12s;
    animation-delay: 12s;
    z-index: 30;
  }

    @keyframes anime {
      0% {
        opacity: 0;
      }
      20% {
        opacity: 1;
      }
      100% {
          opacity: 1;
          background-size: auto 100%;
      }
    }

.mainTxtsp {
position: absolute; 
top: 40%; 
left: 50%; 
transform: translate(-50%, -50%); 
font-family: "Zen Old Mincho";
color:var(--primary-cream);
text-align: center;
font-size: 6.0vw;
font-weight: 300;
line-height: 160%;
}

.mainTxtsp--last {
top: auto;
bottom: 180px;
left: 50px;
width: 0;
transform: translate(0);
white-space: nowrap;
overflow: hidden;
font-family: "Cormorant Garamond";
text-shadow: 0px 2px 2px rgba(87,53,37 0.25);
font-size: 10.0vw;
animation: textanime 5s 16s forwards;
text-align: left;
}

@keyframes textanime {
0% {
width: 0;
}
100% {
width: 100%;
}
}

}

/* ==scroll */
.scrolldown2{
position:absolute;
top:85%; 
right: 8vw;
z-index: 100;
}

.scrolldown2 span{
position: absolute;
left:10px;
bottom:10px;
color: var(--primary-cream);
font-size: 0.7rem;
letter-spacing: 0.05em;
/*縦書き設定*/
-ms-writing-mode: tb-rl;
  -webkit-writing-mode: vertical-rl;
  writing-mode: vertical-rl;
}

.scrolldown2:before {
  content: "";
  position: absolute;
  bottom:0;
  left:-4px;
width:10px;
height:10px;
border-radius: 50%;
background:#eee;
animation:
  circlemove 2.0s ease-in-out infinite,
  cirlemovehide 2.0s ease-out infinite;
}

@keyframes circlemove{
    0%{bottom:45px;}
   100%{bottom:-5px;}
}

@keyframes cirlemovehide{
    0%{opacity:0}
   50%{opacity:1;}
  80%{opacity:0.9;}
100%{opacity:0;}
}

.scrolldown2:after{
content:"";
position: absolute;
bottom:0;
left:0;
width:2px;
height: 60px;
background:var(--primary-cream);
}
/* ==scroll */







/*==========================
Concept
==========================*/

.section--top {
  background-image: url(../image/yoga_mainunder-.png);
  background-size: contain;

}
.section__title--top{
padding: 120px 9.7% 80px;
}
.top_unit {
  display: grid;
  grid-template-columns: 1fr 1fr ;
  justify-content: center;
  align-items: center;
  margin-bottom: 120px;
}

.top_txtblock--b{
  order:2;
  
}
.top_concept-img--b{
  order:1;
  
}


.top_txtblock{
  display: flex;
  flex-direction: column;
  padding: 7%;
  align-items: center;
  gap: 60px;
}


.top_txtblock--a {
  border-left: 0.5px solid  var(--primary-b);
}

.top_txtblock--b {
  border-right: 0.5px solid var(--primary-b);
}

.conceptTitle{
  text-align: left;
  color: var(--primary-b);
font-size: 3.0vw;
}

.top_basetxt{
font-size: 2.0vw;
color: var(--primary-b);
line-height: 180%;
}

.top_concept-img {
  aspect-ratio: 5 / 5;
  box-shadow: 15px 15px  #8993A5;
}

.Island_Obi {
  width: 100vw;
  height: auto;
  object-fit: cover;
}

@media (max-width: 768px)  {

  .top_unit {
    display: flex;
    flex-direction: column;
    width: 100%;
    justify-content: center;
    align-items: center;
    margin-bottom: 80px;
    gap: 20px;
  }

  .top_txtblock{
    gap: 20px;
  }

  .top_txtblock--b{
    order:1;
  }
  .top_concept-img--b{
    order:2;
  }
  
.top_unit:nth-of-type(3n) {
  flex-direction: column;
} 

.conceptTitle{

  text-align: center;
}
  .top_basetxt{
    font-size: 2.0vw;
    }

  .top_concept-img{
    width: 60%;
  }
}

@media screen and (max-width:428px){


  .top_txtblock--a {
    border-left: none;
  }
  
  .top_txtblock--b {
    border-right:  none;
  }

  .conceptTitle{
    font-size: 2.4rem;
   }
    .top_basetxt{
      font-size: 1.6rem;
      }


.Island_Obi {
  height: 120px;
object-fit: cover;
}
}
/*==========================
Prof
==========================*/

.section-prof{
  display: flex;
padding: 120px 15.3%;
align-items: center;
gap: 80px;
background-color: var(--primary-back02);
}

.prof_img {
  width: 400px;
  height: auto;
}

.pc-view{
  display: block;
}

.sp-view{
  display: none;
}

.prof-txtbox{
  display: flex;
  max-width: 520px;
  width: 30vw;
  padding-bottom: 15px;
  flex-direction: column;
  align-items: flex-start;
  gap: 15px;
}

.prof-catch {
  font-family: "Zen Kaku Gothic New";
font-size: 2.0rem;
font-weight: 500;
color: var(--primary-b);
}

.prof-name {
  font-family: "Cormorant Garamond";
  font-size:  4.8rem;
  font-weight: 300;
  color: var(--primary-b);
}

.prof-subcatch {
  font-family: "Zen Kaku Gothic New";
font-size: 2.0rem;
color: var(--primary-b);
}

.prof-txt {
font-size: 2.0rem;
color:var(--primary-b);
}

@media screen and (max-width:999px) {

  .section-prof{
    display: flex;
    flex-direction: column;
    padding: 120px 3%;
  }

  .prof-txtbox{
    align-items: center;
    width: 100%
  }

  .prof-txt{
    max-width: 450px;
    margin: 20px auto 0px;
  }

  .prof_img{
    width: 240px;
    height: auto;
  }

  .pc-view{
    display: none;
  }
  
  .sp-view{
    display: block;
  }


}
@media screen and (max-width:500px) {
  .prof-txt{
      max-width: 311px;
        font-size: 1.6rem;
  }
}

/*==========================
Menu
==========================*/

.section--menu {
  padding: 0 20px 80px;
  background-color: var(--primary-back01);
}



.section__menutitle{
  display: flex;
  /* max-width: 1160px; */
  padding: 120px 9.7% 60px;
  flex-direction: column;
  align-items: center;
}


.menu-btn {
  display: flex;
  justify-content: center; 
  width: 100%;
  align-items: center;  
  max-width: 1160px;
  text-align: center;
  color: var(--primary-b);
  font-family: "Cormorant Garamond";
  font-size: 4.0em;
  transform: scale(0.95, 1);
  font-weight: 300;
  padding: 10% 10%;
  margin-top: 60px;
  cursor:pointer;
  background-size: cover;
  overflow: hidden;
  position: relative;
  transition-duration: .2s;
  z-index: 2;
}
 
.menu-btn::after {

  border-radius: 50%;
  border: 1px solid #fff;
  content: "";
  display: block;
  margin: auto;
  opacity: 0;
  pointer-events: none;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  width: 100%;
  padding-top: 100%;
  height: 0;
  z-index: -1;
  transform: translateY(-50%) scale(0);
  transition: opacity .5s, transform 1s;

}

.menu-btn:hover {
  color: var(--primary-cream);
}
.menu-btn:hover::after {
  transform: translateY(-50%) scale(1.2);  
  transition-delay: 0s;
  transition: opacity 1s, transform 1s ease-in-out;
}

.menu-btn--01{
  background-image: url(../image/top_h_btnYoga.png);
}
.menu-btn--02{
  background-image: url(../image/top_h_btnStay.png);
}

.menu-btn--03{
  background-image: url(../image/top_h_btnPrice.png);
}


.menu-btn--01::after,
.menu-btn--02::after,
.menu-btn--03::after
{
background-color: #fff;
opacity: 0.1;
}

@media screen and (max-width:768px) {
  .menu-btn {
    font-size: 1.8em;
}
}


.section__menutitle{
  padding: 80px 9.7% 40px;
}

@media screen and (max-width:428px) {

  .menu-btn {
    font-size: 1.6em;
    color: var(--primary-cream);
}
}


