@charset "UTF-8";

/*--------------------------------------------------------------
                              INDEX
---------------------------------------------------------------*/

/*---------------------------------------------- VISUAL */

#index .visual {
	position: relative;
}

#index .visual img {
	width: 100%;
	max-width: auto;
}

#index .main-phrase {
	width: 52.5%;
    position: absolute;
    top: 50%;
    left: 50.7%;
    transform: translate(-50%,-50%);
}

#index .main-phrase .line {
	display: flex;
	justify-content: center;
	line-height: 0;
	padding: 4% 0;
}

#index .main-phrase .line img {
	width: 13%;
    height: 13%;
    padding: 0 1.5%;
}


/*---------------------------------------------- INFORMATION */

#index .info-list  + .linkBtn {
	margin-top: 40px;
}

#index .info-list li:not(:last-child) {
	margin-bottom: 24px;
}

#index .info-list li dl {
}

#index .info-list li .date {
	font-size: 1.2rem;
	line-height: 1;
	color: #9d9d9d;
	margin-bottom: 8px;
}

#index .info-list li dd {
	padding-left: 25px;
	position: relative;
}

#index .info-list li dd.link-pdf:before {
	content: "";
	display: block;
	width: 15px;
	height: 18px;
	background: url(../images/common/pdf-icon.svg) center center / 15px 18px no-repeat;
	position: absolute;
	top: 0;
	left: 0;
}

#index .info-list li dd a {
	margin-right: .5rem;
	transition: all 50ms ease;
}

#index .info-list li dd a:hover {
	color: #009944;
	text-decoration: underline;
}

#index .info-list li .capa {
	display: inline-block;
    vertical-align: middle;
    font-size: 1rem;
    padding: 1px 4px;
    border: 1px solid #D7DCDC;
    border-radius: 4px;
}

#index .information .left .section {
	padding-bottom: 90px;
    border-bottom: 10px solid #f5f6f6;
}


/*---------------------------------------------- CSR REPORTS */

#index .csrBook {
	background: #009944;
	padding: 50px 10% 60px;
	position: relative;
	z-index: 15;
}

#index .csrBookImg {
	width: 40%;
    margin: 0 auto;
    position: relative;
    z-index: 1;
    transform: rotate(10deg);
    box-shadow: 3px 3px 9px rgba(0,0,0,.4);
}

#index .csrBookTxt {
	margin: 24px auto 0;
}

#index .csrBookHead {
	color: #fff;
	font-size: 1.7rem;
	text-align: center;
	line-height: 1.75;
}

#index .csrBook .linkBtn {
	margin: 30px auto 0;
}

#index .csrBook .linkBtnTxt {
	line-height: 1.25;
	border: 1px solid #fff;
	color: #009944;
	background: #fff;
	padding: 16px 20px;
	border-radius: 60px;
	transition: all 300ms ease;
}

#index .csrBook .linkBtnTxt span {
	display: block;
	font-size: 1rem;
	padding: 0;
}

#index .csrBook .linkBtnTxt.hover {
	color: #fff;
	background: #009944;
}


/*---------------------------------------------- TWO COLUMN */

#index .bnr {
	padding-left: 5%;
	padding-right: 5%;
}

#index .bnr .bnrInner {
	margin-bottom: 5vw;
}

#index .bnr a {
	display: block;
    width: 100%;
	line-height: 0;
    border-radius: 20px;
    overflow: hidden;
    position: relative;
    z-index: 1;
}

#index .bnr a img {
	transition: all 300ms ease;
    -webkit-backface-visibility: hidden;
    backface-visibility: hidden;
}

#index .bnr a.hover img {
	transform: scale(1.05);
}



/*--------------------------------------------------------------
                              ACTION
---------------------------------------------------------------*/

/*---------------------------------------------- YEAR LIST */

#action .year-list {
	padding-top: 60px; 
	overflow: scroll;
    overflow-scrolling: touch;
    -webkit-overflow-scrolling: touch;
	-ms-overflow-style: -ms-autohiding-scrollbar;
}

#action .year-list-inner {
	display: flex;
	justify-content: flex-start;
	padding: 0 5%;
}

#action .year-list-inner li {
	padding-right: 5%;
}

#action .year-list-inner .current .linkBtnTxt {
	background: #009944;
	cursor: default;
}

#action .year-list-inner .current .linkBtnTxt span {
	color: #fff;
}


/*---------------------------------------------- INFORMATION */

#action .year-list + section {
	padding-top: 40px;
}

#action .info-list  + .linkBtn {
	margin-top: 40px;
}

#action .info-list li:not(:last-child) {
	margin-bottom: 24px;
}

#action .info-list li dl {
}

#action .info-list li .date {
	font-size: 1.2rem;
	line-height: 1;
	color: #9d9d9d;
	margin-bottom: 8px;
}

#action .info-list li dd {
	padding-left: 25px;
	position: relative;
}

#action .info-list li dd.link-pdf:before {
	content: "";
	display: block;
	width: 15px;
	height: 18px;
	background: url(../images/common/pdf-icon.svg) center center / 15px 18px no-repeat;
	position: absolute;
	top: 0;
	left: 0;
}

#action .info-list li dd a {
	margin-right: .5rem;
	transition: all 50ms ease;
}

#action .info-list li dd a:hover {
	color: #009944;
	text-decoration: underline;
}

