/* ============================================
   1. HEADER
   ============================================ */
.site-header {
    position: sticky;
    top: 0;
    z-index: 1000;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    transition: box-shadow 0.3s ease;
}

.site-header.scrolled {}

.header-inner {
    max-width: 100%;
    margin: 0 auto;
    padding: 0 65px;
    height: 90px;
    display: flex;
    align-items: center;
    justify-content: space-between;
}

.site-logo {
    display: flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    flex-shrink: 0;
}

.site-logo svg {
    flex-shrink: 0;
}

.site-logo-text {
    display: flex;
    flex-direction: column;
    line-height: 1.25;
}

.logo-name {
    font-size: 15px;
    font-weight: 700;
    color: rgb(30, 40, 50);
    letter-spacing: -0.3px;
    white-space: nowrap;
}

.header-account {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 36px;
    height: 36px;
    flex-shrink: 0;
    color: #1c1c1c;
    transition: opacity 0.15s ease;
}

.header-account:hover {
    opacity: 0.6;
}

.main-nav {
    display: flex;
    align-items: center;
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
    z-index: 5;
    /* transform 으로 스택 컨텍스트가 생기므로, 메가 선반(.mega-shelf) 위로 올려 서브메뉴가 가려지지 않게 함 */
}

/* 헤더 inner는 relative로 (절대 위치 nav의 기준점) */
.header-inner {
    position: relative;
}

/* 1차 메뉴 리스트 */
.main-nav .nav-list {
    display: flex;
    align-items: center;
    gap: 80px;
    list-style: none;
}

/* 1차 메뉴 li — 드롭다운 기준점 */
.main-nav .nav-list>li {
    position: relative;
}

/* 1차 링크 */
.main-nav .nav-list>li>a {
    display: flex;
    align-items: center;
    gap: 4px;
    padding: 8px 12px;
    font-size: 18px;
    font-weight: 700;
    color: #1c1c1c;
    transition: opacity 0.15s ease;
    position: relative;
    white-space: nowrap;
}

/* ::after 언더라인 제거 */
.main-nav a::after {
    display: none;
}

.main-nav .nav-list>li>a:hover {
    opacity: 0.6;
    color: #1c1c1c;
}

/* has-children 화살표 */
.main-nav .nav-list>li.menu-item-has-children>a::before {
    display: none;
}

.main-nav .nav-list>li.menu-item-has-children:hover>a::before {
    display: none;
}


/* ============================================
   메가메뉴 — 헤더에 마우스 올리면 전체 폭 패널이 아래로 펼쳐짐
   ============================================ */

/* 전체 폭 흰색 선반(패널) — 헤더 바 바로 아래에 깔림.
   .site-header 의 자식이라 이 위에 마우스가 있어도 헤더 hover 가 유지됨(컬럼 사이 빈 공간 브릿지) */
.mega-shelf {
    position: absolute;
    left: 0;
    right: 0;
    top: 100%;
    height: 0;
    background: rgba(255, 255, 255, 0.85);
    backdrop-filter: blur(15px);
    box-shadow: 0 8px 15px rgba(149, 157, 165, 0.07);
    opacity: 0;
    visibility: hidden;
    overflow: hidden;
    transition: height 0.28s ease, opacity 0.2s ease, visibility 0.28s;
    z-index: 1;
}

.site-header:hover .mega-shelf {
    height: 210px;
    opacity: 1;
    visibility: visible;
}

/* ---- 서브메뉴 = 패널 안의 컬럼 (각 1차 항목 바로 아래 중앙 정렬) ---- */
.main-nav .nav-list>li>.sub-menu {
    position: absolute;
    top: calc(100% + 50px);
    left: 50%;
    transform: translateX(-50%) translateY(-8px);
    min-width: 120px;
    background: transparent;
    border-radius: 0;
    box-shadow: none;
    padding: 0;
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 18px;
    opacity: 0;
    visibility: hidden;
    transition: opacity 0.2s ease, transform 0.28s ease, visibility 0.2s;
    z-index: 2;
    pointer-events: none;
}

/* 헤더 어디든 마우스가 올라오면 모든 컬럼이 함께 펼쳐짐 (첨부 이미지처럼) */
.site-header:hover .main-nav .nav-list>li>.sub-menu {
    opacity: 1;
    visibility: visible;
    transform: translateX(-50%) translateY(0);
    pointer-events: auto;
}

/* 서브메뉴 링크 */
.main-nav .nav-list>li>.sub-menu li a {
    display: block;
    padding: 0;
    font-size: 17px;
    font-weight: 400;
    color: #000;
    opacity: 0.7;
    text-align: center;
    white-space: nowrap;
    transition: color 0.12s ease;
}

