/*@import "https://use.fontawesome.com/releases/v5.13.0/css/all.css";*/

/*@import "https://fonts.googleapis.com/css2?family=Roboto:wght@700&display=swap";*/

/**,*/
/**:before,*/
/**:after {*/
/*  -webkit-box-sizing: inherit;*/
/*  box-sizing: inherit;*/
/*}*/

html {
  scroll-behavior: smooth;
}

body {
  margin: 0;
  /*font-family: Helvetica;*/
  font-family:serif;
}

a {
  text-decoration: none;
}

h3 {
  margin: 0;
}

ul {
  margin: 0;
  padding: 0;
}

li {
  list-style: none;
}

.header-logo-link{
    font-family: Helvetica;
}

.SP {
  display: none;
}

.display-flex {
  display: flex;
}

.menu {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100vw;
  z-index: 9999;
  display: none;
}

.menu-active {
  display: flex;
}

.menu-left {
  width: 50%;
  height: 100vh;
  background: url("../images/mens.jpg") no-repeat;
  background-size: auto 100%;
}

.menu-right {
  width: 50%;
  height: 100vh;
  background-color: black;
  opacity: 0.8;
  display: flex;
  align-items: center;
  position: relative;
}

.menu-close {
  position: absolute;
  right: 30px;
  top: 30px;
  color: white;
  font-size: 2em;
  cursor: pointer;
}

.menu-right ul {
  margin-left: 100px;
}

.menu-right li {
  margin-bottom: 20px;
}

.menu-right li a {
  color: white;
  font-weight: bold;
  font-size: 1.2em;
}

.menu-right li span {
  font-size: 1.2em;
  color: white;
  margin: 0 20px;
}

.top-image {
  position: relative;
  height:600px;
}

.top-image-left {
  background-color: #000;
  width: 30%;
}

.top-image-container {
  display: flex;
  position: relative;
}

/*.top-image-bg {*/
/*  width: 70%;*/
/*  background-image: url("../images/top-image.jpg");*/
/*  background-position: center;*/
/*  background-size: cover;*/
/*  background-repeat: no-repeat;*/
/*  height: 700px;*/
/*}*/

/*
.mask {
  background-color: black;
  height: 100%;
  width: 100%;
  opacity: 0.5;
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
}
*/

.top-content {
  /* padding: 50px 20px 0 20px; */
  color: white;
  position: absolute;
  top: 20%;
  left: 5%;
  z-index: 2;
}

.top-content h1 {
  font-size: 84px;
  margin: 0;
}

.vertical {
  writing-mode: vertical-rl;
}

.vertical p {
  margin: 0;
}

.vertical span {
  font-size: 8px;
  letter-spacing: 2px;
}

.top-main-content {
  line-height: 2;
  margin-left: 40px;
}

.top-main-content p {
  margin: 0;
}

.choise {
  display: flex;
}

.choise-left {
  width: 50%;
  background-color: white;
}

.choise-left-content {
  margin: 140px 100px;
}

.choise-left-content h3 {
  font-size: 2.5em;
  letter-spacing: 2px;
}

.choise-left-content p {
  margin: 20px 0 40px 0;
}

.choise-left-content img.PC {
  width: 300px;
}

.choise-right {
  width: 50%;
  background-color: black;
  display: flex;
  align-items: center;
}

.choise-right-content {
  background-color: white;
  box-shadow: 0 0 8px gray;
  position: relative;
  right: 200px;
}

.choise-list-item {
  display: flex;
  border-bottom: gray 2px solid;
  position: relative;
}

.choise-list-num {
  width: 10%;
  background-color: black;
  color: white;
  display: flex;
  align-items: center;
  justify-content: center;
}

.choise-list-content {
  width: 80%;
  padding: 60px 0 60px 30px;
}

.choise-list-content h4 {
  font-weight: normal;
  font-size: 1.1em;
  margin: 0;
}

.choise-list-content p {
  font-size: 0.8em;
  line-height: 25px;
}

.price {
  width: 100%;
  /* 一時的に非表示  */
  display: none;
}

