.visual {
    aspect-ratio:18 / 8;
}

.visual .container {
    width:100%;
    height:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
}

.visual_line {
    width:1px;
    height:136px;
    background-color:#fff;
    margin:0 auto 60px;
}

h2 {
    font-size:50px;
    color:#fff;
    text-align:center;
    font-weight:700;
}

.subh2 {
    font-size:32px;
    color:#fff;
    text-align:left;
    font-weight:500;
    word-break:keep-all;
}

.sec1_logo h3 {
    font-size:50px;
    font-weight:700;
    margin-bottom:30px;
}

.sec1_logo .logo_txt {
    font-size:30px;
    line-height:180%;
    word-break:keep-all;
    color:#898989;
}

.sec1_logo {
    margin-bottom:110px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:start;
}

#page_esg .color {
    margin-bottom:80px;
    padding:100px 0;
}

#page_esg .color.last {
    margin-bottom:130px;
}

#page_esg .wrap_content {
    width:100%;
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    text-align:center;
}

#page_esg h4 {
    font-size:45px;
    font-weight:700;
    margin-bottom:50px;
}

#page_esg .subh4 {
    font-size:30px;
    font-weight:500;
    line-height:160%;
    margin-bottom:50px;
}

#page_esg .content_list li,
#page_esg .box p {
    font-size:25px;
    font-weight:500;
}

#page_esg .box p {
    line-height:180%;
}

#page_esg .content_list {
    width:90%;
    max-width:790px;
    margin-bottom:80px;
}

html[lang="ko"] #page_esg .content_list li {
    text-align:center;
    height:68px;
    line-height:68px;
    border-radius:30px;
    background-color:#fff;
    margin-bottom:20px;
}

html[lang="en"] #page_esg .content_list li {
    text-align:center;
    min-height:68px;
    height:auto;
    display:flex;
    align-items:center;
    justify-content:center;
    line-height:120%;
    border-radius:30px;
    background-color:#fff;
    margin-bottom:20px;
}

#page_esg .content_list li:last-child {
    margin-bottom:0;
}



#page_esg .visual {
    background:url('/img/esg/visual_esg.png') 50% 50% no-repeat;
    background-size:cover;
}

#page_esg .sec_1 {
    padding-top:150px;
}

#page_esg .sec_2 {
    padding-bottom:130px;
}

#page_esg .sec_2 .container {
    display:flex;
    flex-direction:column;
    align-items:center;
    justify-content:center;
}

#page_esg .sec2_chart {
    width:640px;
    height:640px;
    position:relative;
    margin-bottom:34px;
}

#page_esg .chart_round {
    width:100%;
    height:100%;
    background: conic-gradient(from 0deg at 50% 50%, #B4FFA8 0deg, #FFE03D 121.87499642372131deg, #3DA2FF 226.87499284744263deg, #B4FFA8 360deg);
    border-radius:50%;
    position:absolute;
    top:0;
    left:0;
}

#page_esg .chart_area {
    width:calc(100% - 65px);
    height:calc(100% - 65px);
    border-radius:50%;
    background-color:#fff;
    position:absolute;
    top:50%;
    left:50%;
    transform:translate(-50%, -50%);
    display:grid;
    grid-auto-columns: 1fr 1fr;
    grid-auto-rows: 4fr 6fr;
    box-shadow:0 4px 4px rgba(0,0,0,0.25);
}

#page_esg .chart_area .three1 {
    grid-column:1 / 3;
    grid-row: 1 / 2;
}

#page_esg .chart_area .three2 {
    grid-column:1 / 2;
    grid-row: 2 / 3;
    padding-bottom:60px;
}

#page_esg .chart_area .three3 {
    grid-column:2 / 3;
    grid-row: 2 / 3;
    padding-bottom:60px;
}

#page_esg .chart_area .three {
    display:flex;
    flex-direction:column;
    text-align:center;
    align-items:center;
    justify-content:center;
}

#page_esg .chart_area .three .ko_title {
    font-size:30px;
    font-weight:500;
}

#page_esg .chart_area .three .en_title {
    font-size:30px;
    color:#898989;
}

#page_esg .sec_2 p.sub {
    font-size:18px;
}

#page_esg .sec_3 {
    background-color:#F5FAEF;
}

#page_esg .sec_3 h4,
#page_esg .sec_3 .subh4,
#page_esg .sec_3 .content_list li,
#page_esg .sec_3 .box p {
    color:#5B6C32;
}

#page_esg .sec_3 h5 {
    color:#7C8E51;
    font-size:35px;
    font-weight:700;
    padding:25px 0 18px;
    border-bottom:1px solid #7C8E51;
}

#page_esg .sec_3 .img {
    width:70%;
    max-width:568px;
    margin-bottom:80px;
}

#page_esg .sec_3 .wrap_box {
    border:1px solid #7C8E51;
    border-radius:30px;
    width:100%;
    max-width:790px;
}

#page_esg .sec_3 .box {
    padding:30px;
}

#page_esg .sec_4 {
    background-color:#FAF7F1;
}

