@charset "utf-8";

/*
Theme Name:     ★meike子テーマ★
Template:       meike
*/
 
@import url("../meike/style.css");

body {
font-family: 'Roboto','Noto Sans JP','Sawarabi Gothic',sans-serif;
font-size: 16px;
font-weight: 400;
background:#fff;
color: #333;
line-height: 180%;
overflow-x: hidden;
}

.clear	{ clear: both; } 
.mT10	{ margin-top:10px; }
.mT20	{ margin-top:20px; }
.mB10	{ margin-bottom:10px; }
.mB20	{ margin-bottom:20px; }

#topcontrol { z-index:999; }

/* 画像拡大 */
img.grow {
	-webkit-transition:0.2s ease-in-out;
	-moz-transition:0.2s ease-in-out;
	-ms-transition:0.2s ease-in-out;
	-o-transition:0.2s ease-in-out;
	transition:0.2s ease-in-out;
}

img.grow:hover {
	-webkit-transform:scale(1.2,1.2);
	-moz-transform:scale(1.2,1.2);
	-ms-transform:scale(1.2,1.2);
	-o-transform:scale(1.2,1.2);
	transform:scale(1.2,1.2);
}

.topcontents-box {
width: 1260px;
max-width: 90%;
margin: 0 auto;
padding: 0;
position:relative;
}
.wrapper {
width: 1120px;
max-width: 90%;
margin: 0 auto;
padding: 50px 0;
position:relative;
}
.wrapper1120 {
width: 1120px;
max-width: 90%;
margin: 0 auto;
padding: 0;
position:relative;
}
.wrapper1260 {
width: 1260px;
max-width: 90%;
margin: 0 auto;
padding: 0;
overflow: hidden;
}
.wrapper960 {
width: 960px;
max-width: 90%;
margin: 0 auto;
padding: 50px 0;
overflow: hidden;
}
.contents-box { 
width: 100%;
min-height: 200px;
height: auto;
margin: 0;
padding: 0;
position:relative;
z-index: 1;
-moz-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-webkit-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-o-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-ms-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
}
.footericon{
position:absolute;
bottom:0;
right:25%;
z-index:999;
}
.footericon img{
width:85px;
vertical-align: bottom;
}

.row {
    margin-bottom: 0em;
}

/* リンク */
a{
color:#0068b6;
text-decoration:none;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
a:hover{
color:#333;
text-decoration:none;
}

/* 各ページ共通 */
.alllink { text-align: center; }
.alllink a{
color: #333;
background-color:#fff;
font-size: 18px;
display: inline-block;
padding: 15px 5vw 15px;
border: 1px solid #333;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.alllink a:hover{
color: #fff;
border: 1px solid #333;
background-color:#333;
}
.alllink a::after{
position:relative;
top: 2px;
right: -15px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow.svg") no-repeat;
background-size:contain;
}
.alllink a:hover::after{
position:relative;
top: 2px;
right: -15px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow-mo.svg") no-repeat;
background-size:contain;
}

#topcontrol{
  bottom: 55px!important;
  right: 1%!important;
}
#topcontrol img{
  width:50px;
}


/*---------------------------------------------------------------------------------
エフェクト
--------------------------------------------------------------------------------- */
/* 画面外にいる状態 */
.effect {
  opacity : 0;
  transition : all 900ms 300ms ease-out;
  transform: translate(0,0);
}
/* 画面内に入った状態 */
.effect-on {
  opacity: 1.0;
  transform: translate(0,0px);
}


/* ************************************************ 
*	ヘッダー
* ************************************************ */
#header {
width: 100%;
margin: 0;
position: relative;
top:0;
left:0;
z-index: 99999;
}
.header-inner {
margin: 0 auto;
padding: 0;
height: 100px;
width: 95%;
position: relative;
z-index:9;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
align-items: center;
}

.logo-box {
margin: 0;
padding: 0;
width:250px;
}
.tel-box {
width:170px;
margin: 0 0 0 25px;
padding: 0;
}
.tel-box img{
vertical-align: bottom;
}

.nav-box {
margin: 0;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: flex-end;
align-items: center;
}

#header-top h1.logo,
#header h1.logo {
margin: 0;
padding: 0;
}
.logo img{ width: 100%;}

.logo-spbox {
text-align: left;
margin: 0;
padding: 0;
width: 65%;
position: relative;
z-index: 99999;
}
.logo-sp {
margin: 0;
padding: 0;
position:absolute;
top: 20px;
left: 15px;
font-weight: normal;
float: left;
}
.logo-sp img{
width: 100%;
}

.tel-spbox {
text-align: left;
margin: 0;
padding: 0;
position: relative;
z-index: 9999999;
}
.tel-sp {
margin: 0;
padding: 0;
position: absolute;
top: 20px;
right: 80px;
}
.tel-sp img{
width: 30px;
}


/* ************************************************ 
*	トップナビゲーション
* ************************************************ */	
#navDmy{
display:none !important;
}
#nav_bg {
width: 100%;
padding: 0px 0px 0px 0px;
position:fixed;
top:0;
left:0;
border-bottom: solid 5px #0068b6;
z-index: 99999;
background-color: #fff;
-moz-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-webkit-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-o-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
-ms-box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
box-shadow: 0px 2px 3px rgba(0,0,0,0.2);
}

.nav {
margin: 0 auto;
}

.nav ul {
list-style: none;
margin: auto;
letter-spacing: -0.5em; /* 隙間を埋める追加 */
}

.main-navigation {
clear: both;
margin: 0 auto;
position: relative;
}

ul.nav-menu,
div.nav-menu > ul {
margin: 0;
padding: 0;
}

.nav-menu li {
font-family: 'Noto Sans JP';
font-weight: 500;
display: inline-block;
position: relative;
margin: 0 12px;
padding: 0;
float: left; 
text-align:center;
letter-spacing: normal; /* 隙間を埋める追加 */
cursor: pointer;
cursor: hand;
}
.nav-menu li img{
vertical-align: bottom;
}
.nav-menu li:last-child {
margin: 0 0 0 12px;
}

.nav-menu li a {
color: #333;
display: block;
font-size: 16px;
text-decoration: none;
margin: 0;
padding: 8px 0 0 0;
}

.nav-menu li:last-child a {
color: #fff;
display: block;
font-size: 16px;
text-decoration: none;
margin: 2px 0 0 0;
padding: 6px 15px 8px 15px;
/* padding: 6px 30px 8px 30px; */
background-color: #0068b6;
border: 1px solid #0068b6;
}

.nav-menu li:last-child a span{
color: #fff;
font-size: 12px;
}

.nav-menu li:last-child a:after {
	content: '';
	width: 0;
	border-bottom: none;
	display: block;
	padding-bottom:0;
}
.nav-menu li:last-child a:hover {
color: #0068b6;
background-color: #fffbd0;
border: 1px solid #0068b6;
}
.nav-menu li:last-child a:hover span{
color: #0068b6;
}

.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #333;
}
.nav-menu li a:after {
	content: '';
	width: 0;
	transition: all 0.3s ease;
	border-bottom: 4px solid #0068b6;
	display: block;
	padding-bottom:10px;
}
.nav-menu li a:hover:after {
  width: 100%;
}

.nav-menu .sub-menu,
.nav-menu .children {
background-color: rgba(255,255,255,0);
display:none;
position: absolute;
z-index: 99999;
padding: 0 0 0 0;
}

.nav-menu .sub-menu li {
width: 215px;
padding: 0;
margin: 0;
border-left: none;
}