.price-top {
  height: 300px;
  width: 100%;
  background: url("../images/price-back.jpeg") no-repeat center center;
  position: relative;
}

.price-top div {
  background-color: black;
  opacity: 0.5;
  width: 100%;
  height: 100%;
}

.price-top h3 {
  font-size: 2.3em;
  letter-spacing: 3px;
  line-height: 30px;
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  margin: auto;
  text-align: center;
  color: white;
}

.price-top h3 span {
  font-size: 0.4em;
}

.price-bottom {
  display: flex;
  justify-content: space-around;
  padding: 0 100px;
  background-color: rgb(236, 235, 235);
}

.price-bottom h5 {
  text-align: center;
  font-size: 1.5em;
}

.price-bottom-item {
  width: 34%;
  padding: 30px 90px 60px 90px;
  box-shadow: 0 0 8px gray;
  position: relative;
  bottom: 110px;
  background-color: white;
}

.price-bottom-content {
  display: flex;
}

.price-bottom-img {
  width: 100px;
  height: 100px;
  border-radius: 50%;
  border: gray 1px solid;
  overflow: hidden;
  margin-right: 50px;
  
}

.price-bottom-img img {
  width: 100%;
}

.top-strong-point {
  text-align: center;
  /*background: radial-gradient(#000000, #ffffff) fixed;*/
  background:#000;
  /*background-image: url(/images/rock.jpg);*/
}

.top-strong-point h1 {
  font-size: 42px;
  font-weight: 300;
  letter-spacing: 2px;
  line-height: 60px;
}

.canp{
font-size: 5rem;
position: relative;
color: #ffffff;
line-height: 1.4;
/*-webkit-box-reflect: below -10px -webkit-linear-gradient(top,rgba(0,0,0,0),rgba(0,0,0,0) 10%,rgba(0 0 0 / 24%));*/
margin: 0;
padding: 30px 0 0 0;
text-shadow:4px 2px 4px black;
}

.s1-1{
    font-size: 6rem;
}

.s1{
    /*margin-right: 200px;*/
}

.s2{
    /*margin-left: 200px;*/
}

.s3{
    font-family: sans-serif;
    font-weight: bold;
    color: black;
}

.s4{
    font-size:20px; 
    font-family: sans-serif; 
    color: black;
}

.s5{
    font-size:60px; 
    color:#ff3e3e; 
    font-family: sans-serif; 
    font-weight:bold;
}

.s6{
    font-size:40px; 
    color:#ff3e3e; color: black;
    font-size:20px; 
    font-family: sans-serif; 
    color: black;
}

.s7{
    font-size: 20px;
    font-family: sans-serif;
    color: black;
}



.btn-bk{
    background: white;
    font-size: 42px;
    margin: auto;
    width: 600px;
    padding: 30px;
    line-height: 60px;
    box-shadow: 8px 8px 10px #404040;
}

/* 背景*/
/*.btn-bk {*/
/*  padding: 30px;*/
/*  text-align: center;*/
/*  background: rgb(0 0 0 / 0%);*/
/*}*/

/*.btn,*/
/*a.btn,*/
/*button.btn {*/
/*  font-size: 1.6rem;*/
/*  font-weight: 700;*/
/*  line-height: 1.5;*/
/*  position: relative;*/
/*  display: inline-block;*/
/*  padding: 1rem 4rem;*/
/*  cursor: pointer;*/
/*  -webkit-user-select: none;*/
/*  -moz-user-select: none;*/
/*  -ms-user-select: none;*/
/*  user-select: none;*/
/*  -webkit-transition: all 0.3s;*/
/*  transition: all 0.3s;*/
/*  text-align: center;*/
/*  vertical-align: middle;*/
/*  text-decoration: none;*/
/*  letter-spacing: 0.1em;*/
/*  color: #212529;*/
/*  border-radius: 0.5rem;*/
/*}*/

/*a.btn-coupon {*/
/*  font-size: 1.8rem;*/
/*  line-height: 1.2;*/

