/* HOMEヘッダー */
.logo img {
  filter: none;
}

.topLink li {
  border: 1px solid #fff;
}

.topLink li a {
  color: #fff;
}

.topLink img {
  filter: none;
}





/* FVメイン */
#fvContainer {
  width: 100%;
  height: 100vh;
  position: relative;
  overflow: hidden;
  /* background: url(../img/main.jpg) center center / cover no-repeat; */
}
/* FIX背景 */
#fvContainer::after {
  content: "";
  width: 100%;
  height: 100vh;
  position: absolute;
  top: 0;
  left: 0;
  background: url(../img/main.jpg) center center / cover no-repeat;
  z-index: -1;
  animation: topAni3 2.6s 2.5s both;
}
@keyframes topAni3 {
  0% {width: 120%; filter: blur(10px);}
  100% {width: 100%; filter: blur(0);}
}
/* FIXテキスト */
#fvContainer::before {
  content: "";
  width: 100%;
  height: 100vh;
  background: #000;
  position: fixed;
  top: 0;
  left: 0;
  z-index: 6;
  animation: topAni1 0.6s 2.5s both;
}
@keyframes topAni1 {
  0% {transform: translateX(0%);}
  100% {transform: translateX(100%);}
}

.fixText {
  font-size: 24px;
  letter-spacing: 4px;
  -ms-writing-mode: tb-rl;
  writing-mode: vertical-rl;
  color: #fff;
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  z-index: 7;
  animation: topAni2 0.6s 2.5s both;
  white-space: nowrap;
}
@keyframes topAni2 {
  0% {filter: blur(0px); opacity: 1; visibility: visible;}
  100% {filter: blur(6px); opacity: 0; visibility: hidden;}
}

.fvTitle {
  width: 90%;
  max-width: 1300px;
  margin: 0 auto;
  position: absolute;
  top: 50%;
  left: 0;
  right: 0;
  /* transform: translate(0, -50%); */
  animation: topAni4 2.6s 2.5s both;
}

@keyframes topAni4 {
  0% {transform: translate(105px, -50%); opacity: 0;}
  100% {transform: translate(0px, -50%); opacity: 1;}
}

.fvTitle h1 {
  font-size: 128.8px;
  line-height: 1;
}

.fvTitle p {
  font-size: 31px;
  line-height: 1.7;
  letter-spacing: 5.8px;
}




/* トピックス */
#topicsContainer {
  width: 90%;
  max-width: 960px;
  margin: 100px auto 0;
}

.topic {
  width: 100%;
  margin: 30px 0;
}

.topic a {
  width: 100%;
}

.topic img {
  width: 100%;
  vertical-align: bottom;
}





/* コンセプト */
#conceptContainer {
  width: 100%;
  margin: 120px 0 120px;
}

.titleContainer {
  width: 90%;
  max-width: 960px;
  margin: 120px auto 0;
}
#conceptContainer .titleContainer {
  width: 44%;
  max-width: none;
  margin: 120px 3% 0;
}
#conceptContainer h2 {
  width: 422px;
  margin: 0 auto;
}

h2 {
  font-size: 70px;
  color: #B8B47C;
  letter-spacing: 5px;
}

.concept {
  width: 100%;
  margin: 30px 0 150px;
  display: flex;
}

.conceptText {
  flex: 0 0 44%;
  margin: 0 3%;
}

.subTitle {
  line-height: 1.5;
  font-size: 30px;
  letter-spacing: 3px;
}
.concept .subTitle {
  width: 422px;
  margin: 0 auto;
}

.conceptText p {
  width: 422px;
  margin: 40px auto 0;
}

.conceptImg {
  flex: 0 0 50%;
}

.conceptImg img {
  width: 100%;
  vertical-align: bottom;
}

.concept:nth-of-type(odd) .conceptText {
  order: 1;
}

.btn1 {
  width: 422px;
  height: 78px;
  line-height: 76px;
  margin: 20px auto;
  padding: 0 30px;
  border: 1px solid #000;
  box-sizing: border-box;
  font-size: 28px;
  letter-spacing: 3px;
  position: relative;
  overflow: hidden;
}
.btn1:first-of-type {
  margin-top: 50px;
}
.btn1::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #000;
  position: absolute;
  top: 0;
  left: -100%;
  transition: 0.3s;
}
.btn1:hover::before {
  left: 0;
}

.btn1 a {
  display: flex;
  align-items: center;
  position: relative;
  z-index: 1;
  transition: 0.3s;
}
.btn1:hover a {
  color: #fff;
}
.btn1 a::after {
  content: "";
  width: 14.2px;
  height: 4px;
  border-bottom: 1px solid #000;
  border-right: 1px solid #000;
  transform: skewX(45deg);
  position: absolute;
  top: 45%;
  right: 0px;
  transition: 0.3s;
}
.btn1:hover a::after {
  right: -10px;
  border-bottom: 1px solid #fff;
  border-right: 1px solid #fff;
}

.btn1 span {
  font-size: 18px;
  letter-spacing: 1px;
  margin-left: 15px;
}







/* メニュー */
#menuContainer {
  width: 100%;
  background: #000;
  color: #fff;
  padding: 110px 0 130px;
  text-align: center;
}

#menuContainer .titleContainer {
  margin-top: 0;
}

.menuContents {
  width: 90%;
  max-width: 960px;
  margin: 40px auto 50px;
  display: flex;
  justify-content: center;
  flex-wrap: wrap;
}

.menu {
  flex: 0 0 296px;
  height: 296px;
  margin-right: 36px;
  border: 2px solid #fff;
  box-sizing: border-box;
  border-radius: 50%;
  position: relative;
}

