@charset "utf-8";
/* CSS Document */
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;*/
}
.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:#fdeee6;
}
a{
	color:#000000;
}
.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:#f5a984;
	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:#fad4c1;
	height:50px;
	position: relative;
}

.gmenu {
	width:870px;
	height:50px;
	margin:0 auto;
	font-size:13px;
	display: flex;
	justify-content: flex-start;
	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;
}
.footer_line{
	width:100%;
	height:0;
	border-top:#fad4c1 1px solid;
}
footer{
	width:870px;
	margin:0 auto;
	overflow: hidden;
	padding:20px 30px 30px;
}
.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;
}
.ft_bar {
	clear: both;
	background:#fad4c1;
	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_tile.jpg");
	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;
}
.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;
}
.infoarea{
	background:#fdf2ed;
	margin:0 35px;
	padding:30px;
	font-size:16px;
	line-height: 1.8em;
}
.infoarea2{
	background:#fdf2ed;
	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;
}

.listtitle {
	height: 50px;
	font-size:21px;
	border-left:10px solid #FAD4C1;
	display: flex;
	align-items: center;
	padding-left: 15px;
	margin: 0 0 20px 35px;
}
.lt {
	height: 20px;
	font-size:16px;
	border-left:10px solid #91d0e8;
	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:10px;
}

.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{
	margin-left: 100px;
}
.news_area ul li {
	list-style-type: none;
	margin-bottom: 10px;
	display: inline-block;
}
.ndate{
	width:10em;
}
.ntitle{
	width:30em;
}
.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:#def1f8;
	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: 20px;
	bottom:-42px;
	z-index: 1000;
}
.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 #f5a984;
	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;
}
@media screen and (max-width: 870px) {
	/* 959px以下に適用されるCSS（タブレット用） */
	body{
		overflow-x: hidden!important;
	}
	.news_area ul{
		margin-left: 0;
	}
	.ntitle{
		width:auto;
	}

	.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;
	}
	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;
	}
	.ft_bar{
		height:auto;
	}
}
@media screen and (max-width: 480px) {
	/* 480px以下に適用されるCSS（スマホ用） */
}