/*  padding: 2rem 3rem;*/

/*  color: #fa4141;*/
/*  border-radius: 0;*/
/*  background: #fff;*/
/*}*/

/*a.btn-coupon i {*/
/*  font-size: 1.6rem;*/

/*  position: absolute;*/

/*  width: 1rem;*/

/*  -webkit-transition: all 1s;*/

/*  transition: all 1s;*/
/*  text-align: right;*/

/*  color: #fff;*/
/*  background: #fa4141;*/
/*}*/

/*a.btn-coupon i.fa-position-top {*/
/*  top: -1em;*/
/*  left: 1rem;*/
/*}*/

/*a.btn-coupon i.fa-position-bottom {*/
/*  right: 1rem;*/
/*  bottom: -1em;*/
/*  left: auto;*/
/*  -webkit-transform: scale(-1, 1);*/
/*  transform: scale(-1, 1);*/
/*}*/

/*a.btn-coupon span {*/
/*  font-family: "Roboto", sans-serif;*/
/*  font-size: 2.5rem;*/
/*  font-style: italic;*/
/*}*/

/*a.btn-coupon:before {*/
/*  position: absolute;*/
/*  top: -9px;*/
/*  left: -9px;*/
/*  width: calc(100% + 18px);*/
/*  height: calc(100% + 18px);*/
/*  content: "";*/
/*  border: 2px dashed #fff;*/
/*}*/

/*a.btn-coupon:hover {*/
/*  color: #fa4141;*/
/*  background: rgba(255, 255, 255, 0.9);*/
/*}*/

/*a.btn-coupon:hover i {*/
/*  width: 90%;*/
/*}*/

.top-strong-point-list {
  display: flex;
  justify-content: space-around;
  width: 90%;
  margin: 0 auto;
}

.top-strong-point-list a {
  color: #00000087;
}

.top-strong-point-list .display-flex {
  justify-content: center;
}

/*
.top-strong-point-list a,
.top-strong-menu-list p {
  padding: 3px 70px;
  margin: 1px;

}*/

.datumou{
    display: block;
    box-shadow: 0 2px 10px rgb(0 0 0 / 30%);
    background: #ffffff;
    margin: 20px;
    padding: 10px;
    width: 230px;
    height: 50px;
    line-height: 50px;
    float: left;
    font-weight: bold;
}

.cb{
  /* floatを解除 */
  clear: both;
}


.visitprice{
 height:160px;  
 margin-top: 60px;
}

.visitprice h3{
 height: 50px;
    line-height: 50px;
    font-size: 23px;
    font-weight: bold;
    color: #fff;
    text-shadow: 3px 1px 4px black;
}

h3.btn-border {
  border: 3px solid #000;
  border-radius: 0;
  background: #ffffff7a;
  width:300px;
  margin: 20px auto;
  padding: 20px;
}

.bana{
    padding:50px;
}

.bana img{
    width:760px;
}


.top-strong-point-content {
  display: flex;
  flex-direction: column;
  font-size: 24px;
}
.top-strong-point-content span {
  font-size: 26px;
}

.top-strong-point-circle {
  border-radius: 50%;
  width: 30%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  padding: 20px 0;
}

.top-strong-menu-list {
  margin:auto;
}

.btn--orange,
a.btn--orange {
  color: #fff;
  font-size: 50px;
  text-shadow: 2px 1px 4px white;
}

.btn--orange span{
}

.balloon33 {
position: relative;
display: inline-block;
padding: 0 15px;
width: 300px;
height: 300px;
line-height: 50px;
border-radius: 50%;
background-color: #ff8c00;
text-align: center;
color: #fff;
font-size: 1.5rem;
}
.balloon33::before {
content: "";
position: absolute;
border-top: 10px solid transparent;
border-bottom: 10px solid transparent;
border-left: 70px solid #ff8c00;
right: 5px;
bottom: 5px;
transform: rotate(45deg);
}

.balloon33 span{
    margin-top: 65px;
    display: block;
}
}








.system-top {
  height: 200px;
  position: relative;
  margin-top: 72px;
}

