/* ========== Sibling Cupbap (남매컵밥) — Design Tokens ========== */

/* V-Web 공통 디자인 토큰 + 유틸리티 클래스 */
@import url("./vweb-common.css");

:root{
    /* ─── Brand Colors (from PSD audit — 남매컵밥) ─── */
    --mc:  #ea2837;   /* Main · 시그니처 빨강 (전화·NAM/MAE 박스·강조) */
    --sc:  #fff2d3;   /* Sub · 메인 hero 베이지 */
    --tc:  #f41527;   /* Tertiary · 진한 빨강 (CTA·포인트) */
    --fc:  #fff6e0;   /* BG · footer 베이지 (소프트 배경) */
    --fifc: #000000;   /* Dark · 본문 검정 */
    --black:#000000;
    --white:#ffffff;

    /* ─── Font Families ─── */
    --mf:  'Pretendard Variable', 'Pretendard', -apple-system, BlinkMacSystemFont, system-ui, sans-serif;   /* 한글/본문 */
    --sf:  'MBC1961', 'Pretendard Variable', sans-serif;                                                    /* 한글 타이틀 (굵은 임팩트) */
    --tf:  'Paperozi', 'Pretendard Variable', sans-serif;                                                   /* 한글 보조 임팩트 */
    --ff:  'Anton', 'Pretendard Variable', sans-serif;                                                      /* 영문/숫자 */
    --fiff:'HsJandari';

    /* ─── Font Size Tokens (px 기준 · 사용 시 vw 변환, 캔버스 1905) ─── */
    --fs-cap:    13px;
    --fs-body-s: 16px;   /* footer body */
    --fs-body:   18px;   /* default body · 헤더 메뉴 */
    --fs-body-l: 20px;
    --fs-sub:    24px;
    --fs-h6:     25px;   /* 헤더 전화번호 (Anton) */
    --fs-h5:     32px;
    --fs-h4:     42px;
    --fs-h3:     62px;
    --fs-h2:    110px;
    --fs-h1:    151px;
    --fs-mega:  232px;

    /* ─── Letter-spacing ─── */
    --ls-title: -0.025em;
    --ls-body:  -0.05em;

    /* ─── Legacy table tokens (그누보드 기본) ─── */
    --table-header: #fff6e0;
    --table-footer: #ea2837;
    --table-border: #d1d1d1;
    --font-black: #1a1a1a;
}


.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: 100%;
}


.exsm{ font-size:0.85vw; }


.sm{ font-size:0.95vw; }


.sm-md{ font-size:1.3vw; }


.semimd{ font-size:1.7vw; }


.md{ font-size:2vw; }


.exmd{ font-size:2.5vw; }


.md-lg{ font-size:3.4vw; }


.semilg{ font-size:3.9vw; }


.lg{ font-size:4.3vw; }


.exlg{ font-size:5vw; }

/* ========== 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; }


.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: smooth !important; }
/* ========== 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 ========== */ /* 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 */

header.drop{ position:fixed; animation:dropHeader .3s; }


header.insert{ position:fixed; animation:insertHeader .3s; top:-7rem; }


.header_logo_1{ width:100%; }


.header_logo_2{ width:72%; margin-top:-3%; }


.header_menu_1:hover{
    font-weight:700;
    color: var(--mc);
    border-top: 0.35vw solid transparent;
    border-bottom: 0.35vw solid var(--mc);
}


.header_menu_1.header_menu_form{
    background:#c21312; padding:.2vw .5vw; border-radius:.5vw;
}


.header_menu_1.header_menu_form:hover{ font-weight:400; }

/* 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;
}


.header_menu_1ab1 img{
    width: 100%;
}


.header_menu_1ab2 img{
    width: 100%;
}


.header_menu_1ab2{
    top: 0%;
    width: 65%;
    display: flex;
    justify-content: center;
    transition: 0.3s top;
    pointer-events: none;
    opacity: 0;
    align-items: center;
}
/*.header_menu_1:hover .header_menu_1ab1{*/
/*    bottom: 145%;*/
/*    display: flex;*/
/*    justify-content: center;*/
/*    align-items: center;*/
/*    opacity: 1;*/
/*}
*/
/*.header_menu_1:hover .header_menu_1ab2{*/
/*    top: 206%;*/
/*    width: 65%;*/
/*    display: flex;*/
/*    opacity: 1;*/
/*    justify-content: center;*/
/*    align-items: center;*/
/*}
*/


