@charset "utf-8";
/*--------------------------------------------------------------------------------
  ページタイトル
--------------------------------------------------------------------------------*/
.l-pgttl-beauty .l-pgttl_jp {
  overflow: visible;
}
.l-pgttl-beauty .l-pgttl_jp .en {
  font-family: var(--ff-en);
  font-size: 1.1em;
}
.l-pgttl-beauty .l-pgttl_en .min {
  margin-right: 0.5em;
}

/*--------------------------------------------------------------------------------
  hair menu
--------------------------------------------------------------------------------*/
.hair-info {
  max-width: var(--base-width);
  text-align: left;
  padding: var(--space-m) var(--side-space);
}
@media print, screen and (min-width:761px) {
  .hair-info {
    display: inline-block;
    margin-left: auto;
    margin-right: auto;
  }
}

/* 割引システム
----------------------------------------*/
.hair-dsystem {
  padding-top: var(--space-m);
  padding-left: var(--side-space);
  padding-right: var(--side-space);
  border-top: 1px solid rgba(var(--black-rgba),0.15);
}
.hair-dsystem .hdline {
  font-size: 1.7em;
  font-weight: inherit;
}
.dsystem_items {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-top: var(--space-s);
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  grid-column-gap: 1em;
  grid-row-gap: 1em;
}
.dsystem_item {
  background: #FFF;
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  padding: var(--space-s) 0;
}
.dsystem_item dt {
  font-size: 1.15em;
  flex-grow: 1;
  display: flex;
  align-items: center;
  align-self: center;
  padding-bottom: 1em;
}
.dsystem_item dd {
  font-family: var(--ff-en);
  color: var(--brown);
  font-weight: 500;
  line-height: 1;
  font-size: clamp(1.6em, 3vw + 0.25em, 2.6em);
  margin-top: auto;
}
.dsystem_item dd .no {
  font-size: 160%;
  display: inline-block;
  margin-right: 0.25rem;
}
.dsystem_item dd .next {
  font-family: var(--ff-min);
  writing-mode: vertical-rl;
  font-size: 50%;
  display: inline-block;
  margin-right: 0.5rem;
  vertical-align: center;
}
@media print, screen and (max-width:760px) {
  .dsystem_items {
    max-width: var(--sp-max-width);
    grid-template-columns: repeat(2, 1fr);
  }
  .dsystem_item dd {
    font-size: clamp(1.6em, 4vw + 0.5em, 2.2em);
  }
}

/* メニュー
----------------------------------------*/
.sec-hair-menu {
  padding: var(--space-l) var(--side-space) var(--space-max) var(--side-space);
}
.hair-menu {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  grid-column-gap: var(--space-m);
  grid-row-gap: var(--space-m);
  text-align: left;
}
.hair-menu_item {
  line-height: 1.6;
  border-top: 1px solid rgba(var(--black-rgba), 0.7);
}
.hair-menu_item .hdline {
  font-weight: 500;
  font-size: clamp(1.4em, 1.68vw + 0.75em, 1.5em);
  padding-top: 1.5em;
  padding-bottom: 0.75em;
  display: grid;
  grid-template-columns: 1fr auto;
}
.hair-menu_item .hdline small {
  padding-left: 2em;
  font-size: 0.55em;
  padding-bottom: 0.25em;
  align-self: flex-end;
}
.hair-menu_item .menu {
  display: grid;
  grid-template-columns: 1fr auto;
}
.hair-menu_item .menu dt,
.hair-menu_item .menu dd {
  padding-bottom: 0.25em;
}
.hair-menu_item .menu dt {
  padding-top: 0.5em;
  padding-right: 2em;
}
.hair-menu_item .menu dd {
  padding-top: 0.25em;
  text-align: right;
  font-size: 1.1em;
}
.hair-menu_item .menu dd small {
  font-size: 0.7em;
}
.hair-menu_item .menu dd small:last-of-type {
  min-width: 7.5em;
  display: inline-block;
}
@media print, screen and (max-width:760px) {
  .hair-menu {
    max-width: var(--sp-max-width);
    grid-template-columns: 1fr;
    grid-row-gap: var(--space-l);
  }
}

