@charset "UTF-8";
@import url("https://fonts.googleapis.com/css2?family=Crimson+Pro:ital,wght@0,200..900;1,200..900&display=swap");
@import url("https://fonts.googleapis.com/css2?family=Oswald:wght@500&display=swap");
:root {
  --font-noto-sans: "Noto Sans Japanese", sans-serif;
  --font-noto-serif: "Noto Serif Japanese", serif;
  --font-hiragino:
    "Hiragino Sans", "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
  --font-crimson: "Crimson Pro", serif;
  --font-lora: "Lora", serif;
  --font-yugo:
    "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ ProN W3",
    "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  --font-yumincho:
    "游明朝体", "Yu Mincho", "游明朝", "YuMincho", "ヒラギノ明朝 ProN W3",
    "Hiragino Mincho ProN", "MS PMincho", "MS 明朝", serif;
  --font-zen: "Zen Old Mincho", serif;
  --font-bison: "Bison", sans-serif;
  --font-bebas: "Bebas Neue", sans-serif;
  --font-en: Arial, Helvetica, sans-serif;
  --hover-opacity: 0.7;
  --header-height-pc: 119px;
  --header-height-sp: 57px;
  --color-primary: #95424d;
  --gradient-primary: linear-gradient(
    90deg,
    #9f3053 0%,
    #d66b7d 46%,
    #9f3053 78%,
    #d66b7d 100%
  );
  --color-secondary: #ffebeb;
  --color-secondary-light: #fff7f7;
  --color-tertiary: #d1667a;
  --color-gold: #eecf68;
  --color-gold-soft: #ede3b7;
  --color-gold-light: #ffebb9;
}

body {
  font-family: var(--font-yugo);
  font-size: 16px;
  color: #333;
  overflow-x: hidden;
}

.wrapper {
  -webkit-box-sizing: border-box;
  box-sizing: border-box;
  min-width: 1080px;
  height: 100%;
  width: 100%;
  margin-top: var(--header-height-pc);
}
@media screen and (max-width: 744px) {
  .wrapper {
    min-width: 100%;
    width: 100%;
    margin-top: var(--header-height-sp);
  }
}

/**************************************************
  ブレイクポイント改修用
***************************************************/
.tmp-wrapper {
  margin-top: var(--header-height-pc);
  margin-top: 119px;
}
.tmp-wrapper *,
.tmp-wrapper *::before,
.tmp-wrapper *::after {
  box-sizing: border-box;
  overflow-wrap: anywhere;
}
.tmp-wrapper *,
.tmp-wrapper *::before,
.tmp-wrapper *::after {
  box-sizing: border-box;
  overflow-wrap: anywhere;
}
@media screen and (max-width: 767px) {
  .tmp-wrapper {
    width: 100%;
    margin-top: var(--header-height-sp);
  }
}

@media (max-width: 767px) {
  .tmp-pc_only {
    display: none !important;
  }
}

@media (min-width: 768px) {
  .tmp-sp_only {
    display: none !important;
  }
}

.botox {
  --color-primary: #890e18;
  --color-alpha: rgb(252.337218543, 228.942781457, 230.8447682119);
  --color-secondary: rgba(137, 14, 24, 0.3);
  --color-strong: rgb(49, 0, 3.9837398374);
}

/* 古いページの調整用リセット
*****************************************************/
img {
  width: auto;
}

/***********************************
 * レイアウト施術ページ用
***********************************/
#menu_layout {
  max-width: 750px;
}
@media screen and (max-width: 744px) {
  #menu_layout {
    float: none;
  }
}
#menu_layout h1,
#menu_layout h2 {
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  text-align: center;
}
@media screen and (max-width: 744px) {
  #menu_layout section {
    max-width: 92%;
    margin: 0 auto 30px;
  }
}
@media screen and (max-width: 744px) {
  #menu_layout section:last-child {
    margin-bottom: 0;
  }
}

.red {
  color: #ff0000;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/***********************************
 * KV
***********************************/
#lower_menu_botox .custom-background {
  background-image: url("../images/kv.webp");
  background-size: cover;
  background-position: center;
}
@media screen and (max-width: 744px) {
  #lower_menu_botox .custom-background {
    background-image: url("../images/kv_sp.webp");
    background-position: center top;
    height: auto;
  }
}

