@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard@v1.3.9/dist/web/static/pretendard.min.css');

/* ==================== COMMON & RESET ==================== */

#div_md_list.table-wrapper {
    overflow-x: auto !important;
}
:root {
   --primary-blue: #0056b3; /* thead th */
   --light-gray: #f8f9fa;
   --border-color: #dee2e6;
   
   --primary-blue: #23478a;/* 카드형 테이블 */
  	--text-main: #333333;
  	--text-sub: #4a5568;
 
   
        }
.mt30 {mtgin-top:30px;}
.category_bbs_ft2 {
    margin: 0;
    padding-top: 20px;
	/*box-sizing: border-box;*/
}

body {
    /*font-family: 'Noto Sans KR', sans-serif;
/*    color: #333;*/
    /*font-size: 16px;*/
    font-family: "Pretendard Variable", sans-serif;
    height: 100%;
}


.no-scroll { overflow: hidden; }

a { text-decoration: none; color: inherit; }
li { list-style: none; }
/*
img { max-width: 100%; height: auto; display: block; }
*/
/* 공통 레이아웃 */
.inner {
    max-width: 1200px;
    width: 100%;
    margin: 0 auto;
    /*padding: 0 20px;*/
    box-sizing: border-box;
}

#mwrap {
    width: 100%;
    overflow-x: hidden; /* 모바일에서 가로 스크롤 방지 */
}

/* ==================== HEADER ==================== */
#header {
    background: #fff;
    border-bottom: 1px solid #eee;
}
#header .inner {
    display: flex;
    justify-content: space-between;
    align-items: center;
    height: 90px;
	position: fixed;
	background-color: #fff;
	z-index: 9999;
}
#header .logo img { height: 30px; }
#mgnb ul { display: flex; }
#mgnb li a {
    display: block;
    padding: 0 25px;
    font-weight: 500;
    font-size: 18px;
    color: #222;
}

#mgnb .sub-menu{
	display: none;
	padding-left : 20px;
	background: #f9f9f9;
}	


/* 체크박스가 선택된(클릭된) 상태일 때 하위 메뉴 보이기 */
#toggle0:checked ~ .sub-menu,
#toggle1:checked ~ .sub-menu,
#toggle2:checked ~ .sub-menu,
#toggle2_0:checked ~ .sub-menu, #toggle2_1:checked ~ .sub-menu,
#toggle2_2:checked ~ .sub-menu, #toggle2_3:checked ~ .sub-menu,
#toggle2_4:checked ~ .sub-menu, #toggle2_5:checked ~ .sub-menu, #toggle2_6:checked ~ .sub-menu,
#toggle3:checked ~ .sub-menu,
#toggle4:checked ~ .sub-menu,
#toggle5:checked ~ .sub-menu,
#toggle6:checked ~ .sub-menu {
  display: block;
}

/* 체크박스가 체크되면 서브메뉴 보이기 */

#mgnb .sub-menu li a {
  transition: color 0.3s; /* 부드럽게 색 전환 */
}

#mgnb .sub-menu li a:hover {
  text-decoration: underline;
  color: #0667a5;
}


#mgnb .sub-menu-a {
    font-size: 12px !important;
    padding: 3px 3px;
    font: caption;
    border-bottom: none !important;
    width: 200px;
}

#mgnb .sub-menu-a2 {
    font-size: 16px !important;
    padding: 10px 10px;
    font: caption;
    border-bottom: none !important;
    
}

#mgnb .sub-menu-a3 {
    font-size: 15px !important;
    padding: 3px 10px;
    font: caption;
    border-bottom: none !important;
}

#mgnb .sub-menu-t {
    font-size: 15px;
    letter-spacing: 0.3px;
    font-weight: bold;
    color: #004179; !important;
    padding:10px 0px 0px 00px;
    width:100%;
    font-family: 'Noto Sans KR';
}
#mgnb .sub-menu-r {
    display: ruby !important;   
}

/* 기본 메뉴 아이템 스타일 */
.menu-item {
  	padding: 15px 10px;
    font-size: 18px;
    font-family: 'notokr-bold';
    border-bottom: 1px solid #eee;
    
    display: flex;
    justify-content: space-between;
    align-items: center;
   	max-width: 1200px;
    width: 100%;
    box-sizing: border-box;
}

/* 아이콘 컨테이너 스타일 */
.menu-item .icon {
  
  width: 15px;
  height: 15px;
  transition: transform 0.3s ease-in-out;
  
  display: block;
  border: none;
  background: none;
  position: relative;
        
}

.toggle_sub {
	/* 메뉴에 토글 이벤트를 위한 체크박스 숨김 처리*/
	display: none;
}
/* 아이콘 기본 형태 (닫힌 상태: +) */
.menu-item .icon::before,
.menu-item .icon::after {
  content: '';
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: #333;
  transition: transform 0.3s ease-in-out;
}

#mgnb .menu-item .icon::before {
  width: 100%;
  height: 2px;
}

#mgnb .menu-item .icon::after {
  width: 2px;
  height: 100%;
}

/* 체크박스가 체크되었을 때 (열린 상태: -) 아이콘 변화 , opacity :0 세로선 숨기기*/
#mgnb .toggle_sub:checked + .menu-item .icon::after {
  transform: translate(-50%, -50%) rotate(90deg);
  opacity: 0; 
}

.util a {
    margin-left: 15px;
    font-size: 14px;
    color: #555;
}
.m-btn-menu { display: none; } /* 모바일 버튼은 평소에 숨김 */

/* ==================== MAIN VISUAL ==================== */
#main_visual {
    width: 100%;
    max-width: 1920px; /* 원본 사이트 최대 너비 고려 */
    margin: 0 auto;
}

#main_visual .bx-wrapper {
    box-shadow: none !important;
    -moz-box-shadow: none !important;
    -webkit-box-shadow: none !important;

    border: none !important;
    background: transparent !important; /* 필요에 따라 */
}

/* ==================== MAIN CONTAINER ==================== */
#main_container { padding: 0px 0px 0px 0px; }
/*.main-section { margin-bottom: 50px; }*/
.main-section:last-child { margin-bottom: 0; }



