/* ========== Design Tokens ========== */
:root{
    --mc:#0a1959;
    --sc:#3d5eed;
    --tc:#7680a3;
    --fc:#f2f2f7;
    --mf:'Pretendard variable';
    --ef:'Anton';

    --table-header: #f2f2f7;
    --table-footer: #3d5eed;
    --table-border: #d1d1d1;
    --font-black: #1a1a1a;

}
section img{
    width: unset !important;
    max-width: 100%;
    min-width: 99%;
}
.fwrap{
    flex-wrap: wrap;
}
/* 사이트 로딩 초기화 스타일 */
/* 사이트 전체를 일단 숨김 (투명도 0 + 클릭 방지) */
/*body {*/
/*    visibility: hidden;*/
/*    opacity: 0;*/
/*}*/

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Thin.woff2') format('woff2');
    font-weight: 100;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-ExtraLight.woff2') format('woff2');
    font-weight: 200;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Light.woff2') format('woff2');
    font-weight: 300;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Regular.woff2') format('woff2');
    font-weight: normal;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Medium.woff2') format('woff2');
    font-weight: 500;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-SemiBold.woff2') format('woff2');
    font-weight: 600;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Bold.woff2') format('woff2');
    font-weight: 700;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-ExtraBold.woff2') format('woff2');
    font-weight: 800;
    font-display: swap;
}

@font-face {
    font-family: 'Suit';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_suit@1.0/SUIT-Heavy.woff2') format('woff2');
    font-weight: 900;
    font-display: swap;
}


@font-face {
    font-family: 'aHeadlineM';  /* 앞으로 이 폰트를 부를 이름 */
    /* 주의: 경로 설정을 잘 해야 합니다. */
    src: url('/font/a헤드라인M.ttf') format('truetype');
    font-weight: normal;
    font-style: normal;
    font-display: swap; /* 폰트 로딩될 때까지 기본 폰트로 글자 보여주기 (깜빡임 방지) */
}

@font-face {
    font-family: 'SF_HambakSnow';
    src: url('https://fastly.jsdelivr.net/gh/projectnoonnu/noonfonts_2106@1.1/SF_HambakSnow.woff') format('woff');
    font-weight: normal;
    font-style: normal;
}


@font-face {
    font-family: 'NanumSquareNeo';
    src: url(https://hangeul.pstatic.net/hangeul_static/webfont/NanumSquareNeo/NanumSquareNeoTTF-aLt.woff2);
    font-weight: 300;
    font-display: swap;
}
@font-face {
    font-family: 'HsJandari';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/2510-2@1.0/HSJandari.woff2') format('woff2');
    font-weight: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Saenggeojincheon';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2212@1.0/SaenggeoJincheon.woff2') format('woff2');
    font-weight: normal;
    font-display: swap;
}
@font-face {
    font-family: 'YeogiOttaeJalnan';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_four@1.2/JalnanOTF00.woff') format('woff');
    font-weight: normal;
    font-display: swap;
}
@font-face {
    font-family: 'MungyeongGamhongApple';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/2410-2@1.0/Mungyeong-Gamhong-Apple.woff2') format('woff2');
    font-weight: normal;
    font-display: swap;
}
@font-face {
    font-family: 'SuSeongHyeJeong';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2205-2@1.0/SuseongHyejeong.woff2') format('woff2');
    font-weight: normal;
    font-display: swap;
}
@font-face {
    font-family: 'SolmoeKimDaegeon';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts-20-12@1.0/kdg_Light.woff') format('woff');
    font-weight: 300;
    font-display: swap;
}

/* ========== Resets & Base ========== */
*,
*::before,
*::after{ box-sizing:border-box; }

html, body { margin:0; padding:0; }

p{ word-break:keep-all; }

section p{ letter-spacing:-0.04vw; }

/* Prefer visible focus; override where necessary with a custom ring */
:focus-visible{
    outline:2px solid var(--mc);
    outline-offset:2px;
}

/* ========== Typography Utilities ========== */
.sst{ font-family:var(--sf); font-weight:400; font-size:1vw; line-height:1.5; }
.tst{ font-family:var(--tf); font-weight:400; font-size:1vw; line-height:1.5; }
.mst{ font-family:var(--mf); font-weight:400; font-size:1vw; line-height:1.5; }