.sec-hair-menu .sec-hair-menu-precautions {
  line-height: 1.6;
  display: flex;
  flex-direction: column;
  padding:0 0 var(--space-s) 0;
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
}

.sec-hair-menu .sec-hair-menu-precautions .br-sp{
  display:none;
}

@media print, screen and (max-width:760px) {
  .sec-hair-menu .sec-hair-menu-precautions .br-sp{
    display:block;
  }
}

/* gallery
----------------------------------------*/
.hair-gallery {
  padding-bottom: var(--space-l);
  overflow: hidden;
}
.hair-gallery .photos {
  position: relative;
  display: flex;
  overflow: hidden;
}
.hair-gallery .photos ul {
  list-style: none;
  display: flex;
  flex-flow: row nowrap;
}
.hair-gallery .photos li img {
  width: 100%;
  height: auto;
}
.hair-gallery .photos ul:first-child {
  backface-visibility: hidden;
  will-change: transform;
}
@media print,screen and (min-width:761px) {
  .hair-gallery .photos li {
    width: clamp(200px, (100vw / 6), 300px);
  }
  .hair-gallery .photos ul:first-child {
    animation: loop1 180s -90s linear infinite;
  }
  .hair-gallery .photos ul + ul {
    animation: loop2 180s linear infinite;
  }
}
@media screen and (max-width:760px) {
  .hair-gallery .photos li {
    width: clamp(100px, (100vw / 4), 300px);
  }
  .hair-gallery .photos ul:first-child {
    animation: loop1 120s -60s linear infinite;
  }
  .hair-gallery .photos ul + ul {
    animation: loop2 120s linear infinite;
  }
}
@keyframes loop1 {
  0% { transform:translateX(100%); }
  100% { transform:translateX(-100%); }
}
@keyframes loop2 {
  0% { transform:translateX(0); }
  100% { transform:translateX(-200%); }
}

/*--------------------------------------------------------------------------------
  脱毛 menu
--------------------------------------------------------------------------------*/
.sec-beauty {
  padding: 0 var(--side-space) var(--space-max) var(--side-space);
}

