body{margin:0;padding:0;line-height:1.5rem;font-family:sans-serif;}
p,table,dl,ul,ol,hr,
h1,h2,h3,h4,h5,h6{margin-top:1rem;margin-bottom:1rem;}
img{max-width:100%;height:auto;vertical-align:bottom;border:none;}

a img{transition:0.3s;}
a:hover img{opacity:0.8;}

.center{margin-left:auto;margin-right:auto;text-align:center;}
.ta_r{text-align:right;}
.ta_l{text-align:left;}
.ofh{overflow:hidden;}
.ofa{overflow:auto;}
.tofh{white-space:nowrap;text-overflow:ellipsis;overflow:hidden;}
.w1px{width:1px;}
.w100{width:100%;box-sizing:border-box;}
.wsnr{white-space:nowrap;}
.mincho{font-family:serif;}
.dpn{display:none;}
.hide_txt{
	text-indent:100%;
	white-space:nowrap;
	overflow:hidden;
}

.inner_w,
.inner{max-width:1024px;margin:auto;box-sizing:border-box;}
.inner{padding:0 8px;}
.inner>*{overflow:hidden;}



.content{
	padding-top:30px;
	margin-bottom:50px;
}
.clr{
	color:#3bc;
}
.lnkbtn{
	display:table;
	background:#000;
	color:#fff;
	text-decoration:none;
	padding:15px 30px;
	font-size:18px;
	line-height:25px;
	border:none;
	appearance:none;
	-webkit-appearance:none;
}
.mark{
	display:inline-block;
	background:#3bc;
	color:#fff;
	padding:0 6px;
	font-size:13px;
	line-height:20px;
	margin-left:10px;
}



#header_wrapper{
	color:#fff;
	width:100%;
	z-index:2;
}
#header .hdr{
	font-size:18px;
	margin:0;
	line-height:70px;
}
#header .hdr a{
	text-decoration:none;
	color:inherit;
}
#header .hdr img{
	width:120px;
	margin-right:10px;
	vertical-align:middle;
}
#header .nav{
	list-style:none;
	padding:0;
}
#header .nav a{
	text-decoration:none;
	color:inherit;
}



#footer_wrapper{
	background:#3e3a39;
	color:#fff;
}
#footer .wrp{
	display:flex;
	justify-content:space-between;
}
#footer .nav{
	list-style:none;
	padding:0;
}
#footer .nav a{
	text-decoration:none;
	color:inherit;
}



#visual_wrapper{
	background-repeat:no-repeat;
	background-position:center;
	background-size:cover;
	color:#fff;
}
#visual{
	height:45vw;
	position:relative;
}
#visual_wrapper.index{
	background-image:url('../img/visual_top.png');
}
#visual_wrapper.business{
	background-image:url('../img/visual_business.png');
}
#visual_wrapper.philosophy{
	background-image:url('../img/visual_philosophy.png');
}
#visual_wrapper.company{
	background-image:url('../img/visual_company.png');
}
#visual_wrapper.contact{
	background-image:url('../img/visual_contact.png');
}
#visual .wrp{
	position:absolute;
}
#visual .txt+.hdr,
#visual .hdr+.txt{
	margin-bottom:0;
}



.gmap iframe{
	width:100%;
	border:1px solid #ccc;
	box-sizing:border-box;
}



#bc{
	font-size:13px;
	line-height:25px;
}
#bc a{
	text-decoration:none;
	color:inherit;
}


#nxtlnk .wrp{
	display:table;
	width:100%;
	table-layout:fixed;
}
#nxtlnk .cell{
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
	display:table-cell;
	vertical-align:middle;
}
#nxtlnk .company{
	background-image:url('../img/visual_company.png');
}
#nxtlnk .contact{
	background-image:url('../img/visual_contact.png');
}
#nxtlnk a{
	color:#fff;
	text-decoration:none;
	display:table;
	margin:auto;
	position:relative;
}
#nxtlnk a::after{
	content:"→";
	background:#fff;
	color:#3bc;
	display:table;
	position:absolute;
	right:0;
	top:50%;
	width:40px;
	line-height:40px;
	margin-top:-20px;
	font-size:20px;
	font-weight:bold;
	border-radius:50%;
	text-align:center;
}
#nxtlnk a span{
	display:block;
}
#nxtlnk a .hdr{
	font-size:20px;
}
#nxtlnk a .txt{
	font-size:14px;
}
#nxtlnk.philosophy .company,
#nxtlnk.company .company{
	display:none;
}



#top .dscr,
#business .dscr{
	font-weight:bold;
}
#top .bns,
#top .phl,
#business .msg{
	margin-bottom:50px;
}



#top .hsp{
	color:#999;
	font-weight:bold;
}



#philosophy{
	background:url('../img/bg_philo.jpg') center no-repeat;
	background-size:cover;
	position:relative;
}
#philosophy::after{
	content:"";
	width:100%;
	height:100%;
	background:rgba(255,255,255,0.8);
	top:0;
	left:0;
	position:absolute;
}
#philosophy .inner{
	position:relative;
	z-index:1;
}
#philosophy.content{
	margin-bottom:0;
	padding-bottom:40px;
}
#philosophy .hdr{
	display:table;
}



#contact form .lnkbtn{
	padding-left:60px;
	padding-right:60px;
}





/***** form *****/
select,
textarea,
input[type=password],
input[type=tel],
input[type=url],
input[type=email],
input[type=search],
input[type=number],
input[type=reset],
input[type=text]{
	padding:10px;
	font-size:1.1rem;
	border:1px solid rgba(0,0,0,0.1);
	border-radius:5px;
	
	border:none;
	background:#eee;
	
	margin:1px;
	box-sizing:border-box;
	width:100%;
}
input[type=reset]{
	padding:5px 15px;
	font-size:1rem;
}

/***** color *****/
.red{color:#ff0000;}
.green{color:#008000;}
.blue{color:#0000ff;}
.cyan{color:#00ffff;}
.magenta{color:#ff00ff;}
.yellow{color:#ffff00;}
