@charset "UTF-8";
/*---------------------------------------------
	リセット
---------------------------------------------*/
article,
aside,
hgroup,
header,
address,
figure,
figcaption {
  margin: 0;
  padding: 0;
}

ul {
  margin-block-start: 0;
  margin-block-end: 0;
  padding-inline-start: 0;
  padding: 0;
}

p {
  margin-block-start: 0px;
  margin-block-end: 0px;
  margin-inline-start: 0px;
  margin-inline-end: 0px;
  font-family: "Noto Sans JP";
}

ol {
  font-family: "Noto Sans JP";
  font-size: 1.6rem;
}

#main ol.hokuroibo {
  font-size: 1.6rem;
}

#main ol.hokuroibo {
  font-size: 1.6rem;
}

.treat_main ol.sorari {
  font-size: 1.6rem;
  margin: 0 0 2.3rem 1.8rem;
}

h2,
h3,
h4,
h5,
h6,
dl {
  margin-block-start: 0;
  margin-block-end: 0;
  margin: 0;
}

/*---------------------------------------------
	body
---------------------------------------------*/
html {
  scroll-behavior: smooth;
  font-size: 62.5%;
  overflow-y: scroll;
  font-family: "Noto Serif JP";
} /* 10px */
body {
  margin: 0;
  padding: 0;
  font-size: 1.6rem;
  line-height: 1.6;
  text-align: left;
  -webkit-text-size-adjust: 100%;
  color: #122025;
  overflow-x: hidden;
}

/*---------------------------------------------
	カラム
---------------------------------------------*/
.clounm_wrapper {
  width: 90%;
  max-width: 1200px;
  margin: 0 auto;
  position: relative;
}

.clounm_wrapper:after {
  /* content: "."; */
  display: block;
  height: 0;
  font-size: 0;
  clear: both;
  visibility: hidden;
}

/*---------------------------------------------
	Anchor
---------------------------------------------*/
a {
  outline: none;
  color: #122025;
}

a:link {
  text-decoration: none;
  text-decoration: underline;
}

a:visited {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

a:active {
  text-decoration: none;
}

a {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

/*---------------------------------------------
	p
---------------------------------------------*/
p {
  margin-bottom: 0.8em;
}

p + a {
  margin-top: 1em !important;
}

p + div {
  margin-top: 1.5em !important;
}

/*---------------------------------------------
	m_pattern
---------------------------------------------*/
.m_pattern_a {
  padding: 0 0 4rem;
}

.m_pattern_b {
  padding: 0 0 1rem;
}

.m_pattern_c {
  padding: 0 0 6rem;
}

/*---------------------------------------------
	padding
---------------------------------------------*/
.pLR {
  padding-left: 0.7rem;
  padding-right: 0.7rem;
}

/*---------------------------------------------
	fwb
---------------------------------------------*/
.fwb {
  font-weight: 600;
}

/*---------------------------------------------
 ** ON OFF hover
---------------------------------------------*/
.hover {
  -webkit-transition: 0.3s ease-in-out;
  -moz-transition: 0.3s ease-in-out;
  -o-transition: 0.3s ease-in-out;
  transition: 0.3s ease-in-out;
}

.hover:hover {
  opacity: 0.6;
  filter: alpha(opacity=60);
  -ms-filter: "alpha( opacity=60 )";
}

/*---------------------------------------------
 **   text-align
---------------------------------------------*/
.tac {
  text-align: center;
}

/*---------------------------------------------
 ** パンくずリスト
---------------------------------------------*/
#breadcrumb {
  width: 100%;
  margin: 0 auto 4rem;
  font-family: "Noto Sans JP";
}

#breadcrumb ul {
  display: table;
  font-size: 1.4rem;
}

#breadcrumb ul li {
  margin: 0 10px 0 0;
  font-size: 1.4rem;
  float: left;
  list-style-type: none;
}

#breadcrumb ul li a {
  color: #333f8c;
  text-decoration: none;
  font-weight: bold;
}

#breadcrumb ul li:first-child::before {
  content: "";
  padding: 0;
}

#breadcrumb ul li::before {
  padding: 0 10px 0 0;
  font-family: "Font Awesome 5 Free";
  content: "\f054";
  font-weight: bold;
  font-size: 14px;
}

/*---------------------------------------------
 **  flexbox
---------------------------------------------*/
.display_flex {
  display: flex;
}

.flex_wrapper {
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.flex_start {
  justify-content: flex-start;
}

.flex_end {
  justify-content: flex-end;
}

.flex_item_clounm_1 {
  width: 100%;
  max-width: 1200px;
}

.flex_item_clounm_2 {
  width: calc(50% - 20px);
}

.flex_item_clounm_3 {
  width: calc(33.3333333333% - 30px);
}

.flex_item_clounm_4 {
  width: calc(25% - 30px);
}

.order_1 {
  order: 1;
}

.order_2 {
  order: 2;
}

/*---------------------------------------------
 **  アニメーション
---------------------------------------------*/
.animation_base {
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

/*---------------------------------------------
 **  ページトップ
---------------------------------------------*/
#pageTop {
  position: fixed;
  bottom: 20px;
  right: 20px;
  z-index: 999;
}

#pageTop a {
  display: block;
  padding: 5px 3px 0px 3px;
  border-radius: 30px;
  color: #fff;
  font-weight: bold;
  text-decoration: none;
  text-align: center;
  background: url(../img/common/page_top.png) no-repeat;
  background-size: 100%;
  -moz-border-radius: 0px;
  -webkit-border-radius: 0px;
  border-radius: 0px;
}

#pageTop a:hover {
  text-decoration: none;
  opacity: 0.7;
}

/*---------------------------------------------
 ** h1
---------------------------------------------*/
h1 {
  font-size: 3rem;
  line-height: 1.45;
  margin-bottom: 1.8rem;
  font-weight: 600;
  letter-spacing: 3px;
  text-align: center;
}

/*---------------------------------------------
 ** h2
---------------------------------------------*/
h2 {
  font-size: 3rem;
  line-height: 1.45;
  margin-bottom: 1.8rem;
  font-weight: 600;
  letter-spacing: 3px;
  color: #121f25;
  text-align: center;
}

h2 span,
h2 strong {
  display: block;
  color: #8291be;
  letter-spacing: 4px;
  font-size: 12px;
  font-weight: normal;
  font-family: "Noto Sans JP";
  margin-top: 6px;
}

.h2_span_typ_01 {
  color: #2f4792;
  font-family: "Noto Serif JP";
}

.stroke {
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.5), -1px -1px 0 rgba(255, 255, 255, 0.2), -1px 1px 0 rgba(255, 255, 255, 0.5), 1px -1px 0 rgba(255, 255, 255, 0.2), 0px 1px 0 rgba(255, 255, 255, 0.5), -1px 0 rgba(255, 255, 255, 0.2), -1px 0 0 rgba(255, 255, 255, 0.5), 1px 0 0 rgba(255, 255, 255, 0.2);
}

/* インスタh2 */
.insta_h2 {
  position: relative;
}

.insta_h2:before {
  width: 33px;
  height: 33px;
  display: block;
  background: url(../img/top/insta.jpg) no-repeat;
  background-size: contain;
  content: "";
  margin: 0 auto 5px;
}

