@charset "UTF-8";

/*--------------------------------------------------------------------
common
ページ共通部分
--------------------------------------------------------------------*/
.PcNo { display: none; }

div#PageTop a {
	display: block;
	width: 40px;
	height: 40px;
	background: url(../img/pagetop.png) no-repeat left top;
	position: fixed;
	bottom: 1%;
	right: 1%;
	overflow: hidden;
	line-height: 0;
	font-size: 0;
	z-index: 200;
}


/*------------SpNav------------------------------------------------------------*/
div#SpNav { display: none; }


/*------------共通------------------------------------------------------------*/
div.MainBg {
	position: relative;
	box-sizing: border-box;
  background-attachment: fixed;
  background-repeat: no-repeat;
  background-position: center top;
  background-size: cover;
}
div.MainBg h1 {
	position: relative;
	padding-top: 15px;
	text-align: center;
	font-size: 1.78em;
	font-weight: bolder;
}
div.MainBg h1:before {
	position: absolute;
	display: block;
	content: "";
	width: 70px;
	border-bottom: 2px solid #004000;
	bottom: 0;
	left: 50%;
	-webkit-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translateX(-50%);
}
div.inBox {
	position: relative;
	width: 820px;
	margin: 50px auto 0;
}


/*------------header------------------------------------------------------------*/
div#header {
	height: 100vh;
	background-image: url(../img/head_bg.jpg);
}
div#header h1 {
	position: absolute;
	width: 340px;
	margin: 0 auto;
	top: 35%;
	left: 50%;
	-webkit-transform: translate(-50% , -50%);
	    -ms-transform: translate(-50% , -50%);
	        transform: translate(-50% , -50%);
}
div#header h1:before { display: none; }
div#header h1 a {
	display: block;
	padding-top: 88.82352941176471%;
	background: url(../img/header_logo.png) no-repeat center;
	background-size: cover;
	z-index: 1;
	overflow: hidden;
	line-height: 0;
	text-indent: -99999px;
	font-size: 0;
}
div#header p {
	position: absolute;
	width: 100%;
	margin: 0 auto;
	top: 65%;
	left: 50%;
	-webkit-transform: translate(-50% , -50%);
	    -ms-transform: translate(-50% , -50%);
	        transform: translate(-50% , -50%);
	text-align: center;
	font-size: 1.57em;
	font-weight: bolder;
	color: #fff;
	text-shadow: 
		 1px  1px 6px #5a896b,
		-1px  1px 6px #5a896b,
		 1px -1px 6px #5a896b,
		-1px -1px 6px #5a896b,
		 1px  0px 6px #5a896b,
		 0px  1px 6px #5a896b,
		-1px  0px 6px #5a896b,
		 0px -1px 6px #5a896b;
}
div#header p span {
	display: block;
	font-size: 0.78rem;
}


/*------------news------------------------------------------------------------*/
div#news {
	padding-top: 50px;
	padding-bottom: 120px;
	background: -moz-linear-gradient(top,  rgba(255,255,255,0) 0%, rgba(255,255,255,1) 25%, rgba(255,255,255,1) 37%);
	background: -webkit-linear-gradient(top,  rgba(255,255,255,0) 0%,rgba(255,255,255,1) 25%,rgba(255,255,255,1) 37%);
	background: linear-gradient(to bottom,  rgba(255,255,255,0) 0%,rgba(255,255,255,1) 25%,rgba(255,255,255,1) 37%);
	filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#00ffffff', endColorstr='#ffffff',GradientType=0 );
}
div#news:before {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	top: -60px;
	right: 0;
	border-style: solid;
	border-width: 0 0 60px 100vw;
	border-color: transparent transparent #fff transparent;
}
div#news #note {
	margin-top: 30px;
	text-align: center;
}
div#news #note h2 {
	font-size: 1.78em;
	font-weight: bolder;
	color: #c0272d;
}
div#news #note p {
	margin-top: 1em;
}


