@charset "UTF-8";
/* ===== 서브페이지 공통 : S ===== */
.contents { padding-top: 70px; line-height: 1.3; letter-spacing: -0.02em; } 
.contents .hide { overflow: hidden; position: absolute; width: 1px; height: 1px; clip: rect(1px, 1px, 1px, 1px); clip-path: inset(50%); } 

.tab-wrap { display: flex; justify-content: center; padding-bottom: 80px; margin-top: -20px; } 
.tab-btn + .tab-btn { margin-left: -1px; } 
.tab-btn a { display: block; min-width: 180px; padding: 12px 60px; border: 1px solid #bfbfbf; font-weight: 500; font-size: 16px; text-align: center; transition: all 0.3s; } 
.tab-btn:hover a,
.tab-btn.active a { border-color: #21ad93; background-color: #21ad93; color: #fff; } 

@media (max-width: 1280px){
 .contents { padding-top: 65px; } 
 .tab-wrap { padding-bottom: 70px; } 
 .tab-btn a { min-width: 160px; padding: 11px 50px; font-size: 15px; } 
 }
@media (max-width: 1024px){
 .contents { padding-top: 60px; } 
 }
@media (max-width: 768px){
 .contents { padding-top: 55px; } 
 .tab-wrap { padding-bottom: 60px; } 
 .tab-btn a { min-width: 140px; padding: 10px 40px; font-size: 14px; } 
 }
@media (max-width: 480px){
 .contents { padding-top: 50px; } 
 }

/* ===== 서브페이지 공통 : E ===== */

/* ===== 1-1_기업정보 : S ===== */
.company { margin-bottom: 180px; font-weight: 500; } 
.company-intro { display: flex; flex-wrap: wrap; column-gap: 50px; margin-bottom: 130px; } 
.company-slogan { display: flex; flex-direction: column; justify-content: space-around; row-gap: 20px; width: 350px; min-width: 280px; padding: 50px 0; border: 3px solid #21ad93; background: #21ad93 url(../images/contents/1-1_company_bg01.png) no-repeat
 center/130%; font-weight: 700; font-size: 45px; text-align: center; color: #fff; } 
.company-slogan span { letter-spacing: 0.1em; text-indent: 0.1em; } 
.company-slogan br { display: none; } 
.company-txt { display: flex; flex-direction: column; flex-grow: 1; justify-content: center; width: calc(100% - 400px); color: #000; } 
.company-tit { font-size: 40px; text-align: center; } 
.company-tit strong { font-weight: 700; } 
.company-tit strong:first-child { letter-spacing: 0.05em; color: #21ad93; } 
.company-tit span { font-weight: 300; } 
.company-tit br { display: none; } 
.company-quote { padding: 15px 0; margin: 20px 0; border-top: 1px solid #0aac8d; border-bottom: 1px solid #0aac8d; font-weight: 700; font-size: 20px; letter-spacing: -0.04em; text-align: center; color: #21ad93; } 
.company-quote::before { content: "“"; } 
.company-quote::after { content: "”"; } 
.company-quote br { display: none; } 
.company-desc { font-size: 18px; } 
.company-desc + .company-desc { margin-top: 15px; } 
.company-desc strong { display: inline-block; width: 122px; height: 33px; margin-right: 3px; background: url(../images/contents/1-1_company_logo.svg) no-repeat
 center/contain; vertical-align: bottom; color: transparent; } 
.company-desc q { font-weight: 700; color: #21ad93; } 
.company-desc q::before { content: "“"; font-weight: 500; color: #000; } 
.company-desc q::after { content: "”"; font-weight: 500; color: #000; } 

.company-state { background: url(../images/contents/1-1_company_bg02.jpg) no-repeat center
 bottom; color: #fff; } 
.company-state .inner { padding: 60px 0 100px; } 
.company-state-tit { font-weight: 700; font-size: 30px; } 
.company-state-list { display: flex; column-gap: 1%; } 
.company-state-item { width: 25%; padding: 0 5px; text-align: center; } 
.company-state-item::before { display: block; width: 175px; height: 175px; margin: 55px auto 45px; border-radius: 50%; background: #fff url(../images/contents/1-1_company_ico01.svg) no-repeat
 center; content: ""; } 
.company-state-item:nth-child(2):before { background-image: url(../images/contents/1-1_company_ico02.svg); } 
.company-state-item:nth-child(3):before { background-image: url(../images/contents/1-1_company_ico03.svg); } 
.company-state-item:nth-child(4):before { background-image: url(../images/contents/1-1_company_ico04.svg); } 
.company-state-item dt { display: inline; padding: 5px 0; box-shadow: 0 2px 0 #21ad93; font-weight: 700; font-size: 22px; line-height: 1.5; } 
.company-state-item dd { margin-top: 18px; font-size: 15px; } 

@media (max-width: 1440px){
 .company-quote br { display: block; } 
 .company-tit { font-size: 2.7vw; line-height: 1.1; } 
 }
@media (max-width: 1280px){
 .company { margin-bottom: 160px; } 
 .company-intro { column-gap: 30px; margin-bottom: 110px; } 
 .company-slogan { width: 25%; padding: 45px 15px; background-size: 150%; font-size: 40px; } 
 .company-slogan span { display: block; letter-spacing: 0; text-indent: 0; } 
 .company-quote { padding: 13px 0; margin: 17px 0; font-size: 19px; } 
 .company-desc { font-size: 17px; } 
 .company-desc + .company-desc { margin-top: 14px; } 
 .company-desc strong { width: 104px; height: 28px; } 
 .company-desc q { font-weight: 700; } 
 }
@media (max-width: 1024px){
 .company-intro { flex-direction: column; align-items: center; } 
 .company-slogan { display: block; width: 100%; padding: 40px 60px 130px; background-size: auto; } 
 .company-slogan span { display: inline; } 
 .company-slogan br { display: block; } 
 .company-txt { display: flex; flex-direction: column; justify-content: center; width: calc(100% - 120px); padding-top: 55px; margin-top: -100px; background-color: #fff; } 
 .company-quote { margin: 25px auto 20px; font-size: 18px; } 

 .company-tit { font-size: 3vw; } 
 .company-tit strong:first-child { letter-spacing: 0.1em; } 

 .company-state { background-size: cover; } 
 .company-state .inner { padding: 55px 0 90px; } 
 .company-state-tit { font-size: 27px; } 
 .company-state-list { flex-wrap: wrap; column-gap: 2%; } 
 .company-state-item { width: 49%; } 
 .company-state-item::before { width: 145px; height: 145px; margin: 35px auto 25px; } 
 .company-state-item dt { margin-bottom: 16px; font-size: 21px; } 
 .company-state-item dd { font-size: 14px; } 
 }
@media (max-width: 768px){
 .company { margin-bottom: 140px; } 

 .company-intro { margin-bottom: 90px; } 
 .company-slogan { width: auto; padding: 25px 30px; background-size: 80%; font-size: 35px; } 
 .company-slogan span { display: block; letter-spacing: 0.3em; text-indent: 0.3em; } 
 .company-slogan br { display: none; } 
 .company-txt { width: 100%; padding-top: 35px; margin-top: 0; background-color: transparent; } 
 .company-tit { font-size: 22px; } 
 .company-quote { margin: 15px auto; } 
 .company-quote br { display: none; } 
 .company-desc { font-size: 16px; } 

 .company-state .inner { padding: 50px 0 80px; } 
 .company-state-tit { font-size: 24px; } 
 .company-state-item dt { padding: 4px 0; margin-bottom: 15px; border-bottom-width: 1px; font-size: 20px; } 
 .company-state-item dd { font-size: 14px; } 
 }
@media (max-width: 640px){
 .company-tit br { display: block; } 
 }
@media (max-width: 480px){
 .company { margin-bottom: 120px; } 
 .company-intro { margin-bottom: 80px; } 

 .company-slogan { width: 100%; padding: 30px 10px; font-size: 35px; } 
 .company-slogan span { letter-spacing: 0.15em; text-indent: 0.15em; } 
 .company-tit { font-size: 19px; } 
 .company-quote { font-size: 18px; } 
 .company-desc { font-size: 15px; } 

 .company-state { background-image: url(../images/contents/1-1_company_bg02_m.jpg); } 
 .company-state .inner { padding: 40px 0 70px; } 
 .company-state-tit { font-size: 20px; } 
 .company-state-item { width: 100%; } 
 .company-state-item::before { width: 100px; height: 100px; margin: 25px auto 15px; background-size: 48px; } 
 .company-state-item dt { padding: 3px 1px; margin-bottom: 12px; font-size: 18px; } 
 }
/* ===== 1-1_기업정보 : E ===== */

/* ===== 1-2_연혁 : S ===== */
.history { position: relative; padding-bottom: 300px; } 
.history::before { position: absolute; top: 69px; left: 50%; width: 1px; height: calc(100% - 69px); background-color: #21ad93; content: ""; } 
.history-top { display: flex; justify-content: center; margin-bottom: 80px; } 
.history-logo { padding-left: 25px; } 
.history-logo img { height: 100%; object-fit: contain; } 

.history-wrap { display: grid; grid-template-columns: 46% 46%; justify-content: space-between; row-gap: 70px; } 
.history-wrap + .history-wrap { margin-top: 100px; } 
.history-wrap::before { position: absolute; top: 17px; left: 50%; width: 14px; height: 14px; border-radius: 50%; background-color: #21ad93; outline: 6px solid rgba(33, 173, 147, 0.1); content: ""; transform: translateX(-50%); } 

.history-era { position: relative; font-weight: 700; font-size: 55px; line-height: 0.8; color: #222; } 
.history-item { display: flex; } 
.history-item + .history-item { margin-top: 35px; } 
.history-year { flex-shrink: 0; width: 90px; font-weight: 700; font-size: 25px; line-height: 1.1; color: #222; } 
.history-list { display: flex; flex-direction: column; justify-content: center; position: relative; padding-left: 18px; font-weight: 500; color: #3c3c3c; } 
.history-list li { line-height: 1.2; } 
.history-list li + li { margin-top: 15px; } 
.history-list::before { position: absolute; top: 50%; left: 0; width: 2px; height: calc(100% - 10px); background-color: #222; content: ""; transform: translateY(-50%); } 

.history-wrap:nth-child(even) .history-img { grid-column: 1 / 2; grid-row: 1 / 3; } 
.history-wrap:nth-child(even) .history-img img { display: block; border-top-left-radius: 70px; } 
.history-wrap:nth-child(odd) .history-era { text-align: right; color: #21ad93; } 
.history-wrap:nth-child(odd) .history-item { flex-direction: row-reverse; justify-content: end; text-align: right; } 
.history-wrap:nth-child(odd) .history-year { color: #21ad93; } 
.history-wrap:nth-child(odd) .history-list { padding-right: 18px; padding-left: 0; } 
.history-wrap:nth-child(odd) .history-list::before { right: 0; left: auto; background-color: #21ad93; } 
.history-wrap:nth-child(odd) .history-img { grid-column: 2 / 3; grid-row: 1 / 3; } 
.history-wrap:nth-child(odd) .history-img img { display: block; margin-left: auto; border-top-right-radius: 70px; } 

@media (max-width: 1280px){
 .history { padding-bottom: 270px; } 
 .history-top { margin-bottom: 70px; } 

 .history-wrap { grid-template-columns: 47% 47%; row-gap: 60px; } 
 .history-wrap + .history-wrap { margin-top: 90px; } 
 .history-wrap::before { top: 12px; } 

 .history-era { font-size: 44px; } 
 .history-item + .history-item { margin-top: 31px; } 
 .history-year { width: 80px; font-size: 23px; } 
 .history-list { padding-left: 15px; } 

 .history-wrap:nth-child(odd) .history-list { padding-right: 15px; } 
 }
@media (max-width: 1024px){
 .history { padding-bottom: 240px; } 
 .history::before { top: 50px; left: 25px; height: calc(100% - 50px); } 
 .history-top { justify-content: start; margin-bottom: 60px; } 
 .history-logo { height: 50px; padding-left: 8px; } 

 .history-wrap { grid-template-columns: 1fr; grid-template-rows: 35vmin auto auto; row-gap: 45px; padding-left: 80px; } 
 .history-wrap::before { display: none; } 
 .history-era::before { position: absolute; top: 11px; left: -62px; width: 14px; height: 14px; border-radius: 50%; background-color: #21ad93; outline: 6px solid rgba(33, 173, 147, 0.1); content: ""; } 

 .history-year { width: 70px; font-size: 21px; } 
 .history-list { font-size: 15px; } 

 .history-img { width: 80%; } 
 .history-img img { width: 100%; height: 100%; object-fit: cover; } 
 .history-wrap:nth-child(even) .history-img { grid-row: 1 / 2; } 
 .history-wrap:nth-child(even) .history-img img { border-radius: 0 60px 0 0; } 
 .history-wrap:nth-child(odd) .history-era { text-align: left; } 
 .history-wrap:nth-child(odd) .history-item { flex-direction: row; justify-content: start; text-align: left; } 
 .history-wrap:nth-child(odd) .history-year { color: #21ad93; } 
 .history-wrap:nth-child(odd) .history-list { padding-right: 0; padding-left: 15px; } 
 .history-wrap:nth-child(odd) .history-list::before { right: auto; left: 0; } 
 .history-wrap:nth-child(odd) .history-img { grid-column: 1 / 2; grid-row: 1 / 2; } 
 .history-wrap:nth-child(odd) .history-img img { margin-left: 0; border-top-right-radius: 60px; } 
 }
@media (max-width: 768px){
 .history { padding-bottom: 210px; } 
 .history::before { left: 17px; } 
 .history-top { margin-bottom: 50px; } 
 .history-logo { padding-left: 0; } 

 .history-wrap { row-gap: 35px; padding-left: 50px; } 
 .history-era { font-size: 6vw; } 
 .history-era::before { top: 1.8vw; left: -38px; width: 11px; height: 11px; outline-width: 5px; } 
 .history-img { width: 100%; } 

 .history-list { font-size: 14px; } 
 .history-list li + li { margin-top: 14px; } 
 }
@media (max-width: 640px){
 .history { padding-bottom: 180px; } 
 .history-top { margin-bottom: 40px; } 

 .history-wrap { padding-left: 40px; } 
 .history-item { flex-direction: column; row-gap: 20px; } 
 .history-wrap:nth-child(odd) .history-item { flex-direction: column; } 
 .history-era { font-size: 7vw; } 
 .history-era::before { top: 1.4vw; left: -28px; } 
 .history-list::before { display: none; } 
 .history-list { padding-left: 0; } 
 .history-list li { position: relative; padding-left: 8px; } 
 .history-list li::before { position: absolute; top: 8px; left: 0; width: 4px; height: 1px; background-color: #3c3c3c; content: ""; } 
 .history-wrap:nth-child(odd) .history-list li::before { background-color: #21ad93; } 
 .history-wrap:nth-child(odd) .history-list { padding-left: 0; } 
 }
/* ===== 1-2_연혁 : E ===== */

/* ===== 1-4_오시는 길 : S ===== */
.map { margin-bottom: 180px; } 
.map-tab { display: flex; justify-content: center; column-gap: 8px; margin-top: -50px; margin-bottom: 50px; } 
.map-btn button { padding: 30px 40px; border: 0; border-bottom: 3px solid #dfe5e4; background-color: transparent; font-weight: 500; font-size: 18px; color: #666; transition: all 0.3s; } 
.map-btn.active button { border-bottom-color: #21ad93; font-weight: 700; color: #222; } 
.map-btn:not(.active):hover button { background-color: #dfe5e4; color: #444; } 
.map-box { height: 450px; margin-bottom: 70px; } 

.map-item { display: none; } 
.map-item.active { display: block; } 
.map-info { display: flex; flex-wrap: wrap; justify-content: space-evenly; row-gap: 35px; text-align: center; } 

.map-txt.add { width: 100%; } 
.map-txt dt { display: flex; flex-direction: column; align-items: center; row-gap: 30px; margin-bottom: 15px; font-weight: 700; font-size: 25px; color: #222; } 
.map-txt dt::before { width: 50px; height: 50px; background: url(../images/contents/1-4_map_ico01.svg) no-repeat center/contain; content: ""; } 
.map-txt.add dt::before { background-image: url(../images/contents/1-4_map_ico02.svg); } 
.map-txt.tel dt::before { background-image: url(../images/contents/1-4_map_ico03.svg); } 
.map-txt dd { max-width: 800px; margin: 0 auto; font-size: 16px; letter-spacing: 0.05em; } 
.copy-btn { display: block; padding: 6px 12px; margin: 12px auto 0; border: 0; background-color: #21ad93; font-weight: 500; font-size: 14px; letter-spacing: 0.05em; color: #fff; transition: all 0.3s; } 
.copy-btn:hover { background-color: #222; } 

@media (max-width: 1280px){
 .map { margin-bottom: 160px; } 
 .map-box { height: 430px; margin-bottom: 65px; } 
 }
@media (max-width: 1024px){
 .map-box { height: 410px; margin-bottom: 60px; } 

 .map-txt:not(.add) { width: 30%; } 
 .map-txt dt { row-gap: 20px; margin-bottom: 10px; font-size: 22px; } 
 .map-txt dt::before { width: 40px; height: 40px; } 
 .map-txt dd { font-size: 15px; letter-spacing: 0.02em; } 
 }
@media (max-width: 768px){
 .map { margin-bottom: 140px; } 
 .map-tab { column-gap: 6px; margin-bottom: 40px; } 
 .map-btn button { padding: 25px 35px; font-size: 17px; } 
 .map-box { height: 390px; margin-bottom: 50px; } 

 .map-info { gap: 40px 20px; } 
 .map-txt:not(.add) { width: calc(50% - 10px); } 
 .map-txt dt { row-gap: 10px; margin-bottom: 5px; font-size: 20px; } 
 .map-txt dt::before { width: 35px; height: 35px; } 
 .map-txt dd { letter-spacing: 0; } 
 }
@media (max-width: 480px){
 .map-btn button { text-align: center; padding: 25px; } 
 .map-box { height: 370px; margin-bottom: 40px; } 

 .map-info { gap: 30px 0; } 
 .map-txt:not(.add) { width: 100%; } 
 }
/* ===== 1-4_오시는 길 : E ===== */

/* ===== 2_PRODUCT 공통 : S ===== */
.product { margin-bottom: 180px; } 
.product .slick-arrow { display: flex; justify-content: center; align-items: center; position: absolute; top: 50%; z-index: 2; width: 50px; height: 50px; border: 0; border-radius: 50%; background-color: #fff; box-shadow: 0 0 10px rgba(0, 0, 0, 0.08); font-size: 0; transform: translateY(calc(-50% - 5px)); transition: all 0.3s; } 
.product .slick-arrow::before { width: 14px; height: 24px; background: url(../images/contents/2-0_product_slick-arrow_bk.svg) no-repeat
 center/contain; content: ""; transition: all 0.3s; } 
.product .slick-prev { left: 0; padding-right: 3px; } 
.product .slick-next { right: 0; padding-left: 3px; } 
.product .slick-next::before { transform: scaleX(-1); } 
.product .slick-arrow:hover { background: #000; } 
.product .slick-arrow:hover::before { background-image: url(../images/contents/2-0_product_slick-arrow_w.svg); } 
.product .slick-slide img { margin: 0 auto; } 

@media (max-width: 1280px){
 .product { margin-bottom: 160px; } 
 }
@media (max-width: 768px){
 .product { margin-bottom: 140px; } 
 .product .slick-arrow { width: 40px; height: 40px; box-shadow: 0 0 8px rgba(0, 0, 0, 0.08); } 
 .product .slick-arrow::before { width: 12px; height: 20px; } 
 }
/* ===== 2_PRODUCT 공통 : E ===== */

/* ===== 2-1_BIPV : S ===== */
.bipv-item { padding-bottom: 55px; margin-bottom: 110px; border-bottom: 1px solid #e4e4e4; } 
.bipv-item:last-child { padding-bottom: 0; margin-bottom: 0; border-bottom: 0; } 
.bipv-tit { margin-bottom: 40px; font-weight: 700; font-size: 34px; text-align: center; color: #000; } 

.bipv-slick { padding: 0 70px; } 
.bipv-slick-wrap { width: 100%; padding: 65px 65px 60px; margin-bottom: 50px; background-color: #eff2f1; } 
.bipv-slick .slick-dots { display: flex; justify-content: center; column-gap: 25px; padding-top: 20px; } 
.bipv-slick .slick-dots button { width: 6px; height: 6px; border: 0; border-radius: 50%; background-color: #000; font-size: 0; } 
.bipv-slick .slick-dots .slick-active button { background-color: #21ad93; } 
#bipv01 .slick-list,
#bipv04 .slick-list,
#bipv05 .slick-list,
#bipv06 .slick-list,
#bipv08 .slick-list { max-width: 630px; margin: 0 auto; } 
#bipv02 .slick-list,
#bipv03 .slick-list,
#bipv07 .slick-list { max-width: 800px; margin: 0 auto; } 
#bipv09 .slick-dots { column-gap: 20px; } 

.bipv-info { display: flex; justify-content: space-between; } 
.bipv-info-tit { margin-bottom: 30px; font-weight: 700; font-size: 20px; color: #21ad93; } 
.bipv-feature { width: 32%; } 
.bipv-feature li { display: flex; font-weight: 500; font-size: 17px; line-height: 1.2; color: #222; } 
.bipv-feature li + li { margin-top: 8px; } 
.bipv-feature li::before { margin-right: 5px; content: "-"; line-height: 1.1; color: #21ad93; } 
.bipv-spec { width: 65%; } 
.bipv-spec dl { display: grid; border-bottom: 1px solid rgba(191, 206, 203, 0.5); text-align: center; } 
.bipv-spec dt { display: flex; grid-row: 1 / 2; justify-content: center; align-items: center; padding: 15px 5px; background-color: #21ad93; font-weight: 700; font-size: 16px; color: #fff; } 
.bipv-spec dt ~ dt { border-left: 1px solid rgba(191, 206, 203, 0.5); } 
.bipv-spec dd { grid-row: 2 / 3; padding: 15px 5px; font-weight: 500; font-size: 15px; color: #666; } 
.bipv-spec dd ~ dd { border-left: 1px solid rgba(191, 206, 203, 0.5); } 

@media (max-width: 1440px){
 .wide-table2 dt:nth-child(9) ~ dt { grid-row: 3 / 4; } 
 .wide-table2 dd:nth-child(10) ~ dd { grid-row: 4 / 5; } 
 .wide-table2 dt:nth-child(11),
 .wide-table2 dd:nth-child(12) { border-left-width: 0; } 
 .wide-table2 dt:nth-last-child(2) { grid-column: 4 / 6; } 
 .wide-table2 dd:last-child { grid-column: 4 / 6; } 
 }
@media (max-width: 1280px){
 .bipv-item { padding-bottom: 50px; margin-bottom: 95px; } 
 .bipv-tit { margin-bottom: 35px; font-size: 30px; } 

 .bipv-slick-wrap { padding: 55px 55px 50px; margin-bottom: 40px; } 
 .bipv-slick .slick-dots { column-gap: 22px; padding-top: 18px; } 

 .bipv-info-tit { margin-bottom: 25px; font-size: 19px; } 
 .bipv-feature li { font-size: 16px; } 
 .bipv-spec dt { font-weight: 600; font-size: 15px; } 
 .bipv-spec dd { font-size: 14px; } 
 }
@media (max-width: 1024px){
 .bipv-slick-wrap { padding: 50px 40px 45px; } 
 #bipv09 .slick-dots { column-gap: 15px; } 
 .bipv-info { flex-direction: column; row-gap: 25px; } 
 .bipv-info-tit { margin-bottom: 15px; } 
 .bipv-feature { width: 100%; } 
 .bipv-feature li { font-size: 17px; letter-spacing: 0; } 
 .bipv-spec { width: 100%; } 
 }
@media (max-width: 768px){
 .bipv-item { padding-bottom: 45px; margin-bottom: 80px; } 
 .bipv-tit { margin-bottom: 30px; font-size: 26px; } 

 .bipv-slick { padding: 0 60px; } 
 .bipv-slick-wrap { padding: 45px 25px 40px; margin-bottom: 35px; } 
 .bipv-slick .slick-dots { column-gap: 20px; padding-top: 16px; } 

 .bipv-info-tit { margin-bottom: 20px; } 
 .bipv-feature li { font-size: 16px; letter-spacing: -0.02em; } 
 }
@media (max-width: 576px){
 .bipv-item { padding-bottom: 40px; margin-bottom: 65px; } 
 .bipv-tit { margin-bottom: 25px; font-size: 22px; } 

 .bipv-slick { padding: 0 50px; } 
 .bipv-slick-wrap { padding: 45px 10px 40px; margin-bottom: 30px; } 

 .bipv-info { row-gap: 20x; } 
 .bipv-info-tit { margin-bottom: 15px; } 
 .bipv-feature li { font-size: 15px; } 
 .bipv-feature li::before { line-height: 1.2; } 
 .bipv-spec dl { border-right: 1px solid rgba(191, 206, 203, 0.5); } 
 .bipv .bipv-info .bipv-spec dt { grid-column: 1 / 2; grid-row: auto; padding: 12px 5px; border-top: 1px solid rgba(191, 206, 203, 0.5); border-left: 0; } 
 .bipv .bipv-info .bipv-spec dd { display: flex; grid-column: 2 / 3; grid-row: auto; justify-content: center; align-items: center; padding: 12px 5px; border-top: 1px solid rgba(191, 206, 203, 0.5); border-left: 0; } 
 }
/* ===== 2-1_BIPV : E ===== */

/* ===== 2-2_BIPV 구조물 : S ===== */
.bipv-struc-item { display: grid; grid-template-columns: 55% 45%; justify-content: space-between; align-items: end; margin-bottom: 140px; } 
.bipv-struc-item::before { width: 100%; height: 100%; background-color: #21ad93; content: ""; } 
.bipv-struc-img { grid-row: 2 / 4; padding-right: 5%; margin-top: -45px; } 
.bipv-struc-img img { display: block; } 
.bipv-struc-tit { padding: 15px 0; background-color: #21ad93; font-weight: 700; font-size: 24px; color: #fff; } 
.bipv-struc-txt { align-self: center; padding: 25px 0; } 
.bipv-struc-txt h5 { margin-bottom: 10px; font-weight: 700; font-size: 22px; color: #222; } 
.bipv-struc-txt li { display: flex; margin-bottom: 10px; font-weight: 500; } 
.bipv-struc-txt li::before { margin-right: 5px; content: "-"; line-height: 1.2; } 
.bipv-struc .slick-prev { transform: translate(-50%, -50%); } 
.bipv-struc .slick-next { transform: translate(50%, -50%); } 

@media (max-width: 1280px){
 .bipv-struc-item { grid-template-columns: 600px calc(100% - 600px); margin-bottom: 125px; } 
 .bipv-struc-img { padding-right: 3%; margin-top: -40px; } 
 .bipv-struc-tit { font-size: 22px; } 
 .bipv-struc-txt { padding: 15px 0; } 
 .bipv-struc-txt h5 { margin-bottom: 8px; font-size: 20px; } 
 .bipv-struc-txt li { margin-bottom: 8px; font-size: 15px; } 
 .bipv-struc-txt li::before { line-height: 1.3; } 
 .bipv-struc .slick-prev { transform: translate(-10px, -50%); } 
 .bipv-struc .slick-next { transform: translate(10px, -50%); } 
 }
@media (max-width: 1024px){
 .bipv-struc-item { display: block; margin-bottom: 110px; } 
 .bipv-struc-tit { padding: 30px 40px; font-size: 26px; text-align: right; } 
 .bipv-struc-img { width: 75%; padding-right: 0; margin-top: -70px; } 
 .bipv-struc-txt { padding: 25px 0; } 
 .bipv-struc-txt h5 { font-size: 24px; color: #21ad93; } 
 .bipv-struc-slick { padding: 0 70px; } 
 .bipv-struc .slick-prev { transform: translate(0, -50%); } 
 .bipv-struc .slick-next { transform: translate(0, -50%); } 
 }
@media (max-width: 768px){
 .bipv-struc-item { margin-bottom: 95px; } 
 .bipv-struc-tit { padding: 20px 20px 25px; font-size: 22px; } 
 .bipv-struc-img { width: auto; margin-top: -2.5%; } 
 .bipv-struc-txt h5 { font-size: 20px; } 
 .bipv-struc-slick { padding: 0 60px; } 
 }
@media (max-width: 480px){
 .bipv-struc-item { margin-bottom: 80px; } 
 .bipv-struc-tit { width: calc(100% + 40px); padding: 15px 15px 20px; margin: 0 -20px; font-size: 20px; } 
 .bipv-struc-img { width: calc(100% + 40px); padding-right: 10px; margin: -2.5% -20px 0; } 
 .bipv-struc-txt h5 { font-size: 18px; } 
 .bipv-struc-txt li { font-size: 14px; } 
 .bipv-struc-slick { padding: 0; } 
 .bipv-struc .slick-prev { transform: translate(-10px, -50%); } 
 .bipv-struc .slick-next { transform: translate(10px, -50%); } 
 }
/* ===== 2-2_BIPV 구조물 : E ===== */

/* ===== 2-3_GIPV : S ===== */
.gipv section + section { margin-top: 120px; } 
.gipv-tit-box { position: absolute; top: 0; left: 0; padding: 40px; background-color: #000; text-align: center; line-height: 1.1; } 
.gipv-tit-box span { font-weight: 700; font-size: 30px; color: #fff; } 
.gipv-tit-box em { display: block; padding-top: 10px; margin-top: 10px; border-top: 1px solid rgba(255, 255, 255, 0.25); font-weight: 700; font-size: 25px; color: #21ad93; } 

.gipv-intro { text-align: center; } 
.gipv-intro-desc { max-width: 1250px; margin: 0 auto; font-weight: 500; font-size: 22px; line-height: 1.4; } 
.gipv-intro-desc p:first-child { margin-bottom: 15px; } 
.gipv-intro-desc strong { font-weight: 700; color: #21ad93; } 
.gipv-intro-desc em { font-weight: 700; color: #222; } 

.gipv-principle { background: #eff2f1 url(../images/contents/2-3_gipv_principle_bg01.png)
 no-repeat left bottom; background-size: 25vw; text-align: center; } /* 왼쪽 배경그림 */
.gipv-principle::before { position: absolute; right: 0; bottom: 0; width: 22vw; height: 415px; background: url(../images/contents/2-3_gipv_principle_bg02.png) no-repeat
 center bottom/contain; content: ""; } /* 오른쪽 배경그림 */
.gipv-principle .inner { position: relative; padding: 60px 0 160px; } 
.gipv-principle-img { display: flex; flex-direction: column; align-items: center; row-gap: 20px; font-weight: 700; } 
.gipv-principle-sun { display: flex; justify-content: center; align-items: center; position: relative; width: 150px; height: 150px; padding-top: 5px; font-size: 17px; color: #fff; line-height: 1; } 
.gipv-principle-sun::before { position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: url(../images/contents/2-3_gipv_principle_ico01.svg) no-repeat
 center/contain; content: ""; animation: sun 16s linear infinite; } 
@keyframes sun { 
 0% { transform: rotate(0deg); } 
 10% { transform: scale(0.9) rotate(36deg); } 
 20% { transform: scale(1) rotate(72deg); } 
 30% { transform: scale(0.9) rotate(108deg); } 
 40% { transform: scale(1) rotate(144deg); } 
 50% { transform: scale(0.9) rotate(180deg); } 
 60% { transform: scale(1) rotate(216deg); } 
 70% { transform: scale(0.9) rotate(252deg); } 
 80% { transform: scale(1) rotate(284deg); } 
 90% { transform: scale(0.9) rotate(316deg); } 
 100% { transform: scale(1) rotate(359deg); } 
 }
.gipv-principle-sun h5 { position: relative; text-shadow: 1px 0 0 #ee7b00, 0 1px 0 #ee7b00, -1px 0 0 #ee7b00,
 0 -1px 0 #ee7b00; } 
.gipv-principle-percent h5 { font-weight: 700; font-size: 22px; color: #222; line-height: 1.1; } 
.gipv-principle-percent em { font-size: 35px; display: block; } 
.gipv-principle-floor { display: flex; position: relative; width: calc(100% - 200px); padding-top: 70px; } 
.gipv-principle-floor::before { position: absolute; top: 0; left: 50%; width: calc(50% + 4px); height: 60px; border: 3px dashed #000; border-bottom: 0; border-radius: 25px 25px 0 0; content: ""; transform: translateX(-50%); } 
.gipv-principle-floor li { display: flex; flex-direction: column; align-items: center; position: relative; z-index: 2; width: 50%; } 
.gipv-principle-floor h5 span { display: block; overflow: hidden; position: relative; padding: 10px 40px; border-radius: 50px; background-color: #21ad93; font-weight: 700; font-size: 24px; color: #fff; } 
.gipv-principle-floor h5 span::before { opacity: 0.3; position: absolute; top: -100%; right: -5%; width: 240px; height: 240px; background: url(../images/contents/2-3_gipv_principle_ico04.png) no-repeat
 center/contain; content: ""; animation: floor-rotate 3s linear infinite; } 
@keyframes floor-rotate { 
 0% { transform: rotate(0deg); } 
 100% { transform: rotate(359deg); } 
 }
.gipv-principle-floor h5::after { display: inline-block; height: 40px; margin: 20px 0 5px; border-left: 3px dashed #000; content: ""; } 
.gipv-principle-floor em { position: relative; font-size: 22px; color: #21ad93; line-height: normal; } 
.gipv-principle-floor em::before { display: block; width: 96px; height: 96px; margin: 10px auto; background: url(../images/contents/2-3_gipv_principle_ico02.png) no-repeat
 center/contain; content: ""; } 
.floor-top em::after { position: absolute; top: -25px; right: 10px; width: 34px; height: 33px; background: url(../images/contents/2-3_gipv_principle_ico02-2.png) no-repeat
 center/contain; content: ""; } 
.floor-desc { max-width: 400px; } 
.floor-desc::before { display: inline-block; height: 40px; margin: 20px 0 10px; border-left: 3px dashed #000; content: ""; } 
.floor-desc h6 { font-size: 22px; color: #222; } 
.floor-desc b { font-weight: 700; font-size: 35px; color: #21ad93; display: block; } 
.floor-desc p { font-weight: 500; font-size: 17px; } 
.floor-bottom h5 span { background-color: #ee7b00; } 
.floor-bottom h5 span::before { animation-delay: 1.5s; } 
.floor-bottom em { font-size: 33px; line-height: 54px; } 
.floor-bottom em::before { background-image: url(../images/contents/2-3_gipv_principle_ico03.png); } 
.floor-bottom em,
.floor-bottom .floor-desc b { color: #ee7b00; } 

.gipv-benefit h4 { margin-bottom: 30px; font-weight: 700; font-size: 30px; color: #000; } 
.gipv-benefit h4 br { display: none; } 
.gipv-benefit-list { display: flex; } 
.gipv-benefit-item { width: 20%; padding: 45px 15px; background-color: #75c4b5; color: #fff; } 
.gipv-benefit-item:nth-child(2) { background-color: #58b9a6; } 
.gipv-benefit-item:nth-child(3) { background-color: #21ad93; } 
.gipv-benefit-item:nth-child(4) { background-color: #1c977c; } 
.gipv-benefit-item:nth-child(5) { background-color: #0a7c65; } 
.gipv-benefit-box { position: relative; height: 100%; padding-bottom: 140px; margin: 0 auto; } 
.gipv-benefit-box h5 { height: calc(20% + 25px); margin-bottom: 30px; border-bottom: 1px solid rgba(255, 255, 255, 0.25); font-weight: 600; font-size: 20px; line-height: 1.2; } 
.gipv-benefit-box p { font-weight: 500; } 
.gipv-benefit-box::after { position: absolute; right: 0; bottom: 0; width: 96px; height: 96px; background: url(../images/contents/2-3_gipv_benefit_ico01.png) no-repeat
 center/contain; content: ""; } 
.gipv-benefit-item:nth-child(2) .gipv-benefit-box::after { background-image: url(../images/contents/2-3_gipv_benefit_ico02.png); } 
.gipv-benefit-item:nth-child(3) .gipv-benefit-box::after { background-image: url(../images/contents/2-3_gipv_benefit_ico03.png); } 
.gipv-benefit-item:nth-child(4) .gipv-benefit-box::after { background-image: url(../images/contents/2-3_gipv_benefit_ico04.png); } 
.gipv-benefit-item:nth-child(5) .gipv-benefit-box::after { background-image: url(../images/contents/2-3_gipv_benefit_ico05.png); } 

.gipv-case-wrap { display: grid; grid-template-columns: repeat(3, 1fr); justify-content: space-between; gap: 3vmax; } 
.gipv-case-wrap li:first-child { grid-column: 1 / 3; } 
.gipv-case-wrap li { overflow: hidden; border-top-right-radius: 70px; } 
.gipv-case-wrap li img { display: block; } 

@media (max-width: 1280px){
 .gipv section + section { margin-top: 100px; } 
 .gipv-tit-box { padding: 30px; } 
 .gipv-tit-box span { font-size: 26px; } 
 .gipv-tit-box em { padding-top: 8px; margin-top: 8px; font-size: 20px; } 

 .gipv-intro-desc { font-size: 20px; } 

 .gipv-principle { background-size: 27vw; } 
 .gipv-principle::before { width: 24vw; } 
 .gipv-principle .inner { padding: 50px 0 160px; } 
 .gipv-principle-img { row-gap: 15px; font-weight: 700; } 
 .gipv-principle-sun { width: 120px; height: 120px; padding-top: 5px; font-size: 16px; } 
 .gipv-principle-percent h5 { font-size: 20px; } 
 .gipv-principle-percent em { font-size: 31px; } 
 .gipv-principle-floor { width: calc(100% - 120px); padding-top: 60px; } 
 .gipv-principle-floor::before { height: 50px; } 
 .gipv-principle-floor h5 span { padding: 10px 30px; font-size: 21px; } 
 .gipv-principle-floor h5 span::before { width: 200px; height: 200px; } 
 .gipv-principle-floor h5::after { height: 30px; margin: 12px 0 0; } 
 .gipv-principle-floor em { font-size: 20px; } 
 .gipv-principle-floor em::before { margin: 8px auto; } 
 .floor-bottom em { font-size: 29px; line-height: 48px; } 
 .floor-desc { padding: 0 10px; } 
 .floor-desc::before { height: 30px; margin: 12px 0 2px; } 
 .floor-desc h6 { font-size: 20px; } 
 .floor-desc b { font-size: 31px; } 
 .floor-desc p { font-size: 16px; } 

 .gipv-benefit h4 { margin-bottom: 27px; font-size: 26px; } 
 .gipv-benefit-list { flex-direction: column; } 

 .gipv-benefit-item { padding: 40px 15px; } 

 .gipv-benefit-item { width: 100%; padding: 40px 3vw; } 
 .gipv-benefit-box { display: flex; align-items: center; padding: 0; } 
 .gipv-benefit-box h5 { width: 20%; min-width: 210px; flex-shrink: 0; padding: 0 20px 0 0; margin: 0; border-right: 1px solid rgba(255, 255, 255, 0.25); border-bottom-width: 0; text-align: center; } 
 .gipv-benefit-box p { padding: 0 15px; } 
 .gipv-benefit-box::after { flex-shrink: 0; position: relative; margin-left: auto; } 
 }
@media (max-width: 1024px){
 .gipv-principle { background-size: 30vw; background-image: url(../images/contents/2-3_gipv_principle_bg01_mo.png); } 
 .gipv-principle::before { width: 27vw; } 

 .gipv-benefit-item { padding: 40px 2vw; } 

 .gipv-case-wrap { grid-template-columns: repeat(2, 1fr); } 
 .gipv-case-wrap li:first-child { grid-column: 1 / 3; } 
 }
@media (max-width: 768px){
 .gipv section + section { margin-top: 80px; } 

 .gipv-tit-box { left: 50%; padding: 20px 25px; transform: translateX(-50%); white-space: nowrap; } 
 .gipv-tit-box br { display: none; } 
 .gipv-tit-box span { font-size: 22px; } 
 .gipv-tit-box em { padding-top: 6px; margin-top: 6px; font-size: 16px; } 

 .gipv-intro-desc { font-size: 18px; } 

 .gipv-principle { background-size: 220px; } 
 .gipv-principle::before { width: 200px; } 
 .gipv-principle .inner { padding: 130px 0 150px; } 
 .gipv-principle-img { row-gap: 12px; } 
 .gipv-principle-sun { width: 120px; height: 120px; font-weight: 500; font-size: 15px; } 
 .gipv-principle-percent h5 { font-size: 18px; } 
 .gipv-principle-percent em { font-size: 27px; } 
 .gipv-principle-floor { width: 100%; padding-top: 50px; } 
 .gipv-principle-floor::before { width: calc(50% + 2px); height: 40px; border-width: 2px; } 
 .gipv-principle-floor h5 span { padding: 10px 25px; font-weight: 500; font-size: 18px; } 
 .gipv-principle-floor h5 span::before { width: 160px; height: 160px; } 
 .gipv-principle-floor h5::after { height: 25px; margin-top: 10px; border-width: 2px; } 
 .gipv-principle-floor em { font-size: 18px; } 
 .gipv-principle-floor em::before { width: 64px; height: 64px; margin: 6px auto; } 
 .floor-top em::after { top: -12px; right: 20px; width: 22px; height: 21px; } 
 .floor-bottom em { font-size: 25px; line-height: 44px; } 
 .floor-desc::before { height: 25px; margin: 6px 0 0; border-width: 2px; } 
 .floor-desc h6 { font-size: 18px; } 
 .floor-desc b { font-size: 27px; } 
 .floor-desc p { font-size: 15px; } 

 .gipv-benefit h4 { margin-bottom: 24px; font-size: 22px; text-align: center; } 
 .gipv-benefit h4 br { display: block; line-height: 1.1; } 
 .gipv-benefit-item { padding: 35px 20px; } 
 .gipv-benefit-box { flex-direction: column; row-gap: 15px; text-align: center; } 
 .gipv-benefit-box h5 { width: auto; order: 2; min-width: 0; padding: 0; border-right: 0; font-size: 20px; } 
 .gipv-benefit-box h5::after { content: ""; width: 25vw; background-color: rgba(255, 255, 255, 0.25); height: 2px; display: block; margin: 15px auto 0; } 
 .gipv-benefit-box h5 br { display: none; } 
 .gipv-benefit-box p { order: 2; width: 100%; padding: 0; } 
 .gipv-benefit-box::after { order: 1; width: 64px; height: 64px; margin-left: 0; } 

 .gipv-case-wrap { gap: 2vmax; padding-top: 49px; } 
 .gipv-case-wrap li { border-top-right-radius: 50px; } 
 }
@media (max-width: 480px){
 .gipv section + section { margin-top: 70px; } 
 .gipv-tit-box { width: calc(100% + 40px); } 
 .gipv-tit-box span { font-size: 20px; } 
 .gipv-tit-box em { font-size: 15px; } 

 .gipv-intro-desc { font-size: 16px; } 

 .gipv-principle { background-size: 46vw; } 
 .gipv-principle::before { width: 43vw; } 
 .gipv-principle .inner { padding: 130px 0 30vw; } 
 .gipv-principle-floor { flex-direction: column; row-gap: 30px; width: 100%; padding-top: 40px; } 
 .gipv-principle-floor::before { width: 0; height: 30px; border-width: 0; border-left-width: 2px; border-radius: 0; } 
 .gipv-principle-floor li { width: 100%; } 
 .floor-desc { padding: 0; } 

 .gipv-case-wrap { grid-template-columns: 1fr; } 
 .gipv-case-wrap li { height: calc(65vw); } 
 .gipv-case-wrap li:first-child { grid-column: auto; } 
 .gipv-case-wrap li img { width: 100%; height: 100%; object-fit: cover; } 
 }
/* ===== 2-3_GIPV : E ===== */

/* ===== 2-4_MIPV : S ===== */
.mipv { text-align: center; } 
.mipv section + section { margin-top: 120px; } 
.mipv-tit { display: inline-block; padding: 35px; margin-bottom: 60px; background-color: #000; font-weight: 700; font-size: 32px; color: #fff; } 
.mipv-tit strong { color: #21ad93; } 
.mipv-tit br { display: none; } 
.mipv-list li { font-weight: 700; font-size: 18px; color: #222; } 
.mipv-list li + li { margin-top: 15px; } 
.mipv-list li::before { display: inline-block; width: 22px; height: 22px; margin-right: 10px; background: url(../images/contents/2-4_mipv_list-ico.svg) no-repeat
 center/contain; content: ""; vertical-align: text-bottom; } 

.mipv-intro-tit { font-weight: 500; font-size: 25px; margin-bottom: 0.5em; } 
.mipv-intro-tit strong { font-weight: 700; color: #222; } 
.mipv-intro-tit br { display: none; } 
.mipv-intro-tit em { font-weight: 700; color: #21ad93; } 
.mipv-intro-desc { max-width: 1000px; margin: 0 auto; font-weight: 500; font-size: 20px; color: #666; } 

.mipv-effect { padding-bottom: 60px; background-color: #edf6f8; } 
.mipv-effect-point { display: flex; justify-content: center; column-gap: 5%; padding-top: 70px; margin-bottom: 30px; font-weight: 700; } 
.mipv-effect-ico { margin-bottom: 15px; } 
.mipv-effect-item { width: 300px; } 
.mipv-effect-item h5 { display: inline-block; padding-bottom: 5px; margin-bottom: 10px; border-bottom: 2px solid #ec5e00; font-size: 25px; letter-spacing: -0.04em; color: #ec5e00; } 
.mipv-effect-item p { font-size: 19px; color: #222; line-height: 1.1; } 
.mipv-effect-end { font-weight: 700; font-size: 45px; letter-spacing: -0.04em; color: #22b28e; } 
.mipv-effect-end figure { width: 140px; height: 135px; margin: 0 auto 20px; } 
.mipv-effect-end figure img { width: 100%; height: 100%; object-fit: contain; } 
.mipv-effect-end span { color: #ec5e00; } 

.mipv-commerce-table { display: grid; grid-template-columns: repeat(3, 1fr); grid-auto-flow: column; padding-top: 70px; font-size: 17px; text-align: center; } 
.mipv-commerce-table dt,
.mipv-commerce-table dd { padding: 15px 10px; } 
.mipv-commerce-table dt { background-color: #21ad93; font-weight: 700; color: #fff; } 
.mipv-commerce-table dd { border-bottom: 1px solid rgba(191, 206, 203, 0.5); font-weight: 500; } 
.mipv-normal { grid-column: 1; } 
.mipv-cold { grid-column: 2; border-left: 1px solid rgba(191, 206, 203, 0.5); } 
.mipv-trailer { grid-column: 3; border-left: 1px solid rgba(191, 206, 203, 0.5); } 

.mipv-tit-box { position: absolute; top: 0; left: 0; padding: 55px; background-color: #000; text-align: center; } 
.mipv-tit-box span { font-weight: 700; font-size: 40px; line-height: 1.1; color: #fff; } 
.mipv-tit-box em { display: block; padding-top: 10px; margin-top: 10px; border-top: 1px solid rgba(255, 255, 255, 0.25); font-weight: 700; font-size: 27px; color: #21ad93; } 

.mipv-case-wrap { display: grid; grid-template-columns: repeat(3, 1fr); justify-content: space-between; gap: 3vmax; } 
.mipv-case-wrap li:first-child { grid-column: 1 / 3; } 
.mipv-case-wrap li { overflow: hidden; border-top-right-radius: 70px; } 
.mipv-case-wrap li img { display: block; } 

@media (max-width: 1280px){
 .mipv-tit-box { padding: 40px; } 
 .mipv-tit-box span { font-size: 32px; } 
 .mipv-tit-box em { padding-top: 8px; margin-top: 8px; font-size: 22px; } 

 .mipv section + section { margin-top: 100px; } 
 .mipv-tit { padding: 30px; margin-bottom: 50px; font-size: 28px; } 
 .mipv-list li { font-size: 17px; } 
 .mipv-list li + li { margin-top: 14px; } 

 .mipv-intro-tit { margin-bottom: 10px; font-size: 22px; } 
 .mipv-intro-tit br { display: block; } 
 .mipv-intro-desc { max-width: 900px; font-size: 18px; } 

 .mipv-effect { padding-bottom: 50px; } 
 .mipv-effect-point { column-gap: 6%; padding-top: 60px; } 
 .mipv-effect-item h5 { padding-bottom: 4px; margin-bottom: 9px; font-size: 20px; } 
 .mipv-effect-item p { font-size: 17px; } 
 .mipv-effect-end { font-size: 39px; } 
 .mipv-effect-end figure { height: 105px; } 

 .mipv-commerce-table { padding-top: 60px; font-size: 16px; } 
 }
@media (max-width: 1024px){
 .mipv-effect-point { column-gap: 3%; } 
 .mipv-effect-item { width: 30%; } 
 .mipv-tit br { display: block; } 

 .mipv-case-wrap { grid-template-columns: repeat(2, 1fr); } 
 .mipv-case-wrap li:first-child { grid-column: 1 / 3; } 
 }
@media (max-width: 768px){
 .mipv-tit-box { padding: 25px; } 
 .mipv-tit-box span { font-size: 24px; } 
 .mipv-tit-box em { padding-top: 6px; margin-top: 6px; font-size: 17px; } 

 .mipv section + section { margin-top: 80px; } 
 .mipv-tit { padding: 30px 25px; margin-bottom: 45px; font-size: 22px; } 
 .mipv-list li { font-weight: 500; font-size: 16px; } 
 .mipv-list li + li { margin-top: 13px; } 
 .mipv-list li::before { width: 16px; height: 16px; margin-right: 8px; vertical-align: text-top; } 

 .mipv-intro-tit { font-size: 19px; } 
 .mipv-intro-tit br { display: none; } 
 .mipv-intro-desc { font-size: 16px; } 

 .mipv-effect { padding-bottom: 40px; } 
 .mipv-effect-point { justify-content: space-between; column-gap: 3%; padding-top: 50px; margin-bottom: 25px; } 
 .mipv-effect-ico { margin-bottom: 10px; } 
 .mipv-effect-item { width: 33%; } 
 .mipv-effect-item h5 { padding-bottom: 3px; margin-bottom: 8px; border-bottom: 1px solid #ec5e00; font-size: 2.7vw; } 
 .mipv-effect-item p { font-size: 15px; } 
 .mipv-effect-end { font-size: 33px; } 
 .mipv-effect-end figure { height: 75px; } 

 .mipv-commerce-table { padding-top: 50px; font-size: 15px; } 
 .mipv-commerce-table dt,
 .mipv-commerce-table dd { padding: 12px 5px; } 
 .mipv-commerce-table dt { font-weight: 500; } 
 .mipv-commerce-table dd { font-weight: 400; } 

 .mipv-case-wrap { gap: 2vmax; } 
 .mipv-case-wrap li { border-top-right-radius: 50px; } 
 }
@media (max-width: 640px){
 .mipv-commerce-table { display: block; } 
 .mipv-cold,
 .mipv-trailer { border-left-width: 0; } 

 .mipv-effect-point { flex-direction: column; row-gap: 25px; align-items: center; } 

 .mipv-effect-item { width: auto; } 
 .mipv-effect-ico { height: 160px; } 
 .mipv-effect-item h5 { font-size: 18px; } 
 .mipv-effect-ico img { object-fit: contain; height: 100%; } 
 .mipv-effect-end { font-size: 5vw; } 
 }
@media (max-width: 480px){
 .mipv-tit-box { left: 50%; padding: 20px 25px; transform: translateX(-50%); } 
 .mipv-tit-box span { font-size: 20px; } 
 .mipv-tit-box span br { display: none; } 
 .mipv-tit-box em { font-size: 15px; } 

 .mipv section + section { margin-top: 70px; } 
 .mipv-tit { width: 100%; padding: 25px 15px; font-size: 20px; } 
 .mipv-tit br { display: none; } 
 .mipv-list li { font-size: 14px; } 
 .mipv-list li::before { margin-right: 6px; } 
 .mipv-intro-tit { font-size: 16px; } 
 .mipv-intro-desc { font-size: 14px; } 
 .mipv-effect-point { column-gap: 2%; } 
 .mipv-effect-item p { font-weight: 500; font-size: 14px; } 
 .mipv-commerce-table { font-size: 14px; } 
 .mipv-commerce-table dt,
 .mipv-commerce-table dd { padding: 10px 4px; } 

 .mipv-case-wrap { grid-template-columns: 1fr; padding-top: 49px; } 
 .mipv-case-wrap li { height: calc(65vw); } 
 .mipv-case-wrap li:first-child { grid-column: auto; } 
 .mipv-case-wrap li img { width: 100%; height: 100%; object-fit: cover; } 
 }
/* ===== 2-4_MIPV : E ===== */

/* ===== 3-1_R&D : S ===== */
.rnd-txt-color { color: #21ad93; } 
.rnd-sub-color { color: #8ad420; } 
.rnd-tit { display: inline-block; padding: 8px 35px; margin-bottom: 25px; border-radius: 0 20px 20px; background-color: #222; font-weight: 700; color: #fff; } 
.rnd-intro { display: flex; margin-bottom: 50px; } 
.rnd-intro::before { width: 50%; background: url(../images/contents/3-1_rnd_img01.svg) no-repeat center
 bottom/contain; content: ""; } 
.rnd-intro-txt { width: 50%; } 
.rnd-slogan { font-weight: 300; font-size: 34px; line-height: 1.4; letter-spacing: 0.2em; color: #222; } 
.rnd-slogan span { font-weight: 700; } 

.rnd-contents { padding-bottom: 180px; background: url(../images/contents/3-1_rnd_bg.jpg) center bottom no-repeat; } 
.rnd-contents .inner { display: grid; grid-template-columns: 50% 50%; row-gap: 100px; } 
.rnd-contents .inner::before { background: #fff url(../images/contents/3-1_rnd_img02.svg) no-repeat center; content: ""; } 
.rnd-desc { position: relative; padding: 70px 40px 70px 0; background-color: #fff; font-weight: 500; font-size: 17px; line-height: 1.4; color: #222; } 
.rnd-desc .rnd-txt-color { font-weight: 600; } 
.rnd-desc::before { position: absolute; top: 0; left: 0; width: calc(100% - 40px); height: 1px; background-color: #e4e4e4; content: ""; } 
.rnd-list { grid-column: 2 / 3; } 
.rnd-list li { display: flex; padding: 30px 25px; border-radius: 0 20px 20px; background-color: #fff; font-weight: 500; font-size: 17px; } 
.rnd-list li + li { margin-top: 18px; } 
.rnd-list li:before { flex-shrink: 0; width: 4px; height: 4px; margin: 9px; background-color: #000; content: ""; } 
.rnd-list ul ul{margin-top:10px;}
.rnd-list li li{display: flex;padding:0px;background-color: #fff;font-weight: 500;font-size: 16px; margin-top:6px; margin-left:-10px;} 
.rnd-list li li:before { flex-shrink: 0; width: 4px; height:2px; margin: 9px; background-color: #5c5a5a; content: ""; } 

@media (max-width: 1280px){
 .rnd-tit { padding: 7px 30px; margin-bottom: 23px; font-size: 15px; } 
 .rnd-intro { margin-bottom: 40px; } 
 .rnd-intro::before { width: 45%; background-size: 90% 90%; } 
 .rnd-intro-txt { width: 55%; } 
 .rnd-slogan { font-size: 2.8vw; } 

 .rnd-contents { padding-bottom: 160px; } 
 .rnd-contents .inner { grid-template-columns: 45% 55%; row-gap: 80px; } 
 .rnd-desc { padding: 50px 25px 50px 0; font-size: 15px; line-height: 1.3; } 
 .rnd-desc::before { width: calc(100% - 25px); } 
 .rnd-list li { padding: 25px 20px; border-radius: 0 15px 15px; font-weight: 400; font-size: 15px; } 
 .rnd-list li + li { margin-top: 17px; } 
 .rnd-list li:before { margin: 8px; } 
 }
@media (max-width: 1024px){
 .rnd-tit { padding: 7px 25px; margin-bottom: 21px; } 
 .rnd-intro { margin-bottom: 30px; } 
 .rnd-intro::before { width: 40%; background-size: 85%; } 
 .rnd-intro-txt { width: 60%; } 
 .rnd-slogan { font-size: 3vw; } 

 .rnd-contents { background-size: cover; } 
 .rnd-contents .inner { grid-template-columns: 40% 60%; row-gap: 65px; } 
 .rnd-contents .inner::before { background-position: center 30%; background-size: 60%; } 

 .rnd-desc { padding: 35px 20px 35px 0; } 
 }
@media (max-width: 768px){
 .rnd-intro { display: grid; grid-template-columns: 40% 60%; column-gap: 3vw; } 
 .rnd-intro::before { width: auto; height: auto; min-height: 100px; background-size: contain; } 
 .rnd-intro::after { height: 81px; background: #fff url(../images/contents/3-1_rnd_img02.svg) no-repeat
 center/60%; content: ""; } 
 .rnd-intro-txt { grid-column: 2 / 3; grid-row: 1 / 3; width: auto; } 
 .rnd-slogan { font-size: 4.5vw; } 
 .rnd-slogan b { display: block; } 

 .rnd-contents .inner { display: block; } 
 .rnd-contents .inner::before { display: none; } 
 .rnd-desc { padding: 30px 20px; margin-bottom: 35px; font-size: 14px; } 
 .rnd-desc::before { left: 20px; width: calc(100% - 40px); } 

 .rnd-list li { padding: 20px 10px; font-size: 14px; } 
 .rnd-list li + li { margin-top: 16px; } 
 .rnd-list li li{  font-size: 14px;  margin-top: 5px; } 
 .rnd-list li:before { margin: 7px; } 
 }
@media (max-width: 576px){
 .rnd-tit { padding: 6px 20px; margin-bottom: 19px; } 
 .rnd-intro { grid-template-columns: 1fr; margin-bottom: 5px; } 
 .rnd-intro::before { grid-row: 2 / 3; min-height: 100px; background-size: contain; } 
 .rnd-intro::after { grid-row: 3 / 4; background-size: 150px 41px; } 
 .rnd-intro-txt { grid-column: auto; grid-row: auto; padding-bottom: 30px; } 
 .rnd-slogan { font-size: 5vw; } 
 .rnd-slogan b { display: inline; } 

 .rnd-desc { padding: 25px 15px; } 
 .rnd-desc::before { left: 15px; width: calc(100% - 30px); } 
 }
@media (max-width: 480px){
 .rnd-slogan { font-size: 7vw; line-height: 1.3; } 
 .rnd-slogan b { display: block; } 
 }
/* ===== 3-1_R&D : E ===== */

/* ===== 4-2_프로세스 : S ===== */
.process-item { display: flex; flex-wrap: wrap; max-width: 700px; margin: 0 auto 10px; } 
.process-item:last-child { margin-bottom: 180px; } 
.process-arrow { display: block; width: 100%; } 
.process-arrow::before { display: block; width: 35px; height: 35px; margin: 30px auto; border-right: 4px dotted #130c0e; border-bottom: 4px dotted #130c0e; content: ""; transform: rotate(45deg); } 

.process-img { display: flex; flex-shrink: 0; justify-content: center; align-items: center; position: relative; width: 175px; min-height: 175px; padding-right: 6px; border: 6px solid #dfe5e4; border-right: 0; border-radius: 6px; } 
.process-img::before { position: absolute; top: -3px; right: 0; width: 6px; height: calc(100% - 10px); border-radius: 6px; background-color: #dfe5e4; content: ""; } 

.process-txt { display: flex; flex-direction: column; justify-content: center; position: relative; width: calc(100% - 165px); padding: 25px 7% 25px 11%; margin: 18px 0 0 -10px; border: 6px solid #dfe5e4; border-top: 0; border-left: 0; border-radius: 6px; } 
.process-txt::before { position: absolute; top: 0; right: -3px; width: calc(100% - 20px); height: 6px; border-radius: 6px; background-color: #dfe5e4; content: ""; } 
.process-txt h4 { margin-bottom: 5px; font-weight: 700; font-size: 25px; color: #21ad93; } 
.process-txt h4 span { display: inline-block; width: 34px; height: 34px; padding-left: 5px; border-radius: 50%; background-color: #000; font-size: 35px; line-height: 1.28; text-align: center; vertical-align: text-bottom; color: #fff; } 
.process-txt p { font-weight: 500; font-size: 17px; line-height: 1.5; } 

.process-item:first-child .process-img,
.process-item:first-child .process-txt,
.process-item:last-child .process-img,
.process-item:last-child .process-txt { border-color: #21ad93; } 
.process-item:first-child .process-img::before,
.process-item:first-child .process-txt::before,
.process-item:last-child .process-img::before,
.process-item:last-child .process-txt::before { background-color: #21ad93; } 

@media (max-width: 1280px){
 .process-item:last-child { margin-bottom: 160px; } 
 }
@media (max-width: 768px){
 .process-item:last-child { margin-bottom: 140px; } 
 .process-item { margin: 0 auto 5px; } 
 .process-arrow::before { margin: 25px auto; } 

 .process-img { width: 150px; min-height: 150px; padding-right: 4px; border: 4px solid #dfe5e4; border-right: 0; border-radius: 4px; } 
 .process-img::before { top: -1px; width: 4px; height: calc(100% - 10px); border-radius: 4px; } 

 .process-txt { width: calc(100% - 140px); padding: 20px 5% 20px 8%; margin: 18px 0 0 -10px; border: 4px solid #dfe5e4; border-top: 0; border-left: 0; border-radius: 4px; } 
 .process-txt::before { right: -1px; height: 4px; border-radius: 4px; } 
 .process-txt h4 { font-size: 21px; } 
 .process-txt h4 span { width: 30px; height: 30px; padding-left: 4px; font-size: 30px; line-height: 1.32; } 
 .process-txt p { font-size: 15px; line-height: 1.4; } 
 }
@media (max-width: 576px){
 .process-item { flex-direction: column; max-width: 400px; text-align: center; } 
 .process-arrow::before { margin: 20px auto 30px; } 
 .process-img { width: 100%; min-height: 100px; border-bottom: 0; } 
 .process-img::before { height: calc(100% - 15px); } 
 .process-txt { width: 100%; padding: 25px 10px 30px; margin: -5px 0 0 0; border-left: 4px solid #dfe5e4; } 
 .process-txt::before { width: calc(100% - 15px); } 
 }
@media (max-width: 412px){
 .process-txt h4 { font-size: 18px; } 
 }
/* ===== 4-2_프로세스 : E ===== */

/* ===== 5-2_협력사 : S ===== */
.customer-wrap .customer-list { display: grid; grid-template-columns: repeat(4, 1fr); row-gap: 3vw; column-gap: 3%; } 
.customer-wrap .list-item { transition: all 0.3s ease-in-out; } 
.customer-wrap .list-item a:first-child { display: flex; justify-content: center; align-items: center; height: 10vw; padding: 10px; border: 1px solid #e4e4e4; transition: all 0.3s ease-in-out; } 
.customer-wrap .list-item a.m_btn { display: block; padding: 5px; margin-top: 10px; background: #eee; font-size: 18px; text-align: center; color: #222; } 
.customer-wrap .list-item a.m_btn:hover { background: #21ad93; color: #fff; } 
.customer-wrap .list-item .admin-check { margin-top: 5px; text-align: center; } 
.customer-wrap .list-item:hover { transform: translateY(-8px); } 
.customer-wrap .list-item:hover a { border: 0; box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); } 
.customer-wrap .btn { vertical-align: top; } 
.customer-wrap .btn span { line-height: 60px; vertical-align: baseline; } 

@media only screen and (max-width: 1280px){
 .customer-wrap .customer-list { column-gap: 2%; } 
 .customer-wrap .list-item a.m_btn { font-size: 16px; } 
 }
@media only screen and (max-width: 1024px){
 .customer-wrap .customer-list { grid-template-columns: repeat(3, 1fr); column-gap: 2%; } 
 .customer-wrap .list-item a:first-child { height: 14vw; } 
 }
@media only screen and (max-width: 640px){
 .customer-wrap .customer-list { grid-template-columns: repeat(2, 1fr); row-gap: 4vw; column-gap: 4%; } 
 .customer-wrap .list-item a:first-child { height: 20vw; } 
 }
@media only screen and (max-width: 480px){
 .customer-wrap .customer-list { column-gap: 2%; } 
 }
/* ===== 5-2_협력사 : E ===== */

/* ===== 5-4_add : E ===== */
.add > ul { display: flex; flex-wrap: wrap; gap: 100px 50px; margin-bottom: 180px; } 

.add > ul > li { width: calc((100% - 50px) / 2); border-radius: 10px; border: 1px solid #ccc; padding: 30px; position: relative; } 

.add > ul > li > img { position: absolute; top: 30px; right: 30px; max-width: 30%; height: auto; } 

.line02 { position: absolute; left: 30px; } 

.line02 > p { padding: 10px 20px; border-radius: 5px; background: rgba(33, 173, 147, 0.8); text-align: center; font-size: 18px; font-weight: 600; color: #fff; } 

.line03 { margin-top: 90px; height: 6rem; /* outline: 1px solid black; */}

.line03 > p { color: #222; font-size: 20px; font-weight: 700; } 

.line03 > p:nth-child(2) { margin-top: 5px; } 

.line03 > p:last-child { color: #21ad93; font-size: 16px; font-weight: 500; line-height: 25px; } 

.line04 { border: 1px solid #eeeeee; } 

.line05 { display: flex; justify-content: space-between; margin-top: 30px; /* outline: 1px solid black; */}

.line05 > p,
.call { color: #21ad93; font-size: 16px; font-weight: 500; line-height: 25px; /* 156.25% */
 letter-spacing: 0.5px; } 

.Ellipse { position: relative; width: 68px; height: 68px; background-color: #f2f2f2; border-radius: 500px; transition: 0.3s; flex: 0 0 auto; } 

.Ellipse > img { position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%); } 

.Ellipse:hover { background-color: #21ad93; } 

.black,
.white { transition: 0.3s; } 

.Ellipse img:last-child,
.Ellipse:hover .black { opacity: 0; } 

.Ellipse:hover .white { opacity: 1; } 

@media (max-width: 1024px){
 .line02 > p { font-size: 16px; padding: 10px 15px; } 

 .line04 { margin-top: 50px; } 
 }

@media (max-width: 768px){
 .add > ul > li { width: 100%; } 

 .add > ul { gap: 50px 50px; } 

 .line03 { height: 6rem; } 

 .line03 > p { font-size: 18px; } 

 .line03 > p:last-child,
 .line05 > p,
 .call { font-size: 14px; } 

 .line04 { margin-top: 0; } 

 .Ellipse { width: 58px; height: 58px; } 
 }

@media (max-width: 480px){
 .add > ul { margin-bottom: 80px; } 

 .line02 > p { font-size: 14px; padding: 5px 7.5px; } 

 .line03 { margin-top: 70px; } 

 .line03 > p { font-size: 16px; } 

 .line03 > p:last-child { line-height: 16px; } 
 }
/* ===== 5-4_add : E ===== */

/* 솔타일 카테고리명 추가 */
#bipv02 .bipv-slick .slick-slide { display: flex; flex-direction: column; align-items: center; } 
#bipv02 .bipv-slick p { font-size: 20px; font-weight: 600; color: #21ad93; } 
.bipv-spec > p { color: red; font-weight: 600; padding-top: 20px; } 


/* 제품 - ess추가 */
.ess-item { position: relative; } 
.ess-info { display: flex; flex-direction: column; } 
.ess-feature { width: 100%; display: flex; justify-content: space-between; align-items: flex-end; column-gap: 30px; } 
.ess-feature p { font-weight: 500; font-size: 17px; color: #666; line-height: 1.65; } 
.ess-feature p b { color: #222; font-weight: 600; } 
.ess-feature-wrap ul { margin: 30px 0; } 
.ess-feature-wrap ul li { font-weight: 600; } 
.ess-catalogue a { padding: 25px 50px 25px 25px; font-size: 18px; background-color: #0aac8d; color: #fff; font-weight: 600; transition: .3s; display: inline-block; width: 100%; } 
.ess-catalogue a span { padding-right: 10px; } 
.ess-catalogue a:after { position: absolute; content: ""; width: 24px; height: 24px; background: url(../images/common/open_in_new.svg) no-repeat; } 
.ess-catalogue a:hover { background-color: #0a7c65; } 

@media (max-width: 1200px) {.ess-feature { flex-direction: column; align-items: flex-start; } 
.ess-catalogue { margin-bottom: 0; margin-top: 60px; } 
.ess-feature p { font-size: 16px; } 
 }
 @media (max-width: 768px){
 .ess-catalogue a { font-size: 16px; } 
.ess-catalogue a:after { width: 20px; height: 20px; background-size: contain; } 
 }
 
 /*bipv 제품다운로드 버튼*/
.bipv-spec_download{padding:10px 30px;background:#f9f9f9;display:flex;justify-content:space-between;align-items:center; border-bottom:1px solid #dadada;}
.bipv-spec_download.mt20{margin-top:40px;}
.bipv-spec_download span{font-weight:600;}
.bipv-spec_download a{background:#21ad93; font-weight:600; color:#fff; height:40px;  line-height:40px;display:inline-block; padding:0 20px;}

@media (max-width: 576px){
.bipv-spec_download{flex-direction:column; justify-content:center;align-items:center; padding:20px 20px; }
.bipv-spec_download a{margin-top:10px;}
}