/*---------------------------------------------
 ** h3
---------------------------------------------*/
h3 {
  font-size: 2.4rem;
  margin-bottom: 0rem;
  font-weight: 600;
  background: #c8b597; /* Old browsers */
  background: -moz-linear-gradient(left, #c8b597 0%, #f3efe4 90%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #c8b597 0%, #f3efe4 90%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #c8b597 0%, #f3efe4 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#c8b597", endColorstr="#f3efe4",GradientType=1 ); /* IE6-9 */
  font-feature-settings: "palt";
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 1px 2px 1px rgba(0, 0, 0, 0.2);
  padding: 0.8rem 5.3rem 1.1rem;
  margin-bottom: 1.5rem;
}

.h3_inner_page {
  font-size: 3rem;
  display: inline-block;
  margin-bottom: 5rem;
}

/*---------------------------------------------
 ** h4
---------------------------------------------*/
h4 {
  font-family: "Noto Sans JP";
  font-size: 2.1rem;
  color: #323e88;
  padding: 4rem 0 2.6rem;
}

/*---------------------------------------------
 ** コンテンツ全体
---------------------------------------------*/
#content {
  width: 100%;
}

#main {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 2.5rem 0 2rem;
}

#top #main {
  padding-top: 0;
  padding-bottom: 0;
  max-width: 100%;
  padding: 0rem 0 2rem;
}

#slideshow {
  display: none;
}

#top #slideshow {
  display: block;
}

/*---------------------------------------------
 ** セクション
---------------------------------------------*/
.section_block {
  margin-bottom: 70px;
}

.section_block_top {
  padding-top: 56px;
}

/*---------------------------------------------
 ** li list typ 消す
---------------------------------------------*/
.lst_none li {
  list-style-type: none;
}

/* 画像 */
.img_box {
  display: flex;
}

/* フォントサイズ */
.fz20 {
  font-size: 2rem;
}

.mal {
  display: flex;
  justify-content: center;
  align-items: center;
}

/*=================================================================================================================================*/
/**  ここまで共通部分	*/
/*=================================================================================================================================*/
/*---------------------------------------------
 ** ナビ記述
---------------------------------------------*/
#footer .sub-menu {
  display: none;
}

/*---------------------------------------------
 ** ヘッダー記述
---------------------------------------------*/
#header {
  width: 100%;
}

/* ロゴ */
.logo a {
  display: block;
  z-index: 9;
  position: relative;
}

/* ロゴ */
.logo {
  max-width: 380px;
  max-height: 90px;
  display: block;
  z-index: 999;
}

.logo img {
  width: 100%;
}

.header_wrapper {
  padding: 5%;
}

/*---------------------------------------------
 **  TEL
---------------------------------------------*/
/*---------------------------------------------
 ** フッター記述
---------------------------------------------*/
#footer {
  clear: both;
  position: relative;
  padding: 5.6rem 0 0;
  background: url(../img/common/footer_bd.jpg) top center repeat-x;
  margin-top: 5rem;
}

/* footerロゴ */
#footer .logo {
  margin: 0 auto 25px;
  max-width: 435px;
  width: 100%;
  max-height: 341px;
}

/* コピーライト */
#copyright {
  font-size: 0.8em;
  width: 100%;
  text-align: center;
  letter-spacing: 3px;
  padding: 30px 0 46px;
  font-weight: bold;
  color: #3b5198;
}

/* 地図 */
.map {
  width: 100%;
  min-height: 400px;
  height: 400px;
  margin: 0;
}

/* 診療時間 */
.mh {
  max-width: 1000px;
  margin: 0 auto 30px;
  display: block;
}

/* SNS */
.sns {
  -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.09);
  -moz-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.09);
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.09);
  background: #fff;
  padding: 2rem 3rem;
  max-width: 390px;
  width: 100%;
  margin: 0 auto;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
  position: relative;
  margin-bottom: 20px;
}

.sns:after {
  width: 1px;
  height: 70%;
  background: #d6d6d6;
  position: absolute;
  top: 15%;
  left: 0px;
  right: 0px;
  margin: 0 auto;
  content: "";
}

.sns p {
  font-size: 2rem;
  margin-bottom: 0;
  line-height: 0.9;
  text-align: center;
}

.sns a {
  text-decoration: none;
}

.sns span {
  font-size: 1.4rem;
  color: #72645d;
}

/* インスタグラム */
.instagram_footer {
  position: relative;
  width: 50%;
}

.instagram_footer:before {
  width: 37px;
  height: 37px;
  top: 0px;
  position: relative;
  display: inline-block;
  background: url(../img/top/insta.jpg) no-repeat;
  background-size: contain;
  content: "";
  float: left;
  padding-left: 7%;
}

/* LINE@ */
.line_footer {
  position: relative;
  width: 40%;
  line-height: 1.1;
}

.line_footer:before {
  width: 37px;
  height: 37px;
  top: 1px;
  position: relative;
  display: inline-block;
  background: url(../img/top/line.jpg) no-repeat;
  background-size: contain;
  content: "";
  float: left;
  padding-left: 6%;
  position: absolute;
  top: 1px;
  left: -10px;
}

/*LINE 非表示するときに使う*/
.sns {
  justify-content: center;
}
.sns::after,
.sns .line_footer {
  display: none;
}
.sns .instagram_footer {
  width: auto;
  display: flex;
  align-items: center;
}
.sns .instagram_footer::before {
  float: none;
  padding-left: 0;
  aspect-ratio: 1/1;
  width: 37px;
  height: 37px;
  position: static;
}
.sns .instagram_footer p {
  padding-left: 10px;
}
.sns .instagram_footer p a br {
  display: none;
}
.sns .instagram_footer p a span {
  margin-left: 10px;
}

/*=================================================================================================================================*/
/**  共通パーツ	*/
/*=================================================================================================================================*/
/*---------------------------------------------
 **  ボタン
---------------------------------------------*/
.bt_base {
  width: 100%;
  max-width: 400px;
  padding: 2.4rem 8rem;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  text-decoration: none !important;
  font-size: 2rem;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
  margin: 0 auto;
  border: 1px solid #3b5198 !important;
  font-size: 1.8rem;
  font-family: "Noto Sans JP";
  color: #3b5198;
  -webkit-transition: all 0.6s;
  transition: all 0.6s;
  position: relative;
}

/* アニメーション */
.bt_anime_01 {
  position: relative;
  transition: 0.3s;
}

.bt_anime_01:hover {
  color: #fff;
}

.bt_anime_01::before {
  position: absolute;
  top: 0;
  right: 0;
  bottom: 0;
  left: 0;
  z-index: -1;
  content: "";
  background: #3b5198;
  transform-origin: top;
  transform: scale(0, 1);
  transition: transform 0.4s;
}

.bt_anime_01:hover::before {
  transform-origin: top;
  transform: scale(1, 1);
}

/*=================================================================================================================================*/
/**  アニメーション	*/
/*=================================================================================================================================*/
.effect-fade.fadeInUp {
  opacity: 0;
  transform: translateY(30px);
  transition: 1s;
}

.effect-fade.fadeInDown {
  opacity: 0;
  transform: translateY(-30px);
  transition: 2s;
}

.effect-fade.SlideInLeft {
  opacity: 0;
  transform: translateX(-30px);
  transition: 2s;
}

.effect-fade.FadeIn {
  opacity: 0;
  transform: translateX(-30px);
  transition: 2s;
}

/* ディレイ */
.effect-fade.delay-lv1 {
  -webkit-transition-delay: 0.2s;
  transition-delay: 0.2s;
}

.effect-fade.delay-lv2 {
  -webkit-transition-delay: 0.4s;
  transition-delay: 0.4s;
}

.effect-fade.delay-lv3 {
  -webkit-transition-delay: 0.5s;
  transition-delay: 0.5s;
}

.effect-bt {
  transition: 1s;
}

.effect-bt:hover {
  opacity: 0.6;
  transform: translateY(-15px);
  transition: 1s;
}

.icon_typ_01 {
  position: relative;
}

.icon_typ_01:after {
  width: 26px;
  height: 26px;
  position: absolute;
  top: 0px;
  bottom: 0;
  margin: auto 0;
  right: 5%;
  background: url(/img/common/icon_02.png) no-repeat;
  background-size: contain;
  content: "";
}

