@charset "utf-8";


body #single,
html #single {
	color: #003252;
	font-family: -apple-system, BlinkMacSystemFont, "Helvetica Neue", メイリオ, "游ゴシック Medium", YuGothic, YuGothicM, "Hiragino Kaku Gothic ProN", Meiryo, sans-serif;
	text-align: center;
	margin: 0px;
	padding: 0px;
}

a {
	text-decoration: none;
}

#single {
	z-index: 1;
	width:100%;
}

#single ul {
	margin: 0px;
	padding: 0px;
	list-style: none;
}

#single title {
	font-size: 30px;
	font-weight: bold;
	margin-top: 60px;
}

#single h2 {
    color: #ffffff;
	background: #045CB4;
	font-size: 30px;
	font-weight: bold;
	margin: 0 calc(50% - 50vw) 50px;
	padding: 20px 0 16px;
}

#single .box {
	padding: 80px;
}

#single .inner {
	max-width: 1200px;
	margin: 0px auto;
	padding: 0px 20px;
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼ファーストビュー --*/
/*-- --------- --------- --------- --------- --------- --*/
#fv {
/*--	background:#8ac7e6; --*/
	padding: 60px 0px 80px 0px;
}

#fv ul {
	color: #ffffff;
	font-weight: bold;

	list-style: none;

	margin: 0px auto;
	padding: 0px;
}

#fv ul li {
	margin-bottom: 30px;
}

#fv ul li.target {
	color: #045CB4;
	font-size: 20px;
	line-height: 40px;
	display: inline-block;
	padding: 0px 20px;
	background: #ffffff;
	border-radius: 20px;
	position: relative;
}

#fv ul li.target:after {
	content: "";
	display: block;
	width: 45px;
	height: 30px;
	background: url("../img/fv-target-allow.png") no-repeat center center / 100% auto;
	position: absolute;
	bottom: -30px;
	left: 50%;
	margin-left: -22px;
}

#fv ul li.sub {
	font-size: 40px;
	margin-bottom: 10px;
	text-shadow: 0px 0px 5px rgba(0, 50, 82, 0.3);
	-webkit-text-shadow: 0px 0px 5px rgba(0, 50, 82, 0.3);
	-moz-text-shadow: 0px 0px 5px rgba(0, 50, 82, 0.3);
}

#fv ul li.main {
	font-size: 80px;
	text-align: center;
	padding: 0px 10px;
}

#fv ul li.main>* {
	margin-left: -0.3em;
}

#fv ul li.main img {
	display: inline-block;
	height: 78px;
}

#fv ul li.main span {
	display: inline-block;
}

#fv ul li.main b {
	color: #ffff00;
	display: inline-block;
}

#fv ul li.day {
	color: #003252;
	font-size: 24px;
	display: inline-block;
	margin-bottom: 10px;
	line-height: 1.2em;
	padding: 0px 10px;
}

#fv ul li.time img,
#fv ul li.place img,
#fv ul li.day img {
	display: inline-block;
	width: 22px;
	margin: 0px 5px;
}

#fv ul li.day b {
	font-size: 48px;
}

#fv ul li.time {
	color: #003252;
	font-size: 24px;
	line-height: 1.5em;
	display: block;
	margin-bottom: 20px;
}

#fv ul li.time span {
	display: inline-block;
	font-size: 13px;
}

#fv ul li.place {
	color: #003252;
	font-size: 24px;
	line-height: 1.2em;
	padding: 0px 10px;
}

#fv ul li.place span {
	font-size: 20px;
	display: inline-block;
	margin-left: 10px;
}

#fv ul li.btn a {
	color: #045CB4;
	font-size: 20px;
	line-height: 100px;
	display: inline-block;
	width: 400px;
	height: 100px;
	margin: 0px 5px;
	background: #ffff00;
	border-radius: 5px;
	position: relative;
	box-shadow: 0px 4px 0px #d9d900;
}

#fv ul li.btn a:hover {
	box-shadow: none;
	position: relative;
	bottom: -4px;
}

#fv ul li.btn a:after {
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	position: absolute;
	top: 50%;
	right: 20px;
	margin-top: -15px;
	background: url("../img/fv-btn-allow.png") no-repeat center center / 100% auto;
}

a.seminor {
	background: #5ce55c !important;
	box-shadow: 0px 4px 0px #52cc52 !important;
}