/***********************************
 * リード
***********************************/
.bnr_box {
  border: 10px solid #b3a28d;
  margin-bottom: 10px;
}
@media screen and (max-width: 744px) {
  .bnr_box {
    border: none;
  }
}
.bnr_box h1,
.bnr_box h2 {
  color: #890e18;
  font-size: 43px;
  font-weight: 700;
  line-height: 1.4;
  padding: 20px 0;
  margin: 0;
}
@media screen and (max-width: 744px) {
  .bnr_box h1,
  .bnr_box h2 {
    font-size: 29px;
    padding: 0 20px 20px 20px;
  }
}
.bnr_box h1 span,
.bnr_box h2 span {
  clear: both;
  color: #000;
  display: block;
  font-family: "游ゴシック体", YuGothic, "游ゴシック", "Yu Gothic", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN", "メイリオ", "Meiryo", "verdana", sans-serif;
  font-size: 20px;
  margin-bottom: 0;
  padding-bottom: 0;
}
.bnr_box_tbl {
  width: 100%;
}
.bnr_box_tbl tr {
  vertical-align: middle;
}
.bnr_box_tbl th,
.bnr_box_tbl td {
  width: 50%;
}
@media screen and (max-width: 744px) {
  .bnr_box_tbl th,
  .bnr_box_tbl td {
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
  }
}
.bnr_box_tbl td {
  background-color: #eee;
  text-align: center;
  vertical-align: middle;
}
.bnr_box_tbl td div {
  padding: 0 10px;
  letter-spacing: -0.04em;
}
@media screen and (max-width: 744px) {
  .bnr_box_tbl td div {
    padding: 20px;
  }
}
.bnr_box_tbl td p {
  font-size: 18px;
}
.bnr_box_tbl td span {
  display: block;
  font-size: 20px;
  font-weight: 700;
  padding-bottom: 10px;
  text-transform: uppercase;
}

/***********************************
 * アバウト
***********************************/
.about_box {
  background: url(../../../assets/images/menu/common/bg_about.webp) repeat left top;
  margin-bottom: 40px;
  padding: 25px;
}
.about_box .img {
  text-align: center;
}
.about_box h2 {
  color: #890e18;
  font-size: 35px;
  padding: 10px 0;
  margin-bottom: 10px;
}
@media screen and (max-width: 744px) {
  .about_box h2 {
    font-size: 25px;
  }
}
.about_box h3 {
  font-size: 22px;
  font-weight: 700;
  margin: 0;
  padding-bottom: 40px;
  text-align: center;
}
@media screen and (max-width: 744px) {
  .about_box h3 {
    font-size: 20px;
  }
}
.about_box p {
  font-size: 15px;
  padding-bottom: 30px;
}
.about_box .about_list {
  display: flex;
  justify-content: center;
  gap: 20px;
  padding: 0;
  margin: 0;
  list-style: none;
  width: 100%;
  box-sizing: border-box;
}
@media screen and (max-width: 744px) {
  .about_box .about_list {
    flex-direction: column;
    align-items: center;
  }
}
.about_box .about_list li {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  align-items: center;
  gap: 10px;
  box-sizing: border-box;
}
@media screen and (max-width: 744px) {
  .about_box .about_list li {
    align-items: center;
  }
}
.about_box .about_list li div {
  display: flex;
  justify-content: center;
  align-items: center;
}
.about_box .about_list li img {
  height: 200px;
  width: auto;
  object-fit: cover;
}
.about_box .about_list li p {
  font-size: 14px;
  margin: 0;
  padding: 0;
}

/***********************************
 * トリビア
***********************************/
.trivia_box {
  background-color: #f3e6e7;
  font-size: 15px;
  margin: 29px 0 40px;
  padding: 25px;
  position: relative;
  border-radius: 5px;
}
@media screen and (max-width: 744px) {
  .trivia_box {
    padding: 30px 15px;
  }
}
.trivia_box h2 {
  color: #890e18;
  font-size: 35px;
  padding-bottom: 20px;
  margin-bottom: 10px;
}
@media screen and (max-width: 744px) {
  .trivia_box h2 {
    font-size: 21px;
  }
}

