html{font-size:20px;}
body{-webkit-text-size-adjust:100%;}

.for_pc{display:none;}
.center_sp{margin-left:auto;margin-right:auto;text-align:center;}



#header_wrapper{
	background:#3e3a39;
	position:fixed;
	top:0;
	left:0;
	height:70px;
}
body{
	margin-top:70px;
}
#header{
}
#header .nav{
	display:none;
	background:#222;
	margin:0 -8px;
	position:absolute;
	width:100%;
}
#header .nav a{
	display:block;
	padding:20px;
}



#footer{
	padding:15px 0;
	font-size:15px;
	line-height:25px;
}
#footer .nav a{
	display:block;
	padding:5px 0;
}



.drawer{
	position:absolute;
	top:5px;
	right:0;
}
.drawer_hidden {
  display: none;
}

.drawer_open {
  display: flex;
  height: 60px;
  width: 60px;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 100;
  cursor: pointer;
}
.drawer_open span,
.drawer_open span:before,
.drawer_open span:after {
  content: '';
  display: block;
  height: 2px;
  width: 30px;
  background: #fff;
  transition: 0.2s;
  position: absolute;
}

.drawer_open span:before {
  bottom: 10px;
}
.drawer_open span:after {
  top: 10px;
}

#drawer_input:checked ~ .drawer_open span {
  background: rgba(255, 255, 255, 0);
}

#drawer_input:checked ~ .drawer_open span::before {
  bottom: 0;
  transform: rotate(45deg);
}

#drawer_input:checked ~ .drawer_open span::after {
  top: 0;
  transform: rotate(-45deg);
}



#visual .wrp{
	left:10px;
	bottom:20px;
}
#visual .hdr{
	font-size:40px;
	line-height:50px;
	margin:0.5rem 0;
}
#visual .txt{
	font-size:17px;
	line-height:25px;
	margin:0.5rem 0;
}



.dl_tbl dt,
.dl_tbl dd{
	margin:0;
}
.dl_tbl dt{
	padding-top:30px;
	padding-bottom:5px;
	font-weight:bold;
}
.dl_tbl dd{
	padding-bottom:30px;
	border-bottom:1px solid #3bc;
}
.dl_tbl.noline dt,
.dl_tbl.noline dd{
	border-bottom:none;
}



.gmap iframe{
	height:50vh;
}



#nxtlnk .wrp{
	height:170px;
}
#nxtlnk a{
	width:170px;
}



#top .hdr,
#business .hdr{
	font-size:25px;
	line-height:35px;
}
#top .dscr,
#business .dscr{
	font-size:18px;
	line-height:30px;
}
#top .txt,
#business .txt{
	font-size:15px;
	line-height:25px;
}
#top .lnkbtn,
#business .lnkbtn{
	margin:auto;
}
#business .sdn .img{
	text-align:center;
}
#business .sdn .img img{
	width:240px;
}



#top .subhdr{
	margin-bottom:-20px;
}
#top .hsp{
	font-size:75px;
	line-height:75px;
}



#business .hdr{
	text-align:center;
}



#philosophy .hdr{
	font-size:22px;
	line-height:40px;
	margin:1rem auto 30px;
}
#philosophy .txt{
	font-size:16px;
	line-height:35px;
}



#contact .hdr{
	text-align:center;
	font-size:23px;
}
#contact .dscr{
	font-size:18px;
}
