@charset "utf-8";

html{
	scroll-behavior: smooth;
}

/*  common  */
.df{ display: flex !important; }

.pt0 { padding-top: 0px !important; }
.pt10px { padding-top: 10px !important; }
.pt20px { padding-top: 20px !important; }
.pr10px { padding-right: 10px !important; }
.pr20px { padding-right: 20px !important; }
.pb20px { padding-bottom: 20px !important; }
.pt20px { padding-top: 20px !important; }
.pl10px { padding-left: 10px !important; }
.pl20px { padding-left: 20px !important; }

.mg0a { margin: 0 auto !important; }

.mt05em { margin-top: 0.5em !important; }
.mt10em { margin-top: 1.0em !important; }
.mt15em { margin-top: 1.5em !important; }
.mt20em { margin-top: 2.0em !important; }
.mt25em { margin-top: 2.5em !important; }
.mt30em { margin-top: 3.0em !important; }
.mt40em { margin-top: 4.0em !important; }
.mt20px { margin-top: 20px !important; }
.mt30px { margin-top: 30px !important; }
.mt60px { margin-top: 60px !important; }

.mr05px { margin-right: 05px !important; }

.mb0 { margin-bottom: 0 !important; }
.mb05px { margin-bottom: 05px !important; }
.mb10em { margin-bottom: 1.0em !important; }
.mb15em { margin-bottom: 1.5em !important; }
.mb20em { margin-bottom: 2.0em !important; }
.mb20px { margin-bottom: 20px !important; }
.mb30px { margin-bottom: 30px !important; }
.mb40px { margin-bottom: 40px !important; }

.ml0 { margin-left: 0 !important; }
.ml05px { margin-left: 05px !important; }
.mr05px { margin-right: 05px !important; }
.ml10px { margin-left: 10px !important; }
.ml20px { margin-left: 20px !important; }
.ml30px { margin-left: 30px !important; }
.ml40px { margin-left: 40px !important; }

.fsz09px { font-size: 09px !important; }
.fsz13px { font-size: 13px !important; }
.fsz09em { font-size: 0.9em !important; }
.fsz11em { font-size: 1.1em !important; }
.fsz12em { font-size: 1.2em !important; }
.fsz14em { font-size: 1.4em !important; }

.tal { text-align: left !important; }
.tac { text-align: center !important;}
.tar { text-align: right !important;}

.fwb { font-weight: bold !important; }
.fwn { font-weight: normal !important; }

.dib{display: inline-block !important;}

.ti{text-indent: 1em;}

.wsn { white-space: nowrap !important; }

.flex-grow1{
	flex-grow: 1 !important;
}

.w014p { width: 014% !important; }
.w017p { width: 017% !important; }
.w030p { width: 030% !important; }
.w035p { width: 035% !important; }
.w040p { width: 040% !important; }
.w045p { width: 045% !important; }
.w050p { width: 050% !important; }
.w055p { width: 055% !important; }
.w060p { width: 060% !important; }
.w065p { width: 065% !important; }
.w070p { width: 070% !important; }
.w080p { width: 080% !important; }
.w090p { width: 090% !important; }
.w100p { width: 100% !important; }
@media only screen and (max-width: 600px) {
	.w030p { width: 100% !important; }
	.w035p { width: 100% !important; }
	.w040p { width: 100% !important; }
	.w045p { width: 100% !important; }
	.w050p { width: 100% !important; }
	.w055p { width: 100% !important; }
	.w060p { width: 100% !important; }
	.w065p { width: 100% !important; }
	.w070p { width: 100% !important; }
	.w080p { width: 100% !important; }
	.w090p { width: 100% !important; }
}

.h100p{ height: 100% !important; }
@media only screen and (max-width: 600px) {
	.h100p{ height: auto !important; }
}

@media only screen and (max-width: 600px) {
	.sp-nobr{
		display: none;
	}
}

