@charset "utf-8";

/* common
****************************************************/
*{ margin:0; padding:0; word-break:break-all; word-wrap:break-word; box-sizing:border-box; line-height:150%; }
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; }
h1{ font-size:12px; font-weight:normal; }
address{ font-style:normal; }
section p{ line-height: 200%; }

/* margin
****************************************************/
.mt10, .mt10ul li{ margin-top:10px; }
.mt20, .mt20ul li{ margin-top:20px; }
.mt30, .mt30ul li{ margin-top:30px; }
.mt40, .mt40ul li{ margin-top:40px; }
.mt50{ margin-top: 50px; }
.mt60{ margin-top: 60px; }
.mt80{ margin-top: 80px; }
.mt100{ margin-top:100px; }
.mt1adj{ margin-top: 80px; }
.mt2adj{ margin-top: 160px; }

/* 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; }
.fw_b{ font-weight: bold; }

/* color
****************************************************/
.colWT{ color: white; }
.col1, .col1ul li:before, .col1icon:before{ color: #003288; }

/* background
****************************************************/
/* color */
.bgColWT{ background-color: white; }
.bg1col{ background-color: #003288; }

/* icon
****************************************************/
[class*="icon"] li{ text-indent: -1.5em; padding-left: 1.5em; }
.icon1:before, .icon1ul li:before, .icon1dl dt:before{ content:"■"; margin-right: .5em; }
.icon2:before, .icon2ul li:before, .icon2dl dt:before{ content:"●"; margin-right: .5em; }

/* font-size
****************************************************/
.fwB{ font-weight: bold; }
.fsS{ font-size: 23px; }
.fsM{ font-size: 28px; }
.fsL{ font-size: 33px; }
.fs16{ font-size: 16px; }
.fs19{ font-size: 19px; }
.lh200{ line-height: 200%; }

/* border-radius
****************************************************/
.br05, .br05a a{ border-radius: 5px; -webkit-border-radius: 5px; -moz-border-radius: 5px; }
.br10, .br10ul li{ border-radius: 10px; -webkit-border-radius: 10px; -moz-border-radius: 10px; }
.br30{ border-radius: 30px; -webkit-border-radius: 30px; -moz-border-radius: 30px; }
.br35{ border-radius: 35px; -webkit-border-radius: 35px; -moz-border-radius: 35px; }

/* list-style
****************************************************/
.ls_adj{ margin-left: 1em; }
.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; }
.vCen2, .vCenA2 a{ display: flex; flex-wrap: wrap; align-items: center; align-content: center; }

/* headline
****************************************************/
h1, h2, h3, h4, .fFam{ font-family: "UD新ゴ M", "UD Shin Go Medium"; }
.hl1{ background: url("images/icon_title_m@2x.png") no-repeat top 4px left / 26px 30px; padding-left: 50px; }
.hl2{ background: url("images/icon_title_l@2x.png") no-repeat top center / 50px 60px; text-align: center; padding-top: 80px; }
.hl3{ color: #003288; border-bottom: 2px dotted #003288; display: inline-block; }

/* link & button & band
****************************************************/
[class*="lnk"], .listLnk a{ transition : all 0.75s; display: inline-block; }
.lnk:hover, .listLnk a:hover{ opacity: .8; }
.lnk1btn{ border-bottom: 2px dotted #FFF; color: #FFF; padding: 10px 0 8px; }
.lnk1btn:before{ content:"■"; margin-right: .25em; margin-left: .25em }
.lnk1btn:hover{ background: rgba(255, 255, 255, .2); }
.lnk2btn{ border-bottom: 2px dotted #003288; color: #003288; padding: 10px 0 8px; }
.lnk2btn:before{ content:"■"; margin-right: .25em; margin-left: .25em }
.lnk2btn:hover{ background: rgba(0, 50, 136, .2); }
.lnk3btn{ border: 2px solid #003288; background-color: #FFF; color: #141414; position: relative; padding: 10px 20px; }
.lnk3btn:after{
	content: "■";
	position: absolute;
	color: #003288;
	top: 50%;
	right: 10px;
	margin-top: -14px;
}
.lnk3btn:hover{ background-color: #003288; color: #FFF; }
.lnk3btn:hover:after{ color: #FFF; transition : all 0.75s; }


/* #medical.allergytest  */

#medical .sec1 .flex>div>div { padding: 10px; }
#medical .sec1 .flex ul { display: flex; flex-wrap: wrap;  padding: 5px; }
#medical .sec1 .flex li { width: calc( (100% - 20px)/2 ); background-color: #fff; margin: 5px; text-align: center; }
#medical .allergytest_flow div{ background-color: #d8e2f1; padding: 10px; margin-top: 10px; }
#medical .allergytest_flow dt span{ display: block; background-color: #003288; padding: 5px; text-align: center; font-weight: bold; color: #fff;}
#medical .allergytest_flow dd img{ width: 100%; }
#medical .allergytest_flow dt{ font-size:0.9em;}

@media only screen and (min-width:600px), print{
	#medical .sec1 .w550{ width:550px; }
	#medical .sec1 .w400{ width:400px; }
	#medical .sec1 .flex>div { width: 480px; }
	#medical .sec1 .flex>div:first-child { margin-right: 40px; }
	#medical .allergytest_flow { display:flex; }
	#medical .allergytest_flow div{ margin-right: 15px; }
	#medical .allergytest_flow div:last-child{ margin-right: 0;}
	#medical .allergytest_flow dt{ min-height: 6em;}
}

/* gNav
****************************************************/
.gNav .parent ul li a:before{ content:"－"; margin-right: .5em; color: #003288; }
.gNav .parent ul li a:hover{ text-decoration: underline; }

/* content
****************************************************/
/* common */
.posRelCom{ position: relative; }
[class*="adsCom"]{ position: absolute; }
.pad05{ padding: 5px; }
.pad20{ padding: 20px; }
.pad30{ padding: 30px; }
.pad40{ padding: 40px; }
.box1c{ border: 2px solid #003288; background-color: #FFFBCC; color: #141414; padding: 10px 20px; }
.box2c{ border: 2px solid #004BAD; padding: 60px 40px; }
.box3c{ border: solid #141414; border-width: 2px 0; }
#notice li a{ display: block; border-bottom: 1px solid #DDD; padding: 30px 0; }
/* index */
#index .sec1 ul{ border: solid #141414; border-width: 2px 0; }
#index .sec1 li{ border-top: 1px solid #333333; padding: 20px 10px; }
#index .sec1 li:first-child{ border-top: none; }
#index .sec1 .lnk2btn{ width: 100px; }
#greeting .sec1 .fl{ margin-top: 40px; }
#greeting .sec2 .w520{ border-bottom: 2px solid #141414; padding-bottom: 15px; }
#greeting .sec2 ul{ border-top: 2px solid #141414; padding-top: 5px; }
#greeting .box2c{ padding-bottom: 10px; }
#facility .sec2 .gr1{ background: url("images/back_pattern.png"); }
#access .fbPc{ justify-content: center; }
#access .fbPc li{ margin: 0 30px; }

/* symptom
****************************************************/
/* symptom */
#symptom ul{ background-color: #FFFBCC; padding: 20px 50px 50px; border-radius: 10px; }
#symptom li a{ display: block; }
#symptom li a:before{ content: '■'; margin-right: .5em; color: #003288; }
#symptom li a:hover{ color: #003288; }
#symptom li a, #symptom2 li a{ color: #333; }
/* symptom2 */
#symptom2 ul{}
#symptom2 li a:before{ content: '■'; margin-right: .5em; color: #003288; }
#symptom2 li a:hover{ color: #003288; }
/* symptom3 */
#symptom3 .outline{ background-color: #FFFBCC; padding: 40px; border-radius: 10px; }
#symptom3 dt{ font-weight:bold; margin-top:1em; }
#symptom3 dt:before{ content:"【"; margin-right:5px; }
#symptom3 dt:after{ content:"】"; margin-left:5px; }
#symptom3 h3{ margin-top: 50px; }
#symptom3 h3:first-child{ margin-top: 0; }

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

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

/* footer
****************************************************/
footer .sec2 *{ color: #333; font-size: 16px; }
address{ padding: 15px 5px 10px; text-align: center; font-size: 16px; border-top: 1px solid #003288; }

/* 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:5px;
	right:10px;
	z-index: 2;
}
.pagetop a{
	display:block;
	padding:5px;
	background-color: #003288;
	border-radius:5px;
	opacity:.5;
}
.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: 1100px; }
	.sp{ display:none!important; }
	[class*="adsPc"]{ position: absolute; }

	/* 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; }
	.odr1pc{ order: 1; }
	.odr2pc{ order: 2; }

	/* list
	****************************************************/
	.lst1 li, .lst1li{ padding-left: 130px; overflow: hidden; }
	.lst1 li span, .lst1li span{ display: block; float:left; width: 130px; margin-left: -130px; }
	.lst2{ padding-left: 40px; }
	.lst2 li{ width: 33%; margin: 10px 0; }

	/* width
	****************************************************/
	.w280{ width: 280px; }
	.w328{ width: 328px; }
	.w520{ width: 520px; }
	.w714{ width: 714px; }

	/* main
	****************************************************/
	.mv{ background: url("images/01_main@2x_20241125.png") repeat-x top center / 1920px 600px; height: 600px; margin-top: 15px; }

	/* header
	****************************************************/
	header{ height: 115px; margin-bottom: 20px; }
	header h1{ padding-top: 10px; }
	header .adsPc1{ top: 40px; left: 0; }
	header .adsPc2{ top: 52px; left: 460px; }
	header .adsPc3{ top: 40px; right: 0; }

	/* nav
	****************************************************/
	/* nav
	****************************************************/
	.gNav{ line-height: 20px; width: 100%; }
	.gNav ul{ display: flex; flex-wrap: wrap; text-align: center; justify-content: flex-start; }
	.gNav li{ width: 183px; }
	.gNav li:first-child{ width: 184px; }
	.gNav li:last-child{ width: 184px; }
	.gNav li ul li{ display: block; }
	.gNav ul a{ display: block; color: #333; padding: 10px 0; font-size: 16px; width: 160px; margin: 0 auto; }
	.gNav ul a:hover, .gNav ul .stay{ background: rgba(0, 50, 136, .2); }
	.gNav ul a img{ margin-bottom: 6px; }
	.fixed{ position: fixed; top: 0; left: 0; z-index: 9999; background-color: #fff; }
	.space{ margin-top: 60px; }
	.none{ display:none; }

	/* title
	****************************************************/
	.pp1ttl{
		background: url("images/back_pattern.png");
		height: 250px;
		margin-top: 15px;
	}

	/* content
	****************************************************/
	/* common */
	.spa1{ padding: 160px 0; }
	/* index */
	#index .sec1{ padding: 80px 0; }
	#index .sec2{ padding: 80px 0; background: url("images/back2pattern.png") repeat-x bottom center; }
	#index .sec3{ padding: 160px 0; }
	#index .sec3 .fbPc1 figure{ margin-top: 80px; }
	#index .sec4{ background: url("images/01_shinryo_back@2x.png") no-repeat top center / 1920px 520px; padding: 300px 0 80px; }
	#index .sec4 ul{ margin-top: 50px; }
	#index .sec4 li{ margin-right: 25px; margin-top: 25px; }
	#index .sec4 li:nth-child(5n){ margin-right: 0; }
	#index .sec5{ padding: 80px 0 160px; }
	#index .sec5 .gr1{ background: url("images/back_pattern.png"); margin-top: 80px; padding: 80px 0; }
	#medical .sec2 .box2c{ margin-top: 80px; }
	#medical .sec2 .box2c .fl{ width: 666px; }
	#facility .sec2 h3{ height: 80px; margin: 10px 0; }
	#facility .sec2 .gr1{ padding: 40px 0; margin-top: 80px; }
	#facility .sec2 .w328{ margin: 40px 58px 40px 0; }
	#facility .sec2 .w328:nth-child(3n){ margin-right: 0; }

	/* symptom
	****************************************************/
	/* symptom */
	#symptom li{ width: 25%; margin-top: 30px; }
	/* symptom2 */
	#symptom2 ul{ padding: 30px 0 50px 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 .des{ padding: 30px 0; }

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

	/* footer
	****************************************************/
	footer .sec1{ background: url("images/f_back@2x.png") no-repeat top center / cover; padding: 80px 0; color: #FFF; }
	footer .sec1 .box1c{ font-size: 24px; letter-spacing: .5em; height: 60px; }
	footer .sec2{ padding: 20px 0; font-size: 16px; }
    footer .sec2 .fbCom{ justify-content: center; }
	footer .sec2 li{ margin-left: 1em; margin-right: 1em; }
	footer .sec1 .gr1 li{ margin-right: 40px; margin-top: 30px; }
	footer .sec1 .gr1 a{ display: inline-block; min-width: 180px; }

	/* tracking
	****************************************************/
	[class*="trk"]{ position: fixed; transition: all 1s; z-index: 9999; }
	[class*="trk"] a:hover{ opacity: .75; }
	.trk1{ top: 300px; right: 0; }
	.trk2{ top: 425px; right: 0; }

	/* breadcrumbs
	****************************************************/
	.breadcrumbs ol{ margin: 5px 0 0 0; }

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



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

	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; }
	.tacSp{ text-align: center; }
    .lnk3btn{ width: 90%; }
	.lst1 li span, .lst1li span{ display: block; }
	.mt1adj, .mt40sp{ margin-top: 40px; }
	.mt2adj{ margin-top: 50px; }
	.pad40{ padding: 20px; }

	/* font-size
	****************************************************/
	.fsS{ font-size: 19px; }
	.fsM{ font-size: 23px; }
	.fsL{ font-size: 26px; }

	/* 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; }

	/* nav
	****************************************************/
	html{ overflow-x: hidden; }
	#headerSp{ width:100%; background-color: #fff; position:fixed; top: 0px; left: 0px; z-index: 999; }
	#headerSp .inner{ padding: 5px; }
	/* nav */
	.gNav{
		background: rgba(0, 75, 173, .95);
		position: fixed;
		height: 100%;
		width: 50%;
		z-index: 1000;
		transition: all 0.5s;
		right: -100%;
		top: 0;
		overflow-y: scroll;
		-webkit-overflow-scrolling: touch;
		padding-top: 80px;
	}
	.gNav.active{ right: 0%; }
	.gNav li{ border-bottom: 1px solid #DDDDDD; margin-left: -15px; margin-right: -15px; }
	.gNav li a{
		background: url("images/sp_menu_icon@2x.png") no-repeat left center / 12px 18px;
		display: block;
		padding: 15px 15px 15px 20px;
		color: #FFF;
		margin-left: 15px;
	}
	.gNavBk{}
	.gNavBk.active{ right: 0%; }
	.gNav li a img, .gNav li a br{ display: none; }

	/*=============================
	.btn-trigger
	=============================*/
	.btn-trigger{
		position: fixed;
		top: 10px;
		right: 10px;
		z-index: 9999;
		background: #004BAD;
		cursor: pointer;
		width: 50px;
		height:50px;
		border: 1px solid #004BAD;
	}
	.btn-trigger span{
    display: inline-block;
    transition: all .4s;
    position: absolute;
    left: 14px;
    height: 3px;
    border-radius: 2px;
	background: #fff;
  	width: 45%;
	}
	.btn-trigger.active{
		background: #FFFFFF;
	}
	.btn-trigger.active span{
		background: #004BAD;
	}
	.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%;
	}

	/* main
	****************************************************/
	.mv{
		background: url("images/sp_01_main@2x_20241125.png") no-repeat top center / 100% auto;
		padding-top: 133.33%;
		position:relative;
		text-align: center;
	}

	/* title
	****************************************************/
	.pp1ttl{ background: url("images/back_pattern.png"); height: 150px; }

	/* content
	****************************************************/
	/* common */
	.spa1, .spa2{ padding-top: 50px; padding-bottom: 50px; }
	.bg1c{ background: url("images/sp_01_back03@2x.png") no-repeat top center / 100% auto #F5F5F5; }
	/* index */
    #index .sec1{ padding: 30px 15px; }
	#index .sec2{ margin-top: 50px; }
    #index .sec2 .fl{
		background: url("images/back2pattern.png") repeat-x bottom center / 20px 250px;
		margin: 40px -15px 0 -15px;
		padding: 0 15px 30px;
	}
	#index .sec3{ margin-top: 50px; }
	#index .sec3 figure{ margin-top: 40px; text-align: center; }
	#index .sec4{ background: url("images/sp_01_shinryo_back@2x.png") no-repeat top center / 100% auto; margin-top: 65px; padding-top: 53%; }
	#index .sec4 h2{ margin-top: 40px; }
	#index .sec4 .listLnk{ justify-content: space-between; margin-top: 20px; }
	#index .sec4 .listLnk li{ width: 48%; margin-top: 20px; }
	#index .sec5{ margin-top: 80px; margin-bottom: 80px; }
	#index .sec5 .gr1{ background: url("images/back_pattern.png"); padding: 25px 0; margin-top: 40px; }
	#index .sec5 .fl{ margin-top: 40px; }
	#medical .sec1 .fl{ margin-top: 40px; }
	#medical .sec2 .box2c{ margin-top: 40px; padding: 20px; }
	#facility .sec1 h2{ margin-top: 40px; }
	#facility .sec2 h3{ margin: 20px 0; }
	#facility .sec2 .gr1{ margin-top: 40px; padding-bottom: 50px; }
	#facility .sec2 .w328{ margin-top: 50px; }
	#access .fbPc1 figure{ margin-bottom: 30px; }
	#access .fbPc li{ margin-bottom: 30px; }

	/* symptom
	****************************************************/
	/* symptom */
	#symptom li{ margin-top:1em; }
	/* symptom2 */
	#symptom2 h3{ margin-bottom: 2em; }
	#symptom2 ul{ margin-top:30px; padding: 10px 15px 15px; }
	#symptom2 li{ margin-top:10px; }
	/* symptom3 */
	#symptom3 h4{ font-size:18px; margin-top:50px; }
	#symptom3 h4:first-child{ margin-top: 0; }
	#symptom3 .des, #symptom3 dl, #symptom3 .back{ margin-top: 30px; }

	/* footer
	****************************************************/
	footer .sec1{ background: url("images/sp_f_back@2x.png") no-repeat top center / cover; padding: 40px 0 30px; color: #FFF; }
	footer .sec1 .gr1 li{ margin-top: 20px; }
	footer .sec2 ul{ padding: 15px 25px 25px; }
	footer .sec2 li{ width: 50%;  margin-top: 10px; }
	address{ font-size: 12px; padding-bottom: 1em; }

	/* 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; background-color: #004BAD; }
	#footerSp tr td:nth-of-type(1){ width: 50%; text-align: center; }
	#footerSp tr td:nth-of-type(2){ border-left: 1px solid #FFF; }
	#footerSp a{ display: block; text-align:center; padding: 10px 0; color: #fff; }
	#footerSp a img{ vertical-align: -12px; margin-right: 10px; }
}