@charset "utf-8";
.ftbox {
	overflow: hidden;
*zoom: 1;
}
.ff {
	font-family: "ＭＳ Ｐ明朝", "MS PMincho", "ヒラギノ明朝 Pro W3", "Hiragino Mincho Pro", serif;
}
.rbt {
	font-family: 'Roboto', sans-serif;
}
body, #wrapper{
	overflow-x: hidden;
}
/* header
----------------------------------------------- */
#header {
	position: relative;
	padding-bottom: 30px;
}
#header .inner_m {
	padding: 0;
}
.header {
	display: flex;
	justify-content: space-between;
	align-items: flex-end;
}
.hdlogo {
	width: 195px;
	padding: 0 0 0 15px;
}
.hdlogo img{
	width: 100%;
	height: auto;
}
.hdtxt {
	font-size: 12px;
	color: #656464;
	position: absolute;
	top: 25px;
	left: 50%;
	transform: translateX(-50%);
	-webkit-transform: translateX(-50%);
	z-index: 2;
	width:100%;
	max-width: 1200px;
}
.headerbox02 {
	display: flex;
	align-items: flex-end;
}
.hdbtn {
	display: flex;
}
.hdbtn .btn01 a {
	background: #141414;
}
.hdbtn .btn02 a {
	background: #bf0128;
}
.hdbtn .btn {
	width: 130px;
}
.hdbtn .btn a {
	display: block;
	text-align: center;
	color: #fff;
	font-size: 16px;
	text-decoration: none;
	padding: 25px 0 15px;
}
.hdbtn .btn a img {
	display: block;
	margin: 0 auto 15px;
}
.hdbtn .btn a:hover {
	opacity: 0.7;
	-moz-opacity: 0.7;
	filter: alpha(opacity=70);
}
.hdbtn .btn .recruitmenu a {
	color: #000;
  padding: 0;
  background: none;
}
.hdbtn .btn .recruitmenu a img {
	display: block;
	margin: 0;
}
.hdbtn .btn .recruitmenu a:hover {
	opacity: 1;
	-moz-opacity: 1;
	filter: alpha(opacity=100);
}
@media (max-width: 959px) {
#header {
	padding-bottom: 0;
}
.header {
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.hdtxt {
	display: none;
}
.hdlogo {
	width: 130px;
	padding: 0 0 0 15px;
}

.headerbox02 {
	display: none;
}
}
/* gnavi
----------------------------------------------- */

