@charset "UTF-8";
/* **************************************************

Name: esg-mss.css

Description: /solution/esg-mss/

Create: 2024.07.09
Update: 

Copyright Hitachi Systems, Ltd.

***************************************************** */
.p-page .p-wrapper {
    font-family: 'メイリオ', Meiryo, 'ヒラギノ角ゴ Pro W3', 'Hiragino Kaku Gothic Pro', 'ＭＳ Ｐゴシック', Arial, Helvetica, sans-serif;
}

.esg-mss .p-wrapper .esg-mss-inlineblock {
    display: inline-block;
    font-weight: inherit;
}

.p-page__solution__energystorage .p-hero__tit strong {
    margin-bottom: 0.5em;
    white-space: nowrap;
    font-size: 40px;
    font-weight: bold;
    line-height: 1.6;
    letter-spacing: -0.05em;
    opacity: 0;
    -webkit-animation: fadeIn 0.5s ease-in-out 0.9s forwards;
    animation: fadeIn 0.5s ease-in-out 0.9s forwards;
}

.p-page .p-anchorbtn__box > ul {
    gap: 15px;
}

.p-page .p-anchorbtn__box.is_column-03 > ul > li {
    width: calc(calc(100% - 15px * 3) / 3);/*※ボタン4つに増えたら「割る4」に変更*/
}

.p-page .p-linkbtn__box > ul > li {
    width: calc(50% - 10px);
}

.p-page .p-linkbtn__box_item > object > a {
    max-width: 474px;
    font-weight: bold;
}

.p-page .p-linkbtn__box_item > object.CenterAdjust > a {
    margin-left: auto;
    margin-right: auto;
}

.p-page .p-anchorbtn__box_item > object > a {
    min-height: 73px;
    display: flex;
    align-items: center;
    justify-items: center;
    box-sizing: border-box;
    padding: 0 8px;
}

.p-page .p-anchorbtn__box_item > object > a > strong {
    line-height: 1.6;
    text-align: center;
}

#Contents .Inner {
    max-width: 965px;
    margin: auto;
    padding: 4em 0;
}

#Contents .Inner h2 {
	font-size: 1.75em;
	font-weight: bold;
	line-height: 1.6;
	text-align: center;
	padding: .5em 0 1em;
}

#Contents .Inner .TextStyle1 {
	font-size: 1.2em;
    margin-bottom: 1em;
    line-height: 1.6;
}

#Contents h3 {
	font-weight: bold;
	font-size: 1.6em;
    margin: 70px 0 40px;
}

#Contents .Inner .AnnotationsStyle1 {
    font-size: 1rem;
}

#Contents .Inner .AnnotationsStyle1 > li {
    text-indent: -0.7em;
    padding-left: 0.7em;
    line-height: 1.4;
}

.p-page .p-wrapper .box-boder {
    border: 1px solid #cccccc;
    padding: 30px;
    background: #fff;
}

.p-page .p-wrapper .ListStyle1 li {
    font-size: inherit;
    text-indent: -1em;
    padding-left: 1em;
    font-size: 1.2em;
    line-height: 1.6;
}

.p-page .p-wrapper .ListStyle1 li::before {
    content: "・";
    display: inline;
}

.p-page .p-wrapper .p-footernavi__box a {
    font-weight: bold;
}

@media (max-width: 995px){
    .p-page .p-anchorbtn__box_item > object > a {
        font-size: 83%;
    }

    .JS #Contents .Inner {
		padding: 4em 1em;
	}
}

@media (max-width: 767px){
    .p-page__solution__energystorage .p-hero__tit strong {
        margin-bottom: 0.5em;
        font-size: 5.86667vw;
      }

    .JS #Contents .Inner h2 {
		font-size: 1.6em;
	}

    .JS #Contents h3 {
		font-size: 1.4em;
        margin: 40px 0 20px;
        line-height: 1.4;
	}

    .p-page .p-linkbtn__box_item > object > a {
        max-width:none
    }

    #Contents .Inner .AnnotationsStyle1 {
        font-size: 1em;
    }
}

/* branding */
.p-page__solution__energystorage .p-hero__tit {
    margin-bottom: 30px;
}

