@charset "UTF-8";
/* Scss Document */
/* =======================================================================
 共通項目 
======================================================================= */
/*関数*/
/* ----------------------------------------------------------- 関数
----------------------------------------------------------- */
/*サイトの横幅*/
/*media screen*/
/*文字SP*/
/*文字PC*/
/*基本フォント*/
/*游明朝*/
/*基本文字色*/
/*基本背景色PC*/
/*白*/
/*濃いピンク*/
/*オレンジ*/
/*薄いピンク*/
/*ピンク*/
/*薄いピンク*/
/*灰色*/
/*水色*/
/*青*/
/*水色*/
/*青2*/
/*ピンク1*/
/*青*/
/*水色*/
/*ピンク*/
/*オレンジ*/
/*オレンジ*/
/*ピンク*/
/*灰色*/
/*影*/
/*緑*/
/*青*/
/*緑*/
/*青緑*/
/*青*/
/* ----------------------------------------------------------- 特殊フォント読込
----------------------------------------------------------- */
@font-face { font-family: 'notoserif'; src: url(../font/NotoSerifJP-Regular.otf); font-weight: normal; font-style: normal; }
@font-face { font-family: 'notoserif_semibold'; src: url(../font/NotoSerifJP-SemiBold.otf); font-weight: normal; font-style: normal; }
/* ----------------------------------------------------------- フォントサイズ基本
----------------------------------------------------------- */
html { font-size: calc( 100vw / 32 ); overflow-y: auto; font-family: "メイリオ", Meiryo, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Arial, sans-serif; color: #404040; background-color: #ffffff; padding: 0 0 17vw 0; }

@media screen and (min-width: 768px), print { html { font-size: 62.5%; overflow-y: scroll; font-family: "メイリオ", Meiryo, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Arial, sans-serif; color: #404040; background-color: #ffffff; padding: 0; } }
/* ----------------------------------------------------------- 構成
----------------------------------------------------------- */
body { position: relative; width: 100%; margin: 0 auto; }

section { height: auto; overflow: hidden; margin: 3rem 0 0 0; }
section.first { margin: 0 0 0 0; }

.sentence { height: auto; overflow: hidden; }

.pc_none { display: block; }

.sp_none { display: none; }

.pc_none_span { display: inline; }

.sp_none_span { display: none; }

.text_bold { font-weight: bold; }

.d_block { display: block; }

.d_flex { display: flex; }

.d_inlineFlex { display: inline-flex; }

.align-center { align-items: center; }

.gap10 { gap: 1rem; }

.w100 { width: 100%; }

.auto { margin: auto; }

.center { text-align: center; }

.p_initial { padding: initial !important; }

.mt_20 { margin-top: 2rem; }

.mt_30 { margin-top: 3rem; }

.number_warp { counter-reset: counter; }
.number_warp .number { counter-increment: counter; }
.number_warp .number::before { content: counter(counter) ". "; }

@media screen and (min-width: 768px), print { body { position: relative; z-index: 0; overflow: hidden; min-width: 1300px; }
  section { height: auto; overflow: hidden; margin: 0 0 0 0; }
  section.first { margin: 0 0 0 0; }
  .pc_none { display: none; }
  .sp_none { display: block; }
  .pc_none_span { display: none; }
  .sp_none_span { display: inline; } }
/* -----------------------------------------------------------
　枠
----------------------------------------------------------- */
article { height: auto; width: 100%; margin: 0 auto 0 auto; padding: 0; }

.wrapper { height: auto; width: 100%; margin: 0 0 0 0; padding: 2rem 0 0 0; }

.wrapper_low { height: auto; width: 100%; margin: 0 0 0 0; padding: 2rem 0 0 0; }

.main { height: auto; width: 96%; margin: 0 auto 3rem auto; padding: 0 0 0 0; }

.main_low { height: auto; width: 96%; margin: 0 auto 3rem auto; padding: 0 0 0 0; }

@media screen and (min-width: 768px), print { article { height: auto; width: 100%; margin: 78px auto 0 auto; padding: 0; }
  .wrapper { height: auto; width: 1300px; margin: 90px auto 0 auto; padding: 0; }
  .wrapper_low { height: auto; width: 1300px; margin: 90px auto 60px auto; padding: 0 0 0 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .main { height: auto; width: 770px; margin: 0; padding: 0; }
  .main_low { height: auto; width: 1300px; margin: 0 0 100px 0; padding: 0; } }
/* -----------------------------------------------------------
　ヘッダ
----------------------------------------------------------- */
header { display: block; margin: 0 auto; height: auto; }
header .head_frame { background-color: #ffffff; width: 100%; padding: 0; height: auto; }
header .head_frame .head_logo { position: fixed; top: 0; z-index: 99; background: #fff; width: calc(100% - 6.8rem); padding: 6vw 6rem 0 .8rem; display: flex; align-items: center; }
header .head_frame .head_logo .head_logo_mark { max-width: 20vw; }
header .head_frame .head_logo img { width: 100%; height: auto; }
header .head_frame .qr { width: 96%; height: auto; border: #f0855d 2px solid; border-radius: 4px; background-color: rgba(255, 255, 255, 0.9); display: -webkit-flex; display: flex; -webkit-justify-content: space-around; justify-content: space-around; -webkit-align-items: center; align-items: center; -webkit-flex-direction: row; flex-direction: row; color: #f0855d; font-weight: bold; font-size: 1.4rem; padding: 0 0 0 0; box-sizing: border-box; margin: 9rem auto 0 auto; }
header .head_frame .qr br { display: none; }
header .head_frame .head_info { margin: 1rem auto 0 auto; width: 96%; }
header .head_frame .head_info .head_info_access { color: #404040; font-size: 1.4rem; text-align: center; margin: 0; }
header .head_frame .head_info .head_info_access i { color: #eb547b; }
header .head_frame .head_info .head_info_access span { display: block; }
header .head_frame .head_info .head_info_tel { color: #f0855d; font-size: 1.4rem; text-align: center; margin: 0.4rem 0 0 0; font-weight: bold; }
header .head_frame .head_info .head_info_tel span { color: #f0855d; font-size: 2.4rem; }
header .head_frame .head_info .head_info_tel a { color: #f0855d; text-decoration: none; font-size: 2.4rem; }

@media screen and (min-width: 768px), print { header { display: block; width: 100%; margin: 0; height: 115px; overflow: visible; }
  header .head_frame { display: flex; width: 1300px; margin: 0 auto; padding: 0; height: 115px; overflow: visible; position: relative; z-index: 1; }
  header .head_frame .head_logo { background: none; position: unset; width: fit-content; padding: 0; margin: 0; }
  header .head_frame .head_logo .head_logo_mark { padding-top: 6.4rem; margin: 0; }
  header .head_frame .head_logo .head_logo_mark img { height: auto; display: block; }
  header .head_frame .head_logo h1, header .head_frame .head_logo a { display: block; }
  header .head_frame .head_logo h1 img, header .head_frame .head_logo a img { width: 372px; height: auto; margin: 0; }
  header .head_frame .qr { position: absolute; top: -7px; right: 390px; width: 294px; height: 86px; border: #f0855d 2px solid; border-radius: 4px; background-color: rgba(255, 255, 255, 0.9); display: -webkit-flex; display: flex; -webkit-justify-content: space-around; justify-content: space-around; -webkit-align-items: center; align-items: center; -webkit-flex-direction: row; flex-direction: row; color: #f0855d; font-weight: bold; font-size: 1.8rem; padding: 0 15px 0 0; margin: 2.8rem auto 0 auto; box-sizing: border-box; }
  header .head_frame .qr br { display: block; }
  header .head_frame .head_info { margin: 0; width: 370px; position: absolute; right: 0; top: 44px; }
  header .head_frame .head_info .head_info_access { color: #404040; font-size: 1.4rem; text-align: right; margin: 0; }
  header .head_frame .head_info .head_info_access i { color: #eb547b; font-size: 1.8rem; }
  header .head_frame .head_info .head_info_access span { display: inline; }
  header .head_frame .head_info .head_info_tel { color: #f0855d; font-size: 2rem; text-align: right; margin: 2px 0 0 0; font-weight: bold; }
  header .head_frame .head_info .head_info_tel span { color: #f0855d; font-size: 3rem; }
  header .head_frame .head_info .head_info_tel a { color: #f0855d; text-decoration: none; font-size: 3rem; } }
/* -----------------------------------------------------------
　メインナビ
----------------------------------------------------------- */
.main_nav_pc { display: none; }

@media screen and (min-width: 768px), print { .main_nav_pc { display: block; height: 65px; margin: 0; padding: 0; width: 100%; box-sizing: border-box; overflow: visible; position: relative; z-index: 0; background-color: #eb547b; }
  .main_nav_pc.sticky { position: fixed; top: 0; width: 100%; z-index: 1000; /* 必要に応じて調整 */ }
  .main_nav_pc nav { width: 1300px; height: 65px; margin: 0 auto; padding: 0 0 0 0; }
  .main_nav_pc nav ul { list-style-type: none; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; align-items: center; width: 1117px; box-sizing: border-box; height: 65px; padding: 0 0 0 0; position: relative; margin: 0 0 0 183px; background: url("../images/ten.jpg"), url("../images/ten.jpg"), url("../images/ten.jpg"), url("../images/ten.jpg"), url("../images/ten.jpg"); background-repeat: no-repeat,no-repeat,no-repeat,no-repeat,no-repeat; background-position: 139px 30px,293px 30px,491px 30px,643px 30px,902px 30px; }
  .main_nav_pc nav ul li { display: block; text-align: center; box-sizing: border-box; height: 65px; width: auto; }
  .main_nav_pc nav ul li a { text-decoration: none; color: #ffffff; height: 65px; width: 100%; box-sizing: border-box; margin: 0; padding: 0; text-align: center; letter-spacing: 0.1em; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: row; flex-direction: row; font-size: 2rem; font-weight: normal; }
  .main_nav_pc nav ul li a i { margin: 2px 0 0 0; font-size: 1.4rem; }
  .main_nav_pc nav ul li a span { position: relative; }
  .main_nav_pc nav ul li a span::after { position: absolute; bottom: -4px; left: 0; content: ''; width: 100%; height: 4px; transform: scale(0, 1); transform-origin: center top; transition: transform .3s; background: #ffffff; }
  .main_nav_pc nav ul li a span:hover::after { transform: scale(1, 1); }
  .main_nav_pc nav ul li ul { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; display: none; height: auto; margin: 0 0 0 -15px; position: relative; z-index: 99999999999; width: 200px; }
  .main_nav_pc nav ul li ul.open_nav { display: -webkit-flex; display: flex; }
  .main_nav_pc nav ul li ul li { display: block; text-align: center; box-sizing: border-box; width: 200px; height: 40px; line-height: 120%; text-align: center; font-weight: normal; margin: 0 0 0 0; outline-style: none; }
  .main_nav_pc nav ul li ul li a { text-decoration: none; color: #eb547b; background-color: #fff3f6; height: 40px; width: 100%; display: block; box-sizing: border-box; margin: 0; padding: 0 0 0 0; text-align: center; letter-spacing: 0.1em; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 1.6rem; border-bottom: #f2a0b5 1px solid; }
  .main_nav_pc nav ul li ul li a:hover { color: #fff3f6; background-color: #eb547b; transition: all 0.3s ease 0s; }
  .main_nav_pc nav ul li.pc_none { display: none !important; }
  .main_nav_pc nav ul li.home { width: 139px; }
  .main_nav_pc nav ul li.doctor { width: 149px; }
  .main_nav_pc nav ul li.first { width: 193px; }
  .main_nav_pc nav ul li.treatment { width: 171px; }
  .main_nav_pc nav ul li.clinic { width: 215px; }
  .main_nav_pc nav ul li.access { width: 225px; text-align: right; }
  .main_nav_pc nav ul li.access a { display: -webkit-flex; display: flex; -webkit-justify-content: flex-end; justify-content: flex-end; -webkit-align-items: center; align-items: center; } }
/* -----------------------------------------------------------
　キービジュアル
----------------------------------------------------------- */
.key_visual { background-size: cover; background-repeat: no-repeat; background-position: center top; height: 40vw; width: 100%; position: relative; }
.key_visual .key_on { display: none; }

.key_on_sp { width: 96%; margin: 1rem auto 0 auto; }
.key_on_sp .catch_copy { background-color: #f0855d; color: #ffffff; padding: 0.4rem; box-sizing: border-box; margin: 0 0 0.8rem 0; text-align: center; font-size: 1.2rem; }
.key_on_sp .catch_copy2 { background-color: #f0855d; color: #ffffff; padding: 0.4rem; box-sizing: border-box; margin: 0 0 0.8rem 0; text-align: center; font-size: 1.2rem; }
.key_on_sp .key_new { background-color: #eb547b; color: #ffffff; padding: 0.4rem; box-sizing: border-box; margin: 0 0 0.8rem 0; font-weight: bold; text-align: center; }
.key_on_sp .key_new span { font-size: 1.2rem; }
.key_on_sp .key_event { background-color: #eb547b; color: #ffffff; padding: 0.4rem; box-sizing: border-box; margin: 0 0 0.8rem 0; font-weight: bold; text-align: center; }
.key_on_sp .key_event span { font-size: 1.2rem; }

.key_visual_low { background: url(../images/key_visual_low.jpg) no-repeat; background-size: cover; background-position: center top; height: 30vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; }
.key_visual_low h1 { width: 100%; height: 30vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; }
.key_visual_low h1 span { background-color: #f0855d; color: #ffffff; font-weight: normal; font-size: 2.2rem; text-align: center; letter-spacing: 0.1em; padding: 0.6rem 1rem; }

@media screen and (min-width: 768px), print { .key_visual { background-size: cover; background-repeat: no-repeat; background-position: center top; height: 700px; width: 100%; position: relative; z-index: -10; }
  .key_visual .key_on { width: 1300px; height: 700px; margin: 0 auto; position: relative; display: block; }
  .key_visual .key_on .catch_copy { background-color: #f0855d; color: #ffffff; padding: 0 0 0 12px; box-sizing: border-box; margin: 0; text-align: left; font-size: 2.4rem; letter-spacing: 0.1em; width: 764px; height: 42px; position: absolute; top: 394px; left: 0; z-index: 9999; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }
  .key_visual .key_on .catch_copy2 { background-color: #f0855d; color: #ffffff; padding: 0 0 0 12px; box-sizing: border-box; margin: 0; text-align: left; font-size: 2.4rem; letter-spacing: 0.1em; width: 840px; height: 42px; position: absolute; top: 450px; left: 0; z-index: 9999; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }
  .key_visual .key_on .key_new { background-color: #eb547b; color: #ffffff; padding: 0 0 0 0; box-sizing: border-box; margin: 0; font-weight: bold; text-align: center; width: 392px; height: 60px; position: absolute; top: 510px; left: 0; z-index: 9999; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 3.6rem; letter-spacing: 0.05em; }
  .key_visual .key_on .key_new span { font-size: 2.6rem; }
  .key_visual .key_on .key_event { background-color: #eb547b; color: #ffffff; padding: 0 0 0 0; box-sizing: border-box; margin: 0; font-weight: bold; text-align: center; width: 590px; height: 60px; position: absolute; top: 540px; left: 422px; z-index: 9999; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 3.6rem; letter-spacing: 0.05em; }
  .key_visual .key_on .key_event span { font-size: 2.2rem; margin: 0 12px 0 0; }
  .key_on_sp { display: none; }
  .key_visual_low { background: url(../images/key_visual_low.jpg) no-repeat; background-size: cover; background-position: center top; height: 400px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; }
  .key_visual_low h1 { width: 100%; height: 400px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; padding: 5px 0 0 0; box-sizing: border-box; }
  .key_visual_low h1 span { background-color: #f0855d; color: #ffffff; font-weight: normal; font-size: 3.8rem; text-align: center; letter-spacing: 0.1em; padding: 18px 22px 14px 22px; } }
/* -----------------------------------------------------------
　求人バナー
----------------------------------------------------------- */
.bnr_recruit { width: 90%; margin: 0 auto 2rem; padding: 15rem 0 1.5rem; background: url(../images/top_bnr_recruit.jpg) no-repeat center/cover; border: 2px solid #55b285; }
.bnr_recruit .tit { color: #55b285; font-weight: bold; text-align: center; font-size: 1.6rem; text-shadow: #ffffff 1px 1px 6px, #ffffff -1px 1px 6px, #ffffff 1px -1px 6px, #ffffff -1px -1px 6px, #ffffff 2px 2px 6px, #ffffff -2px 2px 6px, #ffffff 2px -2px 6px, #ffffff -2px -2px 6px; }
.bnr_recruit p:not(.tit) { width: 85%; margin: 0 auto 1rem; padding: .5rem 1rem; background: rgba(255, 255, 255, 0.6); }
.bnr_recruit > ul { display: flex; justify-content: center; flex-direction: column; align-items: center; gap: 1rem; }
.bnr_recruit > ul li { list-style: none; width: 60%; margin: 0 auto; }
.bnr_recruit > ul li a { display: block; text-decoration: none; background: #55b285; color: #fff; padding: 1rem 0; text-align: center; font-size: 1.2rem; position: relative; }
.bnr_recruit > ul li a::after { position: absolute; right: 10px; content: " ▶"; display: inline-block; }

@media screen and (min-width: 768px), print { .bnr_recruit { width: 60%; background: url(../images/top_bnr_recruit.jpg) no-repeat left/contain; padding: 3rem 1.5rem 3rem 35rem; border: 3px solid #55b285; }
  .bnr_recruit .tit { font-size: 2.5rem; }
  .bnr_recruit > ul { justify-content: space-between; flex-direction: row; }
  .bnr_recruit > ul li { width: 40%; }
  .bnr_recruit > ul li a { padding: 1.2rem 0; font-size: 1.6rem; }
  .bnr_recruit > ul li a:hover { opacity: .6; }
  .bnr_recruit > ul li a::after { right: 15px; } }
/* -----------------------------------------------------------
　お知らせ
----------------------------------------------------------- */
.notice_frame { width: 100%; margin: 0 0 2rem 0; box-sizing: border-box; overflow: hidden; padding: 2rem 0; height: auto; }
.notice_frame .notice_box { width: 96%; margin: 0 auto; }
.notice_frame .notice_box dl { height: auto; }
.notice_frame .notice_box dl dt { background-color: #fff3f6; color: #eb547b; margin: 0 0 0.6rem 0; padding: 0.6rem 0.4rem 0.4rem 0.4rem; font-size: 1.4rem; box-sizing: border-box; font-weight: normal; letter-spacing: 0.1em; line-height: 120%; }
.notice_frame .notice_box dl dd { margin: 0 0 2rem 0; padding: 0; color: #404040; font-size: 1.4rem; line-height: 120%; }
.notice_frame .notice_box dl dt:before { content: "▲ "; display: inline-block; }
.notice_frame .notice_box dl dt.active:before { -webkit-transform: rotate(180deg); -moz-transform: rotate(180deg); -o-transform: rotate(180deg); -ms-transform: rotate(180deg); transform: rotate(180deg); }

@media screen and (min-width: 768px), print { .notice_frame { width: 100%; margin: 100px 0 13px 0; box-sizing: border-box; overflow: hidden; padding: 0 0 0 0; height: auto; min-height: 317px; }
  .notice_frame .notice_box { width: 1300px; margin: 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; height: auto; min-height: 337px; }
  .notice_frame .notice_box h2.news { width: 220px; margin: 0; }
  .notice_frame .notice_box dl { overflow-y: auto; height: 386px; width: 1050px; margin: 0; height: auto; min-height: 300px; }
  .notice_frame .notice_box dl dt { background-color: #fff3f6; color: #eb547b; margin: 0 0 18px 0; padding: 6px 18px 0 18px; font-size: 2.4rem; box-sizing: border-box; font-weight: normal; letter-spacing: 0.1em; line-height: 120%; display: block; }
  .notice_frame .notice_box dl dt span.date { display: inline; font-size: 1.4rem; color: #a4c5d8; margin: 0 0 0 0.6rem; }
  .notice_frame .notice_box dl dd { margin: 0 0 20px 0; padding: 0; color: #404040; font-size: 1.8rem; line-height: 140%; } }
/*スマホ用スライドバー*/
@media screen and (max-width: 767px) { .notice_frame dl::-webkit-scrollbar { width: 12px; background: #ffffff; }
  .notice_frame dl::-webkit-scrollbar-track { -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3); border-radius: 10px; }
  .notice_frame dl::-webkit-scrollbar-thumb { border-radius: 10px; -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.5); } }
/* -----------------------------------------------------------
求人バナー
----------------------------------------------------------- */
.banner_link { margin: 1rem 0 1rem 0; }
.banner_link a { text-decoration: none; display: block; width: 90%; margin: 0 auto 1rem auto; }
.banner_link a img { width: 100%; height: auto; }

@media screen and (min-width: 768px), print { .banner_link { /*
display: -webkit-flex;
display: flex;
-webkit-justify-content: space-between;
justify-content: space-between;
-webkit-flex-direction:row;
flex-direction:row;
-webkit-flex-wrap: nowrap;
flex-wrap: nowrap; 
*/ width: 450px; margin: 40px auto 0 auto; }
  .banner_link a { text-decoration: none; display: block; /*width: 631px;*/ width: 450px; margin: 0; }
  .banner_link a img { /*width: 631px;*/ width: 450px; height: auto; }
  .banner_link a:hover { opacity: 0.6; transition: all 0.3s ease 0s; } }
/* -----------------------------------------------------------
理念
----------------------------------------------------------- */
.idea_frame { background: url("../images/index_idea_01.png"); background-repeat: no-repeat; background-position: left 2% top; background-size: 40%; background-color: #f7f9fa; padding: 2rem 0 0 0; box-sizing: border-box; }
.idea_frame section { width: 96%; margin: 0 auto; }
.idea_frame section h2.idea { color: #404040; font-family: 'notoserif_semibold'; font-size: 2.4rem; margin: 0 0 1.4rem 0; }
.idea_frame section .idea_text { color: #eb547b; font-family: 'notoserif'; font-size: 1.6rem; }
.idea_frame section .idea_text span { font-size: 1.7rem; font-weight: bold; background: linear-gradient(transparent 60%, #ffdfec 40%); }
.idea_frame section .idea_box .idea_box1 { width: 90%; height: 50vw; margin: 0 auto 4rem auto; position: relative; }
.idea_frame section .idea_box .idea_box1::before { content: ""; position: absolute; top: 0; left: 0; width: 4rem; height: 4rem; border-top: #a4c5d8 1px solid; border-left: #a4c5d8 1px solid; display: block; }
.idea_frame section .idea_box .idea_box1::after { content: ""; position: absolute; bottom: 0; right: 0; width: 4rem; height: 4rem; border-bottom: #a4c5d8 1px solid; border-right: #a4c5d8 1px solid; display: block; }
.idea_frame section .idea_box .idea_box1 p { position: absolute; top: 4vw; left: 0; right: 0; width: 90%; height: 42vw; background-color: #ecf4f8; margin: 0 auto; padding: 2rem; box-sizing: border-box; line-height: 140%; }
.idea_frame section .idea_box .idea_box1 p span { display: block; }
.idea_frame section .idea_box .idea_box1 p span.idea_large { font-size: 1.6rem; color: #6dabce; margin: 0 0 1.4rem 0; }
.idea_frame section .idea_box .idea_box1 p span.idea_smail { font-size: 1.6rem; color: #404040; margin: 0; }
.idea_frame section .idea_box .idea_box1 p span.idea_smail span { color: #2d93e8; font-size: 1.7rem; font-weight: bold; background: linear-gradient(transparent 50%, #d2e8f6 50%); display: inline; }
.idea_frame section .idea_box .idea_box2 { width: 90%; height: 50vw; margin: 0 auto 4rem auto; position: relative; }
.idea_frame section .idea_box .idea_box2::before { content: ""; position: absolute; top: 0; left: 0; width: 4rem; height: 4rem; border-top: #a4c5d8 1px solid; border-left: #a4c5d8 1px solid; display: block; }
.idea_frame section .idea_box .idea_box2::after { content: ""; position: absolute; bottom: 0; right: 0; width: 4rem; height: 4rem; border-bottom: #a4c5d8 1px solid; border-right: #a4c5d8 1px solid; display: block; }
.idea_frame section .idea_box .idea_box2 p { position: absolute; top: 4vw; left: 0; right: 0; width: 90%; height: 42vw; background-color: #ecf4f8; margin: 0 auto; padding: 2rem; box-sizing: border-box; }
.idea_frame section .idea_box .idea_box2 p span { display: block; }
.idea_frame section .idea_box .idea_box2 p span.idea_large { font-size: 1.6rem; color: #6dabce; margin: 0 0 1.4rem 0; }
.idea_frame section .idea_box .idea_box2 p span.idea_smail { font-size: 1.6rem; color: #404040; margin: 0; }
.idea_frame section .idea_box .idea_box2 p span.idea_smail span { color: #2d93e8; font-size: 1.7rem; font-weight: bold; background: linear-gradient(transparent 50%, #d2e8f6 50%); display: inline; }

@media screen and (min-width: 768px), print { .idea_frame { background: url("../images/index_idea_01.png"), url("../images/index_idea_02.png"); background-repeat: no-repeat,no-repeat; background-position: left top,right top; background-size: 528px,1086px; background-color: #f7f9fa; padding: 114px 0 0 0; box-sizing: border-box; height: 678px; margin: 0; }
  .idea_frame section { width: 1300px; margin: 0 auto; position: relative; }
  .idea_frame section h2.idea { color: #404040; font-family: 'notoserif_semibold'; font-size: 4.8rem; margin: 0 0 18px 0; }
  .idea_frame section .idea_text { color: #eb547b; font-family: 'notoserif'; font-size: 2.8rem; line-height: 140%; margin: 0 0 50px 0; letter-spacing: 0.13em; }
  .idea_frame section .idea_text span { font-size: 3rem; font-weight: bold; background: linear-gradient(transparent 65%, #ffdfec 35%); }
  .idea_frame section .idea_box { width: 832px; height: 245px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .idea_frame section .idea_box .idea_box1 { width: 390px; height: 245px; margin: 0; position: relative; }
  .idea_frame section .idea_box .idea_box1::before { content: ""; position: absolute; top: 0; left: 0; width: 50px; height: 50px; border-top: #a4c5d8 1px solid; border-left: #a4c5d8 1px solid; display: block; }
  .idea_frame section .idea_box .idea_box1::after { content: ""; position: absolute; bottom: 0; right: 0; width: 50px; height: 50px; border-bottom: #a4c5d8 1px solid; border-right: #a4c5d8 1px solid; display: block; }
  .idea_frame section .idea_box .idea_box1 p { position: absolute; top: 10px; left: 0; right: 0; width: 370px; height: 224px; background-color: #ecf4f8; margin: 0 auto; padding: 40px 36px; box-sizing: border-box; letter-spacing: 0.1em; }
  .idea_frame section .idea_box .idea_box1 p span { display: block; }
  .idea_frame section .idea_box .idea_box1 p span.idea_large { font-size: 2.8rem; color: #6dabce; margin: 0 0 28px 0; }
  .idea_frame section .idea_box .idea_box1 p span.idea_smail { font-size: 1.8rem; color: #404040; margin: 0; line-height: 180%; }
  .idea_frame section .idea_box .idea_box1 p span.idea_smail span { color: #2d93e8; font-size: 1.8rem; font-weight: bold; background: linear-gradient(transparent 50%, #d2e8f6 50%); display: inline; }
  .idea_frame section .idea_box .idea_box2 { width: 390px; height: 245px; margin: 0; position: relative; }
  .idea_frame section .idea_box .idea_box2::before { content: ""; position: absolute; top: 0; left: 0; width: 50px; height: 50px; border-top: #a4c5d8 1px solid; border-left: #a4c5d8 1px solid; display: block; }
  .idea_frame section .idea_box .idea_box2::after { content: ""; position: absolute; bottom: 0; right: 0; width: 50px; height: 50px; border-bottom: #a4c5d8 1px solid; border-right: #a4c5d8 1px solid; display: block; }
  .idea_frame section .idea_box .idea_box2 p { position: absolute; top: 10px; left: 0; right: 0; width: 370px; height: 224px; background-color: #ecf4f8; margin: 0 auto; padding: 40px 36px; box-sizing: border-box; letter-spacing: 0.1em; }
  .idea_frame section .idea_box .idea_box2 p span { display: block; }
  .idea_frame section .idea_box .idea_box2 p span.idea_large { font-size: 2.8rem; color: #6dabce; margin: 0 0 28px 0; }
  .idea_frame section .idea_box .idea_box2 p span.idea_smail { font-size: 1.8rem; color: #404040; margin: 0; line-height: 180%; }
  .idea_frame section .idea_box .idea_box2 p span.idea_smail span { color: #2d93e8; font-size: 1.8rem; font-weight: bold; background: linear-gradient(transparent 50%, #d2e8f6 50%); display: inline; } }
/* -----------------------------------------------------------
理念2
----------------------------------------------------------- */
.idea_frame2 { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#fddee6+0,fff0f5+100 */ background: #fddee6; /* Old browsers */ background: -moz-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #fddee6 0%, lavenderblush 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fddee6', endColorstr='#fff0f5',GradientType=0 ); /* IE6-9 */ }
.idea_frame2 .top_idea_box { width: 100%; padding: 2rem 1rem; box-sizing: border-box; }
.idea_frame2 .top_idea_box h2.low_idea { color: #ec5483; font-weight: bold; font-size: 2.6rem; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; }
.idea_frame2 .top_idea_box h2.low_idea span { font-size: 1rem; margin: 0 0 0.8rem 0; }
.idea_frame2 .top_idea_box hr.sakura { border: none; background: url("../images/icon_sakura.png") no-repeat; background-position: center center; height: 14px; }
.idea_frame2 .top_idea_box p { text-align: center; line-height: 160%; }
.idea_frame2 .top_idea_box p span { color: #ef855d; font-size: 1.7rem; font-weight: bold; background: linear-gradient(transparent 50%, #ffd19d 50%); display: inline; }
.idea_frame2 .top_idea_box_2 { margin: 4rem 0 0 0; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg { background-color: #ffffff; width: 96%; margin: 0 auto 2rem auto; padding: 3px; box-sizing: border-box; border: #fddee6 2px solid; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 { border: #fddee6 2px solid; /*
outline: $color17 3px solid;
outline-offset:3px;    
*/ margin: 0 auto; width: 100%; position: relative; padding: 2rem 1rem; box-sizing: border-box; background-color: #ffffff; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3::after { content: url("../images/icon_ribbon.png"); position: absolute; top: -6px; left: 2%; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_large { color: #ef855d; font-size: 1.8rem; font-weight: bold; text-align: center; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_large span { border-bottom: #ffd19d 2px solid; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_smail { text-align: center; margin: 0; }
.idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_smail span { color: #ec5483; font-weight: bold; }
.idea_frame2 .idea_sub_frame { width: 96%; margin: 0 auto; }

@media screen and (min-width: 768px), print { .idea_frame2 { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#fddee6+0,fff0f5+100 */ background: #fddee6; /* Old browsers */ background: -moz-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #fddee6 0%, lavenderblush 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fddee6', endColorstr='#fff0f5',GradientType=0 ); /* IE6-9 */ padding: 0 0 50px 0; }
  .idea_frame2 .top_idea_box { width: 1300px; height: 300px; padding: 116px 0 0 0; box-sizing: border-box; margin: 0 auto; }
  .idea_frame2 .top_idea_box h2.low_idea { color: #ec5483; font-weight: bold; font-size: 4.6rem; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; }
  .idea_frame2 .top_idea_box h2.low_idea span { font-size: 1.4rem; margin: 0 0 12px 0; }
  .idea_frame2 .top_idea_box hr.sakura { border: none; background: url("../images/icon_sakura.png") no-repeat; background-position: center center; height: 14px; margin: 10px 0 15px 0; }
  .idea_frame2 .top_idea_box p { text-align: center; line-height: 200%; font-size: 2.4rem; letter-spacing: 0.1em; }
  .idea_frame2 .top_idea_box p span { color: #ef855d; font-size: 2.8rem; font-weight: bold; background: linear-gradient(transparent 50%, #ffd19d 50%); display: inline; }
  .idea_frame2 .top_idea_box_2 { margin: 68px auto 0 auto; width: 1300px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg { background-color: #ffffff; width: 612px; margin: 0 6px; padding: 3px; box-sizing: border-box; border: #fddee6 2px solid; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 { border: #fddee6 2px solid; width: 600px; height: 240px; position: relative; padding: 32px 0 0 0; box-sizing: border-box; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3::after { content: url("../images/icon_ribbon.png"); position: absolute; top: -6px; left: 2%; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_large { color: #ef855d; font-size: 3rem; font-weight: bold; text-align: center; margin: 0 0 45px 0; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_large span { border-bottom: #ffd19d 3px solid; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_smail { text-align: center; margin: 0; font-size: 2.2rem; line-height: 180%; letter-spacing: 0.1em; }
  .idea_frame2 .top_idea_box_2 .top_idea_box_bg .top_idea_box_3 .idea_smail span { color: #ec5483; font-weight: bold; }
  .idea_frame2 .idea_sub_frame { width: 1300px; margin: 0 auto; } }
/* -----------------------------------------------------------
ごあいさつ-
----------------------------------------------------------- */
.greeting_frame { background: url("../images/index_greeting_bg.png"); background-repeat: no-repeat; background-position: left top; background-size: contain; background-color: #fff3ee; padding: 2rem 0; box-sizing: border-box; margin: 0; }
.greeting_frame .greeting_box { width: 96%; margin: 0 auto; overflow: hidden; }
.greeting_frame .greeting_box .greeting_img { width: 100%; margin: 0 auto; }
.greeting_frame .greeting_box .greeting_img img { width: 100%; height: auto; }
.greeting_frame .greeting_box .greeting_doctor_name { text-align: left; float: right; }

@media screen and (min-width: 768px), print { .greeting_frame { background: url("../images/index_greeting_bg.png"), url("../images/index_greeting_bg2.png"); background-repeat: no-repeat,no-repeat; background-position: left top,right bottom; background-size: 1920px,786px; background-color: #fff3ee; padding: 110px 0 0 0; box-sizing: border-box; width: 100%; height: 740px; overflow: hidden; }
  .greeting_frame .greeting_box { width: 1300px; margin: 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .greeting_frame .greeting_box .greeting_text { width: 700px; overflow: hidden; }
  .greeting_frame .greeting_box .greeting_text .greeting_doctor_name { text-align: left; float: right; }
  .greeting_frame .greeting_box .greeting_img { width: 537px; margin: 0; margin: 0 0 0 0; }
  .greeting_frame .greeting_box .greeting_img img { width: 537px; height: auto; } }
/* -----------------------------------------------------------
クリニックの基本方針-
----------------------------------------------------------- */
.pllicy_frame { margin: 2rem 0 0 0; }
.pllicy_frame .policy_box figure { background-color: #fff3f6; width: 90%; margin: 0 auto 4rem auto; padding: 1rem 0 2rem 0; box-sizing: border-box; border-radius: 0.5rem; }
.pllicy_frame .policy_box figure img { width: 90%; height: auto; display: block; margin: 0 auto; }
.pllicy_frame .policy_box figure figcaption { width: 90%; height: auto; margin: 1rem auto 0 auto; font-size: 1.4rem; line-height: 160%; }

@media screen and (min-width: 768px), print { .pllicy_frame { margin: 110px 0 0 0; }
  .pllicy_frame .policy_box { width: 1300px; margin: 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .pllicy_frame .policy_box figure { background-color: #fff3f6; width: 310px; height: 327px; margin: 0 0 28px 0; padding: 1rem 0 2rem 0; box-sizing: border-box; border-radius: 6px; }
  .pllicy_frame .policy_box figure img { width: 270px; height: auto; display: block; margin: 0 auto; }
  .pllicy_frame .policy_box figure figcaption { width: 270px; height: auto; margin: 19px auto 0 auto; font-size: 1.6rem; line-height: 160%; }
  .pllicy_frame .policy_box figure.five { margin: 0 0 28px 164px; height: 350px; }
  .pllicy_frame .policy_box figure.six { height: 350px; }
  .pllicy_frame .policy_box figure.seven { margin: 0 164px 28px 0; height: 350px; } }
/* -----------------------------------------------------------
診療内容-
----------------------------------------------------------- */
.contents_frame { margin: 0 0 0 0; padding: 2rem 0 2rem 0; background: url("../images/index_contents_bg.jpg") no-repeat; background-position: center top; background-size: cover; }
.contents_frame .contents_box { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; width: 96%; margin: 0 auto; }
.contents_frame .contents_box p { width: 48%; height: 46vw; background: url("../images/index_contents_bg.png") no-repeat; background-position: center center; background-size: contain; margin: 0 0 1rem 0; }
.contents_frame .contents_box p a { width: 100%; height: 46vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; text-decoration: none; }
.contents_frame .contents_box p a img { width: 60%; margin: 1rem 0 0 0; }
.contents_frame .contents_box p a span { width: 100%; height: 8vw; background-color: #eb547b; color: #ffffff; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 1.2rem; margin: 1rem 0 0 0; }

@media screen and (min-width: 768px), print { .contents_frame { margin: 120px 0 0 0; padding: 120px 0 0 0; background: url("../images/index_contents_bg.jpg") no-repeat; background-position: center top; background-size: cover; width: 100%; height: 1111px; box-sizing: border-box; }
  .contents_frame .contents_box { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; width: 1300px; margin: 0 auto; }
  .contents_frame .contents_box p { width: 226px; height: 226px; background: url("../images/index_contents_bg.png") no-repeat; background-position: center center; background-size: contain; margin: 0 0 42px 0; }
  .contents_frame .contents_box p a { width: 226px; height: 226px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; text-decoration: none; position: relative; }
  .contents_frame .contents_box p a img { position: absolute; top: 57px; left: 0; right: 0; margin: 0 auto; width: 165px; }
  .contents_frame .contents_box p a span { position: absolute; top: 165px; left: 0; right: 0; width: 100%; height: 34px; background-color: #eb547b; color: #ffffff; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 1.8rem; margin: 0; }
  .contents_frame .contents_box p a:hover { opacity: 0.6; transition: all 0.3s ease 0s; }
  .contents_frame .contents_box p a:hover span { opacity: 1; }
  .contents_frame .contents_box p.numbness { margin: 0 0 42px 129px; }
  .contents_frame .contents_box p.nonsmoking { margin: 0 129px 42px 0; } }
/*----------------------------------------------------------- 医院概要
----------------------------------------------------------- */
.overview { width: 100%; margin: 0; padding: 0; border-bottom: #dbdbdb 1px solid; }
.overview .overview_up { background-color: #fff3f6; padding: 2rem 0; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; }
.overview .overview_up h2.overview_title { order: 2; margin: 0 0 1rem 0; }
.overview .overview_up h2.overview_title img { width: 80%; max-width: 372px; display: block; margin: 0 auto; }
.overview .overview_up img.overview_logo { order: 1; width: 40%; max-width: 80px; display: block; margin: 0 0 1rem 0; }
.overview .overview_up p.overview_tel { order: 3; color: #f0855d; font-size: 1.4rem; text-align: center; margin: 0.4rem 0 0 0; font-weight: bold; }
.overview .overview_up p.overview_tel span { color: #f0855d; font-size: 2.4rem; }
.overview .overview_up p.overview_tel a { color: #f0855d; text-decoration: none; font-size: 2.4rem; }
.overview .overview_frame { background-color: #ffffff; width: 96%; margin: 0 auto; padding: 2rem 0 0 0; box-sizing: border-box; }
.overview .overview_frame .overview_left { width: 100%; margin: 0; }
.overview .overview_frame .overview_left dl { width: 100%; margin: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; line-height: 140%; font-size: 1.4rem; }
.overview .overview_frame .overview_left dl dt { width: 30%; margin: 0 0 2rem 0; padding: 0 0 0.4rem 0; border-bottom: #f2a0b5 2px solid; box-sizing: border-box; font-weight: bold; color: #eb547b; }
.overview .overview_frame .overview_left dl dd { width: 70%; margin: 0 0 2rem 0; padding: 0 0 0.4rem 0; border-bottom: #dbdbdb 2px solid; box-sizing: border-box; color: #404040; }
.overview .overview_frame .overview_left dl dd span { display: block; }
.overview .overview_frame .overview_left table.timetable { margin: 2rem 0 0 0; }
.overview .overview_frame .overview_right { margin: 2rem auto; width: 96%; }
.overview .overview_frame .overview_right img { width: 100%; height: auto; margin: 0 auto 1rem; }
.overview .overview_frame .overview_right iframe.googlemap { width: 100%; height: 500px; }

@media screen and (min-width: 768px), print { .overview { width: 100%; margin: 0; padding: 0 0 73px 0; border-bottom: #dbdbdb 1px solid; }
  .overview .overview_up { background-color: #fff3f6; padding: 0 0 0 0; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; height: 338px; box-sizing: border-box; }
  .overview .overview_up h2.overview_title { order: 2; margin: 0 0 1rem 0; }
  .overview .overview_up h2.overview_title img { width: 372px; max-width: 372px; display: block; margin: 0 auto; }
  .overview .overview_up img.overview_logo { order: 1; width: 40%; max-width: 80px; display: block; margin: 12px 0 12px 0; }
  .overview .overview_up p.overview_tel { order: 3; color: #f0855d; font-size: 2rem; text-align: center; margin: 10px 0 0 0; font-weight: bold; }
  .overview .overview_up p.overview_tel span { color: #f0855d; font-size: 3rem; }
  .overview .overview_up p.overview_tel a { color: #f0855d; text-decoration: none; font-size: 3rem; }
  .overview .overview_frame { background-color: #ffffff; width: 1300px; margin: 0 auto; padding: 80px 0 0 0; box-sizing: border-box; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .overview .overview_frame .overview_left { width: 500px; margin: 0; }
  .overview .overview_frame .overview_left dl { width: 500px; margin: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; line-height: 140%; font-size: 1.6rem; }
  .overview .overview_frame .overview_left dl dt { width: 100px; margin: 0 0 28px 0; padding: 0 0 2px 0; border-bottom: #f2a0b5 2px solid; box-sizing: border-box; font-weight: bold; color: #eb547b; }
  .overview .overview_frame .overview_left dl dd { width: 400px; margin: 0 0 28px 0; padding: 0 0 2px 0; border-bottom: #dbdbdb 2px solid; box-sizing: border-box; color: #404040; letter-spacing: 0.1em; }
  .overview .overview_frame .overview_left dl dd span { display: block; }
  .overview .overview_frame .overview_left table.timetable { margin: 2rem 0 0 0; }
  .overview .overview_frame .overview_right { margin: 0; width: 730px; }
  .overview .overview_frame .overview_right img { width: 90%; height: auto; margin: 0 auto; }
  .overview .overview_frame .overview_right iframe.googlemap { width: 730px; height: 440px; } }
/* -----------------------------------------------------------
　フッター
----------------------------------------------------------- */
footer .footer_frame { display: none; }
footer .copyright { margin: 0; text-align: center; padding: 0.8rem 0; color: #404040; font-size: 1.2rem; height: auto; letter-spacing: 0.05em; }
footer .copyright a { color: #404040; text-decoration: none; letter-spacing: 0.1em; }

.footer_link { position: fixed; bottom: 0; width: 100%; display: -webkit-flex; display: flex; -webkit-justify-content: space-around; justify-content: space-around; -webkit-flex-direction: row; flex-direction: row; padding: 1rem 0; background-color: rgba(255, 255, 255, 0.8); z-index: 999999; }
.footer_link a.footer_tel { width: 75%; height: 100%; margin: 0; color: #ffffff; text-align: center; font-size: 1.4rem; font-weight: normal; letter-spacing: 0.1em; display: block; background-color: #eb547b; padding: 0; text-decoration: none; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.footer_link .smoothScrolls { background-color: #eb547b; width: 20%; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.footer_link .smoothScrolls a { width: 100%; color: #ffffff; padding: 0.8rem 0; font-weight: normal; text-decoration: none; font-size: 1.4rem; }
.footer_link .footer_linkGreen a { text-align: center; background: #55b285; padding: 1.2rem 0; text-decoration: none; color: #ffffff; }
.footer_link .footer_linkGreen small { font-size: .9em; }
.footer_link .calc2 * { width: 100% !important; }
.footer_link .smoothScrolls { width: 30% !important; }

@media screen and (min-width: 768px), print { footer { width: 100%; height: 186px; padding: 0; box-sizing: border-box; padding: 0 0 0 0; margin: 0 0 0 0; overflow: hidden; position: relative; }
  footer .footer_frame { display: block; width: 1300px; height: auto; margin: 0 auto 0 auto; padding: 50px 0 0 0; box-sizing: border-box; position: relative; height: 120px; }
  footer .footer_frame ul.footer_list_main { list-style-type: none; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: row; flex-direction: row; width: 100%; margin: 0; }
  footer .footer_frame ul.footer_list_main li { margin: 0 15px 10px 0; }
  footer .footer_frame ul.footer_list_main li a { color: #404040; font-size: 1.4rem; text-decoration: none; font-weight: normal; position: relative; }
  footer .footer_frame ul.footer_list_main li a::after { position: absolute; bottom: 0; left: 0; content: ''; width: 100%; height: 2px; transform: scale(0, 1); transform-origin: center top; transition: transform .3s; background: #404040; }
  footer .footer_frame ul.footer_list_main li a:hover::after { transform: scale(1, 1); }
  footer .footer_frame ul.footer_list_main li a i { display: none; }
  footer .footer_frame ul.footer_list_main li ul { display: none; }
  footer .footer_frame ul.footer_list_main li::after { content: "|"; font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif; margin: 0 0 10px 15px; color: #404040; font-size: 1.4rem; font-weight: normal; }
  footer .footer_frame ul.footer_list_main li:first-child::before { content: "|"; font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif; margin: 0 15px 10px 0; color: #404040; font-size: 1.4rem; font-weight: normal; }
  footer .footer_frame ul.footer_list_main li.treatment { display: none; }
  footer .copyright { margin: 20px 0 0 0; text-align: center; padding: 0; color: #404040; font-size: 1.2rem; height: auto; letter-spacing: 0.05em; }
  footer .copyright a { color: #404040; text-decoration: none; letter-spacing: 0.1em; }
  .footer_link { display: none; }
  .f_btn a { width: 16rem; display: block; position: fixed; top: 20rem; right: 0; z-index: 1000; border-radius: 1.5rem 0 0 1.5rem; padding: 2.6px; text-decoration: none !important; }
  .f_btn a > span { width: 100%; padding: 1em .5em; display: flex; flex-direction: column; gap: 1.2rem; justify-content: center; align-items: center; line-height: 1.0; background: #55b285; border-radius: 1.2rem 0 0 1.2rem; min-height: 2.8rem; font-size: 1.6rem; text-align: center; color: #fff; }
  .f_btn a > span::before { content: '\e804'; /* width: 2.5rem;
height: 3.0rem; */ display: inline-block; font-family: "fontello"; font-size: 4rem; }
  .f_btn a > span small { font-size: 1.3rem; } }
/* -----------------------------------------------------------
　ページトップへ
----------------------------------------------------------- */
#pagetop_position { display: none; }

@media screen and (min-width: 768px), print { #pagetop_position { display: block; margin: 0; padding: 0; }
  #linkpagetop img { width: 50px; height: auto; display: block; }
  #pagetop { position: fixed; bottom: 0; right: 0; z-index: 999999; } }
/*----------------------------------------------------------- インポート
----------------------------------------------------------- */
/*ハンバーガー*/
.drawr { display: none; position: fixed; top: 26vw; width: 100%; padding: 0; margin: 0 auto; height: auto; z-index: 999999; border-top: #eb547b 1px solid; background-color: #ffffff; }
.drawr ul.hbg { list-style-type: none; }
.drawr ul.hbg li { width: 100%; text-align: center; }
.drawr ul.hbg li a { color: #eb547b; font-size: 1.4rem; text-decoration: none; padding: .5rem 0; border-bottom: #eb547b 1px solid; box-sizing: border-box; letter-spacing: 0.05em; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: row; flex-direction: row; line-height: 140%; }
.drawr ul.hbg li ul { display: none; }
.drawr ul.hbg li ul.open_nav { display: grid; grid-template-columns: repeat(2, 1fr); }
.drawr ul.hbg li ul li { list-style: none; background-color: #eb547b; }
.drawr ul.hbg li ul li:nth-child(odd) a { border-right: #ffffff 1px solid; }
.drawr ul.hbg li ul li a { color: #ffffff; border-bottom: #ffffff 1px solid; }
.drawr ul.hbg li ul li a i { display: none; }

.openNav { display: block; }

@media screen and (min-width: 768px), print { .main_nav_sp { display: none; } }
.toggle { display: none; }

.toggle-label { cursor: pointer; display: block; width: 14%; height: 12vw; padding: 0 0 4px 0; user-select: none; -webkit-tap-highlight-color: transparent; }

.toggle-label:active { -webkit-tap-highlight-color: transparent; }

.toggle-label { cursor: pointer; width: 100%; }

.toggle-label .toggle-icon, .toggle-label .toggle-icon:before, .toggle-label .toggle-icon:after { position: relative; display: block; top: 50%; left: 50%; height: 3px; width: 42px; background: #ffffff; content: ''; transition: all 500ms ease-in-out; }

.toggle-label .toggle-text { position: relative; display: block; top: calc(100% - 10px); height: 14px; font-size: 12px; color: #ffffff; text-align: center; }

.toggle-label .toggle-text:before { position: absolute; width: 100%; left: 0; content: 'MENU'; transition: all 500ms ease-in-out; visibility: visible; opacity: 1; }

.toggle-label .toggle-text:after { position: absolute; width: 100%; left: 0; content: 'CLOSE'; transition: all 500ms ease-in-out; visibility: hidden; opacity: 0; }

.toggle-label .toggle-icon { transform: translate3d(-50%, -5px, 0); }

.toggle-label .toggle-icon:before { transform: translate3d(-50%, -11.5px, 0); }

.toggle-label .toggle-icon:after { transform: translate3d(-50%, 5px, 0); }

.toggle:checked ~ .toggle-label .toggle-icon { background-color: transparent; }

.toggle:checked ~ .toggle-label .toggle-icon:before, .toggle:checked ~ .toggle-label .toggle-icon:after { top: 0; }

.toggle:checked ~ .toggle-label .toggle-icon:before { transform: translateX(-50%) rotate(45deg); top: 1.5px; }

.toggle:checked ~ .toggle-label .toggle-icon:after { transform: translateX(-50%) translateY(-10px) rotate(-45deg); top: 8.5px; }

.toggle:checked ~ .toggle-label .toggle-text:before { visibility: hidden; opacity: 0; }

.toggle:checked ~ .toggle-label .toggle-text:after { visibility: visible; opacity: 1; }

.container { position: fixed; z-index: 100; top: 6vw; right: 0.8rem; display: flex; align-items: center; justify-content: center; width: 14%; cursor: pointer; padding: 0 0 0.6rem 0; background-color: #eb547b; border: #eb547b 1px solid; }

/*見出し*/
h1 { margin: 0; }

h2.news { color: #eb547b; font-size: 2.4rem; font-weight: normal; width: 100%; height: 100%; line-height: 120%; margin: 0 0 2rem 0; letter-spacing: 0.1em; }
h2.news span { display: block; color: #404040; font-size: 1.2rem; margin: -0.6rem 0 0 0; }
h2.top { color: #eb547b; font-size: 2.2rem; font-weight: normal; width: 100%; line-height: 120%; margin: 0 0 2rem 0; letter-spacing: 0.1em; text-align: center; }
h2.top span { display: block; color: #404040; font-size: 1.2rem; margin: -0.6rem 0 0 0; }
h2.top2 { color: #eb547b; font-size: 2.2rem; font-weight: normal; width: 100%; line-height: 140%; margin: 0 0 1rem 0; }
h2.low { color: #eb547b; font-size: 2.2rem; font-weight: normal; width: 100%; line-height: 120%; margin: 0 0 1rem 0; letter-spacing: 0.1em; text-align: center; }
h2.first { margin: 0 0 1rem 0; }

h3.low { background: url(../images/h3_bg.png) no-repeat; background-position: left 0.6rem top 0.6rem; background-size: 8%; background-color: #fff3f6; color: #eb547b; font-size: 1.9rem; font-weight: normal; line-height: 120%; margin: 2rem 0 1rem 0; padding: 0.6rem 0.6rem 0.4rem 3.4rem; box-sizing: border-box; }
h3.doctor { background-color: #fff3f6; color: #eb547b; font-size: 1.9rem; font-weight: normal; width: 100%; line-height: 120%; margin: 0 0 1rem 0; letter-spacing: 0.1em; text-align: center; padding: 0.6rem 0.4rem; }
h3.idea_title { background-color: #ec5483; color: #ffffff; font-size: 1.9rem; font-weight: normal; line-height: 120%; margin: 2rem 0 1rem 0; padding: 0.6rem 0.6rem 0.4rem 3.4rem; box-sizing: border-box; text-align: center; }
h3.idea_title span { overflow: visible; position: relative; width: 100%; display: block; text-align: center; }
h3.idea_title span::after { position: absolute; top: -14px; right: 0; content: url("../images/icon_sakura2.png"); }
h3.first { margin: 0 0 1rem 0; }

.h4_frame { background-color: #fff3f6; padding: 1.5rem 1.5rem 0.5rem 1.5rem; box-sizing: border-box; margin: 2rem 0 1rem 0; }
.h4_frame section { height: auto; overflow: hidden; margin: 0; }

h4 { background-color: #f2a0b5; color: #ffffff; font-size: 1.8rem; font-weight: normal; line-height: 120%; margin: 2rem 0 1rem 0; padding: 0.6rem 0.6rem 0.4rem 0.4rem; box-sizing: border-box; }
h4.first { margin: 1rem 0 1rem 0; }

h5 { color: #eb547b; font-size: 1.7rem; font-weight: normal; margin: 3rem 0 1rem 0; padding: 0 0 0.4rem 0; border-bottom: #eb547b 1px solid; }
h5.first { margin: 1rem 0 1rem 0; }

p { font-size: 1.4rem; margin: 0 0 2rem 0; line-height: 140%; }

@media screen and (min-width: 768px), print { h1 { margin: 4rem 0 0; }
  h2.news { color: #eb547b; font-size: 4.8rem; font-weight: normal; width: 100%; height: 100%; line-height: 100%; margin: 0 0 0 0; letter-spacing: 0.1em; }
  h2.news span { display: block; color: #404040; font-size: 1.8rem; margin: -12px 0 0 0; }
  h2.top { color: #eb547b; font-size: 4.8rem; font-weight: normal; width: 100%; line-height: 120%; margin: 0 0 40px 0; letter-spacing: 0.1em; text-align: center; }
  h2.top span { display: block; color: #404040; font-size: 1.8rem; margin: 0 0 0 0; line-height: 100%; }
  h2.top2 { color: #eb547b; font-size: 3.4rem; font-weight: normal; width: 100%; height: auto; line-height: 140%; margin: 0 0 16px 0; }
  h2.low { color: #eb547b; font-size: 4.8rem; font-weight: normal; width: 100%; line-height: 120%; margin: 90px 0 40px 0; letter-spacing: 0.1em; text-align: center; }
  h2.first { margin: 0 0 50px 0; }
  h3.low { background: url(../images/h3_bg.png) no-repeat; background-position: left 8px top 7px; background-size: 42px; background-color: #fff3f6; color: #eb547b; font-size: 3rem; font-weight: normal; line-height: 120%; margin: 90px 0 28px 0; padding: 8px 8px 6px 64px; box-sizing: border-box; }
  h3.doctor { background-color: #fff3f6; color: #eb547b; font-size: 3rem; font-weight: normal; width: 100%; line-height: 120%; margin: 0 0 28px 0; letter-spacing: 0.1em; text-align: center; padding: 8px 6px; }
  h3.idea_title { background-color: #ec5483; color: #ffffff; font-size: 3rem; font-weight: normal; line-height: 120%; margin: 90px 0 28px 0; padding: 8px 8px 6px 64px; box-sizing: border-box; text-align: center; }
  h3.idea_title span { overflow: visible; position: relative; width: 100%; display: block; text-align: center; }
  h3.idea_title span::after { position: absolute; top: -14px; right: 415px; content: url("../images/icon_sakura2.png"); }
  h3.first { margin: 40px 0 28px 0; }
  .h4_frame { background-color: #fff3f6; padding: 80px 80px 52px 80px; box-sizing: border-box; margin: 0 0 0 0; }
  .h4_frame section { height: auto; overflow: hidden; margin: 0; }
  h4 { background-color: #f2a0b5; color: #ffffff; font-size: 2.6rem; font-weight: normal; line-height: 120%; margin: 40px 0 28px 0; padding: 10px 20px 10px 20px; box-sizing: border-box; }
  h4.first { margin: 0 0 28px 0; }
  h5 { color: #eb547b; font-size: 2.4rem; font-weight: normal; margin: 20px 0 20px 0; padding: 0 0 8px 0; border-bottom: #eb547b 1px solid; }
  h5.first { margin: 10px 0 20px 0; }
  p { font-size: 1.8rem; margin: 0 0 2rem 0; line-height: 160%; } }
/*イメージ*/
/* -----------------------------------------------------------
　イメージ
----------------------------------------------------------- */
.img_right { margin: 0 0 1rem 0; text-align: center; }
.img_right img { width: 70%; height: auto; }

.img_left { margin: 0 0 1rem 0; text-align: center; }
.img_left img { width: 70%; height: auto; }

.img_center { margin: 0 0 10px 0; text-align: center; }
.img_center img { width: 100%; height: auto; }

/*二つ*/
.img_two { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; }
.img_two img { width: 70%; margin: 0 auto 20px auto; display: block; }

@media screen and (min-width: 768px), print { .img_right { float: right; margin: 0 0 20px 64px; }
  .img_right img { width: 550px; height: auto; }
  .img_left { float: left; margin: 0 64px 20px 0; }
  .img_left img { width: 550px; height: auto; }
  .img_center { float: none; margin: 0 0 10px 0; text-align: center; }
  .img_center img { width: auto; height: auto; }
  /*二つ*/
  .img_two { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .img_two img { width: 540px; margin: 0 auto 20px auto; display: block; } }
/*リスト*/
/* -----------------------------------------------------------
　リスト
----------------------------------------------------------- */
/*標準*/
ul.list_normal { font-size: 1.4rem; list-style-type: disc; margin: 0 0 1rem 0; }
ul.list_normal li { margin: 0 0 0.4rem 1.8rem; padding: 0; line-height: 140%; }

ul.list_idea { font-size: 1.4rem; list-style-type: disc; margin: 0 0 1rem 0; }
ul.list_idea li { margin: 0 0 0.8rem 1.8rem; padding: 0; line-height: 140%; }

/*〇*/
ul.list_circle { line-height: 160%; font-size: 1.4rem; list-style-type: circle; margin: 0; }
ul.list_circle li { margin: 0 0 1.4rem 1.8rem; padding: 0; }

/*画像●*/
ul.list_maru { padding: 0; margin: 0 0 1rem 0; }
ul.list_maru li { line-height: 130%; font-size: 1.4rem; list-style-type: none; margin: 0 0 0 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 0.4rem; background-size: 1rem; padding: 0 0 0 1.8rem; line-height: 140%; }
ul.list_maru li ul { margin: 0.8rem 0 0 0; }
ul.list_maru li ul li { background: none; list-style-type: none; margin: 0 0 10px 0; padding: 0 0 0 0; }
ul.list_maru li a { color: #eb547b; text-decoration: none; }
ul.list_maru li span { color: #eb547b; }

ul.list_maru_two { padding: 0; margin: 0; }
ul.list_maru_two li { line-height: 130%; font-size: 1.4rem; list-style-type: none; margin: 0 0 10px 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 0.4rem; background-size: 1rem; padding: 0 0 0 1.8rem; line-height: 140%; }
ul.list_maru_two li a { color: #eb547b; }

/*なし*/
ul.list_none { line-height: 160%; font-size: 1.4rem; list-style-type: none; margin: 0; }
ul.list_none li { margin: 0 0 15px 0; padding: 0 0 0 5px; }
ul.list_none li span { color: #fedc50; margin: 0 0.5rem 0 0; }

/*数値*/
ul.list_num { box-sizing: border-box; width: 100%; }
ul.list_num li { line-height: 130%; font-size: 1.4rem; list-style-type: decimal; margin: 0 0 10px 2rem; box-sizing: border-box; width: 90%; }

/*概要*/
ul.list_overview { box-sizing: border-box; width: 100%; }
ul.list_overview li { line-height: 130%; font-size: 1.4rem; list-style-type: disc; margin: 0 0 10px 25px; box-sizing: border-box; width: 90%; }

/*2列*/
ul.list_normal_two { display: flex; justify-content: space-between; flex-direction: column; }
ul.list_normal_two li { box-sizing: border-box; line-height: 130%; font-size: 1.4rem; list-style-type: disc; margin: 0 0 10px 25px; }

@media screen and (min-width: 768px), print { /*標準*/
  ul.list_normal { font-size: 1.8rem; list-style-type: disc; margin: 0 0 2rem 0; }
  ul.list_normal li { margin: 0 0 0.4rem 25px; padding: 0; line-height: 140%; }
  ul.list_normal li ul { box-sizing: border-box; width: 100%; }
  ul.list_normal li ul li { line-height: 130%; font-size: 1.8rem; list-style-type: none; margin: 0 0 0.8rem 1.8rem; box-sizing: border-box; width: auto; }
  ul.list_idea { font-size: 1.8rem; list-style-type: disc; margin: 0 0 2rem 0; }
  ul.list_idea li { margin: 0 0 20px 25px; padding: 0; line-height: 140%; }
  /*〇*/
  ul.list_circle { line-height: 160%; font-size: 1.8rem; list-style-type: circle; margin: 0; }
  ul.list_circle li { margin: 0 0 1.4rem 25px; padding: 0; }
  /*画像●*/
  ul.list_maru { padding: 0; }
  ul.list_maru li { line-height: 140%; font-size: 1.8rem; list-style-type: none; margin: 0 0 15px 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 5px; background-size: 1.5rem; padding: 0 0 0 25px; line-height: 140%; }
  ul.list_maru li ul { margin: 0.8rem 0 0 0; }
  ul.list_maru li ul li { background: none; list-style-type: none; margin: 0 0 10px 0; padding: 0 0 0 0; }
  ul.list_maru li a { color: #eb547b; }
  ul.list_maru li span { color: #eb547b; }
  ul.list_maru_two { padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  ul.list_maru_two li { width: 45%; line-height: 100%; font-size: 1.8rem; list-style-type: none; margin: 0 0 15px 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 5px; background-size: 1.5rem; padding: 0 0 0 25px; line-height: 140%; }
  ul.list_maru_two li a { color: #eb547b; }
  /*なし*/
  ul.list_none { line-height: 160%; font-size: 1.8rem; list-style-type: none; }
  ul.list_none li { margin: 0 0 15px 0; }
  ul.list_none li span { color: #fedc50; margin: 0 5px 0 0; }
  /*数値*/
  ul.list_num { box-sizing: border-box; width: 100%; }
  ul.list_num li { line-height: 130%; font-size: 1.8rem; list-style-type: decimal; margin: 0 0 10px 25px; box-sizing: border-box; width: 90%; }
  /*概要*/
  ul.list_overview li { line-height: 130%; font-size: 1.8rem; list-style-type: disc; margin: 0 0 10px 25px; }
  ul.list_normal_two { display: flex; justify-content: space-between; flex-direction: row; flex-wrap: wrap; }
  ul.list_normal_two li { width: 45%; box-sizing: border-box; line-height: 130%; font-size: 1.8rem; list-style-type: disc; margin: 0 0 10px 25px; } }
/* -----------------------------------------------------------
　定義リスト
----------------------------------------------------------- */
dl.bio_list { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 1.4rem; box-sizing: border-box; margin: 0 0 20px 0; line-height: 120%; }
dl.bio_list dt { width: 20%; margin: 0 0 0 0; font-weight: bold; }
dl.bio_list dd { width: 80%; margin: 0 0 20px 0; }

dl.num_list { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 1.4rem; box-sizing: border-box; margin: 0 0 20px 0; line-height: 120%; }
dl.num_list dt { width: 6%; margin: 0 0 0 0; font-weight: bold; }
dl.num_list dd { width: 92%; margin: 0 0 20px 0; }

@media screen and (min-width: 768px), print { dl.bio_list { display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 1.8rem; box-sizing: border-box; line-height: 160%; width: 770px; }
  dl.bio_list dt { width: 130px; margin: 0 0 20px 0; font-weight: normal; }
  dl.bio_list dd { width: 620px; margin: 0 0 20px 0; }
  dl.num_list { display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; font-size: 1.8rem; box-sizing: border-box; line-height: 160%; width: 770px; }
  dl.num_list dt { width: 30px; margin: 0 0 20px 0; font-weight: normal; }
  dl.num_list dd { width: 720px; margin: 0 0 20px 0; } }
/*アサイド*/
aside { display: none; }

@media screen and (min-width: 768px), print { aside { display: block; width: 250px; }
  aside p.aside_title { width: 250px; height: 71px; background-color: #eb547b; font-size: 2.8rem; font-weight: normal; color: #ffffff; letter-spacing: 0.2em; margin: 0 0 9px 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
  aside ul.aside_list1 { list-style-type: none; }
  aside ul.aside_list1 li { margin: 0 0 7px 0; width: 250px; }
  aside ul.aside_list1 li a { width: 250px; height: 52px; margin: 0; padding: 0 0 0 20px; box-sizing: border-box; color: #404040; font-size: 1.8rem; background: url(../images/aside_arrow.png) no-repeat; background-position: right 20px center; background-color: #ecf4f8; border: #6dabce 1px solid; text-decoration: none; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; letter-spacing: 0.05em; }
  aside ul.aside_list1 li a:hover { opacity: 0.6; transition: all 0.3s ease 0s; } }
/*診療時間*/
/* -----------------------------------------------------------
　診療時間
----------------------------------------------------------- */
table.timetable { padding: 0; margin: 0; vertical-align: middle; width: 100%; text-align: center; border-collapse: collapse; box-sizing: border-box; line-height: 140%; background-color: #ffffff; }
table.timetable tr th { box-sizing: border-box; font-weight: normal; font-size: 3.4vw; padding: 1rem 0; vertical-align: middle; color: #ffffff; background-color: #f2a0b5; }
table.timetable tr td { box-sizing: border-box; font-weight: normal; font-size: 3.4vw; padding: 1rem 0; vertical-align: middle; background-color: #fff3f6; border-bottom: #f2a0b5 1px solid; }
table.timetable tr td.time { width: 30%; text-align: center; color: #eb547b; font-weight: bold; }
table.timetable tr td i { color: #404040; }

.notice_time { font-size: 3.2vw; color: #404040; text-align: right; margin: 0.6rem auto 0 auto; padding: 0; width: 96%; box-sizing: border-box; }

@media screen and (min-width: 768px), print { table.timetable { padding: 0; margin: 0; vertical-align: middle; width: 100%; text-align: center; border-collapse: collapse; box-sizing: border-box; line-height: 140%; background-color: #ffffff; }
  table.timetable tr th { box-sizing: border-box; font-weight: bold; font-size: 1.6rem; padding: 0; vertical-align: middle; color: #ffffff; background-color: #f2a0b5; height: 35px; }
  table.timetable tr td { box-sizing: border-box; font-weight: normal; font-size: 1.6rem; padding: 0; vertical-align: middle; color: #eb547b; background-color: #fff3f6; border-bottom: #f2a0b5 1px solid; height: 54px; }
  table.timetable tr td.time { width: 145px; text-align: center; }
  .notice_time { font-size: 1.4rem; color: #404040; text-align: right; margin: 10px 0 0 0; padding: 0; width: 100%; box-sizing: border-box; } }
/*下層*/
/*矢印*/
.arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #eb547b; text-align: center; display: block; margin: 30px auto; }

.text_bold { font-weight: bold; }

.link_text { color: #eb547b; }

.emphasis { background-color: #fff3f6; padding: 1rem 1rem 0.5rem 1rem; margin: 0 0 2rem 0; }
.emphasis p { margin: 0; }

.emphasis2 { background-color: #fff3f6; padding: 1rem 1rem 0.5rem 1rem; margin: 0 0 2rem 0; }
.emphasis2 p { margin: 0; }

.tac { text-align: center; }

.low_tel a { color: #f0855d; font-weight: bold; }
.low_tel span { color: #f0855d; font-weight: bold; }
.low_tel i { color: #f0855d; }

@media screen and (min-width: 768px), print { /*矢印*/
  .arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #eb547b; text-align: center; display: block; margin: 30px auto; }
  .text_bold { font-weight: bold; }
  .link_text { color: #eb547b; }
  .link_text:hover { opacity: 0.6; transition: all 0.3s ease 0s; }
  .emphasis { background-color: #fff3f6; padding: 20px 20px 5px 20px; margin: 0 0 30px 0; }
  .emphasis p { margin: 0; }
  .emphasis2 { background-color: #fff3f6; padding: 20px 20px 5px 20px; margin: 0 0 30px 0; width: 600px; }
  .emphasis2 p { margin: 0; }
  .tac { text-align: center; }
  .low_tel a { color: #f0855d; font-weight: bold; }
  .low_tel span { color: #f0855d; font-weight: bold; text-decoration: none; }
  .low_tel i { color: #f0855d; } }
/* -----------------------------------------------------------
　院長紹介
----------------------------------------------------------- */
figure.doctor_img1 { margin: 0 0 10px 0; text-align: center; }
figure.doctor_img1 img { width: 70%; height: auto; }
figure.doctor_img1 figcaption { font-size: 1.4rem; font-weight: bold; margin: 0.4rem 0 1rem 0; }

figure.doctor_img2 { margin: 0 0 10px 0; text-align: center; }
figure.doctor_img2 img { width: 70%; height: auto; }

.doctor_name { float: right; text-align: left; }

.low_idea_box { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#fddee6+0,fff0f5+100 */ background: #fddee6; /* Old browsers */ background: -moz-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #fddee6 0%, lavenderblush 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fddee6', endColorstr='#fff0f5',GradientType=0 ); /* IE6-9 */ width: 100%; padding: 2rem 1rem; box-sizing: border-box; }
.low_idea_box h2.low_idea { color: #ec5483; font-weight: bold; font-size: 2.6rem; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-wrap: wrap; flex-wrap: wrap; -webkit-flex-direction: column; flex-direction: column; }
.low_idea_box h2.low_idea span { font-size: 1rem; margin: 0 0 0.8rem 0; }
.low_idea_box hr.sakura { border: none; background: url("../images/icon_sakura.png") no-repeat; background-position: center center; height: 14px; }
.low_idea_box p { text-align: center; line-height: 160%; }
.low_idea_box p span { color: #ef855d; font-size: 1.7rem; font-weight: bold; background: linear-gradient(transparent 50%, #ffd19d 50%); display: inline; }

.low_idea_box_2 { margin: 4rem 0 0 0; }
.low_idea_box_2 .low_idea_box_3 { border: #fddee6 2px solid; outline: #fddee6 3px solid; outline-offset: 3px; margin: 0 auto 2rem auto; width: 96%; position: relative; padding: 2rem 1rem; box-sizing: border-box; }
.low_idea_box_2 .low_idea_box_3::after { content: url("../images/icon_ribbon.png"); position: absolute; top: -6px; left: 2%; }
.low_idea_box_2 .low_idea_box_3 .idea_large { color: #ef855d; font-size: 1.8rem; font-weight: bold; text-align: center; }
.low_idea_box_2 .low_idea_box_3 .idea_large span { border-bottom: #ffd19d 2px solid; }
.low_idea_box_2 .low_idea_box_3 .idea_smail { text-align: center; margin: 0; }
.low_idea_box_2 .low_idea_box_3 .idea_smail span { color: #ec5483; font-weight: bold; }

@media screen and (min-width: 768px), print { figure.doctor_img1 { float: right; margin: 0 0 10px 20px; text-align: center; }
  figure.doctor_img1 img { width: 350px; height: auto; }
  figure.doctor_img1 figcaption { font-size: 1.8rem; font-weight: bold; margin: 15px 0 0 0; }
  figure.doctor_img2 { float: right; margin: 0 0 10px 20px; text-align: center; }
  figure.doctor_img2 img { width: 550px; height: auto; }
  .doctor_name { float: right; text-align: left; }
  .low_idea_box { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#fddee6+0,fff0f5+100 */ background: #fddee6; /* Old browsers */ background: -moz-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #fddee6 0%, lavenderblush 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #fddee6 0%, lavenderblush 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#fddee6', endColorstr='#fff0f5',GradientType=0 ); /* IE6-9 */ width: 1300px; height: 268px; padding: 48px 0 0 0; box-sizing: border-box; }
  .low_idea_box h2.low_idea { color: #ec5483; font-weight: bold; font-size: 4.6rem; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; -webkit-flex-direction: column; flex-direction: column; }
  .low_idea_box h2.low_idea span { font-size: 1.4rem; margin: 0 0 12px 0; }
  .low_idea_box hr.sakura { border: none; background: url("../images/icon_sakura.png") no-repeat; background-position: center center; height: 14px; margin: 10px 0 15px 0; }
  .low_idea_box p { text-align: center; line-height: 200%; font-size: 2.4rem; letter-spacing: 0.1em; }
  .low_idea_box p span { color: #ef855d; font-size: 2.8rem; font-weight: bold; background: linear-gradient(transparent 50%, #ffd19d 50%); display: inline; }
  .low_idea_box_2 { margin: 50px 0 0 0; width: 1300px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .low_idea_box_2 .low_idea_box_3 { border: #fddee6 2px solid; outline: #fddee6 3px solid; outline-offset: 3px; margin: 0 6px; width: 624px; height: 240px; position: relative; padding: 32px 0 0 0; box-sizing: border-box; }
  .low_idea_box_2 .low_idea_box_3::after { content: url("../images/icon_ribbon.png"); position: absolute; top: -6px; left: 2%; }
  .low_idea_box_2 .low_idea_box_3 .idea_large { color: #ef855d; font-size: 3rem; font-weight: bold; text-align: center; margin: 0 0 45px 0; }
  .low_idea_box_2 .low_idea_box_3 .idea_large span { border-bottom: #ffd19d 3px solid; }
  .low_idea_box_2 .low_idea_box_3 .idea_smail { text-align: center; margin: 0; font-size: 2.2rem; line-height: 180%; letter-spacing: 0.1em; }
  .low_idea_box_2 .low_idea_box_3 .idea_smail span { color: #ec5483; font-weight: bold; } }
/* -----------------------------------------------------------
　クリニック紹介
----------------------------------------------------------- */
.machine_box_low { width: 100%; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
.machine_box_low section { width: 100%; margin: 0 0 80px 0; }
.machine_box_low section h3 { margin: 0 0 20px 0; }
.machine_box_low section figure { margin: 0; padding: 0; }
.machine_box_low section figure img { width: 100%; height: auto; }
.machine_box_low section figure figcaption { font-size: 1.4rem; margin: 0.6rem 0 0 0; line-height: 120%; }

@media screen and (min-width: 768px), print { .machine_box_low { width: 1300px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .machine_box_low section { width: 550px; margin: 0 0 80px 0; }
  .machine_box_low section h3.low { margin: 0 0 20px 0; height: auto; min-height: 86px; background: url(../images/h3_bg.png) no-repeat; background-position: left 8px center; background-size: 42px; background-color: #fff3f6; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; padding: 8px 8px 6px 64px; }
  .machine_box_low section figure { margin: 0; padding: 0; }
  .machine_box_low section figure img { width: 550px; height: auto; }
  .machine_box_low section figure figcaption { font-size: 1.8rem; margin: 0.8rem 0 0 0; line-height: 120%; } }
/*----------------------------------------------------------- 診療時間・アクセス
----------------------------------------------------------- */
table.access_table { padding: 0; margin: 0 auto; vertical-align: middle; width: 100%; border-collapse: collapse; box-sizing: border-box; line-height: 140%; }
table.access_table tr th { display: block; box-sizing: border-box; font-weight: normal; font-size: 1.4rem; padding: 1rem 0; color: #ffffff; background-color: #eb547b; text-align: center; line-height: 140%; }
table.access_table tr td { display: block; box-sizing: border-box; font-weight: normal; font-size: 1.4rem; padding: 1rem; vertical-align: middle; color: #eb547b; background-color: #ffffff; border: #eb547b 1px solid; text-align: left; line-height: 140%; }

iframe.accessmap { width: 98%; height: 500px; margin: 0 auto; }

.access_tel { color: #eb547b; font-weight: bold; font-size: 2rem; }
.access_tel i { color: #eb547b; font-weight: bold; font-size: 2rem; }
.access_tel span { color: #eb547b; font-weight: bold; font-size: 2rem; }
.access_tel a { color: #eb547b; font-weight: bold; font-size: 2rem; }

.access_map img { width: 100%; }

.access_text a { color: #404040; }
.access_text a:hover { opacity: 0.6; }

@media screen and (min-width: 768px), print { iframe.accessmap { width: 100%; height: 500px; margin: 0; }
  .access_tel { color: #eb547b; font-weight: bold; font-size: 3rem; }
  .access_tel i { color: #eb547b; font-weight: bold; font-size: 3rem; }
  .access_tel span { color: #eb547b; font-weight: bold; font-size: 3rem; }
  .access_tel a { color: #eb547b; font-weight: bold; font-size: 3rem; }
  .access_map { text-align: center; }
  .access_map img { width: 510px; } }
/* -----------------------------------------------------------
　下層
----------------------------------------------------------- */
table.price_table { vertical-align: middle; width: 100%; border-collapse: collapse; box-sizing: border-box; border: #404040 1px solid; font-size: 1.4rem; }
table.price_table tr { border-bottom: #404040 1px solid; }
table.price_table tr th { width: 70%; padding: 0.6rem; box-sizing: border-box; border-right: #404040 1px solid; text-align: left; font-weight: normal; vertical-align: middle; }
table.price_table tr td { width: 30%; padding: 0.6rem; box-sizing: border-box; text-align: left; vertical-align: middle; text-align: right; }

.two_img_list figure { width: 90%; margin: 0 auto 4rem auto; }
.two_img_list figure img { width: 100%; }
.two_img_list figure figcaption { color: #3c7a1b; font-weight: normal; font-size: 1.9rem; background: url(../images/h3_line.png) repeat-x; background-position: left bottom; padding: 0 0 1rem 0; margin: 1rem 0 0 0; }

@media screen and (min-width: 768px), print { table.price_table { vertical-align: middle; width: 100%; border-collapse: collapse; box-sizing: border-box; border: #404040 1px solid; font-size: 1.8rem; }
  table.price_table tr { border-bottom: #404040 1px solid; }
  table.price_table tr th { width: 70%; padding: 1rem; box-sizing: border-box; border-right: #404040 1px solid; text-align: left; font-weight: normal; vertical-align: middle; }
  table.price_table tr td { width: 30%; padding: 1rem; box-sizing: border-box; text-align: left; vertical-align: middle; text-align: right; }
  .two_img_list { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; -webkit-flex-wrap: wrap; flex-wrap: wrap; }
  .two_img_list figure { width: 400px; margin: 0 0 60px 0; }
  .two_img_list figure img { width: 100%; }
  .two_img_list figure figcaption { color: #3c7a1b; font-weight: normal; font-size: 3rem; background: url(../images/h3_line.png) repeat-x; background-position: left bottom; padding: 0 0 1rem 0; margin: 20px 0 20px 0; } }
.flow { position: relative; margin-bottom: 6rem; }
.flow:not(:last-child)::after { display: block; width: 0; height: 0; content: ""; position: absolute; bottom: -7.0rem; left: 0; right: 0; border-top: 2rem solid #ec5483; border-right: 3.0rem solid transparent; border-bottom: 1.0rem solid transparent; border-left: 3.0rem solid transparent; margin: auto; }

.button01 a { display: flex; justify-content: space-between; align-items: center; margin: 0 auto; padding: 1em 2em; width: fit-content; color: #ffffff; font-size: 1.6rem; font-weight: 700; border: 0.2rem solid #55b285; text-decoration: none; background: #55b285; border-radius: 1rem; }
.button01 a::after { content: ''; width: 5px; height: 5px; border-top: 0.2rem solid #ffffff; border-right: 0.2rem solid #ffffff; transform: rotate(45deg); }

@media (hover: hover) and (pointer: fine) { .button01 a:hover { color: #55b285; text-decoration: none; background-color: #ffffff; border: 0.2rem solid #55b285; }
  .button01 a:hover::after { border-top: 0.2rem solid #55b285; border-right: 0.2rem solid #55b285; } }
/* -----------------------------------------------------------
　
----------------------------------------------------------- */

/*# sourceMappingURL=style.css.map */