/* お知らせのアイコン */
.icon_typ_01.news_item_wrapper:after {
  right: -12px;
}

/*---------------------------------------------
 **  ボーダー
---------------------------------------------*/
/*---------------------------------------------
 **  色
---------------------------------------------*/
.c_white {
  color: #ffffff !important;
}

.c_black {
  color: #000000 !important;
}

/*---------------------------------------------
 **  文字サイズ
---------------------------------------------*/
.fz_L {
  font-size: 3rem;
}

/*=================================================================================================================================*/
/**  TOPコンテンツ	*/
/*=================================================================================================================================*/
#top .price_first_wrapper {
  display: block;
}

.price_first_wrapper {
  display: none;
}

.icon_time {
  position: relative;
}

.icon_time:before {
  width: 26px;
  height: 26px;
  background: url(../img/common/icon_time.png) no-repeat;
  background-size: contain;
  content: "";
  margin-right: 10px;
}

.tel {
  max-width: 300px;
  width: 100%;
  margin: 0 !important;
  background: #8890c5; /* Old browsers */
  background: -moz-linear-gradient(top, #8890c5 0%, #505ba3 51%, #374495 51%, #323e88 100%); /* FF3.6-15 */
  background: -webkit-linear-gradient(top, #8890c5 0%, #505ba3 51%, #374495 51%, #323e88 100%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to bottom, #8890c5 0%, #505ba3 51%, #374495 51%, #323e88 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#8890c5", endColorstr="#323e88",GradientType=0 ); /* IE6-9 */
  color: #ffffff !important;
  -webkit-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.3);
  -moz-box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.3);
  box-shadow: 0px 0px 2px 0px rgba(0, 0, 0, 0.3);
}

.tel ul {
  width: 100%;
  height: 100%;
  display: block;
  text-align: center;
}

.tel li {
  height: 100%;
}

.tel a {
  text-decoration: none !important;
  color: #ffffff !important;
  width: 100%;
  height: 100%;
  display: block;
}

.tel p {
  font-size: 3.5rem;
  line-height: 1.2;
  margin: 0;
  font-family: "Noto Serif JP";
  padding-top: 2.7rem;
  text-align: center;
}

.tel span {
  margin: 0 0 0 2.4rem;
  color: #d7d9e9;
}

.icon_tel {
  position: relative;
}

.icon_tel::before {
  width: 19px;
  height: 30px;
  background: url(../img/common/icon_sp.png) no-repeat;
  background-size: contain;
  content: "";
  display: inline-block;
  margin-right: 0.5rem;
  position: relative;
  top: 2px;
  left: -3px;
}

.icon_tel b {
  position: relative;
  font-weight: unset;
}

.icon_tel b::after {
  position: absolute;
  content: "トクイ";
  font-size: 9px;
  top: -4px;
  right: -1px;
  text-align: center;
  letter-spacing: 1px;
  letter-spacing: 10px;
}

/*---------------------------------------------
 ** フッター
---------------------------------------------*/
.list_style_01 li {
  position: relative;
  font-weight: bold;
  font-size: 2rem;
}

.list_style_01 li:before {
  font-size: 1.1rem;
  top: -2px;
  left: 0px;
  color: #3b5198;
  content: "●";
  position: relative;
  margin-right: 1.1rem;
}

.footer_item {
  padding: 0 1rem 2rem 2rem;
  margin-bottom: 1.5rem;
  border-bottom: 1px solid #d6d6d6;
}

.footer_item:last-of-type {
  border-bottom: unset;
}

.kyushin dt {
  width: 68px;
  height: 26px;
  background: #eaedf4;
  text-align: center;
  padding: 0 2px;
  color: #122025;
}

.kyushin dd {
  margin-left: 2rem;
  color: #1b4364;
}

.parking {
  border-top: 1px solid #d6d6d6;
  border-bottom: 1px solid #d6d6d6;
  padding: 0.5rem 0.5rem 0.7rem;
  text-align: center;
}

/*=================================================================================================================================*/
/**  内部ページ	*/
/*=================================================================================================================================*/
/* topページ */
.header_L {
  background: url(../img/common/logo_bg.png) no-repeat;
}

.top_banner {
  display: none;
}

#top .top_banner {
  display: flex;
}

/* お知らせ */
.news_wrapper {
  border-bottom: 1px solid #d6d6d6;
  background: #fff;
  min-height: 70px;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
}

.news_right {
  font-family: "Noto Sans JP";
}

.news_btn a {
  text-decoration: none !important;
  color: #fff;
}

.news_item {
  background: #3b5198;
  height: 100%;
  font-size: 20px;
  text-align: center;
  padding: 1.4rem 1rem 0 1rem;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
  line-height: 1.35;
  display: flex;
  justify-content: center;
  align-items: center;
}

.news_item span {
  font-size: 12px;
  letter-spacing: 3px;
  font-family: "Noto Sans JP";
  display: block;
  color: #969cc9;
}

/* お知らせカテゴリー */
.news_category {
  font-size: 12px;
  display: inline-block;
  background: #3b5198;
  padding: 0.3rem 0.5rem;
  color: #fff;
  margin-right: 1.8rem;
  min-width: 71px;
  text-align: center;
}

.news_category.important {
  background: #e16e8d;
}

.news_category.holiday {
  background: #e16e8d;
}

.news_category.campaign {
  background: #4c8099;
}

.news_right div a {
  text-decoration: none !important;
}

/* 診療案内 */
.top_treat {
  color: #122025 !important;
}

.lts_kanji {
  letter-spacing: 10px !important;
}

.treat_guide {
  -webkit-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  -moz-box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 0px 10px 0px rgba(0, 0, 0, 0.15);
  background: #fff;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
}

.treat_guide_inner {
  text-align: center;
}

.treat_guide {
  height: 225px;
  padding: 4.7rem 0 0;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
}

.logo_S_wrapper {
  background: url(/img/common/bg_logo_S.png) top center no-repeat;
  padding: 3rem 0 0rem;
}

.bgc_ptn_01 {
  background: #c9b796;
  font-size: 13px;
  color: #fff;
  padding: 0.4rem 0 0.5rem;
}

.treat_bg_01 {
  background: url(/img/top/top_treat_01.jpg?0617) right 0 #fff no-repeat;
}

.treat_bg_02 {
  background: url(/img/top/top_treat_02.jpg) left 0 #fff no-repeat;
}

.treat_bg_03 {
  background: url(/img/top/top_treat_03.jpg) right 0 #fff no-repeat;
}

.treat_bg_04 {
  background: url(/img/top/top_treat_04.jpg) left 0 #fff no-repeat;
}

.treat_bg_05 {
  background: url(/img/top/top_treat_05.jpg) right 0 #fff no-repeat;
}

.treat_bg_06 {
  background: url(/img/top/top_treat_06.jpg) left 0 #fff no-repeat;
}

.treat_btn_box {
  width: 90%;
  max-width: 540px;
  flex-wrap: wrap;
  margin: 0 auto;
  display: flex !important;
  justify-content: space-between;
}

.treat_btn_box .top_menu_btn {
  max-width: 300px !important;
}

/*---------------------------------------------
 **  画面幅MAX背景
---------------------------------------------*/
.full-width {
  margin-left: calc(-50vw + 50%);
  margin-right: calc(-50vw + 50%);
}

.full-width > div {
  max-width: 1200px;
  width: 90%;
  margin: 0 auto;
}

/* 背景色 */
.bg_cover {
  background: #f8f5ed;
  padding: 3rem;
  margin-bottom: 3rem;
}

.bg_cover2 {
  background: #eaedf4;
  padding: 5rem 3rem 3rem;
  margin-bottom: 0rem;
}

