@charset "utf-8";
.table-wrap table {width: 100%; border-collapse: collapse; border-spacing: 0; text-align: center;}
.table-wrap thead th {border-right: 1px solid #ddd; border-bottom: 1px solid #ddd; border-top: 1px solid var(--primary-color); padding: var(--space-15); font-size: var(--font-size-18); font-weight: 600; background: rgba(20, 109, 172, 0.08);;}
.table-wrap td {padding: var(--space-15); border-right: 1px solid #ddd; border-bottom: 1px solid #ddd;}
.table-wrap thead th:last-child ,.table-wrap td:last-child {border-right: 0;}
.btn-download {display: flex; gap: 10px; align-items: center; width: fit-content; padding: var(--space-15) var(--space-60); margin: 0 auto; border-radius: 100px; border: 1px solid var(--primary-color); font-size: var(--font-size-18); font-weight: 600; color: var(--primary-color); line-height: 1.6667em; border: 1px solid var(--primary-color);}
.btn-download:after {content: ''; display: block; width: 16px; height: 16px; background: url('/images/sub/download.svg') no-repeat center center / contain;}
.btn-download:hover {background: var(--primary-color); color: #fff;}
.btn-download:hover:after {filter: brightness(0) invert(1);}
.hyphen-list li {text-indent: -.3em; padding-left: 0.3em;}
.hyphen-list li:before {content: '-'; margin-right: 3px;}

.layout-body {position: relative; padding-top: clamp(140px, calc(200 / var(--inner) * 100vw), 200px);}
.layout-bg {width: fit-content; margin: 0 auto;}
.layout-shell {position: relative; padding: var(--space-70); border-radius: 100%; border: 1px solid rgba(20, 109, 172, 0.20); overflow: visible; animation: layout-orbit 8s linear infinite;}
.layout-shell:before {content: '●'; position: absolute; top: 0; left: 50%; width: 0; font-size: clamp(8px, calc(14 / var(--inner) * 100vw), 14px); color: var(--primary-color); line-height: 0;}
@keyframes layout-orbit {from {transform:rotate(0deg);} to {transform:rotate(360deg);}}
@keyframes layout-orbit-reverse {from {transform:rotate(1080deg);} to {transform:rotate(0deg);}}
.layout-shell .logo {animation: layout-orbit-reverse 8s linear infinite ; display: flex; align-items: center; justify-content: center; width: clamp(180px, calc(220 / var(--inner) * 100vw), 220px); height: clamp(180px, calc(220 / var(--inner) * 100vw), 220px); padding: var(--space-20); border-radius: 100%; background: linear-gradient(180deg, #1B7FC6 0%, #146DAC 100%);}
.layout-shell-boxes {max-width: 1020px; position: absolute; top: 0; left: 50%; transform: translateX(-50%); height: 100%; width: 100%;}
.layout-shell-box {position: absolute; max-width: 320px; width: 32%; padding: var(--space-30) var(--space-20); background: #fff; border-radius: var(--radius-16); border: 1px solid var(--primary-color); box-shadow: 0 20px 25px -5px rgba(0, 0, 0, 0.10), 0 8px 10px -6px rgba(0, 0, 0, 0.10);}
.layout-shell-box.box1 {top: 0; left: 50%; transform: translateX(-50%);}
.layout-shell-box.box2 {bottom: 0; left: 0;}
.layout-shell-box.box3 {bottom: 0; right: 0;}
.layout-shell-box .icon {width: max-content; margin-left: auto; margin-right: auto; padding: var(--space-25); border-radius: 100%; background: linear-gradient(180deg, #1B7FC6 0%, #146DAC 100%);}
.history-decade {padding-bottom: var(--space-120);}
.history-decade-bg { padding-top: var(--space-120); background: #F9F9F9; max-width: none;}
.history-era {display: flex; justify-content: space-between; gap: 25px 20px; align-items: flex-start;}
.era-tit {display: flex; gap: 8px; flex-shrink: 0;}
.era-tit .year {font-size: var(--font-size-64); font-weight: 700; color: var(--dark-color); line-height: 1em;}
.era-tit .unit {display: flex; align-items: flex-end; font-size: var(--font-size-40); font-weight: 700; color: #BDBDBD; line-height: 1.15em;}
.era-dot {width: clamp(5px, calc(10 / var(--inner) * 100vw), 10px); height: clamp(5px, calc(10 / var(--inner) * 100vw), 10px); background: var(--primary-color); border-radius: 9999px; flex-shrink: 0;}
.era-body {position: relative; display: flex; max-width: 730px; width: 61%;}
.era-line {position: absolute; top: 5px; left: calc(180px - calc(var(--space-30) / 2)); width: 1px; height: 100%; flex-shrink: 0; background: #DDDDDD; align-self: stretch;}
.history-list {flex: 1; display: flex; flex-direction: column; gap: var(--space-100);}
.history-item {display: flex; align-items: flex-start; gap: var(--space-50);}
.history-item .year-num {position: relative; display: flex; justify-content: space-between; align-items: center;width: 180px; flex-shrink: 0; font-size: var(--font-size-40); font-weight: 700; color: var(--dark-color); line-height: 1em;}
.history-item .year-num:after {content: ''; display: block; width: var(--space-30); height: var(--space-30); background: #fff; border: var(--space-10) solid var(--primary-color); border-radius: 9999px;}
.history-item .events {flex: 1; display: flex; flex-direction: column; gap: var(--space-20); min-width: 0; padding-top: .4em;}
.history-item .event {display: flex; line-height: 1.5em;}
.history-item .event .month {width: 66px; flex-shrink: 0; font-size: var(--font-size-20); font-weight: 700; color: #BDBDBD;}
.history-item .event .txt {font-size: var(--font-size-15); color: #454545;}
.partner-list {display: grid; grid-template-columns: repeat(5, 1fr); gap: var(--space-30) var(--space-20);}
.partner-img {position: relative; margin-bottom: var(--space-10); border-radius: var(--radius-16); overflow: hidden;}
.partner-img:after {content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; border-radius: var(--radius-16); border: 1px solid #ddd; z-index: 1;}
.growth-welcome-list li {margin-bottom: var(--space-40);}
.growth-welcome-list .num {display: flex; align-items: center; justify-content: center; width: clamp(26px, calc(34 / var(--inner) * 100vw), 34px); height: clamp(26px, calc(34 / var(--inner) * 100vw), 34px); margin-right: var(--space-20); border-radius:100%; background: var(--primary-color); color: #fff; font-size: var(--font-size-20); font-weight: 700; line-height: 1em;}
.growth-welcome-list p {padding-left: calc(var(--space-20) + clamp(26px, calc(34 / var(--inner) * 100vw), 34px));}
.growth-welcome-box {background: #F5F5F5; border-radius: var(--radius-16); padding: var(--space-80) 20px;}
.growth-system-boxes {display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-30);}
.growth-system-box {display: flex; flex-direction: column; gap: var(--space-30); justify-content: space-between; padding: var(--space-30) var(--space-40); background: #F5F5F5; border-radius: 8px;}
.recruit-gallery {position: relative; margin: 0 calc((clamp(48px, calc(68 / var(--inner) * 100vw), 68px) + var(--space-40)) * -1); padding: 0 calc(clamp(48px, calc(68 / var(--inner) * 100vw), 68px) + var(--space-40));}
.recruit-gallery .slick-arrow {display: flex; justify-content: center; align-items: center; position: absolute; top: 50%; width: clamp(48px, calc(68 / var(--inner) * 100vw), 68px); height: clamp(48px, calc(68 / var(--inner) * 100vw), 68px); background: #fff; border-radius: 100%; border: 1px solid #ddd; overflow: hidden; z-index: 1; text-indent: -9999em; transition: .2s;}
.recruit-gallery .slick-arrow:hover {background: var(--primary-color); border-color: var(--primary-color);}
.recruit-gallery .slick-arrow:hover:after {filter: brightness(0) invert(1);}
.recruit-gallery .slick-arrow:after {content: ''; display: block; width: 14px; height: 24px; background: url('/images/sub/recruit-gallery-arrow.png') no-repeat center center; text-indent: 0;}
.recruit-gallery .slick-arrow.slick-prev {left: 0;}
.recruit-gallery .slick-arrow.slick-next {right: 0;}
.recruit-gallery .slick-arrow.slick-next:after {transform: rotate(180deg);}
.recruit-gallery .slick-list {margin: 0 calc(var(--space-15) * -1);}
.recruit-gallery .slick-slide {padding: 0 var(--space-15);}
.recruit-gallery .item {position: relative; border-radius: var(--radius-16); overflow: hidden;}
.recruit-gallery .item:after {content: ''; position: absolute; top: 0; right: 0; bottom: 0; left: 0; border-radius: var(--radius-16); border: 1px solid #ddd; z-index: 1;}
.bocket-info {gap: 30px;}
.bocket-txt .qr-code {margin-top: var(--space-50); max-width: 300px;}
.bocket-img {width: 48%; max-width: 575px;}
.bocket-mobile-mockup {display: grid; grid-template-columns: repeat(6, 1fr); gap:clamp(1px, calc(30 / var(--inner) * 100vw), 30px);}
.bocket-mobile-boxes {display: grid; grid-template-columns: repeat(3, 1fr); gap:var(--space-30);}
.bocket-mobile-box {border: 1px solid #ddd; border-radius: 8px; padding: var(--space-40);}
.bocket-mobile-box .num {width: clamp(30px, calc(42 / var(--inner) * 100vw), 42px); height: clamp(30px, calc(42 / var(--inner) * 100vw), 42px); margin-right: 12px; border-radius: 100%; background: var(--primary-color);}
.db-boxes {display: grid; grid-template-columns: repeat(2, 1fr); gap:var(--space-50) var(--space-40);}
.db-box {gap: var(--space-30); padding: var(--space-40); border-radius: 8px; background: #F5F5F5;}
.sec-terms h3 {padding: var(--space-20); background: var(--primary-color);}
.terms-content {display: flex; flex-direction: column; gap: var(--space-80); color: #454545;}
.terms-box {padding: var(--space-50); max-height: 60vh; overflow-y: auto; border: 1px solid #ddd; border-top: 0;}
.terms-chapter {display: flex; flex-direction: column; gap: var(--space-50);}
.terms-chap-tit .tit {font-size: var(--font-size-18); font-weight: 700; line-height: 1.44em;}
.terms-chap-tit .date {font-size: var(--font-size-18); line-height: 1.44em;}
.terms-chap-line {height: 0; border-top: 1px solid #DDDDDD;}
.terms-articles {display: flex; flex-direction: column; gap: var(--space-40);}
.terms-article {display: flex; flex-direction: column; gap: var(--space-25);}
.terms-article .art-tit {font-size: var(--font-size-15); font-weight: 600; line-height: 1.625em;}
.terms-article .art-cont {font-size: var(--font-size-15); line-height: 1.5em;}
.consumer-guide-welcome {padding: var(--space-50); background: #FBFCFE; border: 1px solid var(--primary-color); border-radius: var(--radius-16);}
.consumer-guide-welcome .tit {gap: 12px;}
.consumer-guide-welcome .tit:before {content: ''; display: block; width: clamp(30px, calc(40 / var(--inner) * 100vw), 40px); height: clamp(30px, calc(40 / var(--inner) * 100vw), 40px); background: url('/images/sub/guide-welcome-icon.png') no-repeat center center / contain;}
.consumer-guide-welcome .wrap {padding-left: calc(clamp(30px, calc(40 / var(--inner) * 100vw), 40px) + 12px);}
.guide-contact-boxes {display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-30);}
.guide-contact-box {border: 1px solid #ddd; border-radius: var(--radius-16); padding: var(--space-50);}
.guide-contact-box .icon {width: fit-content; padding: var(--space-15); background: var(--primary-color); border-radius: 8px;}
.guide-contact-box .wrap {border-top: 1px solid #ddd; padding-top: var(--space-20); margin-top: var(--space-20);}
.guide-process-boxes {display: flex; flex-direction: column; gap: var(--space-20);}
.guide-process-item {padding: var(--space-50); background: #fff; border-radius: var(--radius-16); border: 1px solid #ddd; display: flex; flex-direction: column; gap: var(--space-20);}
.guide-process-head {display: flex; align-items: center; gap: var(--space-20);}
.guide-process-num {display: flex; align-items: center; justify-content: center; width: clamp(40px, calc(56 / var(--inner) * 100vw), 56px); height: clamp(40px, calc(56 / var(--inner) * 100vw), 56px); background: var(--primary-color); border-radius: 8px; color: #fff; font-size: var(--font-size-24); font-weight: 700; line-height: 1.33em; flex-shrink: 0;}
.guide-process-tit {font-size: var(--font-size-24); font-weight: 700; line-height: 1.33em; color: #454545;}
.guide-process-body {display: flex; flex-direction: column; gap: var(--space-40);}
.guide-process-desc {font-size: var(--font-size-18); line-height: 1.33em; color: #454545;}
.guide-process-sub {display: flex; flex-direction: column; gap: var(--space-20);}
.guide-process-sub-item {padding: var(--space-30); background: #F6F9FC; border-radius: 8px; border: 1px solid #FBFCFE; display: flex; flex-direction: column; gap: var(--space-10);}
.guide-process-sub-item.guide-process-sub-notice {background: #FBFBFB; border-color: transparent;}
.guide-process-sub-tit {font-size: var(--font-size-18); font-weight: 600; line-height: 1.33em; color: var(--primary-color);}
.guide-process-sub-cont {font-size: var(--font-size-15); line-height: 1.5em; color: #454545;}
.cusumer-report-box {background: #FBFBFB; padding: var(--space-40);}
.cusumer-report-box li {display: flex; gap: 5px var(--space-30);}
.cusumer-report-box li:not(:last-child) {margin-bottom: var(--space-10);}
.cusumer-report-box strong {width: 50px;}

.notice-cert-list {display: grid; grid-template-columns: repeat(2, 1fr); gap: clamp(20px, calc(90 / var(--inner) * 100vw), 90px); max-width: 750px; margin: 0 auto;}

.consumer-info-list {display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-30);}
.consumer-info-item {padding: var(--space-40); background: #fff; border-radius: var(--radius-16); border: 1px solid #ddd; display: flex; flex-direction: column; text-decoration: none; color: inherit; transition: box-shadow .2s, border-color .2s;}
.consumer-info-item:hover {border-color: var(--primary-color); box-shadow: 2px 2px 32px -12px rgba(0, 0, 0, 0.16);}
.consumer-info-inner {flex: 1; display: flex; flex-direction: column; justify-content: space-between; align-items: flex-start; gap: var(--space-25);}
.consumer-info-deco {width: clamp(40px, calc(56 / var(--inner) * 100vw), 56px); height: clamp(40px, calc(56 / var(--inner) * 100vw), 56px); padding: 5px; background: rgba(20, 109, 172, 0.08); border-radius: 100%; display: flex; align-items: center; justify-content: center;}
.consumer-info-item.on .consumer-info-deco {opacity: 0.12;}
.consumer-info-cont {display: flex; flex-direction: column; gap: var(--space-20); flex: 1;}
.consumer-info-tit {font-size: var(--font-size-24); font-weight: 600; line-height: 1.33em; color: #222;}
.consumer-info-desc {font-size: var(--font-size-18); line-height: 1.44em; color: #454545;}
.consumer-info-arrow {width: fit-content; padding: clamp(4px, calc(8 / var(--inner) * 100vw), 8px); margin-top: var(--space-25); border-radius: 100%; border: 1px solid #ddd; margin-left: auto;}
.consumer-info-item:hover .consumer-info-arrow {background: var(--primary-color); border-color: var(--primary-color);}
.consumer-info-arrow:after {content: '';display: block; width: 16px; height: 16px; background: url('/images/sub/consumer-info-arrow.png') no-repeat center center / contain;}
.consumer-info-item:hover .consumer-info-arrow:after {filter: brightness(0) invert(1);}




