@charset "UTF-8";
/* _default.scss */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.esg-btn-outline, .esg-layer-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .esg-btn-outline, .esg-layer-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .esg-btn-outline, .esg-layer-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.esg-btn-outline:hover, .esg-layer-link:hover, .esg-btn-outline:active, .esg-layer-link:active, .esg-btn-outline:focus, .esg-layer-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.esg-btn-outline .outlink-icon, .esg-layer-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.esg-btn-outline:hover .outlink-icon, .esg-layer-link:hover .outlink-icon, .esg-btn-outline:active .outlink-icon, .esg-layer-link:active .outlink-icon, .esg-btn-outline:focus .outlink-icon, .esg-layer-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.esg-slider-controls {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 1.875rem;
  margin-block-start: 1rem;
}
@media all and (min-width: 1440px) {
  .esg-slider-controls {
    margin-block-start: unset;
    gap: 1.25rem;
  }
}
.esg-slider-controls .esg-slider-prev,
.esg-slider-controls .esg-slider-next {
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 3rem;
  height: 2rem;
  padding: 0;
  border: 0.0625rem solid #222222;
  border-radius: 0.5rem;
  background-color: #FFFFFF;
  cursor: pointer;
  transition: opacity 0.3s, background-color 0.3s, border-color 0.3s;
}
@media all and (min-width: 1440px) {
  .esg-slider-controls .esg-slider-prev,
  .esg-slider-controls .esg-slider-next {
    width: 2.25rem;
    height: 2.25rem;
    border-radius: 50%;
    box-shadow: 0 0 1px 0 rgba(0, 0, 0, 0.36), 0 2px 8px 0 rgba(0, 0, 0, 0.08);
    border: 0;
  }
}
.esg-slider-controls .esg-slider-prev::after,
.esg-slider-controls .esg-slider-next::after {
  content: "";
  display: block;
  width: 1rem;
  height: 1rem;
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-nav.svg");
}
.esg-slider-controls .esg-slider-prev::after {
  transform: rotate(180deg);
}
.esg-slider-controls .esg-slider-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1rem;
  font-weight: 400;
  color: #000000;
  pointer-events: none;
}
@media all and (min-width: 1440px) {
  .esg-slider-controls .esg-slider-pagination {
    display: none;
  }
}
.esg-slider-controls .esg-slider-pagination .separator {
  width: 0.0625rem;
  height: 0.625rem;
  background-color: rgba(100, 100, 100, 0.4);
  margin-inline: 0.5rem;
}
.esg-slider-controls .esg-slider-pagination .swiper-pagination-current {
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 600;
  min-width: 0.5rem;
}
.esg-slider-controls .esg-slider-pagination .swiper-pagination-total {
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 400;
  color: #646464;
  min-width: 0.5rem;
}
.esg-slider-controls .esg-slider-pagination.swiper-pagination-fraction {
  position: static;
  width: auto;
  gap: 0.25rem;
}

:root {
  --esg-point-color: #ea1917;
}

.sr-only {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  clip-path: inset(50%);
  white-space: nowrap;
  border: 0;
}

body,
html {
  overflow-x: clip;
}

.sustainability-container {
  width: 100%;
  margin: 0 auto;
  background-color: #FFFFFF;
  overflow-x: clip;
}
.sustainability-container .swiper-wrapper {
  height: auto;
}
.sustainability-container .inner {
  width: 100%;
  max-width: 1380px;
  margin: 0 auto;
  padding: 0 1.25rem;
}
@media all and (min-width: 1440px) {
  .sustainability-container .inner {
    padding: 0;
  }
}
.sustainability-container * {
  scrollbar-width: auto;
  word-break: break-all;
}
.sustainability-container *::-webkit-scrollbar {
  background: rgba(0, 0, 0, 0.08); /* 스크롤바 뒷 배경 색상 */
  width: 0.1875rem;
  height: 0.1875rem;
}
.sustainability-container *::-webkit-scrollbar-thumb {
  background: #111111; /* 스크롤바 막대 색상 */
}
.sustainability-container .esg-section sup {
  top: 0;
}
.sustainability-container .esg-section > section + section {
  margin-block-start: calc(var(--esg-spacing-2xl) / 16 * 1rem);
}
.sustainability-container .esg-section.component-keyvisual {
  padding-block: 0;
}

[class*=component-] {
  --xxl-fs: 26;
  --xxl-lh: 38;
  --xxl-ls: -0.0192;
  --xl-fs: 17;
  --xl-lh: 24;
  --xl-ls: -0.0176;
  --lg-fs: 17;
  --lg-lh: 24;
  --lg-ls: -0.0176;
  --md-fs: 17;
  --md-lh: 24;
  --md-ls: -0.0176;
  --sm-fs: 16;
  --sm-lh: 22;
  --sm-ls: -0.0125;
  --xs-fs: 15;
  --xs-lh: 20;
  --xxs-fs: 13;
  --xxs-lh: 18;
  --border-radius: 12;
  --black-color: #000000;
  --default-color: #111111;
  --body-color: #444444;
  --gray-color: #646464;
  --light-gray-color: #727780;
  --invert-color: #fff;
  --fw-bold: 600;
  --fw-bold-white: 450;
  --fw-normal: 400;
  --fw-normal-white: 300;
}
@media all and (min-width: 768px) {
  [class*=component-] {
    --xxl-fs: 29;
    --xxl-lh: 41;
    --xxl-ls: -0.0174;
    --xl-fs: 21;
    --xl-lh: 28;
    --xl-ls: -0.0192;
    --lg-fs: 20;
    --lg-lh: 27;
    --lg-ls: -0.02;
    --md-fs: 19;
    --md-lh: 26;
    --md-ls: -0.011;
    --sm-fs: 16;
    --sm-lh: 22;
    --sm-ls: -0.0125;
    --xs-fs: 15;
    --xs-lh: 20;
    --xxs-fs: 13;
    --xxs-lh: 18;
    --border-radius: 16;
  }
}
@media all and (min-width: 1440px) {
  [class*=component-] {
    --xxl-fs: 32;
    --xxl-lh: 44;
    --xxl-ls: -0.0156;
    --xl-fs: 24;
    --xl-lh: 32;
    --xl-ls: -0.0208;
    --lg-fs: 22;
    --lg-lh: 30;
    --lg-ls: -0.0227;
    --md-fs: 20;
    --md-lh: 28;
    --md-ls: -0.004;
    --sm-fs: 16;
    --sm-lh: 22;
    --sm-ls: -0.0125;
    --xs-fs: 14;
    --xs-lh: 20;
    --xxs-fs: 13;
    --xxs-lh: 18;
    --border-radius: 16;
  }
}
[class*=component-] sup {
  position: relative;
  font-size: 60%;
}

[class*=cmp-] {
  --xxl-fs: 26;
  --xxl-lh: 38;
  --xxl-ls: -0.0192;
  --xl-fs: 17;
  --xl-lh: 24;
  --xl-ls: -0.0176;
  --lg-fs: 17;
  --lg-lh: 24;
  --lg-ls: -0.0176;
  --md-fs: 17;
  --md-lh: 24;
  --md-ls: -0.0176;
  --sm-fs: 16;
  --sm-lh: 22;
  --sm-ls: -0.0125;
  --xs-fs: 15;
  --xs-lh: 20;
  --xxs-fs: 13;
  --xxs-lh: 18;
  --border-radius: 12;
  --black-color: #000000;
  --default-color: #111111;
  --body-color: #444444;
  --gray-color: #646464;
  --light-gray-color: #727780;
  --invert-color: #fff;
  --fw-bold: 600;
  --fw-bold-white: 450;
  --fw-normal: 400;
  --fw-normal-white: 300;
}
@media all and (min-width: 768px) {
  [class*=cmp-] {
    --xxl-fs: 29;
    --xxl-lh: 41;
    --xxl-ls: -0.0174;
    --xl-fs: 21;
    --xl-lh: 28;
    --xl-ls: -0.0192;
    --lg-fs: 20;
    --lg-lh: 27;
    --lg-ls: -0.02;
    --md-fs: 19;
    --md-lh: 26;
    --md-ls: -0.011;
    --sm-fs: 16;
    --sm-lh: 22;
    --sm-ls: -0.0125;
    --xs-fs: 15;
    --xs-lh: 20;
    --xxs-fs: 13;
    --xxs-lh: 18;
    --border-radius: 16;
  }
}
@media all and (min-width: 1440px) {
  [class*=cmp-] {
    --xxl-fs: 32;
    --xxl-lh: 44;
    --xxl-ls: -0.0156;
    --xl-fs: 24;
    --xl-lh: 32;
    --xl-ls: -0.0208;
    --lg-fs: 22;
    --lg-lh: 30;
    --lg-ls: -0.0227;
    --md-fs: 20;
    --md-lh: 28;
    --md-ls: -0.004;
    --sm-fs: 16;
    --sm-lh: 22;
    --sm-ls: -0.0125;
    --xs-fs: 14;
    --xs-lh: 20;
    --xxs-fs: 13;
    --xxs-lh: 18;
    --border-radius: 16;
  }
}
[class*=cmp-] sup {
  position: relative;
  font-size: 60%;
}

.only-pc {
  display: none;
}
.only-tab {
  display: none;
}
.only-mo {
  display: block;
}
@media all and (min-width: 768px) {
  .only-mo {
    display: none;
  }
  .only-tab {
    display: block;
  }
  .only-pc {
    display: none;
  }
}
@media all and (min-width: 1440px) {
  .only-pc {
    display: block;
  }
  .only-tab {
    display: none;
  }
  .only-mo {
    display: none;
  }
}

.hidden-mo {
  display: none;
}
@media all and (min-width: 768px) {
  .hidden-mo {
    display: block;
  }
}
.hidden-ta {
  display: block;
}
@media all and (min-width: 768px) {
  .hidden-ta {
    display: none;
  }
}
@media all and (min-width: 1440px) {
  .hidden-ta {
    display: block;
  }
}
.hidden-pc {
  display: block;
}
@media all and (min-width: 1440px) {
  .hidden-pc {
    display: none;
  }
}

