@charset "utf-8";

/* common
****************************************************/
*{
	margin: 0;
	padding: 0;
	word-break: break-all;
	word-wrap: break-word;
	box-sizing: border-box;
	line-height: 175%;
}
body{ font-size:19px; color:#333; font-family: "UD新ゴ R", "UD Shin Go Regular", sans-serif; }
img{ border:none; font-size:0; vertical-align:top; }
ul{ list-style-type:none; }
a{ text-decoration:none; color:#333; }
a:hover{ text-decoration:none; }
/*a:hover img{ opacity: 0.5; transition:all 0.3s ease; }*/
h1{ font-size: 14px; font-weight:normal; }
address{ font-style:normal; }

/* margin
****************************************************/
.mt10, .mt10ul li{ margin-top:10px; }
.mt20, .mt20ul li{ margin-top:20px; }
.mt30, .mt30ul li{ margin-top:30px; }
.mt40{ margin-top:40px; }
.mt50{ margin-top:50px; }
.mt60{ margin-top:60px; }
.mt75{ margin-top:75px; }
.mt100{ margin-top:100px; }
.mb20{ margin-bottom: 20px; }
.mt1em{ margin-top: 1em; }
.mt2em{ margin-top: 2em; }

/* text-align
****************************************************/
.tar{ text-align:right; }
.tac{ text-align:center; }
.tal{ text-align:left; }
.ti1{ text-indent:1em; }
.ti2, .ti2ul li{ text-indent:-1em; padding-left:1em; }
.ti3, .ti3ul li{ text-indent:-1.5em; padding-left:1.5em; }

/* color
****************************************************/
.col1, .col1ul li:before, .col1icon:before{ color:#4F9551; }

/* background
****************************************************/
/* color */
.bg1col{ background-color: #F8F8B4; }
.bg2col{ background-color: #FFFFFF; }

/* icon
****************************************************/
.icon1:before, .icon1ul li:before, .icon1dl dt:before{ content:"▶"; margin-right: .5em; }
.icon2:before, .icon2ul li:before, .icon2dl dt:before{ content:"●"; margin-right: .5em; }
.icon3:before, .icon3ul li:before, .icon3dl dt:before{ content:"■"; margin-right: .5em; }
.icon4:before, .icon4ul li:before, .icon4dl dt:before{ content:"◆"; margin-right: .5em; }
.icon5:before, .icon5ul li:before, .icon5dl dt:before{ content:"▲"; margin-right: .5em; }
.icon6:before, .icon6ul li:before, .icon6dl dt:before{ content:"※"; margin-right: .5em; }

/* font-size
****************************************************/
.fs_s{ font-size:small; }
.fs12{ font-size:12px; }
.fs14{ font-size:14px; }
.fs15{ font-size:15px; }
.fs16{ font-size:16px; }
.fs20{ font-size:20px; }
.fs23{ font-size:23px; }
.fs24{ font-size:24px; }
.fs26{ font-size:26px; }
.fs28{ font-size:28px; }
.fs32{ font-size:32px; }

/* border-radius
****************************************************/
.br10, .br10ul li{ border-radius:10px; -webkit-border-radius:10px; -moz-border-radius:10px; }
.br20, .br20ul li{ border-radius: 20px; -webkit-border-radius: 20px; -moz-border-radius: 20px; }

/* list-style
****************************************************/
.ls_disc{ list-style:disc; margin-left:1em; }

/* column
****************************************************/
.ofh1, .ofh2{ overflow: hidden; }
.ofh1 .fl, .ofh2 li{ float: left; }
.ofh1 .fr{ float: right; }
/* flexBox */
[class*="fbCom"]{ display: flex; flex-wrap: wrap; }
.fbCom1{ justify-content: space-between; }
.fbComCen{ align-items: center; justify-content: center; align-content: center; }
.vCen, .vCenA a{ display: flex; flex-wrap: wrap; align-items: center; justify-content: center; align-content: center; }

/* headline
****************************************************/
h1, h2, h3, h4{ font-family: "UD新ゴ M", "UD Shin Go Medium", sans-serif; }
.hl1{ color: #4F9551; font-size: 38px; text-align: center; line-height: 100%; }
.hl1 span{ color: #333; font-size: 19px; display: block; }
.hl2{ border-left: 4px solid #4F9551; color: #4F9551; font-size: 24px; line-height: 30px; padding-left: .5em; }
.hl3{ text-align:center; width:100%; position:relative; display:inline-block; color: #4F9551; margin-bottom: 12px; font-size: 28px; }
.hl3:before{
	content:'';
	position:absolute;
	left:50%;
	bottom:-10px;
	display:inline-block;
	width: 80px;
	height:2px;
	-moz-transform:translateX(-50%);
	-webkit-transform:translateX(-50%);
	-ms-transform:translateX(-50%);
	transform:translateX(-50%);
	background-color: #808080;
}
.hl4{
	background-color: #4F9551;
	color: #fff;
	padding: 15px 20px;
	border-radius: 20px;
}
.hl4 span{
	border-left: 4px solid #fff;
	font-size: 24px;
	line-height: 30px;
	padding-left: .5em;
}
.hl5{
	border-bottom: 2px solid #4F9551;
	font-size: 24px;
	padding-bottom: 15px;
	color: #4F9551;
}

/* link
****************************************************/
[class*="lnk"], .listLnk a{ transition : all 0.75s; display: inline-block; }
[class*="lnk"]:hover, .listLnk a:hover{ opacity: .8; transition : all 0.75s; }
.lnk1btn{ background-color: #FFF; border: 2px solid #4F9551; padding: 15px 0; text-align: center; color: #4F9551; border-radius: 30px; font-size: 21px; line-height: 26px; }
.lnk1btn:hover{ opacity: 1; background-color: #4F9551; color: #FFF; }

/* title
****************************************************/
.pp1ttl{ background:url("images/pt1bg.png") repeat-y center top; background-size: cover; color: #fff; }

/* content
****************************************************/
/* notice */
#notice li{ padding: .5em 0; border-bottom: 1px dotted #707070; }
.notice_list{ margin-bottom: 50px; }
.notice_list li{ border-bottom: 1px dotted #707070; }
.notice_list a{ display: block; padding: 20px 0 10px; }
/* index */
#index .sec2 h3{ padding: 10px 0; border-bottom: 2px solid #4F9551; text-align: center; font-size: 24px; margin-bottom: 10px; }
#index .sec3 .gr1 a{ background-color: #4F9551; color: #fff; font-size: 24px; border-radius: 10px; text-align: center; }
/* guidance */
#guidance .sec1 figure img{
	width: 360px;
	height: 360px;
	border-radius: 50%;
	background-color: #F8F8B4;
}
/* etc */
.band1{ background-color: #DF493A; color: #FFF; text-align: center; }
.band2{ background-color: #4F9551; color: #FFF; text-align: center; font-size: 24px; border-radius: 30px; padding: 2.5px; }
.pad1{ padding: 40px; }

/* symptom
****************************************************/
/* symptom */
#symptom li a{ display: block; }
#symptom li a:before{ content: '▶'; margin-right: .5em; color: #4F9551; }
#symptom li a:hover{ color: #f00; }
/* symptom2 */
#symptom2 li a:before{ content: '▶'; margin-right: .5em; color: #4F9551; }
#symptom2 li a:hover{ color: #f00; }
/* symptom3 */
#symptom3 .outline h4{ color: #4F9551; border-left: 4px solid #4F9551; font-size: 19px; line-height: 26px; padding-left: .5em; }
#symptom3 dt{ font-weight:bold; margin-top:1em; }
#symptom3 dt:before{ content:"【"; margin-right:5px; }
#symptom3 dt:after{ content:"】"; margin-left:5px; }

/* site
****************************************************/
#site dt:before{ content:"▶ "; color: #4F9551; }
#site dd{ margin:15px 15px 50px; }

/* sitemap
****************************************************/
#sitemap .parent{ margin-top: -30px; }
#sitemap .parent li{ margin-top: 30px; }
#sitemap .child li{ margin-top: 15px; }
#sitemap .parent li:before{ content:"▶"; color: #4F9551; margin-right:.5em; }
#sitemap .child li:before{ content:"";  margin-right:0; }
#sitemap .child a{ text-decoration:underline; }
#sitemap .child a:hover{ text-decoration:none; }

/* footer
****************************************************/
footer, footer .sec2{ border-top: 3px solid #EBEBEB; }
footer .sec2 *{ color: #333; }
address{ padding: 10px 0; text-align: center; background-color: #4F9551; color: #FFF; font-size: 16px; }

/* 404
****************************************************/
.error404{ text-align:center; color:red; padding:100px 0; }

/* breadcrumbs
****************************************************/
.breadcrumbs ol{ list-style: none; overflow: hidden; font-size: 12px; }
.breadcrumbs li{ float: left; }
.breadcrumbs li::after{ content: '>'; display: inline-block; padding: 0 10px; }
.breadcrumbs li:last-child::after{ display: none; }

/* pagetop
****************************************************/
.pagetop {
	display:none;
	position:fixed;
	bottom:0px;
	right:10px;
	line-height:0;
	z-index: 9999;
}
.pagetop a{
	display:block;
	padding:5px;
	background-color: #4F9551;
	text-align:center;
	color:#ffffff;
	text-decoration:none;
	margin-bottom:5px;
	border-radius:5px;
	-webkit-border-radius:5px;
	-moz-border-radius:5px;
	opacity:.5;
	line-height:0;
}
.pagetop a:hover, .pagetop a:hover img{ opacity:1.0; }





/**************************************************

	600px over

**************************************************/
@media only screen and (min-width:600px), print{

	/* common
	****************************************************/
	.wrap{ margin-left: auto; margin-right: auto; width: 1200px; }
	.sp{ display:none!important; }

	/* margin
	****************************************************/
	.ml30{ margin-left: 30px; }
	
	/* overflow:hidden;
	****************************************************/
	.ofh1pc, .ofh2pc{ overflow:hidden; }
	.ofh1pc .fl, .ofh2pc li{ float:left; }
	.ofh1pc .fr{ float:right; }
	/* flexBox */
	[class*="fbPc"]{ display: flex; flex-wrap: wrap; }
	.fbPc1{ justify-content: space-between; }
	.vCenPc, .vCenApc a{ display: flex; flex-wrap: wrap; align-items: center; justify-content: center; align-content: center; }

	/* width
	****************************************************/
	.w200{ width: 200px; }
	.w300{ width: 300px; }
	.w380{ width: 380px; }
	.w580{ width: 580px; }
	.w740{ width: 740px; }
	.w790{ width: 790px; }
	.w1000{ width: 1000px; }
	.w50p, .w50pUl li{ width: 50%; }

	/* list
	****************************************************/
	.lst1 li, .lst1li{ padding-left: 150px; overflow: hidden; }
	.lst1 li span, .lst1li span{ display: block; float:left; width: 150px; margin-left: -150px; }

	/* main
	****************************************************/
	.mv img{ max-width: 100%; height: auto; }
	
	/* header
	****************************************************/
	header{ position: relative; height: 150px; padding-top: 10px; }
	header [class^="ads"]{ position: absolute; }
	header h1{ text-align: right; }
	header .ads1{ left: 0; top: 50px; }
	header .ads2{ right: 400px; top: 70px; border: 2px solid #DF493A; color: #DF493A; width: 200px; font-size: 24px; text-align: center; }
	header .ads3{ right: 0; top: 70px; }
	
	/* nav
	****************************************************/
	.gNav{ line-height: 20px; width: 100%; background-color: #4F9551; }
	.gNav ul{ overflow:hidden; text-align: center; }
	.gNav li{ float:left; width: 200px; }
	.gNav ul a{
		display:block;
		color: #FFF;
		font-size: 19px;
		padding: 25px 0 17px;
	}
	.gNav ul a img{
		filter: invert(100%) sepia(100%) saturate(19%) hue-rotate(296deg) brightness(106%) contrast(104%);
		margin-bottom: 5px;
	}
	.gNav ul a:hover, .gNav ul .stay{
		color: #FFFF3E;
	}
	.gNav ul a:hover img, .gNav ul .stay img{
		filter: invert(93%) sepia(37%) saturate(1657%) hue-rotate(325deg) brightness(125%) contrast(106%);
	}
	.fixed{ position:fixed; top:0px; left:0px; z-index:9999; }
	.space{ margin-top: 70px; }
	.none{ display:none; }	
	
	/* title
	****************************************************/
	.pp1ttl{
		background: url("images/title_back@2x.png") no-repeat center center / cover;
		height: 200px;
		color: #4F9551;
		font-size: 28px;
		text-align: center;
	}
	.pp1ttl span{ font-size: 19px; color: #333; display: block; line-height: 20px; }
	
	/* content
	****************************************************/
	/* common */
	.ppSpa{ padding: 90px 0 120px; }
	.spa1{ padding: 60px 0; }
	.spa2{ padding-bottom: 60px; }
	/* index */
	#index .sec1{ padding: 60px 0; }
	#index .sec1 .hl1 span{ display: inline-block; margin-left: .5em; }
	#index .sec1 .fl{ padding-top: 30px; }
	#index .sec1 .lnk1btn{ padding: 10px 0; font-size: 16px; }
	#index .sec2{ padding: 100px 0; }
	#index .sec2 h3{ height: 100px; }
	#index .sec3{ padding: 100px 0; }
	#index .sec3 .gr1 a{ height: 120px; }
	#index .sec4{ padding: 100px 0; background: url("images/top_greeting_back@2x.png") no-repeat center center / 1500px 700px #F8F8B4; }
	#index .sec5{ padding: 70px 100px; }
	/* guidance */
	#guidance .sec1 .w380{ margin-right: 30px; }
	#guidance .sec1 .w380:nth-child(3n){ margin-right: 0; }
	/* access */
	#access .wrap{ padding: 0 200px; }

	/* symptom
	****************************************************/
	/* symptom */
	#symptom li{ width: 25%; margin-top: 1.5em; padding-left: .5em; }
	/* symptom2 */
	#symptom2 ul{ margin-top: 50px; padding-left: 100px; letter-spacing:-0.4em; }
	#symptom2 li{ display:inline-block; letter-spacing:normal; vertical-align:top; min-width:31%; margin-left:1%; margin-top:20px; }
	/* symptom3 */
	#symptom3 h4{ font-size: 20px; margin-top: 50px; }
	/* Add */
	#symptom2 p, .sWrap{ padding-left: 100px; padding-right: 100px; }
	
	/* disease
	****************************************************/
	#disease ul{ margin-bottom: 35px; }
	#disease li{ margin: 15px 50px 15px 0; }
	#disease li:nth-child(3n){ margin-right:0; }
	#disease li a{ width:100%; padding: 50px 0; line-height:20px; }
	#disease h3{ font-size: 30px; }
	#disease dt{ font-size: 21px; }
	#disease dl{ padding-top: 80px; }

	/* sitemap
	****************************************************/
	#sitemap .child{ margin-left:1.5em; overflow:hidden; }
	#sitemap .child li{ float:left; width:33%; }

	/* footer
	****************************************************/
	footer .sec1{ padding: 60px 0 80px; }	
	footer .sec2{ padding: 20px 0; font-size: 16px; }
	footer .sec2 li{ margin-left: 1em; margin-right: 1em; }
	
	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ padding: 5px 0 0 0; }

	/* gmap
	****************************************************/
	.gmap{
		width:100%;
		position: relative;
		padding-bottom: 500px;
		height: 0;
		overflow: hidden;
	}
	.gmap iframe, .gmap object, .gmap embed{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 500px;
	}
}





/**************************************************

	600px under

**************************************************/
@media only screen and (max-width:599px){

	/* common
	****************************************************/
	body{ font-size:16px; }
	.wrap{ padding: 15px; line-height:1.5em; }
	img{ max-width:100%; height:auto; }
	.pc{ display:none!important; }
	.sp_tac{ text-align:center; }
	.sp1spa{ margin-top: 20px; }
	
	/* overflow:hidden;
	****************************************************/
	.oh_clm2sp, .oh_clm3sp, .oh_sp{ overflow:hidden; }
	.oh_clm2sp li{ width: 48%; }
	.oh_clm3sp li{ width: 32%; margin-right: 2% !important; margin-top: 2% !important; }
	.oh_clm3sp li:nth-child(3n){ margin-right: 0 !important; }
	.oh_sp .fl, .oh_clm2sp li:nth-child(odd), .oh_clm3sp li{ float: left; }
	.oh_sp .fr, .oh_clm2sp li:nth-child(even), .oh_clm3sp li:nth-child(3n){ float: right; }
	
	/* width
	****************************************************/
	.wp1{ width: 220px; }
	.wp2{ width: 300px; }
	
	/* width
	****************************************************/
	.lnk1btn{ width: 200px; }
	
	/* header
	****************************************************/
	header .wrap{ padding: 0; }

	/* nav
	****************************************************/
	html{ overflow-x: hidden; }
	#headerSp{ width:100%; border-collapse:collapse; background-color: #fff; position:fixed; top: 0px; left: 0px; z-index: 999; }
	#headerSp .inner{ padding: 3% 25% 3% 3%; }
	#headerSp figure{ margin-bottom: 10px; }
	#headerSp img{ width: 100%; }
	#headerSp .txt{ border: 1px solid #DF493A; color: #DF493A; border-radius: 6px; text-align: center; }
	/* nav */
	.gNav{
		background:rgba(248, 248, 180, 1);
		position: fixed;
		width: 100%;
		z-index: 998;
		padding: 0;
		transition: all 0.6s;
		right: -100%;
		top: 0;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
	}
	.gNav .wrap{ padding: 0; }
	.gNav.active{ right: 0%; }
	.gNav ul{ margin-top: 10%; }
	.gNav li{ margin: 0; }
	.gNav li a{ display: block; padding: 20px 0 20px 20px; color: #4F9551; border-bottom: 1px solid #4F9551; }
	.gNav li a:before{ content: "▶"; margin-right: .5em; color: #DF493A; }
	.gNavBk{
		position: fixed;
		background:rgba(0, 0, 0, 0);
		right: -100%;
		top: 0;
		height: 100%;
		width: 100%;
	}
	.gNavBk.active{ right: 0%; }	
	
	/*=============================
	.btn-trigger
	=============================*/
	.btn-trigger{
		position: fixed;
		top: 2%;
		right: 3%;
		z-index: 9999;
		background: #4F9551;
		cursor: pointer;
		width: 50px;
		height:50px;
		border-radius: 0;
		border: 1px solid #4F9551;
	}
	.btn-trigger span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
	background: #fff;
  	width: 45%;
	}
	.btn-trigger span:nth-of-type(1){ top:15px; }
	.btn-trigger span:nth-of-type(2){ top:23px; }
	.btn-trigger span:nth-of-type(3){ top:31px; }

	/*=============================
	#btn01
	=============================*/
	#btn01.active span:nth-of-type(1) {
    top: 18px;
    left: 18px;
    transform: translateY(6px) rotate(-45deg);
    width: 30%;
	}
	#btn01.active span:nth-of-type(2) { opacity: 0; }
	#btn01.active span:nth-of-type(3) {
    top: 30px;
    left: 18px;
    transform: translateY(-6px) rotate(45deg);
    width: 30%;
	}
	
	/* title
	****************************************************/
	.pp1ttl{
		background: url("images/sp_title_back@2x.png") no-repeat center center / cover;
		text-align: center;
		min-height: 150px;
		color: #4F9551;
		font-size: 24px;
		padding: 20px 0;
	}
	.pp1ttl span{ display: block; color: #333; font-size: 16px; line-height: 16px; }

	/* content
	****************************************************/
	/* common */
	.ppSpa{ padding-top: 25px; padding-bottom: 75px; }
	/* index */
	#index .wrap{ padding: 0; }
	#index .sec1{ padding: 40px 20px; }
	#index #notice{ margin-top: 20px; }
	#index .sec2{ padding: 40px 20px; }	
	#index .sec2 h3{ margin-top: 20px; }
	#index .sec3{ padding: 40px 20px; }
	#index .sec3 .gr1{ justify-content: space-between; }
	#index .sec3 .gr1 li{ width: 48%; margin-top: 15px;  min-height: 62px; }
	#index .sec3 .gr1 a{ font-size: 16px; width: 100%; height: 100%; padding: 5px; line-height: 125%; }
	#index .sec3 .fs23,
	#information .sec1 .fs23{ font-size: 16px;  }
	#index .sec4{ padding: 40px 20px; }
	#index .sec4 h3,
	#greeting .sec1 h3{ font-size: 19px; margin-bottom: -20px; }
	#index .sec5{ padding: 10px 20px 30px; text-align: center; }
	#index .sec5 li{ margin-top: 20px; }
	
	/* symptom
	****************************************************/
	/* symptom */
	#symptom li{ margin-top:1em; }
	/* symptom2 */
	#symptom2 h3{ margin-bottom: 1em; }
	#symptom2 ul{ margin-top:30px; padding-top:10px; }
	#symptom2 li{ margin-top:10px; }
	/* symptom3 */
	#symptom3 h4{ font-size:18px; margin-top:20px; }
	#symptom3 .outline{ margin-top: 40px; }

	/* disease
	****************************************************/
	#disease .fb1pc{ margin-top: -30px; }
	#disease li{ margin-top:20px; width: 100%; }
	#disease li:first-child{ margin-top:0; }
	#disease li a{ padding:15px; }
	#disease dl{ padding-top: 40px; }
	
	/* footer
	****************************************************/
	footer .sec1{ padding: 30px 20px; }
	footer .sec1 .fr{ margin-top: 30px; }
    footer .sec2 ul{ padding: 15px 25px 25px; }
	footer .sec2 li{ width: 50%;  margin-top: 10px; }
	address{ font-size: 12px; padding: .5em; }
	
	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ font-size: 10px; }
	
	/* gmap
	****************************************************/
	.gmap{
		position: relative;
		padding-bottom: 80%;
		height: 0;
		overflow: hidden;
	}
	.gmap iframe, .gmap object, .gmap embed{
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
	}

	/* footerSp
	****************************************************/
	#footerSp{ width:100%; border-collapse:collapse; position:fixed; z-index:990; bottom:0px; left:0px; }
	#footerSp tr td:nth-of-type(1){ width: 50%; background-color:#4F9551; border-right: 1px solid #fff; }
	#footerSp tr td:nth-of-type(2){ width: 50%; background-color:#4F9551; border-left: 1px solid #fff; }
	#footerSp a{ display: block; text-align:center; padding: 10px 30px; color: #fff; }
	#footerSp a img{ vertical-align: -5px; }
}