@charset "utf-8";
/* CSS Document */
html { scroll-behavior: smooth;}
body{
	font-family: 'Noto Sans JP', sans-serif; /*ゴシック*/
	font-size:14px;
	font-weight: 400;
	background:#ffffff;
	line-height: 1.6em;
	overflow-x: hidden!important;
}
dl li{
	display: inline-block;
}
.sp_wrap{
	position: absolute;
	left:0;
	top:0;
	width:100%;
	height:auto;
	/*overflow-x: hidden!important;*/
}
.sbnsp{
	display: none;
}
.spclose{
	display: none;
}
.globalMenuSp{
	display: none;
}
.hamburger{
	display: none;
}

.title{
	float:left;
	width:700px;
	overflow: hidden;
}
img{
	max-width: 100%;
}
.centertxt{
	text-align: center;
}
.righttxt{
	text-align: right;
}
table{
	border-collapse: collapse;
	font-size: 13px;
}
th{
	font-weight:400;
	background:#EDF8FE;
}
a{
	color:#000000;
}
a:hover{
	opacity: 0.7;
	transition:0.3s;
}
a.rise img{
	position:relative;
	top:0;
	transition:0.3s;
}
a.rise img:hover{
	top:-10px;
	transition:0.3s;
}
.sp{
	display:none!important;
}
.pc{
	display: block!important;
}
.container{
	width:870px;
	margin: 0 auto;
	display: block;
	position: relative;
}
#menu{
	display: none;
}
.child{
	display: none;
}
header{
	margin: 0 auto;
	height:90px;
	width:870px;
}
header ul{
	float:right;
	padding:10px 0 0;
}
header li{
	font-size:12px;
	list-style:none;
	line-height: 20px;
}
header li:before {
	font-size:10px;
	color:#87d2f8;
	content:"▶ "; 
}

h1{
	font-size:26px;
	font-weight: 500;
	line-height: 50px;
}
.area{
	font-size:21px;
	color:#fff;
	background:#40647e;
	width:fit-content;
	padding:2px 10px 4px;
}
.menubar {
	width:100%;
	background:#87d2f8;
	height:50px;
	position: relative;
}

.gmenu {
	width:870px;
	height:50px;
	margin:0 auto;
	font-size:13px;
	display: flex;
	justify-content: space-around;
	align-items: flex-start;
	z-index: 50;
}
.gmenu li{
	align-items: flex-start;
	list-style-type: none;
	line-height: 0px;
	cursor: pointer;
}
.menuSub{
	position: absolute;
	background:#ffffff;
	height:60px;
	display: none;
	width:100%;
	left:0;
	margin:0 auto;
}
.menuSub.open{
	display: flex;
	justify-content: center;
	align-items: center;
	gap:8em;
	z-index: 51;
}
.ft_wrap{
	float:left;
    width:100%;
}
.footer_line{
	width:100%;
	height:0;
	border-top:#dbf0fd 1px solid;
}
footer{
	width:870px;
	margin:0 auto;
	overflow: hidden;
	padding:20px 30px 0px;
}
.footer_tit{
	font-size:22px;
	line-height: 30px;
	margin-bottom: 10px;
}
.f23{font-size:23px!important;}
.f21{font-size:21px!important;}
.f20{font-size:20px!important;}
.f18{font-size:18px!important;}
.f14{font-size:14px!important;}
.fw400{font-weight: 400!important;}
.ftbox {
	font-size:12.5px;
	line-height: 1.7em;
	float:right;
	margin-right: 3em;
}
.ftbox li{
		list-style-type: none;
}
.ft_sub li{
	margin-left: 1em;
}
.ft_sub li:before{
	color:#f5a984;
	content:"▶ "; 
}
.mr-zero{
	margin-right: 0!important;
}
.mr-5{
	margin-right: 17px!important;
}
.mr-second{
	margin-right: 85px!important;
}
.ft_bar {
	clear: both;
	background:#87D2F8;
	font-size:12.5px;
	height:30px;
	text-align: center;
	font-weight: 500;
	display:flex;
	justify-content: center;
	align-items: center;
}

.hero {
	width:100%;
	height:260px;
	background:url("../images/topback.png");
	background-repeat: repeat;
}
.hero img{
	float:right;
	margin:27px 20px 0 0;
}
.hero h1{
	font-size:24px;
	line-height: 35px;
}
.catch{
	height:260px;
	display: flex;
	align-items: center;
	overflow: hidden;
}
.honbun{
	width:735px;
	margin:30px auto;
}
.honbun_w{
	margin:30px 35px;
}

