@charset "utf-8";
/* ---------------------------------------------------------------------------------
Copyright© SOL*Z GROUP All Rights Reserved.

HTML CSS Selectors index

$Revision: 1.0 $
--------------------------------------------------------------------------------- */
#contents-wrapper {
  padding-top: 180px;
}
.fv-area {
  margin-bottom: 260px;
  position: relative;
}
.fv-area::before {
  width: calc(50% - 394px);
  height: 352px;
  background-color: #f5f5f5;
  position: absolute;
  top: 380px;
  left: 0;
  content:"";
  z-index: 1;
}
.fv-mian-photo {
  width: 680px;
  height: 900px;
  margin: 0 auto;
  position: relative;
  left: 194px;
  z-index: 1;
}
.fv-mian-photo-slide {
  width: 100%;
  height: 100%;
  overflow:hidden;
}
.fv-mian-photo-slide div {
  height: 100%;
}
.fv-mian-photo-nav {
  width: 515px;
  height: 194px;
  padding: 37px 0 0 38px;
  background-color: #fff;
  position: absolute;
  right: -305px;
  bottom: -138px;
  z-index: 10;
}
.fv-mian-photo-nav .nav-item {
  width: 140px!important;
  height: 140px;
  margin-right: 27px;
}
@keyframes shrink {
  0% {
    transform: scale(1);
    filter: blur(32px) brightness(1.01)
  }
  30% {
    filter: blur(0) brightness(1.01)
  }
  100% {
    transform: scale(1.2); /* 拡大率 */
    filter: blur(0) brightness(1.01)
  }
}
.add-animation {
  animation: shrink 10s linear 0s normal both;
}

.fv-sub-photo {
  width: 400px;
  height: 400px;
  position: absolute;
  top: 566px;
  right: 50%;
  margin-right: 255px;
  z-index: 2;
}

.fv-read {
  display: flex;
  flex-direction: column;
  width: 500px;
  position: absolute;
  top: 324px;
  left: 50%;
  margin-left: -415px;
  z-index: 12;
  font-family: var(--font-mon);
  font-size: 48px;
  line-height: 1;
  letter-spacing: 0.1em;
  color: #fff;
}
.fv-read::before {
  width: 327px;
  height: 102px;
  background-image: url("../img/salon/we-are.svg");
  position: absolute;
  top: -95px;
  left: -153px;
  content:"";
}
.fv-read span {
  display: block;
  width: fit-content;
  padding: 20px 24px;
  position: relative;
  z-index: 2;
  opacity: 1;
}
.fv-read span::before {
  display: block;
  width: 0;
  height: 100%;
  background-color: #310700;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  content:"";
  transition : all 500ms 300ms ease-out;
}
.fv-read span.effect-on::before {
  width: 100%;
}
.fv-read span:nth-of-type(2)::before {
  transition-delay:500ms;
}
.fv-read span:nth-of-type(3) {
  margin-top: 24px;
}
.fv-read span:nth-of-type(3)::before {
  transition-delay:700ms;
}

.banner {
  margin-bottom: 175px;
  position: relative;
  z-index: 3;
}

/*---------------------------------------------------------------------------------
SALON
--------------------------------------------------------------------------------- */
.salon {
  padding: 235px 0 270px;
  margin-bottom: 95px;
  position: relative;
  z-index: 2;
  opacity: 1;
}
.salon__bg {
  width: 0;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: #310700;
  z-index: -1;
  transition : all 500ms 0ms ease-out;
}
.salon.effect-on .salon__bg {
  width: 100%;
}
.salon::before {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 15.8vw 100vw 0 0;
  border-color: #ffffff transparent transparent transparent;
  position: absolute;
  top: 0;
  left: 50%;
  margin-left: -50vw;
  content:"";
  z-index: 2;
}
.salon::after {
  display: block;
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 0 0 15.8vw 100vw;
  border-color: transparent transparent #ffffff transparent;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -50vw;
  content:"";
  z-index: 2;
}

