 @charset "utf-8"; /* doc.css는 디자인페이지 스타일을 정의합니다. */
.root_daum_roughmap { width:100% !important; height:545px !important; border-radius: var(--border-radius-24); border: 0; } 
.root_daum_roughmap .wrap_map { width:100% !important; height:545px !important; border-radius: var(--border-radius-24); border: 0; } 
.roughmap_lebel_text:after { content:""; font-size:12px; line-height:15px; } 

.sub-tit { padding-bottom:var(--space-100); text-align:center; font-weight:600; font-size: var(--font-size-36); line-height:normal; letter-spacing: -0.04em; color: var(--color-dark); } 

.cnt-tit h3 { position:relative; padding-bottom:var(--space-40); margin-bottom:var(--space-40); font-size: var(--font-size-38); color: var(--color-dark); line-height:1.42em; letter-spacing: -0.04em; } 
.cnt-tit h3::after { content: ""; position: absolute; left:0; bottom:0; width: var(--space-50); height: 4px; background-color: rgb(36, 165, 162); } 
.cnt-tit.type2 h3 { padding-bottom:0; } 
.cnt-tit.type2 h3::after { display:none; } 
.reverse-list .cnt .txt.space-center .cnt-tit h3::after { left: 50%; transform: translateX(-50%); } 

.doc-tit { padding: var(--space-120) 0 var(--space-100); text-align:center; font-size:var(--font-size-48); line-height:1em; color:var(--color-dark); letter-spacing: -0.04em; } 

.doc-txt { padding-bottom:var(--space-90); text-align:center; font-size: var(--font-size-24); font-weight:500; line-height:1.58em; } 

.doc-cnt { padding:var(--header-height) 0; } 
.doc-cnt:first-child { padding-top:0; } 

.doc-sub-cnt { padding-bottom:var(--header-height) 0; } 
.doc-sub-cnt:last-child { padding-bottom:0; } 