.mf{ font-family:var(--mf); font-weight:400; line-height: 1.5}
.sf{ font-family:var(--sf); font-weight:300; line-height: 1.25}
.tf{ font-family:var(--tf); font-weight:300; } /* fixed: was var(--tc) */
.ff{ font-family:var(--ff); font-weight:300; } /* fixed: was var(--tc) */
.fiff{ font-family:var(--fiff); font-weight:300; } /* fixed: was var(--tc) */

/* Optional semantic weight */
.black{ font-weight:900; }
.extrabold{ font-weight:800; }
.bold{ font-weight:700; }
.semibold{ font-weight:600; }
.medium{ font-weight:500; }
.regular{ font-weight:400; }
.light{ font-weight:300; }
.extralight{ font-weight:200; }
.thin{ font-weight:100; }
.underline{
    line-height: 1.15;
    border-bottom: 0.1vw solid black;
}
.mc.underline{
    border-bottom: 0.1vw solid var(--mc);
    line-height: 1.15;
}
section img{
    width: unset !important;
    max-width: 100%;
    min-width: 99%;
}

/* PSD 기준 (÷1905) */
.exsm{ font-size:0.8399vw; }   /* 16px — 폼/placeholder/카피라이트 */
.sm{ font-size:0.9449vw; }     /* 18px — 상세본문/CTA/버튼 */
.sm-md{ font-size:1.0499vw; }  /* 20px — 설명 본문 */
.sm-md2{ font-size:1.1549vw; } /* 22px — 카드 설명 */
.semimd{ font-size:1.3123vw; } /* 25px — 중간 본문 */
.md{ font-size:1.5748vw; }     /* 30px — 인용문/강조 */
.exmd{ font-size:1.8373vw; }   /* 35px — 섹션 서브타이틀 */
.md-lg{ font-size:2.6772vw; }  /* 51px — 섹션 대타이틀 */
.semilg{ font-size:2.8871vw; } /* 55px — 섹션 대타이틀 */
.lg{ font-size:3.6745vw; }     /* 70px — MV 타이틀 */
.exlg{ font-size:4.1995vw; }   /* 80px — 빅 타이틀 (CONNECTA 등) */

/* ========== Color Utilities ========== */
.mcbg{ background:var(--mc); }
.scbg{ background:var(--sc); }
.tcbg{ background:var(--tc); }
.fcbg{ background:var(--fc); }
.fifcbg{ background:var(--fifc); }

.mc{ color:var(--mc); }
.sc{ color:var(--sc); }
.tc{ color:var(--tc); }
.fc{ color:var(--fc); }
.fifc{ color:var(--fifc); }


/* ========== Layout Utilities ========== */
.vcline{ height:100%; width:0.01vw; }
.hzline{ width:100%; height:0.01vw; }

.absol{ position:absolute; }
.rltv{ position:relative; }

.flexrow{
    width:100%; display:flex; justify-content:center; align-items:center; flex-direction:row;
}
.flexcol{
    width:100%; display:flex; justify-content:center; align-items:center; flex-direction:column;
}

.pc-mobile{ display:flex; }
.mobile-pc{ display:none; }
html { scroll-behavior: auto !important; } /* Lenis */
/* ========== Scroller (Marquee) ========== */
.scrX{
    width:100%; display:flex; justify-content:center; align-items:center;
}
.scrX .scrX_item{
    animation:marqueeX 20s linear infinite; width:100%;
}
.scrX .scrX_item_absol{ right:-100%; width:100%; }
.scrX.reverse .scrX_item{ animation-direction:reverse; }
.scrY.reverse .scrY_item{ animation-direction:reverse; }
.scrX.slow .scrX_item{ animation-duration:40s; }

/* ========== Components ========== */
#bo_v > header{ display:none; } /* keep only once */

