@charset "UTF-8";
/* CSS Document */
html {
	width: 100%;
	height:100%;
}
body {
	width: 100%;
	height: 100%;
	margin: 0;
	font-size: 16px;
	font-family: trajan-pro-3, "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
	font-weight: 300;
}
*, *:before, *:after {
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-o-box-sizing: border-box;
	-ms-box-sizing: border-box;
	box-sizing: border-box;
}
a { 
	text-decoration: none;
    -webkit-transition: 0.3s;
    -moz-transition: 0.3s;
    -o-transition: 0.3s;
    -ms-transition: 0.3s;
    transition: 0.3s;
	cursor: pointer;
}
a:hover {
	text-decoration: underline;
}
.relative {
	position: relative;
}
.clear {
	clear: both;
}
.center {
	text-align: center;
}
.none {
	display: none;
}
#wrapper {
	width: 100%;
	height: 100%;
}
h1,h2,h3,h4,h5 {
	line-height: 150%;
	margin: 0;
	padding: 0;
}
p,ul,figure,figcaption,dl,dt,dd {
	margin: 0;
	padding: 0;
	list-style: none;
}
img {
	margin: 0;
	padding: 0;
	vertical-align: bottom;
}
.clearfix:after {
  display: block;
  clear: both;
  content: "";
}
.red {
	color: #BF0000;
}
input[type="submit"],
input[type="button"] {
  border-radius: 0;
  -webkit-box-sizing: content-box;
  -webkit-appearance: button;
  appearance: button;
  border: none;
  box-sizing: border-box;
  cursor: pointer;
}
input[type="submit"]::-webkit-search-decoration,
input[type="button"]::-webkit-search-decoration {
  display: none;
}
input[type="submit"]::focus,
input[type="button"]::focus {
  outline-offset: -2px;
}
input,button,textarea {
	font-family: "ヒラギノ明朝 ProN W3", "HiraMinProN-W3", "HG明朝E", "ＭＳ Ｐ明朝", "MS PMincho", "MS 明朝", serif;
}
/**********************************
			top
**********************************/
#top {
	width: 100%;
	position: fixed;
	top: 0;
	z-index: 9999;
	overflow: hidden;
	transform: translate(0%,0%);
	transition: 0.5s;
	padding-top: 40px;
}
#top.scr {
	background: #FFFFFF;
	box-shadow: 0 0 20px 0 rgba(0,0,0,0.05);
	transition: 0.5s;
	padding-top: 0;
}
.top_inner {
	position: relative;
	padding: 32px 5%;
}
.top_inner .logo {
	display: none;
	position: absolute;
	top: 50%;
	left: 5%;
	transform: translate(0,-50%);
	float: left;
	width: 200px;
	height: auto;
	margin: 0;
}
.top_inner .logo img {
	width: 100%;
	height: auto;
	margin: 0;
	padding: 0;
	vertical-align: middle;
}
#top.scr .top_inner .logo {
	display: inline-block;
}
.top_inner .nav ul {
	margin: 0;
	padding: 0;
	float: right;
	font-size: 0;
}
.top_inner .nav li {
	display: inline-block;
	width: auto;
	text-align: center;
}
.top_inner .nav ul li a {
	display: inline-block;
	vertical-align: middle;
	color: #FFFFFF;
	padding: 0px;
	margin-right: 20px;
	font-weight: 300;
	font-size: 0.9rem;
	position: relative;
	text-decoration: none;
	letter-spacing: 2px;
	text-shadow: 0 0 30px rgba(0,0,0,1);
}
#top.scr .top_inner .nav ul li a {
	color: #000000;
	text-shadow: none;
}
.top_inner .nav ul li:last-child a {
	margin-right: 0;
}
.top_inner .nav ul li a::after {
	position: absolute;
	bottom: -10px;
	left: 0;
	content: '';
	width: 100%;
	height: 1px;
	background: #000000;
	transform: scale(0, 1);
	transform-origin: left top;
	transition: transform .3s;
}
.top_inner .nav ul li a:hover::after {
	transform: scale(1, 1);
}
.top_inner .nav ul li a.active:before {
	border-bottom: 1px solid #000000;
	position: absolute;
	content: "";
	width: 100%;
	height: 1px;
	background: #000000;
	left: 0;
	bottom: 0;
}
#top .top_inner .nav ul li a span {
	display: block;
	font-size: 0.6rem;
	letter-spacing: 0;
}
/**********************************
			header
**********************************/
header {
	width: 100%;
	height: 100%;
	padding: 0 15% 5% 0;
	position: relative;
	overflow: hidden;
}
header:after {
	position: absolute;
	content: "";
	bottom: 0;
	right: 0;
	width: 80%;
	height: 100%;
	background: #161719;
	z-index: 1;
}
.header_inner {
	position: relative;
	width: 100%;
	height: 100%;
	margin: 0px auto;
	background: url("kv.jpg") 50% 50% / cover;
	z-index: 2;
}
#js-particles {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	mix-blend-mode: overlay;
	z-index: 10;
}
#p2 {
	position: absolute;
	top: 0;
	left: 0;
	width: 100%;
	height: 100%;
	z-index: 10;
}
.header_abs img {
	width: 40%;
	height: auto;
	margin-bottom: 5%;
}
.header_abs {
	width: 100%;
	min-width: 300px;
	text-align: left;
	position: absolute;
	content: "";
	top: 50%;
	left: 10%;
	transform: translate(0,-50%);
	color: #FFFFFF;
	z-index: 3;
}
.header_ttl {
	font-size: 8vw;
	font-weight: 800;
	color: #FFFFFF;
}
.header_sttl {
	font-size: 2rem;
	font-weight: bold;
	color: #FFFFFF;
}
.scroll_down a {
	position: absolute;
	right: 5%;
	bottom: 0;
	text-align: center;
	letter-spacing: 2px;
	font-size: 0.9rem;
	color: #FFFFFF;
	z-index: 3;
	padding-bottom: 80px;
}
.scroll_down a:after {
	position: absolute;
	content: "";
	bottom: 0;
	left: 50%;
	width: 1px;
	height: calc(100% - 40px);
	background: #FFFFFF;
}
#about {
	margin-top: -100px;
	padding-top: 100px;
}
#service {
	margin-top: -100px;
	padding-top: 100px;
}
#company {
	margin-top: -100px;
	padding-top: 100px;	
}
#contact {
	margin-top: -100px;
	padding-top: 100px;	
}
/**********************************
				about
**********************************/
.about {
	width: 100%;
	height: auto;
	position: relative;
}
.about_inner {
	width: 100%;
	height: auto;
	margin: 0px auto;
	padding: 8% 0;
	background: url("/img/common/about_bg.png") 50% 50% / 250% auto repeat-x;
	animation: bgscroll 220s linear infinite;
}
@-webkit-keyframes bgscroll {
  0% {
	  background-position: 0% 100%;
	}
  100% {
	  background-position: 200% 100%;
	}
 }
