@charset "utf-8";

/* =========================== SNB */
#sh_snb {display:inline-block;position:relative;z-index:10;padding:0 40px;text-align:center;box-shadow:0px 2px 12px rgba(0,0,0,.1);background-color:#fff}
#sh_snb li {display:inline-block;position:relative;height:55px;padding:0 35px;font-size:17px;line-height:55px}
#sh_snb li:first-child:before {display:none}
#sh_snb li a {position:relative;font-weight:500}
#sh_snb li a.on{color:#2ba6ff}

/* =========================== sub1 인사말 전용 스타일 */
/* sub1 페이지는 전체 너비를 사용하여 배경색을 꽉 채움 */
.sub1_page #sh_container,
.sub1_page #sh_container_wrapper,
.sub1_page #sh_content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* 각 섹션 내부의 inner 클래스가 중앙 정렬 담당 */
.sub1_page .inner {
    max-width: 1200px;
    margin: 0 auto !important;
    padding: 0 20px;
    position: relative;
}

.sub1_page #sh_sub_banner {
    /* 이미지는 sub1.php에서 인라인 스타일로 지정 */
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
    height: 380px !important; /* [수정] 450px -> 380px */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-top: 96px;
    position: relative;
}
/* 배너 텍스트 가독성을 위한 딤 처리 (필요시 사용) */
.sub1_page #sh_sub_banner::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.3); /* 이미지 위에 30% 어두운 막 */
    z-index: 1;
}

.sub1_page #sh_sub_banner #sh_content_tit {
    padding-top: 0;
    color: #fff;
    position: relative;
    z-index: 2; /* 딤 처리 위로 올림 */
}
.sub1_page #sh_sub_banner #sh_content_tit p {
    font-size: 18px;
    font-weight: 500; /* 굵기 약간 증가 */
    margin-bottom: 10px;
    color: #fff;
    opacity: 0.9;
    letter-spacing: 0.5px;
}
.sub1_page #sh_sub_banner #sh_content_tit h3 {
    font-size: 48px; /* 크기 증가 */
    font-weight: 800; /* 가장 굵게 */
    line-height: 1.3;
    margin-bottom: 0;
    text-shadow: 0 2px 10px rgba(0,0,0,0.2); /* 텍스트 그림자 추가 */
}