/*------------works------------------------------------------------------------*/
div#works {
	padding-bottom: 40px;
	background-color: #e6e6e6;
	overflow: hidden;
}
div#works:before {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 100px 50vw 0 50vw;
	border-color: #fff transparent transparent transparent;
	left: 0;
	top: 0;
	left: 50%;
	top: 0;
	-webkit-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translatex(-50%);
}
div#works ul {
	padding-top: 50px;
	margin-bottom: -35px;
	list-style: none;
	overflow: hidden;
}
div#works ul li {
	position: relative;
	width: 250px;
	margin-bottom: 35px;
	margin-right: 35px;
	float: left;
	overflow: hidden;
}
div#works ul li:nth-of-type(3n) { margin-right: 0; }
div#works ul li:before {
	position: absolute;
	top: 0;
	left: -100%;
	z-index: 2;
	display: block;
	content: '';
	width: 50%;
	height: 100%;
	background: -webkit-linear-gradient(left, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	background: linear-gradient(to right, rgba(255,255,255,0) 0%, rgba(255,255,255,.3) 100%);
	-webkit-transform: skewX(-25deg);
	        transform: skewX(-25deg);
}
div#works ul li:hover:before {
	-webkit-animation: shine .75s;
	        animation: shine .75s;
}
@-webkit-keyframes shine { 100% { left: 125%; } }
         @keyframes shine { 100% { left: 125%; } }
div#works ul li a {
	position: absolute;
	display: block;
	min-width: 100%;
	min-height: 100%;
	width: 100%;
	height: auto;
	top: 0;
	right: 0;
	bottom: 0;
	left: 0;
	z-index: 10;
	text-align: center;
}


/*------------profile------------------------------------------------------------*/
div#profile {
	min-height: 100vh;
	padding-top: 190px;
	padding-bottom: 80px;
	background-image: url(../img/profile_bg.jpg);
	overflow: hidden;
}
div#profile:before {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 100px 50vw 0 50vw;
	border-color: #e6e6e6 transparent transparent transparent;
	left: 50%;
	top: 0;
	-webkit-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translatex(-50%);
}
div#profile:after {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	bottom: 0;
	right: 0;
	border-style: solid;
	border-width: 60px 0 0 100vw;
	border-color: transparent transparent transparent #fff;
}
div#profile table {
	width: 100%;
	border-collapse: collapse;
}
div#profile table tr th,
div#profile table tr td {
	width: auto;
	padding: 0 0 1.5em;
	background-color: transparent;
	border: 0 none;
	text-align: left;
	vertical-align: top;
}
div#profile table tr:nth-last-of-type(1) th,
div#profile table tr:nth-last-of-type(1) td { padding-bottom: 0; }
div#profile table tr th { width: 30%; }
div#profile table dl {
	width: 100%;
	overflow: hidden;
}
div#profile table dl * { float: left; }
div#profile table dl dd { margin-right: 2em; }
div#profile table ul li {
	list-style: none;
	padding-left: 1.3em;
	text-indent: -1.3em;
}
div#profile table ul li:before {
	content: "\0030fb";
	padding-right: 0.3em;
}


/*------------btnBg------------------------------------------------------------*/
div#btnBg {
	position: relative;
	padding-bottom: 470px;
	background-image: url(../img/btm_bg.jpg);
  background-position: center bottom;
	overflow: hidden;
}


/*------------inquiry------------------------------------------------------------*/

/*------------Flow------------------------------------*/
div#inquiry div.Flow {
	width: 830px;
	margin: 30px auto;
}
div#inquiry div.Flow ol {
	width: 100%;
	list-style: none;
	overflow: hidden;
}
div#inquiry div.Flow ol li {
	position: relative;
	width: 33.33%;
	float: left;
}
div#inquiry div.Flow ol li:after {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 5px 0 5px 10px;
	border-color: transparent transparent transparent #d4d5d5;
	top: 50%;
	right: -0.25em;
	-webkit-transform: translateY(-50%);
	    -ms-transform: translateY(-50%);
	        transform: translateY(-50%);
	z-index: 1;
}
div#inquiry div.Flow ol li.this:after { border-color: transparent transparent transparent #002152; }
div#inquiry div.Flow ol.error li.this:after {
	border-width: 5px 10px 5px 0;
	border-color: transparent #002152 transparent transparent;
}
div#inquiry div.Flow ol li:nth-last-of-type(1):after { border: 0 none; }
div#inquiry div.Flow ol li p {
	width: 85%;
	margin: 0 auto;
	color: #fff;
}
div#inquiry div.Flow ol li p span {
	display: block;
	padding: 0.5em 0;
	background-color: #d4d5d5;
	text-align: center;
	font-size: 1em;
}
div#inquiry div.Flow ol.error li.this p span { background-color: #d4d5d5; }
div#inquiry div.Flow ol li.error p span,
div#inquiry div.Flow ol li.this p span {
	background-color: #002152;
	color: #fff;
}