/* Buttons (new) */
.k_new_btn{
    display:flex; justify-content:center; align-items:center; width:100%; margin:2% 0 6%;
}
.k_btn_inner{
    font-size:1.5vw; background:#000; color:#fff; padding:1% 3%;
    border-radius:30px; display:inline-flex; align-items:center; gap:.5em;
    white-space: nowrap;
}
.k_btn_inner > a{ color:#fff; text-decoration:none; }
.k_new_btn > .k_btn_inner:nth-child(2){
    background:#0000008f; margin-left:2%; padding:.7% 2% !important;
}
.k_btn_inner > input{
    outline:none; appearance:none; border:0; background:transparent; color:#fff; font-size:1.1em;
}
.zin{
    z-index: 2;
    position: relative;
}
.absol{
    position: absolute;
}
/* Board */
#bo_v > header{
    display:block; position:relative; background:transparent; padding:0;
    border-bottom:1px solid #000; font-family:var(--mf); /* de-duped */
}
#bo_v_title .bo_v_tit,
.board_title{
    font-family:var(--mf); font-weight:700; letter-spacing:-1px;
}
#bo_v_title .bo_v_tit{ font-size:17px; margin:5px 0 0; word-break:break-all; }

#bo_v_con{
    margin:30px 0; width:100%; min-height:200px; overflow:hidden;
    line-height:1.7; font-size:1.3em; font-family:var(--mf); word-break:break-all;
}

#bo_w .bo_w_tit .frm_input{ padding-right:0; }

/* Header — konnector */
header{
    position:fixed; top:0; left:0; z-index:9999; width:100%;
    display:flex; justify-content:space-between; align-items:center;
    background:rgba(255,255,255,0.95); padding:1.0499% 0;
    transition: background 0.3s, box-shadow 0.3s;
    border-bottom:1px solid rgba(0,0,0,0.06);
}
header.drop{
    background:#fff;
    box-shadow:0 0.1050vw 0.5249vw rgba(0,0,0,0.08);
}

.header_logo{
    display:flex; align-items:center;
    width:9.3438%; margin-left:6.3517%;
}
.header_logo a{ display:flex; align-items:center; width:100%; }
.header_logo img{ width:100%; }

.header_menu{
    display:flex; align-items:center;
    margin-right:6.2467%; gap:2.6247vw;
    font-family:var(--mf); font-size:0.8924vw; font-weight:600;
}
.header_menu_1{
    color:#000; text-decoration:none; white-space:nowrap;
    transition: color 0.3s;
    position:relative;
}
.header_menu_1::after{
    content:''; position:absolute; top:50%; left:50%;
    transform:translate(-50%,-50%); width:0.9449vw; height:0.9449vw;
    background:var(--mc); border-radius:50%;
    opacity:0; transition: opacity 0.25s;
    pointer-events:none;
}
.header_menu_1:hover{ color:transparent; }
.header_menu_1:hover::after{ opacity:1; }

/* Quick */
.header_quick{
    position:fixed; top:30%; right:2%; display:flex; flex-direction:column;
    gap:.5vw; z-index:33333;
}
.header_quick_item{
    width:4vw; height:4vw; display:flex; justify-content:center; align-items:center;
    border-radius:50%; font-size:1vw; color:#fff; font-family:var(--mf); cursor:pointer; transition:.3s;
}
.header_quick_item img{ width:100%; }
.header_quick_item02{ width:5vw; height:5vw; font-size:1.4vw; }

/* Content wrap */
#content_wrap{ padding-bottom:0 !important; }

/* Popups */
#hd_pop > div{ border-radius:30px; overflow:hidden; background:#000; }
.hd_pops img{ width:100% !important; }
#hd_pop > div > div > iframe{ height:100%; }
.hd_pops_footer{ font-size:.9vw !important; }
.hd_pops_footer .hd_pops_reject{ font-family:var(--mf); font-weight:700; }
.hd_pops_footer .hd_pops_close{ background:#000; bottom:0; }

/* ========== Fonts ========== */
@font-face {
    font-family: 'SfHambakneun';
    src: url('https://cdn.jsdelivr.net/gh/projectnoonnu/noonfonts_2106@1.1/SF_HambakSnow.woff') format('woff');
    font-weight: normal;
    font-display: swap;
}
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-1Thin.woff2') format('woff2'); font-weight:100; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-2ExtraLight.woff2') format('woff2'); font-weight:200; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-3Light.woff2') format('woff2'); font-weight:300; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-4Regular.woff2') format('woff2'); font-weight:400; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-5Medium.woff2') format('woff2'); font-weight:500; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-6SemiBold.woff2') format('woff2'); font-weight:600; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-7Bold.woff2') format('woff2'); font-weight:700; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-8ExtraBold.woff2') format('woff2'); font-weight:800; font-display:swap; }
@font-face{ font-family:'Paperozi'; src:url('https://cdn.jsdelivr.net/gh/projectnoonnu/2408-3@1.0/Paperlogy-9Black.woff2') format('woff2'); font-weight:900; font-display:swap; }