/* 뉴스/공지 */
.news-section {
    display: flex;
    gap: 40px;
}
.news-box, .notice-box { flex: 1; }
.news-section h2 {
    font-size: 24px;
    padding-bottom: 15px;
    border-bottom: 2px solid #333;
    margin-bottom: 15px;
}
.news-section li { border-bottom: 1px solid #eee; }
.news-section li a {
    display: flex;
    justify-content: space-between;
    padding: 10px 5px;
    font-size: 15px;
    color: #555;
}
.news-section li a:hover span:first-child { text-decoration: underline; }
.news-section .date { color: #999; }

/* 3단 그리드 */
/*
.content-grid {
    display: flex;
    justify-content: space-between;
    text-align: center;
}
.content-grid article {
    overflow: hidden;
    height: fit-content;
    padding: 10px 10px 5px 5px;
    display: block;
}
.content-grid .img-wrap {
	width: 100%;
    overflow: hidden;
    border-radius: 10px;
    border: 1px solid #e3e5e8;
}

.content-grid .img-wrap img {
    width: 100%;
    height: 100%;
    object-fit: cover;
}

.content-grid article:hover .img-wrap img {
    transform: scale(1.1);
}
*/
/* 이미지 감싸는 래퍼 */
/*
.img-wrap {
  position: relative;
  overflow: hidden;
}

.img-wrap img {
  width: 100%;
  height: auto;
  display: block;
  opacity: 1;
  transition: opacity 1s ease-in-out;
}

.img-wrap img.fade-out {
  opacity: 0;
}
*/

/* 테스트 컨텐츠 250917 */
  /* 최상위 그룹 */
    .slider-group {
      display: flex;
      flex-direction: column;
      gap: 10px; /* 두 줄 사이 간격 */
      /*max-width: 1200px;*/
      padding: 0px 0px 0px 0px;
    }

    /* 한 줄에 3개 슬라이더 */
    .slider-container {
      display: flex;
      flex-wrap: wrap;
      gap: 10px;
      justify-content: center;
      
      height: 100%;
      /*
      max-width: 1200px;
      */
    }

    .slider {
    
      position: relative;
      flex: 1 1 calc(33.333% - 20px); 
      width: calc(33.333% - 20px);
      aspect-ratio: 16 / 10;
      overflow: hidden;
      border-radius: 12px;
    /*  background: #000;*/
     }

    .slide {
      position: absolute;
      top: 0; left: 0;
      width: 100%; height: 100%;
      opacity: 0;
      transition: opacity 1.5s ease-in-out;
      z-index: 0;
    }

    .slide img {
      width: 100%;
      height: 100%;
      object-fit: cover;
      display: block;
    }

    .slide.active {
      opacity: 1;
      z-index: 1; /* 항상 위에 표시 */
    }

    /* 버튼 */
    .slider button {
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      background: rgba(0,0,0,0.5);
      border: none;
      color: white;
      font-size: 1.5rem;
      padding: 8px 12px;
      cursor: pointer;
      border-radius: 6px;
      z-index: 2;
      opacity: 0;
      transition: opacity 0.3s;
    }

    .slider:hover button {
      opacity: 1;
    }

    .prev { left: 10px; }
    .next { right: 10px; }

    
/* 테스트 컨텐츠 250917 end */
  
.content-grid h3 {
    font-size: 22px;
    margin: 20px 0 10px;
}
.content-grid p {
    font-size: 15px;
    color: #666;
    padding-bottom: 30px;
}

/* ==================== FOOTER ==================== */
#footer {
    background-color: #2d3341;
    color: #aaa;
    font-size: 14px;
    padding:40px 10px 40px 10px;
    font-family: sans-serif;
}
#footer .inner {
    /*display: flex;*/
    justify-content: space-between;
   	align-items: center;
}
#footer .footer-info p { line-height: 1.8; }
#footer .footer-links a { margin-left: 20px; }

/* ========================================================== */
/*  반응형 스타일 (Responsive Styles)                          */
/* ========================================================== */

/* Tablet (1200px 이하)-메뉴가 다 안보임 */
@media (max-width: 1200px) {
	/*
    #gnb .menu li a {
	    width: 130px;
    }
    */
    /*
    #gnb .menu ul li {
		font-size: 15px;
    }
    */
    		
    .inner { padding: 0 15px; }
    
    #gnb { width: auto; }
	#gnb .menu{
		width: auto; 
	}
	#mtnb_hd_wrap {width: 100% !important;}
	
	#gnb .submenu0 .box, #gnb .submenu1 .box, #gnb .submenu2 .box, #gnb .submenu3 .box, #gnb .submenu4 .box {
	  	width: auto;
	}
	
	#gnb .submenu1 .box ul, #gnb .submenu2 .box ul, #gnb .submenu3 .box ul, #gnb .submenu4 .box ul {
    	right : 0;
    	left: 300px;
	}
	
	#gnb .submenu0 .box02 .con01, #gnb .submenu0 .box02 .con02 {
		padding: 0 0 0 0;	
	}
	
	#mvisual .order_menu li[class^="main_b"] {
	    width: 120px !important;
	    height: 120px !important;
    }
	
	/*모바일 화면에서 광고창이 1열 세로로 되지 않도록 이미지크기를 줄인다*/
	.popup_img{ width: 200px; }
}

/* Tablet (1114px 이하)-메뉴가 다 안보임 */
@media (max-width: 1115px) {
	
	/* top 메뉴 */
	#gnb .menu {
		float: left;
		margin-left: 50px;	
	}
	
	#gnb .menu li a {
	    width: 130px;
    }
    
    #gnb .menu ul li {
		font-size: 15px;
    }
        
    #mvisual .order_menu {
	    position: relative !important;
	}
	
	#mvisual .order_menu li {
	    margin: 0 0 0 0 !important;
	}

	#main_container {
	    padding: 0 0;
	}
	
	/* top 메뉴  end*/
	
}