.esg-section {
  --esg-color-black: #000000;
  --esg-color-active-red: #ea1917;
  --esg-color-teal: #007798;
  --esg-color-brown: #A46026;
  --esg-color-text-01-basic: #111111;
  --esg-color-text-02-medium: #444444;
  --esg-color-text-03-light: #777777;
  --esg-color-body-01-line: #EBEBF0;
  --esg-color-body-02-divider: #F3F1F7;
  --esg-color-body-03-bg: #F9F9F7;
  --esg-color-box-01-bg---tinted-red: #F0F2F3;
  --esg-color-box-02-bg---tinted-gray: #F3F1F7;
  --esg-color-box-03-stroke---tinted-gray: #DDE1E5;
  --esg-color-g01: #0B0000;
  --esg-color-g02: #111111;
  --esg-color-g03: #555555;
  --esg-color-g04: #777777;
  --esg-color-g05: #8F8F8F;
  --esg-color-g06: #AAAAAA;
  --esg-color-g07: #BBBBBB;
  --esg-color-g08: #CCCCCC;
  --esg-color-g09: #DDDDDD;
  --esg-color-g10: #EEEEEE;
  --esg-color-g11: #F4F4F4;
  --esg-color-g12: #FAFAFA;
  --esg-color-g13: #FFFFFF;
  --esg-color-n01: #101722;
  --esg-color-n02: #212731;
  --esg-color-n03: #43474D;
  --esg-color-n04: #727780;
  --esg-color-n05: #DF9198;
  --esg-color-n06: #A5A8B1;
  --esg-color-n07: #BAC1C7;
  --esg-color-n08: #CBD0D5;
  --esg-color-n09: #DDE1E5;
  --esg-color-n10: #EFF0F2;
  --esg-color-n11: #F3F5F7;
  --esg-color-n12: #F9FAFB;
  --esg-color-2nd-red: #FF5C30;
  --esg-color-error: #FF371A;
  --esg-color-success: #0BA83A;
  --esg-color-ai-gradient: linear-gradient(90deg, #F2313E 0%, #FF145B 33%, #E232F9 66%, #8227FF 100%);
  --esg-color-primary-text-01: #646464;
  --esg-color-esg-lg-green-light: #C8E4C9;
  --esg-color-esg-lg-green: #60984D;
  --esg-color-esg-lg-green-dark: #04563F;
  --esg-color-esg-lg-teal-light: #BFF3EA;
  --esg-color-esg-lg-teal: #7CCCBF;
  --esg-color-esg-lg-teal-dark: #48A2A8;
  --esg-color-esg-lg-yellow-light: #FFF2AF;
  --esg-color-esg-lg-yellow: #F4DC00;
  --esg-color-esg-lg-yellow-dark: #E2BA2C;
  --esg-color-esg-lg-orange-light: #FFBB83;
  --esg-color-esg-lg-orange: #F49045;
  --esg-color-esg-lg-orange-dark: #C35C11;
  --esg-color-esg-lg-lilac-light: #D6C1FA;
  --esg-color-esg-lg-lilac: #B58CE8;
  --esg-color-esg-lg-lilac-dark: #70369B;
  --esg-color-esg-lg-purple-light: #E5BFEC;
  --esg-color-esg-lg-purple: #98329F;
  --esg-color-esg-lg-purple-dark: #681F69;
  --esg-spacing-4xl: 56;
  --esg-spacing-3xl: 56;
  --esg-spacing-2xl: 24;
  --esg-spacing-xl: 20;
  --esg-spacing-l: 16;
  --esg-spacing-m: 12;
  --esg-spacing-s: 8;
  --esg-spacing-xs: 4;
  --esg-font-heading-1-fs: 26;
  --esg-font-heading-1-lh: 38;
  --esg-font-heading-1-fw: 600;
  --esg-font-heading-1-ls: -0.5px;
  --esg-font-heading-2-fs: 24;
  --esg-font-heading-2-lh: 32;
  --esg-font-heading-2-fw: 600;
  --esg-font-heading-2-ls: -0.5px;
  --esg-font-heading-3-fs: 20;
  --esg-font-heading-3-lh: 28;
  --esg-font-heading-3-fw: 600;
  --esg-font-heading-3-ls: -0.4px;
  --esg-font-heading-4-fs: 20;
  --esg-font-heading-4-lh: 28;
  --esg-font-heading-4-fw: 600;
  --esg-font-heading-4-ls: -0.4px;
  --esg-font-heading-5-fs: 17;
  --esg-font-heading-5-lh: 24;
  --esg-font-heading-5-fw: 600;
  --esg-font-heading-5-ls: -0.3px;
  --esg-font-heading-6-fs: 15;
  --esg-font-heading-6-lh: 20;
  --esg-font-heading-6-fw: 600;
  --esg-font-heading-6-ls: -0.2px;
  --esg-font-heading-7-fs: 15;
  --esg-font-heading-7-lh: 20;
  --esg-font-heading-7-fw: 600;
  --esg-font-heading-7-ls: -0.2px;
  --esg-font-body-1-fs: 15;
  --esg-font-body-1-lh: 20;
  --esg-font-body-1-ls: -0.2px;
  --esg-font-body-2-fs: 15;
  --esg-font-body-2-lh: 20;
  --esg-font-body-2-ls: -0.2px;
  --esg-font-body-3-fs: 15;
  --esg-font-body-3-lh: 20;
  --esg-font-body-3-ls: -0.2px;
  --esg-font-eyebrow-l-fs: 15;
  --esg-font-eyebrow-l-lh: 20;
  --esg-font-eyebrow-l-ls: -0.2px;
  --esg-font-eyebrow-l-fw: 600;
  --esg-font-eyebrow-s-fs: 13;
  --esg-font-eyebrow-s-lh: 18;
  --esg-font-eyebrow-s-ls: 0px;
  --esg-font-disclaimer-fs: 13;
  --esg-font-disclaimer-lh: 18;
  --esg-font-disclaimer-cl: #646464;
  --esg-font-disclaimer-ls: 0px;
  --esg-font-table-th-fs: 15;
  --esg-font-table-th-lh: 20;
  --esg-font-table-th-ls: -0.2px;
  --esg-font-table-td-fs: 15;
  --esg-font-table-td-lh: 20;
  --esg-font-table-td-ls: -0.2px;
  --esg-radius-round: 12;
}
@media all and (min-width: 768px) {
  .esg-section {
    --esg-spacing-4xl: 80;
    --esg-spacing-3xl: 64;
    --esg-spacing-2xl: 32;
    --esg-spacing-xl: 24;
    --esg-spacing-l: 16;
    --esg-spacing-m: 12;
    --esg-spacing-s: 8;
    --esg-spacing-xs: 6;
    --esg-font-heading-1-fs: 28;
    --esg-font-heading-1-lh: 40;
    --esg-font-heading-2-fs: 26;
    --esg-font-heading-2-lh: 34;
    --esg-font-heading-3-fs: 22;
    --esg-font-heading-3-lh: 30;
    --esg-font-heading-4-fs: 20;
    --esg-font-heading-4-lh: 30;
    --esg-font-heading-5-fs: 18;
    --esg-font-heading-5-lh: 26;
    --esg-font-heading-6-fs: 17;
    --esg-font-heading-6-lh: 24;
    --esg-font-heading-7-fs: 17;
    --esg-font-heading-7-lh: 24;
    --esg-font-body-1-fs: 16;
    --esg-font-body-1-lh: 21;
    --esg-font-eyebrow-l-fs: 14;
    --esg-font-eyebrow-l-lh: 20;
    --esg-font-eyebrow-s-fs: 13;
    --esg-font-eyebrow-s-lh: 18;
    --esg-font-disclaimer-fs: 13;
    --esg-font-disclaimer-lh: 18;
    --esg-font-table-th-fs: 16;
    --esg-font-table-th-lh: 22;
    --esg-font-table-td-fs: 16;
    --esg-font-table-td-lh: 22;
  }
}
@media all and (min-width: 1440px) {
  .esg-section {
    --esg-spacing-4xl: 120;
    --esg-spacing-3xl: 80;
    --esg-spacing-2xl: 40;
    --esg-spacing-xl: 24;
    --esg-spacing-l: 20;
    --esg-spacing-m: 12;
    --esg-spacing-s: 8;
    --esg-spacing-xs: 8;
    --esg-font-heading-1-fs: 32;
    --esg-font-heading-1-lh: 44;
    --esg-font-heading-2-fs: 28;
    --esg-font-heading-2-lh: 38;
    --esg-font-heading-3-fs: 24;
    --esg-font-heading-3-lh: 32;
    --esg-font-heading-3-ls: -0.5px;
    --esg-font-heading-4-fs: 22;
    --esg-font-heading-4-lh: 32;
    --esg-font-heading-4-ls: -0.5px;
    --esg-font-heading-5-fs: 22;
    --esg-font-heading-5-lh: 30;
    --esg-font-heading-5-ls: -0.4px;
    --esg-font-heading-6-fs: 20;
    --esg-font-heading-6-lh: 28;
    --esg-font-heading-6-ls: -0.4px;
    --esg-font-heading-7-fs: 20;
    --esg-font-heading-7-lh: 28;
    --esg-font-heading-7-ls: -0.4px;
    --esg-font-body-1-fs: 17;
    --esg-font-body-1-lh: 22;
    --esg-font-eyebrow-l-fs: 14;
    --esg-font-eyebrow-l-lh: 20;
    --esg-font-eyebrow-l-ls: 0;
    --esg-font-eyebrow-s-fs: 13;
    --esg-font-eyebrow-s-lh: 18;
    --esg-font-disclaimer-fs: 13;
    --esg-font-disclaimer-lh: 18;
    --esg-font-table-th-fs: 16;
    --esg-font-table-th-lh: 22;
    --esg-font-table-td-fs: 16;
    --esg-font-table-td-lh: 22;
    --esg-radius-round: 16;
  }
}
.esg-section {
  padding-block: calc(var(--esg-spacing-3xl) / 16 * 1rem);
  background-color: #FFFFFF;
}
.esg-section:not(:has(~ .esg-section)) {
  padding-block-end: calc(var(--esg-spacing-4xl) / 16 * 1rem);
}
.esg-section.component-keyvisual {
  padding-block: 0;
}
.esg-section.esg-bg-secondary {
  background-color: #F4F4F4;
}
.esg-section.no-padding-top {
  padding-block-start: 0;
}
.esg-section.no-padding-bottom {
  padding-block-end: 0;
}
.esg-section sup {
  font-size: 60%;
  vertical-align: super;
}
.esg-section.margin-4xl,
.esg-section .margin-4xl {
  margin-block: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.padding-4xl,
.esg-section .padding-4xl {
  padding-block: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.margin-4xl-top,
.esg-section .margin-4xl-top {
  margin-top: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.padding-4xl-top,
.esg-section .padding-4xl-top {
  padding-top: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.margin-4xl-bottom,
.esg-section .margin-4xl-bottom {
  margin-bottom: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.padding-4xl-bottom,
.esg-section .padding-4xl-bottom {
  padding-bottom: calc(var(--esg-spacing-4xl) * 0.0625rem);
}
.esg-section.margin-3xl,
.esg-section .margin-3xl {
  margin-block: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.padding-3xl,
.esg-section .padding-3xl {
  padding-block: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.margin-3xl-top,
.esg-section .margin-3xl-top {
  margin-top: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.padding-3xl-top,
.esg-section .padding-3xl-top {
  padding-top: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.margin-3xl-bottom,
.esg-section .margin-3xl-bottom {
  margin-bottom: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.padding-3xl-bottom,
.esg-section .padding-3xl-bottom {
  padding-bottom: calc(var(--esg-spacing-3xl) * 0.0625rem);
}
.esg-section.margin-2xl,
.esg-section .margin-2xl {
  margin-block: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.padding-2xl,
.esg-section .padding-2xl {
  padding-block: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.margin-2xl-top,
.esg-section .margin-2xl-top {
  margin-top: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.padding-2xl-top,
.esg-section .padding-2xl-top {
  padding-top: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.margin-2xl-bottom,
.esg-section .margin-2xl-bottom {
  margin-bottom: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.padding-2xl-bottom,
.esg-section .padding-2xl-bottom {
  padding-bottom: calc(var(--esg-spacing-2xl) * 0.0625rem);
}
.esg-section.margin-xl,
.esg-section .margin-xl {
  margin-block: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.padding-xl,
.esg-section .padding-xl {
  padding-block: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.margin-xl-top,
.esg-section .margin-xl-top {
  margin-top: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.padding-xl-top,
.esg-section .padding-xl-top {
  padding-top: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.margin-xl-bottom,
.esg-section .margin-xl-bottom {
  margin-bottom: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.padding-xl-bottom,
.esg-section .padding-xl-bottom {
  padding-bottom: calc(var(--esg-spacing-xl) * 0.0625rem);
}
.esg-section.margin-l,
.esg-section .margin-l {
  margin-block: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.padding-l,
.esg-section .padding-l {
  padding-block: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.margin-l-top,
.esg-section .margin-l-top {
  margin-top: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.padding-l-top,
.esg-section .padding-l-top {
  padding-top: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.margin-l-bottom,
.esg-section .margin-l-bottom {
  margin-bottom: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.padding-l-bottom,
.esg-section .padding-l-bottom {
  padding-bottom: calc(var(--esg-spacing-l) * 0.0625rem);
}
.esg-section.margin-m,
.esg-section .margin-m {
  margin-block: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.padding-m,
.esg-section .padding-m {
  padding-block: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.margin-m-top,
.esg-section .margin-m-top {
  margin-top: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.padding-m-top,
.esg-section .padding-m-top {
  padding-top: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.margin-m-bottom,
.esg-section .margin-m-bottom {
  margin-bottom: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.padding-m-bottom,
.esg-section .padding-m-bottom {
  padding-bottom: calc(var(--esg-spacing-m) * 0.0625rem);
}
.esg-section.margin-s,
.esg-section .margin-s {
  margin-block: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.padding-s,
.esg-section .padding-s {
  padding-block: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.margin-s-top,
.esg-section .margin-s-top {
  margin-top: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.padding-s-top,
.esg-section .padding-s-top {
  padding-top: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.margin-s-bottom,
.esg-section .margin-s-bottom {
  margin-bottom: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.padding-s-bottom,
.esg-section .padding-s-bottom {
  padding-bottom: calc(var(--esg-spacing-s) * 0.0625rem);
}
.esg-section.margin-xs,
.esg-section .margin-xs {
  margin-block: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section.padding-xs,
.esg-section .padding-xs {
  padding-block: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section.margin-xs-top,
.esg-section .margin-xs-top {
  margin-top: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section.padding-xs-top,
.esg-section .padding-xs-top {
  padding-top: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section.margin-xs-bottom,
.esg-section .margin-xs-bottom {
  margin-bottom: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section.padding-xs-bottom,
.esg-section .padding-xs-bottom {
  padding-bottom: calc(var(--esg-spacing-xs) * 0.0625rem);
}
.esg-section .font-heading-1 {
  font-size: calc(var(--esg-font-heading-1-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-1-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-1-fw, 400);
  color: var(--esg-font-heading-1-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-1-ls, 0) * 1em);
}
.esg-section .font-heading-2 {
  font-size: calc(var(--esg-font-heading-2-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-2-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-2-fw, 400);
  color: var(--esg-font-heading-2-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-2-ls, 0) * 1em);
}
.esg-section .font-heading-3 {
  font-size: calc(var(--esg-font-heading-3-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-3-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-3-fw, 400);
  color: var(--esg-font-heading-3-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-3-ls, 0) * 1em);
}
.esg-section .font-heading-4 {
  font-size: calc(var(--esg-font-heading-4-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-4-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-4-fw, 400);
  color: var(--esg-font-heading-4-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-4-ls, 0) * 1em);
}
.esg-section .font-heading-5 {
  font-size: calc(var(--esg-font-heading-5-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-5-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-5-fw, 400);
  color: var(--esg-font-heading-5-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-5-ls, 0) * 1em);
}
.esg-section .font-heading-6 {
  font-size: calc(var(--esg-font-heading-6-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-6-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-6-fw, 400);
  color: var(--esg-font-heading-6-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-6-ls, 0) * 1em);
}
.esg-section .font-heading-7 {
  font-size: calc(var(--esg-font-heading-7-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-heading-7-lh) * 0.0625rem);
  font-weight: var(--esg-font-heading-7-fw, 400);
  color: var(--esg-font-heading-7-cl, #111111);
  letter-spacing: calc(var(--esg-font-heading-7-ls, 0) * 1em);
}
.esg-section .font-body-1 {
  font-size: calc(var(--esg-font-body-1-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-body-1-lh) * 0.0625rem);
  font-weight: var(--esg-font-body-1-fw, 400);
  color: var(--esg-font-body-1-cl, #111111);
  letter-spacing: calc(var(--esg-font-body-1-ls, 0) * 1em);
}
.esg-section .font-body-2 {
  font-size: calc(var(--esg-font-body-2-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-body-2-lh) * 0.0625rem);
  font-weight: var(--esg-font-body-2-fw, 400);
  color: var(--esg-font-body-2-cl, #111111);
  letter-spacing: calc(var(--esg-font-body-2-ls, 0) * 1em);
}
.esg-section .font-body-3 {
  font-size: calc(var(--esg-font-body-3-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-body-3-lh) * 0.0625rem);
  font-weight: var(--esg-font-body-3-fw, 400);
  color: var(--esg-font-body-3-cl, #111111);
  letter-spacing: calc(var(--esg-font-body-3-ls, 0) * 1em);
}
.esg-section .font-eyebrow-l {
  font-size: calc(var(--esg-font-eyebrow-l-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-eyebrow-l-lh) * 0.0625rem);
  font-weight: var(--esg-font-eyebrow-l-fw, 400);
  color: var(--esg-font-eyebrow-l-cl, #111111);
  letter-spacing: calc(var(--esg-font-eyebrow-l-ls, 0) * 1em);
}
.esg-section .font-eyebrow-s {
  font-size: calc(var(--esg-font-eyebrow-s-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) * 0.0625rem);
  font-weight: var(--esg-font-eyebrow-s-fw, 400);
  color: var(--esg-font-eyebrow-s-cl, #111111);
  letter-spacing: calc(var(--esg-font-eyebrow-s-ls, 0) * 1em);
}
.esg-section .font-disclaimer-fs {
  font-size: calc(var(--esg-font-disclaimer-fs-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-disclaimer-fs-lh) * 0.0625rem);
  font-weight: var(--esg-font-disclaimer-fs-fw, 400);
  color: var(--esg-font-disclaimer-fs-cl, #111111);
  letter-spacing: calc(var(--esg-font-disclaimer-fs-ls, 0) * 1em);
}
.esg-section .font-disclaimer-lh {
  font-size: calc(var(--esg-font-disclaimer-lh-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-disclaimer-lh-lh) * 0.0625rem);
  font-weight: var(--esg-font-disclaimer-lh-fw, 400);
  color: var(--esg-font-disclaimer-lh-cl, #111111);
  letter-spacing: calc(var(--esg-font-disclaimer-lh-ls, 0) * 1em);
}
.esg-section .font-disclaimer-cl {
  font-size: calc(var(--esg-font-disclaimer-cl-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-disclaimer-cl-lh) * 0.0625rem);
  font-weight: var(--esg-font-disclaimer-cl-fw, 400);
  color: var(--esg-font-disclaimer-cl-cl, #111111);
  letter-spacing: calc(var(--esg-font-disclaimer-cl-ls, 0) * 1em);
}
.esg-section .font-disclaimer-ls {
  font-size: calc(var(--esg-font-disclaimer-ls-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-disclaimer-ls-lh) * 0.0625rem);
  font-weight: var(--esg-font-disclaimer-ls-fw, 400);
  color: var(--esg-font-disclaimer-ls-cl, #111111);
  letter-spacing: calc(var(--esg-font-disclaimer-ls-ls, 0) * 1em);
}
.esg-section .font-table-th {
  font-size: calc(var(--esg-font-table-th-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-table-th-lh) * 0.0625rem);
  font-weight: var(--esg-font-table-th-fw, 400);
  color: var(--esg-font-table-th-cl, #111111);
  letter-spacing: calc(var(--esg-font-table-th-ls, 0) * 1em);
}
.esg-section .font-table-td {
  font-size: calc(var(--esg-font-table-td-fs) * 0.0625rem);
  line-height: calc(var(--esg-font-table-td-lh) * 0.0625rem);
  font-weight: var(--esg-font-table-td-fw, 400);
  color: var(--esg-font-table-td-cl, #111111);
  letter-spacing: calc(var(--esg-font-table-td-ls, 0) * 1em);
}

.component-anchor + .esg-section,
.pin-spacer + .esg-section,
.sustainability-keyvisual + .esg-section {
  padding-block-start: calc(var(--esg-spacing-4xl) / 16 * 1rem);
}

.esg-title-main {
  font-size: calc(var(--esg-font-heading-1-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-1-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-1-fw);
  letter-spacing: var(--esg-font-heading-1-ls);
  color: #111111;
}
.esg-title-lead {
  font-size: calc(var(--esg-font-heading-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-3-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-3-fw);
  letter-spacing: var(--esg-font-heading-3-ls);
  color: #111111;
}
.esg-title-desc {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  color: #444444;
}
.esg-title-sub {
  font-size: calc(var(--esg-font-heading-4-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-4-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-4-fw);
  letter-spacing: var(--esg-font-heading-4-ls);
  color: #111111;
}
.esg-topic {
  font-size: calc(var(--esg-font-heading-5-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-5-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-5-fw);
  letter-spacing: var(--esg-font-heading-5-ls);
  color: #111111;
}
.esg-desc {
  font-size: calc(var(--esg-font-body-1-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-1-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-1-ls);
  color: #444444;
}
.esg-body-l {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  color: #444444;
}
.esg-body-s {
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-3-ls);
  color: #444444;
}
.esg-eyebrow-l {
  font-size: calc(var(--esg-font-eyebrow-l-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-l-lh) / 16 * 1rem);
  font-weight: var(--esg-font-eyebrow-l-fw);
  letter-spacing: var(--esg-font-eyebrow-l-ls);
}
.esg-eyebrow-s {
  font-size: calc(var(--esg-font-eyebrow-s-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-eyebrow-s-ls);
}
.esg-disclaimer {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
}
.esg-heading-group {
  margin-block-end: calc(var(--esg-spacing-2xl) / 16 * 1rem);
}
.esg-heading-group:has(> .esg-heading-sub-group) {
  margin-block-end: calc(var(--esg-spacing-xl) / 16 * 1rem);
}
.esg-heading-group > * + * {
  margin-block-start: calc(var(--esg-spacing-s) / 16 * 1rem);
}
.esg-heading-group > .esg-title-main + .esg-title-desc {
  margin-block-start: calc(var(--esg-spacing-m) / 16 * 1rem);
}
.esg-heading-group > * + .esg-heading-sub-group {
  margin-block-start: calc(var(--esg-spacing-2xl) / 16 * 1rem);
}
.esg-heading-group > .esg-disclaimer {
  margin-block-start: calc(var(--esg-spacing-m) / 16 * 1rem);
}
.esg-heading-group > .esg-disclaimer + esg-link {
  margin-block-start: calc(var(--esg-spacing-s) / 16 * 1rem);
}
.esg-heading-group > .esg-link {
  margin-block-start: calc(var(--esg-spacing-xl) / 16 * 1rem);
}
.esg-heading-group > .esg-title-lead + * {
  margin-block-start: calc(var(--esg-spacing-2xl) / 16 * 1rem);
}
.esg-heading-sub-group {
  display: flex;
  flex-direction: column;
  gap: calc(var(--esg-spacing-xs) / 16 * 1rem);
}
.esg-link {
  display: flex;
  flex-direction: column;
  gap: calc(var(--esg-spacing-s) / 16 * 1rem);
}
@media all and (min-width: 1440px) {
  .esg-link {
    flex-direction: row;
  }
}
.esg-text-white {
  color: #FFFFFF;
}
.esg-common-round {
  border-radius: calc(var(--esg-radius-round) * 0.0625rem);
  overflow: hidden;
}
.esg-img-wrapper {
  display: block;
  width: 100%;
}
.esg-img-wrapper img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.esg-layer {
  --title-color: #111;
  --body-color: #444;
  --gray-color: #646464;
  --invert-color: #fff;
  --font-bold: 600;
}
.esg-layer-eyebrow-l {
  font-size: calc(var(--esg-font-eyebrow-l-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-l-lh) / 16 * 1rem);
  font-weight: var(--esg-font-eyebrow-l-fw);
  letter-spacing: var(--esg-font-eyebrow-l-ls);
}
.esg-layer-title-main {
  font-size: calc(var(--esg-font-heading-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-2-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-2-fw);
  letter-spacing: var(--esg-font-heading-2-ls);
  color: var(--title-color);
}
.esg-layer-title-sub {
  font-size: calc(var(--esg-font-heading-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-3-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-3-fw);
  letter-spacing: var(--esg-font-heading-3-ls);
  color: var(--title-color);
}
.esg-layer-title-third {
  font-size: calc(var(--esg-font-heading-7-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-7-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-7-fw);
  letter-spacing: var(--esg-font-heading-7-ls);
  color: var(--title-color);
}
.esg-layer-title-body {
  font-size: 1rem;
  line-height: 1.375;
  font-weight: 600;
  color: var(--body-color);
  display: block;
  margin-top: 1rem;
  margin-bottom: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-body {
    margin-bottom: 0.5rem;
  }
}
.esg-layer-body-list {
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-body-list {
    gap: 0.5rem;
  }
}
.esg-layer-body-list-item {
  display: block;
}
.esg-layer-body-l {
  font-size: calc(var(--esg-font-body-1-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-1-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-1-ls);
  color: var(--body-color);
}
.esg-layer-body-m {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  color: var(--body-color);
}
.esg-layer-body-s {
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-3-ls);
  color: var(--body-color);
}
.esg-layer-specs-list {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-specs-list {
    gap: 0.5rem;
  }
}
.esg-layer-specs-item {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  position: relative;
  padding-left: 1.5rem;
  color: var(--body-color);
}
@media all and (min-width: 768px) {
  .esg-layer-specs-item {
    padding-left: 1.875rem;
  }
}
.esg-layer-specs-item::before {
  content: "•";
  position: absolute;
  left: 0;
  width: 1.5rem;
  text-align: center;
  color: var(--body-color);
}
@media all and (min-width: 768px) {
  .esg-layer-specs-item::before {
    width: 1.875rem;
  }
}
.esg-layer-disclaimer {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: var(--gray-color);
}
.esg-layer-disclaimer-list {
  margin-block-start: 1rem;
}
.esg-layer-disclaimer-list-title {
  font-size: calc(var(--esg-font-eyebrow-l-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-l-lh) / 16 * 1rem);
  font-weight: var(--esg-font-eyebrow-l-fw);
  letter-spacing: var(--esg-font-eyebrow-l-ls);
  color: var(--gray-color);
}
.esg-layer-disclaimer-list-wrap {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-block: 0.25rem;
}
.esg-layer-disclaimer-list-wrap li {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: var(--gray-color);
  position: relative;
  padding-left: 1.5rem;
  color: var(--gray-color);
}
@media all and (min-width: 768px) {
  .esg-layer-disclaimer-list-wrap li {
    padding-left: 1.875rem;
  }
}
.esg-layer-disclaimer-list-wrap li::before {
  content: "•";
  position: absolute;
  left: 0;
  width: 1.5rem;
  text-align: center;
  color: var(--gray-color);
}
@media all and (min-width: 768px) {
  .esg-layer-disclaimer-list-wrap li::before {
    width: 1.875rem;
  }
}
.esg-layer-two-media {
  display: flex;
  width: 100%;
  flex-direction: column;
  gap: 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer-two-media {
    flex-direction: row;
    gap: 0.75rem;
  }
}
.esg-layer-media {
  position: relative;
  width: 100%;
  overflow: hidden;
  flex-shrink: 0;
  order: -1;
}
.esg-layer-media .video-wrapper,
.esg-layer-media iframe {
  width: 100%;
  height: 100%;
  display: block;
  overflow: hidden;
}
.esg-layer-media img,
.esg-layer-media video {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.esg-layer-cta.center {
  text-align: center;
  margin-block: auto;
}
.esg-layer-link {
  text-align: center;
}
.esg-layer-title-main + .esg-layer-body-m, .esg-layer-title-main + .esg-layer-body-l, .esg-layer-title-main + .esg-layer-body-list {
  margin-top: 0.5rem;
}
.esg-layer-title-main + .esg-layer-media, .esg-layer-title-main + .esg-layer-two-media {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-main + .esg-layer-media, .esg-layer-title-main + .esg-layer-two-media {
    margin-top: 1.5rem;
  }
}
.esg-layer-title-third + .esg-layer-body-m, .esg-layer-title-sub + .esg-layer-body-m, .esg-layer-title-third + .esg-layer-body-list, .esg-layer-title-sub + .esg-layer-body-list {
  margin-top: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-third + .esg-layer-body-m, .esg-layer-title-sub + .esg-layer-body-m, .esg-layer-title-third + .esg-layer-body-list, .esg-layer-title-sub + .esg-layer-body-list {
    margin-top: 0.5rem;
  }
}
.esg-layer-title-sub + .esg-layer-title-sub, .esg-layer-title-third + .esg-layer-title-third {
  margin-top: 0.5rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-sub + .esg-layer-title-sub, .esg-layer-title-third + .esg-layer-title-third {
    margin-top: 1rem;
  }
}
.esg-layer-title-third + .esg-layer-specs-list, .esg-layer-title-main + .esg-layer-specs, .esg-layer-title-sub + .esg-layer-specs {
  margin-top: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-third + .esg-layer-specs-list, .esg-layer-title-main + .esg-layer-specs, .esg-layer-title-sub + .esg-layer-specs {
    margin-top: 0.5rem;
  }
}
.esg-layer-title-sub + .esg-layer-body-s, .esg-layer-body-s + .esg-layer-body-s {
  margin-top: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-title-sub + .esg-layer-body-s, .esg-layer-body-s + .esg-layer-body-s {
    margin-top: 0.25rem;
  }
}
.esg-layer-body-m + .esg-layer-body-m {
  margin-top: 0.5rem;
}
@media all and (min-width: 768px) {
  .esg-layer-body-m + .esg-layer-body-m {
    margin-top: 1rem;
  }
}
.esg-layer-media + .esg-layer-title-main, .esg-layer-two-media + .esg-layer-title-main {
  margin-top: 1.5rem;
}
@media all and (min-width: 768px) {
  .esg-layer-media + .esg-layer-title-main, .esg-layer-two-media + .esg-layer-title-main {
    margin-top: 3rem;
  }
}
.esg-layer-media + .esg-layer-title-sub, .esg-layer-body-m + .esg-layer-media, .esg-layer-body-list + .esg-layer-media, .esg-layer-two-media + .esg-layer-title-sub, .esg-layer-body-m + .esg-layer-two-media, .esg-layer-body-list + .esg-layer-title-sub {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer-media + .esg-layer-title-sub, .esg-layer-body-m + .esg-layer-media, .esg-layer-body-list + .esg-layer-media, .esg-layer-two-media + .esg-layer-title-sub, .esg-layer-body-m + .esg-layer-two-media, .esg-layer-body-list + .esg-layer-title-sub {
    margin-top: 1.5rem;
  }
}
.esg-layer-media + .esg-layer-body-m, .esg-layer-two-media + .esg-layer-body-m, .esg-layer-media + .esg-layer-body-list, .esg-layer-two-media + .esg-layer-body-list {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer-media + .esg-layer-body-m, .esg-layer-two-media + .esg-layer-body-m, .esg-layer-media + .esg-layer-body-list, .esg-layer-two-media + .esg-layer-body-list {
    margin-top: 1.5rem;
  }
}
.esg-layer-body-m + .esg-layer-specs, .esg-layer-body-list + .esg-layer-specs {
  margin-top: 0.25rem;
}
@media all and (min-width: 768px) {
  .esg-layer-body-m + .esg-layer-specs, .esg-layer-body-list + .esg-layer-specs {
    margin-top: 0.5rem;
  }
}
.esg-layer-media + .esg-layer-disclaimer, .esg-layer-media + div > .esg-layer-disclaimer:first-child, .esg-layer-two-media + .esg-layer-disclaimer, .esg-layer-two-media + div > .esg-layer-disclaimer:first-child, .esg-layer-body-m + .esg-layer-disclaimer, .esg-layer-body-m + div > .esg-layer-disclaimer:first-child, .esg-layer-body-list + .esg-layer-disclaimer, .esg-layer-body-list + div > .esg-layer-disclaimer:first-child, .esg-layer-specs + .esg-layer-disclaimer, .esg-layer-specs + div > .esg-layer-disclaimer:first-child {
  margin-top: 0.75rem;
}
.esg-layer-disclaimer + .esg-layer-disclaimer {
  margin-top: 0.25rem;
}
.esg-layer-body-m + .esg-layer-cta, .esg-layer-body-list + .esg-layer-cta {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer-body-m + .esg-layer-cta, .esg-layer-body-list + .esg-layer-cta {
    margin-top: 1.5rem;
  }
}

/* layer */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.esg-layer {
  position: fixed;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 9999;
  display: none;
  overflow: hidden;
  padding: 0 !important;
  background-color: transparent !important;
}
.esg-layer[aria-hidden=false] {
  display: block;
}
.esg-layer .layer-dimmed {
  width: 100%;
  height: 100%;
  position: absolute;
  top: 0;
  left: 0;
  background-color: rgba(0, 0, 0, 0.5);
  cursor: pointer;
}
.esg-layer .layer-container {
  display: flex;
  flex-direction: column;
  width: 100%;
  max-width: 64rem;
  height: 100%;
  position: absolute;
  inset: 0;
  margin: auto;
  z-index: 1;
  background-color: #FFFFFF;
  overflow: hidden;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-container {
    width: calc(100% - 2rem);
    height: calc(100vh - 5rem);
    border-radius: 0.75rem;
  }
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-container {
    height: calc(100vh - 10rem);
    border-radius: 1rem;
  }
}
.esg-layer .layer-fixed {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  padding-block: 0.5rem 1.5rem;
  position: sticky;
  top: 0;
  z-index: 10;
  background-color: #FFFFFF;
  font-family: "LGEI Headline", sans-serif;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed {
    padding-block: 0.75rem 1.5rem;
  }
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-fixed {
    padding-block: 1rem 1.5rem;
  }
}
.esg-layer .layer-fixed .layer-close-btn {
  width: 2rem;
  height: 2rem;
  margin-left: auto;
  margin-right: 0.5rem;
  cursor: pointer;
}
.esg-layer .layer-fixed .layer-close-btn img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-close-btn {
    margin-right: 1rem;
  }
}
.esg-layer .layer-fixed .layer-header {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  position: relative;
  margin-top: 0.5rem;
  padding: 0 1rem;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-header {
    align-items: flex-end;
    margin-top: 0;
    padding: 0 3rem;
  }
  .esg-layer .layer-fixed .layer-header:has(.layer-title:only-child) {
    align-items: center;
  }
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev, .esg-layer .layer-fixed .layer-header .layer-btn-next {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  width: auto;
  height: 2.25rem;
  padding: 0;
  border: none;
  background-color: transparent;
  transition: opacity 0.3s;
  cursor: pointer;
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev.is-hidden, .esg-layer .layer-fixed .layer-header .layer-btn-next.is-hidden {
  opacity: 0;
  pointer-events: none;
  visibility: hidden;
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev::before, .esg-layer .layer-fixed .layer-header .layer-btn-prev::after, .esg-layer .layer-fixed .layer-header .layer-btn-next::before, .esg-layer .layer-fixed .layer-header .layer-btn-next::after {
  content: "";
  display: none;
  flex-shrink: 0;
  width: 2.25rem;
  height: 2.25rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-layer-nav.svg");
  background-repeat: no-repeat;
  background-position: center;
  background-size: contain;
  transition: background-image 0.3s;
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev .layer-nav-label, .esg-layer .layer-fixed .layer-header .layer-btn-next .layer-nav-label {
  position: absolute;
  width: 1px;
  height: 1px;
  padding: 0;
  margin: -1px;
  overflow: hidden;
  clip: rect(0, 0, 0, 0);
  border: 0;
  font-size: 1.0625rem;
  line-height: 1.2941;
  font-weight: 600;
  color: #262626;
  white-space: nowrap;
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-fixed .layer-header .layer-btn-prev .layer-nav-label, .esg-layer .layer-fixed .layer-header .layer-btn-next .layer-nav-label {
    position: static;
    width: auto;
    height: auto;
    padding: 0;
    margin: 0;
    overflow: visible;
    clip: auto;
    border: 0;
  }
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev:hover::before, .esg-layer .layer-fixed .layer-header .layer-btn-prev:hover::after, .esg-layer .layer-fixed .layer-header .layer-btn-next:hover::before, .esg-layer .layer-fixed .layer-header .layer-btn-next:hover::after {
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-layer-nav-hover.svg");
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev:hover .layer-nav-label, .esg-layer .layer-fixed .layer-header .layer-btn-next:hover .layer-nav-label {
  color: #000;
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev {
  justify-self: start;
}
.esg-layer .layer-fixed .layer-header .layer-btn-prev::before {
  display: block;
  transform: rotate(180deg);
}
.esg-layer .layer-fixed .layer-header .layer-btn-next {
  justify-self: end;
}
.esg-layer .layer-fixed .layer-header .layer-btn-next::after {
  display: block;
}
.esg-layer .layer-fixed .layer-header.is-only-title {
  grid-template-columns: 1fr;
}
.esg-layer .layer-fixed .layer-header.is-only-title .layer-title-area {
  grid-column: 1;
}
.esg-layer .layer-fixed .layer-header.is-only-title .layer-title-area .layer-eyebrow,
.esg-layer .layer-fixed .layer-header.is-only-title .layer-title-area .layer-title {
  height: auto;
}
.esg-layer .layer-fixed .layer-header.is-only-title .layer-btn-prev,
.esg-layer .layer-fixed .layer-header.is-only-title .layer-btn-next {
  display: none !important;
}
.esg-layer .layer-fixed .layer-header .layer-title-area {
  grid-column: 2;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: 0.5rem;
}
.esg-layer .layer-fixed .layer-header .layer-title-area.is-align-left {
  align-items: flex-start;
  text-align: left;
}
.esg-layer .layer-fixed .layer-header .layer-title-area.is-align-center {
  align-items: center;
  text-align: center;
}
.esg-layer .layer-fixed .layer-header .layer-title-area .layer-eyebrow {
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 400;
  color: #262626;
}
.esg-layer .layer-fixed .layer-header .layer-title-area .layer-title {
  font-size: 1.25rem;
  line-height: 1.4;
  font-weight: 600;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-header .layer-title-area .layer-eyebrow {
    height: 1.1875rem;
    font-size: 0.875rem;
    line-height: 1.3571;
    font-weight: 400;
  }
  .esg-layer .layer-fixed .layer-header .layer-title-area .layer-title {
    height: 2.5rem;
    font-size: 1.75rem;
    line-height: 1.4286;
    font-weight: 600;
  }
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-fixed .layer-header .layer-title-area .layer-eyebrow {
    height: 1.25rem;
    font-size: 0.9375rem;
    line-height: 1.3333;
    font-weight: 400;
  }
  .esg-layer .layer-fixed .layer-header .layer-title-area .layer-title {
    height: 2.75rem;
    font-size: 2rem;
    line-height: 1.375;
    font-weight: 600;
  }
}
.esg-layer .layer-fixed .layer-tabs-area {
  z-index: 5;
  margin: 1.25rem 1rem 0;
  display: flex;
  justify-content: center;
  flex-shrink: 0;
  height: var(--dropdown-button-height, 2.5rem);
}
.esg-layer .layer-fixed .layer-tabs-area:empty {
  display: none;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-tabs-area {
    margin: 1.5rem 3rem 0;
    height: var(--dropdown-button-height, 3rem);
  }
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-fixed .layer-tabs-area {
    margin: 2rem 3rem 0;
  }
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown {
  position: absolute;
  width: calc(100% - 2rem);
  z-index: 20;
  background-color: #FFFFFF;
  border-radius: 0.625rem;
  --dropdown-button-height: rem(40);
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown {
    display: none;
  }
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-button {
  width: 100%;
  height: 2.5rem;
  padding: 0.6875rem 2.5rem 0.6875rem 1rem;
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 600;
  cursor: pointer;
  display: block;
  text-align: left;
  position: relative;
  z-index: 2;
  border-radius: 0.625rem;
  border: 1px solid #111;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-button::after {
  content: "";
  display: block;
  width: calc(100% - 0.5rem);
  height: 1px;
  background-color: rgba(51, 51, 51, 0.33);
  position: absolute;
  bottom: 0;
  left: 0.25rem;
  opacity: 0;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-button .dropdown-arrow {
  width: 1rem;
  height: 1rem;
  position: absolute;
  right: 0.75rem;
  top: 50%;
  z-index: 3;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-layer-mo-tab.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  transform: translateY(-50%) rotate(-180deg);
  transition: transform 0.3s ease;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu {
  position: absolute;
  top: var(--dropdown-button-height, 2.5rem);
  left: 0;
  right: 0;
  margin-top: -1px;
  border-radius: 0 0 0.625rem 0.625rem;
  border: 1px solid #111;
  border-top: none;
  z-index: 100;
  opacity: 0;
  visibility: hidden;
  transform: translateY(-0.5rem);
  overflow: hidden;
  box-shadow: none;
  background-color: #FFFFFF;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item {
  width: 100%;
  padding: 0.6875rem 1rem;
  border: none;
  background: none;
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 400;
  color: #262626;
  text-align: left;
  cursor: pointer;
  opacity: 0;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item:first-child {
  border-radius: 0;
  border-top: none;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item:last-child, .esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item:only-child {
  border-radius: 0 0 1.375rem 1.375rem;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item:hover {
  background-color: rgba(255, 255, 255, 0.1);
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown-menu .layer-tabs-dropdown-item.is-active {
  background-color: rgba(255, 255, 255, 0.2);
  font-weight: 600;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open {
  z-index: 100;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open .layer-tabs-dropdown-button {
  border-radius: 0.625rem 0.625rem 0 0;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open .layer-tabs-dropdown-button::after {
  opacity: 1;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open .layer-tabs-dropdown-button .dropdown-arrow {
  transform: translateY(-50%) rotate(0deg);
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open .layer-tabs-dropdown-menu {
  opacity: 1;
  visibility: visible;
  transform: translateY(0);
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-dropdown.is-open .layer-tabs-dropdown-menu .layer-tabs-dropdown-item {
  opacity: 1;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-list {
  display: none;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-fixed .layer-tabs-area .layer-tabs-list {
    display: flex;
    justify-content: center;
    height: 3rem;
    padding: 0.25rem;
    border-radius: 6.25rem;
    background-color: rgba(204, 204, 204, 0.25);
    backdrop-filter: blur(20px);
    -webkit-backdrop-filter: blur(20px);
    list-style: none;
    margin: 0;
  }
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-list .layer-tab-btn {
  display: flex;
  padding: 0.625rem 1.5rem;
  border-radius: 6.25rem;
  border: none;
  background-color: transparent;
  font-size: 0.9375rem;
  line-height: 1.3333;
  font-weight: 400;
  color: #262626;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-list .layer-tab-btn:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.esg-layer .layer-fixed .layer-tabs-area .layer-tabs-list .layer-tab-btn.is-active {
  background-color: #000000;
  color: #FFFFFF;
  outline-color: #ea1917 !important;
}
.esg-layer .layer-scrollable {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 1rem 1.25rem 2rem;
  background-color: #FFFFFF;
  outline: none;
}
.esg-layer .layer-scrollable::-webkit-scrollbar {
  display: none;
}
.esg-layer .layer-scrollable:focus-visible {
  outline: 2px solid #000000;
  outline-offset: -3px;
}
.esg-layer .layer-scrollable:has(.layer-content-grid:nth-child(5)) {
  padding-top: 0;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-scrollable {
    padding: 1.625rem 1.75rem;
  }
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-scrollable {
    padding: 1.5rem 2.5rem 4rem;
  }
}
.esg-layer .layer-content-wrap {
  display: flex;
  flex-direction: column;
}
.esg-layer .layer-content-wrap:first-child {
  margin-top: 0;
}
.esg-layer .layer-content-wrap {
  gap: 2.5rem;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-content-wrap {
    gap: 3rem;
  }
}
.esg-layer .layer-content-wrap + .layer-content-wrap {
  margin-top: 2.5rem;
}
@media all and (min-width: 768px) {
  .esg-layer .layer-content-wrap + .layer-content-wrap {
    margin-top: 3rem;
  }
}
.esg-layer .layer-content-wrap.grouped-default {
  gap: 1rem !important;
}
@media all and (min-width: 1440px) {
  .esg-layer .layer-content-wrap.grouped-default {
    gap: 1.5rem !important;
  }
}

body.layer-open {
  overflow: hidden;
  position: fixed;
  width: 100%;
}

/* banner */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-banner-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .sustainability-banner-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-banner-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.sustainability-banner-link:hover, .sustainability-banner-link:active, .sustainability-banner-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.sustainability-banner-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.sustainability-banner-link:hover .outlink-icon, .sustainability-banner-link:active .outlink-icon, .sustainability-banner-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.sustainability-banner {
  position: relative;
}
.sustainability-banner .inner {
  padding: 0;
}
.sustainability-banner-content {
  position: relative;
  overflow: hidden;
  background-color: #FFFFFF;
}
@media all and (min-width: 1440px) {
  .sustainability-banner-content {
    border-radius: 1rem;
  }
}
@media all and (min-width: 768px) {
  .sustainability-banner-content {
    border-radius: 0.875rem;
  }
}
.sustainability-banner-text {
  z-index: 1;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  padding: 2rem 1.25rem;
}
@media all and (min-width: 768px) {
  .sustainability-banner-text {
    padding: 2.25rem 1.5rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-banner-text {
    top: 50%;
    transform: translateY(-50%);
    left: 4rem;
    max-width: 47.5rem;
    padding: 0;
  }
}
.sustainability-banner-title {
  font-size: calc(var(--esg-font-heading-1-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-1-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-1-fw);
  letter-spacing: var(--esg-font-heading-1-ls);
  color: #FFFFFF;
}
.sustainability-banner-desc {
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-3-ls);
  color: #FFFFFF;
}
.sustainability-banner-image {
  position: relative;
  width: 100%;
  aspect-ratio: 390/520;
}
@media all and (min-width: 768px) {
  .sustainability-banner-image {
    aspect-ratio: 768/480;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-banner-image {
    aspect-ratio: 1380/420;
  }
}
.sustainability-banner-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

/* explore-main */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-explore .explore-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.sustainability-explore .explore-card-link:hover, .sustainability-explore .explore-card-link:active, .sustainability-explore .explore-card-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.sustainability-explore .explore-card-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.sustainability-explore .explore-card-link:hover .outlink-icon, .sustainability-explore .explore-card-link:active .outlink-icon, .sustainability-explore .explore-card-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.sustainability-explore {
  position: relative;
  background-color: #FFFFFF;
}
.sustainability-explore-tabs {
  display: flex;
  margin-bottom: 1.5rem;
}
@media all and (min-width: 768px) {
  .sustainability-explore-tabs {
    margin-bottom: 2rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore-tabs {
    margin-bottom: 2.5rem;
  }
}
.sustainability-explore .explore-tabs-list {
  display: flex;
  gap: 0.5rem;
}
.sustainability-explore .explore-tabs-list .explore-tab-btn {
  padding: 0.6875rem 1rem;
  border-radius: 6.25rem;
  border: 1px solid #222222;
  background-color: transparent;
  font-size: 0.8125rem;
  line-height: 138%;
  font-weight: 400;
  color: #666666;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-tabs-list .explore-tab-btn {
    padding: 0.71875rem 1.25rem;
    font-size: 0.84375rem;
    line-height: 126%;
    font-weight: 400;
    color: #666666;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-tabs-list .explore-tab-btn {
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    line-height: 120%;
    font-weight: 400;
    color: #666666;
  }
}
.sustainability-explore .explore-tabs-list .explore-tab-btn:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.sustainability-explore .explore-tabs-list .explore-tab-btn.is-active {
  background-color: #000000;
  font-weight: 600;
  color: #FFFFFF;
  border-color: #000000;
  outline-color: #ea1917 !important;
}
.sustainability-explore .sustainability-explore-content {
  position: relative;
}
.sustainability-explore .explore-content-panel {
  display: none;
}
.sustainability-explore .explore-content-panel.is-active {
  display: block;
}
.sustainability-explore .explore-content-panel-title {
  font-size: 1.25rem;
  line-height: 140%;
  font-weight: 600;
  margin-bottom: 1rem;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-content-panel-title {
    font-size: 1.375rem;
    line-height: 136%;
    font-weight: 600;
    margin-bottom: 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-content-panel-title {
    font-size: 1.5rem;
    line-height: 133%;
    font-weight: 600;
    margin-bottom: 1.5rem;
  }
}
.sustainability-explore .explore-cards-slider {
  position: relative;
}
.sustainability-explore .explore-cards.swiper {
  overflow: visible;
}
.sustainability-explore .explore-cards.swiper .swiper-wrapper {
  align-items: stretch;
}
.sustainability-explore .explore-cards.swiper .swiper-slide {
  width: 19.625rem;
  height: auto;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-cards.swiper .swiper-slide {
    width: 20rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-cards.swiper .swiper-slide {
    width: auto;
  }
}
.sustainability-explore .explore-card {
  display: flex;
  flex-direction: column;
}
.sustainability-explore .explore-card-image {
  position: relative;
  width: 100%;
  border-radius: 0.75rem;
  aspect-ratio: 314/230;
  overflow: hidden;
  margin-bottom: 0.75rem;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-card-image {
    border-radius: 0.875rem;
    margin-bottom: 1.125rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-card-image {
    border-radius: 1rem;
    margin-bottom: 1.5rem;
  }
}
.sustainability-explore .explore-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sustainability-explore .explore-card-content {
  display: flex;
  flex-direction: column;
  flex: 1;
}
.sustainability-explore .explore-card-label {
  margin-bottom: 0.5rem;
}
.sustainability-explore .explore-card-title {
  font-size: calc(var(--esg-font-heading-5-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-5-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-5-fw);
  letter-spacing: var(--esg-font-heading-5-ls);
  margin-bottom: 0.25rem;
}
.sustainability-explore .explore-card-desc {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  color: #444444;
  margin-bottom: 1rem;
  flex: 1;
}
@media all and (min-width: 768px) {
  .sustainability-explore .explore-card-desc {
    font-size: 1rem;
    line-height: 1.25;
    font-weight: 400;
    color: #444444;
    letter-spacing: -0.2px;
    margin-bottom: 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .explore-card-desc {
    margin-bottom: 1.5rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-explore .esg-slider-controls {
    display: none;
  }
}

/* news */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-news-content .news-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .sustainability-news-content .news-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.sustainability-news-content .news-card-link:hover, .sustainability-news-content .news-card-link:active, .sustainability-news-content .news-card-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.sustainability-news-content .news-card-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.sustainability-news-content .news-card-link:hover .outlink-icon, .sustainability-news-content .news-card-link:active .outlink-icon, .sustainability-news-content .news-card-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.sustainability-news {
  position: relative;
  background-color: #FFFFFF;
}
.sustainability-news-heading {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.sustainability-news-tabs {
  display: flex;
  margin-bottom: 1.5rem;
}
@media all and (min-width: 768px) {
  .sustainability-news-tabs {
    margin-bottom: 2rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news-tabs {
    margin-bottom: 2.5rem;
  }
}
.sustainability-news .news-tabs-list {
  display: flex;
  gap: 0.5rem;
}
.sustainability-news .news-tabs-list .news-tab-btn {
  padding: 0.6875rem 1rem;
  border-radius: 6.25rem;
  border: 1px solid #222222;
  background-color: transparent;
  font-size: 0.8125rem;
  line-height: 138%;
  font-weight: 400;
  color: #666666;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
}
@media all and (min-width: 768px) {
  .sustainability-news .news-tabs-list .news-tab-btn {
    padding: 0.71875rem 1.25rem;
    font-size: 0.84375rem;
    line-height: 126%;
    font-weight: 400;
    color: #666666;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news .news-tabs-list .news-tab-btn {
    padding: 0.75rem 1.5rem;
    font-size: 0.875rem;
    line-height: 120%;
    font-weight: 400;
    color: #666666;
  }
}
.sustainability-news .news-tabs-list .news-tab-btn:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.sustainability-news .news-tabs-list .news-tab-btn.is-active {
  background-color: #000000;
  font-weight: 600;
  color: #FFFFFF;
  border-color: #000000;
  outline-color: #ea1917 !important;
}
.sustainability-news-content {
  position: relative;
}
.sustainability-news-content .news-content-panel {
  display: none;
}
.sustainability-news-content .news-content-panel.is-active {
  display: block;
}
.sustainability-news-content .news-cards-slider {
  position: relative;
}
.sustainability-news-content .news-cards.swiper {
  overflow: visible;
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-cards.swiper {
    overflow: hidden;
  }
}
.sustainability-news-content .news-cards.swiper .swiper-wrapper {
  align-items: stretch;
}
.sustainability-news-content .news-cards.swiper .swiper-slide {
  width: 19.625rem;
  aspect-ratio: 314/379;
  height: auto;
}
@media all and (min-width: 768px) {
  .sustainability-news-content .news-cards.swiper .swiper-slide {
    width: 23.75rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-cards.swiper .swiper-slide {
    width: 27.75rem;
    aspect-ratio: 444/528;
  }
}
.sustainability-news-content .news-card {
  position: relative;
  border-radius: 0.75rem;
  overflow: hidden;
  height: 100%;
  display: flex;
  flex-direction: column;
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card {
    border-radius: 1rem;
  }
}
.sustainability-news-content .news-card-image {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 1;
}
.sustainability-news-content .news-card-image picture,
.sustainability-news-content .news-card-image img {
  width: 100%;
  height: 100%;
  display: block;
}
.sustainability-news-content .news-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.sustainability-news-content .news-card:hover .news-card-image img {
  transform: scale(1.05);
}
.sustainability-news-content .news-card-overlay {
  position: relative;
  z-index: 2;
  width: 100%;
  height: 100%;
  padding: 1.5rem;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  color: #FFFFFF;
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card-overlay {
    padding: 2.5rem 1.5rem;
  }
}
.sustainability-news-content .news-card.invert .news-card-overlay {
  color: #000000;
}
.sustainability-news-content .news-card-title {
  font-size: 1.25rem;
  line-height: 140%;
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: -0.4px;
  margin-bottom: 0.5rem;
}
@media all and (min-width: 768px) {
  .sustainability-news-content .news-card-title {
    font-size: 1.75rem;
    line-height: 116%;
    font-weight: 600;
    color: #FFFFFF;
    letter-spacing: -0.4px;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card-title {
    font-size: 1.375rem;
    line-height: 136%;
    font-weight: 600;
    color: #FFFFFF;
    letter-spacing: -0.4px;
  }
}
.sustainability-news-content .news-card-date {
  font-size: 1rem;
  line-height: 112%;
  font-weight: 400;
  color: #FFFFFF;
  margin-top: 0.25rem;
  margin-bottom: 0.75rem;
}
@media all and (min-width: 768px) {
  .sustainability-news-content .news-card-date {
    margin-bottom: 1.125rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card-date {
    margin-bottom: 1.5rem;
  }
}
.sustainability-news-content .news-card-link {
  color: #000000;
}
.sustainability-news-content .news-card.is-dummy {
  display: none;
  width: 0;
  margin: 0;
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-card.is-dummy {
    display: block;
    visibility: hidden;
    pointer-events: none;
    width: 27.75rem;
  }
}
.sustainability-news-content .news-slider-controls {
  overflow: visible;
}
@media all and (min-width: 1440px) {
  .sustainability-news-content .news-slider-controls {
    justify-content: flex-end;
    margin-top: 2rem;
    padding-bottom: calc(var(--esg-spacing-xs) / 16 * 1rem);
  }
}

/* accessibility */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.accessibility-menu-item .accessibility-menu-content .menu-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .accessibility-menu-item .accessibility-menu-content .menu-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-content .menu-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.accessibility-menu-item .accessibility-menu-content .menu-link:hover, .accessibility-menu-item .accessibility-menu-content .menu-link:active, .accessibility-menu-item .accessibility-menu-content .menu-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.accessibility-menu-item .accessibility-menu-content .menu-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.accessibility-menu-item .accessibility-menu-content .menu-link:hover .outlink-icon, .accessibility-menu-item .accessibility-menu-content .menu-link:active .outlink-icon, .accessibility-menu-item .accessibility-menu-content .menu-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.sustainability-accessibility {
  position: relative;
  background-color: #F4F4F4;
  z-index: 1;
}
.sustainability-accessibility .inner {
  padding: 0;
}
.sustainability-accessibility-content {
  display: flex;
  position: relative;
}
.sustainability-accessibility .esg-heading-group {
  padding: 0 1.25rem;
}
@media all and (min-width: 1440px) {
  .sustainability-accessibility .esg-heading-group {
    padding: 0;
  }
}

.accessibility-menu {
  width: 100%;
  position: absolute;
  bottom: 1rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  display: flex;
  align-items: flex-start;
  flex-direction: column-reverse;
  gap: 1rem;
}
@media all and (min-width: 768px) {
  .accessibility-menu {
    bottom: 0.5rem;
    gap: 1rem;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu {
    width: auto;
    height: 100%;
    position: absolute;
    left: 3rem;
    bottom: 0;
    margin-bottom: 0;
    margin-top: 0;
    padding: 0;
    gap: 1rem;
    flex-direction: row;
    align-items: center;
    transform: translateX(0);
  }
}

.accessibility-slider.esg-slider-controls {
  width: 100%;
  display: flex;
  flex-direction: row;
}
@media all and (min-width: 1440px) {
  .accessibility-slider.esg-slider-controls {
    width: auto;
    position: relative;
    left: 0;
    transform: translateX(0);
    flex-direction: column;
    justify-content: flex-start;
  }
}
.accessibility-slider.esg-slider-controls .swiper-pagination-current {
  color: #FFFFFF;
}
@media all and (min-width: 1440px) {
  .accessibility-slider.esg-slider-controls .swiper-pagination-current {
    color: #000000;
  }
}
.accessibility-slider.esg-slider-controls .separator {
  background-color: rgba(255, 255, 255, 0.4);
}
@media all and (min-width: 1440px) {
  .accessibility-slider.esg-slider-controls .separator {
    background-color: rgba(100, 100, 100, 0.4);
  }
}
.accessibility-slider.esg-slider-controls .swiper-pagination-total {
  color: #DDDDDD;
}
@media all and (min-width: 1440px) {
  .accessibility-slider.esg-slider-controls .swiper-pagination-total {
    color: #646464;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-slider.esg-slider-controls .esg-slider-prev,
  .accessibility-slider.esg-slider-controls .esg-slider-next {
    transform: rotate(90deg);
  }
}

.accessibility-menu-list {
  width: 100%;
  display: flex;
  align-items: flex-end;
  padding: 0 1.25rem;
}
.accessibility-menu-list .swiper-wrapper {
  align-items: flex-end;
}
@media all and (min-width: 768px) {
  .accessibility-menu-list {
    padding: 0 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-list {
    flex-direction: column;
    flex-wrap: wrap;
    gap: 0.75rem;
    overflow: visible;
    order: unset;
    width: auto;
    padding: 0;
    align-items: flex-start;
  }
}

.accessibility-menu-item {
  width: 100%;
  background-color: rgba(255, 255, 255, 0.6);
  border-radius: 6.25rem;
  overflow: hidden;
  padding: 0.8125rem 1.25rem;
  transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1);
  box-shadow: 0 0.25rem 1.25rem rgba(0, 0, 0, 0.05);
  backdrop-filter: blur(10px);
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item {
    width: auto;
  }
}
.accessibility-menu-item .accessibility-menu-btn {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  text-align: left;
  transition: all 0.3s ease;
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-btn {
    cursor: pointer;
  }
}
.accessibility-menu-item .accessibility-menu-btn .menu-icon {
  width: 1.5rem;
  height: 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
}
@media all and (min-width: 768px) {
  .accessibility-menu-item .accessibility-menu-btn .menu-icon {
    width: 1.625rem;
    height: 1.625rem;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-btn .menu-icon {
    width: 1.75rem;
    height: 1.75rem;
  }
}
.accessibility-menu-item .accessibility-menu-btn .menu-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
}
.accessibility-menu-item .accessibility-menu-btn .menu-title {
  font-size: 1.25rem;
  line-height: 140%;
  font-weight: 600;
  letter-spacing: -0.4px;
  white-space: nowrap;
}
@media all and (min-width: 768px) {
  .accessibility-menu-item .accessibility-menu-btn .menu-title {
    font-size: 1.3125rem;
    line-height: 138%;
    font-weight: 600;
    letter-spacing: -0.4px;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-btn .menu-title {
    font-size: 1.375rem;
    line-height: 136%;
    font-weight: 600;
    letter-spacing: -0.5px;
  }
}
.accessibility-menu-item .accessibility-menu-content {
  max-height: 0;
  opacity: 0;
  overflow: hidden;
  display: flex;
  flex-shrink: 0;
  position: relative;
  transition: max-height 0.75s cubic-bezier(0.4, 0, 0.2, 1), opacity 0.75s ease 0.1s, padding 0.4s cubic-bezier(0.4, 0, 0.2, 1);
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-content {
    position: absolute;
    bottom: 100%;
    left: 0;
    padding: 0;
  }
}
.accessibility-menu-item .accessibility-menu-content .menu-desc {
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
  color: #444444;
  word-break: keep-all;
  margin-bottom: 0.75rem;
}
@media all and (min-width: 768px) {
  .accessibility-menu-item .accessibility-menu-content .menu-desc {
    margin-bottom: 1.25rem;
    max-width: 15.625rem;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item .accessibility-menu-content .menu-desc {
    margin-bottom: 1.5rem;
    max-width: 18.4375rem;
  }
}
.accessibility-menu-item.is-active {
  width: 100%;
  background-color: #FFFFFF;
  border-radius: 0.75rem;
  padding: 1.25rem;
  flex-shrink: 0;
}
@media all and (min-width: 768px) {
  .accessibility-menu-item.is-active {
    border-radius: 0.875rem;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-menu-item.is-active {
    width: 19.0625rem;
    border-radius: 1rem;
  }
}
.accessibility-menu-item.is-active {
  box-shadow: 0 0.25rem 1rem rgba(0, 0, 0, 0.1);
}
.accessibility-menu-item.is-active .accessibility-menu-content {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  max-height: 12.5rem;
  opacity: 1;
  margin-top: 0.5rem;
  position: relative;
}
.accessibility-menu-item:not(.is-active):hover {
  background-color: rgba(255, 255, 255, 0.95);
}

.accessibility-visual {
  flex: 1;
  overflow: hidden;
  position: relative;
  order: unset;
  width: auto;
}
@media all and (min-width: 1440px) {
  .accessibility-visual {
    border-radius: 1rem;
    margin: 0;
  }
}

.accessibility-visual-slider {
  position: relative;
  width: 100%;
  height: 100%;
  aspect-ratio: 390/508;
}
@media all and (min-width: 768px) {
  .accessibility-visual-slider {
    aspect-ratio: 768/520;
  }
}
@media all and (min-width: 1440px) {
  .accessibility-visual-slider {
    aspect-ratio: 1380/720;
  }
}

.visual-slide {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  clip-path: inset(0 100% 0 0);
  transition: clip-path 0.8s cubic-bezier(0.4, 0, 0.2, 1);
  z-index: 1;
}
.visual-slide img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.visual-slide.is-active {
  clip-path: inset(0 0 0 0);
  z-index: 2;
}
.visual-slide.is-entering-prev {
  clip-path: inset(0 0 0 0);
  z-index: 3;
}
.visual-slide.is-entering-next {
  clip-path: inset(0 0 0 0);
  z-index: 3;
}
.visual-slide.from-right {
  clip-path: inset(0 0 0 100%);
}

/* products */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.product-card-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0.6875rem 1rem;
  border: 1px solid #222222;
  border-radius: 6.25rem;
  background-color: #FFFFFF;
  font-size: 0.875rem;
  line-height: 100%;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.3s ease, color 0.3s ease, border-color 0.3s ease;
  width: fit-content;
  cursor: pointer;
}
@media all and (min-width: 768px) {
  .product-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .product-card-link {
    padding: 0.625rem 1rem;
    font-size: 0.875rem;
    line-height: 100%;
    font-weight: 500;
  }
}
.product-card-link:hover, .product-card-link:active, .product-card-link:focus {
  background-color: #ea1917;
  color: #FFFFFF;
  border-color: transparent;
}
.product-card-link .outlink-icon {
  display: inline-block;
  width: 0.875rem;
  margin-inline-start: 0.5rem;
  background-image: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-outlink.svg");
  background-size: contain;
  background-repeat: no-repeat;
  background-position: center;
  aspect-ratio: 1/1;
  transition: filter 0.3s ease;
}
.product-card-link:hover .outlink-icon, .product-card-link:active .outlink-icon, .product-card-link:focus .outlink-icon {
  filter: brightness(0) invert(1);
}

.sustainability-products .inner:not(:first-child) {
  padding-inline: 0;
}
.sustainability-products-tabs {
  margin-block-end: calc(var(--esg-spacing-2xl) / 16 * 1rem);
  display: flex;
  width: 100%;
  min-width: 0;
  max-width: 100%;
  overflow-x: auto;
  overflow-y: hidden;
  -webkit-overflow-scrolling: touch;
  overscroll-behavior-x: contain;
  touch-action: pan-x;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding-inline: 1.25rem;
}
.sustainability-products-tabs::-webkit-scrollbar {
  display: none;
}
@media all and (min-width: 1440px) {
  .sustainability-products-tabs {
    overflow: visible;
    overscroll-behavior: auto;
    touch-action: auto;
    scrollbar-width: auto;
    -ms-overflow-style: auto;
    padding: 0;
  }
  .sustainability-products-tabs::-webkit-scrollbar {
    display: block;
  }
}

.products-tabs-list {
  display: flex;
  flex-wrap: nowrap;
  gap: 0.5rem;
  width: max-content;
}
@media all and (min-width: 768px) {
  .products-tabs-list {
    gap: 0.5rem;
  }
}
@media all and (min-width: 1440px) {
  .products-tabs-list {
    gap: 0.5rem;
    width: auto;
  }
}
.products-tabs-list > .products-tab-btn {
  flex-shrink: 0;
}
.products-tabs-list .products-tab-btn {
  display: flex;
  padding: 0.5625rem 0.875rem;
  border-radius: 6.25rem;
  border: none;
  color: #666666;
  background-color: transparent;
  cursor: pointer;
  transition: background-color 0.3s ease, color 0.3s ease;
  white-space: nowrap;
  border: 1px solid #222222;
}
.products-tabs-list .products-tab-btn:hover {
  background-color: rgba(0, 0, 0, 0.05);
}
.products-tabs-list .products-tab-btn.is-active {
  background-color: #000000;
  font-weight: 600;
  color: #FFFFFF;
  border-color: #000000;
  outline-color: #ea1917 !important;
}
@media all and (min-width: 768px) {
  .products-tabs-list .products-tab-btn {
    padding: 0.59375rem 0.9375rem;
  }
}
@media all and (min-width: 1440px) {
  .products-tabs-list .products-tab-btn {
    padding: 0.625rem 1rem;
  }
}

.sustainability-products-slider {
  position: relative;
  padding-inline: 1.25rem;
}
@media all and (min-width: 1440px) {
  .sustainability-products-slider {
    padding: 0;
  }
}

.products-swiper {
  overflow: visible;
}
.products-swiper .swiper-wrapper {
  align-items: stretch;
}
.products-swiper .swiper-slide {
  width: 19.625rem;
  height: auto;
}
@media all and (min-width: 768px) {
  .products-swiper .swiper-slide {
    width: 20rem;
  }
}
@media all and (min-width: 1440px) {
  .products-swiper .swiper-slide {
    width: 20.4375rem;
  }
}

.product-card {
  height: 100%;
  display: flex;
  flex-direction: column;
}
.product-card-image {
  position: relative;
  width: 100%;
  aspect-ratio: 1/1;
  overflow: hidden;
  margin-block-end: 0.75rem;
}
@media all and (min-width: 768px) {
  .product-card-image {
    margin-block-end: 1.3125rem;
  }
}
@media all and (min-width: 1440px) {
  .product-card-image {
    margin-block-end: 1.5rem;
  }
}
.product-card-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.5s ease;
}
.product-card-image .esg-disclaimer {
  position: absolute;
  inset: auto 1.5rem 1rem 1.5rem;
}
.product-card:hover .product-card-image img {
  transform: scale(1.05);
}
.product-card-content {
  flex: 1;
  display: flex;
  flex-direction: column;
}
.product-card-title-eyebrow {
  margin-block-end: 0.5rem;
}
.product-card-title {
  font-size: calc(var(--esg-font-heading-5-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-5-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-5-fw);
  letter-spacing: var(--esg-font-heading-5-ls);
  margin-block-end: 0.5rem;
}
.product-card-desc {
  margin-block-end: 0.75rem;
  flex: 1;
}
@media all and (min-width: 768px) {
  .product-card-desc {
    margin-block-end: 1.3125rem;
  }
}
@media all and (min-width: 1440px) {
  .product-card-desc {
    margin-block-end: 1.5rem;
  }
}
.product-card-link {
  font-family: inherit;
}

@media all and (min-width: 1440px) {
  .products-slider-controls {
    position: absolute;
    right: 0;
    top: -4.875rem;
  }
}

/* achievement */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-achievement .inner {
  padding: 0;
}

.achievement-note-wrap {
  display: flex;
  justify-content: flex-end;
  margin-block-end: 0.75rem;
  padding-inline: 1rem;
}
@media all and (min-width: 1440px) {
  .achievement-note-wrap {
    margin-block-end: 1rem;
    padding-inline: 0;
  }
}

.achievement-footer-note {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
  background-color: #F4F4F4;
  border-radius: 1rem;
  padding: 0.25rem 0.5rem;
}

.achievement-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
}
@media all and (min-width: 768px) {
  .achievement-grid-wrap {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
  }
}

.achievement-card {
  position: relative;
  padding: 1.25rem;
  min-height: 13.75rem;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background-color: transparent;
}
@media all and (min-width: 768px) {
  .achievement-card {
    padding: 1.375rem;
    min-height: 14.375rem;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card {
    padding: 1.5rem;
    min-height: 15rem;
  }
}
.achievement-card::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 0;
  transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.achievement-card.from-top::before {
  transform: scaleY(0);
  transform-origin: top center;
}
.achievement-card.from-bottom::before {
  transform: scaleY(0);
  transform-origin: bottom center;
}
.achievement-card.from-left::before {
  transform: scaleX(0);
  transform-origin: left center;
}
.achievement-card.from-right::before {
  transform: scaleX(0);
  transform-origin: right center;
}
.achievement-card.is-animated::before {
  transform: scaleX(1) scaleY(1);
}
.achievement-card .card-scope,
.achievement-card .card-label,
.achievement-card .card-value,
.achievement-card .card-list {
  position: relative;
  z-index: 1;
  opacity: 0;
  transform: translateY(20px);
  transition: opacity 0.5s ease, transform 0.5s ease;
}
.achievement-card .card-icon,
.achievement-card .card-icons {
  z-index: 1;
}
.achievement-card.is-animated .card-scope,
.achievement-card.is-animated .card-label,
.achievement-card.is-animated .card-value,
.achievement-card.is-animated .card-list {
  opacity: 1;
  transform: translateY(0);
}
.achievement-card .card-label {
  font-size: 0.9375rem;
  line-height: 1.3333;
  font-weight: 600;
  color: #111111;
  letter-spacing: -0.2px;
  margin-bottom: auto;
  transition-delay: 0.35s;
}
@media all and (min-width: 768px) {
  .achievement-card .card-label {
    font-size: 1.3125rem;
    line-height: 114%;
    font-weight: 600;
    color: #111111;
    letter-spacing: -0.4px;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-label {
    font-size: 1.125rem;
    line-height: 1.3333;
    font-weight: 600;
    color: #111111;
    letter-spacing: -0.4px;
  }
}
.achievement-card .card-label.wh-text {
  color: #FFFFFF;
}
.achievement-card .card-icon {
  max-width: 4.5rem;
  position: absolute;
  right: 1rem;
  bottom: 50%;
  transform: translateY(50%);
  opacity: 0;
  transition: opacity 0.5s ease 0.4s;
}
@media all and (min-width: 768px) {
  .achievement-card .card-icon {
    max-width: unset;
    right: 0.5rem;
    bottom: 50%;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-icon {
    right: 1rem;
    bottom: 1rem;
    transform: translateY(0);
  }
}
.achievement-card .card-icon.card-icon-large {
  max-width: 18rem;
}
@media all and (min-width: 768px) {
  .achievement-card .card-icon.card-icon-large {
    max-width: auto;
  }
}
.achievement-card .card-icon img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.achievement-card .card-icons {
  position: absolute;
  right: 0;
  bottom: 50%;
  transform: translateY(50%);
  display: flex;
  opacity: 0;
  transition: opacity 0.5s ease 0.4s;
}
@media all and (min-width: 768px) {
  .achievement-card .card-icons {
    right: 0.5rem;
    bottom: 50%;
    transform: translateY(50%);
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-icons {
    right: 1rem;
    bottom: 1rem;
    transform: translateY(0);
  }
}
.achievement-card .card-icons .card-icon {
  position: static;
  transform: none;
  width: 5.625rem;
  height: 5.625rem;
  opacity: 1;
  transition: none;
}
@media all and (min-width: 768px) {
  .achievement-card .card-icons .card-icon {
    width: 5.3125rem;
    height: 5.3125rem;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-icons .card-icon {
    width: 5rem;
    height: 5rem;
  }
}
.achievement-card .card-icons .card-icon img {
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.achievement-card.is-animated .card-icon {
  opacity: 1;
}
.achievement-card.is-animated .card-icons {
  opacity: 1;
}
.achievement-card.achievement-card-2 .card-value .value-unit .value-sup {
  color: #000000;
}
.achievement-card.achievement-card-7 .card-icon, .achievement-card.achievement-card-8 .card-icon {
  bottom: calc(50% + 1.625rem);
}
@media all and (min-width: 768px) {
  .achievement-card.achievement-card-7 .card-icon, .achievement-card.achievement-card-8 .card-icon {
    bottom: 50%;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card.achievement-card-7 .card-icon, .achievement-card.achievement-card-8 .card-icon {
    bottom: 1rem;
  }
}
.achievement-card:hover .card-icon img,
.achievement-card:hover .card-icons .card-icon img {
  transform: scale(1.2);
}
.achievement-card .card-value {
  display: flex;
  align-items: flex-end;
  gap: 0.25rem;
  transition-delay: 0.5s;
}
.achievement-card .card-value .value-number,
.achievement-card .card-value .value-number-2 {
  font-size: 2.25rem;
  line-height: 105%;
  font-weight: 300;
  flex-shrink: 0;
}
.achievement-card .card-value .value-number.wh-text,
.achievement-card .card-value .value-number-2.wh-text {
  color: #FFFFFF;
}
@media all and (min-width: 768px) {
  .achievement-card .card-value .value-number,
  .achievement-card .card-value .value-number-2 {
    font-size: 3.625rem;
    line-height: 102%;
    font-weight: 300;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-value .value-number,
  .achievement-card .card-value .value-number-2 {
    font-size: 4.5rem;
    line-height: 1.1111;
    font-weight: 300;
  }
}
.achievement-card .card-value .value-unit {
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  height: 100%;
  font-size: 0.9375rem;
  line-height: 1.3333;
  font-weight: 500;
  flex-shrink: 0;
}
@media all and (min-width: 768px) {
  .achievement-card .card-value .value-unit {
    font-size: 1.125rem;
    line-height: 1.3333;
    font-weight: 500;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-value .value-unit-text {
    margin-block-end: 0.75rem;
  }
}
.achievement-card .card-value .value-unit.wh-text {
  color: #FFFFFF;
}
.achievement-card .card-value .value-unit .value-sup {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: #FFFFFF;
  margin-block-end: auto;
}
.achievement-card.achievement-card-7 .card-value .value-unit {
  line-height: 140%;
}
@media all and (min-width: 768px) {
  .achievement-card.achievement-card-7 .card-value .value-unit {
    line-height: 130%;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card.achievement-card-7 .card-value .value-unit {
    line-height: 136%;
  }
}
.achievement-card .card-list {
  transition-delay: 0.5s;
}
.achievement-card .card-list li {
  display: flex;
  gap: 0.25rem;
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 400;
}
@media all and (min-width: 768px) {
  .achievement-card .card-list li {
    font-size: 0.875rem;
    line-height: 1.4286;
    font-weight: 600;
    letter-spacing: -0.2px;
  }
}
@media all and (min-width: 1440px) {
  .achievement-card .card-list li {
    font-size: 0.9375rem;
    line-height: 1.3333;
    font-weight: 600;
    letter-spacing: -0.2px;
  }
}
.achievement-card .card-list li::before {
  content: "· ";
}
@media all and (min-width: 1440px) {
  .achievement-card .card-list {
    display: flex;
    flex-direction: column-reverse;
  }
}

.achievement-grid .achievement-card-1::before {
  background-color: #C8E4C9;
}
.achievement-grid .achievement-card-2::before {
  background-color: #BFF3EA;
}
.achievement-grid .achievement-card-3::before {
  background-color: #FFF2AF;
}
.achievement-grid .achievement-card-4::before {
  background-color: #F4DC00;
}
.achievement-grid .achievement-card-5::before {
  background-color: #60984D;
}
.achievement-grid .achievement-card-6::before {
  background: linear-gradient(180deg, rgba(72, 162, 168, 0.5) 0%, rgba(72, 162, 168, 0) 50%), #7CCCBF;
}
.achievement-grid .achievement-card-7::before {
  background: linear-gradient(116deg, rgba(244, 144, 69, 0.6) 39.84%, rgba(244, 144, 69, 0.27) 68.07%, rgba(244, 144, 69, 0) 93.8%), #FFBB83;
}
.achievement-grid .achievement-card-8::before {
  background-color: #F49045;
}
.achievement-grid .achievement-card-9::before {
  background-color: #04563F;
}
.achievement-grid .achievement-card-10::before {
  background-color: #48A2A8;
}
.achievement-grid .achievement-card-11::before {
  background-color: #C35C11;
}
.achievement-grid .achievement-card-11 {
  grid-column: span 2;
}
.achievement-grid .achievement-card-11:hover .card-icon img {
  transform: scale(1.05);
}
.achievement-grid .achievement-card-7 .value-unit {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: #000000;
}
@media all and (min-width: 768px) {
  .achievement-grid .achievement-card-7 .value-unit {
    font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
    line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
    letter-spacing: var(--esg-font-body-3-ls);
  }
}

.achievement-footer {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 1rem;
  padding-inline: 1rem;
  margin-block-start: calc(var(--esg-spacing-m) / 16 * 1rem);
}
@media all and (min-width: 1440px) {
  .achievement-footer {
    margin-block-start: calc(var(--esg-spacing-l) / 16 * 1rem);
    padding-inline: 0;
  }
}
.achievement-footer-list {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 0.5rem;
}
@media all and (min-width: 768px) {
  .achievement-footer-list {
    gap: 0.75rem;
  }
}
@media all and (min-width: 1440px) {
  .achievement-footer-list {
    gap: 1rem;
  }
}
.achievement-footer-list-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
}
.achievement-footer-list-item-number {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-disclaimer-ls);
  color: var(--esg-font-disclaimer-cl);
  width: 1.125rem;
  height: 1.125rem;
  border-radius: 0.125rem;
}
.achievement-footer-list-item:nth-child(1) .achievement-footer-list-item-number {
  background-color: #60984D;
  color: #FFFFFF;
}
.achievement-footer-list-item:nth-child(2) .achievement-footer-list-item-number {
  background-color: #04563F;
  color: #FFFFFF;
}
.achievement-footer-list-item:nth-child(3) .achievement-footer-list-item-number {
  background-color: #BFF3EA;
  color: #000000;
}
.achievement-footer-list-item:nth-child(4) .achievement-footer-list-item-number {
  background-color: #48A2A8;
  color: #FFFFFF;
}

/* overview */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-overview {
  z-index: 2;
}
.sustainability-overview .inner {
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 1rem 1.25rem;
}
@media all and (min-width: 1440px) {
  .sustainability-overview .inner {
    padding: 0;
  }
}
.sustainability-overview .esg-heading-group {
  width: 100%;
  margin-block-end: 1rem;
}
.sustainability-overview .esg-heading-group .esg-title-main {
  text-align: center;
  opacity: 1;
  transform: translateY(0);
}
@media all and (min-width: 1440px) {
  .sustainability-overview .esg-heading-group .esg-title-main {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
  }
}
.sustainability-overview .esg-heading-group .esg-desc {
  opacity: 1;
  transform: translateY(0);
}
@media all and (min-width: 1440px) {
  .sustainability-overview .esg-heading-group .esg-desc {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease;
    transition-delay: 0.15s;
  }
}
.sustainability-overview .sustainability-sticky-bar:not(.is-sticky) {
  opacity: 1;
  transform: translateY(0);
}
@media all and (min-width: 1440px) {
  .sustainability-overview .sustainability-sticky-bar:not(.is-sticky) {
    opacity: 0;
    transform: translateY(30px);
    transition: opacity 0.6s ease, transform 0.6s ease, background-color 0.4s ease, box-shadow 0.4s ease;
    transition-delay: 0.3s;
  }
}
.sustainability-overview.is-animated .esg-title-main,
.sustainability-overview.is-animated .esg-desc {
  opacity: 1;
  transform: translateY(0);
}
.sustainability-overview.is-animated .sustainability-sticky-bar:not(.is-sticky) {
  opacity: 1;
  transform: translateY(0);
}
.sustainability-overview .sustainability-sticky-bar:focus-within:not(.is-sticky):is(:has(.sticky-bar-select-trigger:focus),
:has(.sticky-bar-nav-list a:focus)),
.sustainability-overview .sustainability-sticky-bar.is-expanded:not(.is-sticky) {
  opacity: 1;
  transform: translateY(0);
}
@media all and (min-width: 1440px) {
  .sustainability-overview .sustainability-sticky-bar:focus-within:not(.is-sticky):is(:has(.sticky-bar-select-trigger:focus),
  :has(.sticky-bar-nav-list a:focus)),
  .sustainability-overview .sustainability-sticky-bar.is-expanded:not(.is-sticky) {
    opacity: 1;
    transform: translateY(0);
  }
}

.sustainability-sticky-bar {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  padding: 0 1.25rem;
  gap: 0.25rem;
  transition: box-shadow 0.4s ease;
  background: #FFFFFF;
}
@media all and (min-width: 768px) {
  .sustainability-sticky-bar {
    padding: 0.375rem 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar {
    padding: 0;
  }
}
.sustainability-sticky-bar.is-sticky {
  position: fixed;
  top: 0;
  z-index: 99;
  transition: box-shadow 0.4s ease, top 0.3s ease;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky {
    transition: box-shadow 0.4s ease;
  }
}
.sustainability-sticky-bar.is-sticky.is-expanded {
  z-index: 98;
}
body.layer-open .sustainability-overview .sustainability-sticky-bar.is-sticky {
  display: none;
}
.sustainability-sticky-bar .sustainability-sticky-bar-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0.25rem;
  transition: box-shadow 0.4s ease;
  background: #FFFFFF;
}
.sustainability-sticky-bar .sticky-bar-nav {
  position: relative;
  width: 100%;
  display: flex;
  align-items: center;
  max-width: 0;
  overflow: hidden;
  opacity: 0;
  white-space: nowrap;
  transition: max-width 0.5s cubic-bezier(0.4, 0, 0.2, 1), transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.sustainability-sticky-bar .sticky-bar-nav-list {
  display: flex;
  align-items: center;
  gap: 0.25rem;
  padding-right: 0.75rem;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar .sticky-bar-nav-list {
    white-space: nowrap;
    gap: 0.5rem;
    padding: 0.75rem 1.75rem;
  }
}
.sustainability-sticky-bar .sticky-bar-nav-list li a {
  display: block;
  text-decoration: none;
}
.sustainability-sticky-bar .sticky-bar-nav-list li a:hover, .sustainability-sticky-bar .sticky-bar-nav-list li a.is-active {
  font-weight: 600;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar .sticky-bar-nav-list li a {
    transition: background-color 0.3s ease;
    display: flex;
    position: relative;
  }
  .sustainability-sticky-bar .sticky-bar-nav-list li a:hover::after, .sustainability-sticky-bar .sticky-bar-nav-list li a.is-active::after {
    content: "";
    position: absolute;
    bottom: -0.6875rem;
    left: 0;
    width: 100%;
    height: 4px;
    background-color: #000000;
  }
}
.sustainability-sticky-bar .sticky-bar-select-trigger {
  width: 100%;
  max-width: 15rem;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.5rem;
  border: none;
  cursor: pointer;
  font-weight: 600;
  text-align: left;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar .sticky-bar-select-trigger {
    display: none;
  }
}
.sustainability-sticky-bar .sticky-bar-select-trigger-icon {
  display: block;
  width: 1.5rem;
  height: 1.5rem;
  margin: 0.5rem;
  flex-shrink: 0;
  transition: transform 0.2s ease;
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav, .sustainability-sticky-bar.is-expanded .sticky-bar-nav {
  overflow: visible;
  transition: max-width 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.3s, opacity 0.4s ease 0.4s, transform 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.3s;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav, .sustainability-sticky-bar.is-expanded .sticky-bar-nav {
    transition: max-width 0.5s cubic-bezier(0.4, 0, 0.2, 1) 0.3s, opacity 0.4s ease;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-select-trigger {
  display: flex;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-select-trigger, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-select-trigger {
    display: none;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav.is-open .sticky-bar-select-trigger-icon, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav.is-open .sticky-bar-select-trigger-icon, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav.is-open .sticky-bar-select-trigger-icon, .sustainability-sticky-bar.is-expanded .sticky-bar-nav.is-open .sticky-bar-select-trigger-icon {
  transform: rotate(180deg);
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list {
  width: 100%;
  display: none;
  flex-direction: column;
  text-align: left;
  z-index: 1;
  padding: 0.25rem 0 0;
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list li {
  display: block;
  width: 100%;
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list li a {
  display: block;
  padding-block: 0.6875rem;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list {
    width: auto;
    display: flex;
    flex-direction: row;
    position: static;
    padding: 0;
    padding-right: 1rem;
    background: transparent;
    backdrop-filter: none;
    box-shadow: none;
    border-radius: 0;
    box-shadow: none;
    gap: 0.5rem;
  }
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list li, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list li {
    display: block;
    width: auto;
    padding: 0.5625rem 1.625rem;
  }
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list li a, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list li a {
    transition: background-color 0.3s ease;
  }
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav .sticky-bar-nav-list li a.is-active, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav .sticky-bar-nav-list li a.is-active, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav .sticky-bar-nav-list li a.is-active, .sustainability-sticky-bar.is-expanded .sticky-bar-nav .sticky-bar-nav-list li a.is-active {
    color: #111;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar.is-expanded .sticky-bar-nav.is-open .sticky-bar-nav-list {
  display: flex;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list, .sustainability-sticky-bar.is-expanded .sticky-bar-nav.is-open .sticky-bar-nav-list {
    display: flex;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav.is-open .sticky-bar-nav-list li:has(.is-active), .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list li:has(.is-active), .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav.is-open .sticky-bar-nav-list li:has(.is-active), .sustainability-sticky-bar.is-expanded .sticky-bar-nav.is-open .sticky-bar-nav-list li:has(.is-active) {
  display: none;
}
.sustainability-sticky-bar .sticky-bar-cta {
  transition: transform 0.5s cubic-bezier(0.4, 0, 0.2, 1);
}
.sustainability-sticky-bar .sticky-bar-cta-link {
  display: block;
  padding: 0.625rem 0.875rem;
  margin: 0.25rem 0;
  font-size: 0.875rem;
  line-height: 142%;
  font-weight: 500;
  color: #FFFFFF;
  background-color: #ea1917;
  border-radius: 6.25rem;
  text-decoration: none;
  white-space: nowrap;
  transition: padding 0.4s ease, font-size 0.4s ease, background-color 0.3s ease;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar .sticky-bar-cta-link {
    padding: 0.875rem 1.125rem;
    font-size: 0.9375rem;
    line-height: 133%;
    font-weight: 600;
    color: #FFFFFF;
    letter-spacing: -0.2px;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus), .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus), .sustainability-sticky-bar.is-expanded {
    border-bottom: 1px solid #EFF0F2;
  }
}
.sustainability-sticky-bar.is-sticky .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar.is-expanded .sustainability-sticky-bar-inner {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 100%;
  gap: 0.25rem;
  transition: box-shadow 0.4s ease;
  background: #fff;
}
@media all and (min-width: 768px) {
  .sustainability-sticky-bar.is-sticky .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar.is-expanded .sustainability-sticky-bar-inner {
    justify-content: space-between;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sustainability-sticky-bar-inner, .sustainability-sticky-bar.is-expanded .sustainability-sticky-bar-inner {
    max-width: 90rem;
    justify-content: center;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav, .sustainability-sticky-bar.is-expanded .sticky-bar-nav {
  max-width: 100vw;
  opacity: 1;
  transform: scaleX(1);
  justify-content: space-between;
  flex-direction: column;
  align-items: flex-start;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-nav, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-nav, .sustainability-sticky-bar.is-expanded .sticky-bar-nav {
    max-width: fit-content;
  }
}
.sustainability-sticky-bar.is-sticky .sticky-bar-cta, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-cta, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-cta, .sustainability-sticky-bar.is-expanded .sticky-bar-cta {
  align-self: flex-start;
}
@media all and (min-width: 1440px) {
  .sustainability-sticky-bar.is-sticky .sticky-bar-cta, .sustainability-sticky-bar:focus-within:has(.sticky-bar-select-trigger:focus) .sticky-bar-cta, .sustainability-sticky-bar:focus-within:has(.sticky-bar-nav-list a:focus) .sticky-bar-cta, .sustainability-sticky-bar.is-expanded .sticky-bar-cta {
    align-self: center;
  }
}

/* keyvisual-main */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.sustainability-keyvisual {
  position: relative;
  width: 100%;
  aspect-ratio: 390/494;
  max-height: 30.875rem;
  margin: 0 auto;
  overflow: hidden;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual {
    aspect-ratio: 768/600;
    max-height: 37.5rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual {
    height: 100vh;
    max-height: 67.5rem;
  }
}
.sustainability-keyvisual .keyvisual-bg {
  width: 100%;
  height: 100%;
  background: linear-gradient(135deg, #2C3E50 0%, #4CA1AF 100%);
  z-index: 0;
}
.sustainability-keyvisual .keyvisual-poster {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  z-index: 2;
}
.sustainability-keyvisual .keyvisual-poster img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.sustainability-keyvisual .keyvisual-poster.is-hidden {
  display: none;
}
.sustainability-keyvisual .keyvisual-video {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  z-index: 1;
}
.sustainability-keyvisual .keyvisual-video-btn {
  position: absolute;
  bottom: 5.9375rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  background: none;
  border: none;
  padding: 0;
  cursor: pointer;
}
.sustainability-keyvisual .keyvisual-video-btn .icon-play {
  display: none;
}
.sustainability-keyvisual .keyvisual-video-btn.is-paused .icon-pause {
  display: none;
}
.sustainability-keyvisual .keyvisual-video-btn.is-paused .icon-play {
  display: block;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual .keyvisual-video-btn {
    bottom: 7.5rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-video-btn {
    position: relative;
    bottom: 0;
    left: 0;
    transform: translateX(0);
    margin-top: 1.5rem;
  }
}
.sustainability-keyvisual .keyvisual-arrow {
  width: 2.125rem;
  height: 2.9375rem;
  position: absolute;
  bottom: 1.5rem;
  left: 50%;
  transform: translateX(-50%);
  z-index: 10;
  animation: arrowBounce 1.5s ease-in-out infinite;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual .keyvisual-arrow {
    bottom: 2rem;
    width: 3rem;
    height: 4.25rem;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-arrow {
    bottom: 2.5rem;
    width: 4.25rem;
    height: 6rem;
  }
}
@keyframes arrowBounce {
  0%, 100% {
    transform: translateX(-50%) translateY(0);
  }
  50% {
    transform: translateX(-50%) translateY(10px);
  }
}
.sustainability-keyvisual .keyvisual-overlay {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  z-index: 3;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual .keyvisual-overlay {
    align-items: center;
    padding-top: 0;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-overlay {
    align-items: center;
    flex-direction: column;
  }
}
.sustainability-keyvisual .keyvisual-overlay-bg {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
  background: rgba(0, 0, 0, 0.4);
  clip-path: circle(0% at 50% 50%);
  opacity: 0;
}
.sustainability-keyvisual .keyvisual-overlay-content {
  text-align: center;
  padding-inline: 1.25rem;
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-overlay-content {
    padding: 0;
  }
}
.sustainability-keyvisual .keyvisual-overlay-title {
  opacity: 0;
  text-wrap: balance;
  word-break: keep-all;
  font-size: 1.625rem;
  line-height: 1.4615;
  font-weight: 600;
  color: #FFFFFF;
  letter-spacing: -0.5px;
}
.sustainability-keyvisual .keyvisual-overlay-title span {
  background: rgba(0, 0, 0, 0.4);
  padding: 0.125rem 0.5rem;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual .keyvisual-overlay-title {
    font-size: 1.875rem;
    line-height: 135%;
    font-weight: 600;
    color: #FFFFFF;
    letter-spacing: -0.5px;
  }
  .sustainability-keyvisual .keyvisual-overlay-title span {
    background: none;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-overlay-title {
    font-size: 2.25rem;
    line-height: 138%;
    font-weight: 600;
    color: #FFFFFF;
    letter-spacing: -0.5px;
  }
}
.sustainability-keyvisual .keyvisual-overlay-desc {
  font-size: 1rem;
  line-height: 137%;
  font-weight: 400;
  color: #FFFFFF;
  letter-spacing: -0.096px;
  margin-top: 0.25rem;
  opacity: 0;
  text-wrap: balance;
  word-break: keep-all;
}
.sustainability-keyvisual .keyvisual-overlay-desc span {
  background: rgba(0, 0, 0, 0.4);
  padding: 0.125rem 0.5rem;
  -webkit-box-decoration-break: clone;
  box-decoration-break: clone;
}
@media all and (min-width: 768px) {
  .sustainability-keyvisual .keyvisual-overlay-desc {
    font-size: 1.25rem;
    line-height: 120%;
    font-weight: 400;
    color: #FFFFFF;
    letter-spacing: -0.096px;
    max-width: 48rem;
    margin-top: 0.375rem;
  }
  .sustainability-keyvisual .keyvisual-overlay-desc span {
    background: none;
  }
}
@media all and (min-width: 1440px) {
  .sustainability-keyvisual .keyvisual-overlay-desc {
    font-size: 1.5rem;
    line-height: 133%;
    font-weight: 400;
    color: #FFFFFF;
    letter-spacing: -0.096px;
    max-width: 52.5rem;
    margin-top: 0.5rem;
  }
}

/* nav */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.component-nav {
  position: -webkit-sticky;
  position: sticky;
  z-index: 110;
  top: 0;
  background-color: #FFFFFF;
  width: 100%;
  border-bottom: 1px solid #F4F4F4;
  transition: top 0.3s ease;
}
body.layer-open .component-nav.is-sticky {
  display: none;
}
.component-nav.header-is-absolute {
  top: 0;
}
.component-nav.header-has-shadow {
  top: 2.875rem;
}
@media all and (min-width: 768px) {
  .component-nav.header-has-shadow {
    top: 0;
  }
}
.component-nav.header-has-shadow-hide {
  top: 0;
}
.component-nav {
  height: 3rem;
}
@media all and (min-width: 768px) {
  .component-nav {
    height: 4.25rem;
  }
}
@media all and (min-width: 1440px) {
  .component-nav {
    height: 3.75rem;
  }
}
.component-nav-nav {
  display: block;
  height: 100%;
  position: static;
}
.component-nav-list {
  display: flex;
  flex-direction: row;
  align-items: center;
  max-width: 86.25rem;
  margin: 0 auto;
  height: 100%;
  padding: 0 1.25rem;
  gap: 1.5rem;
}
@media all and (min-width: 1440px) {
  .component-nav-list {
    gap: 2.125rem;
    justify-content: flex-start;
    padding: 0;
  }
}
.component-nav-item {
  position: relative;
  text-align: center;
  height: 100%;
  display: flex;
  align-items: center;
}
.component-nav-item:hover .component-nav-sub, .component-nav-item.is-expanded .component-nav-sub, .component-nav-item:focus-within .component-nav-sub {
  display: block;
}
.component-nav-sub {
  display: none;
  position: absolute;
  top: calc(100% + 1px);
  left: 50%;
  transform: translateX(-50%);
  min-width: 8.125rem;
  background-color: #FFFFFF;
  box-shadow: 0 0 1px 0 rgba(0, 0, 0, 0.36), 0 2px 8px 0 rgba(0, 0, 0, 0.08);
  z-index: 99;
}
.component-nav-sub-list {
  display: flex;
  flex-direction: column;
}
.component-nav-sub-item {
  width: 100%;
  text-align: center;
  display: block;
}
.component-nav-sub-link {
  display: block;
  padding: 0.75rem 0.5rem;
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-3-ls);
  white-space: nowrap;
}
.component-nav-sub-link:hover {
  background-color: #F4F4F4;
  color: #000000;
  text-decoration: none;
}
.component-nav-sub-link.is-active {
  font-weight: var(--fw-bold);
  color: var(--default-color);
}
.component-nav-link {
  display: flex;
  align-items: center;
  position: relative;
  height: 100%;
  font-size: 0.875rem;
  line-height: 1.4286;
  font-weight: var(--fw-normal);
  color: var(--body-color);
  transition: color 0.3s ease, background-color 0.3s ease, font-weight 0.3s ease;
  white-space: nowrap;
}
@media all and (min-width: 1440px) {
  .component-nav-link {
    padding: 0;
    font-size: 1.1875rem;
    line-height: 1.3684;
    font-weight: var(--fw-normal);
    color: var(--body-color);
  }
}
.component-nav-link::before {
  content: "";
  position: absolute;
  bottom: -1px;
  left: 0;
  width: 100%;
  height: 0.25rem;
  background-color: transparent;
  transition: background-color 0.3s ease;
}
.component-nav-link:hover {
  background-color: transparent;
  color: #000000;
  text-decoration: none;
}
.component-nav-link.is-active {
  font-weight: var(--fw-bold);
  color: var(--default-color);
}
.component-nav-link.is-active::before {
  background-color: #111111;
}

/* contents-info */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-info__image, .contents-info__video {
  aspect-ratio: 350/196;
  border-radius: 1rem;
}
@media all and (min-width: 768px) {
  .contents-info__image, .contents-info__video {
    aspect-ratio: 944/480;
  }
}
.auto-height .contents-info__image, .auto-height .contents-info__video {
  aspect-ratio: auto;
}
.auto-height .contents-info__image img, .auto-height .contents-info__image video, .auto-height .contents-info__video img, .auto-height .contents-info__video video {
  height: auto;
}
.contents-info__image.wide {
  aspect-ratio: 350/123;
}
@media all and (min-width: 768px) {
  .contents-info__image.wide {
    aspect-ratio: 944/342;
  }
}
.contents-info__images-wrap .esg-layer-media.size1 {
  aspect-ratio: 350/220;
  width: 100%;
  flex: 1;
}
@media all and (min-width: 768px) {
  .contents-info__images-wrap .esg-layer-media.size1 {
    aspect-ratio: 466/320;
    max-width: 28.75rem;
  }
}
.contents-info .esg-layer-media.auto {
  aspect-ratio: auto;
}

/* contents-list-card */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-list-card__list {
  display: flex;
  flex-direction: column;
  gap: 2.5rem;
}
@media all and (min-width: 1440px) {
  .contents-list-card__list {
    gap: 3rem;
  }
}
.contents-list-card__item {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-direction: column;
}
@media all and (min-width: 768px) {
  .contents-list-card__item {
    gap: 1.25rem;
    flex-direction: row;
  }
}
@media all and (min-width: 1440px) {
  .contents-list-card__item {
    gap: 3rem;
  }
}
@media all and (min-width: 768px) {
  .contents-list-card__item--text-first .contents-list-card__media {
    order: 1;
  }
}
@media all and (min-width: 768px) {
  .contents-list-card__item--text-first .contents-list-card__text {
    order: -1;
  }
}
.contents-list-card__media {
  aspect-ratio: 312/196;
}
@media all and (min-width: 768px) {
  .contents-list-card__media {
    flex-basis: 21.875vw;
    width: 21.875vw;
    max-width: 26.25rem;
    min-width: 18.75rem;
    aspect-ratio: 420/264;
    order: initial;
  }
}
@media all and (min-width: 1440px) {
  .contents-list-card__media {
    flex-basis: 31.875rem;
    width: 26.5625vw;
    max-width: 31.875rem;
    aspect-ratio: 510/320;
  }
}
.contents-list-card__media .video-wrapper {
  border-radius: 62.4375rem;
}
.contents-list-card__media .video-wrapper.video-align-top video,
.contents-list-card__media video.video-align-top {
  object-position: center top;
  transform: scale(0.9);
  transform-origin: center bottom;
}
.contents-list-card__media.portrait {
  aspect-ratio: 328/460;
}
@media all and (min-width: 768px) {
  .contents-list-card__media.portrait {
    max-width: 17.5rem;
    aspect-ratio: 342/480;
  }
}
@media all and (min-width: 1440px) {
  .contents-list-card__media.portrait {
    max-width: 21.375rem;
  }
}
.contents-list-card__text {
  flex: 1;
  width: 100%;
}

/* contents-info-list */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-info-list sup, .contents-info-list sub {
  display: inline-flex;
}
.contents-info-list, .contents-info-list *:not(sup, sub) {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
}
.contents-info-list-disclaimer {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-top-label {
  display: block;
  font-weight: 600;
  font-size: 0.9375rem;
  line-height: 133.333%;
  font-weight: 600;
  color: #646464;
}
@media all and (min-width: 768px) {
  .contents-info-list .disclaimer-top-label {
    font-size: 0.875rem;
    line-height: 142.857%;
    font-weight: 600;
    color: #646464;
  }
}
.contents-info-list .disclaimer-top-label + .contents-table {
  margin-block: 0.25rem;
}
.contents-info-list .disclaimer-label {
  display: block;
}
.contents-info-list .disclaimer-content {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .esg-layer-disclaimer + .esg-layer-disclaimer {
  margin-top: 0rem;
}
.contents-info-list .esg-layer-disclaimer + .disclaimer-list-primary {
  margin-top: 0.75rem;
}
.contents-info-list .disclaimer-list-primary {
  list-style: none;
  margin: 0;
  padding: 0;
  counter-reset: primary-item;
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media all and (min-width: 768px) {
  .contents-info-list .disclaimer-list-primary {
    gap: 1rem;
  }
}
.contents-info-list .disclaimer-list-primary > li {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-list-secondary {
  list-style: none;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-list-secondary > li {
  padding-left: 1.25rem;
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
@media all and (min-width: 768px) {
  .contents-info-list .disclaimer-list-secondary > li {
    padding-left: 1.5rem;
  }
}
.contents-info-list .disclaimer-list-secondary > li::before {
  content: "•";
  position: absolute;
  left: 0.5rem;
}
.contents-info-list .disclaimer-list-tertiary {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-list-tertiary > li {
  position: relative;
  counter-increment: item;
}
.contents-info-list .disclaimer-list-tertiary > li::before {
  content: counter(item) ". ";
}
.contents-info-list .disclaimer-list-tertiary > li > span + .disclaimer-items-quaternary {
  margin-block-start: 0.25rem;
}
.contents-info-list .disclaimer-items-quaternary {
  list-style: disc;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-items-quaternary > li {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list .disclaimer-items-tertiary {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-info-list:has(.disclaimer-more-button) {
  position: relative;
  padding-bottom: 0;
}
.contents-info-list:has(.disclaimer-more-button) .disclaimer-hidden-m {
  display: none;
}
@media all and (min-width: 768px) {
  .contents-info-list:has(.disclaimer-more-button) .disclaimer-hidden-m {
    display: flex !important;
  }
}
@media all and (min-width: 1440px) {
  .contents-info-list:has(.disclaimer-more-button) .disclaimer-hidden-m {
    display: flex !important;
  }
}
.contents-info-list .disclaimer-more-button {
  font-size: 0.625rem;
  line-height: 160%;
  font-weight: 400;
  color: #727780;
  padding: 0.5rem 0 1.5rem;
  margin-top: 0.75rem;
  text-align: center;
  background: linear-gradient(to bottom, rgba(255, 255, 255, 0) 0%, rgb(255, 255, 255) 50%, rgb(255, 255, 255) 100%);
  width: 100%;
  position: relative;
  cursor: pointer;
  border: none;
}
.contents-info-list .disclaimer-more-button::after {
  display: block;
  content: "";
  position: absolute;
  bottom: 0.5rem;
  left: 50%;
  width: 1rem;
  height: 1rem;
  background: url("/kr/sustainability/2025/common/images/sustainability-2025-assets-common-ico-read-more.svg") no-repeat center center;
  background-size: contain;
  transform: translateX(-50%);
  transition: transform 0.3s ease;
}
.contents-info-list .disclaimer-more-button.is-open {
  padding: 1.5rem 0 1.5rem;
  background: transparent;
  margin-top: 0;
}
.contents-info-list .disclaimer-more-button.is-open::after {
  transform: translateX(-50%) rotate(180deg);
}
@media all and (min-width: 768px) {
  .contents-info-list .disclaimer-more-button {
    display: none;
  }
}
@media all and (min-width: 1440px) {
  .contents-info-list .disclaimer-more-button {
    display: none;
  }
}

/* contents-grid */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-grid__item {
  display: flex;
  align-items: center;
  gap: 1rem;
  flex-direction: column;
}
@media all and (min-width: 768px) {
  .contents-grid__item {
    flex-direction: row;
    gap: 3rem;
  }
}
.contents-grid__media {
  aspect-ratio: 35/22;
  border-radius: 0.75rem;
  order: -1;
}
.contents-grid__media.auto {
  aspect-ratio: auto;
}
@media all and (min-width: 768px) {
  .contents-grid__media {
    width: 23.9583333333vw;
    max-width: 28.75rem;
    min-width: 18.75rem;
    aspect-ratio: 460/280;
    order: initial;
  }
}
@media all and (min-width: 1440px) {
  .contents-grid__media {
    width: 23.9583333333vw;
    max-width: 28.75rem;
    aspect-ratio: 460/280;
  }
}
.contents-grid__media .video-wrapper {
  border-radius: 62.4375rem;
}
.contents-grid__text {
  flex: 1;
}

/* contents-graph */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-graph .esg-layer-eyebrow-l {
  margin-bottom: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-graph .esg-layer-eyebrow-l {
    margin-bottom: 1.5rem;
  }
}
.contents-graph .contents-graph-chart-container {
  background-color: #f2f2f2;
  border-radius: 1.75rem;
  padding: 1.75rem 1.5rem;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-chart-container {
    border-radius: 1.5rem;
    padding: 2rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-chart-container {
    border-radius: 1.75rem;
    padding: 2.5rem;
  }
}
.contents-graph .contents-graph-disclaimer + .contents-graph-chart-container {
  margin-top: 0;
}
.contents-graph .contents-graph-bar-chart {
  margin-bottom: 1.5rem;
  padding: 0;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart {
    margin-bottom: 0.875rem;
    padding: 1.25rem 0;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart {
    margin-bottom: 1rem;
    padding: 1.5rem 0;
  }
}
.contents-graph .contents-graph-bar-chart:last-child {
  margin-bottom: 0;
}
.contents-graph .contents-graph-bar-chart h4 {
  font-size: 0.8125rem;
  line-height: 18px;
  font-weight: 300;
  color: #111111;
  margin-bottom: 0.25rem;
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart h4 {
    margin-bottom: 0.5rem;
  }
}
.contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary {
  font-size: 1.0625rem;
  line-height: 1.4118;
  font-weight: 600;
  color: #111111;
  letter-spacing: -0.3px;
  margin-bottom: 0.5rem;
}
.contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary br {
  display: none;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary br {
    display: block;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary br {
    display: block;
  }
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary {
    font-size: 1.375rem;
    line-height: 136%;
    font-weight: 600;
    color: #111111;
    letter-spacing: -0.088px;
    margin-bottom: 0.5rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-summary {
    margin-bottom: 0.75rem;
  }
}
.contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-description {
  font-size: 0.8125rem;
  line-height: 138%;
  font-weight: 400;
  color: #777777;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-description {
    font-size: 0.8125rem;
    line-height: 138%;
    font-weight: 400;
    color: #777777;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-description {
    font-size: 0.8125rem;
    line-height: 138%;
    font-weight: 400;
    color: #777777;
  }
}
.contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-content {
  display: flex;
  flex-direction: column;
  margin-top: 0.75rem;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-content {
    margin-top: 1.5rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-content {
    margin-top: 1.5rem;
  }
}
.contents-graph .contents-graph-bar-chart .contents-graph-bar-chart-content picture img {
  width: 100%;
  height: auto;
  display: block;
}
.contents-graph .contents-graph-bar-chart .contents-graph-contents .contents-graph-disclaimer {
  margin-top: 0.75rem;
}
.contents-graph .contents-graph-bar-item {
  display: flex;
  align-items: center;
}
.contents-graph .contents-graph-bar-wrapper {
  width: 100%;
}
.contents-graph .contents-graph-bar {
  height: 4.25rem;
  min-width: 0;
  flex-shrink: 0;
  border-radius: 0.5rem;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar {
    height: 3.125rem;
    border-radius: 0.5rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar {
    height: 3.125rem;
    border-radius: 0.5rem;
  }
}
.contents-graph .contents-graph-bar-value {
  font-size: 1.0625rem;
  line-height: 141%;
  font-weight: 400;
  color: #FFFFFF;
  flex-shrink: 0;
}
.contents-graph .contents-graph-bar-value.invert {
  color: #000000;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-value {
    font-size: 1.5rem;
    line-height: 1.3333;
    font-weight: 400;
    color: #111111;
    position: absolute;
    min-width: 5.5625rem;
    right: -6rem;
    top: 50%;
    transform: translateY(-50%);
    transform-origin: right center;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-value {
    font-size: 1.75rem;
    line-height: 1.3571;
    font-weight: 400;
    color: #111111;
    right: -6.375rem;
  }
}
.contents-graph .contents-graph-bar-legend-wrapper {
  display: flex;
  align-items: center;
  flex-direction: column;
  align-items: flex-start;
  justify-content: center;
  width: 100%;
  height: 100%;
  position: relative;
  padding: 0.6875rem 1rem;
}
.contents-graph .contents-graph-bar-legend {
  font-size: 1rem;
  line-height: 1.375;
  font-weight: 400;
  color: #FFFFFF;
  letter-spacing: -0.2px;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-legend {
    font-size: 1.125rem;
    line-height: 1.4444;
    font-weight: 400;
    color: #FFFFFF;
    letter-spacing: 0px;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-legend {
    font-size: 1.25rem;
    line-height: 1.4;
    font-weight: 400;
    color: #FFFFFF;
  }
}
.contents-graph .contents-graph-bar-legend.invert {
  color: #000000;
}
.contents-graph .contents-graph-bar-chart-axis {
  display: flex;
  justify-content: space-between;
  border-top: 1px solid #777777;
  padding-top: 0.25rem;
  margin-bottom: 0.75rem;
  font-size: 1rem;
  line-height: 1.375;
  font-weight: 400;
  color: #646464;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart-axis {
    margin-bottom: 1.5rem;
    font-size: 0.8125rem;
    line-height: 1.3846;
    font-weight: 400;
    color: #646464;
    border-top: 1px solid #777777;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-bar-chart-axis {
    margin-bottom: 1.5rem;
    border-top: 1px solid #777777;
  }
}
.contents-graph .contents-graph-bar-chart-axis-label {
  font-size: 0.875rem;
  line-height: 114%;
  font-weight: 400;
  color: #646464;
  text-align: center;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-bar-chart-axis-label {
    font-size: 0.9375rem;
    line-height: 1.3333;
    font-weight: 400;
    color: #646464;
  }
}
.contents-graph .contents-graph-disclaimer {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-disclaimer {
    padding-top: 0.75rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-disclaimer {
    padding-top: 0.75rem;
  }
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-disclaimer.contents-graph-disclaimer-pt-0 {
    padding-top: 0;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-disclaimer.contents-graph-disclaimer-pt-0 {
    padding-top: 0;
  }
}
.contents-graph .contents-graph-disclaimer p {
  font-size: 0.8125rem;
  line-height: 138%;
  font-weight: 400;
  color: #646464;
}
@media all and (min-width: 768px) {
  .contents-graph .contents-graph-disclaimer p {
    font-size: 0.8125rem;
    line-height: 138%;
    font-weight: 400;
    color: #646464;
  }
}
@media all and (min-width: 1440px) {
  .contents-graph .contents-graph-disclaimer p {
    font-size: 0.8125rem;
    line-height: 138%;
    font-weight: 400;
    color: #646464;
  }
}

/* contents-steps */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-steps {
  display: flex;
  flex-wrap: wrap;
  gap: 1.625rem;
}
@media all and (min-width: 768px) {
  .contents-steps {
    flex-wrap: nowrap;
    gap: 1.75rem;
    overflow-x: auto;
    margin: 0 -1.625rem;
    padding: 0 1.625rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-steps {
    overflow-x: auto;
    margin: 0 -2.5rem;
    padding: 0 2.5rem;
  }
}
.contents-steps .contents-steps-item {
  width: 100%;
  max-width: 25rem;
  margin-inline: auto;
  text-align: center;
  position: relative;
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item {
    width: calc((100% - 5.25rem) / 4);
    min-width: 13.4375rem;
  }
}
.contents-steps .contents-steps-item .contents-steps-image {
  width: 100%;
  aspect-ratio: 350/164;
  border-radius: 31.25rem;
  overflow: hidden;
  height: 100%;
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item .contents-steps-image {
    max-width: 13.4375rem;
    width: 100%;
    aspect-ratio: 215/360;
    border-radius: 31.25rem;
  }
}
.contents-steps .contents-steps-item .contents-steps-image img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.contents-steps .contents-steps-item .text-box {
  font-size: 1rem;
  line-height: 125%;
  font-weight: 400;
  color: #262626;
  position: absolute;
  top: 50%;
  left: 0.75rem;
  height: calc(100% - 1.5rem);
  display: flex;
  align-items: center;
  text-align: center;
  justify-content: center;
  flex-direction: column;
  border-radius: 62.4375rem;
  background: linear-gradient(0deg, rgba(0, 0, 0, 0.4) 0%, rgba(0, 0, 0, 0.4) 100%), rgba(255, 255, 255, 0.4);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  transform: translateY(-50%);
  aspect-ratio: 1/1;
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item .text-box {
    font-size: 1rem;
    line-height: 125%;
    font-weight: 400;
    color: #262626;
    top: initial;
    bottom: 0.875rem;
    left: 50%;
    transform: translateX(-50%);
    width: 11.25rem;
    height: 11.25rem;
    border-radius: 62.4375rem;
  }
}
.contents-steps .contents-steps-item .text-box::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  border: 1px solid transparent;
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.6), rgba(255, 255, 255, 0.05) 40%, rgba(255, 255, 255, 0.05) 60%, rgba(255, 255, 255, 0.4)) border-box;
  mask: linear-gradient(#fff 0 0) padding-box, linear-gradient(#fff 0 0);
  mask-composite: exclude;
  pointer-events: none;
}
.contents-steps .contents-steps-item .text-box .step {
  font-size: 0.8125rem;
  line-height: 138%;
  font-weight: 400;
  color: #FFFFFF;
  margin-bottom: 0.25rem;
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item .text-box .step {
    margin-bottom: 0.5rem;
  }
}
.contents-steps .contents-steps-item .text-box .step-text {
  font-size: 1rem;
  line-height: 133.333%;
  font-weight: 600;
  color: #FFFFFF;
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item .text-box .step-text {
    font-size: 1rem;
    line-height: 137.5%;
    font-weight: 600;
    color: #FFFFFF;
  }
}
.contents-steps .contents-steps-item:not(:last-child)::after {
  content: "";
  position: absolute;
  bottom: -1.375rem;
  left: 50%;
  width: 0;
  height: 0;
  border-top: 0.5625rem solid transparent;
  border-bottom: 0.5625rem solid transparent;
  border-left: 0.625rem solid #4A4946;
  transform: translateX(-50%) rotate(90deg);
}
@media all and (min-width: 768px) {
  .contents-steps .contents-steps-item:not(:last-child)::after {
    bottom: initial;
    top: 50%;
    left: initial;
    right: -1.25rem;
    border-top: 0.75rem solid transparent;
    border-bottom: 0.75rem solid transparent;
    border-left: 0.75rem solid #4A4946;
    transform: translateY(-50%) rotate(0deg);
  }
}

/* contents-table */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-table .esg-layer-eyebrow-l + .contents-table-wrap {
  margin-top: 1rem;
}
.contents-table .esg-layer-eyebrow-l + .esg-layer-body-list {
  margin-top: 1rem;
}
@media all and (min-width: 768px) {
  .contents-table .esg-layer-eyebrow-l + .esg-layer-body-list {
    margin-top: 1.5rem;
  }
}
.contents-table .esg-layer-body-list {
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
.contents-table .esg-layer-body-list-item {
  position: relative;
  padding-left: 0.75rem;
}
.contents-table .esg-layer-body-list-item::before {
  content: "";
  position: absolute;
  left: 0;
  top: 0.375rem;
  width: 0.25rem;
  height: 0.25rem;
  background-color: #000;
  border-radius: 50%;
}
@media all and (min-width: 768px) {
  .contents-table .esg-layer-body-list-item::before {
    top: 0.4375rem;
  }
}
.contents-table .esg-layer-body-list + .contents-table-wrap {
  margin-top: 1rem;
}
.contents-table .contents-table-wrap {
  width: 100%;
}
.contents-table .contents-table-wrap.scroll-x {
  overflow-x: auto;
  margin-inline: -1.25rem;
  padding-inline: 1.25rem;
  width: calc(100% + 2.5rem);
}
.contents-table .contents-table-wrap.scroll-x::-webkit-scrollbar {
  height: 0.375rem;
  background: rgba(0, 0, 0, 0.05);
  border-radius: 0.375rem;
}
.contents-table .contents-table-wrap.scroll-x::-webkit-scrollbar-track {
  margin: 0;
  background: rgba(0, 0, 0, 0.05);
  border-radius: 0.375rem;
}
.contents-table .contents-table-wrap.scroll-x::-webkit-scrollbar-thumb {
  background: #646464;
  border-radius: 0.375rem;
}
@media all and (min-width: 768px) {
  .contents-table .contents-table-wrap.scroll-x {
    margin-inline: 0;
    padding-inline: 0;
    width: 100%;
  }
}
.contents-table .contents-table-wrap.scroll-x {
  /* 가로 스크롤 시 테이블 최소 너비 고정 → col %가 3·4번째 컬럼까지 동일 비율로 적용 */
}
.contents-table .contents-table-wrap.scroll-x table {
  min-width: 45.4375rem;
}
.contents-table table {
  width: 100%;
  min-width: 100%;
  table-layout: fixed; /* colgroup col width 적용 */
  border-collapse: collapse;
  border: none;
}
.contents-table table th,
.contents-table table td {
  border-right: 1px solid #dddddd;
  border-bottom: 1px solid #dddddd;
  vertical-align: middle;
}
.contents-table table th:last-child,
.contents-table table td:last-child {
  border-right: none;
}
.contents-table table th:last-child[rowspan],
.contents-table table td:last-child[rowspan] {
  border-left: 1px solid #dddddd;
}
.contents-table table th {
  font-size: calc(var(--esg-font-table-th-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-th-lh) / 16 * 1rem);
  font-weight: var(--esg-font-table-th-fw);
  text-align: center;
  background-color: #777777;
  color: #ffffff;
  padding: 0.75rem 1.25rem;
}
@media all and (min-width: 768px) {
  .contents-table table th {
    padding: 1rem 1.5rem;
  }
}
.contents-table table tbody {
  width: 100%;
}
.contents-table table tbody td {
  padding: 0.75rem 1.25rem;
  text-align: center;
  font-size: calc(var(--esg-font-table-td-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-td-lh) / 16 * 1rem);
}
@media all and (min-width: 768px) {
  .contents-table table tbody td {
    padding: 1.25rem 1.5rem;
  }
}
.contents-table table tbody td[rowspan] {
  border-left: 1px solid #cbc8c2;
}
.contents-table table tbody td.align-left {
  text-align: left;
}
.contents-table table tbody td .contents-cell {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
  text-align: left;
}
.contents-table table tbody td .contents-cell .contents-title {
  display: block;
  font-size: calc(var(--esg-font-table-th-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-th-lh) / 16 * 1rem);
  font-weight: var(--esg-font-table-th-fw);
  font-weight: 600;
}
.contents-table table tbody td .contents-cell .contents-disclaimer {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.contents-table table tbody td .contents-cell .contents-disclaimer-item {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
}
.contents-table-small table th {
  padding: 0.5rem 1.5rem;
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 600;
}
.contents-table-small table tbody td {
  padding: 0.5rem 1.5rem;
  font-size: 0.8125rem;
  line-height: 1.3846;
  font-weight: 400;
}
.contents-table .esg-layer-disclaimer {
  margin-block-start: 1rem;
}

/* contents-water-usage */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-water-usage {
  display: flex;
  gap: 1rem;
  flex-direction: column;
}
@media all and (min-width: 768px) {
  .contents-water-usage {
    gap: 1.5rem;
    flex-direction: row;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage {
    gap: 1.5rem;
  }
}
.contents-water-usage .content-section-half {
  flex-direction: column;
}
.contents-water-usage .content-circular-graph {
  flex-shrink: 0;
  margin-top: 0;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph {
    margin-top: 0.375rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph {
    margin-top: 0.5rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-label {
  font-size: 1rem;
  line-height: 125%;
  font-weight: 400;
  color: #262626;
  margin-bottom: 1.5rem;
  text-align: center;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-label {
    font-size: 1rem;
    line-height: 125%;
    font-weight: 400;
    color: #262626;
    margin-bottom: 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-label {
    font-size: 1rem;
    line-height: 125%;
    font-weight: 400;
    color: #262626;
    margin-bottom: 1.5rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image {
  width: 100%;
  display: flex;
  justify-content: center;
}
.contents-water-usage .content-circular-graph .content-circular-graph-image img {
  max-width: 100%;
  height: auto;
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage {
  display: flex;
  align-items: flex-end;
  justify-content: center;
  gap: 0;
  position: relative;
  width: 100%;
  border-block: 1px solid #646464;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage {
    width: auto;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before,
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  color: #FFFFFF;
  flex-shrink: 0;
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before {
  width: 64%;
  background: linear-gradient(0deg, #262626 0%, #262626 100%), radial-gradient(50% 50% at 50% 50%, rgba(0, 0, 0, 0) 35%, rgba(0, 0, 0, 0.1) 100%);
  z-index: 0;
  aspect-ratio: 1/1;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before {
    width: 25vw;
    max-width: 20rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before {
    width: 20rem;
    height: 20rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before::after {
  content: "";
  width: 1px;
  height: 100%;
  background-color: #646464;
  display: block;
  position: absolute;
  top: 0;
  right: 18%;
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-before::after {
    right: 4.6875rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after {
  width: 36%;
  aspect-ratio: 1/1;
  background: linear-gradient(0deg, #498435 0%, #498435 100%), radial-gradient(50% 50% at 50% 50%, rgba(89, 206, 50, 0) 79.82%, rgba(89, 206, 50, 0.2) 100%);
  z-index: 1;
  position: relative;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after {
    width: 14.0625vw;
    max-width: 11.25rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after {
    width: 9.375rem;
    height: 9.375rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after::before {
  content: "";
  width: 0;
  height: 0;
  border-left: 0.375rem solid transparent;
  border-right: 0.375rem solid transparent;
  border-bottom: 0.5625rem solid #646464;
  position: absolute;
  top: -78%;
  left: 50%;
  transform: translateX(-50%);
  z-index: 1;
  display: block;
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after::before {
    top: -114%;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after::after {
  content: "";
  width: 0;
  height: 0;
  border-left: 0.375rem solid transparent;
  border-right: 0.375rem solid transparent;
  border-bottom: 0.5625rem solid #646464;
  position: absolute;
  top: 0;
  left: 50%;
  transform: translate(-50%, -100%) rotate(180deg);
  z-index: 1;
  display: block;
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-after .content-water-usage-value {
    font-size: 2.625rem;
    line-height: 1.0714;
    font-weight: 250;
    color: #FFFFFF;
    margin-bottom: 0;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-value {
  font-size: 2rem;
  line-height: 84%;
  font-weight: 250;
  color: #FFFFFF;
  margin-bottom: 0.5rem;
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-value {
    margin-bottom: 0.5rem;
  }
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-value {
    font-size: 3.5rem;
    line-height: 84%;
    font-weight: 250;
    color: #FFFFFF;
    margin-bottom: 0.5rem;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-label {
  font-size: 0.875rem;
  line-height: 114%;
  font-weight: 400;
  color: #FFFFFF;
}
@media all and (min-width: 1440px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-image .content-water-usage .content-water-usage-label {
    font-size: 1rem;
    line-height: 125%;
    font-weight: 400;
    color: #FFFFFF;
  }
}
.contents-water-usage .content-circular-graph .content-circular-graph-caption {
  margin-top: 1rem;
  text-align: center;
  font-size: calc(var(--esg-font-body-2-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-2-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-body-2-ls);
}
@media all and (min-width: 768px) {
  .contents-water-usage .content-circular-graph .content-circular-graph-caption {
    margin-top: 1.75rem;
  }
}

/* text-info-box */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.text-info-box__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media all and (min-width: 768px) {
  .text-info-box__list {
    gap: 1.25rem;
  }
}
@media all and (min-width: 1440px) {
  .text-info-box__list {
    gap: 1.5rem;
  }
}
.text-info-box__item {
  background-color: #F2F2F2;
  padding: 1.5rem 1.25rem;
  border-radius: 0.75rem;
}
@media all and (min-width: 1440px) {
  .text-info-box__item {
    border-radius: 1rem;
    padding: 2.5rem 1.5rem;
  }
}
.text-info-box__item .esg-layer-title-third:first-child {
  color: #357F1C;
}
.text-info-box.col {
  padding-inline: 0;
}
.text-info-box.col .text-info-box__list {
  display: grid;
  grid-template-columns: 1fr;
}
@media all and (min-width: 768px) {
  .text-info-box.col .text-info-box__list {
    grid-template-columns: repeat(3, 1fr);
  }
}
@media all and (min-width: 1440px) {
  .text-info-box.col .text-info-box__list {
    grid-template-columns: repeat(3, 1fr);
  }
}

/* contents-discoloration-test */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-discoloration-test__wrapper {
  background-color: #f4f4f4;
  padding: 1.5rem 1rem;
  margin-block-end: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-discoloration-test__wrapper {
    padding: 2.5rem;
  }
}
.contents-discoloration-test__desc {
  font-size: calc(var(--esg-font-eyebrow-s-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) / 16 * 1rem);
  margin-block-end: 0.5rem;
}
@media all and (min-width: 1440px) {
  .contents-discoloration-test__desc {
    margin-block-end: 1rem;
  }
}
.contents-discoloration-test__title {
  font-size: calc(var(--esg-font-heading-7-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-7-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-7-fw);
  margin-block-end: 0.5rem;
}
@media all and (min-width: 1440px) {
  .contents-discoloration-test__title {
    margin-block-end: 1rem;
  }
}
.contents-discoloration-test__table-wrap {
  overflow: hidden;
}
.contents-discoloration-test__table-wrap.scroll-x {
  overflow-x: auto;
  margin-inline: -1rem;
  padding-inline: 1rem;
  width: calc(100% + 2rem);
}
.contents-discoloration-test__table-wrap.scroll-x::-webkit-scrollbar {
  height: 0.375rem;
  background: rgba(0, 0, 0, 0.05);
  border-radius: 0.375rem;
}
.contents-discoloration-test__table-wrap.scroll-x::-webkit-scrollbar-track {
  margin: 0;
  background: rgba(0, 0, 0, 0.05);
  border-radius: 0.375rem;
}
.contents-discoloration-test__table-wrap.scroll-x::-webkit-scrollbar-thumb {
  background: #646464;
  border-radius: 0.375rem;
}
@media all and (min-width: 768px) {
  .contents-discoloration-test__table-wrap.scroll-x {
    margin-inline: 0;
    padding-inline: 0;
    width: 100%;
  }
}
.contents-discoloration-test__table-wrap.scroll-x table {
  min-width: 53rem;
}
.contents-discoloration-test table {
  width: 100%;
  border-collapse: collapse;
  table-layout: fixed;
}
.contents-discoloration-test table th, .contents-discoloration-test table td {
  border-right: 1px solid #dddddd;
  border-bottom: 1px solid #dddddd;
  vertical-align: middle;
  text-align: center;
}
.contents-discoloration-test table th:last-child, .contents-discoloration-test table td:last-child {
  border-right: none;
}
.contents-discoloration-test table th {
  font-size: calc(var(--esg-font-table-th-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-th-lh) / 16 * 1rem);
  font-weight: var(--esg-font-table-th-fw);
  background-color: #777777;
  color: #ffffff;
  padding: 0.75rem 1.25rem;
}
@media all and (min-width: 768px) {
  .contents-discoloration-test table th {
    padding: 1rem 1.5rem;
  }
}
.contents-discoloration-test table tbody th {
  background-color: #fff;
  color: #000;
  text-align: left;
}
.contents-discoloration-test table tbody th .condition-cell {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
}
@media all and (min-width: 768px) {
  .contents-discoloration-test table tbody th .condition-cell {
    gap: 0.5rem;
  }
}
.contents-discoloration-test table tbody th .condition-cell .condition-icon {
  width: 2rem;
  height: 2rem;
}
.contents-discoloration-test table tbody th .condition-cell .condition-icon img {
  width: 100%;
  height: auto;
}
.contents-discoloration-test table tbody th .condition-cell .condition-text {
  font-size: calc(var(--esg-font-table-td-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-td-lh) / 16 * 1rem);
  font-weight: 400;
  color: #000;
}
@media all and (min-width: 1440px) {
  .contents-discoloration-test table tbody th .condition-cell .condition-text {
    white-space: nowrap;
  }
}
.contents-discoloration-test table tbody td {
  background-color: #fff;
  padding: 0.75rem 1.25rem;
  font-size: calc(var(--esg-font-table-td-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-table-td-lh) / 16 * 1rem);
}
@media all and (min-width: 768px) {
  .contents-discoloration-test table tbody td {
    padding: 1.25rem 1.5rem;
  }
}
.contents-discoloration-test table tbody td .test-result {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
}
.contents-discoloration-test table tbody td .sample-group {
  display: flex;
  width: 100%;
  height: 12.5rem;
  border-radius: 1rem;
  overflow: hidden;
}
@media all and (min-width: 1440px) {
  .contents-discoloration-test table tbody td .sample-group {
    height: 15rem;
  }
}
.contents-discoloration-test table tbody td .sample-group .sample-item {
  position: relative;
  flex: 1;
  height: 100%;
  display: flex;
  align-items: flex-start;
  padding: 0.75rem 0.5rem;
}
.contents-discoloration-test table tbody td .sample-group .sample-item .sample-label {
  width: 100%;
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
  text-align: center;
}
.contents-discoloration-test table tbody td .sample-group .sample-item .sample-label.esg-text-white {
  color: #ffffff;
}
.contents-discoloration-test table tbody td .badge-group {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.contents-discoloration-test table tbody td .badge-group .result-badge {
  position: absolute;
  background-color: #fff;
  padding: 0.5rem 0.625rem;
  border-radius: 0.75rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  transform: translate(-50%, -50%);
  top: 50%;
  left: 50%;
  z-index: 5;
}
.contents-discoloration-test table tbody td .badge-group .result-badge:nth-child(1) {
  top: 40%;
}
.contents-discoloration-test table tbody td .badge-group .result-badge:nth-child(2) {
  top: 60%;
}
.contents-discoloration-test table tbody td .badge-group .result-badge:only-child {
  top: 50%;
}
.contents-discoloration-test table tbody td .badge-group .result-badge .badge-text {
  font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
}
.contents-discoloration-test__disclaimers {
  margin-top: 1rem;
}
.contents-discoloration-test__disclaimers .esg-layer-disclaimer {
  color: #646464;
}
.contents-discoloration-test__disclaimers .esg-layer-disclaimer::before {
  content: none;
}
.contents-discoloration-test .footer-disclaimer {
  margin-top: 1rem;
}

/* contents-chart */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-chart .contents-chart-wrapper {
  background-color: #f4f4f4;
  padding: 1.5rem;
  margin-bottom: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-wrapper {
    padding: 2.5rem;
  }
}
.contents-chart .contents-chart-desc {
  font-size: calc(var(--esg-font-eyebrow-s-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) / 16 * 1rem);
  margin-block-end: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-desc {
    margin-block-end: 2.5rem;
  }
}
.contents-chart .contents-chart-legend {
  display: flex;
  justify-content: flex-end;
  gap: 0.5rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-legend {
    gap: 1.5rem;
  }
}
.contents-chart .contents-chart-legend .contents-chart-legend-item {
  display: flex;
  align-items: center;
  gap: 0.25rem;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-legend .contents-chart-legend-item {
    gap: 0.375rem;
  }
}
.contents-chart .contents-chart-legend .contents-chart-legend-color {
  display: inline-block;
  width: 1.125rem;
  height: 1.125rem;
}
.contents-chart .contents-chart-legend .contents-chart-legend-color.circle {
  border-radius: 50%;
}
.contents-chart .contents-chart-legend .contents-chart-legend-color.square {
  border-radius: 0.25rem;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-legend .contents-chart-legend-color {
    width: 1.25rem;
    height: 1.25rem;
  }
}
.contents-chart .contents-chart-legend .contents-chart-legend-label {
  font-size: calc(var(--esg-font-eyebrow-s-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) / 16 * 1rem);
  color: #646464;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-card {
    background-color: #FFF;
    border-radius: 1rem;
    padding: 2.5rem 4rem;
  }
}
.contents-chart .contents-chart-summary {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  margin-block-end: 0.5rem;
}
@media all and (min-width: 768px) {
  .contents-chart .contents-chart-summary {
    font-size: calc(var(--esg-font-body-3-fs) / 16 * 1rem);
    line-height: calc(var(--esg-font-body-3-lh) / 16 * 1rem);
  }
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-summary {
    margin-block-end: 0.25rem;
  }
}
.contents-chart .contents-chart-heading {
  font-size: calc(var(--esg-font-heading-7-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-7-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-7-fw);
  margin-block-end: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-heading {
    margin-block-end: 1.5rem;
  }
}
.contents-chart .contents-chart-canvas-container {
  position: relative;
  width: 100%;
  height: 12.1875rem;
  max-height: 50vh;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-canvas-container {
    height: 27.5rem;
  }
}
.contents-chart .contents-chart-badge {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  padding: 0.125rem 0.375rem;
  background-color: #ffffff;
  position: absolute;
  bottom: calc(50% - 0.5rem);
  right: 0.5rem;
  color: #646464;
  border-radius: 1rem;
  transform: translateY(14px);
  z-index: 10;
  pointer-events: none;
}
@media all and (min-width: 1440px) {
  .contents-chart .contents-chart-badge {
    background-color: #f4f4f4;
    padding: 0.25rem 0.5rem;
    transform: translateY(26px);
  }
}
.contents-chart .contents-chart-disclaimer {
  font-size: calc(var(--esg-font-disclaimer-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-disclaimer-lh) / 16 * 1rem);
  color: var(--esg-font-disclaimer-cl);
  color: #646464;
}

/* contents-value-card */
/* breakpoint - mobile first 로, 기본 mobile scss 작성 후 768부터 tab, 1440부터 pc */
/* PC 기준 inner 사이즈 */
/* device별 기준 section 상하 padding값, rem mixin에 넣어서 사용 */
/* function */
/* rem */
/* vw - pc 기준 */
/* media Query */
/* font */
/* img */
/* btn */
.contents-value-card__main-title {
  font-size: calc(var(--esg-font-heading-5-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-heading-5-lh) / 16 * 1rem);
  font-weight: var(--esg-font-heading-5-fw);
  letter-spacing: var(--esg-font-heading-5-ls);
  margin-block-end: 1.5rem;
}
.contents-value-card__list {
  display: flex;
  flex-direction: column;
  gap: 1rem;
}
@media all and (min-width: 768px) {
  .contents-value-card__list {
    flex-direction: row;
  }
}
.contents-value-card__item {
  flex: 1;
  background-color: #f4f4f4;
  border-radius: 0.75rem;
  display: flex;
  flex-direction: column;
  border-radius: 1rem;
  overflow: hidden;
}
.contents-value-card__image-wrap {
  position: relative;
}
.contents-value-card__image-wrap img {
  width: 100%;
  height: auto;
  display: block;
}
.contents-value-card__text-wrap {
  display: flex;
  flex-direction: column;
  padding: 1.5rem 1.5rem 2.5rem;
}
.contents-value-card__badge {
  height: 1.25rem;
  display: flex;
  align-items: center;
  align-self: flex-start;
  border: 1px solid #000000;
  border-radius: 1.25rem;
  padding-inline: 0.5rem;
  font-size: calc(var(--esg-font-eyebrow-s-fs) / 16 * 1rem);
  line-height: calc(var(--esg-font-eyebrow-s-lh) / 16 * 1rem);
  letter-spacing: var(--esg-font-eyebrow-s-ls);
  margin-block-end: 1rem;
}
@media all and (min-width: 1440px) {
  .contents-value-card__badge {
    height: 1.5rem;
  }
}
.contents-value-card__subtitle {
  font-weight: 600;
  margin-block-end: 0.5rem;
}