@charset "UTF-8";

body {background-color: #fff;}

body.sub .floating ul {display: none;}


/* ----- 헤더 ----- */
body.is-scrolled header * {color: #202020;}
body.is-scrolled .header-top {border-bottom: 1px solid #ccc;}
body.is-scrolled .header-top .cityhall {border-color: #ccc;}
body.is-scrolled .header-top .jnu {border-color: #ccc;}
body.is-scrolled .header-top .header-etc .admin a::before {background: url('../images/common/admin-b.svg')no-repeat center center/contain;}
body.is-scrolled .header-top .header-etc .login a::before {background: url('../images/common/login-b.svg')no-repeat center center/contain;}
body.is-scrolled .header-top .header-etc .logout a::before {background: url('../images/common/logout-b.svg')no-repeat center center/contain;}
body.is-scrolled .header-top .header-etc li .lang-btn::before {background: url('../images/common/lang-b.svg')no-repeat center center/contain;}
body.is-scrolled .header-top .sitemap {background: url('../images/common/sitemap.svg')no-repeat center center/28px;}
body.is-scrolled .header-top .header-etc > ul > li:first-child:before {background-color: #ccc;}
body.is-scrolled .header-top .logo a img.logo-w {opacity: 0; position: absolute; pointer-events: none;}
body.is-scrolled .header-top .logo a img.logo-c {opacity: 1; position: static; pointer-events: unset;}

body.is-scrolled .header-bottom {border-bottom: 1px solid #b0b0b0;}


/* ----- 서브 헤더 ----- */
.sub-header-wrap {width: 100%; height: 550px; position: relative;}
.sub-header-bg {width: 100%; height: 100%; overflow: hidden; position: absolute; top: 0; left: 0;}
.sub-header-bg::before {content: ''; width: 100%; max-width: 100%; height: 100%; background: url('../images/sub/sub-visual01.jpg')no-repeat center center/cover; transition: 0.3s ease-in-out; position: absolute; top: 0; left: 50%; z-index: 0; animation: bgScale 0.5s ease-in-out forwards; filter: brightness(0.5);}
.sub-header {max-width: 1700px; height: 100%; margin: 0 auto; position: relative; z-index: 2;}
@keyframes bgScale {
    from {transform: translateX(-50%) scale(1.2);}
    to {transform: translateX(-50%) scale(1);}
}

.sub-visual01 .sub-header-bg::before {background: url('../images/sub/sub-visual01.jpg')no-repeat center center/cover;}
.sub-visual02 .sub-header-bg::before {background: url('../images/sub/sub-visual02.jpg')no-repeat center center/cover;}
.sub-visual03 .sub-header-bg::before {background: url('../images/sub/sub-visual03.jpg')no-repeat center center/cover;}
.sub-visual04 .sub-header-bg::before {background: url('../images/sub/sub-visual04.jpg')no-repeat center center/cover;}
.sub-visual05 .sub-header-bg::before {background: url('../images/sub/sub-visual05.jpg')no-repeat center center/cover;}
.sub-visual06 .sub-header-bg::before {background: url('../images/sub/sub-visual01.jpg')no-repeat center center/cover;}
.sub-visual07 .sub-header-bg::before {background: url('../images/sub/sub-visual02.jpg')no-repeat center center/cover;}
.sub-visual08 .sub-header-bg::before {background: url('../images/sub/sub-visual03.jpg')no-repeat center center/cover;}
.sub-visual09 .sub-header-bg::before {background: url('../images/sub/sub-visual04.jpg')no-repeat center center/cover;}
.sub-visual10 .sub-header-bg::before {background: url('../images/sub/sub-visual05.jpg')no-repeat center center/cover;}

.sub-header .sub-text {position: absolute; top: 50%; transform: translateY(-50%); left: 20px; padding-top: 130px; padding-right: 20px; transition: 0.15s ease-in-out;}
.sub-header .sub-text h2 {font-family: 'Paperlogy SemiBold'; font-size: 46px; line-height: 1.8; color: rgba(255, 255, 255, 0.4); animation: fade 0.5s ease-in-out forwards; position: relative;}
.sub-header .sub-text h2::before {content: attr(data-text); position: absolute; top: 0; left: 0; white-space: nowrap; background: #fff; -webkit-background-clip: text; background-clip: text; color: transparent; overflow: hidden; width: 0%; animation: textFill 1.5s ease-in-out forwards; animation-delay: 0.3s; pointer-events: none; transition: color 0.3s ease-in-out;}
/* .sub-header .sub-text h2 span {font-family: 'Paperlogy Medium'; font-size: 35px; margin-left: 10px; color: rgba(255,255,255,0.6); position: relative;}            */
/* .sub-header .sub-text h2 span::before {content: attr(data-text); position: absolute; top: 0; left: 0; white-space: nowrap; background: linear-gradient(to right, #389af5, #1fb5db, #28eedd); -webkit-background-clip: text; background-clip: text; color: transparent; overflow: hidden; width: 0%; animation: textFill 1.5s ease-in-out forwards; animation-delay: 0.3s; pointer-events: none;} */
.sub-header .sub-text p {color: rgba(255, 255, 255, 0.8); font-size: 24px; animation: fade 0.5s ease-in-out forwards;}
@keyframes textFill {
  from {width: 0%;}
  to   {width: 100%;}
}
@keyframes fade {
    from {opacity: 0;}
    to {opacity: 1;}
}

.sub-header .sub-menu {display: flex; align-items: center; justify-content: center; gap: 50px; padding: 18px 50px; background-color: #fff; border-radius: 25px 25px 0 0; position: absolute; bottom: 0; right: 90px; transition: 0.3s ease-in-out;}
/* .sub-header .sub-menu::before {content: ''; width: 22px; height: 22px; position: absolute; bottom: 0; right: -22px; background: radial-gradient(circle at right top,rgba(255, 255, 255, 0) 68%, #fff 73%);} */
/* .sub-header .sub-menu::after {content: ''; width: 22px; height: 22px; position: absolute; bottom: 0; left: -22px; background: radial-gradient(circle at left top,rgba(255, 255, 255, 0) 68%, #fff 73%);} */
.sub-header .sub-menu::before, .sub-header .sub-menu::after {content: ""; position: absolute; background-color: transparent; bottom: 0; height: 40px; width: 20px; box-shadow: 0 20px 0 0 #fff;}
.sub-header .sub-menu::before {left: -20px; border-bottom-right-radius: 20px;}
.sub-header .sub-menu::after {right: -20px; border-bottom-left-radius: 20px;}

.sub-header .sub-menu li a {font-family: 'Paperlogy SemiBold'; display: block; transition: color 0.2s ease-in-out;}
.sub-header .sub-menu li a:hover {color: #0249B4;}
.sub-header .sub-menu li.active a {color: #0249B4; border-bottom: 2px solid #0249B4;}
.sub-header .sub-menu li a[target="_blank"]::after {content: '\F1C5'; font-family: 'bootstrap-icons'; font-weight: bold; font-size: 16px; display: inline-block; margin-left: 5px;}


/* 스크롤 시 배경화면 축소 효과 */
body.is-scrolled .sub-header-bg::before {width: calc(100% - 40px); max-width: 1660px; height: 220px; top: auto; bottom: 0; border-radius: 20px;}
body.is-scrolled .sub-header .sub-text {top: 33%;}
body.is-scrolled .sub-header .sub-text h2::before {color: #0249B4;}
body.is-scrolled .sub-header .sub-text p {color: #7c7c7c;}


/* ----- 서브 모바일 뎁스 메뉴 ----- */
.m-sub-menu {width: 100%; background-color: #fff; display: flex; position: absolute; bottom: 0; z-index: 200; display: none;}
.m-sub-menu .depth-wrap {width: 50%; border-top: 1px solid #c3c3c3; border-bottom: 1px solid #c3c3c3; border-right: 1px solid #c3c3c3; position: relative; display: flex; align-items: center; justify-content: center;}
.m-sub-menu .depth-wrap:last-child {border-right: 0;}
.m-sub-menu .depth-wrap > a {font-family: 'Paperlogy SemiBold'; width: 100%; height: 50px; line-height: 50px; background-color: #fff; padding: 0 20px; padding-right: 45px; transition: 0.2s ease-in-out; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;}
.m-sub-menu .depth-wrap > a:hover {color: #0249B4;}
.m-sub-menu .depth-wrap > a::before {content: '\F282'; font-family: 'bootstrap-icons'; font-size: 15px; font-weight: bold; position: absolute; top: 50%; transform: translateY(-50%); right: 20px; transition: transform 0.2s ease-in-out;}
.m-sub-menu .depth-wrap > ul {position: absolute; top: 50px; left: 0; width: 100%; background-color: #eff5fc; border-radius: 0 0 15px 15px; padding: 15px 10px; display: none; word-break: keep-all;}
.m-sub-menu .depth-wrap > ul li a {font-family: 'Paperlogy Medium'; font-size: 18px; display: block; padding: 8px 10px; transition: 0.2s ease-in-out;}
.m-sub-menu .depth-wrap > ul li a:hover {color: #0249B4;}
.m-sub-menu .depth-wrap > ul li.active a {color: #0249B4;}
.m-sub-menu .depth-wrap > ul li a[target="_blank"]::after {content: '\F1C5'; font-family: 'bootstrap-icons'; font-weight: bold; font-size: 15px; display: inline-block; margin-left: 5px;}

.m-sub-menu .depth-wrap.is-open > a {background-color: #eff5fc; color: #0249B4;}
.m-sub-menu .depth-wrap.is-open > a::before{transform: translateY(-50%) rotate(180deg);}

@media (max-width: 1200px) {
    .sub-header-wrap {height: 400px;}
    body.is-scrolled .sub-header-bg::before, body.is-scrolled .sub-header-bg::after {height: 180px;}
    body.is-scrolled .sub-header .sub-text {top: 35%;}

    .sub-header .sub-text {padding-top: 10px;}
    .sub-header .sub-text h2 {font-size: 38px;}
    .sub-header .sub-text h2 span {font-size: 28px;}
    .sub-header .sub-text p {font-size: 20px;}

    .sub-header .sub-menu {padding: 15px 30px; gap: 25px; border-radius: 15px 15px 0 0; right: 70px;}
}
@media (max-width: 1024px) {
    .sub-header-wrap {height: 360px;}

    .sub-header .sub-menu {display: none;}

    .m-sub-menu {display: flex;}
}
@media (max-width: 768px) {
    .sub-header-wrap {height: 320px}
    
    .sub-header .sub-text {left: 15px; padding-right: 15px;}
    .sub-header .sub-text h2 {display: flex; flex-direction: column; gap: 5px; font-size: 30px;}
    .sub-header .sub-text h2 span {margin-left: 0; font-size: 22px;}
    .sub-header .sub-text p {font-size: 18px;}

    .m-sub-menu .depth-wrap > a {font-size: 17px; padding: 0 15px; padding-right: 35px;}
    .m-sub-menu .depth-wrap > a::before {right: 15px; font-size: 13px;}
    .m-sub-menu .depth-wrap > ul {padding: 10px 5px;}
    .m-sub-menu .depth-wrap > ul li a {font-size: 16px; padding: 6px 10px;}
}


/* ----- 서브 컨텐츠 ----- */
#subContents {max-width: 1500px; padding: 100px 20px 200px; margin: 0 auto;}

@media (max-width: 768px) {
    #subContents {padding: 50px 15px 100px;}
}


/* ----- 서브 컨텐츠 안 depth03 ----- */
.cont-tab-wrap {margin-bottom: 50px; position: relative;}
.cont-tab-wrap .cont-tab-mo {display: none; align-items: center; justify-content: space-between; width: 100%; height: 50px; padding: 0 15px; border: 1px solid #1c59a4; background: #fff; border-radius: 10px; font-family: 'Paperlogy Medium'; font-size:18px; color:#1C59A4; cursor:pointer; padding-right: 55px;}
.cont-tab-wrap .cont-tab-mo i {transition:transform 0.2s; background-color: #1C59A4; display: flex; align-items: center; justify-content: center; width: 45px; height: 100%; color: #fff; position: absolute; right: 0; border-radius: 0 10px 10px 0;}
.cont-tab-wrap .cont-tab-mo i::before {font-weight:bold !important; font-size:12px; display:flex; align-items:center; justify-content:center; transition: 0.2s ease-in-out;}
.cont-tab-wrap .cont-tab-mo.open i::before {transform:rotate(180deg);}

.cont-tab-wrap .cont-tab {display:flex; gap: 50px;}
.cont-tab-wrap .cont-tab li {width: fit-content;}
.cont-tab-wrap .cont-tab li a {display:flex; align-items:center; justify-content:center; width:100%; height:100%; position: relative; padding-top: 8px;}
.cont-tab-wrap .cont-tab li a::before {content: ''; width: 7px; height: 7px; border-radius: 50%; background-color: #1C59A4; position: absolute; top: 0; left: 50%; transform: translateX(-50%); opacity: 0; visibility: hidden; transition: 0.2s ease-in-out;}
.cont-tab-wrap .cont-tab li a::after {content: ''; width: 5px; height: 5px; border-radius: 50%; background-color: #666; position: absolute; top: 20px; left: 10px; display: none; transition: 0.2s ease-in-out;}
.cont-tab-wrap .cont-tab li.active a::before {opacity: 1; visibility: visible;}
.cont-tab-wrap .cont-tab li.active a::after {background-color: #1c59a4;}
.cont-tab-wrap .cont-tab li:hover a::after {background-color: #1c59a4;}
.cont-tab-wrap .cont-tab li a span {font-family: 'Paperlogy ExtraBold'; font-size: 25px; text-align: center; word-break: keep-all; transition:0.2s ease-in-out; color: #333;}
.cont-tab-wrap .cont-tab li:hover a span {color:#1C59A4;}
.cont-tab-wrap .cont-tab li.active a span {color:#1C59A4;}

@media (max-width: 1200px){
    .cont-tab-wrap {margin-bottom: 40px;}
    .cont-tab-wrap .cont-tab {gap: 30px;}
    .cont-tab-wrap .cont-tab li a span {font-size: 22px;}
}
@media (max-width: 768px){
    .cont-tab-wrap {margin-bottom: 30px;}
    .cont-tab-wrap .cont-tab-mo {display: flex;}
    
    .cont-tab-wrap .cont-tab {display: none; width: 100%; flex-direction: column; gap: 0; background:#EFF6FF; border-radius: 10px; padding: 6px 5px; position: absolute; top: 55px; left:0; z-index: 200;}
    .cont-tab-wrap .cont-tab li {width: 100%;}
    .cont-tab-wrap .cont-tab li a {justify-content: flex-start; padding: 6px 15px; padding-left: 25px;}
    .cont-tab-wrap .cont-tab li a::before {display: none;}
    .cont-tab-wrap .cont-tab li a::after {display: block;}
    .cont-tab-wrap .cont-tab li.active a {color:#1C59A4;}
    .cont-tab-wrap .cont-tab li a span {font-family: 'Paperlogy Medium'; font-size: 18px; text-align: left;}
    .cont-tab-wrap .cont-tab li a[target="_blank"] span::after {content: '\F1C5'; font-family: 'bootstrap-icons'; font-size: 14px; margin-left: 8px; font-weight: bold !important;}
}
@media (max-width: 500px) {
    .cont-tab-wrap .cont-tab-mo {height: 45px; font-size: 17px; border-radius: 8px; padding-right: 50px;}
    .cont-tab-wrap .cont-tab-mo i {width: 40px; border-radius: 0 8px 8px 0;}
    .cont-tab-wrap .cont-tab {top: 50px; border-radius: 8px;}
    .cont-tab-wrap .cont-tab li a {padding: 6px 12px; padding-left: 20px;}
    .cont-tab-wrap .cont-tab li a::after {left: 7px;}
    .cont-tab-wrap .cont-tab li a span {font-size: 17px;}
}