.face .face_top_2nd{
    margin-left: 0%;
    width: 75.5%;
    overflow: hidden;
    margin-top: 1.3% !important;
    font-size: 0.9vw;
}


.face .face_top_3rd{
    margin-left: 0%;
    width: 76%;
    margin-top: 0.2%;
    overflow: hidden;
}


.face .face_top_4th{
    margin-left: 0%;
    overflow: hidden;
    width: 75.6%;
    margin-top: 0.3%;
}


.face .face_top{
    height: 14.4vw;
    margin-top: 5.7%;
    margin-left: -75.3%;
    background: white;
    width: 0.01vw;
}


.semilg .line{
    overflow: hidden;
}


.md-lg .line{
    overflow: hidden;
}


.bold .line{
    overflow: hidden;
}


.sf .line{
    overflow: hidden;
}


.tf .line{
    overflow: hidden;
}


.menu_2nd .con7_mid_top_cate {
    display: flex
;
    justify-content: center;
    align-items: center;
    width: unset;
    white-space: nowrap;
    height: 100%;
    transition: 0.3s all;
    cursor: pointer;
}


.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;
}
/* gsap에서 넣을 class */

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


.header_tel img{
    width: 100%;
}

.header_menu_1ab1 {
    bottom: 0%;
    opacity: 0;
    display: flex;
    justify-content: center;
    align-items: center;
    transition: 0.3s bottom;
    pointer-events: none;
    background: var(--mc);
    width: 0.2vw;
    height: 0.2vw;
    overflow: hidden;
    border-radius: 50%;
}


.scaleX{
    transform: scaleX(-1);
}


.scaleY{
    transform: scaleY(-1);
}


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


.header_telab{
    left: 115%;
}

.header_menu_1 {
    white-space: nowrap;
    font-weight: 400;
    font-family: var(--mf) !important;
    display: flex;
    justify-content: center;
    align-items: center;
    width: 8%;
    height: 100%;
    box-sizing: border-box;
    transition: 0.2s border;
    border-top: 0.0vw solid transparent;
    border-bottom: 0.0vw solid var(--mc);
    color: white;
    position: relative;
}

.header_logo {
    display: flex;
    justify-content: space-between;
    align-items: center;
    width: unset;
    margin-left: 5%;
    padding: 1.1% 0;
    max-width: 13.455%;
}

.header_menu {
    box-sizing: border-box;
    position: relative;
    left: unset;
    transform: unset;
    font-family: var(--mf);
    font-size: .9vw;
    width: 53%;
    height: 100%;
    display: flex;
    justify-content: space-between;
    align-items: center;
    color: black;
    margin-left: 14%;
}

header {
    position: absolute;
    top: 0;
    z-index: 9999;
    font-size: .9vw;
    display: flex;
    justify-content: flex-start;
    align-items: center;
    background-color: white;
    transition: top .3s;
    padding: 0.5% 0;
    background: transparent;
    border-radius: unset;
    width: 100%;
    left: 50%;
    transform: translateX(-50%);
    border-bottom: 1.4px solid white;
}

.header_tel {
    display: flex;
    justify-content: flex-end;
    align-items: center;
    gap: 0.5vw;
    width: auto !important;
    background: transparent;
    padding: 0;
    right: 4.1995%;
    height: 100%;
    box-sizing: border-box;
    text-decoration: none;
    max-width: unset;
}

/* #hd_pop 안에 div가 없을 때만 pointer-events: none 적용 */

#hd_pop:not(:has(div)) {
    pointer-events: none;
}

/* ─── Sibling Cupbap header tel · PSD spec: icon 22×22 / num Anton 25px #ea2837 ─── */
.header_tel_icon {
    width: 1.1549vw;
    height: auto;
}
.header_tel img.header_tel_icon {
    width: 1.1549vw;
}
.header_tel_num {
    font-family: var(--ff);
    font-size: 1.3123vw;
    font-weight: 500;
    color: var(--mc);
    line-height: 1;
    letter-spacing: 0;
    white-space: nowrap;
}

/* ============================================================
   SIBLINGCUP HEADER OVERRIDE — panel과 동일 폭 (82.5197%), 중앙로고 양쪽메뉴
   PSD: 흰바 1572x93 @ x=174 y=-2 (1905 캔버스 기준)
   ============================================================ */
