html{
  margin: 0px;
  padding: 0px;
  overflow-x: hidden;
  overflow-y: scroll;
}

body{
  margin: 0px;
  padding: 0px;
  /* background: url(../img/common/bg.png); */
  font-size: 14px;
  line-height: 1.5em;
  color: #3c454e;
  text-align: justify;
  text-justify: inter-ideograph;
  font-family: "メイリオ","Meiryo","ＭＳ Ｐゴシック",osaka,monospace;
}
  @media screen and (max-width: 666px) {
    body{
      font-style: normal !important;
      font-size: 13px;
    }
  }

a{
  text-decoration: none;
  color: #0A70C2;
  -webkit-transition:color 0.5s linear;
  -moz-transition:color 0.5s linear;
  -o-transition:color 0.5s linear;
  transition:color 0.5s linear;
}
h1{
  margin: 0;
}
img{
  border: 0px;
}


.t_c,
.tc{
  text-align: center;
}
.f10{
  font-size: 10px;
}
.mb0{
  margin-bottom: 0!important;
}
.mt0{
  margin-top: 0!important;
}

.pc {
  display: block !important;
}
.smt {
  display: none !important;
}
  @media screen and (max-width: 666px) {
    .pc {
      display: none !important;
    }
    .smt {
      display: block !important;
    }
  }

/* ヘッダー */

.header-space{
  height: 60px;
  width: 100%;
}
#header-box{
  position: fixed;
  top: 0;
  height: 60px;
  width: 100%;
  background-color: #fff;
  border-bottom: 1px solid #78B891;
  transition: .5s;
  text-align: center;
  /* display: none; */
  z-index: 600;
  /* opacity: 0; */
}
#header-box img{
  top: 10px;
  height: 60px;
  z-index: 601;
}
@media screen and (min-width: 666px) {
  #header-box{
    text-align: initial;
    z-index: 9999;
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
  #header-box img{
    position: relative;
    top: 0;
    left: 30px;
  }
  #header-box ul{
    list-style: none;
  }
  #header-box ul li{
    display: inline-block;
    margin-right: 30px;
  }
  #header-box ul li:nth-last-child(1){
    margin-right: 50px;
    font-size: 30px;
  }
  #header-box ul li a{
    color: #78B891;
    font-size: 16px;
  }
  .h-insta a i{
    position: relative;
    right: 1px;
    top: 4px;
    font-size: 25px;
  }
}

.topvisual-wp {
  position: relative;
  width: 100%;
}
.topvisual-wp img.logo {
  /* margin-top: 5px; */
  bottom: 10%;
  width: 80%;
  vertical-align: bottom;
  z-index: 2000;
}
#top-bg{
  /* margin: auto;
  background-color: white; */
  position: relative;
  width: auto;
  height: 150vw;
  
}
#top-bg img{
  width: 100vw;
  height: auto;
  position: absolute;
  top: 0;
  left:0;
  z-index: 800;
  opacity: 0.0;
}
#top-bg img.active {
  width: 100%;
  z-index: 1000;
  opacity: 1.0;
}
#top-bg img.last-active {
  z-index: 900;
}


#top-bg2{
  /* margin: auto;
  background-color: white; */
  position: relative;
  width: auto;
  height: 70vw;
  
}
#top-bg2 img{
  width: 100vw;
  height: auto;
  position: absolute;
  top: 0;
  left:0;
  z-index: 800;
  opacity: 0.0;
}
#top-bg2 img.active {
  width: 100%;
  z-index: 1000;
  opacity: 1.0;
}
#top-bg2 img.last-active {
  z-index: 900;
}
.topvisual-wp .visual img.smt {
  display: none;
}
.topvisual-wp .logo {
  position: absolute;
  top: 50%;
  transform: translate(0, -30%);
  -webkit-transform: translate(0, -30%);
  -moz-transform: translate(0, -30%);
  -ms-transform: translate(0, -30%);
  left: 0;
  right: 0;
  width: 30%;
  margin: 0 auto;
  font-size: 11px;
  color: #fff;
  text-align: center;
  line-height: 1.2;
  /* ADD 180715 -> */
  z-index: 1;
  /* ADD 180715 <- */
}
@media screen and (min-width: 666px) {
  .topvisual-wp img.logo {
    /* margin-top: 5px; */
    top: 40%;
    width: 50%;
    vertical-align: bottom;
    z-index: 2000;
  }
}




.footer{
  margin-top: 120px;
  position: relative;
  height: 270px;
  display: block;
  background-color: #233343;
}


.footer-box{
  float: none;
  width: auto;
}
.footer-box img{
  position: absolute;
  /* top: 50%; */
  left: 50%;
  transform: translate(-50%, -50%);
  -webkit-transform: translate(-50%, -50%);
  -moz-transform: translate(-50%, -50%);
  -ms-transform: translate(-50%, -50%);
}

.footer_links{
  display: flex;
  float: none;
  padding: 0 15px 15px;
  text-align: center;
  margin: 0 auto;
  justify-content: center;
}
.footer_links p{
  position: absolute;
  bottom: 0;
}
.footer_links a {
  display: inline-block;
  padding: 0;
  margin: 0 10px 10px 0;
  background: none;
  font-size: 12px;
  line-height: 1.2me;
  color: #fff;
  text-align: center;
}