.w100 img {
	width: 100%;
	height: auto;
}

.ttl_wrap {
	margin-bottom: 80px;
	text-align: center;
}
.main_ttl {
	display: block;
	font-size: 2.6rem;
	letter-spacing: 10px;
	margin-bottom: 10px;
}
.main_ttl span {
	font-weight: 600;
}
.sub_ttl {
	display: block;
	font-size: 1rem;
	letter-spacing: 2px;
}
.about_inner .in {
	display: table;
	width: auto;
	height: auto;
	margin: 0 auto;
}
.about_inner .in .about_ttl {
	display: table-cell;
	vertical-align: top;
	padding-right: 200px;
	font-size: 1.6rem;
}
.about_inner .in .about_ttl span {
	position: relative;
	display: block;
}
.about_inner .in .about_ttl span:after {
	position: absolute;
	content: "";
	top: 50%;
	left: 160px;
	transform: translate(0,-50%);
	width: 60px;
	height: 1px;
	background: #222222;
}
.about_inner .ttl_wrap {
	display: table-cell;
	vertical-align: top;
	margin-bottom: 0;
	text-align: left;
}
.about_inner .main_ttl {
	letter-spacing: 0;
	font-size: 3.2rem;
	margin-bottom: 30px;
}
.about_inner .sub_ttl {
	letter-spacing: 0;
	line-height: 3;
}
/**********************************
			service
**********************************/
.service {
	width: 100%;
	height: auto;
	padding: 5%;
	position: relative;
	background: #161719;
	color: #FFFFFF;
}
.service_bg {
	position: absolute;
	bottom: 0;
	left: 0;
	width: 100%;
	height: 100%;
	background: url("/img/common/service_bg.jpg") 50% 50% / cover;
	mix-blend-mode: overlay;
	z-index: 1;
}
.service_inner {
	display: table;
	width: 100%;
	max-width: 1680px;
	height: auto;
	margin: 0px auto;
	border-collapse: collapse;
}
.service_list_icon {
    display: table-cell;
    width: 50%;
    height: auto;
	background: url("/img/common/service.jpg") 50% 50% / cover;
	vertical-align: middle;
	position: relative;
	z-index: 2;
}
.service_logo img {
	width: 100%;
	max-width: 300px;
	display: block;
	margin-bottom: 60px;
}
.service_ttl {
	font-size: 1.2rem;
	margin-bottom: 30px;
}
.service_text {
	font-size: 1rem;
	line-height: 1.8;
}
.service_btn a {
	position: relative;
	display: block;
	width: 100%;
	height: auto;
	background: #222222;
	color: #FFFFFF;
	margin: 40px auto 0;
	padding: 20px 0;
	text-align: center;
	text-decoration: none;
	font-size: 1rem;
	transition: 0.3s;
	border-radius: 99rem;
	letter-spacing: 2px;
}
.service_btn a:after {
	position: absolute;
	content: "\f061";
	top: 50%;
	right: 26px;
	transform: translate(0,-50%);
	font-family: "Font Awesome 5 Free";
	font-size: 0.8rem;
	color: #FFFFFF;
	font-weight: bold;
}
.service_btn a:hover {
	background: #222222;
	background-position: 50% 50%;
	color: #FFFFFF;
	transition: 0.3s;
}
.service_list_cv {
	position: relative;
	display: table-cell;
	padding: 5% 10% 5% 5%;
	vertical-align: middle;
	line-height: 2;
	z-index: 2;
}