.nav-menu .sub-menu li a {
background:#0068b6;
color: #fff;
display: block;
font-size: 15px;
text-decoration: none;
padding: 15px 0 15px 15px;
text-align: left;
border-bottom: 1px solid #fff;
width: 200px;
}
.nav-menu .sub-menu li:last-child a {
color: #fff;
display: block;
font-size: 15px;
margin: 0;
padding: 15px 0 15px 15px;
text-align: left;
border: none;
}
.nav-menu .sub-menu li a:after {
content: '';
width: 0;
border-bottom: none;
display: block;
padding-bottom: 0;
}

.nav-menu .sub-menu ul {
}

ul.nav-menu ul a,
.nav-menu ul ul a {
color: #fff;
margin: 0;
}

ul.nav-menu ul a:hover,
.nav-menu ul ul a:hover,
.nav-menu .sub-menu li:last-child a:hover {
background-color: #fff;
color: #0068b6;
}

ul.nav-menu li:hover > ul,
.nav-menu ul li:hover > ul {
display: block;
}

.nav-menu .current_page_item > a,
.nav-menu .current_page_ancestor > a,
.nav-menu .current-menu-item > a,
.nav-menu .current-menu-ancestor > a {
}


/* ************************************************ 
*	スライド
* ************************************************ */	
@keyframes zoomUp { 
  0% {
      -webkit-transform: scale(1.2);
      transform: scale(1.2);
  }
  100% {
      -webkit-transform: scale(1);
      transform: scale(1);
  }
}

.swiper-container {
position: relative;
margin: 105px 0 0 0;
}
.swiper-slide {
  overflow: hidden;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}

.swiper-slide-active .slide-img,
.swiper-slide-duplicate-active .slide-img,
.swiper-slide-prev .slide-img { /* 8秒かけて拡大させる */
    -webkit-animation: zoomUp 8s linear 0s;
    animation: zoomUp 8s linear 0s;
    -webkit-animation-fill-mode: both;
    animation-fill-mode: both;
}

.swiper-pagination-bullets {
    bottom: 20px!important;
}
.swiper-pagination-bullet {
  border-radius: 0!important;
  margin: 0 5px!important;
  width: 25px!important;
  height: 5px!important;
}

.slide-img {
    background-size: cover; 
    background-position: center center; /* 背景画像は中央を軸に表示させる */
    height: calc(100vh - 105px); 
}

.slide-text {
position: absolute;
z-index: 10;
top: 50%;
left: 5%;
-webkit-transform: translateY(-50%);
-moz-transform: translateY(-50%);
-ms-transform: translateY(-50%);
-o-transform: translateY(-50%);
transform: translateY(-50%);
}
.slide-text h2{
font-family: 'Noto Sans JP';
white-space: nowrap;
letter-spacing: 0.05em;
font-size:2.8vw;
line-height: 150%;
color: #0068b6;
font-weight: 500;
/* text-shadow: 0px 0px 3px rgba(0,0,0,0.3); */
background:rgba(255,255,255,0.8);
padding: 0 0 0 15px;
border-radius: 10px; /* CSS3 */
}
.slide-text h2 span{
letter-spacing: -0.2em;
color: #0068b6;
}

.slide-time {
width: 33%;
position: absolute;
z-index: 10;
bottom: 160px;
right: 0;
background:rgba(255,255,255,0.8);
padding: 20px 20px 10px 20px;
border-radius: 10px 0 0 0; /* CSS3 */
}
.slide-time img{
vertical-align: bottom;
}


.slide-bg {
width: calc(33% + 40px);
height: 160px;
position: absolute;
z-index: 9;
bottom: 0;
right: 0;
background-color: rgba(255,255,255,0.8);
}



.top-news-box {
width: calc(100% - 40px);
padding: 0;
margin: 0 auto;
position: relative;
z-index: 99;
top: 40px;
left: 0;
}
.top-news {
box-sizing: border-box; 
width: 100%;
padding: 25px 0 0 0 ;
}
.top-news-ttl {
  box-sizing: border-box;
  width: 120px;
  height: 30px;
  padding-top: 9px;
  background-color: #0068b6;
  position: absolute;
  top: -20px;
  left: 0;
  margin: auto;
  font-family: 'Lato', sans-serif;
  font-size: 14px;
  line-height: 1;
  font-weight: 900;
  text-align: center;
  color: #fff;
}
.top-news-inner {
  width: 100%;
}
.top-news-item {
height: 75px!important;
overflow: hidden;
margin: 0;
}
.top-news-item__text {
  width: 80%; 
}
.top-news-item__date {
  width: 100%;
  padding-bottom: 5px;
  font-size: 15px;
  line-height: 1;
  font-weight: 900;
  color: #333;  
}
.top-news-item a { 
  color: #333;  
  display: block;
  width: 100%;
  font-size: 16px;
  line-height: 1.5;
  overflow: hidden;
  display: -webkit-box;
  text-overflow: ellipsis;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 2;
}
.top-news-item a:hover { 
  color: #0068b6; 
}


.slick-prev,
.slick-next {
width: 19px;
height: 8px;
position: absolute;
right: 0;
bottom: 0;
margin: auto;
text-indent: 100%;
white-space: nowrap;
overflow: hidden;
border: none;
cursor: pointer;
font-size: 0;
line-height: 0;
z-index: 999;
}
.slick-prev {
background:url("../meike/images/slider_prev.svg") no-repeat!important;
background-size: 100% auto;
top: -20px;
left: calc(100% - 119px);
}
.slick-next {
background:url("../meike/images/slider_next.svg") no-repeat!important;
background-size: 100% auto;
top: 20px;
right: 50px;
}

.top-news-vew-all {
box-sizing: border-box;
width: 130px;
padding: 10px 0;
font-size: 15px;
line-height: 1;
font-weight: 500;
color: #0068b6!important; 
text-align: center;
position: absolute;
right: 0;
top: -20px;
margin: auto;
}




/* ************************************************ 
*	パンくずリスト
* ************************************************ */	
.breadcrumbs {
width: 1120px;
max-width: 90%;
margin: auto; 
padding: 15px 0;
text-align:left;
font-size: 14px;
}
.breadcrumbs a{
color:#333;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
text-decoration: none;
}
.breadcrumbs a:hover{
color: #000;
text-decoration: underline;
}


/* ************************************************ 
*	はじめに
* ************************************************ */	
.top-lead-box {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
  padding: 100px 0 0 0;
}
.top-lead-box-inner {
position: relative;
width: calc(100% - 100px);
margin: 0;
padding: 50px;
}
.top-lead-box-inner::before {
position: absolute;
top: 0;
left: 10px;
transform: rotate(55deg);
height: 25px;
width: 25px;
background: #00aeeb;
content: '';
}
.top-lead-box-inner::after {
position: absolute;
transform: rotate(15deg);
top: 35px;
left: 0;
height: 14px;
width: 14px;
background: #00aeeb;
content: '';
}

.top-lead-box p{
font-size: min(2.0vw,18px);
line-height: 2;
margin: 0;
}