div#inquiry {
	position: relative;
	/*min-height: 100vh;*/
	padding-top: 50px;
	padding-bottom: 40px;
	background-color: #fff;
}
div#inquiry:before {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	bottom: -60px;
	right: 0;
	border-style: solid;
	border-width: 0 100vw 60px 0;
	border-color: transparent #fff transparent transparent;
	z-index: 1;
}
div#inquiry ul#note {
	list-style: none;
	margin-top: 1em;
}
div#inquiry ul#note li {
	padding-left: 1.3em;
	text-indent: -1.3em;
}
div#inquiry ul#note li:before {
	content: "\00203b";
	padding-right: 0.3em;
}

div#inquiry table {
	width: 100%;
	margin-top: 25px;
	border-collapse: collapse;
	border-top: 1px solid #b5b5b5;
}
div#inquiry table tr th,
div#inquiry table tr td {
	width: auto;
	padding: 10px 20px;
	border-bottom: 1px solid #b5b5b5;
	text-align: left;
	vertical-align: top;
}
div#inquiry table tr th {
	width: 25%;
	padding-top: 15px;
}
div#inquiry table tr th span {
	display: inline-block;
	float: right;
	font-size: 0.81em;
}
div#inquiry table tr td ul {
	width: 100%;
	list-style: none;
	overflow: hidden;
}
div#inquiry table tr td ul li {
	margin-right: 2em;
	float: left;
}
div#inquiry table tr td span {
	margin-left: 0.8em;
	font-size: 0.86em;
	color: #ff1d25;
}
div#inquiry table.form tr td span {
	margin-left: 0;
	font-size: 1rem;
}
div#inquiry table tr td .Inp01 { width: 100%; }
div#inquiry table tr td .Inp02 { width: 44%; }
div#inquiry table tr td .Inp03 { width: 19%; }
div#inquiry table tr td input[type="text"],
div#inquiry table tr td input[type="tel"],
div#inquiry table tr td input[type="email"],
div#inquiry table tr td textarea {
	-webkit-border-radius: 4px;
	   -moz-border-radius: 4px;
	        border-radius: 4px;
	padding: 0.4em;
	transition: 0.3s;
	border: 1px solid #5d83a4;
	outline: none;
}
div#inquiry table tr td input[type="text"]:focus,
div#inquiry table tr td input[type="tel"]:focus,
div#inquiry table tr td input[type="email"]:focus,
div#inquiry table tr td textarea:focus { border-color: #ab4d00; }
div#inquiry table tr td textarea { height: 330px; }
div#inquiry div#SubmitBtn {
	margin: 20px auto 0;
	text-align: center;
}
div#inquiry div#SubmitBtn input { margin: 0 1em; }
div#inquiry div#policy {
	width: 100%;
	height: 180px;
	margin-bottom: 0.25em;
	padding-right: 1em;
	overflow: auto;
	font-size: 0.97em;
}
div#inquiry div#policy h2 {
	margin-bottom: 0.5em;
	font-size: 1.25em;
	font-weight: bold;
	color: #004000;
}
div#inquiry div#policy dl dt {
	margin-top: 1em;
	font-size: 1.05em;
	font-weight: bold;
}
div#inquiry div#home {
	margin-top: 3em;
	text-align: center;
	font-size: 1.05em;
	font-weight: bold;
}


/*------------footer------------------------------------------------------------*/
div#footer {
	padding-top: 200px;
	background-image: url(../img/btm_bg.jpg);
  background-position: center bottom;
	overflow: hidden;
}
div#footer h1 {
	width: 275px;
	margin: 0 auto;
}
div#footer h1:before { display: none; }
div#footer h1 a {
	display: block;
	padding-top: 85.09090909090909%;
	background: url(../img/footer_logo.png) no-repeat left top;
	background-size: cover;
	z-index: 1;
	overflow: hidden;
	line-height: 0;
	text-indent: -99999px;
	font-size: 0;
}
div#footer div#footAdd {
	width: 100%;
	margin: 70px auto 0;
	text-align: center;
}
div#footer div#footAdd * { display: inline-block; }
div#footer div#footAdd h2,
div#footer div#footAdd p,
div#footer div#footAdd dl dd { margin-right: 1em; }
div#footer div#footAdd dl dd:nth-last-of-type(1) { margin-right: 0; }
address {
	margin-top: 0.5em;
	text-align: center;
}