@charset "UTF-8";
body, * {
  box-sizing: border-box !important; }

body {
  font-family: 'IBM Plex Sans JP', sans-serif;
  color: #27212e; }

.container {
  width: 1000px;
  margin: 0 auto; }
  @media screen and (max-width: 767px) {
    .container {
      width: 90%; } }

@media screen and (max-width: 767px) {
  .sp-flex {
    display: flex; } }

header {
  padding-top: 50px;
  padding-bottom: 50px;
  display: flex;
  align-items: center;
  border-top: 6px solid #13AE67;
  background: #fff;
  position: relative; }
  @media screen and (max-width: 767px) {
    header {
      padding-top: 20px;
      padding-bottom: 20px; } }

h1.name {
  font-size: 15px;
  margin-bottom: 25px; }
  @media screen and (max-width: 767px) {
    h1.name {
      font-size: 12px;
      margin-bottom: 10px; } }
  h1.name strong {
    display: block;
    margin-bottom: 10px; }
    @media screen and (max-width: 767px) {
      h1.name strong {
        margin-bottom: 20px; } }
  @media screen and (max-width: 767px) {
    h1.name img {
      width: 250px; } }

.header-flex {
  display: flex;
  align-items: flex-end;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .header-flex {
      display: block; } }

@media screen and (max-width: 767px) {
  .header-right {
    /*top:0;
    right:0;
    position:absolute;*/ } }
@media screen and (max-width: 767px) {
  .header-right .tr {
    text-align: left; }
    .header-right .tr img {
      position: absolute;
      width: 140px;
      top: 10px;
      left: 11em; } }

.header-list {
  display: flex; }
  @media screen and (max-width: 767px) {
    .header-list {
      flex-wrap: wrap; } }
  .header-list li {
    background: #BBDA83;
    padding: 5px 10px;
    color: #fff;
    border-radius: 8px;
    margin-right: 8px; }
    @media screen and (max-width: 767px) {
      .header-list li {
        font-size: 12px;
        padding: 2.5px 6px;
        margin-right: 4px;
        line-height: 1.4; } }

.line-top {
  display: flex;
  align-items: center;
  top: 0;
  right: calc(2.5% + 250px);
  padding: 11px 20px 16px;
  position: absolute;
  background: #06c755;
  color: #fff;
  border-radius: 0 0px 8px 8px; }
  .line-top img {
    width: 30px;
    display: block; }
  .line-top span {
    display: block; }
  @media screen and (max-width: 767px) {
    .line-top {
      top: 70px;
      padding: 5px 10px 5px 10px;
      right: 0;
      border-radius: 8px 0px 0px 8px; }
      .line-top span {
        display: none;
        font-size: 12px; }
      .line-top strong {
        display: block; } }

.main-hospital {
  top: 0;
  right: 2.5%;
  padding: 14px 20px 20px;
  position: absolute;
  background: #13AE67;
  color: #fff;
  display: inline-block;
  border-radius: 0 0px 8px 8px; }
  @media screen and (max-width: 767px) {
    .main-hospital {
      display: none; } }

.explain {
  margin-top: 400px;
  margin-bottom: 400px;
  font-size: 20px;
  text-align: center;
  line-height: 1.5; }
  @media screen and (max-width: 767px) {
    .explain {
      margin-top: 150px;
      margin-bottom: 150px;
      font-size: 16px; } }

footer {
  margin-top: 150px;
  padding-top: 100px;
  background: #EEF3E8; }

.global-navi {
  margin-top: 30px;
  display: flex; }
  @media screen and (max-width: 767px) {
    .global-navi {
      margin-top: 100px;
      display: block; } }
  .global-navi li {
    font-size: 18px;
    margin-right: 20px; }
    .global-navi li:last-child {
      margin-right: 0px; }

.news-section {
  background: #FAFEF2;
  padding-top: 50px;
  padding-bottom: 50px; }

.news {
  width: 90%;
  margin: 30px auto 50px; }
  @media screen and (max-width: 767px) {
    .news {
      width: 100%;
      margin: 15px auto 15px; } }
  .news div {
    border-bottom: 1px dotted #DEF2E9;
    display: flex;
    padding: 20px 0; }
    @media screen and (max-width: 767px) {
      .news div {
        display: block;
        padding: 20px 20px; } }
    .news div dt, .news div dd {
      font-size: 18px; }
      @media screen and (max-width: 767px) {
        .news div dt, .news div dd {
          font-size: 13px; } }
    .news div dd {
      font-weight: 600;
      margin-left: 30px; }
      @media screen and (max-width: 767px) {
        .news div dd {
          margin-left: 0px;
          margin-top: 5px; } }

@media screen and (max-width: 767px) {
  .link-button {
    width: 50% !important;
    margin: 0 auto; } }

.pic-section {
  padding-bottom: 150px; }
  @media screen and (max-width: 767px) {
    .pic-section {
      padding-bottom: 80px; } }

.pic-list {
  display: flex;
  margin-bottom: 50px; }
  @media screen and (max-width: 767px) {
    .pic-list {
      margin-bottom: 20px; } }
  .pic-list figure img {
    width: 100%; }

.pic-explanation {
  font-size: 16px;
  text-align: center; }
  @media screen and (max-width: 767px) {
    .pic-explanation {
      font-size: 13px;
      padding: 10px 30px; } }

.heading-01 {
  font-size: 24px;
  font-weight: bold;
  padding: 10px 0px;
  border-bottom: 1px solid #13AE67;
  margin-bottom: 30px; }
  @media screen and (max-width: 767px) {
    .heading-01 {
      font-size: 16px;
      margin-bottom: 15px; } }

.heading-02 {
  font-size: 18px;
  font-weight: 600;
  margin-bottom: 25px; }
  @media screen and (max-width: 767px) {
    .heading-02 {
      font-size: 14px;
      margin-bottom: 15px; } }

.text-01 {
  font-size: 16px;
  line-height: 1.8; }
  @media screen and (max-width: 767px) {
    .text-01 {
      font-size: 12px; } }

.top-about-section {
  padding-bottom: 100px; }
  @media screen and (max-width: 767px) {
    .top-about-section {
      padding-bottom: 50px; } }

.top-about-flex {
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .top-about-flex {
      display: block; } }
  .top-about-flex figure {
    width: 45%; }
    @media screen and (max-width: 767px) {
      .top-about-flex figure {
        width: 100%;
        margin-bottom: 15px; } }
  .top-about-flex .top-about-text {
    width: 52%; }
    @media screen and (max-width: 767px) {
      .top-about-flex .top-about-text {
        width: 100%; } }

.disease-list {
  margin-top: 30px;
  margin-bottom: 30px;
  display: flex; }
  @media screen and (max-width: 767px) {
    .disease-list {
      flex-wrap: wrap;
      justify-content: space-between; } }
  .disease-list li {
    background: #63695F;
    padding: 5px 30px;
    color: #fff;
    border-radius: 8px;
    margin-right: 8px; }
    @media screen and (max-width: 767px) {
      .disease-list li {
        margin-right: 0px;
        width: 48%;
        text-align: center;
        margin-bottom: 10px;
        font-size: 13px; } }

.caution {
  text-indent: -1em;
  margin-left: 1em; }
  @media screen and (max-width: 767px) {
    .caution {
      font-size: 13px; } }

footer {
  margin-top: 150px;
  padding-top: 100px;
  padding-bottom: 20px;
  background: #EEF3E8; }
  @media screen and (max-width: 767px) {
    footer {
      margin-top: 50px;
      padding-top: 50px; } }

.footer-flex {
  display: flex;
  justify-content: space-between; }
  @media screen and (max-width: 767px) {
    .footer-flex {
      display: block; } }
  .footer-flex .footer-left {
    width: 50%; }
    @media screen and (max-width: 767px) {
      .footer-flex .footer-left {
        margin-bottom: 40px;
        width: 100%; } }
  .footer-flex iframe {
    width: 46%; }
    @media screen and (max-width: 767px) {
      .footer-flex iframe {
        width: 100%; } }

.footer-navi {
  margin: 80px auto 50px;
  width: 50%;
  display: flex;
  justify-content: center;
  border-bottom: 1px solid #13AE67; }
  @media screen and (max-width: 767px) {
    .footer-navi {
      width: 100%; } }
  .footer-navi li a {
    font-size: 18px;
    font-weight: 600;
    padding: 10px;
    display: inline-block; }
    @media screen and (max-width: 767px) {
      .footer-navi li a {
        font-size: 12px; } }

small {
  display: block;
  text-align: center;
  font-size: 13px;
  background: #fff;
  color: #343434;
  padding: 20px; }

/*====================================
ハンバーガーメニュー
====================================*/
@media screen and (min-width: 1024px) {
  .menu-p {
    display: none; } }
@media screen and (max-width: 1023px) {
  .menu-p {
    display: none; } }
@media screen and (max-width: 767px) {
  .menu-p {
    display: block; } }

@media screen and (max-width: 767px) {
  .res_nav {
    display: none;
    position: fixed;
    top: 0;
    right: 0;
    width: 100%;
    height: 100%;
    background: rgba(106, 146, 63, 0.937);
    background: #13AE67;
    left: 0;
    transition-property: transform;
    overflow: hidden;
    z-index: 99; }

  header nav ul {
    display: block;
    width: 90%;
    height: 80%;
    position: absolute;
    top: 0px;
    right: 0px;
    bottom: 0px;
    left: 0px;
    margin: auto; }

  header nav ul li {
    margin: 0 auto;
    text-align: center;
    width: 100%; }

  header nav ul li:last-child {
    border: none; }

  header nav ul li a {
    display: block;
    color: #ffffff;
    width: 100%;
    padding: 10px 20px;
    font-weight: bold;
    font-size: 14px;
    border-bottom: 1px dotted #fff;
    text-align: left;
    letter-spacing: 0.075em; }
    header nav ul li a br {
      display: none; }

  #nav_toggle {
    display: block;
    width: 5%;
    width: 30px;
    height: 5%;
    height: 30px;
    position: absolute;
    top: 16px;
    right: 20px;
    z-index: 101;
    margin-left: auto; }

  #nav_toggle div {
    position: relative; }

  #nav_toggle span {
    display: block;
    height: 3px;
    background: #13AE67;
    position: absolute;
    width: 100%;
    right: 0;
    -webkit-transition: 0.3s ease-in-out;
    -moz-transition: 0.3s ease-in-out;
    transition: 0.3s ease-in-out; }

  #nav_toggle span:nth-child(1) {
    top: 0px; }

  #nav_toggle span:nth-child(2) {
    top: 9px; }

  #nav_toggle span:nth-child(3) {
    top: 18px; }

  #nav_toggle p {
    color: #13AE67;
    position: absolute;
    width: 5em;
    top: 25px;
    left: -1em;
    font-size: 12px; }

  .open {
    position: relative; }

  .open #nav_toggle span:nth-child(1) {
    background: #fff !important;
    top: 10px;
    -webkit-transform: rotate(135deg);
    -moz-transform: rotate(135deg);
    transform: rotate(135deg);
    z-index: 100; }

  .open #nav_toggle span:nth-child(2) {
    width: 0;
    left: 50%; }

  .open #nav_toggle span:nth-child(3) {
    background: #fff !important;
    top: 10px;
    -webkit-transform: rotate(-135deg);
    -moz-transform: rotate(-135deg);
    transform: rotate(-135deg); } }
