@charset "utf-8";
@import url('./defaults/reset.css?ver=240126');
@import url('./defaults/utils.css?ver=240126');
@import url('./defaults/board.css?ver=240126');
@import url('./defaults/popup.css?ver=240126');
@import url('./defaults/ckeditor5.css?ver=240126');
@import url('./defaults/scroll-ani-transition.css?ver=240126');

#sian-nav {position:fixed;top: 120px;right: 0;z-index: 9999999999;}
#sian-nav a {display: block; font-size: 14px; background-color: #666; color: #fff; line-height: 30px; padding: 0 10px; border-radius: 5px 0 0 5px; margin-bottom: 2px; transition: background-color 0.3s;  min-width: 80px;}
#sian-nav a:hover {background-color: #999;}
#sian-nav a.active {background-color: #FC6262; color: #fff;font-weight: 700;}

/* ** 전역적으로 사용될 변수 스타일을 작성합니다. */
:root {
  --container-width: 1200px;
  --container-medium-width: 1100px;
  --container-narrow-width: 1024px;
  --container-wide-width: 1400px;

  --primary: #0045FF;
  --secondary: #0030B1;

  
  --ff-primary: "Pretendard", "맑은 고딕", sans-serif;
  --ff-secondary: 'Poppins', var(--ff-primary);
  
  --cubic-pop1: cubic-bezier(.85,.14,.29,.99);
  --cubic-pop2: cubic-bezier(.71,.45,.36,1.31);
  --cubic-pop3: cubic-bezier(.85,.14,.29,.99);
  
  --scrollbar-color: var(--primary);
}

/* Base assets */
body {font-family: var(--ff-primary); letter-spacing: 0em;}

.fc-primary {color: var(--primary) !important;}
.fc-secondary {color: var(--secondary) !important;}


