html, body {
	height: 100%;
	width: 100%;
	background: #f5f5f5;
}

/**
 * Wrap all.
 */
#app {
	position: relative;
	height: 200%;
	width: 100%;
	background: url(../img/bg_line.png) no-repeat center 510px;
}

.contents {
	position: relative;
	margin: 0 auto;
	width: 900px;
	min-width: 900px;
	padding: 0 40px;
}

/**
 * Header.
 */
#g-header {
	padding: 30px 0 50px;
}

#g-header nav {
	width: 300px;
	margin-top: 120px;
}

#g-header nav ul li {
	width: 100px;
}

#g-header h1 {
	margin-top: 55px;
}

/**
 * Footer.
 */
#g-footer {
	width: 100%;
	padding: 185px 0 90px;
	position: relative
}

.bottom-side-bar {
	position: absolute;
	top:  2770px;
	right: -30px;
}

/**
 * Section Top.
 */
#sec-top {
	margin: 0 auto 110px;
	position: relative;
}

#main-visual {
	width: 900px;
	height: 1200px;
	text-align: left;
	overflow: hidden;
}

#main-visual img {
	top: 0;
	left: 0;
	position: absolute;
}

.side-bar {
	position: absolute;
	top: 280px;
	right: 1050px;
}

#sec-top h2 {
	position: absolute;
	top: 805px;
	right: 130px;
	z-index: 100;
}

.caption {
	margin-top: 20px;
}

/**
 * Section Main.
 */
 #sec-main .content-inner {
 	width: 100%;
 	height: 100%;
 }

#map {
	width: 300px;
	height: 640px;
	margin-top: 605px;
}

.info {
	width: 500px;
}

.info .desc {
	width: 350px;
	margin: 45px 0 135px 50px;
}

/** about table **/
.info #about table {
	width: 450px;
}

.info #about table th {
	width: 105px;
}

.info #about table td {
	width: 320px;
}

/** contact table **/
.info #contact table {
	margin-top: 25px;
}

.info #contact table th {
	width: 70px;
}