@charset "UTF-8";

/* ==========================================================================
    Top Style
============================================================================= */
html {
  font-size: 62.5%;
}

body {
  font-size: 1.4rem;
  line-height: 1.6;
  letter-spacing: 0.05em;
}

/* Wrapper =============================== */
.l-container {
  max-width: 1140px;
  margin-inline: auto;
}

@media screen and (max-width: 1139.98px) {
  .l-container {
    padding-inline: 16px;
  }
}

section {
  padding-block: 150px;
}

section section {
  padding-block: 0;
}

@media screen and (max-width: 767.98px) {
  section {
    padding-block: 100px;
  }
}

/* Main visual =============================== */
.p-mv {
  position: relative;
}

.p-mv img {
  width: 100%;
}

.p-mv__inner {
  margin-inline: auto;
  max-width: 970px;
  padding-inline: 15px;
  position: absolute;
  left: 0;
  right: 0;
  text-align: right;
  width: 100%;
}

.p-mv__copy {
  display: inline-block;
  line-height: 1.2;
  text-align: left;
}

.p-mv__copy b {
  font-size: clamp(2.8rem, 3.0714vw, 4.3rem);
  font-family: var(--font-serif);
  font-weight: normal;
  letter-spacing: 0.05em;
  /* opacity: 0; */
}

.p-mv__copy b strong {
  font-size: clamp(3.2rem, 3.4285vw, 4.8rem);
  font-weight: normal;
  letter-spacing: 0.05em;
}

