@charset "UTF-8";
/* =======================================================================
 共通項目 
======================================================================= */
/*関数*/
/* ----------------------------------------------------------- 関数
----------------------------------------------------------- */
/*サイトの横幅*/
/*media screen*/
/*文字PC*/
/*基本フォント*/
/*游明朝*/
/*基本文字色*/
/*基本背景色PC*/
/*電話番号*/
/*緑１*/
/*黒 ナビ*/
/*緑２*/
/*緑３*/
/*青*/
/*青２*/
/*青３*/
/*青４*/
/*青5*/
/*青6*/
/* ----------------------------------------------------------- フォントサイズ基本
----------------------------------------------------------- */
html { font-size: calc( 100vw / 32 ); overflow-y: auto; font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; color: #222222; background-color: #ffffff; }

@media screen and (min-width: 768px) { html { font-size: 62.5%; overflow-y: scroll; font-family: "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Arial, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif; color: #222222; background-color: #ffffff; } }
/* ----------------------------------------------------------- 構成
----------------------------------------------------------- */
body { position: relative; width: 100%; margin: 0 auto; }

section { height: auto; overflow: hidden; margin: 2rem 0 0 0; }
section.first { margin: 0 0 0 0; }

.sentence { height: auto; overflow: hidden; }

.pc_none { display: block; }

.sp_none { display: none; }

@media screen and (min-width: 768px) { body { position: relative; z-index: 0; max-width: 1920px; margin: 0 auto; }
  section { height: auto; overflow: hidden; margin: 3rem 0 0 0; }
  section.first { margin: 0 0 0 0; }
  .pc_none { display: none; }
  .sp_none { display: block; } }
.mb0 { margin-bottom: 0 !important; }

.mt20 { margin-top: 4.0rem !important; }
@media screen and (min-width: 768px) { .mt20 { margin-top: 6.0rem !important; } }

/* -----------------------------------------------------------
　枠
----------------------------------------------------------- */
article { height: auto; overflow: hidden; width: 100%; margin: 0 auto 0 auto; padding: 0 0 4rem 0; }
article.low { margin: 0 auto; }

.wrapper { height: auto; width: 100%; margin: 0 auto; }

.main { width: 96%; margin: 0 auto 4rem auto; }

@media screen and (min-width: 768px) { article { height: auto; overflow: hidden; width: 100%; margin: 0 auto; padding: 0; }
  article.low { margin: 0 auto; }
  .wrapper { height: auto; width: 100%; margin: 0 auto 80px auto; padding: 0 0 0 0; }
  .main { width: 1080px; margin: 0 auto 40px auto; padding: 0; } }
/* -----------------------------------------------------------
　キービジュアル
----------------------------------------------------------- */
.key_visual_bg { width: 100%; background: url(../images/keyvbg.jpg) no-repeat; background-position: center top 25vw; background-size: cover; position: relative; z-index: 0; padding: 0 0 2rem 0; }
.key_visual_bg .key_visual { display: block; width: 96%; height: 45vw; overflow: hidden; margin: 0 auto; position: relative; z-index: 1; background-size: 100%; }
.key_visual_bg .key_visual p { font-family: "游明朝", "YuMincho", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", serif; color: #006463; font-size: 1.8rem; font-weight: bold; text-align: center; margin: 2rem 0 0 0; text-shadow: 0 3px 4px #fff, 0 2px 4px #fff, 1px 2px 4px #fff, 2px 2px 4px #fff, 2px 1px 4px #fff, 2px 0 4px #fff, 3px 0 4px #fff, 2px -1px 4px #fff, 2px -2px 4px #fff, 2px -3px 4px #fff, 1px -3px 4px #fff, 0 -3px 4px #fff, -1px -3px 4px #fff, -2px -3px 4px #fff, -3px -3px 4px #fff, -3px -2px 4px #fff, -3px -1px 4px #fff, -3px 0 4px #fff, -3px 1px 4px #fff, -3px 2px 4px #fff, -2px 2px 4px #fff, -1px 2px 4px #fff; }

/*下層*/
.key_visual_low { width: 100%; height: 19vw; }
.key_visual_low div { width: 100%; /*background: url(../images/key_low.jpg) no-repeat;
background-size: contain;*/ background: url(../images/key_low_sp.jpg) no-repeat; background-size: contain; height: 19vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; align-items: center; }
.key_visual_low div h1 { color: #222222; text-align: center; font-size: 1.8rem; }

@media screen and (min-width: 768px) { .key_visual_bg { width: 100%; background: url(../images/keyvbg.jpg) no-repeat; background-position: center top 190px; background-size: cover; position: relative; z-index: 0; padding: 0 0 2rem 0; }
  .key_visual_bg .key_visual { display: block; width: 1080px; height: 520px; overflow: hidden; margin: 0 auto; position: relative; z-index: 1; background-size: 100%; }
  .key_visual_bg .key_visual p { font-family: "游明朝", "YuMincho", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", serif; color: #006463; font-size: 3.6rem; font-weight: bold; text-align: center; margin: 122px 0 0 0; line-height: 160%; letter-spacing: 0.3em; text-shadow: 0 3px 18px #fff, 0 2px 18px #fff, 1px 2px 18px #fff, 2px 2px 18px #fff, 2px 1px 8px #fff, 2px 0 18px #fff, 3px 0 18px #fff, 2px -1px 18px #fff, 2px -2px 18px #fff, 2px -3px 18px #fff, 1px -3px 18px #fff, 0 -3px 18px #fff, -1px -3px 18px #fff, -2px -3px 18px #fff, -3px -3px 18px #fff, -3px -2px 18px #fff, -3px -1px 18px #fff, -3px 0 18px #fff, -3px 1px 18px #fff, -3px 2px 18px #fff, -2px 2px 18px #fff, -1px 2px 18px #fff; }
  /*下層*/
  .key_visual_low { width: 100%; height: 200px; background: url(../images/key_low_bg.jpg) no-repeat; background-size: cover; }
  .key_visual_low div { width: 1080px; /*background: url(../images/key_low.jpg) no-repeat;
background-size: contain;*/ background: none; height: 200px; margin: 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; align-items: center; }
  .key_visual_low div h1 { color: #222222; text-align: center; font-size: 3.6rem; } }
/* -----------------------------------------------------------
　診療時間
----------------------------------------------------------- */
table.timetable { padding: 0px; vertical-align: middle; width: 100%; margin: 2rem auto 0 auto; text-align: center; border-collapse: collapse; box-sizing: border-box; border: none; }
table.timetable tr { margin: 0px; padding: 0px; vertical-align: middle; }
table.timetable tr th { padding: 0.8rem 0; text-align: center; font-weight: normal; color: #ffffff; background-color: #1a9c5a; font-size: 1.4rem; vertical-align: middle; box-sizing: border-box; }
table.timetable tr th.holiday { width: 15%; }
table.timetable tr td { text-align: center; padding: 0.8rem 0; color: #1a9c5a; font-size: 1.4rem; vertical-align: middle; box-sizing: border-box; border-bottom: #1a9c5a 1px solid; }
table.timetable tr td.time { width: 35%; color: #222222; font-size: 1.4rem; text-align: center; }
table.timetable tr td.time span { color: #f02525; }

.notice_time { font-size: 1.4rem; color: #222222; line-height: 120%; width: 100%; margin: 15px auto 10px auto; }

@media screen and (min-width: 768px) { table.timetable { padding: 0px; vertical-align: middle; width: 100%; margin: 2rem auto 0 auto; text-align: center; border-collapse: collapse; box-sizing: border-box; border: none; }
  table.timetable tr { margin: 0px; padding: 0px; vertical-align: middle; }
  table.timetable tr th { padding: 0.8rem 0; text-align: center; font-weight: normal; color: #ffffff; background-color: #1a9c5a; font-size: 1.6rem; vertical-align: middle; box-sizing: border-box; }
  table.timetable tr th.holiday { width: 15%; }
  table.timetable tr td { text-align: center; padding: 0.8rem 0; color: #1a9c5a; font-size: 1.6rem; vertical-align: middle; box-sizing: border-box; border-bottom: #1a9c5a 1px solid; }
  table.timetable tr td.time { width: 35%; color: #222222; font-size: 1.6rem; text-align: center; }
  table.timetable tr td.time span { color: #f02525; }
  .notice_time { font-size: 1.6rem; color: #222222; line-height: 140%; width: 100%; margin: 15px auto 10px auto; } }
/* -----------------------------------------------------------
　メインナビ
----------------------------------------------------------- */
.main_nav_pc { display: none; }

@media screen and (min-width: 768px) { .main_nav_pc { display: block; height: 52px; margin: 0 0 30px 0; padding: 0; width: 100%; box-sizing: border-box; }
  .main_nav_pc nav { width: 1080px; height: 52px; margin: 0 auto; }
  .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: 1080px; box-sizing: border-box; height: 50px; padding: 0; position: relative; }
  .main_nav_pc nav ul li { display: block; text-align: center; box-sizing: border-box; height: 52px; line-height: 140%; text-align: center; font-weight: normal; }
  .main_nav_pc nav ul li a { text-decoration: none; color: #555555; height: 52px; width: 100%; display: block; box-sizing: border-box; border-left: #eeeeee 1px solid; margin: 0; font-size: 2rem; font-weight: bold; }
  .main_nav_pc nav ul li a span { display: block; font-size: 1.2rem; color: #1a9c5a; margin: 1rem 0 0 0; }
  .main_nav_pc nav ul li a:hover { opacity: 0.6; }
  .main_nav_pc nav ul li:first-child a { border-left: none; }
  .main_nav_pc nav ul li:nth-child(1) { width: 120px; }
  .main_nav_pc nav ul li:nth-child(2) { width: 140px; }
  .main_nav_pc nav ul li:nth-child(3) { width: 188px; }
  .main_nav_pc nav ul li:nth-child(4) { width: 198px; }
  .main_nav_pc nav ul li:nth-child(5) { width: 199px; }
  .main_nav_pc nav ul li:nth-child(6) { width: 230px; }
  .nav_low { margin: 0 0 0 0; } }
/* -----------------------------------------------------------
　お知らせ
----------------------------------------------------------- */
.notice_frame { width: 96%; margin: 0 auto; }
.notice_frame .notice_frame_title { margin: 0 0 2rem 0; }
.notice_frame .notice_frame_text { box-sizing: border-box; height: 60vw; width: 100%; overflow-y: scroll; }
.notice_frame .notice_frame_text dl dt { margin: 0 0 0.5rem 0; color: #1a9c5a; font-size: 1.6rem; padding: 0; box-sizing: border-box; font-weight: bold; letter-spacing: 0.1em; }
.notice_frame .notice_frame_text dl dd { border-bottom: #aaaaaa 1px dashed; margin: 0 0 2rem 0; }
.notice_frame .notice_frame_text dl dd p { color: #222222; margin: 0 0 2rem 0; font-size: 1.4rem; line-height: 130%; padding: 0; box-sizing: border-box; }

@media screen and (min-width: 768px) { .notice_frame { width: 1080px; height: 220px; margin: 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .notice_frame .notice_frame_title { width: 260px; margin: 0 0 2rem 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; align-items: center; }
  .notice_frame .notice_frame_text { box-sizing: border-box; height: 200px; width: 820px; overflow-y: scroll; margin: 40px 0 0 0; }
  .notice_frame .notice_frame_text dl dt { margin: 0 0 0.8rem 0; color: #1a9c5a; font-size: 2.2rem; padding: 0; box-sizing: border-box; font-weight: bold; letter-spacing: 0.1em; }
  .notice_frame .notice_frame_text dl dd { border-bottom: #aaaaaa 1px dashed; margin: 0 0 2rem 0; }
  .notice_frame .notice_frame_text dl dd p { color: #222222; margin: 0 0 2rem 0; font-size: 1.6rem; line-height: 100%; padding: 0; box-sizing: border-box; } }
/*スマホ用スライドバー*/
@media screen and (max-width: 767px) { .notice_frame_text::-webkit-scrollbar { width: 12px; background: #ffffff; }
  .notice_frame_text::-webkit-scrollbar-track { -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.3); border-radius: 10px; }
  .notice_frame_text::-webkit-scrollbar-thumb { border-radius: 10px; -webkit-box-shadow: inset 0 0 6px rgba(0, 0, 0, 0.5); } }
/* -----------------------------------------------------------
　小林整形外科について
----------------------------------------------------------- */
.about_us { background: url(../images/index_aboutus_bg.jpg) no-repeat; background-size: cover; height: 190vw; margin: 3rem 0 0 0; padding: 2rem 0 0 0; }
.about_us .about_us_frame img { width: 70%; height: auto; display: block; margin: 0 auto; }
.about_us .about_us_frame .about_us_text { background-color: #ffffff; width: 90%; margin: 2rem auto 0 auto; padding: 1rem; box-sizing: border-box; }
.about_us .about_us_frame .about_us_text a { background-color: #70af2a; box-sizing: border-box; color: #ffffff; display: block; font-size: 2rem; padding: 1rem; text-decoration: none; text-align: center; width: 90%; margin: 0 auto; }

@media screen and (min-width: 768px) { .about_us { background: url(../images/index_aboutus_bg.jpg) no-repeat; background-size: cover; height: 814px; margin: 60px 0 0 0; padding: 40px 0 0 0; box-sizing: border-box; }
  .about_us .about_us_frame { position: relative; width: 1080px; margin: 40px auto 0 auto; }
  .about_us .about_us_frame img { position: absolute; top: 0; right: 0; width: 570px; height: auto; display: block; margin: 0 auto; z-index: 1; }
  .about_us .about_us_frame .about_us_text { position: absolute; top: 60px; width: 1080px; height: 480px; z-index: 0; background-color: #ffffff; margin: 0; padding: 60px; box-sizing: border-box; }
  .about_us .about_us_frame .about_us_text p { width: 415px; line-height: 170%; letter-spacing: 0.1em; }
  .about_us .about_us_frame .about_us_text a { background-color: #70af2a; box-sizing: border-box; color: #ffffff; display: block; font-size: 2rem; padding: 18px 0; text-decoration: none; text-align: center; width: 250px; margin: 0; }
  .about_us .about_us_frame .about_us_text a:hover { opacity: 0.6; } }
/* -----------------------------------------------------------
　TOP　フレックスボックス
----------------------------------------------------------- */
.service ul { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; width: 90%; margin: 0 auto; }
.service ul li { display: block; width: 100%; margin: 0 0 2rem 0; }
.service ul li a { text-align: center; text-decoration: none; color: #1a9c5a; font-size: 2rem; font-weight: bold; width: 100%; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; height: 38vw; }
.service ul li:nth-child(1) { background: url(../images/index_service_01.jpg) no-repeat; background-size: 100%; order: 1; }
.service ul li:nth-child(2) { background: url(../images/index_service_02.jpg) no-repeat; background-size: 100%; order: 2; }
.service ul li:nth-child(3) { background: url(../images/index_service_03.jpg) no-repeat; background-size: 100%; order: 4; }
.service ul li:nth-child(4) { background: url(../images/index_service_04.jpg) no-repeat; background-size: 100%; order: 3; }
.service ul li:nth-child(5) { background: url(../images/index_service_05.jpg) no-repeat; background-size: 100%; order: 5; }
.service ul li:nth-child(6) { background: url(../images/index_service_06.jpg) no-repeat; background-size: 100%; order: 6; }

@media screen and (min-width: 768px) { .service { padding: 15px 0 0 0; }
  .service ul { 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: 1080px; margin: 25px auto 0 auto; }
  .service ul li { display: block; width: 530px; margin: 0 0 20px 0; height: 220px; }
  .service ul li a { text-align: center; text-decoration: none; color: #1a9c5a; font-size: 3rem; font-weight: bold; width: 100%; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; height: 220px; }
  .service ul li:hover { opacity: 0.6; }
  .service ul li:nth-child(1) { background: url(../images/index_service_01.jpg) no-repeat; background-size: 100%; order: 1; }
  .service ul li:nth-child(2) { background: url(../images/index_service_02.jpg) no-repeat; background-size: 100%; order: 2; }
  .service ul li:nth-child(3) { background: url(../images/index_service_03.jpg) no-repeat; background-size: 100%; order: 3; }
  .service ul li:nth-child(4) { background: url(../images/index_service_04.jpg) no-repeat; background-size: 100%; order: 4; }
  .service ul li:nth-child(5) { background: url(../images/index_service_05.jpg) no-repeat; background-size: 100%; order: 5; }
  .service ul li:nth-child(6) { background: url(../images/index_service_06.jpg) no-repeat; background-size: 100%; order: 6; } }
/* -----------------------------------------------------------
　医院概要
----------------------------------------------------------- */
.overview { width: 100%; margin: 0 auto; background-color: #f8f8f8; padding: 2rem 0 0 0; }
.overview .overview_frame { width: 96%; margin: 0 auto; }
.overview .overview_frame .overview_frame_left img { width: 80%; height: auto; display: block; margin: 0 auto 2rem auto; }
.overview .overview_frame .overview_frame_left dl { width: 100%; margin: 20px auto 0 auto; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; -webkit-flex-wrap: wrap; flex-wrap: wrap; line-height: 160%; margin: 0 0 20px 0; }
.overview .overview_frame .overview_frame_left dl dt { color: #1a9c5a; font-size: 1.7rem; font-weight: normal; margin: 0; width: 100%; padding: 1rem 0 0 0; box-sizing: border-box; }
.overview .overview_frame .overview_frame_left dl dd { color: #222222; font-size: 1.4rem; margin: 0; width: 100%; padding: 0.5rem 0 0.5rem 0; box-sizing: border-box; border-bottom: #1a9c5a 2px dotted; }
.overview .overview_frame .overview_frame_left dl dd span { color: #222222; text-decoration: none; line-height: 120%; }
.overview .overview_frame .overview_frame_left dl dd a { color: #222222; text-decoration: none; }
.overview .overview_frame .overview_frame_right iframe { width: 100%; height: 600px; }

@media screen and (min-width: 768px) { .overview { width: 100%; margin: 0 auto; background-color: #f8f8f8; padding: 40px 0 36px 0; }
  .overview .overview_frame { width: 1080px; 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_frame_left { width: 500px; }
  .overview .overview_frame .overview_frame_left img { width: 374px; height: auto; display: block; margin: 0 0 35px 0; }
  .overview .overview_frame .overview_frame_left dl { width: 100%; margin: 0 0 30px 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: 160%; }
  .overview .overview_frame .overview_frame_left dl dt { display: -webkit-flex; display: flex; align-items: center; color: #1a9c5a; font-size: 1.6rem; font-weight: bold; margin: 0 0 0 0; display: -webkit-flex; display: flex; align-items: center; width: 110px; height: 52px; padding: 0 0 0 20px; box-sizing: border-box; border-bottom: #1a9c5a 1px dotted; line-height: 140%; }
  .overview .overview_frame .overview_frame_left dl dd { display: -webkit-flex; display: flex; align-items: center; color: #222222; font-size: 1.6rem; margin: 0 0 0 0; border-bottom: #28a7e1 1px solid; width: 390px; height: 52px; padding: 0; box-sizing: border-box; border-bottom: #1a9c5a 1px dotted; line-height: 140%; }
  .overview .overview_frame .overview_frame_left dl dd a { color: #222222; text-decoration: none; }
  .overview .overview_frame .overview_frame_left dl dd span { color: #222222; text-decoration: none; }
  .overview .overview_frame .overview_frame_right { width: 540px; }
  .overview .overview_frame .overview_frame_right iframe { width: 100%; height: 525px; } }
/* -----------------------------------------------------------
　フッターナビ
----------------------------------------------------------- */
.main_nav_2 { display: none; }

@media screen and (min-width: 768px) { .main_nav_2 { display: block; margin: 40px 0 0 0; } }
/* -----------------------------------------------------------
　フッター
----------------------------------------------------------- */
footer .footer_frame { display: none; }
footer .copyright { margin: 0; text-align: center; margin: 0; padding: 0; color: #ffffff; background-color: #1a9c5a; font-size: 1.2rem; height: 10vw; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; align-items: center; }

@media screen and (min-width: 768px) { footer { width: 100%; box-sizing: border-box; padding: 40px 0 0 0; background-color: #dff7d8; }
  footer .footer_frame { display: block; width: 1080px; margin: 0 auto; padding: 0 0 40px 0; box-sizing: border-box; }
  footer .footer_frame .footer_link { width: 780px; margin: 0 auto; }
  footer .footer_frame .footer_link ul { list-style-type: none; font-size: 1.6rem; display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  footer .footer_frame .footer_link ul li { width: auto; line-height: 200%; }
  footer .footer_frame .footer_link ul li a { color: #222222; text-decoration: none; }
  footer .footer_frame .footer_link ul li::after { content: "|"; margin: 0 0 0 10px; }
  footer .footer_frame .footer_link ul li:first-child:before { content: "|"; margin: 0 10px 0 0; }
  footer .copyright { margin: 0; text-align: center; margin: 0; padding: 8px 0; color: #ffffff; background-color: #1a9c5a; font-size: 1.6rem; height: auto; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; align-items: center; } }
/* -----------------------------------------------------------
　ページトップへ
----------------------------------------------------------- */
#linkpagetop { float: right; }

#linkpagetop img { width: 80%; height: auto; }

#pagetop { position: fixed; bottom: 8vw; right: 2px; height: 8vw; text-align: right; margin: 0 2% 0 0; }

#pagetop a { display: block; }

#pagetop_position { float: right; margin: 0px; padding: 0px; }

@media screen and (min-width: 768px) { #linkpagetop { float: left; }
  #linkpagetop img { width: 60px; height: auto; }
  #pagetop { position: fixed; bottom: 130px; left: 50%; margin: 0 0 0 560px; height: 130px; text-align: center; }
  #pagetop a { display: block; color: #ffffff; }
  #pagetop_position { float: right; margin: 0px; padding: 0px; } }
@media screen and (min-width: 768px) and (max-width: 1500px) { #pagetop { position: fixed; bottom: 80px; left: 90%; margin: 0 0 0 0; height: 250px; text-align: center; } }
/*----------------------------------------------------------- インポート
----------------------------------------------------------- */
/*ヘッダー*/
/* -----------------------------------------------------------
　ヘッダ
----------------------------------------------------------- */
header { width: 100%; height: auto; margin: 0 auto; padding: 1rem 0 1.5rem 0; }
header .head_frame { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; width: 96%; margin: 0 auto; padding: 0 0 0 0; }
header .head_frame .head_logo { width: 80%; margin: 0 0 0 0.5rem; }
header .head_frame .head_logo img { width: 100%; height: auto; }
header .head_frame .head_access { text-align: center; font-size: 1.6rem; margin: 2rem 0 0 0; color: #555555; }
header .head_frame .h_tel { text-align: center; font-size: 2rem; border: #1a9c5a 1px solid; padding: 0.5rem; width: 80%; margin: 0.5rem auto; }
header .head_frame .h_tel span { color: #1a9c5a; }
header .head_frame .h_tel a { color: #1a9c5a; text-decoration: none; }

@media screen and (min-width: 768px) { header { width: 1080px; height: 80px; margin: 0 auto; padding: 36px 0 1.5rem 0; }
  header .head_frame { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; width: 1080px; margin: 0 auto; padding: 0 0 0 0; }
  header .head_frame .head_logo { width: 374px; margin: 0 0 0 0.5rem; }
  header .head_frame .head_logo img { width: 374px; height: auto; }
  header .head_frame .head_access { text-align: center; font-size: 1.6rem; margin: 1rem 0 0 0; color: #555555; }
  header .head_frame .h_tel { text-align: center; font-size: 3.2rem; border: #1a9c5a 1px solid; padding: 14px 0; width: 280px; margin: 0; display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; }
  header .head_frame .h_tel span { color: #1a9c5a; }
  header .head_frame .h_tel a { color: #1a9c5a; text-decoration: none; } }
/*ハンバーガー*/
.drawr { display: none; position: absolute; top: 20vw; width: 100%; padding: 0; margin: 0 auto; height: auto; z-index: 999999; background-color: #1a9c5a; }

.openNav { display: block; }

/*ハンバーガーナビ*/
.main_nav_sp { display: block; width: 100%; height: auto; margin: 0; }
.main_nav_sp ul.gnav { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; width: 100%; box-sizing: border-box; margin: 0 auto; }
.main_nav_sp ul.gnav li { width: 100%; font-weight: normal; font-size: 1.6rem; letter-spacing: 0.05em; line-height: 140%; list-style-type: none; box-sizing: border-box; padding: 0; border-bottom: #ffffff 1px solid; text-align: center; }
.main_nav_sp ul.gnav li a { color: #ffffff; text-decoration: none; width: 100%; display: block; padding: 1rem 0; text-shadow: none; box-sizing: border-box; }
.main_nav_sp ul.gnav li a span { display: none; }

@media screen and (min-width: 768px) { .main_nav_sp { display: none; } }
.toggle { display: none; }

.toggle-label { cursor: pointer; display: block; width: 56px; height: 50px; 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; }

.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: #1a9c5a; 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: #1a9c5a; 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: flex; align-items: center; justify-content: center; width: 56px; position: absolute; cursor: pointer; right: 2%; top: 0.5rem; padding: 0 0 0.4rem 0; }

/*アサイド*/
/* -----------------------------------------------------------
　アサイド
----------------------------------------------------------- */
/*SP*/
aside { display: none; }

@media screen and (min-width: 768px) { aside { display: block; width: 285px; background-color: #1a9c5a; }
  aside ul { display: -webkit-flex; display: flex; -webkit-justify-content: center; justify-content: center; -webkit-flex-direction: column; flex-direction: column; list-style-type: none; font-family: "游明朝", "YuMincho", "游明朝体", "YuMincho", "ヒラギノ明朝 ProN", "Hiragino Mincho ProN", "ＭＳ Ｐ明朝", "MS PMincho", serif; margin: 0 0 30px 0; }
  aside ul li { text-align: left; margin: 10px auto 0 auto; width: 265px; }
  aside ul li a { display: block; text-decoration: none; color: #2b3854; font-size: 1.6rem; font-weight: bold; padding: 25px 20px; box-sizing: border-box; background: url(../images/arrow.png) no-repeat; background-position: right 1rem center; background-color: #ffffff; }
  aside ul li a:hover { opacity: 0.6; }
  aside .calendar_frame { background-color: #e2f0d6; padding: 0 0 20px 0; }
  aside .calendar_frame img { margin: 0 0 22px 0; }
  aside .calendar_frame .calendar_info { width: 216px; margin: 10px auto 0 auto; }
  aside .calendar_frame .calendar_info span { font-size: 1.4rem; margin: 0 10px 0 0; }
  aside .calendar_frame .calendar_info span.holiday { background-color: #ffe0e0; border: #bbbbbb 1px solid; width: 20px; margin: 0 5px 0 0; }
  aside .calendar_frame .calendar_info span.amOnly { background-color: #fffaba; border: #bbbbbb 1px solid; width: 20px; margin: 0 5px 0 0; } }
/*イメージ*/
/* -----------------------------------------------------------
　イメージ
----------------------------------------------------------- */
.img_right { margin: 0 0 10px 0; text-align: center; }
.img_right img { width: 70%; height: auto; }

.img_locomo { margin: 0 0 10px 0; text-align: center; }
.img_locomo img { width: 70%; height: auto; }

.img_doctor { margin: 0 0 10px 0; text-align: center; }
.img_doctor 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; }

@media screen and (min-width: 768px) { .img_right { float: right; margin: 0 0 10px 10px; }
  .img_right img { width: 350px; height: auto; }
  .img_locomo { float: right; margin: 0 0 10px 10px; }
  .img_locomo a:hover { opacity: 0.6; }
  .img_locomo img { width: 255px; height: auto; }
  .img_doctor { float: right; margin: 0 0 10px 10px; }
  .img_doctor a:hover { opacity: 0.6; }
  .img_doctor img { width: 450px; 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; } }
/*リスト*/
/* -----------------------------------------------------------
　リスト
----------------------------------------------------------- */
/*標準*/
ul.list_normal { line-height: 160%; font-size: 1.4rem; list-style-type: disc; margin: 0; }
ul.list_normal li { margin: 0 0 10px 1.8rem; padding: 0; }

/*画像●*/
ul.list_maru { padding: 0; margin: 0; }
ul.list_maru 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.gif) 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_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) { /*標準*/
  ul.list_normal { line-height: 160%; font-size: 1.6rem; list-style-type: disc; margin: 0; }
  ul.list_normal li { margin: 0 0 15px 25px; padding: 0; }
  /*画像●*/
  ul.list_maru { padding: 0; }
  ul.list_maru li { line-height: 100%; font-size: 1.6rem; list-style-type: none; margin: 0 0 15px 0; box-sizing: border-box; background: url(../images/maru.gif) no-repeat; background-position: left top 3px; background-size: 1.5rem; padding: 0 0 0 25px; line-height: 140%; }
  /*なし*/
  ul.list_none { line-height: 160%; font-size: 1.6rem; 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.6rem; 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.6rem; 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.6rem; 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: 100%; margin: 0 0 0 0; font-weight: bold; }
dl.bio_list dd { width: 100%; margin: 0 0 20px 0; }

@media screen and (min-width: 768px) { 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.6rem; box-sizing: border-box; line-height: 140%; width: 600px; }
  dl.bio_list dt { width: 80px; margin: 0 0 20px 0; font-weight: normal; }
  dl.bio_list dd { width: 520px; margin: 0 0 20px 0; } }
/*見出し*/
/* -----------------------------------------------------------
　見出し
----------------------------------------------------------- */
h1 { margin: 0; }

h2.top { text-align: center; color: #222222; font-size: 1.8rem; padding: 0.8rem 0; line-height: 100%; }
h2.top span { font-size: 1rem; display: block; font-weight: normal; color: #1a9c5a; margin: 0 0 0.6rem 0; }
h2.top::after { content: url(../images/h2_line.gif); display: block; }

h3 { color: #1a9c5a; font-size: 2rem; margin: 1rem 0 1rem 0; }

h4 { color: #595656; font-size: 1.8rem; padding: 0.8rem 0; margin: 1rem 0 1rem 0; background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ccebfa 0%) repeat scroll 0 0; }

h5 { color: #595656; font-size: 1.6rem; margin: 1rem 0 1rem 0; font-weight: bold; }

p { font-size: 1.4rem; margin: 0 0 2rem 0; line-height: 140%; }

.bold { font-weight: bold; }

.link_text { color: #222222; text-align: right; display: block; }

@media screen and (min-width: 768px) { h1 { margin: 0; }
  h2.top { text-align: center; font-size: 3.6rem; padding: 0.8rem 0; line-height: 90%; color: #222222; margin: 0 0 0.6rem 0; }
  h2.top span { font-size: 1.2rem; display: block; font-weight: normal; }
  h2.top::after { content: url(../images/h2_line.gif); display: block; }
  h2.first { margin: 0 0 1rem 0; }
  h3 { color: #1a9c5a; font-size: 3rem; margin: 10px 0 10px 0; }
  h4 { color: #595656; font-size: 2.2rem; padding: 0.8rem 0; margin: 0 0 1rem 0; background: rgba(0, 0, 0, 0) linear-gradient(transparent 60%, #ccebfa 0%) repeat scroll 0 0; }
  h5 { color: #595656; font-size: 2rem; margin: 1rem 0 1rem 0; font-weight: bold; }
  p { font-size: 1.6rem; margin: 0 0 2rem 0; line-height: 200%; }
  .bold { font-weight: bold; }
  .link_text { color: #222222; text-align: right; display: block; }
  .link_text:hover { opacity: 0.6; } }
/*----------------------------------------------------------- 下層
----------------------------------------------------------- */
/*矢印*/
.arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #1a9c5a; text-align: center; display: block; margin: 30px auto 0 auto; }

/*アクセス*/
.access_frame .access_frame_right iframe { width: 100%; height: 600px; }

@media screen and (min-width: 768px) { /*矢印*/
  .arrow { width: 0; height: 0; border-left: 60px solid transparent; border-right: 60px solid transparent; border-top: 30px solid #1a9c5a; text-align: center; display: block; margin: 30px auto 0 auto; }
  /*アクセス*/
  .access_frame { display: -webkit-flex; display: flex; -webkit-justify-content: space-between; justify-content: space-between; -webkit-flex-direction: row; flex-direction: row; }
  .access_frame .access_frame_left { width: 380px; }
  .access_frame .access_frame_right { width: 700px; }
  .access_frame .access_frame_right iframe { width: 100%; height: 600px; }
  .access_table table.timetable { padding: 0px; vertical-align: middle; width: 100%; margin: 2rem auto 0 auto; text-align: center; border-collapse: collapse; box-sizing: border-box; border: none; }
  .access_table table.timetable tr { margin: 0px; padding: 0px; vertical-align: middle; }
  .access_table table.timetable tr th { padding: 1.2rem 0; text-align: center; font-weight: normal; color: #ffffff; background-color: #1a9c5a; font-size: 1.6rem; vertical-align: middle; box-sizing: border-box; }
  .access_table table.timetable tr th.holiday { width: 15%; }
  .access_table table.timetable tr td { text-align: center; padding: 1.2em 0; color: #1a9c5a; font-size: 1.6rem; vertical-align: middle; box-sizing: border-box; border-bottom: #1a9c5a 1px solid; }
  .access_table table.timetable tr td.time { width: 20%; color: #222222; font-size: 1.6rem; text-align: center; }
  .access_table table.timetable tr td.time span { color: #f02525; } }
/*----------------------------------------------------------- CCSアニメーション
----------------------------------------------------------- */
.appear { transform-origin: center top; animation: show 1s both; }

.appear2 { transform-origin: center top; animation: show2 1s both; }

span.appear { display: inline-block; }

.d1 { animation-delay: 0.2s; }

.d2 { animation-delay: 0.4s; }

.d3 { animation-delay: 0.6s; }

.d4 { animation-delay: 0.8s; }

.d5 { animation-delay: 1.0s; }

.d6 { animation-delay: 1.2s; }

.d7 { animation-delay: 1.4s; }

.d8 { animation-delay: 1.6s; }

@keyframes show { 0% { transform: translate(0, 0); opacity: 0; }
  100% { transform: translate(0, 20px); opacity: 1; } }
@keyframes show2 { 0% { transform: translate(0, 20px); opacity: 0; }
  100% { transform: translate(0, 0); opacity: 1; } }

/*# sourceMappingURL=style.css.map */
