.elementor-40 .elementor-element.elementor-element-b472aed{--display:flex;--flex-direction:row;--container-widget-width:initial;--container-widget-height:100%;--container-widget-flex-grow:1;--container-widget-align-self:stretch;--flex-wrap-mobile:wrap;--gap:0px 0px;--row-gap:0px;--column-gap:0px;--padding-top:0px;--padding-bottom:0px;--padding-left:0px;--padding-right:0px;}/* Start custom CSS for html, class: .elementor-element-b4ccccf *//* ==========================================================================
   1. 헤더 기본 구조 및 레이아웃
   ========================================================================== */
   #custom-header, 
   #custom-header.header-transparent, 
   #custom-header.header-white {
       background-color: transparent !important;
       border: none !important;
       box-shadow: none !important;
       position: fixed !important;
       top: 0 !important;
       left: 0 !important;
       width: 100% !important;
       height: 100px !important;
       z-index: 1000 !important;
   }
   
   .header-inner {
       display: flex !important;
       justify-content: space-between !important;
       align-items: center !important;
       height: 100% !important;
       padding: 40px 100px 0 !important;
       background: #000;
   }
   
   /* 2. 중앙 캡슐 메뉴 박스 */
   .main-menu-area {
       width: auto !important;
       background: rgba(20, 20, 20, 0.8) !important;
       border-radius: 12px !important;
       padding: 0 15px !important;
       height: 54px !important;
       display: flex !important;
       align-items: center !important;
       border: 1px solid rgba(255, 255, 255, 0.1) !important;
       position: absolute !important;
       left: 50% !important;
       transform: translateX(-50%) !important;
   }
   
   /* ==========================================================================
      3. 메인 네비게이션 & PC 서브메뉴 (100px 너비 및 중앙 정렬)
      ========================================================================== */
   .main-nav {
       display: flex !important;
       list-style: none !important;
       margin: 0 !important;
       padding: 0 !important;
   }
   
   .main-nav > li {
       position: relative !important;
       display: flex !important;
       align-items: center !important;
   }
   
   .main-nav a {
       color: #fff !important;
       font-size: 17px !important;
       font-weight: 400 !important;
       padding: 0 25px !important;
       font-family: "Pretendard", sans-serif !important;
       text-decoration: none !important;
   }
   
   .main-nav > li:not(:last-child)::after {
       content: "" !important;
       width: 1px !important;
       height: 12px !important;
       background: rgba(255, 255, 255, 0.2) !important;
   }
   
   @media(min-width: 1400px) {
       .main-nav > li .submenu-content {
           display: block !important;
           position: absolute !important;
           top: 100% !important; 
           left: 50% !important;
           transform: translateX(-50%) translateY(10px) !important;
           width: 100px !important; 
           background: rgba(15, 15, 15, 0.95) !important;
           backdrop-filter: blur(10px) !important;
           border: 1px solid rgba(255, 255, 255, 0.1) !important;
           border-radius: 12px !important;
           padding: 10px 0 !important;
           opacity: 0 !important;
           visibility: hidden !important;
           transition: all 0.3s ease-in-out !important;
           z-index: 1000 !important;
           box-shadow: 0 10px 30px rgba(0,0,0,0.5) !important;
       }
   
       /* 마우스 이탈 방지 가상 다리 */
       .main-nav > li .submenu-content::before {
           content: "";
           position: absolute;
           top: -20px;
           left: 0;
           width: 100%;
           height: 25px;
           background: transparent;
       }
   
       .main-nav > li:hover .submenu-content {
           opacity: 1 !important;
           visibility: visible !important;
           transform: translateX(-50%) translateY(5px) !important;
       }
   
       /* PC 서브메뉴 전용 중앙 정렬 */
       .submenu-content ul {
           width: 100% !important;
           display: flex !important;
           flex-direction: column !important;
           align-items: center !important;
           padding: 0 !important;
           margin: 0 !important;
       }
   
       .submenu-content ul li { 
           width: 100% !important;
           margin: 2px 0 !important;
       }
   
       .submenu-content ul li a {
           font-size: 14px !important;
           padding: 8px 0 !important;
           line-height: 1.3 !important;
           color: rgba(255, 255, 255, 0.7) !important;
           text-align: center !important; /* PC는 중앙 정렬 */
           word-break: keep-all !important;
           display: block !important;
       }
   
       .submenu-content ul li a:hover {
           color: #fff !important;
           background: rgba(255, 255, 255, 0.08) !important;
       }
   }
   
   /* 동그라미 제거 공통 */
   ul, li { list-style: none !important; list-style-type: none !important; }
 
   /* ==============================================
 * 5. 헤더 버튼 영역 (Contact, Lang, Ham)
 * ==============================================
 */
.button-area {
    display: flex;
    align-items: center;
    gap: 10px;
}


/* ==========================================================================
  4. 다국어 선택기 (Language Selector)   ========================================================================== */
