@charset "utf-8";
/* CSS Document */
html, body, div, span, iframe,
h1, h2, h3, h4, h5, h6, p, 
a, strong, sub, sup,
dl, dt, dd, ol, ul, li,
table, caption, tbody, tfoot, thead, tr, th, td {
	margin: 0;
	padding: 0;
	border: 0;
	vertical-align: baseline;
	font-style: inherit;
	font-weight: inherit;
	outline: 0;
}
img {
	vertical-align: text-bottom;
}

#sections .sectionContents.container2 {
	max-width: 100%;
	padding: 0;
}
/*----------------------------------------
    PC
----------------------------------------*/



#wrap{
	width: 1200px;
	font-family: "メイリオ", "Meiryo", "verdana", "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "Osaka", "ＭＳ Ｐゴシック", "MS PGothic", Sans-Serif;
	font-size: 18px;
	color: #003996;
}
.ta_c{
	text-align: center;
}
.ta_r{
	text-align: right;
}
.sp{
	display: none;
}
a{
	color: #4174e1;
	font-weight: normal;
}


#sns{
	width: 1200px;
	background: #001942;
	padding-bottom: 45px;
	margin-bottom: 0; 
	text-align: center;
}
div#sns p{
	display: inline;
}
#btn{
	width: 976px;
	padding-bottom: 45px;
	margin-bottom: 0;
	display: flex;
	justify-content: center;
	flex-wrap:wrap;
	margin: 0 auto;
}
#btn_pc{
	width: 1200px;
	background: linear-gradient(#001942, #2352BC); 
}
#btn p{
	margin: 3px;
}
div#sns p{
	display: inline;
	margin: 0 50px;
}
.right p{
	border-bottom: 1px solid #bababa;
}
#event_info{
	width: 1200px;
	background: #e0eefb;
	padding-bottom: 45px;
	margin-bottom: 0; 
}
#event_info h2{
	margin-bottom: 45px;
}
#event_info p{
	margin-bottom: 20px;
	font-weight: bold;
	line-height: 1.6;
}
#event_info p.ef01{
	font-size: 166%;
	line-height: 30px;
}
#event_info p.ef01 span{
	font-size: 60%;
	color: #000;
}
#event_info p.ef02{
	font-size: 144%;
	color: #000;
}
#event_info p.ef03{
	color: #000;
}
#event_info p.ef04{
	margin: 2em auto;
    padding: 1em;
   width: 50%;
   color: #000; 
   background-color: #f7f7f7;
   border: 1px solid #000; 
}
#event_info a:hover{
	text-decoration: underline !important;
}
.access{
	width: 976px;
	overflow: hidden;
	padding: 20px 100px 20px;
	margin-bottom: 0px;
}
.access h3{
	line-height: 82px;
	margin-bottom: 20px;
}
.access .left{
	width: 450px;
	float: left;
}
.access .right{
	float: right;
	margin: 80px 50px;
}
.access .right p{
	color: #000;
	text-align: left;
	padding-bottom: 20px;
	line-height: 1.6;
	text-indent: -55px;
	
}
.access .right ul{
	color: #000;
	text-align: left;
	margin-top: 20px;
	list-style: none;
	list-style-position: outside;
}
.map{
	background: #e0eefb;
	width: 976px;
	overflow: hidden;
	padding: 20px 100px 20px;
	margin-bottom: 0px;
}
.map h3{
	line-height: 82px;
	margin-bottom: 20px;
}
.map .left{
	width: 450px;
	float: left;
}
.map .right{

	float: right;
}
.boosbg{
	text-align: center;
	background: #2352bc;
		padding-bottom: 30px;
}

@media screen and (max-width:1220px){
	#wrap{
		width: 100%;
	}
	#topimg .pc{
		width: 100%;
	}
}
@media screen and (max-width:1200px) {
	#wrap {
		width: 100%;
	}
}

@media screen and (max-width:976px) {
	#wrap {
		width: 976px;
	}
}
.access:after {
  clear: both;
  content: '';
  display: block;
}
/*----------------------------------------
    SP
----------------------------------------*/
@media screen and (max-width:768px) {
	.pc{
		display: none;
	}
	.sp{
		display: block;
		position: relative;
	}
	#wrap{
		width: 100%;
		font-size: 16px
	}
	#wrap img{
		width: 100%;
		height: auto;
	}
	#topimg a img{
		width: 15%;
	}
	#topimg .pc .sns{
	width: 967px;
	position: relative;
	margin-left: auto;
	margin-right: auto;
}
#sns{
	width: 100%;
	background: #001942;
	padding-bottom: 45px;
	margin-bottom: 0; 
	text-align: center;
}
	#btn{
	width:100%;
	padding-bottom: 45px;
	margin-bottom: 0;
}
	#btn p{
	width: 47%;
}
	div#sns p{
	display: inline;
	margin: 0 0px;
}
	#btn_pc{
	width: auto;

}
	#topimg p.facebook{
	position: static;
	left: 0;
	top: 0;
	width:150px;
}
#topimg p.twitter{
	position: static;
	left: 0;
	top: 0;
	width: 150px;
}
#topimg p.line{
	position: static;
	left: 0;
	top: 0;
	width:150px; 
}
	#bonus{
		width: 100%;
		font-size: 100%;
	}
	#bonus p{
		line-height: 1.8;
		font-size: 100%;
	}
	#bonus p span{
	background: linear-gradient(transparent 75%, #f7e857 75%);
}
	#bonus p.bonus, .right p{
		padding: 0 20px;
	}
	.left p, .left ul{
		padding: 0;
	}
	#event_info{
		background-size: contain;
		width: 100%;
	}
	#event_info h2{
		background-size: contain;
		line-height: inherit;
	}
	#event_info p.ef01{
		line-height: 1.1;
		font-size: 120%;
	}
	#event_info p.ef02 {
		font-size: 100%;
	}
	#event_info p.ef04{

   width: 70%;

}
	.access{
		width: 100%;
		margin-bottom: 70px;
		padding: 0;
	}
	.access .right{
		float: none;
		width: 100%;
		margin-bottom: 30px;
	}
	.access .right div p{
		margin: 20px 0;
	}
	.access .right ul{
	text-align: center;
}
	.access .right div ul {
		margin: 20px 0;
	}

.access .right{
	float: right;
	font-size: .9rem;
	margin: 0;
}
.access .right p{
	color: #000;
	text-align: center;
padding-bottom: 5px;
	text-indent:0px;
	margin: 10px;
	white-space: nowrap;
}
	.map iframe{
		width: 100%;
	}
	.map .right{
		float: none;
		width: 100%;
	}
	.map{
		width: 100%;
		margin-bottom: 70px;
		padding: 0;
	}
	.map .left{
		float: none;
		width: 100%;
		margin-bottom: 30px;
	}
	.map iframe{
		width: 100%;
	}
	.map .right{
		float: none;
		width: 100%;
	}
}