/*--------------------------
ヘッダー
--------------------------*/
header {
	position: fixed;
	top: 0;
	z-index: 999;
	width: 100%;
	-webkit-box-shadow: 0px -7px 25px rgb(51, 51, 51);
	-moz-box-shadow: 0px -7px 25px rgb(51, 51, 51);
	-ms-box-shadow: 0px -7px 25px rgb(51, 51, 51);
	box-shadow: 0px -7px 25px rgb(51, 51, 51);
}
.header_contents {
	padding: 10px 0;
	background: #fff;
}
.logo {
	position: relative;
	z-index: 2;
	text-align: center;
}
.logo img {
	width: 200px;
	height: 34px;
}
.header_right_col {
	position: relative;
	z-index: 2;
	margin: 20px 0 0;
}
.header_right_col > div {
	margin: 0 0 15px;
	text-align: center;
}
.header_right_col > div > svg {
	margin: 0 5px 0 0;
	text-align: center;
}
.header_right_col > div > a {
}
.header_right_col > div > span {
}
.header_tel img {
	width: 184px;
	height: 31px;
}
.header_bnr_wrap {
	display: flex;
	flex-flow: column;
	align-items: center;
	gap: 10px 0;
}
@media only screen and (min-width: 641px) {
	.logo img {
		width: 97px;
		height: 32px;
	}
	.header_contents {
		padding: 22px 0;
	}
}
@media only screen and (min-width: 1025px) {
	header {
		position: fixed;
		box-shadow: none;
	}
	.header_right_col {
		display: flex;
		float: right;
		margin: 5px 20px;
	}
	.header_right_col > div {
		display: flex;
		align-items: center;
		margin: 0;
		padding: 0 0 0 20px;
	}
	.logo {
		float: left;
		text-align: left;
		margin: 0 0 0 20px;
	}
	.logo img {
		width: 158px;
		height: 52px;
	}
}
/*ナビ*/
.nav_col {
	position: relative;
	z-index: 1;
	width: 100%;
	clear: both;
}
.nav_btn_wrap {
	position: fixed;
	right: 20px;
	top: 19px;
	z-index: 1000;
	width: 20px;
	height: 15px;
}
.drawer-hamburger {
	position: relative;
	display: block;
	z-index: 12;
	width: 20px;
	height: 15px;
	padding: 0;
	-webkit-transition: all .5s cubic-bezier(0.39, 0.575, 0.565, 1);
	transition: all .5s cubic-bezier(0.39, 0.575, 0.565, 1);
	box-sizing: border-box;
}
.drawer-hamburger-icon, .drawer-hamburger-icon:after, .drawer-hamburger-icon:before {
	margin: 0;
	height: 2px;
	background: #000;
}
.drawer--right.drawer-open .drawer-hamburger {
	right: 0;
}
.drawer-hamburger-icon:after {
	top: 8px;
}
.drawer-hamburger-icon:before {
	top: -8px;
}
.drawer--right .drawer-nav {
	-webkit-transition: right .5s cubic-bezier(0.39, 0.575, 0.565, 1);
	transition: right .5s cubic-bezier(0.39, 0.575, 0.565, 1);
}
.drawer--right.drawer-open .drawer-hamburger.drawer-main_btn {
	left: 0;
}
.drawer--right.drawer-open .drawer-hamburger.drawer-sub_btn {
	top: 5px;
	right: 13.25rem;
}
.drawer--right .drawer-hamburger.drawer-sub_btn {
	right: 13.25rem;
	letter-spacing: 2px;
}
.drawer--right .drawer-nav {
	right: -100%;
}
.drawer-nav {
	width: 100%;
	overflow-y: scroll;
	z-index: 13;
}
.drawer-menu > ul > li {
	border-bottom: solid #707070 1px;
}
.drawer-overlay {
	z-index: 11;
	background-color: rgba(0,0,0,.8);
}
.gnav {
	text-align: center;
}
.gnav > ul > li {
	font-size: 16px;
	font-weight: bold;
	border-bottom: solid #000 1px;
	transition: all 0.5s ease-out;
}
.gnav > ul > li:hover {
	transition: all 1s ease-out;
}
.gnav > ul > li > a {
	position: relative;
	display: block;
	padding: 10px 20px;
	font-size: 18px;
	color: #000;
}
.gnav > ul > li > span {
	position: relative;
	display: block;
	padding: 10px 20px;
	font-size: 18px;
	color: #000;
	cursor: pointer;
}
.gnav > ul > li:last-child svg {
	margin: 0 0 0 10px;
}
.inner_nav_wrap {
	display: none;
	background: rgba(0,0,0,0.9);
}
.inner_nav li {
	border-bottom: solid #707070 1px;
}
.inner_nav li a {
	display: block;
	padding: 10px 0 10px 30px;
	color: #fff;
	font-size: 16px;
	transition: .3s;
}
.inner_nav li a svg {
	margin: 0 0 0 15px;
}
.nav_btn span {
	display: inline-block;
	padding: 0 0 0 15px;
	background: url(../images/common/nav_off.svg) no-repeat 97% center;
	background-size: 20px 20px;
	color: #ccc;
	font-size: 13px;
}
.nav_btn.nav_on span {
	background: url(../images/common/nav_on.svg) no-repeat 97% center;
	background-size: 20px 20px;
}
.drawer-menu {
	margin: 120px 0 0;
	border-top: solid #000 1px;
}
.drawer-menu > li:nth-child(1) > a:after {
	content: 'HOME';
	padding: 0 0 0 15px;
	display: inline-block;
	font-size: 15px;
	color: #ccc;
	vertical-align: middle;
	font-family: 'brandon_bld_it_0';
}
.drawer-menu > li:nth-child(2) > a:after {
	content: 'CORPORATION';
	padding: 0 0 0 15px;
	display: inline-block;
	font-size: 15px;
	color: #ccc;
	vertical-align: middle;
	font-family: 'brandon_bld_it_0';
}
.drawer-menu > li:nth-child(4) > a:after {
	content: 'RECRUIT';
	padding: 0 0 0 15px;
	display: inline-block;
	font-size: 15px;
	color: #ccc;
	vertical-align: middle;
	font-family: 'brandon_bld_it_0';
}
.drawer-menu > li:nth-child(3) > span:after {
	content: 'BUSINESS';
	padding: 0 0 0 15px;
	display: inline-block;
	font-size: 15px;
	color: #ccc;
	vertical-align: middle;
	font-family: 'brandon_bld_it_0';
}
/* .drawer-menu > li:nth-child(4) > span:after {
	content: 'ITEMS';
	padding: 0 0 0 15px;
	display: inline-block;
	font-size: 15px;
	color: #ccc;
	vertical-align: middle;
	font-family: 'brandon_bld_it_0';
} */
.header_sns {
	text-align: center;
}
.header_sns li {
	display: inline-block;
	padding: 0 10px;
}
.header_sns li a {
	font-size: 20px;
	transition: all 1s ease-out;
}
.header_sns li a:hover {
	color: #777;
}
.inner_nav_br_01 {
	display: block;
}
@media only screen and (min-width: 641px) {
	.drawer--right .drawer-nav {
		right: -30rem;
	}
	.drawer-nav {
		width: 30rem;
	}
	.nav_btn_wrap {
		top: 30px;
	}
}
@media only screen and (min-width: 1025px) {
	.gnav {
		position: relative;
		padding: 0;
	}
	.gnav > ul {
		display: inline-block;
		text-align: center;
		border-top: none;
	}
	.gnav > ul > li {
		margin: 0 30px;
		display: inline-block;
		border-bottom: none;
	}
	.gnav > ul > li:last-child {
		margin: 0;
		padding: 0 0 0 40px;
		border-left: solid #000 1px;
	}
	.gnav > ul > li > a {
		padding: 0;
		font-size: 20px;
		transition: all 0.5s ease-out;
	}
	.gnav > ul > li > span {
		padding: 0 0 30px;
		font-size: 20px;
		transition: all 0.5s ease-out;
	}
	.nav_btn {
		cursor: pointer;
	}
	.drawer-menu {
		margin: 0;
		border-top: none;
	}
	.drawer-menu > li > a:after {
		display: none;
	}
	.gnav > ul > li > a:hover {
		color: #777;
	}
	.gnav > ul > li > span:hover {
		color: #777;
	}
	.inner_nav_wrap {
		position: absolute;
		top: 100%;
		left: 0;
		z-index: 100;
		width: 100%;
	}
	.inner_nav {
		padding: 30px 0;
	}
	.inner_nav li a {
		padding: 10px 15px;
		font-size: 20px;
		color: #fff;
	}
	.nav_btn span {
		background: none;
	}
	.nav_top {
		font-size: 15px;
	}
	.drawer-hamburger {
		display: none;
	}
	.drawer-nav {
		display: none;
		padding: 0;
	}
	.nav_btn.nav_on span {
		background: none;
		background-size: auto;
	}
	.header_sns {
		display: flex;
		align-items: center;
		margin: 0 0 0 20px;
	}
	.inner_nav li {
		border-bottom: none;
	}
	.inner_nav_br_01 {
		display: none;
	}
}
@media only screen and (min-width: 1101px) {
	.gnav > ul > li {
		margin: 0 40px;
	}
}
@media only screen and (min-width: 1681px) {
	.nav_col {
		margin: 7px 0 0;
		clear: inherit;
	}
}
/*--------------------------
hero_ttl
--------------------------*/
.hero_ttl_wrap {
	position: relative;
	text-align: right;
}
.hero_ttl_wrap img {
	width: 100%;
}
.hero_ttl {
	margin: 30px 0;
  color: #000;
}
.hero_ttl h1 {
	font-size: 27px;
	text-align: center;
}
.hero_ttl h2 {
	font-size: 14px;
	text-align: center;
  font-weight: bold;
}
@media only screen and (min-width: 641px) {
	.hero_ttl_wrap img {
		width: 84%;
	}
	.hero_ttl {
		position: absolute;
		width: 100%;
		top: 50%;
		margin: -65px 0 0;
		padding: 0 0 0 40px;
	}
	.hero_ttl h1 {
		font-size: 60px;
		line-height: 1.2;
		text-align: left;
	}
	.hero_ttl h2 {
		font-size: 28px;
		text-align: left;
	}
}
@media only screen and (min-width: 1025px) {
	.hero_ttl {
		margin: -113.5px 0 0;
	}
	.hero_ttl h1 {
		font-size: 100px;
	}
	.hero_ttl h2 {
		font-size: 36px;
	}
}
/*--------------------------
BUSINESS 事業内容
--------------------------*/
.business_area {
	margin: 30px auto 0;
	padding: 0 6%;
	max-width: 1480px;
}
.business_area > ul > li {
	position: relative;
	float: left;
	width: 49%;
	margin: 0 0 20px 2%;
}
.business_area > ul > li:nth-child(2n+1) {
	margin: 0 0 20px;
}
.business_area > ul > li a {
	position: absolute;
	top: 0;
	left: 0;
	display: block;
	width: 100%;
	height: 100%;
}
.business_area > ul > li > a:before {
	content: '';
	position: absolute;
	top: 0;
	left: 0;
	z-index: 2;
	display: block;
	width: 100%;
	height: 100%;
	border-radius: 10px;
	background: url(../images/common/img_off.png);
	transition: all .5s ease-out;
}
.business_area > ul > li > a:hover:before {
	background: url(../images/common/img_on.png);
	transition: all .3s ease-out;
}
.business_area > ul > li > a > img {
	position: absolute;
	top: 0;
	left: 0;
	z-index: 1;
	width: 100%;
	height: 100%;
}
.business_area > ul > li:before {
	content: "";
	display: block;
	padding-top: 70%;
}
.business_ttl {
	position: absolute;
	top: 0;
	left: 0;
	display: flex;
	align-items: center;
	justify-content: center;
	width: 100%;
	height: 100%;
	z-index: 3;
}
.business_ttl h4 {
	text-align: center;
	font-size: 16px;
	color: #fff;
	text-shadow: 0px 3px 6px rgb(150, 150, 150);
	line-height: 1;
}
.business_ttl h4 img {
	width: 80%;
}
.business_ttl h5 {
	text-align: center;
	font-size: 12px;
	font-weight: bold;
	color: #fff;
	text-shadow: 0px 3px 6px rgb(150, 150, 150);
}
.contact_bnr li {
	float: left;
	width: 49%;
	margin: 0 0 0 2%;
}
.contact_bnr li:nth-child(1) {
	margin: 0;
}
.contact_bnr li a {
	display: block;
	padding: 30px 0;
	border-radius: 10px;
	background: #000;
}
.contact_bnr li a:hover {
}
.contact_bnr li a span {
	display: block;
	text-align: center;
	color: #fff;
	transition: all .5s ease-out;
}
.contact_bnr li a:hover span {
	color: #ccc;
	transition: all .3s ease-out;
}
.contact_bnr li a span:nth-child(1) {
	font-size: 16px;
}
.contact_bnr li a span:nth-child(2) {
	font-size: 12px;
}
@media only screen and (min-width: 641px) {
	.business_area > ul > li {
		width: 31%;
		margin: 0 0 40px 2.666%;
	}
	.business_area > ul > li:nth-child(2n+1) {
		margin: 0 0 40px 2.666%;
	}
	.business_area > ul > li:nth-child(3n+1) {
		margin: 0 0 40px;
	}
	.contact_bnr li {
		width: 48.666%;
		margin: 0 0 0 2.666%;
	}
	.contact_bnr li a {
		padding: 20px 0;
	}
	.business_area > ul > li > a:before {
		border-radius: 25px;
	}
	.contact_bnr li a {
		display: block;
		padding: 30px 0;
		border-radius: 25px;
		background: #000;
	}
}
@media only screen and (min-width: 1025px) {
	.business_ttl h4 {
		font-size: 36px;
	}
	.business_ttl h4 img {
		width: auto;
	}
	.business_ttl h5 {
		font-size: 20px;
	}
	.contact_bnr li a span:nth-child(1) {
		font-size: 36px;
	}
	.contact_bnr li a span:nth-child(2) {
		font-size: 20px;
	}
}
/*--------------------------
フッター
--------------------------*/
#footer {
	padding: 60px 0 0;
	border-top: solid #707070 1px;
}
.fotoer_contents {
	position: relative;
	background: #fff;
}
.copy {
	padding: 10px 30px;
	font-size: 13px;
}
.footer_sns {
	display: flex;
	justify-content: center;
	margin: 0 0 60px;
}
.footer_sns li {
	display: inline-block;
	padding: 0 10px;
}
.footer_sns li a {
	font-size: 24px;
	transition: all 1s ease-out;
}
.footer_sns li a:hover {
	color: #777;
}
.footer_sns li:nth-child(2) a {
	font-size: 27px;
}
@media only screen and (min-width: 1025px) {
	.footer_sns {
		align-items: center;
	}
}
/*--------------------------
ボタン
--------------------------*/
a.btn_on_01 {
	padding: 5px 10px;
	border-radius: 5px;
	border: solid #000 1px;
	background: #000;
	transition: all 0.5s ease-out;
	color: #fff;
}
a.btn_on_01:hover {
	background: #fff;
	color: #CCCCCC;
	transition: all 0.3s ease-out;
}
.header_contact a.btn_on_01 {
	padding: 3px 0.5em;
}
.voice_bnr a.btn_on_01 {
	padding: 3px 4em;
}
a.header_contact_btn:hover {
	color: #000;
}
a.btn_on_02 {
	padding: 5px 10px;
	border: solid #000 1px;
	font-size: 14px;
	transition: all 0.3s ease-out;
}
a.btn_on_02:hover {
	background: #000000;
	color: #ffffff;
}
.more_btn_01 a {
	display: block;
	max-width: 735px;
	margin: 40px auto 0;
	padding: 10px 0;
	border-radius: 5px;
	border: solid #000 1px;
	text-align: center;
	font-weight: bold;
	transition: all 0.5s ease-out;
}
.more_btn_01 a:hover {
	border: solid #000 1px;
	background: #000;
	color: #fff;
}
.more_btn_02 {
	margin: 20px 0 0;
}
.more_btn_02 a {
	position: relative;
	display: block;
	width: 100%;
	padding: 10px 0;
	border-radius: 5px;
	border: solid #000 1px;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
	transition: all 0.5s ease-out;
}
.more_btn_02 a:hover {
	border: solid #000 1px;
	background: #000;
	color: #fff;
}
.more_btn_02 a svg {
	position: absolute;
	top: 50%;
	right: 5%;
	margin: -7px 0 0;
}
.more_btn_02 span {
	position: relative;
	display: block;
	width: 100%;
	padding: 10px 0;
	border-radius: 5px;
	border: solid #000 1px;
	text-align: center;
	font-size: 14px;
	font-weight: bold;
	transition: all 0.5s ease-out;
}
.item_box:hover .more_btn_02 span {
	border: solid #000 1px;
	background: #000;
	color: #fff;
}
.more_btn_02 span svg {
	position: absolute;
	top: 50%;
	right: 5%;
	margin: -7px 0 0;
}
.page_contact_btn {
	margin: 40px 0 0;
}
.page_contact_btn a {
	position: relative;
	display: block;
	text-align: center;
	border-radius: 5px;
	border: solid 1px #000;
	padding: 7px 0;
	font-size: 12px;
	font-weight: bold;
	transition: all 0.5s ease-out;
}
.page_contact_btn a svg {
	position: absolute;
	top: 50%;
	right: 2%;
	margin: -6px 0 0;
}
.page_contact_btn a:hover {
	background: #000;
	color: #fff;
}
@media only screen and (min-width: 641px) {
	.page_contact_btn {
		margin: 80px auto 0;
		width: 79%;
	}
	.page_contact_btn a {
		padding: 15px 0;
		font-size: 14px;
	}
	.page_contact_btn a {
		font-size: 18px;
	}
	.page_contact_btn a svg {
		margin: -9px 0 0;
	}
}
@media only screen and (min-width: 769px) {
	.more_btn_01 a {
		font-size: 20px;
	}
	.more_btn_02 a {
		font-size: 18px;
	}
	.more_btn_02 a svg {
		right: 6%;
		margin: -9px 0 0;
	}
	.more_btn_02 span {
		font-size: 18px;
	}
	.more_btn_02 span svg {
		right: 6%;
		margin: -9px 0 0;
	}
}
/*
メインコンテンツ
*/
.main {
	text-align: center;
}
.main_contents {
   margin: 80px 0 0;
}
.page_body_01 {
	width: 100%;
	padding: 0 6%;
}
.page_body_02 {
	width: 100%;
	padding: 0 6%;
}
.page_body_03 {
	width: 100%;
	padding: 0 20px;
}
.inner_01 {
	padding: 30px 0;
}
@media only screen and (min-width: 641px) {
	 .main_contents {
		margin: 110px 0 0;
	}
}
@media only screen and (min-width: 1001px) {
	.page_body_01 {
		width: 990px;
		margin: auto;
		padding: 0;
	}
	.page_body_03 {
		width: 1790px;
		margin: auto;
		padding: 0;
	}
}
@media only screen and (min-width: 1025px) {
	.main_contents {
		margin: 160px 0 0;
	}
	.inner_01 {
		padding: 60px 0;
	}
}
@media only screen and (min-width: 1197px) {
	.page_body_02 {
		width: 1196px;
		margin: auto;
		padding: 0;
	}
}
@media only screen and (min-width: 1681px) {
	.main_contents {
		margin: 120px 0 0;
	}
}
/*
共通
*/
.set_size{
  display:block;
}