table.table{
	width: auto;
	border-top: 2px solid #ccc;
	border-right: 2px solid #ccc;
}
.table th,
.table td{
	padding: 6px 8px;
	background: none;
	border-bottom: 2px solid #ccc;
	border-left: 2px solid #ccc;
	border-collapse: collapse;
	box-sizing: border-box;
}
.table th{}
.table td{}
.table .bg-light-blue{background: #D9E1F2;}
.table .bg-light-green{background: #E2EFDA;}

.table .red-box,
.table .white-box{
	position: relative;
}
.table .red-box::after,
.table .white-box::after{
	content: "";
	display: block;
	width: calc( 100% + 4px );
	height: calc( 100% + 4px );
	position: absolute;
	top: -2px;
	left: -2px;
	box-sizing: border-box;
}
.table .red-box.bd-red-t::after{border-top: 2px solid #fd7e00 !important;}
.table .red-box.bd-red-r::after{border-right: 2px solid #fd7e00 !important;}
.table .red-box.bd-red-b::after{border-bottom: 2px solid #fd7e00 !important;}
.table .red-box.bd-red-l::after{border-left: 2px solid #fd7e00 !important;}

.table .white-box.bd-white-t::after{border-top: 2px solid #fff !important;}
.table .white-box.bd-white-r::after{border-right: 2px solid #fff !important;}
.table .white-box.bd-white-b::after{border-bottom: 2px solid #fff !important;}
.table .white-box.bd-white-l::after{border-left: 2px solid #fff !important;}

.table .erase.white-box::after{
	width: calc( 100% + 3px );
	height: calc( 100% + 2px );
	top: -1px;
	left: -1px;
}
.table .erase2.white-box::after{
	width: calc( 100% + 3px );
	height: calc( 100% + 2px );
	top: -2px;
	left: -3px;
}


h1 span.def{
	display: inline;
	padding: 0 0;
	border: none;
	border-bottom: none;
}
h1 span.fss{
	font-size: 0.8em;
}

.lNav{
	margin: 0 0 30px 20px;
}
.lNav li{
	display: inline-block;
	margin-right: 1em;
	margin-bottom: .3em;
}

.bd-box{
	border: 2px solid #000;
	padding: 1.5em;
	border-radius: 1em;
}
.bd-blue{
	border-color: #89B9EB;
}


.black-circle li{
	padding-left: 1em;
	text-indent: -1em;
}
.black-circle li:before{
	content: "●";
	display: inline;
}
.dot-list,
.decimal{
	padding-left: 1.25em;
}
.dot-list > li{
	list-style-type: disc;
	list-style-position: outside;
	margin-top: .4em;
}
.decimal > li{
	list-style-type: decimal;
	list-style-position: outside;
	margin-top: .4em;
}
.img-gallery{
	display: flex;
	justify-content: space-between;
	flex-wrap: nowrap;
}
.jc-center{
	justify-content: center;
}
.jc-start{
	justify-content: start;
}
.jc-space-around{
	justify-content: space-around;
}
.jc-space-between{
	justify-content: space-between;
}
.ai-end{
	align-items: end;
}
.img figcaption,
.img-gallery figcaption{
	margin-top: .4em;
	font-size: .85em;
}

.flex-column{
	display: flex;
}
@media only screen and (max-width: 600px) { /* SP */
	.flex-column{
		flex-wrap: wrap;
	}
}

.img-bd{
	vertical-align: top;
	border: 1px solid #ccc;
}

.bgc-f2f2f2{ background-color: #f2f2f2 !important; }

.bd1px{ border: 1px solid #000; }
.bdc-cccccc{ border-color: #cccccc !important; }
.bdnone { border: none !important; }

.vat { vertical-align: top !important; }

.normalList{}
.normalList ul,
.normalList ol{
/*	padding-left: 1em;*/
}
.normalList li{
	list-style-position: outside;
}

.section img,
.subSection img{
	max-width: 100% !important;
}


/* Resource Circulation */
.rc{
  text-justify: inter-ideograph;
  text-align: justify;
}

body#company .subSection .annotation {
	text-indent: -1em;
	padding-left: 1em;
}
body#company .subSection .annotation02 {
	text-indent: -2em;
	padding-left: 2em;
}

body#company div.coverBox002.c1 .subBox {
    margin: 0 0 10px 0;
    background: url(../images/cover_bg041_c1.gif) no-repeat 0 0;
}
body#company div.coverBox002.c1 .bottomFrame {
    padding: 0 0 10px 0;
    background: url(../images/cover_bg042_c1.gif) no-repeat left bottom;
}
div.coverBtBox div.subBox02 ul li.reset {
    /* position: relative; */
    float: none;
    width: auto;
    min-height: auto;
    margin-right: 0px;
}

body#company.sustainabilityIndex div.coverBox002:last-child {
	width: 327px;
}

@media only screen and (max-width: 600px) {
	body#company.sustainabilityIndex div.coverBox002:last-child {
		width: 100%;
	}
}

@media only screen and (max-width: 600px) {
	body#company div.coverBox002 dl{
		padding-bottom: 10px !important;
	}
	body#company div.coverBox002 dl dd {
		display: block;
		padding: 5px 0 0 5px;
	}

  div.coverBtBox div.subBox02 ul li{
    padding-bottom: 0;
    margin-right: 10px;
  }
  div.coverBtBox div.subBox02 dl{
    padding: 0 !important;
  }
  div.coverBtBox div.subBox02 dl dt{
    padding: 10px 0 10px 30px !important;
    background: none;
  }
  div.coverBtBox div.subBox02 dl dd{
    padding: 4px 0 10px 30px !important;
  }
  div.coverBtBox div.subBox02 dl dt::before{
    left: 12px;
    margin-top: -6px;
  }

}


/* cover box002 */
div.coverBox002 .fLeft {
	float: left;
	width: 327px;
}
div.coverBox002 .fRight {
	float: right;
	width: 327px;
}

div.coverBox002 .subBox001 {
	clear: both;
	margin: 0 0 11px 0;
	margin: 0 0 10px 0;
	margin: 0 0 5px 0;
	background: url(../images/cover_bg041.gif) no-repeat 0 0;
}
div.coverBox002 .subBox001 .bottomFrame {
	padding: 0 0 10px 0;
	background: url(../images/cover_bg042.gif) no-repeat left bottom;
}
div.coverBox002 .subBox001 .irregularBox {
	padding: 0 0 10px 0;
	padding: 0 0 5px 0;
	background: url(../images/cover_bg042.gif) no-repeat right bottom;
}
div.coverBox002 .subBox001 .irregularBox:nth-child(2) {
	background: none;
}
div.coverBox002 .subBox001 .irregularLayout {
	border-top: #ffffff 10px solid;
	background: url(../images/cover_bg041.gif) no-repeat 0 0;
	/* zoom: 1; */
}
/* SK追記 */
@media only screen and (max-width: 600px) { /* SP */
	div.coverBox002 .subBox001 {
		background: none;
	}
	div.coverBox002 .subBox001 .bottomFrame {
		background: none;
	}
	div.coverBox002 .subBox001 .irregularBox {
		background: none;
	}
	div.coverBox002 .subBox001 .irregularLayout {
		background: none;
	}
	body#company div.coverBox002.coverBoxIrregular .subBox001{
		margin-bottom: 0;
	}
	body#company div.coverBox002.coverBoxIrregular .bottomFrame{
		padding: 0 0 0 0;
	}
	body#company div.coverBox002.coverBoxIrregular .fRight{
		border: none;
		margin-bottom: 0;
	}
	body#company div.coverBox002.coverBoxIrregular .fRight > .irregularBox{
		border: 2px solid #DDDDDD;
		margin-bottom: 10px;
	}
} /* @media */



.subBoxNew{}
.subBoxNew *{
	-webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box;
}
.subBoxNew ul{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}
.subBoxNew > ul > li{
	width: 218px;
	padding-bottom: 5px;
}
.subBoxNew > ul > li.c2{
	width: 442px;
}
.subBoxNew > ul > li.c3{
	width: 100%;
}
.subBoxNew > ul > li > dl{
	display: flex;
	/* flex-wrap: wrap; */
	flex-direction: column;
	padding: 3px;
	/* margin-bottom: 5px; */
	border: 2px solid #ddd;
}
.subBoxNew > ul > li.c2 > dl,
.subBoxNew > ul > li.c3 > dl{
	height: 100%;
}

.subBoxNew > ul > li > dl dt{
	display: block;
	background: #FFFFFF;
	background: linear-gradient(0deg,rgba(255, 255, 255, 1) 0%, rgba(242, 242, 242, 1) 100%);
	font-size: 116%;
	font-weight: bold;
}
.subBoxNew.management > ul > li > dl dt{
	font-size: 111%;
	width: 100%;
	min-height: 36.2px;
	flex-grow: 0;
}
.subBoxNew > ul > li > dl dt span{
	display: block;
	min-height: 36.2px;
	padding: 7px 15px 7px 25px;
	position: relative;
}
.subBoxNew > ul > li > dl dt span.h4em{
	height: 4em;
}
.subBoxNew > ul > li > dl dt span.h55em{
	height: 5.5em;
}

.subBoxNew > ul > li > dl dt span:before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	border-left: 11px solid #048ad4;
	border-right: 0;
	position: absolute;
	top: 14px;
	left: 10px;
}
.subBoxNew > ul > li > dl dd{
	width: 100%;
	padding: 4px 0 6px 15px;
	flex: 1;
	flex-grow: 1;
}