.bg_cover2 .wp-block-columns {
  margin-bottom: 0;
}

#top_news {
  background: #eaedf4;
  padding: 0 3rem 3rem;
  margin-bottom: 0rem;
}
#top_news h2 {
  margin: 0 -3rem 3rem;
  padding: 3rem 3rem;
  background: #3b5198;
  color: #FFF;
  position: relative;
}
#top_news h2:before {
  content: "";
  width: 100vw;
  height: 100%;
  background: #3b5198;
  left: 50%;
  top: 0;
  transform: translateX(-50%);
  z-index: -1;
  display: block;
  position: absolute;
}

#top_news h2 span {
  color: #969cc9;
  margin-top: 0;
}

/*---------------------------------------------
 **  共通　形成外科一覧 呼び出し
---------------------------------------------*/
.inner_page_treat_list .treat_list li a {
  padding: 0.8rem 1.5rem 0.9rem 4.5rem;
}

/*=================================================================================================================================*/
/**  追加ブロックスタイル	*/
/*=================================================================================================================================*/
/* アウトライン 白抜きボタン */
.is-style-icon-btn .wp-block-button__link {
  background: #fff;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
  border: 1px solid #104583;
  font-size: 1.9rem;
  color: #104583 !important;
  font-weight: bold;
  padding: 1rem 0.5rem;
  -webkit-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
  -moz-box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
  box-shadow: 0px 0px 5px 0px rgba(0, 0, 0, 0.15);
}

/* アウトライン 白抜きボタン 並んだ時 */
.is-style-icon-btn {
  display: inline-block;
  min-width: 250px;
}

.is-style-icon-btn + .is-style-icon-btn {
  margin-left: 0;
  margin-top: 20px;
}

/* アイコン戻るボタン */
.is-style-icon-btn_back .wp-block-button__link {
  width: 100%;
  max-width: 300px;
  padding: 1.2rem 4rem;
  text-decoration: none;
  display: inline-block;
  text-align: center;
  text-decoration: none !important;
  font-size: 2rem;
  box-sizing: border-box;
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  -moz-border-radius: 10px;
  -webkit-border-radius: 10px;
  border-radius: 10px;
  margin: 0 6px 0 0;
  background: #e3f1fe;
  box-shadow: 2px 2px #a6a6a6;
  position: relative;
}

.is-style-icon-btn_back .wp-block-button__link:after {
  width: 2rem;
  height: 2rem;
  margin-left: 1rem;
  position: absolute;
  top: 38%;
  left: 2rem;
  background: url(../img/common/icon_next_deep_blue.png) no-repeat;
  background-size: contain;
  content: "";
  transform: rotate(180deg);
}

/* 見出し h2 */
.is-style-h2_cs_01 {
  color: #113766;
  background-color: #a9cbf3;
  letter-spacing: 1px;
  text-shadow: unset;
  font-family: "Noto Sans JP";
  padding: 1.7rem 5rem 1.8rem;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
  margin-bottom: 0;
}

/* 見出し h2 */
.is-style-h2_cs_02 {
  color: #113766;
  letter-spacing: 3px;
  text-shadow: unset;
  font-family: "Noto Sans JP";
  margin: 0;
}

.is-style-h2_cs_02 + p {
  margin: 0;
  letter-spacing: 3px;
  font-size: 1.2rem;
  margin-bottom: 5rem;
}

/* 見出し 背景薄水色 */
.is-style-h_bg_lb {
  background: #eefaff;
}

/* 見出し 背景薄グレー */
.is-style-h_bg_lg {
  background: #f2f2ea;
}

/* 背景パターン */
.bg_ptn_01 {
  background: url(/img/common/bg_logo_L.jpg) right 160px no-repeat;
}

.mptn_01 {
  margin: 1rem 5rem 5rem;
}

.clounm_3 .mptn_01 {
  margin: 1rem 5rem 5rem;
}

.clounm_2 .mptn_01 {
  margin: 1rem 5rem 5rem;
}

#beauty-guide .mptn_01,
#medical-guide .mptn_01 {
  margin: auto;
}

#medical-guide .clounm_3 .mptn_01,
#beauty-guide .clounm_3 .mptn_01 {
  margin: 1rem 5rem 5rem;
}

#medical-guide .clounm_2 .mptn_01,
#beauty-guide .clounm_2 .mptn_01 {
  margin: 1rem 5rem 5rem;
}

.mb50 {
  margin-bottom: 5rem;
}

.mb20 {
  margin-bottom: 2rem;
}

.tal {
  text-align: left;
}

@media (min-width: 768px) {
  .clounm_3 .wp-block-column:not(:first-child) {
    margin-left: 45px !important;
  }
  .clounm_3 .wp-block-column:nth-child(2n) {
    margin-left: 45px !important;
  }
}
@media (max-width: 768px) {
  .clounm_3 .wp-block-column:not(:last-child) {
    margin-bottom: 39px;
  }
  .clounm_3 .wp-block-column:nth-child(2n) {
    margin-bottom: 39px;
  }
}
/* 診療案内 */
.treat_list li {
  border-bottom: 1px solid #cdcdcd;
  list-style-type: none;
  display: flex;
  justify-content: start;
  align-items: center;
}

.treat_list li a {
  color: #37281e;
  text-decoration: none;
  padding: 1.3rem 0rem 1.2rem 3.8rem;
  display: block;
  font-weight: 600;
  position: relative;
}

.treat_list li a:hover {
  text-decoration: underline;
  -webkit-transition: all 0.3s;
  transition: all 0.3s;
}

.treat_list li a:before {
  width: 20px;
  height: 20px;
  background: url(../img/common/icon_01.png) no-repeat;
  background-size: contain;
  content: "";
  position: absolute;
  display: flex;
  justify-content: start;
  align-items: center;
  left: 10px;
}

.treat_list li a span {
  color: #72645d;
  font-size: 12px;
  display: block;
  margin-left: -0.2rem;
  font-feature-settings: "palt";
  font-weight: normal;
}

.treat_list.clounm_1 li {
  width: 100%;
}

.top_bottom_wide_img {
  width: 100%;
  background: url(/img/common/top_bottom_main.png) top center;
}

.top_bottom_wide_img {
  height: 500px;
  margin-bottom: 30px;
}

/*---------------------------------------------
 **  メイン画像
---------------------------------------------*/
.main_img {
  width: 100%;
  position: relative;
  background: url(/img/common/dummy_mainbg.jpg) center top no-repeat #ccc;
}

#top .main_img {
  text-indent: -999em;
  background: unset;
}

.main_h1_wrapper {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 100px 0 0;
}

#top .main_h1_wrapper {
  display: none;
}

.main_h1 {
  display: block;
  text-align: left;
  width: 18em;
  text-shadow: 1px 1px 0 rgba(255, 255, 255, 0.5), -1px -1px 0 rgba(255, 255, 255, 0.2), -1px 1px 0 rgba(255, 255, 255, 0.5), 1px -1px 0 rgba(255, 255, 255, 0.2), 0px 1px 0 rgba(255, 255, 255, 0.5), -1px 0 rgba(255, 255, 255, 0.2), -1px 0 0 rgba(255, 255, 255, 0.5), 1px 0 0 rgba(255, 255, 255, 0.2);
}

#top .main_h1 {
  display: none;
}

/*---------------------------------------------
 **  TOPページスライドショー
---------------------------------------------*/
.slideshow {
  height: 600px;
  list-style-type: none;
  width: 100%;
  position: absolute;
  top: 0;
  left: 0;
  margin: 0 auto;
  padding: 0;
}

.slideshow > li {
  opacity: 0;
  position: absolute;
  transition: opacity 3s ease-in-out; /*フェード時間・イージング*/
}

.slideshow > li.showSlide {
  opacity: 1;
}