.lang-menu {
    position: relative;
}
.lang-toggle {
    /*display: none;*/
    display: flex;
    align-items: center;
    gap: 8px;
    background: none;
    border: none;
    cursor: pointer;
    color: #fff;
    font-size: 15px;
    font-weight: 500;
    padding: 8px;
    border-radius: 5px;
    transition: background-color 0.3s;
}
.lang-toggle .icon-globe {
    width: 20px;
    height: 20px;
    stroke-width: 1.5;
}
.header-transparent .lang-toggle:hover {
    background-color: rgba(0, 0, 0, 0.05);
}
.header-white .lang-toggle:hover {
    background-color: rgba(255, 255, 255, 0.15);
}
#custom-header.header-white:hover .lang-toggle:hover {
    background-color: rgba(0, 0, 0, 0.05);
}
.lang-dropdown {
    position: absolute;
    top: calc(100% + 10px);
    right: 0;
    background-color: #fff;
    border-radius: 5px;
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.1);
    list-style: none;
    margin: 0;
    padding: 5px;
    min-width: 80px;
    opacity: 0;
    visibility: hidden;
    transform: translateY(10px);
    transition: all .3s ease;
}
.lang-menu.is-active .lang-dropdown {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.lang-dropdown a {
    color: #333;
    text-decoration: none;
    display: block;
    padding: 8px 12px;
    border-radius: 4px;
    font-size: 14px;
    letter-spacing: -0.04em;
}
.lang-dropdown a:hover {
    background-color: #f5f5f5;
    color: #e50012;
}
.lang-dropdown a img {
    margin-right: 5px;
}
   
   /* ==========================================================================
      5. 오프캔버스 메뉴 (모바일/태블릿 상세)
      ========================================================================== */
   .offcanvas-menu {
       position: fixed; top: 0; right: -320px; width: 320px; height: 100%;
       background-color: #fff; z-index: 1001; transition: right .4s ease;
       padding: 20px; overflow-y: auto;
   }
   .offcanvas-menu.is-open { right: 0; }
   
   .close-btn {
       position: absolute; top: 15px; right: 20px; background: none;
       border: none; color: #333; font-size: 30px; cursor: pointer; line-height: 1;
   }
   
   .offcanvas-overlay {
       position: fixed; top: 0; left: 0; width: 100%; height: 100%;
       background-color: rgba(0, 0, 0, .5); z-index: 1000;
       opacity: 0; visibility: hidden; transition: opacity .4s;
   }
   .offcanvas-overlay.is-open { opacity: 1; visibility: visible; }
   .offcanvas-nav{padding: 0 !important;}
   .offcanvas-nav li { border-bottom: 1px solid #f0f0f0; }
   .offcanvas-nav li:last-child{border-bottom: 0px;}
   .offcanvas-nav a { color: #333; padding: 15px 10px; display: block; font-weight: 500; }
   
   /* 오프캔버스 서브메뉴 - 왼쪽 정렬 및 들여쓰기 */
   .offcanvas-menu .submenu-content { background-color: #f8f9fc; display: none; }
   .offcanvas-menu .submenu-content ul {
       padding: 0 !important;
       text-align: left !important; /* 모바일은 왼쪽 정렬 */
   }
   .offcanvas-menu .submenu-content a { 
       padding: 12px 10px 12px 40px !important; /* 40px 들여쓰기 유지 */
       color: #666 !important;
       text-align: left !important; /* 모바일은 왼쪽 정렬 */
   }

   /* 오프캔버스 서브메뉴 호버 스타일 강제 지정 */
.offcanvas-menu .submenu-content ul li a:hover {
  color: #000 !important;       /* 호버 시 글씨 색상을 검정색(혹은 원하는 색)으로 변경 */
  background: #eef1f7 !important; /* 호버 시 배경색 (선택 사항) */
  opacity: 1 !important;
}


   
   /* ==========================================================================
      6. 하단 Top 버튼 (회전 애니메이션 포함)
      ========================================================================== */
   #scroll-to-top-btn {
       position: fixed; bottom: 40px; right: 40px; z-index: 99;
       width: 110px; height: 110px; background-color: rgba(0, 0, 0, 0.5);
       border-radius: 50%; display: flex; justify-content: center; align-items: center;
       opacity: 0; visibility: hidden; transition: all 0.4s ease;
   }
   #scroll-to-top-btn.is-visible { opacity: 1; visibility: visible; }
   #scroll-to-top-btn text { font-size: 28px; font-family: "Exo 2", serif; fill: #ddd; }
   
   .rotating-text {
       animation: rotateText 30s linear infinite;
       transform-origin: center;
   }
   @keyframes rotateText {
       from { transform: rotate(0deg); }
       to { transform: rotate(360deg); }
   }
   .fixed-arrow { stroke: #ddd; stroke-width: 2.5; fill: none; }
   
   /* ==========================================================================
      7. 기타 및 반응형
      ========================================================================== */
   .fp-watermark { display: none !important; }
   .logo-white, .icon-globe, .icon-message, .ham-white { filter: brightness(0) invert(1) !important; }
   .button-area{cursor:pointer;}
   
   @media(max-width: 1400px) {
       .main-menu-area { display: none !important; }
       .header-inner { padding: 0 30px !important; height: 70px !important; }
   }
   @media(max-width: 776px) {
       #scroll-to-top-btn, #fp-nav { display: none !important; }
   }/* End custom CSS */