.sec_ttl{
  font-size:27px ;
  font-weight: bold;
  line-height: 1.2;
  text-align: center;
}

.sec_subttl{
  font-size: 14px;
  font-weight: bold;
  text-align: center;
}

.items_ttl{
  font-size: 17px;
  font-family: 'Yu Gothic';
  font-weight: bold;
  text-align: center;
}

.side_ttl{
  font-size:25px ;
  font-style: italic;
  font-weight: bold;
  text-align: center;
}

.us_ttl{
  font-size:25px ;
  font-style: italic;
  font-weight: bold;
  text-align: center;
}

.prev_ttl{
  font-size: 12px;
  text-align: center;
  font-weight: bold;
}

.cmp_ttl{
  font-size: 12px;
  text-align: center;
  font-weight: bold;
}

.crop_ttl{
  display: flex;
  flex-direction:column;
}
.corpsec_ttl{
  font-size:27px ;
  font-style: italic;
  font-weight: bold;
  line-height: 1.2;
}

.corpsec_subttl{
  font-size: 14px;
  font-weight: bold;
}

.kyasec_ttl{
  font-size:27px ;
  font-style: italic;
  font-weight: bold;
  line-height: 1.2;
  text-align: left;
}

@media only screen and (min-width: 641px) {
  .set_size{
    display: none;
  }
	.crop_ttl {
		justify-content: left;
		align-items: center;
		flex-direction: row;
	}
	.corpsec_subttl {
		margin-left: 20px;
	}
}
@media only screen and (min-width: 769px) {

}
@media only screen and (min-width: 1025px) {
  .sec_ttl {
      font-size: 40px;
  }
  .sec_subttl {
      font-size: 20px;
  }
  .items_ttl {
      font-size: 24px;
  }
  .side_ttl {
      font-size: 30px;
  }
  .us_ttl {
      font-size: 36px;
  }
  .prev_ttl {
      font-size: 18px;
  }
  .cmp_ttl {
      font-size: 18px;
  }
  .corpsec_ttl {
      font-size: 40px;
  }
  .corpsec_subttl {
      font-size: 18px;
      line-height: 1.2;
  }
  .kyasec_ttl {
      font-size: 40px;
  }
}
/* -------------------------------------------------------
page_top
------------------------------------------------------- */
.page_top {
	position: fixed;
	right: 2%;
	bottom: 30px;
	z-index: 100;
}
.page_top a {
	width: 40px;
	height: 40px;
	display: block;
	background: url(../images/common/page_top.png) no-repeat;
	-webkit-background-size: 40px;
	background-size: 40px;
}
@media only screen and (min-width: 641px) {
	.page_top a {
		width: 50px;
		height: 50px;
		-webkit-background-size: 50px;
		background-size: 50px;
	}
}
/*
背景色
*/
.bg_body_gray {
	background: #EFEFEF;
}
/*
disc_list
*/
.disc_list li {
	position: relative;
	padding: 0 0 0 18px;
}
.disc_list li:before {
	content: '';
	position: absolute;
	top: 5px;
	left: 0;
	width: 12px;
	height: 12px;
	border: solid #000 1px;
	border-radius: 50%;
	background: #000;
}
@media only screen and (min-width: 641px) {
	.disc_list li {
		padding: 0 0 0 20px;
	}
	.disc_list li:before {
		width: 15px;
		height: 15px;
		top: 5px;
	}
}
/*
スクロールイン
*/
.fadebox {
	transition: 0.8s;
	-webkit-transition: 0.8s;
	-moz-transition: 0.8s;
	-o-transition: 0.8s;
	-ms-transition: 0.8s;
	opacity: 0;
	transform: translate(0,60px);
	-webkit-transform: translate(0,60px);
}
.fadebox_in {
	opacity: 1.0;
	transform: translate(0,0);
	-webkit-transform: translate(0,0);
}
/*
ローディング
*/
#load_display {
	position: absolute;
	left: 50%;
	top: 50%;
	margin: -16px 0 0;
}
#load_display_bg {
	position: fixed;
	width: 100%;
	height: 100%;
	top: 0px;
	left: 0px;
	background: #FFF;
	z-index: 9999;
}

/* アンケートバナー */
/*.voice_bnr {
	 position: fixed;
	right: 0;
	bottom: 10%;
	z-index: 99;
}
.voice_bnr a {
	display: block;
	background: #000;
	color: #fff;
	font-weight: bold;
	padding: 5px;
	font-size: 12px;
	border: #000 solid 1px;
	border-top-left-radius: 5px;
	border-bottom-left-radius: 5px;
	transition: all 0.5s ease-out;
}
@media only screen and (min-width: 641px) {
	.voice_bnr {
		bottom: 12%;
	}
	.voice_bnr a {
		padding: 10px;
		font-size: 16px;
		border-top-left-radius: 10px;
		border-bottom-left-radius: 10px;
	}
	.voice_bnr a:hover {
		background: #fff;
		color: #000;
		transition: all 0.3s ease-out;
	}
} */