/* Tablet (1024px 이하) */
@media (max-width: 1024px) {
	
	/* top 메뉴 */
	#gnb .menu {
		float: left;
		margin-left: 0;	
	}
	
    #mgnb li a {
        padding: 0 15px;
        font-size: 16px;
    }
    /* top 메뉴  end */
    
    /* main.jsp 중앙 배너 */
    .content-grid { gap: 20px; }
    .content-grid h3 { font-size: 20px; }
    .content-grid p { font-size: 14px; }
    /* main.jsp end */
}

/* Tablet (915px 이하)-메뉴께짐 */
/*@media (min-width: 915px) and (max-width: 1000px) {*/
@media (max-width: 915px) {
	
	/* top 메뉴 */
    #gnb .submenu2 .box ul, #gnb .submenu3 .box ul, #gnb .submenu4 .box ul {
    	right : 0;
    	left: initial;
	}
	
	#gnb .submenu1 .box ul{
		right : 0;
    	margin-left: 0px;
	} 
	
	#gnb .submenu0 .box ul li, #gnb .submenu1 .box ul li, #gnb .submenu2 .box ul li,
	#gnb .submenu3 .box ul li, #gnb .submenu4 .box ul li {
		font-size: 12px;
	}
	
	/* 브라우저가 너무 좁으면 keyword 검색 란을 숨겨서 레이아웃 깨짐을 막는다*/
	#P_SEARCH_KEY_WORD{ display: none;}
	
	/* top 메뉴 end */
	
	/* --- 메인 콘텐츠: 세로 정렬 --- */
    .news-section {
        flex-direction: column;
        gap: 30px;
    }
    
}

    
/* Tablet (1114px 이하)-메뉴가 다 안보임 */
@media (max-width: 864px) {
	
	/* top 메뉴 */
	#gnb .menu li a {
	    width: 110px;
    }
    
    #gnb .submenu0 .box02 {
		float: left;
	}
	
	.menu_order {
		display:none;
	}
	
	#gnb .submenu0 .box02 {
    	padding-left: 15px;
	}
	/* top 메뉴 end */
	
	/* main.jsp 메인슬라이드 이미지를 앞으로 당겨서 모바일 크기에 맞춘다*/
    .bx-wrapper img {
	   transform: translate(-5%, 0%) !important;
	}
	
	/*모바일 화면에서 광고창이 1열 세로로 되지 않도록 이미지크기를 줄인다*/
	.popup_img{ width: 180px; }
	
	.slider {
		flex: 1 1 calc(50% - 20px);
        max-width: calc(50% - 20px);
    }
    /* main.jsp end */
    
    /* 개별 content page - 브라우저 넓이 805px 쯤, 왼쪽 sub menu 가 뭉개진다. 그때 모바일용   메뉴를 노출 시키고, left 메뉴는 접는다. */
    .mtab-link { flex: 1 1 40%; /* 최소 너비 확보, 화면 좁으면 2개씩 줄 바꿈 */ }
    .mtab-bar { display:flex !important; }
    #div_left_menu {
    	display:none !important;
    	width: 0px !important;
    }
    
    .mcon-main { 
    	padding-left: 0px !important;
    }
    /* 개별 content page end*/
}

/* Tablet (1114px 이하)-메뉴가 다 안보임 */
@media (max-width: 768px) and @media (max-width: 783px) {

	#gnb .menu li a {
	    width: 100px;
    }
}

