@charset "utf-8";
.ff-library{
	font-family: 'ibrary3am';
}

/*------------ linkbtn01 ------------*/
.linkbtn01 {
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	font-size: 15px;
	line-height: 25px;
	height: 58px;
	padding: 0 90px 0 60px;
	border: 3px solid #000;
	text-align: center;
	position: relative;
	transition: color 0.25s ease;
	background: #fff;
	z-index: 1;
	font-weight: bold;
	width: 100%;
}
.linkbtn01::before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	background: #000;
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	transition: all 0.25s ease;
}
.linkbtn01 svg {
	fill: #000;
	width: 52px;
	height: 12px;
	position: absolute;
	right: 27px;
	top: 0;
	bottom: 0;
	margin: auto;
	transition: all 0.25s ease;
}
@media screen and (min-width: 768px) {
	.linkbtn01:hover {
		color: #fff;
	}
	.linkbtn01:hover svg{
		fill: #fff;
		right: 20px;
	}
	.linkbtn01:hover::before{
		width: 100%;
		height: 100%;
	}
}
.linkbtn01--none {
	pointer-events: none;
	border: 3px solid #ccc;
	color: #ccc;
}
.linkbtn01--none svg {
	fill: #ccc;
}

/*------------ linkbtn02 ------------*/
.linkbtn02{
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
	font-size: 15px;
	line-height: 25px;
	height: 55px;
	padding: 0 40px 0 20px;
	text-align: center;
	position: relative;
	transition: color 0.25s ease;
	background: #323232;
	z-index: 1;
	font-weight: bold;
	color: #fff;
	width: 100%;
}
.linkbtn02::before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	background: #ffe400;
	position: absolute;
	z-index: -1;
	top: 0;
	left: 0;
	right: 0;
	bottom: 0;
	margin: auto;
	transition: all 0.25s ease;
}
.linkbtn02 svg {
	fill: #ffe400;
	width: 16px;
	height: 16px;
	position: absolute;
	right: 20px;
	top: 0;
	bottom: 0;
	margin: auto;
	transition: all 0.25s ease;
}
.linkbtn02--reverse{
	padding: 0 20px 0 40px;
}
.linkbtn02--reverse svg {
	right: auto;
	left: 20px;
	transform-origin: center center;
	transform: rotate(180deg);
}
@media screen and (min-width: 768px) {
	.linkbtn02:hover {
		color: #323232;
	}
	.linkbtn02:hover svg{
		fill: #323232;
		right: 15px;
	}
	.linkbtn02:hover::before{
		width: 100%;
		height: 100%;
	}
	.linkbtn02--reverse:hover svg {
		right: auto;
		left: 15px;
	}
}

