@charset "Shift_JIS";

/*--------------------------------------------------------------------------------
	.container
--------------------------------------------------------------------------------*/
.container {
	margin: 0 auto;
	width: 930px;
	background: #030001;
	font-size: 115%;
	font-family: "ヒラギノ明朝 Pro W3","Hiragino Mincho Pro","ヒラギノ角ゴ Pro W3","Hiragino Kaku Gothic Pro",Meiryo,"メイリオ","ＭＳ Ｐゴシック";
	color: #fff;
	line-height: 1.6;
	-webkit-text-size-adjust: none;
	overflow: hidden;
}

.container img {
	vertical-align: top;
}

.container .clearfix {
	*zoom: 1;
}

.container .clearfix:after {
	display: block;
	clear: both;
	content: "";
}

@media (max-width:640px) {
	.container {
		padding: 0 0 50px;
		width: auto;
		background: #202020;
	}
}

/*--------------------------------------------------------------------------------
	.main
--------------------------------------------------------------------------------*/
.container .main {
	height: 433px;
	overflow: hidden;
	background: url("../images/hx300_main_bg.jpg") no-repeat;
	border-bottom: 6px solid #060606;
}

.container .main h2 {
	margin: 34px 0 0 320px;
}

.container .main img.txt {
	display: block;
	margin: 10px 0 0 339px;
}

.container .main .banner {
	margin: 20px 0 0 340px;
}

.container .main .banner a {
	color: #fff;
	transition: opacity 0.3s ease-out;
	-moz-transition: opacity 0.3s ease-out;
	-webkit-transition: opacity 0.3s ease-out;
	-ms-transition: opacity 0.3s ease-out;
	-o-transition: opacity 0.3s ease-out;
}

.container .main .banner a:hover {
	color: #fff;
	text-decoration: none;
	opacity: 0.8;
}

.container .main em,
.container .main p {
	display: none;
}