.p-page__solution__energystorage .p-hero::before {
    width: 1288px;
    height: 440px;
    background-image: url(/-/media/ind/carbon_neutral/image/solution/esg-mss/branding.png);
    background-position: right center;
    transform: translate(0, 0);
    right: calc(calc(100vw - 100%) / 2* -1);
    margin: 0;
    left: auto;
}

.p-page__solution__energystorage .p-hero {
    height: 440px;
    margin-bottom: 10px;
}

.p-page__solution__energystorage .p-hero__tit h1 {
    text-shadow: 0 0 10px #fff, 0 0 10px #fff, 0 0 10px #fff, 0 0 10px #fff, 0 0 5px #fff;
}

@media (max-width: 767px){
    .p-page__solution__energystorage .p-hero {
        height: 72vw;
    }

    .p-page__solution__energystorage .p-hero::before {
        position: absolute;
        width: 100vw;
        background-size: contain;
        background-position: right bottom;
        height: 72vw;
    }
}


/* movie */
.p-page .p-wrapper .movie-txt {
    text-align: center;
    font-size: 1.75rem;
    font-weight: bold;
    line-height: 1.6;
    margin-bottom: 30px;
}

.p-page .p-wrapper .movie-txt strong {
    font-size: min( 3.7vw ,2.25rem);
    color: #1a7d98;
    line-height: inherit;
    font-weight: bold;
}

.p-page .p-wrapper #movie-thumb {
    text-align: center;
    margin-bottom: 30px;
}

.p-page .p-wrapper #movie-thumb a {
    max-width: 570px;
    width: 100%;
    display: block;
    margin: 0 auto;
}

.p-page .p-wrapper #movie-thumb a:hover {
    opacity: 0.6;
}

@media (max-width: 767px){
    .p-page .p-wrapper .movie-txt {
        font-size: max(1.25rem, 3.9vw);
        text-align: left;
    }

    .p-page .p-wrapper .movie-txt strong {
        font-size: inherit;
    }
}


/* problem */
#Contents #problem .Inner h2 {
    font-size: min( 3.5vw, 2.25rem);
    display: flex;
    align-items: center;
    text-align: left;
    width: fit-content;
    margin-left: auto;
    margin-right: auto;
}

#Contents #problem .Inner h2::before,
#Contents #problem .Inner h2::after {
    content: "";
    display: inline-block;
    width: 130px;
    height: 160px;
    background-repeat: no-repeat;
    background-position: center center;
    background-size: auto 100%;
    margin: 0;
    vertical-align: middle;
}

#Contents #problem .Inner h2::before {
    background-image: url(/-/media/ind/carbon_neutral/image/solution/esg-mss/problem-icon-l.png);
}

#Contents #problem .Inner h2::after {
    background-image: url(/-/media/ind/carbon_neutral/image/solution/esg-mss/problem-icon-r.png);
}

#Contents #problem .Inner h2 > span {
    flex: 1;
    font-weight: inherit;
}

#problem-content {
    padding: 160px 0 70px;
    position: relative;
    z-index: 0;
}

#problem-content h3 {
    margin: 0;
    padding: 0;
}

#problem-list-vertical-problem,
#problem-list-vertical-answer {
    display: block;
    position: absolute;
    top: 0;
    bottom: 0;
    width: calc(calc(100% - 60px - 59px) / 2);
    z-index: -1;
    padding: 30px 15px 0;
    box-sizing: border-box;
}

#problem-list-vertical-problem {
    background: #fffed3;
    left: 30px;
}

#problem-list-vertical-problem > span,
#problem-list-vertical-answer  > span {
    display: block;
    font-size: clamp(1rem, 3.5vw, 1.875rem);
    font-weight: bold;
    text-align: center;
    line-height: 1.2;
}

#problem-list-vertical-answer {
    background: #fee5c9;
    right: 30px;
}

#problem-list > li {
    background: #fff;
    display: flex;
    padding: 40px 30px;
    margin-bottom: 70px;
}

#problem-list > li:last-child {
    margin-bottom: 0;
}

