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:#39c;
}
.lnkbtn{
	display:table;
	background:#fff;
	color:#39c;
	border:1px solid #39c;
	text-decoration:none;
	padding:0 50px;
	font-size:18px;
	line-height:50px;
	border-radius:25px;
	appearance:none;
	-webkit-appearance:none;
}
.mark{
	display:inline-block;
	background:#39c;
	color:#fff;
	padding:0 8px;
	font-size:13px;
	line-height:22px;
	border-radius:5px;
}
.ttl{
	border-bottom:1px solid #39c;
	margin:1rem auto;
}
.ttl .subhdr{
	font-size:16px;
	line-height:20px;
	margin-bottom:0;
	font-weight:normal;
}
.ttl .hdr{
	font-size:30px;
	line-height:40px;
	margin:0;
}
#tocontact .ttl{
	border-color:#000;
}



.nav{
	list-style:none;
	padding:0;
	font-size:18px;
	line-height:20px;
}
.nav span{
	display:block;
	font-size:12px;
}



.dl_tbl{
	display:flex;
	flex-wrap:wrap;
	max-width:700px;
	margin:30px auto;
}
.dl_tbl dt,
.dl_tbl dd{
	margin:0 0 10px;
	padding:10px 20px;
	box-sizing:border-box;
	border:1px solid rgba(0,0,0,0.5);
}
.dl_tbl dt{
	border-right:none;
	white-space:nowrap;
}
.dl_tbl dd{
	border-left:none;
	position:relative;
}
.dl_tbl dd::after{
	content:"";
	background:rgba(0,0,0,0.5);
	width:1px;
	height:calc(100% - 20px);
	left:0;
	top:10px;
	position:absolute;
}



.dl_tbl_form{
	
}
.dl_tbl_form label{
	display:block;
}
.dl_tbl_form label:hover{
	background:#eee;
}
.dl_tbl_form dt,
.dl_tbl_form dd{
	border:1px solid rgba(0,0,0,0.5);
	margin:0;
}
.dl_tbl_form dt{
	background:#eee;
}
.dl_tbl_form dd{
	
}



.hdr.bbl{
	font-size:27px;
	line-height:40px;
	position:relative;
}
.hdr.bbl::after{
	content:"";
	width:70px;
	height:1px;
	background:#cef;
	bottom:0;
	left:0;
	position:absolute;
}



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



#header_wrapper{
	width:100%;
}
#header .hdr a{
	text-decoration:none;
	color:inherit;
	font-weight:normal;
	font-size:28px;
}
#header .hdr img{
	width:20px;
	vertical-align:baseline;
}
#header .nav a{
	text-decoration:none;
	color:inherit;
}



#footer_wrapper{
	background:#39c;
	color:#fff;
}
#footer a{
	color:inherit;
	text-decoration:none;
}
#footer .logo img{
	vertical-align:baseline;
}
#footer .nav{
	display:flex;
	column-gap:25px;
	justify-content:center;
}
#footer .copy{
	font-size:14px;
	line-height:20px;
}



#visual_wrapper{
	background-repeat:no-repeat;
	background-position:center;
	background-size:cover;
}
#visual{
	position:relative;
}
#visual .abs{
	position:absolute;
	margin:0;
}
#visual .wrp{
	color:#fff;
}
#visual .wrp .subhdr{
	font-size:13px;
	line-height:20px;
	margin-bottom:0;
}
#visual .wrp .hdr{
	font-size:30px;
	line-height:35px;
	margin-top:0;
}
#visual .wrp .txt{
	font-size:14px;
	line-height:25px;
}
#visual_wrapper.index .txt{
	font-family:'Cabin Condensed', sans-serif;
	color:#fff;
	font-size:65px;
	line-height:70px;
	text-align:right;
	text-shadow:1px 1px 0 rgba(0,0,0,0.5);
}
#visual_wrapper.index .txt span{
	color:#027;
}
#visual_wrapper.philosophy #visual .wrp{
	color:inherit;
}



#top .wrp_txt_img{
	margin:40px -8px;
}
#top .wrp_txt_img .cell:nth-child(1){
	background:#309bcf;
	color:#fff;
}
#top .wrp_txt_img .cell:nth-last-child(2){
	background:#c1e1f6;
}
#top .wrp_txt_img .hdrtxt .subhdr{
	font-size:14px;
	line-height:18px;
	margin-bottom:0;
	font-weight:normal;
}
#top .wrp_txt_img .hdrtxt .hdr{
	font-size:27px;
	line-height:40px;
	margin:0;
	font-weight:normal;
}
#top .wrp_txt_img .cell:nth-child(1) .hdrtxt{
	border-bottom:1px solid #fff;
}
#top .wrp_txt_img .cell:nth-child(1) .lnkbtn{
	border-color:#fff;
	color:#fff;
	background:none;
}
#top .wrp_txt_img .cell:nth-last-child(2) .hdrtxt{
	border-bottom:1px solid #000;
}
#top .wrp_txt_img .cell:nth-last-child(2) .lnkbtn{
	border-color:#000;
	color:#000;
	background:none;
}
#top .wrp_txt_img .cell.txt{
	display:flex;
	align-items:center;
}



#service .wrp .num{
	color:#ddd;
	font-size:25px;
	line-height:35px;
}
#service_reason .wrp .txt .txt{
	font-size:14px;
}



#philosophy_vision .lst{
	font-weight:bold;
	display:table;
	margin:1rem auto;
}
#philosophy_vision .wrp{
	margin:30px -8px;
}
#philosophy_vision .wrp .cell{
	background-position:center;
	background-repeat:no-repeat;
	background-size:cover;
	padding:10px 20px;
}
#philosophy_vision .wrp .cell .lnkbtn{
	background:none;
}
#philosophy_vision .wrp .cell:first-child{
	background-image:url('../img/bg_phil_1.png');
	color:#fff;
}
#philosophy_vision .wrp .cell:first-child .lnkbtn{
	border-color:#fff;
	color:#fff;
}
#philosophy_vision .wrp .cell:last-child{
	background-image:url('../img/bg_phil_2.png');
}
#philosophy_vision .wrp .cell:last-child .lnkbtn{
	border-color:#000;
	color:#000;
}
#philosophy_vision .wrp .subhdr{
	font-size:14px;
	line-height:18px;
	margin-bottom:0;
	font-weight:normal;
}
#philosophy_vision .wrp .hdr{
	font-size:27px;
	line-height:40px;
	margin:0;
	font-weight:normal;
}





/***** 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;}
