@charset "utf-8";

body.on {overflow: hidden;}

/* header */
.header {position: fixed; left: 0; top: 0; width: 100%; z-index: 100; border-bottom: 1px solid #DDE0EA; transition: 0.3s; background: #fff;}
.header.fixed {position: fixed; left: 0; right: 0; z-index: 50; top: -100%; opacity: 0;}
.header.show.fixed {top: 0; opacity: 1; background: #fff;}
.inner-header-wrap {position: relative;}
.inner-header {height: 7rem; max-width: 1540px; margin: 0 auto; display: flex; justify-content: space-between; align-items: center; padding: 0 10px; gap: 20px; min-height: 55px; box-sizing: border-box;}
.gnb-wrap {display: flex; transition: left 0.3s; flex-direction: column; position: fixed; width: 100%; overflow: auto; left: -100%; top: 71px; bottom: 0; background: #fff; font-size: 15px; z-index: 21;}
.gnb-wrap::before {content: ''; width: 21rem; height: 36rem; background: url("/_user/support/img/layout/bg-gnb.png") no-repeat center/ contain; position: absolute; bottom: 6rem; right: 0; z-index: 1;}
.gnb-wrap.open {left: 0;}
.gnb-inner {display: flex; flex-direction: column; height: 100%; min-width: 280px; position: relative; background: linear-gradient(90deg, #565D6D 13rem, #ffffff 104px);}

.gnb {height: 100%;}
.gnb .dep1 {display: flex; justify-content: space-between;; width: 13rem; box-sizing: border-box; margin-top: 0.2rem;}
.gnb .dep1.active {background: var(--white);}
.gnb .dep1>a {display: flex; width: 100%; height: 47px; align-items: center; justify-content: center; position: relative; z-index: 1; font-size: 16px; color: #fff; box-sizing: border-box; word-break: keep-all;}
.gnb .dep1.active>a {color: var(--point-color);}
.gnb .dep2 {width: calc(100% - 125px); display: none; position: absolute;  padding: 0 10px; left: 104px; box-sizing: border-box; top: 0;}
.gnb .dep2.show {display: block !important;}
.gnb .dep2>p {display: none;}
.gnb .dep2>ul>li:last-of-type>a {border:none;}
.gnb .dep2>ul>li>a {display: flex; align-items: center; justify-content: space-between; padding: 15px 0; box-sizing: border-box; word-break: keep-all; font-size: 16px; color: #111; border-bottom: 1px solid #f1f1f1;}
.gnb .dep2>ul>li>a::after {content: ''; display: inline-block; width: 10px; height: 10px; --svg: url("data:image/svg+xml,%3Csvg width='6' height='10' viewBox='0 0 6 10' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='M0.75 8.75L4.75 4.75L0.75 0.75' stroke='%23DEDEDF' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E%0A"); -webkit-mask: var(--svg); mask: var(--svg); background: #dededf; -webkit-mask-repeat: no-repeat;  mask-repeat: no-repeat;}
.gnb .dep2>ul>li.active>a::after {background: var(--point-color);}
.gnb .dep2>ul>li.active>a {color: var(--point-color); border-bottom: 2px solid var(--point-color);}
.gnb-wrap .gnb .dep3 {padding: 25px 0; display: none; border-top: 1px solid #f1f1f1;}
.gnb-wrap .gnb .dep3>li:not(:first-of-type) {margin-top: 15px;}
.gnb-wrap .gnb .dep3>li>a {font-size: 14px; color: #888; word-break: keep-all; padding: 0;}
.gnb-wrap .gnb .dep3>li>a:hover {color: var(--point-color2);}
.inner-header .logo {display:flex; align-items: center; justify-content: center; width: 21.8rem; height: 7rem;}
.inner-header .logo a {display: block;}
.inner-header .logo img {display: block; min-height: 60px; width: 100%;}

.header .link-wrap {width: calc(100% - 20px); max-width: fit-content; position: fixed; left: -100%; bottom: 0; z-index: 23; transition: .3s;}
.header .link-wrap.on {left: 0}
.header .link-wrap .link-list {display: flex; flex-direction: column-reverse; gap: 20px; padding-left: 10px;}
.header .link-wrap .link-list li>a {display: none; align-items: center; color: var(--black); max-width: 80px;}
.header .link-wrap .link-list li>a img {display: inline-block; padding-right: 8px;}
.header .link-wrap .link-list .mob-login a {display: flex; color: #fff; font-size: 1.5rem;}

.header-util {position: relative; display: flex; gap: 20px;}
.header-util .gnb-btn {position:relative; width:4rem; height:4rem; background: var(--point-color); border-radius:6rem; display:flex; align-items:center; justify-content:center;}
.header-util .gnb-btn::before, .header-util .gnb-btn::after, .header-util .gnb-btn span::before {content:""; position:absolute; left:50%; width:1.8rem; height:2px; background:#fff; transform:translateX(-50%); transition:all .3s ease;}
.header-util .gnb-btn::before {top:1.3rem;}
.header-util .gnb-btn span::before {top:50%; transform:translate(-50%,-50%);}
.header-util .gnb-btn::after {bottom:1.3rem;}
.bottom-wrap {width: 100%; display: flex; justify-content: space-between; align-items: center; max-width: 1540px;}
.login, .logout, .mypage {display: none; align-items: center; min-width: fit-content; gap: 0.5rem; font-size: 1.7rem; font-weight: 600; color: #1D1D1D;}
a + .mypage {padding-left: 1rem;}
.deco-marquee {display: none;}
.header-util .gnb-btn.open::before {top:50%; transform:translate(-50%,-50%) rotate(45deg);}
.header-util .gnb-btn.open span::before {opacity:0;}
.header-util .gnb-btn.open::after {bottom:auto; top:50%; transform:translate(-50%,-50%) rotate(-45deg);}
.txt-header {display: none;}
.txt-header::after {content: ''; display: block; width: 3.9rem; height: 3.6rem; margin-left: auto; background: url("/_user/support/img/layout/deco-header-txt.svg") no-repeat center / cover;}

.mob-login-list {width: 13rem; padding: 2rem; box-sizing: border-box; color: #fff; background: #565D6D;}
.mob-login-list .login, .mob-login-list .logout, .mob-login-list .mypage {display: flex; gap: 0.8rem; color: #fff; font-size: 1.5rem; font-weight: 300; word-break: keep-all;}
.mob-login-list > li + li {padding-top: 1rem;}
.under-lnk {display: flex; align-items: center; justify-content: center; width: calc(100% - 15rem); height: 5rem; position: absolute; left: 14rem; bottom: 1rem; z-index: 1; border: 1px solid #ddd; border-radius: 1.2rem; color: var(--black); background: #F5F5F5; word-break: keep-all; text-align: center;}
.under-lnk img {width: 18rem; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);}

.gnb-mob-login {display: flex; justify-content: center; gap: 1rem; padding: 1.5rem; background: linear-gradient(0deg, #F5F5F5 0%, #F5F5F5 100%), #FFF; border-bottom: 1px solid #DEDEDF; backdrop-filter: blur(40px);}
.gnb-mob-login .login, .gnb-mob-login .logout, .gnb-mob-login .mypage {display: flex; width: 100%; height: 4.4rem; box-sizing: border-box; align-items: center; justify-content: center; font-weight: 500; font-size: 1.4rem; border-radius: 5rem; border: 1px solid #ddd; background: #fff;}
.gnb-mob-login .login {max-width: 30rem;}
@media all and (min-width: 360px){
    .gnb-inner {background: linear-gradient(90deg, #565D6D 13rem, #ffffff 13rem);}
    .inner-header {padding: 0 20px;}
    .gnb .dep1>a {font-size: 18px;}
    .gnb .dep2 {left: 125px; padding: 0 15px;}
    .gnb-mob-login .login, .gnb-mob-login .logout, .gnb-mob-login .mypage {font-size: 1.6rem;}
}

@media all and (min-width: 1200px){
    .under-lnk, .gnb-mob-login {display: none;}
    .header {border: none; background: transparent;}
    .header.show.fixed {top: -4.5rem; border-bottom: 1px solid #DDE0EA;}
    .header::before {content: ''; width: 100%; height: 4.5rem; position: absolute; top: 0; left: 0; z-index: 1;}
    .gnb-wrap::before {display: none;}
    .inner-header .logo {width: auto; height: 100px; align-items: flex-end;}
    .inner-header-wrap {position: relative; height: 146px; box-sizing: border-box; transition: height 0.25s; overflow: hidden;}
    .inner-header-wrap.open::after {content: ''; width: 100%; height: 1px; background: var(--egray); position: absolute; top: 145px; z-index: 100;}
    .inner-header {flex-direction: column; gap:0; position: static; height: 145px; padding: 0 40px; overflow: hidden; max-width: none;}
    .inner-header-wrap.open {box-shadow: 0 20px 20px 0 rgba(0, 0, 0, 0.25); background: linear-gradient(to right, #F7F7F7 18%, #fff 18%)}
    .inner-header-wrap.open .inner-header {overflow: visible; background: #fff;}
    .inner-header-wrap .bg {display: block; position: absolute; left: 160px; top: 200px; width: 245px; height: 188px; background: url("/_user/support/img/main/img-main-bg.svg"); background-size: contain;}
    .mob-gnb-btn, .gnb-wrap .btn-home, .gnb .arrow, .gnb>li>a:after {display: none;}
    .gnb-wrap .sns-wrap {position: fixed; z-index: 10; top: 50%; right: 10px; transform: translateY(-50%); max-height: none; height: auto; flex-direction: column; padding: 0; text-align: center; font-size: 16px; transition: top 0.35s;}
    .inner-header.on .gnb-wrap .sns-wrap {top: 183px;}
    .gnb-wrap {display: block; position: static; border-top: none; right: 0 !important; top: 0; overflow: visible; max-width: inherit; background: transparent;}
    .gnb-wrap .gnb {width: 100%; display: flex; justify-content: center; padding: 0 20px;}
    .gnb .dep1 {width: 25%; position: relative; padding-left: 0;}
    .gnb .dep1>a {height: 100px; font-size: 20px; white-space: nowrap; color: #1D1D1D;}
    .gnb>li>a {height: 100px; font-size: 20px; padding: 30px 16px; justify-content: center; transition: color 0.3s;}
    .gnb>li>a.active {color: var(--point-color);}
    .header .link-wrap {max-width: 1540px; width: 100%;}
    .header .link-wrap .link-list img {display: none;}
    .gnb-close {display: none;}
    .gnb-wrap .dep2 {display: none; padding: 0 5px 30px; position: absolute; z-index: 1; top: 101px; left: 0; width: 100%; text-align: center; box-sizing: border-box;}
    .gnb-wrap .dep2:after {position: absolute; z-index: -1; content: ''; left: 0; right: 0; top: 0; height: 500px;}
    .inner-header-wrap.open .gnb-wrap .dep2 {display: block;}
    .gnb-wrap .dep2 li {padding-top: 20px;}
    .gnb-wrap .dep2 li:first-of-type {padding-top: 4rem;}
    .gnb .dep2>ul>li>a::after {background: #555;}
    .gnb-wrap .dep2>ul>li>a {font-weight: 500; font-size: 16px; text-align: left; border: 1px solid var(--point-color); color: var(--point-color); justify-content: space-between; transition: background 0.3s; background: #fff; border-radius: 0.5rem; height: 6rem; padding: 2rem;}
    .gnb .dep2>ul>li:last-of-type>a {border: 1px solid var(--point-color);}
    .gnb-wrap .dep2>ul>li>a:hover, .gnb-wrap .dep2>li>a:focus {color: var(--white); background: var(--point-color);}
    .gnb-wrap .dep2:before {content: ''; position: absolute; left: 50%; top: 0; width: 0; height: 3px; background: var(--point-color); transition: all .3s; z-index: 1; transform: translateX(-50%);}
    .gnb-wrap .dep2>ul>li>a:hover::after {background: #fff;}
    .dep2.active:before {width: 65%;}
    .gnb .dep2>ul>li>a .arrow {display: none;}
    .gnb-inner {position: static; height: auto; flex-direction: row; background: none; align-items: center; justify-content: flex-end;}
    .header .link-wrap .mypage {width: auto; position: static; display: flex; align-items: center; min-width: auto; background: #fff;}
    .header .link-wrap .mypage>a {color: var(--point-color); font-size: 14px;}
    .header .link-wrap .util {width: auto; position: static; display: flex; align-items: center; min-width: auto; background: #fff; margin-left: 20px;}
    .header-util {display: none;}
    .header .link-wrap {left: 0; height: 45px; position: relative; display: flex; justify-content: space-between; align-items: center; margin-bottom: 0;}
    .header .link-wrap .link-list {max-width: 1540px; padding-left: 0; display: flex; flex-direction: row; align-items: center; font-size: 14px; gap: 0; padding-top: 0;}
    .header .link-wrap .link-list>li {position: relative; padding-right: 30px;}
    .header .link-wrap .link-list>li:before {content: ''; display: block; position: absolute; top: 50%; transform: translateY(-50%); width: 1px; height: 12px; background: #d3d3d3; right: 15px;}
    .header .link-wrap .link-list>li:nth-of-type(n+2)::before {content: none;}
    .header .link-wrap .link-list li>a {display: flex; max-width: inherit;}
    .header .link-wrap .link-list .mob-login a {display: none;}
    .deco-marquee {display: flex; align-items: center; width: 589px; height: 45px; background: var(--point-color); color: var(--white); position: absolute; right: 0; top: 0; font-size: 1.8rem; font-weight: 500; border-radius: 0 0 0 2rem; padding-left: 4rem; z-index: 1; box-sizing: border-box; overflow: hidden;}
    .deco-marquee::before {content: ''; position: absolute; right: 0; top: 0; width: 100px; height: 100%; background: var(--point-color); z-index: 2;}
    .deco-marquee::after {content: ''; width: 80px; height: 1px; background: #00FFFF; position: absolute; right: 0; top: 2.2rem; z-index: 3;}
    .deco-marquee em {color: #00FFFF;}
    .marquee-inner {display: flex; white-space: nowrap; animation: marquee 10s linear infinite;}
    .marquee-txt {padding-right: 3rem;}
    .login, .logout, .mypage {display: flex; word-break: keep-all;}
    .mob-login-list {display: none;}

    @keyframes marquee {
        0% {transform: translateX(0);}
        100% {transform: translateX(-50%);}
    }
}
@media all and (min-width: 1500px){
    .inner-header-wrap.open {background: linear-gradient(to right, #F7F7F7 22%, #FFF 22%);}
    .inner-header .logo a {min-width: 280px;}
    .gnb .dep1>a {font-size: 24px;}
    .gnb>li>a {padding: 50px 30px 20px;}
    .header .link-wrap .link-list {font-size: 16px;}
    .login, .logout, .mypage  {padding-top: 3rem;}
    .gnb-wrap .dep2 {padding: 0 15px 30px;}
    .inner-header-wrap.open .txt-header {display: block; position: absolute; top: 19rem; left: 3%; font-size: 2.5rem;}

}
@media all and (min-width: 1800px){
    .inner-header-wrap.open {background: linear-gradient(to right, #F7F7F7 25%, #FFF 25%);}
    .inner-header-wrap.open .txt-header {left: 9%;}
}

/* footer */
.footer {position: relative; background: #292F32; color: #fff; padding: 40px 20px 60px; font-size: 1.5rem; font-weight: 300;}
.footer-inner {max-width: 1600px; margin: 0 auto;}
.footer-top>ul {display: flex; flex-wrap: wrap; gap: 8px 0; max-width: 1360px; margin: 0 auto;}
.footer-top>ul>li {position: relative; padding: 0 calc(14%/7); word-break: keep-all;}
.footer-top>ul>li+li:before {content: ''; width: 3px; height: 3px; position: absolute; left: 0; top: 50%; transform: translateY(-50%); background: #aaa;}
.footer-top>ul>li>a {display: block; color: #333; font-size: 12px;}
.footer-top>ul>li>a.point {color: var(--point-color);}
.footer-bottom .left .footer-logo img {width: 170px;}
.footer-bottom .left .copyright {word-break: keep-all; padding-top: 1.5rem;}
.footer .family-site-wrap {}
.footer .family-site-wrap .family-site {height: 60px; position: relative; margin-top: 3rem;}
.footer .family-site .site-list {position: absolute; width: 100%; display: none; z-index: 1; bottom: 60px; background: #fff; color: #fff; max-height: 300px; overflow: auto;}
.footer .family-site .site-list:before {display: none;}
.footer .family-site .site-list {border: 1px solid #d3d3d3; border-radius: 4px;}
.footer .family-site .site-list>li>a {display: block; text-align: left; padding: 7px 15px; transition: opacity 0.3s; color: #555; font-weight: 400; font-size: 12px;}
.footer .family-site .site-list>li>a:hover {background: #F6FAFF;}
.footer .family-site-wrap button {width: 100%; height: 60px; padding: 0 10px; border: 1px solid #d3d3d3; border-radius: 36px; color: #fff; display: flex; text-align: left; align-items: center; justify-content: space-between; word-break: keep-all;}
.footer .family-site-wrap button.active {border-radius: 0 0 36px 36px;}
.footer .family-site-wrap button:after {content: ''; display: block; width: 12px; height: 6px; background: url("/_user/support/img/layout/ico-footer-arrow.svg") no-repeat center / contain;}
.footer .family-site-wrap button.active:after {transform: rotate(180deg);}
.contact-list li + li {padding-top: 5px;}
.contact-list li em {display: inline-block; padding-right: 10px; font-weight: 500;}
.footer .link-list {padding-top: 20px; display: flex; flex-wrap: wrap;}
.footer .link-list li + li::before {content: ''; display: inline-block; margin: 0 10px; width: 1px; height: 8px; background: #fff;}
.footer .link-list li:first-of-type a {color: #339AF0;}
.footer .link-list a {color: #fff;}

@media all and (min-width:360px){
    .footer .family-site-wrap button {padding: 0 30px;}
    .footer .family-site-wrap .family-site {margin-top: 4rem;}
}

@media all and (min-width:768px){
    .footer {padding: 35px 30px 40px;}
    .footer .family-site-wrap {grid-template-columns: repeat(3, 1fr); max-width: 1000px;}
    .footer .family-site .site-list>li>a {font-size: 14px;}
}

@media all and (min-width:1024px){
    .footer {padding: 0 0 60px;}
    .footer-top {background: #fff; padding: 20px 40px; border-top: 1px solid #D3D3D3; border-bottom: 1px solid #D3D3D3}
    .footer-top>ul {justify-content: space-between;}
    .footer-top>ul>li {padding: 0;}
    .footer-top>ul>li>a{font-size: 17px;}
    .footer-top>ul>li+li:before {display: none;}
    .footer-bottom {padding: 60px 40px 0; display: flex; justify-content: space-between; align-items: flex-start; gap: 50px;}
    .footer-bottom .left {display: flex; flex-direction: column; justify-content: space-between; flex-shrink: 1;}
    .footer-bottom .left .copyright {text-align: left;}
    .footer-bottom .right {width: 63%; display: block; word-break: keep-all; color: #555; font-size: 14px;}
    .footer-bottom .right>ul {display: flex; flex-direction: column; gap: 10px;}
    .footer-bottom .right>ul>li {display: flex; gap: 10px; align-items: center;}
    .footer .family-site .site-list>li>a {font-size: 16px;}
    .footer-bottom .right>ul>li>em {width: 52px; height: 24px; display: flex; align-items: center; justify-content: center; flex-shrink: 0; border-radius: 3px; color: #fff;}
    .footer-bottom .right>ul>li .tel {font-weight: 500; color: #333; flex-shrink: 0;}
    .footer .family-site-wrap .family-site {width: 100%; margin-top: 0;}
    .contact-list {display: flex; gap: 4rem; font-size: 16px;}
    .contact-list li + li {padding-top: 0;}
    .footer .link-list {padding-top: 5.5rem; font-size: 17px;}
    .footer .link-list li + li::before {margin: 0 15px; height: 10px;}
}

@media all and (min-width:1500px){
    .top-btn {right: 30px;}
    .footer-bottom .left {width: 60%;}
    .footer-bottom .left .footer-logo img {width: 200px;}
    .footer-bottom .left .copyright {text-align: left; font-size: 16px;}
    .footer-bottom .right {width: 40%; font-size: 16px; max-width: 320px;}
    .footer-bottom .right>ul>li>em {width: 66px; height: 27px;}
    .footer .family-site-wrap button {font-size: 16px;}
}

