@charset 'UTF-8';

/*
----------
irex2015 top
----------
*/
#mainimg { position: relative; }
#mainimg .banner { position: absolute; left: 60px; bottom: 50px; }
.subNav { margin-top: 0.75em; }
.subNav ul { text-align: right; letter-spacing: -0.4em; }
.subNav ul li { display: inline-block; margin-left: 20px; letter-spacing: normal; font-size: 92.85%; font-weight: bold; }
.subNav ul li.barcode_link { padding: 7px 10px; border: 1px solid #e00000; }
.subNav ul li.barcode_link:hover { background-color: #fdf2f2; }
.subNav ul li.barcode_link img.icon_rq { margin: -2px 10px 0 0; vertical-align: middle; }


#topTitle { margin: 1.5em 0 2em; padding-bottom: 1em; border-bottom: 1px solid #7f7f7f; font-size: 114.3%; font-weight: bold; }
.topLead { margin-bottom: 2.5em; text-align: center; font-size: 128.5%; font-weight: bold; }

@media only screen and (max-width: 640px) {
	#mainimg { margin: 0 -8px; }
	#mainimg img { width: 100%; vertical-align: bottom; }
	#mainimg .banner { position: inherit; left: inherit; bottom: inherit; padding: 12px 20px 17px 21px; background-color: #a3a3a3; }
	#mainimg .banner img { display: block !important; }
	#mainimg .banner .mordalInline:after { display: none; }
	.subNav ul { margin-top: 1.35em; text-align: left; }
	.subNav ul li { display: block; margin: 1em 0 0; font-size: 85.7%; }
	.subNav ul li:nth-child(3) { display: none; }

	#topTitle { margin: 2.5em 0 1.5em; padding-bottom: 1.5em; font-size: 100%; }
	.topLead { margin-bottom: 2.5em; text-align: left; font-size: 100%; }
}

.topHeadline { margin-bottom: 2.35em; position: relative; text-align: center; }
.topHeadline span { position: relative; display: inline-block; padding: 0 10px; background-color: #fff; text-align: left; color: #e00000; font-size: 200%; font-weight: bold; z-index: 2; }
.topHeadline:before { position: absolute; top: 50%; content: ''; display: block; width: 100%; height: 2px; border-top: 2px solid #e00000; z-index: 1; }

#top .exhibition_section { margin-bottom: 3.5em; }
#top #enquete.exhibition_section { margin-bottom: 5em; }


@media only screen and (max-width: 640px) {
	.topHeadline { margin-bottom: 1em; }
	.topHeadline span { display: block; padding: 0; background: none; font-size: 171.4%; text-align: center; line-height: 1.34; }
	.topHeadline:before { display: none; }
	
}

.topBorderWrap { padding: 28px 48px; border: 1px solid #ccc; }
.topBorderWrap #stampRallyWrap dl { display: table; width: 100%; }
.topBorderWrap #stampRallyWrap dl dt,
.topBorderWrap #stampRallyWrap dl dd { display: table-cell; vertical-align: middle; font-weight: bold; }
.topBorderWrap #stampRallyWrap dl dt { width: 330px; padding-right: 18px; }
.topBorderWrap #stampRallyWrap dl dd + dd { width: 205px; padding-left: 25px; }
.topBorderWrap #stampRallyWrap dl dd a { display: block; padding: 0.75em 5px; background-color: #c13434; text-align: center; font-weight: bold; }
.topBorderWrap #stampRallyWrap dl dd a:hover { opacity: 0.8; filter: alpha(opacity=80); }
.topBorderWrap #stampRallyWrap dl dd a .arw { background: url(../img/arw_white_pc.png) no-repeat 0 0.4em; color: #fff; }
.topBorderWrap #stampRallyWrap dl dd em { display: block; padding: 0.75em 5px; background-color: #bbb; text-align: center; font-weight: bold; }
.topBorderWrap #stampRallyWrap dl dd em .arw { background: url(../img/arw_gray_pc.png) no-repeat 0 0.45em; color: #ddd; }

.topBorderWrap #partners { margin-top: 22px; padding-top: 1.5em; border-top: 1px solid #ccc; }
.topBorderWrap #partners .sponsor { margin-bottom: 1.5em; font-weight: bold; }
.topBorderWrap #partners .sponsor dt { margin-bottom: 0.2em; }
.topBorderWrap #partners li { float: left; width: 205px; margin-left: 20px; font-size: 85.7%; font-weight: bold; text-align: center; }
.topBorderWrap #partners li:first-child { margin-left: 0; }
.topBorderWrap #partners li span { display: block; margin-bottom: 0.5em; }
.topBorderWrap #partners li a { display: block; margin-top: 0.5em; font-size: 91.6%; }
.topBorderWrap #partners li a .blank { margin-left: 2px; }

@media only screen and (max-width: 640px) {
	.topBorderWrap { margin: 0 -8px; padding: 28px 0; background-color: #f8f8f8; border: 1px solid #b2b2b2; border-left: none; border-right: none; }
	.topBorderWrap #stampRallyWrap dl { display: block; }
	.topBorderWrap #stampRallyWrap dl dt,
	.topBorderWrap #stampRallyWrap dl dd { display: block; }
	.topBorderWrap #stampRallyWrap dl dt { width: auto; height: 80px; padding: 0; background: url(../img/sp/img_top_stamp_rally.png) no-repeat center top; background-size: 293px auto; }
	.topBorderWrap #stampRallyWrap dl dt img { display: none; }
	.topBorderWrap #stampRallyWrap dl dd { margin-top: 1em; padding: 0 20px; }
	.topBorderWrap #stampRallyWrap dl dd + dd { width: auto; margin-top: 1.75em; }
	.topBorderWrap #stampRallyWrap dl dd a:hover { opacity: 1.0; filter: alpha(opacity=100); }
	.topBorderWrap #stampRallyWrap dl dd a .arw { background: url(../img/sp/arw_white_sp.png) no-repeat 0 0.4em; background-size: 8px auto; text-align: left; }
	.topBorderWrap #stampRallyWrap dl dd em .arw { background: url(../img/sp/arw_gray_sp.png) no-repeat 0 0.45em; background-size: 7px auto; text-align: left; }
	.topBorderWrap #stampRallyWrap dl dd .mordalInline:after { margin-left: -5px; background: url(../img/sp/icon_modal_w.png) no-repeat; background-size: 17px auto; }

	.topBorderWrap #partners { margin: 30px 20px 0; padding-top: 1.75em;  }
	.topBorderWrap #partners .sponsor dt { margin-bottom: 0.35em; }
	.topBorderWrap #partners li { float: none; width: 100%; margin: 2em 0 0; }
	.topBorderWrap #partners li:first-child { margin-top: 0; }
	.topBorderWrap #partners li span { text-align: center; }
	.topBorderWrap #partners li span img { width: 280px; margin: 0 auto; }
}

#mailnews { margin-bottom: 1em; padding: 38px 50px 20px; background: #fafafa; border: 1px solid #e5e5e5; }
#mailnews .head { position: relative; margin-bottom: 1em; font-size: 171.3%; font-weight: bold; text-align: center; line-height: 1.3; }
#mailnews .head span { position: relative; display: inline-block; padding: 0 10px 0 42px; background: url(../img/bg_mailnews.png) #fafafa no-repeat 10px top; font-weight: bold; z-index: 2; }
#mailnews .head:before { position: absolute; top: 50%; content: ''; display: block; width: 100%; height: 1px; border-top: 1px solid #d9d9d9; z-index: 1; }
#mailnews .label { margin-bottom: 15px; font-size: 142.9%; font-weight: bold; text-align: center; color:#e00000; }
#mailnews .text { margin-bottom: 18px; }
#mailnews .ex_button { display: table-cell; width: 415px; padding: 0.35em 5px; background-color: #3a3a3a; background-image: linear-gradient(-45deg, #000 50%, #3a3a3a 50%, #3a3a3a); text-align: center; vertical-align: middle; color: #fff; font-size: 128.6%; font-weight: bold; line-height: 1; }
#mailnews .ex_button:hover { opacity: 0.8; filter: alpha(opacity=80); }
#mailnews .ex_button .arw { display: inline-block; padding-left: 12px; background: url(../img/arw_white_pc.png) no-repeat 0 0.35em; }
#mailnews .ex_button small {font-size: 66.7%; }
#mailnews #member { float: left; width: 405px; }
#mailnews #regist { float: right; width: 405px; }
#mailnews #regist .link { margin-top: 10px; text-align: center; font-weight: bold; }

@media only screen and (max-width: 640px) {
	#mailnews { margin: 0 -8px 1em; padding: 30px 20px 3em; background: #f5f5f5; border: 1px solid #b2b2b2; border-left: none; border-right: none; }
	#mailnews .head { font-size: 135.7%; }
	#mailnews .head span { display: block; padding: 40px 0 0; background: url(../img/sp/bg_mailnews.png) no-repeat center top; background-size: 27px auto; }
	#mailnews .head:before { display: none; }
	#mailnews .label { margin-bottom: 0.2em; }
	#mailnews .text { margin-bottom: 1em; }
	#mailnews .ex_button { display: block; width: auto; padding: 0.75em 5px; font-size: 114.3%; }
	#mailnews .ex_button:hover { opacity: 1.0; filter: alpha(opacity=100); }
	#mailnews .ex_button .arw { background: url(../img/sp/arw_white_sp.png) no-repeat 0 0.4em; background-size: 8px auto; }
	#mailnews #member { float: none; width: 100%; }
	#mailnews #regist { float: none; width: 100%; margin-top: 2em; }
	#mailnews #regist .ex_button { padding: 1.3em 5px; }
	#mailnews #regist .link { margin-top: 0.75em; text-align: left; font-size: 85.7%; }
}

#stampRally .body { position: relative; padding-top: 23px; }
#stampRally .label { margin-bottom: 28px; }
#stampRally .balloon { position: absolute; top: 0; right: 20px; }
#stampRally .bold { margin-bottom: 0.35em; }
#stampRally .map { margin-top: 48px; }
#stampRally .sponsor { margin-top: 40px; }
#stampRally .map li,
#stampRally .sponsor li { float: right; }
#stampRally .map li:first-child,
#stampRally .sponsor li:first-child { float: left; }

#barcode .body { padding-bottom: 60px; }
#barcode .text { float: left; width: 375px; }
#barcode .text .bold { margin-bottom: 0.75em; }
#barcode .image { float: right; }


@media only screen and (max-width: 640px) {
	#stampRally .body { padding-top: 20px; }
	#stampRally .label { margin-bottom: 25px; width: 239px; height: 70px; background: url(../img/modal/sp/stamp_rally_label.png) no-repeat; background-size: 239px auto; }
	#stampRally .label img { display: none; }
	#stampRally .balloon { right: 5px; overflow: hidden; }
	#stampRally .balloon img { margin-top: -5px; width: 80px !important; }
	#stampRally .bold { margin-bottom: 0.35em; font-size: 107.14%; }
	#stampRally .map { margin-top: 30px; }
	#stampRally .sponsor { margin-top: 40px; }
	#stampRally .map li,
	#stampRally .sponsor li { float: none; }
	#stampRally .map li:first-child,
	#stampRally .sponsor li:first-child { float: none; margin-bottom: 30px; }
	#stampRally .map li:nth-child(2) { width: 154px; }
	
	#access.modal .body { padding-left: 20px; padding-right: 20px; } 

	#barcode .body { padding-left: 20px; padding-right: 20px; padding-bottom: 30px; }
	#barcode .text { float: none; width: 100%; }
	#barcode .text .bold { margin-bottom: 0.75em; }
	#barcode .image { float: none; margin-top: 20px; text-align: center; }
	#barcode .image img { width: 184px !important; }
}


#overview {
	margin:40px 0;
}

#overview img.p_img {
	float:left;
	width:30%;
	display:block;
	margin-right:4%;
	padding-bottom:3em;
}

#overview .ex_txt {
	float:left;
	width:66%;
}

#overview h3.label, .melfaWrap h3.label,
#overview_list dt {
	margin-bottom:15px;
	font-size:142.9%;
	font-weight:bold;
	color:#e00000;
}

#overview_list dt {
	margin-bottom:5px;
}

#overview_list dd {
	margin-left:30px;
	margin-bottom:1em;
}

