@charset "utf-8";
/*--------------------------------------------------------------
common wide setting
--------------------------------------------------------------*/
:root{
	--wide: 1275px;
		--wh: #fff;
	--lgray: #F2F2F2;
	--gray: #c6c6c6;
	--dgray: #727171;
	--bk: #1B1B1B;
	--green: #50AE34;
	--blue: #0077FF;
	--red: #C13360;
	--sax: #41ABC9;
	--orange: #D58B03;
	--grad-horizontal: linear-gradient(90deg,#46972E,#0077FF);
	--grad-vertical: linear-gradient(0deg,#46972E,#0077FF);
	--shadow: 4px 4px 16px 0px #0000001A;
	--col4: calc((100% / 4) - .5rem);
	--col3: calc((100% / 3) - .5rem);
	--col2: calc((100% / 2) - .5rem);
}
@media screen and (min-width: 995px) and (max-width: 1304px) {
	.Under1305 #Contents {
		padding-left: 0;
		padding-right: 0;
	}
	.OptionWideRWD .GridSet {
		max-width: inherit;
	}
	.OptionWideRWD .PageTitleStyle3 .Inner {
		padding: 0 1rem;
		width: 100%;
	}
	.OptionWideRWD .GridSet .Section .Inner {
		padding: 2rem 1rem;
		width: 100%;
	}
		.OptionWideRWD .Grid4 {
			padding: 0;
		}
		/*.OptionWideRWD .Top .PageTitleStyle3 {
			background-size: auto 100%;
		}*/
}
.PageTitleStyle3 .Inner {
	max-width: var(--wide);
	min-height: inherit;
	margin: 0 auto;
	display: flex;
}
#Contents {
	padding-bottom: 0;
}
#Contents * {
	box-sizing: border-box;
}
div#Contents,
.GridSet,
.Grid4 {
	width: 100%;
	margin: auto;
	padding: 0;
	margin: 0;
	overflow: visible;
}
div.Section {
	width: 100%;
}
div.Section.Gray {
	background: var(--gray);
}
div.Section>.Inner {
	max-width: var(--wide);
	width: 100%;
	margin: auto;
	padding: 1rem 0;
	word-break: break-word;
}
#Contents h4 {
	margin: 0;
	font-size: 1.05rem;
}
#Contents h4::before {
	content: none;
}

@media screen and (max-width: 994px) {
	.JS #Contents,
	.JS .GridSet,
	.JS .Grid4 {
		padding:0;
		margin: 0;
		width: auto;
	}
	.JS .GridSet {
		max-width: inherit;
	}
	.JS .Top .PageTitleStyle3 {
			background-size: auto 100%;
	}
	.JS .PageTitleStyle3 .Inner,
	.JS div.Section>.Inner {
		padding: 1rem;
		width: auto;
	}
}
/* top 
--------------------------------------------------------------*/
/*メガメニュー対策*/
.MMSet {
	z-index: 1;
}
.Top .PageTitleStyle3 {
	overflow: hidden;
	background: url(/-/media/sustainability/image/wide/top/bg_main.jpg) no-repeat center / 100% auto;
	display: flex;
	align-items: center;
	justify-content: center;
	min-height: 648px;
	position: relative;
	z-index: 0;
}
.Top .PageTitleStyle3 video {
	position: absolute;
	z-index: 0;
	top: 50%;
	left: 50%;
	width: 100%;
	height: 100%;
	transform: translate(-50%, -50%);
	object-fit: cover;
	object-position: center;
}
.Top .PageTitleStyle3 h1 {
	font-size: 2.2rem;
	color: var(--wh);
	font-weight: bold;
	padding: 1rem;
	background: var(--grad-horizontal);
	display: block;
	height: min-content;
	z-index: 1;
}
div#VideoControl {
	position: absolute;
	bottom: 5%;
	right: 10%;
}
#VideoControl #VideoPlay a {
	position: relative;
	display: block;
	width: 24px;
	height: 24px;
	margin: 4px;
	text-indent: -9999px;
	background-color: #fff;
	border-radius: 5px;
}

