@charset "UTF-8";
/*! normalize.css v1.0.2 | MIT License | git.io/normalize */
/* ==========================================================================
   HTML5 display definitions
   ========================================================================== */
/*
 * Corrects `block` display not defined in IE 6/7/8/9 and Firefox 3.
 */
article,
aside,
details,
figcaption,
figure,
footer,
header,
hgroup,
nav,
section,
summary {
  display: block; }

/*
 * Corrects `inline-block` display not defined in IE 6/7/8/9 and Firefox 3.
 */
audio,
canvas,
video {
  display: inline-block;
  *display: inline;
  *zoom: 1; }

/*
 * Prevents modern browsers from displaying `audio` without controls.
 * Remove excess height in iOS 5 devices.
 */
audio:not([controls]) {
  display: none;
  height: 0; }

/*
 * Addresses styling for `hidden` attribute not present in IE 7/8/9, Firefox 3,
 * and Safari 4.
 * Known issue: no IE 6 support.
 */
[hidden] {
  display: none; }

/* ==========================================================================
   Base
   ========================================================================== */
/*
 * 1. Corrects text resizing oddly in IE 6/7 when body `font-size` is set using
 *    `em` units.
 * 2. Prevents iOS text size adjust after orientation change, without disabling
 *    user zoom.
 */
html {
  font-size: 100%;
  /* 1 */
  -webkit-text-size-adjust: 100%;
  /* 2 */
  -ms-text-size-adjust: 100%;
  /* 2 */ }

/*
 * Addresses `font-family` inconsistency between `textarea` and other form
 * elements.
 */
/*
 * Addresses margins handled incorrectly in IE 6/7.
 */
body {
  margin: 0; }

/* ==========================================================================
   Links
   ========================================================================== */
/*
 * Addresses `outline` inconsistency between Chrome and other browsers.
 */
a:focus {
  outline: thin dotted; }

/*
 * Improves readability when focused and also mouse hovered in all browsers.
 */
a:active,
a:hover {
  outline: 0; }

/* ==========================================================================
   Typography
   ========================================================================== */
/*
 * Addresses font sizes and margins set differently in IE 6/7.
 * Addresses font sizes within `section` and `article` in Firefox 4+, Safari 5,
 * and Chrome.
 */
h1 {
  margin: 0; }

h2 {
  margin: 0; }

h3 {
  margin: 0; }

/*
 * Addresses styling not present in IE 7/8/9, Safari 5, and Chrome.
 */
abbr[title] {
  border-bottom: 1px dotted; }

/*
 * Addresses style set to `bolder` in Firefox 3+, Safari 4/5, and Chrome.
 */
b,
strong {
  font-weight: bold; }

blockquote {
  margin: 1em 40px; }

/*
 * Addresses styling not present in Safari 5 and Chrome.
 */
dfn {
  font-style: italic; }

/*
 * Addresses styling not present in IE 6/7/8/9.
 */