a.seminor:hover {
	box-shadow: none !important;
}

#fv ul li.btn a span {
	font-size: 20px;
}

#fv ul li.btn i {
	font-size: 14px;
	text-align: center;
	margin-top: 20px;
	font-style: normal;
	display: block;
	color: #045CB4;
}

#fv ul li.point {
	color: #045CB4;
	font-size: 20px;
	line-height: 40px;
	display: inline-block;
	padding: 0px 40px;
	background: rgba(255, 255, 255, 0.5);
	border-radius: 20px;
}

#fv ul li.point img {
	display: inline-block;
	width: 20px;
	margin: 0px 4px 0px 12px;
	position: relative;
	bottom: -2px;
}

#fv ul li.f-nav a {
	color: #ffffff;
	font-size: 18px;
	font-weight: normal;
}

#fv ul li.f-nav span:after {
	content: "　│　";
}

#fv ul li.f-nav span:last-child:after {
	content: none;
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼参加企業 --*/
/*-- --------- --------- --------- --------- --------- --*/

div[id*="join"] ul {
	position: relative;
}

div[id*="join"] ul li {
	width:20%;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.2;
	display: inline-block;
	padding: 0px 10px;
	margin-bottom: 20px;
	text-align: left;
}

div[id*="join"] ul li span {
	color: #ffffff;
	font-size: 16px;
	font-weight: normal;
	line-height: 1.8em;
	text-align: left;
	display: none;
	width: 300px;
	padding: 30px;
	margin: 40px 20px 0px 20px;
	background: rgba(0, 50, 82, 0.95);
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: 20;
}

div[id*="join"] ul li span i {
	display: block;
	width: 0;
	height: 0;
	position: absolute;
	top: -20px;
	border-style: solid;
	border-width: 0 20px 20px 20px;
	border-color: transparent transparent #003252 transparent;
	opacity: 0.95;
}

div[id*="join"] ul li b {
	display: block;
	z-index: 0;
}

div[id*="join"] ul li b a {
	color: #003252;
}

div[id*="join"] ul li b a:hover {
	color: #3399ff;
	text-decoration: underline;
}

div[id*="join"] a.more {
	display: none;
}

div[id*="join"] a.list-check {
	color: #ffffff;
	line-height: 60px;
	display: block;
	width: 240px;
	height: 60px;
	margin: 0px auto;
	background: #003252;
}

div[id*="join"] a[class*="open"] {
	color: #ffffff;
	line-height: 60px;
	display: block;
	width: 240px;
	height: 60px;
	margin: 20px auto;
	background: #003252;
	border-radius: 5px;
}

/*-- --------- --------- --------- --*/
/*-- ▼参加企業一覧 --*/
/*-- --------- --------- --------- --*/
div[id*="join-list"] {
	width: 100%;
	height: 100%;
	position: absolute;
	top: 0px;
	left: 0px;
	opacity: 0;
	display: none;
}

div[id*="join-list"] h3 {
	color: #ffffff;
	font-size: 30px;
	margin: 0px auto;
	padding: 30px 0px;
	position: relative;
	z-index: 101;
	max-width: 800px;
}

div[id*="join-list"]>div {
	background: #ffffff;
	max-width: 800px;
	border-radius: 4px;
	margin: 0px auto;
	position: relative;
	z-index: 200;
}

div[id*="join-list"] th {
	text-align: left;
	vertical-align: middle;
	width: 40%;
	padding: 10px;
	display: none;
}

div[id*="join-list"] td {
	font-size: 14px;
	text-align: left;
	vertical-align: middle;
	width: 15%;
	padding: 10px;
}

div[id*="join-list"] td:first-of-type {
	font-weight: bold;
	width: 40%;
}

div[id*="join-list"] td:last-child a {
	color: #ffffff;
	line-height: 30px;
	text-align: center;
	display: inline-block;
	background: #003252;
	border-radius: 4px;
	padding: 0px 20px;
}

div[id*="join-list"] td:last-child {
	text-align: center;
}

div[id*="join-list"] tr:nth-child(1) {
	text-align: center;
}

div[id*="join-list"] tr:nth-child(2n-1) {
	background: #efefef;
}

div[id*="join-list"] table {
	width: 100%;

}

div[id*="join-list"] table td b {
	display: none;
}