/* Mobile (767px 이하) */
@media (max-width: 767px) {
    /* --- 기본 레이아웃 변경 --- */
	
	html, body {
	  width: 100%;
	  overflow-x: hidden;
	}
			
	* {
	  box-sizing: border-box;
	}
	
	.mtab-link { flex: 1 1 40% !important; }
	
	/* top 메뉴  title 표시 화면 1190px -> 에서 100% 조정*/
    #hd_container {
		width: 100% !important;
	}
	
	/* 페이징 넓이  430px -> 100% 적용*/
	.pagemove {
		width: 100% !important;
	}
    /*#main_container { padding: 40px 0; }*/
    .main-section { margin-bottom: 50px; }

    /* --- 헤더: 햄버거 메뉴로 변경 --- */
    #header .inner { height: 60px; border-bottom: 1px solid #cacccc; }
    #header .logo img { height: 40px; }
    #div_gab { height: 60px !important; }
    /* --- 모바일 형이 되면  main-section 빈칸을 채워주고 나타나개 한다 --- */
    
    #article_hide_1, #article_hide_2{
    	display:block !important;
    }
    
    #mgnb {
    	/* 평소에는 메뉴 숨김 */
        display: none; 
        position: fixed;
        top: 60px;
        left: 0;
        width: 100%;
        height: calc(100% - 60px);
        background: rgba(255, 255, 255, 0.95);
        padding: 20px;
		/* 여기서부터 추가*/
        overflow-y: auto; /* 내용이 길어지면 스크롤 가능하게 */
        z-index: 1000; /* 다른 요소 위에 메뉴가 보이도록 */
        box-sizing: border-box;
    }
    
    #mgnb.is-active { 
    	display: block;
    } /* is-active 클래스가 붙으면 보임 */
    
    #mgnb ul { flex-direction: column; }
    #mgnb li a {
        padding: 15px 10px;
        font-size: 18px;
        border-bottom: 1px solid #eee;
    }
    
    /* 모바일 로그인 상태 네비게이션 display */
    #mgnb2 {
    	/* 평소에는 메뉴 숨김 */
        display: none; 
        position: fixed;
        top: 60px;
        left: 0;
        width: 100%;
        /*height: calc(100% - 60px);*/
        background: rgba(255, 255, 255);
        padding: 20px;
		/* 여기서부터 추가*/
        overflow-y: auto; /* 내용이 길어지면 스크롤 가능하게 */
        z-index: 1000; /* 다른 요소 위에 메뉴가 보이도록 */
        box-sizing: border-box;
        
        /*여기서부터 추가 25.12.30*/
        pointer-events: auto;
        /*animation-name: slideFromBottom;*/
        /* animation: slideFromTop 0.4s ease-out both;*/
        
        /*
    	touch-action: none;
	    will-change: transform;
	    transition: transform .5s cubic-bezier(.32, .72, 0, 1);
	    animation-duration: .5s;
	    animation-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
	    */
    }
    
    /*
    @keyframes slideFromTop {
    from {
        transform: translateY(-100%);
        opacity: 0;
	    }
	    to {
	        transform: translateY(0);
	        opacity: 1;
	    }
	}
	*/
    #mgnb2.is-active { 
    	display: block;
    } /* is-active 클래스가 붙으면 보임 */
    
    #mgnb2 ul { flex-direction: column; }
    #mgnb2 li a {
        padding: 15px 10px;
        font-size: 18px;
        border-bottom: 1px solid #eee;
    }
    
    /*로그인 상태 네비게이션 start*/
    
    .div_login_nav{
		box-sizing: border-box;
		/*border: 0 solid #e5e7eb;*/
		/*text-align: center;*/
		/*padding: 1rem;*/
		gap: .125rem;
		flex-direction: column;
		display: flex;
	}

	.div_login_nav_item {
	/*
		transition-duration: .1s;
		transition-property: color, background-color, border-color, text-decoration-color, fill, stroke;
		transition-timing-function: cubic-bezier(.4, 0, .2, 1);
		transition-duration: .15s;
		*/
		outline: 2px solid transparent;
		outline-offset: 2px;
		font-size: .875rem;
		line-height: 1.25rem;
		padding: 1rem;
		border-color: hsl(var(--border));
		/*border-width: 1px;*/
		border-radius: .375rem;
		gap: 1rem;
		align-items: center;
		flex-wrap: wrap;
		display: flex;
		/*border: 1 solid #e5e7eb;*/
		border: 1px solid #cacccc;
		margin-bottom: 10px;
		
    	justify-content: space-between;
    	font-weight: 600;
    	font-family: 'notokr-bold';
	}
	
	.div_login_nav_btn2 {
		/*outline: 2px solid transparent;
		outline-offset: 2px;
		font-size: .875rem;
		line-height: 1.25rem;
		*/
		padding: 5px 10px;
		/*border-color: hsl(var(--border));*/
		/*border-width: 1px;*/
		border-radius: .375rem;
		gap: 1rem;
		align-items: center;
		flex-wrap: wrap;
		display: flex;
		/*border: 1 solid #e5e7eb;*/
		border: 1px solid #cacccc;
		/*margin-bottom: 10px;*/
		
    	/*justify-content: space-between;*/
    	cursor: pointer;
	}
	
	.div_login_nav_item .nav_icon{
		background-color: rgb(229 231 235);
		width: 2.25rem;
		height: 2.25rem;
		border-radius: .5rem;
		display: flex;
	    justify-content: center;
	    align-items: center;
	    margin-right: 10px;
	}
	
	.div_login_nav_item .nav_icon svg {
	    stroke: #666;
	    width: 1.75rem;
	    height: 1.75rem;
	}

	.div_login_nav_btn{
		/* 레이아웃 */
	  display: inline-flex;
	  align-items: center;
	  justify-content: center;
	  
	  /* 크기 및 모양 */
	  width: 35px;
	  height: 35px;
	  border-radius: 50%;
	  
	  /* 테두리 설정: 흰색보다 약간 진한 회색 */
	  border: 1px solid #e0e0e0; 
	  
	  /* 색상 및 배경 */
	  background-color: #ffffff; 
	  /*color: #333333;*/
	  cursor: pointer;
	  --tw-text-opacity: 1;
      color: rgb(55 65 81 / var(--tw-text-opacity)) !important;
	  
	  /* 부드러운 전환 효과 */
	  transition: all 0.3s ease;
	  margin-left: 10px;

	}
	
	.div_login_nav_btn:hover {
	   background-color: #f5f5f5;
	   border-color: #068ACF;
	   color: #068ACF;
	}
	  
	.div_login_nav_btn2:hover {
	  background-color: #f5f5f5; /* 마우스 올리면 배경도 살짝 회색으로 */
	  border-color: #068ACF;     /* 테두리도 조금 더 진하게 변경 */
	  color: #068ACF;
	}
	
	#div_login_screen{
		display: none;
    	pointer-events: auto;
		animation-name: fadeIn;
		animation-duration: .5s;
		animation-timing-function: cubic-bezier(0.32, 0.72, 0, 1);
		opacity: 1;
		background-color: rgba(0, 0, 0, .5);
        left: 0;
		position: fixed;
		width: 100%;
		top: 60px;
        height: 100%;
        z-index: 999;
        
    }
    
	/* include : mtopMenu_pc.jsp 로그인 상태창 start */
	#panel_nav {
		/*display: none;*/
	    position: fixed;
	    top: 60px;
	    left: 0;
	    right: 0;
	    height: 390px;
	    background: #fff;
	    border-bottom: 1px solid #ccc;
	    overflow: hidden;
	    z-index: 1000;
	    border-bottom-left-radius: .5rem;
    	border-bottom-right-radius: .5rem;
    	
    	/* 애니메이션 준비 */
		transform: translateY(-100%);
		transition: transform 0.35s ease;
		
	}
	/*
	#panel_nav.is-active { 
    	display: block !important;
    	height: 200px !important;
    	/*transform: translateY(0) !important;
    }*/ /* is-active 클래스가 붙으면 보임 */
    
	.panel_contents {
	    padding: 10px;
	    padding-bottom: 20px;
	    /*transform: translateY(0);*/
	    
	    transition: max-height 0.35s ease, opacity 0.25s ease;
		max-height: 0;
	  	opacity: 0;
	}
	
	.panel_nav.open {
	  transform: translateY(0) !important;
	  height: auto;
	}
	
	.panel_nav.open .panel_contents {
	  max-height: 100vh;
	  opacity: 1;
	}

	
	/* 핵심: 하단에 절대 고정 */
	.drag-bar {
	    position: absolute;
	    left: 0;
	    right: 0;
	    bottom: 0;
	    top: 355px;
	    height: 35px;
	    background: #f1f1f1;
	    cursor: ns-resize;
	    text-align: center;
	    line-height: 30px;
	    user-select: none;
	    border-top: 1px solid #ddd;
	    align-items: center;
	  	justify-content: center;
	  	display: flex;
	  	
	  	touch-action: none; /* 모바일에서 스크롤 방지 */
	}

	/* include : topMenu_pc.jsp 접속자 정보 상단 패널  end */
    /*메인슬라이드 이미지를 앞으로 당겨서 모바일 크기에 맞춘다*/
    .bx-wrapper img {
	   transform: translate(-20%, 0%) !important;
	}
	
	.news-section li a { font-size: 13px; }
	
    .util { display: none; } /* 유틸리티 링크는 모바일에서 숨김 */
    
    /* 햄버거 버튼 스타일 */
    .m-btn-menu {
        display: block;
        width: 30px;
        height: 30px;
        border: none;
        background: none;
        position: relative;
    }
    .m-btn-menu span {
        display: block;
        width: 100%;
        height: 2px;
        background: #333;
        position: absolute;
        left: 0;
        transition: all 0.3s;
    }
    .m-btn-menu span:nth-child(1) { top: 5px; }
    .m-btn-menu span:nth-child(2) { top: 14px; }
    .m-btn-menu span:nth-child(3) { bottom: 5px; }

    /* 햄버거 버튼 활성화 (X 모양) */
    .m-btn-menu.is-active span:nth-child(1) { transform: rotate(45deg); top: 14px; }
    .m-btn-menu.is-active span:nth-child(2) { opacity: 0; }
    .m-btn-menu.is-active span:nth-child(3) { transform: rotate(-45deg); top: 14px; }

    /* --- 메인 콘텐츠: 세로 정렬 --- */
    .news-section {
        flex-direction: column;
        gap: 30px;
    }
    
    .content-grid {
    	display: grid; /* CSS Grid 레이아웃 적용 */
	  	grid-template-columns: repeat(auto-fit, minmax(300px, 1fr)); /* 유연한 열 설정 */
	  	justify-items: center; /* 아이템(이미지)을 각 그리드 셀의 중앙에 정렬 */
	  	gap: 10px; /* 이미지 간의 간격 설정 */

        /*flex-direction: column;*/ /*원본 소스*/ 
    }
    
    .content-grid article {
        max-width: 400px; /* 너무 커지는 것 방지 */
        margin: 0 auto;
    }

    /* --- 푸터: 세로 정렬 --- */
    #footer .inner {
        flex-direction: column;
        /*text-align: center;*/
    }
    #footer .footer-info {
        order: 2; /* 순서 변경 */
        margin-top: 20px;
        font-size: 12px;
    }
    
    #footer .footer-links {
        order: 1; /* 순서 변경 */
    }
    #footer .footer-links a { margin: 0 10px; }
    
    .category_bbs_ft2 img {
	    width: 100% !important;
	}
}
/* Mobile (654px 이하) */
@media (max-width: 654px) {
	
	/*  Product&Event 항목이 세로로 한줄이되면, 빈칸 채우기용 aritle을 숨긴다 */
	#article_hide_1, #article_hide_2{
    	display:none !important;
    }
    
    .slider {
      flex: 1 1 100%;
      max-width: 100%;
   }
   
}