.centertxt{
	text-align: center;
}
.righttxt{
	text-align: right;
}
.honbuntitle{
	font-size:23px;
	margin-bottom: 0.5em;
    display: flex;
    align-items: center;
    justify-content: center;
}
.infoarea{
	background:#EDF8FE;
	margin:0 35px;
	padding:30px;
	font-size:16px;
	line-height: 1.8em;
}
.infoarea2{
	background:#EDF8FE;
	width:735px;
	margin:30px auto;
	padding:30px 2em;
}
.infoarea h2{
	font-size:20px;
	font-weight: 400;
	text-align: center;
}
.infoarea li{
	list-style-type: none;
	margin-left: 1em;
}
.infoarea li:before{
	margin-left: -1em;
	content:"● "
}
.col_red{
	color:#ff0000;
}
.centerimg{
	display: block;
	margin: 20px auto;
}
.center{
	display: block;
	margin: 0 auto;
}

.spacer40 {
	height: 40px;
}
.spacer100 {
	height: 100px;
}
.listtitle {
	height: 70px;
	font-size:18px;
	border-left:10px solid #fad4c1;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-flow: column;
	flex-wrap: wrap;
	padding-left: 15px;
	margin: 0 0 20px 0px;
}
.listtitle_auto{
	height: auto;
	font-size:20px;
	border-left:10px solid #fad4c1;
	display: flex;
	align-items: flex-start;
	justify-content: center;
	flex-flow: column;
	flex-wrap: wrap;
	padding-left: 15px;
	margin: 0 0 20px 0px;
	
}
.lt {
	height: 20px;
	font-size:16px;
	border-left:10px solid #FAD4C1;
	display: flex;
	align-items: center;
	padding-left: 5px;
	margin: 0 0 0px 0px;
}

.hospital_list {
	margin:0 35px;
	/*width:calc(100% - 70px);*/
	width:800px;
}
.hospital_list td{
	padding: 10px 0 10px 2em;
	
}
.hospital_list2 {
	margin:0 35px;
	width:800px;
}
.hospital_list2 td{
	padding: 10px 0 10px 1em;
	
}

.aname{
	padding-left: 0!important;
	text-align: center;
	min-width: 8em;
}
.icon_area {
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	width:92%;
	margin:30px auto;
	gap:20px;
}
.img_area{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: center;
	width:92%;
	margin:30px auto;
	gap:40px;
    
}
.news_area {
	background: #fdf2ed;
	width:92%;
	margin:20px auto;
	padding:20px;
}
.news_area h1{
	font-size:24px;
	text-align: center;
	font-weight: 400;
}
.news_area ul{
	border-bottom: 1px solid #ccc;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap:0 20px;
	padding:0 2em;
	flex-wrap: wrap;
}

.news_area ul li {
	list-style-type: none;
	margin: 10px 0;
	display: inline-block;
}
.topline{
	border-bottom: 1px solid #ccc;
}
.news_list ul{
	border-bottom: 1px solid #ccc;
	display: flex;
	justify-content: flex-start;
	align-items: center;
	gap:0 20px;
	padding:0 2em;
	flex-wrap: wrap;
}
.news_list ul li {
	list-style-type: none;
	margin: 10px 0;
	display: inline-block;
}
.newsdate{
	
}
.newscate{
    width:5em;
    text-align: center;
    margin-right: 1em;
    color:#fff;
	
}
.newstitle{
	
}
.ndate{
	width:7em;
}
.ncate{
    width:5em;
    text-align: center;
    margin-right: 1em;
    color:#fff;
}
.ntitle{
	width:30em;
}
.cat_news{
    background:#245AA3;
}
.cat_workshop{
    background:#009c53;
}
.cat_doc{
	background:#ed568c;
}
.head-border {
    display: flex;
    align-items: center;
}
 
.head-border:before,
.head-border:after {
    content: "";
    height: 2px;
    flex-grow: 1;
    background-color: #c9c9c9;
}
 
.head-border:before {
    margin-right: 1rem;
}
 
.head-border:after {
    margin-left: 1rem;
}
.outer{
	display: flex;
	justify-content: flex-start;
	align-items: center;
}
.nlist{
	margin:35px;
	display:flex;
	justify-content: flex-start;
	align-items: center;
	gap:20px;
	font-size:21px;
	line-height: 1.4em;
	font-weight:700;
}
.wtback{
	background:#FCE5DA;
	font-size:14px;
	font-weight: 600;
	padding:10px 20px;
}
.imgbox{
	display: flex;
	justify-content: center;
	align-items: center;
	gap:20px;
}
.telbox{
	width:360px;
	height:45px;
	background:#fdeee6;
	margin:0 auto;
	display: flex;
	justify-content: space-around;
	align-items: center;
}
.infobox{
	text-align: center;
	padding:20px;
	line-height: 35px;
}
.telnum{
	font-size:23px;
}
.frm_hd{
	clear: both;
	width:12em;
	padding: 5px 0;
}
.frm_bd{
	width: 40em;
}
.frm_bd p{
	line-height: 2em;
}
.frm_hd,.frm_bd{
	float:left;
	margin: 10px 0;
}
.wrapper{
	height:auto;
	overflow: hidden;
}
.vc_info{
	margin:0 30px;
	background:#fff;
	text-align: center;
	padding:10px;
}