mark {
  background: #ff0;
  color: #000; }

/*
 * Addresses margins set differently in IE 6/7.
 */
p,
pre {
  margin: 0; }

/*
 * Corrects font family set oddly in IE 6, Safari 4/5, and Chrome.
 */
code,
kbd,
pre,
samp {
  font-family: monospace, serif;
  _font-family: 'courier new', monospace;
  font-size: 1em; }

/*
 * Improves readability of pre-formatted text in all browsers.
 */
pre {
  white-space: pre;
  white-space: pre-wrap;
  word-wrap: break-word; }

/*
 * Addresses CSS quotes not supported in IE 6/7.
 */
q {
  quotes: none; }

/*
 * Addresses `quotes` property not supported in Safari 4.
 */
q:before,
q:after {
  content: '';
  content: none; }

/*
 * Addresses inconsistent and variable font size in all browsers.
 */
small {
  font-size: 80%; }

/*
 * Prevents `sub` and `sup` affecting `line-height` in all browsers.
 */
sub,
sup {
  font-size: 75%;
  line-height: 0;
  position: relative;
  vertical-align: baseline; }

sup {
  top: -0.5em; }

sub {
  bottom: -0.25em; }

/* ==========================================================================
   Lists
   ========================================================================== */
/*
 * Addresses margins set differently in IE 6/7.
 */
dl,
menu,
ol,
ul {
  margin: 0; }

/*
 * Addresses paddings set differently in IE 6/7.
 */
menu,
ol,
ul {
  padding: 0; }

/*
 * Corrects list images handled incorrectly in IE 7.
 */
nav ul,
nav ol {
  list-style: none;
  list-style-image: none; }

/* ==========================================================================
   Embedded content
   ========================================================================== */
/*
 * 1. Removes border when inside `a` element in IE 6/7/8/9 and Firefox 3.
 * 2. Improves image quality when scaled in IE 7.
 */
img {
  border: 0;
  /* 1 */
  -ms-interpolation-mode: bicubic;
  /* 2 */ }

/*
 * Corrects overflow displayed oddly in IE 9.
 */
svg:not(:root) {
  overflow: hidden; }

/* ==========================================================================
   Figures
   ========================================================================== */
/*
 * Addresses margin not present in IE 6/7/8/9, Safari 5, and Opera 11.
 */
figure {
  margin: 0; }

/* ==========================================================================
   Forms
   ========================================================================== */
/*
 * Corrects margin displayed oddly in IE 6/7.
 */
form {
  margin: 0; }

/*
 * Define consistent border, margin, and padding.
 */
fieldset {
  border: 1px solid #c0c0c0;
  margin: 0 2px;
  padding: 0.35em 0.625em 0.75em; }

/*
 * 1. Corrects color not being inherited in IE 6/7/8/9.
 * 2. Corrects text not wrapping in Firefox 3.
 * 3. Corrects alignment displayed oddly in IE 6/7.
 */
legend {
  border: 0;
  /* 1 */
  padding: 0;
  white-space: normal;
  /* 2 */
  *margin-left: -7px;
  /* 3 */ }

/*
 * 1. Corrects font size not being inherited in all browsers.
 * 2. Addresses margins set differently in IE 6/7, Firefox 3+, Safari 5,
 *    and Chrome.
 * 3. Improves appearance and consistency in all browsers.
 */
button,
input,
select,
textarea {
  font-size: 100%;
  /* 1 */
  margin: 0;
  /* 2 */
  vertical-align: baseline;
  /* 3 */
  *vertical-align: middle;
  /* 3 */ }

/*
 * Addresses Firefox 3+ setting `line-height` on `input` using `!important` in
 * the UA stylesheet.
 */
button,
input {
  line-height: normal; }

/*
 * 1. Avoid the WebKit bug in Android 4.0.* where (2) destroys native `audio`
 *    and `video` controls.
 * 2. Corrects inability to style clickable `input` types in iOS.
 * 3. Improves usability and consistency of cursor style between image-type
 *    `input` and others.
 * 4. Removes inner spacing in IE 7 without affecting normal text inputs.
 *    Known issue: inner spacing remains in IE 6.
 */
button,
html input[type="button"],
input[type="reset"],
input[type="submit"] {
  -webkit-appearance: button;
  /* 2 */
  cursor: pointer;
  /* 3 */
  *overflow: visible;
  /* 4 */ }

/*
 * Re-set default cursor for disabled elements.
 */
button[disabled],
input[disabled] {
  cursor: default; }

/*
 * 1. Addresses box sizing set to content-box in IE 8/9.
 * 2. Removes excess padding in IE 8/9.
 * 3. Removes excess padding in IE 7.
 *    Known issue: excess padding remains in IE 6.
 */
input[type="checkbox"],
input[type="radio"] {
  box-sizing: border-box;
  /* 1 */
  padding: 0;
  /* 2 */
  *height: 13px;
  /* 3 */
  *width: 13px;
  /* 3 */ }

/*
 * 1. Addresses `appearance` set to `searchfield` in Safari 5 and Chrome.
 * 2. Addresses `box-sizing` set to `border-box` in Safari 5 and Chrome
 *    (include `-moz` to future-proof).
 */
input[type="search"] {
  -webkit-appearance: textfield;
  /* 1 */
  -moz-box-sizing: content-box;
  -webkit-box-sizing: content-box;
  /* 2 */
  box-sizing: content-box; }

/*
 * Removes inner padding and search cancel button in Safari 5 and Chrome
 * on OS X.
 */
input[type="search"]::-webkit-search-cancel-button,
input[type="search"]::-webkit-search-decoration {
  -webkit-appearance: none; }

/*
 * Removes inner padding and border in Firefox 3+.
 */
button::-moz-focus-inner,
input::-moz-focus-inner {
  border: 0;
  padding: 0; }

/*
 * 1. Removes default vertical scrollbar in IE 6/7/8/9.
 * 2. Improves readability and alignment in all browsers.
 */
textarea {
  overflow: auto;
  /* 1 */
  vertical-align: top;
  /* 2 */ }

/* ==========================================================================
   Tables
   ========================================================================== */
/*
 * Remove most spacing between table cells.
 */
table {
  border-collapse: collapse;
  border-spacing: 0; }

/* 表示・非表示切替 --------------------------------------- */
/* PCのみ表示 */
@media only screen and (max-width: 640px) {
  .onlypc {
    display: none !important; } }

/* スマートフォンのみ表示 */
.onlysp {
  display: none !important; }
  @media only screen and (max-width: 640px) {
    .onlysp {
      display: inherit !important; } }

.sp-br {
  display: none; }
  @media only screen and (max-width: 640px) {
    .sp-br {
      display: block; } }

@media only screen and (max-width: 640px) {
  .pc-br {
    display: none; } }

html {
  height: 100%; }

body {
  font-family: "游ゴシック Medium", "游ゴシック体", "Yu Gothic Medium", YuGothic, "ヒラギノ角ゴ ProN", "メイリオ", Meiryo, "Hiragino Kaku Gothic ProN", "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
  font-size: 16px; }
  @media only screen and (max-width: 640px) {
    body {
      width: auto;
      max-width: 100%;
      height: auto;
      word-wrap: break-word;
      overflow-wrap: break-word; } }
  body a {
    text-decoration: none; }
    body a img {
      display: block;
      -webkit-transition: 0.3s ease-in-out;
      -moz-transition: 0.3s ease-in-out;
      -o-transition: 0.3s ease-in-out;
      transition: 0.3s ease-in-out; }
      body a img:hover {
        opacity: 0.8;
        filter: alpha(opacity=80); }
  body a:hover img, body x:-moz-any-link {
    background: transparent; }
  body a:hover img, body x:-moz-any-link, body x:default {
    background: transparent; }
  body p {
    line-height: 1.6; }

/* -------------------------------------------------------------------------------- */
/*	ヘッダー
/* -------------------------------------------------------------------------------- */
header {
  width: 100%;
  padding-top: 20px; }
  @media only screen and (max-width: 640px) {
    header {
      padding-top: 0; } }
  header .infomation_area {
    width: 100%;
    border-bottom: 1px solid #dddddd; }
    header .infomation_area .header_inner {
      width: 960px;
      margin: 0 auto;
      min-height: 1px; }
      header .infomation_area .header_inner:after {
        content: ".";
        display: block;
        clear: both;
        height: 0;
        visibility: hidden; }
      * html header .infomation_area .header_inner {
        height: 1px;
        /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
      @media only screen and (max-width: 640px) {
        header .infomation_area .header_inner {
          width: 100%;
          height: 4em;
          border-bottom: 2px solid #003281; } }
      header .infomation_area .header_inner h1 {
        width: 328px;
        float: left; }
        @media only screen and (max-width: 640px) {
          header .infomation_area .header_inner h1 {
            width: 50%;
            padding: 15px 0 0; } }
        @media only screen and (max-width: 640px) {
          header .infomation_area .header_inner h1 a {
            display: block;
            width: 95%;
            margin: 0 auto; } }
        header .infomation_area .header_inner h1 a img {
          width: 100%; }
      header .infomation_area .header_inner .header_info_pc {
        float: right;
        width: 253px;
        color: #003281; }
        @media only screen and (max-width: 640px) {
          header .infomation_area .header_inner .header_info_pc {
            display: none; } }
        header .infomation_area .header_inner .header_info_pc .header_info_ttl {
          border-bottom: 2px solid #003281;
          min-height: 1px; }
          header .infomation_area .header_inner .header_info_pc .header_info_ttl:after {
            content: ".";
            display: block;
            clear: both;
            height: 0;
            visibility: hidden; }
          * html header .infomation_area .header_inner .header_info_pc .header_info_ttl {
            height: 1px;
            /*\*/
       /*/
  height: auto;
  overflow: hidden;
  /**/ }
          header .infomation_area .header_inner .header_info_pc .header_info_ttl span {
            font-size: 14px; }
          header .infomation_area .header_inner .header_info_pc .header_info_ttl .header_info_open {
            font-family: 'Roboto', sans-serif;
            font-size: 17px;
            float: right; }
            header .infomation_area .header_inner .header_info_pc .header_info_ttl .header_info_open:before {
              content: "\f017";
              font-family: FontAwesome;
              font-size: 18px;
              margin-right: 5px; }
        header .infomation_area .header_inner .header_info_pc .header_info_tel {
          min-height: 1px;
          padding-top: 5px;
          padding-bottom: 17px; }
          header .infomation_area .header_inner .header_info_pc .header_info_tel:after {
            content: ".";
            display: block;
            clear: both;
            height: 0;
            visibility: hidden; }
          * html header .infomation_area .header_inner .header_info_pc .header_info_tel {
            height: 1px;
            /*\*/
       /*/
  height: auto;
  overflow: hidden;
  /**/ }
          header .infomation_area .header_inner .header_info_pc .header_info_tel:before {
            display: block;
            width: 35px;
            float: left;
            content: "\f098";
            font-family: FontAwesome;
            font-size: 30px; }
          header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_shika {
            width: 215px;
            float: left;
            min-height: 1px; }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_shika:after {
              content: ".";
              display: block;
              clear: both;
              height: 0;
              visibility: hidden; }
            * html header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_shika {
              height: 1px;
              /*\*/
         /*/
    height: auto;
    overflow: hidden;
    /**/ }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_shika span {
              display: block;
              float: left;
              font-size: 16px;
              padding-top: 4px;
              margin-right: 5px; }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_shika .header_shika_tel {
              text-align: right;
              font-size: 28px;
              margin-top: -9px;
              font-family: 'Roboto', sans-serif; }
          header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon {
            width: 278px;
            float: right;
            min-height: 1px; }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon:after {
              content: ".";
              display: block;
              clear: both;
              height: 0;
              visibility: hidden; }
            * html header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon {
              height: 1px;
              /*\*/
         /*/
    height: auto;
    overflow: hidden;
    /**/ }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon .komon_ttl_area {
              float: left; }
              header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon .komon_ttl_area .free_dial_ttl {
                font-size: 14px;
                display: block;
                letter-spacing: 0em;
                margin-right: 10px; }
              header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon .komon_ttl_area .free_dial {
                display: block;
                font-size: 11px;
                margin-top: -6px;
                font-feature-settings: "palt"; }
            header .infomation_area .header_inner .header_info_pc .header_info_tel .header_info_komon .komon_tel {
              float: left;
              font-size: 28px;
              margin-top: -2px;
              font-family: 'Roboto', sans-serif; }
      header .infomation_area .header_inner .header_info_sp {
        display: none; }
        @media only screen and (max-width: 640px) {
          header .infomation_area .header_inner .header_info_sp {
            display: block;
            width: 45%;
            float: right; }
            header .infomation_area .header_inner .header_info_sp ul {
              display: table;
              width: 100%; }
              header .infomation_area .header_inner .header_info_sp ul li {
                width: 33.3%;
                height: 4em;
                display: table-cell;
                text-align: center;
                border-left: 1px solid #dddddd;
                text-align: center; }
                header .infomation_area .header_inner .header_info_sp ul li a {
                  display: block;
                  width: 100%;
                  color: #003281;
                  font-size: 10px;
                  font-weight: bold;
                  padding-top: 15px; }
              header .infomation_area .header_inner .header_info_sp ul .sp_header01 a:before {
                display: block;
                content: "\f073";
                font-family: FontAwesome;
                font-size: 24px;
                margin-bottom: 8px; }
              header .infomation_area .header_inner .header_info_sp ul .sp_header02 a:before {
                display: block;
                content: "\f207";
                font-family: FontAwesome;
                font-size: 24px;
                margin-bottom: 8px; }
              header .infomation_area .header_inner .header_info_sp ul .sp_header03 {
                position: relative; }
                header .infomation_area .header_inner .header_info_sp ul .sp_header03 a:before {
                  display: block;
                  content: "\f0c9";
                  font-family: FontAwesome;
                  font-size: 24px;
                  margin-bottom: 8px; }
                header .infomation_area .header_inner .header_info_sp ul .sp_header03 a.close {
                  position: absolute;
                  z-index: 2000 !important; }
                  header .infomation_area .header_inner .header_info_sp ul .sp_header03 a.close:before {
                    content: "\f00d";
                    font-family: FontAwesome; }
                  header .infomation_area .header_inner .header_info_sp ul .sp_header03 a.close span {
                    display: none; } }
  header nav.common_menu {
    width: 100%;
    border-bottom: 3px solid #003281;
    height: 57px;
    margin-top: 1px; }
    @media only screen and (max-width: 640px) {
      header nav.common_menu {
        float: none;
        display: none;
        width: 100%;
        height: auto;
        float: none;
        margin-top: 0;
        position: absolute;
        top: 0;
        left: 0;
        z-index: 1000;
        padding-top: 80px;
        padding-bottom: 600px;
        background-color: rgba(255, 255, 255, 0.85);
        border-bottom: none; } }
    header nav.common_menu ul {
      width: 960px;
      height: 60px;
      margin: 0 auto;
      display: table; }
      @media only screen and (max-width: 640px) {
        header nav.common_menu ul {
          display: block;
          width: 100%;
          margin: 0; } }
      header nav.common_menu ul li {
        display: table-cell;
        width: 160px;
        text-align: center;
        border-right: 1px solid #dddddd;
        border-bottom: 3px solid #003281;
        vertical-align: middle; }
        @media only screen and (max-width: 640px) {
          header nav.common_menu ul li {
            display: block;
            width: 100%;
            line-height: 4em;
            border: none; } }
        header nav.common_menu ul li:hover {
          border-bottom: 3px solid #007d4f; }
          @media only screen and (max-width: 640px) {
            header nav.common_menu ul li:hover {
              border: none; } }
        header nav.common_menu ul li:first-child {
          border-left: 1px solid #dddddd; }
          @media only screen and (max-width: 640px) {
            header nav.common_menu ul li:first-child {
              border: none; } }
        header nav.common_menu ul li a {
          display: block;
          height: 37px;
          padding-top: 10px;
          color: #000;
          font-size: 15px; }
          @media only screen and (max-width: 640px) {
            header nav.common_menu ul li a {
              position: relative;
              text-decoration: none;
              display: block;
              font-weight: bold;
              line-height: 1.8;
              padding: 0.5em 0; } }
          header nav.common_menu ul li a:hover {
            color: #007d4f; }

/* -------------------------------------------------------------------------------- */
/*	トップへ戻るボタン（SP）
/* -------------------------------------------------------------------------------- */
.go_top_btn {
  display: none; }
  @media only screen and (max-width: 640px) {
    .go_top_btn {
      display: block;
      background-color: #d9d9d9;
      text-align: center; }
      .go_top_btn a {
        display: block;
        width: 100%;
        padding: 5px 0;
        color: #fff; }
        .go_top_btn a .fa-angle-up {
          font-size: 36px; } }

/* -------------------------------------------------------------------------------- */
/*	タブ
/* -------------------------------------------------------------------------------- */
.side-tab {
  position: absolute;
  right: 0;
  top: 180px;
  z-index: 999;
  width: 58px; }
  @media only screen and (max-width: 640px) {
    .side-tab {
      width: 48px;
      top: 80px;
      padding: 0; } }
  .side-tab .yoyaku {
    background-color: #007D4F;
    border-radius: 6px 0 0 6px;
    width: 100%;
    padding: 3.5em 0 1em;
    text-align: center;
    transition: background-color 0.3s ease; }
    .side-tab .yoyaku a {
      writing-mode: vertical-rl;
      text-decoration: none;
      color: #ffffff;
      font-size: 1.2rem;
      position: relative;
      display: inline-block; }
      @media only screen and (max-width: 640px) {
        .side-tab .yoyaku a {
          padding: 0; } }
      .side-tab .yoyaku a::before {
        content: "\f15c";
        /* Unicode for FontAwesome 'fa-file-text-o' */
        font-family: "FontAwesome";
        font-size: 1.5rem;
        position: absolute;
        top: -1.5em; }
    .side-tab .yoyaku:hover {
      background-color: #fff; }
      .side-tab .yoyaku:hover a {
        color: #007D4F; }
  .side-tab .instagram {
    position: relative;
    margin-top: 6px;
    z-index: 998;
    padding: 0;
    text-align: center;
    transition: background-color 0.3s ease; }
    .side-tab .instagram a {
      display: block;
      background-color: #000;
      border-radius: 21px 0 0 21px;
      background-image: url(../img/icon/instagram_wh.png);
      background-repeat: no-repeat;
      background-size: 28px;
      background-position: center center;
      text-indent: -9999px;
      height: 42px; }
      .side-tab .instagram a:hover {
        background-color: #fff;
        background-image: url(../img/icon/instagram.png); }

/* タブ単体 未使用 */
.tab-right {
  position: absolute;
  right: 0;
  top: 180px;
  z-index: 999;
  background-color: #007D4F;
  border-radius: 6px 0 0 6px;
  padding: 3.5em 1em 1em;
  writing-mode: vertical-rl;
  text-align: center;
  transition: background-color 0.3s ease; }
  @media only screen and (max-width: 640px) {
    .tab-right {
      top: 80px;
      padding: 3.5em 0.5em 1em; } }
  .tab-right a {
    text-decoration: none;
    color: #ffffff;
    font-size: 1.2rem;
    position: relative;
    display: inline-block; }
    .tab-right a::before {
      content: "\f15c";
      /* Unicode for FontAwesome 'fa-file-text-o' */
      font-family: "FontAwesome";
      font-size: 1.5rem;
      position: absolute;
      top: -1.5em;
      /* Adjusted to avoid overlap with text */
      left: 50%;
      transform: translateX(-50%); }
  .tab-right:hover {
    background-color: #E0E0E0;
    /* Adjusted for white background */ }
    .tab-right:hover a {
      color: #007D4F; }

.tab-sns {
  position: absolute;
  right: 0;
  top: 394px;
  z-index: 998;
  background-color: #007D4F;
  border-radius: 6px 0 0 6px;
  padding: 3.5em 1em 1em;
  writing-mode: vertical-rl;
  text-align: center;
  transition: background-color 0.3s ease; }

/* -------------------------------------------------------------------------------- */
/*	フッター
/* -------------------------------------------------------------------------------- */
footer {
  width: 100%;
  background-color: #004294;
  color: #fff;
  font-size: 14px;
  padding: 60px 0 120px; }
  @media only screen and (max-width: 640px) {
    footer {
      padding: 10px 0 60px; } }
  footer a {
    color: #fff; }
  footer .footer_inner {
    width: 960px;
    margin: 0 auto;
    min-height: 1px; }
    footer .footer_inner:after {
      content: ".";
      display: block;
      clear: both;
      height: 0;
      visibility: hidden; }
    * html footer .footer_inner {
      height: 1px;
      /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
    @media only screen and (max-width: 640px) {
      footer .footer_inner {
        width: 90%; } }
    footer .footer_inner .footer_block {
      display: flex;
      justify-content: space-between;
      margin-right: 40px; }
      footer .footer_inner .footer_block .sns.sp {
        display: none; }
      footer .footer_inner .footer_block .sns.pc {
        display: block; }
      @media only screen and (max-width: 640px) {
        footer .footer_inner .footer_block {
          display: none; }
          footer .footer_inner .footer_block .sns.pc {
            display: none; }
          footer .footer_inner .footer_block .sns.sp {
            display: block;
            text-align: center; }
            footer .footer_inner .footer_block .sns.sp img {
              margin: 6px auto 20px; } }
      footer .footer_inner .footer_block:last-child {
        margin-right: 0; }
        @media only screen and (max-width: 640px) {
          footer .footer_inner .footer_block:last-child {
            display: block;
            width: 100%;
            text-align: center; } }
      @media only screen and (max-width: 640px) {
        footer .footer_inner .footer_block dl {
          display: none; } }
      footer .footer_inner .footer_block dl dt a {
        display: block;
        border-bottom: 1px solid #fff;
        padding-left: 15px;
        margin-bottom: 5px; }
      footer .footer_inner .footer_block dl dd {
        margin: 0; }
        footer .footer_inner .footer_block dl dd ul li {
          list-style: none;
          line-height: 1.8;
          padding-left: 15px; }
          footer .footer_inner .footer_block dl dd ul li a:hover {
            text-decoration: underline; }
      footer .footer_inner .footer_block a.policy {
        display: block;
        padding-left: 15px;
        margin-top: 40px; }
        footer .footer_inner .footer_block a.policy:hover {
          text-decoration: underline; }
      footer .footer_inner .footer_block .shikasyokai {
        margin-top: 35px; }
      footer .footer_inner .footer_block .footer_infomation {
        margin-top: -18px;
        padding-left: 15px; }
        @media only screen and (max-width: 640px) {
          footer .footer_inner .footer_block .footer_infomation {
            margin-top: 0; } }
        footer .footer_inner .footer_block .footer_infomation img {
          width: 190px;
          height: auto; }
        footer .footer_inner .footer_block .footer_infomation h3 {
          margin-top: 20px;
          padding-bottom: 20px; }
          footer .footer_inner .footer_block .footer_infomation h3 img {
            width: 180px;
            height: auto; }
        footer .footer_inner .footer_block .footer_infomation .shika_tel_area h4,
        footer .footer_inner .footer_block .footer_infomation .komon_tel_area h4 {
          margin: 5px 0 0;
          font-size: 16px;
          font-weight: normal; }
          footer .footer_inner .footer_block .footer_infomation .shika_tel_area h4:before,
          footer .footer_inner .footer_block .footer_infomation .komon_tel_area h4:before {
            content: "\f098";
            font-family: FontAwesome;
            font-size: 18px;
            margin-right: 5px; }
        footer .footer_inner .footer_block .footer_infomation .shika_tel_area .tel,
        footer .footer_inner .footer_block .footer_infomation .komon_tel_area .tel {
          font-family: 'Roboto', sans-serif;
          font-size: 21px;
          margin-left: 20px; }
        footer .footer_inner .footer_block .footer_infomation .komon_tel_area {
          margin-top: 20px;
          padding-bottom: 20px; }
          footer .footer_inner .footer_block .footer_infomation .komon_tel_area h4 span {
            font-size: 12px;
            padding-left: 0; }

/* 表示・非表示切替 --------------------------------------- */
/* PCのみ表示 */
@media only screen and (max-width: 640px) {
  .onlypc {
    display: none !important; } }

/* スマートフォンのみ表示 */
.onlysp {
  display: none !important; }
  @media only screen and (max-width: 640px) {
    .onlysp {
      display: inherit !important; } }

.sp-br {
  display: none; }
  @media only screen and (max-width: 640px) {
    .sp-br {
      display: block; } }

@media only screen and (max-width: 640px) {
  .pc-br {
    display: none; } }

/* -------------------------------------------------------------------------------- */
/*	スライドショー
/* -------------------------------------------------------------------------------- */
.kayvisual {
  position: relative;
  min-width: 960px;
  width: 100%; }
  @media only screen and (max-width: 640px) {
    .kayvisual {
      width: 100%;
      min-width: 100%; } }
  .kayvisual .bx-wrapper {
    margin-bottom: 0; }
    .kayvisual .bx-wrapper .bx-viewport {
      border: none;
      left: 0;
      box-shadow: none; }
      @media only screen and (max-width: 640px) {
        .kayvisual .bx-wrapper .bx-viewport .bxslider li {
          left: -25%;
          min-width: 150%; } }
      .kayvisual .bx-wrapper .bx-viewport .bxslider li img {
        width: 100%; }
    .kayvisual .bx-wrapper .bx-controls .bx-controls-direction {
      display: none; }
    .kayvisual .bx-wrapper .bx-controls .bx-pager {
      height: auto !important;
      top: 95% !important;
      bottom: 0 !important;
      padding-top: 0; }
      @media only screen and (max-width: 640px) {
        .kayvisual .bx-wrapper .bx-controls .bx-pager {
          top: 90% !important; } }
      .kayvisual .bx-wrapper .bx-controls .bx-pager .bx-pager-item a.bx-pager-link {
        border-radius: 50px;
        background: rgba(255, 255, 255, 0.5) !important; }
      .kayvisual .bx-wrapper .bx-controls .bx-pager .bx-pager-item a.active {
        background: rgba(255, 255, 255, 0.9) !important; }
  .kayvisual .main_logo_outer {
    position: absolute;
    z-index: 100;
    width: 100%;
    top: 0;
    display: none; }
    .kayvisual .main_logo_outer .main_logo_inner {
      width: 660px;
      margin: 5% auto 0;
      background: rgba(255, 255, 255, 0.7);
      padding: 60px 0;
      text-align: center; }
      @media only screen and (max-width: 1200px) {
        .kayvisual .main_logo_outer .main_logo_inner {
          width: 50%;
          padding: 6% 0; } }
      @media only screen and (max-width: 640px) {
        .kayvisual .main_logo_outer .main_logo_inner {
          width: 70%;
          margin: 13% auto 0; } }
      .kayvisual .main_logo_outer .main_logo_inner img {
        width: 400px;
        height: auto; }
        @media only screen and (max-width: 1200px) {
          .kayvisual .main_logo_outer .main_logo_inner img {
            width: 60%; } }

/* -------------------------------------------------------------------------------- */
/*	SPグローバルナビ
/* -------------------------------------------------------------------------------- */
.sp_g_nav {
  display: none; }
  @media only screen and (max-width: 640px) {
    .sp_g_nav {
      display: block;
      width: 100%; }
      .sp_g_nav ul {
        display: table;
        width: 100%;
        border-bottom: 2px solid #004294; }
        .sp_g_nav ul li {
          width: 33.3%;
          display: table-cell;
          text-align: center;
          border-right: 1px solid #dddddd; }
          .sp_g_nav ul li:last-child {
            border-right: none; }
          .sp_g_nav ul li a {
            display: block;
            color: #000;
            padding: 15px 0; } }

/* -------------------------------------------------------------------------------- */
/*	TOPリード
/* -------------------------------------------------------------------------------- */
.top_lead_outer {
  width: 100%;
  margin-top: 100px; }
  @media only screen and (max-width: 640px) {
    .top_lead_outer {
      margin-top: 30px; } }
  .top_lead_outer .top_lead_inner {
    min-height: 1px;
    width: 960px;
    height: auto;
    margin: 0 auto;
    padding-bottom: 50px;
    border-bottom: 1px solid #dddddd; }
    .top_lead_outer .top_lead_inner:after {
      content: ".";
      display: block;
      clear: both;
      height: 0;
      visibility: hidden; }
    * html .top_lead_outer .top_lead_inner {
      height: 1px;
      /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
    @media only screen and (max-width: 640px) {
      .top_lead_outer .top_lead_inner {
        width: 90%; } }
    .top_lead_outer .top_lead_inner .top_lead_left {
      float: left;
      width: 568px; }
      @media only screen and (max-width: 640px) {
        .top_lead_outer .top_lead_inner .top_lead_left {
          float: none;
          width: auto; } }
      .top_lead_outer .top_lead_inner .top_lead_left .top_lead_copy {
        margin-left: 40px; }
        @media only screen and (max-width: 640px) {
          .top_lead_outer .top_lead_inner .top_lead_left .top_lead_copy {
            margin-left: 0; } }
        .top_lead_outer .top_lead_inner .top_lead_left .top_lead_copy img {
          width: 539px;
          height: auto; }
          @media only screen and (max-width: 640px) {
            .top_lead_outer .top_lead_inner .top_lead_left .top_lead_copy img {
              width: 100%; } }
      .top_lead_outer .top_lead_inner .top_lead_left p {
        width: 512px;
        color: #003281;
        margin-left: 40px;
        margin-top: 35px;
        font-size: 16px;
        line-height: 1.75; }
        @media only screen and (max-width: 640px) {
          .top_lead_outer .top_lead_inner .top_lead_left p {
            width: auto;
            margin-left: 0; } }
      .top_lead_outer .top_lead_inner .top_lead_left a {
        display: block;
        color: #003281;
        margin-left: 45px;
        margin-top: 30px; }
        @media only screen and (max-width: 640px) {
          .top_lead_outer .top_lead_inner .top_lead_left a {
            margin-left: 0; } }
        .top_lead_outer .top_lead_inner .top_lead_left a:before {
          content: "\f0a9";
          font-family: FontAwesome;
          margin-right: 5px; }
        .top_lead_outer .top_lead_inner .top_lead_left a:hover {
          color: #007d4f; }
    .top_lead_outer .top_lead_inner .top_lead_right {
      float: right;
      width: 362px; }
      @media only screen and (max-width: 640px) {
        .top_lead_outer .top_lead_inner .top_lead_right {
          float: none;
          width: 100%;
          margin-top: 20px; } }
      .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper {
        margin-bottom: 0; }
        .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper .bx-viewport {
          border: none;
          left: 0;
          box-shadow: none; }
          .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper .bx-viewport .bxslider li img {
            border-radius: 50%;
            width: 362px;
            height: 362px; }
            @media only screen and (max-width: 640px) {
              .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper .bx-viewport .bxslider li img {
                width: 98%;
                height: auto; } }
        .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper .bx-controls .bx-controls-direction {
          display: none; }
        .top_lead_outer .top_lead_inner .top_lead_right .bx-wrapper .bx-controls .bx-pager {
          display: none; }

/* -------------------------------------------------------------------------------- */
/*	臨時ニュース
/* -------------------------------------------------------------------------------- */
.top_news {
  text-align: center;
  margin: 40px auto;
  width: 960px;
  border: 2px solid #f30;
  color: #f30;
  padding: 0; }
  .top_news a {
    display: block;
    padding: 1.5em; }
  @media only screen and (max-width: 640px) {
    .top_news {
      width: 95%; }
      .top_news a {
        padding: 1em; }
      .top_news span {
        display: block; } }

/* -------------------------------------------------------------------------------- */
/*	診療案内
/* -------------------------------------------------------------------------------- */
.clinic_infomation_outer {
  width: 100%;
  padding-bottom: 120px; }
  .clinic_infomation_outer .clinic_infomation_inner {
    width: 960px;
    margin: 50px auto 0; }
    @media only screen and (max-width: 640px) {
      .clinic_infomation_outer .clinic_infomation_inner {
        width: 90%; } }
    .clinic_infomation_outer .clinic_infomation_inner .clinic_infomation_lead img {
      display: block;
      margin: 0 auto; }
    .clinic_infomation_outer .clinic_infomation_inner .clinic_infomation_lead .infomation_lead_txt {
      width: 378px;
      height: auto; }
      @media only screen and (max-width: 640px) {
        .clinic_infomation_outer .clinic_infomation_inner .clinic_infomation_lead .infomation_lead_txt {
          width: 90%; } }
    .clinic_infomation_outer .clinic_infomation_inner .clinic_infomation_lead span {
      display: block;
      font-size: 21px;
      color: #003281;
      padding-top: 25px;
      text-align: center; }
    .clinic_infomation_outer .clinic_infomation_inner .shika_area {
      padding-top: 90px; }
      .clinic_infomation_outer .clinic_infomation_inner .shika_area h2 {
        margin: 0 0 58px;
        text-align: center; }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area h2 img {
          width: 109px;
          height: auto; }
      .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses {
        min-height: 1px;
        width: 100%; }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses:after {
          content: ".";
          display: block;
          clear: both;
          height: 0;
          visibility: hidden; }
        * html .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses {
          height: 1px;
          /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block,
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block,
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block {
          float: left;
          position: relative;
          width: 300px;
          height: auto;
          margin-right: 30px; }
          @media only screen and (max-width: 640px) {
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block {
              float: none;
              margin-right: 0;
              width: 100%;
              margin-bottom: 60px; } }
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block h3,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block h3,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block h3 {
            position: absolute;
            display: inline-block;
            border: 1px solid #003281;
            color: #003281;
            background: rgba(255, 255, 255, 0.7);
            font-size: 18px;
            padding: 5px 20px;
            top: -7px;
            left: 10px; }
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block img,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block img,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block img {
            width: 100%; }
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block dl,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block dl,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block dl {
            margin-top: 20px; }
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block dl dt,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block dl dt,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block dl dt {
              font-weight: bold;
              font-size: 16px; }
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block dl dd,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block dl dd,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block dl dd {
              margin-top: 10px;
              font-size: 14px;
              margin-left: 0;
              line-height: 1.85; }
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a,
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a {
            display: block;
            width: 278px;
            font-weight: bold;
            border: 2px solid #003281;
            color: #003281;
            padding: 5px 0;
            margin: 0 auto;
            text-align: center;
            border-radius: 50px;
            -webkit-border-radius: 50px;
            -moz-border-radius: 50px; }
            @media only screen and (max-width: 640px) {
              .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a,
              .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a,
              .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a {
                width: 95%; } }
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a:before,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a:before,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a:before {
              content: "\f138";
              font-family: FontAwesome;
              margin-right: 5px; }
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a:hover,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a:hover,
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a:hover {
              border: 2px solid #007d4f;
              color: #007d4f; }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a {
          margin-top: 42px; }
          @media only screen and (max-width: 640px) {
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kyosei_block a {
              margin-top: 35px; } }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a {
          margin-top: 17px; }
          @media only screen and (max-width: 640px) {
            .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .kokugeka_block a {
              margin-top: 35px; } }
        .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block {
          margin-right: 0; }
          .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a {
            margin-top: 42px; }
            @media only screen and (max-width: 640px) {
              .clinic_infomation_outer .clinic_infomation_inner .shika_area .shika_courses .implant_block a {
                margin-top: 35px; } }
    .clinic_infomation_outer .clinic_infomation_inner .komon_area {
      padding-top: 90px; }
      @media only screen and (max-width: 640px) {
        .clinic_infomation_outer .clinic_infomation_inner .komon_area {
          padding-top: 10px; } }
      .clinic_infomation_outer .clinic_infomation_inner .komon_area h2 {
        margin: 0 0 58px;
        text-align: center; }
        @media only screen and (max-width: 640px) {
          .clinic_infomation_outer .clinic_infomation_inner .komon_area h2 {
            margin: 0 0 18px; } }
        .clinic_infomation_outer .clinic_infomation_inner .komon_area h2 img {
          width: 109px;
          height: auto; }
      .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses {
        min-height: 1px;
        width: 100%; }
        .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses:after {
          content: ".";
          display: block;
          clear: both;
          height: 0;
          visibility: hidden; }
        * html .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses {
          height: 1px;
          /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
        .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_right {
          position: relative;
          float: right;
          width: 300px;
          height: auto; }
          @media only screen and (max-width: 640px) {
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_right {
              float: none;
              width: 100%; } }
          .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_right h3 {
            position: absolute;
            display: inline-block;
            border: 1px solid #003281;
            color: #003281;
            background: rgba(255, 255, 255, 0.7);
            font-size: 18px;
            padding: 5px 20px;
            top: -7px;
            right: 10px; }
          .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_right img {
            width: 100%; }
        .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left {
          float: left;
          width: 630px; }
          @media only screen and (max-width: 640px) {
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left {
              float: none;
              width: 100%; } }
          .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left dl {
            width: 100%; }
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left dl dt {
              font-weight: bold;
              font-size: 16px; }
              .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left dl dt:nth-last-of-type(1) {
                margin-top: 30px; }
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left dl dd {
              margin-top: 10px;
              font-size: 14px;
              margin-left: 0; }
          .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left a {
            float: right;
            display: block;
            width: 278px;
            font-weight: bold;
            border: 2px solid #003281;
            color: #003281;
            padding: 5px 0;
            margin: 0 auto;
            text-align: center;
            border-radius: 50px;
            -webkit-border-radius: 50px;
            -moz-border-radius: 50px; }
            @media only screen and (max-width: 640px) {
              .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left a {
                float: none;
                width: 95%;
                margin: 25px auto 0; } }
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left a:before {
              content: "\f138";
              font-family: FontAwesome;
              margin-right: 5px; }
            .clinic_infomation_outer .clinic_infomation_inner .komon_area .komon_courses .komon_left a:hover {
              border: 2px solid #007d4f;
              color: #007d4f; }

/* -------------------------------------------------------------------------------- */
/*	診療時間
/* -------------------------------------------------------------------------------- */
.consultation_hour_outer {
  width: 100%;
  padding: 60px 0 120px;
  background-color: #f4f4ee; }
  .consultation_hour_outer .consultation_hour_inner {
    width: 960px;
    margin: 0 auto;
    color: #003281; }
    @media only screen and (max-width: 640px) {
      .consultation_hour_outer .consultation_hour_inner {
        width: 90%; } }
    .consultation_hour_outer .consultation_hour_inner h2 {
      font-size: 24px;
      font-weight: normal;
      text-align: center; }
      .consultation_hour_outer .consultation_hour_inner h2:before {
        display: block;
        content: "\f073";
        font-family: FontAwesome;
        font-size: 48px;
        padding-bottom: 24px; }
        @media only screen and (max-width: 640px) {
          .consultation_hour_outer .consultation_hour_inner h2:before {
            font-size: 50px;
            padding-bottom: 14px; } }
    .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation {
      min-height: 1px;
      margin-top: 110px; }
      .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation:after {
        content: ".";
        display: block;
        clear: both;
        height: 0;
        visibility: hidden; }
      * html .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation {
        height: 1px;
        /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
      @media only screen and (max-width: 640px) {
        .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation {
          margin-top: 50px; } }
      .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left {
        float: left;
        width: 300px; }
        @media only screen and (max-width: 640px) {
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left {
            float: none;
            width: 100%; } }
        .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner {
          min-height: 1px;
          padding-bottom: 20px; }
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner:after {
            content: ".";
            display: block;
            clear: both;
            height: 0;
            visibility: hidden; }
          * html .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner {
            height: 1px;
            /*\*/
       /*/
  height: auto;
  overflow: hidden;
  /**/ }
          @media only screen and (max-width: 640px) {
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner:last-child {
              padding-bottom: 10px; } }
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner h3 {
            width: 111px;
            text-align: center;
            float: left;
            font-weight: normal;
            border-radius: 50px;
            -webkit-border-radius: 50px;
            -moz-border-radius: 50px;
            color: #fff;
            padding: 3px 0;
            background-color: #003281;
            font-size: 16px; }
            @media only screen and (max-width: 640px) {
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner h3 {
                width: 30%; } }
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner div {
            float: left;
            width: 163px;
            margin-left: 25px;
            line-height: 2; }
            @media only screen and (max-width: 640px) {
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner div {
                width: 60%;
                margin-left: 10%; } }
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner div .am {
              padding-right: 33px; }
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_left .hour_info_left_inner div .pm {
              padding-right: 25px; }
      .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right {
        width: 630px;
        float: right;
        color: #003281; }
        @media only screen and (max-width: 640px) {
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right {
            float: none;
            width: 100%; } }
        .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner {
          width: 100%; }
          @media only screen and (max-width: 640px) {
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner {
              overflow: auto;
              overflow-x: auto;
              white-space: nowrap;
              -webkit-overflow-scrolling: touch; } }
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table {
            width: 100%; }
            @media only screen and (max-width: 640px) {
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table {
                width: 680px; } }
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr th, .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr td,
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr th,
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr td {
              border: 1px solid #003281;
              text-align: center;
              vertical-align: middle;
              padding: 5px 0;
              font-weight: normal; }
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr th:first-child, .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr td:first-child,
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr th:first-child,
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr td:first-child {
                border-left: none; }
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr th:last-child, .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr td:last-child,
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr th:last-child,
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr td:last-child {
                border-right: none; }
            @media only screen and (max-width: 640px) {
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table thead tr th.tbl_ttl {
                width: 35%; } }
            .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr td {
              font-size: 16px; }
              .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right .hour_info_right_inner table tbody tr td .fa-circle-o {
                font-size: 21px;
                padding-top: 2px; }
        .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right ul {
          margin-top: 20px; }
          .consultation_hour_outer .consultation_hour_inner .consultation_hour_infomation .hour_info_right ul li {
            list-style: none;
            text-indent: -1em;
            padding-left: 1em; }

/* -------------------------------------------------------------------------------- */
/*	お知らせ
/* -------------------------------------------------------------------------------- */
.news_area_outer {
  width: 100%; }
  .news_area_outer .news_area_inner {
    width: 960px;
    margin: 0 auto;
    padding: 60px 0 80px;
    min-height: 1px;
    background: transparent url("../img/bg_news.png") no-repeat;
    background-position: 690px 20px;
    background-size: 250px auto; }
    .news_area_outer .news_area_inner:after {
      content: ".";
      display: block;
      clear: both;
      height: 0;
      visibility: hidden; }
    * html .news_area_outer .news_area_inner {
      height: 1px;
      /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
    @media only screen and (max-width: 640px) {
      .news_area_outer .news_area_inner {
        width: 90%;
        background: none; } }
    .news_area_outer .news_area_inner h2 {
      width: 220px;
      float: left;
      color: #003281;
      font-weight: normal;
      font-size: 24px;
      padding-left: 40px; }
      .news_area_outer .news_area_inner h2:before {
        content: "\f1ea";
        font-family: FontAwesome;
        font-size: 34px;
        margin-right: 10px; }
      @media only screen and (max-width: 640px) {
        .news_area_outer .news_area_inner h2 {
          float: none;
          width: 100%;
          text-align: center;
          padding-left: 0;
          padding-bottom: 20px; }
          .news_area_outer .news_area_inner h2:before {
            display: block;
            padding-bottom: 14px;
            font-size: 50px; } }
    .news_area_outer .news_area_inner .news_list {
      width: 700px;
      float: left; }
      @media only screen and (max-width: 640px) {
        .news_area_outer .news_area_inner .news_list {
          float: none;
          width: 100%;
          background: transparent url("../img/bg_news.png") no-repeat;
          background-position: 95% 10%;
          background-size: 50% auto; } }
      .news_area_outer .news_area_inner .news_list ul li {
        list-style: none;
        margin-bottom: 20px;
        line-height: 1.4; }
        .news_area_outer .news_area_inner .news_list ul li:last-child {
          margin-bottom: 0; }
        .news_area_outer .news_area_inner .news_list ul li a {
          color: #000; }
          .news_area_outer .news_area_inner .news_list ul li a:hover {
            color: #007d4f; }
          .news_area_outer .news_area_inner .news_list ul li a span {
            display: inline-block;
            width: 150px; }
            @media only screen and (max-width: 640px) {
              .news_area_outer .news_area_inner .news_list ul li a span {
                display: block; } }
      .news_area_outer .news_area_inner .news_list a.list_pre {
        display: inline-block;
        float: right;
        color: #000;
        margin-top: 40px; }
        .news_area_outer .news_area_inner .news_list a.list_pre:before {
          content: "\f022";
          font-family: FontAwesome;
          margin-right: 5px; }
        .news_area_outer .news_area_inner .news_list a.list_pre:hover {
          color: #007d4f; }

/* -------------------------------------------------------------------------------- */
/*	お知らせ下自動スライダー
/* -------------------------------------------------------------------------------- */
.loopSliderWrap {
  top: 0;
  left: 0;
  height: 220px;
  overflow: hidden;
  position: absolute; }

.loopSlider {
  margin: 0 auto;
  width: 100%;
  height: 220px;
  text-align: left;
  position: relative;
  overflow: hidden; }

.loopSlider ul {
  height: 220px;
  float: left;
  overflow: hidden; }

.loopSlider ul li {
  width: 320px;
  height: 220px;
  float: left;
  display: inline;
  overflow: hidden; }

.loopSlider ul li img {
  width: 100%; }

/* ------------------------------
   CLEARFIX ELEMENTS
------------------------------ */
.loopSliderWrap:after {
  content: "";
  display: none;
  clear: none; }

/* -------------------------------------------------------------------------------- */
/*	交通アクセス
/* -------------------------------------------------------------------------------- */
.access_outer {
  width: 100%;
  background-color: #f4f5f9;
  padding-bottom: 60px; }
  .access_outer .access_inner {
    width: 960px;
    margin: 0 auto; }
    @media only screen and (max-width: 640px) {
      .access_outer .access_inner {
        width: 90%; } }
    .access_outer .access_inner h2 {
      text-align: center;
      padding: 60px 0 40px;
      color: #003281;
      font-weight: normal; }
      .access_outer .access_inner h2:before {
        display: block;
        content: "\f207";
        font-family: FontAwesome;
        margin-bottom: 30px;
        font-size: 48px; }
        @media only screen and (max-width: 640px) {
          .access_outer .access_inner h2:before {
            font-size: 50px;
            margin-bottom: 14px; } }
    .access_outer .access_inner .access_area {
      min-height: 1px; }
      .access_outer .access_inner .access_area:after {
        content: ".";
        display: block;
        clear: both;
        height: 0;
        visibility: hidden; }
      * html .access_outer .access_inner .access_area {
        height: 1px;
        /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
      .access_outer .access_inner .access_area .access_left {
        width: 300px;
        float: left; }
        @media only screen and (max-width: 640px) {
          .access_outer .access_inner .access_area .access_left {
            width: 100%;
            float: none;
            text-align: center; } }
        .access_outer .access_inner .access_area .access_left img {
          width: 100%; }
        .access_outer .access_inner .access_area .access_left h3 {
          margin-top: 20px; }
          .access_outer .access_inner .access_area .access_left h3 img {
            width: 195px;
            height: auto; }
        .access_outer .access_inner .access_area .access_left div {
          margin-left: 30px;
          font-size: 14px; }
          @media only screen and (max-width: 640px) {
            .access_outer .access_inner .access_area .access_left div {
              margin-left: 0; } }
        .access_outer .access_inner .access_area .access_left .shika_tel_area h4,
        .access_outer .access_inner .access_area .access_left .komon_tel_area h4 {
          margin: 5px 0 0;
          font-size: 16px;
          font-weight: normal; }
          .access_outer .access_inner .access_area .access_left .shika_tel_area h4:before,
          .access_outer .access_inner .access_area .access_left .komon_tel_area h4:before {
            content: "\f098";
            font-family: FontAwesome;
            font-size: 18px;
            margin-right: 5px; }
        @media only screen and (max-width: 640px) {
          .access_outer .access_inner .access_area .access_left .shika_tel_area,
          .access_outer .access_inner .access_area .access_left .komon_tel_area {
            color: #003281; } }
        .access_outer .access_inner .access_area .access_left .shika_tel_area .tel,
        .access_outer .access_inner .access_area .access_left .komon_tel_area .tel {
          font-family: 'Roboto', sans-serif;
          font-size: 21px;
          margin-left: 0px; }
        .access_outer .access_inner .access_area .access_left .komon_tel_area h4 span {
          font-size: 12px;
          padding-left: 5px; }
      .access_outer .access_inner .access_area .access_right {
        float: left;
        width: 630px;
        margin-left: 30px; }
        @media only screen and (max-width: 640px) {
          .access_outer .access_inner .access_area .access_right {
            width: 100%;
            float: none;
            margin-left: 0;
            margin-top: 20px; } }
        .access_outer .access_inner .access_area .access_right iframe {
          width: 100%;
          height: 430px;
          border: 1px #ccc solid; }
        .access_outer .access_inner .access_area .access_right #gmap {
          width: 630px;
          height: 348px; }
          @media only screen and (max-width: 640px) {
            .access_outer .access_inner .access_area .access_right #gmap {
              width: 100%;
              height: 346px; } }
        .access_outer .access_inner .access_area .access_right dl {
          margin-top: 20px; }
          .access_outer .access_inner .access_area .access_right dl dt {
            float: left;
            clear: left; }
            @media only screen and (max-width: 640px) {
              .access_outer .access_inner .access_area .access_right dl dt {
                width: 20%; } }
          .access_outer .access_inner .access_area .access_right dl dd {
            margin: 0;
            float: left; }
            @media only screen and (max-width: 640px) {
              .access_outer .access_inner .access_area .access_right dl dd {
                width: 80%; } }
    .access_outer .access_inner .access_fb_area {
      text-align: right;
      margin-top: 110px;
      min-height: 1px; }
      .access_outer .access_inner .access_fb_area:after {
        content: ".";
        display: block;
        clear: both;
        height: 0;
        visibility: hidden; }
      * html .access_outer .access_inner .access_fb_area {
        height: 1px;
        /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
      @media only screen and (max-width: 640px) {
        .access_outer .access_inner .access_fb_area {
          text-align: center;
          width: 50%;
          margin: 110px auto 0; } }
      .access_outer .access_inner .access_fb_area .fb-btn {
        background-color: #3a5a98;
        padding: 50px 8px 0 25px;
        margin-right: 20px;
        border-radius: 4px; }
        .access_outer .access_inner .access_fb_area .fb-btn:before {
          content: "\f09a";
          font-family: FontAwesome;
          font-size: 60px;
          color: #fff; }
      .access_outer .access_inner .access_fb_area iframe {
        display: block;
        float: right;
        margin-top: -13px; }
        @media only screen and (max-width: 640px) {
          .access_outer .access_inner .access_fb_area iframe {
            display: inline-block; } }

/* 表示・非表示切替 --------------------------------------- */
/* PCのみ表示 */
@media only screen and (max-width: 640px) {
  .onlypc {
    display: none !important; } }

/* スマートフォンのみ表示 */
.onlysp {
  display: none !important; }
  @media only screen and (max-width: 640px) {
    .onlysp {
      display: inherit !important; } }

.sp-br {
  display: none; }
  @media only screen and (max-width: 640px) {
    .sp-br {
      display: block; } }

@media only screen and (max-width: 640px) {
  .pc-br {
    display: none; } }

/* -------------------------------------------------------------------------------- */
/*	パンくずリスト
/* -------------------------------------------------------------------------------- */
.breadcrumb {
  width: 960px;
  margin: 0 auto; }
  @media only screen and (max-width: 640px) {
    .breadcrumb {
      width: 90%; } }
  .breadcrumb ol {
    min-height: 1px;
    padding: 20px 0 0; }
    .breadcrumb ol:after {
      content: ".";
      display: block;
      clear: both;
      height: 0;
      visibility: hidden; }
    * html .breadcrumb ol {
      height: 1px;
      /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
    .breadcrumb ol li {
      float: left;
      list-style: none;
      font-size: 14px; }
      .breadcrumb ol li:after {
        content: ">";
        margin: 0 15px; }
      .breadcrumb ol li:last-child:after {
        content: ""; }
      .breadcrumb ol li a {
        color: #000; }
        .breadcrumb ol li a:hover {
          color: #007d4f; }

/* -------------------------------------------------------------------------------- */
/*	院長あいさつ
/* -------------------------------------------------------------------------------- */
.greating {
  background: url(../img/greeting/sky.jpg) no-repeat;
  background-size: auto 100%;
  background-position: center;
  padding-bottom: 240px; }
  @media only screen and (max-width: 640px) {
    .greating {
      background: url(../img/greeting/sky_sp.jpg) no-repeat; } }
  .greating section {
    width: 960px;
    margin: 0 auto; }
    @media only screen and (max-width: 640px) {
      .greating section {
        width: 90%; } }
    .greating section h2 {
      font-size: 24px;
      font-weight: normal;
      text-align: center;
      margin-top: 120px;
      color: #003281; }
    .greating section img {
      display: block;
      margin: 60px auto 0;
      width: 378px;
      height: auto; }
      @media only screen and (max-width: 640px) {
        .greating section img {
          width: 90%; } }
    .greating section .massage {
      width: 700px;
      margin: 80px auto 0;
      min-height: 1px; }
      .greating section .massage .profile {
        float: right;
        margin: 0 0 10px 10px; }
      .greating section .massage:after {
        content: ".";
        display: block;
        clear: both;
        height: 0;
        visibility: hidden; }
      * html .greating section .massage {
        height: 1px;
        /*\*/
     /*/
height: auto;
overflow: hidden;
/**/ }
      @media only screen and (max-width: 640px) {
        .greating section .massage {
          width: 100%; } }
      .greating section .massage p {
        margin-bottom: 30px; }
      .greating section .massage .signature {
        display: inline-block;
        float: right;
        text-align: left;
        font-size: 18px;
        line-height: 2; }
        .greating section .massage .signature img {
          width: 208px;
          height: 208px; }

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