#action .info-list li .capa {
	display: inline-block;
    vertical-align: middle;
    font-size: 1rem;
    padding: 1px 4px;
    border: 1px solid #D7DCDC;
    border-radius: 4px;
}

#action .global-wariming .info-list {
	margin-top: 30px;
}


/*--------------------------------------------------------------
                              PAGES
---------------------------------------------------------------*/

/*---------------------------------------------- PAGE CONCEPT */

#pages .concept {
	padding-top: 80px;
	position: relative;
	margin-bottom: 30px;
}

#pages .concept .site-icon {
	width: 100px;
	height: 100px;
	border-radius: 50%;
	position: absolute;
	top: -50px;
	left: 0;
	right: 0;
	margin: auto;
	box-shadow: 0 0 25px rgba(0,0,0,.15);
}

#pages .concept .site-description {
	font-size: 1.7rem;
}

#pages .concept .sdgs {
	margin-top: 40px;
	position: relative;
}

#pages .concept .sdgs img {
	display: block;
	width: 100%;
	margin: 0;
}

#pages .concept .sdgsInner {
	background: #fff;
	border-radius: 24px;
	border: 1px solid;
	padding: 8%;
	position: relative;
	z-index: 1;
}

#pages .concept .sdgs-head {
	font-size: 1.3rem;
	line-height: 1.75;
	color: #808080;
}

#pages .concept .sdgs-list {
	display: flex;
	flex-wrap: wrap;
	margin-top: 6%;
}

#pages .concept .sdgs-list-head {
	width: 100%;
}

#pages .concept .sdgs-list-inner {
	width: 30%;
	border-radius: 8px;
	overflow: hidden;
	position: relative;
	z-index: 1;
	margin-top: 5%;
	margin-right: 5%;
}

#pages .concept .sdgs-list-inner:nth-of-type(3n) {
	margin-right: 0;
}

#pages .concept .sdgs-link {
	text-align: right;
    margin-top: 8px;
}

#pages .concept .sdgs-link a {
	font-size: 1.2rem;
    color: #9d9d9d;
}

#pages .concept .sdgs-link a.hover {
	text-decoration: underline;
}

#pages .concept .sdgs-link svg {
	display: inline-block;
    width: 12px;
    height: 12px;
    fill: #9d9d9d;
    margin-right: 4px;
}

#pages .concept .sdgs-list-all {
	margin-top: 6%;
}


/*COLORs of EACH PAGE*/

#pages .safety .concept { background: linear-gradient(#FEEFF5,#fff); }
#pages .safety .concept .sdgsInner { border-color: #f55a96; }

#pages .health .concept { background: linear-gradient(#FFEEDB,#fff); }
#pages .health .concept .sdgsInner { border-color: #f08200; }

#pages .local .concept { background: linear-gradient(#E4EFFB,#fff); }
#pages .local .concept .sdgsInner { border-color: #46a0ff; }

#pages .employee .concept { background: linear-gradient(#FFF0F1,#fff); }
#pages .employee .concept .sdgsInner { border-color: #e60012; }

#pages .environment .concept { background: linear-gradient(#EBFFFE,#fff); }
#pages .environment .concept .sdgsInner { border-color: #1AB1AD; }

#pages .donation .concept { background: linear-gradient(#FFF8E4,#fff); }
#pages .donation .concept .sdgsInner { border-color: #DCA80C; }


/*---------------------------------------------- CONTENTS */

#pages .section-img {
	margin-bottom: 30px;
}

#pages .section-img figure {
	width: 100%;
	margin: 0 auto;
}

#pages .section-img figure span {
	display: block;
	width: 100%;
	border-radius: 20px;
	overflow: hidden;
	position: relative;
	z-index: 1;
}

#pages .section-img figure span.border {
	border: 1px solid #d7dcdc;
	padding: 20px;
}

#pages .section-img figure img {
	display: block;
	width: 100%;
}

#pages .section-img figcaption {
	font-size: 1rem;
	font-style: italic;
	margin-top: 12px;
}

#pages .section-sub-head {
	font-size: 1.7rem;
	margin-bottom: 12px;
	padding-left: 2rem;
	position: relative;
}

#pages .letter-body + .section-sub-head {
	margin-top: 20px;
}

#pages .section-sub-head:before {
	content: "■";
	display: block;
	font-size: inherit;
	line-height: inherit;
	color: inherit;
	position: absolute;
	top: 0;
	left: 0;
}

#pages .letter-attention {
	margin-top: 20px;
}

#pages .letter-attention li {
	font-size: 1.2rem;
	padding-left: 1.2rem;
	position: relative;
}

#pages .letter-attention li:before {
	content: "＊";
	display: block;
	font-size: inherit;
	line-height: inherit;
	color: inherit;
	position: absolute;
	top: 0;
	left: 0;
}

#pages .letter-attention li a {
	text-decoration: underline;
}

#pages .letter-attention li a:hover {
	text-decoration: none;
}

#pages .letter-attention li.non-asterisk {
	padding-left: 0;
}

#pages .letter-attention li.non-asterisk:before {
	content: none;
}

#pages .section-txt-list {
}

#pages .section-txt-list li {
	margin-top: 10px;
	position: relative;
	padding-left: 1.75rem;
}

#pages .section-txt-list li:before {
	content: "●";
	display: block;
	position: absolute;
	top: 0;
	left: 0;
	font-size: inherit;
	line-height: inherit;
	color: inherit;
}

#pages .section-txt-list.numbering {
	padding-left: 22px;
}