#VideoControl #VideoPlay a:after {
	content: "";
	position: absolute;
	display: block;
	width: 3px;
	height: 11px;
	top: 50%;
	left: 50%;
	margin: -5.5px 0 0 -4.5px;
	border-left: solid 3px var(--green);
	border-right: solid 3px var(--green);
}
#Contents .GridSet .Top a:link {
	color: var(--bk);
}
#Contents .GridSet .Top a:hover {
	text-decoration: none;
	color: var(--green);
}

/* SustainabilityNews */
.SustainabilityNewsCol{
	display: flex;
	column-gap: 70px;
	flex-wrap: nowrap;
}
.SustainabilityNews {
	padding: 90px 0 90px;
	box-sizing: border-box;
}
.SustainabilityNews .ttlBoxNews{width: 140px;}
.SustainabilityNews .ttlBoxNews .ttl{
	margin: 0 0 44px;
	padding: 0;
}
.SustainabilityNews .ttlBoxNews .ttl>span{
	display: block;
	padding: 0;
	background: transparent;
}

.SustainabilityNews .ttlBoxNews .ttl>span:last-child{
	font-size: 18px;
	line-height: 1.2;
	color: #000;
	margin-top: 8px;
}
.SustainabilityNews .ttlBoxNews .LinkListStyle1 a {
	background-image: url("/-/media/sustainability/image/wide/icon_link_arrow.svg");
	background-size: 14px 14px;
	transition: all .1s;
	color: var(--bk);
}
.SustainabilityNews .ttlBoxNews .LinkListStyle1 a:hover {background-position: right -3px center;}
.SustainabilityNews .SustainabilityNewsListBox {
	max-width: calc((100% - 210px));
	width: 100%;
}
.SustainabilityNews .SustainabilityNewsList {
	border-bottom: 1px solid #ccc;
	display: flex;
	align-items: center;
	gap: 2rem;
	padding: 1rem 0;
}
.SustainabilityNews .SustainabilityNewsList dt {
	word-break: keep-all;
	display: flex
;
	gap: 1rem;
	width: 12rem;
	justify-content: end;
}
.SustainabilityNews .SustainabilityNewsList dd {
	display: flex;
	align-items: center;
	gap: 1.5rem;
	flex: 1;
}
.SustainabilityNews .SustainabilityNewsList dt span {
	background: var(--green);
	color: var(--wh);
	font-size: .8rem;
	padding: .1rem .8rem;
	line-height: 1.6;
	width: 6rem;
	text-align: center;
	text-box: auto;
}
.SustainabilityNews .SustainabilityNewsList.info dt span {
	background: var(--blue);
}
.SustainabilityNews .SustainabilityNewsList.resources dt span {
	background: var(--red);
}
.SustainabilityNews .SustainabilityNewsList.environment dt span {
	background: var(--sax);
}
.SustainabilityNews .SustainabilityNewsList.community dt span {
	background: var(--orange);
}
.SustainabilityNews .SustainabilityNewsList dd a:link,
.SustainabilityNews .SustainabilityNewsList dd a:hover,
.SustainabilityNews .SustainabilityNewsList dd a:active,
.SustainabilityNews .SustainabilityNewsList dd a:focus {
	text-decoration: underline;
}
.SustainabilityNewsCol {
	display: flex;
	box-sizing: border-box;
	align-items: start;
	padding: 0 6em;
}
.SustainabilityNewsCol h2 {
	font-weight: bold;
	font-size: 1.6rem;
}
.SustainabilityNews .ttlBoxNews {
	display: flex;
	flex: 1 0 auto;
	flex-direction: column;
	gap: 3em;
	width: auto;
	align-items: start;
}

.SustainabilityLinkCol{
	display: flex;
	flex-wrap: wrap;
	column-gap: 40px;
}

