body{
font-family: "FOT-筑紫A丸ゴシック Std R", 游ゴシック体, YuGothic, 游ゴシック, "Yu Gothic", メイリオ, sans-serif;
line-height: 1.5;
overflow-x: hidden; 
}
a{
color: rgba(4,100,104,1.00)
}
a:hover{
opacity: 0.7;         /* カーソル時透明度 */
}
.stress{
font-weight: bold;
color: #073a68;
}
/* 見出しデザイン */
h1{
border-bottom: dotted 4px #00ADC9;
font-size: 30px;
text-align: center;
font-weight: bold;
color: #033D7A;
} 
h1::before {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 50px;/*画像の幅*/
height: 50px;/*画像の高さ*/
background-image: url("../img/img01.png");
background-size: contain;
vertical-align: middle;	
}

h1::after {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 50px;/*画像の幅*/
height: 50px;/*画像の高さ*/
background-image: url("../img/img01-r.png");
background-size: contain;
vertical-align: middle;	
}
h2{
font-size: 30px;       /* 文字サイズ指定 */
position:  relative;    /* 位置調整 */
font-weight: bold;   /* 文字の太さ調整 */
margin-bottom: 25px;    /* 周りの余白指定 */
margin-top: 10px;
border-bottom:  dashed #00ADC9;  /* 線指定 */
border-radius: 0px 0px 160px 180px/0px 0px 20px 4px;    /* 角丸指定 */
text-align: center;
padding-top: 30px; 
color: #033D7A;
}
h2::before {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 50px;/*画像の幅*/
height: 50px;/*画像の高さ*/
background-image: url("../img/img02.png");
background-size: contain;
vertical-align: middle;	
}
h2::after {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 50px;/*画像の幅*/
height: 50px;/*画像の高さ*/
background-image: url("../img/img03.png");
background-size: contain;
vertical-align: middle;	
}
h3{
padding-top: 30px;
font-size: 30px;
text-align: center;
font-weight: bold;
color: #033D7A;
}
h3 span {
display: block;/* ブロック要素にする */
font-size:  20px;       /* 文字サイズ指定 */
color: #00ADC9;
line-height: 1;
padding-top: 5px;
}
h4 {
font-size: 20px;        /* 文字サイズ指定 */
text-align:  center;    /* 文字位置指定 */
color: #033D7A;
font-weight: bold;
border-bottom: 5px solid #F9E034;
}
h4 span {
display: block;/* ブロック要素にする */
font-size:  20px;       /* 文字サイズ指定 */
color: #DD3166;
line-height: 1;
}
h5{
font-size: 110%;       /* 文字サイズ指定 */
position:  relative;    /* 位置調整 */
font-weight: bold;   /* 文字の太さ調整 */
border-bottom:  dashed #00ADC9;  /* 線指定 */
border-radius: 0px 0px 160px 180px/0px 0px 20px 4px;    /* 角丸指定 */
color: #033D7A;
}
h5::before {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 25px;/*画像の幅*/
height: 25px;/*画像の高さ*/
background-image: url("../img/img02.png");
background-size: contain;
vertical-align: middle;	
}
h5::after {
content: '';/*何も入れない*/
display: inline-block;/*忘れずに！*/
width: 25px;/*画像の幅*/
height: 25px;/*画像の高さ*/
background-image: url("../img/img03.png");
background-size: contain;
vertical-align: middle;	
}
/* リンクボタン */
.menu{
width: auto;
font-weight: bold;
text-align: center;
padding-bottom: 10px;
padding-top: 15px
}
nav {
background: #bad88d;
}
nav ul {
display: flex;
flex-flow: row;
justify-content: center;
margin: 0;
padding: 3px 7px;
align-items: center;
white-space: nowrap;
}
.menu nav ul li a {
display:block;
}
.menu nav ul li a dl {
display: flex;
align-items: center;
padding-left: 3px;
}
.menu nav ul li a dl dt img{
height: 30px;
}
.menu nav ul li a dl dd {
font-size:110%;
margin: 0 5px;
font-weight: bold;
}
nav li+ li {
border-left: 2px dashed #ffffff;
}
nav a{
padding: 2px 7px;
position: relative;
display: inline-block;
text-decoration: none;
}
nav a:hover{
background: #ffffff;
}
nav a::after {
position: absolute;
bottom: -2px;
left: 0;
content: '';
width: 100%;
height: 3px;
background: rgba(247,9,61,1.00);
transform: scale(0, 1);
transform-origin: center top;
transition: transform .3s;
}
nav a:hover::after {
transform: scale(1, 1);
}
/* TOP画面 */
.top{
position: relative;
}
.top-logo img{
width: 100%;
text-align: center;
height: 100px
}
.top-logo{
position: absolute;
left: 2%;
top: 10px;
}
.hato{
position: absolute;
top: 0%;
left: 8%;
overflow: visible;
}
.caltitle2 {
font-size: 75%;;
width: 100%;
padding: 5px;
margin: 5px auto;
}
.caltitle2_sp{
display: none;
}
.top_box{
display: flex;
flex-direction: column;
position: absolute;
top:5%;
right: 1%;
width: 60%;
padding: 20px 10px;
/*	min-width: 270px; */
background-color: rgba( 255, 255, 255, 0.5);
}
.flexcal{
display: flex;
flex-direction: row;
justify-content: space-around;
align-items: center;
width: 100%;
}
.flexcal section{
width: 48%;
}
.weeknews{
width: 95%;
margin: 5px auto;
}
.weekbox{
width: 100%;
margin: 0 auto;
background: #ffffff;
padding: 10px;
border-radius: 5px;
}
p.weektext{
font-size: 85%;
padding: 10px 5px 5px 5px;
}
.tenmetu{
background: rgba(251,3,7,1.00);
color: #ffffff;
font-size: 60%;
padding: 5px;
font-weight: bold;
animation: flash 3s linear infinite;
}
@keyframes flash {
0% {
opacity: 1;
}
50% {
opacity: 0;
}
100% {
opacity: 1;
}
}
/* contener */
.contener2{
margin-bottom: 40px;
background: rgba(156,224,253,0.2);
padding-top: 50px;
padding-bottom: 40px;
}
.contener3{
margin-bottom: 60px;
}
.contener4{
background: rgba(156,224,253,0.2);
padding-top: 30px;
padding-bottom: 50px;
}
.contener5{
background: rgba(156,224,253,0.2);
padding-bottom: 70px;
}
.contener6{
margin-top: 60px;
margin-bottom: 50px;
}
.contener7{
margin-top: 30px;
margin-bottom: 30px;
}
.contener8{
margin-top: 30px;
margin-bottom: 100px;
}
/* 最新のお知らせ */
.infobox{
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
} 
.infobox01{
width: 65%;
}
.text{
padding: 5px 10px;
background: #ffffff;
border-radius: 10px;
border: solid 4px rgba(156,224,243,0.85);
box-shadow: 2px 2px 4px gray;
height: 250px;/*スクロールの高さ*/
overflow-y: scroll;
margin: 20px auto 20px;
}
.info-img{
width: 20%;
margin-left: 1%;
}
.info-img img{
width: 100%;
height:auto;
}
.topic{
font-weight: bold;
color: #073a68;
font-size: 105%;
padding: 8px 0;
}
.text ul{
padding: 10px;
}
.text li {
line-height:1.2;
border-bottom: 1px dashed rgba(135,210,247,1.00);
list-style-position: inside;
padding: 5px 0;
}
.text li.last{
border-bottom: none;
}
/* 診療案内 */
.schedule{
color: #004098;
font-weight: bold;
width: 80%;
text-align: center;
margin: 10px auto;
} 
.schedule section{
display: inline-block;
max-width: 1400px;	
}
/* 診療案内表 */
.schedule table.table01 {
width: 100%;
border-right: #9CC9EF solid 2px;
border-left: #9CC9EF solid 2px;
border-collapse: collapse;
 border-spacing: 0;
border: solid 2px #9CC9EF;
margin: 0 auto;
}
.schedule table.table01 thead th {
background: #073a68;
color: #ffffff;
padding: 10px 15px;
border-right: #9CC9EF solid 2px;
border-bottom: #9CC9EF solid 2px;
vertical-align: middle;
}
.schedule table.table01 thead th:last-child {
border-right: #9CC9EF solid 2px;
}
.schedule table.table01 tbody th {
background: #073a68;
color: #ffffff;
padding:10px 20px;
border-bottom: #9CC9EF solid 2px;
border-color: #9CC9EF solid 2px;
vertical-align: middle;
}
.schedule table.table01 tbody tr:last-child th {
border-bottom: #9CC9EF solid 2px;
}
.schedule table.table01 tbody td{
padding: 10px 20px;
border-left: #9CC9EF solid 2px;
border-bottom: #9CC9EF solid 2px;
background: #ffffff;
vertical-align: middle;
}
.schedule-img{
display: none;
}
.schedule-sent{
width: 80%;
text-align: center;
margin: 20px auto;
}
.schedule-sent section{
display: inline-block;
max-width: 1400px;	
}
.schedule-sent ul{
text-align: left;
padding: 10px 15px;
border-radius: 10px;
box-shadow: 0 1px 1px rgba(0,0,0,0.2);
background: #F4F9FD;
}
.schedule-sent li {
line-height:2.0em;
border-bottom: 2px dashed rgba(135,210,247,1.00);
list-style-position: inside;
padding-top: 5px;
}
.schedule-sent li.last{
border-bottom: none;
}
.schedule-sent img{
width: 50%;
}
/* 院長挨拶ここから*/
.greeting{
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.greeting-text{
padding: 10px;
width: 60%;
}
.greeting-img{
width: 20%;
margin-left: 1%;
}
.greeting img{
width: 100%;
height:auto;
}
.greeting p{
padding: 10px 15px;
background: #ffffff;
border-radius: 10px;
box-shadow: 0 1px 1px rgba(0,0,0,0.2);
}
.name {
position: relative;
padding: 0.6em;
background: #ffffff;
margin-top: 10px;
margin-bottom: 20px;
display :inline-block;
box-shadow: 0 1px 1px rgba(0,0,0,0.2);
}
.name:after {
position: absolute;
content: '';
top: 100%;
left: 30px;
border: 15px solid transparent;
border-top: 15px solid #ffffff;
width: 0;
height: 0;
}

/* 当院紹介ここから*/
.clinic{
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.clinic-text{
padding: 10px;
max-width: 40%;
background: url("../img/clinic02.png") center top/cover no-repeat;
height: 300px;
}
.clinic-img{
width: 40%;
margin-right: 1%;
}
.clinic-img img{
width: 100%;
height:auto;
}
.clinic p{
padding: 5px 25px;
margin-top: 5px;
}
/*  ワクチン・健診 */
.vaccine {
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.vaccine_box{
padding: 10px;
width: 25%;
border-radius: 10px;
border: solid 4px rgba(156,224,243,0.85);
box-shadow: 2px 2px 4px gray;
margin: 10px 20px;
}
.vaccine_box img{
width: 100%;
}
.vaccine_box p{
margin: 0 auto;
padding: 10px;
text-align: left;
font-size: 90%;
}
a.btn{
display: inline-block;
text-align: center;
width: 100%;
max-width: 700px;
background-image: linear-gradient( #ddeef2 0%, #a8d6e0 100%);
border-radius: 5px;
padding: 10px 0;
 color: #0386DA;
text-decoration: none;
font-weight: bold;
font-size: 115%;
margin: 10px auto;
}
/*ゆらゆらぼたん*/
.yureru:hover {
animation: yureru 2s infinite;
}
@keyframes yureru {
0% {
transform: translate(2px, 0px);
}
5% {
transform: translate(-2px, 0px);
}
10% {
transform: translate(2px, 0px);
}
15% {
transform: translate(-2px, 0px);
}
20% {
transform: translate(2px, 0px);
}
25% {
transform: translate(-2px, 0px);
}
30% {
transform: translate(0px, 0px);
}
}
/*  アクセスここから */
.acc{
width: 80%;
text-align: center;
margin: 20px auto;	
}
.acc　section{
display: inline-block;
max-width: 1200px;
}
.access{
max-width: 100%;
height: 0;
overflow: hidden;
padding-bottom: 45%;
position: relative;
clear: both;
margin-top: 3em;
margin-bottom: 3em;
}
.access iframe {
position: absolute;
left: 0;
top: 0;
height: 100%;
width: 100%;
}
.acc-box{
display: flex;
flex-direction: row;
justify-content: center;
align-items: center;
}
.acc-img{
width: 35%;
margin-left: 1%;
}
.acc-text{
padding: 10px;
width: 40%;
}
.acc-img img{
width: 100%;
height:auto;
}
.acc-box ul{
padding: 10px 15px;
background: #F4F9FD;
border-radius: 10px;
box-shadow: 0 1px 1px rgba(0,0,0,0.2);
}
.acc-box li {
line-height:2.0em;
border-bottom: 2px dashed rgba(135,210,247,1.00);
list-style-position: inside;
padding-top: 5px;
}
.acc-box li.last{
border-bottom: none;
}


/*仕切り線*/
.part01{
min-height: 100px;	background: #ffffff url("../img/part01.png") center top/cover no-repeat;
width: 100%;
margin:03 auto;
position: relative;
}
#page_top {
position: fixed;
bottom: 30px;
right: 20px;
cursor: pointer;
}

/*　フッター　*/
footer{
background: url("../img/footer-bg.jpg")center top/cover no-repeat;
text-align: center;
padding: 30px;
}
.top-ss{
display: none;
}
@media screen and (max-width: 1096px){
.top_box{
display: flex;
flex-direction: column;
position: absolute;
top: 10%;
right: 1%;
width: 50%;
padding: 20px 10px;
/*	min-width: 270px; */
background-color: rgba( 255, 255, 255, 0.5);
}
.flexcal{
flex-direction: column;
justify-content: center;
align-items: center;
}
.flexcal section{
width: 80%;
}
.weeknews{
width: 95%;
margin: 5px auto;
}
.weekbox{
width: 100%;
margin: 0 auto;
background: #ffffff;
padding: 10px;
border-radius: 5px;
}
p.weektext{
font-size: 85%;
padding: 15px 5px 5px 5px;
}
.tenmetu{
background: rgba(251,3,7,1.00);
color: #ffffff;
font-size: 60%;
padding: 5px;
font-weight: bold;
 animation: flash 3s linear infinite;
}
.caltitle2{
display: none;
}
.caltitle2_sp{
display: block;
font-size: 75%;
width: 100%;
padding: 5px;
margin: 5px auto;
}
h5{
font-size: 100%;       /* 文字サイズ指定 */
font-weight: bold;   /* 文字の太さ調整 */
border-bottom:  dashed #00ADC9;  /* 線指定 */
border-radius: 0px 0px 160px 180px/0px 0px 20px 4px;    /* 角丸指定 */
}
h5::before {
content: none;
}
h5::after {
content: none;/*何も入れない*/
}
}
/*iPadサイズ*/
@media screen and (max-width: 768px){
.menu,.part01{
display: none;
}
h1,h2,h3,h4{
font-size: 20px;
}
h3 span {
font-size:  16px;    
}
h5{
font-size: 100%;       /* 文字サイズ指定 */
font-weight: bold;   /* 文字の太さ調整 */
border-bottom:  dashed #00ADC9;  /* 線指定 */
border-radius: 0px 0px 160px 180px/0px 0px 20px 4px;    /* 角丸指定 */
}
h5::before {
content: none;
}
h5::after {
content: none;/*何も入れない*/
}
/* TOP画面 */
.top{
position: static;
}
.top-logo{
display: none;
}
.hato{
display: none;
}
.top-logosoga{
position: absolute;
left: 2%;
top: 10px;
}
.top_box{
position: static;
width: 95%;
padding: 0px;
margin: 0 auto;
flex-direction: column-reverse;
}
.flexcal{
flex-direction: column;
justify-content: center;
align-items: center;
width: 90%;
	margin: 0 auto;
}
.flexcal section{
width: 100%;
}
.weeknews{
width: 98%;
margin: 0 auto;
}
.weekbox{
width: 95%;
margin: 5px auto;
background: #E0EFFB;
padding: 5px;
border-radius: 5px;
}
p.weektext{
font-size: 85%;
padding: 15px 5px 5px 5px;
}
.tenmetu{
background: rgba(251,3,7,1.00);
color: #ffffff;
font-size: 60%;
padding: 5px;
font-weight: bold;
 animation: flash 3s linear infinite;
}
/*コンテナ*/	
.contener2{
padding-top: 10px;
margin-bottom: 20px;
}
.contener3{
margin-bottom: 20px;
padding-bottom: 25px;
}	
.contener4{
padding-top: 20px;
padding-bottom: 20px;
}
.contener5{
padding-bottom: 20px
}
.contener6{
margin-top: 20px;
margin-bottom: 20px;
}
/* 最新のお知らせ */
.infobox{
display: flex;
flex-direction: column;
} 
.infobox01{
padding: 6px;
width: 95%;
}
.text{
height: 250px;/*スクロールの高さ*/
font-size: 85%;
}
.info-img{
width: 45%;
}
.info-img img{
width: 100%;
}
/* 診療案内表 */
.schedule{
width: 100%;
}
.schedule-sent{
width: 95%;
}
table.table01{
display: none;
}
.schedule-img{
display: block;
}
.schedule-img img{
width: 100%;
}
.schedule-sent img{
width: 80%;
}
/* 院長挨拶ここから*/
.greeting{
flex-direction: column;
}
.greeting-text{
width: 90%;
}
.greeting-img{
width: 30%;
margin-right: 0;
}
/* 当院紹介ここから*/
.clinic{
flex-direction: column-reverse;
}
.clinic-text{
padding: 10px;
max-width: 90%;
}
.clinic-img{
width: 90%;
margin-right: 0;
}
/*  ワクチン・健診 */
.vaccine {
flex-direction: column;
}
.vaccine_box{
padding: 10px;
width: 90%;
border: solid 3px rgba(156,224,243,0.85);
box-shadow: 1px 1px 2px gray;
}
.vaccine_box p{
margin: 0;
padding: 10px;
text-align: left;
}
/*  アクセスここから */
.acc,.acc-box{
width: 100%;
flex-direction: column;
}
.acc-img{
width: 85%;
}
.acc-text{
width: 90%;
}
.acc-box ul{
padding: 10px 15px;
}
.footer img{  
width: 50%;
}
}
/*スマホサイズ*/
@media only screen and (max-width:479px) {
.footer img{  
width: 80%;
}
.schedule-sent img{
width: 100%;
}	
#page_top {
position: fixed;
bottom: 15px;
right: 10px;
cursor: pointer;
opacity: 0.7;
}
}