/* Mobile (430px 이하) */
@media (max-width: 430px) {
	#footer .footer-info .horizontal-list3 li {
    	width: 130px !important;
    }
    
    .horizontal-list4 .div_ARS_1 span {
    	width: 140px !important;
    	font-size: 12px;
    }
}


.horizontal-line {
	max-width: 100%;
    /*width: 100%;*/ /* 브라우저 가로 전체를 채움 */
    height: 1px; /* 줄의 두께 */
    background-color: #ccc; /* 줄의 색상 */
    /*margin: 30px 0;*/ /* 위아래 섹션과의 간격 */
}

#footer .horizontal-list {
  display: flex;
  flex-wrap: wrap;             /* 화면이 작아지면 줄바꿈 */
  list-style: none;            /* 점 제거 */
  padding: 0;
  margin: 0;
  font-weight: bold;
  color: #fff;
}

#footer .horizontal-list li {
  padding: 0px 40px 15px 0px;
  border-radius: 8px;
  white-space: nowrap;         /* 텍스트 줄바꿈 방지 */
}

#footer .horizontal-list2 {
  display: flex;
  flex-wrap: wrap;             /* 화면이 작아지면 줄바꿈 */
  list-style: none;            /* 점 제거 */
  padding: 0;
  margin: 0;
}

#footer .horizontal-list2 li {
  border-radius: 8px;
  white-space: nowrap;         /* 텍스트 줄바꿈 방지 */
}

#footer .horizontal-list3 li {
  border-radius: 8px;
  white-space: nowrap;         /* 텍스트 줄바꿈 방지 */
}


#div_partner {
    height: 100px;
    /*width: 1920px;*/
    overflow: hidden;
    margin: 0 auto;
    background: #fff;
    border-top: 1px solid #cacccc;
    align-items: center;  /* 세로 중앙도 필요하면 사용 */
    display: flex;
  	justify-content: center;
}

#div_gab{	height:95px;	}


#footer .footer-info{
	width: 100%;
}

#footer .footer-info ul li span.f_tel {
    background: url(/images/icon/footer_icon.png) no-repeat 0px -38px;
	padding: 0px 0px 0px 21px;
	width: 120px;
	display: inline-block;
}
/*
#footer .footer-info ul li {
	width: 135px;
	display: inline-block;
}
*/
#footer .footer-info ul li span.f_fax {
    background: url(/images/icon/footer_icon.png) no-repeat 0px 1px;
    padding: 0px 0px 0px 21px;
    width: 120px;
    display: inline-block;
}

#footer .footer-info ul li span.f_mail {
    background: url(/images/icon/footer_icon.png) no-repeat 0px -16px;
    padding: 0px 0px 0px 21px;
    width: 150px;
    display: inline-block;
    justify-content: flex-end;
	cursor: pointer;
}

#footer .footer-info .horizontal-list2 span {
    padding: 0px 0px 0 10px;
    display: inline-block;
    letter-spacing: 0.2px;
}

#footer .footer-info .horizontal-list2 b {
    width: 150px;
}

