@charset "utf-8";

/* common */
#subWrap { padding-top: var(--header-H);}
.sub-visual { overflow: hidden; }
.sub-visual .inner { display: flex; flex-wrap: wrap; gap: 20px; justify-content: space-between; padding: 140px 0 100px;}
.sub-visual .main-title { font-family: var(--font-Mix); font-size: clamp(34px,4.16vw,80px); font-weight: 600; color: #000; animation: textRight 0.6s 0.2s ease-out both; }
.sub-visual .main-title > br { display: none; }
.visual-img { position: relative; width: 100%; height: clamp(160px,26.04vw,500px); background-color: #aaa; }
.visual-img::before { content:""; position: absolute; right: 0; bottom: 100%; display: block; width: clamp(260px,39.27vw,754px); aspect-ratio: 3.125/1; background: url("/img/sub/sub_visual_text.png") no-repeat 100% 100%/contain; z-index: -1;  }
.navigation { display: flex; align-items: center; column-gap: 46px; animation: textLeft 0.6s 0.2s ease-out both; }
.navigation > li { position: relative; }
.navigation > li::before { content: ""; position: absolute; left: -26px; top: 50%; display: block; width: 6px; height: 6px; background-color: #DDDDDD; transform: translateY(-50%); }
.navigation > li:first-child::before { display: none; }
.navigation > li.home > a { display: block; width: 30px; height: 30px; background: url("/img/common/icon_home.svg") no-repeat center center/auto var(--main-color3); }
.navigation > li > a, .navigation > li > span { font-family: var(--font-Mix); font-size: 18px; font-weight: 500; color: #333; }
.navigation > li > a > br, .navigation > li > span > br { display: none; }

.container { overflow: hidden; }
.content { padding-top: 150px; padding-bottom: 250px; }
.content .section + .section { margin-top: 200px; }
.content__title { font-family: var(--font-Mix); margin-bottom: 100px; font-size: clamp(32px,3.64vw,70px); font-weight: 600; color: #111; text-align: center; }
.sub__title { font-family: var(--font-Mix); margin-bottom: 60px; font-size: clamp(30px,2.6vw,50px); font-weight: 600; color: #111; }

.paging a { border: none; }
.paging a { width: 30px; height: 30px; font-family: var(--font-Oxanium); font-size: 18px; line-height: 1; font-weight: 600; letter-spacing: 0; color: #AAA; }
.paging ul { margin: 0 10px; }
.paging ul li a { padding-top: 0.1em; }
.paging ul li.on a { color: #000; background-color: transparent; }
.paging ul li:not(:last-child) { margin-right: 10px; }
.paging a i { width: 10px; height: 16px; }
.paging a i::before { display: none; }
.paging .arr a:not(:last-child) { margin-right: 10px; }
.paging .arr a.last i, .paging .arr a.first i { transform: none; }
.paging a i.xi-angle-left-min { background: url("/img/common/page_prev.svg") no-repeat center center/contain; }
.paging a i.xi-angle-right-min { background: url("/img/common/page_next.svg") no-repeat center center/contain; }
.board_box{border-top: 3px solid #000;}
.board_box table tr{position: relative; border-bottom: 1px solid #DDD; }
.board_box table th{position: relative;}
.board_box table th::after{content:""; position: absolute; top: 50%; right: 0; width: 1px; height: 15px; transform: translateY(-50%);}
.board_box table th:last-of-type::after{display: none;}
.board_box table td{ padding: 0 30px; text-align: center; }
.board_box table td.date, .board_box table td.hit { font-family: var(--font-Oxanium); font-size: 18px; font-weight: 300; letter-spacing: 0; color: #999; }
.board_box table td a{width: 100%; display: inline-block; padding-block: 35px; vertical-align: top; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; text-align: left; font-size: 20px; font-weight: 500; color: #333;}
.board_box table .notice td { position: relative; }
.board_box table .notice td:first-child{ text-align: left; }
.board_box table .notice td a { padding-left: 100px; }
.board_box table .notice td .tag { position: absolute; display: block; left: 30px; top: 50%; width: 70px; font-family: var(--font-Oxanium); font-size: 16px; font-weight: 600; letter-spacing: 0; line-height: 30px; background-color: var(--main-color2); color: var(--main-color); text-align: center; transform: translateY(-50%); }
.search__area { margin-bottom: 30px; }
.search__area form { display: flex; align-items: center; height: 60px; gap: 10px; }
.search__area .search-select { width: 220px; height: 100%; border: none; padding: 0 24px; font-size: 18px; font-weight: 500; color: #333; background: url("/img/common/select_arrow.svg") no-repeat calc(100% - 24px) center/auto #F5F5F5; }
.search__area .search-input { width: 360px; height: 100%; border: none; padding: 0 24px; font-size: 18px; font-weight: 500; color: #333; background-color: #F5F5F5; }
.search__area .btn-search { width: 60px; height: 60px; border: none; background: url("/img/common/icon_search.svg") no-repeat center center/auto var(--main-color3); }
.view_ctn .tit { padding-bottom: 60px; border-bottom: 3px solid #000; }
.view_ctn .tit h2 { font-size: clamp(24px,3.125vw,60px); font-weight: 500; color: #111; }
.view_ctn .tit ul { overflow: hidden; display: flex; flex-wrap: wrap; align-items: center; margin-top: 30px; }
.view_ctn .tit ul li { position: relative; display: flex; gap: 10px; font-family: var(--font-Oxanium); font-size: 18px; font-weight: 300; letter-spacing: 0; color: #666; }
.view_ctn .tit ul li:not(:last-child) { padding-right: 66px; }
.view_ctn .tit ul li:not(:nth-child(1))::before { content: ""; position: absolute; left: -36px; top: 50%; display: block; width: 6px; height: 6px; background-color: #DDD; transform: translateY(-50%); }
.view_ctn .tit ul li span { font-family: inherit; font-weight: 500; letter-spacing: inherit; color: #333; }
.view_ctn .info { padding: 100px 60px 200px; font-size: 16px; }
.view_ctn .file_box { width: calc(100% - 120px); margin-inline: auto; padding: 50px 100px; background-color: #F5F5F5; }
.view_ctn .file_box dl { display: flex; gap: 66px; }
.view_ctn .file_box dl + dl { margin-top: 15px; }
.view_ctn .file_box dt { position: relative; width: 137px; padding: 8.5px 0; font-family: var(--font-Oxanium); font-size: 18px; font-weight: 500; letter-spacing: 0; color: #333; text-transform: capitalize; }
.view_ctn .file_box dt > span { font-family: inherit; line-height: inherit; font-weight: inherit; }
.view_ctn .file_box dt::after { content: ""; position: absolute; right: -36px; top: 50%; display: block; width: 6px; height: 6px; background-color: #DDD; transform: translateY(-50%); }
.view_ctn .file_box dd { width: calc(100% - 202px); font-size: 18px; font-weight: 300; color: #666; }
.view_ctn .file_box dd a { position: relative; display: block; width: 100%; padding-block: 8.5px; padding-right: 175px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.view_ctn .file_box dd a .download { position: absolute; right: 0px; top: 50%; font-family: var(--font-Oxanium); font-size: 18px; font-weight: 500; letter-spacing: 0; color: #333; transform: translateY(-50%); }
.view_ctn .file_box dd a .download::after { content: ""; display: inline-block; width: 40px; height: 40px; margin-left: 20px; background: url("/img/common/icon_download.svg") no-repeat center center/auto var(--main-color3); vertical-align: middle; }
.view_ctn .pages { display: flex; justify-content: space-between; align-items: center; margin-top: 150px; }
.view_ctn .pages .btn-page a { font-family: var(--font-Oxanium); font-size: 22px; font-weight: 700; letter-spacing: 0; color: #111; }
.view_ctn .pages .btn-bracket { width: 286px; }

/* product */
.sv01 .visual-img { background: url("/img/sub/visual_product.jpg") no-repeat center center/cover; }
.depth2-tab { display: flex; flex-wrap: wrap; justify-content: center; gap: 20px 60px; margin-bottom: 100px; }
.depth2-tab .tab__item { display: flex; column-gap: 10px; }
.depth2-tab .tab__item .num{ font-family: var(--font-Oxanium); font-size: 18px; font-weight: 700; letter-spacing: 0; color: #AAA; }
.depth2-tab .tab__item > a { font-family: var(--font-Mix); font-size: 30px; font-weight: 600; color: #AAA; text-align: center; }
.depth2-tab .tab__item.on .num { color: var(--main-color); }
.depth2-tab .tab__item.on > a { color: #111; }
.product_list { display: flex; flex-wrap: wrap; gap: 20px; }
.product_list .item { position: relative; width: calc((100% - 40px)/3); background-color: #F5F5F5; padding: 30px 30px 50px; transition: 0.3s ease-out; }
.product_list .img-box { overflow: hidden; position: relative; width: 100%; }
.product_list .img-box img { position: absolute; left: 50%; top: 50%; width: 100%; min-height: 100%; transform: translate(-50%, -50%); object-fit: cover; }
.product_list .text-box { margin-top: 30px; padding: 0 20px; }
.product_list .title { font-family: 'Oxanium', 'Pretendard',sans-serif; font-size: 28px; font-weight: 600; letter-spacing: 0; color: #222; }
.product_list .info__list { margin-top: 15px; }
.product_list .info__list .info__item { display: flex; }
.product_list .info__list .info__item + .info__item { margin-top: 10px; }
.product_list .info__list .info__item .label { width: 50px; font-size: 18px; font-weight: 500; color: #333; }
.product_list .info__list .info__item .text { width: calc(100% - 50px); font-size: 18px; font-weight: 300; color: #666; }

.product-swiper .swiper-pagination-bullet:only-child { display: block !important; }
.product-swiper__area { position: relative; }
.product-swiper { position: static; height: 500px; }
.product-swiper .swiper-slide { background-color: #fff; }
.product-swiper .swiper-slide img { position: absolute;  left: 50%; top: 50%; width: 100%; min-height: 100%; object-fit: cover; transform: translate(-50%, -50%); }
.product-swiper .swiper-pagination { bottom: 6%; display: flex; align-items: center; column-gap: 10px; }
.product-swiper .swiper-pagination-bullets.swiper-pagination-horizontal { display: flex; justify-content: center; }
.product-swiper .swiper-pagination-horizontal.swiper-pagination-bullets .swiper-pagination-bullet { margin: 0; }
.product-swiper .swiper-pagination-bullet { display: flex; justify-content: center; align-items: center; width: 10px; height: 10px; border-radius: 0; background-color: var(--main-color2); opacity: 1; }
.product-swiper .swiper-pagination-bullet-active{ background-color: var(--main-color); }
.product-swiper__area .swiper-button-prev::after, .product-swiper__area .swiper-button-next::after { display: none; }
.product-swiper__area .swiper-button-prev { left: 0; top: 50%; width: 60px; height: 60px; margin-top: 0; border: 2px solid var(--main-color2); background: url("/img/common/swiper_prev2.svg") no-repeat center center/auto #fff; transform: translate(-50%, -50%); }
.product-swiper__area .swiper-button-next { right: 0; top: 50%; width: 60px; height: 60px; margin-top: 0; border: 2px solid var(--main-color2); background: url("/img/common/swiper_next2.svg") no-repeat center center/auto #fff; transform: translate(50%, -50%); }
.product__text { margin-top: 60px; }
.product__text > h4 { margin-bottom: 0.55em; font-size: 36px; font-weight: 500; color: #111; }
.product__text > p { font-size: 22px; font-weight: 300; color: #333; }

/* company */
.sv02 .visual-img { background: url("/img/sub/visual_company.jpg") no-repeat center center/cover; }
.about-main { display: flex; flex-wrap: wrap; gap: 20px;}
.about-main .img-box { width:49.375%; }
.about-main .img-box img { width: 100%; }
.about-main .about-text { position: relative; display: flex; align-items: flex-end; width: calc(50.625% - 20px); padding: 40px 30px; color: #fff; background-color: #221E1F; }
.about-text .tag-logo { position: absolute; right: 0; top: 0; padding-left: 10px; padding-bottom: 10px; background-color: #fff; }
.about-text .tag-logo img { width: 190px; }
.about-text .text-box > em { font-size: 46px; font-weight: 500; line-height: 1; }
.about-text .text-box .text { margin-top: 40px; }
.about-text .text-box .text p { font-size: 20px; line-height: 1.7; }
.about-text .text-box .text p + p { margin-top: 20px; }

.container:has(.greeting__content) { overflow: visible; }
.greeting__wrap { display: flex; flex-wrap: wrap; justify-content: space-between; }
.greeting__wrap .text__area { position: sticky; top: 60px; height: 100%; }
.greeting__wrap .text__area, .greeting__wrap .img__area { width:43.75%; }
.greeting__wrap .title { margin-bottom: 60px; font-size: 46px; font-weight: 500; line-height: 1.3; color: #111; }
.greeting__wrap .text-box p { font-size: 20px; font-weight: 300; line-height: 1.7; color: #333; }
.greeting__wrap .text-box p + p { margin-top: 1em; }
.greeting__wrap .ceo { display: flex; align-items: center; margin-top: 20px; }
.greeting__wrap .ceo span { font-size: 20px; color: #333; }
.greeting__wrap .ceo b { margin-left: 10px; font-size: 24px; font-weight: 500; color: #111; }
.greeting__wrap .img__area .img-box + .img-box { margin-top: 30px; }

.mission__area { display: flex; align-items: flex-start; gap: 10px; }
.mission__area .text-box { display: flex; justify-content: center; align-items: center; width: 300px; aspect-ratio: 1/1; background-color: var(--main-color2); }
.mission__area .text-box > p { font-family: var(--font-Oxanium); font-size: 46px; font-weight: 900; letter-spacing: 0; color: #fff; }
.mission__area .img__area { display: flex; width: calc(100% - 310px); gap: 10px; }
.mission__area .img__area .box { position: relative; width: calc(50% - 5px); }
.mission__area .img__area .box::before { content: ""; display: block; padding-top: 109%; }
.mission__area .img__area .box:nth-child(1) { background: url("/img/sub/mission_img_01.jpg") no-repeat center center/cover; }
.mission__area .img__area .box:nth-child(2) { background: url("/img/sub/mission_img_02.jpg") no-repeat center center/cover; }
.mission__area .img__area .text { position: absolute; display: flex; flex-direction: column; justify-content: space-between; left: 0; top: 0; width: 100%; height: 100%; padding: 40px; }
.mission__area .img__area .text .top-text { font-family: var(--font-Oxanium); font-size: 22px; font-weight: 600; letter-spacing: 0; color: #fff; opacity: 0.6; }
.mission__area .img__area .text .bottom-text { font-family: var(--font-Mix); font-size: 40px; font-weight: 600; text-align: right; color: #fff; }
.vision__wrap .vision__area { position: relative; height: 700px; background: url("/img/sub/vision_img_01.jpg") no-repeat center center/cover; }
.vision__wrap .text-box { width: fit-content; padding: 50px; background-color: var(--main-color2); box-shadow: 5px 5px 0 5px #fff; }
.vision__wrap .text-box > .text { font-size: 40px; font-weight: 600; color: #fff; }
.vision__wrap .text-box > .sub-text { margin-bottom: 0.75em; font-family: var(--font-Oxanium); font-size: 20px; font-weight: 600; letter-spacing: 0; color: var(--main-color); text-transform: capitalize; }
.core-value__list { position: relative; display: flex; flex-wrap: wrap; gap: 20px; border: 2px dotted #DDD; border-radius: 400px; padding: 20px; }
.core-value__list > li { display: flex; justify-content: center; align-items: center; width: calc((100% - 60px)/4); aspect-ratio: 1/1; border: 3px solid var(--main-color2); padding-top: 3.25em; border-radius: 50%; text-align: center; }
.core-value__list > li:nth-child(odd) { color: #fff; background-color: var(--main-color2); }
.core-value__list > li > .box { width: 100%; text-align: center; }
.core-value__list > li img { max-width: 21.3%; }
.core-value__list > li .text-box { margin-top: 40px; }
.core-value__list > li .text-box > span { display: block; }
.core-value__list > li .text-box .text { font-family: var(--font-Mix); font-size: 34px; font-weight: 500; }
.core-value__list > li .text-box .eng { margin-top: 0.5em; font-family: var(--font-Oxanium); font-size: 20px; font-weight: 500; letter-spacing: 0; }

.history__wrap { display: none; }
.history__wrap.on { display: block; }
.history__item { position: relative; display: flex; justify-content: space-between; gap: 40px; padding-bottom: 100px; }
.history__item::after { content: ""; position: absolute; right:0; bottom: -3px; display: block; width: var(--history-line); height: 3px; background-color: #000; }
.history__item:first-child::before { content: ""; position: absolute; right:0; top: 0px; display: block; width: var(--history-line); height: 3px; background-color: #000; }
.history__item .year { display: inline-block; height: fit-content; font-family: var(--font-Oxanium); font-size: 100px; line-height: 1; font-weight: 600; letter-spacing: 0; color: #DDD; }
.history__item .year-content { width: var(--history-line); min-height: 100px; padding-top: 40px; }
.history__box + .history__box { margin-top: 20px; }
.history-text { display: flex; align-items: baseline; column-gap: 20px;}
.history-text .month { width: 40px; font-family: var(--font-Oxanium); font-size: 24px; font-weight: 500; letter-spacing: 0; color: #333; }
.history-text .text { max-width: calc(100% - 60px); font-family: var(--font-Pretendard); font-size: 20px; font-weight: 300; color: #666; }
.history-img { margin-top: 20px; display: flex; gap:10px; }
[data-aos="text-fill"] { position: relative; display: inline-block; color: #DDDDDD; }
[data-aos="text-fill"]::after { content: attr(data-text); overflow: hidden; position: absolute; left: 0; top: 0; color: transparent; background: no-repeat 0 center /0 100% linear-gradient(#000 0 0); -webkit-background-clip: text; background-clip: text; white-space: nowrap; transition: background-size 0.6s ease-out; transition-delay: 0.2s; }
[data-aos="text-fill"].aos-animate::after { background-size: 100% 100%; }

.certificate__list > li { display: flex; padding: 60px 0; gap: 30px; border-bottom: 3px solid #000; }
.certificate__list > li:first-child { border-top: 3px solid #000; }
.certificate__list > li .text-box { width: calc(40.8% - 30px); }
.certificate__list > li .text-box .num { font-family: var(--font-Oxanium); display: inline-block; width: 30px; line-height: 30px; font-size: 16px; font-weight: 700; color: #fff; background-color: var(--main-color2); text-align: center; }
.certificate__list > li .text-box .title-text { margin-top: 20px; }
.certificate__list > li .text-box .title { display: block; font-family: var(--font-Mix); font-size: 36px; font-weight: 500; letter-spacing: -0.015em; } 
.certificate__list > li .text-box .date { display: inline-block; margin-top: 0.25em; font-size: 20px; font-weight: 300; color: #666; }
.certificate__list > li .img-box { overflow: hidden; position: relative; width: 295px; border: 2px solid #EEEEEE; box-shadow: 5px 5px 5px 0 rgba(16, 16, 16, 0.1); }
.certificate__list > li .img-box::before { content: ""; display: block; padding-top: 138.98%; }
.certificate__list > li .img-box > img { position: absolute; left: 50%; top: 50%; width: 100%; min-height: 100%; -moz-object-fit: cover; object-fit: cover; transform: translate(-50%, -50%); }

.map-info__list { display: flex; flex-wrap: wrap; gap: 20px; }
.map-info__list > li { width: calc((100% - 60px)/4); height: 325px; padding: 30px; background-color: #F5F5F5; }
.map-info__list > li .logo { font-family: var(--font-Oxanium); font-size: 60px; font-weight: 900; letter-spacing: 0; color: var(--main-color); }
.map-info__list > li dl { display: flex; flex-direction: column; justify-content: space-between; gap: 20px; height: 100%; }
.map-info__list > li dt { font-size: 20px; }
.map-info__list > li dd { font-size: 46px; font-weight: 500; color: #000; }
.map-info__list > li.first { position: relative; background-color: var(--main-color3); }
.map-info__list > li.first .arrow { position: absolute; right: 0; bottom: 0; }
.map-info__list > li.address dd { max-width: 295px; font-size: 30px; word-break: break-all; }
.map-info__list > li dd > div + div { margin-top: 20px; }
.map-info__list > li .box span { display: block; font-size: 36px; }
.map-info__list > li .box .tag { width: fit-content; margin-bottom: 5px; padding: 7px 15px; font-size: 16px; font-weight: 600;  }
.map-info__list > li .box:nth-child(1) .tag { color: #fff; background-color: var(--main-color2); }
.map-info__list > li .box:nth-child(2) .tag { color: var(--main-color2); background-color: var(--main-color); }
.map__box { margin-top: 20px; height: 500px; }
.map__box iframe { width: 100%; height: 100%; }

/* procution */
.sv03 .visual-img { background: url("/img/sub/visual_production.jpg") no-repeat center center/cover; }
.step__row { display: flex; flex-wrap: wrap; align-items: center; gap: 20px;}
.step__row:nth-child(even) { flex-direction: row-reverse; }
.step__row + .step__row { margin-top: 20px; }
.step__row .product__item { position: relative; width: calc((100% - 80px)/5); }
.step__row .product__item::before { content: ""; position: absolute; left: -30px; top: 50%; display: block; width: 40px; height: 40px; border:2px solid var(--main-color3); background: url("/img/sub/process_arrow.svg") no-repeat calc(50% + 1px) center/auto #fff; box-sizing: border-box; transform: translateY(-50%); z-index: 5; }
.step__row .product__item.text + .product__item::before { display: none; }
.step__row:not(.col):first-child .product__item:last-child::after { content: ""; position: absolute; left: 50%; bottom: -30px; display: block; width: 40px; height: 40px; border:2px solid var(--main-color3); background: url("/img/sub/process_arrow.svg") no-repeat calc(50% + 1px) center/auto #fff; box-sizing: border-box; transform: translateX(-50%) rotate(90deg); z-index: 5; }
.step__row:not(:nth-child(even)) .product__item:first-child::before { display: none; }
.step__row:not(.col):nth-child(even) .product__item::before { transform: translateY(-50%) rotateY(180deg); }
.step__row:not(.col):nth-child(even) .product__item:last-child::before { display: none; }
.step__row .product__item .title-box {position: absolute; left: 0; top: 0; width: 100%; display: flex; justify-content: center; align-items: center; gap: 5px 10px; height: 50px; padding: 10px 5px; background-color: var(--main-color3); font-size: clamp(16px,1.04vw,20px); font-weight: 500; color: #fff; text-align: center; z-index: 3; }
.step__row .product__item .step { color: var(--main-color); }
.step__row .product__item .img-box { overflow: hidden; position: relative; text-align: center; }
.step__row .product__item .img-box::before { content: ""; display: block; width: 100%; padding-top: 100%; }
.step__row .product__item .img-box img { position: absolute; left: 50%; top: 50%; width: 100%; min-height: 100%; object-fit: cover; transform: translate(-50%, -50%); }
.step__row .product__item.text { position: relative; border: 2px dotted var(--main-color2); }
.step__row .product__item.text::after { content: ""; display: block; width: 100%; padding-top: 100%; }
.step__row .product__item.text p { position: absolute; left: 50%; top: 50%; font-family: var(--font-Mix); font-size: clamp(18px,1.56vw,30px); font-weight: 600; text-align: center; transform: translate(-50%, -50%); }
.step__row:nth-child(2) .product__item .title-box { top: auto; bottom: 0; }
.product-step__list > li { margin-top: 100px; }
.product-step__list .num-box { display: flex; align-items: center; column-gap: 15px; }
.product-step__list .num-box .num { width: 30px; font-family: var(--font-Mix); font-size: 20px; font-weight: 700; line-height: 30px; color: var(--main-color); background-color: var(--main-color3); text-align: center; }
.product-step__list .num-box .title { font-size: 28px; font-weight: 500; color: #111; }
.product-step__list .img__area { display: flex; flex-wrap: wrap; align-items: stretch; gap: 20px; margin-top: 30px; }
.product-step__list .img__area .box { width: calc((100% - 40px)/3); }
.product-step__list .img__area .img-box img { width: 100%; }
.product-step__list .img__area .text-box { position: relative; border: 1px solid #DDDDDD; padding: 70px 39px 39px; font-size: 20px; }
.product-step__list .img__area .text-box > p { font-weight: 300; line-height: 1.7; color: #666; }
.product-step__list .img__area .text-box > p + p { margin-top: 1em; }
.product-step__list .img__area .tag { position: absolute; left: 0; top: 0; display: flex; align-items: center; width: fit-content; padding: 10px 20px; background-color: var(--main-color3); }
.product-step__list .img__area .tag .icon { width: 30px; height: 30px; margin-right: 10px; background: no-repeat center center/contain; }
.product-step__list .img__area .tag .icon-desc { background-image: url("/img/sub/icon_desc.svg"); }
.product-step__list .img__area .tag .icon-setting { background-image: url("/img/sub/icon_setting.svg"); }
.product-step__list .img__area .tag .title { font-weight: 500; color: #fff; }
.product-step__list .img__area .setting + .setting { margin-top: 30px; }
.product-step__list .img__area .setting > p { font-weight: 300; }
.product-step__list .img__area .setting > img { margin-bottom: 20px; }
.product-step__list .img__area .list { margin-top: 10px; }
.product-step__list .img__area .list > li { position: relative; padding-left: 15px; font-weight: 300; color: #666; }
.product-step__list .img__area .list > li::before { content: ""; position: absolute; left: 0; top: 0.5em; display: block; width: 5px; height: 5px; background-color: #AAA; }
.product-step__list .img__area .list > li + li { margin-top: 0.5em; }
.product-status__list { display: flex; flex-wrap: wrap; gap: 20px; }
.product-status__list > li { width: calc((100% - 60px)/4); }
.product-status__list > li .img-box img { width: 100%; }
.product-status__list > li .title { padding: 15.5px 5px; font-size: 22px; font-weight: 500; color: #fff; background-color: var(--main-color3); text-align: center; }
.product-status__list > li .info { padding: 30px; border: 2px dotted var(--main-color3); border-top: none; }
.product-status__list > li .info dl { display: flex; font-size: 18px; }
.product-status__list > li .info dl + dl { margin-top: 10px; }
.product-status__list > li .info dt, .product-status__list > li .info dd { font-family: var(--font-Oxanium); letter-spacing: 0; }
.product-status__list > li .info dt { width: 140px; font-weight: 500; color: #333; }
.product-status__list > li .info dd { width: calc(100% - 140px); font-weight: 300; color: #666; }

/* esg */
.sv04 .visual-img { background: url("/img/sub/visual_esg.jpg") no-repeat center center/cover; }
.line-content__list > li { display: flex; justify-content: space-between; align-items: flex-end; gap: 40px; padding-top: 40px; border-top: 3px solid #000; }
.line-content__list > li + li { margin-top: 200px; }
.line-content__list .text-box { width: 43.9%; }
.line-content__list .text-box .sub-title { font-family: var(--font-Oxanium); font-size: 20px; font-weight: 500; letter-spacing: 0; color: #AAA; text-transform: uppercase; }
.line-content__list .text-box .main-title { margin-top: 0.55em; font-size: 36px; font-weight: 500; color: #222; }
.line-content__list .text-box .text { margin-top: 1em; font-size: 20px; font-weight: 300; line-height: 1.7; color: #666; }
.line-content__list .img-box { position: relative; width: 50%; }
.line-content__list .img-box img { width: 100%; }
.line-content__list .img-box .num { content: ""; position: absolute; left: 0; top: 0; display: inline-block; width: 40px; height: 40px; background-color: #fff; z-index: 1; }
.line-content__list .img-box .num > span { position: absolute; left: 0; top: 0; display: inline-block; width: 30px; line-height: 30px; background-color: var(--main-color); font-family: var(--font-Oxanium); font-size: 16px; font-weight: 700; letter-spacing: 0; color: #000; text-align: center; z-index: 5; }
.about__area { display: flex; justify-content: space-between; align-items: center; gap: 40px; }
.about__area.reverse { flex-direction: row-reverse; }
.about__area .img-box { width: 50%; }
.about__area .text-box { width: 40.625%; }
.about__area .text-box .sub-title { font-family: var(--font-Oxanium); font-size: 20px; font-weight: 500; letter-spacing: 0; color: #AAA; text-transform: uppercase; }
.about__area .text-box .main-title { margin-top: 0.535em; font-family: var(--font-Mix); font-size: 56px; font-weight: 600; color: #111; }
.about__area .text-box .text { margin-top: 1.5em; font-size: 20px; font-weight: 300; line-height: 1.7; color: #333; word-break: break-all; }
.about__area .text-box .button__wrap { justify-content: left; margin-top: 60px; gap: 10px; }
.esg-card__list { display: flex; flex-wrap: wrap; gap: 20px; }
.esg-card__list > li { display: flex; flex-direction: column; justify-content: space-between; width: calc((100% - 40px)/3); height: 440px; padding: 60px; background-color: #F5F5F5; }
.esg-card__list > li .img-box { position: relative; display: flex; justify-content: right; }
.esg-card__list > li .icon-box {  position: relative;}
.esg-card__list > li .icon-box::before { content: ""; display: block; position: absolute; left: 10px; top: 10px; width: 100%; height: 100%; background-color: var(--main-color); z-index: 1;}
.esg-card__list > li .icon { position: relative; display: flex; justify-content: center; align-items: center; width: 80px; height: 80px; background-color: var(--main-color3); z-index: 3; }
.esg-card__list > li .text-box .num { font-family: var(--font-Oxanium); font-size: 22px; font-weight: 500; color: #AAA; }
.esg-card__list > li .text-box .title { margin-top: 1.1em; font-size: 22px; font-weight: 500; color: #333; }
.esg-card__list > li .text-box .text { font-size: 22px; font-weight: 300; line-height: 1.54; color: #666; word-break: normal; }
.esg-card__list > li.first { padding: 30px; border: 3px solid var(--main-color3); background-color: #fff; }
.esg-card__list > li.first .top { display: flex; flex-direction: column; }
.esg-card__list > li.first .top .title { margin-bottom: 1.5em; font-size: 20px; color: #111; }
.esg-card__list > li.first .top > p { font-size: clamp(16px,1.458vw,28px); color: #222; }
.esg-card__list > li.first .bottom > span { display: block; font-size: 18px; color: #333; }
.esg-card__list > li.first .bottom > span:first-child { margin-bottom: 5px; font-family: var(--font-Oxanium); font-weight: 300; letter-spacing: 0; }
.esg-img__list { display: flex; flex-wrap: wrap; gap:60px; }
.esg-img__list > li { width: calc(50% - 30px); text-align: center; }
.esg-img__list > li .img-box img { width: 100%; }
.esg-img__list > li > span { display: inline-block; margin-top: 1em; font-size: 20px; font-weight: 500; color: #333; }
.card-num__list { display: flex; flex-wrap: wrap; gap: 20px; }
.card-num__item { position: relative; display: flex; flex-direction: column; justify-content: space-between; width: calc((100% - 60px)/4); height: 300px; padding: 50px 30px 30px; background-color: #F5F5F5; }
.card-num__item.first { border: 3px solid var(--main-color3); padding: 38px; background-color: #fff; }
.card-num__item .img-box { text-align: center; }
.card-num__item .num-box { position: absolute; left: 0; top: 0; width: 30px; }
.card-num__item .num-box .num { position: relative; display: inline-block; width: 100%; height: 100%; font-family: var(--font-Oxanium); font-size: 16px; font-weight: 700; letter-spacing: 0; color: var(--main-color); line-height: 30px; background-color: var(--main-color3); text-align: center; z-index: 5; }
.card-num__item .num-box::before { content: ""; position: absolute; left: 0px; top: 0px; display: block; width: calc(100% + 10px); height: calc(100% + 10px); background-color: #fff; z-index: 1; }
.card-num__item .img-box img { mix-blend-mode: multiply; }
.card-num__item .text-box > p { font-size: 20px; font-weight: 300; line-height: 1.6; color: #333; word-break: normal; }
.card-num__item.first .text-box > p { font-size: 24px; font-weight: 500; line-height: 1.3; color: #111; }
.caption-text { margin-bottom: 10px; font-size: 16px; font-weight: 300; color: #666; text-align: right; }
.caption-text.title { font-size: 20px; text-align: left; font-weight: 500 ;color: #333; }
.table-item table { table-layout: fixed; width: 100%; border-top: 3px solid #000; }
.table-item table tr { border-bottom: 1px solid #DDD; }
.table-item table thead th { height: 80px; padding: 0 20px; font-size: 20px; font-weight: 500; color: #333; text-align: center; }
.table-item table tbody th, .table-item table td { height: 70px; padding: 22px 20px; font-size: 20px; font-weight: 300; color: #666; text-align: center; }
.table-item table th.color-dark { font-weight: 400; color: #333; }
.table-item table td ul { padding: 3px 0; }
.table-item table td ul > li { position: relative; padding-left: 15px; text-align: left; }
.table-item table td ul > li::before { content: ""; position: absolute; left: 0; top: 0.5em; display: block; width: 5px; height: 5px; background-color: #AAAAAA; }
.table-item table td ul > li + li { margin-top: 0.5em; }
.table-item table .dot { display: inline-block; width: 20px; height: 20px; border-radius: 50%; background-color: var(--main-color3); }
.table-item table td.td-percent { text-align: left; }
.table-item table td.td-percent .bar { display: inline-block; width: 0%; height: 80%; background-color: var(--main-color); }
.financial__content .table-item table tr { border-bottom: none; }
.financial__content .table-item table tr:not(:first-child) { border-top: 1px dashed #DDD; }
.financial__content .table-item table tr.main-tr { border-top: 1px solid #DDD; }
.financial__content .table-item table tr.main-tr th, .financial__content .table-item table tr.main-tr td { font-weight: 500; color: #333; }
.financial__content .table-item table tr.total { border-top: 1px solid #DDD; border-bottom: 1px solid #DDD; background-color: #F5F5F5; }
.financial__content .table-item table tr.total th, .financial__content .table-item table tr.total td { font-weight: 500; color: #333; }
.table-item .table-scroll { padding-bottom: 1px; }
.border-table tbody th { border-right: 1px solid #DDD; }
.border-table tbody td { padding: 0 5px; }
.border-table thead th.border { border-right: 1px solid #DDDDDD; }
.social__content .esg-card__list > li:not(.first) { flex-direction: column-reverse; }
.governance-org .img-box { position: relative; }
.esg-part { position: absolute; right: 0; top: 0; padding: 30px; border: 2px dashed #000; }
.esg-part > p { font-size: 18px; font-weight: 500; color: #222; }
.esg-part > .list { margin-top: 15px; }
.esg-part > .list > li { display: flex; align-items: center; column-gap: 10px; }
.esg-part > .list > li + li { margin-top: 10px; }
.esg-part > .list > li > span.num { width: 25px; line-height: 25px; font-family: var(--font-Oxanium); font-size: 14px; font-weight: 700; background-color: var(--main-color3); text-align: center; color: #fff; }
.esg-part > .list > li > span:not(.num) { font-size: 18px; font-weight: 300; color: #333; }
.director-state { margin-top: 60px; }
.director-state .title { font-size: 22px; color: #222; }
.director-state .title > small { font-size: 18px; font-weight: 300; color: #666; }
.director-state .list { display: flex; flex-wrap: wrap; gap: 20px; margin-top: 20px; }
.director-state .list > li { width: calc((100% - 60px)/4); border: 3px solid var(--main-color3); }
.director-state .list > li .position { padding: 17px 10px; font-size: 20px; font-weight: 500; color: #fff; background-color: var(--main-color3); text-align: center; }
.director-state .list > li .name { padding: 20px 10px; font-size: 20px; font-weight: 300; color: #333; background-color: #fff; text-align: center; }

/* career */
.sv05 .visual-img { background: url("/img/sub/visual_career.jpg") no-repeat center center/cover; }
.talent__content .section.core-value { position: relative; z-index: 3; }
.value__area + .value__area { margin-top: 100px; }
.value-title { display: flex; align-items: center; gap: 20px; font-size: 36px; font-weight: 500; color: #111; }
.value-title > span { font-family: var(--font-Oxanium); font-size: 24px; font-weight: 600; letter-spacing: 0; color: #CCC; }
.value__list { display: flex; gap: 20px; margin-top: 30px; }
.value__item { display: flex; flex-direction: column; justify-content: space-between; gap: 30px; width: calc((100% - 40px)/3); height: 662px; background-color: #F5F5F5; }
.value__item .icon { display: flex; justify-content: center; align-items: center; width: 60px; height: 60px; background-color: var(--main-color3); }
.value__item .text-box { padding: 30px 50px 0; }
.value__item .text-box dt { font-size: 28px; font-weight: 500; line-height: 1.2; color: #222; }
.value__item .text-box dd { margin-top: 0.5em; font-size: 20px; font-weight: 300; line-height: 1.7; color: #333; }
.talent__area { position: relative; }
.talent__area .circle { position: absolute; left: 50%; top: 50%; aspect-ratio: 1 / 1; border-radius: 50%; border: 2px dashed #fff; background: linear-gradient(#fff 0 0) padding-box, linear-gradient(to bottom, rgba(0, 0, 0, 0.00) 0%, rgba(0, 0, 0, 0.10) 30.28%, rgba(0, 0, 0, 0.10) 69.75%, rgba(0, 0, 0, 0.00) 100%) border-box; transform: translate(-50%, -50%); z-index: -1;}
.talent__area .circle-1 { width: 1140px;  }
.talent__area .circle-2 { width: 700px; }
.talent__list { display: flex; justify-content: center; align-items: center; }
.talent__item { display: flex; flex-direction: column; justify-content: center; align-items: center; min-width: 340px; aspect-ratio: 1/1; border: 10px solid #fff; border-radius: 50%; text-align: center; background-color: #F5F5F5; }
.talent__item > em { font-family: var(--font-Oxanium); font-size: clamp(20px,2.08vw,40px); font-weight: 600; letter-spacing: 0; color: #000; }
.talent__item > span { margin-top: 0.5em; font-size: clamp(16px,1.042vw,20px); color: #333; }
.talent__item.logo { position: relative; min-width: 380px; background-color: var(--main-color3); z-index: 5; }
.talent__item.logo img { width: clamp(100px,12.55vw,241px); }
.talent__item:nth-child(1) { transform: translateX(calc(20.55%)); }
.talent__item:nth-child(2) { transform: translateX(13.2%); }
.talent__item:nth-child(4) { transform: translateX(-13.2%); }
.talent__item:nth-child(5) { transform: translateX(calc(-20.55%)); }
.method__list { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; }
.method__item { position: relative; display: flex; justify-content: center; align-items: center; width: calc((100% - 40px)/5); aspect-ratio: 1/1; padding: 10px; border: 3px solid var(--main-color3); }
.method__item > .num { position: absolute; left: 50%; top: 22.1%; font-family: var(--font-Oxanium); font-size: 150px; font-weight: 900; letter-spacing: 0; color: #000; text-align: center; opacity: 0.03; transform: translateX(-50%); }
.method__item > p { font-size: 24px; font-weight: 500; color: #222; text-align: center; }
.method__item.last { background-color: var(--main-color3); }
.method__item.last > .num { color: #fff; opacity: 0.05; }
.method__item.last > p { font-family: var(--font-Oxanium); font-size: clamp(36px,2.4vw,46px); font-weight: 700; line-height: 1.2; letter-spacing: 0; color: var(--main-color); }
.system__area { display: flex; justify-content: space-between; gap: 40px; }
.system__area + .system__area { margin-top: 200px; }
.system__area .sub__title { width: calc(37.5% - 40px); }
.system__box { width: 62.5%; }
.system__area .system__box .flex { display: flex; gap: 20px; }
.job-type { flex: 1; display: flex; flex-direction: column; align-items: center; padding: 60px; background-color: #F5F5F5; text-align: center; }
.job-type .icon-box img { display: block; margin: 0 auto 10px; }
.job-type .icon-box span { font-size: 24px; font-weight: 500; color: #222; }
.job-type .text-box { display: flex; flex-wrap: wrap; width: 100%; gap: 20px; margin-top: 30px; }
.job-type .text-box > p { position: relative; display: flex; justify-content: center; align-items: center; width: calc((100% - 60px)/4); height: 100px; font-size: 20px; font-weight: 500; color: #333; background-color: #DDD; }
.job-type .text-box > p:not(:last-child)::after {  content: ""; position: absolute; right: 0; top: 50%; display: block; width: 40px; height: 40px; border: 2px solid var(--main-color3); background: url("/img/sub/process_arrow.svg") no-repeat center center / auto #fff; transform: translate(calc(50% + 10px), -50%); box-sizing: border-box; z-index: 5; }
.job-type .text-box > .color-main-1 { background-color: var(--main-color); }
.job-type .text-box > .color-main-3 { color: #fff; background-color: var(--main-color3); }
.system__list > li { display: flex; align-items: center; gap: 40px; padding: 60px; border-top: 3px solid #000; }
.system__list > li .icon { display: flex; justify-content: center; align-items: center; width: 100px; height: 100px; background-color: var(--main-color3); }
.system__list > li .text-box { width: calc(100% - 140px); }
.system__list > li .text-box dt { font-size: 24px; font-weight: 500; color: #222; }
.system__list > li .text-box dd { margin-top: 0.75em; font-size: 20px; font-weight: 300; line-height: 1.7; color: #333; }
.benefits__area { display: flex; flex-wrap: wrap; gap: 20px; padding-top: 10px; }
.benefits__area .item { position: relative; display: flex; align-items: flex-end; width: calc((100% - 40px)/3); height: 520px; padding: 40px 50px; background: no-repeat center center/cover; color: #fff; transition: 0.3s ease-out; }
.benefits__area .item:nth-child(1) { background-image: url("/img/sub/career/benefit_img_01.jpg"); }
.benefits__area .item:nth-child(2) { background-image: url("/img/sub/career/benefit_img_02.jpg"); }
.benefits__area .item:nth-child(3) { background-image: url("/img/sub/career/benefit_img_04.jpg"); }
.benefits__area .item:nth-child(4) { background-image: url("/img/sub/career/benefit_img_08.jpg"); }
.benefits__area .item:nth-child(5) { background-image: url("/img/sub/career/benefit_img_09.jpg"); }
.benefits__area .item:nth-child(6) { background-image: url("/img/sub/career/benefit_img_10.jpg"); }
.benefits__area .item:nth-child(7) { background-image: url("/img/sub/career/benefit_img_12.jpg"); }
.benefits__area .item:nth-child(8) { background-image: url("/img/sub/career/benefit_img_14.jpg"); }
.benefits__area .item:nth-child(9) { background-image: url("/img/sub/career/benefit_img_11.jpg"); }
.benefits__area .item::before { content: ""; position: absolute; left: 0; top: 0; display: block; width: 100%; height: 100%; background: linear-gradient(180deg, rgba(17, 17, 17, 0) 0%, #111 100%); }
.benefits__area .item .text-box { position: relative; z-index: 1; }
.benefits__area .item .text-box dt { font-size: 28px; font-weight: 500; }
.benefits__area .item .text-box dd { margin-top: 1em; font-size: 20px; line-height: 1.5; font-weight: 200; }
.benefits__area .item:hover { transform: translateY(-10px); }
.agree__box { margin-bottom: 20px; padding: 33px 58px; border: 3px solid #AAAAAA; }
.agree__box:has(.checkbox-01:checked) { border-color: var(--main-color3); }
.check__label { display: flex; align-items: center; gap: 20px; width: fit-content; cursor: pointer; }
.check__label span { max-width: calc(100% - 50px); font-size: 20px; font-weight: 500; color: #333; }
.checkbox-01 { width: 30px; height: 30px; background: url("/img/common/icon_checkbox.svg") no-repeat center center/auto #AAA; cursor: pointer; }
.checkbox-01:checked { background: url("/img/common/icon_checkbox_on.svg") no-repeat center center/auto var(--main-color3); }
.radio__label { display: flex; align-items: center; gap: 15px; width: fit-content; cursor: pointer; }
.radio__label span { font-size: var(--input-Font); color: #333; }
.radio-01 { width: 25px; height: 25px; border: 6px solid #DDDDDD; background-color: #AAAAAA; cursor: pointer; }
.radio-01:checked { border-color: var(--main-color3); background-color: var(--main-color); }
.terms__box { overflow: hidden; height: 400px; padding: 0 30px; background-color: #F5F5F5; }
.terms__box .terms__text { overflow-y: auto; padding: 60px 27px; height: 100%; font-size: var(--input-Font); font-weight: 300; line-height: 1.67; color: #666; }
.terms__box .terms__text * { font-weight: inherit; line-height: inherit; letter-spacing: inherit; }
.terms__box .terms__text > dl,.terms__box .terms__text > p { margin-top: 1em; }
.terms__box .terms__text::-webkit-scrollbar{ width: 3px; }
.terms__box .terms__text::-webkit-scrollbar-thumb{background-color: #AAA;}
.terms__box .terms__text::-webkit-scrollbar-track{background-color: transparent;}
.terms__box .terms__text::-webkit-scrollbar-button:vertical:start:decrement,
.terms__box .terms__text::-webkit-scrollbar-button:vertical:start:increment { display: block;}
.terms__box .terms__text::-webkit-scrollbar-button:vertical:end:decrement { display: block; height: 30px; }
.form__area { margin-top: 100px; padding: 58px 0; border-top: 3px solid #000; border-bottom: 3px solid #000; }
.form__item { display: flex; align-items: center; padding: 15px 0; }
.form__item .form__label { width: 300px; padding: 0 40px; font-size: 20px; font-weight: 500; color: #111; }
.form__item .form__label > .star { font-size: inherit; line-height: inherit; letter-spacing: inherit; color: var(--main-color); }
.form__item .input__box { width: calc(100% - 300px); padding: 0 40px; }
.input__box { display: flex;}
.input__box.check { height: var(--input-H); }
.input__box .radio__label +  .radio__label { margin-left: 60px; }
.form-select { width: 100%; max-width: 500px; height: var(--input-H); border: none; background: url("/img/common/select_arrow.svg") no-repeat calc(100% - 29px) center/auto #F5F5F5; padding-left: 30px; padding-right: 60px; font-size: var(--input-Font); color: #333; }
.form-input { width: 100%; max-width: 700px; height: var(--input-H); border: none; background-color: #F5F5F5; padding: 0 30px; font-size: var(--input-Font); color: #333; }
.form-input.size-s { max-width: 500px; }
.form-input.size-l { max-width: initial; }
.form-textarea { width: 100%; height: 280px; background-color: #F5F5F5; border: none; padding: 30px; font-size: var(--input-Font); color: #333; resize: none; }
.file-box { display: flex; align-items: center; gap: 10px; width: 100%; }
.file-box .form-input { max-width: 500px; }
.file-box .btn-file { display: flex; justify-content: center; align-items: center; width: 200px; height: var(--input-H); background-color: var(--main-color3); font-size: var(--input-Font); font-weight: 500; color: #fff; cursor: pointer; }
.file-box .btn-file input[type="file"] { overflow: hidden; position: absolute; width: 1px; height: 1px; margin: -1px; clip: rect(0 0 0 0); }
.kcaptcha-box { display: flex; gap: 10px; width: 100%; }
.kcaptcha-box .kcaptcha-img { overflow: hidden; position: relative; min-width: 200px; height: var(--input-H); }
.kcaptcha-box .kcaptcha-img img { position: absolute; left: 50%; top: 50%; width: 100%; min-height: 100%; object-fit: cover; transform: translate(-50%, -50%); }
.kcaptcha-box #btnKcaptcha { min-width: 70px; height: 70px; border: none; background: url("/img/common/icon_refresh.svg") no-repeat center center/auto var(--main-color3); }
.kcaptcha-box .form-input { max-width: 420px; }
.form-01 .button__wrap { margin-top: 100px; }

/* pr */
.sv06 .visual-img { background: url("/img/sub/visual_pr.jpg") no-repeat center center/cover; }
.promotion__area .img-box { overflow: hidden; position: relative; width: fit-content; max-width: 800px; border: 3px solid #EEE; margin: 0 auto 30px; }
.promotion__area .btn-download > span { font-family: var(--font-Oxanium); font-size: 18px; font-weight: 500; letter-spacing: 0; color: #333; }
.promotion__area .btn-download::after { content: ""; width: 40px; height: 40px; margin-left: 20px; background: url("/img/common/icon_download.svg") no-repeat center center/auto var(--main-color3); }
.media__area .video-box { overflow: hidden; position: relative; width: 100%; max-width: 1200px; border: 3px solid #EEE; margin: 0 auto; }
.media__area .video-box::before { content: ""; display: block; width: 100%; height: 0; padding-top: 56.25%; }
.media__area .video-box video { position: absolute; left: 50%; top: 50%; width: 100%; min-height: 100%; object-fit: cover; transform: translate(-50%, -50%); }

/* policy */
.sv07 .visual-img { background: url("/img/sub/visual_policy.jpg") no-repeat center center/cover; }

/* investment */
.sv08 .visual-img { background: url("/img/sub/visual_investment.jpg") no-repeat center center/cover; }
.investment .table-item + .table-item { margin-top: 60px; }
.investment-data { overflow-x: auto; text-align: center; }
.investment-data img { max-width: fit-content; }

@media screen and (max-width: 1660px) {
    .about-text .text-box > em { font-size: clamp(26px,2.77vw,46px); }
    .about-text .text-box .text p { font-size: clamp(14px,1.2vw,20px);}
    .greeting__wrap .title { font-size: clamp(24px,2.77vw,46px); }
    .greeting__wrap .text-box p { font-size: clamp(16px,1.2vw,20px); }
    .mission__area .text-box { width: 18.07vw; }
    .mission__area .text-box > p { font-size: clamp(20px,2.77vw,46px); }
    .mission__area .img__area { width: calc(100% - 18.07vw); }
    .mission__area .img__area .text .bottom-text { font-size: clamp(20px,2.41vw,40px); }
    .core-value__list > li .text-box .text { font-size: clamp(20px,2.048vw,34px); }
    .vision__wrap .vision__area { height: 500px; }
    .vision__wrap .text-box > .text { font-size: clamp(20px,2.41vw,40px); }
    .history__item .year {font-size: clamp(40px,6vw,100px);}
    .history__item .year-content {  min-height: clamp(60px,6.02vw,100px); padding-top: clamp(0px,2.41vw,40px);  }
    .map-info__list > li .logo { font-size: clamp(20px,3.61vw,60px); }
    .map-info__list > li dd { font-size: clamp(24px,2.77vw,46px); }
    .map-info__list > li.address dd, .map-info__list > li .box span { max-width: initial; font-size: clamp(20px,1.8vw,30px); }
    .map-info__list > li.address dd > br { display: none; }

    .product-swiper { height: clamp(200px,30vw,500px); }
    .product-swiper__area .swiper-button-prev, .product-swiper__area .swiper-button-next { width: 40px; height: 40px; background-size: 20%; }
    .product__text > p { font-size: clamp(18px,1.325vw,22px); }

    .product-step__list .img__area .text-box { font-size: clamp(14px,1.2vw,20px); }

    .line-content__list .text-box .main-title { font-size: clamp(20px,2.17vw,36px); }
    .line-content__list .text-box .sub-title, .line-content__list .text-box .text { font-size: clamp(16px,1.2vw,20px); }
    .line-content__list .text-box .text > br { display: none; }
    .about__area .text-box .sub-title, .about__area .text-box .text { font-size: clamp(16px,1.2vw,20px); }
    .about__area .text-box .main-title { font-size: clamp(24px,3.37vw,56px); }
    .esg-card__list > li .text-box .text > br:not(.fixed-br) { display: none; }
    .esg-card__list > li.first .top > p { font-size: 20px;}
    .esg-card__list > li.first .top > p > br { display: none; }
    .card-num__item .text-box > p { font-size: clamp(14px,1.2vw,20px); }
    .card-num__item.first .text-box > p { font-size: clamp(18px,1.44vw,24px); }
    .card-num__item:not(.first) .text-box > p > br { display: none; }
    .method__item > .num { font-size: clamp(120px,9.03vw,150px); top: 50%; transform: translate(-50%, -50%); }

    .value-title { font-size: clamp(24px,2.16vw,36px); }
    .value-title > span { font-size: clamp(16px,1.45vw,24px); }
    .value__list { align-items: stretch; }
    .value__item { height: auto; gap: 50px; }
    .value__item .text-box dd > br { display: none; }
    .talent__area .circle-1 { width: clamp(400px,68.67vw,1140px);  }
    .talent__area .circle-2 { width: clamp(300px,42.16vw,700px); }
    .talent__item { min-width: clamp(180px,20.45vw,340px); }
    .talent__item.logo { min-width: clamp(200px,22.9vw,380px); }
    .system__list > li .text-box dd > br { display: none; }
    .benefits__area .item .text-box dd > br { display: none; }
}
@media screen and (max-width: 1400px) {
    .about-main .about-text { padding: 24px; }
    .greeting__wrap .text-box p > br { display: none; }
    .about-text .text-box .text p > br:not(.fixed-br) { display: none; }
    .value__item .text-box dt { font-size: 24px; }
    .value__item .text-box dd { font-size: 18px; }
    .core-value__list > li .text-box { margin-top: 30px; }

    .board_box table td { padding: 0 20px; }

    .map-info__list > li { height: auto; min-height: 260px; padding: 30px 20px; }
    .map-info__list > li.first .logo { width: 120px; }
    .map-info__list > li.first .arrow { width: 80px; }

    .product-status__list > li .info { padding: 30px 20px; }
    .product-status__list > li .info dl { font-size: 16px; }
    .product-status__list > li .info dt { width: 120px; }
    .product-status__list > li .info dd { width: calc(100% - 120px); }

    .about__area .text-box .text > br:not(.fixed-br) { display: none; }
    .esg-card__list > li { padding: 30px; height: 450px; }
    
    .table-item table thead th { font-size: 18px; } 
    .table-item table tbody th, .table-item table td { font-size: 18px; }
}
@media screen and (max-width: 1200px) {
    .depth2-tab { gap: 20px 40px; } 
    .depth2-tab .tab__item .num { font-size: 14px; }
    .depth2-tab .tab__item > a { font-size: 20px; }

    .board_box table .notice td a { padding-left: 90px; }
    .board_box table .notice td .tag { left: 20px; width: 70px; line-height: 25px; font-size: 16px; }
    .board_box table td a { padding-block: 20px; font-size: 16px; }
    .board_box table td.date, .board_box table td.hit { font-size: 14px; }
    .pr .board_box colgroup col:nth-child(1) { width: 65%; }
    .pr .board_box colgroup col:nth-child(2) { width: 20%; }
    .pr .board_box colgroup col:nth-child(3) { width: 15%; }
    .view_ctn .info { padding: 60px 20px 100px; }
    .view_ctn .tit { padding-bottom: 40px; }
    .view_ctn .file_box { width: calc(100% - 40px); padding: 30px 50px; }
    .view_ctn .file_box dl { gap: 5px 40px; }
    .view_ctn .file_box dt { font-size: 16px; }
    .view_ctn .file_box dt::after{ right: -17px; }
    .view_ctn .file_box dd { width: calc(100% - 177px); font-size: 16px; }
    .view_ctn .file_box dd a { padding-right: 150px; }
    .view_ctn .file_box dd a .download { font-size: 16px; }
    .view_ctn .file_box dd a .download::after { width: 30px; height: 30px; background-size: 50%; }
    .view_ctn .pages { margin-top: 60px; }

    .about-main .img-box { width: 100%; max-width: 600px; margin: 0 auto; }
    .about-main .about-text { width: 100%; padding: 40px; }
    .about__area .text-box .button__wrap { margin-top: 20px; }
    .core-value__list > li { padding-top: 0; }
    .core-value__list > li .text-box { margin-top: 20px; }
    .core-value__list > li .text-box .eng { font-size: 16px; }
    .product_list .item { padding: 30px 20px; }
    .product_list .text-box{ padding: 0 10px; }
    .product_list .title { font-size: 24px; }
    .product_list .info__list .info__item .label { width: 40px; font-size: 14px; }
    .product_list .info__list .info__item .text { width: calc(100% - 40px); font-size: 14px; }
    .product-step__list .img__area .text-box { padding: 50px 20px 20px; }
    .product-step__list .img__area .tag { padding: 8px 14px; }
    .product-step__list .img__area .tag .icon { width: 20px; height: 20px; }
    .product-step__list .img__area .setting + .setting { margin-top: 15px; }
    
    .product-status__list > li { width: calc(50% - 10px); }
    .product-status__list > li .title { font-size: 20px; }
    .product-status__list > li .info dl { font-size: 15px; }
    .product-step__list .img__area .text-box > p > br { display: none; }
    .esg-card__list > li { width: calc(50% - 10px); }
    .esg-part { padding: 20px; }
    .esg-part > .list > li > span:not(.num) { font-size: 16px; }
    .esg-card__list > li .text-box .text { font-size: 20px; }
    .card-num__item { width: calc((100% - 40px)/3); height: 250px; }

    .method__item { width: calc((100% - 20px)/3); }
    .job-type { padding: 40px; }
    .job-type .text-box > p { height: 80px; }

    .benefits__area .item { width: calc(50% - 10px); }
}
@media (min-width: 1025px) and (max-height: 880px) {
    .greeting__wrap .title { font-size: 32px; }
    .greeting__wrap .text-box p { font-size: 16px; }
}
@media (min-width: 1025px) and (max-height: 750px){
    .greeting__wrap { row-gap: 60px; }
    .greeting__wrap .text__area { position: static;}
    .greeting__wrap .title { margin-bottom: 30px; }
    .greeting__wrap .title > br { display: none; }
    .greeting__wrap .text__area, .greeting__wrap .img__area { width: 100%; }
    .greeting__wrap .img__area { display: flex; gap: 10px; }
    .greeting__wrap .img__area .img-box + .img-box { margin-top: 0; }
    .greeting__wrap .ceo span { font-size: 16px; }
    .greeting__wrap .ceo b { font-size: 20px; }
}
@media screen and (max-width: 1024px) {
    :root {
        --input-H: 50px;
        --input-Font: 16px;
    }
    #subWrap { padding-top: var(--header-H); }
    .sub-visual .inner { padding: 80px 0 60px; }
    .navigation > li > a, .navigation > li > span { font-size: 16px; }
    .depth2-tab { margin-bottom: 60px; } 
    .content__title { margin-bottom: 60px; }
    .paging { margin-top: 60px; }
    .content { padding-top: 60px; padding-bottom: 160px; }
    .content .section + .section { margin-top: 100px; }
    .sub__title { margin-bottom: 30px; }

    .search__area { margin-bottom: 20px; }
    .search__area form { height: 50px; }
    .search__area .search-select { width: 180px; font-size: 16px; }
    .search__area .btn-search { width: 50px; height: 50px; }

    .product_list .item { width: calc(50% - 10px); }
    .product-swiper .swiper-pagination-bullet { width: 6px; height: 6px; }
    .product__text { margin-top: 30px; }
    .product__text > p { font-size: 16px; }
    .product-step__list > li { margin-top: 50px; }
    .product-step__list .num-box { column-gap: 10px; }
    .product-step__list .num-box .num { width: 24px; font-size: 16px; line-height: 24px; }
    .product-step__list .num-box .title { font-size: 24px; }

    .about-main .about-text { padding: 40px 30px; }
    .about-text .tag-logo img { width: 100px; }
    .about-text .tag-logo { padding-left: 10px; padding-bottom: 10px; }
    .greeting__wrap { row-gap: 60px; }
    .greeting__wrap .text__area { position: static; }
    .greeting__wrap .title { margin-bottom: 30px; }
    .greeting__wrap .title > br { display: none; }
    .greeting__wrap .text__area, .greeting__wrap .img__area { width: 100%; }
    .greeting__wrap .img__area { display: flex; gap: 10px; }
    .greeting__wrap .img__area .img-box + .img-box { margin-top: 0; }
    .greeting__wrap .ceo span { font-size: 16px; }
    .greeting__wrap .ceo b { font-size: 20px; }
    .mission__area .img__area .text { padding: 20px; }
    .mission__area .img__area .text .top-text { font-size: 16px; }
    .vision__wrap .text-box { padding: 20px; }
    .vision__wrap .text-box > .sub-text { font-size: 16px; }
    .core-value__list { max-width: 600px; border-radius: 150px; margin: 0 auto; }
    .core-value__list > li { width: calc(50% - 10px); }
    .certificate__list > li .text-box .title { font-size: 28px; }
    .certificate__list > li .text-box .date { font-size: 16px; }
    .map-info__list > li .logo { font-size: clamp(36px,5.86vw,60px); }
    .map-info__list > li { width: calc(50% - 20px); min-height: 200px; padding: 20px; }
    .map-info__list > li dt { font-size: 16px; }
    .map-info__list > li .box .tag { padding: 4px 10px; font-size: 14px; }
    .map__box  { height: 360px; }

    .step__row:nth-child(even) { flex-direction: row; }
    .step__row .product__item { width: calc((50% - 10px)); }
    .step__row .product__item.text { width: 100%; padding: 20px 10px; }
    .step__row .product__item.text::after { display: none; }
    .step__row .product__item.text p { position: static; transform: none; }
    .step__row .product__item::before { display: none; width: 30px; height: 30px; left: -25px; }
    .step__row:not(.col):first-child .product__item:last-child::after { display: none; }
    .step__row:nth-child(2) .product__item .title-box { bottom: auto; top: 0; }
    .step__row .product__item .title-box { height: 45px; padding: 5px; font-size: 16px; }
    .product-step__list .img__area .img-box { width: 100%; max-width: 600px; margin: 0 auto; }
    .product-step__list .img__area .text-box { width: calc(50% - 10px); }
    .product-step__list .img__area .list > li { padding-left: 8px; }
    .product-step__list .img__area .list > li::before { width: 3px; height: 3px; }
    .product-status__list > li .title { padding: 10px 5px; font-size: 16px; }
    
    .line-content__list > li { flex-direction: column-reverse; align-items: flex-start; }
    .line-content__list > li + li { margin-top: 100px; }
    .line-content__list .img-box, .line-content__list .text-box { width: 100%; }
    .line-content__list .img-box { max-width: 400px; }
    .about__area, .about__area.reverse { flex-direction: column; align-items: flex-start; }
    .about__area .img-box { width: 100%; max-width: 500px; }
    .about__area .text-box { width: 100%; }
    .esg-card__list > li { height: 300px; }
    .esg-card__list > li .text-box .text { font-size: 16px; }
    .esg-img__list { gap: 30px 20px; }
    .esg-img__list > li { width: calc(50% - 10px); }
    .esg-img__list > li > span { font-size: 16px; }
    .card-num__item { width: calc(50% - 10px); }
    .caption-text { font-size: 14px; }
    .caption-text.title { font-size: 16px; }
    .table-item .table-scroll { overflow-x: auto; padding-bottom: 10px; }
    .table-item .table-scroll table { min-width: 800px; }
    .table-item .table-scroll.size-s table { min-width: 500px; }
    .table-item table thead th { height: 70px; font-size: 16px; padding: 0 10px; }
    .table-item table tbody th, .table-item table td { height: 60px; font-size: 16px; padding: 15px 10px; }
    .table-item table .dot { width: 12px; height: 12px; }
    .table-item table td ul { padding: 0; }

    .esg-part { position: static; margin-top: 20px; }
    .esg-part > .list { display: flex; flex-wrap: wrap; gap: 10px 20px; }
    .esg-part > .list > li + li { margin-top: 0; }
    .esg-part > p { font-size: 16px; }
    .esg-part > .list > li > span.num { width: 22px; line-height: 22px; font-size: 14px; }
    .esg-part > .list > li > span:not(.num) > br { display: none; }
    .director-state .title { font-size: 18px; }
    .director-state .title > small { font-size: 14px; }
    .director-state .list { gap: 10px; }
    .director-state .list > li { width: calc((100% - 30px)/4); }
    .director-state .list > li .position { font-size: 16px; }
    .director-state .list > li .name { font-size: 16px; }
    .value__item { gap: 40px ; }
    .value__item .icon { width: 50px; height: 50px; }
    .value__item .text-box { padding: 20px 20px 0; }
    .value__item .text-box dt { font-size: 20px; }
    .value__item .text-box dd { font-size: 14px; }
    
    .system__area + .system__area { margin-top: 100px; }
    .talent__list{ display: grid; grid-template-columns: 2fr 1fr 2fr; grid-template-rows: 2fr 1fr 2fr; max-width: 500px; flex-wrap: wrap; margin: 0 auto; }
    .talent__item { width: 100%; border-width: 5px; }
    .talent__item:nth-child(1) { grid-row-start:1; grid-column-start:1; }
    .talent__item:nth-child(2) { grid-row-start:3; grid-column-start:1; }
    .talent__item:nth-child(4) { grid-row-start:1; grid-column-start:3; }
    .talent__item:nth-child(5) { grid-row-start:3; grid-column-start:3; }
    .talent__item.logo { position: absolute; left: 50%; top: 50%; width: 300px; transform: translate(-50%, -50%); }
    .talent__item:nth-child(1),.talent__item:nth-child(2) { transform: none; }
    .talent__item:nth-child(4),.talent__item:nth-child(5) { transform: none; }
    .system__area { flex-direction: column; align-items: flex-start; row-gap: 0; }
    .system__area .sub__title { width: 100%; }    
    .system__area .sub__title > br { display: none; }    
    .system__box { width: 100%; }
    .system__list > li { padding: 40px 30px; }
    .system__list > li .icon { width: 80px; height: 80px; }
    .system__list > li .icon img { width: 60%; }
    .system__list > li .text-box { width: calc(100% - 120px); }
    .system__list > li .text-box dt { font-size: 20px; }
    .system__list > li .text-box dd { font-size: 16px; }
    .job-type .icon-box span { font-size: 20px; }
    .job-type .text-box > p { height: 60px; font-size: 16px; }
    .job-type .text-box > p:not(:last-child)::after { width: 30px; height: 30px; bottom: -24px; background-size: 30%; }
    .method__item > p { font-size: 20px; }
    .benefits__area .item { height: 400px; padding: 30px; }
    .benefits__area .item .text-box dt { font-size: 22px; }
    .benefits__area .item .text-box dd { font-size: 16px; }
    .agree__box { padding: 20px 30px; border-width: 2px; }
    .form__area { margin-top: 60px; padding: 40px 0; }
    .check__label span { max-width: calc(100% - 38px); font-size: 18px; }
    .terms__box { padding: 0 15px; }
    .terms__box .terms__text{ padding: 30px 15px; }
    .form__item .form__label { width: 180px; padding: 0 20px; font-size: 18px; }
    .form__item .input__box { width: calc(100% - 180px); padding: 0 20px; }
    .form-select { padding-left: 20px; padding-right: 40px; background-position: calc(100% - 20px) center; }
    .form-input { padding: 0 20px; }
    .form-textarea { padding: 20px; }
    .kcaptcha-box #btnKcaptcha { min-width: 50px; height: 50px; background-size: 40%; }
    .form-01 .button__wrap { margin-top: 60px; }
    .kcaptcha-box .kcaptcha-img { min-width: fit-content; width: fit-content; }
    .kcaptcha-box .kcaptcha-img img { position: static; width: auto; object-fit: contain; transform: none; }
}

@media screen and (max-width: 768px) {
    :root{
        --history-line: calc(100% - 130px);
    }
    .sub-visual .inner { flex-direction: column; padding: 40px 0 30px; }
    .navigation { column-gap: 30px; }
    .navigation > li::before { left: -16px; width: 4px; height: 4px; }
    .navigation > li.home > a { width: 24px; height: 24px; background-size: 70%; }
    .navigation > li > a, .navigation > li > span { font-size: 14px; }
    .navigation > li > a > br, .navigation > li > span > br { display: inline; }

    .paging a { width: 20px; height: 24px; font-size: 14px; }
    .paging .arr a:not(:last-child) { margin-right: 5px; }
    .paging a i { width: 8px; height: 13px; }
    .paging ul { margin: 0 5px; }
    .paging ul li:not(:last-child) { margin-right: 5px; }
    .paging ul li a { padding-top: 0; }
    .board_box table tr { display: flex; flex-wrap: wrap; width: 100%; padding: 5px 0; }
    .board_box table td { display: inline-block; width: 100%; padding: 5px 10px; }
    .board_box table td.date { width: 110px; text-align: left; }
    .board_box table td.hit { position: relative; width: fit-content; text-align: left; }
    .board_box table td.hit::before { content: ""; position: absolute; left: -10px; top: 50%; display: block; width: 1px; height: 10px; background-color: #DDD; transform: translateY(-50%); }
    .board_box table td a { padding-block: 5px;  }
    .board_box table .notice td a { padding-left: 70px; }
    .board_box table .notice td .tag { width: 60px; left: 10px; font-size: 14px; }
    .pr .board_box colgroup { display: none; }
    .search__area form { height: 40px; }
    .search__area .search-select { width: 120px; font-size: 14px; padding: 0 14px; background-position: calc(100% - 14px) center; }
    .search__area .search-input { width: calc(100% - 180px ); }
    .search__area .btn-search { width: 40px; height: 40px; background-size: 50%; }
    .view_ctn .tit { padding-bottom: 20px; }
    .view_ctn .tit ul { margin-top: 20px; }
    .view_ctn .tit ul li { font-size: 14px; }
    .view_ctn .info {  padding: 30px 0px 60px; }
    .view_ctn .file_box { width: 100%; padding: 20px; }
    .view_ctn .file_box dl { flex-direction: column; }
    .view_ctn .file_box dt { padding: 0; }
    .view_ctn .file_box dt::after { display: none; }
    .view_ctn .file_box dd { width: 100%; }
    .view_ctn .file_box dd a { padding-right: 50px; }
    .view_ctn .file_box dd a .download { font-size: 0; }
    .view_ctn .pages .btn-bracket { width: 180px; }
    .view_ctn .pages .btn-page a { font-size: 13px; }

    .depth2-tab { gap: 14px 20px; }
    .depth2-tab .tab__item .num { font-size: 12px; }
    .depth2-tab .tab__item { column-gap: 6px; }
    .depth2-tab .tab__item > a { font-size: 16px; }
    
    .product_list .item { width: 100%; }

    .mission__area { flex-wrap: wrap; }
    .mission__area .text-box,.mission__area .img__area { width: 100%; }
    .mission__area .text-box { height: 100px; }
    .mission__area .text-box > p > br { display: none; }
    .core-value__list { max-width: 300px; }
    .core-value__list > li { width: 100%; }
    .history__item { gap: 30px; }
    .history__item .year { width: 100px; font-size: 36px; }
    .history-text { column-gap: 10px; }
    .history-text .month { width: 30px; font-size: 20px; }
    .history-text .text { max-width: calc(100% - 40px); font-size: 16px; }

    .product-swiper { padding: 0 15px; }
    .product-swiper .swiper-pagination { gap: 5px; }
    .product-swiper__area .swiper-button-prev, .product-swiper__area .swiper-button-next { width: 30px; height: 30px; }
    .product-swiper__area .swiper-button-prev { left: 15px; }
    .product-swiper__area .swiper-button-next { right: 15px; }
    .product__content .sub__title { font-size: 24px; }

    .esg-card__list > li { width: 100%; }
    .esg-card__list > li .icon { width: 60px; height: 60px; }
    .esg-card__list > li .icon img { width: 80%; }
    .esg-card__list > li .text-box .title { margin-top: 0.8em; }
    .esg-card__list > li.first .top > p { font-size: 16px; }
    .table-item table thead th { height: 60px; }
    .table-item table tbody th, .table-item table td { height: 50px; font-size: 14px; }
    .esg-part { padding: 14px 20px; }
    .esg-part > .list > li { width: calc(50% - 10px); }
    .esg-part > .list > li > span:not(.num) { font-size: 14px; }
    .director-state .list > li { width: calc(50% - 5px); }
    .card-num__item { width: 100%; height: auto; padding: 40px 20px 20px; }
    .card-num__item.first { padding: 30px 20px; }
    .card-num__item .num-box { width: 24px; }
    .card-num__item .num-box .num { font-size: 14px; line-height: 24px; }
    .card-num__item .num-box::before { width: calc(100% + 5px); height: calc(100% + 5px); }
    .card-num__item.first .text-box > p > br { display: none; }

    .value__list { flex-direction: column; }
    .value__item { width: 100%; gap: 20px; }
    .talent__list { display: flex; max-width: 400px; height: 975px; }
    .talent__item { width: 220px; }
    .talent__item.logo { position: static; width: 255px; transform: none; }
    .talent__item:nth-child(2) { transform: translateY(-40px); }
    .talent__item:nth-child(3) { transform: translateY(-80px); }
    .talent__item:nth-child(4) { transform: translateY(-120px); }
    .talent__item:nth-child(5) { transform: translateY(-160px); }
    .method__item { width: calc(50% - 5px); padding: 5px; }
    .benefits__area .item { width: 100%; height: 360px; }
    .agree__box { padding: 14px 20px; }
    .check__label { gap:14px; }
    .checkbox-01 { width: 24px; height: 24px; background-size: 50%;  }
    .checkbox-01:checked { background-size: 50%; }
    .check__label span { font-size: 16px; }
    .terms__box .terms__text { font-size: 14px; }
    .form__item { flex-direction: column; align-items: flex-start; row-gap: 14px; }
    .form__item .form__label { width: fit-content; font-size: 16px; }
    .form__item .input__box { width: 100%; }
    .radio__label { gap: 10px; }
    .radio-01 { width: 20px; height: 20px; border-width: 5px; }

    .promotion__area .btn-download::after { width: 30px; height: 30px; margin-left: 10px; background-size: 50%; }
}
@media screen and (max-width: 640px) {
    :root{
        --history-line: 100%;
    }
    .greeting__wrap .img__area { flex-direction: column; }
    .mission__area .img__area { flex-wrap: wrap; }
    .mission__area .img__area .box { width: 100%; height: 300px; }
    .vision__wrap .vision__area { height: 400px; background-position: center 100px; }
    .vision__wrap .text-box { width: 100%; box-shadow: 0 5px 0 5px #fff; }
    .history__item { flex-direction: column; padding-top: 40px; }
    .history__item .year-content { width: 100%; padding-top: 0; min-height: initial; }
    .certificate__list > li { flex-direction: column; }
    .certificate__list > li .text-box { width: 100%; }
    .certificate__list > li .text-box .title-text { margin-top: 10px; }
    .certificate__list > li .text-box .title { font-size: 24px; }
    .map-info__list { gap: 10px; }
    .map-info__list > li { width: 100%; min-height: 160px; }

    .product-step__list .img__area .text-box { width: 100%; }
    .product-status__list > li { width: 100%; }
    .product-status__list > li .title { padding: 10px 5px; font-size: 18px; }
    
    .esg-img__list > li { width: 100%; }

    .system__area .system__box .flex { flex-direction: column; }
    .job-type { flex:none; }
    .job-type .text-box > p { width: 100%; }
    .job-type .text-box > p:not(:last-child)::after { right:50%; bottom: 0; transform: translate(50%, calc(50% + 10px)) rotate(90deg); }
    .system__list > li { flex-direction: column; }
    .system__list > li .text-box { width: 100%; text-align: center; }
    .kcaptcha-box { flex-wrap: wrap; }
}
@media screen and (max-width: 500px) {
    .step__row .product__item { width: 100%; }
    
    .method__item > .num { font-size: 90px; }
    .method__item > p { font-size: 16px; }
    .method__item.last > p { font-size: 26px; }
}

/* keyframes */
@keyframes textRight {
    0%{ opacity: 0; transform: translateX(-50%); }
    100%{ opacity: 1; transform: translateX(0%); }
}
@keyframes textLeft {
    0%{ opacity: 0; transform: translateX(50%); }
    100%{ opacity: 1; transform: translateX(0%); }
}