#pages .section-txt-list.numbering li {
	list-style: decimal;
	padding-left: 0;
}

#pages .section-txt-list.numbering li:before {
	content: none;
}

#pages .section-txt figure {
	margin: 20px 5% 0;
}


/*IMPLEMENT*/

#pages .implement {
	background: #f5f6f6;
    border-radius: 24px;
    border: 1px solid #d7dcdc;
    padding: 8%;
	margin-top: 30px;
}

#pages .implementList {
	font-size: 1.3rem;
	margin-top: 20px;
}

#pages .implementList dt,
#pages .implementList dd {
	padding-left: 1.5rem;
	position: relative;
}

#pages .implementList dt:before {
	content: "●";
	font-size: inherit;
	line-height: inherit; 
	color: inherit;
	position: absolute;
	top: 0;
	left: 0;
}

#pages .implementList dl:not(:last-child) {
	margin-bottom: 10px;
}

/*ISO TABLE*/

table.iso-table {
	width: 100%;
	font-size: 1.3rem;
	border-collapse:collapse;
	margin: 20px auto 0;
}

table.iso-table td {
	border: 1px solid #d7dcdc;
	padding: 10px 7.5px;
}

table.iso-table td:first-child {
	width: 110px;
}

table.iso-table td:last-child {
	width: calc(100% - 110px);
}


/*---------------------------------------------- OTHER */

.other .firstSection {
	padding-top: 80px;
}

.other .firstSection .site-icon {
	width: 100px;
    height: 100px;
    border-radius: 50%;
    position: absolute;
    top: -50px;
    left: 0;
    right: 0;
    margin: auto;
    box-shadow: 0 0 25px rgba(0,0,0,.15);
}

.other .firstSection h2 {
	font-size: 1.7rem;
	line-height: 2;
	margin-bottom: 30px;
}

.other .firstSection h2 br {
	display: none;
}

.other .firstSection p {
	text-align: justify;
	text-indent: 1.5rem;
}

.other .firstSection p + p {
	margin-top: 3rem;
}

.other .portrait {
	padding: 0;
	margin-bottom: -30px;
	position: relative;
}

.other .portrait figure {
	width: 100%;
	margin: 0 auto;
}

.other .portrait figure img {
	width: 100%;
}

.other .portrait figcaption.signature {
	padding: 0;
    font-size: 4vw;
    line-height: 1.5;
    text-align: right;
    position: absolute;
    left: 9%;
    top: 21%;
    transform: scale(.5);
    transform-origin: left center;
    opacity: .85;
}

.other .portrait figcaption.signature span {
	font-size: 85%;
}

.other .signature {
	padding-top: 60px;
}

.other .signature p {
	font-size: 1.7rem;
	line-height: 1.5;
	text-align: right;
}

.other .signature span {
	display: block;
    font-size: 1.2rem;
    padding-bottom: 5px;
}


/*POLICY*/

.policy .guidelines {
	width: 100%;
	padding: 0 8%;
	position: relative;
}

.policy .guidelines figure {
	width: 100%;
	position: relative;
	overflow: hidden;
	margin: 0 auto;
}

.policy .guidelines figure img {
	width: 100%;
}

.policy .guidelines figure img.middle,
.policy .guidelines figure img.bottom {
	position: absolute;
	top: 0;
	left: 0;
}

.policy .guidelines figure img.top {
	opacity: 0;
    transform: translate(0,30px);
    transition: all 600ms ease 600ms;
}

.policy .guidelines figure img.middle {
	opacity: 0;
    transform: translate(0,30px);
    transition: all 600ms ease 300ms;
}

.policy .guidelines figure img.bottom {
	opacity: 0;
    transform: translate(0,30px);
    transition: all 600ms ease;
}

.policy .guidelines figure.in img.top,
.policy .guidelines figure.in img.middle,
.policy .guidelines figure.in img.bottom {
	opacity: 1;
    transform: translate(0,0);
}

.policy .policy-list li {
	font-size: 1.7rem;
    margin-bottom: 30px;
}

.policy .policy-list li:last-child {
	margin-bottom: 0;
}

.policy .sdgs-table {
	position: relative;
	margin-top: 30px;
}

.policy .sdgs-table .tableInner {
	width: 100vw;
    overflow: scroll;
    overflow-scrolling: touch;
    -webkit-overflow-scrolling: touch;
    -ms-overflow-style: -ms-autohiding-scrollbar;
	margin-left: -5vw;
	background: #f5f6f6;
}

.policy table {
	display: block;
	width: calc(980px + 10%);
	border-collapse: collapse;
	padding: 7.5% 5%;
	background: #f5f6f6;
}

.policy table tbody,
.policy table thead {
	display: block;
	width: 100%;
}

.policy table tr {
	display: flex;
	width: 100%;
}

.policy table .num { width: 40px; }
.policy table .problem { width: 220px; }
.policy table .action { width: 420px; }
.policy table .goal { width: 300px; }

.policy table th {
	display: inline-flex;
    align-items: center;
}

.policy table th span {
	display: block;
	width: calc(100% - 40px);
	height: 40px;
	line-height: 40px;
	color: #9d9d9d;
	background: #fff;
	border-radius: 20px;
	margin: 0 auto;
}

.policy table th.goal span {
	width: calc(100% - 20px);
	margin-left: 20px;
}

.policy table tbody tr:last-child {
	margin-bottom: 0;
}

.policy table td {
	display: inline-flex;
	align-items: center;
	padding-top: 20px;
	padding-bottom: 20px;
}

