@charset "UTF-8";
/*.footer a {display: inline-block;}
a {pointer-events:none;}
a.slicknav_btn, a[href="###"], a[href="#top"], a[href="./"], a[href="doctor.html"], a[href="access.html"] {pointer-events:auto;}*/
/*a.slicknav_btn{pointer-events:auto;}
a {pointer-events:none;}*/
/*薄い青*/
/*濃い青*/
/*薄い緑*/
/*濃い緑*/
/*グレー*/
/*ピンク*/
/*フォント　太さ*/
/*フォント　太さ*/
/* ----------------------------------------------------------------------------------
リセット　_reset.scss
---------------------------------------------------------------------------------- */
html, body, div, span, object, iframe,
h1, h2, h3, h4, h5, h6, p, blockquote, pre,
abbr, address, cite, code,
del, dfn, em, img, ins, kbd, q, samp,
small, strong, sub, sup, var,
b, i,
dl, dt, dd, ol, ul, li,
fieldset, form, label, legend,
table, caption, tbody, tfoot, thead, tr, th, td,
article, aside, canvas, details, figcaption, figure,
footer, header, hgroup, menu, nav, section, summary,
time, mark, audio, video {
  margin: 0;
  padding: 0;
  border: 0;
  outline: 0;
  vertical-align: baseline;
  background: transparent;
  font-style: normal !important;
}

html {
  font-size: calc( 100vw / 32 );
  font-family: 'Noto Sans Japanese',   sans-serif;
  box-sizing: border-box;
  font-weight: 400;
}

@media (min-width: 768px) {
  html {
    font-size: 62.5%;
  }
}
*, *::before, *::after {
  box-sizing: inherit;
}

body {
  color: #212121;
  line-height: 1;
  margin: 0;
}

ol, ul {
  margin: 0;
  padding: 0;
  list-style: none;
}

h1, h2, h3, h4, h5, h6 {
  margin: 0;
  padding: 0;
  font-size: inherit;
  font-weight: normal;
}

img {
  vertical-align: bottom;
}

a {
  text-decoration: none;
  margin: 0;
  padding: 0;
  font-size: 100%;
  vertical-align: baseline;
  background: transparent;
}

article, aside, details, figcaption, figure,
footer, header, hgroup, menu, nav, section {
  display: block;
}

nav ul {
  list-style: none;
}

blockquote, q {
  quotes: none;
}

blockquote:before, blockquote:after,
q:before, q:after {
  content: '';
  content: none;
}

/* change colours to suit your needs */
ins {
  background-color: #ff9;
  color: #000;
  text-decoration: none;
}

/* change colours to suit your needs */
mark {
  background-color: #ff9;
  color: #000;
  font-style: italic;
  font-weight: bold;
}

del {
  text-decoration: line-through;
}

abbr[title], dfn[title] {
  border-bottom: 1px dotted;
  cursor: help;
}

table {
  border-collapse: collapse;
  border-spacing: 0;
}

/* change border colour to suit your needs */
hr {
  display: block;
  height: 1px;
  border: 0;
  border-top: 1px solid #cccccc;
  margin: 1em 0;
  padding: 0;
}

button,
html [type="button"],
[type="reset"],
[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
}

/**
 * Remove the inner border and padding in Firefox.
 */
button::-moz-focus-inner,
[type="button"]::-moz-focus-inner,
[type="reset"]::-moz-focus-inner,
[type="submit"]::-moz-focus-inner {
  border-style: none;
  padding: 0;
}

/**
 * Restore the focus styles unset by the previous rule.
 */
button:-moz-focusring,
[type="button"]:-moz-focusring,
[type="reset"]:-moz-focusring,
[type="submit"]:-moz-focusring {
  outline: 1px dotted ButtonText;
}

input, select {
  vertical-align: middle;
}

/*CLEARFIX*/
.cf {
  zoom: 1;
}

.cf:before, .cf:after {
  content: "";
  display: table;
}

.cf:after {
  clear: both;
}

section {
  zoom: 1;
}

section:before, section:after {
  content: "";
  display: table;
}

section:before, section:after {
  clear: both;
}

.font_bold{
  font-weight: bold;
}

.border{
  border: 1px solid #212121;
}

.underline{
text-decoration: underline;
}


/* -----------------------------------------------------------------------
　カラー
----------------------------------------------------------------------- */
.red { 
color: #FF0000;
}

.blue { 
color: #1b83a6;
}

.box-red {
border:#FF2233 1px solid;
padding: 15px;
}

/* 汎用 　*/
/* タイトル　*/
/* リスト */
/* 画像回り込み */
/* 診察概要 */
/* お知らせ　*/
/* top back */
/* カレンダー */
/* map */
/* テーブルタイプ */
/*:::::::::::::::::::::::::::::::::::::::::::::::

汎用 

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*画像
------------------------------------*/
.img-responsive {
  display: block;
  max-width: 100%;
  height: auto;
}

/*youtube
------------------------------------*/
.youtube {
  display: block;
  margin: 0 auto;
  max-width: 100%;
}

/* 表示・非表示
------------------------------------*/
@media screen and (min-width: 768px) {
  .spN {
    display: block;
  }

  .pcN {
    display: none;
  }
}
@media screen and (max-width: 768px) {
  .spN {
    display: none;
  }

  .pcN {
    display: block;
  }
}
/*テキスト配置*/
.txC {
  text-align: center;
}

.txR {
  text-align: right;
}

.txL {
  text-align: left;
}

/*一部テキストカラー変更*/
.textCl-type01 {
  color: #714627;
}

/****ギャラリーのテキスト****/
.slider-pro p.sp-layer {
  font-size: 3.2rem;
  line-height: 1.2;
}

@media (min-width: 768px) {
  .slider-pro p.sp-layer {
    font-size: 2.6rem;
  }
}
/* Spaces
------------------------------------*/
.pT0 {
  padding-top: 0;
}

.content-xs {
  padding-top: 10px;
  padding-bottom: 10px;
}

.content {
  padding-top: 20px;
  padding-bottom: 20px;
}

.content-sm {
  padding-top: 30px;
  padding-bottom: 30px;
}

.content-md {
  padding-top: 40px;
  padding-bottom: 40px;
}

.content-lg {
  padding-top: 50px;
  padding-bottom: 50px;
}

@media (min-width: 768px) {
  .content-xs {
    padding-top: 20px;
    padding-bottom: 20px;
  }

  .content {
    padding-top: 40px;
    padding-bottom: 40px;
  }

  .content-sm {
    padding-top: 60px;
    padding-bottom: 60px;
  }

  .content-md {
    padding-top: 80px;
    padding-bottom: 80px;
  }

  .content-lg {
    padding-top: 100px;
    padding-bottom: 100px;
  }
}
.mB0, .mB5, .mB10, .mB15, .mB20, .mB25, .mB30, .mB35, .mB40, .mB45, .mB50, .mB55, .mB60 {
  clear: both;
}

.mB0 {
  margin-bottom: 0px !important;
}

.mB5 {
  margin-bottom: 5px !important;
}

.mB10 {
  margin-bottom: 10px !important;
}

.mB15 {
  margin-bottom: 15px !important;
}

.mB20 {
  margin-bottom: 20px !important;
}

.mB25 {
  margin-bottom: 25px !important;
}

.mB30 {
  margin-bottom: 30px !important;
}

.mB35 {
  margin-bottom: 35px !important;
}

.mB40 {
  margin-bottom: 40px !important;
}

.mB45 {
  margin-bottom: 45px !important;
}

.mB50 {
  margin-bottom: 50px !important;
}

.mB55 {
  margin-bottom: 55px !important;
}

.mB60 {
  margin-bottom: 60px !important;
}

@media (max-width: 768px) {
  .sm_mB10 {
    margin-bottom: 10px !important;
  }

  .sm_mB20 {
    margin-bottom: 20px !important;
  }

  .sm_mB30 {
    margin-bottom: 30px !important;
  }

  .sm_mB40 {
    margin-bottom: 40px !important;
  }

  .sm_mB50 {
    margin-bottom: 50px !important;
  }

  .sm_mB60 {
    margin-bottom: 60px !important;
  }
}
@media (max-width: 992px) {
  .md_mB10 {
    margin-bottom: 10px !important;
  }

  .md_mB20 {
    margin-bottom: 20px !important;
  }

  .md_mB30 {
    margin-bottom: 30px !important;
  }

  .md_mB40 {
    margin-bottom: 40px !important;
  }

  .md_mB50 {
    margin-bottom: 50px !important;
  }

  .md_mB60 {
    margin-bottom: 60px !important;
  }
}
.mT0 {
  margin-top: 0px !important;
}

.mT5 {
  margin-top: 5px !important;
}

.mT10 {
  margin-top: 10px !important;
}

.mT15 {
  margin-top: 15px !important;
}

.mT20 {
  margin-top: 20px !important;
}

.mT25 {
  margin-top: 25px !important;
}

.mT30 {
  margin-top: 30px !important;
}

.mT35 {
  margin-top: 35px !important;
}

.mT40 {
  margin-top: 40px !important;
}

.mT45 {
  margin-top: 45px !important;
}

.mT50 {
  margin-top: 50px !important;
}

.mT55 {
  margin-top: 55px !important;
}

.mT60 {
  margin-top: 60px !important;
}

@media (max-width: 768px) {
  .sm_mT10 {
    margin-top: 10px !important;
  }

  .sm_mT20 {
    margin-top: 20px !important;
  }

  .sm_mT30 {
    margin-top: 30px !important;
  }

  .sm_mT40 {
    margin-top: 40px !important;
  }

  .sm_mT50 {
    margin-top: 50px !important;
  }

  .sm_mT60 {
    margin-top: 60px !important;
  }
}
@media (max-width: 992px) {
  .md_mT10 {
    margin-top: 10px !important;
  }

  .md_mT20 {
    margin-top: 20px !important;
  }

  .md_mT30 {
    margin-top: 30px !important;
  }

  .md_mT40 {
    margin-top: 40px !important;
  }

  .md_mT50 {
    margin-top: 50px !important;
  }

  .md_mT60 {
    margin-top: 60px !important;
  }
}
.mL0 {
  margin-left: 0px !important;
}

.mL5 {
  margin-left: 5px !important;
}

.mL10 {
  margin-left: 10px !important;
}

.mL15 {
  margin-left: 15px !important;
}

.mL20 {
  margin-left: 20px !important;
}

.mL25 {
  margin-left: 25px !important;
}

.mL30 {
  margin-left: 30px !important;
}

.mL35 {
  margin-left: 35px !important;
}

.mL40 {
  margin-left: 40px !important;
}

.mL45 {
  margin-left: 45px !important;
}

.mL50 {
  margin-left: 50px !important;
}

.mL55 {
  margin-left: 55px !important;
}

.mL60 {
  margin-left: 60px !important;
}

