@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: 1420px;

  --primary: #005DFF;
  --primary-dark: #0040B2;
  --primary-light: #0088FF;

  --secondary: #FFA500;
  --secondary-dark: #CC8400;
  --secondary-light: #FFDAB9;

  --cyan: #00B5C2;
  --cyan-dark: #0094A0;
  --cyan-light: #00D9E9;

  --gray: #a0a0a0;
  --gray-dark: #707070;
  --gray-light: #dedede;
  --gray-lighter: #f3f2f1;

  
  --font-primary: "Pretendard", "맑은 고딕", sans-serif;
  --font-secondary: 'Poppins', var(--font-primary);
  --font-tertiary: 'Orbitron', var(--font-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(--font-primary); letter-spacing: 0em;}

.fc--primary {color: var(--primary);}
.fc--primary-dark {color: var(--primary-dark);}
.fc--primary-light {color: var(--primary-light);}

.fc--secondary {color: var(--secondary);}
.fc--secondary-dark {color: var(--secondary-dark);}
.fc--secondary-light {color: var(--secondary-light);}

.fc--cyan {color: var(--cyan);}
.fc--cyan-dark {color: var(--cyan-dark);}
.fc--cyan-light {color: var(--cyan-light);}

/* Header */
.header {position: fixed; top: 0; left: 0; width: 100%; height: 94px; z-index: 9999; transition: background 0s, transform .4s; background: rgb(0,0,0,.4); color: #fff; backdrop-filter: blur(4px);}
.header-container {display: grid; grid-template-columns: 180px 1fr 180px; align-items: center; height: 100%; gap: 55px; width: 100%; 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; 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-weight: 500; text-transform: uppercase; font-size: 20px; position: relative;}

.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(--font-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-lang-nav {}
.header-lang-nav .lang-ls {display: flex; font-weight: 500; text-transform: uppercase; font-family: var(--font-secondary);}
.header-lang-nav .lang-ls a {position: relative; padding-inline: 0.6em; color: #dbdbdb; line-height: 1;}
.header-lang-nav .lang-ls a:not(:last-child)::after {position: absolute; top: 50%; right: 0; width: 2px; height: 0.8em; background: #989898; content: ''; transform: translate(50%, -50%);}
.header-lang-nav .lang-ls a.active {color: white;}

.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--scrolled .header-lang-nav .lang-ls a.active {color:var(--primary-light);}
}



@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)); 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: 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 0px;}
  .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 {font-weight: 500;}

  .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;}
  .header .logo {height: 20px;}

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


.mainpage .footer .footer-cont .address-cont .address b {color:#B3001A;}
.mainpage .footer .footer-cont .inquiry-cont .inquiry .sbj {color:#B3001A;}


.footer {background: #373737; }
.footer .footer-bar {background:#0E0E0E;height: 64px;}
.footer .footer-bar .container--wide {display: flex; justify-content: space-between;}
.footer .footer-bar .footer-nav {padding: 20px 0;}
.footer .footer-bar .footer-nav .btn {padding:0 30px; border-right: 1px solid #707070; font-size: 17px; color:#D4D4D4;}
.footer .footer-bar .footer-nav .btn:first-child {padding-left: 0;}
.footer .footer-bar .footer-nav .btn:last-child {border-right: none;}
.footer .footer-bar .top-btn {width: 64px; height: 64px; background: var(--primary); display: flex; align-items: center; justify-content: center; border-radius: 0; transform: translateX(64px); cursor: pointer;}
.footer .footer-bar .top-btn .icon {}
.footer .footer-bar .top-btn .icon svg {display: block;}
.footer .footer-cont {padding: 55px 0 80px; display: flex; gap: 100px; justify-content: space-between; color:#D4D4D4;}
.footer .footer-cont .address-cont {width: 50%;}
.footer .footer-cont .address-cont .address {display: flex; flex-direction: column;padding: 14px 0 16px; font-size: 17px; gap: .5em;}
.footer .footer-cont .address-cont .address .addr {}
.footer .footer-cont .address-cont .address .contact {display: flex; gap: .5em;}
.footer .footer-cont .address-cont .address b {margin: 0.5em; color:var(--primary-light);}
.footer .footer-cont .address-cont .address b:first-child {margin-left: 0;}
.footer .footer-cont .address-cont .copy {font-size: 14px; color:#A8A8A8;}
.footer .footer-cont .inquiry-cont {display: flex; gap: 24px;align-items: flex-end; width: 50%; justify-content: flex-end;}
.footer .footer-cont .inquiry-cont .logo-text {font-size: 26px; color:rgba(212, 212, 212, 0.27); text-align: right;   width: auto; font-family: var(--font-secondary); text-transform: uppercase; font-weight: 700;}
.footer .footer-cont .inquiry-cont .inquiry {display: flex; flex-direction: column;padding-inline:40px;  border-left: 1px solid #707070;border-right: 1px solid #707070;}
.footer .footer-cont .inquiry-cont .inquiry .sbj {font-size:17px; color:var(--primary-light);font-weight: 700; padding-bottom: .5em;}
.footer .footer-cont .inquiry-cont .inquiry .tel {font-size: 33px;line-height: 1.5; color:#fff;}
.footer .footer-cont .inquiry-cont .inquiry .hours {font-size: 14px;line-height: 1.8; padding-top: 1em;}
.footer .footer-bar .top-btn:hover {opacity: 0.8;}
.footer .copy.mo-copy {display: none;}





@media screen and (max-width: 1600px) {
  .footer .footer-bar .top-btn {transform: none;}
}
@media screen and (max-width: 1399px) {
  .footer .footer-cont {flex-direction: column; gap: 20px; padding-block: 40px 60px;}
  .footer .footer-cont .address-cont,
  .footer .footer-cont .inquiry-cont {width: 100%;}
  .footer .footer-bar .footer-nav .btn {padding:0 15px;}
}
@media screen and (max-width: 767px) {
  .footer .footer-bar,
  .footer .footer-bar .footer-nav {display: none;}
  .footer .footer-cont {padding-block: 50px;}
  .footer .footer-cont .address-cont {order: 2;}
  .footer .footer-cont .address-cont .address {font-size: 15px; gap: 0;}
  .footer .footer-cont .address-cont .address .contact {flex-direction: column; gap: 0;}
  .footer .footer-cont .inquiry-cont {flex-direction: column; align-items: flex-start; order: 1;}
  .footer .footer-cont .inquiry-cont .logo-text {text-align: left; line-height: 1.1;}
  .footer .footer-cont .inquiry-cont .inquiry .hours {padding-top: 0.5em;}
  .footer .footer-cont .inquiry-cont .inquiry {padding-inline: 0; border: none;}
  .footer .footer-cont .inquiry-cont .inquiry .sbj {font-size: 16px;}
  .footer .footer-cont .inquiry-cont .inquiry .tel {font-size: 24px;}
}


.application .ing {position: relative; width:100%; padding-block:80px; display: flex; align-items: center; justify-content: center; background: #f3f3f3; border-radius: 20px; flex-direction: column; gap: 20px;}
.application .ing .loading {width: 130px;}
.application .ing .tit {font-size: 50px;}
.application .ing .desc {font-size: 20px; text-align: center; line-height: 1.4;}

@media screen and (max-width: 1399px) {
  .application .ing {padding-block:80px;}
  .application .ing .tit {font-size: 30px;}
  .application .ing .desc {font-size: 17px;}
}
@media screen and (max-width: 767px) {
  .application .ing {padding-block:44px;}
  .application .ing .loading {width: 60px;}
  .application .ing .tit {font-size: 20px;}
  .application .ing .desc {font-size: 14px;}
  
}