.policy table td:not(.num) {
	padding-left: 20px;
	padding-right: 20px;
}

.policy table td.num {
	padding: 0;
}

.policy table td.num span {
	display: block;
	width: 40px;
	height: 40px;
	line-height: 40px;
	text-align: center;
	color: #fff;
	background: #46b400;
	border-radius: 50%;
}

.policy table td.problem {
	line-height: 1.75;
	color: #46B400;
	border-right: 1px solid #d7dcdc;
	border-bottom: 1px solid #d7dcdc;
}

.policy table td.action {
	border-right: 1px solid #d7dcdc;
	border-bottom: 1px solid #d7dcdc;
}

.policy table td.action ul li {
	font-size: 1.3rem;
    position: relative;
    padding-left: 1.5rem;
	margin-top: 5px;
}

.policy table td.action ul li:first-child {
	margin-top: 0;
}

.policy table td.action ul li:before {
	content: "●";
    display: block;
    position: absolute;
    top: 0;
    left: 0;
    font-size: inherit;
    line-height: inherit;
    color: inherit;
}

.policy table td.goal {
	flex-wrap: wrap;
	padding-right: 0;
	border-bottom: 1px solid #d7dcdc;
}

.policy table td.goal ol {
	display: flex;
	flex-wrap: wrap;
	width: 100%;
}

.policy table td.goal ol li {
	width: 18%;
	height: auto;
	line-height: 0;
	margin-right: 2.5%;
}

.policy table td.goal ol li:last-child,
.policy table td.goal ol li:nth-child(5) {
	margin-right: 0;
}

.policy table td.goal ol li:nth-child(6),
.policy table td.goal ol li:nth-child(7),
.policy table td.goal ol li:nth-child(8),
.policy table td.goal ol li:nth-child(9),
.policy table td.goal ol li:nth-child(10) {
	margin-top: 2.5%;
}

.policy table td.goal ol li img {
	border-radius: 4px;
	position: relative;
	overflow: hidden;
	z-index: 1;
}

.policy table td.goal p {
    display: block;
    width: 100%;
    font-size: 1.3rem;
	font-weight:700;
    line-height: 1.5;
    margin-bottom: 8px;
}

.policy table tr:last-child td.problem,
.policy table tr:last-child td.action,
.policy table tr:last-child td.goal {
	border-bottom: none;
}

.policy .sdgs-table .how-to-scroll {
	display: flex;
    align-items: center;
    justify-content: center;
    min-width: 170px;
    font-size: 1rem;
    line-height: 24px;
    color: #9d9d9d;
    padding: 0 16px;
    border-radius: 12px;
    z-index: 5;
	margin: 0 auto 12px;
}

.policy .sdgs-table .how-to-scroll svg {
	display: block;
	fill: #9d9d9d;
	width: 5px;
	height: 10px;
	vertical-align: middle;
}

.policy .sdgs-table .how-to-scroll svg:first-child {
	transform: rotate(180deg);
}

.policy .sdgs-table .how-to-scroll span {
	padding: 0 7.5px;
}

.policy .sdgs-table + .linkBtn {
    margin-top: 40px;
}


/*GREEN CHALLENGE TABLE*/

.policy .green-challenge-table tbody, .policy .green-challenge-table thead {
	display: table-header-group;
}

.policy .green-challenge-table th {
	display: table-cell;
}

.policy .green-challenge-table tr {
	display: table-row;
}

.policy .green-challenge-table td {
	display: table-cell;
}

.policy .green-challenge-table .theme {
	width: 250px;
	line-height: 1.75;
    color: #46B400;
}

.policy .green-challenge-table .ideal2030,
.policy .green-challenge-table .ideal2050 {
	width: 365px;
}

.policy .green-challenge-table td.ideal2030,
.policy .green-challenge-table td.ideal2050,
.policy .green-challenge-table .ideal-colspan {
	font-size: 1.3rem;
	line-height: 1.5;
}

.policy .green-challenge-table tr:not(:last-child) td {
	border-bottom: 1px solid #d7dcdc;
}

.policy .green-challenge-table td.theme {
	border-right: 1px solid #d7dcdc;
}

.policy .green-challenge-table td.ideal2030 {
	border-right: 1px solid #d7dcdc;
}

.policy .letter-body + .letter-body {
	margin-top: 30px;
}

/*---------------------------------------------- リンクバナー */

.section .bnrBox {
    margin-top: 40px;
}

.section .linkBnr {
	width: 50%;
	margin: 20px auto 0;
}

.section .linkBnr.movie {
	width: 70%;
}

.section .linkBnr .radius {
	border-radius: 20px;
}

/*---------------------------------------------- MODAL */

.modal-open {
	cursor: pointer;
}

.modal-contents {
	display: none;
	position: fixed;
	width: 80%;
	max-width: 590px;
    border-radius: 6px;
	background: #fff;
    margin: auto;
    z-index: 1002;
}

.modal-contents .modal-close {
	width: 40px;
    height: 40px;
    background: #009944;
    position: absolute;
    top: -15px;
    left: -15px;
    border-radius: 50%;
	cursor: pointer;
	/*animation: 1s mc-bounds-in ease;
	-ms-animation: 1s mc-bounds-in ease;
	-webkit-animation: 1s mc-bounds-in ease;*/
}

