.fadeup
{
    visibility: hidden;

    opacity: 0;

    translate: 0 30px;
}

.lead_area
{
    display: flex;

    width: 100%;
    min-height: 760px;
    padding-bottom: 180px;

    background: url(/_kyokko-wp-files/wp-content/themes/kyokko//sustainability/img/bg_lead.webp) center/cover;

    aspect-ratio: 1500/760;
    justify-content: center;
    align-items: flex-end;
}
@media screen and (max-width: 768px)
{
    .lead_area
    {
        min-height: 450px;
        padding-bottom: 50px;

        aspect-ratio: auto;
    }
}
.lead_area > .inner
{
    width: 90%;
    max-width: 1300px;
}
.lead_area > .inner h3
{
    font-size: 48px;
    line-height: 1.3333333333;

    margin-bottom: 40px;

    letter-spacing: 0;
}
@media screen and (max-width: 768px)
{
    .lead_area > .inner h3
    {
        font-size: 30px;

        margin-bottom: 25px;
    }
}
.lead_area > .inner h3 br
{
    display: block;
}
@media screen and (max-width: 600px)
{
    .lead_area > .inner h3 br
    {
        display: none;
    }
}
.lead_area > .inner h2
{
    font-size: 34px;
    line-height: 1.3235294118;

    margin-bottom: 25px;

    letter-spacing: 0;

    color: var(--bc-blue);
}
@media screen and (max-width: 768px)
{
    .lead_area > .inner h2
    {
        font-size: 24px;

        margin-bottom: 15px;
    }
}
.lead_area > .inner p
{
    font-size: 16px;
    line-height: 1.875;

    max-width: 780px;

    letter-spacing: .06em;
}
@media screen and (max-width: 768px)
{
    .lead_area > .inner p
    {
        font-size: 14px;
    }
}

.policy_area
{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto 150px;
}
@media screen and (max-width: 768px)
{
    .policy_area
    {
        margin-bottom: 70px;
    }
}
.policy_area > .inner
{
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner
    {
        width: 100%;
    }
}
.policy_area > .inner hgroup
{
    font-family: 'Shippori Mincho', serif;
    font-weight: 400;
    font-style: normal;

    margin-bottom: 70px;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner hgroup
    {
        margin-bottom: 30px;
    }
}
.policy_area > .inner hgroup p.en
{
    font-size: 20px;
    line-height: 1;

    position: absolute;
    top: 0;
    left: 0;

    display: flex;

    white-space: nowrap;
    letter-spacing: .06em;

    color: var(--bc-blue);

    align-items: center;
    gap: 10px;
    writing-mode: vertical-rl;
    font-feature-settings: normal;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner hgroup p.en
    {
        font-size: 16px;

        position: static;

        margin-bottom: 10px;

        writing-mode: horizontal-tb;
    }
}
.policy_area > .inner hgroup p.en:before
{
    width: 1px;
    height: 60px;

    content: '';

    background: var(--bc-blue);
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner hgroup p.en:before
    {
        width: 40px;
        height: 1px;
    }
}
.policy_area > .inner hgroup h2
{
    font-size: 48px;
    line-height: 1.0416666667;

    letter-spacing: 0;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner hgroup h2
    {
        font-size: 24px;
    }
}
.policy_area > .inner hgroup h2 span
{
    font-size: 48px;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner hgroup h2 span
    {
        font-size: 30px;
    }
}
.policy_area > .inner ul.policy
{
    width: 100%;
    max-width: 800px;
    margin: 0 auto;

    counter-reset: number 0;
}
.policy_area > .inner ul.policy > li
{
    font-size: 16px;
    line-height: 1.875;

    position: relative;

    padding-left: 35px;

    letter-spacing: .06em;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner ul.policy > li
    {
        font-size: 14px;

        padding-left: 25px;
    }
}
.policy_area > .inner ul.policy > li ul.theme
{
    display: grid;

    margin-top: 30px;

    grid-template-columns: repeat(3, 1fr);
}
.policy_area > .inner ul.policy > li ul.theme li
{
    display: grid;

    text-align: center;

    border-left: 1px solid #c3ccd9;

    grid-row: span 2;
    grid-template-rows: subgrid;
    gap: 15px 0;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner ul.policy > li ul.theme li
    {
        gap: 10px;
    }
}
.policy_area > .inner ul.policy > li ul.theme li:last-child
{
    border-right: 1px solid #c3ccd9;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner ul.policy > li ul.theme li .icon img
    {
        height: 35px;
    }
}
.policy_area > .inner ul.policy > li ul.theme li p
{
    font-size: 16px;
    line-height: 1.5;

    display: flex;

    letter-spacing: 0;

    color: var(--bc-blue);

    align-items: center;
    justify-content: center;
}
@media screen and (max-width: 768px)
{
    .policy_area > .inner ul.policy > li ul.theme li p
    {
        font-size: 11px;
    }
}
.policy_area > .inner ul.policy > li:not(:last-child)
{
    margin-bottom: 40px;
}
.policy_area > .inner ul.policy > li:before
{
    position: absolute;
    top: 0;
    left: 0;

    content: counter(number) '.';
    counter-increment: number;
}

div.bg
{
    padding: 150px 0;

    background: url(/_kyokko-wp-files/wp-content/themes/kyokko//sustainability/img/bg.webp) right bottom/100% 150% no-repeat;
}
@media screen and (max-width: 768px)
{
    div.bg
    {
        padding: 70px 0;
    }
}
div.bg hgroup
{
    font-family: 'Shippori Mincho', serif;
    font-weight: 400;
    font-style: normal;

    margin-bottom: 70px;
}
@media screen and (max-width: 768px)
{
    div.bg hgroup
    {
        margin-bottom: 30px;
    }
}
div.bg hgroup p.en
{
    font-size: 20px;
    line-height: 1;

    position: absolute;
    top: 0;
    left: 0;

    display: flex;

    white-space: nowrap;
    letter-spacing: .06em;

    color: var(--bc-blue);

    align-items: center;
    gap: 10px;
    writing-mode: vertical-rl;
    font-feature-settings: normal;
}
@media screen and (max-width: 768px)
{
    div.bg hgroup p.en
    {
        font-size: 16px;

        position: static;

        margin-bottom: 10px;

        writing-mode: horizontal-tb;
    }
}
div.bg hgroup p.en:before
{
    width: 1px;
    height: 60px;

    content: '';

    background: var(--bc-blue);
}
@media screen and (max-width: 768px)
{
    div.bg hgroup p.en:before
    {
        width: 40px;
        height: 1px;
    }
}
div.bg hgroup h2
{
    font-size: 48px;
    line-height: 1.0416666667;

    letter-spacing: 0;
}
@media screen and (max-width: 768px)
{
    div.bg hgroup h2
    {
        font-size: 24px;
    }
}
div.bg hgroup h2 span
{
    font-size: 48px;
}
@media screen and (max-width: 768px)
{
    div.bg hgroup h2 span
    {
        font-size: 30px;
    }
}
div.bg section
{
    width: 90%;
    max-width: 1200px;
    margin: 0 auto;
}
div.bg section.ga_area,
div.bg section.qualification_area
{
    margin-bottom: 140px;
}
@media screen and (max-width: 768px)
{
    div.bg section.ga_area,
    div.bg section.qualification_area
    {
        margin-bottom: 70px;
    }
}
div.bg section > .inner
{
    width: 90%;
    max-width: 1000px;
    margin: 0 auto;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner
    {
        width: 100%;
    }
}
div.bg section > .inner ul.actions > li
{
    display: grid;

    padding: 40px 0;

    border-top: 1px solid #c3ccd9;

    grid-template-columns: repeat(2, 1fr);
    align-items: center;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.actions > li
    {
        padding: 20px 0;

        grid-template-columns: 1fr;
    }
}
div.bg section > .inner ul.actions > li:last-child
{
    border-bottom: 1px solid #c3ccd9;
}
div.bg section > .inner ul.actions > li h3
{
    display: flex;

    padding-left: 100px;

    text-align: left;

    align-items: center;
    gap: 35px;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.actions > li h3
    {
        margin-bottom: 20px;
        padding: 0;

        gap: 20px;
    }
}
div.bg section > .inner ul.actions > li h3 .txt
{
    font-size: 20px;
    line-height: 1.7;

    letter-spacing: 0;

    color: var(--bc-blue);
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.actions > li h3 .txt
    {
        font-size: 18px;
    }
}
div.bg section > .inner ul.actions > li ul.details
{
    counter-reset: number 0;
}
div.bg section > .inner ul.actions > li ul.details li
{
    font-size: 16px;
    line-height: 1.875;

    position: relative;

    padding-left: 30px;

    letter-spacing: .06em;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.actions > li ul.details li
    {
        font-size: 14px;
    }
}
div.bg section > .inner ul.actions > li ul.details li:not(:last-child)
{
    margin-bottom: 10px;
}
div.bg section > .inner ul.actions > li ul.details li:before
{
    position: absolute;
    top: 0;
    left: 0;

    content: counter(number) '.';
    counter-increment: number;
}
div.bg section > .inner ul.sdgs
{
    display: flex;

    margin-top: 40px;

    gap: 10px;
    justify-content: space-between;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.sdgs
    {
        display: grid;

        grid-template-columns: repeat(5, 1fr);
        gap: 5px;
    }
}
div.bg section > .inner ul.qualifications
{
    padding: 40px 100px;

    background: rgba(255, 255, 255, .6);
    box-shadow: 0 10px 9.6px .4px rgba(0, 0, 0, .04);
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.qualifications
    {
        padding: 20px 5%;
    }
}
div.bg section > .inner ul.qualifications > li
{
    display: grid;

    grid-template-columns: 180px 1fr;
    gap: 60px;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.qualifications > li
    {
        display: block;
    }
}
div.bg section > .inner ul.qualifications > li:not(:last-child)
{
    margin-bottom: 40px;
    padding-bottom: 40px;

    border-bottom: 1px solid #c3ccd9;
}
div.bg section > .inner ul.qualifications > li .logo
{
    text-align: center;

    align-self: center;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.qualifications > li .logo
    {
        margin-bottom: 30px;
    }
}
div.bg section > .inner ul.qualifications > li .logo img
{
    width: 100%;
    max-width: 180px;
}
div.bg section > .inner ul.qualifications > li .txt_wrap
{
    align-self: center;
}
div.bg section > .inner ul.qualifications > li .txt_wrap h3
{
    font-family: 'Shippori Mincho', serif;
    font-size: 24px;
    font-weight: 400;
    font-style: normal;
    line-height: 1.4583333333;

    margin-bottom: 20px;

    letter-spacing: 0;

    color: var(--bc-blue);
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.qualifications > li .txt_wrap h3
    {
        font-size: 20px;
    }
}
div.bg section > .inner ul.qualifications > li .txt_wrap p.txt
{
    font-size: 16px;
    line-height: 1.875;

    letter-spacing: .06em;
}
@media screen and (max-width: 768px)
{
    div.bg section > .inner ul.qualifications > li .txt_wrap p.txt
    {
        font-size: 14px;
    }
}
div.bg section > .inner ul.qualifications > li .txt_wrap p.txt a
{
    color: var(--bc-blue);
    border-bottom: 1px solid var(--bc-blue);
}
div.bg section > .inner ul.qualifications > li .txt_wrap p.txt a[target=_blank]:after
{
    display: inline-block;

    width: 10px;
    margin-left: 10px;

    content: '';

    background: url(/_kyokko-wp-files/wp-content/themes/kyokko//company/img/icon_blank.webp) center/cover;

    aspect-ratio: 1;
}
div.bg section > .inner .report
{
    padding: 25px;

    background: #f0f3f7;
}
div.bg section > .inner .report ul
{
    display: flex;

    justify-content: center;
    flex-wrap: wrap;
    gap: 30px 100px;
}
div.bg section > .inner .report ul li a
{
    font-size: 16px;
    line-height: 1.875;

    display: flex;

    letter-spacing: .06em;

    color: var(--bc-blue);
    border-bottom: 1px solid var(--bc-blue);

    align-items: center;
    gap: 10px;
}
div.bg section > .inner .report ul li a:after
{
    display: block;

    width: 15px;

    content: '';

    background: url(/_kyokko-wp-files/wp-content/themes/kyokko//sustainability/img/icon_pdf.webp) center/cover;

    aspect-ratio: 31/33;
}

.separate
{
    background: url(/_kyokko-wp-files/wp-content/themes/kyokko/sustainability/img/img_separate.webp) top center/120% auto no-repeat;

    aspect-ratio: 16/7;
}
.separate img
{
    width: 100%;
    height: 100%;

    object-fit: cover;
}

section
{
    position: relative;
}

footer
{
    margin-top: 20px;
}

.breadcrumbs_area
{
    margin-top: 150px;
    padding: 0 50px;
}
@media screen and (max-width: 768px)
{
    .breadcrumbs_area
    {
        margin-top: 70px;
        padding: 0 5%;
    }
}
.breadcrumbs_area nav ol
{
    display: flex;

    align-items: center;
    gap: 15px;
}
.breadcrumbs_area nav ol li
{
    font-size: 14px;
    line-height: 1;

    display: flex;

    letter-spacing: 0;

    color: #8a9099;

    align-items: center;
    gap: 15px;
}
.breadcrumbs_area nav ol li:not(:last-child):after
{
    content: '>';
}
.breadcrumbs_area nav ol li a
{
    color: #8a9099;
}
/*# sourceMappingURL=style.css.map */