div[id*="join-list"] a.close.top {
	color: #ffffff;
	font-size: 40px;
	line-height: 60px;
	text-align: center;
	width: 60px;
	height: 60px;
	background: #ff3333;
	z-index: 300;
	position: fixed;
	top: 0px;
	right: 0px;
	left: auto;
}

div[id*="join-list"] a.close.bottom {
	color: #ffffff;
	line-height: 40px;
	text-align: center;
	display: block;
	width: 100px;
	height: 40px;
	margin: 100px auto 200px auto;
	background: #ff3333;
	border-radius: 5px;
	z-index: 200;
	position: relative;
}

div[id*="join-list"] a.close.all {
	content: "";
	display: block;
	width: 100%;
	height: 100%;
	position: fixed;
	top: 0px;
	left: 0px;
	z-index: 100;
	background: rgba(0, 0, 0, 0.7);
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼イベント内容 --*/
/*-- --------- --------- --------- --------- --------- --*/
#event-content {
	background: #045CB4;
}

#event-content h2 {
	color: #ffffff;
	position: relative;
	z-index: 11;
}

#event-content ul {
	border-radius: 5px;
}

#event-content ul li {
	background: #ffffff;
	border-radius: 5px;
	margin-top: 40px;
	position: relative;
}

#event-content ul li:nth-child(1) {
	z-index: 10;
}

#event-content ul li:nth-child(2) {
	z-index: 8;
}

#event-content ul li:nth-child(3) {
	z-index: 7;
}

#event-content ul li:nth-child(4) {
	z-index: 6;
}

#event-content ul li:nth-child(5) {
	z-index: 5;
}

#event-content ul li:nth-child(6) {
	z-index: 4;
}

#event-content ul li:nth-child(1):before {
	content: "1";
}

#event-content ul li:nth-child(2):before {
	content: "2";
}

#event-content ul li:nth-child(3):before {
	content: "3";
}

#event-content ul li:nth-child(4):before {
	content: "4";
}

#event-content ul li:nth-child(5):before {
	content: "5";
}

#event-content ul li:nth-child(6):before {
	content: "6";
}

#event-content ul li:before {
	color: #ffffff;
	font-size: 30px;
	font-weight: bold;
	text-align: center;
	line-height: 120px;
	display: block;
	width: 100px;
	height: 100px;
	position: absolute;
	top: -60px;
	left: 50%;
	margin-left: -50px;
	background: #045CB4;
	border-radius: 50px;
	z-index: 5;
}

#event-content ul li:after {
	content: "";
	display: block;
	clear: both;
}


#event-content ul li div.image {
	width: 50%;
	position: absolute;
	top: 0px;
	left: 0px;
	z-index: 2;
	overflow: hidden;
	border-radius: 5px 0px 0px 5px;
}

#event-content ul li:nth-child(2n) div.image {
	left: auto;
	right: 0px;
	border-radius: 0px 5px 5px 0px;
}

#event-content ul li div.image img {
	display: block;
	width: 100%;
	height: auto;
	position: absolute;
	margin: auto auto;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
}

#event-content ul li div.text {
	line-height: 1.66em;
	text-align: left;
	padding: 40px;
}

#event-content ul li:nth-child(2n) div.text {
	float: left;
}

#event-content ul li div.text b {
	font-size: 18px;
	line-height: 1.4em;
	display: block;
	margin-bottom: 10px;
	position: relative;
}

#event-content ul li div.text a.btn {
	color: #ffffff;
	font-size: 14px;
	line-height: 1.0em;
	text-align: center;
	display: block;
	max-width: 400px;
	padding: 1.5em 3.0em;
	margin: 20px auto;
	background: #003252;
	border-radius: 5px;
	position: relative;
	clear: both;
}

#event-content ul li div.text a:after {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -10px;
	background: url("../img/allow40w.png") no-repeat center center / 100% auto;
}

#event-content ul li div.text a.btn span {
	font-size: 15px;
}