.menu:last-of-type {
  margin-right: 0;
}

.menu dl {
  width: 251.7px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

.menu dt span {
  display: block;
  font-size: 12px;
  margin-bottom: 5px;
}

.menu dt {
  font-size: 20px;
  line-height: 1;
}

.menu dd:first-of-type {
  height: 62.3px;
  margin: 22px 0;
  padding: 10px 0 10px;
  border-top: 1px solid #424242;
  border-bottom: 1px solid #424242;
  font-size: 24px;
  color: #B8B47C;
  line-height: 1.3;
  letter-spacing: 1px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.menu dd:last-of-type {
  font-size: 33px;
  line-height: 1;
  letter-spacing: 3px;
}

.more {
  width: 367.6px;
  height: 77.7px;
  line-height: 77.7px;
  margin: 50px auto 0;
  border: 1px solid #fff;
  text-align: center;
  position: relative;
  overflow: hidden;
}
.more::before {
  content: "";
  width: 100%;
  height: 100%;
  background: #fff;
  position: absolute;
  top: 0;
  left: -100%;
  transition: 0.3s;
}
.more:hover::before {
  left: 0;
}
.more:hover a {
  color: #000;
}

.more a {
  display: block;
  font-size: 18px;
  color: #fff;
  letter-spacing: 2px;
  transition: 0.3s;
  position: relative;
  z-index: 1;
}
.more a::after {
  content: "";
  width: 14.2px;
  height: 4px;
  border-bottom: 1px solid #fff;
  border-right: 2px solid #fff;
  transform: skewX(45deg);
  position: absolute;
  top: 45%;
  right: 20px;
  transition: 0.3s;
}
.more:hover a::after {
  right: 15px;
  border-bottom: 1px solid #000;
  border-right: 2px solid #000;
}





/* ビューティーケア */
#careContainer {
  width: 100%;
  padding: 150px 0 150px;
  position: relative;
  overflow: hidden;
}

#careContainer > img {
  width: 82.3%;
  position: absolute;
  top: -170px;
  right: -5%;
  z-index: -1;
}

.subTitle {
  margin-top: 36px;
}


.careContents {
  width: 100%;
  max-width: 1400px;
  margin: 0 auto;
}

.care {
  width: calc(50% + 480px);
  padding: 60px 0;
  border-bottom: 1px solid #B5B5B6;
  display: flex;
}
.care:first-of-type {
  margin-top: 30px;
}
.care:last-of-type {
  border-bottom: none;
}

.careImg {
  flex: 0 1 710px;
  height: 477.7px;
  background: url(../img/care1.jpg) center center / cover no-repeat;
}
.care:nth-of-type(2) .careImg {
  background: url(../img/care2.jpg) center center / cover no-repeat;
}
.care:nth-of-type(3) .careImg {
  background: url(../img/care3.jpg) center center / cover no-repeat;
}

.careText {
  flex: 0 0 398px;
  height: 477.7px;
  margin-left: 60px;
  position: relative;
}

h3 {
  font-size: 60px;
  color: #B8B47C;
  line-height: 1.2;
  position: absolute;
  bottom: -13px;
  left: 0;
}

.careText dt {
  font-size: 20px;
  margin-top: 20px;
}

.careText dd:first-of-type {
  font-size: 26px;
}

.careText dd:last-of-type {
  margin-top: 20px;
}

.moreContainer {
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
}

#careContainer .more {
  border: 1px solid #000;
  margin-right: 0;
}
#careContainer .more::before {
  background: #000;
}

#careContainer .more a {
  color: #000;
}
#careContainer .more:hover a {
  color: #fff;
}
#careContainer .more a::after {
  border-bottom: 1px solid #000;
  border-right: 2px solid #000;
}
#careContainer .more:hover a::after {
  border-bottom: 1px solid #fff;
  border-right: 2px solid #fff;
}





/* スタッフ */
#staffContainer {
  width: 100%;
  background: #000;
  color: #fff;
  padding: 100px 0 130px;
  border-bottom: 1px solid #424242;
}

#staffContainer .titleContainer {
  margin-top: 0;
}

.staffContents {
  width: 90%;
  max-width: 960px;
  margin: 80px auto 0;
  display: flex;
  justify-content: space-between;
}

.staff {
  flex: 0 1 47%;
}

.staffImg {
  width: 100%;
  height: 430px;
  background: url(../img/staff1.jpg) center center / cover no-repeat;
}
.staff:nth-of-type(2) .staffImg {
  background: url(../img/staff2.jpg) center center / cover no-repeat;
}

.staffText {
  margin-top: 25px;
}

.staffText dt {
  font-size: 26.7px;
}

.staffText dd:first-of-type {
  font-size: 33.4px;
  color: #B8B47C;
  line-height: 1.2;
  letter-spacing: 0.5px;
}

.staffText dd:last-of-type {
  font-size: 20px;
}

#staffContainer .more {
  margin-top: 80px;
  margin-right: 0;
}





/* リンク */
#linkContainer {
  width: 100%;
  padding: 130px 0;
  background: #000;
}

.linkContents {
  width: 90%;
  max-width: 960px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
}

.link {
  width: 461.6px;
  height: 171.2px;
  border: 2px solid #B8B47C;
  position: relative;
  text-align: center;
  transition: 0.6s;
}
.link:hover {
  background: #B8B47C;
}
.link:hover dl {
  color: #000;
}

.link a {
  display: block;
  width: 100%;
  height: 100%;
}

.link dl {
  width: 100%;
  color: #B8B47C;
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  transition: 0.6s;
}

.link dt {
  font-size: 30px;
  line-height: 1.3;
  letter-spacing: 3px;
}