.problem-list-arrow {
    width: 59px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.problem-list-problem,
.problem-list-answer {
    flex: 1;
    position: relative;
}

#problem #problem-list .problem-list-arrow-icon {
    width: 0;
    height: 0;
    border-left: 30px solid #333;
    border-top: 50px solid transparent;
    border-bottom: 50px solid transparent;
    border-right: 0 solid transparent;
}


#problem #problem-list .problem-list-num {
    width: 70px;
    height: 70px;
    color: #fff;
    border-radius: 50%;
    font-size: 2.875rem;
    font-weight: bold;
    text-align: center;
    line-height: 74px;
    position: absolute;
    top: -85px;
    left: 50%;
    transform: translateX(-50%);
}

.problem-list-problem .problem-list-num {
    background: #1a7d98;
}

.problem-list-answer .problem-list-num {
    background: #1a7d98;
}

#problem #problem-list .problem-list-img {
    width: 100%;
    margin-bottom: 20px;
}

#problem #problem-list .problem-list-title {
    font-weight: bold;
    font-size: min(2.6vw, 1.625rem);
    color: #333;
    line-height: 1.6;
    margin: 0 0 10px;
    text-align: center;
}

#problem #problem-list .problem-list-title::before {
    display: none;
}

#problem #problem-list .problem-list-title strong {
    font-weight: inherit;
}

.problem-list-problem .problem-list-title strong {
    color: #1a7d98;
}

.problem-list-answer .problem-list-title strong {
    color: #1a7d98;
}

#problem #problem-list .problem-list-txt {
    padding: 0 15px;
}

#problem #problem-list .problem-list-txt p {
    font-size: 1.2em;
    line-height: 1.6;
    margin-bottom: 0;
}

@media (max-width: 767px){
    #Contents #problem .Inner h2 {
        font-size: 1.6em;
        width: 100%;
        flex-wrap: wrap;
    }

    #Contents #problem .Inner h2::before,
    #Contents #problem .Inner h2::after {
        width: 50%;
        height: 130px;
        margin: 0;
    }

    #Contents #problem .Inner h2::before {
        background-position: right center;
        order: 1;
    }

    #Contents #problem .Inner h2::after {
        background-position: left center;
        order: 2;
    }

    #Contents #problem .Inner h2 > span {
        order: 3;
        width: 100%;
        text-align: center;
        margin-top: 10px;
        line-height: 1.3;
    }

    #problem-content {
        padding-top: max(70px, 13vw);
        padding-bottom: 50px;
    }

    #problem-list-vertical-problem,
    #problem-list-vertical-answer {
        width: 50%;
    }

    #problem-list-vertical-problem {
        left: 0;
    }

    #problem-list-vertical-answer {
        right: 0;
    }

    #problem-list > li {
        padding: 20px 15px;
        margin-bottom: 50px;
    }

    .problem-list-arrow {
        width: 30px;
    }

    #problem #problem-list .problem-list-arrow-icon {
        border-width: 20px 0 20px 12px;
    }

    #problem #problem-list .problem-list-num {
        transform: translate(-50%, -70%) scale(0.6);
        top: 0;
        transform-origin: center top;
    }

    #problem #problem-list .problem-list-title {
        font-size: 1em;
        line-height: 1.4;
        text-align: left;
    }

    #problem #problem-list .problem-list-title br {
        display: none;
    }

    #problem #problem-list .problem-list-txt {
        padding: 0;
        font-size: 1em;
        line-height: 1.4;
    }

    #problem #problem-list .problem-list-txt p {
        font-size: inherit;
        line-height: inherit;
    }

    #problem #problem-list .problem-list-txt .ListStyle1 {
        line-height: inherit;
    }

    #problem #problem-list .problem-list-txt .ListStyle1 > li {
        font-size: inherit;
        line-height: inherit;
    }
}


/* summary */
#summary-cycle-content {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap : 0 clamp(15px , 3% , 30px);
}

#summary-cycle-img {
    width: calc(370 / 965 * 100%);
}

.JS #Contents #summary-cycle-img img {
    max-width: 370px;
    display: inline-block;
}

#summary-cycle-txt {
    flex: 1;
}