/***********************************
 * 特徴
***********************************/
.content_list {
  width: 100%;
  margin-bottom: 40px;
  box-sizing: border-box;
}
.content_list h2 {
  margin-bottom: 40px;
}
.content_list .content_flex {
  display: flex;
  flex-wrap: wrap;
  gap: 30px;
  align-items: flex-start;
  box-sizing: border-box;
}
@media screen and (max-width: 744px) {
  .content_list .content_flex {
    flex-direction: column;
    gap: 20px;
    align-items: center;
  }
}
.content_list .content_flex .content_flex_img {
  flex-shrink: 0;
}
.content_list .content_flex .content_flex_img img {
  width: auto;
  max-width: 100%;
  height: auto;
}
.content_list .content_flex p {
  flex: 1;
  box-sizing: border-box;
}
.content_list .content_flex._r {
  flex-direction: row-reverse;
}
@media screen and (max-width: 744px) {
  .content_list .content_flex._r {
    flex-direction: column;
    gap: 20px;
    align-items: center;
  }
}
.content_box {
  width: 100%;
  box-sizing: border-box;
  font-size: 15px;
  padding-bottom: 60px;
}
@media screen and (max-width: 744px) {
  .content_box {
    padding-bottom: 30px;
  }
}
.content_box h3 {
  color: #890e18;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 21px;
  font-weight: 700;
  padding: 0 0 25px 15px;
  position: relative;
}
@media screen and (max-width: 744px) {
  .content_box h3 {
    padding: 0 0 0 15px;
    margin-bottom: 15px;
  }
}
.content_box h3 small {
  font-size: 15px;
}
.content_box h3::before {
  background-color: #890e18;
  content: "";
  height: 28px;
  left: 0;
  position: absolute;
  top: 1px;
  width: 4px;
}
@media screen and (max-width: 744px) {
  .content_box h3::before {
    height: 100%;
  }
}
.content_box p {
  padding-bottom: 20px;
  padding-right: 0;
}
.content_box_inner {
  background-color: #f3e6e7;
  border-radius: 4px;
  padding: 20px;
}
.content_box_inner h4 {
  color: #851213;
  font-size: 22px;
  font-weight: 700;
  padding-bottom: 20px;
}
.content_box_inner img {
  float: left;
  padding-right: 20px;
}
.content_box_inner strong {
  font-weight: 700;
}
.content_box_last {
  padding-bottom: 0;
}

/***********************************
 * 適応部位
***********************************/
.sites_list {
  margin-bottom: 40px;
}
.sites_img {
  display: block;
  margin: 40px auto;
  text-align: center;
  max-width: 612px;
}
.sites_txt h2 {
  background-color: #e8dece;
  font-size: 30px;
  line-height: 1;
  padding: 14px;
  border-radius: 5px;
}
@media screen and (max-width: 744px) {
  .sites_txt h2 {
    font-size: 19px;
    text-align: center;
  }
}
.sites_txt h2 span {
  color: #890e18;
  display: inline-block;
  font-size: 40px;
  padding-bottom: 14px;
}
@media screen and (max-width: 744px) {
  .sites_txt h2 span {
    font-size: 25px;
  }
}
.sites_txt h2 small {
  font-size: 30px;
}
.sites_info {
  padding-bottom: 100px;
  position: relative;
  z-index: 1;
  height: 350px;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  align-items: center;
}
@media screen and (max-width: 744px) {
  .sites_info {
    padding-bottom: 0;
    min-height: 0;
    display: block;
    height: auto;
  }
}
.sites_info li {
  display: block;
  font-size: 25px;
  font-weight: 600;
  padding: 0 0 15px 30px;
  position: relative;
}
@media screen and (max-width: 744px) {
  .sites_info li {
    font-size: 16px;
    padding: 0 0 15px 25px;
  }
}
.sites_info li::before {
  content: url("../../../assets/images/menu/common/icon_check.svg");
  left: 0;
  position: absolute;
  top: 3px;
}
@media screen and (max-width: 744px) {
  .sites_info li::before {
    top: 0;
    transform: scale(0.75);
  }
}
.sites_info li:last-child {
  padding-bottom: 0;
}
.sites_info::after {
  content: url("../../../assets/images/menu/common/model.webp");
  position: absolute;
  right: 0;
  top: -51px;
  z-index: -1;
}
@media screen and (max-width: 744px) {
  .sites_info::after {
    display: none;
  }
}