.slideshow > li {
  width: 100%;
  height: 100%;
}

/* SP用メディアクエリ */
@media screen and (max-width: 812px) {
  .slideshow {
    width: 100%; /* スライドショー幅（SP）*/
    height: 270px;
  }
}
.main_img_slide_01 {
  background: url(../img/main_img/main_img_01.png) top center no-repeat;
}

.main_img_slide_02 {
  background: url(../img/main_img/main_img_02.png) top center no-repeat;
}

.main_img_slide_03 {
  background: url(../img/main_img/main_img_03.png) top center no-repeat;
}

.main_img_slide_04 {
  background: url(../img/main_img/main_img_04.png) top center no-repeat;
}

.main_img_slide_01,
.main_img_slide_02,
.main_img_slide_03,
.main_img_slide_04 {
  background-size: cover;
}

/*---------------------------------------------
 **  クリニック紹介スライドショー
---------------------------------------------*/
#image-gallery li {
  text-align: center;
}

#image-gallery li img {
  border-radius: 20px;
}

.clinic_ga {
  position: relative;
  overflow: hidden;
}

.lSPager {
  display: none;
}

/*=================================================================================================================================*/
/**  グーテン用 追加CSS	*/
/*=================================================================================================================================*/
.disease_tiryo_wrapper .wp-block-group__inner-container {
  padding: 0;
}

.disease_tiryo_wrapper .wp-block-columns {
  margin-bottom: 1rem;
}

.disease_tiryo_syoujyo {
  background: #eefaff;
  display: flex;
  justify-content: center;
  align-items: center;
}

.disease_tiryo_thiryo {
  background: #f2f2ea;
  display: flex;
  justify-content: center;
  align-items: center;
}

.disease_tiryo_syoujyo h3,
.disease_tiryo_thiryo h3 {
  margin-bottom: 0 !important;
  padding: 1rem;
  font-size: 2.3rem;
}

.disease_tiryo_inner_p {
  padding-top: 1rem;
}

/* 見出し 背景薄グレー */
.is-style-p_under_line_01 {
  background-color: #000000;
}

/*-----------------------------------------------------	*/
/*  個別指定 for PC	*/
/*-----------------------------------------------------	*/
@media screen and (min-width: 416px) {
  .disease_tiryo_syoujyo,
  .disease_tiryo_thiryo {
    flex-basis: 124px;
  }
}
/*---------------------------------------------
 **  グーテン 付与クラス
---------------------------------------------*/
.pLR_1per {
  padding: 0 1%;
}

.pLR_2per {
  padding: 0 2%;
}

.pLR_4per {
  padding: 0 4%;
}

.pLR_5per {
  padding: 0 5%;
}

.pTB_1per {
  padding: 1% 0;
  box-sizing: border-box;
}

.pALL_1per {
  padding: 1%;
  box-sizing: border-box;
}

.lh170 {
  line-height: 1.7;
}

.mb0 {
  margin-bottom: 0 !important;
}

/* ミダシ */
.bg_typ_01,
.treat_main ul {
  font-size: 2.3rem;
  font-weight: normal;
  border-radius: 4px;
  padding: 2.5rem 5% 1.7rem;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  border-top: 1px solid #d6d6d6;
  border-bottom: 1px solid #d6d6d6;
  justify-content: center;
}

.bg_typ_01 li,
.treat_main ul li {
  margin-right: 3rem;
  margin-bottom: 1rem;
  list-style-type: none;
  font-size: 1.9rem;
  color: #2e4692;
  font-weight: 600;
}

.bg_typ_01 li strong,
.treat_main ul li strong {
  display: inline-block;
  font-size: 14px;
  text-align: center;
}

.bg_typ_01 li::before,
.treat_main ul li::before {
  position: relative;
  top: -2px;
  left: -0.8rem;
  display: inline-block;
  width: 12px;
  height: 12px;
  content: "";
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
  background: #efeadd;
}

/*---------------------------------------------
 **  診療詳細ページ
---------------------------------------------*/
/* 診療案内リスト */
.treat_main ul {
  font-size: 2.3rem;
  justify-content: left;
  margin: 0 0 2.3rem;
}

.treat_main ul li {
  margin-right: 5rem;
}

.treat_main ol {
  font-size: 2.3rem;
  justify-content: left;
  margin: 0 0 2.3rem;
}

.treat_main ol li {
  margin-right: 5rem;
}

/* 術後の注意点 */
ul.attention_list {
  border-top: unset;
  border-bottom: unset;
  padding: 1.5rem 5% 1.7rem;
}

ul.attention_list li {
  color: #000000;
  font-size: 1.6rem;
}

ul.attention_list li::before {
  background: #faa495;
}

/* テーブル */
div.treat_main table {
  width: 100%;
}

div.treat_main table th {
  padding: 1rem;
  text-align: center;
}

div.treat_main table td {
  padding: 1rem;
}

/* ｈ４ */
.h_style_01 {
  font-family: "Noto Serif JP";
  font-size: 2rem;
  color: #323e88;
  padding: 0 0 0.7rem;
}

.flow_wrap .wp-block-group {
  background: #fcfaf8;
  padding-bottom: 3rem;
}

.flow_wrap .wp-block-image {
  margin-bottom: 0;
}

.flow_wrap .wp-block-image img {
  display: block;
}

.flow_wrap h5 {
  background: #efeadd;
  font-size: 1.8rem;
  color: #121f25;
  padding: 3rem 5rem 2rem;
  font-family: "Noto Sans JP";
  margin-bottom: 2rem;
  position: relative;
}

.flow_wrap h5:after {
  position: absolute;
  top: 20px;
  right: -24px;
  content: "";
  width: 0;
  height: 0;
  border-style: solid;
  border-width: 26px 0 26px 25px;
  border-color: transparent transparent transparent #c8b597;
}

.flow_wrap .wp-block-column:nth-child(3n) h5:after {
  display: none;
}

.flow_wrap h5 strong {
  color: #c7b497;
  font-size: 1.2rem;
  display: block;
  letter-spacing: 4px;
}

.flow_wrap p {
  margin: 0 3rem;
}

@media (min-width: 768px) {
  .flow_wrap .wp-block-column:not(:first-child) {
    margin-left: 40px;
  }
  .flow_wrap .wp-block-column:nth-child(2n) {
    margin-left: 40px;
  }
}
/*-----  よくあるご質問--------------------*/
.treat_main .tenteki_block {
  margin-bottom: 10vh;
}

.treat_main .tenteki_effect_list {
  font-size: 2.3rem;
  border-radius: 0;
  padding: 0;
  margin: 0;
  display: block;
  border: none;
  width: fit-content;
}

.treat_main .tenteki_effect_list li {
  margin: 0 0 1rem;
  list-style-type: none;
  font-size: 2.2rem;
  font-family: "Noto Sans JP";
  color: #344AA9;
  font-weight: 600;
  position: relative;
  display: flex;
  align-items: center;
  gap: 16px;
  background: #eaedf4;
  padding: 5px 24px 5px 12px;
}

.treat_main .tenteki_effect_list li::before {
  position: relative;
  top: 0;
  left: 0;
  display: inline-block;
  width: 18px;
  height: 18px;
  content: "";
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 0;
  background: #FFF;
}

.treat_main .tenteki_effect_list li::after {
  content: "";
  display: block;
  position: absolute;
  top: 5px;
  left: 13px;
  width: 20px;
  height: 10px;
  border-left: 3px solid #344AA9;
  border-bottom: 3px solid #344AA9;
  transform: rotate(-45deg);
}

.tenteki_block .wp-block-table {
  margin: 0;
}