/* ************************************************ 
*	コンセプト
* ************************************************ */	
.concept-box {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
  padding: 100px 0;
}
.concept-box-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
}
.concept-box-inner__textbox {
width: 60%;
position:relative;
}
.concept-box-inner__textbox::after{
position:absolute;
bottom: 0;
right: 0;
content:"";
display:inline-block;
width:150px;
height:150px;
background:url("../meike/images/logo_bg.png") no-repeat;
background-size:contain;
opacity: 0.3;
z-index: -1;
}
.concept-box-inner__imgbox {
width: 35%;
}
.concept-title-box{
margin: 0 auto 70px auto;
text-align: center;
}
.concept-box h3{
font-size: min(3.6vw,36px);
font-weight: 500;
margin: 0 auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
display: inline-block;
}
.concept-box h3::after {
content: '';
display: inline-block;
position: absolute;
bottom: -15px;
left: 50%;
transform: translateX(-50%);
width: 60px;
height: 4px;
background-color: #0068b6;
}
.concept-box p{
font-size: min(2.0vw,18px);
line-height: 2;
margin: 0;
}


/* ************************************************ 
*	クリニック概要
* ************************************************ */	
.outline-box {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
  padding: 50px 0 100px 0;
}

.outline-box-inner {
position: relative;
width: calc(100% - 100px);
margin: 0;
padding: 50px 50px 0 50px;
}
.outline-box-inner::before {
position: absolute;
top: 0;
left: 0;
transform: rotate(55deg);
height: 35px;
width: 35px;
background: #00aeeb;
content: '';
border-radius: 50vh; /* CSS3 */
}
.outline-box-inner::after {
position: absolute;
transform: rotate(15deg);
top: 37px;
left: 30px;
height: 15px;
width: 15px;
background: #00aeeb;
content: '';
border-radius: 50vh; /* CSS3 */
}

.outline-title-box{
margin: 0 auto 40px auto;
text-align: center;
}
.outline-box h3{
font-size: min(3.6vw,36px);
font-weight: 500;
margin: 0 auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
display: inline-block;
}
.outline-box h3::after {
content: '';
display: inline-block;
position: absolute;
bottom: -15px;
left: 50%;
transform: translateX(-50%);
width: 60px;
height: 4px;
background-color: #0068b6;
}

.outline-box p{
font-size: min(2.0vw,18px);
line-height: 2;
margin: 0;
}


/* ************************************************ 
*	ごあいさつ
* ************************************************ */	
.greeting-box {
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
  padding: 50px 0 100px 0;
}
.greeting-box-inner {
margin: 0;
padding: 30px 0;
}
.greeting-box-inner__imgbox {
width: 100%;
margin: 0 auto 50px auto;
text-align: center;
}
.greeting-box-inner__imgbox img{
width: 20%;
border-radius: 50vh;
}
.greeting-box-inner__imgbox h4.license{
font-size: min(2.0vw,18px);
font-weight: 500;
margin: 15px auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
}
.greeting-box-inner__imgbox h4.doctorname{
font-size: min(2.6vw,24px);
font-weight: 500;
margin: 0 auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
}

.greeting-box-inner__textbox {
width: 100%;
margin: 0 0 70px 0;
}
.greeting-title-box{
margin: 0 auto 40px auto;
text-align: center;
}
.greeting-box h3{
font-size: min(3.6vw,36px);
font-weight: 500;
margin: 0 auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
display: inline-block;
}
.greeting-box h3::after {
content: '';
display: inline-block;
position: absolute;
bottom: -15px;
left: 50%;
transform: translateX(-50%);
width: 60px;
height: 4px;
background-color: #0068b6;
}

.greeting-box p{
font-size: min(2.0vw,18px);
line-height: 2;
margin: 0;
}
.greeting-box p span {
font-weight: 500;
color: #ff0000;
}
ol.greeting{
list-style-type: none;
padding: 0;
margin: 15px 0;
counter-reset: li;
padding: 15px 20px;
background-color: #fff;
border: 1px solid #0068b6;
}
ol.greeting li{
display: flex;
align-items: baseline;
font-size: min(2.0vw,18px);
line-height: 2;
padding: 0 0 0 0;
margin: 5px 0;
font-weight: 500;
}
ol.greeting li::before{
display: inline-block;
min-width: 1.5em;
margin-right: 5px;
border-radius: 50%;
background-color: #00aeeb;
color: #fff;
line-height: 1.5em;
text-align: center;
content: counter(li);
counter-increment: li;
}
.greeting-box-inner__keireki {
margin: 0;
}
.greeting-box-inner__keireki h4 {
font-size: min(2.1vw,21px);
margin: 0 0 30px 0;
padding: 0 0 20px 0;
letter-spacing: 0.05em;
font-weight: 500;
position: relative;
display: block;
}
.greeting-box-inner__keireki h4:after {
  position: absolute;
  bottom: 0;
  left: 0;
  width: 100%;
  height: 10px;
  content: '';
  background-image: -webkit-repeating-linear-gradient(135deg, #999, #999 1px, transparent 2px, transparent 5px);
  background-image: repeating-linear-gradient(-45deg, #999, #999 1px, transparent 2px, transparent 5px);
  background-size: 7px 7px;
  -webkit-backface-visibility: hidden;
  backface-visibility: hidden;
}


table.profile {
width: 100%;
margin: 0 0 70px 0;
padding: 0;
border: none;
border-collapse: collapse;
border-spacing: 0;
border-top: 1px solid #999;
}
table.profile tr {
border-bottom: 1px solid #999;
}
table.profile th {
padding: 20px 20px 19px 20px;
white-space: normal;
font-weight: normal;
vertical-align: top;
width: 15%;
text-align: left;
}
table.profile td {
text-align: left;
padding: 20px 20px 19px 20px;
white-space: normal;
vertical-align: top;
}

ul.profile{
box-sizing: border-box;
margin: 0;
padding: 0;
}
ul.profile li{
position:relative;
padding: 0 0 0 17px;
margin: 7px 0 7px 0px;
font-size: min(1.8vw,16px);
line-height: 1.8;
list-style: none;
text-align: left;
text-indent: 0;
}
ul.profile li:before{
counter-increment: list;
content: "";
display: block;
position: absolute;
left: 0px;
height: 10px;
width: 10px;
background: #00aeeb;
border-radius: 50%;
top: 13px;
-moz-transform: translateY(-50%);
-webkit-transform: translateY(-50%);
-o-transform: translateY(-50%);
-ms-transform: translateY(-50%);
transform: translateY(-50%);
}


/* ************************************************ 
*	Slide
* ************************************************ */
.topslider-box { margin: 0 0 100px 0; }
.slider-1 .slick-slide {
  width: 360px !important;
  height: 270px !important;
  position: relative;
  overflow: hidden;
}
.slider-1 .slick-slide img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}


/* ************************************************ 
*	3セクション
* ************************************************ */	
.section-box {
  display: flex;
  justify-content: center;
  align-items: center;
  align-content: center;
  flex-wrap: wrap;
  width: 100%;
  position: relative;
  z-index: 0;
background: linear-gradient(
    -45deg,
    #ececec 25%, #fff 25%,
    #fff 50%, #ececec 50%,
    #ececec 75%, #fff 75%,
    #fff
  );
background-size: 12px 12px;
}
.section-box-inner {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 1000px;
  max-width: 90%;
  margin: 0 auto;
  padding: 100px 0;
}
.section-box-inner .box{
width: calc(31% - 40px);
padding: 30px 20px;
text-align: center;
position: relative;
background-color: #fff;
box-shadow: 0 0 5px #ccc;
}
.section-box-inner .box .img-box{
width: 205px;
margin: 0 auto 65px auto;
}
.section-box-inner .box .img-box img{
vertical-align: bottom;
}
.section-box-inner .box .btn-box{
width: 54px;
margin: 0 auto;
position: absolute;
bottom: 20px;
left: 50%;
-webkit-transform: translateX(-50%);
-moz-transform: translateX(-50%);
-ms-transform: translateX(-50%);
-o-transform: translateX(-50%);
transform: translateX(-50%);
}

.section-box-inner .box h3.box1,
.section-box-inner .box h3.box2{
font-size: min(2.4vw,24px);
width: 100%;
font-weight: 500;
margin: 0 0 20px 0;
color: #333;
}
.section-box-inner .box h3.box3{
font-size: min(2.4vw,24px);
width: 100%;
font-weight: 500;
margin: 20px 0 30px 0;
color: #333;
}


/* ************************************************ 
*	各セクション
* ************************************************ */	
#box1,
#box2 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 1200px;
  max-width: 90%;
  margin: -80px auto 0 auto;
  border-bottom: 1px solid #b1b1b1;
  padding: 180px 0 100px 0;
}
#box3 {
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  width: 1200px;
  max-width: 90%;
  margin: -80px auto 0 auto;
  padding: 180px 0 100px 0;
}