/* 섹션 공통 */
.sub_section { padding: 120px 0; }
.sub_blue_tit { display: block; color: #2ba6ff; font-weight: 900; font-size: 15px; letter-spacing: 1.5px; margin-bottom: 20px; }
.sub_main_tit { font-size: 42px; font-weight: 800; color: #111; line-height: 1.3; margin-bottom: 40px; letter-spacing: -1px; }
.sub_main_tit b { font-weight: 900; } /* 강조 부분 더 굵게 */

/* 인사말 섹션 */
.sub1_greeting { text-align: center; }
.sub1_greeting .greeting_txt { font-size: 18px; line-height: 1.8; color: #333; font-weight: 500; margin-bottom: 50px; word-break: keep-all; } /* 폰트 진하게, 줄바꿈 개선 */
.sub1_greeting .greeting_sign { font-size: 16px; color: #555; font-weight: 600; }

/* 생각 섹션 */
.sub1_thinking { 
    background: #fbfcfe; /* [수정] 더 연한 배경색 */
    text-align: center; 
    width: 100% !important; 
    padding: 120px 0; 
    overflow: hidden; 
} 
.sub1_thinking .inner { 
    max-width: 1200px; 
    margin: 0 auto !important; 
    padding: 0 20px;
    display: flex !important; 
    flex-direction: column !important;
    align-items: center !important; 
}
.sub1_thinking .thinking_tit { 
    font-size: 38px; 
    margin-bottom: 70px; 
    font-weight: 400; 
    letter-spacing: -1.5px; 
    color: #111;
    width: 100%;
}
.sub1_thinking .thinking_tit b { color: #2ba6ff; font-weight: 900; }

/* 리스트 컨테이너 - 중앙 정렬 상태에서 수동 조정 */
.thinking_grid { 
    display: flex; 
    flex-direction: column; 
    width: 100%;
    max-width: 900px; 
    margin: 0 auto; 
    border-top: 1.5px solid #e1e5f0; 
    
    /* 수동 위치 조정 */
    position: relative;
    left: 170px; 
}

.thinking_item { 
    display: flex; 
    align-items: center; 
    background: transparent; 
    padding: 45px 0; 
    border-radius: 0; 
    box-shadow: none; 
    text-align: left; 
    border-bottom: 1px solid #e1e5f0; 
}

/* 좌측 라벨 (캡슐 형태) */
.thinking_item .label { 
    flex-shrink: 0; 
    width: 170px; 
    height: 44px; 
    line-height: 40px; 
    text-align: center;
    border-radius: 22px; 
    font-size: 15px; 
    font-weight: 800; 
    margin-right: 70px; 
    border: 2px solid #2ba6ff; 
    color: #2ba6ff; 
    background: #fff;
    letter-spacing: 0.5px;
}

.thinking_item .txt {
    flex: 1;
}

.thinking_item .txt strong { 
    display: block; 
    font-size: 22px; 
    color: #000; 
    margin-bottom: 12px; 
    font-weight: 800; 
    letter-spacing: -0.5px;
}

.thinking_item .txt { 
    font-size: 17px; 
    color: #444; 
    line-height: 1.6; 
    font-weight: 500; 
}

/* 하단 상세 섹션 */
.sub1_detail .inner { 
    display: flex; 
    align-items: center; 
    gap: 60px; 
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}
.sub1_detail .detail_img { 
    flex: 0 0 48%; 
    border-radius: 0 30px 30px 0; 
    overflow: hidden; 
    box-shadow: 0 10px 30px rgba(0,0,0,0.08); 
}
.sub1_detail .detail_img img { width: 100%; display: block; }
.sub1_detail .detail_txt { 
    flex: 1; 
    padding: 0 50px 0 20px; 
}
.sub1_detail .detail_txt .sub_blue_tit { margin-bottom: 25px; }
.sub1_detail .detail_txt p { font-size: 17px; line-height: 1.8; color: #333; font-weight: 500; } /* 설명글 진하게 */

@media (max-width: 1024px) {
    /* 배너 높이 축소 */
    .sub1_page #sh_sub_banner { height: 320px !important; margin-top: 64px; }
    .sub1_page #sh_sub_banner #sh_content_tit h3 { font-size: 36px; }
    
    /* 섹션 여백 조정 */
    .sub_section { padding: 80px 0; }
    .sub_main_tit { font-size: 32px; word-break: keep-all; }
    
    /* Thinking 섹션 */
    .sub1_thinking { padding: 80px 0; }
    .sub1_thinking .thinking_tit { font-size: 28px; margin-bottom: 50px; word-break: keep-all; }
    
    .thinking_grid { 
        left: 0; /* 수동 위치 조정 해제 */
        width: 100%;
    }
    
    .thinking_item { 
        flex-direction: column; 
        text-align: center; 
        padding: 40px 20px;
    }
    
    .thinking_item .label { 
        margin-right: 0; 
        margin-bottom: 20px; 
    }
    
    /* Detail 섹션 */
    .sub1_detail .inner { 
        flex-direction: column !important; 
        gap: 40px; 
    }
    .sub1_detail .detail_txt { text-align: center; }
}

@media (max-width: 768px) {
    /* 더 작은 화면 대응 */
    .sub1_page #sh_sub_banner { height: 260px !important; }
    .sub1_page #sh_sub_banner #sh_content_tit { border: none !important; } /* 테두리 제거 */
    .sub1_page #sh_sub_banner #sh_content_tit h3 { font-size: 28px; }
    .sub1_page #sh_sub_banner #sh_content_tit p { font-size: 15px; }
    
    .sub_section { padding: 60px 0; }
    .sub_blue_tit { font-size: 13px; }
    .sub_main_tit { font-size: 26px; }
    
    .sub1_greeting .greeting_txt { font-size: 15px; }
    
    .thinking_item .txt strong { font-size: 18px; }
    .thinking_item .txt { font-size: 15px; }
    
    .sub1_detail .detail_txt p { font-size: 15px; text-align: justify; } /* 본문 양쪽 정렬 */
}

/* =========================== sub2 조건 및 절차 전용 스타일 */
/* sub2 페이지도 전체 너비를 사용하여 배경색을 꽉 채움 */
.sub2_page #sh_container,
.sub2_page #sh_container_wrapper,
.sub2_page #sh_content {
    width: 100% !important;
    max-width: none !important;
    margin: 0 !important;
    padding: 0 !important;
}

/* 각 섹션 내부의 inner 클래스가 중앙 정렬 담당 */
.sub2_page .inner {
    max-width: 1200px;
    margin: 0 auto !important;
    padding: 0 20px;
    position: relative;
}

.sub2_page #sh_sub_banner {
    /* 이미지는 sub2.php에서 인라인 스타일로 지정 */
    background-repeat: no-repeat !important;
    background-position: center center !important;
    background-size: cover !important;
    height: 380px !important;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    margin-top: 96px;
    position: relative;
}
.sub2_page #sh_sub_banner::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0; bottom: 0;
    background: rgba(0,0,0,0.3);
    z-index: 1;
}
.sub2_page #sh_sub_banner #sh_content_tit {
    padding-top: 0;
    color: #fff;
    position: relative;
    z-index: 2;
}
.sub2_page #sh_sub_banner #sh_content_tit p {
    font-size: 18px;
    font-weight: 500;
    margin-bottom: 10px;
    color: #fff;
    opacity: 0.9;
}
.sub2_page #sh_sub_banner #sh_content_tit h3 {
    font-size: 48px;
    font-weight: 800;
    line-height: 1.3;
    margin-bottom: 0;
    text-shadow: 0 2px 10px rgba(0,0,0,0.2);
}

