/*
Theme Name: Nakagawa Clinic Theme
Theme URI: 
Author: Nakagawa Clinic
Author URI: 
Description: Original Theme of Nakagawa Clinic
Version: 1.0
License: Nakagawa Clinic
License URI: 
Tags: 
Text Domain: 
*/
@charset "UTF-8";
@import url(https://fonts.googleapis.com/css?family=Montserrat:400,700|Oswald:600|Noto+Serif+JP:900&amp;display=swap);
@font-face {
  font-family: "Yu Gothic M";
  src: local("Yu Gothic Medium")
}
@font-face {
  font-family: "Yu Gothic M";
  font-weight: 700;
  src: local("Yu Gothic Bold")
}
a, abbr, acronym, address, applet, article, aside, audio, b, big, blockquote, body, canvas, caption, center, cite, code, dd, del, details, dfn, div, dl, dt, em, embed, fieldset, figcaption, figure, footer, form, h1, h2, h3, h4, h5, h6, header, hgroup, html, i, iframe, img, ins, kbd, label, legend, li, mark, menu, nav, object, ol, output, p, pre, q, ruby, s, samp, section, small, span, strike, strong, sub, summary, sup, table, tbody, td, tfoot, th, thead, time, tr, tt, u, ul, var, video {
  margin: 0;
  padding: 0;
  border: 0;
  font: inherit;
  font-size: 100%;
  vertical-align: baseline
}
article, aside, details, figcaption, figure, footer, header, hgroup, main, menu, nav, picture, section {
  display: block
}
body {
  line-height: 1
}
ol, ul {
  list-style: none
}
blockquote, q {
  quotes: none
}
blockquote:after, blockquote:before, q:after, q:before {
  content: '';
  content: none
}
table {
  border-spacing: 0;
  border-collapse: collapse
}
*, ::after, ::before {
  -webkit-box-sizing: border-box;
  -moz-box-sizing: border-box;
  box-sizing: border-box
}
html {
  font-size: 62.5%
}
body {
  padding-top: 12rem;
  font-family: "游ゴシック体", YuGothic, "Yu Gothic M", "游ゴシック Medium", "Yu Gothic Medium", "ヒラギノ角ゴ ProN W3", "Hiragino Kaku Gothic ProN W3", HiraKakuProN-W3, "ヒラギノ角ゴ ProN", "Hiragino Kaku Gothic ProN", "ヒラギノ角ゴ Pro", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 1.8rem;
  font-weight: 400;
  color: #222;
  letter-spacing: .05em;
  -webkit-text-size-adjust: 100%;
  -moz-text-size-adjust: 100%;
  -ms-text-size-adjust: 100%;
  text-size-adjust: 100%;
  -webkit-font-feature-settings: "palt";
  -moz-font-feature-settings: "palt";
  font-feature-settings: "palt"
}
body.home {
  padding-top: 0
}
a, a:active, a:link, a:visited {
  text-decoration: none
}
img {
  max-width: 100%;
  vertical-align: bottom
}
.l-container, .l-container-s, .l-fluid {
  width: 100%;
  margin: 0 auto;
  padding-right: 4rem;
  padding-left: 4rem
}
.l-container {
  max-width: 1280px
}
.l-container-s {
  max-width: 1024px
}
.l-offset {
  margin-right: -4rem;
  margin-left: -4rem
}
.l-fluid {
  max-width: 192rem
}
.l-nopadding {
  width: 100%;
  max-width: 1280px;
  margin: 0 auto
}
.l-flex {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.l-flex.a-center {
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.isHover .h-opacity {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .h-opacity:hover {
  opacity: .5
}
.isHover .h-underline:hover {
  text-decoration: underline
}
.isHover .h-a-opacity a {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .h-a-opacity a:hover {
  opacity: .5
}
.isHover .h-a-underline a:hover {
  text-decoration: underline
}
.mt0 {
  margin-top: 0 !important
}
.mt1 {
  margin-top: 1em !important
}
.mt2 {
  margin-top: 2em !important
}
.mt3 {
  margin-top: 3em !important
}
.mt4 {
  margin-top: 4em !important
}
.mt5 {
  margin-top: 5em !important
}
.mt6 {
  margin-top: 6em !important
}
.mt7 {
  margin-top: 7em !important
}
.mt8 {
  margin-top: 8em !important
}
.mt9 {
  margin-top: 9em !important
}
.mt10 {
  margin-top: 10em !important
}
.mr0 {
  margin-right: 0 !important
}
.mr1 {
  margin-right: 1em !important
}
.mr2 {
  margin-right: 2em !important
}
.mr3 {
  margin-right: 3em !important
}
.mr4 {
  margin-right: 4em !important
}
.mr5 {
  margin-right: 5em !important
}
.mr6 {
  margin-right: 6em !important
}
.mr7 {
  margin-right: 7em !important
}
.mr8 {
  margin-right: 8em !important
}
.mr9 {
  margin-right: 9em !important
}
.mr10 {
  margin-right: 10em !important
}
.mb0 {
  margin-bottom: 0 !important
}
.mb1 {
  margin-bottom: 1em !important
}
.mb2 {
  margin-bottom: 2em !important
}
.mb3 {
  margin-bottom: 3em !important
}
.mb4 {
  margin-bottom: 4em !important
}
.mb5 {
  margin-bottom: 5em !important
}
.mb6 {
  margin-bottom: 6em !important
}
.mb7 {
  margin-bottom: 7em !important
}
.mb8 {
  margin-bottom: 8em !important
}
.mb9 {
  margin-bottom: 9em !important
}
.mb10 {
  margin-bottom: 10em !important
}
.ml0 {
  margin-left: 0 !important
}
.ml1 {
  margin-left: 1em !important
}
.ml2 {
  margin-left: 2em !important
}
.ml3 {
  margin-left: 3em !important
}
.ml4 {
  margin-left: 4em !important
}
.ml5 {
  margin-left: 5em !important
}
.ml6 {
  margin-left: 6em !important
}
.ml7 {
  margin-left: 7em !important
}
.ml8 {
  margin-left: 8em !important
}
.ml9 {
  margin-left: 9em !important
}
.ml10 {
  margin-left: 10em !important
}
.pt0 {
  padding-top: 0 !important
}
.pt1 {
  padding-top: 1em !important
}
.pt2 {
  padding-top: 2em !important
}
.pt3 {
  padding-top: 3em !important
}
.pt4 {
  padding-top: 4em !important
}
.pt5 {
  padding-top: 5em !important
}
.pt6 {
  padding-top: 6em !important
}
.pt7 {
  padding-top: 7em !important
}
.pt8 {
  padding-top: 8em !important
}
.pt9 {
  padding-top: 9em !important
}
.pt10 {
  padding-top: 10em !important
}
.pr0 {
  padding-right: 0 !important
}
.pr1 {
  padding-right: 1em !important
}
.pr2 {
  padding-right: 2em !important
}
.pr3 {
  padding-right: 3em !important
}
.pr4 {
  padding-right: 4em !important
}
.pr5 {
  padding-right: 5em !important
}
.pr6 {
  padding-right: 6em !important
}
.pr7 {
  padding-right: 7em !important
}
.pr8 {
  padding-right: 8em !important
}
.pr9 {
  padding-right: 9em !important
}
.pr10 {
  padding-right: 10em !important
}
.pb0 {
  padding-bottom: 0 !important
}
.pb1 {
  padding-bottom: 1em !important
}
.pb2 {
  padding-bottom: 2em !important
}
.pb3 {
  padding-bottom: 3em !important
}
.pb4 {
  padding-bottom: 4em !important
}
.pb5 {
  padding-bottom: 5em !important
}
.pb6 {
  padding-bottom: 6em !important
}
.pb7 {
  padding-bottom: 7em !important
}
.pb8 {
  padding-bottom: 8em !important
}
.pb9 {
  padding-bottom: 9em !important
}
.pb10 {
  padding-bottom: 10em !important
}
.pl0 {
  padding-left: 0 !important
}
.pl1 {
  padding-left: 1em !important
}
.pl2 {
  padding-left: 2em !important
}
.pl3 {
  padding-left: 3em !important
}
.pl4 {
  padding-left: 4em !important
}
.pl5 {
  padding-left: 5em !important
}
.pl6 {
  padding-left: 6em !important
}
.pl7 {
  padding-left: 7em !important
}
.pl8 {
  padding-left: 8em !important
}
.pl9 {
  padding-left: 9em !important
}
.pl10 {
  padding-left: 10em !important
}
.d-n-pclarge {
  display: none
}
.d-n-pc {
  display: none
}
.d-n-tab {
  display: none
}
.d-n-sp {
  display: none
}
.d-n-spsmall {
  display: none
}
.p-para {
  line-height: 2
}
.p-hr {
  width: 30%;
  min-width: 28rem;
  height: .4rem;
  margin: 2em auto;
  border: none;
  background-repeat: repeat-x;
  background-position: center center;
  -webkit-background-size: 1.8rem .4rem;
  -moz-background-size: 1.8rem .4rem;
  background-size: 1.8rem .4rem
}
.p-hr.white {
  background-image: url(images/border_hl_wh.png)
}
.p-hr.green {
  background-image: url(images/border_hl_gr.png)
}
.p-hr.red {
  background-image: url(images/border_hl_re.png)
}
.p-table-container {
  overflow-x: auto;
  overflow-y: hidden;
  padding-top: 1px;
  padding-bottom: 1px;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch
}
.p-table-container table td, .p-table-container table th {
  min-width: 20rem
}
.p-center {
  text-align: center
}
.p-left {
  text-align: left
}
.p-right {
  text-align: right
}
.p-link {
  color: #ed9f54
}
.isHover .p-link:hover {
  text-decoration: underline
}
.Section {
  padding-top: 4em;
  padding-bottom: 4em
}
.Section .Button {
  margin-top: 2em
}
.Section__body, .Section__head {
  min-width: 28rem;
  max-width: 60rem;
  margin: 0 auto
}
.Section__head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  font-size: 1.55556em;
  font-weight: 700;
  line-height: 1.7;
  text-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Section__head .strong {
  color: #ed9f54
}
.Section__head__icon {
  position: relative;
  display: block;
  width: 6.66667em;
  margin: 0 auto;
  margin-bottom: 2em;
  border: 4px solid #a0d5cc;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  background-color: #fff
}
.Section__head__icon::before {
  display: block;
  padding-top: 100%;
  content: ''
}
.Section__head__icon img {
  position: absolute;
  top: 20%;
  left: 20%;
  width: 60%;
  height: 60%
}
.Section__body {
  color: #444;
  text-align: center
}
.Button {
  display: inline-block;
  padding: .75em 3em;
  border: 4px solid;
  border-color: #a0d5cc;
  -webkit-border-radius: 9999px;
  -moz-border-radius: 9999px;
  border-radius: 9999px;
  background-color: #fff;
  font-weight: 700;
  line-height: 1.2;
  color: #222
}
.isHover .Button {
  -webkit-transition: .2s background-color, .2s color;
  -o-transition: .2s background-color, .2s color;
  -moz-transition: .2s background-color, .2s color;
  transition: .2s background-color, .2s color
}
.isHover .Button:hover {
  background-color: #088e78;
  color: #fff
}
.Breadcrumb {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  height: 4em;
  font-size: .88889em;
  color: grey;
  white-space: nowrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Breadcrumb a {
  color: #03816d
}
.Breadcrumb .l-container {
  overflow-x: auto;
  overflow-y: hidden;
  padding-top: 1px;
  padding-bottom: 1px;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch
}
.Pagetop {
  position: fixed;
  z-index: 7000;
  right: 0;
  bottom: -6em;
  display: block;
  width: 6em;
  height: 6em;
  padding: 1em;
  outline: 0;
  -webkit-transition: .4s bottom;
  -o-transition: .4s bottom;
  -moz-transition: .4s bottom;
  transition: .4s bottom
}
.Pagetop img {
  display: block;
  width: 100%;
  height: 100%
}
.isHover .Pagetop {
  -webkit-transition: .2s opacity, .4s bottom;
  -o-transition: .2s opacity, .4s bottom;
  -moz-transition: .2s opacity, .4s bottom;
  transition: .2s opacity, .4s bottom
}
.isHover .Pagetop:hover {
  opacity: .5
}
.isTopper.isActive .Pagetop {
  bottom: 80px
}
.Header {
  position: fixed;
  z-index: 9000;
  top: 0;
  left: 0;
  width: 100%;
  background-color: #fff
}
.home .Header {
  background-color: transparent;
  -webkit-transition: .2s background-color;
  -o-transition: .2s background-color;
  -moz-transition: .2s background-color;
  transition: .2s background-color
}
.home.isTopper.isActive .Header {
  background-color: #fff
}
.Header > .l-nopadding {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  height: 9rem
}
.Header__head {
  height: 100%;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 16.11111em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 16.11111em;
  flex: 0 0 16.11111em
}
.Header__head__logo {
  position: relative;
  width: 100%;
  height: 100%
}
.home .Header__head__logo {
  height: 16.11111em;
  background-color: #088e78;
  -webkit-transition: .4s height, .2s background-color;
  -o-transition: .4s height, .2s background-color;
  -moz-transition: .4s height, .2s background-color;
  transition: .4s height, .2s background-color
}
.home .Header__head__logo img.green {
  opacity: 0
}
.home .Header__head__logo img.white {
  opacity: 1
}
.home.isTopper.isActive .Header__head__logo {
  height: 100%;
  background: 0 0
}
.home.isTopper.isActive .Header__head__logo img.green {
  opacity: 1
}
.home.isTopper.isActive .Header__head__logo img.white {
  opacity: 0
}
.isHover .Header__head__logo a {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .Header__head__logo a:hover {
  opacity: .5
}
.Header__head__logo > * {
  position: absolute;
  top: 20%;
  right: 4rem;
  left: 4rem;
  display: block;
  width: auto;
  height: 60%
}
.Header__head__logo img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.Header__head__logo img.green {
  opacity: 1
}
.Header__head__logo img.white {
  opacity: 0
}
.Header__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Header__body__button {
  margin-left: auto;
  cursor: pointer;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 4rem;
  -moz-box-flex: 0;
  -ms-flex: 0 0 4rem;
  flex: 0 0 4rem
}
.Header__body__button .bar, .Header__body__button::after, .Header__body__button::before {
  display: none
}
.Header__body__button::before {
  top: 34%;
  -webkit-transition: .2s top .2s, -webkit-transform .2s;
  -o-transition: .2s top .2s, -o-transform .2s;
  -moz-transition: .2s top .2s, transform .2s, -moz-transform .2s;
  transition: .2s top .2s, -webkit-transform .2s;
  transition: .2s top .2s, transform .2s;
  transition: .2s top .2s, transform .2s, -webkit-transform .2s, -moz-transform .2s, -o-transform .2s
}
.Header__body__button .bar {
  top: 50%;
  -webkit-transition: 0s opacity .2s;
  -o-transition: 0s opacity .2s;
  -moz-transition: 0s opacity .2s;
  transition: 0s opacity .2s
}
.Header__body__button::after {
  top: 66%;
  -webkit-transition: .2s top .2s, -webkit-transform .2s;
  -o-transition: .2s top .2s, -o-transform .2s;
  -moz-transition: .2s top .2s, transform .2s, -moz-transform .2s;
  transition: .2s top .2s, -webkit-transform .2s;
  transition: .2s top .2s, transform .2s;
  transition: .2s top .2s, transform .2s, -webkit-transform .2s, -moz-transform .2s, -o-transform .2s
}
.Header__body__button.isActive::before {
  top: 50%;
  -webkit-transition: .2s top, .2s -webkit-transform .2s;
  -o-transition: .2s top, .2s -o-transform .2s;
  -moz-transition: .2s top, .2s transform .2s, .2s -moz-transform .2s;
  transition: .2s top, .2s -webkit-transform .2s;
  transition: .2s top, .2s transform .2s;
  transition: .2s top, .2s transform .2s, .2s -webkit-transform .2s, .2s -moz-transform .2s, .2s -o-transform .2s;
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg)
}
.Header__body__button.isActive .bar {
  opacity: 0
}
.Header__body__button.isActive::after {
  top: 50%;
  -webkit-transition: .2s top, .2s -webkit-transform .2s;
  -o-transition: .2s top, .2s -o-transform .2s;
  -moz-transition: .2s top, .2s transform .2s, .2s -moz-transform .2s;
  transition: .2s top, .2s -webkit-transform .2s;
  transition: .2s top, .2s transform .2s;
  transition: .2s top, .2s transform .2s, .2s -webkit-transform .2s, .2s -moz-transform .2s, .2s -o-transform .2s;
  -webkit-transform: rotate(-45deg);
  -moz-transform: rotate(-45deg);
  -ms-transform: rotate(-45deg);
  -o-transform: rotate(-45deg);
  transform: rotate(-45deg)
}
.Header__body__content {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: end;
  -ms-flex-align: center;
  width: 100%;
  height: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: end;
  -webkit-justify-content: flex-end;
  -moz-box-pack: end;
  justify-content: flex-end
}
.Header__body__content .phc {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  margin-right: auto;
  font-weight: 700;
  color: #fff;
  -webkit-transition: .2s color;
  -o-transition: .2s color;
  -moz-transition: .2s color;
  transition: .2s color;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Header__body__content .phc .img {
  position: relative;
  height: 2.5em;
  margin-right: .5em;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 2.5em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 2.5em;
  flex: 0 0 2.5em
}
.Header__body__content .phc .img img {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.Header__body__content .phc .img img.white {
  opacity: 1
}
.Header__body__content .phc .img img.gray {
  opacity: 0
}
.Header__body__content .phc .text {
  font-size: .77778em;
  line-height: 1.2;
  white-space: nowrap
}
.isTopper.isActive .Header__body__content .phc {
  color: #444
}
.isTopper.isActive .Header__body__content .phc .img img.white {
  opacity: 0
}
.isTopper.isActive .Header__body__content .phc .img img.gray {
  opacity: 1
}
.Header__body__content > * {
  margin-left: 2em
}
.Header__body__content .tel {
  font-weight: 700;
  color: inherit
}
.Header__body__content .tel, .Header__body__content .tel > * {
  display: block
}
.Header__body__content .tel .small {
  margin-bottom: .25em;
  font-size: .66667em;
  color: #444
}
.Header__body__content .tel .strong {
  font-size: 1.66667em;
  color: #03816d
}
.Header__body__content .Button {
  font-size: .88889em
}
.isHover .Header__body__content .Button:hover {
  background-color: #fff
}
.isHover .Header__body__content .Button:hover::before {
  opacity: .5
}
.isHover .Header__body__content .Button::before {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.Header__nav {
  height: 3rem;
  font-size: .77778em
}
.Header__nav__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  height: 100%;
  line-height: 1.4;
  text-align: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Header__nav__list li {
  border-left: 1px solid grey;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Header__nav__list li:last-child {
  border-right: 1px solid grey
}
.Header__nav__list li a {
  display: block;
  color: #222
}
.isHover .Header__nav__list li a {
  -webkit-transition: .2s color;
  -o-transition: .2s color;
  -moz-transition: .2s color;
  transition: .2s color
}
.isHover .Header__nav__list li a:hover {
  color: #03816d
}
.Footer__head {
  background: #ecf2f1
}
.Footer__copy {
  padding: 2em;
  font-size: .77778em;
  line-height: 1.2;
  color: #444;
  text-align: center
}
.Footer__nav__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  justify-content: space-between
}
.Footer__nav__list li {
  margin-bottom: 1em
}
.Footer__nav__list li:last-of-type {
  margin-bottom: 0
}
.Footer__nav__list li a {
  line-height: 1.4
}
.Footer__nav__list > li {
  margin-bottom: 0
}
.Footer__nav__list > li > a {
  font-weight: 700;
  color: #03816d
}
.Footer__nav__list .sub-menu {
  margin-top: 1em;
  font-size: .88889em
}
.Footer__nav__list .sub-menu li::before {
  color: #03816d;
  content: '・'
}
.Footer__nav__list .sub-menu li a {
  color: #444
}
.Nav {
  overflow: hidden
}
.Nav > .l-nopadding {
  position: relative
}
.Nav > .l-nopadding::after, .Nav > .l-nopadding::before {
  display: none;
  margin-top: -.2rem
}
.Nav__list {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.Nav__list::after, .Nav__list::before, .Nav__list > li::after {
  position: absolute;
  top: 1em;
  bottom: 1em;
  display: block;
  width: .4rem;
  height: auto;
  background-image: url(images/border_vr_gr.png);
  background-repeat: repeat-y;
  background-position: center top;
  -webkit-background-size: .4rem 1.8rem;
  -moz-background-size: .4rem 1.8rem;
  background-size: .4rem 1.8rem;
  content: ''
}
.isHover .Nav__list > li a .image::after {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .Nav__list > li a:hover .image::after {
  opacity: 0
}
.Nav__list::before {
  left: 0
}
.Nav__list::after {
  right: 0
}
.Nav__list > li {
  position: relative;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Nav__list > li::before {
  position: absolute;
  top: 0;
  right: 1em;
  left: 1em;
  display: none;
  width: auto;
  height: .4rem;
  margin-top: -.2rem;
  background-image: url(images/border_hl_gr.png);
  background-repeat: repeat-x;
  background-position: center center;
  -webkit-background-size: 1.8rem .4rem;
  -moz-background-size: 1.8rem .4rem;
  background-size: 1.8rem .4rem;
  content: ''
}
.Nav__list > li::after {
  right: -.2rem;
  content: ''
}
.Nav__list > li a {
  position: relative;
  display: block;
  padding-top: 3em;
  padding-bottom: 3em;
  font-size: .83333em;
  font-weight: 700;
  color: #222;
  text-align: center
}
.Nav__list > li a .image {
  position: relative;
  display: block;
  width: 4em;
  height: 4em;
  margin: 0 auto;
  margin-bottom: 1em
}
.Nav__list > li a .image::after, .Nav__list > li a .image::before {
  position: absolute;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-color: #fff;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  background-size: contain;
  content: ''
}
.Nav__list > li.about a .image::before {
  background-image: url(images/icon/about_or.svg)
}
.Nav__list > li.about a .image::after {
  background-image: url(images/icon/about_gr.svg)
}
.Nav__list > li.medical a .image::before {
  background-image: url(images/icon/medical_or.svg)
}
.Nav__list > li.medical a .image::after {
  background-image: url(images/icon/medical_gr.svg)
}
.Nav__list > li.treatment a .image::before {
  background-image: url(images/icon/treatment_or.svg)
}
.Nav__list > li.treatment a .image::after {
  background-image: url(images/icon/treatment_gr.svg)
}
.Nav__list > li.online a .image::before {
  background-image: url(images/icon/online_or.svg)
}
.Nav__list > li.online a .image::after {
  background-image: url(images/icon/online_gr.svg)
}
.Nav__list > li.access a .image::before {
  background-image: url(images/icon/access_or.svg)
}
.Nav__list > li.access a .image::after {
  background-image: url(images/icon/access_gr.svg)
}
.Nav__list > li.news a .image::before {
  background-image: url(images/icon/news_or.svg)
}
.Nav__list > li.news a .image::after {
  background-image: url(images/icon/news_gr.svg)
}
.Nav__list > li.news::after {
  display: none
}
.Nav__sp {
  position: fixed;
  z-index: 8000;
  top: 0;
  left: 0;
  overflow: hidden;
  width: 100%;
  height: auto;
  height: 0;
  background-color: rgba(0, 0, 0, .5);
  -webkit-transition: .4s height;
  -o-transition: .4s height;
  -moz-transition: .4s height;
  transition: .4s height
}
.Nav__sp__container {
  overflow-y: auto;
  max-height: 100%;
  padding-top: 12rem;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch
}
.home .Nav__sp__container {
  padding-top: 9rem
}
.Nav__sp .Nav {
  border-top: 1px solid #a0d5cc;
  background-color: #fff
}
.Nav__sp.isActive {
  height: 100%
}
.Page__head {
  position: relative;
  overflow: hidden;
  height: 12em;
  background-color: #ecf2f1
}
.Page__head .l-container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  height: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Page__head__image {
  position: relative;
  display: block;
  width: 4.44444em;
  height: 4.44444em;
  border: 3px solid #a0d5cc;
  -webkit-border-radius: 9999px;
  -moz-border-radius: 9999px;
  border-radius: 9999px;
  background-color: #fff;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 4.44444em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 4.44444em;
  flex: 0 0 4.44444em
}
.Page__head__image img {
  position: absolute;
  top: 20%;
  left: 20%;
  width: 60%;
  height: 60%
}
.Page__head__head {
  position: relative;
  margin-left: 1em;
  font-size: 1.22222em;
  font-weight: 700;
  line-height: 1.4
}
.Contact {
  position: relative;
  overflow: hidden;
  background-image: url(images/bg_contact_pc.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover
}
.Contact .p-hr {
  margin-top: 1.5em
}
.Contact__inner {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Contact__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: .5em;
  line-height: 1.4;
  white-space: nowrap
}
.Contact__item:last-of-type {
  margin-bottom: 0
}
.Contact__item .head {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 3em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 3em;
  flex: 0 0 3em
}
.Contact__item a {
  color: #ed9f54
}
.Contact::before {
  position: absolute;
  top: 0;
  left: 32.5%;
  display: block;
  width: 35%;
  height: 100%;
  background-image: url(images/bg_circle_wh.svg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  content: ''
}
.Contact > * {
  position: relative
}
.Contact__container {
  width: 35%;
  min-width: 26rem;
  margin: 0 auto
}
.Contact__container .Section__body, .Contact__container .Section__head, .Contact__container .p-hr {
  min-width: 26rem
}
.Contact .Section__head {
  color: #03816d
}
.Contactpage {
  max-width: 1024px;
  margin: 0 auto
}
.Contactpage__content {
  margin-top: 2em;
  font-size: 1.11111em;
  line-height: 1.7;
  text-align: center
}
.Contactpage__form {
  padding: 4em;
  background: #ecf2f1
}
.Contactpage__form .wpcf7-list-item-label a {
  color: #ed9f54;
  text-decoration: underline
}
.Contactpage__form .wpcf7-list-item-label a[target="_blank"] {
  padding-right: 0
}
.Contactpage__form .wpcf7-list-item-label a[target="_blank"]::after, .Contactpage__form .wpcf7-list-item-label a[target="_blank"]::before {
  display: none
}
.isHover .Contactpage__form .wpcf7-list-item-label a:hover {
  text-decoration: none
}
.Contactpage__form input, .Contactpage__form textarea, .Contactpage__form select {
  max-width: 100%;
  padding: .75em .5em;
  border: none;
  background: #fff;
  font-family: inherit;
  font-size: inherit;
  line-height: inherit;
  color: inherit;
  letter-spacing: inherit;
  margin-bottom: 0.25em;
}
.Contactpage__form input.Button, .Contactpage__form textarea.Button {
  padding: .75em 2em
}
.Contactpage__form input.Button.primary, .Contactpage__form textarea.Button.primary, .Contactpage__form button.Button.primary {
  background-color: #088e78;
  color: #fff
}
.Contactpage__form textarea {
  min-width: 100%;
  max-width: 100%;
  line-height: 1.7
}
.Contactpage__form__list {
  line-height: 1.4
}
.Contactpage__form__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  margin-bottom: 2em;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Contactpage__form__item:last-of-type {
  margin-bottom: 0
}
.Contactpage__form__item__head {
  max-width: 30%;
  font-weight: 700;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 30%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 30%;
  flex: 0 0 30%
}
.Contactpage__form__item.required .Contactpage__form__item__head::after {
  display: inline-block;
  margin-left: .5em;
  padding: .15em .5em;
  -webkit-border-radius: .25em;
  -moz-border-radius: .25em;
  border-radius: .25em;
  background: #edb781;
  font-size: .7em;
  color: #fff;
  vertical-align: .15em;
  content: '必須'
}
.Contactpage__form__item__body {
  max-width: 70%;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 70%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 70%;
  flex: 0 0 70%
}
.Contactpage__form__action {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  margin-top: 2em;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Contactpage__form__action .Button {
  margin-top: 0;
  font-family: inherit;
  font-size: inherit
}
.Contactpage__form__action .Button:not(.border) {
  border: none
}
.Contactpage__form__action .Button + .Button {
  margin-left: 1em
}
.Gmap {
  width: 100%;
  height: 24em
}
.Gmap iframe {
  width: 100%;
  height: 100%
}
.Gmap.large {
  height: 32em
}
.Schedule table {
  width: 100%
}
.Schedule table tr {
  border-bottom: 1px solid #a0d5cc
}
.Schedule table td, .Schedule table th {
  padding-top: 1em;
  padding-bottom: 1em;
  vertical-align: middle
}
.Schedule table td .small, .Schedule table th .small {
  display: none
}
.Schedule table thead tr th {
  padding-top: 0
}
.Schedule table thead tr th:first-of-type {
  text-align: left
}
.Schedule table thead tr th.week {
  padding-right: .25em;
  padding-left: .25em
}
.Schedule table thead tr:first-of-type th:first-of-type {
  font-weight: 700;
  color: #03816d
}
.Schedule table tbody tr td {
  text-align: center
}
.Schedule table tbody tr td.p-left {
  text-align: left
}
.Schedule table tbody tr td.key {
  font-weight: 700;
  color: #03816d
}
.Schedule__comment {
  margin-top: 1em;
  font-size: .88889em;
  line-height: 1.4;
  color: #444
}
.Schedule__comment .strong {
  display: block;
  color: #ed9f54
}
.Post {
  line-height: 2;
  color: #444
}
.Post > * {
  margin-bottom: 2em
}
.Post > :first-child {
  margin-top: 0
}
.Post > :last-child {
  margin-bottom: 0
}
.Post h2, .Post h3, .Post h4, .Post h5, .Post h6 {
  margin-top: 3em;
  margin-bottom: 1.5em;
  font-weight: 700;
  line-height: 1.4;
  color: #222
}
.Post h2 {
  padding-top: .25em;
  padding-bottom: .25em;
  padding-left: 2rem;
  border-left: 8px solid #088e78;
  font-size: 1.22222em
}
.Post h3 {
  padding-left: 2rem;
  border-left: 8px solid #a0d5cc;
  font-size: 1.16667em
}
.Post h4 {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  font-size: 1.11111em;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Post h4::before {
  display: block;
  width: .5em;
  height: .5em;
  margin-right: 2rem;
  background-color: #ecf2f1;
  content: '';
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 .5em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 .5em;
  flex: 0 0 .5em
}
.Post h5 {
  font-size: 1.05556em
}
.Post a:not(.Button) {
  color: #ed9f54;
  text-decoration: underline
}
.isHover .Post a:hover {
  text-decoration: none
}
.Post a[target="_blank"] {
  position: relative;
  display: inline-block;
  padding-right: 1em
}
.Post a[target="_blank"]::after, .Post a[target="_blank"]::before {
  position: absolute;
  display: block;
  border: 1px solid #edb781;
  content: ''
}
.Post a[target="_blank"]::before {
  right: .4em;
  bottom: 30%;
  width: .5em;
  height: .5em
}
.Post a[target="_blank"]::after {
  top: 25%;
  right: 0;
  width: .65em;
  height: .65em
}
.Post table {
  width: 100%
}
.Post table td, .Post table th {
  padding: 1em;
  border: 1px solid #fff
}
.Post table thead tr th {
  background-color: #a0d5cc;
  font-weight: 700;
  line-height: 1.4;
  color: #222
}
.Post table tbody tr td {
  background-color: #ecf2f1;
  font-size: .88889em
}
.Post img {
  height: auto !important;
  border: .5em solid #ecf2f1
}
.Pagination {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  margin-top: 4em;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Pagination > a, .Pagination > span {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  height: 2em;
  margin-right: 1em;
  border: 1px solid grey;
  -webkit-border-radius: 9999px;
  -moz-border-radius: 9999px;
  border-radius: 9999px;
  color: grey;
  letter-spacing: 0;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 2em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 2em;
  flex: 0 0 2em;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Pagination > a.pages, .Pagination > span.pages {
  display: none
}
.Pagination > a.current, .Pagination > span.current {
  border-color: #088e78;
  color: #03816d
}
.isHover .Pagination > a {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .Pagination > a:hover {
  opacity: .5
}
.Index__mv {
  overflow: hidden;
  min-height: 40rem;
  max-height: 64rem;
  background-image: url(images/mv_pc.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover
}
.Index__mv::before {
  display: block;
  padding-top: 40%;
  content: ''
}
.Index__intro {
  background-color: #ecf2f1
}
.Index__intro .Section__head .phc {
  display: inline-block;
  color: #ed9f54
}
.Index__intro .Section__head .phc img {
  display: inline-block;
  width: 1.4em;
  height: 1.4em;
  margin-right: .25em;
  vertical-align: middle
}
.isHover .Index__intro .Section__head .phc {
  -webkit-transition: .2s opacity;
  -o-transition: .2s opacity;
  -moz-transition: .2s opacity;
  transition: .2s opacity
}
.isHover .Index__intro .Section__head .phc:hover {
  opacity: .5
}
.Index__consultation {
  position: relative
}
.Index__consultation::before {
  position: absolute;
  z-index: -1;
  top: 0;
  left: 0;
  display: block;
  width: 100%;
  height: 100%;
  background-image: url(images/bg_consultation_pc.jpg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  content: ''
}
.Index__consultation__list {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.Index__consultation__item {
  position: relative;
  padding: 2em 2em 4em;
  background: rgba(255, 255, 255, .9);
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Index__consultation__item.immunity {
  margin-right: 2rem
}
.Index__consultation__item.immunity .title::before {
  background-image: url(images/icon/immunity_or.svg)
}
.Index__consultation__item.flora {
  margin-left: 2rem
}
.Index__consultation__item.flora .title::before {
  background-image: url(images/icon/flora_or.svg)
}
.Index__consultation__item .title {
  position: relative;
  font-size: 1.55556em;
  font-weight: 700;
  line-height: 1.4;
  text-align: center
}
.Index__consultation__item .title.small {
  font-size: 1.44444em
}
.Index__consultation__item .title > * {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  width: 100%;
  height: 100%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Index__consultation__item .title::before {
  display: block;
  width: 4em;
  height: 4em;
  margin: 0 auto;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: cover;
  -moz-background-size: cover;
  background-size: cover;
  content: ''
}
.Index__consultation__item .subtitle {
  margin-top: 2em;
  margin-bottom: 1em;
  padding: .5em;
  background: #edb781;
  font-size: 1.11111em;
  font-weight: 700;
  line-height: 1.4;
  color: #fff;
  text-align: center
}
.Index__consultation__item .desc {
  font-size: .91667em;
  line-height: 1.7;
  color: #444
}
.Index__consultation__item .desc .strong {
  font-weight: 700;
  color: #222
}
.Index__consultation__item .link {
  position: absolute;
  right: 2em;
  bottom: 2em;
  text-align: right
}
.Index__consultation__item .link a {
  font-weight: 700;
  color: #ed9f54
}
.Index__online {
  background: #088e78
}
.Index__online .Section__head {
  color: #fff
}
.Index__online .Section__head .strong {
  color: #edb781
}
.Index__online .Section__body {
  color: #fff
}
.Index__online .Section__body .strong {
  font-weight: 700;
  color: #edb781
}
.Index__important {
  padding: 3em 0
}
.Index__important__container {
  overflow-y: auto;
  max-height: 20em;
  padding: 2em;
  border: 4px solid #edbfb7;
  -webkit-overflow-scrolling: touch;
  overflow-scrolling: touch
}
.Index__important .Section__head {
  color: #e3533a
}
.Index__news__container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Index__news__head {
  padding-right: 4rem;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 22.22222em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 22.22222em;
  flex: 0 0 22.22222em
}
.Index__news__head .Section__head {
  color: #03816d
}
.Index__news__head .Section__body {
  font-size: .88889em
}
.Index__news__body {
  padding-left: 4rem;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Index__news__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  padding: 1.5em 0;
  border-bottom: 1px solid #a0d5cc;
  line-height: 1.4;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -moz-box-orient: horizontal;
  -moz-box-direction: reverse
}
.Index__news__item:last-of-type {
  border-bottom: none
}
.Index__news__item .time {
  color: grey;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 20%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 20%;
  flex: 0 0 20%
}
.title{
    margin: 1em 0;
    font-size: 1.22222em;
    font-weight: 700;
    line-height: 1.4;
    color: #03816d;
}
.col_internal_chuumidashi{
    margin: 2em 0 1em 0;
    font-size: 1.5em;
    font-weight: 700;
    line-height: 1.4;
    color: #03816d;
	text-align: center;
}
.Index__news__item a {
  color: #ed9f54;
  text-decoration: underline;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 80%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 80%;
  flex: 0 0 80%
}
.isHover .Index__news__item a:hover {
  text-decoration: none
}
.Index__info.Section {
  padding-top: 2em;
  padding-bottom: 2em
}
.Index__info__container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Index__info__head {
  position: relative;
  margin-top: -4em;
  margin-bottom: -4em;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 16.66667em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 16.66667em;
  flex: 0 0 16.66667em
}
.Index__info__head::before {
  display: block;
  padding-top: 100%;
  content: ''
}
.Index__info__head__container {
  position: absolute;
  top: 0;
  left: 0;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  width: 100%;
  height: 100%;
  padding-right: 4rem;
  padding-left: 4rem;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Index__info__head__container::before {
  position: absolute;
  z-index: 0;
  top: -10%;
  left: -10%;
  display: block;
  width: 120%;
  height: 120%;
  -webkit-border-radius: 9999px;
  -moz-border-radius: 9999px;
  border-radius: 9999px;
  background-color: #088e78;
  content: ''
}
.Index__info__head__inner {
  position: relative;
  width: 100%
}
.Index__info__head__inner .logo {
  width: 100%;
  margin-bottom: 1.5em
}
.Index__info__head__inner .logo .green {
  display: none
}
.Index__info__head__inner .info {
  font-size: .77778em;
  line-height: 1.4;
  color: #fff;
  text-align: left
}
.Index__info__head__inner .info dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: .5em
}
.Index__info__head__inner .info dl:last-of-type {
  margin-bottom: 0
}
.Index__info__head__inner .info dl dt {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 4em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 4em;
  flex: 0 0 4em
}
.Index__info__head__inner .info dl dt::after {
  content: '：';
  opacity: .5
}
.Index__info__head__inner .info dl dd a {
  color: inherit
}
.Index__info__head__inner .p-hr {
  width: 100%;
  min-width: 0
}
.Index__info__body {
  padding-left: 8rem;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Archive__container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.Archive__main {
  padding-right: 4rem;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Archive__main .Index__news__list {
  margin-top: 0;
  border-top: none
}
.Archive__main .Index__news__item:last-of-type {
  border-bottom: none
}
.Archive__side {
  padding-left: 4rem;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 15.55556em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 15.55556em;
  flex: 0 0 15.55556em
}
.Archive__side__head {
  margin-bottom: 1em;
  font-weight: 700;
  line-height: 1.4
}
.Archive__side > * {
  margin-bottom: 4em
}
.Archive__side > :last-of-type {
  margin-bottom: 0
}
.Archive__side__recent .Archive__side__list li {
  margin-bottom: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #ececec
}
.Archive__side__recent .Archive__side__list li .time {
  display: block;
  margin-top: .25em;
  font-size: .88889em;
  color: grey
}
.Archive__side__recent .Archive__side__list li a {
  line-height: 1.4;
  color: #ed9f54
}
.Archive__side__recent .Archive__side__list li:last-of-type {
  border-bottom: none
}
.isHover .Archive__side__recent .Archive__side__list li a {
  text-decoration: underline
}
.isHover .Archive__side__recent .Archive__side__list li a:hover {
  text-decoration: none
}
.Archive__side__monthly .Archive__side__list li {
  margin-bottom: 1px
}
.Archive__side__monthly .Archive__side__list li a {
  position: relative;
  display: block;
  padding: 1em 2.5em 1em 1em;
  background: #ecf2f1;
  color: #222
}
.Archive__side__monthly .Archive__side__list li a::after {
  position: absolute;
  top: 50%;
  right: 1em;
  display: block;
  width: .5em;
  height: .5em;
  margin-top: -.25em;
  border-top: 1px solid #088e78;
  border-right: 1px solid #088e78;
  -webkit-border-top-right-radius: .1em;
  border-top-right-radius: .1em;
  content: '';
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg);
  -moz-border-radius-topright: .1em
}
.Archive__side__monthly .Archive__side__list li:last-of-type {
  margin-bottom: 0
}
.isHover .Archive__side__monthly .Archive__side__list li a {
  -webkit-transition: .2s background-color, .2s color;
  -o-transition: .2s background-color, .2s color;
  -moz-transition: .2s background-color, .2s color;
  transition: .2s background-color, .2s color
}
.isHover .Archive__side__monthly .Archive__side__list li a:hover {
  background-color: #088e78;
  color: #fff
}
.isHover .Archive__side__monthly .Archive__side__list li a:hover::after {
  border-color: #fff
}
.isHover .Archive__side__monthly .Archive__side__list li a::after {
  -webkit-transition: .2s border-color;
  -o-transition: .2s border-color;
  -moz-transition: .2s border-color;
  transition: .2s border-color
}
.Archive__date::after {
  display: block;
  width: 2em;
  height: 4px;
  margin-top: 1.5em;
  background-color: #a0d5cc;
  content: ''
}
.Archive__date > * {
  display: inline-block
}
.Archive__date .strong {
  font-size: 1.22222em
}
.Single__head {
  font-size: 1.44444em;
  font-weight: 700;
  line-height: 1.4
}
.Single__info {
  margin-bottom: 2em;
  padding-bottom: 2em;
  border-bottom: 1px solid #ececec
}
.Single__info__time {
  display: block;
  margin-top: 1em;
  font-weight: 700;
  color: grey
}
.Single__nav {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  overflow: hidden;
  margin-top: 4em;
  border: 1px solid #088e78;
  text-align: center
}
.isHover .Single__nav > * > a {
  -webkit-transition: .2s background-color;
  -o-transition: .2s background-color;
  -moz-transition: .2s background-color;
  transition: .2s background-color
}
.isHover .Single__nav > * > a:hover {
  background-color: rgba(8, 142, 120, .15)
}
.Single__nav > * {
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Single__nav > * > * {
  display: block;
  padding: 1em;
  color: grey
}
.Single__nav > * > a {
  color: #03816d
}
.Single__nav__left {
  border-right: 1px solid #088e78
}
.Single__nav__center {
  border-right: 1px solid #088e78
}
.Single__nav__bottom {
  display: none
}
.Access__head {
  display: inline-block;
  padding: .5em 1em;
  background-color: #088e78;
  font-weight: 700;
  line-height: 1.4;
  color: #fff
}
.Access__map .Access__head {
  margin-bottom: -4em
}
.Access__map__container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -moz-box-orient: horizontal;
  -moz-box-direction: reverse
}
.Access__map__head {
  position: relative;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 40%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 40%;
  flex: 0 0 40%
}
.Access__map__head::before {
  display: block;
  padding-top: 100%;
  content: ''
}
.Access__map__head .image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%
}
.Access__map__head .image img {
  width: 100%;
  height: 100%
}
.Access__map__body {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 60%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 60%;
  flex: 0 0 60%
}
.Access__map__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  padding: 1.5em 0;
  border-bottom: 1px solid #a0d5cc;
  white-space: nowrap;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  justify-content: space-between
}
.Access__map__item > * {
  font-size: 1.44444em;
  line-height: 1.2
}
.Access__map__item:last-of-type {
  border-bottom: none
}
.Access__map__item dt .number {
  display: none;
  font-size: .75em
}
.Access__map__item dt .small {
  margin-top: .25em;
  margin-left: .25em
}
.Access__map__item dd .small {
  margin-right: .25em
}
.Access__map__item .small {
  display: inline-block;
  font-size: .75em;
  color: #444
}
.Access__root {
  background-color: #ecf2f1
}
.Access__root__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 4em
}
.Access__root__head {
  font-size: 1.33333em;
  font-weight: 700;
  line-height: 1.2;
  text-align: center
}
.Access__root__item {
  padding-top: 2em;
  padding-right: 4rem;
  padding-bottom: 2em;
  padding-left: 4rem;
  border: 4px solid #a0d5cc;
  background-color: #fff;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Access__root__item__container .image {
  margin: 0 auto 1em
}
.Access__root__item__container .image, .Access__root__item__container .image img {
  display: block;
  width: 4em;
  height: 4em
}
.Access__root__item__container .data {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: justify;
  -ms-flex-align: center;
  min-height: 2.66667em;
  margin-bottom: 2em;
  white-space: nowrap;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: justify;
  -webkit-justify-content: space-between;
  -moz-box-pack: justify;
  justify-content: space-between
}
.Access__root__item__container .data:last-of-type {
  margin-bottom: 0
}
.Access__root__item__container .data .bar {
  height: 1px;
  margin-right: 3em;
  margin-left: 1.5em;
  background-color: #a0d5cc;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Access__root__item__container .data dd {
  margin-top: .25em
}
.Access__root__item__container .data dd .strong {
  font-size: 1.77778em
}
.Access__root__item__container .data dd .small {
  position: relative;
  display: inline-block;
  margin-right: .25em;
  font-size: .77778em;
  color: #444
}
.Access__root__item__container .data dd .small::before {
  position: absolute;
  bottom: 0;
  left: -120%;
  display: block;
  width: 120%;
  height: 2.25em;
  background-image: url(images/icon/walk_gr.svg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  background-size: contain;
  content: ''
}
.Access__root__item__container .data dd .small span {
  position: relative
}
.Access__root__item.train .Access__root__item__container .data dt .strong {
  font-size: 1.77778em
}
.Access__root__item.train .Access__root__item__container .data dt .small {
  display: block;
  margin-bottom: .25em;
  font-size: .77778em;
  color: #088e78
}
.Access__root__item.buss .Access__root__item__container .data dt .number {
  font-size: 1.22222em
}
.Access__root__item.buss .Access__root__item__container .data dt .strong {
  font-size: 1.22222em
}
.Access__root__item.buss .Access__root__item__container .data dt .small {
  font-size: .77778em;
  color: #444
}
.Access__root__item + .Access__root__item {
  margin-left: 4rem
}
.About__overview {
  background-color: #ecf2f1
}
.About__overview__container {
  background-color: #fff
}
.About__overview__head {
  position: relative;
  overflow: hidden;
  padding-top: 1em;
  padding-bottom: 1em;
  background-color: rgba(8, 142, 120, .6);
  font-size: 1.44444em;
  font-weight: 700;
  color: #fff
}
.About__overview__head::before {
  position: absolute;
  right: 1em;
  bottom: 50%;
  display: block;
  width: 3em;
  height: 3em;
  margin-bottom: -2em;
  background-image: url(images/icon/about_wh.svg);
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  background-size: contain;
  content: '';
  opacity: .5
}
.About__overview__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: end;
  padding-top: 1em;
  padding-bottom: 1em;
  -webkit-box-align: end;
  -webkit-align-items: flex-end;
  -moz-box-align: end;
  align-items: flex-end
}
.About__overview__image {
  display: block;
  margin: 0 auto;
  padding-top: 1em;
  padding-right: 4rem;
  padding-bottom: 1em;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 20em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 20em;
  flex: 0 0 20em
}
.About__overview__list {
  line-height: 1.4
}
.About__overview__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  padding-top: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #a0d5cc
}
.About__overview__item:last-of-type {
  border-bottom: none
}
.About__overview__item__head {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 35%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 35%;
  flex: 0 0 35%
}
.About__overview__item__body {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 65%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 65%;
  flex: 0 0 65%
}
.About__greeting .sign {
  margin-top: 2em
}
.About__greeting .history {
  display: inline-block;
  margin-top: 4em;
  padding: 2em;
  border: 1px solid #a0d5cc
}
.About__greeting .history .Post {
  font-size: .88889em
}
.About__greeting .title {
  margin-bottom: 1em;
  padding-bottom: 1em;
  border-bottom: 1px solid #a0d5cc;
  font-size: 1.22222em;
  font-weight: 700;
  line-height: 1.4;
  color: #03816d
}
.About__greeting__container .image {
  position: relative;
  float: right;
  width: 35%;
  min-width: 28rem;
  margin-left: 2em
}
.About__greeting__container .image .caption {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  padding: 1.5em .75em .75em;
  background-image: -webkit-gradient(linear, left bottom, left top, from(rgba(0, 0, 0, .25)), to(rgba(0, 0, 0, 0)));
  background-image: -webkit-linear-gradient(bottom, rgba(0, 0, 0, .25), rgba(0, 0, 0, 0));
  background-image: -moz-linear-gradient(bottom, rgba(0, 0, 0, .25), rgba(0, 0, 0, 0));
  background-image: -o-linear-gradient(bottom, rgba(0, 0, 0, .25), rgba(0, 0, 0, 0));
  background-image: linear-gradient(to top, rgba(0, 0, 0, .25), rgba(0, 0, 0, 0));
  font-size: .88889em;
  line-height: 1.4;
  color: #fff
}
.Medical__subject__list {
  padding: 2px;
  background-color: #ecf2f1;
  line-height: 1.2
}
.Medical__subject__item {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-bottom: 2px;
  background-color: #fff
}
.Medical__subject__item > * {
  padding: 1.5em 1em;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Medical__subject__item:last-of-type {
  margin-bottom: 0
}
.Medical__subject__head {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  border-left: 8px solid;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 45%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 45%;
  flex: 0 0 45%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Medical__subject__item.insurance .Medical__subject__head {
  border-color: #a0d5cc
}
.Medical__subject__item.free .Medical__subject__head {
  border-color: #f2c291
}
.Medical__subject__head a {
  color: #ed9f54;
  text-decoration: underline
}
.isHover .Medical__subject__head a:hover {
  text-decoration: none
}
.Medical__subject__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 35%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 35%;
  flex: 0 0 35%;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Medical__subject__foot {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 20%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 20%;
  flex: 0 0 20%
}
.Medical__subject__item.insurance .Medical__subject__foot .label {
  opacity: 0
}
.Medical__subject__foot .label {
  display: inline-block;
  padding: .5em .75em;
  -webkit-border-radius: 9999px;
  -moz-border-radius: 9999px;
  border-radius: 9999px;
  background-color: #e88879;
  font-size: .88889em;
  font-weight: 700;
  color: #fff
}
.Medical__schedule .Schedule {
  width: 100%;
  min-width: 0
}
.Medical__schedule .About__overview__head::before {
  background-image: url(images/icon/calender_wh.svg)
}
.Medical__schedule .About__overview__container {
  padding-top: 2em;
  padding-bottom: 2em
}
.Online__head {
  margin-bottom: 2em;
  font-size: 1.44444em;
  font-weight: 700;
  line-height: 1.4;
  text-align: center
}
.Online__head .strong {
  color: #ed9f54
}
.Online__intro .Online__head {
  margin-bottom: 3em
}
.Online__action .Online__head .strong {
  color: #edb781
}
.Online__intro__section {
  max-width: 80rem;
  margin: 0 auto;
  margin-bottom: 4em
}
.Online__intro__section:last-of-type {
  margin-bottom: 0
}
.Online__intro__section__head {
  margin-bottom: 1.5em;
  padding: .75em;
  background-color: #ecf2f1;
  font-size: 1.22222em;
  font-weight: 700;
  line-height: 1.4;
  text-align: center
}
.Online__intro__section__head .strong {
  color: #ed9f54
}
.Online__intro__section .Section__body {
  max-width: 100%
}
.Online__intro__section .Section__body .strong {
  color: #ed9f54
}
.Online__intro__section .text {
  font-weight: 700;
  line-height: 1.7;
  text-align: center
}
.Online__intro__section .price {
  font-weight: 700;
  line-height: 1.4;
  color: #222;
  text-align: center
}
.Online__intro__section .price .number {
  font-size: 2.33333em;
  color: #ed9f54
}
.Online__intro__section .price .small {
  color: #444
}
.Online__intro__list {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.Online__intro__item {
  -webkit-box-flex: 1;
  -webkit-flex: 1 1;
  -moz-box-flex: 1;
  -ms-flex: 1 1;
  flex: 1 1
}
.Online__intro__item:last-of-type {
  margin-bottom: 0
}
.Online__intro__item__head {
  display: block;
  width: 6em;
  height: 6em;
  margin: 0 auto
}
.Online__intro__item__head img {
  width: 100%;
  height: 100%
}
.Online__intro__item__body {
  margin-top: 1em;
  font-weight: 700;
  line-height: 1.4;
  color: #444;
  text-align: center
}
.Online__action {
  background-color: #088e78;
  color: #fff
}
.Online__action .Section__body {
  color: inherit
}
.Online__action__container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  margin-top: 2em
}
.Online__action__head {
  position: relative;
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  border: 1px solid #fff;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Online__action__head .notice {
  position: absolute;
  right: 13em;
  bottom: 5%;
  display: block;
  width: 12em;
  font-size: .88889em;
  text-align: center
}
.Online__action__head > * {
  padding: 2em
}
.Online__action__head .title {
  font-size: 1.22222em;
  font-weight: 700;
  line-height: 1.4
}
.Online__action__head .desc {
  margin-top: .5em;
  font-size: .88889em;
  line-height: 1.7
}
.Online__action__head .desc a {
  color: #edb781;
  text-decoration: underline
}
.isHover .Online__action__head .desc a:hover {
  text-decoration: none
}
.Online__action__head .left {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Online__action__head .right {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  border-left: 1px solid #fff;
  color: #edb781;
  text-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Online__action__head .right > * {
  font-size: 2.66667em;
  font-weight: 700
}
.Online__action__head .qr {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  padding: 1em;
  background-color: #fff;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 10em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 10em;
  flex: 0 0 10em;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Online__action__head + .Online__action__body {
  margin-left: 4rem
}
.Online__action__body {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-pack: center;
  -ms-flex-align: center;
  -webkit-box-flex: 1;
  -webkit-flex: 1 0 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 0 auto;
  flex: 1 0 auto;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center;
  -webkit-box-pack: center;
  -webkit-justify-content: center;
  -moz-box-pack: center;
  justify-content: center
}
.Online__action__body .button {
  display: inline-block
}
.Online__action__body .button img {
  width: 16em;
  height: auto
}
.Online__action__body .list {
  display: block
}
.Online__action__body .list .item + .item {
  margin-top: 1em;
  margin-left: 0
}
.Treatment .l-container {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -webkit-flex-direction: row-reverse;
  -ms-flex-direction: row-reverse;
  flex-direction: row-reverse;
  -webkit-box-orient: horizontal;
  -webkit-box-direction: reverse;
  -moz-box-orient: horizontal;
  -moz-box-direction: reverse
}
.Treatment__side {
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 24rem;
  -moz-box-flex: 0;
  -ms-flex: 0 0 24rem;
  flex: 0 0 24rem
}
.Treatment__side__head {
  margin-bottom: 2em;
  padding-bottom: 2em;
  border-bottom: 2px solid #a0d5cc;
  font-weight: 700
}
.Treatment__side__item {
  margin-bottom: 1px
}
.Treatment__side__item:last-of-type {
  margin-bottom: 0
}
.isHover .Treatment__side__item a {
  -webkit-transition: .2s color;
  -o-transition: .2s color;
  -moz-transition: .2s color;
  transition: .2s color
}
.isHover .Treatment__side__item a:hover {
  color: #ed9f54
}
.Treatment__side__item a {
  display: block;
  padding: 1em 0;
  font-size: .88889em;
  line-height: 1.4;
  color: #444
}
.Treatment__side__item > a {
  font-weight: 700;
  color: #03816d
}
.Treatment__side__item .list {
  margin-top: 1px
}
.Treatment__side__item .list .item {
  margin-bottom: 1px
}
.Treatment__side__item .list .item a {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex
}
.Treatment__side__item .list .item a::before {
  display: inline-block;
  margin-right: .5em;
  margin-left: .5em;
  font-size: .5em;
  font-weight: 700;
  color: grey;
  content: '∟'
}
.Treatment__side__item .list .item:last-of-type {
  margin-bottom: 0
}
.Treatment__main {
  margin-right: 4rem;
  padding-right: 4rem;
  -webkit-box-flex: 1;
  -webkit-flex: 1 1 auto;
  -moz-box-flex: 1;
  -ms-flex: 1 1 auto;
  flex: 1 1 auto
}
.Treatment__main > * {
  margin-bottom: 6em
}
.Treatment__main > :last-child {
  margin-bottom: 0
}
.Treatment__main__head {
  position: relative;
  overflow: hidden;
  padding: .75em 1em;
  background-color: rgba(8, 142, 120, .6);
  font-size: 1.44444em;
  font-weight: 700;
  line-height: 1.4;
  color: #fff
}
.Treatment__main__head .small {
  display: inline-block;
  margin-left: 1em;
  font-size: .75em;
  opacity: .75
}
.Treatment__main__head::before {
  position: absolute;
  right: 1em;
  bottom: 50%;
  display: block;
  width: 2.5em;
  height: 2.5em;
  margin-bottom: -1.5em;
  background-repeat: no-repeat;
  background-position: center center;
  -webkit-background-size: contain;
  -moz-background-size: contain;
  background-size: contain;
  content: '';
  opacity: .5
}
.Treatment__immunity .Treatment__main__head::before {
  background-image: url(images/icon/immunity_wh.svg)
}
.Treatment__flora .Treatment__main__head::before {
  background-image: url(images/icon/flora_wh.svg)
}
.Treatment__macro .Treatment__main__head::before {
  background-image: url(images/icon/treatment_wh.svg)
}
.Treatment__cytokine .Treatment__main__head::before {
  background-image: url(images/icon/cytokine_wh.svg)
}
.Treatment__main__section {
  margin-bottom: 2em;
  padding-top: 2em;
  padding-bottom: 2em
}
.Treatment__main__section__head {
  position: relative;
  margin-bottom: 2em;
  padding: 1em;
  border: 1px solid #a0d5cc;
  -webkit-border-radius: .5em;
  -moz-border-radius: .5em;
  border-radius: .5em;
  font-size: 1.22222em;
  font-weight: 700;
  line-height: 1.4
}
.Treatment__main__section__head .small {
  display: inline-block;
  margin-left: 1em;
  font-size: .75em;
  color: rgba(8, 142, 120, .6)
}
.Treatment__main__section__head::after {
  position: absolute;
  bottom: -.9rem;
  left: 3.2rem;
  display: block;
  width: 1.6rem;
  height: 1.6rem;
  border-right: 1px solid #a0d5cc;
  border-bottom: 1px solid #a0d5cc;
  background-color: #fff;
  content: '';
  -webkit-transform: rotate(45deg);
  -moz-transform: rotate(45deg);
  -ms-transform: rotate(45deg);
  -o-transform: rotate(45deg);
  transform: rotate(45deg)
}
.Treatment__main__section:last-of-type {
  margin-bottom: 0
}
.Treatment__main__section__body {
  color: #444
}
.Treatment__main__section__body .image-1 {
  display: block;
  margin-left: 2em;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 30%;
  -moz-box-flex: 0;
  -ms-flex: 0 0 30%;
  flex: 0 0 30%
}
.Treatment__main__section__body .title {
  margin-top: 3em;
  font-weight: 700;
  line-height: 1.4;
  color: #ed9f54
}
.Treatment__main__section__body dl {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Treatment__main__section__body dl dt {
  padding: .5em .75em;
  -webkit-border-radius: .25em;
  -moz-border-radius: .25em;
  border-radius: .25em;
  background-color: rgba(8, 142, 120, .6);
  color: #fff;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto
}
.Treatment__main__section__body dl dd {
  margin-left: 1em;
  font-weight: 700;
  color: #222;
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 auto;
  -moz-box-flex: 0;
  -ms-flex: 0 0 auto;
  flex: 0 0 auto
}
.Treatment__main__section__body a:not(.Button) {
  color: #ed9f54;
  text-decoration: underline
}
.isHover .Treatment__main__section__body a:not(.Button):hover {
  text-decoration: none
}
.Treatment__main__section__body .large {
  font-size: 1.5em
}
.Treatment__main__section__body > * {
  margin-bottom: 1.5em
}
.Treatment__main__section__body > :first-child {
  margin-top: 0
}
.Treatment__main__section__body > :last-child {
  margin-bottom: 0
}
.Treatment__main__section__body .strong {
  color: #ed9f54
}
.Treatment__main__section__body ol, .Treatment__main__section__body ul {
  line-height: 1.4
}
.Treatment__main__section__body ol li, .Treatment__main__section__body ul li {
  display: -webkit-box;
  display: -webkit-flex;
  display: -moz-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-align: center;
  margin-bottom: 1em;
  -webkit-box-align: center;
  -webkit-align-items: center;
  -moz-box-align: center;
  align-items: center
}
.Treatment__main__section__body ol li:last-child, .Treatment__main__section__body ul li:last-child {
  margin-bottom: 0
}
.Treatment__main__section__body ul li::before {
  display: block;
  width: .5em;
  height: .5em;
  margin-right: .5em;
  border: 2px solid #a0d5cc;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  content: '';
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 .5em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 .5em;
  flex: 0 0 .5em
}
.Treatment__main__section__body ol {
  counter-reset: ordered-list
}
.Treatment__main__section__body ol li {
  counter-increment: ordered-list
}
.Treatment__main__section__body ol li::before {
  display: block;
  width: 1.75em;
  height: 1.75em;
  margin-right: .5em;
  -webkit-border-radius: 50%;
  -moz-border-radius: 50%;
  border-radius: 50%;
  background-color: rgba(8, 142, 120, .6);
  font-size: .65em;
  font-weight: 700;
  line-height: 1.75em;
  color: #fff;
  text-align: center;
  letter-spacing: 0;
  content: counter(ordered-list);
  -webkit-box-flex: 0;
  -webkit-flex: 0 0 1.75em;
  -moz-box-flex: 0;
  -ms-flex: 0 0 1.75em;
  flex: 0 0 1.75em
}
@media only screen and (max-width:1599px) {
  .d-b-pclarge {
    display: none
  }
  .d-n-pclarge {
    display: block
  }
  .Contact::before {
    left: 25%;
    width: 50%
  }
}
@media only screen and (max-width:1280px) {
  .Nav__list::after, .Nav__list::before {
    display: none
  }
}
@media only screen and (max-width:1279px) {
  body {
    font-size: -webkit-calc(.4171vw + 1.26653rem);
    font-size: -moz-calc(.4171vw + 1.26653rem);
    font-size: calc(.4171vw + 1.26653rem)
  }
  .d-b-pc {
    display: none
  }
  .d-n-pc {
    display: block
  }
  .p-para {
    line-height: 1.9
  }
  .Header__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 15em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 15em;
    flex: 0 0 15em
  }
  .home .Header__head__logo {
    height: 15em
  }
  .Contact::before {
    left: 17.5%;
    width: 65%
  }
  .Index__mv::before {
    padding-top: 45%
  }
  .Index__news__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 16.66667em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 16.66667em;
    flex: 0 0 16.66667em
  }
  .Index__news__body {
    padding-left: 0
  }
  .Index__info__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 16.11111em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 16.11111em;
    flex: 0 0 16.11111em
  }
  .Index__info__body {
    padding-left: 4rem
  }
  .Access__map__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 45%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 45%;
    flex: 0 0 45%
  }
  .Access__map__body {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 55%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 55%;
    flex: 0 0 55%
  }
  .Treatment__side {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 22rem;
    -moz-box-flex: 0;
    -ms-flex: 0 0 22rem;
    flex: 0 0 22rem
  }
  .Treatment__main {
    margin-right: 3rem;
    padding-right: 3rem
  }
}
@media only screen and (max-width:1023px) {
  body {
    font-size: 1.6rem;
    font-size: -webkit-calc(.4171vw + 1.26653rem);
    font-size: -moz-calc(.4171vw + 1.26653rem);
    font-size: calc(.4171vw + 1.26653rem)
  }
  body {
    padding-top: 10rem
  }
  body.home {
    padding-top: 0
  }
  .l-container, .l-container-s, .l-fluid {
    padding-right: 3rem;
    padding-left: 3rem
  }
  .l-container.tab-none {
    padding-right: 0;
    padding-left: 0
  }
  .l-offset {
    margin-right: -3rem;
    margin-left: -3rem
  }
  .d-b-tab {
    display: none
  }
  .d-n-tab {
    display: block
  }
  .p-para {
    line-height: 1.8
  }
  .Pagetop {
    bottom: -5.5em;
    width: 5.5em;
    height: 5.5em
  }
  .Header > .l-nopadding {
    height: 7rem
  }
  .Header__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 13.88889em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 13.88889em;
    flex: 0 0 13.88889em
  }
  .home .Header__head__logo {
    height: 13.88889em
  }
  .Header__head__logo > * {
    right: 3rem;
    left: 3rem
  }
  .Header__body__content > * {
    margin-left: 1em
  }
  .Footer__nav__list {
    -ms-flex-pack: start;
    -webkit-box-pack: start;
    -webkit-justify-content: flex-start;
    -moz-box-pack: start;
    justify-content: flex-start;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .Footer__nav__list > li {
    margin-bottom: 2em;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 33.33333%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%
  }
  .Nav__sp__container {
    padding-top: 10rem
  }
  .home .Nav__sp__container {
    padding-top: 7rem
  }
  .Page__head {
    height: 11.5em
  }
  .Contact::before {
    left: 10%;
    width: 80%
  }
  .Contactpage__form {
    padding-right: 3em;
    padding-left: 3em
  }
  .Post {
    line-height: 1.9
  }
  .Index__mv::before {
    padding-top: 50%
  }
  .Index__news__container {
    display: block
  }
  .Index__news__head {
    padding-right: 0
  }
  .Index__news__head .Section__body {
    font-size: 1em
  }
  .Index__news__body {
    min-width: 28rem;
    max-width: 60rem;
    margin: 0 auto
  }
  .Index__news__list {
    margin-top: 2em
  }
  .Index__news__item {
    display: block
  }
  .Index__news__item .time {
    display: block;
    margin-top: .5em
  }
  .Index__info__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 15.55556em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 15.55556em;
    flex: 0 0 15.55556em
  }
  .Index__info__head__container {
    padding-right: 3rem;
    padding-left: 3rem
  }
  .Archive__main {
    padding-right: 2rem
  }
  .Archive__side {
    padding-left: 2rem
  }
  .Access__map__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%
  }
  .Access__map__body {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%
  }
  .Access__root__list {
    display: block
  }
  .Access__root__item {
    padding-right: 3rem;
    padding-left: 3rem
  }
  .Access__root__item__container {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
  }
  .Access__root__item__container .p-hr {
    display: none
  }
  .Access__root__item__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 35%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 35%;
    flex: 0 0 35%
  }
  .Access__root__item__body {
    margin-left: 3rem;
    padding-left: 3rem;
    border-left: 1px solid #a0d5cc;
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
    -moz-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto
  }
  .Access__root__item + .Access__root__item {
    margin-top: 2em;
    margin-left: 0
  }
  .About__overview__image {
    padding-right: 3rem;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 22.22222em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 22.22222em;
    flex: 0 0 22.22222em
  }
  .About__overview__item {
    display: block
  }
  .About__overview__item__head {
    font-weight: 700
  }
  .About__overview__item__body {
    margin-top: .5em;
    color: #444
  }
  .Online__action__container {
    display: block;
    max-width: 60rem;
    margin: 2em auto 0
  }
  .Online__action__head .notice {
    width: 11em
  }
  .Online__action__head > * {
    padding: 1.5em
  }
  .Online__action__body .button {
    height: auto
  }
  .Online__action__body .button img {
    width: auto;
    height: 4em
  }
  .Online__action__body .list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    margin-top: 2em
  }
  .Online__action__body .list .item + .item {
    margin-top: 0;
    margin-left: 1em
  }
  .Treatment__side {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 20rem;
    -moz-box-flex: 0;
    -ms-flex: 0 0 20rem;
    flex: 0 0 20rem
  }
  .Treatment__main {
    margin-right: 2rem;
    padding-right: 2rem
  }
}
@media only screen and (max-width:767px) {
  body {
    font-size: 1.5rem;
    font-size: -webkit-calc(.4171vw + 1.26653rem);
    font-size: -moz-calc(.4171vw + 1.26653rem);
    font-size: calc(.4171vw + 1.26653rem)
  }
  body {
    padding-top: 5rem
  }
  body.home {
    padding-top: 5rem
  }
  .l-container, .l-container-s, .l-fluid {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .l-container.tab-none {
    padding-right: 0;
    padding-left: 0
  }
  .l-offset {
    margin-right: -2rem;
    margin-left: -2rem
  }
  .d-b-sp {
    display: none
  }
  .d-n-sp {
    display: block
  }
  .p-para {
    line-height: 1.7
  }
  .Section__head {
    text-align: left
  }
  .Section__head br {
    display: none
  }
  .Section__head__icon {
    border-width: 3px
  }
  .Section__body {
    text-align: left
  }
  .Button {
    padding: 1em 3em;
    border-width: 3px
  }
  .home .Header {
    background-color: #fff
  }
  .Header > .l-nopadding {
    height: 5rem
  }
  .Header__head {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    height: 100%;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 12.77778em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 12.77778em;
    flex: 0 0 12.77778em;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
  }
  .home .Header__head__logo {
    width: 100%;
    height: 60%;
    background-color: transparent
  }
  .home .Header__head__logo img.green {
    opacity: 1
  }
  .home .Header__head__logo img.white {
    opacity: 0
  }
  .Header__head__logo > * {
    top: 0;
    right: 2rem;
    left: 2rem;
    height: 100%
  }
  .Header__body__button {
    position: relative;
    background: #088e78;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 5rem;
    -moz-box-flex: 0;
    -ms-flex: 0 0 5rem;
    flex: 0 0 5rem
  }
  .Header__body__button::after, .Header__body__button::before {
    content: ''
  }
  .Header__body__button .bar, .Header__body__button::after, .Header__body__button::before {
    position: absolute;
    left: 20%;
    display: block;
    width: 60%;
    height: 2px;
    margin-top: -1px;
    background-color: #fff
  }
  .Header__body__content > * {
    margin-left: 0
  }
  .Header__body__content .tel {
    margin-right: 1em;
    font-weight: 400
  }
  .Header__body__content .tel .small {
    letter-spacing: 0
  }
  .Header__body__content .tel .strong {
    font-size: 1.55556em
  }
  .Header__body__content .Button {
    position: relative;
    width: 5rem;
    height: 5rem;
    padding: 0;
    border: none;
    -webkit-border-radius: 0;
    -moz-border-radius: 0;
    border-radius: 0;
    background: 0 0
  }
  .Header__body__content .Button::before {
    display: block;
    width: 60%;
    height: 60%;
    margin-top: 20%;
    margin-left: 20%;
    background-image: url(images/icon/contact_key.svg);
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: contain;
    -moz-background-size: contain;
    background-size: contain;
    content: ''
  }
  .Header__body__content .Button::after {
    position: absolute;
    top: 10%;
    left: 0;
    display: block;
    width: 1px;
    height: 80%;
    background-color: #ecf2f1;
    content: ''
  }
  .Header__body__content .Button .inner {
    display: none
  }
  .Header__nav {
    display: none
  }
  .Footer__nav__list > li {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%
  }
  .Nav > .l-nopadding::before {
    top: 50%;
    display: block
  }
  .Nav__list {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .Nav__list > li {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 33.33333%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 33.33333%;
    flex: 0 0 33.33333%
  }
  .Nav__list > li::after {
    top: 1em;
    bottom: 1em;
    height: auto
  }
  .Nav__list > li:nth-of-type(3n)::after {
    display: none
  }
  .Nav__list > li:nth-of-type(n+4)::before {
    display: block
  }
  .Nav__list > li a .image {
    width: 4.5em;
    height: 4.5em
  }
  .Nav__sp__container {
    padding-top: 5rem
  }
  .home .Nav__sp__container {
    padding-top: 5rem
  }
  .Page__head {
    height: 11em
  }
  .Page__head__image {
    border-width: 2px
  }
  .Contact__list {
    font-size: 1.05556em
  }
  .Contact::before {
    left: 2.5%;
    width: 95%
  }
  .Contact {
    background-image: url(images/bg_contact_sp.jpg)
  }
  .Contactpage__content {
    text-align: left
  }
  .Contactpage__form {
    padding-top: 3em;
    padding-right: 2rem;
    padding-bottom: 3em;
    padding-left: 2rem
  }
  .Contactpage__form input.Button, .Contactpage__form textarea.Button {
    padding: 1em 2em
  }
  .Contactpage__form__item {
    display: block
  }
  .Contactpage__form__item#form-privacy {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex
  }
  .Contactpage__form__item__head {
    max-width: 100%
  }
  .Contactpage__form__item__body {
    max-width: 100%;
    margin-top: .5em
  }
  .Schedule {
    width: 75%;
    min-width: 44rem;
    margin: 0 auto
  }
  .Post {
    line-height: 1.8
  }
  .Post h2 {
    padding-left: 1rem
  }
  .Post h3 {
    padding-left: 1rem
  }
  .Post h4::before {
    margin-right: 1rem
  }
  .Index__mv {
    background-image: url(images/mv_sp.jpg)
  }
  .Index__consultation::before {
    position: relative;
    height: 18em;
    margin-top: -4em;
    margin-bottom: -4em;
    background-image: url(images/bg_consultation_sp.jpg)
  }
  .Index__consultation__list {
    display: block
  }
  .Index__consultation__item {
    margin-bottom: 2em;
    padding: 2em 0 3em;
    border: 4px solid #edb781;
    background-color: #fff
  }
  .Index__consultation__item:last-of-type {
    margin-bottom: 0
  }
  .Index__consultation__item.immunity {
    margin-right: 0
  }
  .Index__consultation__item.flora {
    margin-left: 0
  }
  .Index__consultation__item .subtitle {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Index__consultation__item .desc {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Index__consultation__item .link {
    right: 2rem;
    bottom: 1em
  }
  .Index__important__container {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Index__info.Section {
    padding-top: 4em;
    padding-bottom: 4em
  }
  .Index__info .Schedule {
    margin-top: 2em
  }
  .Index__info__container {
    display: block
  }
  .Index__info__head {
    margin-top: 0;
    margin-bottom: 0
  }
  .Index__info__head::before {
    display: none
  }
  .Index__info__head__container {
    position: relative;
    display: block;
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Index__info__head__container::before {
    display: none
  }
  .Index__info__head__inner {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    width: 75%;
    min-width: 44rem;
    margin: 0 auto;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
  }
  .Index__info__head__inner .logo {
    position: relative;
    margin-bottom: 0;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    background-color: #088e78;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 35%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 35%;
    flex: 0 0 35%
  }
  .Index__info__head__inner .logo::before {
    display: block;
    padding-top: 100%;
    content: ''
  }
  .Index__info__head__inner .logo img {
    position: absolute;
    top: 15%;
    left: 15%;
    width: 70%;
    height: 70%
  }
  .Index__info__head__inner .info {
    padding-left: 4rem;
    font-size: 1em;
    color: #444
  }
  .Index__info__body {
    padding-left: 0
  }
  .Archive__container {
    display: block
  }
  .Archive__main {
    padding-right: 0
  }
  .Archive__side {
    margin-top: 4em;
    padding-left: 0
  }
  .Single__nav {
    margin-bottom: 2em;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .Single__nav__center {
    display: none
  }
  .Single__nav__bottom {
    display: block;
    border-top: 1px solid #088e78;
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 100%;
    -moz-box-flex: 1;
    -ms-flex: 1 1 100%;
    flex: 1 1 100%
  }
  .Access__map__container {
    display: block
  }
  .Access__map__head {
    width: 75%;
    min-width: 28rem;
    margin: 0 auto;
    margin-top: -2em;
    margin-bottom: 2em
  }
  .Access__map__item dt {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-align: center;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center
  }
  .Access__map__item dt .number {
    display: block;
    height: 1.5em;
    margin-right: .25em;
    -webkit-border-radius: 50%;
    -moz-border-radius: 50%;
    border-radius: 50%;
    background-color: #a0d5cc;
    font-weight: 700;
    line-height: 1.5;
    color: #fff;
    text-align: center;
    letter-spacing: 0;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 1.5em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 1.5em;
    flex: 0 0 1.5em
  }
  .Access__root__item {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Access__root__item__container {
    display: block
  }
  .Access__root__item__container .p-hr {
    display: block;
    min-width: 23.2rem
  }
  .Access__root__item.buss .Access__root__item__container .data dt .number {
    display: block;
    margin-bottom: .25em;
    font-size: .77778em;
    color: #088e78
  }
  .Access__root__item__body {
    margin-left: 0;
    padding-left: 0;
    border-left: none
  }
  .About__overview__image {
    padding-right: 2rem;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 45%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 45%;
    flex: 0 0 45%
  }
  .Medical__subject__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%
  }
  .Medical__subject__body {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 25%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 25%;
    flex: 0 0 25%
  }
  .Medical__subject__foot {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 25%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 25%;
    flex: 0 0 25%
  }
  .Online__action__head .notice {
    right: auto;
    bottom: 1em;
    left: 1em;
    width: auto
  }
  .Online__action__head {
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .Online__action__head > * {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Online__action__head .left {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 100%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 100%;
    flex: 0 0 100%
  }
  .Online__action__head .right {
    border-top: 1px solid #fff;
    border-left: none;
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 auto;
    -moz-box-flex: 1;
    -ms-flex: 1 1 auto;
    flex: 1 1 auto
  }
  .Online__action__head .qr {
    border-top: 1px solid #fff;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 8em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 8em;
    flex: 0 0 8em
  }
  .Online__action__head + .Online__action__body {
    margin-left: 0
  }
  .Treatment .l-container {
    display: block
  }
  .Treatment__side {
    position: relative;
    margin-bottom: 4em;
    padding-right: 2rem;
    padding-bottom: 1em;
    padding-left: 2rem;
    border: 2px solid #f2c291;
    -webkit-border-radius: 1em;
    -moz-border-radius: 1em;
    border-radius: 1em
  }
  .Treatment__side__head {
    margin-top: 2em;
    margin-bottom: 1em;
    border-bottom: 2px solid #f2c291
  }
  .Treatment__side__list {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -webkit-flex-wrap: wrap;
    -ms-flex-wrap: wrap;
    flex-wrap: wrap
  }
  .Treatment__side__item {
    -webkit-box-flex: 1;
    -webkit-flex: 1 1 50%;
    -moz-box-flex: 1;
    -ms-flex: 1 1 50%;
    flex: 1 1 50%
  }
  .Treatment__side__item a {
    padding: .75em 0
  }
  .Treatment__side__item > a {
    color: #222
  }
  .Treatment__main {
    margin-right: 0;
    padding-right: 0
  }
}
@media only screen and (max-width:767px) and (-webkit-min-device-pixel-ratio:2), only screen and (max-width:767px) and (min--moz-device-pixel-ratio:2), only screen and (max-width:767px) and (-o-min-device-pixel-ratio:2/1), only screen and (max-width:767px) and (min-resolution:192dpi) {
  .Contact {
    background-image: url(images/bg_contact_sp.jpg)
  }
  .Index__consultation::before {
    background-image: url(images/bg_consultation_sp@2x.jpg)
  }
}
@media only screen and (max-width:767px) and (max-width:480px) {
  .Index__mv {
    background-image: url(images/mv_sp@2x.jpg)
  }
  .Index__info__head__inner .logo::before {
    display: none
  }
}
@media only screen and (max-width:480px) {
  body {
    font-size: 1.5rem;
    font-size: -webkit-calc(.4171vw + 1.26653rem);
    font-size: -moz-calc(.4171vw + 1.26653rem);
    font-size: calc(.4171vw + 1.26653rem)
  }
  .l-container.tab-none {
    padding-right: 0;
    padding-left: 0
  }
  .l-flex.b-spsmall {
    display: block
  }
  .d-b-spsmall {
    display: none
  }
  .d-n-spsmall {
    display: block
  }
  .Pagetop {
    bottom: -5em;
    width: 5em;
    height: 5em
  }
  .Header__head {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 12.11111em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 12.11111em;
    flex: 0 0 12.11111em
  }
  .Header__head__logo > * {
    right: 1rem
  }
  .Header__body__content .tel {
    position: relative;
    width: 5rem;
    height: 5rem;
    margin-right: 0
  }
  .Header__body__content .tel::before {
    display: block;
    width: 60%;
    height: 60%;
    margin-top: 20%;
    margin-left: 20%;
    background-image: url(images/icon/tel_gr.svg);
    background-repeat: no-repeat;
    background-position: center center;
    -webkit-background-size: cover;
    -moz-background-size: cover;
    background-size: cover;
    content: ''
  }
  .Header__body__content .tel > * {
    display: none
  }
  .Footer__nav__list {
    display: block
  }
  .Nav > .l-nopadding::before {
    top: 33.33333%
  }
  .Nav > .l-nopadding::after {
    top: 66.66667%;
    display: block
  }
  .Nav__list > li {
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 50%;
    -moz-box-flex: 0;
    -ms-flex: 0 0 50%;
    flex: 0 0 50%
  }
  .Nav__list > li:nth-of-type(2n)::after {
    display: none
  }
  .Nav__list > li:nth-of-type(3n)::after {
    display: block
  }
  .Nav__list > li:nth-of-type(6n)::after {
    display: none
  }
  .Nav__list > li:nth-of-type(n+3)::before {
    display: block
  }
  .Nav__list > li a .image {
    width: 5em;
    height: 5em
  }
  .Page__head {
    height: 10em
  }
  .Page__head .l-container {
    -ms-flex-pack: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center
  }
  .Page__head__image {
    position: absolute;
    bottom: 50%;
    left: 50%;
    width: 8.88889em;
    height: 8.88889em;
    margin-bottom: -4.44444em;
    margin-left: -4.44444em;
    border: none;
    background: 0 0;
    opacity: .5
  }
  .Page__head__head {
    margin-left: 0
  }
  .Contact__list {
    font-size: 1.11111em
  }
  .Contact::before {
    left: -5%;
    width: 110%
  }
  .Contactpage .l-container {
    padding-right: 0;
    padding-left: 0
  }
  .Contactpage__content {
    padding-right: 2rem;
    padding-left: 2rem
  }
  .Contactpage__form {
    margin-bottom: 0
  }
  .Schedule {
    width: 100%;
    min-width: 0
  }
  .Schedule table td .small, .Schedule table th .small {
    display: block;
    margin-bottom: .25em;
    font-size: .77778em;
    font-weight: 700;
    color: #03816d
  }
  .Post {
    line-height: 1.7
  }
  .Index__info__head__inner {
    display: block;
    width: 100%;
    min-width: 28rem
  }
  .Index__info__head__inner .logo .white {
    display: none
  }
  .Index__info__head__inner .logo .green {
    display: block
  }
  .Index__info__head__inner .logo {
    margin-bottom: 2em;
    margin-left: 0;
    background-color: transparent
  }
  .Index__info__head__inner .logo img {
    position: relative;
    top: 0;
    left: 0;
    width: 100%;
    height: 3em
  }
  .Index__info__head__inner .info {
    padding-left: 0
  }
  .Access__map .Access__head {
    margin-bottom: 0
  }
  .Access__map__head {
    margin-top: 2em
  }
  .Access__map__item > * {
    font-size: 1.22222em
  }
  .Access__root__item__container .data {
    -ms-flex-align: end;
    -webkit-box-align: end;
    -webkit-align-items: flex-end;
    -moz-box-align: end;
    align-items: flex-end
  }
  .Access__root__item__container .data .bar {
    display: none
  }
  .Access__root__item__container .data dd .strong {
    font-size: 1.55556em
  }
  .Access__root__item.train .Access__root__item__container .data dt .strong {
    font-size: 1.55556em
  }
  .About__overview__body {
    display: block;
    padding-bottom: 0
  }
  .About__overview__image {
    padding-bottom: 2rem;
    padding-left: 2rem
  }
  .About__greeting .history {
    display: block
  }
  .About__greeting__container .image {
    width: 100%;
    margin-bottom: 2em
  }
  .Medical__subject__item {
    display: block;
    border-left: 8px solid
  }
  .Medical__subject__item.insurance {
    border-color: #a0d5cc
  }
  .Medical__subject__item.free {
    border-color: #f2c291
  }
  .Medical__subject__head {
    border: none;
    font-weight: 700
  }
  .Medical__subject__body {
    padding-top: 0;
    padding-left: 2em;
    color: #444
  }
  .Medical__subject__foot {
    padding-top: 0;
    padding-left: 2em
  }
  .Medical__subject__item.insurance .Medical__subject__foot {
    display: none
  }
  .Medical__schedule .About__overview__head {
    overflow: visible;
    margin-bottom: 2em;
    padding-right: 0;
    padding-left: 0;
    background-color: transparent;
    color: #222;
    text-align: center
  }
  .Medical__schedule .About__overview__head > span {
    position: relative
  }
  .Medical__schedule .About__overview__head::before {
    right: 50%;
    bottom: 50%;
    width: 3em;
    height: 3em;
    margin-right: -1.5em;
    margin-bottom: -1.5em;
    background-image: url(images/icon/calender_gr.svg)
  }
  .Medical__schedule .About__overview__container {
    padding: 0;
    background-color: transparent
  }
  .Online__intro__list {
    display: block
  }
  .Online__intro__item {
    display: -webkit-box;
    display: -webkit-flex;
    display: -moz-box;
    display: -ms-flexbox;
    display: flex;
    -ms-flex-pack: center;
    -ms-flex-align: center;
    margin-bottom: 2em;
    -webkit-box-align: center;
    -webkit-align-items: center;
    -moz-box-align: center;
    align-items: center;
    -webkit-box-pack: center;
    -webkit-justify-content: center;
    -moz-box-pack: center;
    justify-content: center
  }
  .Online__intro__item__head {
    width: 5em;
    height: 5em;
    margin: 0;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 5em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 5em;
    flex: 0 0 5em
  }
  .Online__intro__item__body {
    margin-top: 0;
    padding-left: 2rem;
    text-align: left;
    -webkit-box-flex: 0;
    -webkit-flex: 0 0 10em;
    -moz-box-flex: 0;
    -ms-flex: 0 0 10em;
    flex: 0 0 10em
  }
  .Online__action__body .button img {
    width: 16em;
    height: auto
  }
  .Online__action__body .list {
    display: block
  }
  .Online__action__body .list .item + .item {
    margin-top: 1em;
    margin-left: 0
  }
  .Treatment__side__list {
    display: block
  }
  .Treatment__main__head .small {
    display: block;
    margin-left: 0
  }
  .Treatment__main__section__head .small {
    display: block;
    margin-left: 0
  }
  .Treatment__main__section__body .image-1 {
    width: 75%;
    margin: 2em auto 0
  }
}
@media only screen and (max-width:480px) and (-webkit-min-device-pixel-ratio:2), only screen and (max-width:480px) and (min--moz-device-pixel-ratio:2), only screen and (max-width:480px) and (-o-min-device-pixel-ratio:2/1), only screen and (max-width:480px) and (min-resolution:192dpi) {
  .Contact {
    background-image: url(images/bg_contact_sp.jpg)
  }
}
@media only screen and (max-width:480px) and (max-width:480px) {
  .Index__mv {
    background-image: url(images/mv_sp.jpg)
  }
}
@media print {
  body, html {
    top: 0 !important;
    left: 0 !important;
    zoom: .9 !important;
    width: 1280px !important;
    height: 297mm !important;
    -webkit-print-color-adjust: exact
  }
  body {
    padding-top: 0 !important
  }
  .Header {
    position: relative !important
  }
  .Pagetop {
    display: none
  }
}
/* -------------------------- 追加分 */
/*お問い合わせ*/
.must {
  display: inline-block;
  margin-left: 0.5em;
  padding: 0.15em 0.5em;
  border-radius: 0.25em;
  background: #edb781;
  font-size: .7em;
  float: none;
  vertical-align: 0.15em;
  border: none;
  text-shadow: none;
  box-shadow: none;
}
.mfp_col5 + .mfp_col5 {
  margin-left: 0.5em;
}
.mfp_col5 {
  display: inline-block;
}
form#mailformpro dl dt {
  margin-top: 1em;
  border-top: 0;
}
form#mailformpro dl dd {
  border-top: none;
  padding: 5px 0;
}
form#mailformpro .policy {
  margin: 3em auto 0;
  padding: 1em;
  border: solid 1px #b2b2b2;
}
form#mailformpro .policy p {
  font-size: 0.85em;
  margin-bottom: 0.5em;
}
form#mailformpro .policy p strong {
  font-weight: bold;
}
@media only screen and (min-width: 768px) {
  form#mailformpro dl dt {
    font-size: 1.8rem;
    width: 30%;
    margin-top: 0;
    text-align: left;
  }
  form#mailformpro dl dd {
    font-size: 1.8rem;
    width: 70%;
  }
  .mailform > div {
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    margin-bottom: 2em;
  }
  form#mailformpro .policy {
    width: 80%;
    padding: 2em;
  }
}
/*追従メニュー（SNS）*/
.s_insta_line_btn {
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 100px;
  height: 150px;
  text-align: center;
  z-index: 99999;
}
.s_insta_btn, .s_line_btn, .s_ameblo_btn, .s_youtube_btn {
  padding: 0.5em 1em;
  background: #fff;
  width: 152px;
  text-align: center;
}
.s_insta_line_btn img {
  width: 76px;
  height: 76px;
  margin-top: 5px;
}
.s_line_btn a h5 {
  white-space: pre;
  font-size: .8em;
  line-height: 1em;
  text-decoration: none;
  background: #06C755;
  color: #fff !important;
  padding: 0.4em 0.8em;
  border-radius: 100px;
  transition: .4s;
}
.s_insta_btn a h5 {
  white-space: pre;
  font-size: .8em;
  line-height: 1em;
  text-decoration: none;
  background-image: linear-gradient(140deg, rgba(247, 166, 12, 1) 10%, rgba(255, 34, 87, 1) 40%, rgba(154, 39, 238, 1) 93%);
  color: #fff !important;
  padding: 0.4em 0.8em;
  border-radius: 100px;
  transition: .4s;
}
.s_ameblo_btn a h5 {
  white-space: pre;
  font-size: .8em;
  line-height: 1em;
  text-decoration: none;
  background: #1B6037;
  color: #fff !important;
  padding: 0.4em 0.8em;
  border-radius: 100px;
  transition: .4s;
}
.s_youtube_btn a h5 {
  white-space: pre;
  font-size: .8em;
  line-height: 1em;
  text-decoration: none;
  background: #F03950;
  color: #fff !important;
  padding: 0.4em 0.8em;
  border-radius: 100px;
  transition: .4s;
}
@media (max-width: 1600px) {
  .s_line_btn, .s_insta_btn, .s_ameblo_btn, .s_youtube_btn {
    position: static;
    width: 100%;
    border-radius: 0;
    background: none;
    margin: 0;
    padding: 0;
  }
  .s_insta_line_btn {
    display: flex;
    flex-direction: row;
    position: fixed;
    top: auto;
    bottom: 0;
    right: 0;
    padding: 0;
    background: #fff;
    width: 100%;
    height: 50px;
    text-align: center;
    z-index: 99999;
  }
  .s_line_btn a h5, .s_insta_btn a h5, .s_ameblo_btn a h5, .s_youtube_btn a h5 {
    border-radius: 0;
    width: auto;
    height: 50px;
    line-height: 50px;
    vertical-align: middle;
    display: block;
    margin: 0;
    padding: 0;
  }
}
/*追従メニュー（オンライン診療・予約）*/
div.pc_online_btn {
  padding: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  position: fixed;
  top: 100px;
  right: 20px;
  background: #fff;
  border: #8890C2 2px solid;
  border-radius: 20px;
  width: 100px;
  height: 150px;
  z-index: 99999;
}
div.pc_yoyaku_btn {
  padding: 4px;
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  position: fixed;
  top: 270px;
  right: 20px;
  background: #fff;
  z-index: 800;
  border: #8890C2 2px solid;
  border-radius: 20px;
  width: 100px;
  height: 150px;
}
div.pc_online_btn a, div.pc_yoyaku_btn a, div.pc_supple_btn a {
  height: 100%;
  display: flex;
  flex-direction: column;
  align-content: center;
  justify-content: center;
  align-items: center;
  color: #666 !important;
  text-decoration: none;
  font-size: .8em;
  text-align: center;
  line-height: 1.5;
  letter-spacing: 0em;
}
div.pc_online_btn img {
  width: 40px;
  display: block;
  margin: 0 auto 5px;
}
div.pc_yoyaku_btn img {
  width: 40px;
  display: block;
  margin: 0 auto 5px;
}
@media (max-width: 1600px) {
  div.shinryo_btm_flex {
    z-index: 99999;
    display: flex;
    position: fixed;
    bottom: 50px;
    width: 100%;
    line-height: 50px;
    height: 50px;
  }
  div.pc_online_btn, div.pc_yoyaku_btn, div.pc_supple_btn {
    border: none;
    width: 100%;
    height: 100%;
    vertical-align: middle;
    display: block;
    margin: 0;
    padding: 0;
    position: static;
    border-radius: 0;
    background: #8890C2;
  }
  div.pc_online_btn a, div.pc_yoyaku_btn a, div.pc_supple_btn a {
    display: block;
    line-height: 50px;
    color: #fff !important;
    border: 1px solid #fff;
    box-sizing: border-box;
  }
  div.pc_online_btn img, div.pc_yoyaku_btn img, div.pc_supple_btn img {
    display: none;
  }
  div.pc_online_btn a em {
    display: none;
  }
}