#overview_list dd em {
	margin-top:5px;
	display:inline-block;
}

.melfaWrap {
	margin-top:40px;
}

.melfaWrap img.p_img {
	float:left;
	width:285px;
	height:auto;
	border:1px solid #ccc;
	padding:5px;
	display:block;
	margin-bottom:20px!important;
}

.melfaWrap .ex_txt {
	float:left;
	width:60%;
	margin-left:4%;
}

.melfaWrap ul {
	margin-left:-1%;
	margin-top:20px;
	margin-bottom:20px;
}

.melfaWrap ul li {
	width:48%;
	margin-left:1%;
	margin-bottom:10px;
	display:inline-block;
}

.melfaWrap ul li img {
	margin: -6px 5px 0px 0px;
	vertical-align: middle
}

.melfaWrap ul li a {
	text-align:center;
	background:#0082d5;
	padding:0.98em 0;
	display:block;
	width:100%;
	color:#fff;
	font-weight:bold;
}

.melfaWrap ul li a:hover {
	text-decoration:none;
	background:#52a2d8;
}

.partner .t_link {
	font-weight:bold;
}

.link_border_wrap { margin-bottom: 40px; padding: 34px 40px; background-color: #fcfcfd; border: 1px solid #d9d9d9; text-align: center; }
.link_border_wrap .text { margin-bottom: 1.35em; font-size: 130%; font-weight: bold; }
.link_border_wrap .btn_stage a { display: block; width: 500px; margin: 0 auto; padding: 1.25em 5px; background: #c13434; text-align: center; color: #fff; font-size:107.14%; font-weight:bold; }
.link_border_wrap .btn_stage a:hover {opacity: 0.8; -ms-filter: "alpha(opacity=80)"; }
.link_border_wrap .btn_stage a .arw { background-image: url(../img/arw_red_pc.png); }


@media screen and (max-width: 640px) {
	.link_border_wrap { margin-bottom: 35px; padding: 20px 15px; }
	.link_border_wrap .btn_stage a { width: auto; margin: 0 0; padding: 1.25em 13px; }
	.link_border_wrap .btn_stage a:hover {opacity: 1.0; -ms-filter: "alpha(opacity=100)"; }
	.link_border_wrap .btn_stage a .arw { background-image: url(../img/sp/arw_red_sp.png); background-size: 8px auto; }

	.melfaWrap ul {
		margin-left:0;
	}

	#overview .ex_txt, #overview_list {
		width:97%;
		margin-left:1.5%;
	}	
	
	img.p_img, .melfaWrap .ex_txt {
		float:none!important;
		clear:both!important;
	}
	
	 .melfaWrap .ex_txt {
	 	width:97.5%;
		margin:20px auto;
	 }
	
	.melfaWrap ul li {
		width:100%;
		margin:15px auto;
		display:block;
	}
	
	img.p_img {
		display:block;
		margin:0 auto!important;
	}
	
	#overview img.p_img {
		width:90%;
		max-width:376px;
	}

	.melfaWrap img.p_img {
		width:96%;
	}
	
	#overview_list em {
		font-weight:bold!important;
	}

}