/*---------------------------------------------
 **  よくあるご質問
---------------------------------------------*/
.faq h3 {
  background: #eaedf4;
  position: relative;
  height: 60px;
  padding-left: 9rem;
  padding-top: 1.2rem;
  color: #121f25;
  font-family: "Noto Sans JP";
  _zoom: 1;
  overflow: hidden;
  box-sizing: border-box; /*通常の記述*/
  -webkit-box-sizing: border-box; /*Google ChromeやSafariの機能を利用*/
  -moz-box-sizing: border-box; /*Firefoxの機能を利用*/
  text-shadow: unset;
  font-size: 1.8rem;
  display: flex;
  justify-content: flex-start;
  align-items: center;
}

.faq h3 strong {
  background: #395198;
  position: absolute;
  top: 0;
  left: 0;
  width: 60px;
  height: 60px;
  display: flex;
  justify-content: center;
  align-items: center;
  font-family: "Noto Serif JP";
  color: #fff;
}

.faq h3 + p {
  padding-left: 8.8rem;
  margin-bottom: 5.5rem;
}

/*---------------------------------------------
 **  治療方法
---------------------------------------------*/
.cf_pricelist {
  max-width: 1080px;
  margin: 0 auto;
}

.cf_pricelist table {
  width: 100% !important;
}

.cf_pricelist table th {
  max-width: 450px;
  width: unset !important;
  padding: 0.8em 1em !important;
}

.cf_pricelist table td {
  padding: 0.6em 1em !important;
}

.cf_pricelist table tr:nth-of-type(1) th {
  width: 330px !important;
  max-width: 200px;
}

/*---------------------------------------------
 **  ドクター紹介
---------------------------------------------*/
/* テーブル */
.table_ptn_01 table {
  width: 100%;
}

.table_ptn_01 table th {
  padding: 0.1rem !important;
  text-align: center;
}

.table_ptn_01 table td {
  padding: 1.1rem 1.2rem !important;
}

.table_ptn_01 table tr td:nth-of-type(1) {
  width: 100px;
  background: #f9f8f4;
}

/*---------------------------------------------
 ** 個別指定 for スマートフォン
---------------------------------------------*/
@media screen and (min-width: 416px) and (max-width: 767px) {
  .doctor_img {
    display: none;
  }
}
/* リスト */
ul.list_ptn_01 {
  margin-bottom: 3rem;
}

ul.list_ptn_01 li,
#main_contents ul li {
  position: relative;
  list-style: none;
  font-family: "Noto Sans JP";
}

ul.list_ptn_01 li:before,
#main_contents ul li:before {
  font-size: 1.1rem;
  top: -2px;
  left: 0px;
  color: #3b5198;
  content: "●";
  position: relative;
  margin-right: 0.9rem;
}

.doctor_name img {
  height: 42px;
  width: 143px;
  margin-top: 10px;
}

.new-posts-wrap {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-start;
  margin-bottom: 30px;
}

.new-posts {
  background: #FFF;
  -moz-border-radius: 8px;
  -webkit-border-radius: 8px;
  border-radius: 8px;
  _zoom: 1;
  overflow: hidden;
  border: 1px solid #D5D5D5;
  /* box-shadow */
  box-shadow: 2px 2px 0px 1px #E5E7F1;
  margin-right: 20px;
  margin-bottom: 20px;
}

.new-posts a {
  text-decoration: none;
}

.img-box-new-posts img {
  height: 230px;
  object-fit: cover;
}

.new-posts_category {
  font-size: 12px;
  display: block;
  background: #EAEDF4;
  width: 98px;
  text-align: center;
  -moz-border-radius: 50px;
  -webkit-border-radius: 50px;
  border-radius: 50px;
  color: #3b5198;
  padding: 0.3rem 0.8rem;
  margin: -15px auto 0 !important;
  position: relative;
  text-decoration: none;
}

.new-posts-inner {
  padding: 1rem;
}

.news-ttl {
  font-weight: bold;
  font-size: 1.4rem;
}

.news-contents {
  color: #3b5198;
}

@media (max-width: 767px) {
  .new-posts-wrap {
    width: 100%;
  }
  .new-posts {
    width: 47% !important;
    margin-right: 15px;
  }
  .new-posts:nth-of-type(2n) {
    margin-right: 0;
  }
  .img-box-new-posts img {
    height: 134px;
  }
  .kako_btn {
    padding: 1.3rem !important;
  }
}
.price-p {
  font-size: 80%;
  color: #727070;
}

.wp-block-video {
  height: 470px;
}

.wp-block-video video {
  height: 100%;
}

/* メディカルコスメ追加 20200831　*/
.medi_cosme_read_bs {
  background: url(../info/wp-content/uploads/2020/08/bs_img00.png) no-repeat right top;
  background-size: 40% auto;
  padding: 0% 40% 5% 0;
}

.medi_cosme_read_zo {
  margin-bottom: 20px;
}

.medi_cosme_read_zo_img {
  width: 90%;
  margin: 0 auto;
  max-width: 851px;
}

ol.zo_list {
  width: 95%;
  margin: 30px auto 60px;
  font-size: 2rem;
  display: flex;
  flex-wrap: wrap;
  justify-content: space-between;
}

.zo_list li {
  width: 45%;
  margin-bottom: 10px;
}

.zo_program {
  width: 90%;
  margin: 0 auto;
}

.zo_program > div:nth-child(2) img {
  max-width: 57px;
  margin-top: 120%;
}

.zo_read {
  font-size: 130%;
  line-height: 2;
}

.zo_text {
  background: url(../info/wp-content/uploads/2020/10/staff_icon.png) #eaedf4 no-repeat center left 15px;
  background-size: 100px auto;
  font-size: 160%;
  padding: 3% 5% 3% 130px;
  line-height: 2;
}

.zo_img {
  max-width: 700px;
  margin: 0 auto;
}

.medi_cosme_read_bs strong, .medi_cosme_read_zo strong {
  color: #323e88;
  font-size: 2rem;
  margin-bottom: 0px;
  display: block;
}

.media_cosme h3 em {
  font-size: 80%;
  display: block;
}

.media_cosme ul {
  font-size: 2.3rem;
  font-weight: normal;
  border-radius: 4px;
  padding: 0.5rem 0 0.5rem !important;
  position: relative;
  display: flex;
  flex-wrap: wrap;
  border-top: none;
  border-bottom: none;
  justify-content: flex-start;
  margin-bottom: 10px;
}

.media_cosme ul li {
  margin-right: 10px;
  margin-bottom: 10px;
  list-style-type: none;
  font-size: 1.5rem;
  color: #2e4692;
  font-weight: 600;
  background: #eaedf4;
  padding: 3px 10px;
  text-align: center;
  display: inline-block;
}

.media_cosme ul li::before {
  content: "";
  background: none;
  width: 0;
  height: 0;
}

.media_cosme .media_cosme_ul_detail {
  margin-left: 1.5rem;
}

.media_cosme .media_cosme_ul_detail li {
  margin-right: 10px;
  margin-bottom: 10px;
  list-style-type: none;
  font-size: 1.8rem !important;
  color: #122025;
  font-weight: normal;
  background: none;
  padding: 3px 10px;
  text-align: left;
  display: inline-block;
  font-family: "Noto Sans JP";
  position: relative;
}

.media_cosme .media_cosme_ul_detail li::before {
  content: "・";
  background: none;
  position: absolute;
  left: -7px;
  top: 7px;
}

.media_cosme h4 {
  padding: 0 0 2.6rem;
}

.media_cosme figure {
  text-align: center;
}

.environ {
  width: 90%;
  max-width: 380px;
  margin: -20px auto 40px;
}

.envi_notice {
  width: 85%;
  border: 2px solid #d91919 !important;
  padding: 3% 3%;
  margin: 10px auto !important;
}

.envi_notice li {
  color: #d91919 !important;
  margin-left: 2rem !important;
  text-indent: -1.5rem !important;
}