@media (max-width: 768px) {
  .sm_mL10 {
    margin-left: 10px !important;
  }

  .sm_mL20 {
    margin-left: 20px !important;
  }

  .sm_mL30 {
    margin-left: 30px !important;
  }

  .sm_mL40 {
    margin-left: 40px !important;
  }

  .sm_mL50 {
    margin-left: 50px !important;
  }

  .sm_mL60 {
    margin-left: 60px !important;
  }
}
@media (max-width: 992px) {
  .md_mL10 {
    margin-left: 10px !important;
  }

  .md_mL20 {
    margin-left: 20px !important;
  }

  .md_mL30 {
    margin-left: 30px !important;
  }

  .md_mL40 {
    margin-left: 40px !important;
  }

  .md_mL50 {
    margin-left: 50px !important;
  }

  .md_mL60 {
    margin-left: 60px !important;
  }
}
.mR0 {
  margin-right: 0px !important;
}

.mR5 {
  margin-right: 5px !important;
}

.mR10 {
  margin-right: 10px !important;
}

.mR15 {
  margin-right: 15px !important;
}

.mR20 {
  margin-right: 20px !important;
}

.mR25 {
  margin-right: 25px !important;
}

.mR30 {
  margin-right: 30px !important;
}

.mR35 {
  margin-right: 35px !important;
}

.mR40 {
  margin-right: 40px !important;
}

.mR45 {
  margin-right: 45px !important;
}

.mR50 {
  margin-right: 50px !important;
}

.mR55 {
  margin-right: 55px !important;
}

.mR60 {
  margin-right: 60px !important;
}