#gNavi {
	padding: 0 30px 15px 0;
}
#gNavi ul {
	display: flex;
}
#gNavi ul > li {
	padding: 0 20px;
}
#gNavi ul > li > a {
	display: block;
	font-size: 16px;
	text-decoration: none;
	padding: 0 0 0 25px;
	font-weight: bold;
	white-space: nowrap;
}
#gNavi ul li a:hover {
	color: #bf0128;
}
#gNavi ul li a.gnavi01 {
	background: url(../images/common/ico_navi01.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi02 {
	background: url(../images/common/ico_navi02.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi03 {
	background: url(../images/common/ico_navi03.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi04 {
	background: url(../images/common/ico_navi04.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi05 {
	background: url(../images/common/ico_navi05.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi06 {
	background: url(../images/common/ico_navi06.png) 0 3px no-repeat;
}
#gNavi ul li a.gnavi07 {
	background: url(../images/common/ico_navi07.png) 0 3px no-repeat;
}
.pullmenu {
	position: absolute;
	top: 96px;
	left: 0;
	width: 100%;
	z-index: 9;
	padding-top: 50px;
	display: none;
}
.pullmenubg {
	background: rgba(0,0,0,0.8);
	padding: 30px 0;
}
.pullmenulist {
	margin: -30px 0 0 -30px;
}
.pullmenulist li {
	float: left;
	width: 33.33%;
	padding: 30px 0 0 30px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
.recruitmenu .pullmenulist li {
	width: 25%;
}
.pullmenubox {
	display: table;
	width: 100%;
	background: #000;
	padding: 25px 30px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
.pullmenubox dt {
	display: table-cell;
	width: 45px;
	vertical-align: middle;
}
.pullmenubox dd {
	display: table-cell;
	vertical-align: middle;
	padding: 0 0 0 15px;
	color: #fff;
	font-size: 18px;
}
.pullmenubox dd span {
	font-size: 14px;
	display: block;
}

@media (max-width: 1090px) {
	#gNavi ul > li{
		padding: 0 15px;
	}
	#gNavi ul > li > a{
		white-space: nowrap;
	}
}

/* navbarToggle
----------------------------------------------- */
.navbarToggle {
	width: 50px;
	height: 50px;
	background: url(../images/common/menu_no.png) 0 0 no-repeat;
	background-size: 100%;
	border-left: 1px solid #eee;
}
.navbarToggle.on {
	background: url(../images/common/menu_on.png) 0 0 no-repeat;
	background-size: 100%;
}
.pulldown {
	border-top: 4px solid #eee;
	position: absolute;
	top: 100%;
	left: 0;
	z-index: 9;
	width: 100%;
	height: 500px;
	overflow-y: scroll;
	display: none;
	background: #fff;
}
.pulllist li + li {
	border-top: 1px solid #eee;
}
.pulllist a {
	display: block;
	font-weight: bold;
	text-decoration: none;
	padding: 10px 0 10px 50px;
	background: url(../images/common/ico_arrow01.png) 20px center no-repeat;
	background-size: 8px;
}
.pulllist .toggle a {
	background: url(../images/common/ico_open.png) 16px center no-repeat;
	background-size: 12px;
}
.pulllist .toggle.on a {
	background: url(../images/common/ico_active.png) 16px center no-repeat;
	background-size: 12px;
}
.pullbox {
	padding: 0 0 0 30px;
	display: none;
}
/* mainimg
----------------------------------------------- */


#mainimg {
	background: url(../images/top/bg_mainimg.png) 0 0 repeat-x;
	background-size: auto 100%;
}
.mainimgbox {
	width: 81.25%;
	float: right;
	position: relative;
}
.mainimgbox .tit {
	position: absolute;
	top: 55%;
	left: -60px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	z-index: 2;
}
.mainimgbox .tit span {
	background: rgba(0,0,0,0.7);
	color: #fff;
	font-size: 48px;
	padding: 0 15px;
	font-weight: bold;
	display:inline-block;
}
.mainimgbox .tit .txt {
	font-size: 30px;
	margin:15px 0 0;
}
.mainimgbox .ico {
	position: absolute;
	bottom: 180px;
	left: 190px;
	z-index: 2;
}
@media (max-width: 959px) {
#mainimg {
	background: none;
}
.mainimgbox {
	width: 100%;
	float: none;
}
.mainimgbox .tit {
	position: absolute;
	top: auto;
	bottom: 10%;
	left: 10px;
	transform: none;
	-webkit-transform: none;
	z-index: 2;
}
.mainimgbox .tit span {
	font-size: 24px;
	padding: 2px 10px;
}
.mainimgbox .tit .txt {
	font-size: 15px;
	margin:5px 0 0;
}
.mainimgbox .ico {
	bottom: 10px;
	left: auto;
	right: 10px;
	width: 120px;
}
}
.sliderbg01 {
	background: url(../images/top/img_slider01c.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}
.sliderbg02 {
	background: url(../images/top/img_slider02e.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}
.sliderbg03 {
	background: url(../images/top/img_slider03a.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}
.sliderbg04 {
	background: url(../images/top/img_slider04.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}
.sliderbg05 {
	background: url(../images/top/img_slider05.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}
.sliderbg06 {
	background: url(../images/top/img_slider06.jpg) center center no-repeat;
	background-size: cover;
	height: 700px;
}

#mainimg .slick-dots {
	width: 790px;
	right: 0;
	bottom: 60px;
}
#mainimg .slick-dots li {
	margin: 0;
}
#mainimg .slick-dots li button:before {
	content: "■";
}
#mainimg .slick-dots li.slick-active button:before {
	color: #bf0128;
	opacity: 1;
}
#mainimg .slick-dots li button:before {
	color: rgba(255,255,255,0.6);
	opacity: 1;
}
 @media (max-width: 959px) {
.sliderbg01 {
	height: 280px;
}
.sliderbg02 {
	height: 280px;
}
.sliderbg03 {
	height: 280px;
}
}
/* teaser
----------------------------------------------- */

#teaser {
	background: #eee;
	padding: 0 0 65px;
	overflow: hidden;
}
.teaserbox {
	width:100%;
	max-width: 1560px;
}
@media (max-width: 959px) {
#teaser {
	padding: 0;
}
.teaserbox {
	width: 100%;
	float: none;
}
}
/* contents
----------------------------------------------- */


#main {
	float: left;
	width: 820px;
	padding: 0 40px;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
#side {
	float: right;
	width: 220px;
}
.bortop {
	border-top: 2px solid #d6d5d5;
}
.toppage .bortop,
body.philosphy .bortop{
	border-top: none;
}
@media (max-width: 959px) {
#main {
	float: none;
	width: 100%;
	padding: 0;
	margin-bottom: 30px;
}
#side {
	float: none;
	width: 100%;
}
.bortop {
	border-top: 1px solid #d6d5d5;
}
}
/* H
----------------------------------------------- */

.hdL {
	color: #fff;
	font-size: 24px;
	position: absolute;
	top: 55%;
	left: 60px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	z-index: 2;
	font-weight: bold;
}
.hdL span {
	display:inline-block;
	margin-right: 25px;
	font-size:62px;
	font-weight:bold;
}
.hdM {
	text-align: center;
	font-size: 18px;
	font-weight: bold;
	line-height: 1.4;
}
.hdM span {
	display: block;
  font-size: 50px;
  line-height: 1.2;
  margin-bottom: 5px;
}
.hdM span i {
	font-style: normal;
	color: #bf0128;
}
@media (max-width: 959px) {
.hdL {
	font-size: 14px;
	top: 50%;
	left: 50%;
	transform: translate(-50%, -50%);
	-webkit-transform: translate(-50%, -50%);
	text-align: center;
	width: 100%;
}
.hdL span {
	display:block;
	margin-right: 0;
	font-size:28px;
	line-height:1.1;
	margin-bottom:5px;
}
.hdM {
	font-size: 14px;
	text-align: left;
}
.hdM span {
	font-size: 24px;
}
}
/* wrapper
----------------------------------------------- */
.wrapper {
	position: relative;
}
.inner_l {
	max-width: 1720px;
	margin: 0 auto;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
.inner_m {
	max-width: 1200px;
	margin: 0 auto;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
.inner_s {
	max-width: 1080px;
	margin: 0 auto;
	-webkit-box-sizing: border-box;
	-moz-box-sizing: border-box;
	-ms-box-sizing: border-box;
	-o-box-sizing: border-box;
	box-sizing: border-box;
}
@media (max-width: 959px) {
.inner_l,
.inner_m,
.inner_s {
	padding:0 25px;
}
}
/* breadcrumb
----------------------------------------------- */

#breadcrumb {
	background: #000;
	color: #fff;
	font-size: 12px;
	padding: 5px 0 5px 60px;
}
/* #breadcrumb span {
	display: inline-block;
	padding: 0 10px;
	margin-top: -4px;
	vertical-align: middle;
} */
#breadcrumb .breadcrumb_arrow{
	display: inline-block;
	padding: 0 10px;
	margin-top: -4px;
	vertical-align: middle;
}
#breadcrumb a {
	font-size: 12px;
	color: #afafaf;
	text-decoration: underline;
}
#breadcrumb .link {
	color: #fff;
	text-decoration: none;
}
#breadcrumb a:hover {
	text-decoration: none;
}
#breadcrumb .link:hover {
	text-decoration: underline;
}
@media (max-width: 959px) {
#breadcrumb {
	padding: 5px 10px;
}
}
/* footer
----------------------------------------------- */