#box1 .left-box,
#box2 .left-box,
#box3 .left-box{
width: 30%;
}

#box1 .left-box img,
#box1 .right-box img,
#box2 .left-box img,
#box2 .right-box img,
#box3 .left-box img,
#box3 .right-box img{
vertical-align: bottom;
}

#box1 .right-box,
#box2 .right-box,
#box3 .right-box{
width: 64%;
}

#box1 .right-box .lead-text,
#box2 .right-box .lead-text,
#box3 .right-box .lead-text{
font-size: min(2.0vw,18px);
line-height: 180%;
}
#box3 .right-box .lead-text span{
font-weight: 700;
}

.morelink {
margin: 0;
text-align:center;
width: 300px;
}
.morelink a{
color: #333;
background-color:#fff;
font-size: min(2.0vw,18px);
display: block;
padding: 15px 0;
line-height: 150%;
border: 1px solid #333;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.morelink a:hover{
color: #fff;
border: 1px solid #00aeeb;
background-color:#00aeeb;
}
.morelink a::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow.svg") no-repeat;
background-size:contain;
}
.morelink a:hover::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow-mo.svg") no-repeat;
background-size:contain;
}


/* ************************************************ 
*	トップお知らせ
* ************************************************ */
#topnewsbox_bg {
width: 100%;
padding: 90px 0;
margin: 0 auto;
background-color: #efefef;
}

.top-newsbox-title-box{
margin: 80px auto 50px auto;
text-align: center;
}

#topnewsbox_bg h2{
font-size: min(4.2vw,42px);
text-align: center;
margin: 0 auto 45px auto;
font-weight: 500;
color:#333;
}

#topnewsbox{
width: 860px;
max-width: calc(90% - 140px);
margin: 0 auto;
padding: 50px 70px;
background-color: #fff;
}

#topnewsbox ul{
float:left;
margin: 0 0 50px 0;
padding: 0 0 0 0;
width: 100%;
}

#topnewsbox li{
float:left;
margin: 0 0 0 0;
padding: 20px 0;
list-style: none;
width: 100%;
border-bottom: 1px solid #999;
}

#topnewsbox li a{
color:#333;
margin: 0 0 0 0;
padding: 0 0 0 0;
list-style: none;
line-height:180%;
text-decoration: none;
}

#topnewsbox li a:hover{
text-decoration:underline;
color:#000;
}

.item-title-news {
line-height: 150%;
margin: 0 0 0 0;
padding: 0 0 0 0;
}
.item-title-news span{
font-weight: 500;
margin: 0px 15px 0px 0px;
}

.top-alllink {
margin: 0 auto;
text-align:center;
width: 30%;
}
.top-alllink a{
color: #333;
background-color:#fff;
font-size: min(2.0vw,18px);
display: block;
padding: 10px 0;
line-height: 150%;
border: 1px solid #333;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.top-alllink a:hover{
color: #fff;
border: 1px solid #0068b6;
background-color:#0068b6;
}
.top-alllink a::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow.svg") no-repeat;
background-size:contain;
}
.top-alllink a:hover::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow-mo.svg") no-repeat;
background-size:contain;
}


/* ************************************************ 
*	トップ診療時間・休診日
* ************************************************ */
.top-openbox {
width: 100%;
padding: 100px 0;
margin: 0 auto;
background: linear-gradient(
    -45deg,
    #ececec 25%, #fff 25%,
    #fff 50%, #ececec 50%,
    #ececec 75%, #fff 75%,
    #fff
  );
background-size: 12px 12px;
}
.top-openbox-title-box{
margin: 0 auto 50px auto;
text-align: center;
}
.top-openbox h2{
font-size: min(3.6vw,36px);
font-weight: 500;
margin: 0 auto;
padding: 0;
color: #333;
text-align: center;
position: relative;
display: inline-block;
}
.top-openbox h2::after {
content: '';
display: inline-block;
position: absolute;
bottom: -15px;
left: 50%;
transform: translateX(-50%);
width: 60px;
height: 4px;
background-color: #0068b6;
}


.top-openbox-inner{
width: 1000px;
max-width: 90%;
margin: 0 auto;
padding: 0;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
}

.top-openbox-inner__timebox{
width: 70%;
}

.top-openbox-inner__timebox table{
margin: 0 0 10px 0;
border-collapse: separate;
border-spacing: 0;
border: 1px solid #0068b6;
}

.top-openbox-inner__timebox th{
border: 1px solid #0068b6;
color:#333;
font-weight: 500;
}
.top-openbox-inner__timebox th{
font-size: min(2.3vw,21px);
text-align: center;
margin:0 auto;
line-height: 1;
padding: 5px 0;
height: 60px;
width: 9%;
vertical-align: middle;
background-color: #efefef;
}

.top-openbox-inner__timebox td{
border: 1px solid #0068b6;
color:#0068b6;
font-weight: 500;
}
.top-openbox-inner__timebox td{
font-size: min(2.3vw,21px);
text-align: center;
margin:0 auto;
line-height: 1;
padding: 5px 0;
height: 60px;
vertical-align: middle;
background-color: #fff;
}
.top-openbox-inner__timebox th:first-child{
width: 23%;
}
.top-openbox-inner__timebox td span{
font-size: min(2.1vw,18px);
position:relative;
top: 0;
line-height:1;
}
.top-openbox-inner__timebox td.htime{
color:#333;
}

.top-openbox-inner__timebox p{
font-size: min(1.8vw,16px);
line-height: 150%;
}
.top-openbox-inner__timebox p.holiday{
font-size: min(1.8vw,16px);
font-weight: 500;
margin: 0 0 15px 0;
}
.top-openbox-inner__timebox p span{
font-size: min(1.8vw,16px);
color:#0068b6;
font-weight: 700;
}

.top-openbox-inner__daybox{
width: 25%;
margin: -38px 0 0 0;
}
.xo-event-calendar table.xo-month .month-dayname td div {
height: auto!important;
line-height: 1!important;
padding: 7px 5px!important;
}
.xo-event-calendar table.xo-month .month-event-space {
display: none!important;
}
.xo-event-calendar table.xo-month .month-dayname-space {
height: 30px!important;
}
.xo-event-calendar table th {
background-color: #efefef!important;
height: 20px!important;
padding: 3px 0 2px 0!important;
}