@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 100;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 200;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 300;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 400;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 500;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 600;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 700;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 800;
    font-style: normal;
}
@font-face{
    font-family: "proxima-nova", sans-serif;
    font-weight: 900;
    font-style: normal;
}


/* ========== Animations ========== */
@keyframes marqueeX{ from{ transform:translateX(0); } to{ transform:translateX(-100%);} }
@keyframes marquee3{ from{ transform:translateX(0);} to{ transform:translateX(-100%);} }
@keyframes blk{ 0%,30%{opacity:0;} 31%,99%{opacity:1;} 100%{opacity:0;} }
@keyframes blk2{ 0%,49%{opacity:0;} 50%,99%{opacity:1;} 100%{opacity:0;} }

@keyframes ddm_m{ 0%{transform:scale(1);} 50%{transform:matrix(1.05,0.01,0.01,1.05,0,-15);} 100%{transform:scale(1);} }
@keyframes ddm_m_reverse{ 0%{transform:scale(1);} 50%{transform:matrix(0.8,0.01,0.01,0.8,0,-5);} 100%{transform:scale(1);} }

@keyframes line-top{ from{ transform:translateY(0);} to{ transform:translateY(13px);} }
@keyframes line-top-reverse{ from{ transform:translateY(13px);} to{ transform:translateY(0);} }
@keyframes line-top-rotate{ from{ transform:translateY(13px) rotateZ(0);} to{ transform:translateY(13px) rotateZ(45deg);} }
@keyframes line-top-rotate-reverse{ from{ transform:translateY(13px) rotateZ(45deg);} to{ transform:translateY(13px) rotateZ(0);} }
@keyframes line-mid{ from{ transform:scale(1);} to{ transform:scale(0);} }
@keyframes line-mid-reverse{ from{ transform:scale(0);} to{ transform:scale(1);} }
@keyframes line-mid-invisible{ from{ transform:scale(0);} to{ transform:scale(0);} }
@keyframes line-bot{ from{ transform:translateY(0);} to{ transform:translateY(-13px);} }
@keyframes line-bot-reverse{ from{ transform:translateY(-13px);} to{ transform:translateY(0);} }
@keyframes line-bot-rotate{ from{ transform:translateY(-13px) rotateZ(0);} to{ transform:translateY(-13px) rotateZ(135deg);} }
@keyframes line-bot-rotate-reverse{ from{ transform:translateY(-13px) rotateZ(135deg);} to{ transform:translateY(-13px) rotateZ(0);} }

@keyframes dropHeader{ from{ top:-7rem;} to{ top:0;} }
@keyframes insertHeader{ from{ top:0;} to{ top:-7rem;} }
.bgimg {
    width: 106% !important;
    height: 100% !important;
    position: absolute;
    object-fit: cover;
    display: block;
    pointer-events: none;
    z-index: 0;
}

.white{
    color: white;
}

.whitebg{
    background: white;
}

