body{margin:0;padding:0;line-height:2rem;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{
	margin-bottom:50px;
}
.color_t{
	color:#063;
}
.lnkbtn{
	display:table;
	background:#063;
	color:#fff;
	text-decoration:none;
	padding:10px 40px;
	font-size:18px;
	line-height:25px;
	border:none;
	appearance:none;
	-webkit-appearance:none;
}
.mark{
	display:inline-block;
	background:#063;
	color:#fff;
	padding:0 8px;
	font-size:13px;
	line-height:22px;
	margin-left:10px;
	border-radius:5px;
}
.ttl .hdr{
	font-size:30px;
	line-height:35px;
	margin-bottom:0;
}
.ttl .subhdr{
	font-size:25px;
	line-height:30px;
	margin-top:0;
	font-weight:bold;
}



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



#header_wrapper{
	color:#fff;
	width:100%;
}
#header > *{
	margin:0;
}
#header .hdr{
	font-weight:normal;
	font-size:20px;
	line-height:26px;
}
#header .hdr a{
	color:inherit;
	text-decoration:none;
}
#header .nav{
	list-style:none;
	padding:0;
}
#header .nav a{
	color:inherit;
	text-decoration:none;
}
#header .nav.contact{
	margin:0;
	color:#063;
}
#header .nav.contact a{
	background:url('../img/icn_mail.png') center left 14px no-repeat #fff;
	background-size:30px;
	display:block;
	padding:0 10px 0 60px;
	height:100%;
}



#footer .name a{
	text-decoration:none;
	color:inherit;
}
#footer .nav{
	list-style:none;
	padding:0;
	text-align:right;
	margin:0;
}
#footer .nav a{
	text-decoration:none;
	color:inherit;
	line-height:28px;
}
#footer .copy{
	font-size:14px;
	line-height:20px;
}



#tocontact{
	background:linear-gradient(to bottom,#0c8f43,#fff);
	color:#fff;
}
#tocontact .hdr{
	margin-top:0;
}
#tocontact .subhdr{
	font-weight:bold;
	margin-bottom:0;
}
#tocontact .lnkbtn{
	padding-top:50px;
	background-image:url('../img/icn_mail_w.png');
	background-repeat:no-repeat;
	background-position:center top 6px;
	background-size:36px;
}



.dl_tbl{
	display:flex;
	flex-wrap:wrap;
	max-width:700px;
	margin-left:auto;
	margin-right:auto;
}
.dl_tbl dt,
.dl_tbl dd{
	padding:20px 30px;
	margin:0;
	box-sizing:border-box;
	border-bottom:2px solid #063;
}
.dl_tbl dt{
	width:30%;
	font-weight:bold;
	white-space:nowrap;
}
.dl_tbl dd{
	width:70%;
}



#visual_wrapper{
	background:url('../img/visual.png') center no-repeat;
	background-size:cover;
}
#visual{
	height:50vw;
	color:#fff;
	position:relative;
}
#visual .abs{
	position:absolute;
	right:20px;
	margin:0;
	font-weight:bold;
}
#visual .txt{
	text-align:right;
}



#top .box:nth-last-child(n+2){
	margin-bottom:50px;
}
#top .box .hdr{
	margin-top:0;
}
#top .box .subhdr{
	font-weight:bold;
	margin-bottom:0;
}



#service .wrp:nth-last-child(n+2){
	margin-bottom:30px;
}
#service .wrp .hdr{
	font-size:20px;
	line-height:30px;
}
#service .wrp.shokai .logo img{
	width:180px;
}



#philosophy .bigtxt{
	color:#8bb19c;
	font-weight:bold;
}
#philosophy .hdrtxt{
	font-size:20px;
	line-height:30px;
}





/***** 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.3);
	border-radius:5px;
	margin:1px;
	box-sizing:border-box;
	width:calc(100% - 1px);
}
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;}