.reservelink-box {
display: flex;
justify-content: center;
flex-wrap: wrap;
margin: 50px auto 0 auto;
width: 100%;
}
.reservelink {
margin: 0;
text-align:center;
width: 300px;
}
.reservelink a{
color: #fff;
background-color:#0068b6;
font-size: min(2.0vw,18px);
display: block;
padding: 15px 0;
line-height: 150%;
border: 1px solid #0068b6;
text-decoration:none;
border-radius: 50vh; /* CSS3 */
 -webkit-border-radius: 50vh; /* Firefox */
 -moz-border-radius: 50vh; /* Safari,Chrome */
}
.reservelink a:hover{
color: #0068b6;
border: 1px solid #0068b6;
background-color: #fffbd0;
}
.reservelink a::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow-mo.svg") no-repeat;
background-size:contain;
}
.reservelink a:hover::after{
position:relative;
top: 2px;
right: -10px;
content:"";
display:inline-block;
width:7px;
height:15px;
background:url("../meike/images/more-arrow-yellow.svg") no-repeat;
background-size:contain;
}


/* ************************************************ 
*	トップアクセス
* ************************************************ */
#topaccess_bg {
width: 100%;
padding: 100px 0;
position: relative;
z-index:0;
}

#topaccess_bg .access-title-box{
margin: 0 auto 50px auto;
text-align: center;
}
#topaccess_bg .access-title h2{
font-size: min(3.6vw,36px);
text-align: center;
margin: 0 auto;
font-weight: 500;
color: #333;
position: relative;
z-index:99;
display: inline-block;
}
#topaccess_bg .access-title h2::after {
content: '';
display: inline-block;
position: absolute;
bottom: -15px;
left: 50%;
transform: translateX(-50%);
width: 60px;
height: 4px;
background-color: #0068b6;
}

#topaccess_bg .access-box {
margin: 0 0 0 10%; 
padding: 0;
width: 90%;
background-color: #fff;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
#topaccess_bg .access-box .accessbox-inner {
width: calc(35% - 20px);
margin: 0;
padding: 0 20px 0 0;
position: relative;
}

#topaccess_bg .access-box .accessbox-inner .tel-text{
font-size: min(3.3vw,33px);
font-weight: 500;
letter-spacing: 0.02em;
position: relative;
top: 0;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .tel-text2{
font-size: min(2.1vw,18px);
font-weight: 500;
position: relative;
top: -10px;
left: 32px;
line-height: 1.2;
}
#topaccess_bg .access-box .accessbox-inner .tel-text3{
font-size: min(2.1vw,18px);
font-weight: 500;
position: relative;
top: -10px;
left: 110px;
line-height: 1.2;
}
#topaccess_bg .access-box .accessbox-inner .tel-text4{
font-size: min(2.1vw,18px);
font-weight: 500;
position: relative;
top: -10px;
left: 54px;
line-height: 1.2;
}
#topaccess_bg .access-box .accessbox-inner .tel-text2 span,
#topaccess_bg .access-box .accessbox-inner .tel-text4 span{
font-size: min(1.6vw,14px);
font-weight: 500;
}
#topaccess_bg .access-box .accessbox-inner .tel-text::before{
position:relative;
top: 0;
left: -10px;
content:"";
display:inline-block;
width:25px;
height:25px;
background:url("../meike/images/icon_tel.svg") no-repeat;
background-size:contain;
}

#topaccess_bg .access-box .accessbox-inner .map-text{
font-size: min(2.1vw,18px);
position: relative;
top: 0;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .map-text2{
font-size: min(2.1vw,18px);
position: relative;
top: -5px;
left: 35px;
line-height: 1.5;
}
#topaccess_bg .access-box .accessbox-inner .map-text::before{
position:relative;
top: 15px;
left: -10px;
content:"";
display:inline-block;
width:25px;
height:30px;
background:url("../meike/images/icon_access.svg") no-repeat;
background-size:contain;
}

#topaccess_bg .access-box .accessbox-inner .park-text{
font-size: min(2.1vw,18px);
position: relative;
top: 0;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .park-text::before{
position:relative;
top: 5px;
left: -10px;
content:"";
display:inline-block;
width:25px;
height:35px;
background:url("../meike/images/icon_parking.svg") no-repeat;
background-size:contain;
}

#topaccess_bg .access-box .accessbox-inner .bus-text{
font-size: min(2.1vw,18px);
position: relative;
top: 0;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .bus-text::before{
position:relative;
top: 20px;
left: -10px;
content:"";
display:inline-block;
width:25px;
height:35px;
background:url("../meike/images/icon_bus.svg") no-repeat;
background-size:contain;
}
#topaccess_bg .access-box .accessbox-inner .bus-text2{
font-size: min(2.1vw,18px);
position: relative;
top: -5px;
left: 35px;
line-height: 1.5;
}
#topaccess_bg .access-box .accessbox-inner .accessbox-inner__img {
position: absolute;
left: 0;
bottom: 0;
width: calc(100% - 20px);
margin: 0;
padding: 0;
}
#topaccess_bg .access-box .accessbox-inner .accessbox-inner__img img{
vertical-align: bottom;
}

#topaccess_bg .access-box .map-box {
margin: 0; 
padding: 0;
width: 65%;
height: 600px;
}


/* ************************************************ 
*	フッター
* ************************************************ */
#footer {
clear:both;
width:100%;
background: #fff;
margin: 0 auto;
padding: 0 0 60px 0;
}
#footer .row{
margin-bottom: 0px;
}
.footer-inner {
margin: 0 auto;
width: 1000px;
max-width: 90%;
padding: 70px 0;
position:relative;
z-index:0;
}

.footer-navbox {
margin: 0;
padding: 0;
}
#topbox{
margin: 0 0 0 0;
padding: 0 0 0 0;
}
#topbox .footerlist {
margin: 0px 0px 0px 0px;
padding: 0px 0px 0px 0px;
}
#topbox .footerlist li{
margin: 0px 0px 0px 0px;
padding: 3px 0px 2px 0px;
line-height: 200%;
list-style: none;
border-bottom: none;
font-size:15px;
}
#topbox .footerlist li a{
font-size:15px;
color: #333;
display:inline-block;
}
#topbox .footerlist li a:hover{
color: #000;
text-decoration: underline;
}

#topbox ul.sub-menu {
margin-bottom: 0;
display: block;
padding: 0 0 0 0;
}
#topbox ul.sub-menu li {
padding: 0px 0px 0px 1em;
}

#topbox .footername {
float: right;
margin: 0;
padding: 0;
}
#topbox .footername p{
font-size:15px;
}
#topbox .footername span{
font-weight: 500;
}
#topbox .footername .footname{
font-size:16px;
}
#topbox .footername .footnamebig{
font-size:21px;
}

.foot-centerline {
border: 1px solid #0068b6;
width: 60px;
text-align: center;
margin: 0 auto;
}

.footer-inner a{
font-size:15px;
color: #333;
text-decoration: none;
}
.footer-inner a:hover{
color: #333;
text-decoration: underline;
}

#copyright {
font-size:14px;
text-align:center;
position: relative;
margin: 0 0 0 0;
padding: 30px 0;
}
#copyright a{
color:#333;
}
#copyright a:hover {
color: #000;
}

#footer-contactbox {
display:none;
}
/* 表示用 */
#footer-contactbox.active{
display:block;
transition: 0.5s;
}
/* 表示用ここまで */
#footer-contactbox {
position: fixed;
bottom: 0;
left: 0;
z-index: 999;
width: 100%;
margin: 0;
padding: 10px 0;
background-color: #0068b6;
}
.footer-contactbox-inner {
width: 800px;
max-width: 90%;
margin: 0 auto;
padding: 0;
display: flex;
flex-wrap: wrap;
justify-content: space-between;
}
.footer-contactbox-inner .contactbox{
width: 40%;
height: 40px;
margin: 0;
padding: 0;
background-color: #fff;
}
.footer-contactbox-inner .contactbox a{
text-decoration: none;
display: block;
background-color: #fff;
}
.footer-contactbox-inner .contactbox a:hover{
background-color: #fffbd0;
text-decoration: none;
}