.copyright {
  margin: 0;
  position: relative;
  clear: both;
  background-color: #6b7177;
  font-size: 12px;
  padding: 15px 0;
  color: #FFF;
  text-align: center;
  font-style: normal;
}
.copyright small {
  font-size: inherit;
}




/* */
section{
  padding: 0 20%;
}
@media screen and (max-width: 850px) {
  section{
    padding: 0 5%;
  }
}
.h-title {
  margin: 25px 0 25px;
  font-family: 'Niconne', cursive;
  font-size: 50px !important;
  color: #3c454e;
  letter-spacing: 0.025em;
  line-height: 1;
  text-align: center;
  font-weight: bold;
}
.h-title small {
  font-size: 50%;
}
  @media screen and (max-width: 799px) {
    .h-title {
      margin: 15px 0;
      font-size: 30px;
    }
  }
  @media screen and (max-width: 499px) {
    .h-title {
      font-size: 7.5vw;
    }
  }


/* */
.h-lead {
  margin-bottom: 40px;
  /* padding-top: 30px; */
  background-image: url('../img/common/renewal/title_line_pink.svg');
  background-repeat: no-repeat;
  background-position: 50% 0;
  background-size: auto 3px;
  font-size: 16px;
  font-weight: normal;
  line-height: 1.6;
}
.h-lead.none-bg {
  padding-top: 0;
  background: none;
}
  @media screen and (max-width: 799px) {
    .h-lead {
      margin: 0 15px 20px;
      padding-top: 15px;
      background-size: auto 2px;
      font-size: 13px;
    }
  }


/* */
.button {
  display: inline-block;
  width: 80%;
  padding: 12px 0;
  background-color: #3c454e;
  border-radius: 30px;
  -webkit-border-radius: 30px;
  -moz-border-radius: 30px;
  color: #fff;
  text-align: center;
}
.button:hover {
  filter: alpha(opacity=70);
  -moz-opacity: 0.7;
  opacity: 0.7;
  transition: opacity 0.2s ease-out;
  text-decoration: none;
  color: #fff;
}
.button span{
  display: inline-block;
  font-size: 20px;
  font-family: 'Dancing Script', cursive;
}
  @media screen and (max-width: 799px) {
    .button {
      width: 80%;
      margin: 0 auto;
      padding: 12px 0;
    }
  }



hr{
  border-top:1px solid #00BB00;
  margin: 30px 20%;
}

.gallery , .member{
  display: flex;
  white-space: nowrap;
  overflow-x: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
}
.gallery::-webkit-scrollbar,  .member::-webkit-scrollbar{
  display:none;
}
.gallery div, .member > div{
  margin-right: 15px;
  text-align: center;
}
.gallery div img{
  padding-bottom: 0;
  width: 300px;
}
.gallery div p{
  margin-top: 10px;
  color: #333333;
  font-family: 'Playball', cursive;
  font-size: 20px;
  margin-bottom: 40px;
}

.member > div > div{
  padding: 0 10%;
}

.position{
  border-bottom: 1px solid #333333;
  margin-bottom: 0;
  font-family: 'Playball', cursive;
  text-align: left;
  font-size: 18px;
}
.name{
  /* font-family: 'Courier New', Courier, monospace; */
  text-align: right;
  font-family: 'Playball', cursive;
  font-size: 24px;
  margin-top: 5px;
}
.contact {
  display: inline-block;
  text-align: center;/*中央揃え*/
  color: #2e6ca5;/*文字色*/
  font-size: 20px;/*文字サイズ*/
  text-decoration: none;/*下線消す*/
  position: relative;
  top:60px;
  left: -150px;
  margin-bottom: 15px;
}

.contact:hover {/*ホバー時*/
  color:#668ad8;/*文字色*/
  transition: .5s;/*ゆっくり変化*/
}