.SustainabilityLinkCol .SustainabilityLinkColItem {
	padding: 20px 100px 60px;
}
.SustainabilityLinkCol .SustainabilityLinkColItem:last-child {
	padding: 60px 100px 40px;
}
.PanelLinkList {
	display: flex;
	flex-wrap: wrap;
	margin: 2rem 0;
	gap: 1rem;
	justify-content: stretch;
}
.PanelLinkList li {
	box-shadow: var(--shadow);
	width: var(--col3);
	flex: 1 1 0;
}
.PanelLinkList li img {
	width: 100%;
}
.PanelLinkList li p {
	padding: 1rem;
}
.PanelLinkList li p a:link {
	display: flex;
	font-weight: bold;
	justify-content: space-between;
}
.PanelLinkList li p a::after {
	content: "";
	display: block;
	width: 14px;
	height: 14px;
	background: url(/-/media/sustainability/image/wide/icon_link_arrow.svg);
	transition: .08s ease-in;
}
.PanelLinkList li p a:hover::after {
	transform: translateX(.15rem);
}
.MenuPanelList {
	display: flex;
	flex-wrap: wrap;
	justify-content: stretch;
	gap: 1rem;
}
.MenuPanelList li {
	background: var(--lgray);
	flex: 1 1 0;
}
.MenuPanelList dt {
	min-height: 158px;
	color: var(--wh);
	font-weight: bold;
	font-size: 1.4rem;
	display: flex;
	align-items: center;
	justify-content: center;
}
.MenuPanelList li:nth-of-type(1) dt {
	background: url(/-/media/sustainability/image/wide/top/img_menu_sustainability.png) no-repeat center;
}
.MenuPanelList li:nth-of-type(2) dt {
	background: url(/-/media/sustainability/image/wide/top/img_menu_society.png) no-repeat center;
}
.MenuPanelList li:nth-of-type(3) dt {
	background: url(/-/media/sustainability/image/wide/top/img_menu_environment.png) no-repeat center;
}
.MenuPanelList dd {
	padding: 2rem 1.5rem;
}
.MenuPanelList dd li {
	width: inherit;
}
.MenuPanelList dd li a:link {
	background: none;
	font-size: 1rem;
	display: flex;
	gap: .5rem;
	padding: 0;
	line-height: 1.6;
	align-items: center;
}
.MenuPanelList dd li a::after {
	content: "";
	width: 14px;
	height: 14px;
	display: block;
	background: url(/-/media/sustainability/image/wide/icon_link_arrow.svg) no-repeat center;
	transition: .08s ease-in;
}
.MenuPanelList dd li a:hover::after {
	transform: translateX(.15rem);
}
.PickUp .Inner {
	background: var(--lgray);
	padding: 1rem;
}
.PickUp h2 {
	font-weight: bold;
	font-size: 1.8rem;
	text-align: center;
}