.footercont {
	padding: 35px 0;
	display: flex;
	justify-content: space-between;
	align-items: center;
}
.ftcontbox01 {
	display: flex;
	align-items: center;
}
.fttxt {
	font-size: 14px;
	padding: 0 0 0 30px;
}
.fttel {
	display: table;
	width: 100%;
}
.fttel dt {
	display: table-cell;
	width: 30px;
	vertical-align: middle;
}
.fttel dd {
	display: table-cell;
	padding: 0 0 0 15px;
	font-size: 14px;
	vertical-align: middle;
}
.fttel dd a {
  pointer-events: none;
}
.fttel dd span {
	display: block;
	font-size: 40px;
	font-weight: bold;
	line-height: 1;
}
.ftlink {
	background: #141414;
	padding: 60px 0 40px;
}
.ftlinkbox01 {
	float: left;
	width: 350px;
}
.ftlinkbox02 {
	overflow: hidden;
	padding: 0 0 0 50px;
}
.ftlinklist01 li {
	float: left;
	width: 50%;
}
.ftlinklist01 li p + p {
	margin: 25px 0 0;
}
.ftlinklist01 li a {
	font-size: 14px;
	color: #fff;
	padding: 0 0 0 10px;
	position: relative;
}
.ftlinklist01 li a:before {
	background: #bf0128;
	width: 5px;
	height: 2px;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	content: "";
	z-index: 2;
	position: absolute;
}
.ftlinklist02 li + li {
	margin: 30px 0 0;
}
.ftlinklist02 li .link a {
	font-size: 14px;
	color: #fff;
	padding: 0 0 0 10px;
	position: relative;
}
.ftlinklist02 li .link a:before {
	background: #bf0128;
	width: 5px;
	height: 2px;
	top: 50%;
	left: 0;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	content: "";
	z-index: 2;
	position: absolute;
}
.ftlinklist02 li .pagelink a {
	display: inline-block;
	padding: 0 10px;
	color: #afafaf;
	font-size: 14px;
	line-height: 1;
}
.ftlinklist02 li .pagelink a + a {
	border-left: 1px solid #6e6e6e;
}
.footer_logo{
	width: 195px;
	height: auto;
}
.footer_logo img{
	width: 100%;
	height: auto;
}
.ft_sns {
	width: 350px;
	margin-top: 20px;
}
@media (max-width: 959px) {
.footercont {
	padding: 20px 0 15px;
	display: block;
}
.footer_logo{
	width: 195px;
	height: auto;
	margin: 0 auto;
}
.footer_logo img{
	width: 100%;
	height: auto;
}
.ftcontbox01 {
	display: block;
	text-align: center;
}
.ftcontbox02 {
	display: none;
}
.fttxt {
	font-size: 12px;
	padding: 15px 0 0;
	text-align: left;
}
.fttel dd a {
  pointer-events: auto;
}
.ftlink {
	background: #141414;
	padding: 25px 0 15px;
}
.ftlinkbox01 {
	float: none;
	width: 100%;
	margin-bottom: 20px;
}
.ftlinkbox02 {
	padding: 0;
}
.ftlinklist01 li p + p {
	margin: 15px 0 0;
}
.ftlinklist01 li a {
	font-size: 12px;
}
.ftlinklist02 li + li {
	margin: 15px 0 0;
}
.ftlinklist02 li .link a {
	font-size: 12px;
}
.ftlinklist02 li .pagelink a {
	display: block;
	padding: 5px 0 5px 20px;
	font-size: 12px;
	margin: 12px 0;
}
.ftlinklist02 li .pagelink a + a {
	border-left: none;
}
}
#copyright {
	position: absolute;
	top: 280px;
	left: 55px;
	z-index: 2;
	-webkit-writing-mode: vertical-rl;
	writing-mode: tb-rl;
	font-size: 12px;
}