.footer-contactbox-inner .foot-contacttel{
font-size: min(2.4vw,24px);
font-weight: 700;
margin: 0 auto;
text-align: center;
color: #0068b6;
line-height: 40px;
}
.footer-contactbox-inner .foot-contacttel::before{
position:relative;
top: 1px;
left: -7px;
content:"";
display:inline-block;
width:20px;
height:20px;
background:url("../meike/images/icon_foot_tel.svg") no-repeat;
background-size:contain;
}
.footer-contactbox-inner .foot-contactreserve{
font-size: min(2.1vw,21px);
font-weight: 500;
margin: 0 auto;
text-align: center;
color: #0068b6;
line-height: 40px;
}
.footer-contactbox-inner .foot-contactreserve span{
color: #0068b6;
}
.footer-contactbox-inner .foot-contactreserve span.preparation{
font-size: min(1.6vw,15px);
color: #0068b6;
}
.footer-contactbox-inner .foot-contactreserve::before{
position:relative;
top: 1px;
left: -7px;
content:"";
display:inline-block;
width:20px;
height:20px;
background:url("../meike/images/icon_foot_cal.svg") no-repeat;
background-size:contain;
}


/* ************************************************ 
*	ウィジット
* ************************************************ */
.widget{
margin: 0 0 0 0;
}
.textwidget{
font-size: 13px;
color: #444;
line-height:170%;
margin: 0 0 0 0;
padding: 5px 0 0 0;
}
#topbox li a{
font-size:13px;
color:#444;
margin: 0 0 0 0;
padding: 3px 0px 2px 0px;
list-style: none;
transition: 0.5s;
-webkit-transition: 0.5s;
-moz-transition: 0.5s;
-o-transition: 0.5s;
-ms-transition: 0.5s;
}
#topbox li a:hover{
color:#45AAB8;
}


/* ************************************************ 
*	サイドバー　新着表示
* ************************************************ */
#sidebar {
width: 100%;
margin: 0px 0px 40px 0px;
padding: 0 0 0 0;
}
.sidebar-title{
color: #333;
font-size: 16px;
font-weight: bold;
letter-spacing: 0.05em;
font-style:normal;
margin: 0px 0px 10px 0px;
padding: 0 0 0 0;
border-bottom:3px solid #ccc;
}
#sidebar li{
font-size: 13px;
margin: 0 0 0 0;
padding: 15px 0;
list-style: none;
border-bottom: 1px dotted #999;
}
#sidebox-new {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}
#sidebox-new li a:hover{
color:#6cbb63;
}
#sidebox-works {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}
#sidebox-works li{
font-size: 13px;
margin: 0 0 0 0;
padding: 5px 0;
list-style: none;
border-bottom: 1px dotted #999;
}
#sidebox-works li a{
color:#333;
}
#sidebox-works li a:hover{
color:#6cbb63;
}
#sidebox-archives {
margin: 0 0 50px 0 ;
padding: 0 0 0 0 ;
}


/* ************************************************ 
*	レスポンシブ
* ************************************************ */
/* PC 画面の横幅が1160px以上 */
@media only screen and (min-width: 1160px) {
iframe { width: 100%; height:100%; max-width: 100%; }
.logo-spbox { display: none; }
.tel-spbox { display: none; }
a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}
.show_sp { display: none; }

.nav-menu li:nth-child(6) { display: none; }

#topopen {
margin-top: -80px;
padding-top: 80px;
}
}


/* Tablet (Portrait) 画面の横幅が768px〜1159pxまで */
@media only screen and (min-width: 768px) and (max-width: 1159px) {
iframe { width: 100%; height:100%; max-width: 100%; }
.logo-spbox { display: none; }
.tel-spbox { display: none; }
.logo-box {
margin: 20px 0 0 0;
width: 170px;
}
#nav_bg { height: 100px; }
.nav-menu li { margin: 0 5px; }
.nav-menu li a{ font-size: 11px; }
.nav-menu li a:after { padding-bottom: 6px; }
.nav-menu li:nth-child(6) { display: none; }
.nav-menu li:last-child { margin: 0 0 0 0; }
.nav-menu li:last-child a {
font-size: 11px;
padding: 4px 10px 6px 10px;
}
.nav-menu .sub-menu li a {
font-size: 11px;
padding: 10px 0 10px 10px;
width: 150px;
}
.nav-menu .sub-menu li:last-child a {
font-size: 11px;
padding: 10px 0 10px 10px;
}

.tel-box {
width: 100px;
margin: 0 0 0 5px;
}

.swiper-container { margin-top: 100px; }
.slide-img { height: 35vh;  }
.slide-time {
width: 40%;
padding: 15px;
bottom: 140px;
}
.slide-bg {
width: calc(40% + 30px);
height: 140px;
}
.top-news-ttl {
width: 100px;
height: 30px;
padding-top: 9px;
top: -20px;
left: 0;
font-size: 12px;
}
.top-news-vew-all {
width: 80px;
padding: 10px 0;
font-size: 12px;
right: 0;
top: -20px;
}
.top-news-item__date { font-size: 12px; }
.top-news-item a { font-size: 13px; }
.slick-prev {
top: -20px;
left: calc(100% - 59px);
}
.slick-next {
top: 20px;
right: 20px;
}

.swiper-pagination-bullets { display: none; }


.top-lead-box { padding: 50px 0 0 0; }
.concept-box { padding: 50px 0; }
.outline-box { padding: 50px 0; }
.greeting-box { padding: 50px 0; }


.section-box-inner { padding: 70px 0; }
.section-box-inner .box{
width: calc(31% - 30px);
padding: 20px 15px;
}
.section-box-inner .box .img-box{
width: 80%;
}
.section-box-inner .box .btn-box{ width: 45px; }
.section-box-inner .box h3.box1,
.section-box-inner .box h3.box2{
font-size: 18px;
}
.section-box-inner .box h3.box3{
margin: 10px 0 35px 0;
font-size: 18px;
}

table.profile th {
padding: 20px 10px 19px 10px;
width: 15%;
}
table.profile td {
padding: 20px 10px 19px 10px;
}

#box1,
#box2,
#box3 {
  padding: 70px 0;
}
#box1 .left-box,
#box2 .left-box,
#box3 .left-box{
width: 25%;
}
#box1 .right-box,
#box2 .right-box,
#box3 .right-box{
width: 70%;
}
#box1 .right-box .lead-text,
#box2 .right-box .lead-text,
#box3 .right-box .lead-text{
font-size: 15px;
}

#topnewsbox_bg h2,
.top-openbox h2,
#topaccess_bg .access-title h2 {
font-size: 30px;
margin: 0 auto 20px auto;
}

#topnewsbox_bg { padding: 60px 0; }
#topnewsbox li { padding: 12px 0; }
.top-alllink { width: 40%; }

.top-openbox { padding: 60px 0; }
.top-openbox-inner__timebox p.holiday { font-size: 15px; }
.top-openbox-inner__timebox p { font-size: 15px; }
.top-openbox-inner__timebox th,
.top-openbox-inner__timebox td {
font-size: 18px;
height: 50px;
}

#topaccess_bg { padding: 60px 0; }
#topaccess_bg .access-box {
margin: 0 0 0 5%;
width: 95%;
}
#topaccess_bg .access-box .accessbox-inner {
width: calc(40% - 20px);
padding: 10px;
}