@keyframes mc-bounds-in {
	from { transform: scale(0); -ms-transform: scale(0); -webkit-transform: scale(0);}
	40% { transform: scale(1.2); -ms-transform: scale(1.2); -webkit-transform: scale(1.2);}
	65% { transform: scale(.8); -ms-transform: scale(.8); -webkit-transform: scale(.8);}
	75% { transform: scale(1.1); -ms-transform: scale(1.1); -webkit-transform: scale(1.1);}
	82% { transform: scale(.98); -ms-transform: scale(.98); -webkit-transform: scale(.98);}
	95% { transform: scale(1.05); -ms-transform: scale(1.05); -webkit-transform: scale(1.05);}
	to { transform: scale(1); -ms-transform: scale(1); -webkit-transform: scale(1);}
}

.modal-contents .modal-close:before,
.modal-contents .modal-close:after {
	content: "";
	display: block;
    width: 22px;
    height: 2px;
    background: #FFF;
    position: absolute;
	top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    margin: auto;
}

.modal-contents .modal-close:before {
	transform: rotate(45deg);
    -ms-transform: rotate(45deg);
    -webkit-transform: rotate(45deg);
}

.modal-contents .modal-close:after {
	transform: rotate(135deg);
    -ms-transform: rotate(135deg);
    -webkit-transform: rotate(135deg);
}

.modalOverlay {
	display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    opacity: .75;
    background: #000904;
    z-index: 1001;
    cursor: pointer;
}

.modal-inner {
	width: 100%;
	height: auto;
	padding: 10px;
}

.modal-inner * {
	box-sizing: border-box;
}

.modal-inner .modal-wrap {
	width: 100%;
	max-height: 80vh;
	padding: 12px;
	overflow: hidden;
	position: relative;
}

.modal-inner .modal-wrap .mw-title {
	font-size: 18px;
    line-height: 1.4;
    font-weight: bold;
	text-align: left;
    color: #444;
    padding-bottom: 5px;
    border-bottom: 1px solid #d6d6d6;
    margin: 0 auto 20px;
}

.modal-inner .modal-wrap .mw-attention {
	font-size: 12px;
	line-height: 1.4;
	text-align: left;
	margin: -10px auto 18px;
}

.modal-inner .modal-wrap dl + .mw-attention {
	text-align: left;
    padding: 20px 0 6px;
    border-bottom: 1px solid #d6d6d6;
}

.modal-inner .modal-wrap dl {
	display: table;
	width: 100%;
	height: auto;
	padding: 0;
	margin: 0 auto 16px;
}

.modal-inner .modal-wrap dl:nth-last-of-type(1) {
	margin: 0;
}

.modal-inner .modal-wrap dl dt {
	display: table-cell;
	vertical-align: top;
	width: 10%;
    min-width: 80px;
	font-size: 14px;
	font-weight: bold;
	line-height: 1.6;
	text-align: left;
	color: #444;
}

.modal-inner .modal-wrap dl dd {
	display: table-cell;
	vertical-align: top;
	font-size: 14px;
	line-height: 1.6;
	text-align: left;
	color: #666;
}

.modal-inner ul {
	margin: 0;
}

.modal-inner ul li {
	font-size: 14px;
    padding-left: 14px;
	line-height: 1.6;
	position: relative;
	margin-top: 5px;
}

.modal-inner ul li:first-child {
	margin: 0;
}

.modal-inner ul li:before {
	content: "※";
    font-size: inherit;
    line-height: inherit;
    text-align: left;
    color: inherit;
    position: absolute;
    top: 0;
    left: 0;
}

.ps-container {
  -ms-touch-action: none;
  touch-action: none;
  overflow: hidden !important;
  -ms-overflow-style: none;
}
@supports (-ms-overflow-style: none) {
  .ps-container {
    overflow: auto !important;
  }
}
@media screen and (-ms-high-contrast: active), (-ms-high-contrast: none) {
  .ps-container {
    overflow: auto !important;
  }
}

.modal-inner .ps-scrollbar-x-rail {
	display: none;
}

.modal-inner .ps-scrollbar-y-rail {
	display: block;
	position: absolute;
	background: #fff;
	right: 0;
	width: 8px;
}

.modal-inner .ps-scrollbar-y {
	position: absolute;
	background: #d6d6d6;
	right: 0;
	width: 8px; 
	border-radius: 4px;
}

.ps-container > .ps-scrollbar-y-rail > .ps-scrollbar-y {
    transition: height .2s linear;
	-ms-transition: height .2s linear;
	-webkit-transition: height .2s linear;
}

/*HOVER*/

.section-img .modal-open {
	transition: all 300ms ease;
}

.section-img .modal-open:hover {
	opacity: .5;
}

.section-img .modal-open img {
	transition: all 300ms ease;
}

.section-img .modal-open img:hover {
	transform: scale(1.1);
}

/*3つ並び*/

#pages .section-img .expansionBox {
	display: flex;
	justify-content: space-between;
}

#pages .section-img .expansionBox figure {
	width: calc(88% / 3);
}


/*--------------------------------------------------------------
                              SITEMAP
---------------------------------------------------------------*/

.sitemapInner {
	padding-top: 60px;
}

.sitemapList:not(:last-child) {
	margin-bottom: 12.5%;
}

.sitemapList h2 {
	width: 100%;
	color: #9d9d9d;
	font-size: 1.2rem;
	padding: 10px 5%;
	background: #f5f6f6;
	margin-bottom: 7.5%;
}

.sitemapListInner {
}

.sitemapListInner li {
	width: 90%;
	margin: 0 auto 5%;
}