.header {
    position: fixed !important;
    top: 0;
    left: 50%;
    transform: translateX(-50%);
    width: 82.5197%; /* panel 폭과 동일 (1572/1905) */
    height: 4.8819vw; /* 93/1905 */
    background: #ffffff;
    border-bottom: none;
    padding: 0;
    z-index: 9999;
    box-sizing: border-box;
    display: flex;
    align-items: center;
    transition: top .3s;
}
.header_inner {
    position: relative;
    width: 100%;
    height: 100%;
    box-sizing: border-box;
}
/* ── 좌측 메뉴 그룹 (absolute left) ── */
.header_menu {
    width: auto;
    height: auto;
    margin: 0;
    background: transparent;
    font-family: var(--mf);
    color: #000;
    display: flex;
    align-items: center;
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    gap: 5vw;
    left: auto;
}
.header_menu_left  {
    /* PSD: 남매컵밥 x=367 (193 from header left)  */
    left: 12.2774%;  /* (367-174)/1572 */
    justify-content: flex-start;
}
.header_menu_right {
    /* PSD: 창업안내 x=1171 (997 from header left) */
    left: 63.4224%;  /* (1171-174)/1572 */
    justify-content: flex-start;
}
.header_menu_item {
    font-family: var(--mf);
    font-weight: 500;
    font-size: 0.8924vw; /* 17/1905 */
    color: #000;
    text-decoration: none;
    white-space: nowrap;
    letter-spacing: -0.025em;
    line-height: 1;
    transition: color 0.2s;
    display: inline-flex;
    align-items: center;
    padding: 0;
}
.header_menu_item:hover { color: var(--mc); font-weight: 600; }

/* ── 중앙 로고 (absolute center, panel/header 중심축에 정확히 정렬) ── */
.header_logo {
    position: absolute;
    top: 50%;
    left: 48.5%;
    transform: translate(-50%, -50%);
    width: 13.8583vw; /* 264/1905 — h_logo.png natural width */
    max-width: unset;
    margin: 0;
    padding: 0;
    display: flex;
    align-items: center;
    justify-content: center;
}
.header_logo_img {
    width: 100%;
    height: auto;
    display: block;
}

/* ── 우측 전화 (absolute right) ── */
.header_tel {
    position: absolute;
    top: 50%;
    right: auto;
    /* PSD: h_call x=1441 (1267 from header left) */
    left: 80.5980%;  /* (1441-174)/1572 */
    transform: translateY(-50%);
    display: inline-flex;
    align-items: center;
    gap: 0.4199vw; /* 8/1905 */
    background: transparent;
    padding: 0;
    text-decoration: none;
    height: auto;
}
.header_tel_icon {
    width: 1.1549vw; /* 22/1905 */
    height: 1.1549vw;
    display: block;
}
.header_tel img.header_tel_icon { width: 1.1549vw; }
.header_tel_num {
    font-family: var(--ff);
    font-weight: 400;
    font-size: 1.3123vw; /* 25/1905 */
    color: var(--mc);
    line-height: 1;
    letter-spacing: 0;
    white-space: nowrap;
}

/* ========== Responsive ========== */
@media (max-width:1023px) {

}
@media (max-width:599px) {
    /* ── 공통 유틸 ── */
    .pc-mobile{ display:none; }
    .mobile-pc{ display:flex; }
    .hd_pops_con{ width:100% !important; height:auto !important; }
    .hd_pops_footer{ font-size:2.6vw !important; }
    #hd_pop {
        height: 100vh;
        position: absolute;
        width: 100% !important;
        display: flex;
        justify-content: center;
        align-items: center;
        top: 5% !important;
    }
    #hd_pop > div {
        margin: 0 auto !important;
        left: auto !important;
        top: 5% !important;
        border-radius: 22px;
        overflow: hidden;
        width: 90% !important;
    }

    /* ── 모바일 헤더 바 (빨간 배경, 로고 가운데, 햄버거 우측) ── */
