        /* Çì´õ »ó´Ü °íÁ¤ ¼¼ÆÃ */
        .site-header {
            position: fixed;
            top: 0;
            left: 0;
            width: 100%;
            background-color: #fff;
            z-index: 1000;
            border-bottom: 1px solid #e0e0e0;
            transition: box-shadow 0.3s ease;
        }

        /* ½ºÅ©·Ñ ½Ã ±×¸²ÀÚ È¿°ú (JS¿Í ¿¬µ¿) */
        .site-header.scrolled {
            box-shadow: 0 4px 15px rgba(0,0,0,0.08);
        }

        /* 1. »ó´Ü Á¤º¸ ¿µ¿ª */
        .header-top {
            display: flex;
            justify-content: space-between;
            align-items: center;
            padding: 20px 40px;
            border-bottom: 1px solid #f0f0f0;
        }
        .logo h1 { font-size: 24px; font-weight: 700; display: inline-block; margin-right: 10px; }
        .logo .sub-logo { font-size: 11px; color: #888; letter-spacing: 1px; }
        .contact-info, .cert-info { font-size: 13px; color: #666; }
        .cert-info { text-align: right; line-height: 1.4; }

        /* 2. ³×ºñ°ÔÀÌ¼Ç ÄÁÅ×ÀÌ³Ê */
        .main-nav-container {
            position: relative;
            background-color: #fff;
        }

        /* 3. ¸ÞÀÎ ¸Þ´º ¹× ¼­ºê ¸Þ´º ÄÁÅ×ÀÌ³Ê ÅëÀÏ */
        .main-menu,
        .mega-menu-inner {
            display: flex;
            justify-content: center;
            width: 100%;
            max-width: 100%;
            margin: 0 auto;
        }

        /* 4. ´ë¸Þ´º Ç×¸ñ°ú ¼­ºê¸Þ´º »À´ë ¿Ïº® µ¿±âÈ­ */
        .main-menu > li,
        .sub-menu {
            flex: 1;
            min-width: 0;
            box-sizing: border-box;
            text-align: center;
            border-right: 1px solid #f0f0f0;
        }

        /* Ã¹ ¹øÂ° Ç×¸ñ ÁÂÃø ¼¼·ÎÁÙ ÅëÀÏ */
        .main-menu > li:first-child,
        .sub-menu:first-child {
            border-left: 1px solid #f0f0f0;
        }

        /* 5. ´ë¸Þ´º µðÀÚÀÎ */
        .main-menu > li > a {
            display: block;
            padding: 20px 0;
            font-size: 18px;
            font-weight: 600;
            white-space: nowrap;
			color:#000;
        }
        .main-menu > li:hover > a { background-color: #fcfcfc; }

        /* 6. ¸Þ°¡ ¸Þ´º (½½¶óÀÌµù ·ÎÁ÷) */
        .mega-menu-wrapper {
            position: absolute;
            top: 100%;
            left: 0;
            width: 100%;
            background-color: #fbfbfb;
            border-bottom: 1px solid #e0e0e0;

            /* ÃÊ±â »óÅÂ */
            max-height: 0;
            opacity: 0;
            visibility: hidden; /* ¿ÏÀüÈ÷ ´ÝÇûÀ» ¶§ ³»ºÎ ¸µÅ© Å¬¸¯ ¹æÁö */
            overflow: hidden;

            /* ºÎµå·¯¿î °¡°¨¼ÓÀ» À§ÇÑ cubic-bezier Àû¿ë ¹× transition ºÐ¸® */
            transition: max-height 0.4s cubic-bezier(0.25, 1, 0.5, 1),
                        opacity 0.3s ease-in-out,
                        visibility 0.4s;
        }

        /* È£¹ö ½Ã ¸Þ°¡¸Þ´º ³ëÃâ */
        .main-nav-container:hover .mega-menu-wrapper {
            /* ½ÇÁ¦ ÄÜÅÙÃ÷ ³ôÀÌ(¾à 300~350px)¿¡ ÃÖ´ëÇÑ °¡±õ°Ô ¸ÂÃçÁÖ¼¼¿ä.
               ÀÌ °ªÀÌ ½ÇÁ¦ ³ôÀÌ¿Í ºñ½ÁÇÒ¼ö·Ï ¸¶¿ì½º¸¦ ¶ÃÀ» ¶§ Áï°¢ÀûÀ¸·Î ºÎµå·´°Ô ¿Ã¶ó°©´Ï´Ù.
            */
            max-height: 380px;
            opacity: 1;
            visibility: visible;
        }

        /* 7. ¼­ºê¸Þ´º µðÀÚÀÎ */
        .sub-menu {
            padding: 25px 0 40px 0;
        }
		.sub-menu li { width:100%; }

        .sub-menu li a {
            display: block;
            padding: 8px 0;
            font-size: 14px;
            color: #666;
            white-space: nowrap;
            overflow: hidden;
            text-overflow: ellipsis;
			text-align:center;
        }
        .sub-menu li a:hover {
            color: #000;
            font-weight: bold;
        }

        /* 8. Æ¯Á¤ ÄÃ·³ ³Êºñ ºñÀ² Á¶Á¤ */
        .main-menu > li:nth-child(2),
        .sub-menu:nth-child(2) { flex: 1.1; }

        .main-menu > li:nth-child(3),
        .sub-menu:nth-child(3) { flex: 1.5; }

        .main-menu > li:nth-child(4),
        .sub-menu:nth-child(4) { flex: 1.2; }

        .main-menu > li:nth-child(6),
        .sub-menu:nth-child(6) { flex: 1.1; }

        /* 9. ¹ÝÀÀÇü (ÅÂºí¸´/¸ð¹ÙÀÏ ºÐ±â) */
        @media (max-width: 1024px) {
            .header-top { flex-direction: column; gap: 10px; text-align: center; }
            .main-menu > li > a { font-size: 14px; padding: 15px 0; }
            .sub-menu li a { font-size: 13px; }
        }