/*====================ハンバーガーメニューEND==========================*/
/*====================Swiper.js==========================*/
.swiper-button-prev, .swiper-button-next {
  color: #fff !important; }

.swiper-pagination-bullet {
  background: #fff !important; }

.swiper-horizontal > .swiper-pagination-bullets, .swiper-pagination-bullets.swiper-pagination-horizontal, .swiper-pagination-custom, .swiper-pagination-fraction {
  bottom: -5px !important; }

/*====================Swiper.jsーEND==========================*/
.subpage-title {
  background: #13AE67;
  padding-top: 100px;
  padding-bottom: 100px;
  margin-bottom: 100px; }
  @media screen and (max-width: 767px) {
    .subpage-title {
      padding-top: 50px;
      padding-bottom: 50px;
      margin-bottom: 50px; } }
  .subpage-title h2 {
    text-align: center;
    font-size: 36px;
    color: #fff;
    font-weight: 500; }
    @media screen and (max-width: 767px) {
      .subpage-title h2 {
        font-size: 22px; } }

.director {
  font-size: 18px;
  margin-top: 30px;
  text-align: right; }
  @media screen and (max-width: 767px) {
    .director {
      font-size: 15px;
      margin-top: 20px; } }

.image-flex {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap; }
  .image-flex li {
    width: 49%;
    margin-bottom: 20px; }

.first-text {
  text-align: left;
  font-size: 16px; }
  @media screen and (max-width: 767px) {
    .first-text {
      font-size: 13px; } }

@media screen and (max-width: 767px) {
  .res-pic {
    width: 50% !important;
    margin: 0 auto; } }

.map-flex {
  display: flex; }
  @media screen and (max-width: 767px) {
    .map-flex {
      display: block; }
      .map-flex figure {
        margin-bottom: 20px; } }

.banner-flex {
  display: flex;
  align-items: baseline;
  justify-content: space-between; }

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