@media (max-width:640px) {
	.container .main {
		padding: 30px 10px 30px;
		height: auto;
		background: linear-gradient(top, #050306, #202020);
		background: -moz-linear-gradient(top, #050306, #202020);
		background: -webkit-linear-gradient(top, #050306, #202020);
		background: -webkit-gradient(linear,left top, left bottom, from(#050306), to(#202020));
		background: -o-linear-gradient(top, #050306, #202020);
		background: -ms-linear-gradient(top, #050306, #202020);
		filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#050306", endColorstr="#202020", GradientType=0);
	}
	.container .main h2 {
		margin: 0;
		text-align: center;
	}
	.container .main h2 img {
		width: 95%;
		max-width: 576px;
	}
	.container .main img.txt {
		display: none;
	}
	.container .main p {
		display: block;
		margin: 20px auto 0;
		width: 90%;
		font-size: 80%;
	}
	.container .main .banner {
		margin: 20px 10px 0;
		text-align: center;
	}
	.container .main .banner img {
		width: 100%;
		max-width: 547px;
	}
}

/*--------------------------------------------------------------------------------
	.section
--------------------------------------------------------------------------------*/
.section {
	position: relative;
	overflow: hidden;
	*zoom: 1;
}

.section:after {
	clear: both;
	display: block;
	content: "";
}

.section .txt-box h3 {
	position: relative;
	z-index: 1;
	margin: 0;
}

.section .txt-box p {
	position: relative;
	z-index: 1;
	margin: 20px 0 0;
}

.section .txt-box p.note {
	margin: 5px 0 0;
	font-size: 75%;
}

.section .txt-img {
	position: relative;
	z-index: 1;
	margin-top: 15px;
}

.section .sec-img {
	z-index: 0;
}


@media (max-width:640px) {
	.section {
		padding-left: 18px;
		padding-right: 18px;
	}
	.section .txt-box h3 img {
		width: 100%;
	}
	.section .txt-box p {
		margin: 15px auto 0;
		line-height: 1.6;
	}
	.section .txt-box p.note {
		margin: 10px auto 0;
		font-size: 70%;
	}
	.section .txt-img {
		margin: 15px auto 0;
	}
	.section .txt-img img {
		width: 100%;
	}
}

/* .line-01
--------------------------------------------------------------------------------*/
.section.line-01 {
	padding-top: 40px;
	padding-bottom: 40px;
	background: url("../images/hx300_01_bg.jpg") no-repeat 0 0 #000;
	border-bottom: 7px solid #000;
}

.section.line-01 .txt-box {
	margin-left: 73px;
	width: 410px;
}

.section.line-01 .sec-img {
	position: absolute;
	left: 385px;
	top: 30px;
}

@media (max-width:640px) {
	.section.line-01 {
		background: #000;
	}
	.section.line-01 .txt-box {
		margin: 0 auto;
		width: 100%;
	}
	.section.line-01 .txt-box p:not(.note) {
		margin-top: -15px;
	}
	.section.line-01 .sec-img {
		position: static;
		margin-top: -50px;
		width: 100%;
		text-align: center;
	}
	.section.line-01 .sec-img img {
		margin-left: -20px;
		width: 120%;
		max-width: 636px;
	}
}

/* .line-02
--------------------------------------------------------------------------------*/
.section.line-02 {
	padding-top: 64px;
	padding-bottom: 64px;
	background: url("../images/hx300_02_bg.gif") repeat-x 0 0 #161616;
	border-bottom: 7px solid #000;
}

.section.line-02 .txt-box {
	margin: 0 0 0 572px;
	width: 312px;
	min-height: 360px;
	_height: 360px;
}

.section.line-02 .sec-img {
	position: absolute;
	left: 73px;
	top: 20px;
	width: 446px;
	height: 385px;
	overflow: hidden;
}

.section.line-02 .sec-img img {
	width: 100%;
	height: auto;
}

.section.line-02 .txt-img {
	margin-left: 68px;
}

.section.line-02 .txt-img .img-02 {
	margin-left: 40px;
}

.section.line-02 .btn {
	margin: 23px 0 0 72px;
}

.section.line-02 .btn a {
	transition: opacity 0.3s ease-out;
	-moz-transition: opacity 0.3s ease-out;
	-webkit-transition: opacity 0.3s ease-out;
	-ms-transition: opacity 0.3s ease-out;
	-o-transition: opacity 0.3s ease-out;
}

.section.line-02 .btn a:hover {
	opacity: 0.7;
}

.section.line-02 .btn span {
	display: none;
}

@media (max-width:640px) {
	.section.line-02 {
		padding-top: 40px;
		padding-bottom: 40px;
	}
	.section.line-02 .txt-box {
		margin: 0 auto;
		width: 100%;
	}
	.section.line-02 .sec-img {
		position: static;
		margin: 10px 0 0;
		width: 100%;
		height: auto;
		text-align: center;
	}
	.section.line-02 .sec-img img {
		width: 100%;
		height: auto;
		max-width: 462px;
	}
	.section.line-02 .txt-img {
		margin-left: 0;
	}
	.section.line-02 .txt-img .img-01 {
		display: block;
		margin: 30px 0 0 0;
		max-width: 443px;
	}
	.section.line-02 .txt-img .img-02 {
		display: block;
		margin: 30px 0 0 0;
		padding: 0;
		max-width: 307px;
	}
	.section.line-02 .btn {
		display: none;
	}
}

/* .line-03
--------------------------------------------------------------------------------*/
.section.line-03 {
	padding-top: 47px;
	padding-bottom: 40px;
	background: url("../images/hx300_03_bg.gif") repeat-x 0 0;
}

.section.line-03 .txt-box {
	margin: 0 0 0 70px;
	width: 340px;
	min-height: 350px;
	_height: 350px;
}

.section.line-03 .sec-img {
	position: absolute;
	left: 179px;
	top: -61px;
}

.section.line-03 .txt-img {
	margin: 0 0 0 -15px;
}

@media (max-width:640px) {
	.section.line-03 {
		padding-top: 40px;
		padding-bottom: 40px;
		background: none;
		background: linear-gradient(top, #050306, #0c0c0c);
		background: -moz-linear-gradient(top, #050306, #0c0c0c);
		background: -webkit-linear-gradient(top, #050306, #0c0c0c);
		background: -webkit-gradient(linear,left top, left bottom, from(#050306), to(#0c0c0c));
		background: -o-linear-gradient(top, #050306, #0c0c0c);
		background: -ms-linear-gradient(top, #050306, #0c0c0c);
		filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#050306", endColorstr="#0c0c0c", GradientType=0);
	}
	.section.line-03 .txt-box {
		margin: 0 auto;
		width: 100%;
	}
	.section.line-03 .sec-img {
		position: relative;
		left: 0;
		top: 0;
		margin: -40px 0 0 -70px;
		width: 120%;
		text-align: center;
	}
	.section.line-03 .txt-box p:not(.note) {
		margin-top: -15px;
	}
	.section.line-03 .sec-img img {
		width: 100%;
		max-width: 807px;
	}
}

/* .gallery
--------------------------------------------------------------------------------*/
.gallery {
	margin: 45px auto 0;
	width: 844px;
	background: url("../images/hx300_gallery_bg.jpg") repeat-y 0 400px #fff;
}

.gallery .inner {
	padding-top: 90px;
	background: url("../images/hx300_gallery_head.jpg") no-repeat;
}

.gallery h3 {
	margin: 0 0 38px;
	text-align: center;
}

.gallery .photo {
	margin: 39px auto 0;
	width: 677px;
}

.gallery .photo.dotline {
	padding-bottom: 24px;
	border-bottom: 1px dotted #231815;
}

.gallery .photo img {
	margin-left: 15px;
}

@media (max-width:640px) {
	.gallery {
		margin: 30px 10px 0;
		width: auto;
		background: #fff;
		box-shadow: 0px 0px 5px #000;
		-moz-box-shadow: 0px 0px 5px #000;
		-webkit-box-shadow: 0px 0px 5px #000;
		-o-box-shadow: 0px 0px 5px #000;
		-ms-box-shadow: 0px 0px 5px #000;
	}
	.gallery .inner {
		padding: 30px 15px;
		background: none;
	}
	.gallery h3 img {
		width: 100%;
	}
	.gallery .photo {
		margin: 25px auto 0;
		width: auto;
	}
	.gallery .photo.dotline {
		padding-bottom: 25px;
		border-bottom: 1px dotted #888;
	}
	.gallery .photo img {
		margin: 0;
		width: 100%;
	}
	.gallery img.bottom {
		display: none;
	}
}

/*--------------------------------------------------------------------------------
	.footer
--------------------------------------------------------------------------------*/
.container .footer {
	margin-top: 34px;
	padding: 0 10px 42px;
}

.container .footer a {
	color: #fff;
	transition: opacity 0.3s ease-out;
	-moz-transition: opacity 0.3s ease-out;
	-webkit-transition: opacity 0.3s ease-out;
	-ms-transition: opacity 0.3s ease-out;
	-o-transition: opacity 0.3s ease-out;
}

.container .footer a:hover {
	color: #fff;
	text-decoration: none;
	opacity: 0.8;
}

.container .footer .inner {
	margin: 0 auto;
	width: 844px;
}

.container .footer h3 {
	display: none;
	margin: 0 0 10px 0;
	padding: 12px 10px 10px;
	font-size: 90%;
	font-style: normal;
	color: #fff;
	box-shadow: 0px 1px 3px #111;
	-moz-box-shadow: 0px 1px 3px #111;
	-webkit-box-shadow: 0px 1px 3px #111;
	-o-box-shadow: 0px 1px 3px #111;
	-ms-box-shadow: 0px 1px 3px #111;
	background: linear-gradient(top, #5b6063, #3d4042);
	background: -moz-linear-gradient(top, #5b6063, #3d4042);
	background: -webkit-linear-gradient(top, #5b6063, #3d4042);
	background: -webkit-gradient(linear,left top, left bottom, from(#5b6063), to(#3d4042));
	background: -o-linear-gradient(top, #5b6063, #3d4042);
	background: -ms-linear-gradient(top, #5b6063, #3d4042);
	filter: progid:DXImageTransform.Microsoft.gradient(startColorstr="#5b6063", endColorstr="#3d4042", GradientType=0);
}

.container .footer .inner div {
	margin: 0 0 10px 0;
}

.container .footer ul {
	margin: 0;
	padding: 0;
	list-style: none;
	*zoom: 1;
}

.container .footer ul:after {
	clear: both;
	display: block;
	content: "";
}

.container .footer li {
	float: left;
	margin: 0;
}

.container .footer li span {
	display: none;
	margin-right: 10px;
	font-size: 105%;
	line-height: 1.2;
}

@media (max-width:640px) {
	.container .footer {
		padding-bottom: 0;
		background: none;
	}
	.container .footer h3 {
		display: block;
		margin: 0 0 5px 0;
	}
	.container .footer .inner {
		width: 100%;
	}
	.container .footer .inner div {
		display: none;
	}
	.container .footer ul {
		margin: 0 auto;
		width: 97%;
		border-bottom: 1px solid #333;
	}
	.container .footer li {
		float: none;
		border-top: 1px solid #333;
		border-bottom: 1px solid #111;
	}
	.container .footer li:first-child {
		border-top: none;
	}
	.container .footer li a {
		display: block;
		margin-right: 5px;
		padding: 16px 15px 16px 5px;
		background: url("../images/icn_arrow.png") no-repeat right center;
	}
	.container .footer li img {
		display: none;
	}
	.container .footer li span {
		display: block;
	}
}