.sitemapListInner li:last-child {
	margin-bottom: 0;
}

.sitemapListInner li.lv1 {
	font-size: 2rem;
}

.sitemapListInner li.lv2 {
	padding-left: 20px;
}

.sitemapListInner li a {
	display: inline-block;
	font-weight: 700;
    line-height: 1;
    color: #009944;
    background: none;
    padding: 0 0 0 16px;
	position: relative;
}

.sitemapListInner li svg {
	display: inline-block;
    width: 6px;
    height: 12px;
    fill: #009944;
	position: absolute;
	top: 0;
	left: 0;
	bottom: 0;
	margin: auto;
    transition: all 300ms ease;
}

.sitemapListInner li .hover svg {
	transform: translate(3px,0);
}

.sitemapListInner li span {
	display: inline-block;
	line-height: 1.5;
}

.sitemapListInner li .hover span {
	text-decoration: underline;
}


/*------------------------------------------------------------------------------------
                                    以下 TAB 用
------------------------------------------------------------------------------------*/

@media print, screen and (min-width: 481px) {
	
/*--------------------------------------------------------------
                              INDEX
---------------------------------------------------------------*/

#index #header-nav { display: none; }


/*---------------------------------------------- VISUAL */

#index .main-phrase {
    width: 43%;
}


/*---------------------------------------------- INFORMATION */

#index .info-list + .linkBtn {
    margin-top: 50px;
}


/*---------------------------------------------- CSR REPORTS */

#index .csrBook {
	padding: 60px 15%;
}

#index .csrBookImg {
	width: 25%;
	margin: 0;
}

#index .csrBookTxt {
	width: 75%;
	padding-left: 45px;
	margin: 0;
}

#index .csrBookHead {
	text-align: left;
}

#index .csrBookInner {
	display: flex;
	align-items: center;
	justify-content: center;
}

#index .csrBook .linkBtn {
    margin: 20px auto 0;
    text-align: left;
}
	
/*---------------------------------------------- TWO COLUMN */

#index .bnr {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 7.5%;
	padding-right: 7.5%;
	margin-bottom: 7.5%;
}
	
#index .bnr .bnrInner {
	width: calc(95% / 2);
    margin-bottom: 0;
}
	
#index .bnr .bnrInner:only-child {
    margin-left: auto;
    margin-right: auto;
}
    
/*---------------------------------------------- THREE COLUMN */
    
/*#index .bnr {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 7.5%;
	padding-right: 7.5%;
	margin-bottom: 7.5%;
}
    
#index .bnr .bnrInner {
	width: calc(92% / 3);
}*/
    
/*---------------------------------------------- FOUR COLUMN */
/*    
#index .bnr {
	display: flex;
	align-items: center;
	justify-content: space-between;
	padding-left: 0;
	padding-right: 0;
	margin: 0 auto 7.5%;
	width: 85%;
}
    
#index .bnr .bnrInner {
	width: calc(92% / 4);
}*/


/*--------------------------------------------------------------
                              ACTION
---------------------------------------------------------------*/

/*---------------------------------------------- YEAR LIST */

#action .year-list-inner {
	padding: 0 7.5%;
}

#action .year-list-inner li {
    padding-right: 20px;
}

#action .year-list-inner li:last-child {
	padding-right: 7.5%;
}


/*--------------------------------------------------------------
                              PAGES
---------------------------------------------------------------*/

/*---------------------------------------------- PAGE CONCEPT */

#pages .concept {
	padding-top: 90px;
}

#pages .concept .sdgsInner {
	padding: 36px;
	margin: 0 auto;
}

#pages .concept .sdgs {
	margin-top: 50px;
}

#pages .concept .sdgs-list {
	justify-content: center;
	margin-top: 24px;
}

#pages .concept .sdgs-list-head {
	width: 100%;
	margin: 0 auto;
}

#pages .concept .sdgs-list-head img {
    width: 50%;
    margin: 0 auto;
}

#pages .concept .sdgs-list-inner,
#pages .concept .sdgs-list-inner:nth-of-type(3n) {
    width: 18%;
	margin-top: 24px;
	margin-right: 2.5%;
}

#pages .concept .sdgs-list-inner:nth-of-type(5n) {
	margin-right: 0;
}

#pages .concept .sdgs-list-all {
	margin-top: 24px;
}


/*---------------------------------------------- CONTENTS */

#pages .section-img figure span.border {
	padding: 30px;
}

#pages .section-txt figure {
	margin: 25px 12.5% 0;
}

/*IMPLEMENT*/

#pages .implement {
    padding: 36px;
}

/*ISO TABLE*/

table.iso-table {
	margin: 25px auto 0;
}


/*---------------------------------------------- OTHER */

.other .firstSection {
	padding-top: 90px;
}
	
.other .portrait {
    padding: 0;
}
	
.other .portrait figcaption.signature {
	left: 23%;
    top: 20%;
    transform: scale(.3);
}
	

/*POLICY*/

.policy .guidelines {
    padding: 0;
}

.policy .guidelines figure {
	width: 380px;
	margin: 0 auto;
}

.policy .policy-list li {
	margin-bottom: 15px;
}

.policy .sdgs-table .tableInner {
    margin-left: -7.5vw;
}

.policy table {
    width: calc(980px + 15%);
    padding: 5% 7.5%;
}

.policy .sdgs-table + .linkBtn {
    margin-top: 50px;
}


