@charset "UTF-8";

/*--------------------------------------------------------------------
common
ページ共通部分
--------------------------------------------------------------------*/
.SpNo { display: none; }

div#PageTop a {
	display: block;
	width: 20px;
	height: 20px;
	background: url(../img/pagetop.png) no-repeat left top;
	background-size: cover;
	position: fixed;
	bottom: 1%;
	right: 1%;
	overflow: hidden;
	line-height: 0;
	font-size: 0;
	z-index: 200;
}


/*------------SpNav------------------------------------------------------------*/
div#SpNav ul {
	position: fixed;
	display: block;
	background-color: #004000;
	top: 0;
	left: 0;
	width: 100%;
	list-style: none;
	overflow: hidden;
	z-index: 999999;
}
div#SpNav ul li {
	width: calc(100% / 5);
	float: left;
	padding: 0.25em 0.15em;
	text-align: center;
}
div#SpNav ul li a {
	display: block;
	font-size: 0.81em;
	color: #fff;
}


/*------------共通------------------------------------------------------------*/
div.MainBg { position: relative; }
div.MainBg:before {
	position: relative;
	display: block;
	content: "";
	width: 100%;
	height: 100%;
	box-sizing: border-box;
 /* background-attachment: fixed;*/
  background-repeat: no-repeat;
  background-position: center top;
  -webkit-background-size: cover;
     -moz-background-size: cover;
       -o-background-size: cover;
          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: 90%;
	margin: 50px auto 0;
}


/*------------header------------------------------------------------------------*/
div#header:before {
	height: 100vh;
	background-image: url(../img/head_bg.jpg);
}
div#header h1 {
	position: absolute;
	width: 90%;
	margin: 0 auto;
	top: 30%;
	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 span {
	display: block;
	width: 100%;
}
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;
	padding: 0 1em;
	top: 70%;
	left: 50%;
	-webkit-transform: translate(-50% , -50%);
	    -ms-transform: translate(-50% , -50%);
	        transform: translate(-50% , -50%);
	line-height: 1.4;
	text-align: center;
	font-size: 1.47em;
	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-color: #fff;
}
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: -4%;
	list-style: none;
	overflow: hidden;
}
div#works ul li {
	position: relative;
	width: 48%;
	margin-bottom: 4%;
	margin-right: 4%;
	float: left;
	overflow: hidden;
}
div#works ul li:nth-of-type(2n) { 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:before {
	position: absolute;
	width: 100%;
	height: 100%;
	background-image: url(../img/profile_bg.jpg);
	background-position: center center;
	z-index: 0;
}
div#profile {
	min-height: 100vh;
	padding-bottom: 40px;
	overflow: hidden;
}
div#profile h1 {
	margin-top: 190px;
}
div#profile:after {
	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%);
	z-index: 2;
}
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: 20%; }
div#profile table dl {
	width: 100%;
	overflow: hidden;
}
div#profile table dl dt { float: left; }
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;
}


/*------------inquiry------------------------------------------------------------*/

/*------------Flow------------------------------------*/
div#inquiry div.Flow {
	width: 90%;
	margin: 30px auto;
}
div#inquiry div.Flow ol {
	width: 100%;
	list-style: none;
	overflow: hidden;
}
div#inquiry div.Flow ol li {
	position: relative;
	padding-bottom: 20px;
	width: 100%;
}
div#inquiry div.Flow ol li:after {
	position: absolute;
	display: block;
	content: "";
	width: 0;
	height: 0;
	border-style: solid;
	border-width: 10px 5px 0 5px;
	border-color: #d4d5d5 transparent transparent transparent;
	bottom: 5px;
	left: 50%;
	-webkit-transform: translateX(-50%);
	    -ms-transform: translateX(-50%);
	        transform: translateX(-50%);
	z-index: 1;
}
div#inquiry div.Flow ol li.this:after { border-color: #002152 transparent transparent transparent; }
div#inquiry div.Flow ol.error li.this:after {
	border-width: 0 5px 10px 5px;
	border-color: transparent transparent #002152 transparent;
}
div#inquiry div.Flow ol li:nth-last-of-type(1):after { border: 0 none; }
div#inquiry div.Flow ol li p {
	width: 93%;
	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 {
	/*min-height: 100vh;*/
	padding-top: 50px;
	padding-bottom: 40px;
	background-color: #fff;
	overflow: hidden;
}
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 {
	display: block;
	width: auto;
	padding: 10px 20px;
	border-bottom: 1px solid #b5b5b5;
	text-align: left;
	vertical-align: top;
}
div#inquiry table tr th {
	padding: 10px;
	background-color: #f3f3f3;
}
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: 56%; }
div#inquiry table tr td .Inp03 { width: 32%; }
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:before {
	position: absolute;
	width: 100%;
	height: 100%;
	background-image: url(../img/btm_bg.jpg);
  background-position: center bottom;
	z-index: 0;
}
div#footer {
	padding-top: 0;
	padding-bottom: 180px;
	overflow: hidden;
}
div#footer h1 {
	width: 275px;
	margin: 170px auto 0;
}
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 {
	position: relative;
	width: 100%;
	margin: 70px auto 0;
	text-align: center;
}
div#footer div#footAdd dl * { display: inline-block; }
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;
}