#footer .footer-info .horizontal-list3 {
	display: flex;
  	flex-wrap: wrap;             /* 화면이 작아지면 줄바꿈 */
	list-style: none;            /* 점 제거 */
  	padding: 0;
  	margin: 0;
  	padding-bottom: 2px;
}

#footer .footer-info .horizontal-list3 span {
    padding: 0px 0px 0px 10px;
    letter-spacing: 0.2px;
    display: inline-block;
}

#footer .footer-info .horizontal-list3 b {
    width: 150px;
	display: inline-block;
}

#footer .footer-info .horizontal-list3 li {
    width: 180px;
	display: inline-block;
}

#footer .footer-info .horizontal-list4 {
	display: flex;
  	flex-wrap: wrap;             /* 화면이 작아지면 줄바꿈 */
	list-style: none;            /* 점 제거 */
  	padding: 0;
  	margin: 0;
}


#footer .footer-info .horizontal-list4 span {
    padding: 0px 0px 0px 0px;
    letter-spacing: 0.2px;
    display: inline-block;
    white-space: nowrap;      /* 텍스트가 줄바꿈되지 않게 설정 */
  	overflow: hidden;         /* 넘치는 부분은 숨김 */
  	text-overflow: ellipsis;  /* 넘치는 부분을 '...'으로 표시 */
}

.horizontal-list4 .li_ARS{
    width: 180px;
    display: inline-block;
    vertical-align: top;
    padding: 0px 0px 0 0px; 
}

.horizontal-list4 .div_ARS_1 b {
    width: 25px;
    display: inline-block;
    padding: 0px 0px 0 0px;
}

.horizontal-list4 .div_ARS_1 span {
    width: 180px;
    display: inline-block;
    padding: 0px 0px 0 0px;
}

/* PC 메뉴 start */
#mcontents_header {
    position: fixed;
    width: 100%;
    background-color: #fff;
    z-index: 9998;
    border-bottom: 1px solid #cacccc;
    padding: 0px 15px;
}

#mtnb_hd {
    width: 100%;
    height: 35px;
}

#mtnb_hd_wrap {
    position: relative;
    width: 1190px;
    margin: 0 auto;
    padding: 0 auto;
}

#mtnb_hd ul.mtnb li {
    float: left;
    padding: 5px 5px 0 5px;
}

#mtnb_hd ul.mtnb li a {
    width: 70px;
    color: #555;
}

#mtnb_hd .mtnb {
    height: 25px;
    float: right;
    margin-top: 8px;
    font-size: 11px;
    padding-right: 30px;
}

#mtnb_hd .mlogo {
    float: left;
    margin-top: 25px;
}

#mtnb_hd ul.mtnb li {
    float: left;
    padding: 5px 5px 0 5px;
    box-sizing: content-box;
}


#mtnb_hd ul.mtnb li a img{
    font-size: 1%;
    line-height: 1;
    border: 0;
    vertical-align: middle;
}

#mtnb_hd .msearch {
    float: right;
    width: 140px;
    height: 22px;
    padding: 0 10px;
    border: 1px solid #c7c7c7;
    background: url(/images/common/gnb/search_icon.jpg) no-repeat 132px 6px;
}

#mtnb_hd ul.mtnb li.ri {
    float: right;
    /*width: 150px;*/
    padding-right: 20px;
    padding-left: 35px;
    padding-top: 0px;
}

.mgnb-pc * {
  /*
  	box-sizing: content-box; 처리를 하지 않으면 메뉴 텍스트가 접혀진다
  	홈페이지 메뉴는 아래가 값이 디폴트, 하지만 box-sizing: border-box; 처리가 되어야 모바일 아이콘이 깔끔하다.
  	반응형은 모바일 기준으로 box-sizing: border-box; 값을 사용하고
  	PC형 일때만 box-sizing: content-box; 적용시킨다
  */
  box-sizing: content-box;
}

/* PC 메뉴  end*/


#mvisual {
	position: relative;
	max-width: 1920px;
	height: 100%;
}


.main_slider > li {
  /* 개별 이미지의 최소 너비를 설정합니다. */
  /* 이 값은 `.main_slider`의 min-width와 동일하게 설정합니다. */
  min-width: 900px;
}


#mvisual .order_menu {
	width: 100%;
	/*display: flex;
  	justify-content: center;*/
}

#mvisual .order_menu li {
    display: inline-block;
    float: left;
    margin: 0 10px 10px 0;
}

#mvisual .order_menu {
    position: absolute;
    bottom: 7%;
}

.bx-wrapper .bx-pager, .bx-wrapper-main .bx-controls-auto {
    position: absolute;
    bottom: 20px;
    width: 100%;
}

.bx-wrapper {
    position: relative;
    margin-bottom: 0px;
    padding: 0;
    -ms-touch-action: pan-y;
    touch-action: pan-y;
    border: 0px;
}

.bx-wrapper img {
    /*max-width: 1920px;*/
    max-width: 100%;
    display: block;
    outline: 0;
    height: auto;
    margin: 0;
}

.flex-center {
  display: flex;
  justify-content: center;
}

/*
	cosmo_common.css 커스텀 css 
	<div id="visual"> -> <div id="mvisual"> 로 교체 
	모바일 반응형(@media) css 가 무조건 우선으로 적용되기 위해서는 맨 나중에 선언되어 있어야 한다
	cosmo_common.css 에서 사용하던 것 중 mystyle.css 로 가져온 것은 앞자리에 <m>을 넣어 구분하였음
*/

#mvisual .order_menu li.main_b1 {background:url(/images/main/box01.png)50%; width: 160px; height: 140px; background-color:#fff; 
opacity:85%;
transform:translateY(0);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}
#mvisual .order_menu li.main_b1:hover 
{cursor:pointer; 
background:url(/images/main/box01-a.png);
opacity:100%;
background-color:#1b8fdd;
transform:translateY(-5px);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}

