@charset "UTF-8";

#pageBody > section#mainVisual {
	position : relative;
	overflow : hidden;
	height : 800px;
	margin-bottom : 0;
	background-color : #333333;
}
#mainVisual .text {
	position : absolute;
	top : 50%;
	left : calc(50% - 200px);
	font-size : 3em;
	transform : translateX(-100%) translateY(-50%);
	color : #ffffff;
	font-weight: bold;
	text-shadow: 2px 2px 3px #333333;
}
#mainVisual .text > p:not(:last-child) {
	margin-bottom : 24px;
}
#mainVisual .text .copy {
	font-size : 0.5em;
}

#mvslide {
	z-index : 0;
	position : absolute;
	top : 0;
	left : 0;
	overflow : hidden;
	width : 100%;
	height : 100%;
}
#mvslide .slide {
	display : flex;
	width : 100%;
	height : 100%;
}
#mvslide .jqSlideshow_indicator {
	display : none;
	/* display : flex; */
	z-index : 2;
	position : absolute;
	bottom : 10px;
	justify-content : center;
	width : 100%;
}
#mvslide .jqSlideshow_indicator a {
	display : block;
	overflow : hidden;
	width : 8px;
	height : 8px;
	margin : 0 5px;
	transition : 0.3s ease-out;
	text-indent : 9999px;
	border : 1px solid #000000;
	border-radius : 50%;
}
#mvslide .jqSlideshow_indicator a:hover {
	background-color : #000000;
}
#mvslide .jqSlideshow_indicator a.__select {
	background-color : #cc0000;
}

#pageBody > section#product {
	margin-bottom : 0;
	padding : 100px 0;
	text-align : left;
	color : #ffffff;
	background-color : #202020;
}
#pageBody > section#product > .inner {
	max-width : 800px;
}
#product h2 {
	margin-bottom : 32px;
	text-align : center;
}
#product h3 {
	font-size : 1.2em;
	line-height : 1.7;
	margin-bottom : 32px;
	text-align : center;
}
#product .text {
	margin-bottom : 32px;
	text-align : left;
}
#product .linkBtn {
	width : 14em;
	margin : 0 auto;
}

#company {
	position : relative;
	height : 600px;
	padding-top : 0;
	padding-bottom : 0;
}
#company .content {
	z-index : 1;
	position : absolute;
	top : 50%;
	left : 45%;
	width : 480px;
	padding : 100px 60px;
	transform : translateX(-100%) translateY(-50%);
	color : #ffffff;
	background : url(/img/bg_company.jpg) 0 0 no-repeat;
	background-color : #666666;
}
#company .hl02 {
	color : #ffffff;
}
#company .hl02::after {
	left : 0;
	transform : none;
}
#company iframe {
	z-index : 0;
	position : absolute;
	width : 100%;
	height : 100%;
}
#company .content .link {
	position : absolute;
	right : 0;
	bottom : 0;
}


#product .btn {
	width: 60%;
	margin:  0 auto;
	display : grid;
	grid-template-columns : 1fr 1fr;
	grid-gap : 20px;
}
	
#info  {
	padding-top: 90px;
}
#info .inner {
	display : grid;
	grid-template-columns : 10em 1fr;
	grid-gap : 60px;
}
#info .inner h2 {
	font-size : 1.8em;
}
#info .inner h2 span {
	display : block;
	position : relative;
	padding-bottom : 1em;
}
#info .inner h2 span::after {
	display : block;
	position : absolute;
	bottom : 0;
	left : 0;
	width : 40px;
	height : 2px;
	content : "";
	background-color : #111329;
}
#info .inner ul li > :first-child {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif, "Century Gothic";
	margin-bottom : 32px;
}
#info .inner ul li .category {
	margin-left : 32px;
	padding : 0.5em 1em;
	color : #ffffff;
	background-color : #111329;
}
#info .inner ul li .title {
	font-family: "ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif, "Century Gothic";
	font-size : 1.2em;
	margin-bottom : 1em;
}

/* --- for 2K or more pc --- */
@media screen and (min-width: 1980px) {
}

/* --- for HD pc --- */
@media screen and (min-width: 1440px) and (max-width: 1979px) {
}

/* --- for normal pc --- */
@media screen and (min-width: 1024px) and (max-width: 1439px) {
	#mainVisual .text {
		left : calc(50% - 40px);
	}
	#company .content {
		left : 50%;
	}
}

/* --- for tablet --- */
@media screen and (min-width: 768px) and (max-width: 1023px) {
	#mainVisual .text {
		left : calc(55%);
	}
}

/* --- for mobile --- */
@media screen and (max-width: 767px) {
	#mainVisual img {
		transform : translateX(-60%)!important;
	}
	#mainVisual .text {
		top : 40%;
		left : calc(20%);
		transform : translateX(-10%);
		font-size : 2.5em;
	}
	#business .inner {
		grid-template-columns : 1fr;
	}
	#business .img img {
		width : 100%;
	}
	#product .btn {
		width: 100%;
		grid-template-columns : 1fr;
	}
	#info .inner {
		grid-template-columns : 1fr;
		grid-gap : 32px;
	}
	#company {
		height : auto;
	}
	#company .content {
		position : relative;
		top : unset;
		left : unset;
		padding : 32px;
		transform : unset;
		width : 100%;
	}
	#company iframe {
		position : static;
		width : 100%;
		height : 400px;
	}
}
