@charset "UTF-8";


h1,h2,h3,h4,h5,h6,strong,th,.bold{font-weight:700;}
table caption {overflow:hidden;width:0;height:0;margin:0;padding:0;font-size:0;line-height:0;text-indent:-999em;}
img{border:0;max-width:100%;vertical-align:top;}

em {font-style:normal; display:block;}
.blind {position:absolute;overflow:hidden;width:0;height:0;margin:0;padding:0;font-size:0;line-height:0;}
.semibold {font-weight:600;}
img[usemap] {border:none; height:auto; max-width:100%; width:auto;}

a{
	color:inherit;
	text-decoration:none;
	-webkit-transition: all 0.2s ease-in-out;
	   -moz-transition: all 0.2s ease-in-out;
		-ms-transition: all 0.2s ease-in-out;
		 -o-transition: all 0.2s ease-in-out;
			transition: all 0.2s ease-in-out;
}
a:hover,
a:active{
	-webkit-transition: all 0.2s ease-in-out;
	   -moz-transition: all 0.2s ease-in-out;
		-ms-transition: all 0.2s ease-in-out;
		 -o-transition: all 0.2s ease-in-out;
			transition: all 0.2s ease-in-out;
}

::-webkit-input-placeholder {color:#999; font-weight:300;}
:-moz-placeholder {color:#999; font-weight:300;}
::-moz-placeholder {color:#999; font-weight:300;}
:-ms-input-placeholder {color:#999; font-weight:300;}
:placeholder-shown {color:#999; font-weight:300;}


.mgb55 {margin-bottom:55px !important;}

.f-s30 {font-size:30px; line-height:1.4em;}
.f-s60 {font-size:60px;}

.focus-color {color:#ee3b29;}
.blue-color {color:#4789e7;}


.input {height:55px; padding:4px 10px;color:#1b1b1b; background:#fff; font-size:20px; line-height:1.5em; letter-spacing:-.025em; border:1px solid #dcdcdc;}
.input[readonly] {background-color:#eee; color:#878787;}
select.input {padding-right:40px; background:#fff url('../img/bbs/select.png') right 14px center no-repeat; -webkit-appearance:none; -moz-appearance:none; appearance:none;}
select.input::-ms-expand {display:none;}
textarea.input {height:auto; padding:7px 14px; overflow:auto; resize:none;}

/* Chrome, Safari, Edge, Opera */
input::-webkit-outer-spin-button,
input::-webkit-inner-spin-button {
  -webkit-appearance: none;
  margin: 0;
}

/* Firefox  */
input[type='number'] {
  -moz-appearance: textfield;
}

.space-center {text-align:center;}

/* header */
#header {position:fixed; top:0; left:0; width:100%; transition: all 0.2s; z-index:101;}
#header .inner {position:relative; height:100px; max-width:1860px;}
.sitelogo {position:absolute; top:50%; left:20px; -ms-transform:translateY(-50%); transform:translateY(-50%); z-index:2}
.sitelogo a {display:block;}
#gnb > ul {display:flex;justify-content: center;/* margin:0 -45px;*/}
#gnb > ul > li {position: relative;}
#gnb > ul > li > a {display:block; padding:0 45px; color:rgba(21,21,21,.80); font-size:18px; line-height:100px;}
#gnb > ul > li.active > a {color:#002b60; font-weight:500;}
#gnb > ul > li > a.current {color:#002b60; font-weight:500;}

#gnb .submenu {display:none !important; position:absolute; top:100px; left:0; background:#fff; border-top:2px solid #002b60; border-radius:0 0 8px 8px; width:100%; z-index:50;}
#gnb .submenu > ul {position:relative; padding:20px 0;}
#gnb .submenu > ul > li {margin-bottom:16px; text-align:center;}
#gnb .submenu > ul > li:last-child {margin-bottom: 0;}
#gnb .submenu > ul > li > a {display:block; color:#151515;font-size:16px;line-height:1.4em; font-weight:300;}
#gnb .submenu > ul > li > a:hover {color:#002b60; font-weight:600;}
#gnb .depth3 {display:none;}


.lang {position:absolute; top:50%; -ms-transform:translateY(-50%); transform:translateY(-50%); right:20px; height:19px; width:50px; z-index:2;}
.lang .tit {display:inline-block; position:relative; width:42px; height:19px; background:url('../img/common/ico_world.png') 0 50% no-repeat;}
.lang .tit:after {content:""; position:absolute; top:50%; right:0; transform:translateY(-75%) rotate(45deg); width:6px; height:6px; border-right:1px solid #151515; border-bottom:1px solid #151515;}
.lang ul {position:absolute; top:30px; left:50%; width:70px; margin-left:-35px; display:none; background:#fff; padding:5px 0;border-radius:0 0 4px 4px; border:1px solid #dedede;}
.lang ul li a {display:block; text-align:left; padding-left:10px; font-size:14px; line-height:25px; color:#151515} 
.lang ul li a:hover {color:#002b60;}
.lang.active .tit:after {transform:translateY(-35%) rotate(-135deg);}
.lang.active ul {display:block;}


.header-fixed #header {background:#fff; border-bottom:1px solid #ddd;} 


/* for mobile */
.btn-m-menu {display:none; position:absolute; top:50%; right:20px; width:24px; height:20px; margin-top:-10px; text-align:center; z-index:50;}
.btn-m-menu span {position:absolute; left:0; right:0; top:50%; margin-top:-1px; height:2px; background:#151515;}
.btn-m-menu span:before,
.btn-m-menu span:after {content:" "; position:absolute; left:0; right:0; height:2px; background:#151515;}
.btn-m-menu span:before {top:-8px;}
.btn-m-menu span:after {bottom:-8px;}

.mobile-navigation {display:none; position:fixed; top:0; right:0; width:70%; height:100%; overflow:auto; transition:.3s ease-in-out; -ms-transform:translateX(100%); transform:translateX(100%); background:#fff; z-index:1005;}
.mobile-navigation .head {padding-left:20px;}
.mobile-navigation .head a {display:flex; align-items:center; height:60px;}
.mobile-navigation .head img {height:31px}
.mobile-navigation .nav-menu>ul>li>a {position:relative; padding:20px 20px; display:block; color:#000; font-size:20px; line-height:1.3em; border-bottom:1px solid #f5f5f5;}
.mobile-navigation .nav-menu>ul>li>a:after {content:""; position:absolute; top:50%; right:20px; transform:translateY(-75%) rotate(45deg); width:10px; height:10px; border-right:2px solid #000; border-bottom:2px solid #000;}
.mobile-navigation .nav-menu>ul>li.active>a {color:#002b60;font-weight:700; border-bottom:0; background:#f3f3f3}
.mobile-navigation .nav-menu>ul>li.active>a:after {transform:translateY(-35%) rotate(-135deg); border-color:#002b60;}
.mobile-navigation .nav-menu>ul>li:nth-child(3)>a:after,
.mobile-navigation .nav-menu>ul>li.active:nth-child(3)>a:after {transform:translateY(-50%) rotate(-45deg);}
.mobile-navigation .nav-menu>ul>li:nth-child(5)>a:after,
.mobile-navigation .nav-menu>ul>li.active:nth-child(5)>a:after {transform:translateY(-50%) rotate(-45deg);}
.mobile-navigation .nav-menu>ul>li:nth-child(6)>a:after,
.mobile-navigation .nav-menu>ul>li.active:nth-child(6)>a:after {transform:translateY(-50%) rotate(-45deg);}
.mobile-navigation .nav-menu .submenu {display:none; margin:-1px 0 0 0; padding:18px 20px; background:#fff; border-bottom:1px solid #f5f5f5;}
.mobile-navigation .nav-menu .submenu>ul>li>a {display:block; padding:6px 0; color:#000; font-size:18px; line-height:1.3em;}
.mobile-navigation .nav-menu .depth3 {display:none;}
.mobile-navigation .close {position:absolute; top:18px; right:15px; width:24px; height:24px; opacity:1;}
.mobile-navigation .close:before,
.mobile-navigation .close:after {content:" "; position:absolute; top:50%; left:0; width:100%; height:2px; background:#121212;}
.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:.6; z-index:1003}



html.menu-opened {overflow:hidden;}
html.menu-opened .mobile-navigation {-ms-transform:translateX(0); transform:translateX(0);}
html.menu-opened .mobile-overlay {display:block;}



/* footer */

#footer {font-size:16px; line-height:1.69em; background:#fff;  color:rgba(21,21,21,.60);}
.foot-info {border-top:1px solid #dedede; border-bottom:1px solid #dedede; padding:45px 0;}
.foot-info address p {font-weight: 300;}
.foot-info .foot-logo {margin-bottom:20px;}
.foot-info .bar {display:inline-block; vertical-align:middle; width:2px; height:12px; background:#151515; opacity:.43; margin:0 10px;}

.foot-copy {padding:36px 0;}
.foot-copy .inner {display:flex; align-items:center;}
.foot-copy .copy {flex:1 1 auto; min-width:0; width:1%;}
.foot-copy .btns a {display:inline-block; font-size:18px; line-height:1.69em; color:#c30d19;font-weight:700;}

.top-btn {display:none !important;}


@font-face {
    font-family: 'NEXON';
    src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_20-04@2.1/NEXON Lv1 Gothic OTF.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}

.scroll-top {position:fixed; bottom:50px; right:50px; width:94px; color:#fff;  opacity:0; z-index:-9999; transition: none;}
.scroll-top.active {position:fixed; top:auto; bottom:30px; transform:translateX(0); opacity:1; z-index:30}
.scroll-top.fixed {position:absolute; bottom:auto; top:-160px; }
.scroll-top ul li {margin-bottom:10px;}
.scroll-top ul li:last-child {margin-bottom:0;}
.scroll-top ul li a {display:flex; width:75px; height:75px; border-radius:100%; font-size:13px; line-height:1em; align-items:center; justify-content:center; text-align:center; align-content:center; flex-wrap:wrap;font-weight:700;  font-family: 'NEXON',sans-serif;}
.scroll-top ul li:nth-child(1) a {background:#c30d19;}
.scroll-top ul li:nth-child(2) a {background:#002b60;}
.scroll-top ul li .icon {width:100%; margin-bottom:5px;}
.scroll-top ul li a:not(.scroll-top-link) .icon img {width: 19px;}
.scroll-top ul li:nth-child(2) .icon {margin-bottom:10px;}
.scroll-top ul li p {width:100%}

/* 일본어 */
html:lang(ja) {
    font-family: "Maven Pro","Pretendard JP",sans-serif !important;
    font-weight: 300;
}

html:lang(ja) body {
    word-break: break-all;
}


/* 2025.06.18 스타일 수정 */

.padding-y-50px {
    padding-top: 3.125rem;
    padding-bottom: 3.125rem;
}

.padding-y-30px {
    padding-top: 1.875rem;
    padding-bottom: 1.875rem;
}

.row.none-margin {
    margin: 0 !important;
}

.gap15px {
    gap: 0.937rem;
}

.gap50px {
    gap: 3.125rem;
}

.ico {
    display: inline-block;
    font-size: 0 !important;
    text-indent: -9999px !important;
}

.ico-in { 
    width: 0.9375rem; 
    height: 0.9375rem; 
    background: url(/html/_skin/img/common/ico_in.svg) no-repeat center / contain; 
}

.ico-youtube { 
    width: 1.375rem; 
    height: 1rem; 
    background: url(/html/_skin/img/common/icon_youtube.svg) no-repeat center / contain;  
    top: 1px; 
    position: relative;
}

.ico-insta { 
    width: 1.1875rem; 
    height: 1.1875rem; 
    background: url(/html/_skin/img/common/ico_insta.svg) no-repeat center / contain; 
}

.ico-face { 
    width: 0.5rem; 
    height: 1rem; 
    background: url(/html/_skin/img/common/ico_face.svg) no-repeat center / contain; 
}

.btn {
    display: -ms-flexbox !important;
    display: flex !important;
    -ms-flex-align: center !important;
    align-items: center !important;
    -ms-flex-pack: center !important;
    justify-content: center !important;
    -moz-transition: all 0.3s ease;
    -o-transition: all 0.3s ease;
    -webkit-transition: all 0.3s ease;
    transition: all 0.3s ease;
    border-radius: 0px;
}

.ft-view-more { 
    height: 2.625rem;
    width: 11.25rem;
    padding: 0.3125rem 1.125rem;
    border: 1px solid #151515;
    font-weight: 300 !important;
    font-size: 1rem !important;
}

.ft-view-more.jp {
    width: 14.6875rem;
}

.ft-view-more span {
    width: 100%;
    text-align: left;
    background: url(/html/_skin/img/common/ico_view_more.svg) no-repeat right center / 1.375rem;
}

.ft-view-more:hover {
    background: #002b60;
    border-color: #002b60;
}

.ft-view-more:hover span {
    color: #fff;
    background-image: url(/html/_skin/img/common/ico_view_more_w.svg);
}

#header .inner {
    width: 100%;
    max-width: 100%;
    padding: 0 3.125rem;
}



.lang .tit {
    background-image: url(/html/_skin/img/common/ico_world.svg);
    background-size: 1.1875rem;
}

#footer {
    font-size: 1.125rem !important;
}

#footer .footer-tp, 
#footer .footer-btm {
    border-top: 1px solid #dedede;
    border-bottom: none;
    text-align: left;
}

#footer .footer-tp .infos {
    margin-top: 1.25rem;
    color: rgba(21, 21, 21, 0.8) !important;
    font-weight: 300 !important;
    font-size: 1.125rem !important;
}

#footer .footer-btm.foot-copy .inner > .row  {
    width: 100%;
}

#footer .footer-btm.foot-copy .copy {
    width: fit-content;
}
#footer .footer-btm.foot-copy .btns a { 
    padding: 0;
}

@media (min-width: 1200px) {
    #header .inner {
        height: 5rem;
    }

    #gnb > ul > li > a {
        height: 5rem;
    }

    .lang {
        height: 1.1875rem;
        width: 3.125rem;
    }

    .lang .tit {
        width: 2.625rem;
        height: 1.1875rem;
    }
}

@media (max-width: 1199px) {
    .padding-y-50px {
        padding-top: 2.5rem;
        padding-bottom: 2.5rem;
    }
}

@media (max-width: 767px) {
    .padding-y-50px {
        padding-top: 1.875rem;
        padding-bottom: 1.875rem;
    }

    .padding-y-30px {
        padding-top: 1.5rem;
        padding-bottom: 1.5rem;
    }

    .gap50px {
        gap: 2.5rem;
    }
}

@media (max-width: 480px) {
    .main-news .main-more {
        position: relative !important;
        width: fit-content !important;
        right: initial !important;
        top: initial !important;
        margin-bottom: 1.25rem;
    }
}