@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: 1400px;
  --container-medium-width: 1200px;
  --container-narrow-width: 1024px;
  --container-wide-width: 1400px;

  --primary: #396BFF;
  --secondary: #007FFF;

  --blue: #3982FF;
  --navy: #001BCA;

  
  --ff-primary: "Pretendard","Noto Sans JP", "맑은 고딕", 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 */
:lang(jp) body {line-break: strict; overflow-wrap: anywhere}
body {font-family: var(--ff-primary); letter-spacing: 0em;}

.primary {color: var(--primary) !important;}
.secondary {color: var(--secondary) !important;}
.blue {color: var(--blue) !important;}
.skyblue {color: #44C6FF !important;}

.bg {display: block; width: 100%; height: 100%; position: absolute; top: 0; left: 0; z-index: -1;}
.bg img {width: 100%; height: 100%; object-fit: cover;}

.pb-0 {padding-bottom: 0 !important;}
.pb-5 {padding-bottom: 50px !important;}
.pt-4 {padding-top: 40px !important;}
.pt-8 {padding-top: 80px !important;}
.mt-1 {margin-top: 10px !important;}


.pcView {display: block;}
.tabView {display: none;}
.moView {display: none;}
.pcHide {display: none;}
.tabHide {display: block;}
.moHide {display: block;}
.min {display: none;}

@media screen and (max-width: 1399px) {
  .pcView {display: none;}
  .tabView {display: block;}
  .moView {display: none;}
  .pcHide {display: block;}
  .tabHide {display: none;}
  .moHide {display: block;}
}
@media screen and (max-width: 767px) {
  .pcView {display: none;}
  .tabView {display: none;}
  .moView {display: block;}
  .pcHide {display: block;}
  .tabHide {display: block;}
  .moHide {display: none;}
}
@media screen and (max-width: 499px) {
  .min {display: block;}
  .nomin {display: none;}
}



/* Header */
.header {position: fixed; top: 0; left: 0; width: 100%; height: 100px; z-index: 9999;  transition: background 0s, transform .4s; background: rgb(0,0,0,.7); color: #fff; backdrop-filter: blur(5px); -webkit-backdrop-filter: blur(10px);}
.header-container {display: grid; grid-template-columns: 200px 1fr 200px; align-items: center; height: 100%; gap: 55px; width: 100%; padding-inline: 60px;}
.header .logo {display: flex; position: relative; width: 196px; height: 100%;}
.header .logo img {position: absolute; top: 50%; left: 0; transform: translateY(-50%); display: block; opacity: .6; transition: opacity .4s;}
.header .logo img.light {opacity: .6;}
.header .logo img.dark {opacity: 0;}

.header-gnb {display: flex; margin: 0 auto; height: 100%;}
.header-gnb-item {display: flex; align-items: stretch; position: relative;}
.header-gnb-item > a {display: flex; justify-content: center; align-items: center; text-align: center; padding-inline: 25px; font-size: 17px; font-weight: 500; color: #ACACAC; text-transform: uppercase; position: relative;}
.header-gnb-item:not(:last-child) > a::before {content: ""; width: 6px; height: 6px; border-radius: 50%; background: #ABABAB; position: absolute; right: -3px; flex-shrink: 0;}
.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;}
.header .btn--sitemap-toggle {display: none;}

.header .lang-nav {}
.header .lang-nav .lang-ls {display: flex; font-weight: 500;}
.header .lang-nav .lang-ls a {position: relative; padding-inline: 1em; color: #989898; line-height: 1; white-space: noWrap;}
.header .lang-nav .lang-ls a:not(:last-child)::after {position: absolute; top: 50%; right: 0; width: 6px; height: 6px; border-radius: 50%; background: #989898; content: ''; transform: translate(50%, -50%);}
.header .lang-nav .lang-ls a.active {color: var(--primary);}


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

.subpage .header {background: rgba(255,255,255,0.7); border-bottom: 1px solid #ededed;}
.subpage .header .logo img.light {opacity: 0;}
.subpage .header .logo img.dark {opacity: 1;}
.subpage .header-gnb-item > a {color: #000;}
.subpage .header-submenu {background: #f9f9f9; border-top: 1px solid #ededed;}
.subpage .header-submenu-item > a {color: #000;}


.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;}

  .subpage .header:has(.header-gnb-item:hover) {background: #fff;}
  .subpage .header-gnb-item:hover > a {color: var(--primary);}
  .subpage .header-submenu-item > a:hover {color: var(--primary);}
}
@media screen and (max-width: 1399px) {
  .header {height: 60px;}
  .header-container {width: min(1920px, calc(100% - 30px)); display: flex; justify-content: space-between; padding-inline: 0; gap: 0;}
  .header-gnb {display: none;}
  .header .logo {font-size: 32px;}
  .header .logo img {height: 25px; 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 .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 .btn--sitemap-toggle .bar {width: 100%; height: 2px; background: #fff; transition: .4s; border-radius: 2px;}
  .header .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: space-between; 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;}
  .sitemap-submenu-ls > .item {}
  .sitemap-submenu-ls > .item > a {display: block; padding-block: 5px; font-weight: 300;}
  .sitemap-submenu-ls > .item.active > a {color: var(--primary); font-weight: 600;}

  .sitemap-submenu-ls > .item:has(.depth2-ls) > a {display: flex; align-items: center; gap: .8em;}
  .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;}
  .sitemap-submenu-ls > .item.active .depth2-ls {display: block;}
  .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;}
  .sitemap-submenu-ls > .item .depth2-ls > li.active {color: #1b1b1b; font-weight: 500;}

  .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-etc-nav {gap: 10px;}

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


/* Footer */
.footer {background: #171717; padding:0;}
.footer .container {width: 100%; max-width: 1526px; margin: 0 auto;}

.footer .footer_cont {padding: 55px 0 80px; display: flex; gap: 0px; color:#9A9A9A;}
.footer .footer_cont .address_cont {width: 50%; font-size: 18px;}
.footer .footer_cont .sbj {width: 200px; margin-right: 100px;}
.footer .footer_cont .sbj img {opacity: .6;}
.footer .footer_cont .address_cont .address {display: flex; flex-direction: column; padding: 0px 0 50px; gap: 10px; word-break: keep-all;}
.footer .footer_cont .address_cont .address .addr b {color:#fff;}
.footer .footer_cont .address_cont .address .contact b {margin-left: 1.2em; font-weight: 400; color:#fff;}
.footer .footer_cont .address_cont .address .contact b:first-child {margin-left: 0;}
.footer .copy {font-size: 16px; color:#A8A8A8;}
.footer .address_cont .copy {display: block;}
.footer .info-cont .copy {display: none;}
.footer .footer_cont .info-cont {height: auto; display: flex; flex-direction: column; /*justify-content: space-between;*/ justify-content: flex-end; align-items: end; text-align: right; margin-left: auto; color:#818181}
.footer .footer_cont .info-cont .cert-list {padding-right: 15px; display: flex; justify-content: right; align-items: center; gap: 0;}
.footer .footer_cont .info-cont .cert-list li {padding: 0 15px; height: 100%; display: flex; align-items: center; position: relative;}
.footer .footer_cont .info-cont .cert-list li::before {content: ''; width: 1px; height: 80%; background: #707070; position: absolute; right: 0; top: 10%;}
.footer .footer_cont .info-cont .cert-list li:last-child::before {display: none;}

.footer .footer_cont .info-cont .cert-list li img {width: auto; height: 45px;}
.footer .footer_cont .info-cont .cert-list li:nth-child(4) img {height: 30px;}

.footer .info-cont .flex {margin-top: 80px;}

.footer .footer_nav.en {display: none;}
.footer .footer_nav .btn {padding:0 30px; border-right: 2px solid #707070; font-size: 17px; color:#9A9A9A;}
.footer .footer_nav .btn:first-child {padding-left: 0;}
.footer .footer_nav .btn:last-child {border-right: none;}



@media screen and (max-width: 1399px) {
  .footer .container {width: min(calc(100% - 30px), 720px);}

  .footer .footer_cont .sbj {width: 200px;}
  .footer .footer_nav .btn {font-size: 15px; padding: 0 15px;}
  .footer .footer_cont {flex-direction: column; gap: 20px;}
  .footer .footer_cont .address_cont {width: 100%;}
  .footer .footer_cont .address_cont .address {padding: 20px 0;}
  .footer .footer_cont .address_cont .address .contact {margin-top: 20px;}

  .footer .address_cont .copy {display: none;}
  .footer .footer_cont .info-cont {margin-left: 0;}
  .footer .info-cont .copy {display: block; text-align: left;}
  .footer .info-cont .flex {width: 100%; margin-top: 40px; flex-direction: row-reverse; justify-content: space-between; align-items: center;}

  .footer .footer_cont .info-cont .cert-list li img {height: 35px;}
  .footer .footer_cont .info-cont .cert-list li:nth-child(4) img {height: 30px;}
  
}

@media screen and (max-width: 767px) {
  .footer .footer_nav {display: none;}
  .footer .top_btn {width: 40px;height: 40px; margin-left: auto;}
  .footer .footer_cont .address_cont .address {font-size: 15px;}
  .footer .footer_cont .address_cont .address .contact b {margin-left: 0;}

  .footer .info-cont .flex {flex-direction: column; align-items: flex-start;}
  .footer .footer_cont .info-cont .cert-list {justify-content: start;}
  .footer .footer_cont .info-cont .cert-list li img {height: 30px;}
  .footer .footer_cont .info-cont .cert-list li:nth-child(4) img {height: 20px;}
  .footer .info-cont .copy {font-size: 14px;}
}


/* 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;}

.modal.type--image {--width: 100vw; width: auto;}
.modal.type--image .container {--padding: 0; border-radius: 10px; display: flex; overflow: visible; flex-direction: column; background: transparent; gap: 20px; width: auto; max-width: none;}
.modal.type--image .container .content {border-radius: 10px; overflow: hidden; order: 1; padding: 0; width: auto;}
.modal.type--image .container .btn--close {position: static; margin-inline: auto; order: 2;}
.modal.type--image .container .btn--close .ico--times::before,
.modal.type--image .container .btn--close .ico--times::after {background: #fff;}
.modal.type--image .image-box {width: auto; display: flex; justify-content: center; align-items: center; border: 0; padding: 0;}
.modal.type--image .modal-image {max-width: 90vw; max-height: 80vh; object-fit: contain; border-radius: 10px; width: auto; height: auto;}
.modal-trigger {cursor: pointer;}

@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;}
}

