@charset "utf-8";/* layout.css는 전체적인 레이아웃 스타일을 정의합니다. */

.fancybox-close {background-color:#242424 !important;}

#skipToContent a { z-index:100000; position:absolute; top:0; left:0; width:1px; height:1px; font-size:0; line-height:0; overflow:hidden } 
#skipToContent a:focus, 
#skipToContent a:active { width:200px; height:50px; background:#21272e; color:#fff; font-size:14px; font-weight:bold; text-align:center; text-decoration:none; line-height:50px } 

.only-desktop-tablet { display:block; } 
.only-desktop { display:block; } 
.only-tablet { display:none; } 
.only-mobile { display:none; } 

#main #wrapper ,
#sub #wrapper {padding-top: var(--header-height);}

/* header */
#header {position:fixed; top:0; left:0; width:100%; z-index:90; background: #fff;} 
#header .contain {display:flex; align-items:center; justify-content:space-between; position:relative; height:var(--header-height); max-width:1780px !important;} 
#header .sitelogo a {display:block; width:clamp(120px, calc( 166 / var(--inner) * 100vw ), 166px); height:var(--header-height); text-indent:-999em; background-image:url(../images/common/logo-c.svg); background-size:contain; background-repeat:no-repeat; background-position: 0 50%;} 

#header.active {box-shadow:rgba(0, 0, 0, 0.3) 0px 8px 16px -8px;}
#header.active .submenu-bg::after {width: 100%;} 
#header:hover  .submenu-bg::after {width: 100%;} 

#gnb>ul { display:flex; justify-content:center; } 
#gnb>ul>li { position:relative; text-align:center; padding:0 50px; } 
#gnb>ul>li>a {position:relative; display:flex; align-items:center; flex-direction: column; justify-content:center; height:var(--header-height); font-size:clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px); font-weight:600; letter-spacing:-.03em; line-height:1.3em;}
#gnb>ul>li.active>a {color: var(--color-primary) !important;}
/* #gnb>ul>li:hover>a:after { content:""; width:60px; height:4px; background-color:var(--color-primary); position:absolute; left:50%; bottom:0; transform:translateX(-50%); }  */
#gnb .submenu { position:absolute; top:var(--header-height); left:0; width:100%; height:0; overflow:hidden; z-index:20; } 
#gnb .submenu ul { display:block; padding:30px 0; } 
#gnb .submenu ul li { padding:0; text-align:center; } 
#gnb .submenu ul li:not(:last-child) {padding-bottom: 8px;}
#gnb .submenu ul li a { display:inline-block; color:var(--color-body); font-size:clamp(14px, calc( 16 / var(--inner) * 100vw ), 16px); line-height:2.2em; font-weight:400; position:relative; } 
#gnb .submenu ul li:hover a {color:var(--color-primary); font-weight: 600;}
.submenu-bg {position:relative; background-color:#fff; } 
.submenu-bg::after {position:absolute; content: ''; top:0; left:0; width:0; height:1px; background:#ddd;}


/* 공통  */
.section {overflow:hidden;}
.flxWrap {display:flex; flex-wrap:wrap;}
.sec-pd {padding: clamp(50px, calc( 140  / var(--inner) * 100vw ), 140px) 0;}
.text-center {text-align:center;}
.align-items-center {align-items:center !important;}
.justify-content-center {justify-content:center !important;}
.main-color {color:var(--color-primary) !important;}
.sub-color {color:var(--color-secondary) !important;}
.color-dark {color: var(--color-dark) !important;}
.red {color:#e32020;}
.pt-0 {padding-top:0 !important;} 
.pb-0 {padding-bottom:0 !important;}
.mb-0 {margin-bottom:0 !important;}
.mt-0 {margin-top:0 !important;}
.font-light {font-weight:300 !important;}
.font-medium {font-weight:500 !important;}
.font-semi {font-weight:600 !important;}
.font-extra {font-weight:800 !important;}
.font-normal {font-weight:400 !important;}
.text-center {text-align:center !important;}
.text-left {text-align:left !important;}
.text-right {text-align:right !important;}
.max-wid {max-width:1460px; width:100%; margin:0 auto; padding-left:var(--container-space); padding-right:var(--container-space);}
.sec-titbox {line-height:1.1;}
.sec-titbox .section-tit {font-size:var(--font-size-40); font-weight:bold; line-height: 1.35;}
.sec-titbox .section-dec {padding-top:var(--padding-50); font-size:var(--font-size-20); color:var(--color-body); line-height:1.7;}
.bg-gray {background:#fafafa;}

/* main */
[data-aos=fade-up] { transform: translate3d(0,100px,0); } 
.main-visual { position:relative; overflow:hidden; color:#fff; } 
.main-visual .item {position:relative; height:100vh; overflow:hidden;}
.main-visual .image {position:absolute; top:0; left:0; width:100%; height:100%; overflow:hidden; transition:5s linear; transform:scale(1.15);}
.main-visual .image img {position:absolute; top:50%; left:0; transform:translateY(-50%); -ms-transform:translateY(-50%); -webkit-transform:translateY(-50%); width:100%; height:auto !important; max-width:100%; min-height:100%; object-fit:cover;}
.main-visual .item .video-js,
.main-visual .item video {position:absolute; top:0; left:0; width:100%; height:100%; object-fit:cover;}
.main-visual .item iframe {position:absolute; top:50%; left:50%; width:100vw; height:100%; -webkit-transform:translate(-50%,-50%); transform:translate(-50%,-50%);}

/* .main-visual .vjs-controls-disabled {position:relative; padding-bottom:36.11%; overflow:hidden;}
.main-visual .vjs-controls-disabled video {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%;object-fit : cover;}
.main_visual_vod_0-dimensions ,
.vjs-workinghover {height: 100% !important; width: 100% !important;} */

.main-visual .text-box {padding-left:var(--container-space); padding-right:var(--container-space); position:absolute; left:50%; top:50%; transform:translate(-50%,-50%); max-width:1460px; width:100%; line-height:1.3;}
.main-visual .text-box p {transition:1.2s; transform:translate(50px,0); opacity:0; }
.main-visual .text-box .txt1 {font-size: clamp(20px, calc( 50 / var(--inner) * 100vw ), 50px);font-weight: bold;}
.main-visual .text-box .txt2 {padding-top: clamp(6px, calc( 11 / var(--inner) * 100vw ), 11px); font-size: clamp(16px, calc( 32 / var(--inner) * 100vw ), 32px);}
.main-visual .controls {display:flex; align-items:center; padding-left:var(--container-space); padding-right:var(--container-space); position:absolute; top:calc(50% + 175px); left:50%; transform:translatex(-50%); max-width:1460px; width:100%; color:#fff; z-index:40;}
.main-visual .pager {font-size:clamp(15px, calc( 18 / var(--inner) * 100vw ), 18px);}
.main-visual .pager .current {display:inline-block; width:.6em;}
.main-visual .progress {position:relative; margin:0 10px; width:150px; height:2px; background:#fff;}
.main-visual .progress-bar {position:absolute; top:0; left:0; height:100%; background:var(--color-primary);}
.main-visual .slide-btn {width:24px; height:24px; margin-right:6px; background-color:#000; background-position:50% 50%; background-repeat:no-repeat; border-radius:100%; border:0; overflow:hidden;}
.main-visual .slide-prev {background-image:url("../images/main/ctr_prev.svg");}
.main-visual .slide-next {background-image:url("../images/main/ctr_next.svg");}
.main-visual .slide-stop {background-image:url("../images/main/ctr_stop.svg");}
.main-visual .slide-play {display:none; background-image:url("../images/main/ctr_play.svg");}
.main-visual .active .image {transform:scale(1);}
.main-visual .active .text-box p {transform:translate(0,0); opacity:1;}
.main-visual .active .text-box .txt1 {transition-delay:.5s;}
.main-visual .active .text-box .txt2 {transition-delay:.7s;}
.main-visual .scroll {position:absolute; bottom:20px; right:70px; animation:scrollDown .9s linear infinite alternate; z-index:40;}
.main-visual .scroll .flxWrap {flex-direction:column; align-items:center;}
.main-visual .scroll .name {padding-bottom:10px; writing-mode: vertical-rl; font-size:var(--font-size-14);}

.progress-bar.animated {animation:progressBar 1 linear;}
.progress-bar.paused {animation-play-state:paused !important;}
.progress-bar.play {animation-play-state:running !important;}

@keyframes progressBar {
	0%{width:0;}
	100%{width:100%;}
}
@keyframes scrollDown{
	0%{transform:translateY(0);}
	100%{transform:translateY(15px);}
}

.morebx .btn-more {display: inline-flex;align-items: center;justify-content: center;width:40px; height: 40px; border-radius: 50%; background: #fafafa;}
.morebx .btn-more:hover {background: var(--color-primary);}
.morebx .btn-more:hover path {stroke: #fff;}
.morebx .btn-more.ty2:hover {background: var(--color-secondary);}


#main .section {position: relative;}
.sec-dotnav {position: absolute; left:clamp(10px, calc( 50 / var(--inner) * 100vw ), 50px); top: 50%; transform: translateY(-50%);}
.sec-dotnav-list {display: flex;flex-direction: column;gap: var(--padding-24);}
.sec-dotnav-link {display: flex;flex-direction: column; align-items: center;justify-content: center; gap:var(--padding-12);}
.sec-dotnav-link img {width:clamp(10px, calc( 16 / var(--inner) * 100vw ), 16px) ;}
.sec-dotnav-label {display: none; font-size: var(--font-size-18); font-weight: 600; line-height: 1;writing-mode: vertical-rl; letter-spacing: -1px;}
.sec-dotnav-link.is-active .sec-dotnav-label {display: block;}

.sec1 {padding:40px 0;}
.sec1grid + .sec1grid2 {margin-top: var(--padding-16);}
.sec1grid { display:grid; grid-template-columns: repeat(2,1fr); gap: var(--padding-16); }
.sec1-mission { border-radius:16px; background:#DE5D2A; color:#fff; }
.sec1-mission-inner { display:flex; flex-direction:column; justify-content:center; gap:var(--padding-55);padding: var(--padding-45) var(--padding-50); height: 100%;}
.sec1-mission-hd { display:flex; flex-direction:column; align-items:center; gap:var(--padding-30); text-align:center; }
.sec1-mission-logoimg { display:block; width:clamp(150px, calc(258 / var(--inner) * 100vw), 258px); height:auto; }
.sec1-mission-lead { font-size:var(--font-size-28); font-weight:600; letter-spacing:-0.03em; line-height:1.5; color:#fff; }
.sec1-mission-list { display:flex; flex-direction:column; align-items: flex-start; gap:var(--padding-20); }
.sec1-mission-item {font-size:var(--font-size-20); font-weight:500; letter-spacing:-0.03em; line-height:1.7; color:#fff; }

.sec1-pair { display:grid; grid-template-columns: repeat(2,1fr); gap:var(--padding-16); }
.sec1-card { position:relative; display:block; width:100%; height:clamp(420px, calc( 519 / var(--inner) * 100vw ), 519px); border:1px solid #eee; border-radius:16px; background:#fff; color:inherit; text-decoration:none; box-sizing:border-box; transition:border-color .25s ease, box-shadow .25s ease; overflow:hidden; }
.sec1-card-default { position:relative; z-index:0; display:flex; flex-direction:column; align-items:center; justify-content:center; gap:var(--padding-45); padding:var(--padding-30); height:100%; transition:opacity .25s ease, visibility .25s ease; }
.sec1-card-ico { display:flex; align-items:center; justify-content:center; width:clamp(30px, calc( 48 / var(--inner) * 100vw ), 48px); height:clamp(30px, calc( 48 / var(--inner) * 100vw ), 48px); flex-shrink:0; }
.sec1-card-txt { display:flex; flex-direction:column; align-items:center; gap:var(--padding-20); width:100%; text-align:center; }
.sec1-card-tit { font-size:var(--font-size-28); font-weight:600; letter-spacing:-0.03em; line-height:1.5; color:#222; }
.sec1-card-desc { font-size:var(--font-size-20); font-weight:400; letter-spacing:-0.03em; line-height:1.7; color:var(--color-body); }
.sec1-card-pill { display:inline-flex; align-items:center; justify-content:center; padding:15px; border-radius:80px; background:#fafafa; flex-shrink:0; }
.sec1-card-hover { position:absolute; left:0; top:0; right:0; bottom:0; z-index:1; display:flex; flex-direction:column; gap:clamp(15px, calc( 30 / var(--inner) * 100vw ), 30px); align-items:flex-start; padding:var(--padding-30); background:#fff; border-radius:16px; opacity:0; visibility:hidden; transition:opacity .25s ease, visibility .25s ease; box-sizing:border-box; overflow:auto; }
.sec1-card-hover-hd { display:flex; align-items:center; justify-content:space-between; width:100%; gap:var(--padding-16); }
.sec1-card-hover-tit { font-size:var(--font-size-28); font-weight:600; letter-spacing:-0.03em; line-height:1.5; color:#222; flex-shrink:0; }
.sec1-card-hover-go { display:inline-flex; align-items:center; justify-content:center; width:clamp(25px, calc( 40 / var(--inner) * 100vw ), 40px); height: clamp(25px, calc( 40 / var(--inner) * 100vw ), 40px); border-radius:50%; }
.sec1-card-hover-go svg {width: clamp(4px, calc( 8 / var(--inner) * 100vw ), 8px);}
.sec1-card-hover-go--biz { background:#DE5D2A; }
.sec1-card-hover-go--news { background:var(--color-secondary); }
.sec1-card-hover-line { width:100%; height:0; border-top:1px solid #eee; flex-shrink:0; }
.sec1-card-feed { display:flex; flex-direction:column; gap:var(--padding-24); width:100%; }
.sec1-card-feed--news { gap:var(--padding-30); }
.sec1-card-feed-it { display:flex; gap:var(--padding-10); align-items:flex-start; width:100%; }
.sec1-card-feed-dot { flex-shrink:0; width:clamp(4px, calc( 8 / var(--inner) * 100vw ), 8px); height:clamp(4px, calc( 8 / var(--inner) * 100vw ), 8px); margin-top:clamp(9px, calc( 12 / var(--inner) * 100vw ), 12px); border-radius:50%; background:#DE5D2A; }
.sec1-card-feed-dot--news { background:var(--color-secondary); }
.sec1-card-feed-body { display:flex; flex-direction:column; gap:var(--padding-16); min-width:0; }
.sec1-card-feed-tit { font-size:var(--font-size-18); font-weight:600; letter-spacing:-0.03em; line-height:1.5; color:#222; }
.sec1-card-feed-meta { display:flex; flex-direction:column; gap:4px; }
.sec1-card-feed-row { display:flex; flex-wrap:wrap; align-items:center; gap:var(--padding-10); font-size:var(--font-size-16); font-weight:400; letter-spacing:-0.5px; line-height:1.5; color:#999; }
.sec1-card-feed-lbl { flex-shrink:0; }
.sec1-card-feed-sep { width:1px; height:10px; background:#ddd; flex-shrink:0; }
.sec1-card-feed-val { flex-shrink:0; flex:1;}
.sec1-card-feed-date { font-size:var(--font-size-16); font-weight:400; letter-spacing:-0.03em; line-height:1.5; color:#999; }
.sec1-card--biz:hover,
.sec1-card--biz:focus-visible { border-color:#DE5D2A; box-shadow:0 8px 24px rgba(222,93,42,.12); }
.sec1-card--news:hover,
.sec1-card--news:focus-visible { border-color:var(--color-secondary); box-shadow:0 8px 24px rgba(0,140,153,.12); }
.sec1-card--biz:hover .sec1-card-default,
.sec1-card--biz:focus-visible .sec1-card-default,
.sec1-card--news:hover .sec1-card-default,
.sec1-card--news:focus-visible .sec1-card-default { opacity:0; visibility:hidden; }
.sec1-card--biz:hover .sec1-card-hover,
.sec1-card--biz:focus-visible .sec1-card-hover,
.sec1-card--news:hover .sec1-card-hover,
.sec1-card--news:focus-visible .sec1-card-hover { opacity:1; visibility:visible; }
.sec1grid2 { display:grid; grid-template-columns:repeat(2, 1fr); gap:var(--padding-16); }
.aiintroinner {display:flex; flex-direction:column; align-items:center; justify-content:center; gap:var(--padding-30); padding:var(--padding-65) var(--padding-24); border-radius:16px;  border: 1px solid var(--color-secondary); height: 100%; transition: all 0.4s;}
.sec1-aiintro-hd { display:flex; justify-content:center; align-items:center; width:100%; padding-bottom:8px; box-sizing:border-box; }
.sec1-aiintro-tit {font-size:var(--font-size-28); font-weight:700; letter-spacing:-0.03em; line-height:1.5; color: var(--color-secondary); text-align:center; }
.sec1-aiintro-desc {font-size:var(--font-size-20); font-weight:500; letter-spacing:-0.03em; line-height:1.7; color: var(--color-secondary); text-align:center; }
.aiintroinner:hover {background: var(--color-secondary);}
.aiintroinner:hover .sec1-aiintro-tit {color: #fff;}
.aiintroinner:hover .sec1-aiintro-desc {color: #fff;}

.splitpairbx { display:block; width:100%; height:100%; min-height:0; box-sizing:border-box; }
.sec1-gpro-pairwrap { display:flex; flex-direction:row; flex-wrap:nowrap; align-items:stretch; gap:var(--padding-16); width:100%; height:100%; box-sizing:border-box; }
.sec1-gpro-pair { display:flex; flex-direction:column; flex-wrap:nowrap; align-items:stretch; gap:var(--padding-16); flex:1 1 0; min-width:0; height:100%; box-sizing:border-box; }
.sec1-gpro-card { display:flex; flex-direction:row; flex-wrap:nowrap; align-items:center; justify-content:flex-start; gap:var(--padding-16); width:100%; flex:1 1 0; min-height:clamp(56px, calc( 72 / var(--inner) * 100vw ), 72px); padding:var(--padding-20) var(--padding-24); border:1px solid #ddd; border-radius:16px; background:#fff; color:#222; text-decoration:none; box-sizing:border-box; transition:border-color .25s ease, box-shadow .25s ease, background-color .25s ease, color .25s ease; outline:none; }
.sec1-gpro-card.ty1:hover,
.sec1-gpro-card.ty1:focus-visible { border-color:var(--color-secondary);  box-shadow:0 8px 24px rgba(0,93,42,.12); }
.sec1-gpro-card.ty2:hover,
.sec1-gpro-card.ty2:focus-visible { border-color:var(--color-primary);  box-shadow:0 8px 24px rgba(0,93,42,.12); }

.sec1-gpro-card__icn { display:flex; flex-direction:row; flex-wrap:nowrap; align-items:center; justify-content:center; flex-shrink:0; width:clamp(30px, calc( 48 / var(--inner) * 100vw ), 48px); height:clamp(30px, calc( 48 / var(--inner) * 100vw ), 48px); }
.sec1-gpro-card__img { display:block; width:100%; height:auto; max-width:100%; object-fit:contain; }
.sec1-gpro-card__meta { display:inline-flex; flex-direction:row; flex-wrap:wrap; align-items:center; gap:8px; font-size:var(--font-size-18); font-weight:600; letter-spacing:-0.03em; line-height:1.78; color:#222; transition:color .25s ease; }
@media (max-width: 520px) {
.sec1-gpro-pairwrap { flex-direction:column; flex-wrap:nowrap; }
}

.sec2 {padding: clamp(150px, calc( 300 / var(--inner) * 100vw ), 300px) 0; position: relative; background:url(../images/main/sec2-bg.jpg) no-repeat center center / cover;}
.sec2 .btmtext {position:absolute; left:0; right:0; bottom:clamp(-20px, calc( -20 / var(--inner) * 100vw ), -10px); width:100%; overflow:hidden; line-height:1; }
.sec2 .btmtext-track {display:inline-flex; width:max-content; animation:sec2-btmtext-marquee 50s linear infinite; will-change:transform; }
.sec2 .btmtext-seg {flex-shrink:0; font-size:clamp(60px, calc( 160 / var(--inner) * 100vw ), 160px); font-weight:700; color:rgba(0, 140, 153, 0.32); white-space:nowrap; line-height:1; padding-right:clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px); }
@keyframes sec2-btmtext-marquee { 0% { transform:translate3d(0,0,0); } 100% { transform:translate3d(-50%,0,0); } }
@media (prefers-reduced-motion: reduce) {
.sec2 .btmtext-track { animation:none; transform:none; }
}

.sec3-grid { display:grid; grid-template-columns:repeat(4, 1fr); gap:var(--padding-16); margin-top:var(--padding-40); align-items:stretch; }
.sec3-card { position:relative; display:block; min-height:clamp(230px, calc( 300 / var(--inner) * 100vw ), 300px);border:1px solid #eee; border-radius:16px; background:#fff; box-sizing:border-box; overflow:hidden; transition:border-color .28s ease, box-shadow .28s ease, min-height .35s ease; }

.sec3-card-hit { display:flex; flex-direction:column; justify-content: space-between; gap:15px;padding:var(--padding-24); color:inherit; text-decoration:none; box-sizing:border-box; width:100%; height:100%; transition:gap .35s ease, min-height .35s ease; }
.sec3-card:hover .sec3-card-hit,
.sec3-card:focus-within .sec3-card-hit { gap:0; }
.sec3-card-fig { display:flex; align-items:center; justify-content:flex-start; width:48px; height:48px; flex-shrink:0; transition:opacity .28s ease, transform .28s ease; }
.sec3-card:hover .sec3-card-fig,
.sec3-card:focus-within .sec3-card-fig { display:none; }
.sec3-card-img { display:block; width:clamp(30px, calc( 48 / var(--inner) * 100vw ), 48px); height:auto; max-width:100%; }
.sec3-card-body { display:flex; flex-direction:column; gap:var(--padding-16); align-items:flex-start; justify-content: space-between; width:100%; height: 100%; transition:gap .35s ease; }
.sec3-card-meta { display:inline-flex; flex-wrap:wrap; align-items:center; gap:8px; margin:0; font-size:var(--font-size-18); font-weight:600; letter-spacing:-0.03em; line-height:1.78; color:#999; }
.sec3-card-sep { display:inline-block; width:2px; height:12px; background:#ddd; border-radius:2px; flex-shrink:0; }
.sec3-card-row { display:flex; flex-direction:row; flex-wrap:nowrap; align-items:center; justify-content:space-between; gap:var(--padding-16); width:100%; min-width:0; transition:gap .28s ease; }
.sec3-card:hover .sec3-card-row,
.sec3-card:focus-within .sec3-card-row { align-items:flex-end; justify-content:flex-start; }
.sec3-card-titwrap { display:block; flex:1; min-width:0; transition:padding .28s ease, gap .28s ease; }
.sec3-card:hover .sec3-card-titwrap,
.sec3-card:focus-within .sec3-card-titwrap { display:flex; flex-direction:column; align-items:flex-start; gap:8px; }
.sec3-card-tit { font-size:var(--font-size-24); font-weight:600; letter-spacing:-0.03em; line-height:1.58; color:#222; transition:color .28s ease; }
.sec3-card-desc { max-height:0; opacity:0; overflow:hidden; font-size:var(--font-size-18); font-weight:400; letter-spacing:-0.03em; line-height:1.78; color:var(--color-body); transition:max-height .35s ease, opacity .28s ease, margin .28s ease; }
.sec3-card:hover .sec3-card-desc,
.sec3-card:focus-within .sec3-card-desc { max-height:5em; opacity:1; }
.sec3-card--mis:hover .sec3-card-tit,
.sec3-card--mis:focus-within .sec3-card-tit { color:#DE5D2A; }
.sec3-card--teal:hover .sec3-card-tit,
.sec3-card--teal:focus-within .sec3-card-tit { color:var(--color-secondary); }
.sec3-card-hit .morebx { position:static; flex-shrink:0; opacity:1; visibility:visible; }
.sec3-card--mis:hover,
.sec3-card--mis:focus-within { border-color:#DE5D2A; box-shadow:0 8px 24px rgba(222,93,42,.12); }
.sec3-card--teal:hover,
.sec3-card--teal:focus-within { border-color:var(--color-secondary); box-shadow:0 8px 24px rgba(0,140,153,.12); }
.sec3-card--mis:hover .sec3-card-hit .morebx .btn-more,
.sec3-card--mis:focus-within .sec3-card-hit .morebx .btn-more { background:#DE5D2A; }
.sec3-card--mis:hover .sec3-card-hit .morebx .btn-more path,
.sec3-card--mis:focus-within .sec3-card-hit .morebx .btn-more path { stroke:#fff; }
.sec3-card--teal:hover .sec3-card-hit .morebx .btn-more,
.sec3-card--teal:focus-within .sec3-card-hit .morebx .btn-more { background:var(--color-secondary); }
.sec3-card--teal:hover .sec3-card-hit .morebx .btn-more path,
.sec3-card--teal:focus-within .sec3-card-hit .morebx .btn-more path { stroke:#fff; }

.sec4container {display: grid;grid-template-columns: repeat(2,1fr); gap:var(--padding-16);}
.sec4container .main-color {color: #DE5D2A !important;}
.sec4container .commborder {padding: var(--padding-48); border: 1px solid #eee; border-radius: 24px; height: 100%;}
.sec4container .commtit {padding-bottom: var(--padding-40); font-size: var(--font-size-32); font-weight: 600; line-height: 1.43;}
.commwid.row {display: flex;flex-direction: column;gap: var(--padding-16);}
.noticewrap {overflow-y: auto;}
.noticelist {height:clamp(250px, calc( 485 / var(--inner) * 100vw ), 485px); border-top: 1px solid #686868;}
.noticeitem {display: flex;align-items: center; gap: 15px; padding:clamp(20px, calc( 30 / var(--inner) * 100vw ), 30px) 0; border-bottom: 1px dashed #ddd;}
.noticeitem .textbx {display: flex;flex-direction: column;gap: 5px ; flex: 1; padding-left: 18px; position: relative; letter-spacing: -0.6px;}
.noticeitem .textbx:after {position: absolute; content: ''; left: 0; top: clamp(10px, calc( 12 / var(--inner) * 100vw ), 12px); width: clamp(6px, calc( 8 / var(--inner) * 100vw ), 8px); height: clamp(6px, calc( 8 / var(--inner) * 100vw ), 8px); background:#999; border-radius: 50%;}
.noticeitem .title {font-size:var(--font-size-20); font-weight: 600; line-height: 1.7; display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp: 1;}
.noticeitem .txtbadge {display: flex; flex-wrap: wrap; gap:var(--padding-24);}
.noticeitem .badgeitem {margin:0 -10px;}
.noticeitem .badgeitem span {display: inline-block;padding:0 10px; position: relative; line-height: 1.87; color: #999;}
.noticeitem .badgeitem span:first-child:after {position: absolute; content: ''; right: -1px; top: clamp(7px, calc( 9 / var(--inner) * 100vw ), 9px); width: 1px; height:10px; background: #ddd;}
.noticeitem .btn-right {display: inline-flex;align-items: center;justify-content: center;width:clamp(35px, calc( 56 / var(--inner) * 100vw ), 56px); height: clamp(35px, calc( 56 / var(--inner) * 100vw ), 56px); border-radius: 24px; border: 1px solid #ddd;}
.sec4-visit-inner { display:flex; flex-direction:column; align-items:flex-start; justify-content: center; gap:var(--padding-40); height: 100%;}
.sec4-visit-block { display:flex; align-items:center; gap:var(--padding-16);}
.sec4-visit-icnwrap { display:flex; align-items:center; justify-content:center; width:14px; height:14px; }
.sec4-visit-addr { font-style:normal; font-size:var(--font-size-20); font-weight:500; letter-spacing:-0.03em; line-height:1.7; color:var(--color-body); }
.sec4-visit-contact { display:flex; flex-wrap:wrap; align-items:flex-start; gap:var(--padding-16); font-size:var(--font-size-18); font-weight:400; letter-spacing:-0.03em; line-height:1.78; }
.sec4-visit-pair { display:inline-flex; flex-wrap:nowrap; align-items:center; gap:var(--padding-16); }
.sec4-visit-lab { font-weight:600; color:#DE5D2A; }
.sec4-visit-val { color:var(--color-body); text-decoration:none; }

.mainmap .map {width: 100%; height: 295px; border-radius: 24px; overflow: hidden;}

.sec5 {background:url(../images/main/sec5-bg.jpg) no-repeat center center /cover;}
.sec5 .section-cate {display: block;margin-bottom: var(--padding-40); font-size: var(--font-size-20); font-weight: 600; line-height: 1.7; color: var(--color-primary );}
.sec5 .morebx {margin-top: var(--padding-60); text-align: center;}
.morebx .btn-more2 {display: inline-flex;align-items: center;justify-content: center;gap: 16px; padding: var(--padding-10) 16px; min-width: 170px; font-size: var(--font-size-20); color: var(--color-primary); font-weight: 600; line-height: 1.7; border: 1px solid var(--color-primary); border-radius: 48px;}
.morebx .right {display: inline-flex;align-items: center;justify-content: center;width:clamp(30px, calc( 40 / var(--inner) * 100vw ), 40px); height: clamp(30px, calc( 40 / var(--inner) * 100vw ), 40px); font-size: var(--font-size-18); font-weight: 500; border-radius: 50%;  background: var(--color-primary); color: #fff;}
.morebx .btn-more2:hover {background: var(--color-primary); color: #fff;}
.morebx .btn-more2:hover .right {background: #fff; color: var(--color-primary);}


/* slide btn 공통 */
.btn-arrow {margin-top:0; top:40%; width:clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px); height:clamp(30px, calc( 50 / var(--inner) * 100vw ), 50px); border-radius:50%;  border:1px solid #ddd; transition: all 0.3s;}
.btn-arrow::after {display: none;}
.swiper-button-next {right:0; }
.swiper-button-prev {left:0; }
.btncontrol {display:flex; align-items:center; padding-right:clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px);}
.btncontrol .btn-arrow {margin-right:clamp(10px, calc( 16 / var(--inner) * 100vw ), 16px); position:initial;}
.btncontrol .btn-arrow:last-child {margin-right:0;}
.btn-arrow svg {color: #ddd; width:clamp(20px, calc( 28 / var(--inner) * 100vw ), 28px);}
.btn-arrow:hover {background:var(--color-primary); border-color:var(--color-primary);}
.btn-arrow:hover svg {color: #fff;}

/* slide type1 */
.slidecont {position:relative; padding-right:clamp(10px, calc( 150 / var(--inner) * 100vw ), 150px); padding-left:clamp(10px, calc( 150 / var(--inner) * 100vw ), 150px); max-width:1500px; width:100%; margin:0 auto;}
.slidecont .ginner {display:block;}
.slidecont .ginner .image {position:relative; padding-bottom:63.90%; overflow:hidden; border-radius:24px;}
.slidecont .ginner .image img {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%; object-fit : cover;}
.slidecont .ginner .textbx {padding-top:clamp(10px, calc( 30 / var(--inner) * 100vw ), 30px); text-align:center;}
.slidecont .ginner .title {font-size:clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); font-weight:600; display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp:1;}
.slidecont .ginner .date {padding-top:clamp(10px, calc( 18 / var(--inner) * 100vw ), 18px); font-size:clamp(12px, calc( 14 / var(--inner) * 100vw ), 14px); color:#b9b9b9;}

/* slide progress */
.galleryitem {position:relative;}
.galleryitem .image {border-radius:16px; position:relative; padding-bottom:73.17%; overflow:hidden;}
.galleryitem .image img {position:absolute; top:50%; left:0; transform:translateY(-50%); width:100%; height:auto; max-width:100%; min-height:100%; object-fit : cover;}
.galleryitem .textbx {padding-top:clamp(10px, calc( 13 / var(--inner) * 100vw ), 13px); padding-left:clamp(10px, calc( 20 / var(--inner) * 100vw ), 20px);}
.galleryitem .title {font-size:clamp(16px, calc( 20 / var(--inner) * 100vw ), 20px); font-weight:500; display:-webkit-box; -webkit-box-orient: vertical; overflow: hidden; -webkit-line-clamp:1;}
.galleryitem .date {display:inline-block; padding-top:5px; color: #898989;}
.controlpaging {display:flex; align-items:center; padding-top:clamp(20px, calc( 40 / var(--inner) * 100vw ), 40px);}
.controlpaging .swiper-pagination {position:initial; height:clamp(3px, calc( 5 / var(--inner) * 100vw ), 5px); border-radius:3px;}
.controlpaging .swiper-pagination-progressbar-fill {background:var(--color-primary); border-radius:3px;}


/* sub page */
.contain { max-width:1500px; margin:0 auto; padding-left:var(--container-space); padding-right:var(--container-space); width:100%;} 
#contArea { max-width:1500px; padding-left:var(--container-space); padding-right:var(--container-space); margin:0 auto;min-height: 70vh;} 
#sub .contain {max-width:1500px; }
#contArea.wide { max-width:100% !important; padding-left:0 !important; padding-right:0 !important;} 
.sub-title {margin-bottom:var(--padding-100); }
.sub-title .maintit { font-size:clamp(24px, calc( 48 / var(--inner) * 100vw ), 48px);} 
.sub-box { display:flex; align-items:center; justify-content:center; width:300px; height:300px; border-radius:var(--border-radius-30); background-color:var(--color-warning); font-size:var(--font-size-20); color:var(--color-white); text-align:center; } 

.real-cont {padding:clamp(60px, calc( 130 / var(--inner) * 100vw ), 130px) 0;} 

.sub-visual { position:relative; height:410px; z-index:10; overflow:hidden; } 
.sub-visual .background {position:absolute;top:0;left:0;width:100%; height:100%;background-position:50% 50%;background-repeat:no-repeat;background-size:cover;transform:scale(1.09); -ms-transform:scale(1.09); /* IE 9 */
 -moz-transform:scale(1.09); /* Firefox */
 -webkit-transform:scale(1.09); /* Safari and Chrome */
 -o-transform:scale(1.09); /* Opera */
transition: all 2s ease-out 0s;transition-delay: 0.1s;z-index:0; } 
.sub-visual.load .background {transform:scale(1); -ms-transform:scale(1); /* IE 9 */
 -moz-transform:scale(1); /* Firefox */
 -webkit-transform:scale(1); /* Safari and Chrome */
 -o-transform:scale(1); /* Opera */}
.sub-visual .tt-wrap {padding-right:var(--container-space); padding-left:var(--container-space); max-width:1260px; width: 100%; position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%); z-index: 1; color: #fff; text-align: center; } 
.sub-visual .tt-wrap .tit {font-size: clamp(16px, calc( 30 / var(--inner) * 100vw ), 30px); line-height: 1.2em; font-weight: 700; }

.lnb-wrap {margin-bottom: var(--padding-60);}
.lnb {border-bottom: 1px solid #ddd;}
.lnb ul {display:flex; justify-content:center; margin:0 auto;  width:100%; }
.lnb ul li {width:auto; flex:1; text-align:center;}
.lnb ul li.active {border-bottom: 2px solid var(--color-primary);}
.lnb ul li.active a {color:var(--color-primary);}
.lnb ul li a {display:flex; align-items:center; justify-content:center; padding:0 20px; height:var(--nav-height); line-height:1.2em; font-size:clamp(15px, calc( 22 / var(--inner) * 100vw ), 22px); color:#999; font-weight: 500;}



.path-wrap {margin-bottom:var(--padding-45);}
.path-wrap .inner {display:flex;align-items: center; margin: 0 -16px;} 
.path-wrap .home {display:flex; align-items:center; padding-right:12px; color: #a8a8a8;}
.path-wrap .home a { background:url("../images/common/home.svg") no-repeat center center /contain; text-indent: -999em; width: clamp(13px, calc( 16 / var(--inner) * 100vw ), 16px); height: clamp(13px, calc( 16 / var(--inner) * 100vw ), 16px);}
.path-wrap .part {display:flex; align-items:center; padding:0 16px; cursor:default; position: relative; font-size:var(--font-size-20); line-height: 1; color: #999; letter-spacing: -0.5px; font-weight: 600;}
.path-wrap .part.second {color: var(--color-secondary); font-weight: 600;}
.path-wrap .part:not(:first-child):after {position: absolute; content: ''; left: -2px; top: 50%; transform: translateY(-50%); width:5px; height: 10px; background:url(../images/common/path-arrow.svg) no-repeat  50% 50% / contain;}

/* footer */
#footer {padding:clamp(40px, calc( 80 / var(--inner) * 100vw ), 80px) 0; background-color:#212121;border-radius: var(--padding-80) var(--padding-80) 0 0;} 
#footer .contain {max-width:1780px !important; display: flex;flex-wrap: wrap; justify-content: space-between; align-items: flex-end; gap: 30px; position: relative;}
#footer .f-menu  {display:flex;}
#footer .f-menu li {padding-left:clamp(15px, calc( 60 / var(--inner) * 100vw ), 60px);}
#footer .f-menu li:first-child {padding-left:0;}
#footer .f-menu li a {display:block; padding-left:clamp(18px, calc( 24 / var(--inner) * 100vw ), 24px); color:#fff; font-weight:600; background:url(../images/common/f-icn.png) no-repeat left center; background-size:clamp(12px, calc( 16 / var(--inner) * 100vw ), 16px) auto;}
#footer .foot-addr {display: flex; flex-wrap: wrap; gap: var(--padding-100); color: #fff; letter-spacing:-0.5px;} 
#footer .foot-logo img {width:clamp(120px, calc( 219 / var(--inner) * 100vw ), 219px);} 
#footer .foot-addr .company {margin-bottom: var(--padding-40); font-size: var(--font-size-24); font-weight: bold; color: #fff;}
#footer address+address {margin-top: var(--padding-10);}
#footer address { font-style:normal; display:flex; flex-wrap:wrap;} 
#footer .address-txt {display:inline-flex; padding-right:var(--padding-20); gap: var(--padding-35); line-height: 1.714em; } 
#footer .address-txt .name {font-weight: bold;}
#footer .copy {margin-top: var(--padding-10);color:#999; line-height: 1.714em;} 

.btn-top {position: absolute;top: 0; right:var(--container-space); display:flex; flex-direction:column; justify-content:center; align-items:center; padding:5px; width:clamp(35px, calc( 80 / var(--inner) * 100vw ), 80px); height:clamp(35px, calc( 80 / var(--inner) * 100vw ), 80px); border-radius:24px; background:var(--color-primary);}
.btn-top img {width:clamp(12px, calc( 20 / var(--inner) * 100vw ), 20px);}

/* all menu */
html.menu-all-opened {overflow:hidden;}
html.menu-all-opened .all-navigation {-ms-transform:translateX(0); transform:translateX(0); }
html.menu-all-opened .all-navigation .only-all-menu {display:block;}
html.menu-all-opened .mobile-overlay {display:block;}

.btn-all-menu {position:relative; top:0; right:0; width:24px; height:15px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out; } 
.btn-all-menu span{ position:absolute; right:0; top:0; height:2px; width:24px; background:#fff; } 
.btn-all-menu span:before,
.btn-all-menu span:after { content:" "; position:absolute; right:0; height:2px; background:#fff; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s; } 
.btn-all-menu span:before {top:7.5px; width:24px; transition-property:top, transform; } 
.btn-all-menu span:after { bottom:-15px; width:24px; transition-property:bottom, transform; } 

.all-navigation {position:fixed; top:0; right:0; padding:20px 0; width:100%; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202; } 
.all-navigation .contain {padding-top:200px; max-width:1460px !important;}
.all-navigation .home {display:none;}
.all-navigation .sitelogo {display:block; margin-bottom:20px; padding-left:15px; } 
.all-navigation .sitelogo img { height:23px; } 
.all-navigation .all-nav-menu>ul>li {display:flex; align-items:center; padding:50px 0; border-bottom:1px solid #dfdfdf; } 
.all-navigation .all-nav-menu>ul>li>a {flex:1 0 410px; max-width:410px; position:relative; font-size:36px; font-weight:bold; line-height:1.3em; color:#2c2c2c;}
.all-navigation .all-nav-menu>ul>li>a:hover {color:var(--color-primary);}
.all-navigation .all-nav-menu .submenu {flex:1; display:block;} 
.all-navigation .all-nav-menu .submenu>ul {display:flex;}
.all-navigation .all-nav-menu .submenu>ul>li {flex:1 0 25%; max-width:25%; padding-right:15px;}
.all-navigation .all-nav-menu .submenu>ul:after { content:""; display:block; clear:both; } 
.all-navigation .all-nav-menu .submenu>ul>li>a {display:block; position:relative; color:#898989; font-size:18px; font-weight:500; line-height:1.3em; } 
.all-navigation .all-nav-menu .submenu>ul>li>a:hover {color:var(--color-secondary); text-decoration: underline;}
.all-navigation .close { position:absolute; top:20px; right:100px; width:24px; height:24px; text-indent:-9999em; overflow:hidden; } 
.all-navigation .close:before,
.all-navigation .close:after { content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#2c2c2c; } 
.all-navigation .close:before { transform:rotate(45deg); } 
.all-navigation .close:after { transform:rotate(-45deg); } 


/* for mobile */
.only-mobile { display:none; } 
.btn-m-menu {display: none; position:relative; top:0; right:0; width:20px; height:16px; text-align:center; text-indent:-9999em; z-index:99; transition:all 0.5s ease-in-out; } 
.btn-m-menu span { position:absolute; right:0; top:0; height:2px; width:20px; background:#242424; } 
.btn-m-menu span:before,
.btn-m-menu span:after { content:" "; position:absolute; right:0; height:2px; background:#242424; transition-duration:0.3s, 0.3s; transition-delay:0.3s, 0s; } 
.btn-m-menu span:before {top:8px; width:20px; transition-property:top, transform; } 
.btn-m-menu span:after { bottom:-16px; width:20px; transition-property:bottom, transform; } 
.mobile-navigation { position:fixed; top:0; right:0; padding:20px 0; width:400px; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:202; } 
.mobile-navigation .home {margin-left:15px; width:100px;}
.mobile-navigation .sitelogo {display:block; margin-bottom:20px; padding-left:15px; } 
.mobile-navigation .sitelogo img { height:23px; } 
.mobile-navigation .nav-menu>ul {margin-top:20px;}
.mobile-navigation .nav-menu>ul>li { border-bottom:1px solid #dfdfdf; } 
.mobile-navigation .nav-menu>ul>li>a { position:relative; padding:12px 15px; display:block; color:#454545; font-size:18px; font-weight:500; line-height:1.3em; } 
.mobile-navigation .nav-menu>ul>li a:after { content:""; position:absolute; top:50%; right:15px; transform:translateY(-75%) rotate(45deg); width:10px; height:10px; border-right:2px solid #2c2c2c; border-bottom:2px solid #2c2c2c; } 
.mobile-navigation .nav-menu>ul>li.active>a { color:#305e92 } 
.mobile-navigation .nav-menu>ul>li.active>a:after { transform:translateY(-35%) rotate(-135deg); border-color:#305e92; } 
.mobile-navigation .nav-menu .submenu { display:none; margin:-1px 0 0 0; padding:0 15px 15px; } 
.mobile-navigation .nav-menu .submenu>ul:after { content:""; display:block; clear:both; } 
.mobile-navigation .nav-menu .submenu>ul>li>a { display:block; position:relative; padding:5px 15px; color:#454545; font-size:16px; font-weight:400; line-height:1.3em; } 
.mobile-navigation .nav-menu .submenu>ul>li>a:after { display:block; content:""; position:absolute; top:14px; left:5px; width:4px; height:4px; background:#dfdfdf; border-radius:50%; transition:.3s ease-in-out; border-radius: 50%;} 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover { color:#305e92 } 
.mobile-navigation .nav-menu .submenu>ul>li>a:hover:after { background:#305e92 } 
.mobile-navigation .close { position:absolute; top:20px; right:15px; width:24px; height:24px; text-indent:-9999em; overflow:hidden; } 
.mobile-navigation .close:before,
.mobile-navigation .close:after { content:" "; position:absolute; top:12px; left:0; width:100%; height:2px; background:#2c2c2c; } 
.mobile-navigation .close:before { transform:rotate(45deg); } 
.mobile-navigation .close:after { transform:rotate(-45deg); } 

.mobile-overlay { display:none; position:fixed; top:0; left:0; width:100%; height:100%; background:#000; opacity:0.6; z-index:201; } 

html.menu-opened { overflow:hidden; } 
html.menu-opened .mobile-navigation { -ms-transform:translateX(0); transform:translateX(0); } 
html.menu-opened .mobile-overlay { display:block; } 