#mvisual .order_menu li.main_b2 {background:url(/images/main/box02.png)50%; width: 160px; height: 140px; background-color:#fff; 
opacity:85%;
transform:translateY(0);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}
#mvisual .order_menu li.main_b2:hover 
{cursor:pointer; 
background:url(/images/main/box02-a.png);
opacity:100%;
background-color:#1b8fdd;
transform:translateY(-5px);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}

#mvisual .order_menu li.main_b3 {background:url(/images/main/box03.png)50%; width: 160px; height: 140px; background-color:#fff; 
opacity:85%;
transform:translateY(0);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}
#mvisual .order_menu li.main_b3:hover 
{cursor:pointer; 
background:url(/images/main/box03-a.png);
opacity:100%;
background-color:#1b8fdd;
transform:translateY(-5px);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}

#mvisual .order_menu li.main_b4 {background:url(/images/main/box04.png)50%; width: 160px; height: 140px; background-color:#fff; 
opacity:85%;
transform:translateY(0);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}
#mvisual .order_menu li.main_b4:hover 
{cursor:pointer; 
background:url(/images/main/box04-a.png);
opacity:100%;
background-color:#1b8fdd;
transform:translateY(-5px);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}

#mvisual .order_menu li.main_b5 {background:url(/images/main/box05.png)50%; width: 160px; height: 140px;; background-color:#fff; 
opacity:85%;
transform:translateY(0);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}
#mvisual .order_menu li.main_b5:hover 
{cursor:pointer; 
background:url(/images/main/box05-a.png);
opacity:100%;
background-color:#1b8fdd;
transform:translateY(-5px);
transition: background 300ms ease-in-out, transform 300ms ease-in-out, opacity 300ms;}



#mtnb_hd_wrap #mmypage {position:fixed; z-index:9999; right: 192px; top: 31px; border:1px solid #c7c7c7;border-top:2px solid #0667a5; width: 130px; background:#fff; color:#aeaeae; font-size: 12px;}
#mtnb_hd_wrap #mmypage ul {margin-top: 4px;}
#mtnb_hd_wrap #mmypage ul li{clear:both; margin:8px auto; padding:0 auto; text-align:left;}
#mtnb_hd_wrap #mmypage a {color:#000; padding-left: 13px;}
#mtnb_hd_wrap #mmypage a:HOVER {text-decoration: underline; color:#0667a5;  }

#mtnb_hd_wrap #mlangList {position:fixed; z-index:9999; border:1px solid #c7c7c7; border-top:2px solid #0667a5; width:72px; height:54px; background:#fff; font-size: 12px;}
#mtnb_hd_wrap #mlangList ul {margin-top: 2px;}
#mtnb_hd_wrap #mlangList ul li{clear:both; margin:8px auto; padding:0 auto; text-align:left;}
#mtnb_hd_wrap #mlangList a {color:#000;padding-left: 13px;}
#mtnb_hd_wrap #mlangList a:HOVER {text-decoration: underline; color:#0667a5; }

.mbox_product_T a, .mbox_product_bbsT {
    font-family: 'notokr-bold';
    display: inline-block;
    font-size: 25px;
    letter-spacing: -1px;
    text-align: left;
    padding: 0px 0px 20px;
}

.mbox_product_bbs {
    display: flex;
    flex-wrap: wrap;
    width: 100%;
    max-width: 1190px;
}

.mcategory_bbs {
    padding: 0px;
}

.mcategory_bbs > ul > li {
	height: auto;
    border-bottom: 1px dotted #cccccc;
    font-size: 15px;
    padding: 6.5px;
}

.mmodal_pop1 {
    justify-content: center;
    align-items: center;
    display: flex;
    position: fixed;
    z-index: 9999;
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(0, 0, 0, 0.4);
}

.mmodal_content1{
	display: flex;
    flex-direction: column;
    padding: 0px 0px 0px 0px;
}
.mmodal-sections{
	display: flex;
    flex-wrap: wrap;
    justify-content: center;
}

/*컨텐츠 페이지 메인 제목 크기*/
.main-h1 {
	font-size: 30px !important;
}

/*컨텐츠 페이지 서브 제목 크기*/
.main-h2{
	font-size: 25px !important;
}
    
/*
	cosmo_common.css 변형한 css 끝 
*/

/* ========================================================== */
/*  반응형 스타일 서비스 컨텐츠 페이지 css			                          */
/* ========================================================== */

	.msub_menu {
	    font-family: 'Inter', system-ui, sans-serif;
	    /*background: #f8fafc;*/
	    margin: 0;
	    padding: 2rem;
	    display: flex;
	    /*justify-content: center;*/
	}

	/* 탭 메뉴 컨테이너 */
  .mtab-bar {
    /*display: flex;*/
    flex-wrap: wrap; /* 브라우저 너비 부족 시 다음 줄로 이동 */
    gap: 0.5rem;    /* 탭 간 간격 */
    background: #fff;
    border-radius: 0.75rem;
    box-shadow: 0 4px 12px rgba(0,0,0,0.08);
    padding: 0.5rem;
	margin-bottom: 20px;
	display: none;
  }
  
  /* 탭 버튼 링크 */
  .mtab-link {
    /* flex: 1 1 auto;        최소 너비 확보, 공간 부족 시 줄 바꿈 가능  */
    text-align: center;
    padding: 0.75rem 1.5rem;
    text-decoration: none;
    color: #475569;       /* slate-600 */
    font-weight: 500;
    border-bottom: 3px solid transparent;
    border-radius: 0.5rem;
    transition: all 0.25s ease;
    background-color: #f8fafc;
    flex: 1 1 25%;
  }

  /* 활성 탭 */
  .mtab-link.active {
    color: #1e3a8a;       /* blue-800 */
    border-bottom: 3px solid #2563eb; /* blue-600 */
    background-color: #fff;
  }

  /* 호버 효과 */
  .mtab-link:hover {
    color: #1d4ed8;
    background-color: #f1f5f9;
  }
	
#mhd_bg {
    clear: both;
    width: 100%;
    /* height: 105px; */
    background: #e5e5e5;
    /*border-top: 1px solid #cacccc;*/
    border-bottom: 1px solid #eee;
    /*padding-top: 95px;*/
    overflow: hidden;
}