.envi_notice li strong {
  font-size: 120% !important;
}

.envi_ttl {
  max-width: 751px;
  margin: 0 auto;
}

.envi_chart {
  width: 90% !important;
  max-width: 1024px !important;
  margin: 0 auto;
}

.envi_pdf {
  width: 100% !important;
  max-width: 1000px;
  margin: 0 auto 0;
}

#ct01, #ct02, #ct03, #ct04, #ct05 {
  margin-top: 50px;
  display: block;
  padding: 30px;
}

.luscious_img01 {
  max-width: 820px;
  margin: 0 auto;
}

.luscious_img02 {
  max-width: 730px;
  margin: 0 auto;
}

/* ダーマペン */
.derma_img01 {
  max-width: 290px;
  margin-right: 0;
  margin-top: 30px;
}

.derma_read, .derma_read2 {
  width: 90%;
}

.derma_read strong {
  color: #323e88;
  font-size: 2rem;
  margin-bottom: 10px;
  margin-top: 30px;
  display: block;
}

.derma_read em {
  background: linear-gradient(transparent 60%, #b9e7f9 60%);
  font-style: normal;
}

.derma_read_box {
  margin: 40px auto 20px !important;
}

.derma_read2 strong {
  color: #323e88;
  font-size: 120%;
  margin-bottom: 10px;
}

.derma_read_li li {
  color: #323e88;
  font-size: 120%;
  margin-bottom: 10px;
  display: inline-block;
  margin-right: 10px !important;
  background: #e1f4f3;
  border-radius: 10px;
  border: 1px solid #d6d6d6;
  padding: 5px 10px;
}

.treat_main .derma_read_li {
  border: none;
  padding: 0;
  margin: 0;
}

.treat_main .derma_read_li li::before {
  content: "";
  width: 0;
  height: 0;
}

.derma_img03 {
  max-width: 470px;
  margin-right: 0;
}

.derma_osusume {
  background: url(../info/wp-content/uploads/2020/12/derma_img02.png) no-repeat right top;
  background-size: 45% auto;
  padding-right: 30% !important;
  margin-top: -60px;
}

.derma_osusume h4 {
  font-size: 180%;
  font-family: "Noto Serif JP";
  text-align: center;
}

.derma_osusume li {
  width: 43%;
  text-indent: -1em;
  margin-left: 1em;
  margin-right: 1em !important;
  font-size: 2.2rem !important;
}

.derma_osusume li::before {
  background: #2e4692 !important;
}

.derma_ba div {
  margin-bottom: 0;
}

.derma_before {
  position: relative;
}

.derma_before::after {
  content: "";
  width: 0;
  height: 0;
  border-top: 25px solid transparent;
  border-bottom: 25px solid transparent;
  border-left: 25px solid #2e4692;
  position: absolute;
  right: -16%;
  top: 35%;
  z-index: 999;
}

.derma_ba_small img {
  padding: 35% 0 0;
}

.derma_ba2 {
  width: 90%;
  margin: 0 auto;
}

.derma_ba2 .derma_before::after {
  content: "";
  width: 0;
  height: 0;
  border-top: 25px solid transparent;
  border-bottom: 25px solid transparent;
  border-left: 25px solid #2e4692;
  position: absolute;
  right: -10%;
  top: 35%;
  z-index: 999;
}

.derma_merit_h3 {
  width: 86%;
}

.derma_merit ul {
  border: 0px !important;
}

.derma_merit ul li {
  width: 100%;
  list-style: none;
  border: 1px solid #d6d6d6;
  border-radius: 10px;
  background: #e1f4f3;
  margin: 30px 0 0;
  padding: 5%;
  text-align: center;
}

.derma_merit ul li::before {
  display: none;
}

.derma_merit .wp-block-column:nth-child(2n) {
  margin-left: 5px;
}

.darma_m_box img {
  max-width: 80px;
}

.darma_m_box2 img {
  max-width: 140px;
}

.derma_h4 {
  font-size: 2.4rem;
  margin-bottom: 0rem;
  font-weight: 600;
  background: #0064c2; /* Old browsers */
  background: -moz-linear-gradient(left, #0064c2 0%, #cadcec 90%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #0064c2 0%, #cadcec 90%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #0064c2 0%, #cadcec 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#0064c2", endColorstr="#cadcec",GradientType=1 ); /* IE6-9 */
  font-feature-settings: "palt";
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 1px 2px 1px rgba(0, 0, 0, 0.2);
  padding: 0.8rem 2.5rem 1.1rem !important;
  margin-bottom: 1.5rem;
  font-family: "Noto Serif JP";
}

.prx-33 {
  font-size: 2.4rem;
  margin-bottom: 0rem;
  font-weight: 600;
  background: #0064c2; /* Old browsers */
  background: -moz-linear-gradient(left, #0064c2 0%, #cadcec 90%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #0064c2 0%, #cadcec 90%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #0064c2 0%, #cadcec 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#0064c2", endColorstr="#cadcec",GradientType=1 ); /* IE6-9 */
  font-feature-settings: "palt";
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 1px 2px 1px rgba(0, 0, 0, 0.2);
  padding: 0.8rem 2.5rem 1.1rem !important;
  margin-bottom: 1.5rem;
  font-family: "Noto Serif JP";
}

h4.peel {
  font-size: 2.4rem;
  margin-bottom: 0rem;
  font-weight: 600;
  background: #771c47; /* Old browsers */
  background: -moz-linear-gradient(left, #771c47 0%, #ffe3f0 90%); /* FF3.6-15 */
  background: -webkit-linear-gradient(left, #771c47 0%, #ffe3f0 90%); /* Chrome10-25,Safari5.1-6 */
  background: linear-gradient(to right, #771c47 0%, #ffe3f0 90%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */
  filter: progid:DXImageTransform.Microsoft.gradient( startColorstr="#771c47", endColorstr="#ffe3f0",GradientType=1 ); /* IE6-9 */
  font-feature-settings: "palt";
  letter-spacing: 2px;
  color: #fff;
  text-shadow: 1px 2px 1px rgba(0, 0, 0, 0.2);
  padding: 0.8rem 2.5rem 1.1rem !important;
  margin-bottom: 1.5rem;
  font-family: "Noto Serif JP";
}

.derma_m_point li {
  font-size: 85% !important;
  list-style: none;
  border: 1px solid #d6d6d6;
  border-radius: 10px;
  background: #e1f4f3 !important;
  margin: 5px 0 0;
  padding: 5%;
  text-align: center;
}

.derma_m_point + .wp-block-columns {
  margin-bottom: 0;
}

.derma_seibun {
  margin: 0 0 5px;
}

.derma_list_w100 li {
  width: 100%;
}

.derma_mask_read {
  font-size: 120%;
  font-family: "Noto Serif JP";
  color: #ad7a58;
  margin: 15px 0 5px;
}

.derma_mask_w {
  max-width: 432px;
  margin: 10px auto;
}

.mt-40 {
  margin-top: -40px;
}

.derma_flow {
  width: 94%;
  margin: 0 3% !important;
  counter-reset: item;
  list-style-type: none;
  border: 0px !important;
}

.derma_flow li {
  width: calc(100% - 1.5em);
  margin-bottom: 20px !important;
  background: #eaedf4;
  padding: 12px 2em 1.5em 12px;
  font-family: "Noto JP";
  font-size: 70% !important;
  color: #121f25 !important;
  box-sizing: border-box;
  text-align: left;
  display: flex;
  align-items: center;
}

.derma_flow li::before {
  font-size: 120%;
  color: #fff;
  padding: 2px 10px;
  width: auto !important;
  height: auto !important;
  display: inline-block;
  border-radius: 0 !important;
  background: #395198 !important;
  counter-increment: item !important;
  content: "STEP" counter(item) !important;
  font-family: "Noto JP";
  margin-left: 10px;
}

.flow_peel li {
  background: #f9ebf1;
}

.flow_peel li::before {
  background: #771c47 !important;
}

.derma_flow2 li {
  padding-bottom: 1em !important;
}

.derma_flow li strong {
  min-width: 210px;
  font-size: 110% !important;
  display: inline-block;
  padding-left: 10px;
  padding-right: 10px;
  text-align: left !important;
}

.derma_flow li em {
  font-style: normal;
}

.derma_mask_p {
  margin-bottom: 0px !important;
}

.derma_mask_merit {
  width: 95%;
  margin: 0 auto 50px;
  background: #eaedf4;
  border: 1px solid #d6d6d6;
  border-radius: 10px;
  padding: 0;
}

.derma_mask_merit h4 {
  text-align: center;
  position: relative;
  margin: 0 auto 10px;
  padding: 1rem 0 0;
}

.derma_mask_merit h4 strong {
  display: inline-block;
  font-family: "Noto Serif JP";
  font-size: 100%;
}

.derma_mask_merit ul {
  background: #fff;
  margin-bottom: 0;
  border-radius: 0 0 10px 10px;
  border: 0px;
}

.derma_mask_merit ul li {
  font-family: "Noto Sans JP";
  color: #122025;
  font-weight: normal;
  font-size: 80%;
  margin-right: 0;
  text-indent: -1em;
  margin-left: 1em;
}

.derma_vel {
  text-align: center;
}

.derma_vel p {
  font-family: "Noto Serif JP";
  color: #b78a33;
  font-size: 170%;
  font-weight: bold;
  text-align: center;
}

.derma_vel p br {
  display: none;
}

.derma_vel img {
  width: 100%;
  max-width: 900px;
  margin: 0 auto;
}

.derma_vel_ba div {
  margin-bottom: 0;
  display: flex;
}

.derma_vel_ba div img {
  width: 90%;
  max-width: 325px;
  margin: 0 5%;
}

.derma_vel_before {
  position: relative;
}

.derma_vel_before::after {
  content: "";
  width: 0;
  height: 0;
  border-top: 20px solid transparent;
  border-bottom: 20px solid transparent;
  border-left: 20px solid #2e4692;
  position: absolute;
  right: -12px;
  bottom: 50%;
  z-index: 999;
  margin: 0 auto;
}

.derma_voice ul {
  border: 0px;
  padding: 0;
}

.derma_voice ul li {
  list-style: none;
  background-color: #f9ebf1;
  padding: 15px 20px;
  margin: 0 10px 20px;
  color: #122025;
  font-family: "Noto Sans JP";
}

.derma_voice ul li::before {
  width: 0;
  height: 0;
}

.derma_voice img {
  width: 90%;
  margin: 0 auto;
  max-width: 400px;
}

.h4_peel {
  color: #771c47;
}

.flow_peel li {
  background: #f9ebf1;
}

.flow_peel li::before {
  background: #771c47 !important;
}

.faq_peel h3 {
  background: #f9ebf1;
}

.faq_peel h3 strong {
  background: #771c47;
}

.derma_prx_faq strong {
  display: inline-block;
  padding: 10px 0 0;
  margin: 0;
}

/*---------------------------------------------
 **  20220304_plusRestore追加分
---------------------------------------------*/
.plusrestore_box {
  background-color: #fff7f9;
  box-sizing: border-box;
  border-radius: 10px;
  margin: 1rem auto;
}

.plusrestore_box h4 {
  background-color: #F0CDD1;
  color: #FF7373;
  padding: 1rem 2rem;
  border-radius: 10px 10px 0 0;
}

.plusrestore_box ul {
  display: flex;
  margin: 1rem auto;
  border: none;
  list-style: none;
  box-sizing: border-box;
  justify-content: center;
  padding: 2rem;
}

.plusrestore_box ul li:before {
  background: #FF7373;
}

.plusrestore_box ul li {
  color: #FF7373;
  font-family: "Noto Sans JP";
  font-size: 16px;
}

/*
ul.plusrestore_box li{
  width: 100%;
  background-color: #fff7f9;
  border-radius: 10px;
  box-sizing: border-box;
  padding: 1rem;
  font-weight: bold;
  color: #fd7c7c;
  font-size: 1.8rem;
  margin-bottom: 5px;
  font-family: "Noto Sans JP";
}
ul.plusrestore_box{
    width: 100%;
    font-size: unset;
    font-weight: unset;
    border-radius: unset;
    padding: unset;
    position: unset;
    display: unset;
    flex-wrap: unset;
    border-top: unset;
    border-bottom: unset;
    justify-content: unset;
    margin-bottom: 1rem;
  }
*/
.plusrestore_img img {
  max-width: 200px;
  margin: 1rem auto;
}

.alinitemCenter {
  align-items: center;
}

.notoMincho {
  font-family: "Noto Serif JP";
}

/*---------------------------------------------
 **  20221124　メディカルコスメに料金追加
---------------------------------------------*/
.cosume_price {
  font-family: "Noto Serif JP";
  text-align: right;
  padding-right: 2rem;
  font-weight: bold;
  font-size: 2.6rem;
  padding: 0.5rem 1rem 0.5rem 0;
  box-sizing: border-box;
}

.m-b-none {
  margin-bottom: 0 !important;
}

.bnr_area .item img {
  width: 100%;
}

.cosume_price .tax {
  font-size: 1.8rem;
}


/*---------------------------------------------
 **  2023.7.4 アップデートによるCSS差分変更
---------------------------------------------*/
body .is-layout-flex {
  align-items: flex-start !important;
}

body .is-layout-flex {
  gap: unset !important;
}

.wp-block-button {
  width: 100%;
}

body .wp-block-button__link {
  color: #3b5198;
  background-color: #FFF !important;
  border-radius: unset !important;
  box-shadow: none;
  text-decoration: none;
  padding: 1.6rem 4rem 1.5rem 4rem;
}

@media (min-width: 768px) {
  .wp-block-button__link {
    font-size: unset !important;
  }
}
/*---------------------------------------------
 **  SP
---------------------------------------------*/
@media (max-width: 767px) {
  body .wp-block-columns {
    margin-bottom: unset !important;
  }
  .is-layout-flex {
    flex-direction: column;
  }
}
/*---------------------------------------------
 **  料金表（再利用ブロック 編集表）
---------------------------------------------*/
.wp-block-table {
  border-collapse: collapse; /* セルの間にボーダーを付けるための設定 */
  width: 100%;
  margin: 4rem 0;
  box-sizing: border-box;
}

.wp-block-table th,
.wp-block-table td {
  border: 1px solid #ccc; /* セルのボーダーを設定 */
  padding: 8px; /* セルの内側の余白を設定 */
  text-align: left; /* テキストを左寄せにする */
}

.wp-block-table th {
  background-color: #f2f2f2; /* ヘッダーセルの背景色を設定 */
}

/*---------------------------------------------
 **  2025.2.15 トップページに連携医療機関
---------------------------------------------*/
#relationClinic h2 {
  margin-bottom: 40px;
}

#relationClinic .clounm_wrapper {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 30px;
  min-width: 900px;
  width: fit-content;
}

#relationClinic .clounm_wrapper h3 {
  font-size: 2rem;
  background: none;
  text-shadow: none;
  color: #1b4364;
  padding: 0.8em 0;
  border-bottom: 1px solid #1b4364;
  border-top: 1px solid #1b4364;
  margin-bottom: 1rem;
  text-align: center;
}

#relationClinic .clounm_wrapper ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

#relationClinic .clounm_wrapper ul li {
  margin-bottom: 0.5rem;
}