@charset "utf-8";
body {
	min-width: 1240px;
	font-family: "Hiragino Kaku Gothic ProN", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	-webkit-text-size-adjust: 100%
}
#cspi2022 {
	color: #333f48;
	line-height: 2.0;
	box-sizing: border-box;
}
#cspi2022 *, #cspi2022 *::before, #cspi2022 *::after {
	box-sizing: inherit;
}
#cspi2022 img {
	max-width: 100%;
	vertical-align: middle;
}
.noto {
	font-family: 'Noto Sans Japanese', "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
}
#cspi2022 .h1Area {
	background: url(../img/main-bg.jpg) center center no-repeat;
	background-size: cover;
	text-align: center;
	margin-bottom: 40px;
}
#cspi2022 h2 {
	margin-bottom: 20px;
	padding-bottom: 5px;
	background: url(../img/bg_h2.png) left bottom no-repeat;
	font-size: 156.3%;
}
#cspi2022 h3 {
	margin-bottom: 20px;
	border-bottom: 1px solid #e6e6e6;
	font-size: 143.8%;
}
#cspi2022 h4 {
	border-left: 3px solid #80d6d7;
	padding-left: 10px;
	margin-bottom: 15px;
}
#cspi2022 #catch {
	text-align: center;
}
#cspi2022 #catch h2 {
	padding-bottom: 0;
	background-image: none;
}
#cspi2022 .contentsBlock {
	width: 1200px;
	margin: 40px auto;
}
#cspi2022 .contentsPadding {
	padding: 0 20px;
}
/*#cspi2022 > [id] {
	padding-top: 70px;
	margin-top: -70px;
}*/
.col {
	float: left;
}
.col4Block .col {
	width: 25%;
}
.col5Block .col {
	width: 20%;
}
#cspi2022 .anchorList {
	background-color: #ebebeb;
	padding: 10px 5px;
	text-align: center;
}
#cspi2022 .anchorList .col {
	padding: 0 5px;
}
#cspi2022 .normalList {
	list-style: none;
}
#cspi2022 .normalList li {
	background: url(../img/ic_lnavi_link_sub_on.png) 4px 10px no-repeat;
	padding-left: 20px;
    margin-bottom: 15px;
	line-height: 1.6;
}
#cspi2022 .normalList li:last-child{
    margin-bottom: 0;
}
#cspi2022 .anchorList + .text01 {
	margin-top: 30px;
	text-align: center;
}

#cspi2022 .bold {
	font-weight: bold;
}
#cspi2022 .anchorList a {
	background: #00adb0 url(../img/ic_anchor.png) no-repeat right 10px center;
	display: block;
	display: flex;
	justify-content: center;
	align-items: center;
	height: 52px;
	font-weight: bold;
	line-height: 1.15;
	color: #fff;
}
#cspi2022 .anchorList a:hover {
	background-color: #028484;
	background-image: url(../img/ic_anchor_on.png);
	text-decoration: none;
}
#place #placeBoxLeft {
	float: left;
	width: 560px;
}
#place #placeBoxLeft p {
	font-size: 90%;
}
#place #placeBoxLeft ul {
	font-size: 90%;
	margin-bottom: 25px;
}
#place .textBtn a {
	display: block;
	width: 300px;
	margin: 30px 0;
	border: 1px solid #00adb0;
	border-radius: 16px;
	padding: 8px 0 6px;
	background: url(../img/ic_btn_link.png) right 10px center no-repeat;
	text-align: center;
	line-height: 2.0;
}
#place .textBtn a:hover {
	background-color: #00adb0;
	background-image: url(../img/ic_lnavi_link.png);
	text-decoration: none;
	color: #fff;
}
#place #placeBoxRight {
	float: right;
	width: 560px;
}
#day .fesday {
	font-size: 137.5%;
}
#day .normalList .fesday {
	background-position: 4px 14px;
}
#day .fesday span {
	display: inline-block;
	margin-left: 1em;
}
#position .contentsPadding:after {
	content: "";
	display: block;
	clear: both;
}
#position ul {
	float: left;
	width: 50%;
}
#position img {
	float: right;
	width: 50%;
}
#position .area {
	color: #00adb0;
}
#position .boothNo {
	font-weight: bold;
	font-size: 131.3%;
}
#machine:after {
	content: "";
	display: block;
	clear: both;
}
#machine li {
	font-size: 100%;
}
#machine .machinesBox-wrap {
	display: -webkit-flex;
	display: -moz-flex;
	display: -ms-flex;
	display: -o-flex;
	display: flex;
}
#machine .machinesBox {
	/*float: left;*/
	width: 50%;
	padding: 0 20px;
}
#machine .machinesBox + .machinesBox {
	/*float: right;*/
}
#machine .machinesBox p {
	margin: 15px 0 5px;
}
#machine .caution {
	/*float: left;*/
	padding-left: 20px;
	padding-top: 60px;
	font-size: 87.5%;
}
#machine .caution li {
	text-indent: -1em;
	padding-left: 1em;
}
#machine .caution li + li {
	margin-top: 8px;
}
#machine ul + .textHeader {
	margin-top: 40px;
}
#machine .productbox {
	width: 300px;
	margin: 15px auto 30px;
	text-align: center;
	line-height: 1.4;
}
#machine .productbox .textBtn {
	margin: 20px auto 0;
}
#machine .productbox .textBtn a {
	display: block;
	border: 1px solid #00a7ac;
	border-radius: 20px;
	padding: 9px 12px;
	position: relative;
}
#machine .productbox .textBtn a::before {
	content: '';
	position: absolute;
	right: 12px;
	bottom: 50%;
	transform: translateY(50%);
	border-style: solid;
	border-color: transparent transparent transparent #00a7ac;
	border-width: 5px 0 5px 8px;
}
#machine .productbox .textBtn a:hover {
	text-decoration: none;
	background-color: #00a7ac;
	color: #fff;
}
#machine .productbox .textBtn a:hover::before {
	border-color: transparent transparent transparent #fff;
}