.p-mv__copy.is-active b {
  -webkit-animation-name: fade-in;
  animation-name: fade-in;
  -webkit-animation-delay: 1s;
  animation-delay: 1s;
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

.p-mv__copy span {
  display: block;
  font-size: clamp(1.4rem, 1.4285vw, 2rem);
  letter-spacing: 0.15em;
  line-height: 1.5;
  -webkit-margin-before: 3.3571vw;
  margin-block-start: 3.3571vw;
  /* opacity: 0; */
}

.p-mv__copy.is-active span {
  -webkit-animation-name: slid-in-up;
  animation-name: slid-in-up;
  -webkit-animation-delay: 2s;
  animation-delay: 2s;
  -webkit-animation-duration: 2s;
  animation-duration: 2s;
  -webkit-animation-iteration-count: 1;
  animation-iteration-count: 1;
  -webkit-animation-fill-mode: forwards;
  animation-fill-mode: forwards;
}

@media (min-width: 576px) {
  .p-mv__inner {
    top: 52.75%;
    -webkit-transform: translateY(-50%);
    transform: translateY(-50%);
  }

  .p-mv__inner span {
    color: #7a5c54;
  }
}

@media (max-width: 575.98px) {
  .p-mv {
    overflow: hidden;
    top: 0;
  }

  .p-mv img {
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
    height: -webkit-fill-available;
    -webkit-transform: translateZ(0);
    transform: translateZ(0);
    -o-object-fit: cover;
    object-fit: cover;
    width: 100%;
    will-change: transform;
  }

  .p-mv::before {
    background: -webkit-gradient(linear, left top, left bottom, from(rgba(100, 55, 44, 0)), to(#64372c));
    background: -webkit-linear-gradient(top, rgba(100, 55, 44, 0) 0%, #64372c 100%);
    background: linear-gradient(180deg, rgba(100, 55, 44, 0) 0%, #64372c 100%);
    content: "";
    height: 100%;
    opacity: 0.3;
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    z-index: 1;
  }

  .p-mv__inner {
    color: #fff;
    bottom: 36vw;
    z-index: 10;
  }

  .p-mv__inner b {
    font-size: clamp(24px, 6.4vw, 3.2rem);
  }

  .p-mv__inner b strong {
    font-size: 2.7rem;
    font-size: clamp(27px, 7.2vw, 3.5rem);
  }

  .p-mv__inner span {
    font-size: clamp(1.3rem, 3.466vw, 1.6rem);
    -webkit-margin-before: 14px;
    margin-block-start: 14px;
  }
}

/* Special-menu =============================== */
.p-special-menu {
  background-color: #f6e3cc;
  padding-block: 80px;
}

.p-special-menu .c-heading {
  -webkit-margin-after: 40px;
  margin-block-end: 40px;
}

.p-special-menu .c-heading .en {
  color: #d77500;
  font-size: 4rem;
}

.p-special-menu a {
  border-radius: 10px;
  display: block;
  overflow: hidden;
}

.p-special-menu a img {
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
  vertical-align: middle;
}

.p-special-menu a:hover img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.p-special-menu__bnr {
  display: -ms-grid;
  display: grid;
  gap: 8px;
  -ms-grid-columns: (1fr)[3];
  grid-template-columns: repeat(3, 1fr);
}

/* 医療脱毛キャンペーン */
.p-special-menu .hdg-campaign {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  color: #d77500;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-margin-after: 50px;
  margin-block-end: 50px;
}

.p-special-menu .hdg-campaign b {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 2.8rem;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  letter-spacing: 0.05em;
  gap: clamp(8px, 2.1428vw, 30px);
}

.p-special-menu .hdg-campaign b::before,
.p-special-menu .hdg-campaign b::after {
  background-color: #d77500;
  content: "";
  height: 42px;
  width: 2px;
}

.p-special-menu .hdg-campaign b::before {
  -webkit-transform: rotate(-35deg);
  transform: rotate(-35deg);
}

.p-special-menu .hdg-campaign b::after {
  -webkit-transform: rotate(35deg);
  transform: rotate(35deg);
}

.p-special-menu .hdg-campaign span {
  font-size: 1.8rem;
  letter-spacing: 0.05em;
}

.p-special-menu__campaign {
  counter-reset: order;
  display: -ms-grid;
  display: grid;
  gap: 1px;
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
  -webkit-margin-after: 32px;
  margin-block-end: 32px;
}

.p-special-menu__campaign li {
  background-color: #fff;
  overflow: hidden;
  position: relative;
}

.p-special-menu__campaign li::before {
  background-color: var(--color-brown);
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  height: 8px;
  width: 100%;
  z-index: 1;
}

.p-special-menu__campaign li::after {
  background-color: var(--color-orange);
  counter-increment: order;
  content: 'Plan 0' counter(order);
  color: #fff;
  display: block;
  font-family: var(--font-en);
  font-size: 1.5rem;
  height: 1.5em;
  left: -20px;
  padding-inline: 15px;
  position: absolute;
  top: 20px;
  text-align: center;
  -webkit-transform: rotate(-45deg);
  transform: rotate(-45deg);
  width: 58px;
}

.p-special-menu__campaign li:hover {
  background-color: var(--color-beige-01);
}

.p-special-menu__campaign li .cont {
  display: -ms-grid;
  display: grid;
  padding-block: 64px 46px;
  place-content: center;
  text-align: center;
}

.p-special-menu__campaign li .cont:hover {
  opacity: 0.5;
}

.p-special-menu__campaign li .cont:hover .icon img {
  -webkit-transform: scale(1.1);
  transform: scale(1.1);
}

.p-special-menu__campaign li .cont::after {
  background: url("data:image/svg+xml,%3Csvg width='13' height='8' viewBox='0 0 13 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.3536 4.35355C12.5488 4.15829 12.5488 3.84171 12.3536 3.64645L9.17157 0.464465C8.97631 0.269203 8.65973 0.269203 8.46447 0.464465C8.2692 0.659728 8.2692 0.97631 8.46447 1.17157L11.2929 4L8.46447 6.82843C8.2692 7.02369 8.2692 7.34027 8.46447 7.53553C8.65973 7.7308 8.97631 7.7308 9.17157 7.53553L12.3536 4.35355ZM4.37114e-08 4.5L12 4.5L12 3.5L-4.37114e-08 3.5L4.37114e-08 4.5Z' fill='%2364372C'/%3E%3C/svg%3E%0A") no-repeat center/12px auto;
  content: "";
  display: block;
  margin: 28px auto 0;
  height: 12px;
  width: 12px;
}

.p-special-menu__campaign li .icon {
  -webkit-margin-after: 16px;
  margin-block-end: 16px;
  -webkit-transition: -webkit-transform 0.6s ease;
  transition: -webkit-transform 0.6s ease;
  transition: transform 0.6s ease;
  transition: transform 0.6s ease, -webkit-transform 0.6s ease;
}

.p-special-menu__campaign li .ttl {
  font-size: 1.2rem;
}

.p-special-menu__campaign li .ttl b {
  color: var(--color-orange);
  font-size: 1.8rem;
  font-weight: normal;
  -webkit-margin-end: 8px;
  margin-inline-end: 8px;
}

.p-special-menu__campaign li .price {
  font-size: 1.4rem;
}

.p-special-menu__campaign li .price b {
  color: var(--color-accent);
  font-family: var(--font-serif);
  font-size: clamp(2.8rem, 2.5714vw, 3.6rem);
  -webkit-margin-end: 4px;
  margin-inline-end: 4px;
}

.p-special-menu__sub {
  display: -ms-grid;
  display: grid;
  gap: 2.64285vw;
  -ms-grid-columns: (1fr)[2];
  grid-template-columns: repeat(2, 1fr);
}

@media screen and (min-width: 768px) {
  .p-special-menu__bnr {
    -webkit-margin-after: 100px;
    margin-block-end: 100px;
  }

  .p-special-menu__campaign li:first-child {
    border-radius: 10px 0 0 10px;
  }

  .p-special-menu__campaign li:last-child {
    border-radius: 0 10px 10px 0;
  }
}

@media screen and (max-width: 767.98px) {
  .p-special-menu__bnr {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    -webkit-margin-after: 64px;
    margin-block-end: 64px;
  }

  .p-special-menu__campaign {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
  }

  .p-special-menu__campaign li::before {
    height: 4px;
  }

  .p-special-menu__campaign li::after {
    left: -30px;
    top: 15px;
    width: 80px;
  }

  .p-special-menu__campaign li .cont {
    padding-block: 46px 34px;
  }

  .p-special-menu__campaign li .cont::after {
    -webkit-margin-before: 16px;
    margin-block-start: 16px;
  }

  .p-special-menu__sub {
    -ms-grid-columns: (1fr)[1];
    grid-template-columns: repeat(1, 1fr);
  }
}

@media (max-width: 575.98px) {
  .p-special-menu__bnr {
    -ms-grid-columns: (1fr)[1];
    grid-template-columns: repeat(1, 1fr);
  }
}

/* 選ばれる理由 =============================== */
.p-reason {
  background-color: var(--color-beige-01);
  -webkit-padding-before: 0;
  padding-block-start: 0;
}

.p-reason .c-heading__photo {
  min-height: 388px;
}

.p-reason .c-heading__photo .hdg {
  top: 40.2%;
}

.p-reason__list {
  counter-reset: num;
  position: relative;
  z-index: 20;
}

.p-reason__list>li {
  background-color: #fff;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 24px 3.21428vw;
  padding: 90px 7vw 56px;
  position: relative;
}

.p-reason__list>li+li {
  -webkit-border-before: solid 1px var(--color-border);
  border-block-start: solid 1px var(--color-border);
}

.p-reason__list .en {
  color: var(--color-accent);
  font-size: 2rem;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  letter-spacing: 0.05em;
  line-height: 1.2;
  position: absolute;
  top: 40px;
  left: 5.3571vw;
}

.p-reason__list .en::after {
  counter-increment: num;
  content: '0' counter(num);
  font-size: clamp(4.8rem, 5.1428vw, 7.2rem);
  line-height: 0.6;
}

.p-reason__list .figure img {
  border-radius: 10px;
}

.p-reason__list .lead {
  -webkit-margin-after: 16px;
  margin-block-end: 16px;
}

.p-reason__list .txt {
  -webkit-margin-after: 24px;
  margin-block-end: 24px;
}

@media screen and (min-width: 768px) {
  .p-reason__list {
    -webkit-transform: translateY(-86px);
    transform: translateY(-86px);
    -webkit-margin-after: -86px;
    margin-block-end: -86px;
  }

  .p-reason__list>li:first-child {
    border-radius: 10px 10px 0 0;
  }

  .p-reason__list>li:last-child {
    border-radius: 0 0 10px 10px;
  }

  .p-reason__list .figure {
    -ms-flex-preferred-size: 310px;
    flex-basis: 310px;
  }

  .p-reason__list .details {
    -ms-flex-preferred-size: calc(100% - 310px - 3.21428vw);
    flex-basis: calc(100% - 310px - 3.21428vw);
  }
}

@media screen and (max-width: 767.98px) {
  .p-reason .c-heading__photo {
    min-height: 212px;
  }

  .p-reason .c-heading__photo .hdg {
    top: 50%;
  }

  .p-reason__list {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 8px;
    -webkit-transform: translateY(-32px);
    transform: translateY(-32px);
    -webkit-margin-after: -32px;
    margin-block-end: -32px;
  }

  .p-reason__list>li {
    padding: 52px 30px 32px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-about {
    -webkit-padding-after: 70px;
    padding-block-end: 70px;
  }
}

/* 医師紹介 =============================== */
.p-doctor {
  -webkit-padding-after: 80px;
  padding-block-end: 80px;
}

.p-doctor .c-heading {
  -webkit-margin-after: 72px;
  margin-block-end: 72px;
}

.p-doctor__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 32px 5.1428vw;
}

.p-doctor__info .figure img {
  -webkit-margin-after: 34px;
  margin-block-end: 34px;
}

.p-doctor__info .figure figcaption {
  font-family: var(--font-serif);
  font-size: 2.8rem;
  letter-spacing: 0.05em;
  line-height: 1.4;
  text-align: center;
}

.p-doctor__info .figure figcaption span {
  display: block;
  font-family: var(--font-sans);
  font-size: 1.4rem;
  -webkit-margin-after: 7px;
  margin-block-end: 7px;
}

.p-doctor__info .sns-list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px 2.2857vw;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin: 20px 18px 0;
  max-width: 328px;
}

.p-doctor__info .sns-list a {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  font-family: var(--font-serif);
  font-size: clamp(1.6rem, 1.1428vw, 1.8rem);
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 8px;
}

.p-doctor__info .sns-list .icon {
  max-width: 28px;
}

.p-doctor__info>.details .lead {
  -webkit-margin-after: 24px;
  margin-block-end: 24px;
}

.p-doctor__info>.details .txt {
  font-size: 1.6rem;
  line-height: 1.6;
}

.p-doctor__info .ttl {
  -webkit-border-after: solid 1px var(--color-border);
  border-block-end: solid 1px var(--color-border);
  font-size: 2rem;
  -webkit-margin-after: 32px;
  margin-block-end: 32px;
  -webkit-padding-after: 12px;
  padding-block-end: 12px;
}

@media screen and (min-width: 768px) {
  .p-doctor__info+.p-doctor__info {
    -webkit-margin-before: 96px;
    margin-block-start: 96px;
  }

  .p-doctor__info>.profile {
    -ms-flex-preferred-size: 356px;
    flex-basis: 356px;
  }

  .p-doctor__info>.details {
    -ms-flex-preferred-size: calc(100% - 356px - 5.1428vw);
    flex-basis: calc(100% - 356px - 5.1428vw);
  }

  .p-doctor__info .figure {
    max-width: 328px;
  }

  .p-doctor__info .history,
  .p-doctor__info .entry {
    position: relative;
  }

  .p-doctor__info .history .c-link,
  .p-doctor__info .entry .c-link {
    position: absolute;
    right: 0;
    top: 12px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-doctor {
    padding-inline: calc(9.3333vw - 20px);
  }

  .p-doctor__info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    row-gap: 56px;
  }

  .p-doctor__info+.p-doctor__info {
    -webkit-margin-before: 56px;
    margin-block-start: 56px;
  }

  .p-doctor__info .sns-list {
    gap: 10px 8.533vw;
    margin: 24px auto 0;
    max-width: 338px;
  }

  .p-doctor__info .details .txt {
    font-size: 1.4rem;
  }

  .p-doctor__info .history .c-definition,
  .p-doctor__info .entry .c-media {
    -webkit-margin-after: 24px;
    margin-block-end: 24px;
  }
}

/* 6つの安心保証 =============================== */
.p-promise {
  background-color: var(--color-beige-01);
  border-radius: 10px;
  padding: 4.714vw 7vw 4.4285vw;
}

.p-promise__hdg {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-orient: vertical;
  -webkit-box-direction: normal;
  -ms-flex-direction: column;
  flex-direction: column;
  -webkit-margin-after: calc(-72px - 4.714vw);
  margin-block-end: calc(-72px - 4.714vw);
  -webkit-transform: translateY(calc(-72px - 4.714vw));
  transform: translateY(calc(-72px - 4.714vw));
}

.p-promise__hdg .en {
  color: var(--color-accent);
  font-size: 10rem;
  letter-spacing: 0.05em;
  line-height: 1.21;
  opacity: 0.2;
}

.p-promise__hdg em {
  background: url("data:image/svg+xml,%3Csvg width='420' height='14' viewBox='0 0 420 14' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.5 0.863281L199.322 0.863281L210.368 12.8633L222.15 0.863281L419.5 0.863281' stroke='%23DCD1CE'/%3E%3C/svg%3E") no-repeat center bottom/420px auto;
  font-size: 2.2rem;
  letter-spacing: 0.05em;
  line-height: 1.6;
  -webkit-margin-after: 35px;
  margin-block-end: 35px;
  -webkit-padding-after: 47px;
  padding-block-end: 47px;
}

.p-promise__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  gap: 10px;
  -webkit-box-pack: center;
  -ms-flex-pack: center;
  justify-content: center;
  margin-inline: auto;
  max-width: 800px;
}

.p-promise__list>li {
  -ms-flex-preferred-size: calc(50% - 5px);
  flex-basis: calc(50% - 5px);
}

.p-promise__txt {
  display: inline-block;
  font-size: clamp(1.8rem, 2.1428vw, 3rem);
  line-height: 1;
  padding-inline: 42px;
  position: relative;
}

.p-promise__txt b {
  color: var(--color-accent);
  display: inline-block;
  font-family: var(--font-serif);
  font-size: clamp(5.6rem, 6.5714vw, 9.2rem);
  line-height: 1.195;
  margin-inline: 14px 12px;
}

.p-promise__txt::before,
.p-promise__txt::after {
  background-color: var(--color-brown);
  content: "";
  position: absolute;
  bottom: 0;
  height: 40px;
  width: 2px;
}

.p-promise__txt::before {
  -webkit-transform: rotate(-35deg);
  transform: rotate(-35deg);
  left: 0;
}

.p-promise__txt::after {
  -webkit-transform: rotate(35deg);
  transform: rotate(35deg);
  right: 0;
}

@media screen and (min-width: 768px) {
  .p-promise {
    -webkit-margin-before: 100px;
    margin-block-start: 100px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-promise {
    -webkit-padding-before: 48px;
    padding-block-start: 48px;
  }

  .p-promise__hdg {
    -webkit-box-align: baseline;
    -ms-flex-align: baseline;
    align-items: baseline;
    -webkit-margin-after: calc(-34px - 48px);
    margin-block-end: calc(-34px - 48px);
    -webkit-transform: translateY(calc(-34px - 48px));
    transform: translateY(calc(-34px - 48px));
  }

  .p-promise__hdg .en {
    font-size: 5rem;
  }

  .p-promise__hdg em {
    display: block;
    font-size: 2.4rem;
    font-weight: bold;
    margin: 20px auto 24px;
    -webkit-padding-after: 36px;
    padding-block-end: 36px;
    text-align: center;
  }

  .p-promise__list {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    gap: 0;
  }

  .p-promise__txt {
    padding-inline: 25px;
  }

  .p-promise__txt::before,
  .p-promise__txt::after {
    bottom: 7px;
    height: 24px;
    width: 1px;
  }
}

/* 施術メニュー =============================== */
.p-menu {
  padding-block: 0 60px;
}

.p-menu .c-heading__photo {
  min-height: 327px;
}

.p-menu .c-heading__photo .hdg .en {
  display: block;
  font-size: 6.4rem;
  font-weight: bold;
  letter-spacing: 0.05em;
}

.p-menu .c-heading__photo .hdg em {
  font-size: 1.8rem;
}

.p-menu__cont {
  -webkit-padding-before: 56px;
  padding-block-start: 56px;
}

.p-menu__cont .item {
  background-color: #fff;
  border: solid 1px var(--color-border);
  -webkit-border-after: 0;
  border-block-end: 0;
}

.p-menu__cont .item:first-child {
  -webkit-border-after: solid 1px var(--color-border);
  border-block-end: solid 1px var(--color-border);
  border-radius: 10px;
  -webkit-margin-after: 16px;
  margin-block-end: 16px;
}

.p-menu__cont .item:nth-child(2) {
  border-radius: 10px 10px 0 0;
}

.p-menu__cont .item:last-child {
  -webkit-border-after: solid 1px var(--color-border);
  border-block-end: solid 1px var(--color-border);
  border-radius: 0 0 10px 10px;
}

.p-menu__cont .item .ttl {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  cursor: pointer;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 2rem;
  gap: 24px;
  letter-spacing: 0.05em;
  padding: 32px 0 32px 4.5714vw;
}

.p-menu__cont .item .ttl::after {
  -webkit-border-start: solid 1px var(--color-border);
  border-inline-start: solid 1px var(--color-border);
  padding: 12px 0;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  text-align: center;
  width: 98px;
}

.p-menu__cont .item .ttl:hover {
  opacity: 0.5;
}

.p-menu__cont .item a.ttl::after {
  background: url("data:image/svg+xml,%3Csvg width='13' height='8' viewBox='0 0 13 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.3536 4.35355C12.5488 4.15829 12.5488 3.84171 12.3536 3.64645L9.17157 0.464465C8.97631 0.269203 8.65973 0.269203 8.46447 0.464465C8.2692 0.659728 8.2692 0.97631 8.46447 1.17157L11.2929 4L8.46447 6.82843C8.2692 7.02369 8.2692 7.34027 8.46447 7.53553C8.65973 7.7308 8.97631 7.7308 9.17157 7.53553L12.3536 4.35355ZM4.37114e-08 4.5L12 4.5L12 3.5L-4.37114e-08 3.5L4.37114e-08 4.5Z' fill='%23F38400'/%3E%3C/svg%3E%0A") no-repeat center/24px auto;
  content: "";
  display: block;
  height: 24px;
}

.p-menu__cont .item summary {
  list-style: none;
}

.p-menu__cont .item summary::-webkit-details-marker {
  display: none;
}

.p-menu__cont .item summary.ttl::after {
  content: "＋";
  color: var(--color-orange);
  font-size: 2.4rem;
}

.p-menu__cont .item[open] .p-menu__list {
  -webkit-border-before: solid 1px var(--color-border);
  border-block-start: solid 1px var(--color-border);
}

.p-menu__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  font-size: 1.6rem;
  gap: 24px 32px;
  padding: 32px 4.5714vw;
}

.p-menu__list>li {
  line-height: 1.5;
}

@media screen and (max-width: 767.98px) {
  .p-menu .c-heading__photo {
    min-height: 170px;
  }

  .p-menu .c-heading__photo .hdg .en {
    font-size: 5rem;
    line-height: 1;
  }

  .p-menu .c-heading__photo .hdg em {
    font-size: 1.4rem;
  }

  .p-menu__cont .item .ttl {
    font-size: 1.6rem;
    gap: 12px;
    padding: 16px 0 16px 24px;
  }

  .p-menu__cont .item .ttl::after {
    width: 56px;
  }

  .p-menu__cont .item .ttl .icon {
    max-width: 54px;
  }

  .p-menu__cont .item summary.ttl::after {
    font-size: 1.8rem;
  }

  .p-menu__cont .item a.ttl::after {
    background-size: 12px auto;
    height: 12px;
  }
}

/* 無料カウンセリング =============================== */
.p-counseling {
  background: url("../images/top/bg_counseling.webp") no-repeat center/cover;
  padding-block: 108px;
  position: relative;
}

.p-counseling::before {
  background-color: rgba(215, 117, 0, 0.2);
  content: "";
  height: 100%;
  position: absolute;
  left: 0;
  top: 0;
  width: 100%;
  z-index: 1;
}

.p-counseling .l-container {
  position: relative;
  z-index: 10;
}

.p-counseling .c-heading {
  -webkit-margin-after: 72px;
  margin-block-end: 72px;
}

.p-counseling__cont {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 5.71428vw;
}

.p-counseling__cont .txt {
  font-size: 1.6rem;
  line-height: 1.6;
}

.p-counseling__cont .c-button {
  font-size: 2rem;
  padding-block: 24px;
  text-align: center;
  width: 100%;
}

.p-counseling__cont .c-tel {
  font-size: 4.2rem;
  -webkit-margin-before: 32px;
  margin-block-start: 32px;
}

.p-counseling__cont .c-tel .info {
  -webkit-margin-before: 8px;
  margin-block-start: 8px;
}

@media screen and (min-width: 768px) {
  .p-counseling__cont .details {
    -ms-flex-preferred-size: calc(100% - 363px - 5.71428vw);
    flex-basis: calc(100% - 363px - 5.71428vw);
  }

  .p-counseling__cont .contact {
    -ms-flex-preferred-size: 363px;
    flex-basis: 363px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-counseling {
    background: url("../images/top/bg_counseling_sp.webp") no-repeat center/cover;
    padding-block: 56px;
  }

  .p-counseling .c-heading {
    -webkit-margin-after: 27px;
    margin-block-end: 27px;
  }

  .p-counseling .l-container {
    padding-inline: 32px;
  }

  .p-counseling__cont {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
  }
}

/* はじめての方へ =============================== */
.p-first {
  padding-block: 120px;
}

.p-first .c-heading {
  -webkit-margin-after: 72px;
  margin-block-end: 72px;
  -ms-flex-preferred-size: 100%;
  flex-basis: 100%;
}

.p-first__cont {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
  flex-wrap: wrap;
  -webkit-column-gap: 6.666%;
  -moz-column-gap: 6.666%;
  column-gap: 6.666%;
  -webkit-margin-after: 96px;
  margin-block-end: 96px;
}

.p-first__figure {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
}

.p-first__figure img {
  height: 100%;
  -o-object-fit: cover;
  object-fit: cover;
  width: 100%;
}

.p-first__list li {
  -webkit-border-after: solid 1px var(--color-border);
  border-block-end: solid 1px var(--color-border);
}

.p-first__list a {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-size: 1.6rem;
  padding: 20px 8px;
}

.p-first__list a::after {
  background: url("data:image/svg+xml,%3Csvg width='13' height='8' viewBox='0 0 13 8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M12.3536 4.35355C12.5488 4.15829 12.5488 3.84171 12.3536 3.64645L9.17157 0.464465C8.97631 0.269203 8.65973 0.269203 8.46447 0.464465C8.2692 0.659728 8.2692 0.97631 8.46447 1.17157L11.2929 4L8.46447 6.82843C8.2692 7.02369 8.2692 7.34027 8.46447 7.53553C8.65973 7.7308 8.97631 7.7308 9.17157 7.53553L12.3536 4.35355ZM4.37114e-08 4.5L12 4.5L12 3.5L-4.37114e-08 3.5L4.37114e-08 4.5Z' fill='%23F38400'/%3E%3C/svg%3E%0A") no-repeat center/20px auto;
  content: "";
  height: 20px;
  width: 20px;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
}

.p-first__list a:hover {
  color: var(--color-orange);
}

@media screen and (min-width: 768px) {
  .p-first__figure {
    -ms-flex-preferred-size: 48.42%;
    flex-basis: 48.42%;
  }

  .p-first__figure img {
    border-radius: 10px;
  }

  .p-first__list {
    -ms-flex-preferred-size: calc(100% - 48.42% - 6.666%);
    flex-basis: calc(100% - 48.42% - 6.666%);
  }
}

@media screen and (max-width: 767.98px) {
  .p-first {
    padding-block: 56px 38px;
  }

  .p-first__cont {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    -webkit-margin-after: 40px;
    margin-block-end: 40px;
  }

  .p-first__figure {
    -webkit-box-ordinal-group: 2;
    -ms-flex-order: 1;
    order: 1;
    -webkit-margin-after: 40px;
    margin-block-end: 40px;
  }

  .p-first .c-heading {
    -webkit-box-ordinal-group: 3;
    -ms-flex-order: 2;
    order: 2;
    -webkit-margin-after: 20px;
    margin-block-end: 20px;
  }

  .p-first__list {
    -webkit-box-ordinal-group: 4;
    -ms-flex-order: 3;
    order: 3;
  }
}

/* 目整形 =============================== */
.p-eye {
  --color-eye: #3daca7;
  background-color: #fff;
}

.p-eye .c-heading,
.p-eye .c-heading .en {
  color: var(--color-eye);
}

.p-eye .c-heading.level-3 {
  font-size: 4.8rem;
  -webkit-margin-after: 56px;
  margin-block-end: 56px;
}

.p-eye a:hover {
  opacity: 0.7;
}

.p-eye__info {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  gap: 37px 40px;
  margin-block: 80px;
}

.p-eye__case {
  display: -ms-grid;
  display: grid;
  gap: 56px 24px;
  -ms-grid-columns: (1fr)[4];
  grid-template-columns: repeat(4, 1fr);
  -webkit-margin-after: 80px;
  margin-block-end: 80px;
}

.p-eye__case .details {
  -webkit-box-align: center;
  -ms-flex-align: center;
  align-items: center;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  font-weight: bold;
  -webkit-margin-before: 12px;
  margin-block-start: 12px;
}

.p-eye__case .details .ttl {
  color: var(--color-eye);
  font-size: 1.6rem;
}

.p-eye__case .details .button {
  background-color: var(--color-eye);
  border-radius: 4px;
  color: #fff;
  display: inline-block;
  font-size: 1.2rem;
  line-height: 1.4;
  -webkit-margin-start: auto;
  margin-inline-start: auto;
  padding: 2px 8px;
}

.p-eye__case .figure img {
  border-radius: 10px;
}

.p-eye__links {
  display: -ms-grid;
  display: grid;
}

.p-eye__links .ttl {
  color: var(--color-eye);
  font-size: 1.6rem;
}

.p-eye__links .ttl span {
  display: block;
  font-size: 1.4rem;
}

@media screen and (min-width: 768px) {
  .p-eye__info {
    margin-block: 37px;
  }

  .p-eye__info .details {
    -ms-flex-preferred-size: calc(100% - 390px - 40px);
    flex-basis: calc(100% - 390px - 40px);
  }

  .p-eye__info .figure {
    -ms-flex-preferred-size: 390px;
    flex-basis: 390px;
  }

  .p-eye__links {
    -ms-grid-columns: (1fr)[2];
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
    text-align: center;
  }

  .p-eye__links .item:nth-child(2n) {
    -webkit-border-start: solid 1px var(--color-brown);
    border-inline-start: solid 1px var(--color-brown);
  }

  .p-eye__links .figure {
    margin: 0 auto 16px;
    max-width: 64px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-eye {
    padding-block: 90px 78px;
  }

  .p-eye .c-heading.level-3 {
    -webkit-margin-after: 37px;
    margin-block-end: 37px;
  }

  .p-eye__info {
    -webkit-box-orient: vertical;
    -webkit-box-direction: normal;
    -ms-flex-direction: column;
    flex-direction: column;
    margin-block: 37px;
  }

  .p-eye__info .details {
    padding-inline: 32px;
  }

  .p-eye__info .figure img {
    width: 100%;
  }

  .p-eye__case {
    /* -ms-grid-columns: (1fr)[2]; */
    grid-template-columns: repeat(2, 1fr);
    gap: 24px 15px;
    -webkit-margin-after: 56px;
    margin-block-end: 56px;
  }

  .p-eye__links {
    /* -ms-grid-columns: (1fr)[1]; */
    grid-template-columns: repeat(1, 1fr);
    gap: 36px;
    padding-inline: 16px;
  }

  .p-eye__links .item a {
    display: -webkit-box;
    display: -ms-flexbox;
    display: flex;
    gap: 16px;
  }

  .p-eye__links .figure {
    max-width: 54px;
  }

  .p-eye__links .ttl {
    padding-block: 8px;
  }

  .p-eye__links .ttl span {
    font-size: 1.2rem;
  }
}

/* 未成年の方へ =============================== */
.p-other {
  padding-block: 40px;
}

/* 公式アカウント =============================== */
.p-sns .c-heading {
  -webkit-margin-after: 40px;
  margin-block-end: 40px;
}

.p-sns__list {
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  margin: 72px auto 0;
  max-width: 966px;
}

.p-sns__list>li {
  font-size: 2.4rem;
  letter-spacing: 0.05em;
  text-align: center;
}

.p-sns__list>li a {
  display: block;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.p-sns__list>li a:hover {
  -webkit-transform: translateY(-10px);
  transform: translateY(-10px);
}

.p-sns__list>li img {
  -webkit-margin-end: 10px;
  margin-inline-end: 10px;
  max-width: 48px;
  vertical-align: bottom;
}

@media screen and (min-width: 768px) {
  .p-sns__list {
    gap: 48px;
  }

  .p-sns__list>li {
    -webkit-border-after: solid 1px var(--color-border);
    border-block-end: solid 1px var(--color-border);
    -ms-flex-preferred-size: calc(33.3333% - 16px);
    flex-basis: calc(33.3333% - 16px);
    line-height: 48px;
  }

  .p-sns__list>li a {
    -webkit-padding-after: 16px;
    padding-block-end: 16px;
  }
}

@media screen and (max-width: 767.98px) {
  .p-sns {
    padding-block: 36px;
  }

  .p-sns .c-heading {
    -webkit-margin-after: 24px;
    margin-block-end: 24px;
  }

  .p-sns__list {
    gap: 32px;
    -webkit-box-pack: center;
    -ms-flex-pack: center;
    justify-content: center;
    -webkit-margin-before: 32px;
    margin-block-start: 32px;
  }

  .p-sns__list>li {
    font-size: 1.6rem;
  }

  .p-sns__list>li a {
    display: block;
    text-align: center;
  }

  .p-sns__list>li img {
    display: block;
    margin: 0 auto 8px;
    max-width: 30px;
  }
}