/* Header */
.header {position: fixed; top: 0; left: 0; width: 100%; height: 90px; z-index: 9999; font-family: var(--ff-secondary); transition: background 0s, transform .4s; background: rgb(0,0,0,0.8); color: #fff; backdrop-filter: blur(10px); -webkit-backdrop-filter: blur(10px);}
.header-container {display: grid; grid-template-columns: 300px 1fr 200px; align-items: center; height: 100%; gap: 10px; width: 100% !important; padding-inline: 60px;}
.header .logo {display: flex; position: relative; font-size: 42px;}
.header .logo img {display: block; transition: opacity .4s;}
.header .logo img.light {opacity: 1;}
.header .logo img.dark {position: absolute; top: 0; left: 0; opacity: 0;}

.header-gnb {display: flex; height: 100%; justify-content: flex-end; width: 100%;}
.header-gnb-item {display: flex; align-items: stretch; position: relative;}
.header-gnb-item > a {position: relative; display: flex; justify-content: center; align-items: center; text-align: center; padding-top: 10px; padding-inline: 37px; font-weight: 500; text-transform: uppercase; font-size: 16px; position: relative;}
.header-gnb-item > a:before {content: ''; position: absolute; left:100%; width: 6px; height: 6px; background: #808080;border-radius: 50%; }
.header-gnb-item:last-child > a:before {display: none;}


.header-submenu {position: absolute; top: 100%; left: 50%; transform: translate(-50%, 0px); padding: 20px 15px; background: black; border-block: 1px solid rgb(255,255,255,0.3); border-radius: 0px; overflow: hidden; box-shadow: 0 5px 10px rgb(0,0,0,.05); color: #303030; width: 200vw; height: auto; padding-block: 10px; min-width: 180px; opacity: 0; transition: transform .5s var(--easing1), opacity .5s var(--easing1); text-align: center; pointer-events: none; font-family: var(--ff-primary); display: flex; justify-content: center; color: white;}
.header-submenu-item > a {display: block; padding: 0.5em 20px; color: rgb(255,255,255,.7);}

.header-etc-nav {display: flex; justify-content: flex-end; align-items: center; gap: 25px; padding-top: 10px;}

.header-lang-nav {}
.header-lang-nav .lang-ls {display: flex; font-weight: 500; text-transform: uppercase; font-family: var(--ff-secondary); font-size: 14px; width: 71px;border-radius: 50px; background: var(--primary);transition: .3s ease;}
.header-lang-nav .lang-ls a {position: relative;  color: #c0c0c0; line-height: 1; opacity: 0; width: 0; display: flex; align-items: center; justify-content: center; transition: .3s ease;}
.header-lang-nav .lang-ls a.active {color: white; opacity: 1; width: 100%;padding: 0.6em;}

.header-dropdown {--rounded: 0px; --theme-1: var(--secondary); color: var(--theme-1); position: relative; font-size: 15px;}
.header-dropdown .trigger {padding: 0 1em 0 1em; border: 1px solid var(--theme-1); border-radius: var(--rounded); transition: color .4s, border .4s, background .4s; display: flex; align-items: center; justify-content: space-between; gap: 1em; height: 40px; text-transform: uppercase; background: rgb(0,0,0,0.5); font-weight: 600;}
.header-dropdown .trigger .arrow {border-color: var(--theme-1); margin-top: -3px; width: 10px; height: 10px; transition: color .4s, border .4s, background .4s;}
.header-dropdown ul {position: absolute; top: 100%; left: 0; width: 100%; border: 1px solid var(--theme-1); border-bottom-left-radius: var(--rounded); border-bottom-right-radius: var(--rounded); padding-block: 0.5em; border-top: none; display: none; background: rgb(0,0,0,0.5); transition: color .4s, border .4s, background .4s;}
.header-dropdown ul > li {}
.header-dropdown ul > li > a {display: flex; align-items: center; padding-inline: 1em; padding-block: 0.3em; line-height: 1; font-weight: 500; transition: color .4s, border .4s, background .4s; gap: 0.5em;}
.header-dropdown ul > li > a img {width: 1.4em; height: 1.4em; border-radius: 50%; object-fit: cover;}
.header-dropdown:hover .trigger {border-bottom-left-radius: 0; border-bottom-right-radius: 0;}
.header-dropdown:hover ul {display: block;}
.header-dropdown ul > li > a:hover {color: var(--sub-color1);}


/* Header 상태관리 */
.header--scrolled {background: black;}
.header--hide {transform: translate(0, -100%);}

.header:not(.header--scrolled) {}
.header:not(.header--scrolled) .logo img.dark {opacity: 0;}
.header:not(.header--scrolled) .logo img.light {opacity: 1;}

.sitemap {display: none;}

@media (hover: hover) {
  .header:has(.header-gnb-item:hover) {background: black;}
  .header .header-gnb:has(.header-gnb-item:hover) .header-gnb-item:not(:hover) > a {opacity: 0.4;}
  .header .header-gnb-item:hover > a {opacity: 1;}
  .header-gnb-item:hover .header-submenu {opacity: 1; pointer-events: initial;}
  .header-submenu-item > a:hover {font-weight: 700; color: var(--primary);}
  .header-lang-nav > a:not(.active):hover {opacity: .7;}

  .header-lang-nav .lang-ls:hover {width: 90px;}
  .header-lang-nav .lang-ls:hover a {width: 100%; opacity: 1; padding-block: 0.6em;}

}
@media screen and (max-width: 1399px) {
  .header {height: 60px; background: #fff; border-bottom: 1px solid #dfdfdf; color: #333!important;}
  .header-container {width: min(1920px, calc(100% - 30px)) !important; display: flex; justify-content: space-between; padding-inline: 0; gap: 0;}
  .header-gnb {display: none;}
  .header .logo {font-size: 32px;}
  .header .logo img {height: 100%; width: auto;}
  .header .logo .light {opacity: 0!important;}
  .header .logo .dark {opacity: 1!important;}

  .header-etc-nav {gap: 25px; padding: 0;}
  .header-etc-nav .btn--sitemap-toggle {display: flex;}
  .header-lang-nav {display: none;}
  .header .header-dropdown {display: none;}

  .header-etc-nav .btn--sitemap-toggle {display: flex; flex-direction: column; justify-content: center; gap: 3px; border: none; outline: none; box-shadow: none; appearance: none; width: 45px; height: 30px; border-radius: 10px; padding: 10px 12px; cursor: pointer; position: relative; overflow: hidden; background: var(--primary);}
  .header-etc-nav .btn--sitemap-toggle .bar {width: 100%; height: 2px; background: #fff; transition: .4s; border-radius: 2px;}
  .header-etc-nav .btn--sitemap-toggle .bar {background: #fff;}

  .sitemap {display: block; position: fixed; top: 0; left: 0; z-index: 9998; width: 100%; height: calc(var(--vh, 1vh) * 100); pointer-events: none;}
  .sitemap-dim {position: absolute; top: 0; left: 0; width: 100%; height: 100%; background: rgb(0,0,0,.6); backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(5px); opacity: 0; transition: opacity .5s;}
  .sitemap-container {position: absolute; z-index: 10; top: 0; right: 0; width: 100%; max-width: 520px; height: 100%; background: #fff; overflow: hidden auto; --padding-inline: 30px; transform: translate(100%); opacity: 0; transition: opacity .5s, transform .5s; padding-top: 80px;}
  .sitemap-container .body {padding-block: 20px;}
  .sitemap-container .body .block {padding-inline: var(--padding-inline); padding-block: 15px;}

  body.sitemap--open .sitemap {pointer-events: initial;}
  body.sitemap--open .sitemap-dim {opacity: 1;}
  body.sitemap--open .sitemap-container {opacity: 1; transform: translate(0);}

  .sitemap-gnb {}
  .sitemap-gnb-item {padding-block: .7em;}
  .sitemap-gnb-item:not(:last-child) {border-bottom: 1px solid #ededed;}
  .sitemap-gnb-item .trigger {display: flex; align-items: center; justify-content: center; font-size: 22px; font-family: var(--sub-font1);}
  .sitemap-gnb-item .trigger .ico--plus {width: 1em; height: auto; aspect-ratio: 1 / 1; display: none;}
  .sitemap-gnb-item .trigger .ico--plus::before,
  .sitemap-gnb-item .trigger .ico--plus::after {background: #afafaf; border-radius: 2px;}
  .sitemap-gnb-item .trigger .ico--plus::before {width: 2px;}
  .sitemap-gnb-item .trigger .ico--plus::after {height: 2px;}
  .sitemap-gnb-item.active .trigger {font-weight: 700;}
  .sitemap-gnb-item.active .trigger .ico--plus::before {display: none;}
  .sitemap-gnb-item.active .trigger .ico--plus::before,
  .sitemap-gnb-item.active .trigger .ico--plus::after {background: var(--secondary);}

  .sitemap-submenu {display: none; margin-block: 10px; padding: 0 0 20px 5px;}
  .sitemap-gnb-item.active .sitemap-submenu {display: block;}
  .sitemap-submenu-ls {font-size: 20px; text-align: center;}
  .sitemap-submenu-ls > .item {}
  .sitemap-submenu-ls > .item > a {display: block; padding-block: 5px; font-weight: 300;}
  .sitemap-submenu-ls > .item.active > a {font-weight: 600;}

  .sitemap-submenu-ls > .item:has(.depth2-ls) > a {display: flex; align-items: center; gap: .8em; justify-content: center;}
  .sitemap-submenu-ls > .item:has(.depth2-ls) > a::after {width: .3em; aspect-ratio: 1 / 1; border-top: 1px solid #dfdfdf; border-right: 1px solid #dfdfdf; transform: rotate(45deg); content: ''; display: block; transition: transform .4s;}
  .sitemap-submenu-ls > .item:has(.depth2-ls).active > a::after {transform: translate(0, -25%) rotate(135deg);}
  .sitemap-submenu-ls > .item .depth2-ls {display: none; font-size: 0.9em; padding: 5px 0 40px 0; text-align: center;}
  .sitemap-submenu-ls > .item.active .depth2-ls {display: block; background: #f8f8f8; padding: 5px 10px; border-radius: 10px;}
  .sitemap-submenu-ls > .item:last-child .depth2-ls {padding-bottom: 0;}
  .sitemap-submenu-ls > .item .depth2-ls > li > a {display: block; padding-block: 8px; line-height: 1; text-align: center;}
  .sitemap-submenu-ls > .item .depth2-ls > li.active {color: #1b1b1b; font-weight: 700;}

  .sitemap-lang {display: flex; font-size: 18px;}
  .sitemap-lang a {display: flex; align-items: center; color: #909090; text-transform: uppercase;}
  .sitemap-lang a.active {color: var(--primary); font-weight: 600;}
  .sitemap-lang a:not(:last-child)::after {width: 1px; height: .7em; content: ''; background: #dfdfdf; margin: 0 .6em;}
}
@media screen and (max-width: 767px) {
  .header {height: 50px;}
  .header .logo {width: 80px;}
  .header-etc-nav {gap: 10px;}

  .sitemap-container {--padding-inline: 20px;}
}



/* Footer */
@media screen and (max-width: 1399px) {}
@media screen and (max-width: 767px) {}


/* Modal */
.modal {--width: 890px; position: fixed; top: 0; left: 0; width: 100%; height: 100vh; z-index: 999999; align-items: center; justify-content: center; padding: 50px 15px; display: none; opacity: 0;  background: rgb(0,0,0,.7); -webkit-backdrop-filter: blur(5px); backdrop-filter: blur(5px);}
.modal-small {--width: 652px;}
.modal .dim {position: absolute; top: 0; left: 0; width: 100%; height: 100%;}
.modal .container {--padding: 70px 60px; width: var(--width)!important; max-width: 100%; position: relative; z-index: 1; background: #fff; overflow: hidden auto; max-height: 100%; border-radius: 10px;}
.modal .container .head {position: sticky; top: 0; left: 0; width: 100%; padding: var(--padding); padding-bottom: 30px; background: #fff; z-index: 10;}
.modal .container .btn--close {position: absolute; top: 20px; right: 20px;}
.modal .container .btn--close .ico--times::before {background: #000;}
.modal .container .btn--close .ico--times::after {background: #000;}
.modal .container .content {padding: var(--padding); padding-top: 0;}

.modal.overflow {overflow: hidden auto; align-items: flex-start;}
.modal.overflow .dim {background: none; backdrop-filter: none;}
.modal.overflow .container {overflow: visible; max-height: none;}
.modal.overflow .container .head {top: -50px; border-radius: 10px 10px 0 0; padding-block: 50px 20px; padding-right: 60px; border-bottom: 1px solid var(--gray-lighter);}
.modal.overflow .container .content {padding-top: 20px;}

.modal-brand-notice {--width: 500px;}
.modal-brand-notice.active {opacity: 1; display: flex;}
.modal-brand-notice .container .head {padding-block: 50px 20px;}
.modal-brand-notice .container .content .title {margin-bottom: 0.6em;}

.modal.type--video {--width: 1000px;}
.modal.type--video .container {--padding: 0; border-radius: 0; display: flex; overflow: visible; flex-direction: column; background: transparent; gap: 20px;}
.modal.type--video .container .content {border-radius: 10px; overflow: hidden; order: 1;}
.modal.type--video .container .btn--close {position: static; margin-inline: auto; order: 2;}
.modal.type--video .container .btn--close .ico--times::before,
.modal.type--video .container .btn--close .ico--times::after {background: #fff;}

@media screen and (max-width: 1399px) {
  .modal .container {--padding: 70px 30px;}
  .modal.overflow .container .head {padding-block: 20px;}
}
@media screen and (max-width: 767px) {
  .modal .container {--padding: 70px 15px;}
  .modal.type--video {padding-inline: 0;}
  .modal.type--video .container {--padding: 0; max-height: none;}
}


/* Policy */
.policy-doc {padding: 30px; border-radius: 10px; background: #FCFCFC; border: 1px solid #E8E8E8; font-size: 16px;}
.policy-doc dl {word-break: break-all;}
.en .policy-doc dl {word-break: normal;}
.policy-doc dt {display: block; font-weight: 700; color: var(--dark-navy); margin-bottom: 0.3em;}
.policy-doc dd {margin-bottom: 1.5em;}
.policy-doc dd :where(h1, h2, h3, h4, h5, h6) {color: var(--dark-navy); margin-bottom: 0.3em;}
.policy-doc dd .indent {padding-left: 1em;}
.policy-doc dd p {margin-bottom: 0.5em;}
.policy-doc dd table {width: 100%; font-size: 13px;}
.policy-doc dd table :where(th, td) {border: 1px solid var(--gray-lighter); padding: .3em .5em; line-height: 1.5;}
.policy-doc dd table thead th {background: var(--gray-light);}
.policy-doc .bullet > li::before {background: var(--primary);}
.policy-doc ol {margin-block: 1em;}
.policy-doc ol > li:not(:last-child) {margin-bottom: 0.7em;}

@media screen and (max-width: 1399px) {
  .policy-doc {padding: 30px 20px; font-size: 15px;}
}
@media screen and (max-width: 767px) {
  .policy-doc {padding: 25px 15px; font-size: 14px;}
  .policy-doc dd .indent {padding-left: 0em;}
}



/* footer */

.footer {background: #1D1D1D; color: #DBDBDB;}
.footer .container {position: relative; display: flex; gap: 5rem; padding: 60px 0 90px 0;}
.footer .footer-nav {border-bottom: 1px solid #525252;}
.footer .footer-nav .container {padding: 0; gap: 0; display: flex; justify-content: space-between; align-items: center;}
.footer .footer-nav .container .top_btn{background: #0045FF; padding-block: 20px; padding-inline: 24px;}
.footer .footer-nav .btn {font-size: 16px; font-weight: 700; color:#9A9A9A; border-right: 1px solid #656565; padding-right: 1rem;}
.footer .footer-nav .btn:last-child {border:none; padding: 0; padding-left: 1rem;}
.footer .top-button {position: absolute; top: 0; left: 100%; transform: translate(0, -50%);}
.footer-col-head {}
.footer-col-head .footer-logo {margin-top: -10px; width: 190px;}
.footer-col-head .family-site-dropdown {background: none;}
.footer-col-head .family-site-dropdown .trigger {background: #272727;}
.footer-col-head .family-site-dropdown ul {background: #272727; bottom: 100%; top: auto; border-bottom: none; border-top: 1px solid var(--secondary);}
.footer-col-body {padding-top: 20px;}
.footer-col-body address {font-size: 22px; font-style: normal; font-weight: 500; margin-bottom: 20px;}
.footer-col-body .slogan {display: block; opacity: 0.5; font-weight: 400; margin-bottom: 1em;}
.footer-col-body .copyright {font-size: 14px; font-weight: 500; color: #858585;}
.footer-col-foot {margin-left: auto; padding-top: 15px; flex-shrink: 0;}
.footer-col-foot ul > li {max-width: 300px; padding-block: 10px; border-bottom: 1px solid #656565; display: grid; grid-template-columns: 60px 1fr; align-items: center; gap: 22px; padding-left: 10px;}
.footer-col-foot ul > li:first-child {padding-top: 0; }
.footer-col-foot ul > li:last-child {padding-bottom: 0; border-bottom: none;}
.footer-col-foot ul > li .tag {color: var(--primary); font-weight: 700; text-transform: uppercase;}
.footer-col-foot ul > li .val {font-size: 22px; color: white;}

@media screen and (max-width: 1399px) {
  .footer .container {gap: 10px; padding-block: 50px;}
  .footer > .container {display: grid;}
  .footer .footer-nav .container {flex-direction:row;}
  .footer-col-head {grid-column: span 2;}
  .footer-col-head .footer-logo {width: auto;}
  .footer-col-body {padding-top: 8px;}
  .footer-col-body address {font-size: 16px;}
  .footer-col-foot {margin-left: 0; padding-top: 0;}
  .footer-col-foot ul > li {font-size: 14px; display: flex;}
  .footer-col-foot ul > li .tag {flex-shrink: 0;}
  .footer-col-foot ul > li .val {font-size: inherit;}
  .footer .top-button {left: auto; right: 0;}
  .footer-col-body .slogan {margin-bottom: 0.5rem;}
}
@media screen and (max-width: 767px) {
  .footer .container {grid-template-columns: repeat(1, 1fr); gap: 20px;}
  .footer-col-head {grid-column: span 1;}
  .footer-col-head .footer-logo {width: 120px; margin-bottom: 0px;}
  .footer-col-body {padding-top: 0px; }
  .footer-col-body address {font-size: 14px; margin-bottom: 12px;}
  .footer-col-body .slogan {font-size: 14px;}
  .footer-col-foot {grid-column: span 1;}
  .footer-col-foot ul > li {font-size: 14px; padding-left: 0;}
  .footer .footer-nav .btn {font-size: 14px;}
  .footer .footer-nav .container {padding-block: 15px;}
}

@media screen and (max-width: 409px) {
  .footer-col-body address {font-size: 13px;}
}
