@charset "utf-8";
/* CSS Document */

/* Basic CSS elements */
.clearfix:after {
	content: ".";
	display: block;
	clear: both;
	height: 0;
	visibility: hidden;
}

.clearfix {
	min-height: 1px;
}

* html .clearfix {
	height: 1px;
	/*¥*//*/
	height: auto;
	overflow: hidden;
	/**/
}

p,
ul li,
ol li {
	line-height: 1.4;
}

sup {
	vertical-align: super;
	font-size: 80%;
}

small {
	font-size: 75%;
}

/* index.html CSS elements */
html {
	background-color: #fffcf6;
	color: #484848;
}

body {
	font-family:"ヒラギノ角ゴ Pro W3", "Hiragino Kaku Gothic Pro", "メイリオ", Meiryo, Osaka, "ＭＳ Ｐゴシック", "MS PGothic", sans-serif;
	font-size: 16px;
	-webkit-text-size-adjust: 100%;
	min-width: 1024px;
}

.wrapper {
	overflow: hidden;
}

header,
aside,
article,
footer {
	width: 900px;
	margin: 0 auto;
}

.hdw {
	background: #a2cd4a url(../images/header.jpg) center top no-repeat;
	padding-bottom: 20px;
}

@media screen and (min-width: 1281px) {
.hdw {
	background: #a2cd4a url(../images/header-2560.jpg) center 60% no-repeat;
	background-size: cover;
}
}

header {
	min-height: 900px;
}

header > div {
	height: 750px;
	position: relative;
}

header > p {
	font-size: 18px;
	font-weight: bold;
	color: #ffffff;
	text-align: center;
	letter-spacing: 2px;
}

header > p > span {
	font-size: 24px;
	color: #0033ff;
}

#header-nav {
	margin-top: 20px;
	text-align: center;
}

#header-nav ul {
	font-size: 0;
}

#header-nav ul li {
	display: inline;
	margin-left: 5px;
}

#header-nav ul li:first-child {
	margin-left: 0;
}

.asw {
	background: #89ba45;
}

aside {
	display: table;
	padding: 10px 0;
	color: #ffffff;
}

aside a {
	color: #ffffff;
}

aside section {
	display: table-cell;
	vertical-align: middle;
}

aside section h1 {
	text-shadow: 1px 1px 2px #333333;
	font-size: 20px;
	letter-spacing: 1px;
}

#news {
	vertical-align: top;
	padding: 10px 15px 10px 0;
	width: 434px;
	border-right: solid 1px #ffffff;
	min-height: 90px;
	font-size: 14px;
}

#news dl {
	margin-top: 0.8em;
	line-height: 1.6em;
}

#news dt {
	margin-top: 0.8em;
}

#news dd {
	margin: -1.6em 0 0 98px;
}

.btn {
	width: 197px;
}

.btn a img {
	vertical-align: text-top;
}

#btn-env {
	text-align: left;
	padding-left: 28px;
}

#btn-env a {
	display: block;
	width: 184px;
	margin-top: 10px;
}

#btn-env a:first-child {
	margin-top: 0;
}

#btn-dl {
	text-align: right;
	padding-right: 28px;
}

.acw {
	background: #a2cd4a;
}

article {
	padding-bottom: 100px;
}

#main-area h1 {
	margin-top: 100px;
	text-align: center;
	font-size: 48px;
	letter-spacing: 2px;
	color: #e4004f;
	text-shadow: 1px  1px 0px #ffffff,
	            -1px  1px 0px #ffffff,
	             1px -1px 0px #ffffff,
	            -1px -1px 0px #ffffff,
	             0px  2px 4px #000000;
}

#main-area h1 small {
	font-size: 32px;
}

.scene {
	height: 520px;
	position: relative;
	background: url(../images/function.jpg) left top no-repeat;
	margin-top: 100px;
	color: #754c24;
}

.scene h2 {
	position: absolute;
	top: 0px;
	left: 0px;
}

.scene p {
	position: absolute;
	top: 30px;
	left: 300px;
}