.table-style table { width:100%; border-collapse:collapse; border-spacing:0px; border-top:1px solid #1f1f1f; line-height:1.5em; } 
.table-style table th { padding:13px; border:1px solid #ddd; border-top:0; font-weight:600; background:#fafafa; } 
.table-style table td { padding:13px; text-align:center; border:1px solid #ddd; border-top:0; color: #454545; } 
.table-style tr th:first-child,
.table-style tr td:first-child { border-left:0; } 
.table-style tr th:last-child,
.table-style tr td:last-child { border-right:0; } 
.table-style span { display:inline-block; } 
.table-style .normal { font-weight:400; } 

.flex-wrap { display:flex; } 
.flex-wrap.ai-center { align-items:center; } 
.flex-wrap .flex { flex: 1 1 auto; width:1%; min-width:0; } 

.dot-list > li { position:relative; padding-left:10px; } 
.dot-list > li:before { content:"·"; position:absolute; top:-2px; left:0; font-weight:700; font-size:20px; color:#242424; } 
.dot-list > li strong { font-weight:600; } 

.dash-list > li { position:relative; padding-left:10px; } 
.dash-list > li:before { content:"-"; position:absolute; top:-2px; left:0; font-weight:700; font-size:20px; color:#242424; } 
.dash-list > li strong { font-weight:600; } 
.dash-list.none > li { padding-left:0; } 
.dash-list.none > li::before { display: none; } 

.p0 { padding:0 !important; } 
.pt0 { padding-top:0 !important; } 
.pt100 { padding-top:var(--space-100) !important; } 
.pb0 { padding-bottom:0 !important; } 
.pb30 { padding-bottom:var(--space-30) !important; } 

.mb30 { margin-bottom:var(--space-30) !important; } 
.pt180 { padding-top:var(--space-180) !important; } 

.mt30 { margin:var(--space-30) 0 0 0 !important; } 

.txt-primary { color: var(--color-primary) !important; } 
.txt-second { color: var(--color-secondary) !important; } 
.txt-grey { color: #888888 !important; } 
.txt-wht { color: #fff !important; } 

.fs-42 { font-size: var(--font-size-42) !important; } 

.highlight { display: inline; box-shadow: inset 0 -14px 0 #f7f5fa; border-radius: 3px; } 

.tag { padding:7px 16px; font-weight:500; font-size: var(--font-size-18); letter-spacing: 0; line-height:1em; background-color: var(--color-second); border-radius: 50vh; color: #fff; width:fit-content; } 

.bg-grey { background-color: #f9f9f9; } 

/* 소개 */
.reverse-list .cnt { display:flex; align-items: center; margin-bottom:var(--space-140); } 
.reverse-list .cnt .img { width:45.714%; } 
.reverse-list .cnt .txt { flex: 1 1 auto; width:1%; min-width:0; padding-left:var(--space-130); } 
.reverse-list .cnt .txt p { font-size: var(--font-size-20); line-height:1.7em; letter-spacing: -0.06em; } 
.reverse-list .cnt .txt p:not(:last-child) { margin-bottom:var(--space-20); } 
.reverse-list .cnt:nth-child(even) { flex-direction: row-reverse; justify-content: space-between; } 
.reverse-list .cnt:nth-child(even) .txt { padding-left:0; padding-right:30px; } 
.reverse-list .cnt:last-child { margin-bottom:0; } 
.reverse-list.reverse .cnt { flex-direction: row-reverse; margin-bottom:0; } 
.reverse-list.reverse .cnt .txt { padding:0 var(--space-70) 0 var(--space-30) !important; } 
.reverse-list.type2 .cnt > div { width:50% !important; } 
.reverse-list.type2 .cnt .txt { padding-left: var(--space-80); } 

/* 연혁 */
.history-wrap { display:grid; grid-template-columns: repeat(3,1fr); gap: var(--space-70); } 
.history-wrap .col .wrap { position:relative; margin-top:var(--space-60); padding-top:var(--space-40); border-top:1px solid var(--color-primary); } 
.history-wrap .year { position: absolute; top: -20px; left: 0; z-index: 10; padding-right: var(--space-40); background: #fff; font-weight: 700; font-size: var(--font-size-42); color: var(--color-primary); line-height: 1em; } 
.history-wrap .col .wrap ul li { display: flex; } 
.history-wrap .col .wrap ul li:not(:last-child) { margin-bottom:10px; } 
.history-wrap .col .wrap ul li .day { position:relative; padding-left:20px; width: 100px; font-weight: 600; font-size: var(--font-size-18); color: var(--color-dark); } 
.history-wrap .col .wrap .day::before { content: ""; position: absolute; top:10px; left:0; width: 8px; height: 8px; border-radius: 100%; background-color: rgb(36, 165, 162); } 
.history-wrap .wrap .info { font-size: var(--font-size-18); line-height:1.56em; } 

.his-wrap {display:grid; gap:var(--space-70); font-size:var(--font-size-20); line-height:1.65em;}
.his-wrap h3 {display:flex; align-items:center; margin-bottom:var(--space-30); font-size:clamp(24px, calc(42 / var(--inner)* 100vw), 42px); color:var(--color-primary); line-height:1.3em;}
.his-wrap h3 span {min-width:clamp(160px, calc(318 / var(--inner)* 100vw), 318px);}
.his-wrap h3:after {content:''; display:block; width:100%; height:1px; background:var(--color-primary);}
.his-wrap ul {display:grid; gap:var(--space-10);}
.his-wrap ul li {position:relative; padding-left:clamp(14px, calc(28 / var(--inner)* 100vw), 28px);}
.his-wrap ul li:before {content:''; position:absolute; top:.55em; left:0; width:clamp(4px, calc(8 / var(--inner)* 100vw), 8px); height:clamp(4px, calc(8 / var(--inner)* 100vw), 8px); background:var(--color-primary); border-radius:100%;}

.tab { margin-bottom:var(--space-80); } 
.tab ul { display: flex; } 
.tab ul li { position: relative; flex: 1; text-align: center; } 
.tab ul li a { display: flex; flex-direction: column; justify-content: center; align-items: center; position: relative; width: 100%; height: var(--space-80); padding: 0 15px; font-size: clamp(13px, calc( 24 / var(--inner) * 100vw ), 24px); line-height: 1.25em; font-weight:600; color: #cccccc; border-top: 1px solid #ccc; border-right: 1px solid #ccc; border-bottom: 1px solid var(--color-primary); background: #fff; border-top-left-radius: var(--space-16); border-top-right-radius: var(--space-16); } 
.tab ul li:first-child a { border-left: 1px solid #ddd; } 
.tab ul li.active a { color: var(--color-primary); font-weight:700; border: 1px solid var(--color-primary); border-bottom: 1px solid #fff; } 

/* 오시는길 */
.directions-wrap {margin-top:40px;}
.directions-wrap .root_daum_roughmap {width:100% !important; height:400px !important;}
.directions-wrap .address-info {margin-bottom:30px;}
.directions-wrap .address-info .comp {color:var(--color-primary); font-weight:600; margin-bottom:2px;}
.directions-wrap .address-info .addr {color:var(--color-dark); font-size:var(--font-size-24); font-weight:600; line-height:1.33em; letter-spacing:-.03em; margin-bottom:5px;}
.directions-wrap .address-info .etc {color:#454545;}
.directions-wrap .address-info .etc span {display:inline-block; margin-right:16px;}
.directions-wrap .address-info .etc span:last-child {margin-right:0;}
.directions-wrap .contact-info {border-top:1px solid #ddd; font-size:var(--font-size-18); line-height:1.5em;}
.directions-wrap .contact-info dl {display:flex; padding:28px 0; border-bottom:1px solid #ddd;}
.directions-wrap .contact-info dt {width:180px; padding-left:30px; color:#242424; font-size:1.125em; font-weight:500;}
.directions-wrap .contact-info dt svg {vertical-align:middle; margin:-.2em 15px 0 0;}
.directions-wrap .contact-info dt path {fill:var(--color-primary);}
.directions-wrap .contact-info dd {flex:1 1 auto; min-width:0; width:1%; color:#454545;}

/* 제품 */
.cnt-wrap { display:flex; padding-bottom:var(--space-100); } 
.cnt-wrap .txt { width:33.3333%; padding-right:30px; } 
.cnt-wrap .tab-contents { flex: 1 1 auto; width:1%; min-width: 0; } 

.cate-menu ul { display:flex; gap: 8px; } 
.cate-menu ul li a { display:flex; justify-content: center; align-items: center; width: 124px; height: 54px; border-radius: 50vh; font-weight:500; font-size: var(--font-size-18); color: #a8a8a8; background-color: #f4f4f4; border: 1px solid #f4f4f4; } 
.cate-menu ul li.active a { color: var(--color-dark); background-color: rgb(255, 246, 215); border: 1px solid var(--color-secondary); } 

.cate-menu.type2 { margin-bottom:var(--space-90) } 
.cate-menu.type2 ul { justify-content: center; } 
.cate-menu.type2 ul li a { width: 151px; height: 67px; font-size: var(--font-size-22); border-radius: var(--space-16); } 

.info-wrap { border-top:1px solid var(--color-primary); border-bottom: 1px solid var(--color-primary); padding:var(--space-50) 0; } 
.info-wrap ul li:not(:last-child) { margin-bottom:var(--space-100); } 
.info-wrap ul li { display:flex; } 
.info-wrap ul li .tit { width:30%; font-weight:600 !important; font-size: var(--font-size-30); line-height:1em; color: var(--color-dark); } 
.info-wrap ul li .tit span { display:inline-block; margin-right:var(--space-15); color: var(--color-primary); letter-spacing: -0.04em; } 
.info-wrap .info-list { flex: 1 1 auto; width:1%; min-width: 0; } 
.info-list dl { display:flex; font-size: var(--font-size-20); letter-spacing: -0.04em; line-height:normal; } 
.info-list dl:not(:last-child) { margin-bottom:var(--space-30); } 
.info-list dl dt { width:130px; font-weight:600; color: #878787; } 
.info-list dl dd { flex: 1 1 auto; width:1%; min-width: 0; } 

/* 기술 */
.img-list { display:flex; justify-content: space-between; gap: 0 clamp(16px, calc( 150 / var(--inner) * 100vw ), 150px ); ; } 
.img-list .img {text-align:center;}
.img-list .img img { border-radius: var(--border-radius-24); box-shadow: 0px 4px 28px 0px rgba(0, 0, 0, 0.12); } 

.directions { display:flex; } 
.directions .map { width:39%; margin-right:var(--space-40); } 
.directions .inquiry-form { flex: 1 1 auto; width:1%; min-width:0; } 

.inquiry-form .item {display: inline-block; margin: 4px 16px 4px 0;}

.charging-fee {text-align:center;}
.charging-fee .subtitle {margin-bottom:var(--space-100); font-size:var(--font-size-24); line-height:1.5em;}
.charging-fee .items {display:grid; grid-template-columns:repeat(2, 1fr); gap:var(--space-40);}
.charging-fee .item {padding:var(--space-100) 20px; border-radius:var(--border-radius-32); box-shadow: 1px 1.732px 16px 0px rgba(0, 0, 0, 0.08); font-size:var(--font-size-20); line-height:1.5em;}
.charging-fee .item .title {margin-bottom:var(--space-30); font-size:var(--font-size-32); font-weight:600; color: var(--color-dark);}
.charging-fee .item .price {margin-bottom:var(--space-30); font-size:var(--font-size-54); font-weight:700; line-height:1.2em; color: var(--color-primary);}

.operator-message {margin-bottom:var(--space-100); text-align:center; font-size:var(--font-size-24); font-weight:500; line-height:1.6em; letter-spacing: -0.03em;}
.operator-message.has-qm {padding:10px 0;}
.operator-message.has-qm p {display:inline-block; position:relative; padding:8px 2em;}
.operator-message .qm {position:absolute; top:0;}
.operator-message .qm.start {left:0;}
.operator-message .qm.end {right:0;}

.operator-intro {display:flex; gap:var(--space-40); margin-bottom:var(--space-120);} 
.operator-intro .img {flex:1;}
.operator-intro .cnt {flex:1;}
.operator-intro .group:not(:last-child) {margin-bottom:var(--space-40);}
.operator-intro .title {margin-bottom:var(--space-15); margin-top:-.1em; color:var(--color-primary); font-size:var(--font-size-24); font-weight:600; line-height:1.3em; letter-spacing: -0.03em;}
.operator-intro .table {width:100%; border-collapse:collapse; border-spacing:0px; line-height:1.5em; border-top:1px solid var(--color-primary);}
.operator-intro .table th {padding:14px; border:1px solid #ddd; border-top:0; font-weight:600; color:var(--color-dark);}
.operator-intro .table td {padding:14px 5%; border:1px solid #ddd; border-top:0;}
.operator-intro .table td strong {font-weight:600; }
.operator-intro .table thead th {background:#f9f9f9;}
.operator-intro .table tr th:first-child,
.operator-intro .table tr td:first-child {border-left:0;} 
.operator-intro .table tr th:last-child,
.operator-intro .table tr td:last-child {border-right:0;} 
.operator-intro .note {margin-top:var(--space-20); line-height:1.6em;}
.operator-intro .note li {padding-left:.5em; text-indent:-0.5em;}
.operator-intro .note li:not(:last-child) {margin-bottom:5px;}

.operator-step .wrap {margin-bottom:var(--space-60);}
.operator-step .steps {display:grid; grid-template-columns:repeat(5, 1fr); gap:var(--space-20); margin-bottom:var(--space-40);}
.operator-step .step {padding:var(--space-40) var(--space-20); border:1px solid #ddd; border-radius:var(--border-radius-16); text-align:center;}
.operator-step .step .tit {color:var(--color-primary); font-size:var(--font-size-24); font-weight:600; line-height:1.3em;}
.operator-step .step .tit strong {font-weight:600;}
.operator-step .step .ico {display:flex; justify-content:center; align-items:center; width:clamp(80px, calc(150 / var(--inner)* 100vw), 150px); height:clamp(80px, calc(150 / var(--inner)* 100vw), 150px); margin:var(--space-30) auto; padding:14%; border:1px solid #ddd; border-radius:100%;}