.main-nav .nav-list>li>.sub-menu li a:hover {
    color: #1c1c1c;
    opacity: 1;
    background: transparent;
}

/* 모바일에서는 메가 선반 비활성화 (기존 off-canvas 메뉴 유지) */
@media (max-width: 768px) {
    .mega-shelf {
        display: none !important;
    }
}





/* Mobile menu toggle */
.menu-toggle {
    display: none;
    background: none;
    border: none;
    cursor: pointer;
    padding: 8px;
}

.menu-toggle span {
    display: block;
    width: 22px;
    height: 2px;
    background: #1c1c1c;
    margin: 5px 0;
    transition: all 0.3s ease;
}

/* 로고 sub: 진료과 표시 */
.logo-sub {
    font-size: 11px;
    color: #6b7280;
    font-weight: 500;
    letter-spacing: -0.2px;
    margin-top: 2px;
}

/* 임시 로고 이미지 사이즈 */
.site-logo-img {
    height: 45px;
    width: auto;
    display: block;
}

/* ============================================
   현재 페이지 메뉴 active 표시 (ludental 레퍼런스)
   2026-06-12 추가
   ============================================ */
/* 1차 메뉴 (현재 페이지가 속한 상위) — 하단 밑줄 */
.main-nav .nav-list>li.current-menu-item>a,
.main-nav .nav-list>li.current-menu-parent>a,
.main-nav .nav-list>li.current-menu-ancestor>a,
.main-nav .nav-list>li.current_page_item>a,
.main-nav .nav-list>li.current_page_parent>a,
.main-nav .nav-list>li.current_page_ancestor>a {
    color: #233E71;
}


/* 2차(드롭다운) 현재 항목 — 앞에 점 + 강조 */
.main-nav .nav-list>li>.sub-menu li.current-menu-item>a,
.main-nav .nav-list>li>.sub-menu li.current_page_item>a {
    color: #233E71;
    opacity: 1;
    font-weight: 700;
}

/* ============================================
   현재위치(current) 표시 v2 — ref ludental.co.kr (2026-06-13)
   1차: 헤더 바닥 2px 밑줄이 가운데서 양옆으로 차오름 (width 0→100%, 0.5s) — active 유지 + hover 동작
   2차: 3px 원형 점이 텍스트 왼쪽 바깥(-15px)에서 -5px로 슬라이드 인 + 페이드 (0.3s ease-in-out)
   ============================================ */
@media (min-width: 769px) {
    /* .main-nav 는 absolute(top:50% translate 센터링)라 stretch 불가 → 풀높이로 전환 */
    .main-nav { height: 100%; top: 0; transform: translateX(-50%); }
    .main-nav .nav-list { height: 100%; }
    .main-nav .nav-list>li { height: 100%; display: flex; align-items: center; }
    .main-nav .nav-list>li>a { position: relative; height: 100%; }

    /* 기존 has-children 화살표 숨김 규칙(display:none)이 밑줄을 가리므로 복원 */
    .main-nav .nav-list>li.menu-item-has-children>a::before,
    .main-nav .nav-list>li.menu-item-has-children:hover>a::before { display: block; }

    .main-nav .nav-list>li>a::before {
        content: "";
        display: block;
        position: absolute;
        left: 50%;
        bottom: 0;
        width: 0;
        height: 2px;
        background-color: #233E71;
        transform: translateX(-50%);
        transition: width 0.5s;
    }

    .main-nav .nav-list>li:hover>a::before,
    .main-nav .nav-list>li.current-menu-item>a::before,
    .main-nav .nav-list>li.current-menu-parent>a::before,
    .main-nav .nav-list>li.current-menu-ancestor>a::before,
    .main-nav .nav-list>li.current_page_item>a::before,
    .main-nav .nav-list>li.current_page_parent>a::before,
    .main-nav .nav-list>li.current_page_ancestor>a::before {
        width: 100%;
    }

    .main-nav .nav-list>li>.sub-menu li a span { position: relative; }

    .main-nav .nav-list>li>.sub-menu li a span::before {
        content: "";
        position: absolute;
        left: -15px;
        top: 50%;
        width: 3px;
        height: 3px;
        border-radius: 50%;
        background-color: #233E71;
        transform: translate(-100%, -50%);
        opacity: 0;
        transition: 0.3s ease-in-out;
    }

    .main-nav .nav-list>li>.sub-menu li.current-menu-item a span::before,
    .main-nav .nav-list>li>.sub-menu li.current_page_item a span::before,
    .main-nav .nav-list>li>.sub-menu li a:hover span::before {
        left: -5px;
        opacity: 1;
    }
}