.contact .insta{/*アイコンの背景*/
  position: relative;/*相対配置*/
  display: inline-block;
  width: 50px;/*幅*/
  height: 50px;/*高さ*/
  background: -webkit-linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;
  background: linear-gradient(135deg, #427eff 0%, #f13f79 70%) no-repeat;/*グラデーション①*/
  overflow: hidden;/*はみ出た部分を隠す*/
  border-radius: 13px;/*角丸に*/

}

.contact .insta:before{/*グラデーションを重ねるため*/
  content: '';
  position: absolute;/*絶対配置*/
  top: 23px;/*ずらす*/
  left: -18px;/*ずらす*/
  width: 60px;/*グラデーションカバーの幅*/
  height: 60px;/*グラデーションカバーの高さ*/
  background: -webkit-radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);
  background: radial-gradient(#ffdb2c 10%, rgba(255, 105, 34, 0.65) 55%, rgba(255, 88, 96, 0) 70%);/*グラデーション②*/
}

.contact .fa-instagram {/*アイコン*/
  color: #FFF;/*白に*/
  position: relative;/*z-indexを使うため*/
  z-index: 2;/*グラデーションより前に*/
  font-size: 40px;/*アイコンサイズ*/
  line-height: 50px;/*高さと合わせる*/
}
.contact{
  top: 110px;
  left: 0px;
  display: flex;
  width: 100%;
  justify-content:center;
  align-items: center;
}
.contact span{
  width: 30%;
  /* left: 40px; */
}
.contact p {
  /* width: 3%; */
  font-size: 13px;
  padding: 5px 20px;
  text-decoration: none;
  color: #FFFFFF;
  background-color: #78B891;
  border: 1px solid #78B891;
  border-radius: 10px;
  margin-left: 20px;
  position: relative;
}
.contact p::before{
  content: "";
position: absolute;
top: 50%;
left: -24px;
margin-top: -12px;
border: 12px solid transparent;
border-right: 12px solid #78B891;
z-index: 2;
}





/* galleryページ */


.g-title{
  background-color: #3c454e;
  color: #FFFFFF;
  /* width: 100%; */
  padding: 5px;
  font-size: 20px;
  margin-top: 30px;
  /* font-family: 'Kalam', cursive; */
  /* font-family: 'Sofia', cursive; */
  /* font-family: 'Calligraffitti', cursive; */
  font-family: 'Playball', cursive;
}

.img-gallery{
  display: flex;
  white-space: nowrap;
  overflow-x: scroll;
  -ms-overflow-style: none;
  scrollbar-width: none;
  margin-bottom: 10px;
}
.img-gallery::-webkit-scrollbar{
  display:none;
}
.img-gallery img{
  margin-right: 10px;
  height: 210px;
}
.img-gallery img:nth-last-child(1){
  margin-right: 0;
}



/* Planページ */
.plan-img {
  width: 100%;
}
.price{
  background-color: #3c454e;
  color: #FFFFFF;
  padding: 5px;
  margin-bottom: 10px;
}
.plan-text{
  margin: 0 0 30px;
  font-size: 11px;
}

/* privacy policy */
.pp-title{
  text-align: center;
  font-size: 25px;
}
.psec-title{
  text-align: center;
  margin: 40px 0 30px;
}
table{
  border-collapse:  collapse;
}
table td{
  border: 1px solid #000;
  padding: 3px;
}
table td span{
  font-size: 11px;
  line-height: 0.5;
}
table td:nth-child(1){
  width: 33%;
}
/*　ハンバーガーボタン　*/
.hamburger {
  display : block;
  position: fixed;
  z-index : 9999;
  right : 13px;
  top   : 12px;
  width : 42px;
  height: 42px;
  cursor: pointer;
  text-align: center;
}
.hamburger span {
  display : block;
  position: absolute;
  width   : 30px;
  height  : 2px ;
  left    : 6px;
  background : #78B891;
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition   : 0.3s ease-in-out;
  transition        : 0.3s ease-in-out;
}
.hamburger span:nth-child(1) {
  top: 10px;
}
.hamburger span:nth-child(2) {
  top: 20px;
}
.hamburger span:nth-child(3) {
  top: 30px;
}

/* ナビ開いてる時のボタン */
.hamburger.active span:nth-child(1) {
  top : 16px;
  left: 6px;
  -webkit-transform: rotate(-45deg);
  -moz-transform   : rotate(-45deg);
  transform        : rotate(-45deg);
}

.hamburger.active span:nth-child(2),
.hamburger.active span:nth-child(3) {
  top: 16px;
  -webkit-transform: rotate(45deg);
  -moz-transform   : rotate(45deg);
  transform        : rotate(45deg);
}

nav.globalMenuSp {
  position: fixed;
  z-index : 3000;
  top  : 0;
  left : 0;
  color: #000;
  background: #ccc;
  text-align: center;
  opacity: 0;
  transition: opacity .6s ease, visibility .6s ease;
  width: 100%;
  pointer-events: none;
}

nav.globalMenuSp ul {
  background: rgb(251, 255, 249);
  margin: 0 auto;
  padding: 0;
  width: 100%;
}

nav.globalMenuSp ul li {
  list-style-type: none;
  padding: 0;
  width: 100%;
  border-bottom: 1px solid #dfdfdf;
}
nav.globalMenuSp ul li:nth-child(1){
  border-bottom: 1px solid #78B891;
  background-color: #fff;
}
/* nav.globalMenuSp ul li:last-child {
  padding-bottom: 0;
  border-bottom: none;
} */
nav.globalMenuSp ul li:hover{
  background :#fff;
}
nav.globalMenuSp ul li img {
  display: block;
  height: 60px;
  margin: 0 auto;
}
nav.globalMenuSp ul li a {
  display: block;
  color: #78B891;
  padding: 1em 0;
  text-decoration :none;
}

/* このクラスを、jQueryで付与・削除する */
nav.globalMenuSp.active {
  opacity: 100;
  pointer-events: all;
}

.insta-area{
  display: flex;
  justify-content: center;
  align-items: center;
}
@media screen and (min-width: 666px) {
  .insta-area{
    margin-bottom: 100px;
  }
}