/***********************************
 * 施術の流れ
***********************************/
.steps_list {
  margin-bottom: 40px;
}
.steps_list .step {
  margin-bottom: 30px;
  padding-bottom: 50px;
  position: relative;
}
.steps_list .step:after {
  border-left: 18px solid transparent;
  border-right: 18px solid transparent;
  border-top: 16px solid #b3a28d;
  bottom: 0;
  clear: both;
  content: "";
  height: 0;
  left: 0;
  margin: 0 auto;
  position: absolute;
  right: 0;
  width: 0;
}
.steps_list .step.step-no {
  margin-bottom: 0;
  padding-bottom: 0;
}
.steps_list .step.step-no:after {
  border: none;
}
.steps_list .step h5 {
  background: url("../../../assets/images/menu/flow/bg_step.webp") repeat-y left top;
  font-family: "ヒラギノ明朝 ProN W3", "Hiragino Mincho ProN", "游明朝", YuMincho, "HG明朝E", "ＭＳ Ｐ明朝", "ＭＳ 明朝", "Noto Serif JP", serif;
  font-size: 20px;
  margin-bottom: 25px;
  padding: 10px 0 10px 20px;
  border-top-left-radius: 5px;
  border-bottom-left-radius: 5px;
}
@media screen and (max-width: 744px) {
  .steps_list .step h5 {
    background: url("../../../assets/images/menu/flow/bg_step_sp.webp") repeat-x left top;
    text-align: center;
    border-bottom-left-radius: 0;
    border-top-right-radius: 5px;
    padding: 10px;
  }
}
.steps_list .step .step_txt {
  font-size: 15px;
  min-height: 150px;
  padding-left: 250px;
  position: relative;
}
.steps_list .step .step_txt img {
  left: 0;
  position: absolute;
  top: 0;
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_txt img {
    position: relative;
  }
}
.steps_list .step .step_txt span {
  display: block;
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_txt span {
    padding-top: 20px;
  }
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_txt .img {
    margin: 0 auto;
    text-align: center;
  }
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_txt {
    min-height: 10px;
    padding-left: 0;
  }
}
.steps_list .step .step_tbl {
  width: 100%;
}
.steps_list .step .step_tbl tr {
  vertical-align: middle;
}
.steps_list .step .step_tbl tr th,
.steps_list .step .step_tbl tr td {
  vertical-align: middle;
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_tbl tr th,
  .steps_list .step .step_tbl tr td {
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
  }
}
.steps_list .step .step_tbl tr th {
  width: 250px;
  padding-right: 20px;
}
@media screen and (max-width: 744px) {
  .steps_list .step .step_tbl tr th {
    margin: 0 auto;
    padding-bottom: 20px;
    text-align: center;
  }
}
.steps_list .step .step_tbl tr td {
  font-size: 15px;
}
.steps_list .step .step_tbl tr td small {
  font-size: 13px;
}
@media screen and (max-width: 744px) {
  .steps_list .step {
    margin-bottom: 20px;
    padding-bottom: 36px;
  }
}