#topaccess_bg .access-box .accessbox-inner .tel-text{
top: 10px;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .tel-text2{
top: 0;
left: 30px;
}
#topaccess_bg .access-box .accessbox-inner .tel-text::before{
top: 0;
left: -10px;
}

#topaccess_bg .access-box .accessbox-inner .map-text{
top: 15px;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .map-text2{
top: 12px;
left: 35px;
}
#topaccess_bg .access-box .accessbox-inner .map-text::before{
top: 15px;
left: -10px;
}

#topaccess_bg .access-box .accessbox-inner .park-text{
top: 35px;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .park-text::before{
top: 5px;
left: -10px;
}

#topaccess_bg .access-box .accessbox-inner .bus-text{
font-size: min(2.1vw,18px);
position: relative;
top: 45px;
left: 10px;
}
#topaccess_bg .access-box .accessbox-inner .bus-text::before{
top: 20px;
left: -10px;
}
#topaccess_bg .access-box .accessbox-inner .bus-text2{
top: 42px;
left: 35px;
}
#topaccess_bg .access-box .map-box { width: 60%; }


#topbox .footername p { font-size: 13px; }
.footer-inner { padding: 50px 0; }
#topbox .footername .footnamebig { font-size: 18px; }
#topbox .footerlist li { padding: 0px 0px 0px 0px; }
#topbox .footerlist li a{ font-size: 13px; }
#copyright {
    font-size: 13px;
    padding: 20px 0;
}
.footer-inner a { font-size: 13px; }

a[href*="tel:"] {
pointer-events: none;
cursor: default;
text-decoration: none;
}
select {
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid #333;
  border-radius: 0px;
background-color: #fff;
padding: 5px;
font-size:14px;
}

#topcontrol{
  bottom: 30px!important;
  right: 5%!important;
}
#topcontrol img{
  width:50px;
}

.show_sp { display: none; }
#box1,
#box2,
#box3 {
margin: 0px auto 0 auto;
padding: 60px 0 50px 0;
}
}


/* Mobile (Portrait) 画面の横幅が767pxまで */
@media only screen and (max-width: 767px) {
body { font-size: 4vw; }
iframe { width: 100%; height:100%; max-width: 100%; }
.breadcrumbs { display: none; }
.header-inner { width: 90%; margin:auto;}
.logo-box { display:none; }
.tel-box { display:none; }
.nav-box { display:none; }
.swiper-container { margin-top: 0; }
.slide-img {
height: 35vh;
margin-top: 70px;
}
.slide-text {
top: 50%;
left: 50%;
-webkit-transform: translateX(-50%);
-moz-transform: translateX(-50%);
-ms-transform: translateX(-50%);
-o-transform: translateX(-50%);
transform: translateX(-50%);
}
.slide-text h2{ font-size:7vw; }
.slide-time { display:none; }
.slide-bg { display:none; }
.swiper-pagination-bullets { display:none; }

#navDmy{
display:none !important;
}
#nav_bg {
height: 70px;
padding: 0px;
background-color: #fff;
position: absolute;
}
/* 上部固定用 */
#nav_bg.active{
position: absolute;
}
/* 上部固定用ここまで */

.nav { float: none; text-align:center; width: 100%; padding: 0;}
.nav-menu li {
display: inline-block;
position: relative;
margin: 0 0;
padding: 0;
width: 100%;
z-index:99999;
text-align: left;
text-decoration: none;
border-bottom: none;
}
.nav-menu li:last-child {
display: block;
width: 100%;
padding: 0;
margin: 0;
}
.nav-menu li a {
background-color: #0068b6;
color: #fff;
display: block;
font-size: 4.5vw;
text-decoration: none;
border-bottom: 1px solid #fff;
}
.nav-menu li:hover > a,
.nav-menu li a:hover {
color: #fff;
}
.nav-menu li a:after { display: none; }

.nav-menu li:nth-child(5) { display: none; }
.nav-menu li:last-child a {
background-color: #0068b6;
color: #fff;
display: block;
font-size: 4.5vw;
}
.nav-menu li:last-child a span{
font-size: 3.5vw;
color: #fff;
}

.nav-menu .sub-menu {
display: block;
padding: 0;
position: relative;
z-index: 99999;
}
.nav-menu .sub-menu li {
width: 100%;
}
.nav-menu .sub-menu li a {
background:#fff;
color: #0068b6;
display: block;
font-size: 4.5vw;
text-decoration: none;
padding: 15px 0 13px 20px;
text-align: left;
width: calc(100% - 20px);
border-bottom: 1px solid #0068b6;
}
.nav-menu .sub-menu li:last-child a {
background:#fff;
color: #0068b6;
display: block;
font-size: 4.5vw;
text-decoration: none;
padding: 1.2em 10%;
text-align: left;
width: 80%;
border-bottom: none;
}
.nav-menu .sub-menu li:hover > a,
.nav-menu .sub-menu li a:hover {
color: #fff;
}

.top-lead-box { padding: 50px 0 0 0; }
.top-lead-box p{ font-size: 4.5vw; }
.top-lead-box-inner {
width: calc(100% - 30px);
margin: 0;
padding: 35px 15px 0 15px;
}

.concept-box { padding: 50px 0; }
.concept-title-box{ margin: 0 auto 30px auto; }
.concept-box h3 {
font-size: 7.5vw;
margin: 0 auto 20px auto;
}
.concept-box p { font-size: 4.5vw; }
.concept-box-inner__textbox { width: 100%; }
.concept-box-inner__imgbox {
width: 100%;
margin: 0 0 20px 0;
}
.concept-box-inner__textbox::after{
bottom: 0;
right: 0;
width:100px;
height:100px;
}

.outline-box { padding: 50px 0; }
.outline-title-box{ margin: 0 auto 0 auto; }
.outline-box h3 {
font-size: 7.5vw;
margin: 0 auto 20px auto;
}
.outline-box p { font-size: 4.5vw; }
.outline-box-inner {
width: calc(100% - 30px);
margin: 0;
padding: 50px 15px 0 15px;
}
.outline-box-inner::before {
height: 30px;
width: 30px;
}
.outline-box-inner::after {
top: 30px;
left: 25px;
}

.greeting-box {
padding: 0 0 0 0;
}
.greeting-box h3 {
font-size: 7.5vw;
margin: 0 auto 20px auto;
}
.greeting-box-inner {
padding: 0 0 30px 0;
}
.greeting-box-inner__imgbox img {
width: 60%;
}
.greeting-box-inner__imgbox h4.license {
font-size: 4.5vw;
margin: 15px auto;
line-height: 1.6;
}
.greeting-box-inner__imgbox h4.doctorname {
font-size: 5.5vw;
}
.greeting-box-inner__textbox {
margin: 0 0 50px 0;
}
.greeting-box p {
font-size: 4.5vw;
}
ol.greeting {
padding: 15px 10px 0 10px;
}
ol.greeting li {
font-size: 4.5vw;
line-height: 1.6;
margin: 0 0 15px 0;
}
ul.profile{
box-sizing: border-box;
margin: 0;
padding: 0;
background-color: #fff;
}
ul.profile li {
font-size: 4vw;
line-height: 1.6;
margin: 0 0 15px 0;
}



.greeting-box-inner__keireki h4 {
font-size: 5vw;
}