/*------------ linkbtn03 ------------*/
.linkbtn03{
	display: block;
	margin: 0 auto;
	width: 500px;
	height: 90px;
	border-radius: 45pc;
	background: linear-gradient(0deg, #ea2b25 0%, #ea2b25 50%, #f1443c 50%, #f1443c 100%);
	position: relative;
	padding: 30px 0 0 144px;
}
.linkbtn03 svg{
	width: 24px;
	height: 24px;
	fill: #ffe400;
	position: absolute;
	right: 54px;
	top:0;
	bottom: 0;
	margin: auto;
}
.linkbtn03 img{
	width: 211px;
}

/* ---------------------------------------------------------------- news-term ---- */
.news-term{
	width: 100px;
	height: 20px;
	line-height: 20px;
	background: #ccc;
	text-align: center;
	color: #fff;
	font-size: 12px;
}
.news-term--news{background-color: #22bf94;}
.news-term--exhibitor{background-color: #f4961c;}
.news-term--visitor{background-color: #f25858;}
.news-term--column{background-color: #52b9ef;}

/* ---------------------------------------------------------------- Title ---- */
.ttl-01{
	font-size: 26px;
	line-height: 30px;
	font-weight: bold;
	letter-spacing: 0.05em;
	text-align: center;
	display: flex;
	justify-content: center;
	flex-wrap: wrap;
	align-items: center;
}
.ttl-01::before,
.ttl-01::after{
	content: "";
	display: inline-block;
	width: 27px;
	height: 23px;
	vertical-align: middle;
	background: url(../img/ico_01.svg) no-repeat left top / cover;
	margin: 0 20px;
}

.ttl-02{
	font-size: 20px;
	line-height: 30px;
	font-weight: bold;
	color: #fff;
	padding: 10px 32px;
	background: #22bf94;
	border-radius: 5px;
}

/* ---------------------------------------------------------------- 2カラム ---- */
.sbs{
	width: 1000px;
	margin: 70px auto;
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	align-items: flex-start;
}
.sbs-side{
	width: 210px;
	position: relative;
}
.sbs-side__in{
	width: 210px;
}
.sbs-main{
	width: 750px;
}
.sbs__title{
	display: block;
	width: 100%;
	border-top: 2px solid #000;
	border-bottom: 2px solid #000;
	padding: 34px 0 36px 16px;
	position: relative;
	margin-bottom: 30px;
}
.sbs__title::before,
.sbs__title::after{
	content: "";
	display: block;
	width: 100%;
	height: 2px;
	background: #000;
	position: absolute;
	left: 0;
}
.sbs__title::before{
	top: 2px;
}
.sbs__title::after{
	bottom: 2px;
}
.sbs-list{
	margin-bottom: 30px;
}
.sbs-list__item{
	margin-bottom: 13px;
}
.sbs-list__item > a{
	display: block;
	position: relative;
	font-size: 15px;
	line-height: 22px;
	padding-left: 23px;
}
.sbs-list__item a.current{
	font-weight: bold;
}
@media screen and (min-width: 768px) { /* ---- PC ---- */
	.sbs-list__item a:hover{
		font-weight: bold;
	}
}
.sbs-list__item > a::before{
	content: "\f105";
	display: block;
	font-family: "FontAwesome";
	color: #fff;
	font-size: 13px;
	line-height: 15px;
	text-align: center;
	text-indent: 1px;
	width: 15px;
	height: 15px;
	border-radius: 50%;
	background: #22bf94;
	position: absolute;
	top: 3px;
	left: 0;
	margin: auto;
	font-weight: bold;
}
.sbs-list--02 .sbs-list__item > a::before{
	background: #f1443c;
}
.sbs-sublist{
	font-size: 13px;
	line-height: 22px;
}
.sbs-sublist__item{
	margin-top: 8px;
	padding-left: 22px;
}
.sbs-sublist__item > a{
	display: block;
	width: 100%;
}
.sbs-sublist__item > a::before{
	content: ">";
}
/* ---------------------------------------------------------------- SP ---- */
@media screen and (max-width: 767px) {
	/*------------ linkbtn01 ------------*/
	.linkbtn01 {
		font-size: 12px;
		line-height: 15px;
		height: 45px;
		padding: 8px 35px 8px 18px;
		border: 2px solid #000;
		text-align: left;
	}
	.linkbtn01 svg {
		width: 23px;
		height: 6px;
		right: 8.5px;
	}

	/*------------ linkbtn02 ------------*/
	.linkbtn02{
		font-size: 10px;
		line-height: 16px;
		height: 40px;
		padding: 0 35px 0 17px;
	}
	.linkbtn02 svg {
		width: 12px;
		height: 12px;
		right: 15px;
	}
	.linkbtn02--reverse{
		padding: 0 17px 0 35px;
	}
	.linkbtn02--reverse svg {
		right: auto;
		left: 15px;
	}

	/*------------ linkbtn03 ------------*/
	.linkbtn03{
		width: 265px;
		height: 50px;
		border-radius: 25pc;
		padding: 16px 0 0 62px;
	}
	.linkbtn03 svg{
		width: 12px;
		height: 12px;
		right: 15px;
	}
	.linkbtn03 img{
		width: 140px;
	}

	/* ---------------------------------------------------------------- news-termegory ---- */
	.news-term{
		min-width: 50px;
		width: auto;
		padding: 0 10px;
		height: 15px;
		line-height: 15px;
		font-size: 11px;
	}

	/* ---------------------------------------------------------------- Title ---- */
	.ttl-01{
		font-size: 18px;
		line-height: 25px;
	}
	.ttl-01::before,
	.ttl-01::after{
		width: 19px;
		height: 16px;
		margin: 0 10px;
	}
	.ttl-02{
		font-size: 18px;
		line-height: 27px;
		padding: 12px 15px;
		border-radius: 0;
	}
	/* ---------------------------------------------------------------- 2カラム ---- */
	.sbs{
		width: 100%;
		margin: 40px auto;
		display: block;
	}
	.sbs-side{
		width: calc(100% - 30px);
		margin: 0 auto;
	}
	.sbs-side__in{
		width: 100%;
	}
	.sbs-main{
		width: 100%;
	}
	.sbs__title{
		padding: 20px 0 20px 2.6vw;
		margin-bottom: 20px;
	}
	.sbs-list{
		margin-bottom: 10px;
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		align-items: flex-start;
	}
	.sbs-list__item{
		width: calc(50% - 5px);
		margin-right: 10px;
		margin-bottom: 5px;
	}
	.sbs-list__item:nth-child(2n){
		margin-right: 0;
	}
	.sbs-list__item > a{
		display: flex;
		justify-content: flex-start;
		flex-wrap: wrap;
		align-items: center;
		position: relative;
		font-size: 3.2vw;
		line-height: 15px;
		padding: 5px 10px 5px 10px;
		border: 1px solid #22bf94;
		height: 40px;
	}
	.sbs-list__item > a::before{
		content: "\f107";
		right: 10px;
		left: auto;
		bottom: 0;
		text-indent: 0px;
	}
	.sbs-list--02 .sbs-list__item{
		width: 100%;
		margin-right: 0;
	}
	.sbs-list--02 .sbs-list__item > a{
		border: 1px solid #f1443c;
	}
	.sbs-list--02 .sbs-list__item > a::before{
		background: #f1443c;
	}
	.sbs-sublist{
		display: none;
	}
}