@media (max-width: 768px) {
  .sm_mR10 {
    margin-right: 10px !important;
  }

  .sm_mR20 {
    margin-right: 20px !important;
  }

  .sm_mR30 {
    margin-right: 30px !important;
  }

  .sm_mR40 {
    margin-right: 40px !important;
  }

  .sm_mR50 {
    margin-right: 50px !important;
  }

  .sm_mR60 {
    margin-right: 60px !important;
  }
}
@media (max-width: 992px) {
  .md_mR10 {
    margin-right: 10px !important;
  }

  .md_mR20 {
    margin-right: 20px !important;
  }

  .md_mR30 {
    margin-right: 30px !important;
  }

  .md_mR40 {
    margin-right: 40px !important;
  }

  .md_mR50 {
    margin-right: 50px !important;
  }

  .md_mR60 {
    margin-right: 60px !important;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

タイトル

:::::::::::::::::::::::::::::::::::::::::::::::*/
.tit-type01 {
  color: #303030;
  font-size: 2.0rem;
  letter-spacing: .5rem;
  background: #f5f5f5;
  width: 100%;
  height: 100%;
  text-align: center;
}
.tit-type01 span {
  margin: 0 auto;
  padding: 2.4rem 0;
  display: block;
}
.tit-type01 span.keyb_2 {
  letter-spacing: 0;
}

.tit-type02 {
  font-size: 1.8rem;
  color: #1b83a6;
  border: solid 2px #4ec4d3;
  text-align: center;
  padding: 2px;
  background: #e9f3f9;
  margin-bottom: 1.5rem;
}
.tit-type02 span {
  display: block;
  border: 1px solid #4ec4d3;
}

.tit-type02 span small {
  font-size: 65%;
}

.tit-type03 {
  color: #729920;
  font-size: 1.7rem;
  margin-bottom: 1.5rem;
  border-bottom: 2px solid #c4e194;
}

.tit-type04 {
  color: #e78eb6;
  font-size: 2.2rem;
  position: relative;
  display: inline-block;
  /*padding: 0 0 0 2.5rem;*/
  vertical-align: middle;
  font-weight: 300;
  margin-bottom: 10px;
}/*
.tit-type04::before {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  box-sizing: border-box;
  width: 2.2rem;
  height: 2.2rem;
  border: 2px solid #e78eb6;
  -webkit-border-radius: 50%;
  border-radius: 50%;
}
.tit-type04::after {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 0;
  margin: auto;
  content: "";
  vertical-align: middle;
  left: 4px;
  width: 1rem;
  height: 1rem;
  border-top: 2px solid #e78eb6;
  border-right: 2px solid #e78eb6;
  -webkit-transform: rotate(45deg);
  transform: rotate(45deg);
}
*/
.tit-type05 {
  color: #1b83a6;
  font-size: 1.7rem;
  /*display: inline-block;*/
  padding: 0 5px;
  text-align: center;
  position: relative;
  width: 80%;
  margin: 0 auto;
}
.tit-type05 span {
  padding: 20px 0;
  /*position: relative;*/
}
.tit-type05 span::before, .tit-type05 span:after {
  position: absolute;
  width: 50px;
  height: 25px;
}
.tit-type05 span::before {
  content: "";
  background: url(../images/doctor_bg_left.png) no-repeat;
  left: 0;
  bottom: 0;
}
.tit-type05 span::after {
  content: "";
  background: url(../images/doctor_bg_right.png) no-repeat;
  right: -7px;
  bottom: 0;
}

/*.tit-type05:before, .tit-type05:after{
  content: '';
  position: absolute;
  top: 50%;
  display: inline-block;
  width: 45px;
  height: 5px;
  border-top: double 1px #1b83a6;
  border-bottom: double 1px #1b83a6;
}
*/
.tit-type05:before {
  left: 0;
}

.tit-type05:after {
  right: 0;
}

@media (min-width: 768px) {
  .tit-type01 {
    width: 1100px;
    margin: 0;
    text-align: center;
    font-size: 3.6rem;
    color: #303030;
    background: url(../images/keyv_bg_right.png) no-repeat right center/contain #f5f5f5;
  }
  .tit-type01 span {
    width: 1100px;
    margin: 0 auto;
    padding: 4.0rem 0;
    display: block;
  }

  .doctor .tit-type01 span {
    background: url(../images/keyv_bg_left_doctor.png) no-repeat left center/contain;
  }

  .treatment .tit-type01 span {
    background: url(../images/keyv_bg_left_treatment.png) no-repeat left center/contain;
  }

  .clinic .tit-type01 span {
    background: url(../images/keyv_bg_left_clinic.png) no-repeat left center/contain;
  }

  .access .tit-type01 span {
    background: url(../images/keyv_bg_left_access.png) no-repeat left center/contain;
  }

  .price .tit-type01 span {
    background: url(../images/keyv_bg_left_price.png) no-repeat left center/contain;
  }

  .dermatology .tit-type01 span {
    background: url(../images/keyv_bg_left_dermatology.png) no-repeat left center/contain;
  }

  .pediatrics .tit-type01 span {
    background: url(../images/keyv_bg_left_aesthetic_pediatrics.png) no-repeat left center/contain;
  }

  .allergy .tit-type01 span {
    background: url(../images/keyv_bg_left_allergy.png) no-repeat left center/contain;
  }

  .aesthetic_dermatology .tit-type01 span {
    background: url(../images/keyv_bg_left_aesthetic_dermatology.png) no-repeat left center/contain;
  }

  .light_treatment .tit-type01 span {
    background: url(../images/keyv_bg_left_light_treatment.png) no-repeat left center/contain;
  }

  .recruit .tit-type01 span {
    background: url(../images/keyv_bg_left_recruit.png) no-repeat left center/contain;
  }

  .laser .tit-type01 span {
    background: url(../images/keyv_bg_left_qswitch.png) no-repeat left center/contain;
  }

  .tit-type02 {
    font-size: 2.8rem;
    letter-spacing: 0.5rem;
    margin-bottom: 2.0rem;
  }
  .tit-type02 span {
    padding: 23px 0;
    position: relative;
  }
  .tit-type02 span::before, .tit-type02 span:after {
    position: absolute;
    width: 50px;
    height: 50px;
  }
  .tit-type02 span::before {
    content: "";
    background: url(../images/tit_bottom_left.svg) no-repeat;
    left: 0;
    bottom: 0;
  }
  .tit-type02 span::after {
    content: "";
    background: url(../images/tit_top_right.svg) no-repeat;
    right: 0;
    top: 0;
  }

  .tit-type03 {
    font-size: 2.4rem;
    margin-bottom: 2.0rem;
    padding-bottom: 5px;
  }

  .tit_type_04 {
    font-size: 2.6rem;
    padding: 0 0 0 30px;
  }

  .tit-type05 {
    font-size: 2.4rem;
    width: 40%;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

リンク

:::::::::::::::::::::::::::::::::::::::::::::::*/
.link-type01 {
  font-size: 1.5rem;
  padding-left: 5px;
  margin-top: 5px;
  display: inline-block;
  text-align: left;
  color: #e9f3f9;
  position: relative;
  padding-left: 20px;
}

.link-type01::before {
  font-family: "fontello";
  content: '\f138';
  position: absolute;
  font-size: 1.5rem;
  display: block;
  right: 0;
  left: 0;
  color: #f0f6e6;
}

.link-type01:hover {
  text-decoration: underline;
}

@media (min-width: 768px) {
  .link-type01 {
    font-size: 1.6rem;
  }

  .link-type01::before {
    font-size: 1.6rem;
  }
}
.mailLink {
  font-size: 1.5rem;
  display: inline-block;
  margin-bottom: 10px;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

ボタン

:::::::::::::::::::::::::::::::::::::::::::::::*/
.contact_btn {
  text-decoration: none;
  color: #fff;
  border: double 0px #e78eb6;
  background: #e78eb6;
  border-radius: 3px;
  text-align: center;
  width: 80%;
  font-size: 1.5rem;
  position: relative;
  margin: 0 auto;
  display: block;
  font-weight: 600;
}
.contact_btn a {
  display: block;
  color: #fff;
  padding: 1.0rem 1.0rem 1.0rem;
  line-height: 1.3;
}
/*.contact_btn::before {
  font-family: "fontello";
  content: '\e800';
  position: absolute;
  font-size: 3.5rem;
  display: block;
  left: 1.5rem;
  color: #745029;
  top: 2.2rem;
}*/

@media (min-width: 768px) {
  .contact_btn {
    /*padding: 1.0rem 2.0rem 1.0rem 5.5rem;*/
    line-height: 1.3;
  width: 40%;
  font-size: 2rem;
  }
  .contact_btn::before {
    top: 1.3rem;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

リスト

:::::::::::::::::::::::::::::::::::::::::::::::*/
/* list-type別
------------------------------------*/
.list-type01 {
  margin-bottom: 10px;
  list-style-type: none;
}
.list-type01 li {
  line-height: 1.5;
  font-size: 1.4rem;
  padding-left: 20px;
  position: relative;
  margin-bottom: 15px;
  text-indent: -0.5em;
}
.list-type01 li::before {
  content: '';
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background: #e78eb6;
  left: -10px;
  margin-top: 4px;
  position: relative;
}

.list-type02 {
  margin-bottom: 10px;
  list-style-type: none;
}
.list-type02 li {
  line-height: 1.5;
  font-size: 1.4rem;
  padding-left: 20px;
  position: relative;
  margin-bottom: 15px;
  text-indent: -0.5em;
}
.list-type02 li::before {
  content: '';
  display: inline-block;
  width: 0.8rem;
  height: 0.8rem;
  border-radius: 50%;
  background: #e78eb6;
  left: -10px;
  margin-top: 4px;
  position: relative;
}

.list-type03 li {
  margin-bottom: 0;
}
.list-type03 li dl {
  border: 1px solid #CCC;
}
.list-type03 li dt {
  background: #eee;
  padding-left: 10px;
  margin-bottom: 0;
}
.list-type03 li dd {
  border-bottom: 1px solid #CCC;
  margin-bottom: 0;
  padding: 5px 0 5px 10px;
}
.list-type03 li dd:last-child {
  border-bottom: none;
}

@media (min-width: 768px) {
  .list-type01 li {
    font-size: 1.8rem;
    margin-bottom: 12px;
    margin-left: .8rem;
  }
  .list-type01 li::before {
    width: 1.0rem;
    height: 1.0rem;
    left: -15px;
    margin-top: 2px;
    top: -2px;
  }

  .list-type02 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .list-type02 li {
    font-size: 1.8rem;
    flex-basis: 47.5%;
    margin-bottom: 12px;
    margin-left: .8rem;
  }
  .list-type02 li::before {
    width: 1.0rem;
    height: 1.0rem;
    left: -15px;
    margin-top: 2px;
    top: -2px;
  }

  .list-type03 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  .list-type03 li {
    margin-bottom: 0;
    flex-basis: 50%;
  }
  .list-type03 li dl {
    border: 1px solid #ccc;
  }
  .list-type03 li dt {
    background: #eee;
    padding: 10px;
    margin-bottom: 0;
  }
  .list-type03 li dd {
    border-bottom: 1px solid #ccc;
    margin-bottom: 0;
    padding: 5px 0 5px 10px;
  }
  .list-type03 li dd:last-child {
    border-bottom: none;
  }
}
/****リンクのリスト****/
.link-list-type01 li a {
  font-size: 1.5rem;
  padding-left: 5px;
  margin-top: 5px;
  display: inline-block;
  text-align: left;
  color: #e78eb6;
  position: relative;
  padding-left: 15px;
}
.link-list-type01 li a::before {
  /*サイトによって変更WEBフォント*/
  font-family: "fontello";
  content: '\e800';
  position: absolute;
  font-size: 1.6rem;
  display: block;
  right: 0;
  left: 0;
  color: #e78eb6;
}
.link-list-type01 li a:hover {
  text-decoration: underline;
}

@media (min-width: 768px) {
  .link-list-type01 li a {
    font-size: 1.8rem;
  }
  .link-list-type01 li a::before {
    font-size: .7rem;
  }
}
/*番号リスト*/
.number-type01 {
  counter-reset: number 0;
}
.number-type01 li::before {
  counter-increment: number 1;
  /* number カウンタを増加 */
  content: "※" counter(number);
  /* 表示形式を指定 */
  padding-right: 5px;
}

/* detail-type(dl)
------------------------------------*/
.detail-type01 dt {
  font-size: 1.6rem;
  position: relative;
  margin-bottom: 0;
  font-weight: 600;
}
.detail-type01 dd {
  font-size: 1.5rem;
  margin-bottom: 2.0rem;
}

@media (min-width: 768px) {
  .detail-type01 dt {
    font-size: 1.9rem;
    margin-bottom: 0.5rem;
  }
  .detail-type01 dd {
    font-size: 1.8rem;
    margin-bottom: 20px;
  }
}
.detail-type02 dt {
  font-size: 1.6rem;
  position: relative;
  padding-left: 2.0rem;
  margin-bottom: 0;
  color: #1b83a6;
}
.detail-type02 dt:before {
  background: #1b83a6;
  content: "";
  height: 1.2rem;
  width: 1.2rem;
  left: 0;
  position: absolute;
  top: 50%;
  -moz-transform: translateY(-50%);
  -webkit-transform: translateY(-50%);
  -ms-transform: translateY(-50%);
  transform: translateY(-50%);
}
.detail-type02 dd {
  font-size: 1.5rem;
  margin-bottom: 1.5rem;
}

@media (min-width: 768px) {
  .detail-type02 dt {
    font-size: 1.9rem;
    margin-bottom: 0.5rem;
  }
  .detail-type02 dd {
    margin-bottom: 20px;
    font-size: 1.8rem;
  }
}
/****flowBox(流れ)****/
.flowBox {
  list-style: none;
  padding: 0;
  margin: 10px auto 0px;
}

.flowBox li {
  margin-bottom: 5.0rem;
  position: relative;
  border: 1px solid #1b83a6;
  /*詳細がない場合があるため先にlastから記載*/
}
.flowBox li span:last-child {
  display: block;
  background: #FFF;
  padding: 10px;
  font-size: 1.5rem;
  line-height: 1.5;
}
.flowBox li span:first-child {
  background: #1b83a6;
  padding: 5px 10px;
  display: block;
  font-size: 1.6rem;
  line-height: 1.3;
  color: #FFF;
}
.flowBox li span:first-child::first-letter {
  /*1文字めを大きく*/
  font-size: 2.2rem;
  letter-spacing: 0.15em;
}

@media (min-width: 768px) {
  .flowBox li {
    margin-bottom: 5.0rem;
    position: relative;
    border: 1px solid #1b83a6;
    /*詳細がない場合があるため先にlastから記載*/
  }
  .flowBox li span:last-child {
    padding: 15px;
    font-size: 1.8rem;
  }
  .flowBox li span:first-child {
    padding: 5px 10px;
    font-size: 1.9rem;
  }
  .flowBox li span:first-child::first-letter {
    /*1文字めを大きく*/
    font-size: 2.5rem;
  }
  .flowBox li .imgR2 {
    margin-bottom: 0 !important;
  }
}
.flowBox li::after {
  bottom: -3.5rem;
  color: #1b83a6;
  content: "▼";
  font-size: 2.0rem !important;
  left: 47.5%;
  position: absolute;
}

.flowBox li:last-child {
  margin-bottom: 0;
}

.flowBox li:last-child::after {
  /*最後の▼を外す*/
  content: "";
}

@media (min-width: 768px) {
  .flowBox li::after {
    bottom: -43px;
    font-size: 2.5rem !important;
  }
}
/*経歴*/
.career-list {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -moz-justify-content: space-between;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -moz-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-content: center;
  font-size: 1.5rem;
  margin: 0;
}
.career-list dt {
  flex-basis: 100%;
  margin-bottom: 5px;
}
.career-list dd {
  flex-basis: 100%;
  margin-left: 0;
  margin-bottom: 25px;
  line-height: 1.3;
}

@media (min-width: 768px) {
  .career-list {
    font-size: 1.8rem;
  }
  .career-list dt {
    flex-basis: 4em;
    margin-bottom: 10px;
  }
  .career-list dd {
    flex-basis: calc(100% - 5em);
    margin-bottom: 20px;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

カラムボックス

:::::::::::::::::::::::::::::::::::::::::::::::*/
/****PC カラム****/
@media (min-width: 768px) {
  .flex_col2,
  .flex_col3 {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
  }

  .flex_col3:after {
    content: "";
    display: block;
    width: 32.5%;
  }

  /*2カラム*/
  .col-6 {
    flex-basis: 48.5%;
  }

  /*3カラム*/
  .col-4 {
    flex-basis: 32.5%;
  }

  /*テキストがあれば*/
  .col-6 span,
  .col-4 span {
    display: block;
  }
  .col-6 span:nth-of-type(1),
  .col-4 span:nth-of-type(1) {
    text-align: center;
    margin: 15px 0;
    font-size: 1.7rem;
    line-height: 1.5;
  }
  .col-6 span:nth-of-type(2),
  .col-4 span:nth-of-type(2) {
    margin: 15px 0;
    font-size: 1.4rem;
    line-height: 1.5;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

画像回り込み

:::::::::::::::::::::::::::::::::::::::::::::::*/
.imgNomal img {
  width: auto;
  margin: 10px 5px 0 5px;
}

@media (min-width: 768px) {
  .imgNomal img {
    width: auto;
    margin: 10px 5px;
  }
}
/*-----------------------------------------

右

----------------------------------------------*/
/**** PC テキスト回り込こみのみ　imgにクラス追加****/
.imgR2 {
  width: 80%;
  /*サイトによって変更*/
  padding-bottom: 15px;
  margin: 0 auto;
  display: block;
}
.imgR2 .img100 {
  width: 100%;
}

@media (min-width: 768px) {
  .imgR2 {
    float: right;
    width: 33%;
    margin-left: 2.0rem;
    margin-bottom: 2.0rem;
    padding-bottom: 0px;
  }
}
@media (max-width: 768px) {
  .imgR2 {
    text-align: center;
  }

  /*院長紹介用*/
  .imgR2 img {
    width: 70%;
  }
}
/****テキスト回り込なし　右 imgタグを　div alignRboxで囲む****/
@media (min-width: 768px) {
  .alignRbox p {
    width: 64%;
    overflow: hidden;
  }
}
/*-----------------------------------------

左

----------------------------------------------*/
/**** PC テキスト回り込こみのみ　imgにクラス追加****/
.imgL2 {
  width: 80%;
  /*サイトによって変更*/
  padding-bottom: 15px;
  margin: 0 auto;
  display: block;
}

@media (min-width: 768px) {
  .imgL2 {
    float: left;
    width: 32%;
    /*サイトによって変更*/
    padding-bottom: 0px;
    margin-right: 2.0rem;
    margin-bottom: 2.0rem;
  }
}
/****テキスト回り込なし　右 imgタグを　div alignRboxで囲む****/
@media (min-width: 768px) {
  .alignLbox p {
    overflow: hidden;
  }
}
/*-----------------------------------------

中央

----------------------------------------------*/
/*中央配置*/
.alignCbox {
  text-align: center;
  margin-bottom: 20px;
}
.alignCbox img {
  width: 80%;
}

@media (min-width: 768px) {
  .alignCbox {
    margin-bottom: 30px;
  }
  .alignCbox img {
    width: auto;
  }
}
/*画像丸*/
.imgMaru {
  border-radius: 50%;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

診療概要

:::::::::::::::::::::::::::::::::::::::::::::::*/
.overviewBox {
  padding: 0rem 0 4rem;
}

@media (min-width: 768px) {
  .overviewBox {
    padding: 0;
  }

  .gaiyo {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
}
.gaiyoBox .clinicName {
  font-size: 1.7rem;
  font-weight: 600;
  margin-bottom: 1.3rem;
}
.gaiyoBox .telphon {
  line-height: 1.0rem;
}
.gaiyoBox .telphon span {
  display: inline-block;
  width: 4.0rem;
  font-size: 1.6rem;
  font-weight: 600;
}
.gaiyoBox .telphon .tel {
  width: 22rem;
  color: #212121;
}
.gaiyoBox .telphon .tel a {
  color: #212121;
}
.gaiyoBox dl {
  align-content: center;
  margin-bottom: .3rem;
}
.gaiyoBox dt {
  color: #e78eb6;
  padding: 5px 0;
  font-size: 1.4rem;
  margin-bottom: 0;
  display: inline-block;
  margin-top: .5rem;
  font-weight: 400;
}
.gaiyoBox dd {
  padding: 5px 0 5px 5px;
  font-size: 1.3rem;
  display: inline;
  line-height: 1.3rem;
}
.gaiyoBox dd br {
  display: none;
}

@media (min-width: 768px) {
  .gaiyoBox {
    width: 100%;
    margin-bottom: 3.0rem;
  }
  .gaiyoBox .clinicName {
    font-size: 2.2rem;
    margin-bottom: 1.5rem;
  }
  .gaiyoBox .telphon span {
    width: 4.0rem;
    font-size: 1.8rem;
    font-weight: 400;
  }
  .gaiyoBox .telphon .tel {
    width: 25rem;
    color: #212121;
  }
  .gaiyoBox .telphon + p {
    font-size: 1.5rem;
  }
  .gaiyoBox dl {
    align-content: center;
    margin-bottom: 0;
  }
  .gaiyoBox dt {
    padding: 0;
    font-size: 1.5rem;
    display: inline-block;
    margin-top: .5rem;
  }
  .gaiyoBox dd {
    padding: 0 5px;
    font-size: 1.5rem;
    display: inline;
    line-height: 1.3rem;
  }
  .gaiyoBox dd br {
    display: none;
  }
}
.timetable th, .timetable td {
  padding: .7rem 0;
  border-bottom: 1px solid #DDD;
  text-align: center;
}

.timetable {
  width: 100%;
  margin-bottom: 2.0rem;
}
.timetable th {
  font-weight: normal;
  font-size: 1.3rem;
  background: #75ccf3;
  color: #FFF;
}
.timetable td {
  width: 7rem;
  text-align: center;
  font-size: 1.3rem;
  vertical-align: middle;
}
.timetable td .time2 {
  font-size: 1.0rem;
}
.timetable td:first-child {
  width: 25rem;
  font-size: 1.3rem;
  color: #729920;
  background: #f0f6e6;
}

@media (min-width: 768px) {
  .timetable th, .timetable td {
    padding: 1.5rem 0;
  }

  .timetable {
    width: 100%;
    margin-bottom: 0;
  }
  .timetable th {
    font-size: 1.6rem;
  }
  .timetable th:first-child {
    text-align: center;
  }
  .timetable td {
    width: 10%;
    text-align: center;
    font-size: 1.8rem;
  }
  .timetable td .time2 {
    font-size: 1.4rem;
  }
  .timetable td:first-child {
    width: 25%;
    font-size: 1.8rem;
    text-align: center;
  }
  .timetable td:last-child {
    width: 10%;
  }
}
caption {
  caption-side: bottom;
  padding: 10px 0 10px;
  font-size: 1.4rem;
  line-height: 1.5;
  text-align: left;
}
caption span {
  color: #e78eb6;
  display: block;
}

@media (min-width: 768px) {
  caption {
    font-size: 1.5rem;
  }
  caption span {
    display: inline-block;
    margin-right: 15px;
  }
}
.hoshi {
  color: #e78eb6;
  font-size: 2.0rem;
}

@media (min-width: 768px) {
  .hoshi {
    font-size: 2.5rem;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

お知らせ

:::::::::::::::::::::::::::::::::::::::::::::::*/
.notice_frame {
  height: 16rem;
  overflow-y: scroll;
  background: #FFF;
  padding: 10px;
  border-bottom: 2px solid #ddd;
}
.notice_frame dl {
  margin-top: 0;
}

@media only screen and (min-width: 768px) {
  .notice_frame {
    height: 300px;
    overflow-y: scroll;
    padding: 30px;
  }
  .notice_frame dl {
    margin-top: 0;
  }
}
.news_title {
  padding: 0px;
  font-size: 1.6rem;
  margin: 5px 0 5px;
  color: #729920;
}

@media only screen and (min-width: 768px) {
  .news_title {
    font-size: 1.8rem;
    margin-bottom: 5px;
  }
}
.news_body {
  margin: 0 0 15px 0;
  padding-bottom: 15px;
}

.news_body p {
  line-height: 1.3;
  font-size: 1.4rem;
  margin-top: 0;
  margin-bottom: 0;
}

@media (min-width: 768px) {
  .news_body p {
    font-size: 1.5rem;
  }
}
/*リンク*/
.news_body a {
  color: #4ec4d3;
  font-size: 1.4rem;
  display: block;
}
.news_body a::before {
  content: "\f105";
  font-family: 'fontello';
  position: relative;
  display: inline-block;
  padding-right: 5px;
}

@media (min-width: 768px) {
  .news_body a {
    font-size: 1.6rem;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

Back To Top

:::::::::::::::::::::::::::::::::::::::::::::::*/
#topcontrol {
  font-size: 1.4rem;
  position: relative;
  z-index: 99;
  right: 5px !important;
  bottom: 106px !important;
  width: 20%;
  height: 10%;
  color: #a6a6a6;
  border: 1px solid #a6a6a6;
  background: #FFF;
}

#topcontrol:before {
  position: absolute;
  top: 20px;
  left: 19px;
  text-align: center;
  content: "PAGE TOP";
  right: 10vw;
  font-family: 'Noto Sans Japanese', sans-serif;
}

#topcontrol:after {
  font-family: "fontello";
  position: absolute;
  top: -1px;
  left: 1vw;
  content: '\f106';
  text-align: center;
  color: #e78eb6;
  right: 0;
  font-size: 2.4rem;
}

@media (min-width: 768px) {
  #topcontrol {
    font-size: 31px;
    position: relative;
    z-index: 99;
    right: 0px !important;
    bottom: 10px !important;
    width: 80px;
    height: 80px;
    margin-right: 10px;
    border: 1px solid #a6a6a6;
  }

  #topcontrol:before {
    position: absolute;
    top: 30px;
    left: 0;
    text-align: center;
    font-size: 16px;
    right: 0;
    width: 70px;
    margin: 0 auto;
  }

  #topcontrol:after {
    font-family: "fontello";
    position: absolute;
    top: 5px;
    left: 0;
    right: 0;
    margin: 0 auto;
    content: '\f106';
    text-align: center;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

オンライン受付

:::::::::::::::::::::::::::::::::::::::::::::::*/
#reserve_online {
  font-size: 1.6rem;
  position: fixed;
  z-index: 99;
  right: 0px !important;
  bottom: 0px !important;
  width: 100%;
  height: 45px;
  color: #212121;
  border: 1px solid #c5ecfa;
  background: #6ac4ea;
}
#reserve_online a {
  text-decoration: none;
}
#reserve_online a:hover {
  opacity: 0.6;
}

#reserve_online :before {
  position: absolute;
  top: 10px;
  left: 0;
  text-align: center;
  content: "オンライン受付はこちら";
  color: #fff;
  right: 10vw;
  font-family: 'Noto Sans Japanese', sans-serif;
}

#reserve_online :after {
  font-family: "fontello";
  position: absolute;
  top: 5px;
  left: 55vw;
  content: '\f101';
  text-align: center;
  color: #1b83a6;
  right: 0;
  font-size: 2.4rem;
}

/*スマホ　フッターより下に固定のボタン*/
.pf_down {
  display: none;
  width: 100%;
  /*float: left;*/
  position: fixed;
  left: 0;
  bottom: 0;
  background: #fff;
  height: 106px;
  z-index: 999;
  border-top: solid 1px #eee;
}

.pf_down li {
  width: 33.333333%;
  /*float: left;
  text-align: center;
  padding: 7px 0 5px 0;*/
  list-style: none;
  position: relative;
	margin-top: 15px;
}
.on_bg, .bo_bg1, .bo_bg2 {
	display: block;
	position: relative;
	text-align: center;
}
.on_bg::after {
	position: absolute;
	/*right: 13px;
	left: 25%;
	top: 3px;*/
	content: '';
	width: 100px;
	height: 100px;
	box-sizing: border-box;
	background-color: #50b6fe;
	border-radius: 50%;
	z-index: -1;
}
.bo_bg1.center a{
  display: flex;
  width: 100%;
  height: 100%;
  justify-content: center;
  align-items: center;
}
.bo_bg1.center .bo_bg1_txt{
  margin-top: 0!important;
}
.bo_bg1::after {
	position: absolute;
	/*right: 13px;
	left: 10%;
	top: 3px;*/
	content: '';
	width: 100px;
	height: 100px;
	box-sizing: border-box;
	background-color: #61d729;
	border-radius: 50%;
	z-index: -1;
}

.bo_bg2::after {
	position: absolute;
	/*right: 13px;
	left: 10%;
	top: 3px;*/
	content: '';
	width: 100px;
	height: 100px;
	box-sizing: border-box;
	background-color: #ff90bb;
	border-radius: 50%;
	z-index: -1;
}
/*
.pf_down li.bo::before {
  display: block;
  content: '';
  position: absolute;
  top: .5em;
  width: 1px;
  height: 44px;
  background-color: #fff;
}
}*/

.pf_down li .ico7 {
  /*width: 100%;
  float: left;*/
  height: 22px;
  color: #fff;
}

.pf_down li .name {
  /*width: 100%;
  float: left;*/
  margin-top: 15px;
  font-size: 14px;
  color: #fff;
  line-height: 14px;
}

.pf_down li.l1 .ico7::before {
  font-family: "fontello";
  content: '\e805';
  /*text-align: center;*/
  color: #fff;
  font-size: 2.0rem;
}

.pf_down li.l2 .ico7::before {
  font-family: "fontello";
  content: '\e80e';
  /*text-align: center;*/
  color: #fff;
  font-size: 2.5rem;
	display: block;
	margin-top: -7px;
}

.bo_bg1_txt {
	margin-top: 30%!important;
}

.pf_down li.l3 .ico7::before {
  font-family: "fontello";
  content: '\e806';
  text-align: center;
  color: #fff;
  font-size: 2.0rem;
}

@media screen and (max-width: 767px) {
  .pf_down {
    /*display: block;*/
		display: flex;
		
  }
	.pf_down li {
		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;
	}
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

map

:::::::::::::::::::::::::::::::::::::::::::::::*/
.gmap img {
  margin-bottom: 1.5rem;
}
.gmap dl {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -moz-justify-content: space-between;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -moz-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
  font-weight: 600;
}
.gmap dt {
  flex-basis: 12em;
  max-width: 12em;
  font-size: 1.3rem;
  line-height: normal;
  margin-bottom: 0;
  position: relative;
  padding-left: 1.2rem;
}
.gmap dt::before {
  background: #000;
  content: "";
  height: 15px;
  width: 15px;
  left: 0;
  position: absolute;
  top: 5px;
}
.gmap dt:nth-of-type(1)::before {
  background: #8dc21f;
}
.gmap dt:nth-of-type(2)::before {
  background: #8b2126;
}
.gmap dd {
  flex-basis: calc(100% - 10em);
  font-size: 1.6rem;
  line-height: normal;
  margin-bottom: 0;
}
.gmap dd span {
  font-size: 1.3rem;
}

@media (min-width: 768px) {
  .gmap {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 800px;
  }
  .gmap img {
    flex-basis: 562px;
    max-width: 562px;
    height: 351px;
  }
  .gmap dl {
    flex-basis: 215px;
    max-width: 215px;
    display: block;
  }
  .gmap dt {
    font-size: 1.8rem;
    padding-left: 1.7rem;
  }
  .gmap dt::before {
    height: 15px;
    width: 15px;
  }
  .gmap dd {
    font-size: 2.2rem;
    line-height: normal;
    margin-bottom: 2.0rem;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

カレンダー

:::::::::::::::::::::::::::::::::::::::::::::::*/
.scheduleBox ul li {
  font-size: 1.4rem;
  margin-bottom: 20px;
}

.scheduleBox ul li:nth-child(2) {
  width: 49%;
  display: inline-block;
}

.scheduleBox ul li:nth-child(3) {
  width: 49%;
  display: inline-block;
}

.scheduleBox ul li:nth-child(4) {
  width: 49%;
  display: inline-block;
}

.scheduleBox ul li:nth-child(5) {
  width: 49%;
  display: inline-block;
}
.scheduleBox ul li::before {
  content: "　";
  margin-right: 5px;
  padding: 0px 3px;
  border-width: 1px;
  border-style: solid;
  border-color: #ddd;
  border-image: initial;
}

.scheduleBox ul li:first-child::before {
  background: #d4eeff;
}

.scheduleBox ul li:nth-child(2)::before {
  background: #E8D4FF;
}

.scheduleBox ul li:nth-child(3)::before {
  background: #CCFFCC;
}

.scheduleBox ul li:nth-child(4)::before {
  background: #ffe28a;
}

.scheduleBox ul li:nth-child(5)::before {
  background: #e8e8e8;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

テーブルタイプ

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*スマホ用　2行のため　カラム落ちタイプ*/
@media (max-width: 768px) {
  .table-type02 {
    overflow: auto;
  }
  .table-type02 table, .table-type02 td, .table-type02 th {
    display: block;
    border: 1px solid #ccc;
    line-height: 1.5;
    text-align: center;
  }
  .table-type02 table {
    width: 100%;
    box-sizing: border-box;
    font-size: 1.4rem;
    margin: 0 0 30px 0;
    border: none;
    border-bottom: 1px solid #CCC;
    display: inline-table;
    /*キャプション*/
  }
  .table-type02 table tr {
    display: block;
  }
  .table-type02 table tr:first-child {
    margin-bottom: 0;
  }
  .table-type02 table th {
    font-size: 1.4rem;
    font-weight: 400;
    background: #FFFFF5;
    padding: 10px 5px;
    width: 100%;
    vertical-align: middle;
    border-bottom: none;
    line-height: 1.5;
  }
  .table-type02 table td {
    width: 100%;
    padding: 5px;
  }
  .table-type02 table th, .table-type02 table td {
    border: none;
  }
  .table-type02 table th {
    border-right: 1px solid #CCC;
    border-left: 1px solid #CCC;
    border-top: 1px solid #CCC;
  }
  .table-type02 table td {
    width: 100%;
    padding: 15px 0;
    text-align: center;
    border-top: 1px solid #CCC;
    border-right: 1px solid #CCC;
    border-left: 1px solid #CCC;
    background: #FFF;
  }
  
  .table-type02 table .timetable-caption {
    caption-side: top;
    padding: 5px 0;
    font-size: 1.5rem;
    border-top: 1px solid #CCC;
    border-left: 1px solid #CCC;
    border-right: 1px solid #CCC;
    font-weight: 600;
    text-align: center;
    background: #CCC;
  }
}
/*pc用は通常テーブル*/
@media (min-width: 768px) {
  .table-type02 {
    overflow: inherit;
    white-space: normal;
    margin-bottom: 30px;
    /*キャプション*/
  }
  .table-type02 table, .table-type02 td, .table-type02 th {
    border: 1px solid #CCC;
    border-collapse: collapse;
  }
  .table-type02 table {
    width: 100%;
    box-sizing: border-box;
    font-size: 1.7rem;
    margin: 0 0 30px 0;
  }
  .table-type02 table th {
    font-size: 1.7rem;
    background: #FFFFF5;
    border: #CCC 1px solid;
    padding: 10px 5px;
    width: 40%;
    vertical-align: middle;
    font-weight: 400;
    height: 65px;
    line-height: 1.5;
  }
  .table-type02 table td {
    width: 60%;
    padding: 5px;
    vertical-align: middle;
    text-align: right;
    background: #FFF;
    font-size: 1.7rem;
  }
  .table-type02 .timetable-caption {
    caption-side: top;
    padding: 15px 0;
    font-size: 1.7rem;
    border-top: 1px solid #595959;
    border-left: 1px solid #595959;
    border-right: 1px solid #595959;
    font-weight: 600;
    text-align: center;
    background: #CCC;
  }
}

/*pc用は通常テーブル----------------------------------------------------------------------------------------------------------================================================================---*/
/*@media (min-width: 768px) {*/
  .table-type02_i {
    overflow: inherit;
    white-space: normal;
    margin-bottom: 30px;
    /*キャプション*/
  }
  .table-type02_i table, .table-type02_i td, .table-type02_i th {
    border: 1px solid #CCC;
    border-collapse: collapse;
  }
  .table-type02_i table {
    width: 100%;
    box-sizing: border-box;
    font-size: 1.7rem;
    margin: 0 0 30px 0;
  }
  .table-type02_i table th {
    font-size: 1.7rem;
    background: #FFFFF5;
    border: #CCC 1px solid;
    padding: 10px 5px;
    width: 40%;
    vertical-align: middle;
    font-weight: 400;
    height: 65px;
    line-height: 1.5;
  }
  .table-type02_i table td {
    width: 60%;
    padding: 5px;
    vertical-align: middle;
    text-align: right;
    background: #FFF;
    font-size: 1.7rem;
  }
  .table-type02_i .timetable-caption {
    caption-side: top;
    padding: 15px 0;
    font-size: 1.7rem;
    border-top: 1px solid #595959;
    border-left: 1px solid #595959;
    border-right: 1px solid #595959;
    font-weight: 600;
    text-align: center;
    background: #CCC;
  }
  .table-type02_i table th.price_head {
    background: #feeacf;
  }
/*}*/

/*スマホ用=============================================================================================================================================================*/
@media (max-width: 768px) {
  .table-type02_i table {
    font-size: 1.4rem;
  }
  .table-type02_i table th {
    font-size: 1.4rem;
  }
  .table-type02_i table td {
    font-size: 1.4rem;
  }
  .table-type02_i .timetable-caption {
    font-size: 1.4rem;
  }
}


/*タイプ3*/
@media (max-width: 768px) {
  .table-type03 {
    overflow: auto;
    margin-bottom: 30px;
  }
  .table-type03 table, .table-type03 td, .table-type03 th {
    display: block;
    border: 1px solid #ccc;
  }
  .table-type03 table {
    width: 100%;
    box-sizing: border-box;
    font-size: 1.5rem;
    margin: 0 0 30px 0;
    border: none;
    display: inline-table;
    border-bottom: 1px solid #595959;
    /*キャプション*/
  }
  .table-type03 table tr {
    display: block;
  }
  .table-type03 table tr:first-child {
    margin-bottom: 0;
  }
  .table-type03 table th {
    font-size: 1.5rem;
    font-weight: 400;
    background: #eee;
    padding: 8px 0;
    width: 100%;
    vertical-align: middle;
    border-bottom: none;
  }
  .table-type03 table thead {
    display: none;
  }
  .table-type03 table th, .table-type03 table td {
    display: list-item;
    list-style-type: none;
    border: none;
    padding: 10px 0;
    line-height: 1.5;
  }
  .table-type03 table th {
    border-right: 1px solid #595959;
    border-left: 1px solid #595959;
    border-top: 1px solid #595959;
  }
  .table-type03 table td {
    width: 100%;
    padding: 15px 0;
    text-align: center;
    border-top: 1px solid #595959;
    border-right: 1px solid #595959;
    border-left: 1px solid #595959;
    background: #FFF;
  }
  .table-type03 table .timetable-caption {
    caption-side: top;
    padding: 5px 0;
    font-size: 1.5rem;
    border-top: 1px solid #595959;
    border-left: 1px solid #595959;
    border-right: 1px solid #595959;
    text-align: center;
    background: #CCC;
  }

  /****テキスト SP時****/
  .table-type03 tbody td:nth-of-type(1):before {
    content: '『標準的接種期間』';
    margin-right: 20px;
    display: block;
  }

  .table-type03 tbody td:nth-of-type(2):before {
    content: '『接種回数』';
    margin-right: 20px;
    display: block;
  }

  .table-type03 tbody td:nth-of-type(3):before {
    content: '『接種費用』';
    margin-right: 20px;
    display: block;
  }
}
/*pc用は通常テーブル*/
@media (min-width: 768px) {
  .table-type03 {
    overflow: inherit;
    white-space: normal;
    margin: 15px 0 30px 0;
    /*キャプション*/
  }
  .table-type03 table, .table-type03 td, .table-type03 th {
    border: 1px solid #595959;
    border-collapse: collapse;
  }
  .table-type03 table {
    width: 100%;
    margin-bottom: 10px;
    border-collapse: collapse;
    font-size: 1.6rem;
  }
  .table-type03 table td {
    background: #FFF;
  }
  .table-type03 table thead th {
    background: #eee;
    font-size: 1.6rem;
  }
  .table-type03 table .trTh {
    background: #eee;
    width: 40%;
    height: 65px;
    font-size: 1.6rem;
  }
  .table-type03 table td, .table-type03 table th {
    font-weight: normal;
    padding: 20px 5px;
    text-align: center;
    border: 1px solid #595959;
    line-height: 1.5;
    vertical-align: middle;
  }
  .table-type03 .timetable-caption {
    caption-side: top;
    padding: 15px 0;
    font-size: 1.6rem;
    border-top: 1px solid #595959;
    border-left: 1px solid #595959;
    border-right: 1px solid #595959;
    font-weight: 600;
    text-align: center;
    background: #CCC;
  }
}
/* ----------------------------------------------------------------------------------
共通　_common.scss
---------------------------------------------------------------------------------- */
/* body 　*/
/* フォント 　*/
/* webフォント 　*/
/* ノーマル 　*/
/* レイアウト　*/
/* section　スペース　*/
/* キーヴィジュアル　*/
/* プルダウン(診療内容)*/
/*:::::::::::::::::::::::::::::::::::::::::::::::

body

:::::::::::::::::::::::::::::::::::::::::::::::*/
@media screen and (min-width: 768px) {
  body {
    min-width: 1150px;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

フォント

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*:::::::::::::::::::::::::::::::::::::::::::::::

webフォント 

:::::::::::::::::::::::::::::::::::::::::::::::*/
@font-face {
  font-family: 'fontello';
  src: url("fnt/font/fontello.eot?1131762");
  src: url("fnt/font/fontello.eot?1131762#iefix") format("embedded-opentype"), url("fnt/font/fontello.woff?1131762") format("woff"), url("fnt/font/fontello.ttf?1131762") format("truetype"), url("fnt/font/fontello.svg?1131762#fontello") format("svg");
  font-weight: normal;
  font-style: normal;
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

ノーマル

:::::::::::::::::::::::::::::::::::::::::::::::*/
h1, h2, h3, h4, h5, h6 {
  line-height: 1.5;
}

p {
  font-size: 1.4rem;
  margin-bottom: 1em;
  line-height: 1.5;
}

@media (min-width: 768px) {
  p {
    font-size: 1.8rem;
  }
}
ul li, ol li {
  font-size: 1.4rem;
  margin-bottom: 0.8em;
}

@media (min-width: 768px) {
  ul li, ol li {
    font-size: 1.8rem;
    margin-bottom: 1em;
    line-height: 1.5;
  }
}
dl dt {
  font-size: 1.5rem;
  margin-bottom: 0.5em;
  line-height: 1.5;
}
dl dd {
  font-size: 1.4rem;
  margin-bottom: 1em;
  line-height: 1.5;
}

@media (min-width: 768px) {
  dl dt {
    font-size: 1.9rem;
  }
  dl dd {
    font-size: 1.8rem;
  }
}
.logo a:hover img {
  opacity: 0.9;
  -moz-opacity: 0.9;
  -khtml-opacity: 0.9;
  filter: alpha(opacity=90);
}

a:hover, a:active, .current {
  text-decoration: none;
}

a:focus {
  text-decoration: none;
}

a:hover {
  text-decoration: none;
}

a:hover img {
  opacity: 0.7;
  -moz-opacity: 0.7;
  -khtml-opacity: 0.7;
  filter: alpha(opacity=70);
}

img {
  width: 100%;
  height: auto;
  vertical-align: bottom;
}

figcaption {
  font-size: 1.5rem;
  text-align: center;
  line-height: 1.5;
  margin: 10px 0;
}
figcaption span {
  font-size: 1.4rem;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

レイアウト(base)

:::::::::::::::::::::::::::::::::::::::::::::::*/
.contents {
  width: 100%;
  padding-bottom: 2rem;
}

@media (min-width: 768px) {
  .contents {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: center;
    -webkit-justify-content: center;
    justify-content: center;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    margin-bottom: 0rem;
  }
}
main {
  flex-basis: 100%;
  max-width: 100%;
  padding: 2.0rem 15px 0;
}

@media (min-width: 768px) {
  main {
    flex-basis: 800px;
    max-width: 800px;
    margin: 0 0 0 32px;
    padding: 0;
  }
}
aside {
  flex-basis: 100%;
  max-width: 100%;
}

@media (min-width: 768px) {
  aside {
    flex-basis: 250px;
    max-width: 250px;
    padding: 0;
  }
}
/*※ブロックにてcontainer幅変更あり*/
.container {
  width: 100%;
  margin: 0 auto;
}

@media (min-width: 768px) {
  .container {
    max-width: 100%;
    width: 1100px;
    margin: 0 auto;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

section　スペース

:::::::::::::::::::::::::::::::::::::::::::::::*/
main > section ~ section {
  margin-top: 4.0rem;
}
main > section ~ section > section ~ section {
  margin-top: 4.0rem;
}
main > section ~ section > section ~ section > section ~ section {
  margin-top: 2.0rem;
}

/*使ってる*/
@media (min-width: 768px) {
  main > section ~ section {
    margin-top: 6.0rem;
  }
  main > section ~ section > section ~ section {
    margin-top: 5.0rem;
  }
  main > section ~ section > section ~ section > section ~ section {
    margin-top: 2.0rem;
  }
}
section section {
  margin-top: 3.0rem;
}
section section section {
  margin-top: 2.0rem;
}

@media (min-width: 768px) {
  section section {
    margin-top: 5.0rem;
  }
  section section section {
    margin-top: 3.0rem;
  }
}
.tit-type02 + section, .tit-type02 + p + section, .tit-type03 + section {
  margin-top: 2.0rem;
}

/*:::::::::::::::::::::::::::::::::::::::::::::::

visual

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*top*/
@media (min-width: 768px) {
  .keyBox {
    flex-basis: 100%;
    margin-bottom: 5.0rem;
  }
  .keyBox .container {
    position: relative;
    top: -40.5rem;
  }
}
/* キービジュアルスライダー -------------------------------------- */
#keyvsl {
  max-width: 100%;
  height: 100%;
  position: relative;
}
#keyvsl ul .chiryou {
  background: url(../images/keyv_bg_01_sp.jpg) no-repeat center top/cover;
}
#keyvsl ul .chiiki {
  background: url(../images/keyv_bg_02_sp.jpg) no-repeat center top/cover;
}
#keyvsl ul .riyuu {
  background: url(../images/keyv_bg_03_sp.jpg) no-repeat center top/cover;
}

@media screen and (min-width: 768px) {
  #keyvsl {
    padding: 0;
    width: 100%;
    margin: auto;
    display: block;
  }
  #keyvsl ul li span {
    width: 1100px;
    margin: auto;
    display: block;
  }
  #keyvsl ul li span img {
    width: 710px;
    margin: 0 0 0 auto;
    display: block;
  }
  #keyvsl ul .chiryou {
    background: url(../images/keyv_bg01.jpg) no-repeat center top/cover;
  }
  #keyvsl ul .chiiki {
    background: url(../images/keyv_bg2.jpg) no-repeat center top/cover;
  }
  #keyvsl ul .riyuu {
    background: url(../images/keyv_bg3.jpg) no-repeat center top/cover;
  }
}
/*#keyvsl {
  max-width: 100%;
  width: 100%;
  margin: 0 0 0 auto;
}
@media screen and (min-width: 768px) {
  #keyvsl {
    width: 1100px;
    margin: auto;
    display: block;
    img {
      width: 710px;
      margin: 0 0 0 auto;
      display: block;
    }
  } 
}*/
/*#keyvsl li.chiryou {
  background: url(../images/keyv_bg_01_sp.jpg) no-repeat center top/cover;
}
#keyvsl li.chiiki {
  background: url(../images/keyv_bg_02_sp.jpg) no-repeat center top/cover;
}
#keyvsl li.riyuu {
  background: url(../images/keyv_bg_03_sp.jpg) no-repeat center top/cover;
}*/
/*@media screen and (min-width: 768px) {
  #keyvsl li.chiryou {
    background: url(../images/keyv_bg01.jpg) no-repeat center top/ cover;
    //display: flex;
    //display: -webkit-flex;
    span {
      width: 1100px;
      margin: auto;
      background: url(../images/keyv_bg01.jpg) no-repeat center top/ cover;
      img {
        width: 710px;
        margin: 0 0 0 auto;
        display: block;
      }
    }
  }
  #keyvsl li.chiiki {
    background: url(../images/keyv_bg2.jpg) no-repeat center top/cover;
  }
  #keyvsl li.riyuu {
    background: url(../images/keyv_bg3.jpg) no-repeat center top/cover;
  }
}*/
/****新規開院　コピー****/
.infoBox {
  margin: 10px auto;
  text-align: center;
}
.infoBox img {
  margin: 10px auto;
  width: 70%;
}
.infoBox .open {
  border-style: solid;
  border-width: 2px;
  border-color: white;
  background-color: rgba(63, 191, 240, 0.302);
  box-shadow: 0px 0px 4.8px 1.2px rgba(67, 67, 67, 0.24);
  padding: 1.5rem 0;
  text-align: center;
  margin: 2.5rem 0 1.5rem;
}
.infoBox .open img {
  width: 22.5rem;
}
.infoBox .copy {
  background-color: rgba(255, 220, 236, 0.8);
  box-shadow: 0px 0px 4.8px 1.2px rgba(67, 67, 67, 0.24);
  padding: 3px;
}
.infoBox .copy span {
  padding: 1.3rem;
  border: 1px solid #FFF;
  display: block;
}
.infoBox ul {
  margin: 0 40px;
}

@media screen and (min-width: 768px) {
  .infoBox {
    padding: 0;
    position: absolute;
    right: 0;
    top: 0;
    z-index: 99;
    width: 380px;
  }
  .infoBox .open {
    padding: 4.0rem 3.0rem;
    margin: 0rem 0 2.5rem;
  }
  .infoBox .open img {
    width: 30rem;
  }
  .infoBox .copy {
    font-size: 1.7rem;
    line-height: 1.7;
  }
  .infoBox .copy span {
    padding: 2.2rem;
  }
}
/****下層ページ****/
#page .keyBox {
  height: 8rem;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -moz-justify-content: center;
  -webkit-justify-content: center;
  justify-content: center;
  -moz-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}

/*画像*/
@media (min-width: 768px) {
  #page .keyBox {
    height: 130px;
    width: 1100px;
    margin: 0 auto 5.0rem;
    position: relative;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

プルダウン/SPのみアコーディオン（診療内容）

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*@media (max-width: 768px) {
.treatment ul {
	list-style: none;
	margin:0;
}
label{
	cursor: pointer;
	display: block;
}
.toggle{
	display: none;
}
.toggle + label + ul{
	max-height: 0;
	overflow: hidden;
	transition: all .5s ease-out;
}
.toggle:checked + label + ul{
	max-height: 999px;
	transition: all 2s ease-in;
}
}

@media (min-width: 768px) {
	
	label{
	display: none !important;
}
	
	.toggle{
		display: none;
	}
}*/
/* ----------------------------------------------------------------------------------
_header.scss
---------------------------------------------------------------------------------- */
/* --------------------------
スマホ
---------------------------- */
/*visual*/
header {
  margin-bottom: 10px;
}
header .headTxt {
  background: #e78eb6;
}
header .headTxt span {
  color: #FFF;
  text-align: center;
  padding: 5px 0;
  font-size: 1.0rem;
  display: block;
  line-height: 1.3;
}
header .headGroup {
  padding: 5px 1.5rem 0;
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -moz-justify-content: space-between;
  -webkit-justify-content: space-between;
  justify-content: space-between;
  -moz-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
}
header .logo {
  width: 24rem;
  margin-bottom: 1.5rem;
}
header .logo a {
  display: -webkit-box;
  display: -moz-box;
  display: -ms-flexbox;
  display: -webkit-flex;
  display: flex;
  -moz-flex-wrap: wrap;
  -webkit-flex-wrap: wrap;
  flex-wrap: wrap;
  align-items: center;
}
header .logo .symbol {
  flex-basis: 5.0rem;
}
header .logo .clinic_name {
  flex-basis: calc(100% - 6rem);
  margin-left: 10px;
}
header .headInfo {
  flex-basis: 20rem;
  margin: 0 auto;
}

@media screen and (max-width: 47.938em) {
  /* SP */
  header .headInfo {
    flex-basis: 100%;
    text-align: center;
  }
  header .headInfo img {
    width: 60%;
    height: auto;
  }
  header .headInfo .timeTable {
    width: 100%;
    font-size: 1.4rem;
    margin: 1.0rem 0;
  }
  header .headInfo .timeTable .sp_none {
    display: none !important;
  }
  header .headInfo .timeTable tr:nth-child(3) {
    display: none;
  }
  header .headInfo .timeTable td {
    text-align: right;
    font-weight: bold;
    padding: .2rem 0;
  }
}
header .headInfo .timeTable tr:nth-child(2) {
  color: #e78eb6;
}

/* ------------------------
pc
---------------------------*/
@media (min-width: 768px) {
  header {
    margin-bottom: 0;
    padding: 0;
  }
  header .headTxt span {
    margin-bottom: 1.5rem;
    font-size: 1.2rem;
  }
  header .headTxt span br {
    display: none;
  }
  header .headGroup {
    padding: 0;
  }
  header .logo {
    width: 65rem;
    margin-bottom: 2.5rem;
  }
  header .logo a {
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    align-items: center;
  }
  header .logo .symbol {
    flex-basis: 12rem;
    margin-right: 5rem;
    order: 2;
  }
  header .logo .clinic_name {
    flex-basis: 39rem;
    margin-left: 10px;
    order: 1;
  }
  header .headInfo {
    margin: 0;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: flex-end;
    -webkit-justify-content: flex-end;
    justify-content: flex-end;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    flex-basis: 37rem;
  }
  header .headInfo .tel {
    flex-basis: 32rem;
  }
  header .headInfo .addressTxt {
    font-size: 1.4rem;
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
  }
  header .headInfo .addressTxt dt {
    flex-basis: 6em;
    margin-bottom: 5px;
    font-size: 1.5rem;
  }
  header .headInfo .addressTxt dd {
    flex-basis: calc(100% - 7em);
    margin-bottom: 5px;
    font-size: 1.5rem;
    text-align: right;
  }
  header .headInfo .timeTable {
    width: 100%;
    text-align: right;
    font-size: 1.6rem;
  }
  header .headInfo .timeTable th {
    font-weight: normal;
    width: 25%;
  }
  header .headInfo .timeTable td {
    width: 20%;
  }
  header .headInfo .timeTable td:last-child {
    width: 50%;
  }
}
/* ----------------------------------------------------------------------------------
_nav.scss
---------------------------------------------------------------------------------- */
/* --------------------------
スマホ
---------------------------- */
nav {
  display: none;
}

.slicknav_nav .nav-bnr {
  border-bottom: none !important;
  text-align: center;
  padding: 0 0 0 0;
  margin-bottom: 15px;
}
.slicknav_nav .nav-bnr a {
  background: #FFF;
  display: inline-block;
  padding: 0;
}

/****slicknav****/
.slicknav_nav {
  background: #FFF;
}

.slicknav_nav a {
  padding: 15px 10px;
  font-size: 1.5rem;
  color: #212121;
}
.slicknav_nav a:hover {
  color: #212121;
}

/****診療内容関連****/
@media (max-width: 768px) {
  .sub_ippan a {
    background: #ffffeb;
    color: #d69d22;
    border-top: 1px solid #cccccc;
  }

  .sub_shoni a {
    background: #f0f6e6;
    color: #729920;
  }

  .sub_arerug a {
    background: #fdf6ed;
    color: #e69230;
  }

  .sub_biyou a {
    background: #fff1f7;
    color: #e78eb6;
  }
}
/* サイドバー　診療内容 -------------------------------------- */
/*.treatment {
margin-bottom: 30px;
text-align: center;}

.toggle:checked + label::before {
    content: "▲";
}

.treatment ul{
@include flex;
@include SetPrefix(justify-content, space-between);
@include SetPrefix(flex-wrap, wrap);

}

.treatment  ul li {
width: 49.83%;
font-size: 1.4rem;
margin-bottom: 1px;
background: $clr_base1;
letter-spacing: -0.05em;
padding: 10px 5px;

a{
  color: #FFF;
}
}*/
/* ------------------------
pc
---------------------------*/
@media (min-width: 768px) {
  nav {
    display: block;
  }
  nav #menu {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
  }
  nav #menu li {
    text-align: center;
  }
  nav #menu li a {
    font-size: 1.8rem;
    display: inline-block;
    padding: 0 1em;
    color: #212121;
    position: relative;
    line-height: 1.5;
    border-bottom: 5px solid #fff;
  }
  nav #menu li a:hover {
    color: #e78eb6;
    border-bottom: 2px solid #e78eb6;
  }
  nav #menu li a::before {
    content: "\f105";
    font-family: 'fontello';
    position: relative;
    left: 0;
    color: #FFF;
    width: 100%;
    height: 2px;
  }
  nav #menu li a:hover::before {
    content: "\f105";
    font-family: 'fontello';
    position: relative;
    left: 0;
    color: #e78eb6;
  }

  /*8個目以降　非表示*/
  nav #menu li:nth-child(n + 8) {
    display: none;
  }

  .slicknav_btn {
    display: none;
  }
}
/*-----------------------------------------

mスマホ

----------------------------------------------*/
aside.subnav {
  /****sp　サイドバー消えて　nav.scssのspに記載****/
  display: none;
}

/*-----------------------------------------

pc

----------------------------------------------*/
@media (min-width: 768px) {
  aside.subnav {
    display: block;
    /****サイドバーのタイトル****/
  }
  aside.subnav .treatment ul {
    margin-bottom: 5.0rem;
  }
  aside.subnav .treatment ul li {
    margin-bottom: 0;
    margin-bottom: 1.7rem;
    /****サイドのメニュー画像****/
  }
  aside.subnav .treatment ul li a {
    text-indent: 120%;
    white-space: nowrap;
    overflow: hidden;
    display: block;
    height: 13rem;
  }
  aside.subnav .treatment ul li a:hover {
    opacity: 0.5;
  }
  aside.subnav .treatment ul li:nth-of-type(1) a {
    background: url(../images/aside_dermatology.png) no-repeat;
  }
  aside.subnav .treatment ul li:nth-of-type(2) a {
    background: url(../images/aside_pediatric.png) no-repeat;
  }
  aside.subnav .treatment ul li:nth-of-type(3) a {
    background: url(../images/aside_allergy.png) no-repeat;
  }
  aside.subnav .treatment ul li:nth-of-type(4) a {
    background: url(../images/aside_cosmetic.png) no-repeat;
  }
  aside.subnav .tit-side {
    font-size: 2.0rem;
    padding: 0 0 15px;
    text-align: center;
    position: relative;
    margin-bottom: 2.5rem;
  }
  aside.subnav .tit-side::after {
    position: absolute;
    content: "";
    background: url(../images/asid_tit_treatment.jpg) no-repeat center center;
    width: 250px;
    height: 33px;
    left: 0;
    right: 0;
    margin: 0 auto;
    top: 1rem;
    background-size: 100% 100%;
    z-index: -9;
  }
  aside.subnav .treatment dl dt {
    background: #ece9de;
    color: #70653c;
    font-size: 1.6rem;
    padding: 7px 10px;
  }
  aside.subnav .treatment dl dd {
    line-height: 1.5;
    font-size: 1.5rem;
    padding-left: 20px;
    position: relative;
    margin-bottom: 15px;
    text-indent: -0.5em;
  }
  aside.subnav .treatment dl dd::before {
    content: '';
    display: inline-block;
    width: 0.8rem;
    height: 0.8rem;
    border-radius: 50%;
    background: #212121;
    left: -10px;
    margin-top: 4px;
    position: relative;
  }
  aside.subnav .treatment dl dd a {
    color: #212121;
  }
  aside.subnav .treatment dl dd a:hover {
    color: #1b83a6;
  }
}
/* ----------------------------------------------------------------------------------
_main.scss
---------------------------------------------------------------------------------- */
/*-----------------------------------------

ご挨拶

----------------------------------------------*/
.greeting_Box .name {
  text-align: right;
}
.greeting_Box .name span {
  display: block;
  font-size: 1.2rem;
}
.greeting_Box .name img {
  width: 14rem;
}

@media (min-width: 768px) {
  .greeting_Box p {
    font-size: 1.8rem;
  }
  .greeting_Box .name span {
    font-size: 1.5rem;
  }
  .greeting_Box .name img {
    width: 18rem;
  }
}
/****当院の強み****/
.concept {
  /****光線治療****/
  /****Qスイッチアレキサンドライトレーザー****/
}
.concept li {
  padding: 1.5rem;
  background: #f5f5f5;
  margin-bottom: 1.5rem;
}
.concept li img {
  margin-bottom: 1.5rem;
}
.concept li dl dt {
  color: #729920;
  font-size: 1.7rem;
  margin-bottom: .5rem;
  line-height: 1.2;
}
.concept li dl dd {
  font-size: 1.4rem;
  margin-bottom: 0;
}
.concept .bnr {
  background: url(../images/index_kousen_bg.png) no-repeat bottom center;
  background-size: 100% 100%;
  padding: 1.3rem;
}
.concept .bnr dt {
  color: #e78eb6;
  font-size: 1.7rem;
  margin-bottom: 3px;
  line-height: 1.2;
  font-weight: 500;
}
.concept .bnr dt span {
  background: #f594c0;	
  color: #FFFFFF;	
  font-size: 1rem;	
  vertical-align: middle;	
  margin-left: 1rem;	
  padding-left: 0.8rem;	
  padding-right: 0.8rem;	
  padding-bottom: 0.2rem;	
  letter-spacing: 0.2rem;
}
.concept .bnr dd {
  font-size: 1.4rem;
  margin-bottom: 0;
  color: #212121;
  line-height: 1.2;
}
.concept .bnr span {
  font-size: 1.4rem;
}
.concept .bnr2 {
  background: url(../images/index_qswitch_bg.png) no-repeat bottom center;
  background-size: 100% 100%;
  padding: 0.8rem 1.3rem;
}
.concept .bnr2 dt {
  color: #1b83a6;
  font-size: 1.7rem;
  margin-bottom: 3px;
  line-height: 1.3;
  font-weight: 500;
}
.concept .bnr2 dd {
  font-size: 1.3rem;
  margin-bottom: 0;
  color: #212121;
  line-height: 1.3;
}

.concept a:hover dl {
  opacity: 0.8;
}

@media (min-width: 768px) {
  /****当院の強み****/
  .concept {
    /****光線治療****/
    /****Qスイッチアレキサンドライトレーザー****/
  }
  .concept ul {
    display: -webkit-box;
    display: -moz-box;
    display: -ms-flexbox;
    display: -webkit-flex;
    display: flex;
    -moz-justify-content: space-between;
    -webkit-justify-content: space-between;
    justify-content: space-between;
    -moz-flex-wrap: wrap;
    -webkit-flex-wrap: wrap;
    flex-wrap: wrap;
    width: 100%;
  }
  .concept ul li {
    margin-bottom: 2.0rem;
    width: 48.8%;
  }
  .concept ul li dl dt {
    font-size: 2.2rem;
    line-height: 1.2;
  }
  .concept ul li dl dd {
    font-size: 1.5rem;
    margin-bottom: 0;
  }
  .concept .bnr {
    padding: 3.0rem;
  }
  .concept .bnr dt {
    font-size: 3.4rem;
    margin-bottom: 1.0rem;
    font-weight: 600;
  }
  .concept .bnr dd {
    font-size: 2.0rem;
    margin-bottom: 0;
    width: 36rem;
    line-height: 1.2;
  }
  .concept .bnr span {
    font-size: 2.8rem;
  }
  .concept .bnr dt span {
    font-size: 1.6rem;	
  }
  .concept .bnr2 {
    padding: 2.0rem 3.0rem;
  }
  .concept .bnr2 dt {
    font-size: 3.4rem;
    margin-bottom: 1.0rem;
    font-weight: 600;
  }
  .concept .bnr2 dd {
    font-size: 2.0rem;
    margin-bottom: 0;
    width: 36rem;
    line-height: 1.2;
  }
}
/*:::::::::::::::::::::::::::::::::::::::::::::::

下層

:::::::::::::::::::::::::::::::::::::::::::::::*/
/*-----------------------------------------

アクセス

----------------------------------------------*/
.access_box {
  /*診療時間*/
}
.access_box .gmap {
  position: relative;
  height: 0;
  margin-bottom: .6rem;
  padding-bottom: 75%;
  overflow: hidden;
  width: 100%;
}
.access_box .gmap iframe {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  border: 0;
}
.access_box .tel {
  font-size: 2.0rem;
  font-weight: 600;
}
.access_box .tel a {
  font-size: 2.0rem;
  color: #212121;
}
.access_box .timeBox .timetable tr th {
  font-size: 1.8rem;
}
.access_box .timeBox .timetable tr td {
  background: #FFF;
  font-size: 1.8rem;
}

@media (max-width: 768px) {
  .access_box {
    /*診療時間*/
  }
  .access_box caption {
    font-size: 1.2rem;
  }
  .access_box .timeBox .timetable tr th {
    font-size: 1.3rem;
  }
  .access_box .timeBox .timetable tr td {
    font-size: 1.4rem;
  }
}
/*-----------------------------------------

料金表

----------------------------------------------*/
.price_list {
  list-style-type: none;
  width: 100%;
  display: flex;
  flex-wrap: wrap;
}
.price_list li {
  flex-basis: 48%;
  max-width: 48%;
  position: relative;
  background: #fff2f7;
  border: #f1c4d5 2px solid;
  box-sizing: border-box;
  font-size: 1.4rem;
  text-align: center;
  margin-right: 1rem;
  margin-bottom: 1rem;
  border-radius: 5px;
  box-shadow: 0 2px 4px rgba(0, 0, 0, 0.3);
  transition: .5s;
  /*background-color: #53b9da;
  background-image: url(../images/price_top_right.png), url(../images/price_bottom_left.png);
  background-repeat: no-repeat, no-repeat;
  background-position: right 2px top 2px ,left 2px bottom 2px;*/
}
.price_list li a {
  color: #515151;
  text-decoration: none;
  display: block;
  width: 100%;
  padding: 1.0rem 0 1.2rem;
}
.price_list li:hover {
  box-shadow: 0 0 2px rgba(0, 0, 0, 0.2);
  /*  box-shadow: 3px 3px #e68eb6;*/
}
.price_list li:nth-child(2n) {
  margin-right: 0;
}

@media screen and (min-width: 768px) {
  .price_list li {
    margin-right: 2.5rem;
    margin-bottom: 2.5rem;
    flex-basis: 31%;
    max-width: 31%;
    font-size: 1.8rem;
  }
  .price_list li a {
    padding: 2.2rem 0;
  }
  .price_list li a:before {
    position: absolute;
    top: 0;
    bottom: 0;
    right: 1.0rem;
    margin: auto;
    content: "";
    vertical-align: middle;
    box-sizing: border-box;
    width: 1.6rem;
    height: 1.6rem;
    border: 2px solid #f1c4d5;
    -webkit-border-radius: 50%;
    border-radius: 50%;
  }
  .price_list li a:after {
    /*color: #1c93ba;
    content: "▼";
    font-size: 1.0rem !important;
    position: absolute;
    left: 47%;
    top: 72%;*/
    position: absolute;
    top: 0;
    bottom: 0;
    right: 1.6rem;
    margin: auto;
    content: "";
    vertical-align: middle;
    width: 0.6rem;
    height: 0.6rem;
    border-top: 2px solid #f1c4d5;
    border-right: 2px solid #f1c4d5;
    -webkit-transform: rotate(45deg);
    transform: rotate(45deg);
  }
  .price_list li:hover {
    opacity: 0.6;
  }
  .price_list li:nth-child(2n) {
    margin-right: 2.5rem;
  }
  .price_list li:nth-child(3n) {
    margin-right: 0;
  }
}
/* ----------------------------------------------------------------------------------
_foooter.scss
---------------------------------------------------------------------------------- */
/* --------------------------
スマホ
---------------------------- */
footer {
  position: relative;
  background: #e9f3f9;
  margin-bottom: 105px;
}

.footerMenu {
  display: none;
}

.copyright {
  font-size: 12px;
  text-align: center;
  padding: 15px 0;
  margin-bottom: 60px;
  color: #1b83a6;
  display: block;
}

/* ------------------------
pc
---------------------------*/
@media (min-width: 768px) {
  .footerMenu {
    display: block;
    padding: 40px 0;
    text-align: center;
  }
  .footerMenu ul li {
    display: inline-block;
    margin-bottom: 10px;
    margin-right: 8px;
  }
  .footerMenu ul li a {
    font-size: 1.4rem;
    padding: 5px 5px 5px 15px;
    color: #212121;
    position: relative;
  }
  .footerMenu ul li a span {
    display: none;
  }

  .copyright {
    margin-bottom: 0;
  }
}

/*症状*/
.sjy {
  border-bottom: 2px solid #4ec4d3;
  border-top: 2px solid #4ec4d3;
  border-left: 2px solid #4ec4d3;
  border-right: 2px solid #4ec4d3;
  display: -webkit-box;
  display: -ms-flexbox;
  display: flex;
  -ms-flex-wrap: wrap;
      flex-wrap: wrap;
}
.kym, .iai, .oko, .utr {
  width: 25%;
  border-bottom: 2px solid rgb(180, 222, 239);
}
.kym, .iai, .oko, .dkm, .zys {
  border-right: 2px solid rgb(180, 222, 239);
}
.dkm, .zys, .snt {
  width: 33.333333%;
}
.sjy ul li, ol li, dl dt, dl dd {
    margin-bottom: 0;
    line-height: 1;
}
.sjy dt, .sjy dd a {
  font-size: 1.7rem;
}
.sjy dd a {
  display: block;
  padding-bottom: 3px;
  padding-top: 3px;
  font-size: 14px;
  color: #212121;
}
.sjy dd a:hover {
  text-decoration: underline;
  color: #1d7da4;
}
.sjy dt {
  background-color: #e9f3f9;
  font-size: 18px;
	font-weight: 400;
  color: #1b83a6;
  text-align: center;
  padding: 1.7rem 0;
}
.sjy dd {
  padding-left: 15px;
  padding-top: 15px;
  padding-bottom: 15px;
}
.sjy ul li {
  position: relative;
  font-size: .7rem;
  padding-left: 1.5rem;
}
.sjy ul li::before {
  content: '';
  position: absolute;
  top: .5rem;
  left: 0rem;
  width: 9px;
  height: 6px;
  border-top: 5px solid transparent;
  border-bottom: 5px solid transparent;
  border-left: 8px solid #1d7da4;
}
.annotation {
	font-size: 1.7rem;
}
@media (max-width: 767px) {
  .kym, .iai, .oko, .utr, .dkm, .zys, .snt {
    width: 50%;
  }
  .iai, .zys {
    border-right: none;
  }
  .dkm, .zys {
    border-bottom: 2px solid rgb(180, 222, 239);
  }
  .sjy dt, .sjy dd a {
    font-size: 1.2rem;
  }
  .sjy ul li {
    padding-left: 1rem;
  }
  .sjy ul li::before {
    top: .6rem;
  }
  .snt {
    border-right: 2px solid rgb(180, 222, 239);
  }
	.annotation {
		font-size: 1.3rem;
	}
}

.s_list {
  list-style-type: decimal;
  padding-left: 44px;
}

.s_item ol li, dl dt, dl dd {
    margin-bottom: 0;
    line-height: 1.7;
}

.s_item {
    margin-bottom: 2rem;
}

.j_ann {
    text-indent: -5rem;
    padding-left: 5rem;
}

.bnr_qswitch {
	background: url(../images/keyv_bg_right.png) no-repeat right center/contain #f5f5f5;
}
.bnr_qswitch a {
	background: url(../images/keyv_bg_left_qswitch.png) no-repeat left center/contain;
	text-align: center;
	display: block;
	font-size: 2.2rem;
	line-height: 1.2;
    color: #303030;
	padding: 2.0rem 1rem;
}
.bnr_qswitch a span {
	position: relative;
	display: inline-block;
	font-size: 1.6rem;
	color: #1d7da4;
	padding-left: 1.5rem;
}
.bnr_qswitch a span::before {
	content: '';
    position: absolute;
    top: .5rem;
    left: 0rem;
    width: 9px;
    height: 6px;
    border-top: 5px solid transparent;
    border-bottom: 5px solid transparent;
    border-left: 8px solid #1d7da4;
}

@media (min-width: 768px) {
	.bnr_qswitch:hover {
		opacity: 0.7;
	}
}

@media (max-width: 767px) {
	.bnr_qswitch {
		background-image: none;
	}
	.bnr_qswitch a {
		background: url(../images/qswitch_01.png) no-repeat left 5% center / 16% auto;
		text-align: left;
		font-size: 1.7rem;
		padding: 2.0rem 1rem 2.0rem 24%;
	}
	.bnr_qswitch a span {
		font-size: 1.3rem;
	}
}

span.faq_q{
background: #729920;
color: #fff;
border-radius: 4px;
padding: 2px 5px;
}
span.faq_a{
color: #729920;
padding: 2px 5px;
}



.access_video iframe{
	width: 560px;
	height: 315px;
}

@media (max-width: 767px) {
	.access_video iframe{
		max-width: 100%;
}
}



.online{
  padding: 1em;
  margin-bottom: 3rem;
}

@media screen and (min-width: 768px) {
  .online{
    margin-top: 3rem;
    padding: 1em;
    margin-bottom: initial;
  }
  
  .online p{
    margin-bottom: initial;
  }
}