/*-- --------- --------- --------- --*/
/*-- ▼19.02.06修正 --*/
/*-- --------- --------- --------- --*/
@media screen and (min-width: 600px) {
	#event-content ul li div.image {
		width: 35%;
		position: relative;
		float: right;
		z-index: 2;
		overflow: none;
		border-radius: 0px;
		margin: 40px 40px 20px 20px;
	}

	#event-content ul li:nth-child(2n) div.image {
		left: auto;
		right: auto;
		border-radius: 0px;
		float: right;
		margin: 40px 40px 20px 20px;
	}

	#event-content ul li div.image img {
		position: relative;
	}

	#event-content ul li div.text {
		width: auto;
		float: none;
	}

	#event-content ul li:nth-child(2n) div.text {
		float: none;
	}

	#event-content ul li div.text p {
		margin: 0px !important;
		padding: 0px;
	}

	#event-content ul li div.text a.btn {
		width: 80%;
		padding: 1.5em 3.0em;
		margin: 20px auto 0px auto;
	}
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼参加特典 --*/
/*-- --------- --------- --------- --------- --------- --*/
#present {
	background: url("../img/present-bg.png");
}

#present ul {
	text-align: center;
}

#present ul:after {
	content: "";
	clear: both;
	display: block;
}

#present ul li {
	font-weight: bold;
	text-align: left;
	vertical-align: top;
	display: inline-block;
	width: 30%;
	margin-right: 3%;
	margin-bottom: 20px;
	position: relative;
}

#present ul li:last-child {
	margin-right: 0px;
}

#present ul li b {
	color: #ffffff;
	text-align: center;
	display: block;
	font-size: 20px;
	line-height: 40px;
	height: 40px;
	margin: 0px auto 20px auto;
	background: #f5a517;
	position: relative;
}

#present ul li b:after {
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 10px 0 10px;
	border-color: #f5a517 transparent transparent transparent;
	position: absolute;
	bottom: -10px;
	left: 50%;
	margin-left: -10px;
}


#present ul li img {
	display: block;
	width: 85%;
	margin: 0px auto 10px auto;
}

#present .caution {
	font-size: 14px;
	line-height: 1.78em;
	text-align: left;
	margin-top: 30px;
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼入場までの流れ --*/
/*-- --------- --------- --------- --------- --------- --*/
#event-step ul {
	padding: 20px 0px;
	background:
		url("../img/step-allow.png")no-repeat 32.33% center / 50px 100%,
		url("../img/step-allow.png")no-repeat 66.66% center / 50px 100%,
		#f0f5f7;
	border-radius: 5px;
}

#event-step ul:after {
	content: "";
	display: block;
	clear: both;
}

#event-step ul li {
	font-size: 16px;
	text-align: left;
	line-height: 30px;
	width: 33.33%;
	padding: 20px;
	float: left;
}

#event-step ul li b {
	text-align: center;
	display: block;
	font-size: 20px;
	line-height: 2.0em;
	margin-bottom: 10px;
}

#event-step ul li b img {
	display: block;
	width: 120px;
	margin: 0px auto;
}

#event-step ul li span {
	color: #ff3333;
	font-size: 12px;
	text-align: right;
	display: block;
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼アクセス --*/
/*-- --------- --------- --------- --------- --------- --*/
#access {
	background: #f0f5f7;
}

#access ul {
	margin-bottom: 40px;
}

#access ul li {
	margin-bottom: 10px;
}

#access ul li:nth-child(1),
#access ul li:nth-child(2) {
	font-size: 20px;
}

#access ul li:nth-child(3) {
	font-size: 14px;
}

/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼お問い合わせ --*/
/*-- --------- --------- --------- --------- --------- --*/
#contact {
	font-size: 16px;
}

#contact span {
	display: inline-block;
}

#contact b {
	font-size: 32px;
	line-height: 1.5em;
	display: block;
	margin: 20px;
}

#contact b img {
	display: inline-block;
	width: 30px;
	height: 30px;
	position: relative;
	bottom: -3px;
	margin-right: 5px;
}

#contact b a {
	color: #003252;
	background: none;
	transition: all 0.4s linear 0s;
}

#contact b a:hover {
	background: #ffff00;
}

#contact .caution {
	color: #ff3333;
	text-indent: -1.0em;
	padding-left: 1em;
}


#contact .caution .highlights {
	background: linear-gradient(transparent 0%, #f6ff5f 0%);
	display: inline !important;
}


/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼イベント概要 --*/
/*-- --------- --------- --------- --------- --------- --*/
#summary {
	color: #ffffff;
	background: #003252;
}

#summary table {
	color: #ffffff;
	margin: 0px auto;
}

#summary table th {
	font-size: 18px;
	font-weight: normal;
	line-height: 1.8em;
	vertical-align: middle;
	text-align: center;
	width: 30%;
	padding: 10px;
}