.subBoxNew > ul > li > dl dd:before{
	content: "";
	display: block;
	width: calc(100% + 18px);
	height: 5px;
	background: url(../images/cover_line001.gif) left top no-repeat ;
	background-size: calc( 100% - 10px ) 5px;
	position: relative;
	left: -18px;
}

@media only screen and (max-width: 600px) {
	.subBoxNew > ul > li{width: 100% !important;}
	.subBoxNew > ul > li > dl dt span.h4em,
	.subBoxNew > ul > li > dl dt span.h55em{
		height: auto;
	}
} /* @media */



/* sustainability/index.html
----- ----- ----- ----- ----- ----- ----- ----- ----- */
.topBoxCont *{
	-webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box;
}
div.coverBox002.topBoxCont .subBox001.topBox,
body#company div.coverBox002.topBoxCont .subBox,
body#company div.coverBox002.topBoxCont .bottomFrame,
body#company div.coverBox002.topBoxCont dl dt,
div.coverBox002 .subBox001.topBox .irregularBox,
div.coverBox002 .subBox001.topBox .irregularLayout{
	background: none;
}
body#company div.coverBox002.topBoxCont .fLeft,
body#company div.coverBox002.topBoxCont .fRight{
	float: none;
}

body#company div.coverBox002.topBoxCont .bottomFrame{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
	padding: 0;
}