.system-top h3 {
  font-size: 2.3em;
  letter-spacing: 3px;
  /*line-height: 30px;*/
  /*position: relative;*/
  /*top: 60%;*/
  /*left: 50%;*/
  /*transform: translateY(-50%) translateX(-50%);*/
  /*-webkit-transform: translateY(-50%) translateX(-50%);*/
  /*margin: auto;*/
  text-align: center;
  line-height: 25px;
    margin: 20px 0;
}

.system-top h3 span {
  font-size: 0.4em;
}

.system-bottom {
  background-color: black;
}

.system-bottom-flex {
  display: flex;
  flex-wrap: wrap;
  margin: 0 auto;
  width: 55%;
  justify-content: space-around;
}

.system1 {
  background: url("../images/whitening.jpg") no-repeat center center;
}

.system2 {
  background: url("../images/hair-removal.jpg") no-repeat center center;
}

.system3 {
  background: url("../images/system3.jpeg") no-repeat center center;
}

.system4 {
  background: url("../images/system4.jpg") no-repeat center center;
}

.system5 {
  background: url("../images/system5.jpg") no-repeat center center;
}

.system-item {
  display: block;
  height: 150px;
  width: 49%;
  background-size: 100% auto;
  position: relative;
  margin-bottom: 10px;
  cursor: pointer;
}

.system-item div {
  background-color: black;
  opacity: 0.5;
  width: 100%;
  height: 100%;
}

.system-item:hover div {
  opacity: 0.2;
}

.system-item p {
  color: white;
  position: absolute;
  font-weight: bold;
  top: 45%;
  left: 50%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  text-align: center;
  font-size: 1em;
  line-height: 35px;
  letter-spacing: 3px;
}

.system-item span {
  color: white;
  position: absolute;
  top: 57%;
  left: 85%;
  transform: translateY(-50%) translateX(-50%);
  -webkit-transform: translateY(-50%) translateX(-50%);
  font-size: 1.4em;
  font-weight: bold;
}
/* 各施術css */

.treatment {
  width: 70%;
  margin: 50px auto;
  margin-top: 128px;
}

.treatment-title {
  text-align: center;
}

.treatment-title p {
  font-size: 14px;
  margin-bottom: 0;
  margin-top: 2rem;
  font-weight: bold;
}

.treatment-title h2 {
  display: inline-block;
  border-bottom: 2px solid #333;
  margin: 5px 0;
}

.treatment-content {
  width: 70%;
  margin: 40px auto;
}

.treatment-btn-box {
  text-align: center;
  margin: 10px 0;
}
.treatment-btn {
  padding: 10px 24px;
  background-color: black;
  width: 230px;
  color: white;
  border: none;
  cursor: pointer;
}

/* SAHARA脱毛 */

.hair-price-left {
  width: 100%;
  text-align: center;
}

.hair-price-left img {
  width: 50%;
}

.hair-price-right {
  width: 100%;
}

.hair-price {
  flex-direction: column;
}

.hair-price-img {
  display: flex;
}

.hair-price-borde {
  width: 70%;
  margin: 0 auto;
}

/* 写真が左のパターン */

.each-box-top,
.each-box-under {
  background-color: #f5f5f5;
  margin-left: 30%;
}
.bg-black {
  background-color: #000;
  position: relative;
  height: 400px;
}

.bg-black img {
  position: absolute;
  top: -30px;
  left: 0;
  width: 50%;
}

.catch-copy {
  width: 50%;
  margin-left: 30%;
  position: absolute;
  top: 70px;
  right: 50px;
  padding: 40px;
  background-color: white;
  box-shadow: 5px 5px 3px 0 rgba(0, 0, 0, 0.4);
  box-sizing: border-box;
}

.catch-copy-content {
  font-size: 12px;
  margin: 0;
  padding-bottom: 10px;
  padding-top: 10px;
  letter-spacing: 2px;
}

.catch-copy-title {
  letter-spacing: 2px;
}

.underline {
  border-bottom: 1px solid #f3f3f3;
}

