@charset "utf-8";
/* ---------------------------------------------------------------------------------
Copyright © J-SURE

HTML CSS Selectors gallery

$Revision: 1.0 $
--------------------------------------------------------------------------------- */

/*---------------------------------------------------------------------------------
一覧
--------------------------------------------------------------------------------- */
.list {
  margin-bottom: 150px;
}
.category-nav {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  margin-bottom: 98px;
  font-family: 'Mukta', sans-serif;
  font-size: 18px;
  line-height: 1;
  font-weight: 600;
  transition-delay: 2200ms;
}
.category-nav__ttl {
  padding: 0 42px 0 30px;
  background: url("../img/gallery/icon_category.svg") no-repeat left 1px;
}
.category-nav a {
  padding: 0 13px;
  margin: 0 25px;
  position: relative;
}

.gallery-list {
  display: flex;
  flex-wrap: wrap;
  width: 1248px;
  margin: 0 auto 50px;
}
.gallery-list li {
  width: 368px;
  margin: 0 24px 65px;
}
.gallery-list a {
  display: block;
  font-family: 'Mukta', sans-serif;
  line-height: 1;
}
.gallery-list a .img-box {
  width: 100%;
  padding-top: 100%;
  position: relative;
}
.gallery-list a .img-box-in {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
}
.gallery-list__category {
  padding: 25px 0 13px;
  font-size: 18px;
}
.gallery-list__name {
  font-size: 14px;
}
.gallery-list li:nth-of-type(3n+2) .img-box-in::before {
  transition-delay: .6s
}
.gallery-list li:nth-of-type(3n) .img-box-in::before {
  transition-delay: .8s
}

/*---------------------------------------------------------------------------------
詳細
--------------------------------------------------------------------------------- */
.contents-mv div {
  height: 100%;
}
.category-ttl {
  font-family: 'Mukta', sans-serif;
  height: 48px;
  font-size: 48px;
  line-height: 1;
  font-weight: 600;
  text-align: center;
  color: #ffffff;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  margin: auto;
  z-index: 2;
  /*mix-blend-mode : overlay;*/
}

.detail-wrap {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  align-content: flex-start;
  flex-wrap: wrap;
  width: 1000px;
  padding-bottom: 40px;
  margin: 0 auto 70px;
  position: relative;
  opacity: 1.0;
  transform: translate(0,0px);
}
.detail-wrap::before {
  width: 0;
  height: calc(100% - 134px);
  background-color: #f4f4f4;
  position: absolute;
  bottom: 0;
  right: 50%;
  margin-right: -50vw;
  content:"";
  transition : all 500ms 3000ms ease-out;
}
.effect-on.detail-wrap::before {
  width: calc(50vw - 228px);
}

.detail-header {
  width: 470px;
  position: relative;
  z-index: 2;
}
.detail-header__ttl {
  padding-bottom: 24px;
  font-size: 18px;
  line-height: 1.5;
  font-weight: 500;
}
.detail-header > p {
}
.detail-header-in {
  padding: 35px 28px 30px 45px;
  background-color: #f4f4f4;
  margin-top: 30px;
}
.detail-header-in__ttl {
  padding-bottom: 15px;
  font-size: 18px;
  line-height: 1.5;
  color: #007a66;
  font-weight: 500;
}

.detail-main-photo {
  width: 520px;
  position: relative;
  right: -100px;
  z-index: 2;
}
.detail-main-photo .img-box-in::before {
  transition-delay:2500ms;
}
.detail-main-photo-name {
  padding-top: 20px;
  font-size: 15px;
  line-height: 1;
}

.other-photo {
  width: 1120px;
  margin: 0 auto 110px;
}
.other-photo .item {
  width: 438px;
  padding: 0 61px 115px;
}

.banner {
  width: 660px;
  margin: 0 auto 220px;
}
.banner li .img-box,
.banner li .img-box-in {
  height: 100%;
}
.banner a {
  display: block;
  position: relative;
}
.banner a:hover {
  opacity: 1;
}
.banner a:hover .img-box-in {
  opacity: 0.6;
}
.banner-in {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-direction: column;
  width: 100%;
  height: 100%;
  color: #fff;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 2;
  opacity: 0;
  transition: 0.2s ease-in-out;
}
.banner a:hover .banner-in {
  opacity: 1;
}

.banner-in__en {
  width: 100%;
  padding-bottom: 20px;
  margin-bottom: 22px;
  font-family: 'Mukta', sans-serif;
  font-size: 18px;
  line-height: 1;
  font-weight: 300;
  text-align: center;
  position: relative;
}
.banner-in__en::after {
  width: 58px;
  height: 3px;
  background-color: #fff;
  position: absolute;
  right: 0;
  bottom: 0;
  left: 0;
  margin: 0 auto;
  content:"";
}
.banner-in__jp {
  font-size: 20px;
  line-height: 1.5;
  text-align: center;
  font-weight: 700;
}

.staff-wrap {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  padding: 105px 0 90px;
  background-color: #f4f4f4;
}
.staff-photo {
  width: 250px;
  height: 250px;
  background-color: #fff;
  border-radius: 50%;
  overflow:hidden;
  margin: 0 50px 30px 0;
}
.staff-name {
  display: flex;
  font-family: 'Mukta', sans-serif;
  line-height: 1;
  font-weight: 600;
  white-space: nowrap;
  transition-delay:800ms;
}
.staff-name__job {
  position: relative;
  font-size: 16px;
  padding-right: 64px;
}
.staff-name__job::after {
  width: 82px;
  height: 2px;
  background-color: #000;
  transform: rotate(135deg);
  position: absolute;
  top: 27px;
  right: 0px;
  content:"";
}
.staff-name__name {
  padding-top: 40px;
  font-size: 20px;
}

.salon-tel {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 100%;
  padding-bottom: 25px;
  font-family: 'Mukta', sans-serif;
  line-height: 1;
  font-size: 16px;
  font-weight: 500;
  color: #00987f;
}
.salon-tel span {
  display: block;
  padding-left: 10px;
  font-size: 30px;
  font-weight: 600;
}

.detail-reserve {
  width: 420px;
  margin: 0 auto;
}
.detail-reserve a {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 100%;
  height: 70px;
  background-color: #00987f;
  font-family: 'Mukta', sans-serif;
  font-size: 16px;
  line-height: 1;
  font-weight: 600;
  letter-spacing: 0.3em;
  color: #fff;
}
.detail-reserve a img {
  width: 30px;
  margin-right: 21px;
}

