@charset "UTF-8";
/* =======================================================================
 共通項目 
======================================================================= */
/*汎用モジュール*/
/* ----------------------------------------------------------------------------------
モジュール　_module.scss
---------------------------------------------------------------------------------- */
/* clearfix -------------------------------------- */
.cf::before, .cf::after { content: ''; display: block; }

.cf::after { clear: both; }

/* float -------------------------------------- */
.fl_l { float: left; }

.fl_r { float: right; }

/* txt -------------------------------------- */
.txt_c { text-align: center; }

.txt_l { text-align: left; }

.txt_r { text-align: right; }

.txt_small { font-size: 90% !important; }

.bold { font-weight: bold; }

.red { color: red; }

/* img -------------------------------------- */
.img_c { display: block; max-width: 100%; height: auto; margin: 1.0rem auto; }

.img_l, .img_r { display: block; max-width: 80%; height: auto; margin: 1.0rem auto; }

/*関数*/
/* ----------------------------------------------------------- 関数
----------------------------------------------------------- */
/*サイトの横幅*/
/*media screen*/
/*文字SP*/
/*文字PC*/
/*基本フォント*/
/*游明朝*/
/*Josefin Sans*/
/*基本文字色*/
/*基本背景色PC*/
/*白*/
/*緑*/
/*緑2*/
/*水色*/
/*水色2*/
/*黒*/
/*青*/
/*灰色*/
/*水色3*/
/*水色4*/
/*黒2*/
/*緑3*/
/*緑4*/
/*紺色*/
/*グレイ2*/
/*グレイ3*/
/*青4*/
/*水色7*/
/*青緑*/
/*ハンバーガー*/
.drawr { display: none; position: absolute; top: 22vw; width: 100%; padding: 0 0 0 0; margin: 0 auto; height: auto; z-index: 999999; background-color: #4dbea0; border-top: #ffffff 1px solid; }
.drawr ul.hbg { list-style-type: none; }
.drawr ul.hbg li { text-align: center; }
.drawr ul.hbg li a { color: #ffffff; font-size: 1.4rem; text-decoration: none; padding: 1rem; display: block; border-bottom: #ffffff 1px solid; }
.drawr ul.hbg li a figure { display: none; }
.drawr ul.hbg li a span span { display: none; }
.drawr ul.hbg li ul { display: none; background-color: #e5e5e5; }
.drawr ul.hbg li ul.open_nav { display: block; }
.drawr ul.hbg li.adult_allergie { 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; height: 12vw; padding: 4px 0 4px 0; user-select: none; -webkit-tap-highlight-color: transparent; }

.toggle-label:active { -webkit-tap-highlight-color: transparent; }

.toggle-label { cursor: pointer; }

.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: 10vw; 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 { display: block; align-items: center; justify-content: center; width: 16vw; height: 18vw; position: absolute; cursor: pointer; right: 2%; top: 2vw; padding: 0; background-color: #4dbea0; z-index: 9999999; border-radius: 0.3rem; }

/*診療時間*/
/* -----------------------------------------------------------
　診療時間
----------------------------------------------------------- */
table.timetable { padding: 0; margin: 0 auto; vertical-align: middle; width: 100%; text-align: center; border-collapse: separate; border-spacing: 4px; box-sizing: border-box; }
table.timetable tr { box-sizing: border-box; }
table.timetable tr th { width: auto; box-sizing: border-box; font-weight: normal; font-size: 1rem; padding: 0.8rem 0; vertical-align: middle; color: #ffffff; background-color: #4dbea0; border: #4dbea0 1px solid; width: 10%; }
table.timetable tr th.time { width: 24%; letter-spacing: 0.1em; }
table.timetable tr th.holiday { width: 12%; }
table.timetable tr td { box-sizing: border-box; font-weight: normal; font-size: 1rem; padding: 10px 0; vertical-align: middle; color: #0d8061; background-color: #ffffff; border: #4dbea0 1px solid; font-weight: bold; }
table.timetable tr td i { color: #0d8061; font-weight: bold; }
table.timetable tr td.time { box-sizing: border-box; font-size: 1rem; color: #0d8061; background-color: #c2f1e4; text-align: center; font-weight: bold; }
table.timetable tr td.closed { font-weight: normal; background-color: #e5e5e5; }

.notice_time { color: #484848; font-size: 1.4rem; margin: 0.6rem 0 0 0; width: 96%; line-height: 140%; }
.notice_time span { font-size: 1.2rem; }

@media screen and (min-width: 768px), print { table.timetable { padding: 0; margin: 0 auto; vertical-align: middle; width: 100%; text-align: center; border-collapse: separate; border-spacing: 4px; box-sizing: border-box; }
  table.timetable tr { box-sizing: border-box; }
  table.timetable tr th { width: auto; box-sizing: border-box; font-weight: normal; font-size: 1.6rem; padding: 6px 0; vertical-align: middle; color: #ffffff; background-color: #4dbea0; border: #4dbea0 1px solid; width: 52px; }
  table.timetable tr th.time { width: 146px; letter-spacing: 0.1em; }
  table.timetable tr td { box-sizing: border-box; font-weight: bold; font-size: 1.4rem; padding: 6px 0; vertical-align: middle; color: #0d8061; background-color: #ffffff; border: #4dbea0 1px solid; }
  table.timetable tr td i { color: #0d8061; font-weight: bold; }
  table.timetable tr td.time { width: 146px; box-sizing: border-box; font-size: 1.4rem; color: #0d8061; background-color: #c2f1e4; text-align: center; font-weight: bold; }
  table.timetable tr td.closed { font-weight: normal; background-color: #e5e5e5; }
  .notice_time { color: #484848; font-size: 1.6rem; margin: 2px 0 0 0; width: 100%; line-height: 160%; }
  .notice_time span { font-size: 1.4rem; } }
/*見出し*/
h1 { margin: 0; }

h2.low { color: #0d8061; font-size: 2rem; font-weight: normal; border-bottom: #cef5eb 5px solid; padding: 0 0 0.4rem 0; box-sizing: border-box; margin: 0.1rem 0 1rem 0; line-height: 140%; }
h2.low span.kana { font-size: 1.6rem; }
h2.first { margin: 0.1rem 0 1rem 0; }

h3 { background-color: #4dbea0; color: #ffffff; padding: 0.8rem 0.6rem; box-sizing: border-box; font-size: 1.8rem; font-weight: normal; margin: 0.1rem 0 1rem 0; }
h3.first { margin: 0.1rem 0 1rem 0; }

h4 { background: url(../images/icon_h4.png) no-repeat; background-position: left center; padding: 0 0 0 2.2rem; font-size: 1.7rem; font-weight: normal; margin: 2rem 0 1rem 0; color: #0d8061; }
h4.first { margin: 0.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: 0; }
  h2.low { color: #0d8061; font-size: 3rem; font-weight: normal; border-bottom: #cef5eb 5px solid; padding: 0 0 12px 0; box-sizing: border-box; margin: 0 0 16px 0; }
  h2.low span.kana { font-size: 2.4rem; }
  h2.first { margin: 0 0 20px 0; }
  h3 { background-color: #4dbea0; color: #ffffff; padding: 10px; box-sizing: border-box; font-size: 2.2rem; font-weight: normal; margin: 1px 0 20px 0; }
  h3.first { margin: 1px 0 20px 0; }
  h4 { background: url(../images/icon_h4.png) no-repeat; background-position: left center; padding: 0 0 0 32px; font-size: 2.2rem; font-weight: normal; color: #0d8061; margin: 20px 0 18px 0; }
  h4.first { margin: 1px 0 18px 0; }
  p { font-size: 1.7rem; margin: 0 0 2rem 0; line-height: 160%; } }
/*アサイド*/
input[type="checkbox"].on-off { display: none; }

input[type="checkbox"].on-off + ul { height: 0; overflow: hidden; }

input[type="checkbox"].on-off:checked + ul { height: auto; }

.accordion { margin: 0 0 2rem 0; }
.accordion label { background-color: #ffffff; color: #484848; padding: 1rem 0; display: block; text-align: center; box-sizing: border-box; letter-spacing: 0.1em; font-size: 1.8rem; font-weight: normal; margin: 3rem auto 0 auto; border: #4dbea0 2px solid; width: 96%; }
.accordion ul.aside_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; width: 96%; box-sizing: border-box; margin: 0 auto 0 auto; }
.accordion ul.aside_list li { width: 100%; height: auto; text-align: center; font-weight: normal; font-size: 1.6rem; letter-spacing: 0.05em; line-height: 140%; list-style-type: none; box-sizing: border-box; padding: 0 0 0 0; margin: 0 0 0 0; background: #ffffff; border-bottom: #4dbea0 2px solid; border-left: #4dbea0 2px solid; border-right: #4dbea0 2px solid; }
.accordion ul.aside_list li br { display: none; }
.accordion ul.aside_list li a { color: #484848; text-decoration: none; width: 100%; display: block; padding: 1rem 0; text-shadow: none; box-sizing: border-box; }
.accordion ul.aside_list li a:hover { opacity: 0.6; }

@media screen and (min-width: 768px), print { aside p.aside_title { background-color: #0d8061; color: #ffffff; font-size: 3rem; width: 250px; height: 100px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; margin: 0 0 10px 0; }
  aside ul.aside_nav li { margin: 0 0 2px 0; list-style-type: none; }
  aside ul.aside_nav li a { display: block; background: url(../images/icon_arrow.png) no-repeat; background-position: right 15px center; background-color: #4dbea0; color: #ffffff; font-size: 1.8rem; width: 100%; height: 65px; display: -webkit-flex; display: flex; -webkit-align-items: center; align-items: center; text-decoration: none; padding: 0 0 0 12px; box-sizing: border-box; }
  aside ul.aside_nav li a:hover { opacity: 0.6; } }
/*下層*/
/*文中リンク*/
.text_link { color: #0d8061; font-weight: bold; }

/*太文字*/
.text_bold { font-weight: bold; }

/*矢印*/
.arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #0d8061; text-align: center; display: block; margin: 30px auto; }

/*ボタンリンク*/
a.link_btn { text-decoration: none; width: 100%; }
a.link_btn span { display: block; color: #ffffff; background-color: #0d8061; border-radius: 0.4rem; text-align: center; font-size: 1.2rem; padding: 1rem 0; margin: 1rem 0 0 0; position: relative; }
a.link_btn span span { font-size: 1rem; padding: 0; margin: 0; display: inline; }
a.link_btn span i { position: absolute; right: 2%; font-size: 1.2rem; }

/*左右並べ*/
.emphasis { background-color: #e6f9f4; padding: 1rem; box-sizing: border-box; margin: 0 0 2rem 0; }
.emphasis p { margin: 0; }

@media screen and (min-width: 768px), print { /*文中リンク*/
  .text_link { color: #0d8061; font-weight: bold; }
  .text_link:hover { opacity: 0.6; }
  /*太文字*/
  .text_bold { font-weight: bold; }
  /*矢印*/
  .arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #0d8061; text-align: center; display: block; margin: 30px auto; }
  a.link_btn { text-decoration: none; width: 300px; display: block; }
  a.link_btn span { display: block; color: #ffffff; background-color: #0d8061; border-radius: 0.6rem; text-align: center; font-size: 1.8rem; padding: 14px 0; margin: 14px 0 0 0; position: relative; }
  a.link_btn span span { font-size: 1.4rem; padding: 0; margin: 0; display: inline; }
  a.link_btn span i { position: absolute; right: 2%; font-size: 1.8rem; }
  a.link_btn:hover { transform: translateY(-4px); filter: drop-shadow(0 0.6rem 0.8rem rgba(109, 98, 74, 0.6)); transition: transform 0.6s cubic-bezier(0.165, 0.84, 0.44, 1), filter 0.6s cubic-bezier(0.165, 0.84, 0.44, 1); }
  @supports (-ms-ime-align: auto) { a.link_btn:hover { filter: none; } }
  /*左右並べ*/
  .two_box { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .two_box section { width: 48%; }
  .emphasis { background-color: #e6f9f4; padding: 20px; box-sizing: border-box; margin: 0 0 30px 0; }
  .emphasis p { margin: 0; } }
/* ----------------------------------------------------------- 院長紹介
----------------------------------------------------------- */
.doctor_img { text-align: center; }
.doctor_img img { width: 50%; display: block; margin: 0 auto; }
.doctor_img figcaption { margin: 1rem 0 0 0; font-size: 1.8rem; line-height: 140%; }

.doctor_name { text-align: center; font-size: 1.8rem; line-height: 140%; }

@media screen and (min-width: 768px), print { .doctor_img { text-align: center; }
  .doctor_img img { width: 150px; display: block; margin: 0 auto; }
  .doctor_img figcaption { margin: 1rem 0 0 0; font-size: 2em; line-height: 140%; }
  .doctor_name { text-align: center; font-size: 1.8rem; line-height: 140%; } }
/* ----------------------------------------------------------- クリニック紹介
----------------------------------------------------------- */
video { width: 100%; margin: 0 0 4rem 0; }

@media screen and (min-width: 768px), print { video { width: 750px; margin: 0 auto 40px auto; display: block; } }
/* ----------------------------------------------------------- アクセス
----------------------------------------------------------- */
.accessmap { width: 100%; height: 500px; margin: 4rem 0 0 0; }

@media screen and (min-width: 768px), print { .accessmap { width: 100%; height: 500px; margin: 40px 0 0 0; } }
/* ----------------------------------------------------------- 下層テーブル
----------------------------------------------------------- */
/*テーブル*/
table.low_table { padding: 0px; width: 100%; margin: 0 auto 1rem auto; border-collapse: collapse; box-sizing: border-box; line-height: 140%; font-size: 1.4rem; }
table.low_table tr th { background-color: #e6f9f4; vertical-align: middle; text-align: center; width: auto; padding: 0.8rem; border: #0d8061 1px solid; font-weight: normal; color: #0d8061; }
table.low_table tr th.left { width: 50%; }
table.low_table tr th.right { width: 50%; }
table.low_table tr td { vertical-align: middle; text-align: left; border: #0d8061 1px solid; padding: 0.8rem; background-color: #ffffff; color: #484848; }

@media screen and (min-width: 768px), print { /*テーブル*/
  table.low_table { padding: 0px; width: 100%; margin: 0 auto 1rem auto; border-collapse: collapse; box-sizing: border-box; line-height: 140%; font-size: 1.7rem; }
  table.low_table tr th { background-color: #e6f9f4; vertical-align: middle; text-align: center; width: auto; padding: 14px; border: #0d8061 1px solid; font-weight: normal; color: #484848; }
  table.low_table tr th.left { width: 30%; }
  table.low_table tr th.right { width: 70%; }
  table.low_table tr td { vertical-align: middle; text-align: left; border: #0d8061 1px solid; padding: 14px; background-color: #ffffff; color: #484848; } }
/* ----------------------------------------------------------- アクセス
----------------------------------------------------------- */
dl.infirmary_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; font-size: 1.4rem; box-sizing: border-box; margin: 0 0 0 0; line-height: 120%; width: 100%; }
dl.infirmary_box dt { width: 15%; margin: 0 0 0 0; }
dl.infirmary_box dd { width: 85%; margin: 0 0 20px 0; }
dl.infirmary_box dd dl { 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; font-size: 1.4rem; }
dl.infirmary_box dd dl dt { width: 8%; }
dl.infirmary_box dd dl dd { width: 92%; }

@media screen and (min-width: 768px), print { dl.infirmary_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; font-size: 1.7rem; box-sizing: border-box; margin: 0 0 0 0; line-height: 120%; width: 750px; }
  dl.infirmary_box dt { width: 60px; margin: 0 0 0 0; }
  dl.infirmary_box dd { width: 690px; margin: 0 0 20px 0; }
  dl.infirmary_box dd dl { width: 690px; 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.7rem; }
  dl.infirmary_box dd dl dt { width: 30px; }
  dl.infirmary_box dd dl dd { width: 660px; } }
/*リスト*/
/* -----------------------------------------------------------
　リスト
----------------------------------------------------------- */
/*標準*/
ul.list_normal { line-height: 120%; font-size: 1.4rem; list-style-type: disc; margin: 0 0 1rem 0; }
ul.list_normal li { margin: 0 0 10px 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 1rem 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 0.6rem; background-size: 1rem; padding: 0 0 0 1.8rem; line-height: 140%; }
ul.list_maru li.aj { margin: 0 0 4rem 0; }
ul.list_maru li ul { margin: 1rem 0; }
ul.list_maru li ul li { line-height: 120%; font-size: 1.4rem; list-style-type: disc; margin: 0 0 1rem 2rem; padding: 0 0 0 0; background: none; }

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.6rem; background-size: 1rem; padding: 0 0 0 1.8rem; line-height: 140%; }

/*なし*/
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_alphabet { box-sizing: border-box; width: 100%; margin: 0 0 2rem 0; }
ul.list_alphabet li { line-height: 130%; font-size: 1.4rem; list-style-type: upper-latin; margin: 0 0 1.4rem 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 { line-height: 160%; font-size: 1.7rem; list-style-type: disc; margin: 0 0 1rem 0; }
  ul.list_normal li { margin: 0 0 0 25px; padding: 0; }
  /*画像●*/
  ul.list_maru { padding: 0; }
  ul.list_maru li { line-height: 100%; font-size: 1.7rem; list-style-type: none; margin: 0 0 15px 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 7px; background-size: 10px; padding: 0 0 0 25px; line-height: 140%; }
  ul.list_maru li.aj { margin: 0 0 40px 0; }
  ul.list_maru li ul { margin: 15px 0; }
  ul.list_maru li ul li { line-height: 100%; font-size: 1.7rem; list-style-type: disc; margin: 0 0 15px 25px; padding: 0 0 0 0; background: none; }
  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: 48%; line-height: 100%; font-size: 1.7rem; 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: 10px; padding: 0 0 0 25px; line-height: 140%; }
  /*なし*/
  ul.list_none { line-height: 160%; font-size: 1.7rem; 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.7rem; list-style-type: decimal; margin: 0 0 10px 25px; box-sizing: border-box; width: 90%; }
  /*数値*/
  ul.list_alphabet { box-sizing: border-box; width: 100%; }
  ul.list_alphabet li { line-height: 130%; font-size: 1.7rem; list-style-type: upper-latin; margin: 0 0 10px 25px; box-sizing: border-box; width: 90%; }
  /*概要*/
  ul.list_overview li { line-height: 130%; font-size: 1.7rem; 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.7rem; 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 0 0; line-height: 120%; width: 100%; }
dl.bio_list dt { width: 30%; margin: 0 0 0 0; }
dl.bio_list dd { width: 68%; margin: 0 0 20px 0; }

dl.bio_list2 { 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: 4rem 0 4rem 0; line-height: 120%; width: 100%; }
dl.bio_list2 dt { width: 25%; margin: 0 0 0 0; }
dl.bio_list2 dd { width: 75%; margin: 0 0 2rem 0; }

dl.list_no { 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.2rem; box-sizing: border-box; margin: 0 0 20px 0; line-height: 120%; }
dl.list_no dt { width: 8%; margin: 0 0 0 0; font-weight: bold; }
dl.list_no dd { width: 92%; margin: 0 0 20px 0; }

dl.list_arrow { 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.1rem; box-sizing: border-box; margin: 0 0 20px 0; line-height: 160%; }
dl.list_arrow dt { width: 6%; margin: 0 0 0 0; font-weight: bold; }
dl.list_arrow dd { width: 94%; 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.7rem; box-sizing: border-box; line-height: 140%; width: 1080px; margin: 0; }
  dl.bio_list dt { width: 120px; margin: 0 0 10px 0; font-weight: normal; }
  dl.bio_list dd { width: 960px; margin: 0 0 10px 0; }
  dl.bio_list2 { 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.7rem; box-sizing: border-box; line-height: 140%; width: 700px; margin: 40px auto; }
  dl.bio_list2 dt { width: 100px; margin: 0 0 20px 0; font-weight: normal; }
  dl.bio_list2 dd { width: 600px; margin: 0 0 20px 0; }
  dl.list_no { 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: 140%; width: 750px; }
  dl.list_no dt { width: 30px; margin: 0 0 20px 0; font-weight: normal; }
  dl.list_no dd { width: 720px; margin: 0 0 20px 0; }
  dl.list_arrow { 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.6rem; box-sizing: border-box; line-height: 140%; width: 1050px; }
  dl.list_arrow dt { width: 20px; margin: 0 0 20px 0; font-weight: normal; }
  dl.list_arrow dd { width: 1180px; margin: 0 0 20px 0; } }
/*画像*/
/* -----------------------------------------------------------
　イメージ
----------------------------------------------------------- */
.img_right { margin: 0 0 10px 0; text-align: center; }
.img_right img { width: 70%; height: auto; }

.img_doctor { margin: 0 0 1rem 0; text-align: center; }
.img_doctor img { width: 100%; height: auto; }

.img_doctor2 { margin: 0 0 10px 0; text-align: center; }
.img_doctor2 img { width: 70%; height: auto; }

.img_center { margin: 0 0 10px 0; text-align: center; }
.img_center img { width: 100%; height: auto; }

/*画像右*/
.img_right_frame { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; margin: 0 0 1rem 0; }
.img_right_frame div.right { order: 1; width: 100%; text-align: center; }
.img_right_frame div.right img { width: 80%; height: auto; margin: 0 0 1rem 0; }
.img_right_frame div.left { order: 2; width: 100%; }
.img_right_frame div.left .doctor_name { text-align: right; }

/*画像左*/
.img_left_frame { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; margin: 0 0 1rem 0; }
.img_left_frame div.left { order: 1; width: 100%; text-align: center; }
.img_left_frame div.left img { width: 80%; height: auto; margin: 0 0 1rem 0; }
.img_left_frame div.right { order: 2; width: 100%; line-height: 120%; }

/*二つ*/
.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; }

.top_doctor_name { font-size: 1.5rem; text-align: right; }
.top_doctor_name span { font-size: 1.8rem; }

.doctor_name2 { text-align: right; }

@media screen and (min-width: 768px), print { .img_right { float: right; margin: 0 0 10px 20px; }
  .img_right img { width: 350px; height: auto; }
  .img_doctor { margin: 0 0 5rem 0; text-align: center; }
  .img_doctor img { width: auto; height: auto; }
  .img_doctor2 { float: right; margin: 0 0 10px 10px; }
  .img_doctor2 img { width: 350px; height: auto; }
  .img_center { float: none; margin: 0 0 10px 10px; text-align: center; }
  .img_center img { width: auto; height: auto; }
  /*画像右*/
  .img_right_frame { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; margin: 0 0 3rem 0; }
  .img_right_frame div.right { order: 2; width: 350px; text-align: center; }
  .img_right_frame div.right img { width: 350px; height: auto; margin: 0; }
  .img_right_frame div.left { order: 1; width: 445px; line-height: 120%; }
  .img_right_frame div.left .doctor_name { text-align: right; }
  /*画像左*/
  .img_left_frame { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; margin: 0 0 0 0; }
  .img_left_frame div.left { order: 1; width: 350px; text-align: left; }
  .img_left_frame div.left img { width: 350px; height: auto; margin: 10px 0; }
  .img_left_frame div.right { order: 2; width: 445px; line-height: 120%; }
  /*二つ*/
  .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; }
  .top_doctor_name { font-size: 1.8rem; text-align: right; }
  .top_doctor_name span { font-size: 2.2rem; } }
/* ----------------------------------------------------------- フォントサイズ基本
----------------------------------------------------------- */
html { font-size: calc( 100vw / 32 ); overflow-y: auto; font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "メイリオ", Meiryo, Arial, sans-serif; color: #484848; background-color: #ffffff; padding: 0 0 17vw 0; font-family: "Kosugi Maru", "sans-serif"; }

@media screen and (min-width: 768px), print { html { font-size: 62.5%; overflow-y: scroll; font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", "メイリオ", Meiryo, Arial, sans-serif; color: #484848; background-color: #ffffff; padding: 0; font-family: "Kosugi Maru", "sans-serif"; } }
/* ----------------------------------------------------------- 構成
----------------------------------------------------------- */
body { position: relative; width: 100%; margin: 0 auto; border-top: #4dbea0 5px solid; }

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; }

.text_decoration_none { text-decoration: none; }

@media screen and (min-width: 768px), print { body { position: relative; z-index: 0; overflow: hidden; border-top: #4dbea0 5px solid; }
  section { height: auto; overflow: hidden; margin: 40px 0 0 0; }
  section.first { margin: 0 0 0 0; }
  .sentence { height: auto; min-height: 243px; overflow: hidden; }
  .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 2rem auto; padding: 0; }

.wrapper { height: auto; width: 100%; margin: 3rem auto 4rem auto; padding: 0; }

aside { display: none; }
aside.aside_sp { display: block; height: auto; }

.main { 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: 0 auto 0 auto; padding: 0 0 0 0; }
  .wrapper { height: auto; width: 1050px; margin: 30px auto 50px auto; padding: 0; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  aside { display: block; width: 250px; }
  aside.aside_sp { display: none; }
  .main { width: 750px; margin: 0; padding: 0; } }
/* -----------------------------------------------------------
　ヘッダ
----------------------------------------------------------- */
header { display: block; height: auto; margin: 0 auto; }
header .head_frame { background-color: #ffffff; width: 100%; padding: 0 0 1rem 0; height: auto; }
header .head_frame .head_logo { width: 98%; margin: 4vw auto; box-sizing: border-box; }
header .head_frame .head_logo img { width: 100%; height: auto; }
header .head_frame .head_info { width: 96%; margin: 5vw auto 0 auto; background-color: #4dbea0; padding: 0.5rem; box-sizing: border-box; }
header .head_frame .head_info p { color: #ffffff; margin: 0; padding: 0; text-align: center; line-height: 140%; }
header .head_frame .head_info p.head_access { font-size: 1rem; margin: 0 0 0.6rem 0; }
header .head_frame .head_info p.head_tel { font-size: 1rem; }
header .head_frame .head_info p.head_tel span { font-size: 2rem; }
header .head_frame .head_info p.head_tel a { font-size: 2rem; text-decoration: none; color: #ffffff; }

@media screen and (min-width: 768px), print { header { display: block; height: 96px; width: 1050px; margin: 0 auto; }
  header .head_frame { background-color: #ffffff; width: 1050px; padding: 0 0 0 0; height: 96px; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  header .head_frame .head_logo { width: 525px; margin: 26px 0 0 0; box-sizing: border-box; }
  header .head_frame .head_logo img { width: 525px; height: auto; }
  header .head_frame .head_info { width: 280px; height: 80px; margin: 0; background-color: #4dbea0; padding: 0; box-sizing: border-box; }
  header .head_frame .head_info p { color: #ffffff; margin: 0; padding: 0; text-align: center; line-height: 140%; }
  header .head_frame .head_info p.head_access { font-size: 1.6rem; margin: 10px 0 6px 0; }
  header .head_frame .head_info p.head_tel { font-size: 1.6rem; }
  header .head_frame .head_info p.head_tel span { font-size: 3rem; }
  header .head_frame .head_info p.head_tel a { font-size: 3rem; text-decoration: none; color: #ffffff; } }
/* -----------------------------------------------------------
　メインナビ
----------------------------------------------------------- */
.main_nav_pc nav { margin: 0 0 1rem 0; }
.main_nav_pc nav ul.main_nav { 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; width: 96%; margin: 0 auto; box-sizing: border-box; background-color: #ffffff; /*position: relative;
z-index: 2;*/ }
.main_nav_pc nav ul.main_nav li { width: 50%; margin: 0 0 0 0; box-sizing: border-box; height: 15vw; background-color: #ffffff; }
.main_nav_pc nav ul.main_nav li a { padding: 1rem; width: 100%; text-decoration: none; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-flex-direction: row; flex-direction: row; box-sizing: border-box; }
.main_nav_pc nav ul.main_nav li a figure { width: 15%; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.main_nav_pc nav ul.main_nav li a figure img { display: block; width: 100%; }
.main_nav_pc nav ul.main_nav li a span { width: 83%; color: #484848; display: block; text-align: left; font-size: 1.2rem; margin: 0 0 0 2%; }
.main_nav_pc nav ul.main_nav li a span span { color: #4dbea0; text-align: left; margin: 0.4rem 0 0 0; font-size: 1rem; }
.main_nav_pc nav ul.main_nav li ul.main_nav_sub { display: none; position: static; z-index: 9999999; background-color: #ffffff; }
.main_nav_pc nav ul.main_nav li ul.main_nav_sub.open_nav { 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; position: relative; z-index: 99999999; }
.main_nav_pc nav ul.main_nav li ul.main_nav_sub li { width: 100%; margin: 0 0 0 0; box-sizing: border-box; background-color: #4dbea0; height: 10vw; border-bottom: #ffffff 2px solid; }
.main_nav_pc nav ul.main_nav li ul.main_nav_sub li a { color: #ffffff; height: 10vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.main_nav_pc nav ul.main_nav li ul.main_nav_sub li:last-child { border-bottom: none; }
.main_nav_pc nav ul.main_nav li.home { display: none; border-top: #4dbea0 2px solid; border-left: #4dbea0 2px solid; border-right: #4dbea0 2px solid; border-bottom: #4dbea0 2px solid; }
.main_nav_pc nav ul.main_nav li.doctor { border-top: #4dbea0 2px solid; border-left: #4dbea0 2px solid; border-bottom: #4dbea0 2px solid; }
.main_nav_pc nav ul.main_nav li.guide { border-top: #4dbea0 2px solid; border-left: #4dbea0 2px solid; border-right: #4dbea0 2px solid; border-bottom: #4dbea0 2px solid; }
.main_nav_pc nav ul.main_nav li.facility { border-left: #4dbea0 2px solid; border-bottom: #4dbea0 2px solid; }
.main_nav_pc nav ul.main_nav li.location { border-left: #4dbea0 2px solid; border-right: #4dbea0 2px solid; border-bottom: #4dbea0 2px solid; }

@media screen and (min-width: 768px), print { .main_nav_pc { display: block; }
  .main_nav_pc nav { margin: 0; }
  .main_nav_pc nav ul.main_nav { 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; width: 1050px; margin: 24px auto 0 auto; }
  .main_nav_pc nav ul.main_nav li { width: 210px; height: 90px; margin: 0 0 0 0; border: none; box-sizing: border-box; }
  .main_nav_pc nav ul.main_nav li a { padding: 0; width: 100%; text-decoration: none; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; }
  .main_nav_pc nav ul.main_nav li a figure { display: block; width: 100%; text-align: center; }
  .main_nav_pc nav ul.main_nav li a figure img { display: block; width: 34px; margin: 0 auto 10px auto; }
  .main_nav_pc nav ul.main_nav li a span { width: 100%; color: #484848; display: block; text-align: center; font-size: 1.8rem; margin: 0 0 0 0; }
  .main_nav_pc nav ul.main_nav li a span span { color: #4dbea0; text-align: center; margin: 6px 0 0 0; font-size: 1rem; display: block; }
  .main_nav_pc nav ul.main_nav li a:hover { opacity: 0.6; }
  .main_nav_pc nav ul.main_nav li ul.main_nav_sub { display: none; position: relative; z-index: 9999999; background-color: #ffffff; width: 210px; margin: 15px 0 0 0; }
  .main_nav_pc nav ul.main_nav li ul.main_nav_sub.open_nav { 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; }
  .main_nav_pc nav ul.main_nav li ul.main_nav_sub li { width: 210px; margin: 0 0 0 0; box-sizing: border-box; background-color: #4dbea0; height: 55px; border-bottom: #ffffff 2px solid; }
  .main_nav_pc nav ul.main_nav li ul.main_nav_sub li a { color: #ffffff; height: 55px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; font-size: 1.8rem; }
  .main_nav_pc nav ul.main_nav li ul.main_nav_sub li:last-child { border-bottom: none; }
  .main_nav_pc nav ul.main_nav li.home { display: block; border: none; }
  .main_nav_pc nav ul.main_nav li.doctor { border: none; }
  .main_nav_pc nav ul.main_nav li.guide { border: none; }
  .main_nav_pc nav ul.main_nav li.guide ul { display: none; }
  .main_nav_pc nav ul.main_nav li.facility { border: none; }
  .main_nav_pc nav ul.main_nav li.location { border: none; } }
/* -----------------------------------------------------------
　キービジュアル
----------------------------------------------------------- */
.key_visual { position: static !important; height: 35vw; }
.key_visual .key_in { background: url(../images/key_visual_01.jpg); background-size: cover; background-repeat: no-repeat; background-position: center bottom; height: 36vw; position: static; z-index: 1; display: block; overflow: visible; }
.key_visual .key_in .key_in_time { background-color: rgba(255, 255, 255, 0.9); width: 60%; height: 30vw; padding: 1rem 3rem; box-sizing: border-box; position: absolute; top: 3vw; right: 3vw; }
.key_visual .key_in .key_in_time p { margin: 0; line-height: 120%; }
.key_visual .key_in .key_in_time p.key_in_time_title { color: #4daabe; font-size: 1rem; }
.key_visual .key_in .key_in_time p.key_in_time_text { color: #4dbea0; font-size: 1.6rem; font-weight: bold; }
.key_visual .key_in .key_in_time p.key_in_time_text span { display: block; font-size: 1rem; font-weight: normal; line-height: 100%; }
.key_visual .key_in .googlemap_top_pc { display: none; }
.key_visual .key_in .key_time { display: none; }
.key_visual .open_nav_key { /*height: auto;*/ }
.key_visual div { /*
overflow: visible !important;
position: static !important;
*/ }

.googlemap_top_sp { display: block; width: 96%; height: 400px; margin: 1rem auto 0 auto; }

.key_visual_low { background: url(../images/key_visual_low.jpg) no-repeat; background-position: center center; height: 30vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
.key_visual_low h1 { color: #0d8061; font-size: 2.2rem; font-weight: normal; }

.key_time_sp { width: 96%; margin: 1rem auto 0 auto; position: relative; z-index: 1; }
.key_time_sp .notice_time { font-size: 1.2rem; }

@media screen and (min-width: 768px), print { .key_visual { background: url(../images/key_visual_bg.jpg) no-repeat; background-position: center top; height: 500px; position: relative !important; display: block; }
  .key_visual .key_in { background: url(../images/key_visual_01.jpg); background-size: cover; background-repeat: no-repeat; background-position: center top; height: 500px; display: block; width: 1050px; margin: 0 auto; position: relative; z-index: 1; }
  .key_visual .key_in .key_in_time { background-color: rgba(255, 255, 255, 0.8); width: 380px; height: 135px; padding: 16px 0 0 58px; box-sizing: border-box; position: absolute; top: 44px; right: 58px; }
  .key_visual .key_in .key_in_time p { margin: 0; }
  .key_visual .key_in .key_in_time p.key_in_time_title { color: #4daabe; font-size: 1.8rem; }
  .key_visual .key_in .key_in_time p.key_in_time_text { color: #4dbea0; font-size: 3rem; font-weight: bold; }
  .key_visual .key_in .key_in_time p.key_in_time_text span { display: block; font-size: 1.6rem; font-weight: normal; }
  .key_visual .key_in .googlemap_top_pc { display: block; position: absolute; top: 202px; right: 58px; width: 380px; height: 282px; }
  .key_visual .key_in .key_time { display: block; position: absolute; bottom: 15px; right: 15px; width: 500px; height: auto; background-color: #ffffff; padding: 10px; box-sizing: border-box; }
  .key_visual .key_in .key_time .notice_time { font-size: 1.4rem; width: 470px; margin: 0 auto; }
  .key_visual .open_nav_key { /*height: auto;  */ }
  .googlemap_top_sp { display: none; }
  .key_time_sp { display: none; }
  .key_visual_low { background: url(../images/key_visual_low.jpg) no-repeat; background-position: center center; height: 250px; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
  .key_visual_low h1 { color: #0d8061; font-size: 3.8rem; font-weight: normal; } }
/* -----------------------------------------------------------
　お知らせ
----------------------------------------------------------- */
.notice_frame { margin: 0; }
.notice_frame .notice_box h2.notice_h2 { color: #0d8061; font-size: 2rem; font-weight: normal; border-left: #cef5eb 5px solid; padding: 0 0 0 0.4rem; box-sizing: border-box; margin: 0 0 1rem 0; }
.notice_frame .notice_box dl { overflow-y: scroll; height: 60vw; box-sizing: border-box; border: #cef5eb 2px solid; padding: 1rem; }
.notice_frame .notice_box dl dt { margin: 0 0 0.6rem 0; font-size: 1.4rem; box-sizing: border-box; font-weight: normal; letter-spacing: 0.1em; line-height: 120%; color: #4daabe; padding: 0; }
.notice_frame .notice_box dl dd { color: #4c4c4c; margin: 0 0 2rem 0; padding: 0 0 2rem 0; box-sizing: border-box; font-size: 1.2rem; line-height: 110%; border-bottom: #e5e5e5 1px solid; }

.staff_box { border: #cef5eb 2px solid; padding: 1rem; margin-bottom: 1rem; }
.staff_box h2 { color: #0d8061; font-size: 1.8rem; text-align: center; margin-bottom: 1rem; }
.staff_box h2 span { border-bottom: 2px solid #0d8061; }
.staff_box table { border-left: 1px solid #CCC; border-bottom: 1px solid #CCC; width: 100%; margin-bottom: .5rem; }
.staff_box table th, .staff_box table td { border-top: 1px solid #CCC; border-right: 1px solid #CCC; padding: 1rem; font-size: 1.2rem; vertical-align: middle; }
.staff_box table th { background: #cef5eb; }

@media screen and (min-width: 768px), print { .notice_frame { margin: 0; }
  .notice_frame .notice_box { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; width: 750px; }
  .notice_frame .notice_box h2.notice_h2 { width: 60px; color: #0d8061; height: 366px; font-size: 3.2rem; font-weight: normal; border-left: #cef5eb 5px solid; padding: 0 0 0 8px; box-sizing: border-box; margin: 0 0 0 0; writing-mode: vertical-lr; }
  .notice_frame .notice_box dl { width: 666px; overflow-y: scroll; height: 366px; box-sizing: border-box; border: #cef5eb 2px solid; padding: 26px 28px; }
  .notice_frame .notice_box dl dt { margin: 0 0 0.6rem 0; font-size: 2.2rem; box-sizing: border-box; font-weight: normal; letter-spacing: 0.1em; line-height: 120%; color: #4daabe; padding: 0; }
  .notice_frame .notice_box dl dd { color: #4c4c4c; margin: 0 0 30px 0; padding: 0 0 30px 0; box-sizing: border-box; font-size: 1.7rem; line-height: 140%; border-bottom: #b6eedf 1px dotted; }
  .staff_box { padding: 26px 28px; margin-bottom: 2rem; }
  .staff_box h2 { font-size: 3.2rem; margin-bottom: 2rem; }
  .staff_box table th, .staff_box table td { font-size: 1.7rem; } }
/*スマホ用スライドバー*/
@media screen and (max-width: 767px) { .notice_box dl::-webkit-scrollbar { width: 12px; background: #ffffff; }
  .notice_box dl::-webkit-scrollbar-track { -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3); border-radius: 10px; }
  .notice_box dl::-webkit-scrollbar-thumb { border-radius: 10px; -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.5); } }
/* -----------------------------------------------------------
　当院の特徴
----------------------------------------------------------- */
.features_frame { background-color: #e6f9f4; box-sizing: border-box; margin: 4rem 0 0 0; border: #4dbea0 3px solid; }
.features_frame h2.features_h2 { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#0d8061+0,0d8061+50,0d8061+50,0ba37a+50,0ba37a+100 */ background: #0d8061; /* Old browsers */ background: -moz-linear-gradient(top, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0d8061', endColorstr='#0ba37a',GradientType=0 ); /* IE6-9 */ font-size: 2.2rem; font-weight: normal; text-align: center; color: #ffffff; padding: 0.6rem 0; }
.features_frame .features_box { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; width: 96%; height: auto; margin: 2rem auto 0 auto; }
.features_frame .features_box p { margin: 0 auto 2rem auto; width: 90%; box-sizing: border-box; }
.features_frame .features_box p span { color: #ffffff; padding: 1rem; box-sizing: border-box; border: #ffffff 1px solid; outline: #4dbea0 5px solid; font-size: 1.4rem; display: block; box-shadow: 12px 12px #b6eedf; }
.features_frame .features_box p.features_01 span { background: url(../images/index_features_01.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_02 span { background: url(../images/index_features_02.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_03 span { background: url(../images/index_features_03.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_04 span { background: url(../images/index_features_04.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_05 span { background: url(../images/index_features_05.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_06 span { background: url(../images/index_features_06.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_07 span { background: url(../images/index_features_07.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }
.features_frame .features_box p.features_08 span { background: url(../images/index_features_08.png) no-repeat; background-position: right 4px bottom 4px; background-size: 7%; background-color: #4dbea0; }

@media screen and (min-width: 768px), print { .features_frame { width: 750px; background-color: #e6f9f4; box-sizing: border-box; margin: 50px 0 0 0; border: #4dbea0 3px solid; }
  .features_frame h2.features_h2 { /* Permalink - use to edit and share this gradient: https://colorzilla.com/gradient-editor/#0d8061+0,0d8061+50,0d8061+50,0ba37a+50,0ba37a+100 */ background: #0d8061; /* Old browsers */ background: -moz-linear-gradient(top, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* FF3.6-15 */ background: -webkit-linear-gradient(top, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* Chrome10-25,Safari5.1-6 */ background: linear-gradient(to bottom, #0d8061 0%, #0d8061 50%, #0d8061 50%, #0ba37a 50%, #0ba37a 100%); /* W3C, IE10+, FF16+, Chrome26+, Opera12+, Safari7+ */ filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0d8061', endColorstr='#0ba37a',GradientType=0 ); /* IE6-9 */ font-size: 3.2rem; font-weight: normal; text-align: center; color: #ffffff; padding: 14px 0; }
  .features_frame .features_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: 692px; height: auto; margin: 34px auto 0 auto; }
  .features_frame .features_box p { width: 330px; height: 120px; box-sizing: border-box; }
  .features_frame .features_box p span { color: #ffffff; padding: 1rem; box-sizing: border-box; border: #ffffff 2px solid; outline: #4dbea0 5px solid; font-size: 2rem; display: block; box-shadow: 12px 12px #b6eedf; width: 320px; height: 110px; line-height: 120%; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-align-items: center; align-items: center; }
  .features_frame .features_box p.features_01 { margin: 0 0 32px 0; }
  .features_frame .features_box p.features_01 span { background: url(../images/index_features_01.png) no-repeat; background-position: right 5px bottom 5px; background-size: 31px; background-color: #4dbea0; }
  .features_frame .features_box p.features_02 { margin: 0 0 32px 0; }
  .features_frame .features_box p.features_02 span { background: url(../images/index_features_02.png) no-repeat; background-position: right 5px bottom 5px; background-size: 36px; background-color: #4dbea0; }
  .features_frame .features_box p.features_03 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_03 span { background: url(../images/index_features_03.png) no-repeat; background-position: right 5px bottom 5px; background-size: 36px; background-color: #4dbea0; }
  .features_frame .features_box p.features_04 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_04 span { background: url(../images/index_features_04.png) no-repeat; background-position: right 5px bottom 5px; background-size: 37px; background-color: #4dbea0; }
  .features_frame .features_box p.features_05 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_05 span { background: url(../images/index_features_05.png) no-repeat; background-position: right 5px bottom 5px; background-size: 38px; background-color: #4dbea0; }
  .features_frame .features_box p.features_06 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_06 span { background: url(../images/index_features_06.png) no-repeat; background-position: right 5px bottom 5px; background-size: 36px; background-color: #4dbea0; }
  .features_frame .features_box p.features_07 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_07 span { background: url(../images/index_features_07.png) no-repeat; background-position: right 5px bottom 5px; background-size: 33px; background-color: #4dbea0; }
  .features_frame .features_box p.features_08 { margin: 0 0 12px 0; }
  .features_frame .features_box p.features_08 span { background: url(../images/index_features_08.png) no-repeat; background-position: right 5px bottom 5px; background-size: 35px; background-color: #4dbea0; } }
/* -----------------------------------------------------------
　医院概要
----------------------------------------------------------- */
.overview { background-color: #e6f9f4; padding: 2rem 0 2rem 0; box-sizing: border-box; }
.overview .overview_frame { width: 96%; margin: 0 auto; }
.overview .overview_frame .overview_left dl.overview_info { 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; }
.overview .overview_frame .overview_left dl.overview_info dt { width: 25%; color: #0d8061; font-size: 1.4rem; border-bottom: #96e6d0 3px dotted; padding: 0 0 0.4rem 0; margin: 0 0 1rem 0; line-height: 120%; }
.overview .overview_frame .overview_left dl.overview_info dd { width: 75%; font-size: 1.4rem; border-bottom: #96e6d0 3px dotted; padding: 0 0 0.4rem 0; margin: 0 0 1rem 0; line-height: 120%; }
.overview .overview_frame .overview_left dl.overview_info dd a { color: #484848; text-decoration: none; }
.overview .overview_frame .overview_right { margin: 2rem 0 0 0; }
.overview .overview_frame .overview_right iframe.googlemap { width: 100%; height: 500px; }

@media screen and (min-width: 768px), print { .overview { background-color: #e6f9f4; padding: 30px 0 14px 0; box-sizing: border-box; }
  .overview .overview_frame { width: 1050px; margin: 0 auto; 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: 525px; }
  .overview .overview_frame .overview_left dl.overview_info { 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: 525px; margin: 0 0 16px 0; }
  .overview .overview_frame .overview_left dl.overview_info dt { width: 130px; color: #0d8061; font-size: 1.6rem; border-bottom: #96e6d0 3px dotted; padding: 0 0 0.3rem 0; margin: 0 0 1rem 0; line-height: 120%; }
  .overview .overview_frame .overview_left dl.overview_info dd { width: 395px; font-size: 1.6rem; border-bottom: #96e6d0 3px dotted; padding: 0 0 0.3rem 0; margin: 0 0 1rem 0; line-height: 120%; }
  .overview .overview_frame .overview_right { width: 500px; margin: 0 0 0 0; }
  .overview .overview_frame .overview_right iframe.googlemap { width: 500px; height: 260px; } }
/* -----------------------------------------------------------
　フッター
----------------------------------------------------------- */
footer .footer_frame { display: none; }
footer .copyright { margin: 0; text-align: center; margin: 0; padding: 0.8rem 0; color: #ffffff; font-size: 1.2rem; height: auto; letter-spacing: 0.05em; background-color: #4dbea0; }
footer .copyright a { color: #ffffff; text-decoration: none; }

.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: 9999999999; }
.footer_link .footer_link_in { width: 80%; }
.footer_link .footer_link_in a.footer_tel { width: 100%; margin: 0 0 1rem; color: #ffffff; text-align: center; font-size: 1.4rem; font-weight: bold; letter-spacing: 0.1em; display: block; background-color: #4dbea0; padding: 1rem 0; text-decoration: none; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; border-radius: 0.6rem; }
.footer_link .footer_link_in a.footer_apoco { width: 100%; margin: 0; color: #ffffff; text-align: center; font-size: 1.4rem; font-weight: bold; letter-spacing: 0.1em; display: block; background-color: #005d9d; padding: 1rem 0; text-decoration: none; display: flex; justify-content: center; align-items: center; flex-wrap: wrap; border-radius: 0.6rem; }
.footer_link .smoothScrolls { background-color: #4dbea0; width: 15%; text-align: center; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; border-radius: 0.6rem; }
.footer_link .smoothScrolls a { width: 100%; color: #ffffff; padding: 0.8rem 0; font-weight: bold; text-decoration: none; font-size: 1.4rem; }

@media screen and (min-width: 768px), print { footer { width: 100%; height: 136px; padding: 0; box-sizing: border-box; padding: 20px 0 0 0; margin: 0 0 0 0; overflow: hidden; background-color: #4dbea0; }
  footer .footer_frame { display: block; width: 1050px; margin: 0 auto; padding: 0 0 6px 0; box-sizing: border-box; }
  footer .footer_frame ul { list-style-type: none; display: -webkit-flex; display: flex; -webkit-justify-content: flex-start; justify-content: flex-start; -webkit-flex-direction: row; flex-direction: row; }
  footer .footer_frame ul li { margin: 0 30px 6px 0; }
  footer .footer_frame ul li a { color: #ffffff; text-decoration: none; line-height: 140%; font-size: 1.4rem; }
  footer .footer_frame ul li a span span { display: none; }
  footer .footer_frame ul li a br { display: none; }
  footer .footer_frame ul li a figure { display: none; }
  footer .footer_frame ul li a:hover { text-decoration: underline; }
  footer .footer_frame ul li.guide { display: none; }
  footer .copyright { display: block; margin: 0; text-align: center; padding: 0 0; color: #ffffff; font-size: 1.2rem; height: auto; max-width: 2000px; border-top: none; letter-spacing: 0.05em; background-color: #4dbea0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-align-items: center; align-items: center; }
  footer .copyright a { width: 1050px; text-align: left; color: #ffffff; text-decoration: none; }
  footer .copyright a:hover { text-decoration: underline; }
  .footer_link { display: none; } }
/* -----------------------------------------------------------
　ページトップへ
----------------------------------------------------------- */
#pagetop_position { display: none; }

@media screen and (min-width: 768px), print { #linkpagetop { float: left; }
  #linkpagetop img { width: 70px; height: auto; display: block; }
  #pagetop { position: fixed; bottom: 0; right: 0; text-align: center; }
  #pagetop a { display: block; color: #ffffff; }
  #pagetop_position { display: block; float: right; margin: 0; padding: 0; } }
/* -----------------------------------------------------------
　
----------------------------------------------------------- */
.main_low_frame ul { padding: 0; margin: 0 0 1rem 0; }
.main_low_frame ul li { line-height: 130%; font-size: 1.4rem; list-style-type: none; margin: 0 0 1rem 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%; }

@media screen and (min-width: 768px), print { .main_low_frame ul { padding: 0; }
  .main_low_frame ul li { line-height: 100%; font-size: 1.7rem; list-style-type: none; margin: 0 0 15px 0; box-sizing: border-box; background: url(../images/maru.png) no-repeat; background-position: left top 4px; background-size: 17px; padding: 0 0 0 25px; line-height: 180%; } }
.floating_bnr { display: none; }

@media screen and (min-width: 768px), print { .floating_bnr { position: fixed; right: 0; top: 50%; transform: translateY(-50%); background-color: #005d9d; color: #fff; font-size: 1.8rem; text-align: center; padding: 30px 20px; border-radius: 10px 0 0 10px; writing-mode: vertical-rl; letter-spacing: 0.2em; display: flex; align-items: center; justify-content: center; cursor: pointer; z-index: 1000; text-decoration: none; }
  .floating_bnr a { color: #fff; text-decoration: none; display: flex; flex-direction: column; align-items: center; justify-content: center; }
  .floating_bnr::before { content: "\e832"; font-family: "fontello"; font-size: 3rem; display: block; margin-bottom: 5px; }
  .floating_bnr:hover { background-color: #1d69a2; } }
.reserve_box { width: 96%; margin: 1rem auto; background-color: #005d9d; color: #fff; display: flex; align-items: center; padding: 1rem 0; }
.reserve_box .icon_reserve { width: 15%; }
.reserve_box .icon_reserve::before { font-family: "fontello"; content: "\e832"; font-size: 6rem; margin-right: 15px; font-style: normal; text-decoration: none; padding-left: 1rem; }
.reserve_box .reserve_content { display: flex; flex-direction: column; justify-content: center; width: 80%; text-align: center; }
.reserve_box .title { font-size: 1.6rem; font-weight: bold; margin-bottom: 1rem; text-decoration: none; letter-spacing: 0.2em; }
.reserve_box .text { background-color: #fff; color: #005d9d; padding: 8px 16px; font-size: 1rem; font-weight: bold; text-decoration: none; display: flex; align-items: center; width: fit-content; margin: 0 auto; }
.reserve_box .text::after { font-family: "fontello"; content: "\e805"; margin-left: 5px; font-size: 1rem; }

@media screen and (min-width: 768px), print { .reserve_box { width: 640px; margin: 3rem auto; background-color: #005d9d; color: #fff; display: flex; align-items: center; padding: 20px; }
  .reserve_box .icon_reserve::before { font-family: "fontello"; content: "\e832"; font-size: 10rem; margin-right: 15px; font-style: normal; text-decoration: none; padding-left: 3rem; }
  .reserve_box .reserve_content { display: flex; flex-direction: column; justify-content: center; width: 100%; text-align: center; }
  .reserve_box .title { font-size: 2.4rem; font-weight: bold; margin-bottom: 10px; text-decoration: none; letter-spacing: 0.2em; }
  .reserve_box .text { background-color: #fff; color: #005d9d; padding: 8px 16px; font-size: 1.4rem; font-weight: bold; text-decoration: none; display: flex; align-items: center; width: fit-content; margin: 0 auto; }
  .reserve_box .text::after { font-family: "fontello"; content: "\e805"; margin-left: 5px; font-size: 1rem; } }

/*# sourceMappingURL=style.css.map */