/*--------------------------------------------------------------
                              SITEMAP
---------------------------------------------------------------*/

.sitemapList:not(:last-child) {
    margin-bottom: 60px;
}

.sitemapList h2 {
	padding: 10px 7.5%;
	margin-bottom: 30px;
}

.sitemapListInner {
	display: flex;
	flex-wrap: wrap;
	width: 85%;
	margin: 0 auto;
}

.sitemapListInner li {
	margin-bottom: 25px;
}

.sitemapListInner li.lv1 {
	width: 100%;
	margin-bottom: 25px;
}

.sitemapListInner li.lv1:last-child {
	margin-bottom: 0;
}

.sitemapListInner li.lv2 {
	width: calc(50% - 20px);
	padding-left: 0;
}

.sitemapListInner li.lv2:nth-of-type(2n + 1) {
	margin-left: 40px;
}

.sitemapListInner li:last-child {
	margin-left: 0;
}


}



/*------------------------------------------------------------------------------------
                                    以下 PC 用
------------------------------------------------------------------------------------*/

@media print, screen and (min-width: 769px) {
	
/*--------------------------------------------------------------
                              INDEX
---------------------------------------------------------------*/

/*---------------------------------------------- VISUAL */

#index .main-phrase {
    width: 31%;
	left: 50.4%;
}


/*---------------------------------------------- INFORMATION */

#index .information {
	display: flex;
	justify-content: space-between;
	width: 85%;
	max-width: 1280px;
	margin: 0 auto;
}
	
#index .information .section:first-of-type {
    padding-top: 0;
}

#index .information .left,
#index .information .right {
	width: calc(50% - 30px);
	padding-top: 90px;
	padding-bottom: 0;
	margin: 0;
}
	
#index .information .left .section {
	padding-bottom: 0;
    border-bottom: none;
}


/*---------------------------------------------- CSR REPORTS */

#index .csrBook {
    padding: 40px 0;
}

#index .csrBookInner {
	width: 85%;
	max-width: 640px;
	margin: 0 auto;
}

#index .csrBookImg {
    width: 120px;
}

#index .csrBookTxt {
	width: calc(100% - 120px);
}
	
/*---------------------------------------------- TWO COLUMN */

/*#index .bnr {
    width: 60%;
    max-width: 800px;
    padding:  0;
    margin: 0 auto 60px;
}*/
    
/*---------------------------------------------- THREE COLUMN */
    
#index .bnr {
	width: 80%;
	max-width: 1200px;
    padding:  0;
    margin: 0 auto 60px;
}

/*---------------------------------------------- FOUR COLUMN */
    
/*#index .bnr {
	width: 80%;
	max-width: 1200px;
    padding:  0;
    margin: 0 auto 60px;
}*/


/*--------------------------------------------------------------
                              ACTION
---------------------------------------------------------------*/

/*---------------------------------------------- YEAR LIST */

#action .year-list {
	width: 120px;
    padding-top: 90px;
    overflow: visible;
}

#action .year-list-inner {
	display: block;
    padding: 0;
}

#action .year-list-inner li {
	padding: 0;
	margin-bottom: 16px;
}

#action .year-list-inner .linkBtnTxt {
	width: 120px;
}


/*---------------------------------------------- INFORMATION */

#action .year-list + section {
	width: calc(100% - 120px);
    padding-top: 90px;
	padding-left: 60px;
}

#action .information {
	display: flex;
	justify-content: space-between;
	flex-wrap: wrap;
	width: 85%;
	max-width: 1280px;
	margin: 0 auto;
}

#action .info-list li:not(:last-child) {
    margin-bottom: 30px;
}

#action .global-wariming {
	width: 100%;
	padding-left: 180px;
}


/*--------------------------------------------------------------
                              PAGES
---------------------------------------------------------------*/

#pages .padding-left { padding-left: 100px; }
#pages .siteInner { position: relative; }
#pages .verticalLine {
	display: block;
    width: 1px;
    height: calc(100% - 50px - 120px);
    position: absolute;
    top: 50px;
    left: calc(7.5% + 50px);
	z-index: 10;
}

#pages .head-style:before {
	content: "";
	display: block;
	width: 20px;
	height: 20px;
	border-radius: 20px;
	background: #009944;
	position: absolute;
	top: 0;
	bottom: 0;
	left: -60px;
	margin: auto;
	transform: scale(0);
}

#pages .in .head-style:before {
	animation: 500ms bounce ease 250ms forwards;
}

#pages .safety .head-style:before { background: #f55a96; }
#pages .health .head-style:before { background: #f08200; }
#pages .local .head-style:before { background: #46A0FF; }
#pages .employee .head-style:before { background: #e60012; }
#pages .environment .head-style:before { background: #1AB1AD; }
#pages .donation .head-style:before { background: #DCA80C; }


/*---------------------------------------------- PAGE CONCEPT */

#pages .concept {
	margin-bottom: 0;
}

#pages .conceptInner {
	position: relative;
}

#pages .concept .site-icon {
    top: -140px;
    left: 0;
	right: auto;
}

#pages .concept .site-description {
	font-size: 1.8rem;
}

#pages .concept .sdgs {
    /*margin-top: 60px;*/
}

#pages .concept .sdgsInner {
	width: 100%;
	padding: 36px 48px;
}

#pages .concept .sdgs-head {
	text-align: center;
}

#pages .concept .sdgs-list {
	align-items: center;
	margin-top: 20px;
}