.sub2_section { text-align: center; padding: 80px 0; width: 100%; } /* 전체 상하 패딩 축소 */
.sub_desc { font-size: 17px; color: #555; margin-bottom: 40px; word-break: keep-all; font-weight: 500; } /* 타이틀 하단 여백 축소 */
.sub_desc b { color: #111; font-weight: 800; }

/* [추가] Condition 전체를 감싸는 흰색 쉐도우 박스 */
.condition_white_box {
    background: #fff;
    border-radius: 40px;
    padding: 60px 40px 50px; /* 상단 60px, 하단 50px로 축소 */
    box-shadow: 0 20px 60px rgba(0,0,0,0.08); 
    max-width: 1100px;
    margin: 0 auto;
}

/* Condition Circles (교집합 느낌의 디자인) */
.condition_circles {
    display: flex;
    justify-content: center;
    align-items: center;
    margin-bottom: 50px; /* 아래 문의 박스와 간격 대폭 축소 */
    padding: 10px 0;
}
.circle_item {
    width: 220px;
    height: 220px;
    border-radius: 50%;
    
    /* [수정] 배경 완전 투명하게 */
    background: transparent !important; 
    backdrop-filter: none !important;
    
    border: 2.5px solid #00a0e9; 
    display: flex;
    align-items: center;
    justify-content: center;
    
    /* [수정] 간격 조정 */
    margin: 0 -10px; 
    
    position: relative;
    box-shadow: none; 
    transition: all 0.4s ease;
    z-index: 1;
}

.circle_item:hover {
    transform: translateY(-15px);
    z-index: 10; 
    border-color: #008ac9;
    border-width: 4px; /* 호버 시 테두리 강조 */
}

.circle_inner { text-align: center; width: 100%; padding: 0 15px; }
.circle_inner strong { 
    font-size: 21px; 
    font-weight: 800; 
    color: #111; 
    line-height: 1.4; 
    display: block; 
    
    /* [보강] 배경이 투명하므로 텍스트 뒤에 흰색 그림자를 주어 선과 겹쳐도 잘 보이게 함 */
    text-shadow: -2px -2px 0 #fff, 2px -2px 0 #fff, -2px 2px 0 #fff, 2px 2px 0 #fff, 0 0 10px #fff;
}

/* Inquiry Box - 스타일 단순화 (부모 박스가 배경 역할) */
.inquiry_box {
    display: flex;
    justify-content: space-between;
    align-items: center;
    background: transparent; /* 배경 제거 */
    border-radius: 0; 
    padding: 0 40px; /* 내부 여백 조정 */
    box-shadow: none; /* 그림자 제거 */
    max-width: 900px;
    margin: 0 auto;
    border: none;
}
.inquiry_box .icon_tel { display: flex; align-items: center; gap: 30px; }
.inquiry_box .tel_icon_circle {
    width: 70px;
    height: 70px;
    border-radius: 50%;
    background: transparent; 
    color: #00a0e9;
    display: flex;
    align-items: center;
    justify-content: center;
}
.inquiry_box .txt_group { 
    display: flex; 
    align-items: center; 
    gap: 15px; /* 텍스트 사이 간격 */
}
.inquiry_box .txt { font-size: 20px; font-weight: 600; color: #555; }
.inquiry_box .tel_num { font-size: 40px; font-weight: 900; color: #111; font-family: 'Poppins'; letter-spacing: -1.5px; }

.inquiry_box .btn_apply {
    background: linear-gradient(90deg, #2ba6ff, #2ba6ff);
    color: #fff;
    padding: 20px 55px;
    border-radius: 45px;
    font-size: 19px;
    font-weight: 800;
    transition: all 0.3s;
    box-shadow: 0 10px 25px rgba(0,160,233,0.3);
    display: flex;
    align-items: center;
    gap: 12px;
}
.inquiry_box .btn_apply:hover { transform: translateY(-5px); box-shadow: 0 15px 35px rgba(0,160,233,0.4); }

/* Process Section */
.process_section { 
    background: #fbfcfe !important; /* [수정] sub1과 동일한 연한 배경색 */
    padding: 100px 0 120px; /* 상하 패딩 조정 */
    width: 100% !important;
}
.process_list {
    display: flex;
    justify-content: space-between;
    gap: 10px;
}
.process_list li {
    flex: 1;
    background: #fff;
    border-radius: 25px;
    padding: 50px 25px; /* 내부 패딩 조정으로 높이 밸런스 맞춤 */
    text-align: center;
    box-shadow: 0 15px 40px rgba(0,0,0,0.06);
    border: 1px solid #fff;
    transition: all 0.4s;
}
.process_list li:hover {
    transform: translateY(-15px);
    box-shadow: 0 25px 60px rgba(0,0,0,0.12);
    border-color: #cceeff;
}

.step_badge {
    display: inline-block;
    font-size: 20px;
    font-weight: 800;
    color: #00a0e9;
    margin-bottom: 30px;
    font-family: 'Poppins';
    background: #eaf7ff;
    padding: 8px 22px;
    border-radius: 20px;
}

.process_list li h3 {
    font-size: 26px;
    font-weight: 800;
    color: #111;
    margin-bottom: 25px;
}
.process_list li p {
    font-size: 17px;
    color: #555;
    line-height: 1.7;
    word-break: keep-all;
    font-weight: 500;
}

@media (max-width: 1024px) {
    .sub2_page #sh_sub_banner { height: 320px !important; margin-top: 64px; }
    
    .condition_circles { margin: 0 auto 50px; flex-wrap: wrap; }
    .circle_item { margin: 10px; width: 170px; height: 170px; } /* 모바일은 가독성을 위해 겹침 해제 */
    .circle_inner strong { font-size: 17px; }
    
    .inquiry_box { flex-direction: column; padding: 40px 20px; text-align: center; }
    .inquiry_box .icon_tel { flex-direction: column; margin-bottom: 30px; }
    .inquiry_box .txt_group { text-align: center; }
    .inquiry_box .tel_num { font-size: 32px; }
    
    .process_list { flex-wrap: wrap; }
    .process_list li { flex: 0 0 48%; margin-bottom: 25px; }
}

@media (max-width: 768px) {
    .sub2_page #sh_sub_banner { height: 260px !important; }
    .sub2_page #sh_sub_banner #sh_content_tit { border: none !important; }
    
    .circle_item { width: 150px; height: 150px; }
    .circle_inner strong { font-size: 15px; }
    
    .process_list li { flex: 0 0 100%; }
}

/* =========================== PAGE */
#greeting{font-size:15px;font-weight:400;line-height:1.8;letter-spacing:-.2px;color:#777;font-family:'Noto Sans KR'}
#greeting .tit_area{padding:0 0 40px 5%;font-size:38px;font-weight:100;line-height:1.35;letter-spacing:-.5px;color:#222}
#greeting .tit_area p{font-weight:600}
#greeting .img{height:600px;background:url(../img/sub/debate.jpg) center no-repeat;background-size:cover}
#greeting .cont{padding:40px 0 0 25%}
#greeting .cont .pl{white-space:pre-line}
#greeting .cont .sign{margin-top:30px;font-weight:500;color:#222}
#greeting .cont .sign span{margin-left:20px;font-size:17px}
@media(max-width:1024px){
#greeting{padding:20px;font-size:14px;line-height:1.6}
#greeting .tit_area{padding:0;font-size:28px;line-height:1.4;color:#222;word-break:keep-all}
#greeting .img{height:200px;margin:15px 0}
#greeting .cont{padding:0}
#greeting .cont .sign{margin-top:20px}
#greeting .cont .sign span{margin-left:0;font-size:15px}
}
@media(max-width:768px){
#greeting .cont .pl{white-space:normal}	
}
@media(max-width:480px){
#greeting{padding:15px 12px}	
#greeting .tit_area{font-size:22px}
}

/* =========================== wgallery 251211 탁도현 */
#wgallery{max-width:1400px;margin:120px auto;padding:40px 20px}
#wgallery_category{display:flex;gap:14px;margin-bottom:40px;justify-content:center}
#wgallery_category button{padding:12px 26px;border:none;border-radius:40px;background:rgba(255,255,255,0.6);backdrop-filter:blur(6px);font-size:16px;font-weight:600;color:#444;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 10px rgba(0,0,0,0.05)}
#wgallery_category button:hover{background:rgba(255,255,255,0.95);transform:translateY(-2px);box-shadow:0 6px 14px rgba(0,0,0,0.10)}
#wgallery_category button.active{background:linear-gradient(90deg,#4c5fc2,#7488e8);color:#fff;box-shadow:0 6px 14px rgba(76,95,194,0.3)}
#wgallery_header{text-align:center;margin-bottom:40px}
#wgallery_header p{font-size:18px;font-weight:700;color:#1e1e1e;margin:0;letter-spacing:-0.5px}
#wgallery_header h2{font-size:18px;color:#666;margin-top:8px}
#wgallery_list ul{display:flex;flex-wrap:wrap;gap:32px;justify-content:center;list-style:none;padding:0;margin:0;}
#wgallery_list ul li{width:calc((75% - 64px) / 3);background:#fff;border-radius:20px;box-shadow:0 6px 20px rgba(0,0,0,0.06);overflow:hidden;transition:transform .25s;}
#wgallery_list ul li:hover{transform:translateY(-6px)}
#wgallery_list .thumb {width: 100%;aspect-ratio: 1 / 1;padding: 30px;overflow: hidden;}
#wgallery_list .thumb img {width: 100%;height: 100%;padding: 30px;object-fit: contain;display: block;}
#wgallery_list .info{padding:18px 20px;display:flex;justify-content:space-between;align-items:center}
#wgallery_list .info .left{font-size:15px;color:#757575;font-weight:500}
#wgallery_list .info .right{font-size:18px;font-weight:600;color:#333}
#wgallery_pagination{display:flex;justify-content:center;margin-top:50px;gap:8px}
#wgallery_pagination button{width:40px;height:40px;border:none;border-radius:50%;background:#fff;box-shadow:0 4px 12px rgba(0,0,0,0.08);color:#444;font-size:15px;cursor:pointer;transition:.25s}
#wgallery_pagination button:hover{background:#2ba6ff;color:#fff}
#wgallery_pagination button.active{background:#2ba6ff;color:#fff}
#main_category_nav {display: flex;flex-wrap: wrap;gap: 10px;justify-content:center;margin: 0 0 40px 0;}
#main_category_nav .nav_btn {padding: 10px 18px;background: #f2f4f8;border: 1px solid #d0d6e1;border-radius: 6px;cursor: pointer;font-size: 14px;transition: 0.2s;}
#main_category_nav .nav_btn:hover {background: #316aff;color: #fff;border-color: #316aff;}
#main_category_nav .nav_btn.active {background: #316aff;color: #fff;border-color: #316aff;}
@media (max-width:768px){
#main_category_nav{gap:8px;margin-bottom:30px;}
#main_category_nav .nav_btn{flex:1 1 calc(50% - 8px);padding:12px 0;font-size:15px;}}
@media (max-width:480px){
#main_category_nav .nav_btn{flex:1 1 100%;font-size:16px;}}
/* =========================== wgallery mobile */
@media(max-width:768px){
#wgallery{padding:20px;margin:60px auto}
#wgallery_header h2{font-size:28px}
#wgallery_list ul li{width:100%}
#wgallery_list .thumb{height:200px}
}

.condition_section{margin-bottom:100px}
.section_title{font-size:30px;font-weight:500;color:#111;margin-bottom:60px;line-height:1.25}
.section_title span{display:block;font-size:12px;color:#6f7cff;letter-spacing:3px;font-weight:500;margin-bottom:4px}
.process_timeline{position:relative;padding-left:32px;border-left:1px solid rgba(111,124,255,.25);counter-reset:step}
.process_timeline li{position:relative;padding:0 0 48px 28px;counter-increment:step}
.process_timeline li::before{content:"";position:absolute;left:-7px;top:6px;width:10px;height:10px;background:#6f7cff;border-radius:50%;box-shadow:0 0 0 6px rgba(111,124,255,.12)}
.process_timeline strong{font-size:19px;font-weight:500;color:#222}
.process_timeline strong::before{content:"0" counter(step) ". ";color:#6f7cff;font-weight:500}
.process_timeline p{margin-top:10px;font-size:15px;color:#666;line-height:1.7}
.process_timeline li:hover strong{color:#6f7cff}
.condition_box{background:#fff;padding:48px 50px;border-radius:18px;border:1px solid rgba(111,124,255,.25);box-shadow:0 4px 12px rgba(0,0,0,.03);max-width:900px}
.condition_box ul{margin:0;padding:0;list-style:none}
.condition_box ul li{font-size:15px;color:#444;padding:14px 0;border-bottom:1px dashed rgba(111,124,255,.25)}
.condition_box ul li:last-child{border-bottom:none}

.board_section{max-width:1000px;margin:0 auto}
.section_title{font-size:30px;font-weight:500;color:#111;margin-bottom:50px}
.section_title span{display:block;font-size:12px;color:#6f7cff;letter-spacing:3px;margin-bottom:6px}
.board_table_wrap{border-top:2px solid #111}
.board_table{display:flex;align-items:center;border-bottom:1px solid #eee}
.board_table.head{background:#f9faff;font-weight:500}
.board_table li{padding:18px 10px;font-size:15px;color:#333}
.board_table .col_no{width:80px;text-align:center;color:#777}
.board_table .col_title{flex:1}
.board_table .col_title a{color:#222}
.board_table .col_title a:hover{color:#3a6df0}
.board_table .col_writer{width:120px;text-align:center;color:#666}
.board_table .col_date{width:120px;text-align:center;color:#999}
.board_table .col_hit{width:80px;text-align:center;color:#999}
.board_table:hover:not(.head){background:#f9faff}
.board_table.empty li{width:100%;text-align:center;color:#aaa;padding:40px 0}
.board_search{margin-top:40px;display:flex;justify-content:center;gap:10px}
.board_search select,
.board_search input{height:42px;border:1px solid #ddd;border-radius:6px;padding:0 12px;font-size:14px}
.board_search button{padding:0 22px;border:none;border-radius:6px;background:#3a6df0;color:#fff;font-size:14px}
#support_banner{width:100%;height:260px;margin-top:96px;background:url(/img/main/inc04/inc04_bg.jpg) no-repeat center/cover;position:relative}
#support_banner::after{content:"";position:absolute;inset:0;background:rgba(0,0,0,.35)}
#support_banner #sh_content_tit{position:absolute;left:50%;top:15%;transform:translate(-50%,-50%);color:#fff;text-align:center;z-index:2}
#support_banner h3{font-size:40px;font-weight:500;margin-bottom:10px}
#support_banner p{font-size:14px;color:rgba(255,255,255,.8)}
#support_banner a{color:#fff}


/* =========================== COMMON SUPPORT STYLES */
.support_tit_area { text-align: center; margin: 80px 0 40px; }
.support_tit_area .eng { display: block; font-size: 16px; color: #2ba6ff; font-weight: 800; text-transform: uppercase; letter-spacing: 1px; margin-bottom: 10px; font-family: 'Poppins', sans-serif; }
.support_tit_area .kor { font-size: 42px; color: #111; font-weight: 800; letter-spacing: -1px; margin: 0; }

.support_hero { position: relative; width: 100%; height: 380px; background-size: cover; background-position: center; margin-top: 96px; display: flex; align-items: center; justify-content: center; text-align: center; }
.support_hero_dim { position: absolute; inset: 0; background: rgba(0,0,0,0.45); z-index: 1; }
.support_hero_inner { position: relative; z-index: 2; width: 100%; max-width: 1200px; padding: 0 20px; color: #fff; display: flex; flex-direction: column; align-items: center; }
.support_hero_kicker { font-size: 15px; letter-spacing: 1px; opacity: 0.9; margin-bottom: 10px; font-weight: 500; }
.support_hero_title { font-size: 48px; font-weight: 700; letter-spacing: -1.5px; margin-bottom: 35px; line-height: 1.2; text-shadow: 0 2px 10px rgba(0,0,0,0.2); }

.support_hero_nav { display: flex; flex-wrap: wrap; justify-content: center; gap: 10px; max-width: 720px; } /* max-width 조절로 시안처럼 2줄 유도 */
.support_hero_nav .nav_btn { display: inline-block; padding: 10px 24px; border-radius: 50px; border: 1px solid rgba(255,255,255,0.6); background: rgba(0,0,0,0.1); color: #fff; font-size: 15px; font-weight: 500; text-decoration: none; transition: all 0.3s ease; }
.support_hero_nav .nav_btn:hover { background: rgba(255,255,255,0.2); border-color: #fff; }
.support_hero_nav .nav_btn.active { background: #2ba6ff; border-color: #2ba6ff; color: #fff; font-weight: 700; box-shadow: 0 4px 12px rgba(0, 160, 233, 0.4); }

#support_wrap { max-width: 1200px; margin: 0 auto; padding: 0 20px 100px; }

/* 중분류 탭 버튼 스타일 (ID 선택자로 우선순위 확보) */
#wgallery_category.support_tabs { display: flex; justify-content: center; gap: 12px; margin-bottom: 60px; flex-wrap: wrap; background: none; box-shadow: none; padding: 0; backdrop-filter: none; }
#wgallery_category.support_tabs button { padding: 9px 32px; border-radius: 50px; background: #fff; border: 1px solid #ccc; font-size: 16px; color: #555; font-weight: 500; cursor: pointer; transition: all 0.2s; font-family: 'Noto Sans KR', sans-serif; box-shadow: none; backdrop-filter: none; }
#wgallery_category.support_tabs button:hover { border-color: #888; color: #333; transform: translateY(-2px); box-shadow: 0 4px 10px rgba(0,0,0,0.05); background: #fff; }
#wgallery_category.support_tabs button.active { border-color: #2ba6ff; color: #2ba6ff; background: #fff; font-weight: 700; box-shadow: 0 4px 12px rgba(0, 160, 233, 0.15); }

.support_grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; list-style: none; padding: 0; margin: 0; }
.support_card { background: #fff; border-radius: 16px; overflow: hidden; box-shadow: 0 5px 20px rgba(0,0,0,0.05); transition: transform 0.3s ease, box-shadow 0.3s ease; border: 1px solid #eee; }
.support_card:hover { transform: translateY(-5px); box-shadow: 0 15px 30px rgba(0,0,0,0.1); }
.support_card_link { display: block; text-decoration: none; padding: 25px 20px; height: 100%; display: flex; flex-direction: column; justify-content: space-between; }
.support_thumb { width: 100%; height: 200px; display: flex; align-items: center; justify-content: center; margin-bottom: 20px; }
.support_thumb img { max-width: 90%; max-height: 100%; object-fit: contain; transition: transform 0.3s; }
.support_card:hover .support_thumb img { transform: scale(1.05); }
.support_info { display: flex; justify-content: space-between; align-items: center; border-top: 1px solid #f5f5f5; padding-top: 15px; }
.support_info .left { font-size: 15px; color: #888; font-weight: 500; }
.support_info .right { font-size: 16px; color: #111; font-weight: 700; }

.support_pagination { display: flex; justify-content: center; align-items: center; gap: 20px; margin-top: 80px; }
.support_pagination button { background: none; border: none; font-size: 18px; color: #bbb; font-family: 'Poppins', sans-serif; cursor: pointer; transition: color 0.2s; padding: 5px; }
.support_pagination button:hover { color: #666; }
.support_pagination button.active { color: #111; font-weight: 700; border-bottom: 2px solid #111; }

@media (max-width: 1024px) {
    .support_hero { height: 480px; }
    .support_hero_title { font-size: 40px; margin-bottom: 40px; }
    .support_grid { grid-template-columns: repeat(2, 1fr); gap: 20px; }
    .support_thumb { height: 200px; }
}
@media (max-width: 768px) {
    .support_hero { height: auto; padding: 60px 0; margin-top: 64px; }
    .support_hero_title { font-size: 32px; }
    .support_hero_nav .nav_btn { padding: 10px 20px; font-size: 14px; }
    .support_tit_area .kor { font-size: 28px; }
    .support_grid { grid-template-columns: 1fr; }
}


.support_detail_top{max-width: 980px;margin: 0 auto;padding: 40px 15px 20px;}
.support_detail_nav{display:flex;justify-content:space-between;gap:10px;margin-bottom:22px;}
.support_detail_btn{display:inline-flex;align-items:center;justify-content:center;padding:10px 16px;border-radius:12px;border:1px solid rgba(58,109,240,.25);background:#f8faff;color:#2ba6ff;;font-weight:700;font-size:13px;cursor:pointer;transition:all .2s ease;}
.support_detail_btn:hover{background:#2ba6ff;color:#fff;border-color:#2ba6ff;transform:translateY(-1px);}
.support_detail_title{text-align:center;font-size: 40px;font-weight: 900;margin: 26px 0 36px;color:#1e1e1e;}
.support_detail_img_wrap{background:#fff;border-radius: 18px;border:1px solid rgba(0,0,0,0.06);box-shadow: 0 12px 26px rgba(0,0,0,0.07);padding: 18px;}
.support_detail_img_wrap img{width:100%;height:auto;display:block;object-fit: contain;}

.support_apply_wrap{margin-top:30px;padding: 0px 0px 50px;text-align:center;}
.support_apply_btn{display:inline-block;padding:20px 46px;background:#2ba6ff;color:#fff;font-size:17px;font-weight:700;border-radius:14px;text-decoration:none;box-shadow:0 8px 20px rgba(59,130,246,.35);transition:all .3s ease;}
.support_apply_btn:hover{background:#2563eb;box-shadow:0 12px 30px rgba(59,130,246,.5);}

@media (max-width: 1024px){
.support_hero{ margin-top:64px; }
.support_hero_title{font-size: 30px;}
.support_grid{grid-template-columns: repeat(2, minmax(0, 1fr));}}
@media (max-width: 640px){
.support_hero_inner{padding: 70px 15px 45px;}
.support_hero_title{font-size: 24px;}
.support_grid{grid-template-columns: repeat(1, minmax(0, 1fr));}}
@media(max-width:480px){
.support_main_nav{ padding:12px 10px; border-radius:14px; }
.support_main_nav .nav_btn{ padding:10px 14px; font-size:13px; }}

.board_view{max-width:1000px;margin:0 auto}
.view_title{font-size:26px;font-weight:500;margin-bottom:20px;color:#111}
.view_info{display:flex;gap:20px;font-size:14px;color:#777;border-bottom:1px solid #eee;padding-bottom:15px}
.view_info span{margin-left:5px;color:#333}
.view_content{padding:40px 0;font-size:16px;color:#444;line-height:1.8}
.view_btn{text-align:right}
.view_btn a{display:inline-block;padding:10px 20px;border:1px solid #ddd;border-radius:6px;color:#555}
.view_btn a:hover{border-color:#3a6df0;color:#3a6df0}
/* ===== 게시판 모바일 대응 ===== */
@media all and (max-width: 768px){
	.board_table.head{display:none}.board_table{display:block;padding:18px 10px;}
    .board_table li{display:none;}
    .board_table .col_title{display:block;font-size:16px;font-weight:500;margin-bottom:6px;}
    .board_table .col_title a{color:#222;line-height:1.4;display:block;}
	.board_table .col_date{display:block;font-size:13px;color:#999;}
}
/* 게시글 상세 이미지 */
.view_image{margin:30px 0;text-align:center;}
.view_image img{max-width:100%;height:auto;border-radius:14px;}

@media (max-width:768px){
#support_banner{height:180px;margin-top:64px}
#support_banner #sh_content_tit{top:50%;transform:translate(-50%,-50%)}
#support_banner h3{font-size:26px}
#support_banner p{font-size:13px}
#support_banner{margin-bottom:30px}.section_title{margin-top:20px}
#sh_aside{position:static;margin:0}
#sh_snb{display:flex;justify-content:flex-start;padding:12px 14px;overflow-x:auto;white-space:nowrap;box-shadow:none}
#sh_snb ul{display:flex;gap:8px}
#sh_snb li{height:auto;padding:0}
#sh_snb li a{display:inline-block;padding:10px 16px;font-size:14px;border-radius:999px;background:#f5f6fa}
#sh_snb li a.on{background:#6e62c3;color:#fff}
#sh_content{padding:0 14px}.board_search{flex-wrap:wrap}.board_search select,.board_search input{flex:1;min-width:0}
.board_search button{width:100%;height:38px;font-size:13px}
.board_search{margin-bottom:50px}#sh_footer,#footer,footer{margin-top:40px}
}

.view_content a {
    color: #1e88e5;      /* 원하는 색 */
    font-weight: 600;
    text-decoration: underline;
}

.view_content a:hover {
    color: #b71c1c;
}

/* ==================== 
   Notice (co1, co2, co3) Custom CSS 
   ==================== */

/* [배너 영역] */
#support_banner {
    display: flex;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    text-align: center;
    height: 380px;
    background-size: cover;
    background-position: center;
    position: relative;
    margin-top: 96px;
}
#support_banner::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(0,0,0,0.1);
    z-index: 1;
}
#support_banner .banner_inner {
    position: relative;
    z-index: 10;
    color: #fff;
    width: 100%;
    max-width: 1200px;
    padding: 0 20px;
}
#support_banner .sub_tit {
    font-size: 16px;
    margin-bottom: 10px;
    opacity: 0.9;
    letter-spacing: 1px;
}
#support_banner h3 {
    font-size: 50px;
    font-weight: 700;
    margin-bottom: 50px;
    letter-spacing: -1px;
}
.banner_tabs {
    display: flex;
    justify-content: center;
    gap: 12px;
}
.banner_tabs a {
    display: block;
    min-width: 160px;
    padding: 14px 0;
    border-radius: 50px;
    border: 1px solid rgba(255,255,255,0.6);
    color: #fff;
    font-size: 16px;
    font-weight: 500;
    text-align: center;
    transition: all 0.3s ease;
    background: transparent;
}
.banner_tabs a:hover {
    background: rgba(255,255,255,0.1);
    border-color: #fff;
}
.banner_tabs a.active {
    background: #2ba6ff;
    border-color: #2ba6ff;
    color: #fff;
    font-weight: 700;
    box-shadow: 0 5px 15px rgba(0,170,255,0.4);
}

/* [컨텐츠 공통] */
#sh_content {
    width: 100%;
    max-width: 1200px;
    margin: 80px auto 100px;
    padding: 0 20px;
}

.notice_header_area {
    display: flex;
    justify-content: space-between;
    align-items: center;
    border-bottom: 2px solid #222;
    padding-bottom: 25px;
    margin-bottom: 0;
}
.notice_header_area h2 {
    font-size: 36px;
    font-weight: 800;
    color: #111;
    letter-spacing: -1px;
}

.custom_search {
    display: flex;
    align-items: center;
    border: 1px solid #ddd;
    border-radius: 50px;
    padding: 4px;
    width: 480px;
    height: 50px;
    background: #fff;
    overflow: hidden; /* 넘침 방지 */
}
.custom_search select {
    border: none;
    padding: 0 10px 0 20px;
    height: 100%;
    font-size: 15px;
    color: #333;
    outline: none;
    background: transparent;
    cursor: pointer;
    font-weight: 500;
    width: 100px; /* 고정 너비 수정 */
    flex-shrink: 0; /* 너비 보존 */
}
.custom_search input {
    flex: 1;
    border: none;
    border-left: 1px solid #eee;
    height: 70%;
    padding: 0 15px;
    outline: none;
    font-size: 15px;
    color: #333;
}
.custom_search button {
    background: #2ba6ff;
    color: #fff;
    border: none;
    padding: 0 30px;
    height: 100%;
    border-radius: 50px;
    font-weight: 600;
    font-size: 16px;
    cursor: pointer;
    white-space: nowrap;
    min-width: 100px;
}

/* [아코디언 공통] */
.notice_accordion { border-bottom: 1px solid #ddd; }
.notice_item { border-bottom: 1px solid #eee; background: #fff; transition: all 0.3s; }
.notice_head { display: flex; justify-content: space-between; align-items: center; padding: 25px 20px; cursor: pointer; }
.notice_head .title { font-size: 17px; font-weight: 500; color: #333; flex: 1; padding-right: 20px; }
.notice_head .info { display: flex; align-items: center; gap: 30px; font-size: 15px; color: #bbb; font-family: 'Poppins'; }
.notice_head .info i { transition: transform 0.3s; font-size: 18px; color: #ccc; }
.notice_item.active { background-color: #eaf7ff; }
.notice_item.active .notice_head .info i { transform: rotate(180deg); color: #2ba6ff; }
.notice_body { display: none; padding: 10px 40px 40px; background-color: #eaf7ff; font-size: 15px; color: #444; line-height: 1.8; }
.notice_item.active .notice_body { display: block; animation: fadeIn 0.3s ease-in-out; }

/* [co2 게시판 리스트] */
.board_list_wrap { border-top: 1px solid #ddd; border-bottom: 1px solid #ddd; } /* co1과 비슷하게 변경 */
.board_head, .board_row { display: flex; align-items: center; padding: 25px 20px; text-align: center; font-size: 16px; color: #333; } /* 패딩, 폰트사이즈 통일 */
.board_head { background: #fff; font-weight: 700; color: #111; border-bottom: 1px solid #eee; } /* 배경 흰색으로 변경 */
.board_row { border-bottom: 1px solid #eee; transition: background 0.2s; }
.board_row:hover { background: #fcfcfc; }
.board_list_wrap .col_no { width: 100px; color: #333; font-weight: 500; font-family: 'Poppins'; } /* 색상 통일 */
.board_list_wrap .col_title { flex: 1; text-align: left; padding-left: 20px; font-weight: 500; }
.board_list_wrap .col_writer { width: 120px; color: #555; }
.board_list_wrap .col_date { width: 120px; color: #bbb; font-family: 'Poppins'; }
.board_list_wrap .col_title a { display: block; width: 100%; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; color: #333; }
.board_list_wrap .col_title a:hover { color: #00aaff; text-decoration: underline; }

/* [co2 상세 페이지] */
.view_top_nav { display: flex; justify-content: flex-end; gap: 10px; margin-bottom: 20px; }
.view_top_nav a { padding: 8px 20px; border: 1px solid #ddd; border-radius: 4px; font-size: 14px; color: #666; background: #fff; }
.view_top_nav a:hover { background: #f5f5f5; }

.co2_view_header { border-top: 2px solid #222; border-bottom: 1px solid #eee; padding: 30px 20px; display: flex; justify-content: space-between; align-items: center; }
.co2_view_header .title_area { display: flex; align-items: center; gap: 20px; }
.co2_view_header .no { color: #00aaff; font-size: 18px; font-weight: 700; font-family: 'Poppins'; }
.co2_view_header h3 { font-size: 22px; font-weight: 700; color: #111; }
.co2_view_header .info_area { display: flex; gap: 30px; font-size: 15px; color: #888; }
.co2_view_header .info_area span b { color: #333; font-weight: 500; margin-right: 5px; }

.co2_view_content { padding: 50px 20px; text-align: center; border-bottom: 1px solid #eee; }
.co2_view_content img { max-width: 100%; height: auto; margin-bottom: 40px; border-radius: 8px; box-shadow: 0 5px 25px rgba(0,0,0,0.1); }
.co2_view_content .text { font-size: 17px; color: #444; line-height: 1.8; text-align: left; }

/* [댓글 영역] */
.comment_section { margin-top: 60px; }
.comment_count { font-size: 18px; font-weight: 700; color: #111; margin-bottom: 20px; }
.comment_list { border-top: 1px solid #eee; }
.comment_item { padding: 25px 0; border-bottom: 1px solid #f5f5f5; }
.comment_item .comment_info { display: flex; justify-content: space-between; margin-bottom: 10px; }
.comment_item .writer { font-weight: 700; color: #333; font-size: 15px; }
.comment_item .date { font-size: 13px; color: #bbb; font-family: 'Poppins'; }
.comment_item .text { font-size: 15px; color: #666; line-height: 1.6; margin-bottom: 10px; }
.comment_item .btn_reply { font-size: 13px; color: #aaa; cursor: pointer; }

/* 대댓글 스타일 */
.comment_item.reply { padding-left: 40px; background: #fafafa; border-radius: 8px; margin-top: 5px; }

.comment_form { margin-top: 40px; background: #f9f9f9; padding: 30px; border-radius: 12px; border: 1px solid #eee; }
.comment_form .form_top { display: flex; gap: 10px; margin-bottom: 15px; }
.comment_form input { height: 40px; border: 1px solid #ddd; border-radius: 4px; padding: 0 12px; font-size: 14px; }
.comment_form textarea { width: 100%; height: 100px; border: 1px solid #ddd; border-radius: 4px; padding: 15px; font-size: 14px; resize: none; outline: none; }
.comment_form .form_bottom { display: flex; justify-content: flex-end; margin-top: 15px; }
.comment_form .btn_submit { background: #333; color: #fff; border: none; padding: 12px 40px; border-radius: 4px; font-weight: 600; cursor: pointer; transition: background 0.2s; }
.comment_form .btn_submit:hover { background: #000; }

/* 페이징 */
.pagination { display: flex; justify-content: center; gap: 20px; margin-top: 60px; font-size: 18px; color: #bbb; font-family: 'Poppins'; }
.pagination span { cursor: pointer; }

@keyframes fadeIn { from { opacity: 0; transform: translateY(-5px); } to { opacity: 1; transform: translateY(0); } }

/* ==================================
   [Mobile Responsive] max-width: 768px
   ================================== */
@media screen and (max-width: 768px) {
    /* [배너] */
    #support_banner { height: 260px; margin-top: 60px; }
    #support_banner h3 { font-size: 32px; margin-bottom: 25px; }
    #support_banner .sub_tit { font-size: 14px; }
    .banner_tabs { gap: 8px; flex-wrap: wrap; }
    .banner_tabs a { min-width: 30%; padding: 10px 0; font-size: 13px; }

    /* [컨텐츠 레이아웃] */
    #sh_content { margin: 40px auto; padding: 0 15px; }
    
    /* [헤더 & 검색] */
    .notice_header_area { flex-direction: column; align-items: flex-start; gap: 15px; padding-bottom: 20px; }
    .notice_header_area h2 { font-size: 26px; }
    .custom_search { width: 100%; height: 45px; }
    .custom_search select { width: 80px; font-size: 13px; padding-left: 10px; }
    .custom_search button { padding: 0 20px; font-size: 14px; min-width: 70px; }

    /* [아코디언 - co1, co3] */
    .notice_head { padding: 15px 10px; }
    .notice_head .title { font-size: 15px; line-height: 1.4; padding-right: 10px; }
    .notice_head .info { gap: 10px; font-size: 12px; }
    .notice_body { padding: 15px 20px 25px; font-size: 14px; }

    /* [co2 게시판 리스트] - 카드형 변환 */
    .board_head { display: none; }
    .board_row { flex-wrap: wrap; padding: 15px 10px; position: relative; }
    .board_list_wrap .col_no { display: none; } /* 모바일에서 번호 숨김 */
    .board_list_wrap .col_title { flex: none; width: 100%; padding-left: 0; margin-bottom: 8px; font-size: 16px; font-weight: 600; }
    .board_list_wrap .col_title a { white-space: normal; line-height: 1.4; overflow: visible; }
    .board_list_wrap .col_writer { width: auto; font-size: 13px; margin-right: 10px; color: #888; text-align: left; }
    .board_list_wrap .col_date { width: auto; font-size: 13px; color: #bbb; text-align: left; }
    .board_list_wrap .col_writer::after { content: '|'; margin-left: 10px; color: #ddd; }

    /* [co2 상세 페이지] */
    .view_top_nav { justify-content: space-between; }
    .view_top_nav a { padding: 8px 12px; font-size: 12px; }
    
    .co2_view_header { padding: 20px 10px; flex-direction: column; align-items: flex-start; gap: 10px; }
    .co2_view_header .title_area { gap: 10px; width: 100%; }
    .co2_view_header h3 { font-size: 18px; line-height: 1.4; }
    .co2_view_header .info_area { width: 100%; justify-content: space-between; gap: 0; font-size: 13px; }
    
    .co2_view_content { padding: 30px 10px; }
    .co2_view_content .text { font-size: 15px; }

    /* [댓글] */
    .comment_form { padding: 20px 15px; }
    .comment_form .form_top { flex-direction: column; }
    .comment_form input { width: 100% !important; }
}