:root { accent-color: #0fa5aa; }

.header { position: fixed; top: 0; left: 0; z-index: 999; width: 100%; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; padding: 20px 0; -webkit-transition: background ease 0.3s; transition: background ease 0.3s; }
.header > .inner { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; width: 100%; height: 40px; }
.header .header__logo { width: 165px; }
.header .header__logo p { display: none; }
.header.active { background-color: rgba(17, 17, 17, 0.25); -webkit-backdrop-filter: blur(17px); backdrop-filter: blur(17px); }
.header.sub .i18n,
.header.active .i18n { border-color: #fff; }
.header.sub .gnb button.gnb__depth1::after,
.header.active .gnb button.gnb__depth1::after { -webkit-filter: brightness(10); filter: brightness(10); }

.gnb { position: absolute; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); }
.gnb ul { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; }
.gnb ul > li { position: relative; }
.gnb ul > li:not(:last-child) { margin-right: 56px; }
.gnb .gnb__depth1 { color: #fff; font-size: 20px; font-weight: 500; }
.gnb button.gnb__depth1 { position: relative; padding-right: 18px; }
.gnb button.gnb__depth1::after { content: ''; position: absolute; top: 55%; right: 0; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 10px; height: 10px; background-image: url(/assets/images/common/gnb_arrow.svg); background-repeat: no-repeat; background-size: 100%; background-position: center; -webkit-transition: -webkit-transform ease 0.3s; transition: -webkit-transform ease 0.3s; transition: transform ease 0.3s; transition: transform ease 0.3s, -webkit-transform ease 0.3s; }
.gnb button.gnb__depth1.active::after { -webkit-transform: translateY(-50%) rotate(-180deg); transform: translateY(-50%) rotate(-180deg); }

.gsnb { position: absolute; z-index: 99; top: 45px; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); width: 220px; background-color: #fff; -webkit-box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-orient: vertical; -webkit-box-direction: normal; -ms-flex-direction: column; flex-direction: column; text-align: center; border-radius: 24px; padding: 16px 0; display: none; }
.gsnb > a { height: 45px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; font-size: 20px; font-weight: 600; -webkit-transition: color ease 0.3s; transition: color ease 0.3s; }
.gsnb > a:hover { color: #11b7bd; }

.i18n { position: relative; border: 1px solid #78829d; border-radius: 2em; margin-left: auto; margin-right: 12px; cursor: pointer; }
.i18n > button { color: #fff; padding-right: 18px; position: relative; width: 80px; height: 40px; }
.i18n > button::after { content: ''; position: absolute; top: 48%; right: 16px; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 10px; height: 10px; background-image: url(/assets/images/common/gnb_arrow.svg); background-repeat: no-repeat; background-size: 100%; background-position: center; -webkit-filter: brightness(10); filter: brightness(10); -webkit-transition: all ease 0.3s; transition: all ease 0.3s; }
.i18n > button.active::after { -webkit-transform: translateY(-50%) rotate(-180deg); transform: translateY(-50%) rotate(-180deg); }
.i18n .i18n__list { position: absolute; top: 50px; width: 100%; background-color: #fff; border-radius: 1em; display: none; z-index: 99; -webkit-box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); }
.i18n .i18n__list > a { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; height: 40px; color: #000; }
.i18n .i18n__list > a.active { color: #888; }

.header__contact { padding: 0 16px; background-color: #fff; font-size: 16px; font-weight: 600; color: #072148; border-radius: 2em; height: 40px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; -webkit-transition: all ease 0.3s; transition: all ease 0.3s; }
.header__contact:hover { background-color: #11b7bd; color: #fff; }

.footer { background-color: #072148; padding: 80px 0 32px; }
.footer .inner { display: -webkit-box; display: -ms-flexbox; display: flex; -ms-flex-wrap: wrap; flex-wrap: wrap; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; }
.footer-info .regi { color: #fff; font-size: 18px; font-weight: 400; margin-top: 12px; opacity: 0.5; }
.footer-info .footer-info__logo { width: 165px; display: block; }
.footer-info .footer-info__logo p { display: none; }
.footer-info ul { margin-top: 24px; }
.footer-info ul > li { font-size: 18px; color: #fff; padding-left: 30px; background-repeat: no-repeat; background-position: left center; }
.footer-info ul > li > a { font-size: 18px; color: #fff; }
.footer-info ul > li:not(:last-child) { margin-bottom: 12px; }

.footer-links li { display: -webkit-box; display: -ms-flexbox; display: flex; align-items: center; }
.footer-links li:not(:last-child) { margin-bottom: 20px; }
.footer-links li > p { width: 125px; border-right: 2px solid #56638b; font-size: 20px; font-weight: 600; color: #fff; line-height: 1em; }
.footer-links li > div { margin-left: 25px; }
.footer-links li > div > a { display: inline-block; font-size: 18px; font-weight: 600; color: #fff; line-height: 1em; -webkit-transition: color ease 0.3s; transition: color ease 0.3s; }
.footer-links li > div > a:not(:last-child) { margin-right: 16px; }
.footer-links li > div > a:hover { color: #11b7bd; }

.footer-family h3 { color: #fff; font-size: 32px; text-align: center; }
.footer-family h3 strong { color: #11b7bd; }

.footer-family__btn { position: relative; border: 1px solid #78829d; border-radius: 2em; cursor: pointer; width: 220px; height: 46px; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; padding-left: 18px; margin-top: 35px; margin-left: auto; }
.footer-family__btn > button { width: 100%; color: #fff; padding-right: 18px; position: relative; font-size: 18px; text-align: left; }
.footer-family__btn > button::after { content: ''; position: absolute; top: 50%; right: 16px; -webkit-transform: translateY(-50%); transform: translateY(-50%); width: 10px; height: 10px; background-image: url(/assets/images/common/gnb_arrow.svg); background-repeat: no-repeat; background-size: 100%; background-position: center; -webkit-filter: brightness(10); filter: brightness(10); -webkit-transition: all ease 0.3s; transition: all ease 0.3s; }
.footer-family__btn > button.active::after { -webkit-transform: translateY(-50%) rotate(-180deg); transform: translateY(-50%) rotate(-180deg); }
.footer-family__btn .footer-family__links { position: absolute; top: 50px; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); width: 100%; background-color: #fff; border-radius: 1em; display: none; z-index: 99; -webkit-box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); box-shadow: 0px 4px 4px rgba(0, 0, 0, 0.15); padding: 10px 0; }
.footer-family__btn .footer-family__links > a { display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-align: center; -ms-flex-align: center; align-items: center; -webkit-box-pack: center; -ms-flex-pack: center; justify-content: center; height: 35px; -webkit-transition: all ease 0.3s; transition: all ease 0.3s; }
.footer-family__btn .footer-family__links > a:hover { color: #11b7bd; }

.footer-copy { width: 100%; margin-top: 64px; padding-top: 32px; border-top: 1px solid #1e375e; display: -webkit-box; display: -ms-flexbox; display: flex; }
.footer-copy p { margin-left: auto; opacity: 0.5; font-size: 16px; color: #fff; }
.footer-copy a { color: #fff; margin-right: 16px; font-size: 20px; font-weight: 600; }
.footer-copy .footer-copy__private { color: #11b7bd; }

.dim { z-index: 99998; position: fixed; width: 100%; height: 100vh; top: 0; left: 0; background-color: rgba(0, 0, 0, 0.7); cursor: pointer; display: none; }

.modal { z-index: 99999; position: fixed; background-color: #fff; width: 930px; left: 50%; top: 50%; -webkit-transform: translate(-50%, -50%); transform: translate(-50%, -50%); display: none; }
.modal hgroup { border-bottom: 1px solid #11b7bd; display: -webkit-box; display: -ms-flexbox; display: flex; -webkit-box-pack: justify; -ms-flex-pack: justify; justify-content: space-between; padding: 15px 20px; }
.modal hgroup h2 { font-size: 24px; font-weight: 600; color: #222; }

.modal-contents { padding: 20px; height: 500px; overflow-y: scroll; }

.show-default { display: block !important; }

.hide-default { display: none !important; }
.hamburger-btn { width: 26px; cursor: pointer; position: relative; margin-left: auto; }
.hamburger-btn span { display: block; width: 100%; height: 3px; background: #fff; transition: all 0.3s ease; position: relative; }
.hamburger-btn span:not(:first-child) { margin-top: 6px; }
.hamburger-btn span:nth-child(2) { width: 80%; margin-left: auto; }
.hamburger-btn span:nth-child(1),
.hamburger-btn span:nth-child(2) { transform: scale(1); }
.hamburger-btn span:nth-child(3) { transform: rotate(0deg) translate(0, 0); }
.hamburger-btn.active span:nth-child(1) { transform: rotate(45deg) translate(7px, 6px); }
.hamburger-btn.active span:nth-child(2) { transform: scale(0); }
.hamburger-btn.active span:nth-child(3) { transform: rotate(-45deg) translate(6.5px, -6px); }
@media all and (max-width: 1200px){
 .show-1200 { display: block !important; }
 .hide-1200 { display: none !important; }
 .gnb { display: none; opacity: 0; left: auto; top: -20px; transform: none; right: -3.90625vw; bottom: 0; height: 100vh; background-color: rgba(0, 0, 0, 0.8); backdrop-filter: blur(17px); width: 50vw; padding: calc(var(--headerHeight) + 50px) 3.90625vw 0; }
 .gnb ul { width: 100%; flex-direction: column; gap: 28px; }
 .gnb ul > li { width: 100%; text-align: center; }
 .gnb ul > li:not(:last-child) { margin-right: 0; }
 .gnb button.gnb__depth1 { width: 100%; font-size: 24px; padding-right: 0; }
 .gsnb { background-color: transparent; position: static; transform: none; width: 100%; box-shadow: none; padding-bottom: 0; }
 .gsnb > a { color: #fff; font-size: 18px; }
 .i18n > button::after,
 .gnb button.gnb__depth1::after { background-image: url('/assets/images/common/gnb_arrow_m.svg'); width: 16px; height: 16px; }
 .gnb button.gnb__depth1.active::after { -webkit-filter: brightness(0) invert(1); filter: brightness(0) invert(1); }
 .i18n { border: none; width: 100%; margin: 0; }
 .i18n > button { width: 100%; padding: 0; border: 1px solid #fff; border-radius: 2em; }
 .i18n .i18n__list { position: static; background-color: transparent; }
 .i18n .i18n__list > a { color: #fff; }
 .i18n .i18n__list > a.active { color: #11b7bd; }
 .header__contact { margin-top: 15px; }
 .footer { background-color: #072148; padding: 50px 0 22px; }
 .footer-family h3 { font-size: 26px; }
 .footer-info ul > li { font-size: 15px; }
 .footer-links li:not(:last-child) { margin-bottom: 14px; }
 .footer-links li > p { width: 100px; font-size: 16px; }
 .footer-links li > div > a { font-size: 16px; }
 .footer-links li > div { margin-left: 16px; }
 .footer-links li > div > a:not(:last-child) { margin-right: 10px; }
 .footer-family__btn > button { font-size: 16px; }
 .footer-copy { margin-top: 40px; padding-top: 20px; }
 .footer-copy a { font-size: 15px; }
 .footer-copy p { font-size: 14px; }
 .footer-info .regi { font-size: 14px; }
 }
@media all and (max-width: 1024px){
 .show-1024 { display: block !important; }
 .hide-1024 { display: none !important; }
 .footer .inner { flex-direction: column; }
 .footer-links { margin-top: 30px; }
 .footer-family h3 { text-align: left; margin-top: 20px; }
 .footer-family__btn { margin-left: 0; margin-top: 20px; }
 .footer-copy { flex-wrap: wrap; margin-top: 30px; }
 .footer-copy p { margin-left: 0; margin-top: 10px; flex: none; width: 100%; }
 .footer-info ul > li:not(:last-child) { margin-bottom: 10px; }
 }
@media all and (max-width: 768px){
 .show-768 { display: block !important; }
 .hide-768 { display: none !important; }
 .header { padding: 10px 0; }
 .header .header__logo { width: 140px; }
 .gnb { width: 80vw; top: -10px; }
 .footer-copy{ gap: 5px 0; }
 }
@media all and (max-width: 640px){
 .show-640 { display: block !important; }
 .hide-640 { display: none !important; }
 }
@media all and (max-width: 425px){
 .hamburger-btn { width: 20px; }
 .hamburger-btn span { height: 2px; }
 .hamburger-btn span:not(:first-child) { margin-top: 5px; }
 .hamburger-btn.active span:nth-child(1) { transform: rotate(45deg) translate(5px, 7px); }
 .hamburger-btn.active span:nth-child(3) { transform: rotate(-45deg) translate(3px, -5px); }
 .header .header__logo { width: 120px; }
 .footer { padding: 32px 0 22px; }
 .footer-info ul > li { font-size: 14px; padding-left: 26px; }
 .footer-links li > p,
 .footer-links li > div > a { font-size: 15px; }
 .footer-family__btn { width: 100%; }
 .footer-family__btn > button { font-size: 15px; }
 .gnb { width: 100vw; padding: calc(var(--headerHeight) + 30px) 3.90625vw 0; }
 .gnb button.gnb__depth1 { font-size: 20px; }
 .gsnb > a { font-size: 16px; height: 36px; }
 .footer-info ul > li > a,
 .footer-info ul > li:not(:last-child) { font-size: 13px; }
 .footer-info ul > li { background-size: 14px; padding-left: 20px; }
 .footer-info .regi { font-size: 12px; }
 .footer-family h3 { font-size: 22px; }
 .footer-links li > p,
 .footer-links li > div > a { font-size: 13px; }
 .footer-links li > p { width: 80px; border-width: 1px; }
 .footer-copy a { font-size: 13px; }
 .footer-copy p { font-size: 12px; }
 }