#page_esg .sec_4 h4,
#page_esg .sec_4 .subh4,
#page_esg .sec_4 .content_list li,
#page_esg .sec_4 .box p {
    color:#7E6942;
}

#page_esg .sec_5 {
    background-color:#F7FCFD;
}

#page_esg .sec_5 h4,
#page_esg .sec_5 .subh4,
#page_esg .sec_5 .content_list li,
#page_esg .sec_5 .box p {
    color:#43696D;
}


@media all and (max-width:1379px) {
    .visual_line {
        margin-bottom:30px;
    }

}



@media all and (max-width:1024px) {
    .visual_line {
        height:100px;
    }

    h2 {
        font-size:32px;
    }
    
    .subh2 {
        font-size:21px;
    }

    .sec1_logo h3 {
        font-size:38px;
    }

    .sec1_logo .logo_txt {
        font-size:24px;
    }

    .sec1_logo {
        margin-bottom:100px;
    }


    .container.blank {
        padding:0;
        width:100%;
    }

    #page_esg .sec_1 {
        padding-top:80px;
    }

    #page_esg .sec_2 {
        padding-bottom:100px;
    }

    #page_esg .color {
        padding:50px 0;
        margin-bottom:40px;
    }

    #page_esg h4 {
        font-size:36px;
        margin-bottom:40px;
    }

    #page_esg .sec_3 h5 {
        font-size:24px;
    }

    #page_esg .subh4,
    #page_esg .content_list li {
        font-size:21px;
    }

    #page_esg .box p {
        font-size:18px;
    }

    #page_esg .color.last {
        margin-bottom:100px;
    }

}

@media all and (max-width:768px) {
    .visual {
        aspect-ratio:10 / 9;
    }

    .visual_line {
        height:60px;
        margin-bottom:20px;
    }

    h2 {
        font-size:20px;
    }
    
    .subh2 {
        font-size:15px;
        letter-spacing:-0.5px;
    }

    .sec1_logo h3 {
        font-size:30px;
        margin-bottom:20px;
    }

    .sec1_logo .logo_txt {
        font-size:15px;
    }

    .sec1_logo {
        margin-bottom:60px;
    }


    
    #page_esg .sec_1 {
        padding-top:50px;
    }

    #page_esg .sec_2 {
        padding-bottom:50px;
    }

    #page_esg .sec2_chart {
        width:480px;
        height:480px;
        margin-bottom:20px;
    }

    #page_esg .chart_area {
        width: calc(100% - 40px);
        height: calc(100% - 40px);
    }

    #page_esg .chart_area .three .ko_title,
    #page_esg .chart_area .three .en_title {
        font-size:21px;
    }

    #page_esg .sec_2 p.sub {
        font-size:15px;
    }

    #page_esg .color {
        padding:30px;
        margin-bottom:20px;
    }

    #page_esg h4 {
        font-size:20px;
        margin-bottom:20px;
    }

    #page_esg .sec_3 h5 {
        font-size:18px;
        padding:12px 0;
    }

    #page_esg .sec_3 .box {
        padding:18px;
    }

    html[lang="en"] #page_esg .sec_3 .box,
    html[lang="en"] #page_esg .sec_4 .box {
        text-align:left;
    }

    #page_esg .subh4 {
        margin-bottom:30px;
    }

    #page_esg .subh4,
    #page_esg .content_list li,
    #page_esg .box p {
        font-size:15px;
        word-break:keep-all;
    }

    html[lang="en"] #page_esg .content_list li,
    html[lang="ko"] #page_esg .content_list li {
        min-height:36px;
        line-height:140%;
        height:auto;
        padding:14px 0;
        margin-bottom:10px;
    }

    html[lang="en"] #page_esg .sec_3 .content_list li {
        justify-content: flex-start;
        text-align:left;
        padding:14px 8px;
    }

    #page_esg .content_list {
        margin-bottom:20px;
    }

    #page_esg .sec_3 .img {
        margin-bottom:30px;
    }

    #page_esg .color.last {
        margin-bottom:60px;
    }

}


@media all and (max-width:560px) {
    .sec1_logo h3 {
        font-size:20px;
    }

    #page_esg .sec2_chart {
        width:320px;
        height:320px;
    }

    #page_esg .chart_area {
        width: calc(100% - 30px);
        height: calc(100% - 30px);
    }

    #page_esg .chart_area .three .ko_title,
    #page_esg .chart_area .three .en_title {
        font-size:17px;
    }

    #page_esg .chart_area .three2,
    #page_esg .chart_area .three3 {
        padding-bottom:40px;
    }
}


@media all and (max-width:455px) {
    .sec1_logo .logo_txt br {
        display:none;
    }

    .sec1_logo h3 {
        word-break:keep-all;
    }

    #page_esg .subh4 br,
    #page_esg .sec_5 .box p br {
        display:none;
    }

    #page_esg .subh4,
    #page_esg .content_list li,
    #page_esg .box p {
        letter-spacing:-1px;
    }
}

@media all and (max-width:359px) {
    #page_esg .sec2_chart {
        width:290px;
        height:290px;
    }

}