.mcon-main {
	display: flex;
	padding-left: 30px;
}

.orderBtn{
	position: fixed;
	right: 80px;
	bottom: 20px;
	cursor: pointer;
	z-index: 9990;
}

.sub-list-table table td {
	font-size: 15px; 
    padding: 5px 0;
}


/* ========================================================== */
/*  반응형 스타일 서비스 컨텐츠 페이지 css end		                          */
/* ========================================================== */

/* ========================================================== */
/*  footer bottom 메뉴 시작 */
/* ========================================================== */

/* 기본 스타일: 화면 아래로 완전히 숨겨진 상태 */
.bottom-nav {
    position: fixed;
    bottom: -100px; /* 초기 위치: 숨김 */
    left: 50%;
    transform: translateX(-50%); /* 가운데 정렬 */
    max-width: 500px;
    height: 50px;
    background-color: #ffffff;
    border-radius: 35px; /* 양 끝을 둥글게 */
    box-shadow: 0 -2px 15px rgba(0, 0, 0, 0.1); /* 부드러운 그림자 */
    display: flex;
    justify-content: space-around;
    align-items: center;
    transition: bottom 0.4s ease-in-out; /* 등장 애니메이션 */
    z-index: 9999;
    padding: .5rem;
}

/* 클래스가 추가되면 화면 위로 올라옴 */
.bottom-nav.visible {
    bottom: 20px; /* 하단에서 20px 띄움 */
}

/* 메뉴 내부 아이템 스타일 */
.nav-item {
    text-align: center;
    color: #666;
    font-size: 11px;
    /*gap: .125rem;*/
    display: block;
    font-family: initial;
}
.nav-item .icon {
	width: 50px;
	height: 28px; /* 아이콘 영역 높이 지정 */
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 2px;
	cursor: pointer;
}

.nav-item .icon svg {
    /* CSS로 색상을 한꺼번에 조절하고 싶을 때 사용 */
    stroke: #666; 
    width: 1.75rem;
    height: 1.75rem;
}

.nav-item2 {
    text-align: center;
    color: #666;
    font-size: 11px;
    /*gap: .125rem;*/
    diplay: block;
}

.nav-item2 .icon2 {
    width: 45px;
    /* height: 28px; */
    display: flex;
    justify-content: center;
    align-items: center;
    /* margin-bottom: 2px; */
    cursor: pointer;
}

.nav-item2 .icon2 svg {
    /* CSS로 색상을 한꺼번에 조절하고 싶을 때 사용 */
    stroke: #666; 
    width: 1.75rem;
    height: 1.75rem;
}


/*2026 1.30 */
.content_wrapper {max-width: 100%; margin: 0 auto; font-size: 1.2rem;}
.content_wrapper h3 {margin-bottom:30px; font-size:30px;}
.info_box {padding-bottom: 15px; font-size:1.2rem;}
.content_wrapper h4 {font-size:20px; color: #0056b3; margin-top: 20px; padding-bottom: 5px; }
.sub-title {font-size:18px;}

/* 카드방식 표 스타일 */
.service-container {
  display: flex;
  flex-direction: column;
  gap: 24px; /* 카드 사이 간격 */
  padding: 30px 0;
  background-color: #ffffff;
}

.card {
  background: #ffffff;
  border-radius: 12px;
  padding: 35px;
  /* X축 0, Y축 0, Blur 20px, Spread 0 */
  box-shadow: 0 0 20px rgba(0, 0, 0, 0.08);
  border: 1px solid #ececec; /* 아주 연한 선으로 형태만 보조 */
  display: flex;
  flex-direction: column;
  transition: none; 
}

.card-title {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--primary-blue);
  padding-bottom: 12px;
}


.info-row {
  line-height: 1.8;
}

.label {
  font-size: 1rem;
  color: var(--text-sub);
  word-break: keep-all;
}

.label b {
  color: var(--text-main);
  font-weight: 700;
}

/* Quality Control 등 내부 섹션 구분 */
.card b + br + span {
  display: block;
  margin-top: 15px;
  padding-top: 15px;
  border-top: 1px dashed #edf2f7;
}

.info-row span br + span {
    display: inline-block;
    margin-top: 10px;
    color: var(--primary-blue);
    font-weight: 600;
}

 
/* 테이블 */  
.table-wrapper { 
    width: 100%; 
    max-width: 100%;
    display: block;
    overflow-x: auto; /* 가로 스크롤 허용 */
    -webkit-overflow-scrolling: touch;
    margin-top: 20px;
   	border-radius: 12px 12px 0 0; /* 둥글게  */
    border-collapse: separate; /* 테두리 겹침 방지 */
    border-spacing: 0;
    overflow: hidden; /* 내부 테이블이 둥근 모서리 밖으로 나가지 않게 함 */
    border: none;
 
  }

.simple-table {
    width: 100%;
    min-width: 450px;
    border-collapse: separate;
    border-spacing: 0;
  	font-size: 14px; /* 맨 윗줄만 강조 */
  	border-left: 1px solid var(--border-color);
    border-top: 1px solid var(--border-color);
    /* 둥근 모서리 적용을 위해 필요 */
    border-radius: 12px 12px 0 0;

  }
.simple-table th, .simple-table td {
   border-right: 1px solid var(--border-color);
    border-bottom: 1px solid var(--border-color);
   box-sizing: border-box;}


.simple-table thead th {
   background-color: var(--primary-blue);
   color: white;
   font-weight: 500;
   border-right: 1px solid rgba(255, 255, 255, 0.4);
    border-bottom: 1px solid rgba(255, 255, 255, 0.4);}
  
.simple-table tbody tr:nth-child(even) td {
    background-color: #f9f9f9;
}
 .simple-table th {padding: 12px 8px;}
 .simple-table td {
    padding: 15px 8px;
    text-align: center; }
  .item-name { 
    text-align: left !important; 
    font-weight: bold; 
    color: #333; 
    background: #fff;
  }
  .price-text { font-weight: bold; color: #d32f2f; }
  
 

/* ========================================================== */
/*  footer bottom 메뉴 end  */
/* ========================================================== */