.section-box-inner { padding: 50px 0 40px 0; }
.section-box-inner .box{
width: calc(100% - 30px);
padding: 20px 15px;
margin: 0 auto 30px auto;
}
.section-box-inner .box .img-box{
width: 65%;
margin: 0 auto 75px auto;
}
.section-box-inner .box .btn-box{ width: 55px; }
.section-box-inner .box h3.box1,
.section-box-inner .box h3.box2,
.section-box-inner .box h3.box3{
font-size: 6vw;
}
.section-box-inner .box h3.box3{ margin: 0 0 20px 0; }

table.profile th {
padding: 10px 0 0 0;
width: 100%;
display: block;
}
table.profile td {
padding: 0 0 10px 0;
width: 100%;
display: block;
}

#box1,
#box2,
#box3 {
padding: 50px 0 30px 0;
}
#box1 .left-box,
#box2 .left-box,
#box3 .left-box{
width: 100%;
text-align: center;
}
#box1 .left-box img,
#box2 .left-box img,
#box3 .left-box img{
width: 60%;
margin: 0 0 20px 0;
}
#box1 .right-box,
#box2 .right-box,
#box3 .right-box{
width: 100%;
margin: 0 auto;
}
#box1 .right-box .lead-text,
#box2 .right-box .lead-text,
#box3 .right-box .lead-text{
font-size: 5vw;
}
.morelink { width: 100%; }
.morelink a {
font-size: 5vw;
padding: 15px 0;
}

#topnewsbox_bg { padding: 50px 0; }
#topnewsbox_bg h2,
.top-openbox h2,
#topaccess_bg .access-title h2 {
font-size: 7.5vw;
margin: 0 auto 20px auto;
}
#topnewsbox {
max-width: calc(90% - 30px);
padding: 15px 15px 30px 15px;
}
#topnewsbox ul { margin: 0 0 30px 0; }
#topnewsbox li { padding: 15px 0; }
.top-alllink { width: 100%; }
.top-alllink a { font-size: 4vw; }
.alllink a{ display: block; }


.topslider-box { margin:20px 0 50px 0; }

.top-openbox { padding: 50px 0; }
.top-openbox-title-box{ margin: 0 auto 30px auto; }
.top-openbox-inner__timebox th{
font-size: 4.5vw;
height: 30px;
}
.top-openbox-inner__timebox td{
font-size: 4.5vw;
padding: 5px 0;
height: auto;
}
.top-openbox-inner__timebox td span{
font-size: 3.5vw;
position:relative;
top: 0;
}

.top-openbox-inner__timebox p{ font-size: 4.5vw; }
.top-openbox-inner__timebox p.holiday{ font-size: 4.5vw; }
.top-openbox-inner__timebox p span{ font-size: 4.5vw; }

.reservelink { width: 100%; }
.reservelink a {
font-size: 5vw;
padding: 15px 0;
}

.top-openbox-inner__timebox{
width: 100%;
margin: 0 0 50px 0;
}
.top-openbox-inner__daybox{
width: 100%;
margin: 0 0 0 0;
}


#topaccess_bg { padding: 50px 0 0 0; }
#topaccess_bg .access-title-box{ margin: 0 auto 30px auto; }
#topaccess_bg .access-box {
margin: 0 auto;
width: 90%;
}
#topaccess_bg .access-box .accessbox-inner {
width: 90%;
margin: 0 auto;
padding: 0;
}

#topaccess_bg .access-box .accessbox-inner .tel-text {
font-size: 7vw;
top:0;
left:0;
}
#topaccess_bg .access-box .accessbox-inner .tel-text a{
color: #333;
text-decoration: none;
}
#topaccess_bg .access-box .accessbox-inner .tel-text::before {
left: -10px;
width: 20px;
height: 20px;
}
#topaccess_bg .access-box .accessbox-inner .tel-text2 {
font-size: 4.5vw;
top:-5px;
left:10px;
width:calc(100% - 10px)
}
#topaccess_bg .access-box .accessbox-inner .tel-text2 span {
font-size: 4vw;
}
#topaccess_bg .access-box .accessbox-inner .tel-text3 {
font-size: 4.5vw;
top:-5px;
left:95px;
width:calc(100% - 95px)
}
#topaccess_bg .access-box .accessbox-inner .tel-text4 {
font-size: 4.5vw;
top:-5px;
left:35px;
width:calc(100% - 35px)
}
#topaccess_bg .access-box .accessbox-inner .tel-text4 span {
font-size: 4vw;
}

#topaccess_bg .access-box .accessbox-inner .map-text {
font-size: 4.5vw;
top:10px;
left:0;
}
#topaccess_bg .access-box .accessbox-inner .map-text::before {
top: 10px;
left: -10px;
width: 20px;
height: 25px;
}
#topaccess_bg .access-box .accessbox-inner .map-text2 {
font-size: 4.5vw;
top:5px;
left:20px;
}
#topaccess_bg .access-box .accessbox-inner .park-text {
font-size: 4.5vw;
top:15px;
left:0;
}
#topaccess_bg .access-box .accessbox-inner .park-text::before {
top: 5px;
left: -10px;
width: 20px;
height: 30px;
}
#topaccess_bg .access-box .accessbox-inner .bus-text {
font-size: 4.5vw;
top:20px;
left:0;
}
#topaccess_bg .access-box .accessbox-inner .bus-text2 {
font-size: 4.5vw;
top:18px;
left:20px;
padding-bottom: 15px;
}
#topaccess_bg .access-box .accessbox-inner .bus-text::before {
top: 15px;
left: -10px;
width: 20px;
height: 30px;
}
#topaccess_bg .access-box .accessbox-inner .accessbox-inner__img {
position: relative;
left: 0;
bottom: 20px;
width: 110%;
margin: 0 0 0 -5%;
padding: 40px 0 0 0;
}
#topaccess_bg .access-box .map-box {
width: 100%;
height: 400px;
margin: 30px 0 0 0;
}

.alllink a{ display: block; }

.sidebar-title{ font-size: 4.5vw; }
table.similar-side td{ font-size: 4vw; }

.footer-inner { padding: 50px 0 50px 0; }
#topbox .footername p{
font-size: 4vw;
}
.footer-inner a {
font-size: 4vw;
}
#topbox .footerlist li a {
font-size: 4vw;
padding: 5px 0px 5px 0px;
}

#topbox .footername {
margin: 30px 0 0 0;
float: left;
}

#copyright {
font-size: 3.5vw;
padding: 30px 0;
line-height: 150%;
}

.footer-contactbox-inner .contactbox {
width: 49%;
height: 40px;
}
.footer-contactbox-inner .foot-contacttel {
font-size: 5.5vw;
line-height: 40px;
}
.footer-contactbox-inner .foot-contacttel::before {
top: 1px;
left: -5px;
width: 17px;
height: 17px;
}
.footer-contactbox-inner .foot-contactreserve {
font-size: 4.25vw;
line-height: 40px;
}
.footer-contactbox-inner .foot-contactreserve span.preparation{
font-size: 3vw;
}
.footer-contactbox-inner .foot-contactreserve::before {
top: 2px;
left: -3px;
width: 16px;
height: 16px;
}


/* topcontrol ====================*/
#topcontrol{
  bottom: 65px!important;
  right: 5%!important;
}
#topcontrol img{
  width:50px;
}

select {
  -webkit-appearance: none;
  appearance: none;
  border: 1px solid #333;
  border-radius: 0px;
background-color: #fff;
padding: 5px;
font-size:4vw;
}
.show_pc { display: none; }
#box1,
#box2,
#box3 {
margin: 0px auto 0 auto;
padding: 60px 0 50px 0;
}
}