#sakunen h2 {
	width: 1200px;
	margin: 0 auto;
}
#sakunen #youtubeArea {
	width: 720px;
	margin: 30px auto 50px;
}
#sakunen #youtube_responsive {
	position: relative;
	width: 100%;
	height: 0;
	padding-top: 56.25%;
}
#sakunen #youtube_responsive iframe {
	position: absolute;
	left: 0;
	top: 0;
	width: 100%;
	height: 100%;
}
#sakunen .youtubeMenu {
	padding-top: 15px;
	position: relative;
}
#sakunen .youtubeMenu li {
	float: left;
	width: 238px;
	margin-right: 3px;
	position: relative;
}
#sakunen .youtubeMenu li:last-child {
	margin-right: 0;
}
#sakunen .youtubeMenu li a {
	display: block;
	background-color: #999;
	padding: 12px;
	text-align: center;
	font-family: Arial, Helvetica, sans-serif;
	transition: background-color .2s linear;
	color: #fff;
}
#sakunen .youtubeMenu li a span {
	display: inline-block;
	background: url(../img/ico_video.png) no-repeat left center;
	background-size: 20px auto;
	padding-left: 30px;
}
#sakunen .youtubeMenu li .current,
#sakunen .youtubeMenu li a:hover {
	background-color: #00a7ac;
}
#sakunen .youtubeMenu li .current:before,
#sakunen .youtubeMenu li a:hover:before {
	content: "";
	position: absolute;
	left: 111px;
	top: -10px;
	border-style: solid;
	border-width: 0 12px 10px;
	border-color: transparent transparent #00a6ac;
}
#slickSection .textHeader {
	width: 1200px;
	margin-left: auto;
	margin-right: auto;
}
#sakunen #slickArea {
	background-color: #f3f3f3;
	width: 100%;
	padding: 50px 0 60px;
	margin-bottom: 80px;
}
#sakunen #slickBox {
	width: 1200px;
	margin: 0 auto;
}
/*#sakunen #slickBox .multiple-item li {
	padding-left: 5px;
}*/
#slickBox .multiple-item li {
	padding-left: 5px;
}
.slick-dots li.slick-active button:before,
.slick-dots li button:hover:before,
.slick-dots li button:active:before,
.slick-dots li button:focus:before {
	color: #00a7ac;
}

#breadcrumbs {
	min-width: 1240px;
	background-color: #000;
	color: #fff;
}
#breadcrumbs ol {
	width: 1200px;
	margin: 0 auto;
	padding: 0;
	list-style: none;
}
#breadcrumbs li {
	float: left;
	padding: 12px 0 10px 21px;
	margin-left: 12px;
	background: url(../img/ic_bc_link.png) left center no-repeat;
	font-size: 81.3%;
}
#breadcrumbs li:first-child {
	background-image: none;
	padding-left: 0;
	margin-left: 0;
}
#breadcrumbs li a {
	color: #bec3c8;
	text-decoration: none;
}
#breadcrumbs li a:hover {
	text-decoration: underline;
}