.slideArea {
	position: relative;
	margin: 0 2rem;
	overflow-x: hidden;
}
.PickUp #slider {
	opacity: 0;
	width: 90%;
	margin: 1rem auto;
	overflow: hidden;
}
.PickUp .slick-track {
	gap: 1rem;
	display: flex;
	padding: 1rem 0;
}
.PickUp .slideChild.slick-slide {
	display: flex;
	align-items: center;
	background: var(--wh);
	box-shadow: var(--shadow);
}
.PickUp .slideChild.slick-slide p {
	padding: 1rem;
	flex: 1;
}
.PickUp .slideChild a:link {
	display: flex;
	justify-content: center;
	align-items: center;
}
.PickUp .slideChild a::after {
		content: "";
	width: 14px;
	height: 14px;
	display: block;
	background: url(/-/media/sustainability/image/wide/icon_link_arrow.svg) no-repeat center;
	transition: .08s ease-in;
}
.PickUp .slideChild a:hover::after {
	transform: translateX(.15rem);
}
.PickUp .slick-dots {
	justify-content: center;
}
.slideNav {
	margin: 0 0 1rem;
}
#Contents .slick-prev,
#Contents .slick-next {
	position: absolute;
	top: 50%;
	border: none;
	border-radius: 0;
	background-color: transparent!important;
}
.slick-prev,
.slick-prev:hover {
	left: 0;
	background: transparent url(/-/media/image/renew/top_image02/slider_prev.png) no-repeat center;
}
.slick-next,
.slick-next:hover {
	right: 0;
	background: transparent url(/-/media/image/renew/top_image02/slider_next.png) no-repeat center;
}
.SubMenuLink {
	display: flex;
	align-items: center;
	justify-content: stretch;
	gap: 1rem;
	flex-wrap: wrap;
	margin: 2rem 0;
}
.SubMenuLink li {
	width: var(--col3);
	flex: 1 1 auto;
	border: 1px solid var(--gray);
	display: flex;
	padding: .5rem;
	gap: 1rem;
	align-items: center;
}
.SubMenuLink li a:link {
	display: flex;
	align-items: center;
	gap: .5rem;
}
.SubMenuLink li a::after {
		content: "";
	width: 14px;
	height: 14px;
	display: block;
	background: url(/-/media/sustainability/image/wide/icon_link_arrow.svg) no-repeat center;
	transition: .08s ease-in;
}
.SubMenuLink li a:hover::after {
	transform: translateX(.15rem);
}
@media screen and (max-width: 995px) {
	.JS .SustainabilityNewsCol {
		padding: 0 1em;
	}
	.JS .SustainabilityNews .SustainabilityNewsListBox {
		max-width: inherit;
	}
		.JS .SustainabilityNews .SustainabilityNewsList {
		flex-direction: column;
		justify-content: flex-start;
		align-items: flex-start;
		gap: .5rem;
	}
	.JS .SustainabilityNews .SustainabilityNewsList dt {
		min-width: 3rem;
		gap: 1rem;
	}
	.SustainabilityNews .SustainabilityNewsList dd {
		margin-top: 0;
		padding: 0;
	}
	.JS .PanelLinkList li,
	.JS .MenuPanelList li,
	.JS .SubMenuLink li {
		width: var(--col2);
		flex: 0 auto;
	}
	.JS .slideChild {
		flex-direction: column;
	}
	.JS .slideChild img {
		width: 100%;
	}
}

@media screen and (max-width: 996px){
	.JS .GridSet {margin: 0 0 0 0}	
}
@media screen and (max-width: 767px){
	.JS .GridSet {margin: 0 0 0 0}	
	/* top 
	--------------------------------------------------------------*/
	.JS .Top .PageTitleStyle3 {
		min-height: 379px;
		background-size: auto 100%;
	}
	.JS .Top .PageTitleStyle3 {
		overflow: hidden;
		background-image: url(/-/media/sustainability/image/top/pageTitleImgb.jpg);
	}
	.JS .Top .PageTitleStyle3 video,
		#VideoControlBox {
			display: none;
	}
	.JS .Top .PageTitleStyle3 h1 {
		font-size: 1.8rem;
	}
	/* SustainabilityNews */
	.JS .SustainabilityNewsCol {display: block;}	
	.JS .SustainabilityNews{
		width: 100%;
		padding: 0;
	}
	.JS .SustainabilityNews .ttlBoxNews {
		display: flex;
		justify-content: space-between;
		width: 100%;
	}
	.JS .SustainabilityNews .ttlBoxNews {
		gap: 1rem;
	}
	.SustainabilityNews .SustainabilityNewsListBox{max-width: 100%;}
	.SustainabilityNews .ttlBoxNews .ttl{margin-bottom: 0px;}

}
@media screen and (max-width: 579px){
	.JS .PanelLinkList li,
	.JS .MenuPanelList li,
	.JS .SubMenuLink li {
		width: 100%;
		flex: 0 auto;
	}
	.JS .MenuPanelList li dt {
		background-size: 100% auto;
		background-position: top center;
	}
		.JS .Top .PageTitleStyle3 {
		min-height: 220px;
		background-size: 100% auto;
	}
	.JS .Top .PageTitleStyle3 h1 {
		padding: .8rem;
	}
}
@media screen and (min-width: 995px) and (max-width: 1304px) {
	.OptionWideRWD #Contents {
		padding: 0 0 65px;
	}
	.OptionWideRWD .GridSet {
        margin: 0 1em;
    }
}