#summary-cycle-txt p {
    background: #f0f0f0;
    padding: 20px;
    font-weight: bold;
    font-size: 1.1875rem;
    line-height: 1.6;
}

#summary-cycle-txt p + p {
    margin-top: 40px;
}

@media (max-width: 767px){
    #summary-cycle-content {
        display: block;
    }

    #summary-cycle-img {
        width: 100%;
        margin-bottom: 20px;
    }

    #summary-cycle-txt p {
        font-size: 1.2em;
    }

    #summary-cycle-txt p + p {
        margin-top: 20px;
    }
}

/* function */
#function-list {
    display: flex;
    flex-wrap: wrap;
    gap: 20px 15px;
    margin-bottom: 40px;
}

#function-list > div {
    width: calc(calc(100% - 30px) / 3);
    background: #fff;
    padding: 15px;
    box-sizing: border-box;
}

#function-list > div > dt {
    font-weight: bold;
    font-size: 1.1875rem;
    line-height: 1.3;
    color: #1a7d98;
    margin-bottom: 5px;
    padding-left: 38px;
    position: relative;
    padding-top: calc(calc(34px - 1.3em) / 2);
}

#function-list > div > dt::before {
    content: "";
    display: inline-block;
    width: 34px;
    height: 34px;
    background: url(/-/media/ind/carbon_neutral/image/solution/esg-mss/esg-mss-icon-check.png) no-repeat center center;
    background-size: 100%;
    position: absolute;
    top: 0;
    left: 0;
}

#function-list > div > dd {
    font-size: 1.125rem;
    line-height: 1.6;
    word-break: keep-all;
}

@media (max-width: 767px){
    #function-list > div {
        width: 100%;
        padding: 15px;
    }

    #function-list > div > dt {
        font-size: 1.4em;
    }

    #function-list > div > dd {
        font-size: 1.2em;
    }
}

/* examples */
#examples .Inner {
    padding-bottom: 0;
}

#examples-list {
    display: flex;
    justify-content: space-around;
    align-items: center;
    padding-left: 50px;
    padding-right: 50px;
}

#examples-list > li > a:hover {
    opacity: 0.6;
}

#examples-list > li > a > img {
    max-width: 100%;
    width: auto;
    margin: 0 auto;
}

@media (max-width: 767px){
    #examples-list {
        display: block;
    }

    #examples-list > li > a > img {
        max-height: 80px;
    }
}

/* document */
#document {
    margin-top: 80px;
}

#document .Inner {
    background: #f0f0f0;
    padding: 40px;
    box-sizing: border-box;
}

#document .Inner h2 {
    margin-top: 0;
    margin-bottom: 20px;
}

#document .Inner h3 {
    margin-top: 0;
}

#document-content {
    display: flex;
    gap: min( 5% , 30px);
    margin-bottom: 40px;
}

#document-txt {
    flex: 1;
}

#document-img {
    width: calc(400 / 885 * 100%);
}

#document-btn {
    margin-bottom: 30px;
}

@media (max-width: 767px){
    #document .Inner h2 {
        margin-bottom: 0;
    }

    #document-content {
        display: block;
        margin-bottom: 30px;
    }

    #document-txt {
        margin-bottom: 20px;
    }

    #document .Inner h3 {
        margin-top: 10px;
    }

    #document-img {
        width: 100%;
    }

    #document-content #document-img img {
        max-width: 400px;
        display: inline-block;
    }

    #document .p-linkbtn__box_item {
        margin-bottom: 10px;
    }
}

/* relation */
.relation-link:hover {
    opacity: 0.6;
}

.relation-content {
    display: flex;
    align-items: center;
    gap: 30px;
}

.relation-img {
    width: calc(360 / 903 * 100%);
}

.relation-txt {
    flex: 1;
}

#relation .relation-txt h3 {
    margin-top: 0;
    margin-bottom: 20px;
    word-break: keep-all;
}

@media (max-width: 767px){
    .relation-content {
        display: block;
    }

    .relation-img {
        max-width: 360px;
        width: 100%;
    }

    #relation .relation-content h3 {
        margin-top: 20px;
    }
}