#contents #reserve {
	margin: 0 auto 80px;
}
#contents #reserve .reserveBtn{
	padding: 40px 0;
}
#contents #reserve .reserveBtn a{
	display: block;
	width: 500px;
	max-width: 100%;
	margin: 0 auto;
	color: #fff;
	background-color: #00a7ac;
	text-align: center;
	font-size: 20px;
	padding: 15px;
	border-radius: 100px;
}
#contents #reserve .reserveBtn a:hover{
	text-decoration: none;
	opacity: 0.5;
}

#contents #reserve .reserveBtn a .icOtherW{
	background: url(/shared/images/ic_other_top.png) no-repeat right center;
}

@media screen and (max-width: 767px) {
	body {
		min-width: 100%;
	}
	#cspi2022 .contentsBlock {
		width: 100%;
		margin: 30px auto;
	}
	#cspi2022 .contentsBlock {
		width: 100%;
		padding: 0 10px;
	}
	#cspi2022 .contentsPadding {
		padding: 0 10px;
	}
	#cspi2022 h2 {
		font-size: 112.5%;
	}
	#cspi2022 h3 {
		font-size: 106.3%;
	}
	.pcBr {
		display: none;
	}
	#cspi2022 .h1Area {
		margin-bottom: 30px;
	}
	#cspi2022 #catch {
		text-align: left;
		font-size: 93.8%;
	}
	#cspi2022 .anchorList {
		padding: 30px 10px;
		margin: 0 -10px;
	}
	#cspi2022 .col5Block .col,#cspi2022 .col4Block .col {
		width: 100%;
		margin-bottom: 1px;
	}
	#cspi2022 .anchorList a {
		display: block;
		padding: 10px;
		height: auto;
		line-height: 2.0;
	}
	#cspi2022 .anchorList a br {
		display: none;
	}
	#cspi2022 .anchorList + .text01 {
		text-align: left;
	}
	#cspi2022 .anchorList + .text01 span {
		display: block;
	}
	#place #placeBoxLeft,
	#place #placeBoxRight {
		width: auto;
		float: none;
	}
	#place .textBtn a {
		width: auto;
	}
	#day .fesday {
		font-size: 100%;
	}
	#day .normalList .fesday {
		background-position: 4px 10px;
	}
	#day .fesday span {
		display: block;
		margin-left: 0;
	}
	#position ul,
	#position img {
		float: none;
		width: auto;
	}
	#position .boothNo {
		font-size: 118.8%;
	}
	#machine .machinesBox-wrap {
		display: block;
	}
	#machine .machinesBox {
		/*float: none;*/
		width: auto;
		padding: 0 10px;
	}
	#machine .machinesBox + .machinesBox {
		/*float: none;*/
		margin-top: 20px;
	}
	#machine li {
		font-size: 100%;
		font-weight: normal;
	}
    #machine ul + .textHeader {
	    margin-top: 20px;
    }
	#machine .caution {
/*		float: none;*/
		padding: 40px 10px 0;
	}

	#machine .productbox {
		max-width: 300px;
		width: auto;
	}
	#sakunen h2 {
		width: auto;
		margin: 0 10px;
	}
	#sakunen #youtubeArea {
		width: 100%;
		padding: 0 10px;
		margin-top: 20px;
	}
	#sakunen .youtubeMenu li {
		width: 100%;
		margin-bottom: 1px;
	}
	#sakunen .youtubeMenu li .current:before,
	#sakunen .youtubeMenu li a:hover:before {
		display: none;
	}
	#slickSection .textHeader {
		width: auto;
		margin-left: 10px;
		margin-right: 10px;
	}
	#sakunen #slickArea {
		background-color: transparent;
		padding: 0 10px;
	}
	#sakunen #slickBox {
		width: auto;
	}
	/*#sakunen #slickBox .multiple-item li {
		padding-left: 0;
	}*/
	#slickBox .multiple-item li {
		padding-left: 0;
	}
	.slick-arrow {
		border: 1px solid #00a7ac;
		top: auto;
		bottom: -60px;
		width: 30px;
		height: 30px;
		text-align: center;
	}
	.slick-prev {
		left: 50%;
		margin-left: -50px;
	}
	.slick-next {
		right: calc(50% - 50px);
	}
	.slick-prev:before {
		content: "<";
		font-size: 15px;
		line-height: 30px;
		color: #00a7ac;
	}
	.slick-next:before {
		content: ">";
		font-size: 15px;
		line-height: 30px;
		color: #00a7ac;
	}
	#breadcrumbs {
		display: none;
	}
	#contents #reserve .reserveBtn a{
		font-size: 18px;
	}
}