.header {
    position: fixed !important;
    top: 2vw;
    left: 2vw !important;
    width: 96vw !important;
    height: 11vw !important;
    transform: none !important;
    background: var(--tc) !important;
    border-bottom: none;
    /* border-radius: 0 !important; */
    padding: 0 !important;
    z-index: 9999;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100px;
}
    header.drop {
        position: fixed;
        animation: none;
        background: var(--tc) !important;
        transition: none;
    }
    header.insert { top: -15vw; }

    .header_inner {
        position: relative;
        width: 100%;
        height: 100%;
        display: flex !important;
        justify-content: center !important;
        align-items: center !important;
        padding: 0 5vw !important;
        box-sizing: border-box;
    }

    /* 로고 (가운데, 흰색 처리) */
    .header_inner .header_logo {
        position: relative !important;
        left: auto !important;
        top: auto !important;
        transform: none !important;
        width: 39vw !important;
        max-width: unset !important;
        margin: 0 !important;
        padding: 0 !important;
    }

    /* ── 슬라이드 패널 (header_open 상태일 때 우측에서 슬라이드인) ── */
    .header_inner .header_menu,
    .header_inner .header_tel {
        position: fixed;
        right: -100vw;
        left: auto !important;
        transform: none !important;
        margin: 0 !important;
        background: var(--tc);
        transition: right 0.35s ease;
        box-sizing: border-box;
        width: 50vw;
        height: auto;
    }
    .header_menu{
        z-index: 0;
    }

    /* 좌측 메뉴 (남매컵밥/경쟁력/수익률) — 패널 상단 */
.header_inner .header_menu_left {
    top: 8vw;
    padding: 10vw 8vw 5vw 8vw;
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 5vw;
    border-bottom: 1px solid rgba(255,255,255,0.2);
}
    /* 우측 메뉴 (창업안내/창업문의) — 좌측 메뉴 아래 */
.header_inner .header_menu_right {
    top: calc(15vw + 33vw);
    padding: 0 8vw 6vw 8vw;
    display: flex !important;
    flex-direction: column;
    align-items: flex-start;
    gap: 5vw;
    border-bottom: 1px solid rgba(255,255,255,0.2);
}
    /* 전화 — 패널 하단 */
.header_inner .header_tel {
    top: calc(15vw + 57vw);
    padding: 3vw 0;
    width: 50vw !important;
    justify-content: center;
    display: flex !important;
    flex-direction: row;
    align-items: center;
    gap: 3vw;
}

    /* 드롭 활성화 */
    header.header_open .header_inner .header_menu,
    header.header_open .header_inner .header_tel {
        right: 2vw;
    }

    /* 메뉴 아이템 (흰색 큰 글씨) */
    .header_inner .header_menu_item {
        color: #ffffff !important;
        font-size: 4.3vw;
        font-weight: 600;
        text-decoration: none;
        width: 100%;
        text-align: left;
        padding: 0;
        white-space: nowrap;
        line-height: 1.2;
        letter-spacing: -0.025em;
    }
    .header_inner .header_menu_item:hover { color: rgba(255,255,255,0.7) !important; }

    /* 전화 패널 안 표시 */
    .header_inner .header_tel_icon {
        width: 6vw;
        height: 6vw;
        filter: brightness(0) invert(1);
    }
    .header_inner .header_tel img.header_tel_icon { width: 5vw; }
    .header_inner .header_tel_num {
        color: #ffffff;
        font-size: 6vw;
        font-weight: 500;
        line-height: 1;
    }

    /* ── 햄버거 버튼 (우측, 흰색 라인) ── */
    .hamburger {
        position: absolute;
        top: 50%;
        right: 5vw;
        transform: translateY(-50%);
        background: transparent;
        border: 0;
        padding: 0;
        z-index: 10000;
        cursor: pointer;
        width: 10vw;
        height: 10vw;
        display: flex;
        align-items: center;
        justify-content: center;
    }
    .hamburger-menu {
        width: 7vw;
        height: 5vw;
        position: relative;
        display: flex;
        justify-content: center;
        align-items: center;
    }
    div.line {
        width: 100%;
        height: 0.5vw;
        background: #ffffff !important;
        position: absolute;
        left: 0;
        transition: all 0.3s;
        transform-origin: center;
        margin: 0 !important;
        border-radius: 0;
    }
    .top-reverse { top: 0; }
    .mid-reverse { top: 50%; transform: translateY(-50%); }
    .bot-reverse { bottom: 0; }
    .line_change.top-reverse {
        top: 50%;
        transform: translate(0, -50%) rotate(45deg);
    }
    .line_change.mid-reverse { opacity: 0; }
    .line_change.bot-reverse {
        bottom: 50%;
        transform: translate(0, 50%) rotate(-45deg);
    }
    #line-mid { background: #ffffff !important; }

    /* quick 등 기존 구조 유지 */
    .header_quick { top: 48%; right: 0; gap: 1.5vw; }
    .header_quick_item { width: 13vw; height: 13vw; }
    .header_quick_item02 { width: 16vw; height: 16vw; }
}