.each-box-top {
  height: 70px;
  margin-top: 50px;
}

.each-box-under {
  height: 120px;
  margin-bottom: 50px;
}

/* 写真が右のパターン */

.each-box-top-sec,
.each-box-under-sec {
  background-color: #f3f3f3;
  margin-right: 30%;
}

.each-box-top-sec {
  height: 70px;
  margin-top: 50px;
}

.each-box-under-sec {
  height: 300px;
  margin-bottom: 50px;
}

.each-box-under-thi {
  height: 200px;
  margin-bottom: 50px;
}

.catch-copy-sec {
  width: 50%;
  margin: 50px 0;
  margin-right: 30%;
  position: absolute;
  top: 70px;
  left: 50px;
  padding: 40px;
  background-color: white;
  box-shadow: 5px 5px 3px 0 rgba(0, 0, 0, 0.4);
  box-sizing: border-box;
}

.bg-black-sec {
  background-color: #000;
  position: relative;
  height: 400px;
}

.catch-copy-img-sec {
  position: absolute;
  top: -30px;
  right: 0;
  width: 50%;
}

/* 価格表css */

.price-section {
  display: flex;
}

.price-title {
  text-align: center;
  margin-left: 20px;
}

.price-board,
.price-board2 {
  display: flex;
  margin-bottom: 5px;
}

.price-left {
  background-color: black;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  align-items: center;
  box-sizing: border-box;
}

.price-left p {
  color: #fff;
  width: 200px;
  font-size: 14px;
  text-align: center;
}

table,
th,
td {
  border-collapse: collapse;
  border: 1px solid #fff;
  line-height: 1.5;
}

table.price-type td {
  width: 200px;
  padding: 10px;
  vertical-align: top;
}

tr:nth-child(odd) {
  background-color: #f3f3f3;
}

tr:nth-child(even) {
  background: #d9d9d9;
}

.point {
  border-left: 8px solid #40e0d0;
}

.wide {
  border-left: 8px solid #f0e68c;
}

.vio {
  border-left: 8px solid #ffa500;
}

.standart {
  border-left: 8px solid #000;
}

.price-hair-notice {
  display: flex;
  justify-content: center;
}

.hair-cycle {
  margin-left: 20px;
}

.hair-notice {
  color: red;
}

/* 間の価格表 */
.while-price {
  text-align: center;
  margin: 128px 0;
}

.mini-price-table {
  display: flex;
  width: 50%;
  margin: 0 auto;
  margin-bottom: 5px;
  font-size: 14px;
}

.mini-price-left,
.mini-price-right {
  width: 50%;
}

.mini-price-left {
  background-color: #000;
  color: white;
}
.mini-price-right {
  background-color: #f3f3f3;
}

.while-price-left {
  width: 40%;
  margin: 32px auto;
}

.while-price-right {
  width: 60%;
  margin: 32px auto;
}

.add-while-price {
  width: 90%;
}

.mini-price-table-last {
  background-color: #f4f4f4;
  width: 90%;
  margin: 0 auto;
}

.mini-price-table-last p {
  margin: 0;
  padding: 8px;
}

.magne-price {
  width: 100%;
}

.magne-price-list {
  display: flex;
  width: 100%;
}

.magne-price-title {
  width: 90%;
  margin: 0 auto;
  background-color: #000;
  color: #fff;
  padding: 14px 0;
  border-bottom: 1px solid #fff;
}

.magne-price-title p {
  margin: 0;
}

.magne-price-cell {
  background-color: #d9d9d9;
  border-left: 1px solid #fff;
  font-size: 14px;
  padding: 10px;
  margin: 0;
  border-bottom: 1px solid #fff;
}

.magne-price-cell:nth-child(1) {
  width: 20%;
  display: flex;
  align-items: center;
  justify-content: center;
}
.magne-price-cell:nth-child(2),
.magne-price-cell:nth-child(3) {
  width: 40%;
}

.sp-treatment-title {
  display: none;
}