@media (max-width: 1400px) {
	#copyright {
		background: #141414;
		color: #fff;
		text-align: center;
		border-top: 1px solid #fff;
		position: static;
		-webkit-writing-mode: lr-tb;
		writing-mode: lr-tb;
		padding: 10px 0;
	}
}

@media (max-width: 959px) {
#copyright {
	background: #141414;
	color: #fff;
	text-align: center;
	border-top: 1px solid #fff;
	padding: 10px 0;
	position: inherit;
	top: auto;
	left: auto;
	z-index: inherit;
	-webkit-writing-mode: horizontal-tb;
	writing-mode: horizontal-tb;
	font-size: 10px;
	margin-bottom: 14%;
}
}
.fixepage {
	position: fixed;
	bottom: 0;
	left: 0;
	width: 100%;
	z-index: 8;
	display: none;
}
.fixedlink {
	display: flex;
}
.fixedlink p {
	text-align: center;
	flex: 1;
}
.fixedlink p img {
	width: 100%;
}
/* combtn
----------------------------------------------- */

.combtn {
	width: 280px;
}
.combtn a {
	display: block;
	background: #141414;
	font-size: 16px;
	text-align: center;
	position: relative;
	text-decoration: none;
	padding: 10px 0;
	color: #fff;
	position: relative;
}
.combtn a:hover {
	background: #bf0128;
}
.combtn a:before {
	background: url(../images/common/ico_arrow02.png) 0 0 no-repeat;
	width: 6px;
	height: 10px;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	content: "";
	z-index: 2;
	position: absolute;
}
@media (max-width: 959px) {
.combtn {
	width: 100%;
}
.combtn a {
	font-size: 15px;
	padding: 8px 0;
}
}

/*------------------------↓↓ 20240823 add ↓↓----------------------*/
/* pdfbtn
----------------------------------------------- */