.salon-ttl {
  width: 75px;
  height: fit-content;
  font-family: var(--font-en);
  font-size: 72px;
  line-height: 1;
  letter-spacing: 0.2em;
  writing-mode: vertical-rl;
  white-space: nowrap;
  color: #fff;
  position: absolute;
  top: 0;
  bottom: 0;
  right: 50%;
  margin: auto;
  margin-right: -658px;
  z-index: 3;
}
.salon-list {
  width: 960px;
  margin: 0 auto;
}
.salon-list li {
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  align-content: flex-end;
  flex-wrap: wrap;
  padding-right: 24px;
  margin-bottom: 20px;
  position: relative;
}
.salon-list-inner {
  display: flex;
  align-items: flex-end;
  align-content: flex-end;
  width: 615px;
  padding: 0 20px 17px 0;
  position: relative;
  color: #fff;
}
.salon-list-inner::after {
  width: 100%;
  height: 2px;
  background-color: #FFF;
  position: absolute;
  bottom: -8px;
  left: 0;
  content:"";
}
.salon-list-inner__box01 {
  width: 265px;
}
.salon-list-inner__box01 .logo {
  width: fit-content;
  margin: 0 auto 22px;
}
.salon-list-inner__box01 .logo img {
  width: fit-content;
  height: 54px;
}
.salon-list-inner__box01 .btn-reserve {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 188px;
  height: 46px;
  border: 2px solid #fff;
  border-radius: 23px;
  margin: 0 auto;
  font-family: var(--font-mon);
  font-size: 18px;
  line-height: 1;
  color: #fff!important;
  font-weight: 200;
}
.salon-list-inner__box02 {
  width: 150px;
}
.salon-list-inner__box02 .sns {
  display: flex;
  flex-wrap: wrap;
  margin-bottom: 40px;
  line-height: 1;
}
.salon-list-inner__box02 .sns a {
  width: 30px;
  margin: 0 10px;
}
.salon-list-inner__box02 .name {
  font-size: 16px;
  line-height: 1.625;
}
.salon-list-inner__box03 {
  width: 200px;
  text-align: right;
}
.salon-list-inner__box03 .tel {
  padding-bottom: 15px;
  font-size: 22px;
  line-height: 1;
}
.salon-list-inner__box03 .add {
  font-size: 16px;
  line-height: 1.5;
}
.salon-list-inner__box03 .open {
  font-size: 16px;
  line-height: 1.5;
}

.salon-list-img {
  width: 300px;
}

/*---------------------------------------------------------------------------------
STAFF
--------------------------------------------------------------------------------- */
.staff {
  width: 1100px;
  margin: 0 auto 285px;
}
.staff-salon-name {
  display: flex;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  height: 144px;
  padding-left: 360px;
  background-color: #310700;
  margin-bottom: 16px;
  font-size: 30px;
  line-height: 1;
  color: #fff;
  position: relative;
  cursor: pointer;
}
.staff-salon-name .en {
  font-family: var(--font-en);
  font-size: 48px;
}
.staff-salon-name::after {
  width: 52px;
  height: 52px;
  background-image: url("../img/top/btn_open.svg");
  position: absolute;
  top: 0;
  right: 55px;
  bottom: 0;
  margin: auto;
  content:"";
}
.staff-salon-name.selected {
  background-color: #65c4c6;
}
.staff-salon-name.selected::after {
  background-image: url("../img/top/btn_close.svg");
}

.staff-list {
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 50px;
}
.staff-list li {
  width: 225px;
  margin: 0 22px 30px;
}
.staff-list li:nth-of-type(4n+2) {
  transition-delay:400ms;
}
.staff-list li:nth-of-type(4n+3) {
  transition-delay:500ms;
}
.staff-list li:nth-of-type(4n) {
  transition-delay:600ms;
}
.staff-list a {
  display: block;
}
.staff-list__img {
  padding-bottom: 10px;
}
.staff-list__job {
  padding-bottom: 12px;
  font-size: 14px;
  line-height: 1;
}
.staff-list__name-jp {
  padding-bottom: 6px;
  font-size: 16px;
  line-height: 1;
}
.staff-list__name-en {
  font-family: var(--font-en);
  font-size: 24px;
  line-height: 1;
}