input{
	padding:5px 1em;
}
input[type=text]{
	width:100%;
	border:1px solid #999999;
}
textarea{
	border:1px solid #999999;
	padding:1em;
	width:100%;
}
#page_top{
	width:42px;
	height:42px;
	position: fixed;
	right: 70px;
	bottom: -42px;*/
	z-index: 99999!important;
}
.linkoff{
	opacity:0.3;
}
.table_wrap{
	overflow-x: hidden;
}
.mediacal_check{
	width: 250px;
	height:150px;
	margin: 100px auto;
	display: flex;
	border:3px solid #f5a984;
	border-radius: 8px;
	background: #fbe5da;
	justify-content: center;
	align-items: center;
	gap:20px;
	box-shadow: 5px 5px 5px 2px rgba(0,0,0,0.2);
	flex-wrap: wrap;
}
.btn{
	width:80px;
	background:#eeeeee;
	border:1px solid #999999;
	display: flex;
	justify-content: center;
	align-items: center;
	border-radius: 5px;
}
.hpvimg{
	gap:80px;
}
.vaccine_tbl{
	width:100%;
}
.vaccine_tbl td{
	border: 1px solid #aaaaaa;
	text-align: center;
}
.vac1{
	background:#def1f8;
	height:3em;
}
.vac2{
	background:#fdeee6;
	height:3em;
}
.vac3 {
	background:#ddedbc;	
	height:3em;
}
.scbox{
	width:735px;
	margin:30px auto;
	padding:0 2em;
	border:1px solid #87D2F8;
	position: relative;
}
.oyako{
	position:absolute;
	top:-40px;
	right:50px;
}
.grbox{
	display: flex;
	flex-flow: column wrap;
	align-items: flex-start;
	height:320px;
}
.gr1{
	border-right:1px solid #808080;
	border-bottom:1px solid #808080;
	padding:0 10px 15px 0;
}
.gr2{
	border-right:1px solid #808080;
	padding:23px 9px 10px 0;
}
.kome{
	font-size:10px;
	line-height: 1.6em;
}
.videoframe{
    width: 376px;
    height: 211px;
	display:block; 
	margin:0 auto!important;
	max-width: 90%;
}
.videoframe iframe{
    width: 100%;
    height: 100%;
}
.videobtn{
	width: 400px;
	max-width: 100%;
	display: flex;
	margin:0 auto;
	justify-content: space-between;
	align-items: center;
	flex-wrap: wrap;
	gap:10px;
}
.videobtn img{
	cursor: pointer;
}
.centerbtn{
	display: block;
	margin:40px auto;
	max-width: calc(100% - 70px);
}
.centerblock{
	display: block;
	margin:0px auto;
}
.areamap{
	position: absolute;
	right:30px;
}
.blockarea{
	margin:0 0 20px 40px;
	display: flex;
	justify-content: flex-start;
	align-items: flex-start;
	gap:10px;
}
.block,.block2{
	width:270px;
	
}
.block li,.block2 li { list-style:none; }
.block li:before { content:"●"; color:#9fd11e;}
.block2 li:before { content:"●"; color:#d0e790;}
.ftlink{
    margin: 20px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    flex-wrap: wrap;
	font-size:12.5px;
}
.ftlink li{
    list-style-type: none;
}
.balloon1 {
  position: relative;
  display: inline-block;
  margin: 1.5em 0;
  padding: 7px 10px;
  min-width: 120px;
    width:90%;
  max-width: 100%;
  color: #fff;
  font-size: 16px;
  background: #40647E;
  border-radius: 15px;
}

.balloon1:before {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  margin-left: -10px;
  border: 10px solid transparent;
  border-top: 10px solid #40647E;
}

.balloon1 p {
  margin: 0;
  padding: 0;
}
.bnarea{
	display: flex;
	flex-wrap: wrap;
	justify-content: space-around;
	align-items: flex-start;
	gap:20px;
}
.videoarea{
	display: flex;
	flex-wrap: wrap;
	justify-content: center;
	align-items: flex-start;
	gap:30px;
}
.vbox{
	width:380px;
	display: block;
}
.sbn01{
	position: fixed;
	top:100px;
	right:0;
	transition:0.3s;
	z-index: 5010;
}
.sbn02{
	position: fixed;
	top:251px;
	right:0;
	transition:0.3s;
	z-index: 5010;
}
.sbn03{
	position: fixed;
	top:402px;
	right:0;
	transition:0.3s;
	z-index: 5010;
}
.pgnation{
	display: flex;
	padding:20px;
	justify-content: center;
	align-items: center;
	gap:30px;
}
.sbn01:hover,.sbn02:hover,.sbn03:hover{
	right:-10px;
	transition:0.3s;
}
.page-numbers{
	border:1px solid #ccc;
	padding:5px 10px;
}
.prev.page-numbers,.next.page-numbers{
	display: none;
}
.current{
	background:#245aa3;
	color:#fff;
}
.cb{
	clear:both;
}

@media screen and (max-width: 870px) {
	/* 959px以下に適用されるCSS（タブレット用） */
	body{
		overflow-x: hidden!important;
	}
	.news_area ul{
		margin-left: 0;
	}
	.ntitle{
		width:auto;
	}
	header a{
		text-decoration: none;
	}
	.title{
		width:100%;
		float: inherit;
	}
	.nlist{
		flex-wrap: wrap;
		gap:10px;
	}
	.nlist div{
		width:100%;
	}
	.table_wrap{
		overflow-x: scroll;
	}
	.sp{
		display: block!important;
	}
	.pc{
		display: none!important;
	}

	.container{
		width:100%;
	}
	header{
		height:auto;
		width:100%;
		padding:5px 20px;
	}
	header ul li{
		z-index: 5020!important;
	}
	h1{
		font-size:20px;
		font-weight: 500;
		line-height: 30px;
	}
	.area{
		font-size:16px;
		color:#fff;
		background:#40647e;
		width:fit-content;
		padding:1px 10px;
	}
	.menubar{
		display:none;
	}
	.hero {
		width:100%;
		height:auto;
	}
	.catch{
		width:100%;
		height:100px;
		display: flex;
		justify-content: center;
		align-items: center;
		text-align: center;
	}
	.hero img{
		float:inherit;
		margin:0 auto;
		max-width: 100%;
	}
	.honbun{
		width:90%;
	}
	.scbox{
		width:90%;
	}
	.infoarea2{
		width:90%;
	}
	.telbox{
		width:90%;
	}
	.frm_bd{
		width: 100%;
	}
	footer{
		width:100%;
	}
	.ft_wrap{
		float:inherit;
	}
	.ftbox {
		font-size:11px;
		line-height: 2em;
		float:inherit;
		margin-right: 3em;
	}
	.footer_tit{
		font-size:18px;
		line-height: 25px;
		margin: 10px 0;
	}
	.vc_info{
		margin:0 5px;
	}
	.hpvimg{
		flex-wrap: wrap;
		gap:20px;
	}
	.oyako{
		top:-80px;
		right:50px;
	}
	.grbox{
		flex-flow: column wrap;
		align-items: flex-start;
		height:auto;
	}
	.gr1{
		border-right:none;
		border-bottom:1px solid #808080;
		padding:0 10px 15px 0;
	}
	.gr2{
		border-right:none;
		border-bottom:1px solid #808080;
		padding:23px 0 25px 0;
	}
	.gr3{
		padding: 20px 0;
	}
    .blockarea{
        margin:0;
        display: flex;
        justify-content: center;
        align-items: flex-start;
        flex-wrap: wrap;
        gap:40px;
    }
    .block{
        width:270px;
        max-width: 100%;
    }
    .listtitle {
    	margin: 0 0 20px 10px;
    }
	
    .areamap{
        position: inherit;
        margin: 0 auto;
		width:183px;
        max-width: 90%;
    }
	.ftlink{
		width:250px;
	}
	.ft_bar{
		height:auto;
	}
    .videoframe{
        width:100%;
        height: 50vw;
    }
	.sbnsp{
		display: flex;
		position:fixed;
		bottom:-10px;
		left:0;
		width:100%;
		z-index: 5010;
		padding:0;
		justify-content: center;
		align-items: flex-start;
	}
	.sbnsp img{
		position: relative;
		bottom:0px;
		transition: 0.3s;
	}
	.sbnsp img:hover{
		bottom:-15px;
		transition: 0.3s;
	}
	#page_top{
		position: fixed;
		right: 20px;
		bottom: -42px;
		z-index: 99999!important;
	}

}
@media screen and (max-width: 480px) {
	/* 480px以下に適用されるCSS（スマホ用） */
}