/***********************************
 * 適応部位
***********************************/
.downtime_list {
  margin-bottom: 40px;
}
.downtime_list .ttl_bnr {
  border-bottom: 1px solid #b3a28d;
  margin-bottom: 30px;
}
.downtime_list .tbl_default {
  width: 100%;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default {
    box-sizing: border-box;
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
    justify-content: center;
    display: flex;
  }
  .downtime_list .tbl_default tbody {
    width: 100%;
  }
}
.downtime_list .tbl_default tr {
  vertical-align: middle;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default tr {
    display: block;
    width: 100%;
  }
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default tr:last-child td {
    border-bottom: 1px solid #000;
  }
}
.downtime_list .tbl_default th,
.downtime_list .tbl_default td {
  border: 1px solid #000;
  padding: 15px;
  vertical-align: middle;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default th,
  .downtime_list .tbl_default td {
    border-bottom: none;
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
    -moz-box-sizing: border-box;
    text-align: center;
  }
}
.downtime_list .tbl_default th {
  background-color: #fdfcfa;
  font-size: 18px;
  font-weight: 700;
  width: 200px;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default th {
    width: 100%;
  }
}
.downtime_list .tbl_default td {
  font-size: 15px;
}
.downtime_list .tbl_default td small {
  font-size: 13px;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default td small {
    clear: both;
    display: block;
    font-size: 12px;
    overflow: hidden;
    margin-left: 0;
  }
}
.downtime_list .tbl_default td span {
  padding-right: 30px;
}
@media screen and (max-width: 744px) {
  .downtime_list .tbl_default td span {
    padding-right: 0;
  }
}
.downtime_list .tbl_default p {
  padding-bottom: 20px;
}
.downtime_list .tbl_default strong {
  font-weight: 600;
}

/***********************************
 * 費用
***********************************/
.price_list {
  width: 100%;
  box-sizing: border-box;
}
@media screen and (max-width: 744px) {
  .price_list {
    display: block;
  }
}
.price_list .tbl_price_c {
  margin: 30px 0 40px;
  width: 100%;
  border-collapse: collapse;
}
@media screen and (max-width: 744px) {
  .price_list .tbl_price_c {
    margin-bottom: 0;
    box-sizing: border-box;
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
    border-bottom: 1px solid #000;
  }
}
@media screen and (max-width: 744px) {
  .price_list .tbl_price_c tbody,
  .price_list .tbl_price_c tr {
    display: block;
    width: 100%;
  }
}
.price_list .tbl_price_c tr {
  vertical-align: middle;
}
.price_list .tbl_price_c tr.pcDisp {
  display: table-row;
}
.price_list .tbl_price_c th,
.price_list .tbl_price_c td {
  border: 1px solid #000;
  padding: 15px;
  vertical-align: middle;
  box-sizing: border-box;
}
@media screen and (max-width: 744px) {
  .price_list .tbl_price_c th,
  .price_list .tbl_price_c td {
    border-bottom: none;
    clear: both;
    display: block;
    overflow: hidden;
    width: 100%;
    box-sizing: border-box;
  }
}
.price_list .tbl_price_c th {
  width: 385px;
  background-color: #fdfcfa;
  text-align: center;
}
@media screen and (max-width: 744px) {
  .price_list .tbl_price_c th {
    width: 100%;
  }
}
.price_list .tbl_price_c td {
  color: #890e18;
  font-size: 18px;
  font-weight: 700;
  width: 150px;
  text-align: center;
}
@media screen and (max-width: 744px) {
  .price_list .tbl_price_c td {
    width: 100%;
  }
}
.price_list .tbl_price_c td .text_trial {
  text-align: left;
  display: inline-block;
}
.price_list .tbl_price_c td small {
  font-size: 12px;
  display: block;
  color: #111111;
  font-weight: normal;
}
.price_list .tbl_price_c td small.spDisp {
  margin-left: 5px;
  font-size: 10px;
}
.price_list .tbl_price_c td span.spDisp {
  margin-right: 10px;
}
.price_list .tbl_price_c:last-of-type {
  margin-bottom: inherit;
}
.price_list .pick_note {
  width: 100%;
  background-color: #fff;
  color: #dd5564;
  text-align: center;
  font-size: 15px;
  font-weight: 700;
  border: 1px solid #dd5564;
  margin-top: 16px;
  padding: 4px;
}
@media screen and (max-width: 744px) {
  .price_list .pick_note {
    font-size: 3.2vw;
    border: 0.2666666667vw solid #dd5564;
    padding-right: 2.1333333333vw;
    padding-left: 6.4vw;
    text-indent: -3.2vw;
    margin-top: 4.2666666667vw;
    text-align: left;
  }
}

/*# sourceMappingURL=style.css.map */