/**********************************
			vision
**********************************/
.vision {
	position: relative;
	width: 100%;
	height: auto;
	padding: 5% 0;
	overflow: hidden;
}
.vision_inner {
}
.vision_inner .right {
	position: relative;
}
.vision_inner .right_bg {
	position: absolute;
	content: "";
	bottom: 0;
	right: 0;
	width: 80%;
	height: 100%;
	background: url("/img/common/vision_bg.jpg") 50% 50% / cover;
	z-index: 2;
}
.vision_inner .right:after {
	position: absolute;
	content: "";
	bottom: -10%;
	left: 0;
	width: 80%;
	height: 65%;
	background: #E4E4E9;
	z-index: 1;
}
.vision_inner .right .in {
	position: relative;
	width: 100%;
	height: auto;
	padding: 0 20%;
	text-align: center;
	font-size: 0;
	z-index: 3;
}
.vision_inner .right .in .in_copy {
	display: inline-block;
	width: auto;
	margin: 0 auto;
	padding: 20% 10%;
	color: #FFFFFF;
	text-align: left;
}
.vision_inner .right .in .in_copy .sttl {
	font-size: 1.2rem;
}
.vision_inner .right .in .in_copy .ssttl {
	position: relative;
	font-size: 0.8rem;
	padding-bottom: 20px;
}
.vision_inner .right .in .in_copy .ssttl:after {
	position: absolute;
	content: "";
	bottom: 0;
	left: 0;
	width: 80px;
	height: 3px;
	background: #FFFFFF;
	z-index: 1;
}
.vision_inner .right .in .in_copy .ttl {
	font-size: 2rem;
	margin-top: 60px
}
.vision_inner .right .in .in_copy .txt {
	font-size: 1.2rem;
	margin-top: 60px;
/*	background: rgba(0,0,0,0.4);*/
	background: rgba(255,255,255,0.1);
	padding: 10%;
	border: 1px solid #FFFFFF;
}

/**********************************
			company
**********************************/
.company {
	position: relative;
	width: 100%;
	height: auto;
	padding: 10% 5%;
}
.company_inner {
	max-width: 1280px;
	height: auto;
	margin: 0px auto;
}
.company .ttl_wrap {
	text-align: left;
	max-width: 800px;
	margin: 0 auto 60px;
}
.company .main_ttl {
	font-size: 1.6rem;
	letter-spacing: 0;
}
.company .sub_ttl {
	position: relative;
	padding-bottom: 20px;
}
.company .sub_ttl:after {
	position: absolute;
	content: "";
	bottom: 0;
	left: 0;
	width: 80px;
	height: 3px;
	background: #161719;
	z-index: 1;
}
table.news {
	display: table;
	width: 100%;
	max-width: 800px;
	margin: 0px auto;
	border-collapse: collapse;
	font-size: 0.9rem;
}
table.news tr {
	width: 100%;
	border-bottom: 1px solid #DDDDDD;	
}
table.news th {
	width: 180px;
	text-align: left;
	font-weight: 300;
	padding: 30px 30px 30px 0;
	letter-spacing: 2px;
}
table.news td {
	width: auto;
	padding: 30px;
}
table.news td a {
	color: #000000;
}