body#company div.coverBox002.topBoxCont .fLeft,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight{}

body#company div.coverBox002.topBoxCont .fLeft dl,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl{
	display: flex;
	flex-direction: column;
	padding: 3px 4px !important;
	border: 2px solid #ddd;
}
body#company div.coverBox002.topBoxCont .fLeft dl dt,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dt,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dt,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dt{
	display: block;
	padding: 0 0 0 0 !important;
	background: #FFFFFF;
	background: linear-gradient(0deg,rgba(255, 255, 255, 1) 0%, rgba(242, 242, 242, 1) 100%);
	font-size: 116%;
	font-weight: bold;
}
body#company div.coverBox002.topBoxCont .fLeft dl dt span,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dt span,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dt span,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dt span{
	display: block;
	/* min-height: 36.2px; */
	padding: 6px 0px 5px 31px;
	position: relative;
}
body#company div.coverBox002.topBoxCont .fLeft dl dt span:before,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dt span:before,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dt span:before,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dt span:before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	border-left: 11px solid #048ad4;
	border-right: 0;
	position: absolute;
	top: 13px;
	left: 15px;
}
body#company div.coverBox002.topBoxCont .fLeft dl dd,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dd,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dd,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dd{
	width: 297px;
	padding: 10px 0px 10px 18px;
	margin: 0 auto;
	flex: 1;
	flex-grow: 1;
	position: relative;
}
body#company div.coverBox002.topBoxCont .fLeft dl dd:before,
body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dd:before,
body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dd:before,
body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dd:before{
	content: "";
	display: block;
	width: 297px;
	height: 5px;
	background: url(../images/cover_line001.gif) left top repeat-x;
	position: absolute;
	top: 0;
	left: 0;
}
div.coverBox002 .subBox001 .irregularBox:nth-child(2) {padding-bottom: 0;}