.pdfbtn {
	width: 280px;
}
.pdfbtn a {
	display: block;
	background: #141414;
	font-size: 16px;
	text-align: center;
	position: relative;
	text-decoration: none;
	padding: 10px 0;
	color: #fff;
	position: relative;
}
.pdfbtn a:hover {
	background: #bf0128;
}
.pdfbtn a:before {
	background: url(../images/common/ico_arrow02.png) 0 0 no-repeat;
	width: 6px;
	height: 10px;
	top: 50%;
	right: 20px;
	transform: translateY(-50%);
	-webkit-transform: translateY(-50%);
	content: "";
	z-index: 2;
	position: absolute;
}
@media (max-width: 959px) {
.pdfbtn {
	width: 100%;
}
.pdfbtn a {
	font-size: 15px;
	padding: 8px 0;
}
}
/*------------------------↑↑ 20240823 add ↑↑----------------------*/


/* comlinksec
----------------------------------------------- */

.comlinksec {
	background:#eee;
	padding:90px 0 100px;
}
.comlinllist {
	display:flex;
	flex-wrap:wrap;
}
.comlinllist01 li {
	width:17%;
	margin:50px 15px 0;
}
.comlinkpanel {
	background:#fff;
}
.comlinkpanel .img img {
	width:100%;
}
.comlinkpanel .tit {
	display:table;
	width:100%;
	padding:15px 0 15px;
}
.comlinkpanel .tit span {
	display:table-cell;
	text-align:center;
	vertical-align:top;
	position:relative;
	line-height:1.2;
}
@media (max-width: 959px) {
.comlinksec {
	background:#eee;
	padding:45px 0 50px;
}
.comlinllist01 {
	justify-content:center;
}
.comlinllist01 li {
	width:46%;
	margin:15px 5px 0;
}
.comlinkpanel .tit {
	padding:10px 0 10px;
}
.comlinkpanel .tit span {
	font-size:12px;
	padding:0px 5px 0;
}
}



.sales .inner_m {
	max-width:700px;
}
.sales .comlinllist01 li {
	width:28.5%;
}
@media (max-width: 959px) {
.sales .comlinllist01 li {
	width:46%;
}
}


.envirjecbox01 {
	float:left;
	width:700px;
}
.envirjecbox01 .comlinllist01 li {
	width:30%;
	margin:50px 3.33% 0 0;
}
.envirjecbox02 {
	float:left;
	width:700px;
	margin-top:30px;
}
.envirjecbox02 .comlinllist01 li {
	width:30%;
	margin:50px 3.33% 0 0;
}
.envirjectpanel {
	margin:30px auto 0;
	width: 680px;
}
.envirjecbox01 .comlinllist01 li,
.envirjecbox02 .comlinllist01 li {
	margin-top:10px;
}
@media (max-width: 1149px) {
.envirjecbox02 {
	float:left;
}
}
@media (max-width: 959px) {
.envirjecbox01 {
	float:none;
	width:100%;
}
.envirjecbox01 .comlinllist01 li {
	width:46%;
}
.envirjecbox02 {
	float:none;
	width:100%;
	margin-top: 20px;
	margin-left: 0;
}
.envirjecbox02 .comlinllist01 li {
	width:46%;
}
.envirjectpanel {
	margin-top:15px;
	width: 100%;
}
.envirjecbox01 .comlinllist01 li,
.envirjecbox02 .comlinllist01 li {
	margin-top:10px;
}
}

/* ======== gNaviアニメーション ========== */
.pullmenu{
	display: block;
	visibility: hidden;
	overflow: hidden;
}
.pullmenu.is_active, .pullmenu:hover{
	display: block;
	visibility: visible;
}
.pullmenu > .pullmenubg{
	transition: all 0.3s;
	opacity: 0;
	transform: translateY(-100px);
}
.pullmenu.is_active > .pullmenubg,
.pullmenu:hover > .pullmenubg{
	transition: all 0.3s;
	opacity: 1;
	transform: translateY(0);
}

.credit_homepage {
    color: #bdbdbd;
    font-size: 14px;
    text-align: right;
    padding-right: 20px;
    padding-bottom: 10px;
}
.credit_homepage a {
    color: #bdbdbd;
    font-size: 14px;
}

@media (max-width: 959px) {
    .credit_homepage {
	font-size: 12px;
	text-align: left;
	padding-top: 20px;
	padding-right: 0px;
	padding-bottom: 10px;
    }
    .credit_homepage a {
	color: #bdbdbd;
	font-size: 12px;
    }
}


.pagetop {
  display: none;
  position: fixed;
  bottom: 40px;
  right: 40px;
  z-index: 10;
}
@media (max-width: 959px) {
  .pagetop {
    bottom: 60px;
    right: 10px;
  }
  .pagetop img {
    width: 45px;
    height: auto;
  }
}