/*---------------------------------------------------------------------------------
RECRUIT
--------------------------------------------------------------------------------- */
.recruit {
  margin-bottom: 430px;
  position: relative;
  z-index: 2;
  opacity: 1;
}
.recruit::before {
  display: block;
  width: 460px;
  height: 375px;
  background-color: #f5f5f5;
  position: absolute;
  bottom: -130px;
  left: 50%;
  opacity: 0;
  margin-left: -346px;
  transition : all 500ms 1000ms ease-out;
  transform: translate(50px,-50px);
  content:"";
}
.effect-on.recruit::before {
  opacity: 1.0;
  transform: translate(0,0px); 
}
.recruit-img {
  width: 500px;
  margin: 0 auto;
  position: relative;
  left: 30px;
  z-index: 2;
  transition-delay:500ms;
}
.recruit-img::after {
  width: 596px;
  height: 177px;
  background-image: url("../img/top/txt_recruit.svg");
  position: absolute;
  bottom: -70px;
  left: 143px;
  z-index: 2;
  content:"";
}
.recruit-en {
  display: flex;
  flex-direction: column;
  width: 500px;
  position: absolute;
  top: 151px;
  left: 50%;
  margin-left: 130px;
  z-index: 12;
  font-family: var(--font-mon);
  font-size: 48px;
  line-height: 1;
  letter-spacing: 0.1em;
  font-weight: 200;
  color: #fff;
}
.recruit-en span {
  display: block;
  width: fit-content;
  padding: 20px 24px;
  position: relative;
  z-index: 2;
  opacity: 1;
}
.recruit-en span::before {
  display: block;
  width: 0;
  height: 100%;
  background-color: #310700;
  position: absolute;
  top: 0;
  left: 0;
  z-index: -1;
  content:"";
  transition : all 500ms 300ms ease-out;
}
.recruit-en span.effect-on::before {
  width: 100%;
}
.recruit-en span:nth-of-type(2)::before {
  transition-delay:500ms;
}
.recruit-en span:nth-of-type(3)::before {
  transition-delay:700ms;
}

.recruit-read {
  font-size: 60px;
  line-height: 1.4;
  letter-spacing: 0.1em;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-decoration-thickness: 2px;
  position: absolute;
  top: 220px;
  left: 50%;
  margin-left: -595px;
  z-index: 3;
}

/*---------------------------------------------------------------------------------
CONCEPT
--------------------------------------------------------------------------------- */
.concept {
  display: flex;
  justify-content: center;
  align-items: flex-end;
  align-content: flex-end;
  flex-wrap: wrap;
  padding-bottom: 396px;
  margin-bottom: 155px;
  position: relative;
  z-index: 2;
  overflow:hidden;
}
.concept::before {
  display: block;
  width: 1px;
  height: 100vw;
  background-color: #404040;
  position: absolute;
  bottom: 0;
  left: 50%;
  margin-left: -108px;
  transform-origin: right bottom;
  transform: rotate(-45deg);
  content:"";
  z-index: -1;
}
.concept::after {
  display: block;
  width: 200px;
  height: 244px;
  background-color: #fff;
  position: absolute;
  bottom: 332px;
  left: 50%;
  margin-left: -512px;
  z-index: 1;
  content:"";
}
.concept-ttl {
  width: 76px;
  font-family: var(--font-en);
  font-size: 72px;
  line-height: 1;
  letter-spacing: 0.2em;
  writing-mode: vertical-rl;
  white-space: nowrap;
  position: absolute;
  top: 276px;
  left: 50%;
  margin-left: -700px;
  z-index: 3;
}

.concept-inner {
  width: 50%;
  margin-right: 96px;
  position: relative;
  z-index: 2;
}
.concept-inner__ttl {
  width: 535px;
  margin-left: auto;
  margin-bottom: 70px;
  font-size: 48px;
  line-height: 1.5;
  font-weight: 700;
  text-decoration: underline;
  text-decoration-skip-ink: none;
  text-decoration-thickness: 2px;
}
.concept-inner__txt {
  width: 452px;
  padding-right: 98px;
  margin-left: auto;
  line-height: 1.875;
}
.concept-photo01 {
  width: calc(50% - 96px);
  height: 530px;
  margin-bottom: 32px;
}
.concept-photo02 {
  width: 460px;
  position: absolute;
  top: 440px;
  right: 50%;
  margin-right: -406px;
  z-index: 3;
}