.scene img {
	position: absolute;
}

#f01-i01 { top: 140px; left: 0px; }
#f01-i02 { top: 140px; right: 0px; }
#f02-i01 { top: 140px; left: 0px; }
#f02-i02 { top: 140px; left: 300px; }
#f02-i03 { top: 140px; right: 0px; }
#f03-i01 { top: 140px; left: 0px; }
#f03-i02 { top: 140px; right: 80px; }
#f04-i01 { top: 140px; left: 0px; }
#f04-i02 { top: 140px; right: 0px; }
#f05-i01 { top: 140px; left: 0px; }
#f05-i02 { top: 140px; right: 0px; }

.ftw {
	background: #a2cd4a url(../images/footer.jpg) center bottom no-repeat;
}

@media screen and (min-width: 1281px) {
.ftw {
	background: #a2cd4a url(../images/footer-2560.jpg) center top no-repeat;
	background-size: 100% auto;
}
}

footer {
	min-height: 200px;
}

#footer-nav {
}

#footer-nav ul {
	padding: 20px 0;
	font-size: 0;
	text-align: center;
	border-top: solid 1px #ffffff;
}

#footer-nav ul li {
	display: inline-block;
	width: 220px;
	font-size: 16px;
	padding: 5px 0;
	border-left: solid 1px #ffffff;
}

#footer-nav ul li:first-child {
	border-left: 0;
}

#footer-nav ul li a {
	color: #ffffff;
	text-decoration: none;
	padding: 10px 0;
	border-bottom-left-radius: 5px;
	border-bottom-right-radius: 5px;
}

#footer-nav ul li a:hover {
	text-decoration: underline;
}

footer small {
	display: block;
	margin-top: 60px;
	text-align: center;
	font-size: 14px;
	color: #ffffff;
}

#main-nav {
	position: fixed;
	top: 50%;
	left: -200px;
	margin-top: -292px;
	z-index: 100;
	transition: all ease-in 0.5s;
}

#main-nav ul {
	font-size: 0;
	text-align: center;
}

#main-nav ul li {
	display: table;
	margin-top: 10px;
}

#main-nav ul li:first-child {
	margin-top: 0;
}

#main-nav ul li a {
	display: table-cell;
	width: 100px;
	height: 75px;
	background-color: rgba(80, 80, 80, 0.5);
	color: #ffffff;
	text-decoration: none;
	vertical-align: middle;
	border-top-right-radius: 5px;
	border-bottom-right-radius: 5px;
	transition: all ease 0.25s;
	font-size: 16px;
	line-height: 1.0;
}

#main-nav ul li a:hover {
	background-color: #ffffff;
	color: #333333;
	width: 110px;
}

#main-nav ul li a img {
	opacity: 0.5;
	transition: all ease 0.25s;
}

#main-nav ul li a:hover img {
	opacity: 1.0;
}

#main-nav ul li#mnav-dl a {
	height: 160px;
	font-weight: bold;
	background-color: #c1272d;
	color: #ffffff;
}

#main-nav ul li#mnav-dl a img {
	opacity: 1.0;
}

#main-nav ul li#mnav-dl a:hover {
	background-color: #c1272d;
	color: #ffffff;
}


#pics-wrapper {
	position: absolute;
	top: 414px;
	left: 0;
	width: 512px;
	height: 288px;
	border-radius: 10px;
}

#pics-area {
	position: absolute;
	top: 24px;
	left: 24px;
	width: 340px;
	height: 240px;
	background: rgba(255, 255, 255, 0.9);
	overflow: hidden;
}

#pics-area img {
	display: none;
	position: absolute;
	left: 340px;
	transform-origin: left bottom;
}


/* for PC/Tablets */
br.pc-only,
span.pc-only {
	display: inline;
}

br.sp-only,
span.sp-only {
	display: none;
}


/* for Smartphones */
@media screen and (max-width: 767px) {

br.pc-only,
span.pc-only {
	display: none;
}

br.sp-only,
span.sp-only {
	display: inline;
}

}