/**********************************
			access
**********************************/
.access {
	width: 100%;
	height: auto;
}
.access_inner {
}
.map {
	height: 0;
	overflow: hidden;
	padding-bottom: 28.25%;
	position: relative;
}
.map iframe {
	position: absolute;
	left: 0;
	top: 0;
	height: 100%;
	width: 100%;
}
.map_caption {
	padding: 5%;
	text-align: center;
}
.map_caption .view {
	margin-top: 20px;
}
.map_caption .view a {
	position: relative;
	display: inline-block;
	font-weight: bold;
	color: #222222;
	text-decoration: underline;
}
.map_caption .view a:after {
	position: absolute;
	content: "\f3c5";
	top: 50%;
	left: -20px;
	transform: translate(0,-50%);
	font-family: "Font Awesome 5 Free";
	font-size: 0.8rem;
	color: #222222;
	font-weight: bold;
}
.map_caption .tel {
	margin-top: 20px;
}
.map_caption .tel a {
	position: relative;
	display: inline-block;
	font-weight: bold;
	color: #222222;
	text-decoration: underline;
}
.map_caption .tel a:after {
	position: absolute;
	content: "\f879";
	top: 50%;
	left: -20px;
	transform: translate(0,-50%);
	font-family: "Font Awesome 5 Free";
	font-size: 0.8rem;
	color: #222222;
	font-weight: bold;
}

/**********************************
			contact
**********************************/
.contact {
	position: relative;
	width: 100%;
	height: auto;
	padding: 5% 0 0;
	background: #E4E4E9;
}
.contact_inner {
	width: 100%;
	max-width: 1680px;
	height: auto;
	margin: 0px auto;
}
.contact_inner .caption {
	text-align: center;
	color: #333333;
}
.contact_choice {
	display: table;
	width: 100%;
	font-size: 0;
}
.contact_choice.mt {
	margin-top: 5%;
}
.contact_choice .buy {
	display: table-cell;
	vertical-align: middle;
	width: 50%;
	height: auto;
}
.contact_choice .sell {
	display: table-cell;
	vertical-align: middle;
	width: 50%;
	height: auto;
}
.contact_choice a {
	display: block;
	width: 100%;
	color: #FFFFFF;
	padding: 20% 0;
	text-align: center;
	font-size: 1rem;
	text-decoration: none;
}
.contact_choice a i {
	display: inline-block;
	vertical-align: middle;
	margin-left: 10px;
	font-size: 1rem;
	transition: 0.3s;
}
.contact_choice a:hover i {
	transform: translateX(10px);
	transition: 0.3s;
}
.contact_choice .sell a {
	background: #212526;
	background: url("/img/common/contact_sell.jpg") 50% 50% / cover;
}
.contact_choice .buy a {
	background: #18191B;
	background: url("/img/common/contact_buy.jpg") 50% 50% / cover;
}
.contact_choice.blk .sell a {
	background: #18191B!important;
}
.contact_choice.blk .buy a {
	background: #212526!important;
}

.contact_choice .ttl {
	font-size: 2.6rem;
}
.contact_choice .sttl {
	letter-spacing: 1px;
}

/**********************************
			footer
**********************************/
footer {
	width: 100%;
	height: auto;
	background: #0E0E0E;
	padding: 5%;
}
.footer_inner {
	max-width: 1280px;
	height: auto;
	margin: 0px auto;
}
.footer_inner .logo img {
	width: 100%;
	max-width: 260px;
	height: auto;
}
ul.footer_nav {
	margin-top: 40px;
	font-size: 0;
}
ul.footer_nav li {
	display: inline-block;
	vertical-align: middle;
	font-size: 0.8rem;
	margin-right: 20px;
	letter-spacing: 2px;
}
ul.footer_nav li:last-child {
	margin-right: 0;
}
ul.footer_nav li a {
	color: #888888;
}
ul.footer_nav li a span {
	display: block;
	font-size: 0.6rem;
}
.footer_inner .copyright {
	margin-top: 80px;
	font-size: 0.8rem;
	color: #444444;
}