#summary table td {
	line-height: 1.8em;
	text-align: center;
	vertical-align:middle;
	width: 70%;
	padding: 10px;
	word-break: keep-all;
}

#summary table td i {
	display: block;
	font-size: 12px;
	font-style: normal;
}

#single #summary table+a {
	color: #045CB4;
	font-size: 30px;
	font-weight: bold;
	line-height: 80px;
	display: block;
	width: 300px;
	height: 80px;
	margin: 40px auto 0px auto;
	background: #ffff00;
	border-radius: 5px;
	position: relative;
}

#single #summary table+a:after {
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -15px;
	background: url("../img/fv-btn-allow.png") no-repeat center center / 100% auto;
}

#summary table+a span {
	font-size: 15px;
}


/*-- --------- --------- --------- --------- --------- --*/
/*-- ▼追尾ナビ --*/
/*-- --------- --------- --------- --------- --------- --*/
#move-nav{
	text-align: center;
	width: 100%;
	padding: 20px;
	position: fixed;
	bottom: 0px;
	left: 0px;
	background: rgba(0,50,82,0.9);
	z-index: 9999;
}
#move-nav a{
	color: #045CB4;
	font-size: 20px;
	font-weight: bold;
	line-height: 80px;
	text-align: center;
	display: inline-block;
	width: 300px;
	height: 80px;
	margin: 0px 10px;
	background: #ffff00;
	border-radius: 5px;
	box-shadow: 0px 4px 0px #d9d900;
	position: relative;
}
#move-nav a:hover{
	box-shadow: none;
	bottom: -4px;
}

#move-nav a:after{
	content: "";
	display: block;
	width: 30px;
	height: 30px;
	position: absolute;
	top: 50%;
	right: 10px;
	margin-top: -15px;
	background: url("../img/fv-btn-allow.png") no-repeat center center / 100% auto;
}
#move-nav a span{
	font-size: 20px;
}

#move-nav.hidden {
  opacity: 0;
  pointer-events: none;
}

/*-- --------- --------- --------- --*/
/*-- 完了画面追加修正190322 --*/
/*-- --------- --------- --------- --*/
#fin {
	text-align: center;
	width: 100%;
	position: relative;
	margin: 40px 0px;
}

/*
#fin > div{
	position: absolute;
	top: 0px;
	left: 0px;
	right: 0px;
	bottom: 0px;
	height: 500px;
	margin: auto auto;
}*/
#fin h2 a {
	color: #ffffff;
	font-size: 60px;
}

#fin p {
	color: #045CB4;
	font-size: 16px;
	margin: 80px;
}

#fin a {
	color: #045CB4;
	font-size: 20px;
	text-decoration: underline;
}

@media screen and (min-width: 0px) and (max-width: 601px) {
	#fin {
		height: auto;
	}

	#fin>div {
		height: auto;
	}

	#fin h2 a {
		font-size: 30px;
	}

	#fin p {
		font-size: 14px;
		margin: 40px;
	}

	#fin a {
		font-size: 20px;
	}

	#single footer {
		padding-bottom: 80px !important;
	}

	div[id*="join-list"] tr:nth-child(1) {
		display: none;
	}
}

/*-- --------- 2019.06.06 --------- --*/
#fv2 img {
	display: block;
	max-width: 1000px;
	margin: 0px auto;
}

#fv2 img.sp {
	display: none;
}

@media screen and (min-width: 602px) and (max-width: 1000px) {
	#fv2 img.pc {
		width: 100%;
	}
}

@media screen and (min-width: 320px) and (max-width: 601px) {
	#fv2 img.pc {
		display: none;
	}

	#fv2 img.sp {
		display: block;
		width: 100%;
	}
}

/* イベント概要（#summary）スマホ対応 */
#summary table {
    width: 100%;
    border-collapse: collapse;
    table-layout: fixed;
}

#summary th,
#summary td {
    word-break: break-word;
    overflow-wrap: break-word;
    white-space: normal;
    vertical-align: top;
}

#summary img {
    max-width: 100%;
    height: auto;
}



/*-- --------- --------- --------- --*/
/*-- ▼ドライバー --*/
/*-- --------- --------- --------- --*/
p.driver-caution {
	color: #ff3333;
	font-size: 14px;
	text-align: left;
	display: block;
}