@charset "UTF-8";
.footer a { display: inline-block; }

/*
a[href*="pediatrics"],
a[href*="allergies"],
a[href*="pediatric-derma"],
a[href*="vaccination"],
a[href*="infants"],
a[href*="constipation"],
a[href*="enuresis"],
a[href*="height"],
a[href*="umbilical-hernia"],
a[href*="visual-impairment"],
a[href*="lifestyle-related"],
*/
a[href*="dummy"] { pointer-events: none; }

html { -webkit-box-sizing: border-box; box-sizing: border-box; }

*, *::before, *::after { -webkit-box-sizing: inherit; box-sizing: inherit; }

ol, ul { margin: 0; padding: 0; list-style: none; }

h1, h2, h3, h4, h5, h6 { margin: 0; padding: 0; font-weight: normal; font-size: inherit; }

img { max-width: 100%; height: auto; vertical-align: bottom; }

.cf::before, .cf::after { content: ''; display: block; }

.cf::after { clear: both; }

.fl_l { float: left; }

.fl_r { float: right; }

.txt_c { text-align: center; }

.txt_l { text-align: left; }

.txt_r { text-align: right; }

.bold { font-weight: bold; }

.lg { font-size: 120%; }

.larger { font-size: 150%; }

.red { color: #f00; }

.blue { color: #00f; }

.green { color: #00B050; }

.img_c { display: block; max-width: 100%; height: auto; margin: 1.0rem auto; }

.img_l, .img_r { display: block; max-width: 80%; height: auto; margin: 1.0rem auto; }

.tate { max-width: 60%; }

@media screen and (min-width: 48em), print { .img_l { float: left; margin: 0 3.0rem 3.0rem 0; }
  .img_r { float: right; margin: 0 0 3.0rem 3.0rem; }
  .tate { width: 20%; }
  .mini { width: 70%; }
  .small { max-width: 35.0rem; }
  .small45 { max-width: 49.95rem; } }
.sp_n { display: none !important; }

@media screen and (min-width: 48em), print { .sp_n { display: block !important; }
  .pc_n { display: none !important; } }
.mt40 { margin-top: 4rem !important; }

.mt30 { margin-top: 3rem !important; }

.mt20 { margin-top: 2rem !important; }

.mt10 { margin-top: 1rem !important; }

.mg0 { margin: 0 !important; }

.main > section ~ section, .flex2 > section ~ section { margin-top: 4.0rem; }

.main > section section ~ section, .flex2 > section section ~ section { margin-top: 3.0rem; }

.main > section > section section ~ section, .flex2 > section > section section ~ section { margin-top: 2.0rem; }

.main > section > section > section section ~ section, .flex2 > section > section > section section ~ section { margin-top: 2.0rem; }

@media screen and (min-width: 48em), print { .mt40 { margin-top: 8rem !important; }
  .mt30 { margin-top: 6rem !important; }
  .mt20 { margin-top: 4rem !important; }
  .mt10 { margin-top: 2rem !important; }
  .main > section ~ section, .flex2 > section ~ section { margin-top: 7.3rem; }
  .main > section section ~ section, .flex2 > section section ~ section { margin-top: 6.0rem; }
  .main > section > section section ~ section, .flex2 > section > section section ~ section { margin-top: 4.0rem; }
  .main > section > section > section section ~ section, .flex2 > section > section > section section ~ section { margin-top: 2.0rem; } }
.tbl_time { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 1.2rem; table-layout: fixed; overflow: hidden; }
.tbl_time tr th[scope="col"] { padding: .8rem 0; color: #fff; background: #a19278; font-weight: normal; }
.tbl_time tr th[scope="col"]:first-child { width: 32%; }
.tbl_time tr th[scope="col"]:last-child { padding: 0 1.0rem 0 0; white-space: nowrap; }
.tbl_time tr th.time { white-space: nowrap; text-align: center; border-bottom: .2rem #a19278 solid; font-weight: normal; background: #fff; font-size: 1.2rem; line-height: 1.4; }
.tbl_time tr td { text-align: center; font-weight: normal; font-size: 1.1rem; padding: 1.6rem 0; line-height: 1.0; color: #4E3B30; border-bottom: .2rem #a19278 solid; background: #fff; }

p.notice { margin: .8rem 0 0 0; font-size: 1.2rem; text-align: left; line-height: 1.4; }

@media screen and (min-width: 48em), print { .tbl_time tr th[scope="col"] { padding: .6rem 0; font-size: 2.0rem; }
  .tbl_time tr th[scope="col"]:first-child { width: 25%; }
  .tbl_time tr th.time { font-size: 2.0rem; }
  .tbl_time tr td { font-size: 2.0rem; padding: 1.6rem 0; }
  p.notice { font-size: 1.8rem; margin: 1.0rem 0 0 0; } }
.gmap { width: 100%; }
.gmap iframe { width: 100%; height: 100%; border: none; }

.tit_01 { font-size: 2.2rem; text-align: center; padding: 2.0rem 1.0rem; margin: 0 0 3.0rem; color: #7e6249; }

.tit_02 { text-align: center; color: #7e6249; font-size: 2.0rem; margin: 0 0 2.0rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.tit_02 span { max-width: 65%; }
.tit_02::before, .tit_02::after { display: inline-block; content: ''; width: 2.8rem; height: 2.2rem; background: url("../img/icon_h2.png") no-repeat center center/contain; }
.tit_02::before { margin: 0 1.4rem 0 0; }
.tit_02::after { margin: 0 0 0 1.4rem; }

.tit_03 { color: #3dbf90; font-weight: normal; font-size: 1.8rem; padding: 0 0 .2rem 0; margin: 0 0 2.0rem 0; border-bottom: #3dbf90 .4rem solid; position: relative; }
.tit_03::before { content: ''; width: 100%; border-bottom: #a9d8c7 solid .3rem; position: absolute; left: 0px; bottom: -.7rem; }

.tit_04 { color: #ee7e7e; font-size: 1.8rem; border-bottom: solid 0.4rem #ee7e7e; margin: 0 0 2.0rem; }

.tit_05 { color: #7e6249; font-size: 1.6rem; border-bottom: dashed 0.1rem #7e6249; }

@media screen and (min-width: 48em), print { .tit_01 { font-size: 4.4rem; padding: 35.0rem 1.0rem 0; margin: 0; }
  .tit_02 { font-size: 4.0rem; margin: 0 0 3.0rem; }
  .tit_02 span { max-width: 80%; }
  .tit_02::before, .tit_02::after { width: 5.6rem; height: 4.4rem; }
  .tit_03 { font-size: 3.8rem; padding: 0; margin: 0 0 3.0rem; border-bottom: #3dbf90 .5rem solid; line-height: 1.3; }
  .tit_03::before { border-bottom: #a9d8c7 solid .4rem; bottom: -.9rem; }
  .tit_04 { font-size: 3.4rem; }
  .tit_05 { font-size: 3.2rem; } }
.lst_ul01 li, .lst_ul02 li, .lst_ul03 li { text-indent: -1.4rem; padding-left: 2.0rem; padding-bottom: 1.0rem; line-height: 1.4; font-size: 1.4rem; }
.lst_ul01 li::before, .lst_ul02 li::before, .lst_ul03 li::before { content: '●'; margin-right: .4rem; color: #a9d8c7; vertical-align: .1rem; font-size: 80%; }
@media screen and (min-width: 48em), print { .lst_ul01 li, .lst_ul02 li, .lst_ul03 li { font-size: 1.8rem; text-indent: -1.8rem; padding-left: 2.0rem; }
  .lst_ul01 li::before, .lst_ul02 li::before, .lst_ul03 li::before { vertical-align: .2rem; } }

.lst_ul02 { padding: 1.3rem 1.3rem 0 1.3rem; }

.lst_ul03 li::before { content: ''; }

.lst_ol01 { margin: 1.0rem 0 1.0rem 2.6rem; }
.lst_ol01 li { line-height: 1.4; counter-increment: number 1; text-indent: -1.0rem; padding: 0 0 1.0rem 0; }
.lst_ol01 li::before { display: inline-block; content: counter(number) "."; margin-right: .8rem; font-family: 'Lato', sans-serif; color: #444; font-weight: bold; }

.lst_ol02 { counter-reset: my-counter; list-style: none; padding: 0; margin: 1.0rem; }
.lst_ol02 li { position: relative; padding-left: 3.0rem; line-height: 1.4; margin: 0 0 1.0rem; }
.lst_ol02 li:last-of-type { margin: 0; }
.lst_ol02 li::before { content: counter(my-counter); counter-increment: my-counter; background-color: transparent; border: 0.1rem #444 solid; border-radius: 50%; -webkit-box-sizing: border-box; box-sizing: border-box; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; height: 2.2rem; width: 2.2rem; color: #444; font-size: 85%; line-height: 1; position: absolute; top: 0; left: 0; }

.lst_dl01 dt { font-weight: bold; }
.lst_dl01 dd { margin: 0 0 1.0rem; }

.lst_dl02 dt { background: #EAF4FB; padding: .2rem .8rem; }
.lst_dl02 dd { margin: 0 0 2.0rem; padding: .8rem; }

@media screen and (min-width: 48em), print { .lst_ol01 { margin: 1.0rem 0 1.0rem 3.0rem; }
  .lst_ol01 li { text-indent: -1.2rem; padding: 0 0 1.4rem 0; }
  .lst_dl01 dt { float: left; width: 15.0rem; font-weight: bold; clear: left; }
  .lst_dl01 dd { padding-left: 15.0rem; }
  .lst_dl02 dt { padding: .4rem 1.0rem; }
  .lst_dl02 dd { padding: 1.0rem; } }
.flex2 li { margin: 0 0 1.0rem; }

.flex3 { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.flex3 > li { width: 46%; }

@media screen and (min-width: 48em), print { .flex2 { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .flex2 > section, .flex2 > li { width: 40%; margin: 0 !important; }
  .flex3 li { width: 31%; } }
.tel { line-height: 1.0; color: #ee7e7e; }
.tel::before { font-family: fontello; content: '\e808'; font-size: 79%; }
.tel a { text-decoration: none !important; }

.btn_rsv, .btn_rsv2 { display: block; background: #ee7e7e; color: #fff; text-align: center; border-radius: .8rem; padding: .4rem .6rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; border-right: .2rem #fff solid; border-bottom: .2rem #fff solid; -webkit-box-shadow: 2px 2px 4px #ccc; box-shadow: 2px 2px 4px #ccc; }

.btn_rsv2 { display: initial; }
@media screen and (min-width: 48em), print { .btn_rsv2 { padding: .6rem 2.0rem; } }

.btn_link { display: block; background: #3dbf90; border-radius: .4rem; text-align: center; padding: .4rem 0; color: #fff; }
.btn_link::before { display: inline-block; font-family: 'fontello'; content: '\e807'; font-size: 120%; margin: 0 .6rem 0 0; }

.btn_detail { display: inline-block; padding: .6rem 3.0rem; font-size: 1.4rem; border-radius: 3.0rem; background: #84b50a; background: -webkit-gradient(linear, left top, right top, from(#84b50a), color-stop(50%, #70ae12), color-stop(86%, #4fa31f), to(#419f25)); background: linear-gradient(to right, #84b50a 0%, #70ae12 50%, #4fa31f 86%, #419f25 100%); filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#84b50a', endColorstr='#419f25',GradientType=1 ); color: #fff; text-decoration: none !important; }
.btn_detail::before { font-family: 'fontello'; content: '\e80d'; margin: 0 .6rem 0 0; }
@media screen and (min-width: 48em), print { .btn_detail { padding: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
  .btn_detail::before { margin: 0 .8rem 0 0; } }

.btn_txt { color: #7e6249; text-decoration: underline !important; }
@media screen and (min-width: 48em), print { .btn_txt:hover { color: #b79b58; } }

.anc li .btn_detail::after { content: '▼'; }

@media screen and (min-width: 48em), print { .anc { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .anc li { margin: 0 2.0rem 2.0rem 0; }
  .anc li .btn_detail::after { content: '▼'; } }
.box_white { padding: 1.0rem; background: #fff; border-radius: .6rem; }
@media screen and (min-width: 48em), print { .box_white { padding: 4.0rem; } }

.box_blue, .box_yellow { padding: 1.0rem; background: #f7f3ea; }
@media screen and (min-width: 48em), print { .box_blue, .box_yellow { padding: 2.4rem; } }

.box_yellow { background: #fcebeb; }

html { font-size: calc(100vw / 32); font-family: "メイリオ", Meiryo, "Yu Gothic Medium", "游ゴシック Medium", YuGothic, "游ゴシック体", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", Osaka, "ＭＳ Ｐゴシック", "MS PGothic", Arial, sans-serif; }

body { background: #fff; color: #444; }

a { color: inherit; text-decoration: none; }

aside { display: none; }

.main { font-size: 1.2rem; line-height: 1.6; padding: 0 0 6.0rem; background: #fffdf4; }
.main a:not([href="tel"]) { text-decoration: underline; }
.main a[class*="btn_"] { text-decoration: none; }

@media screen and (min-width: 48em), print { :target::before { 	/* content: ""; display: block; height: 20.0rem; margin: -20.0rem 0 0;
	*/ }
  html { font-size: 62.5%; }
  body { min-width: calc(1110px + 40px); }
  a, button { -webkit-transition: .2s; transition: .2s; }
  a:hover, button:hover { opacity: .8; }
  .wrap { width: 1110px; margin: auto; }
  .wrapper { width: 100%; margin: 0 auto; padding: 0; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .main { width: 100%; font-size: 1.8rem; margin: 0; } }
@font-face { font-family: 'fontello'; src: url("fontello/font/fontello.eot"); src: url("fontello/font/fontello.eot#iefix") format("embedded-opentype"), url("fontello/font/fontello.woff2") format("woff2"), url("fontello/font/fontello.woff") format("woff"), url("fontello/font/fontello.ttf") format("truetype"), url("fontello/font/fontello.svg#fontello") format("svg"); }
@font-face { font-family: 'fontello2'; src: url("fontello2/font/fontello.eot"); src: url("fontello2/font/fontello.eot#iefix") format("embedded-opentype"), url("fontello2/font/fontello.woff2") format("woff2"), url("fontello2/font/fontello.woff") format("woff"), url("fontello2/font/fontello.ttf") format("truetype"), url("fontello2/font/fontello.svg#fontello") format("svg"); }
.header .sticky .wrap { margin: 0 1.0rem 1.0rem 1.0rem; }
.header .sticky .wrap .logo { padding: 0; width: 25.0rem; height: 7.3rem; background: url("../img/cloud_logo.png") no-repeat center center/contain; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; }
.header .sticky .wrap .logo a { display: block; width: 80%; height: 58%; background: url(../img/logo.svg) no-repeat left center/contain; text-indent: 100%; white-space: nowrap; overflow: hidden; }
.header .sticky .wrap .tel { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; font-size: 2.2rem; margin: -.6rem 0 0 0; }
.header .sticky .wrap .btn_rsv_header { display: none; text-align: center; background: url("../img/cloud_rsv_pink.png") no-repeat left center/contain; color: #fff; font-size: 1.6rem; font-weight: bold; -webkit-animation-name: anim_h; animation-name: anim_h; -webkit-animation-timing-function: ease-in-out; animation-timing-function: ease-in-out; -webkit-animation-iteration-count: infinite; animation-iteration-count: infinite; -webkit-animation-direction: alternate; animation-direction: alternate; -webkit-animation-duration: 1.8s; animation-duration: 1.8s; }
.header .sticky .wrap .btn_rsv_header span { display: block; }
@-webkit-keyframes anim_h { 0% { -webkit-transform: translate(0px, 0); transform: translate(0px, 0); }
  100% { -webkit-transform: translate(10px, 0); transform: translate(10px, 0); } }
@keyframes anim_h { 0% { -webkit-transform: translate(0px, 0); transform: translate(0px, 0); }
  100% { -webkit-transform: translate(10px, 0); transform: translate(10px, 0); } }
@media screen and (min-width: 48em), print { .header { margin: 0; padding: 0; }
  .header .sticky .wrap { margin: 0 auto; padding: 0; position: relative; }
  .header .sticky .wrap .logo { width: 64.0rem; height: 19.6rem; margin: 0; padding: 0; background: url("../img/cloud_logo.png") no-repeat center center/auto; position: absolute; top: 0; left: -5.7rem; z-index: 999; }
  .header .sticky .wrap .logo a { width: 53.7rem; height: 10.6rem; }
  .header .sticky .wrap .tel { background: url("../img/cloud_tel.png") no-repeat left center/auto; width: 41.9rem; height: 11.8rem; font-size: 4.6rem; padding: 2.0rem 0 0 0; position: absolute; top: 0; left: 58.3rem; margin: 0; }
  .header .sticky .wrap .btn_rsv_header { display: block; width: 32.6rem; height: 17.2rem; font-size: 4.0rem; background: url("../img/cloud_rsv_pink.png") no-repeat left center/auto; position: absolute; top: 10.0rem; /*right: -7.4rem;*/ right: 0; line-height: 1.0; padding: 5.0rem 0 0 0; z-index: 999; }
  .header .sticky .wrap .btn_rsv_header span { font-size: 2.0rem; line-height: 1.2; } }
.fixed_rsv_btn { display: none; }
.fixed_rsv_btn .fixed_rsv, .fixed_rsv_btn .fixed_rsv2, .fixed_rsv_btn .fixed_rsv3, .fixed_rsv_btn .fixed_rsv2, .fixed_rsv_btn .fixed_rsv3 { display: none; }
@media screen and (min-width: 48em), print { .fixed_rsv_btn .fixed_rsv, .fixed_rsv_btn .fixed_rsv2, .fixed_rsv_btn .fixed_rsv3 { color: #fff; font-size: 2.4rem; background: #ee7e7e; border-radius: 2.0rem 0 0 2.0rem; border: .3rem #fff solid; -webkit-box-shadow: 2px 2px 4px #ccc; box-shadow: 2px 2px 4px #ccc; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; z-index: 999; position: fixed; top: 3.0rem; right: 0; width: 7.7rem; height: 16.0rem; text-align: center; -webkit-writing-mode: vertical-lr; writing-mode: vertical-lr; -ms-writing-mode: tb-lr; }
  .fixed_rsv_btn .fixed_rsv2 { top: 20rem; }
  .fixed_rsv_btn .fixed_rsv3 { top: 42rem; }
  .fixed_rsv_btn .large { height: 21.0rem; }
  .fixed_rsv_btn .line { background: #06c755; }
  .fixed_rsv_btn .instagram { background: #e83361; } }

.tel_add .tel { font-size: 200%; }

.slicknav_menu { position: fixed; top: 0; right: 0; font-size: 1.4rem; display: inline-block; background: none; padding: 0; 	/*
	-webkit-transform: translate(-50%); -moz-transform: translate(-50%); -ms-transform: translate(-50%); -o-transform: translate(-50%); transform: translate(-50%);
	*/ z-index: 1000000; }
.slicknav_menu .slicknav_btn { width: 5.0rem; height: 5.5rem; color: #419F25; background: #fff; border: 1px solid #419F25; text-shadow: none; border-radius: 0; text-align: center; line-height: 1.0; margin: 1.0rem; padding: .4rem 0 0 0; z-index: 999; }
.slicknav_menu .slicknav_btn .slicknav_menutxt { display: none !important; }
.slicknav_menu .slicknav_btn.slicknav_collapsed::before { display: block; font-family: 'fontello2'; content: '\e801'; line-height: 1.0; font-size: 3.0rem; margin: .3rem 0 0 0; }
.slicknav_menu .slicknav_btn.slicknav_collapsed::after { display: block; content: 'MENU'; font-size: 1.0rem; margin: 0.4rem 0 0 0; }
.slicknav_menu .slicknav_btn.slicknav_open::before { display: block; font-family: 'fontello2'; content: '\e800'; line-height: 1.0; font-size: 3.0rem; }
.slicknav_menu .slicknav_btn.slicknav_open::after { display: block; content: 'CLOSE'; font-size: 1.0rem; margin: 0.4rem 0 0 0; }
.slicknav_menu .slicknav_icon, .slicknav_menu .slicknav_icon-bar, .slicknav_menu .slicknav_row:after { display: none !important; }
.slicknav_menu .slicknav_nav { width: 100vw; background: #a9d8c7; padding: 7.6rem 1.6rem 1.6rem 1.6rem; position: absolute; top: 0; right: 0; overflow: auto; -webkit-overflow-scrolling: touch; margin: 0; }
.slicknav_menu .slicknav_nav li { border-bottom: 1px solid #6f5c4b; }
.slicknav_menu .slicknav_nav li a { display: block; color: #444 !important; padding: 1.0rem 0; font-size: 1.6rem; position: relative; }
.slicknav_menu .slicknav_nav li a span { display: none; }
.slicknav_menu .slicknav_nav li a span.treatment { display: block; }
.slicknav_menu .slicknav_nav li a.sub { background: none; border: none; }
.slicknav_menu .slicknav_nav li a.sub::after { position: absolute; right: 1.0rem; top: 1.2rem; content: '▼'; color: #6f5c4b; }
.slicknav_menu .slicknav_nav li a:hover { color: inherit; background: none; }
.slicknav_menu .slicknav_nav li.slicknav_parent a.slicknav_item { padding: 0; }
.slicknav_menu .slicknav_nav li.slicknav_parent ul li:last-child { border: none; }
.slicknav_menu .slicknav_nav li.slicknav_open > a.slicknav_item .sub::after { content: '▲'; }
.slicknav_menu .slicknav_nav li .subnav li { border: none; }
.slicknav_menu .slicknav_nav li .subnav li a { padding: 1.0rem; background: rgba(255, 255, 255, 0.8); }
.slicknav_menu .slicknav_nav li .subnav li a span { display: block; }

.vaccination .slicknav_menu .slicknav_nav li a.infants { display: none; }

.menu_var_scroll { height: 100%; }
.menu_var_scroll ul { height: 100% !important; overflow: auto !important; }

#nav { display: none; }

@media screen and (min-width: 48em), print { .slicknav_menu { display: none; }
  #nav { display: block; width: 100%; height: 13.0rem; padding: 2.4rem 0 0 0; margin: 0; background: url("../img/bg_gnav.jpg"); }
  #nav ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; width: 1110px; margin: 0 auto; height: 7.8rem; }
  #nav ul li { position: relative; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-flex: 1; -ms-flex: 1; flex: 1; }
  #nav ul li:hover .children-1 { display: block; }
  #nav ul li a { display: block; text-align: center; font-size: 2.2rem; color: #fff; width: 100%; height: 100%; padding: 1.0rem 0 0 0; border-right: .1rem #fff dotted; }
  #nav ul li a::after { display: block; font-family: fontello; margin: .4rem auto 0; font-size: 3.0rem; }
  #nav ul li a.home { border-left: .1rem #fff dotted; }
  #nav ul li a.home::after { content: '\e82c'; }
  #nav ul li a.doctor::after { content: '\e80a'; }
  #nav ul li a.first::after { content: '\e840'; }
  #nav ul li a.sub::after { content: '\e82a'; }
  #nav ul li a.clinic::after { content: '\e82d'; }
  #nav ul li a.access::after { content: '\e804'; }
  #nav ul .children-1, #nav ul .children-2 { width: 42.0rem; }
  #nav ul .children-1 li, #nav ul .children-2 li { width: 21.0rem; float: left; height: 6.1rem; border-left: 0; border-bottom: .1rem #fff dotted; background: rgba(126, 98, 73, 0.8); }
  #nav ul .children-1 li:last-of-type, #nav ul .children-2 li:last-of-type { border-bottom: 0; }
  #nav ul .children-1 li a, #nav ul .children-2 li a { height: auto; padding: 2.0rem 1.0rem; width: 100%; border-left: 0; margin: 0; font-size: 1.8rem; color: #fff; text-align: left; white-space: nowrap; }
  #nav ul .children-1 li a:hover, #nav ul .children-2 li a:hover { background: #7e6249; }
  #nav ul .children-1 li:nth-of-type(even) a, #nav ul .children-2 li:nth-of-type(even) a { border-right: 0; }
  #nav ul .children-1 { display: none; position: absolute; background: transparent; z-index: 999; top: 0; left: 0; margin: auto; padding: 10.5rem 0 0 0; }
  #nav ul .children-1 li .children-2 { display: none; position: absolute; top: 0px; left: 110px; width: 100%; }
  #nav ul .children-1 li:hover .children-2 { display: block; background: #E6E4D7; }
  #nav ul .children-2 a { width: 100%; } }
.overview { padding: 4.0rem 1.0rem 2.0rem 1.0rem; background: url("../img/bg_summary.png") no-repeat center bottom, #e3f2d9; }
.overview .clinic_name { text-align: center; margin: 0 auto 2.0rem; }
.overview .clinic_name img { width: 85%; }
.overview > .wrap .overview_time { margin: 2.0rem 0 0 0; }
.overview > .wrap .overview_time p.tit { color: #6f5c4b; margin: 0 0 .4rem; font-size: 1.6rem; }
.overview > .wrap .overview_time .tbl_time caption { display: none; }
.overview > .wrap .overview_time .tbl_time tr th[scope="col"] { padding: .8rem 0; }
.overview > .wrap .overview_time .tbl_time tr th.time { background: transparent; }
.overview > .wrap .overview_time .tbl_time tr td { background: transparent; padding: 1.6rem 0; }
.overview > .wrap .overviewL .gaiyo, .overview > .wrap .overviewR .gaiyo { width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; margin: 0; }
.overview > .wrap .overviewL .gaiyo dt, .overview > .wrap .overviewL .gaiyo dd, .overview > .wrap .overviewR .gaiyo dt, .overview > .wrap .overviewR .gaiyo dd { border-bottom: .2rem solid #a19278; margin: 0; padding: 1.8rem 0; line-height: 1.3; }
.overview > .wrap .overviewL .gaiyo dt, .overview > .wrap .overviewR .gaiyo dt { width: 30%; color: #6f5c4b; font-size: 1.6rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: start; -ms-flex-pack: start; justify-content: flex-start; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.overview > .wrap .overviewL .gaiyo dd, .overview > .wrap .overviewR .gaiyo dd { width: 70%; line-height: 1.6; font-size: 1.4rem; }
.overview > .wrap .overviewL .gaiyo dd span.tel, .overview > .wrap .overviewR .gaiyo dd span.tel { font-size: 1.8rem; line-height: 1.0; color: #ee7e7e; }
.overview > .wrap .overviewL { margin: 3.0rem 0 0 0; }
.overview > .wrap .overviewL dt:first-of-type, .overview > .wrap .overviewL dd:first-of-type { border-top: .2rem solid #a19278; }

iframe { width: 90%; height: 30.0rem; margin: 2rem auto; border-width: 0; display: block; }

@media screen and (min-width: 48em), print { .overview { padding: 10.0rem 0; }
  .overview .clinic_name { margin: 0 auto 3.8rem; }
  .overview .clinic_name img { width: 54.2rem; }
  .overview > .wrap { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .overview > .wrap .overview_time { margin: 5.0rem 0 0 0; }
  .overview > .wrap .overview_time p.tit { margin: 0 0 1.0rem; font-size: 2.2rem; }
  .overview > .wrap .overview_time .tbl_time tr th[scope="col"] { padding: 1.0rem 0; }
  .overview > .wrap .overview_time .tbl_time tr td { padding: 2.05rem 0; }
  .overview > .wrap .overviewL, .overview > .wrap .overviewR { width: 48%; margin: 0; }
  .overview > .wrap .overviewL .gaiyo dt, .overview > .wrap .overviewL .gaiyo dd, .overview > .wrap .overviewR .gaiyo dt, .overview > .wrap .overviewR .gaiyo dd { padding: 2.55rem 0; }
  .overview > .wrap .overviewL .gaiyo dt:first-of-type, .overview > .wrap .overviewL .gaiyo dd:first-of-type, .overview > .wrap .overviewR .gaiyo dt:first-of-type, .overview > .wrap .overviewR .gaiyo dd:first-of-type { border-top: .2rem solid #a19278; }
  .overview > .wrap .overviewL .gaiyo dt, .overview > .wrap .overviewR .gaiyo dt { line-height: 1.5; font-size: 2.2rem; }
  .overview > .wrap .overviewL .gaiyo dd, .overview > .wrap .overviewR .gaiyo dd { font-size: 1.8rem; }
  .overview > .wrap .overviewL .gaiyo dd span.tel, .overview > .wrap .overviewR .gaiyo dd span.tel { font-size: 3.2rem; }
  iframe { width: 100%; height: 49.8rem; margin: 0; } }
.tel_up { width: 100%; background: #a58a72; padding: .2rem .6rem; visibility: visible; position: fixed; bottom: 0; left: 0; right: 0; z-index: 1; font-size: 1.4rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.tel_up .call { width: 40%; }
.tel_up .call a { white-space: nowrap; text-align: center; padding: .8rem 0; border-radius: .4rem; font-size: 1.4rem; line-height: 1.0; background: #fff; color: #ee7e7e; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.tel_up .call a::before { font-family: fontello; content: '\e9a6'; margin: 0 .3rem 0 0; font-size: 1.6rem; }
.tel_up .btn_rsv, .tel_up .btn_rsv2 { width: 40%; white-space: nowrap; padding: .8rem 0; font-size: 1.4rem; border-radius: .4rem; -webkit-box-shadow: none; box-shadow: none; border-right: 0; border-bottom: 0; }
.tel_up .btn_rsv::before, .tel_up .btn_rsv2::before { font-family: fontello; content: '\e9a5'; margin: 0 .3rem 0 0; font-size: 1.6rem; }
.tel_up .pageup a { display: block; width: 4.0rem; height: 4.0rem; font-size: 2.8rem; text-align: center; padding: .4rem 0 0 0; line-height: 1.0; color: #fff; background: #3dbf90; border-radius: 50%; /*margin: 0 0 0 auto;*/ }
.tel_up .pageup a::before { font-family: 'fontello'; content: '\e801'; font-weight: normal; }
.tel_up .pageup a span { display: none; }

@media screen and (min-width: 48em), print { .tel_up { display: block; width: 8.0rem; bottom: 4.0rem; right: 6.0rem; left: auto; cursor: pointer; background: none; padding: 0; }
  .tel_up .call, .tel_up .btn_rsv, .tel_up .btn_rsv2 { display: none; }
  .tel_up .pageup a { width: 6.0rem; height: 6.0rem; font-size: 4.0rem; padding: .5rem 0 0 0; } }
.footer { text-align: center; padding: 0; }
.footer .copy { color: #fff; display: block; padding: 1.0rem 1.0rem 5.4rem; font-size: 1.2rem; background: #a58a72; }
.footer .footer_wrapper { display: none; }

@media screen and (min-width: 48em), print { .footer { background: #a58a72; }
  .footer .footer_wrapper { width: 1110px; margin: 0 auto; padding: 4.5rem 0 10.0rem; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .footer .footer_wrapper .footer_nav { margin: 0; }
  .footer .footer_wrapper .footer_nav ul.glo, .footer .footer_wrapper .footer_nav ul.sub { width: 1110px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .footer .footer_wrapper .footer_nav ul.glo li, .footer .footer_wrapper .footer_nav ul.sub li { display: inline-block; font-size: 1.8rem; -webkit-text-size-adjust: none; border-right: .1rem #fff solid; padding: 0 2.0rem; margin: 0; }
  .footer .footer_wrapper .footer_nav ul.glo li:nth-of-type(4), .footer .footer_wrapper .footer_nav ul.sub li:nth-of-type(4) { display: none; }
  .footer .footer_wrapper .footer_nav ul.glo li:last-of-type, .footer .footer_wrapper .footer_nav ul.sub li:last-of-type { border-right: 0; }
  .footer .footer_wrapper .footer_nav ul.glo li a, .footer .footer_wrapper .footer_nav ul.sub li a { color: #fff; opacity: 1.0; }
  .footer .footer_wrapper .footer_nav ul.glo li a span, .footer .footer_wrapper .footer_nav ul.sub li a span, .footer .footer_wrapper .footer_nav ul.glo li a br, .footer .footer_wrapper .footer_nav ul.sub li a br { display: none; }
  .footer .footer_wrapper .footer_nav ul.glo li a:hover, .footer .footer_wrapper .footer_nav ul.sub li a:hover { text-decoration: underline; }
  .footer .footer_wrapper .footer_nav ul.glo li .subnav, .footer .footer_wrapper .footer_nav ul.sub li .subnav { display: none; }
  .footer .footer_wrapper .footer_nav ul.sub { margin: 2.6rem 0 0 0; }
  .footer .footer_wrapper .footer_nav ul.sub li { margin: 0; }
  .footer .footer_wrapper .footer_nav ul.sub li.border { border-right: 0; }
  .footer .footer_wrapper .footer_nav ul.sub li:nth-of-type(4) { display: block; }
  .footer .footer_wrapper .footer_nav ul.sub li a span { display: block; }
  .footer .copy { margin: 0 auto; padding: 2.6rem 0; font-size: 1.6rem; } }
body.index .main { padding: 2.0rem 0; }
@media screen and (min-width: 48em), print { body.index .main { padding: 11.4rem 0 0 0; } }

.bg_kvsl { background: url("../img/bg_keyvsl.jpg") no-repeat top center/cover; padding: 0; }
.bg_kvsl > div { z-index: 0 !important; top: 10.0rem !important; }
.bg_kvsl #keyvsl { margin: 0; padding: 0; max-width: 100%; background: url("../img/index_keyvsl01_sp.jpg") no-repeat center top/100% auto; }
.bg_kvsl #keyvsl .catch { position: relative; padding: 0 1.0rem 1.0rem 1.0rem; }
.bg_kvsl #keyvsl .catch p { font-size: 1.6rem; color: #6f5c4b; margin: 21.0rem 0 0 0; text-align: center; line-height: 1.5; text-shadow: #fff 1px 1px 3px, #fff -1px 1px 3px, #fff 1px -1px 3px, #fff -1px -1px 3px; }
.bg_kvsl #keyvsl .catch p span { font-weight: bold; font-size: 2.0rem; }
.bg_kvsl #keyvsl .catch p span.pink { color: #ee7e7e; }
.bg_kvsl #keyvsl .catch p span.green { color: #61cca5; }
.bg_kvsl #keyvsl .catch .flex2 { display: none; margin: 0; }
.bg_kvsl #keyvsl .catch .flex2 .open, .bg_kvsl #keyvsl .catch .flex2 .event { display: none; border-radius: 50%; background: #ee7e7e; -webkit-box-shadow: 2px 2px 4px #333; box-shadow: 2px 2px 4px #333; border: 0.3rem #fcebeb solid; text-align: center; color: #fff; font-size: 1.6rem; width: 12.0rem; height: 12.0rem; margin: 0 auto; padding: 2.4rem 0 0 0; line-height: 1.3; }
.bg_kvsl #keyvsl .catch .flex2 .open span.fs20, .bg_kvsl #keyvsl .catch .flex2 .event span.fs20 { font-size: 1.2rem; }
.bg_kvsl #keyvsl .catch .flex2 .open span.fs22, .bg_kvsl #keyvsl .catch .flex2 .event span.fs22 { font-size: 1.6rem; }
.bg_kvsl #keyvsl .catch .flex2 .open span.fs40, .bg_kvsl #keyvsl .catch .flex2 .event span.fs40 { font-size: 2.0rem; }
.bg_kvsl #keyvsl .catch .flex2 .event { display: none; line-height: 1.0; letter-spacing: -.1rem; }

@media screen and (min-width: 48em), print { .bg_kvsl { background: url("../img/bg_keyvsl.jpg") no-repeat center center/auto; padding: 0; position: relative; }
  .bg_kvsl > div { top: 17.0rem !important; }
  .bg_kvsl #keyvsl { background: url(../img/index_keyvsl01.png) no-repeat center top/auto; }
  .bg_kvsl #keyvsl .catch { width: 1110px; margin: 0 auto; height: 90.0rem; padding: 38.0rem 0 0 0; }
  .bg_kvsl #keyvsl .catch p { font-size: 3.4rem; text-align: left; margin: 0 0 0 7.0rem; -webkit-transform: translateX(-50%); transform: translateX(-50%); -webkit-writing-mode: vertical-rl; writing-mode: vertical-rl; -ms-writing-mode: tb-rl; }
  .bg_kvsl #keyvsl .catch p span { font-size: 4.0rem; }
  .bg_kvsl #keyvsl .catch .flex2 { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; width: 20.0rem; margin: -11.5rem 0 0 auto; }
  .bg_kvsl #keyvsl .catch .flex2 .open, .bg_kvsl #keyvsl .catch .flex2 .event { width: 20.0rem; height: 20.0rem; font-size: 2.8rem; padding: 3.0rem 0 0 0; border: 0.5rem #fcebeb solid; }
  .bg_kvsl #keyvsl .catch .flex2 .open span.fs20, .bg_kvsl #keyvsl .catch .flex2 .event span.fs20 { font-size: 2.0rem; }
  .bg_kvsl #keyvsl .catch .flex2 .open span.fs22, .bg_kvsl #keyvsl .catch .flex2 .event span.fs22 { font-size: 2.2rem; }
  .bg_kvsl #keyvsl .catch .flex2 .open span.fs40, .bg_kvsl #keyvsl .catch .flex2 .event span.fs40 { font-size: 4.0rem; } }
.bnr { margin: 0 1.0rem; }
.bnr img { display: block; margin: 0 auto 2.0rem; max-width: 23.0rem; position: relative; }

@media screen and (min-width: 48em), print { .bnr { width: 1110px; margin: 0 auto; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .bnr img { margin: 0 0 2.4rem; max-width: 54.0rem; } }
.info { margin: 2.0rem 1.0rem 0; }
.info dl { margin: 0 auto; line-height: 1.4; padding: 2.0rem 1.0rem 1.0rem 1.0rem; background: #fff; border: 0.2rem #f29b8f solid; border-radius: 1.0rem; }
.info dl dt { font-size: 1.4rem; color: #ee7e7e; }
.info dl dt:not(.close)::before { content: '▲'; margin: 0 .6rem 0 0; display: inline-block; -webkit-transform: rotate(-180deg); transform: rotate(-180deg); }
.info dl dt.close::before { content: '▲'; margin: 0 .6rem 0 0; display: inline-block; -webkit-transform: rotate(0deg); transform: rotate(0deg); }
.info dl dd { font-size: 1.2rem; padding: 0 0 1.6rem; margin: 0 0 1.6rem; }
.info dl dd .link_text { display: block; }
.info dl dd:not(:nth-of-type(-n+3)) { display: none; }

@media screen and (min-width: 48em), print { .info { margin-top: 11.9rem !important; padding: 0; background: url("../img/bg_info_01.jpg") no-repeat center top/auto; }
  .info dl { width: 1110px; height: auto; min-height: 40.0rem; margin: 0 auto; padding: 3.0rem; border: 0.3rem #f29b8f solid; }
  .info dl dt { font-size: 2.2rem; }
  .info dl dd { font-size: 2.0rem; } }
.info02 { margin: 2.0rem 1.0rem 0; background: url("../img/bg_info_02.jpg") no-repeat center bottom/110%; }
.info02 .flex_content .main_timetable { background: url("../img/tree_01.png") no-repeat center bottom 1.6rem/90% 120%; margin: 0 0 3.0rem; padding: 1.0rem 0 4.0rem; }
.info02 .flex_content .main_timetable .timetable_wrapper { border: 0.2rem #b79b58 solid; background: #fff; border-radius: 1.0rem; padding: 1.0rem; }
.info02 .flex_content .main_timetable .timetable_wrapper .tbl_time caption { color: #6f5c4b; font-size: 1.8rem; }
.info02 .flex_content .main_access { background: url("../img/tree_02.png") no-repeat center bottom/contain; padding: 1.0rem 0 4.0rem; }
.info02 .flex_content .main_access .tbl_access { border: 0.2rem #b79b58 solid; background: #fff; border-radius: 1.0rem; padding: 1.0rem; }
.info02 .flex_content .main_access .tbl_access .tel { color: #ee7e7e; text-align: center; font-size: 2.0rem; }
.info02 .flex_content .main_access .tbl_access .btn_rsv, .info02 .flex_content .main_access .tbl_access .btn_rsv2 { font-size: 1.8rem; padding: .4rem 0 .2rem; margin: .6rem 0 1.0rem; }
.info02 .flex_content .main_access .tbl_access p.border-top { margin: .6rem 0 0 0; padding: .8rem 0 0 0; border-top: .2rem #b79b58 dashed; }

@media screen and (min-width: 48em), print { .info02 { margin-top: 6.5rem !important; margin: 0; padding: 0; background: url("../img/bg_info_02.jpg") no-repeat center bottom/auto; }
  .info02 .flex_content { width: 1110px; margin: 0 auto; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
  .info02 .flex_content .main_timetable { width: 63.4rem; padding: 1.5rem 0 12.5rem; margin: 0; background: url("../img/tree_01.png") no-repeat center bottom/auto; }
  .info02 .flex_content .main_timetable .timetable_wrapper { width: 100%; border: 0.3rem #b79b58 solid; padding: 2.8rem 3.6rem; }
  .info02 .flex_content .main_timetable .timetable_wrapper .tbl_time caption { font-size: 3.0rem; }
  .info02 .flex_content .main_access { width: 44.5rem; padding: 1.5rem 0 12.5rem; margin: 0; background: url("../img/tree_02.png") no-repeat center bottom/auto; }
  .info02 .flex_content .main_access .tbl_access { width: 100%; height: 37.0rem; border: 0.3rem #b79b58 solid; padding: 2.8rem 3.6rem; }
  .info02 .flex_content .main_access .tbl_access .tel { font-size: 3.8rem; }
  .info02 .flex_content .main_access .tbl_access .tel::before { vertical-align: .2rem; }
  .info02 .flex_content .main_access .tbl_access .btn_rsv, .info02 .flex_content .main_access .tbl_access .btn_rsv2 { font-size: 2.8rem; height: 4.3rem; margin: 0 0 1.6rem; padding: .4rem 0; } }
.features { margin-top: 0 !important; margin: 0; padding: 3.0rem 1.0rem 0 1.0rem; background: url("../img/bg_feature_01.png") no-repeat center top 9rem, url("../img/bg_feature_02.png") no-repeat center bottom 14.8rem, #eaf8fe; }
.features .features_wrapper { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.features .features_wrapper .box { margin: 0 0 3.0rem; width: 49%; }
.features .features_wrapper .box figure { margin: 0; padding: 0; position: relative; text-align: center; }
.features .features_wrapper .box figure img { border-radius: 1.2rem; }
.features .features_wrapper .box figure figcaption { font-size: 1.3rem; position: absolute; bottom: -3.0rem; left: 0; right: 0; width: 12.5rem; height: 7.0rem; margin: auto; background: url("../img/bg_obj_pink.png") no-repeat center center/contain; color: #fff; font-weight: bold; text-align: center; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.features .features_wrapper .box figure figcaption.green { background: url("../img/bg_obj_green.png") no-repeat center center/contain; }
.features .features_wrapper .box p { margin: 3.5rem 0 0 0; padding: .6rem; }

@media screen and (min-width: 48em), print { .features { margin-top: 0 !important; padding: 10.0rem 0 4.5rem; width: 100%; }
  .features .features_wrapper { width: 1110px; margin: 6.0rem auto 0; }
  .features .features_wrapper .box { width: 25.5rem; margin: 0 0 5.5rem; }
  .features .features_wrapper .box figure figcaption { top: 19.2rem; width: 21.5rem; height: 13.3rem; font-size: 2.2rem; }
  .features .features_wrapper .box p { margin: 7.3rem 0 0 0; padding: 0; } }
.tre { margin-top: 0 !important; margin: 0; padding: 3.0rem 1.0rem; background: url("../img/bg_treatment.png") no-repeat center top/contain; }
.tre .list_tre { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -ms-flex-wrap: wrap; flex-wrap: wrap; }
.tre .list_tre li { margin: 0 0 1.0rem; padding: 0 .2rem; }
.tre .list_tre li a { display: block; text-decoration: none; font-size: 1.2rem; width: 9.5rem; height: 9.5rem; color: #6f5c4b; background: #afead3; text-align: center; border-radius: 50%; border: .3rem #fff solid; -webkit-box-shadow: 2px 2px 4px #ccc; box-shadow: 2px 2px 4px #ccc; padding: 2rem 0 0 0; }
.tre .list_tre li a::before { display: block; font-family: fontello; margin: 0 0 .2rem; font-size: 3.5rem; line-height: 1.0; }
.tre .list_tre li a.pediatrics::before { content: '\e88f'; }
.tre .list_tre li a.allergies { background: #b9eaa6; }
.tre .list_tre li a.allergies::before { content: '\e88e'; }
.tre .list_tre li a.pediatric-derma { background: #fdea92; }
.tre .list_tre li a.pediatric-derma::before { content: '\e88d'; }
.tre .list_tre li a.vaccination { background: #feceb3; }
.tre .list_tre li a.vaccination::before { content: '\e88c'; }
.tre .list_tre li a.infants { background: #fdd6df; }
.tre .list_tre li a.infants::before { content: '\e88b'; }

@media screen and (min-width: 48em), print { .tre { margin-top: 0 !important; padding: 8.0rem 0 11.0rem; width: 100%; background: url("../img/bg_treatment.png") no-repeat center top/auto; }
  .tre .list_tre { width: 1110px; margin: 0 auto; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .tre .list_tre li { margin: 0; padding: 0; }
  .tre .list_tre li a { font-size: 2.2rem; width: 20.0rem; height: 20.0rem; border: .5rem #fff solid; padding: 3.0rem 0 0 0; }
  .tre .list_tre li a::before { margin: 0 0 1.0rem; font-size: 8.5rem; } }
.cal { background: #fff; padding: 3.0rem 1.0rem; }
.cal .inner p { margin: 0; }
.cal .inner p span.kyuushin::before, .cal .inner p span.day::before, .cal .inner p span.weekend::before, .cal .inner p span.kakunin::before { width: 16px; height: 16px; content: ''; background: #FF9AB5; display: inline-block; border: .2rem #909196 solid; vertical-align: -.2rem; margin: 0 .2rem; }
.cal .inner p span.day::before, .cal .inner p span.weekend::before, .cal .inner p span.kakunin::before { background-color: #CCFFFF; }
.cal .inner p span.day::before { background-color: #c1ebdb; }
.cal .inner p span.weekend::before { background-color: #FFEFB9; }
.cal .inner p span.kakunin::before { background-color: #fcd6db; }

@media screen and (min-width: 48em), print { .cal { padding: 9.5rem 0; }
  .cal .inner { width: 1110px; padding: 0; margin: 3.6rem auto 0; }
  .cal .inner .swiper-slide { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .cal .inner .swiper-slide div { width: 54.0rem; margin: 0; }
  .cal .inner .swiper-slide div table { width: 100%; margin: 0; }
  .cal .inner p { margin: 0 0 2.4rem; text-align: left; }
  .cal .inner p span.kyuushin, .cal .inner p span.day, .cal .inner p span.weekend, .cal .inner p span.kakunin, .cal .inner p span.day, .cal .inner p span.weekend, .cal .inner p span.kakunin { font-size: 2.2rem; margin: 0 3.2rem 0 0; }
  .cal .inner p span.kyuushin::before, .cal .inner p span.day::before, .cal .inner p span.weekend::before, .cal .inner p span.kakunin::before, .cal .inner p span.day::before, .cal .inner p span.weekend::before, .cal .inner p span.kakunin::before { width: 3.2rem; height: 3.2rem; margin: 0 .7rem 0 0; vertical-align: -.7rem; } }
body:not(.index) .wrapper { background: #fffdf4; }
body:not(.index) .main { margin: 0 1.0rem; padding: 4.0rem 0; background: url("../img/bg_low.png") no-repeat center top/contain, #fffdf4; }
@media screen and (min-width: 48em), print { body:not(.index) .main { background: url("../img/bg_low.png") no-repeat center top/auto, #fffdf4; width: 1110px; margin: 0 auto; padding: 8.6rem 0; } }
body:not(.index) .bg_kvsl { background: url("../img/keyvisual_low.jpg") no-repeat top center/cover; padding: 0 0 3.0rem; }
@media screen and (min-width: 48em), print { body:not(.index) .bg_kvsl { background: url("../img/keyvisual_low.jpg") no-repeat center center/auto; height: 74.0rem; padding: 0; } }

.arrow { width: 0; height: 0; border-left: 6.0rem solid transparent; border-right: 6.0rem solid transparent; border-top: 3.0rem solid #00b9d5; text-align: center; display: block; margin: 3.0rem auto; }

.block { display: block; font-weight: bold; }

.break { overflow-wrap: break-word; line-height: 2.8; }
@media screen and (min-width: 48em), print { .break { line-height: inherit; } }

#clinicslide01 img, #clinicslide01 p, #clinicslide02 img, #clinicslide02 p { display: none; }

.sp-layer.sp-black.sp-padding { text-align: left; font-size: 2.4rem; }

.sp-selected-thumbnail { border: 2px solid #a58a72; }

.machine_flex .equip { margin: 0 0 3.0rem; }
.machine_flex .equip p { margin: 0; }
@media screen and (min-width: 48em), print { .machine_flex { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
  .machine_flex .equip { width: 48%; margin: 0 0 3.0rem; }
  .machine_flex .equip img { margin: 0 0 1.0rem; }
  .machine_flex .equip p { font-size: 1.6rem; } }

.flow dt { font-weight: bold; }
.flow dd { margin: 0 0 6.0rem; position: relative; }
@media screen and (min-width: 48em), print { .flow dd { margin: 0 0 10.0rem; } }
.flow dd:not(:last-child)::after { display: block; width: 0; height: 0; content: ""; position: absolute; bottom: -5.0rem; left: 0; right: 0; border-top: 2rem solid #a9d8c7; border-right: 3.0rem solid transparent; border-bottom: 1.0rem solid transparent; border-left: 3.0rem solid transparent; margin: auto; }

.access .main .tbl_time caption { display: none; }
.access .illustmap { margin: 0 auto 2.0rem; display: block; }
.access .gmap { height: 30.0rem; margin: 2.0rem 0; }

@media screen and (min-width: 48em), print { .access .main .tbl_time tr th[scope="col"] { font-size: 1.8rem; }
  .access .main .tbl_time tr th.time { font-size: 1.8rem; }
  .access .main p.notice { font-size: 1.8rem; }
  .access .main .gmap { height: 50.0rem; } }
.tbl_price, .tbl_lst { width: 100%; border-collapse: collapse; table-layout: fixed; }
.tbl_price tr th, .tbl_lst tr th { display: block; padding: .4rem 1.0rem; text-align: left; background: #f6f6f6; font-weight: normal; border: 1px solid #ccc; border-bottom: none; }
.tbl_price tr td, .tbl_lst tr td { display: block; padding: 1.0rem; border: 1px solid #ccc; text-align: right; }
.tbl_price tr:not(:last-child) td, .tbl_lst tr:not(:last-child) td { border-bottom: none; }
.tbl_price.num, .num.tbl_lst { counter-reset: number 0; }
.tbl_price.num tr th, .num.tbl_lst tr th { counter-increment: number 1; }
.tbl_price.num tr th::before, .num.tbl_lst tr th::before { display: inline-block; content: counter(number) "."; margin-right: .4rem; }

.tbl_lst tr th, .tbl_lst tr td { display: table-cell; }
.tbl_lst tr th { text-align: center; }
.tbl_lst tr td { background: #fff; text-align: left; }

@media screen and (min-width: 48em), print { .tbl_price tr th, .tbl_lst tr th, .tbl_price tr td, .tbl_lst tr td { display: table-cell; padding: 2.0rem; }
  .tbl_price tr th, .tbl_lst tr th { width: 45%; border-bottom: 1px solid #ccc; }
  .tbl_price tr:not(:last-child) td, .tbl_lst tr:not(:last-child) td { border-bottom: 1px solid #ccc; } }
.treatment .kasomenu_btn { text-align: right; }

/*# sourceMappingURL=style.css.map */