#pages .concept .sdgs-list-head {
	width: 32%;
	margin: 0 2.6% 0 0;
}

#pages .concept .sdgs-list-head img {
	width: 100%;
}

#pages .concept .sdgs-list-inner,
#pages .concept .sdgs-list-inner:nth-of-type(3n) {
	width: 11%;
	margin: 0 2.6% 0 0;
}

#pages .concept .sdgs-list-all {
	margin-top: 20px;
}


/*---------------------------------------------- CONTENTS */

#pages .contents {
	width: 85%;
    max-width: 1280px;
    margin: 0 auto;
}

#pages .sectionInner {
	display: flex;
	flex-direction: row-reverse;
	justify-content: space-between;
}

#pages .section-img {
	width: calc(50% - 20px);
	margin: 0;
}

#pages .section-img figcaption {
	font-size: 1.2rem;
}

#pages .section-img + .section-txt {
	width: calc(50% - 20px);
}

#pages .section-txt {
	width: 100%;
}

#pages .section-img figure span {
    border-radius: 24px;
}

#pages .section-img figure span.border {
	padding: 24px;
}

/*IMPLEMENT*/

#pages .implementList.three-column {
	display: flex;
	justify-content: space-between;
}

#pages .implementList.three-column dl {
	width: calc(33.3333% - 24px);
}

#pages .implementList {
    margin-top: 24px;
}

#pages .implementList dl {
	margin-bottom: 0;
}


/*---------------------------------------------- OTHER */
	
.other .portrait figcaption.signature {
    left: 31%;
    top: 10%;
    transform: scale(.2);
}

.other .firstSection {
	width: 85%;
    max-width: 1280px;
    margin: 0 auto;
}

.other .firstSection h2 {
	font-size: 2.2rem;
	text-align: center;
}

.other .firstSection p {
	font-size: 1.6rem;
	padding: 0 7.5%;
}
	
.other .signature p {
    font-size: 1.8rem;
}


/*POLICY*/

.policy .firstSection h2 {
	margin-bottom: 40px;
}

.policy .guidelines {
	overflow: hidden;
	background: url(../images/common/guidelines-background.jpg) center bottom / 100% auto no-repeat;
}

.policy .secondSection {
	display: flex;
    justify-content: space-between;
	flex-wrap: wrap;
	width: 85%;
    max-width: 1280px;
    margin: 0 auto;
}

#pages .policy .head-style:before { content: none; }

.policy .leftBox {
	width: calc(50% - 30px);
	margin: 0;
}

.policy .rightBox {
    width: calc(50% - 30px);
	margin: 0;
}

.policy .actionBox {
	width: 100%;
}

.policy .sdgs-table {
	margin-top: 40px;
}

.policy .sdgs-table .tableInner {
	width: 100%;
	overflow: visible;
	margin: 0 auto;
	background: none;
}

.policy .sdgs-table .how-to-scroll {
	display: none;
}

.policy table {
    width: 100%;
	padding: 48px;
	border-radius: 24px; 
}

.policy table .problem {
    width: calc( .25 * (100% - 40px));
}

.policy table .action {
    width: calc( .45 * (100% - 40px));
}

.policy table .goal {
   width: calc( .3 * (100% - 40px));
}

.policy table .goal {
	position: relative;
}

.policy table th.goal:after {
	display: block;
	content: "マウスをおくとマークを拡大できます";
	width: 100%;
	font-size: 1rem;
	line-height: 1;
	color: #9d9d9d;
	padding: 0 20px 0 40px;
	position: absolute;
	left: 50%;
	bottom: -15px;
	transform: translate(-50%,0);
}

.policy table td.goal ol li {
	position: relative;
}

.policy table td.goal ol li:hover {
	z-index: 10;
}

.policy table td.goal ol li img {
	position: relative;
	box-shadow: 0 0 25px rgba(0,0,0,0);
	transition: all 300ms ease-in-out;
}

.policy table td.goal ol li:hover img {
	transform: scale(2.75);
	box-shadow: 0 0 25px rgba(0,0,0,.15);
}
	
.policy table#agenda thead {
    margin-bottom: 12px;
}


/*GREEN CHALENGE 2050*/
	
.policy .green-challenge-table .theme {
	width: 240px;
}
	
.policy .green-challenge-table .ideal2030,
.policy .green-challenge-table .ideal2050 {
    width: calc((100% - 240px) / 2)
}

/*---------------------------------------------- リンクバナー */

.section .linkBnr a {
	transition: all 300ms ease;
}

.section .linkBnr a:hover {
	opacity: .5;
}

.section .linkBnr.movie {
	width: 50%;
}


/*--------------------------------------------------------------
                              SITEMAP
---------------------------------------------------------------*/

.sitemapInner {
	width: 85%;
    max-width: 1280px;
	padding-top: 80px;
    margin: 0 auto;
}

.sitemapListInner {
	width: 100%;
}

.sitemapList h2 {
	line-height: 34px;
    padding: 0 17px;
	border-radius: 17px;
}

}

/*画面幅最大時のコンテンツ内の線の位置調整*/
@media (min-width: 1513px) { #pages .verticalLine{ left: calc(50% - 640px + 50px ) } }

/*IE10以下ののCSR基本方針 グラフの調整*/
@media all and (-ms-high-contrast: none){
  .policy table .num { width: 7%; }
  .policy table .problem { width: 23%; }
  .policy table .action { width: 42%; }
  .policy table .goal { width: 28%; }
}
94