/* nav
----------------------------------------*/
.beauty-menu-nav {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  padding-top: var(--space-m);
}
.beauty-menu-nav ul {
  list-style: none;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
.beauty-menu-nav li {
  line-height: 1.6;
  font-family: var(--ff-en);
  font-weight: 500;
  font-size: clamp(0.8em, 3vw + 0.5em, 1.6em);
}
.beauty-menu-nav li a {
  display: block;
}
.beauty-menu-nav li .txt {
  background-color: #FFF;
  display: block;
  padding: var(--space-2s) 0 var(--space-s) 0;
  position: relative;
  transition: color 0.15s ease-in-out, background 0.2s ease-in-out;
}
.beauty-menu-nav li:not(:first-of-type) .txt {
  border-left: 1px solid rgba(var(--black-rgba),0.1);
}
.beauty-menu-nav a,
.beauty-menu-nav a:visited,
.beauty-menu-nav a:hover {
  color: inherit;
}
.beauty-menu-nav li .txt:before {
  content: "";
  line-height: 0;
  display: inline-block;
  position: absolute;
  left: 50%;
  bottom: calc(var(--space-2s) + 0.4em);
  width: 0.4em;
  height: 0.4em;
  border-bottom: 1px solid var(--brown);
  border-left: 1px solid var(--brown);
  transform: rotate(-45deg) translateX(-50%);
  transition: bottom 0.6s var(--cubic-bezier);
}
@media print, screen and (max-width:760px) {
  .beauty-menu-nav li {
    font-size: clamp(0.8em, 3vw + 0.25em, 1.6em);
  }
}
@media (hover: hover) {
  .beauty-menu-nav li a:hover .txt {
    background-color: var(--b-beige2);
  }
  .beauty-menu-nav li:not(:first-of-type) a:hover .txt {
    border-left-color: var(--b-beige2);
  }
  .beauty-menu-nav li:hover + li .txt {
    border-left-color: #FFF;
  }
  .beauty-menu-nav li a:hover .txt:before {
    bottom: calc(var(--space-2s) + 0.2em);
  }
}

/* メニュー
----------------------------------------*/
.beauty-menu-container {
  max-width: 1200px;
  margin-left: auto;
  margin-right: auto;
  text-align: left;
  padding-top: var(--space-m);
}
.beauty-info {
  padding-top: var(--space-s);
}
.beauty-menu {
  padding-top: var(--space-s);
  display: grid;
  grid-template-columns: 1fr;
  grid-row-gap: var(--space-m);
}
.beauty-menu:not(:last-of-type) {
  padding-bottom: var(--space-l);
}
.beauty-menu_item {
  overflow-x: hidden;
  line-height: 1.6;
}
.beauty-menu_item .hdline {
  border-top: 1px solid rgba(var(--black-rgba), 0.7);
  font-weight: 500;
  font-size: clamp(1.4em, 1.68vw + 0.75em, 1.6em);
  padding-top: 1.5em;
  padding-bottom: 1.5em;
  display: grid;
  grid-template-columns: auto 1fr;
}
.beauty-menu_item .hdline small {
  padding-left: 2em;
  font-size: 0.55em;
  padding-bottom: 0.25em;
  align-self: flex-end;
}
@media print, screen and (max-width:760px) {
  .beauty-menu {
    grid-row-gap: var(--space-l);
  }
}
.sec-beauty .rsb-btn {
  padding-top: var(--space-m);
}
.sec-beauty .rsb-btn .p-btn {
  width: 360px;
  font-size: 1.1em;
}
@media print, screen and (max-width:760px) {
  .sec-beauty .rsb-btn {
    padding-top: var(--space-l);
  }
}
@media print, screen and (max-width:480px) {
  .sec-beauty .rsb-btn .p-btn {
    width: 100%;
  }
}

/* 対象パーツ */
.beauty-menu_item .parts {
  font-size: 0.9em;
  list-style: none;
  transform: translateY(-0.75em);
  padding-bottom: 2em;
  display: inline-flex;
  flex-wrap: wrap;
  gap: 0.5em;
}
.beauty-menu_item .parts li {
  position: relative;
}
.beauty-menu_item .parts li:not(:last-of-type) {
  padding-right: 1.5em;
}
.beauty-menu_item .parts li:not(:last-of-type):before {
  content: "/";
  width: 1em;
  position: absolute;
  right: -0.25em;
  top: 0;
}
@media print, screen and (max-width:760px) {
  .beauty-menu_item .parts {
    font-size: 0.8em;
  }
}

/* table */
.beauty-menuTbl-scr {
  overflow-x: auto;
}
.beauty-menuTbl {
  width: 100%;
  border-collapse: separate;
  border: 0;
}
.beauty-menuTbl-scr .beauty-menuTbl thead th:first-of-type,
.beauty-menuTbl-scr .beauty-menuTbl tbody th {
  position: sticky;
  left: 0;
  z-index: 2;
}
.beauty-menuTbl th,
.beauty-menuTbl td {
  line-height: 1.4;
  padding: 1.25em 1em;
  vertical-align: middle;
}
.beauty-menuTbl thead th {
  padding: 1em;
  text-align: center;
  font-weight: 500;
  background-color: var(--b-beige2);
}
.beauty-menuTbl tbody tr:nth-child(odd) th,
.beauty-menuTbl tbody tr:nth-child(odd) td {
  background-color: #FFF;
}
.beauty-menuTbl tbody tr:nth-child(even) th,
.beauty-menuTbl tbody tr:nth-child(even) td {
  background: url("../../image/bg_white.gif") repeat center top;
  background-size: var(--bgsize);
}
.beauty-menuTbl tbody th {
  white-space: nowrap;
  text-align: center;
  font-weight: 500;
  font-size: 1.2em;
}
.beauty-menuTbl tbody th small {
  font-weight: normal;
  font-size: 0.7em;
}
.beauty-menuTbl tbody td {
  white-space: nowrap;
  text-align: center;
  font-size: 1.1em;
}
.beauty-menuTbl tbody td small {
  font-size: 0.7em;
}
@media print, screen and (max-width:760px) {
  .beauty-menuTbl {
    font-size: 0.9em;
  }
}
@media print, screen and (max-width:640px) {
  .beauty-menuTbl th,
  .beauty-menuTbl td {
    padding: 1em 0.75em;
  }
}
