* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
  -webkit-font-smoothing: antialiased;  
  text-rendering: optimizeLegibility;  
}
.sound_only {
    width:0; height:0; z-index:-1; position:absolute; top:0; left:0; opacity:0;
}
.mainPopupSlider0224 {font-size:0;}
.cell-ring{
  position:relative;            /* 필요하면 absolute로 바꾸고 left/top 지정 */
  display:inline-block;
  border-radius:50%;
  /* 안쪽 구멍을 비우기: 비율 유지됨 */
  -webkit-mask:
    radial-gradient(circle, transparent 0 33%, #000 33% 100%);
          mask:
    radial-gradient(circle, transparent 0 33%, #000 33% 100%);
  /* 세포 느낌 살짝 소프트 */

}

/* 숨쉬기 모션 */
@keyframes breathe {
  0%, 100% {
    transform: scale(0.9);
  }
  50% {
    transform: scale(1);
  }
}
@keyframes breathe02 {
  0%, 100% {
    transform: scale(1);
  }
  50% {
    transform: scale(0.9);
  }
}
.cell-ring01 {
  width:107px;
  height:107px;
  background:#ff5453;  
  filter: drop-shadow(0 0 10px rgba(0,0,0,.08));
  animation: breathe 3.9s ease-in-out infinite;
  transform-origin: center center;
  will-change: transform;
  position:absolute;
  top: 260px;
  left: 34%;
}
.cell-ring02 {
  width:70px;
  height:70px;
  background:#fff2e9;  
  filter: drop-shadow(0 0 10px color-mix(in srgb, #ff5a58, transparent 70%));
  animation: breathe02 4.2s ease-in-out infinite;  
  position:absolute;
  bottom:153px;
  left:53%;
}
.cell-ring03 {
  width:90px;
  height:90px;
  background:#98b7e1;  
  filter: drop-shadow(0 0 10px rgba(0,0,0,.08));
  animation: breathe 4.2s ease-in-out infinite;  
  transform-origin: center center;
  will-change: transform;  
  position:absolute;
  bottom:-31px;
  left:53%;
}
/* IE/Edge의 기본 화살표 제거 */
select::-ms-expand {
  display: none;
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 900;
  src: url('../fonts/Pretendard-Black.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 700;
  src: url('../fonts/Pretendard-Bold.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 600;
  src: url('../fonts/Pretendard-SemiBold.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 500;
  src: url('../fonts/Pretendard-Medium.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 400;
  src: url('../fonts/Pretendard-Regular.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 300;
  src: url('../fonts/Pretendard-Light.woff2') format('woff2');
}
@font-face {
  font-family: "Pretendard";
  font-style: normal;
  font-weight: 200;
  src: url('../fonts/Pretendard-ExtraLight.woff2') format('woff2');
}
@font-face {
  font-family: "Retrosans";
  src: url('../fonts/Retrosans.ttf') format('truetype');
  font-weight: normal;
  font-style: normal;
  font-display: swap;
}
/* NotoSans CJK KR - Thin (100) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 100;
  src: url("../fonts/NotoSansCJKkr-Thin.otf") format("opentype");
}

/* Light (300) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 300;
  src: url("../fonts/NotoSansCJKkr-Light.otf") format("opentype");
}

/* DemiLight (350~400 중간값 → 실제로는 350이 없으니 350 대신 350~400 역할) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 350;
  src: url("../fonts/NotoSansCJKkr-DemiLight.otf") format("opentype");
}

/* Regular (400) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 400;
  src: url("../fonts/NotoSansCJKkr-Regular.otf") format("opentype");
}

/* Medium (500) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 500;
  src: url("../fonts/NotoSansCJKkr-Medium.otf") format("opentype");
}

/* Bold (700) */
@font-face {
  font-family: "Noto Sans CJK KR";
  font-style: normal;
  font-weight: 700;
  src: url("../fonts/NotoSansCJKkr-Bold.otf") format("opentype");
}

@font-face {
  font-family: "Gmarket Sans TTF";
  src: url('../fonts/GmarketSansTTFLight.ttf') format('truetype');
  font-weight: 300;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gmarket Sans TTF";
  src: url('../fonts/GmarketSansTTFMedium.ttf') format('truetype');
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gmarket Sans TTF";
  src: url('../fonts/GmarketSansTTFBold.ttf') format('truetype');
  font-weight:700;
  font-style: normal;
  font-display: swap;
}
html, body {
  font-family: "NanumGothic";    
  height: 100%;
  color: #333;
  background-color: #fff;
}

ul, ol, li {
  list-style: none;
  text-decoration: none;  
}

a {
  text-decoration: none;
  color: inherit;
  border-bottom:navajowhite;
}
.memberText {
    word-break:keep-all;
    white-space: pre-line;
    font-size:18px;
    font-weight:400;
    color:#000;
    line-height:1.4;
    text-align:left;
}
.articlesText {
    word-break:keep-all;
    font-size:17px;
    font-weight:400;
    color:#636363;
    line-height:1.4;
    text-align:left;
}
.articlesText .tit_chapter,
.articlesText .tit_article {
    display:block;
    line-height:1;
}
.articlesText .tit_chapter {
    font-size:22px;
    font-weight:500;
    color:#000;
    margin-top:50px;
}
.terms-section .articlesText .tit_chapter {
    margin-top:0;
}
.articlesText .tit_article {
    font-size:19px;
    font-weight:700;
    color:#222;
    padding:30px 0 10px 0;
}
button {
  background: none;
  border: none;
  cursor: pointer;
  font: inherit;
}
.sec .inner {
  width:1680px;
  margin:0 auto;
  position:relative;
  z-index:2;
}
.sec .inner02 {
  padding:0 40px;
}
/* 숨김 처리 (접근성용) */
.sr-only {
  position: absolute;
  width: 1px; height: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  white-space: nowrap;
}

/* 텍스트 정렬 */
.text-center { text-align: center; }
.text-left { text-align: left; }
.text-right { text-align: right; }

.wd100 {width:100%;}

/* 마진 & 패딩 */
.mt8 {
  margin-top: 8px;
}
.mt40 {
  margin-top: 40px;
}
.ml10 {margin-left:10px !important;}
.mt10 { margin-top: 10px !important; }
.mt15 { margin-top: 15px !important; }
.mt30 { margin-top:30px !important; }
.mb0 {margin-bottom:0 !important;}
.mb8 { margin-bottom:8px !important; }
.mb10 { margin-bottom: 10px !important; }
.mb15 { margin-bottom: 15px !important; }
.mb20 {margin-bottom:20px !important;}
.mb25 {margin-bottom:25px !important;}
.mb30 {margin-bottom:30px !important;}
.mb35 {margin-bottom:35px !important;}
.mb40 {margin-bottom:40px !important;}
.mb45 {margin-bottom:45px !important;}
.mb50 {margin-bottom:50px !important;}
.mb70 {margin-bottom:70px !important;}
.mb100 {margin-bottom:100px !important;}
.mb150 {margin-bottom:150px !important;}
.mr2 {margin-right:2px !important;}
.mr20 {margin-right:20px !important;}
.pt10 { padding-top: 10px !important; }
.pt30 { padding-top: 30px !important; }
.pt50 { padding-top: 50px !important; }
.pt100 {padding-top:100px;}
.pt110 {padding-top:110px;}
.pb10 { padding-bottom: 10px !important; }
.pb140 {
  padding-bottom:140px;
}

.flex { display: flex; }
.flex02 {display:flex; flex-direction:row; align-items:center; justify-content:space-between;}
.flex03 {display:flex; flex-direction:row; align-items:center;}
.flex-center { display: flex; justify-content: center; align-items: center; }
.flex-start {display:flex; flex-direction:row; align-items:flex-start;}
.flexEnd {display:flex; flex-direction:row; justify-content:space-between; align-items:end;}
.flexEnd02 {display:flex; flex-direction:row; justify-content:end; align-items:center;}
.between {}
.grid { display: grid; }

.gap10 {gap:10px;}
.gap80 {gap:80px;}

.check_wrap_square label { font-size:14px; font-weight:300; color:#333333; cursor:pointer; position:relative; display:flex; flex-direction:row; align-items:center;}
.check_wrap_square .checkmark { display:inline-block; position: relative; width:26px; height:26px;  vertical-align: middle; background-color: #fff;  border:1px solid #cdcdcd; box-sizing:border-box;  cursor:pointer; overflow:hidden; border-radius:4px; margin-right:8px; cursor:pointer;}
.check_wrap_square input[type='checkbox']{display:none;}
.check_wrap_square label span.checkmark:after {
  content: '';
  display: none;
  position: absolute;
  left: 7px;
  top: 2px;
  width: 7px;
  height: 13px;
  border: solid #336fdf;
  border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.check_wrap_square input[type=checkbox]:checked + label span.checkmark:after { display:block; }

:root{
  --brand:#6A5CF6; --point:#d91d58; --navy:#0E2540;
  --gray-900:#1F1F1F; --gray-700:#555; --gray-400:#A8A8A8;
  --gray-200:#E9E9E9; --gray-100:#F5F6F8; --white:#fff;
  --space:8px; --radius:16px; --radius-lg:24px; --shadow:0 10px 30px rgba(0,0,0,.08);
  --container:1280px;
}
.header .gnb .gnb_main >li:hover > a {color:var(--point) !important;}

*{box-sizing:border-box;}

html,body{margin:0;padding:0}
body{
  font-family: "Pretendard";
  font-size:18px;
  line-height:1; color:#666666;
}
.container{max-width:var(--container); margin:0 auto; padding:0 40px;}
.infoBtn {
  width:160px;
  height:55px;
  line-height:53px;
  border-radius:27px;
  color:#999999;
  border:2px solid #999999;
  box-sizing:border-box;
  font-size:18px;
  font-weight:400;
  color:#999999;
  text-align:center;
}
.infoBtn:hover {
  border:2px solid transparent;
  color:#fff;
  background-color:var(--point);
}
.tab-btn { 
  background-color:#000000;
  width:75px;
  height:75px;
  border-radius:50%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}
.tab-btn:hover {
    background-color:var(--point);
}
.tab-btn:hover .on {
    display:none;
}
.tab-btn:hover .on {
    display:block;
}
.tab-btn:hover .off {
    display:none;
}
.tab-btn02 {
  margin:0 auto;
  border:1px solid #fff;
  background-color:transparent;
}
.tab-btn02:hover {
  border:1px solid transparent;
}
.arrowBtn {
  width:54px;
  height:54px;  
  border-radius:50%;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}
.arrowBtn:hover {
  background-color:var(--point);
}
.arrowBtn01 {
  background-color:#333333;
}
.arrowBtn02 {
  background-color:var(--point);
}
.arrowBtn02:hover {
  background-color:#000;
}
.arrowBtn .xi-lock:before {
    font-size:27px;
}
.textType01 {
  font-size:20px;
  font-weight:300;
  line-height:1.5;
}
/* header */
.main .header {top:45px;}
.header { position:fixed; top:0; left:0; width:100%; z-index:999999;}

.header.on,
.main .header.on {background-color:#fff; top:0;} 

.header.on {padding:48px 0; box-shadow:3px 3px 10px rgba(0, 0, 0, 0.25);}
.sub .header {position:fixed; padding:48px 0; box-shadow:3px 3px 10px rgba(0, 0, 0, 0.1); background-color:#fff;}
.sub .header.on {position:fixed;}
.sub .header::after {
  height:530px;
}
.header::after {
  display:none;
  content:'';
  width:100%;
  height:480px;
  background-color:#fff;
  position:absolute;
  top:-45px;
  left:0;
  z-index:-1;
  box-shadow:3px 3px 10px rgba(0,0,0,0.1);
}
.header.on::after {
    top:0;
}
.header.active::after {
  display:block;
}
.header .inner {
  width:100%;
  padding:0 40px;
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
  margin:0 auto;
  position:relative;
}
.header .logo img {width:141px;}
.header .gnb .gnb_main >li:not(:last-child) {padding-right:70px; position:relative;}
.header .gnb .gnb_main >li:not(:last-child)::after {
  content:'';
  width:4px;
  height:4px;
  border-radius:50%;
  background-color:#333;
  position:absolute;
  top:50%; transform:translateY(-50%);
  right:30px;
}
.header .gnb .gnb_main >li >a {font-size:24px; font-weight:600; color:#333333;}
.header .util li .login img {width:23px;}
.header .util li .sign img {width:32px;}
.header .util li .mypageIcon img {width:23px;}
.header .util li .login img,
.header .util li .sign img {opacity:0.5;}
.header .util li .mypageIcon img {opacity:0.3;}
.header .util li .login:hover img,
.header .util li .sign:hover img,
.header .util li .mypageIcon:hover img {
    opacity:1;
}
.header .util li .allBtn img {width:30px;}
.header .util li img.on {display:none;}
.header .util li img.on {display:block;}
.header .util li a {position:relative;}
.header .util li a:hover i {color:#fff;}
.header .util li:hover .textDesc {display:block;}
.header .util li {position:relative;}
.header .util li .textDesc {display:none; text-align:center; position:absolute; bottom:-25px; font-size:15px; width:200%; left:50%; transform:translateX(-50%);}
.header .util li img.off {display:none;}
.gnb {
    position: relative;
}
.gnb_main {
    display: flex;
}
.gnb_main > li {
    position: relative;
}
.gnb_main > li > a {
    display: block;
    padding: 15px 10px;
    font-size: 16px;
    font-weight: 500;
}
.header.active .gnb .gnb_main >li > .gnb_sub {
  display:block;
}
.header .gnb .gnb_main >li > .gnb_sub {
    display:none;
    position: absolute;
    top: 100%;
    left: 0;
    z-index: 50;
    width:100%;   
    height:350px; 
    padding-top:20px;
}
.gnb_sub li a {
    display: block;
    padding: 10px 15px;
    font-size: 17px;
    white-space: nowrap;
    color:#333;
}
.gnb_sub li a:hover {
  color:#000;
}
/* footer */
.footer {  
    width:100%;
    background-color:#e8e8e8;
    border-top:none;
    padding-top:60px;
    padding-bottom:0;
    position:relative;
}
.footer .inner {
    width:1660px;
    margin:0 auto;
}
.footer .boxWrap {
    width:100%;
    padding:60px 75px 35px 75px;
    border-top-left-radius:30px;
    border-top-right-radius:30px;
    background-color:#333;
    display:flex;
    flex-direction:row;
    align-items:stretch;
}
.footer .fooInfo01 {
    width:calc(100% - 380px);
    padding-right:80px;
    position:relative; 
    display:flex;
    flex-direction:row;
    justify-content:space-between;
    align-items:flex-end;
}
.footer .fooInfo01 .lfBox {
  height:100%;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
}
.footer .fooInfo01 .lfBox h2 {
  font-size:20px;
  font-weight:600;
  color:#fff;
  margin-bottom:20px;
  line-height:1;
}
.footer .fooInfo03 {
    padding-left:80px;
    width:270px;
}
.footer .logo {
    display:block;
    margin-bottom:20px;
    margin-left:80px;
    width:fit-content;
}
.footer .logo img {
    width:230px;
}
.footer .ftCompanyBox li p {
  font-size: 16px;
  font-weight:300;
  color: rgba(255, 255, 255, 0.502);
  text-transform: uppercase;
  line-height: 1.75;
  text-align: left;
}
.footer .ftCompanyBox li a {
  display:block;
  border-radius: 4px;
  background-color: rgb(237, 237, 237,0.251);
  width: 90px;
  height: 24px;
  line-height: 24px;
  font-size: 12px;
  color: rgb(255, 255, 255);
  text-align: center;
  margin:15px 0 40px 0;
}
.footer .ftCompanyBox li a:hover {
    background-color:#000;
}
.footer .ftSnsBox {
    gap:10px;
}
.footer .ftSnsBox,
.footer .fooInfo02 dl {
    display:flex;
    flex-direction:row;
    align-items:center;
}
.footer .ftSnsBox li a {
    display:block;
    width:60px;
    height:60px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    border-radius:50%;
    text-align:center;
    background-color:rgba(0,0,0,0.2);
}
.footer .ftSnsBox li a:hover {
    background-color:#000;
}
.footer .ftSnsBox li a:hover img {
    opacity:1;
}
.footer .ftSnsBox li a img {
    opacity:0.5;
}
.footer .ftSnsBox li:nth-child(1) a img {
    width:16px;
}
.footer .ftSnsBox li:nth-child(2) a img {
    width:31px;
}
.footer .ftSnsBox li:nth-child(3) a img {
    width:32px;
}
.footer .ftAgreeBox {
    text-align:right;
    margin-bottom:15px;
}
.footer .ftAgreeBox li {
    margin-bottom:15px;
}
.footer .ftAgreeBox li a {
  font-size: 18px;
  font-weight:400;
  color: rgba(255, 255, 255, 0.702);
  text-align: right;
  line-height:1;
}
.footer .ftAgreeBox .bold a {
    font-weight:500;
    color:#fff;
}
.footer .rightBox .copyright {
  font-size: 13px;
  font-weight:200;
  text-align:right;
  color: rgba(255, 255, 255, 0.302);
  text-align: center;
}
.footer .fooInfo02 {
    position:relative;
    width:380px;
    padding-left:80px;
}
.footer .fooInfo02::before {
    content:'';
    width:1px;
    height:250px;
    background-color:rgba(169,169,169,0.15);
    position:absolute;
    top:0;
}
.fooInfo02::before {
    left:0;
}
.fooInfo02::after {
    right:0;
}
.footer .fooInfo02 h3 {
  font-size: 28px;
  font-weight:500;
  color: rgb(255, 255, 255);
  line-height: 1;
  text-align: left;
}
.footer .fooInfo02 ul {
    margin:35px 0 40px 0;
}
.footer .fooInfo02 ul li:not(:last-child) {
    margin-bottom:15px;
}
.footer .fooInfo02 ul li dl {
    justify-content:space-between;
}
.footer .fooInfo02 ul li dt {
  font-size: 20px;
  font-weight:350;
  color: rgba(255, 255, 255, 0.502);
  text-transform: uppercase;
  line-height: 1.4;
  text-align: left;
}
.footer .fooInfo02 ul li dd a {
  font-size: 26px;
  font-weight:500;
  color:#fff;
  line-height: 1.077;
  text-align: right;
}
.footer .fooInfo02 ul li dd .mailText {
    font-size:17px;
    letter-spacing:-0.6px;
}
.footer .fooInfo02 .inquiryBtn {
  display:block;
  border-radius: 4px;
  background-color: var(--point); 
  width:100%;
  height: 60px;
  line-height:60px;
  text-align:center;
  font-size: 18px;
  font-weight:400;
  color: rgb(0, 0, 0);
}
.footer .fooInfo02 .inquiryBtn:hover {
    background-color:#000;
    color:#fff;
}
.footer .fooInfo03 li a {
  display:block;
  font-size: 18px;
  font-weight:400;
  color: rgba(255, 255, 255, 0.502);
  line-height: 1;
  text-align: left;
}
.footer .fooInfo03 li:not(:last-child) a {
  margin-bottom:30px;
}
.footer .ftAgreeBox li a:hover,
.footer .fooInfo02 ul li dd:not(.fax) a:hover,
.footer .fooInfo03 li a:hover {
    color:var(--point); 
}
.footer .fooInfo02 ul li dd.fax a {
    cursor:default;
}
.footer .selectCustom {
  appearance: none;          /* 크롬, 사파리 */
  -webkit-appearance: none;  /* 크롬, 사파리 구버전 */
  -moz-appearance: none;     /* 파이어폭스 */  
  width:100%;
  height:50px;
  background-color:#696969;
  font-size:18px;
  font-weight:400 !important;
  color:rgba(236,236,236,0.5);
  padding-left:25px;
  background-image:url('../../_images/common/footer_arrow.png');
  background-repeat:no-repeat;
  background-size:15px;
  background-position:95% 20px;
}
.footer .logoLeft img {
  width:141px;
}
.footer .infoBox {
  padding:0 70px 20px 70px;
  width:100%;
  box-sizing:border-box;
  display:flex;
  flex-direction:row;
  align-items:center;
  justify-content:space-between;
}
.footer .btnType02 {
  display:block;
  width:220px;
  height:60px;
  line-height:60px;
  border-radius:30px;
  background-color:#5a5a5a;
  font-size:20px;
  font-weight:300;
  color:#fff;
  text-align:center;
}
.footer .btnType02:hover {
  background-color:var(--point);
}
.footer .inner {
  position:relative;
}
.footer .arrowBtn {
  position:absolute;
  bottom:110px;
  right:-40px;
  width:72px;
  height:72px;
  border-radius:50%;
  background-color:#909090;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
}
.footer .arrowBtn:hover {
  background-color:var(--point);
}

/* start : 전체메뉴 */
body.no-scroll {overflow:hidden;}
#gnb { position:fixed; top:0; left:0; z-index:99999999999999999999;}
#gnb .boxWrap {width:100%; padding:35px 30px; box-sizing:border-box; position:relative; height:100vh; overflow-y:auto;}
#gnb.on {width:100%; height:100vh;}
#gnb.on .bg {display:block;}
#gnb.on .gnb_wrap {display:block; transform:translateX(0%); transition:all 0.6s; opacity:1;}
#gnb .bg {position:fixed !important; top:0 !important; left:0 !important; z-index:1; width:100%; height:100%; background-color:rgba(0,0,0,0.7); display:none;}
#gnb .gnbTopBox {align-items:center;}
#gnb #logoBox02 {align-items:center; position:relative;}
#gnb #logoBox02 a img {width:120px;}
#gnb #gnb_close {background-color:transparent; font-size:26px; position:absolute; right:30px; top:35px;}
#gnb #gnb_close i {color:#000;}
#gnb .gnb_wrap { max-width:500px; width:100%; height:100vh; background-color:#fff; position:fixed; top:0; right:0; transform: translateX(100%); z-index:9; opacity:0;}
#gnb .gnb_wrap::-webkit-scrollbar { width:1px; -webkit-transition: all 300ms; transition: all 300ms;}
#gnb .gnb_wrap::-webkit-scrollbar-track { width:10px; /* 스크롤바의 너비 */ background-color:#ddd; }
#gnb .gnb_wrap::-webkit-scrollbar-thumb {height:5%; /* 스크롤바의 길이 */ background:#fff; /* 스크롤바의 색상 */ background-clip: padding-box; border:2px solid transparent; border-radius: 8px; }
#gnb .gnb_left, 
#gnb .gnbTopBox {display:none; }
#gnb.on .gnb_left {display:block; } 
#gnb.on .gnbTopBox {display:flex;}
#gnb .gnb_left{ width:100%; margin: 0 auto; margin-top:30px; text-align:left; }
#gnb .gnb_left > li > a { display:block; font-family:var(--NotoSans); font-size:18px; font-weight:400; color:#000; padding:20px 0; border-bottom:1px solid #e6e6e6; box-sizing:border-box;}
#gnb .gnb_left > li > a.on {color:var(--point); font-weight:600; border-bottom:1px solid var(--point);}
#gnb .gnb_left > li > a > span { display:block; width:25px; float:right; text-align:center;}
#gnb .gnb_left > li > a > span::after {content: "\e942"; font-family: 'xeicon' !important; font-size:20px;}
#gnb .gnb_left > li > a > span.on::after {content:"\e945"; font-weight:400;}
#gnb .gnb_sub li a {font-family:var(--NotoSans); font-size:16px; font-weight:400; color:#333; padding:10px 0; display:block;}
#gnb .gnb_sub li a:hover {color:var(--point); }
#gnb .gnb_left > li:nth-child(1) > a {padding-top:0;}
#gnb .gnb_left ul { display:none; margin:15px 0;}
#gnb .gnb_left ul.on {display:block;}
#gnb .sidemenuMo {margin-top:30px; align-items:center;}
#gnb .sidemenuMo li {margin-right:15px;}
#gnb .sidemenuMo li a:hover i {color:var(--point); opacity:1;}
#gnb .sidemenuMo li a i {font-size:30px; color:#333; opacity:0.3;}
#gnb .sidemenuMo li:nth-child(2) a i {position:relative; top:0.5px; font-size:31px;}
#gnb .globalLink {margin-top:40px;}
#gnb .globalLink li:not(:last-child) {margin-right:15px;}
#gnb .globalLink li.active a {font-weight:600; color:var(--point); border-bottom:1px solid var(--point); box-sizing:border-box;}
#gnb .globalLink li a {display:block; font-size:16px; font-weight:400; color:#919191; line-height:1.2;}
#gnb .globalLink li:hover a {color:var(--point);}
#gnb .infoBox02 {padding-right:30px;}
#gnb .infoBox02 .globalLink {justify-content:end; margin-top:20px;}
/* end : 전체메뉴 */

.fullDown {
    display:none;
    border-top:1px solid #e5e5e5;
    box-sizing:border-box;
    background-color:#fff;
    box-shadow:-1px 20px 20px rgba(0, 0, 0, 0.25);
    position:absolute;
    top:65px;
    left:0;
    width:100%;
    z-index:15;
    padding:30px 0 50px 0;
}
.fullDown.active {
    display:block;
}
.fullDown .inner {
    display:flex;
    flex-direction:row;
    align-items:flex-start;
    gap:40px;
    width: 1600px;
    margin: 0 auto;
    position: relative;    
}
.fullDown ul {
    width:168px;
}
.fullDown ul:nth-child(4) {
    width:145px;
}
.fullDown ul:nth-child(3),
.fullDown ul:nth-child(5) {
    width:200px;
}
.fullDown ul:last-child {
    width:fit-content;
}
.fullDown ul li a {
    position:relative;
    font-size:17px;
    font-weight:300;
    color:#333333;
    line-height:1.3;
}
.fullDown ul li a::before {
    display:none;
    content:'';
    width:6px;
    height:6px;
    border-radius:50%;
    background-color:var(--pointColor);
    position:absolute;
    top:50%;
    transform:translateY(-50%);
    left:-12px;
}
.fullDown ul li:not(:last-child) {
    margin-bottom:10px;
}
.fullDown ul li:hover a {
    font-weight:500;
    color:#000;
}
.fullDown ul li:hover a::before {
    display:block;
}


/* =========================
   1440px 이하 : 내부 폭 풀로, 패딩만
   ========================= */
@media (max-width:1680px) {

  :root {
    --container: 1280px;
  }

  .sec .inner,
  .footer .inner {
    width: 100%;
    padding: 0 40px;
  }
  .footer .arrowBtn {right:0;}
  .footer .boxWrap {
    padding: 50px 50px 30px 50px;
  }

  .footer .infoBox {
    padding: 0 50px 20px 50px;
  }

  .container {
    max-width: var(--container);
    padding: 0 40px;
  }
  .footer .fooInfo01 .topBox li {
    display:block;
  }
  .footer .fooInfo01 {padding-right:20px; width:calc(100% - 270px);}
  .footer .fooInfo02 {padding-left:20px; width:270px;}
}

@media screen and (max-width:1480px) {
  .header .gap80 {gap:40px;}
  .header .logo img {width:120px;}
  .header .gnb .gnb_main >li >a {font-size:20px;}
  .infoBtn {width:130px; height:50px; line-height:48px; font-size:15px;}
  .arrowBtn {width:50px; height:50px;}
  .header .util li .login img {
      width:18px;
  }  
  .header .util li .sign img {width:26px;}
  .header .util li .allBtn img {width:26px;}  
}
@media (max-width: 1200px) {
  .sub .header, .header.on {padding:20px 0;}
  .footer .arrowBtn {position:fixed; right:20px; bottom:20px; z-index:9;}
  .footer .infoBox {padding:0 20px 20px 20px;}
  .footer .logoLeft img {width:120px;}
  .footer .btnType02 {width:150px; height:50px; line-height:50px; font-size:16px;}  
  .main .header {top:20px;}
  :root {
    --container: 1024px;
  }

  .header .inner {
    padding: 0 30px;
  }

  .header .gnb .gnb_main > li:not(:last-child) {
    padding-right: 40px;
  }
  .header .gnb .gnb_main > li:not(:last-child)::after {
    right: 18px;
  }
  .header .gnb .gnb_main > li > a {
    font-size: 20px;
  }

  .footer .boxWrap {
    padding: 40px 40px 30px 40px;
  }
  .footer .fooInfo02 h3 {
    font-size: 24px;
  }
  .footer .fooInfo02 ul li dt {
    font-size: 18px;
  }
  .footer .fooInfo02 ul li dd a {
    font-size: 22px;
  }
}

/* =========================
   1024px 이하 : 헤더/푸터 재정렬
   ========================= */
@media (max-width: 1024px) {
  .mb150 {margin-bottom:80px !important;}
  :root {
    --container: 100%;
  }

  .container {
    max-width: 100%;
    padding: 0 24px;
  }

  .sec .inner,
  .sec .inner02 {
    width: 100%;
    padding: 0 24px;
  }
  .header .inner {
    padding: 0 24px;
  }

  /* 데스크톱 GNB는 숨기고, 전체메뉴(#gnb)로 모바일 메뉴 처리 */
  .header .gnb {
    display: none;
  }

  /* 유틸 : 로그인/회원가입 텍스트는 숨겨두고 전체메뉴 버튼만 */
  .header .util li .login,
  .header .util li .sign {
    display: none;
  }

  /* 햄버거 버튼 느낌으로 쓰는 allBtn 크기만 보정 (이미지로 들어온다고 가정) */
  .header .util li .allBtn img {
    width: 28px;
  }

  /* 풀다운 메뉴는 태블릿 이하에서는 안 씀 */
  .fullDown {
    display: none !important;
  }

  /* footer 레이아웃 조금 타이트하게 */
  .footer {
    padding-top: 40px;
  }

  .footer .inner {
    width: 100%;
    padding: 0 20px;
  }

  .footer .boxWrap {
    padding: 32px 24px 24px 24px;
  }
  .footer .fooInfo03 {
    display: none; /* 필요하면 유지해도 됨 */
  }

  .footer .infoBox {
    padding: 0 24px 20px 24px;
  }

}

/* =========================
   768px 이하 : 완전 모바일 구조
   ========================= */
@media (max-width: 768px) {

  html, body {
    font-size: 15px;
  }

  .container {
    padding: 0 16px;
  }

  .sec .inner,
  .sec .inner02 {
    padding: 0 16px;
  }

  /* 헤더 모바일 */
  .header {
    padding: 14px 0;
  }
  .header .inner {
    padding: 0 16px;
  }
  .header .logo img {
    width: 100px;
  }
  .arrowBtn {
      width:45px;
      height:45px;
  }  
  .header .util .gap10 {gap:0;}
  .header .gnb {
    display: none;
  }
  .infoBtn {
      width:110px;
      height:45px;
      line-height:42px;
      font-size:14px;
      margin-right:10px !important;
  }
  .header.on {padding:15px 0;}
  .header .util li .allBtn img {width:25px;}
  /* 전체메뉴(#gnb) 버튼만 남기기 */
  .header .util {
    display: flex;
  }
  .header .util li .login,
  .header .util li .sign {
    display: none;
  }

  /* footer 컬럼 → 세로 스택 */
  .footer .boxWrap {
    flex-direction: column;
    padding: 32px 20px 24px 20px;
  }

  .footer .fooInfo01,
  .footer .fooInfo02 {
    width: 100%;
    padding: 0;
  }

  .footer .fooInfo01 {
    flex-direction: column;
    align-items: flex-start;
    gap: 24px;
  }

  .footer .fooInfo01 .lfBox h2 {
    font-size: 18px;
  }
  .footer .fooInfo01 .topBox {
    margin-bottom:20px;
  }
  .footer .logo {
    margin-left: 0;
  }
  .footer .logo img {
    width: 180px;
  }
  .footer .ftCompanyBox li {
    display:block;
  }
  .footer .ftCompanyBox li p {
    font-size: 14px;
  }

  .footer .ftAgreeBox {
    text-align: left;
  }
  .footer .ftAgreeBox li a {
    font-size: 15px;
  }

  .footer .fooInfo02 {
    margin-top: 30px;
  }

  .footer .fooInfo02::before {
    width: 100%;
    height: 1px;
    top: -16px;
  }

  .footer .fooInfo02 h3 {
    font-size: 22px;
  }

  .footer .fooInfo02 ul {
    margin: 24px 0 30px 0;
  }

  .footer .fooInfo02 ul li dt {
    font-size: 16px;
  }
  .footer .fooInfo02 ul li dd a {
    font-size: 20px;
  }

  .footer .fooInfo02 .inquiryBtn {
    height: 52px;
    line-height: 52px;
    font-size: 16px;
  }

  .footer .fooInfo03 {
    display: none;
  }

  .footer .infoBox {
    align-items: flex-start;
    padding: 12px 20px 20px 20px;
    gap: 16px;
  }

  .footer .btnType02 {
    text-align: center;
  }

  .footer .rightBox .copyright {
    text-align: left;
    font-size: 12px;
  }

  .footer .arrowBtn {
    width: 56px;
    height: 56px;
  }
  .footer .infoBox {align-items:center; gap:0; padding:0 5px 10px 5px;}
  .footer .logoLeft img {width:100px;}
  .footer .btnType02 {font-size:14px; width:140px; height:45px; line-height:45px;}
}

/* =========================
   480px 이하 : 초소형 모바일 튜닝
   ========================= */
@media (max-width: 480px) {

  body {
    font-size: 14px;
  }

  .header .logo img {
    width: 110px;
  }

  #gnb .boxWrap {
    padding: 24px 20px;
  }
  #gnb #logoBox02 a img {
    width: 100px;
  }

  #gnb .gnb_left > li > a {
    font-size: 16px;
    padding: 16px 0;
  }
  #gnb .gnb_sub li a {
    font-size: 14px;
  }

  .footer .boxWrap {
    padding: 28px 16px 20px 16px;
  }

  .footer .ftSnsBox li a {
    width: 48px;
    height: 48px;
  }

  .footer .fooInfo02 h3 {
    font-size: 20px;
  }
  .footer .fooInfo02 ul li dt {
    font-size: 14px;
  }
  .footer .fooInfo02 ul li dd a {
    font-size: 18px;
  }
  .footer .arrowBtn {
    width: 52px;
    height: 52px;
  }
    .footer .ftSnsBox li:nth-child(1) a img {
        width:12px;
    }
    .footer .ftSnsBox li:nth-child(2) a img {
        width:22px;
    }
    .footer .ftSnsBox li:nth-child(3) a img {
        width:25px;
    }  
}