/* ========== Clip-path Utilities ========== */
.clip_left{ clip-path:polygon(0 0,0 0,0 100%,0% 100%); transition:all 0.8s; }
.clip_right{ clip-path:polygon(100% 0,100% 0,100% 100%,100% 100%); transition:all 0.8s; }
.clip_mid{ clip-path:polygon(50% 0,50% 0,50% 100%,50% 100%); transition:all 0.8s; }
.clip_circle{ clip-path:circle(0% at 50% 50%); transition:all 2s !important; }
.clip_bottom{ clip-path:polygon(0 100%,100% 100%,100% 100%,0% 100%); transition:all 0.8s; }
.clip_top{ clip-path:polygon(0 0,100% 0,100% 0,0 0); transition:all 0.8s; }
.clip_on{ clip-path:polygon(0 0,100% 0,100% 100%,0 100%) !important; }
.clip_on2{ clip-path:polygon(0 100%,100% 100%,100% 0,0 0) !important; }
.clip_on3{ clip-path:polygon(0 0,100% 0,100% 100%,0 100%) !important; }
.clip_on4{ clip-path:circle(100.0% at 50% 50%) !important; }
.clip_right_on{ clip-path:polygon(100% 0,0 0,0 100%,100% 100%); }

.scaleX{ transform:scaleX(-1); }
.scaleY{ transform:scaleY(-1); }
.scaleanti{ transform:scale(-1); }

/* #hd_pop 안에 div가 없을 때만 pointer-events: none 적용 */
#hd_pop:not(:has(div)) {
    pointer-events: none;
}

/* ========== Responsive ========== */
@media (max-width:599px){
    .pc-mobile{ display:none; }
    .mobile-pc{ display:flex; }

    /* 헤더 */
    header{
        background:rgba(255,255,255,0.95); height:15vw; padding:0;
        border-bottom:1px solid rgba(0,0,0,0.08);
    }
    header.drop{ background:#fff; box-shadow:0 0.5vw 2vw rgba(0,0,0,0.08); }
    .header_logo{ width:25%; margin-left:5%; }

    /* 햄버거 */
    .hamburger{ position:absolute; top:50%; right:5%; transform:translateY(-50%); z-index:10000; }
    .hamburger-menu{
        width:7vw; height:4.5vw; position:relative;
        display:flex; justify-content:center; align-items:center;
    }
    .hamburger div.line{
        background:var(--mc); width:100%; height:2px;
        position:absolute; transition:all 0.3s; transform-origin:center;
        margin:0 !important; border-radius:0;
    }
    .top-reverse{ top:0; }
    .bot-reverse{ bottom:0; }
    .line_change.top-reverse{ top:50%; transform:translate(0,-50%) rotate(45deg); background:#fff; }
    .line_change.mid-reverse{ opacity:0; }
    .line_change.bot-reverse{ bottom:50%; transform:translate(0,50%) rotate(-45deg); background:#fff; }

    /* 모바일 메뉴 슬라이드 */
    .header_menu{
        position:fixed !important; right:-100%; top:0;
        width:60%; height:100vh; padding:20% 4% 0 10%;
        background:var(--mc); font-size:4.5vw;
        display:flex; flex-direction:column; gap:3vh;
        justify-content:flex-start; align-items:flex-start;
        pointer-events:none; transition:right 0.3s;
        margin-right:0; box-sizing:border-box;
    }
    .header_menu.header_menu_drop{
        right:0; pointer-events:auto; opacity:1;
    }
    .header_menu_1{
        color:#fff; font-weight:500; width:100%;
        display:flex; justify-content:flex-start; align-items:center;
    }
    .header_menu_1::after{ display:none; }
    .header_menu_1:hover{ color:var(--sc); font-weight:600; }

    /* 폰트 사이즈 모바일 */
    .exsm{ font-size:3.1vw; }
    .sm{ font-size:3.45vw; }
    .sm-md{ font-size:3.8vw; }
    .sm-md2{ font-size:3.9vw; }
    .semimd{ font-size:4.2vw; }
    .md{ font-size:5.8vw; }
    .exmd{ font-size:6.5vw; }
    .md-lg{ font-size:8.5vw; }
    .semilg{ font-size:9.7vw; }
    .lg{ font-size:9.3vw; }
    .exlg{ font-size:14vw; }

    /* 팝업 */
    #hd_pop{ width:100% !important; height:100vh; position:absolute; top:3% !important; display:flex; justify-content:center; align-items:center; }
    #hd_pop > div{ margin:0 auto !important; left:auto !important; top:5% !important; width:85% !important; border-radius:22px; overflow:hidden; }
    .hd_pops_con{ width:100% !important; height:auto !important; }
    .hd_pops_footer{ font-size:2.6vw !important; }
}