@media only screen and (max-width: 600px) {
	body#company div.coverBox002.topBoxCont dl dt::before{
		display: none;
	}
	body#company div.coverBox002.topBoxCont .fLeft dl dd,
	body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dd,
	body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dd,
	body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dd{
		width: 96%;
	}
	body#company div.coverBox002.topBoxCont .fLeft dl dd:before,
	body#company div.coverBox002.topBoxCont .subBox001 .irregularBox dl dd:before,
	body#company div.coverBox002.topBoxCont .subBox.topBox .fLeft dl dd:before,
	body#company div.coverBox002.topBoxCont .subBox.topBox .fRight dl dd:before{
		width: 100%;
	}
	body#company div.coverBox002.topBoxCont.coverBoxIrregular .fRight > .irregularBox{
		border: none;
		margin-bottom: 0;
	}
	div.coverBox002 .subBox001 .irregularBox {padding-bottom: 0px;}
	body#company div.coverBox002.topBoxCont .fLeft,
	body#company div.coverBox002.topBoxCont .fRight{
		margin-bottom: 10px;
		border: none
	}
} /* @media */



.topBoxCont{}
.topBox{}


/* management
----- ----- ----- ----- ----- ----- ----- ----- ----- */
.subBoxNew.management .c-accordion__content{
	padding-left: 1em;
	padding-bottom: .5em;
}


.img-esg{
	vertical-align: top;
	border: 1px solid #000;
}
.title-esg{
	display: flex;
	justify-content: space-between;
	align-items: end;
	flex-wrap: wrap;
}
.title-esg .title{
	display: inline-block;
}
.title-esg .checkmark{
	display: inline-block;
	font-size: 9px;
	font-weight: normal;
}
.title-esg .checkmark .ico{
	height: 1em;
	vertical-align: text-bottom;
}





/* social > localcommunitie
----- ----- ----- ----- ----- ----- ----- ----- ----- */
.section.localcommunitie{}
.section.localcommunitie{}
.section.localcommunitie .buttonLinkBox001{
	width: 100%;
	text-align: right;
}
.section.localcommunitie .buttonLink{
	display: inline-block;
}
.section.localcommunitie .buttonWide120{
	width: auto;
}
.section.localcommunitie .buttonWide120 a{
	width: auto;
}

.valuecreationList{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}
.valuecreationList *{
	-webkit-box-sizing: border-box; -moz-box-sizing: border-box; -o-box-sizing: border-box; -ms-box-sizing: border-box; box-sizing: border-box;
}
.valuecreationList li{
	width: 49%;
	border: 2px solid #ddd;
	padding: 3px;
	margin-bottom: 10px;
}
.valuecreationList li dt{
	padding: 6px 6px;
	border-bottom: 2px solid #ddd;
	font-weight: bold;
	margin-bottom: 0 !important;
}
.valuecreationList li dd{
	padding: 6px 6px;
	text-align: center;
}
@media only screen and (max-width: 600px) {
	.valuecreationList li{
		width: 100%;
	}
}

/* stakeholder > report.html
----- ----- ----- ----- ----- ----- ----- ----- ----- */
.report-bk-list{
	display: flex;
	justify-content: space-between;
	align-items: stretch;
	flex-wrap: wrap;
}
.report-bk-list li{
	width: 15%;
	text-align: center;
	margin-bottom: 10px;
}
.report-bk-list img{
	margin-bottom: .5em;
}
.report-bk-list figcaption{
	font-size: .85em;
}


/* environment > tcfd
----- ----- ----- ----- ----- ----- ----- ----- ----- */
.tcfd-bnrs{
	display: flex;
	justify-content: space-between;
}
.tcfd-bnrs li{
	width: 49%;
}
.tcfd-bnrs a{
	display: flex;
	justify-content: space-between;
	align-items: center;
	padding: 0px 0px 0px 24px;
	border: 2px solid #ddd;
	position: relative;
	background: #eee;
	font-weight: bold;
	font-size: 111%;
}
.tcfd-bnrs a:before{
	content: "";
	display: block;
	width: 0;
	height: 0;
	border-style: solid;
	border-top: 4px solid transparent;
	border-bottom: 4px solid transparent;
	border-left: 11px solid #048ad4;
	border-right: 0;
	position: absolute;
	top: 50%;
	left: 10px;
	transform: translateY(-50%);
}
.tcfd-bnrs .txt{
	width: 65%;
}
.tcfd-bnrs figure{
	width: 35%;
}





@media only screen and (max-width: 600px) {
	.tcfd-bnrs li{
		width: 100%;
	}
}
