/* 상단 메뉴 스타일 */
        .m_com_header {  
            padding: 0px 0; 
        }

        .m_com_nav {
            max-width: 100%;
            margin: 0 auto;
            padding: 0 0px;
        }

        .m_com_nav ul {
            list-style: none;
            padding: 0;
            margin: 0;
            display: flex; /* 가로로 나열 */
            justify-content: space-around; /* 균등하게 분배 */
        }

        .m_com_nav li {
            flex-grow: 1; /* 아이템이 남은 공간을 차지 */
            text-align: center;
        }

        .m_com_nav a {
            display: block;
            padding: 15px 10px; 
            text-decoration: none;
            color: #042848;
            font-weight: bold;
			border-radius: 5rem;
            transition: background-color 0.3s ease, color 0.3s ease;
			 font-size: 1.35em;
        }

        .m_com_nav a:hover { 
            color: #55a7f0;
        }

        .m_com_nav li.active-top a {
            background-color: #55a7f0;
            color: white;
        }

        /* 메인 콘텐츠 래퍼 */
        .main-wrapper {
            display: flex;
            max-width: 1600px;
            margin: 40px auto; /* 상단 헤더와 간격 두기 */
            overflow: hidden; 
            background-color: #042848;
            flex-grow: 1; /* 남은 세로 공간을 채우도록 */
        }

        /* 왼쪽 내용 표시 영역 */
        .content-display-area {
            flex: 1; /* 너비 1 */
            padding: 30px;
            border-right: 0px solid #eee;
            min-width: 300px; /* 최소 너비 지정 */
            position: relative; /* 자식 요소 포지셔닝 기준 */
            overflow: hidden; /* transition 때 내용 잘림 방지 */
        }
        

        .content-item {
            display: none; /* 기본적으로 모든 내용 숨김 */
            position: absolute; /* 겹쳐지게 */
            width: calc(100% - 60px); /* 패딩 제외 */
            top: 30px; /* 제목으로부터 패딩 */
            left: 30px; /* 왼쪽 패딩 */
            opacity: 0;
            transition: opacity 0.5s ease-in-out; /* 내용 페이드 효과 */
        }

        .content-item.active {
            display: block; /* 활성 상태일 때만 보임 */
            opacity: 1;
            position: relative; /* active일때 relative로 바꾸어 다른 요소를 밀어내도록 (선택 사항) */
                                /* 또는 display: block과 opacity 1만으로 충분 */
        }

        .content-item p {
            font-size: 1.05em;
            line-height: 1.7;
            color: #f0f0f0;
        }


        /* 오른쪽 이미지 패널 */
        .right-panel {
            flex: 1.5; /* 왼쪽보다 더 넓게 (예: 1.5배) */ 
            display: flex;
            justify-content: center;
            align-items: center;
            padding: 0px;
        }

        .right-panel img {
            max-width: 100%;
            height: auto; 
            box-shadow: 0 2px 15px rgba(0, 0, 0, 0.15);
            transition: opacity 0.5s ease-in-out; /* 이미지 전환 효과 */
        }

        /* -------------------- 반응형 디자인 (모바일) -------------------- */
        @media (max-width: 768px) {
            .m_com_nav ul {
                flex-wrap: wrap; /* 모바일에서 메뉴가 여러 줄로 */
            }
            .m_com_nav li {
                flex-basis: 50%; /* 2개씩 한 줄에 */
                flex-grow: 0;
            }
            .m_com_nav a {
                padding: 10px 5px;
                font-size: 0.8em;
            }

            .main-wrapper {
                flex-direction: column; /* 세로로 쌓이게 */
                margin: 0px;
                box-shadow: none; /* 모바일에서는 그림자 제거 */
            }

            .content-display-area {
                border-right: none;
                border-bottom: 1px solid #eee; /* 모바일에서는 하단 경계선 */
                padding: 20px;
                min-width: unset; /* 최소 너비 해제 */
                width: auto;
            }
            .content-display-area h2 {
                margin-bottom: 20px;
                font-size: 1em;
            }

			.content-display-area h3 {
                margin-bottom: 10px;
                font-size: 1.5em;
            }

			.content-display-area p {
                font-size: 0.9em;
            }

            .content-item {
                position: relative; /* 모바일에서는 항상 relative로 쌓이도록 */
                top: unset;
                left: unset;
                width: 100%;
                padding-bottom: 20px;
                text-align: left;
            }

            .right-panel {
                padding: 0px;
                order: 1; /* 이미지를 내용 위로 이동 (모바일) */
            }
            .content-display-area {
                order: 2; /* 내용을 이미지 아래로 이동 (모바일) */
            }
        }

        @media (max-width: 480px) {
            .m_com_nav li {
                flex-basis: 100%; /* 1개씩 한 줄에 */
            }
            .m_com_nav a {
                font-size: 0.85em;
            }

            .content-display-area {
                padding: 15px;
            }
            .content-display-area h2 {
                font-size: 1.5em;
            }
        }