.price-board-third {
  text-align: center;
  margin-top: 128px;
}

.sp-price-board-third {
  display: none;
}

.price-board-third-list {
  width: 80%;
  margin: 0 auto;
}

.price-board-third-list-item {
  display: flex;
  justify-content: center;
  margin-bottom: 5px;
}

.price-board-third-list-cont {
  padding: 8px;
  text-align: center;
}

.price-board-third-list-cont:nth-child(1) {
  width: 25%;
  background-color: #000;
  color: #fff;
}

.price-board-third-list-cont:nth-child(2) {
  width: 15%;
  background-color: #dcdcdc;
  border-left: 1px solid #fff;
}

.price-board-third-list-cont:nth-child(3) {
  width: 60%;
  background-color: #dcdcdc;
  border-left: 1px solid #fff;
}

.footer-bg {
  margin-top: 124px;
  background-image: url("../images/mens.jpg");
  background-repeat: no-repeat;
  background-size: cover;
  background-position: center;
  height: 300px;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  position: relative;
}

.footer-mask {
  background-color: #000;
  opacity: 0.5;
  height: 100%;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
}

.footer-reserve,
.footer-contact {
  position: relative;
  z-index: 1;
  width: 49%;
  margin: 0 auto;
  text-align: center;
}

.footer-reserve {
  border-right: 1px solid white;
}

.footer-reserve h2,
.footer-contact h2 {
  color: white;
  font-size: 30px;
  letter-spacing: 3px;
}

.footer-button {
  display: inline-block;
  text-decoration: none;
  border: 1px solid white;
  width: 50%;
  margin: 0 auto;
  padding: 15px 48px;
  color: white;
  letter-spacing: 3px;
  margin-bottom: 30px;
  transition: color 0.25s ease;
}

.footer-button:hover {
  color: #fff;
  background-color: #000;
  border: 1px solid #000;
}

/* thanxページ */

.thanx-main {
  background-color: #f3f3f3;
  padding: 64px 0;
  height: 70vh;
  display: flex;
  flex-wrap: wrap;
  flex-direction: column;
  justify-content: center;
  align-items: center;
}

.thanx-container {
  width: 80%;
  margin: 0 auto;
  background-color: #fff;
  padding: 24px;
}

.send-success {
  border-left: 3px solid #000;
  border-bottom: 1px solid #000;
  padding: 8px;
}

.thanx-cont {
  margin-top: 64px;
}

.visitor-block {
    width: 80%;
    display: flex;
    margin: 0 auto;
}

.visitor-block div {
    width: 25%;
    display: flex;
    border: 1px solid white;
    justify-content: center;
    align-items: center;
    height: 80px;
    color: white;
    background-color: black;
}

.visitor-block.visitor-block-value div {
    color: black;
    background-color: rgb(214, 212, 212);
}

.bg-slider {
	width: 100vw;
	height: 100vh;
	background-position:center center;
	background-size: cover;
	display: flex;
	align-items: center;
	justify-content: center;
	height: 600px;
	background-size:cover;
	background-repeat:no-repeat;
}

.bg-slider__title{
	color: #fff;
	font-size: 48px;
	line-height: 1.5;
	font-weight: bold;
	text-align:center;
	text-shadow: 1px 1px 1px #000;
}

.header-logo h1{
        line-height: 0.5;
}

.header-logo-text{
    color:#fff;
    font-size:0.9rem;
}

.visi p{
    text-align:center;
    margin-top:20px;
}

.visih2{
    margin: 50px 0 0 !important;
}


/*==================================================
ふわっ
===================================*/


/* fadeUp */

.fadeUp{
animation-name:fadeUpAnime;
animation-duration:0.5s;
animation-fill-mode:forwards;
opacity:0;
}

@keyframes fadeUpAnime{
  from {
    opacity: 0;
  transform: translateY(100px);
  }

  to {
    opacity: 1;
  transform: translateY(0);
  }
}


/* スクロールをしたら出現する要素にはじめに透過0を指定　*/
 
.fadeUpTrigger{
    opacity: 0;
}