
/* s:딤레이어 */
.eventStatus {
    position:absolute;
    top:10px;
    left:10px;
    background-color:#000;
    width:fit-content;
    font-size:18px;
    font-weight:400;
    color:#fff;
    padding:5px 20px;
    border-radius:30px;
    z-index:9;
    box-shadow:0px 0px 10px rgba(255,255,255,0.1);
}
.eventStatus01 {
    background-color:var(--color02);
}
.eventStatus02 {
    background-color:#333;
}
body.active {
    overflow:hidden;
}
.dim {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.7); /* 불투명 블랙 */
    display:none;
    justify-content: center;
    align-items: center;
    z-index:99999;
}
.dim.active {
    display: flex;
}
.dim-container {
    position: relative;
    width: 780px;
}
.dim-container500 {
    width:500px;
}
.dim-header {
    background: #444;
    padding: 18px 40px;
    border-top-left-radius:20px;
    border-top-right-radius:20px;
}
.dim-title {
    color: #fff;
    font-size: 20px;
    font-weight: 500;
}
.dim-content {
    background-color:#fff;
    border-bottom-left-radius:20px;
    border-bottom-right-radius:20px;    
    overflow:hidden;
}
.dim-inner {
    width:100%;
    padding:30px 40px 40px 40px;
}
#mainPop .dim-content {
    border-radius:20px;
}
#mainPop .dim-inner {
    padding:35px 40px;
    max-height:calc(100vh - 200px);
    overflow-y:auto;
}
.dim-inner02 {
    width:100%;    
    padding:15px;
    max-height:calc(100vh - 250px);
    overflow-y:auto;
}
.dimCompany .dim-inner{
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
}
.dim-desc {
    text-align: center;
    font-size: 18px;
    margin-bottom: 30px;
    line-height: 1.4;
    word-break:keep-all;
}
.dim-desc .highlight {
    color: #0047A3;
    font-weight: 500;
}
.list-container {
    width:100%;
    border: 1px solid #E2E2E2;
    border-radius: 10px;
    overflow: hidden;
    margin-top:30px;
}
.list-header {
    background: #F8FBFF;
    padding:12px 0;
    text-align: center;
    font-size:18px;
    font-weight: 500;
    color:#000;
    line-height:1.3;
    border-bottom: 1px solid #E2E2E2;
}
.list-body {
    max-height: 33vh;
    overflow-y: auto;
}
.list-body li button {
    width: 100%;
    text-align: left;
    padding:7px 20px;
    border: none;
    background: none;
    border-bottom: 1px solid #F1F1F1;
    font-size: 18px;
    cursor: pointer;
}
.list-body li button:hover {
    background: #f9f9f9;
}
.list-body .empty p {
    font-size:16px;
    font-weight:400;
    color:#000;
    text-align:center;
    padding:40px 0;
}
.btn-close {
    width: 48px;
    height: 48px;
    background:#000;
    border: none;
    cursor: pointer;
    border-radius:50%;
    background-image:url('../../_images/sub/dim_close.png');
    background-size: 16px;
    background-position:50% 50%;
    background-repeat:no-repeat;
    display:block;
    margin:20px auto 0 auto;
}
.btn-close:hover {
    background-color:var(--hover);
}
.couponDown {
    width: 100%;
    height: 65px;
    background:#0047A3;
    color: #FFF;
    text-align: center;
    font-size: 20px;
    font-weight: 700;
    display:flex;
    flex-direction:row;
    align-items:center;
    justify-content:center;
    gap:10px;
}
.couponDown:hover {
    background-color:var(--hover);
}

/* 팝업 컨테이너 상세 수치 */
.coupon-container {
    width: 780px;
    background: #FFF;
}

.coupon-card {
    border: 10px solid #88D9FF; 
    padding:30px 45px; 
    text-align: center;
    position: relative;
}

/* 상단 타이틀 스타일 */
.coupon-main-title {
    color: #0047A3;
    font-size: 26px;
    font-weight: 600;
    line-height: normal;
    margin-bottom:3px;
    letter-spacing:-0.6px;
    word-break:keep-all;
}
.coupon-sub-title {
    color: #1D1D1D;
    font-size: 20px;
    font-weight: 500;
    line-height: 1.4;
    margin-bottom: 50px;
}
.brand-area {
    width:100%;
    position:relative;
    display: flex;
    justify-content: center;
    align-items: center;
    justify-content:space-between;
    gap: 20px;
    margin-bottom: 30px;
    padding:10px 20px;
    border-top: 1px dotted #DDD;
    border-bottom: 1px dotted #DDD;
}
.brand-area .brand-name {
    max-width:45%;
    word-break:keep-all;
}
.brand-area .topLogo {
    height:90px;
    position:absolute;
    top:-45px;
    left:50%; transform:translateX(-50%);
}
.brand-name {
    font-size: 24px;
    font-weight: 700;
}

/* 쿠폰 상세 리스트 (dt, dd) */
.coupon-info-list {
    text-align: left;
    max-width: 560px;
    margin: 0 auto;
}

.info-item {
    display: flex;
    flex-direction:row;
    align-items:center;
    margin-bottom:3px;
}
.info-item dt {
    width: 70px; 
    height: 30px;
    background: #003C6B;
    color: #FFF;
    font-size: 18px;
    font-weight: 400;
    display: flex;
    align-items: center;
    justify-content: center;
    border-radius: 100px;
    flex-shrink: 0;
    margin-right: 15px;
}

.info-item dd {
    font-size: 18px;
    line-height: 30px;
    color: #000;
    font-weight: 500;
}

/* 하단 추가 문구 영역 */
.additional-txt {
    margin-top: 20px;
    padding-top: 20px;
    border-top:2px dotted #DDD;
    font-size: 18px;
    color: #000;
    line-height: 1.2;
    text-align:left;
}

/* 푸터 인쇄 버튼 */
.dim-footer {
    background: #0047A3;
    height: 64px;
    display: flex;
    align-items: center;
    justify-content: center;
}

.btn-print {
    background: transparent;
    border: none;
    color: #FFF;
    font-size: 20px;
    font-weight: 700;
    display: flex;
    align-items: center;
    gap: 10px;
    cursor: pointer;
}
/* e:딤레이어 */

.board .sec .inner {
    max-width:1400px; margin:0 auto;
    padding:55px 0 100px 0;
}
.board-search {
    width: 100%;
    background: #F9F9F9;
    position:relative;
}
.board-search .inner {
    padding:60px 0;
}
.detail-search-area {
    display:flex;
    flex-direction:column;
}
.board-search .search-item {
    display:flex;
    flex-direction:row;
    align-items:flex-start;
    margin-bottom:30px;    
}
.board-search .search-item .lfTit {
    width:190px;
    color:#1D1D1D;
    font-size: 20px;
    font-style: normal;
    font-weight: 500;
    line-height:1.3;
    padding-left: 30px;   
    position:relative;
}
.board-search .search-item .lfTit::before {
    content: '';
    width: 5px;
    height: 5px;
    border-radius: 50%;
    background-color: #000;
    margin: 0 15px;
    position: absolute;
    top: 10px;
    left: 0;
}
.board-search .search-item .type-list .icon {
    display:flex;
    flex-direction:column;
    justify-content:end;
    align-items:center;
    height:90px;
}
.board-search .search-item .type-list .icon img {
    max-width:initial;
}
.board-search .search-item .type-list .icon01 img {
    width:74px;
}
.board-search .search-item .type-list .icon02 img {
    width:64px;
}
.board-search .search-item .type-list .icon03 img {
    width:72px;
}
.board-search .search-item .type-list .icon04 img {
    width:76px;
}
.board-search .search-item .type-list {
    gap:10px;
    display:flex;
    flex-direction:row;
}
.board-search .search-item .type-list li {
    width: 160px;
    border-radius: 8px;
    border: 1px solid #E2E2E2;
    background: #FFF;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    overflow:hidden;
}
.board-search .search-item .type-list li button {
    width:100%;
    height:100%;
    padding:10px 0 20px 0;    
}
.board-search .search-item .type-list li.active button {
    background-color:var(--hover02);
}
.board-search .search-item .type-list li.active button p,
.board-search .search-item .type-list li.active button span {
    color:#fff;
}
.board-search .search-item .type-list p {
    margin-top:10px;
    color: #000;
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
    line-height: 1.2;
    text-align:center;
}
.board-search .search-item .type-list p span {
    display:block;
    color:#0047A3;
    font-size: 16px;
    font-weight: 400;
}
.board-search .search-item .rtBox {
    width:calc(100% - 190px);
    position:relative;
}
.board .search-box {
    position: relative;
    max-width: 900px;
    height: 60px;
    background-color: #003C6B;
    border:1px solid transparent;
    border-radius: 60px; 
    display: flex;
    align-items: center;
    overflow: hidden;
    width:calc(100% - 40px);
}
.board .search-box:focus-within {
    background-color:#fff;
    border:1px solid #006CFF;
    outline:none !important;
    color:#006CFF;    
}
.board .search-box input:focus {
    color:#006CFF;
}
.board .search-box input::placeholder {
    color: var(--textColor01);
}
.board .search-box .btn-search .search-text {
    font-size: 20px;
    font-family: var(--font-main);
    color: var(--textColor02);
    font-weight: 500;
}
.board .search-box .btn-search .search-icon {
    width: 27px;
    display: flex;
    align-items: center;
}
.board .search-box .btn-search .search-icon img {
    width:100%;
}
.board .search-box input {
    flex: 1;
    border: none;
    outline: none;
    height: 100%;
    padding: 0 30px; /* 텍스트 내부 여백 */
    font-size: 22px;
    font-weight:300;
    font-family: var(--font-main);
    background-color:transparent;
    color:#fff;
}
.board .search-box input::placeholder {
    color:#fff;
}
.board .search-box02 {
    border: 1px solid #E2E2E2;
    background-color:#fff;
    width:530px;
}
.board .search-box02 input,
.board .search-box02 input::placeholder {
    color:#666;
    font-size: 18px;
    font-style: normal;
    font-weight: 300;
}
.board .search-box .btn-search {
    width: 105px;
    height: calc(100% - 8px);
    background-color: var(--color01);
    border: none;
    cursor: pointer;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    border-radius:30px;
    overflow:hidden;
    margin-right:4px;
}
.board .search-box02 .btn-search {
    gap:5px;
}
.board .search-box02 .btn-search {
    background-color:#003C6B;
}
.board .search-box02 .btn-search .search-text {
    font-size:18px;
    font-weight:400;
}
.board .search-box02 .btn-search .search-icon {width:20px;}
.board .search-box02 .btn-search:hover {
    background-color:#333;
}
/* 상세검색 토글 버튼 */
.btn-detail-toggle {
    position: absolute; right: 0; bottom: 0; 
    display: flex;
    width: 250px;
    padding: 20px 30px;
    justify-content: flex-end;
    align-items: center;
    gap: 10px;
    border-radius: 140px 0 0 0;
    background:#0047A3;  
    color:#fff;
    font-size: 24px;
    font-weight: 500;
    gap:10px;
}
.btn-detail-toggle img {width:30px;}
.btn-detail-toggle.on img { transform: rotate(180deg); }

/* 필터 리스트 스타일 */
.search-detail-view {display:none;}
.filter-list { display: flex; flex-wrap: wrap; gap: 10px; } /* 박스간격 10px */
.filter-list .swiper-slide {width:auto;}
.filter-list01 {max-width:1130px;}
.filter-list02 {max-width:1340px;}
.filter-list03 {width:100%; display:flex; flex-direction:row; align-items:center; justify-content:center;}
.filter-list03 li button {display:flex; flex-direction:column; justify-content:center; align-items:center;}
.filter-list03 li img {margin-bottom:5px;}
.filter-list li button { 
    border-radius: 8px; border: 1px solid #E2E2E2; background: #FFF; 
    padding: 10px 0; text-align: center;
    font-size: 18px; font-weight: 500; color: #000; line-height:1.3;
    transition: 0.2s;
    min-width:120px; min-height:65px;
}
.filter-list03 li.active img {
    filter: brightness(0) invert(1);
}
.filter-list02 li button {
    min-width:140px; min-height:85px;
}
.filter-list li button span { font-size: 16px; font-weight: 400; color: #0047A3; display: block; } /* 레귤러 16px */

.filter-list li.active button { background: #0047A3; border-color: #0047A3; color: #fff; }
.filter-list li.active button span { color: #fff; }

@media screen and (min-width:1200px) {
    .filter-list03 li:hover img {
        filter: brightness(0) invert(1);
    }    
    .filter-list li:hover button { background: #0047A3; border-color: #0047A3; color: #fff; }
    .filter-list li:hover button span { color: #fff; }
    .board-search .search-item .type-list li button:hover {
        background-color:var(--hover02);
    }
    .board-search .search-item .type-list li button:hover p,
    .board-search .search-item .type-list li button:hover span {
        color:#fff;
    }    
}


.pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap:5px;
  margin-top:60px;
  width:100%;
}
.pagination .page-btn {
  width: 36px;
  height: 36px;
  background-color:#003C6B;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  text-decoration: none;
}
.pagination .page-btn:hover {
  background-color: var(--hover);
}
.pagination .page-btn i, 
.pagination .page-btn img {
  width: 18px;  /* 이미지 크기 여기서 조절 */
  height: 18px;
  object-fit: contain;
}
.pagination .page-numbers {
  display: flex;
  gap: 20px;
  margin: 0 35px;
  max-width:calc(100% - 160px);
  flex-wrap:wrap;
  justify-content:center;
  align-items:center;
}
.pagination .num {
  color: #666666;
  font-size: 18px;
  font-weight: 300;
  line-height: 140%;
  text-decoration: none;
  transition: color 0.2s ease;
  position:relative
}
.pagination .num::after {
    display:none;
    content:'';
    width:100%;
    height:1px;
    position:absolute;
    bottom:-5px;
    left:0;
    background-color:#000;
}
.pagination .num:hover {
    color:#1D1D1D;   
    font-weight:400;
}
.pagination .num:hover::after {
    display:block;
}
.pagination .num.active {
  color: #0047A3;
  font-weight: 700;
  letter-spacing: -1px;
}
/* 공통 설정 */
.boardListContainer {
  width: 100%;
  font-family: 'Pretendard', sans-serif;
}

/* 상단 타이틀 스타일 */
.boardListTopTitle {
  display: flex;
  justify-content: center;
  align-items: center;
  align-self: stretch;
  background-color: #F0F9FF; /* 이미지 기반 연한 하늘색 배경 추가 */
  border-top: 1px solid #D1E1F0;
  border-bottom: 1px solid #D1E1F0;
  list-style: none;
  margin: 0;
}

.boardListTopTitle li {
  color: #000;
  text-align: center;
  font-size: 18px;
  font-weight: 500;
  padding:10px 0;
}
.boardListTopTitle li:not(:last-child) {
    border-right: 1px solid #D1E1F0;
}
/* 리스트 본문 스타일 */
.boardList {
  list-style: none;
  padding: 0;
  margin: 0;
}

.boardList li {
  display: flex;
  padding: 10px 0;
  align-items: center;
  align-self: stretch;
  border-bottom: 1px solid #EEE;
  min-height: 60px;
}
.boardList02 li a {
  display: flex;
  padding: 10px 12px;
  align-items: center; /* 이미지 가이드에 맞춰 세로 중앙 정렬 */
  gap: 8px;
  align-self: stretch;
  min-height: 60px;
  border-bottom: 1px solid #EEE;  
}
/* 컬럼별 너비 설정 (유연하게 조정하세요) */
.col-name { flex: 2; }
.col-type { flex: 2; }
.col-address { flex: 2; }
.col-status { 
  flex:1; 
  display: flex; 
  flex-direction:row;
  align-items:center;
  justify-content:center;
  gap: 8px; 
  word-break:keep-all;
}
.col-status li {
    display:flex;
    flex-direction:row;
    align-items:center;
    gap:10px;
}
.col-status01 {
    justify-content: flex-end; 
    margin-bottom:15px;
}
.col-status li:not(:last-child) {
    margin-right:10px;
}
.col-status li p {
    color: #666;
    font-size: 16px;
    font-weight: 300;
}
.col-1 {width:120px; text-align:center;}
.col-2 { flex:1; }
.boardList li p {
    color: #444;
    font-size: 16px;  
    font-weight: 300;
    line-height:1.3;
}
.boardList li .col-date span,
.boardList li .col-hit span{
    display:none;
}
.boardList li .category {
    display:block;
    width: 65px;
    height: 30px;
    line-height:30px;
    border-radius: 100px;
    background:#003C6B;
    color: #FFF;
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;  
    margin:0 auto;
}
.boardList li p.type01 {
    color:#000;
}
.boardList li p.type02 {

}
.boardList li .subject {
    color:#333;
    font-weight:400;    
    white-space: nowrap;      /* 1. 줄바꿈 금지 (한 줄로 나오게) */
    overflow: hidden;         /* 2. 넘치는 텍스트 숨김 */
    text-overflow: ellipsis;  /* 3. 끝부분을 ... 으로 처리 */
    padding:0 10px;
}
.boardList li .subject:hover {
    color:var(--color02);
}
/* 아이콘 박스 공통 스타일 */
.icon-box {
  width: 30px;
  height: 30px;
  aspect-ratio: 1/1;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

/* 아이콘별 배경색 및 텍스트 제어 */
.icon-box.icon01 { background-color: #C0F0FF; }
.icon-box.icon01 img {width:66%;}

.icon-box.icon02 { background-color: #FFED97; }
.icon-box.icon02 img {width:68%;}

.icon-box.icon03 { background-color: #A9FFEE; }
.icon-box.icon03 img {width:62%;}

/* 갤러리형 */
.boardtabTopWrap {
    background: #F9F9F9;
}
.boardTabBtn {
    display:flex;
    flex-direction:row;
    align-items:center;
    justify-content:center;
    gap:20px;
    margin-bottom:30px;
}
.boardTabBtn li button {
    display: flex;
    width: 200px;
    height: 60px;
    padding: 18px 65px;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 100px;
    background:#666;    
    color: #FFF;
    text-align: center;
    font-size: 20px;
    font-style: normal;
    font-weight: 400; 
}
.boardTabBtn li.active button {
    background-color:#1D1D1D;
}   
.boardTabBox .boardBox {
    display: none;
    flex-direction:column;
    justify-content:center;
    align-items:center;
}
.boardTabBox .boardBox.active {
    display: flex;
}
.boardTabBox .boardBox .list-head .count {
    margin-bottom:20px;
}
.boardTabBox02 .boardBox {
    display:flex;
}
.boardTabBox02 .boardBox ul,
.boardTabBox02 .boardBox ul li,
.popularityBox,
.popularityBox li {
    width:100%;
}
.boardTabBox02 .boardBox ul,
.popularityBox {
    display:flex;
    flex-direction:column;
    gap:30px;
}
.popularityBox {
    margin-bottom:80px;
}
#LIST_AREA {
    width:100%;
}
.couponBox {
    width:100%;
    border-radius: 20px;
    border: 1px solid var(--1px, #E2E2E2);
    background: #FFF;
    box-shadow: 0 0 25px 0 rgba(0, 0, 0, 0.10);
    overflow:hidden;
    padding:35px 25px;
    display:flex;
    flex-direction:row;
    align-items:center;
    box-sizing:border-box;
}

.couponBox .lfTextBox {
    width:calc(100% - 260px);
    margin-right:30px;
    display:flex;
    flex-direction:row;
    align-items:center;    
}
.couponBox .lfTextBox .imgBox {
    width:360px;
    height:180px;
    display:flex;
    flex-direction:column;
    justify-content:center;
    align-items:center;
    overflow:hidden;
}
.couponBox .lfTextBox .imgBox img {
    max-width:100%;
    max-height:100%;
}
.downBox {
    width: 260px;
    border-radius: 20px;
    background: #F5F5F5;
    padding:75px 35px 35px 35px;
    position:relative;
    border:1px solid transparent;
    box-sizing:border-box;
}
.downBox img {
    width:48px;
    position:absolute;
    top:25px;
    right:25px;
}
.downBox img.on {
    display:none;
}
.boardTabBox02 .boardBox ul li.active .couponBox img.off,
.couponBox:hover .downBox img.off {
    display:none;
}
.boardTabBox02 .boardBox ul li.active .couponBox img.on,
.couponBox:hover .downBox img.on {
    display:block;
}
.downBox p {
    color: #333;
    font-size: 20px;
    font-weight: 700;
    line-height:1.4;
    word-break:keep-all;
    text-align:left;
}
.downBox p span {
    display:block;
    font-weight:400;
}
.coupon-info {
    padding-left:40px;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap:20px;
}
.coupon-info .info-row {
    display: flex;
    align-items: flex-start;
}
.coupon-info .info-row .label {
    width: 80px;
    flex-shrink: 0;
    color:#1D1D1D;
    font-size: 20px;
    font-weight: 500;
    line-height: 140%;
    margin-left:40px;
    position:relative;
}
.coupon-info .info-row .label::before {
    content:'';
    width:5px;
    height:5px;
    border-radius:50%;
    background-color:#000;
    position:absolute;
    left:-20px;
    top:50%;
    transform:translateY(-50%);
}
.coupon-info .info-row .desc {
    color:#333;
    font-size: 18px;
    font-weight: 300;
    line-height:1.5;
    word-break:keep-all;
    padding-left:30px;
    position:relative;
    text-align:left;
}
.coupon-info .info-row .desc::before {
    content:'';
    width:1px;
    height:100%;
    background: #E2E2E2;
    position:absolute;
    top:0;
    left:0;
}
.boardTabBox02 .boardBox ul li.active .couponBox {
   border: 1px solid #49B0FF;
}
.boardBox ul:not(.popularityBox) .couponBox:hover,
.boardBox ul:not(.popularityBox) .couponBox:focus {
    border:1px solid #49B0FF;
    outline:none !important;
}
.boardTabBox02 .boardBox ul li.active .couponBox .downBox,
.boardBox ul:not(.popularityBox) .couponBox:hover .downBox,
.boardBox ul:not(.popularityBox) .couponBox:focus .downBox {
    background-color:#F3FBFF;;
    border: 1px solid #88D9FF;  
    outline:none !important;
}
.boardTabBox02 .boardBox ul li.active .couponBox .downBox p,
.boardBox ul:not(.popularityBox) .couponBox:hover .downBox p {
    color:#0047A3;
}
.popularityBox .couponBox {
    border:2px solid #F3FBFF;
}
.popularityBox li .couponBox:hover,
.popularityBox li .couponBox:focus {
    border:2px solid #0092CD;
    outline:none !important;
}
.popularityBox .downBox {
    background-color:#003C6B;
}
.popularityBox .downBox p,
.popularityBox .downBox p span {
    color:#fff;
}
.pageNum {
    width:100%;
    color: #000;
    font-size: 18px;
    font-style: normal;
    font-weight: 400;
    line-height:1.3;
    text-align:left;
    margin-bottom:25px;
}
.noResult {
    padding:150px 0 100px 0;
    text-align:center;
    font-size:25px;
    font-style: normal;
    font-weight: 400;
    color:#000;    
}
/* 셀렉트 */
.custom-select-wrapper {
    position: relative;
    width: 180px;
    font-family: 'Pretendard', sans-serif;
}

/* 버튼 스타일 (기본 버튼 스타일 제거 및 커스텀) */
.select-trigger {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    height: 60px;
    padding: 0 24px;
    
    background: #FFFFFF;
    border: 1px solid #E2E2E2;
    border-radius: 100px;
    
    font-size: 18px;
    font-weight: 300;
    color: #1D1D1D;
    line-height: 140%;
    cursor: pointer;
    transition: all 0.2s ease;
    
    /* 버튼 기본 스타일 초기화 */
    appearance: none;
    -webkit-appearance: none;
    text-align: left;
    position:relative;
}

/* [접근성] 키보드 포커스 시 시각적 표시 (검은 테두리) */
.select-trigger:focus-visible {
    outline: 2px solid #1D1D1D;
    outline-offset: 2px;
}
.select-trigger::after {
    content:'';
    background-image:url(../../_images/sub/select_custom_search_arrow.png);
    background-size:cover;
    background-repeat:no-repeat;
    background-position:center;
    width:24px;
    height:24px;
    position:absolute;
    right:25px;
    top:50%;
    transform:translateY(-50%);
}
.mainTabBox .select-trigger {
    background-color: #0047A3;
    color:#fff;
    font-size:17px;
    letter-spacing:-0.8px;
}
.mainTabBox .select-trigger::after {
    background-image: url(../../_images/main/select_arrow_icon.png);
    top: 50%;
    right: 25px;
    transform: translateY(-50%);
    width: 15px;
    height: 8px;    
}
.custom-select-wrapper.active .select-trigger::after {
    transform:translateY(-50%) rotate(-180deg);
    margin-bottom: -2px;
}
.select-options {
    position: absolute;
    top: 68px;
    left: 0;
    width: 100%;
    background: #FFF;
    border: 1px solid #E2E2E2;
    border-radius: 12px;
    box-shadow: 0 4px 12px rgba(0,0,0,0.05);
    padding: 8px 0;
    list-style: none;
    margin: 0;
    
    opacity: 0;
    visibility: hidden;
    transform: translateY(-10px);
    transition: all 0.2s ease;
    z-index: 10;
}

.select-options li {
    padding: 12px 24px;
    font-size: 16px;
    color: #1D1D1D;
    cursor: pointer;
    font-weight: 300;
    outline: none; /* 리스트 내부 포커스 스타일은 배경색으로 대체 */
}

/* 마우스 호버 또는 키보드 포커스 시 배경색 변경 */
.select-options li:hover,
.select-options li:focus {
    background-color: #F5F5F5;
}

/* 활성화 상태 */
.custom-select-wrapper.active .select-trigger {
    border-color: #1D1D1D;
}
.custom-select-wrapper.active .select-options {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
}
.listSearch {
    display:flex;
    flex-direction:row;
    align-items:center;
    justify-content:center;
    gap:10px;
    margin-bottom:30px;
}

/* 뷰페이지 */
.boardViewTopBox .qnaStatus {width:auto; justify-content:flex-start; margin-bottom:15px;}
.boardViewTopBox .qnaStatus::before {display:none;}
.boardViewTopBox .tit{margin-bottom:20px; font-size:24px; font-weight:500; letter-spacing: -0.75px; color:#000; line-height:1.3;}
.boardViewWrap .board_noticeDdak{text-align: center; font-size: var(--font-nor); font-weight: 300; display: inline-block; vertical-align: middle;}

.boardViewTopBox .topInfoBox {border-top:2px solid #666; gap:50px; display: flex; flex-direction:row; align-items:center; padding:20px 0;}
.boardViewTopBox .topInfoBox li,
.boardViewTopBox .topInfoBox li dl {position: relative; display:flex; flex-direction:row; align-items:center;}
.boardViewTopBox .topInfoBox li dl {gap:15px; margin-left:5px;}
.boardViewTopBox .topInfoBox li dl dt {
    color: #333;
    font-size: 16px;
    font-weight: 400;
}
.boardViewTopBox .topInfoBox li dl dd {
    color:#1D1D1D;
    font-size: 16px;
    font-weight: 500;
}
.boardViewTopBox .topInfoBox  li i{margin-right:5px; color:#666666; font-size:20px;}
.boardViewTopBox .topInfoBox  li:last-child{margin-right: 0; padding-right: 0;}
.boardViewTopBox .topInfoBox li p {font-size:16px; font-weight:300; color:#666666;}
.boardViewTopBox .fileDown {
    display: flex;
    width: 100%;
    padding: 20px 30px;
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    border-radius: 6px;
    border: 1px solid #88D9FF;
    background: #F3FBFF;    
}
.boardViewTopBox .fileDown a {
    display:flex; 
    flex-direction:row; 
    align-items:center; 
    gap:10px;
    color: #000;
    font-size: 16px;
    font-style: normal;
    font-weight: 300;
    line-height: normal;
    letter-spacing:-0.6px;
}
.boardViewTopBox .fileDown a:hover {color:var(--color01);}
.boardViewCont {border-bottom:2px solid #666; width:100%;}
.boardViewCont .boardViewContInner {
    padding:80px 0; 
}
.boardViewCont,
.boardViewCont p {font-size:18px; line-height: 1.6; color: #333; letter-spacing: -0.9px; font-weight: 300;;}
.boardViewCont p {word-break:keep-all; white-space: pre-line;}
.boardViewCont img, .boardViewCont iframe {max-width: 100%; margin:30px auto 50px auto; display:block;}

.prevNextWrap{position:relative; margin:30px 0; display: flex; justify-content: space-between; width:100%; gap:0 !important;}
.prevNextWrap >a {width:calc(45% - 100px);}
.prevNextWrap .txtWrap{display: flex; flex-direction:row; align-items:center; width: 100%; cursor:pointer; position:relative; gap:25px;}

.prevNextWrap .right{justify-content: flex-end; text-align: right;}
.prevNextWrap .txtWrap {overflow:hidden;}
.prevNextWrap .txtWrap .txt{font-size: 16px; font-weight:400; letter-spacing: -0.7px; color:#0047A3; }
.prevNextWrap .txtWrap p {margin-top: 10px; width:100%; font-size:16px; font-weight:500; letter-spacing: -0.9px; color:#1D1D1D; width:100%;   white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; }
.prevNextWrap .txtWrap:hover p {color:var(--hover);}
.prevNextWrap .txtOmitWrap{width:calc(100% - 40px);}
.prevNextWrap .txtWrap img {max-width:initial;}
.prevNextWrap .txtWrap:hover p {color:#000;}
.listBtn {
    display: flex;
    width: 200px !important;
    padding: 20px;
    flex-direction: column;
    justify-content: center;
    align-items: center;
    gap: 10px;
    border-radius: 100px;
    background:#003C6B;
    color: #FFF;
    text-align: center;
    font-size: 18px;
    font-style: normal;
    font-weight: 500;
}
.listBtn:hover {
    background-color:#000;
}
.boardBtnLists {
    justify-content:center;
    gap:10px;
}
.boardBtnLists .listBtn  {
    margin:0 !important;
}
.listBtn-edit {
    background-color:#ddd;
    color:#333;
}
.listBtn-del {
    background-color:#878787;
}

/* 비디오리스트 */
.card-list {
    display: flex;
    flex-direction:row;
    align-items:flex-start;
    flex-wrap: wrap;
    list-style: none;
    padding: 0;
    width:100%;
    gap:25px;
}
.card-list li {
    width:calc((100% - 75px) / 4);
    background: #FFF;
    border: 1px solid #E2E2E2;
    border-radius: 20px;
    box-shadow: 0 0 30px 0 rgba(0, 0, 0, 0.1);
    overflow: hidden;
    transition: transform 0.2s;
    border:1px solid transparent;
}
.card-list li:hover {
    border:1px solid var(--hover);
}
.card-list li a {
    display: block;
    text-decoration: none;
    color: inherit;
    position:relative;
}
.card-list .imgBox {
    position: relative;
    width: 100%;
    background: #000;
    overflow:hidden;
    background-repeat:no-repeat;
    background-position:center;
    background-size:cover;
}
.card-list .imgBox img {
    width:100%;
}
.card-list .textBox {
    padding: 20px;
    display: flex;
    flex-direction: column;
    gap: 20px;
}
.card-list .title {
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    text-overflow: ellipsis;
    font-family: 'Pretendard', sans-serif;
    font-size: 18px;
    font-weight: 400;
    line-height: 1.4;
    color: #333;
    min-height:50px;
}
.card-list .info {
    display: flex;
    justify-content: space-between;
    align-items: center;
}
.card-list .date, 
.card-list .views {
    font-family: 'Pretendard', sans-serif;
    font-size: 16px;
    font-weight: 300;
    color: #444;
}
.card-list .views {
    display: flex;
    align-items: center;
    gap: 4px;
}
.card-list .views img {
    width: 18px;
    height: auto;
}
.card-list03 {
    gap:20px;
}
.card-list03 li {
    width:calc(50% - 10px);
}
.card-list03 li a {
    width:100%;
    height:210px;
    padding:20px;
    box-sizing:border-box;
    display:flex;
    flex-direction:row;
    align-items:center;
    gap:30px;
}
.card-list03 li .imgBox {
    width:260px;
    height:100%;
    overflow:hidden;
    border-radius:0;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;    
}
.card-list03 .textBox {
    width:calc(100% - 260px);
    height:100%;
    display:flex;
    flex-direction:column;
    justify-content:space-between;
    gap:0;
    padding:20px 0 20px 0;
}

@media screen and (max-width:1200px) {
    .board-search {overflow:hidden;}
    .board-search .inner {width:calc(100% - 40px);}
    .board-search .search-detail-view,
    .board-search .search-detail-view .search-item,
    .boardTabBtn,
    .boardTabBox,
    .boardTabBox .boardBox {width:100%; overflow:hidden;}
    .board-search .search-item {width:100%; margin:0 auto 30px auto;}
    .board-search .search-item {flex-direction:column;}
    .filter-list01, .filter-list02 {max-width:100%; width:100%;}
    .board-search .search-item .lfTit {width:100%; margin-bottom:10px; padding-left:15px;}
    .board-search .search-detail-view .lfTit {width:100%; margin:0 auto 10px auto;}    
    .board-search .search-item .lfTit::before {margin:0;}
    .board-search .search-item .rtBox {width:100%;}
    .filter-list {gap:5px; justify-content:center; display: grid; grid-template-columns: repeat(4, 1fr); align-items: stretch;}
    .filter-list03 li img {max-width:40px; width:55%;}
    .filter-list li {width:100%;}
    .filter-list li button {width:100%; height:100% !important; font-size:16px; min-width:initial !important; min-height:initial !important; word-break:keep-all; padding:10px 2px;}
    .filter-list li button br {display:none;}
    .filter-list li button span {font-size:14px;}
    .btn-detail-toggle {width:200px; padding:15px 20px; font-size:20px; gap:5px;}
    .btn-detail-toggle img {width:25px;}


    .listSearch .select-trigger {height:50px;}
    .board .search-box {max-width:400px; height:50px;}
    .board .search-box input,
    .board .search-box input::placeholder {font-size:15px; padding:0 10px;}
    .board .search-box .btn-search .search-text {display:none;}
    .board .search-box .btn-search .search-icon {width:19px;}
    .board .search-box .btn-search {width:42px; height:42px; border-radius:50%; gap:0;}

    .pagination .page-numbers {gap:5px; margin:0 10px;}
    .pagination .num {font-size:16px;}
    .pagination .page-btn {width:30px; height:30px;}

    .prevNextWrap {
        display: flex;
        flex-wrap: wrap; 
        justify-content: space-between;
        gap: 10px;
        width: 100%;
        margin: 30px 0;
    }
    .prevNextWrap a:first-child {
        order: 1; 
        width:50%;
    }

    .prevNextWrap a:last-child {
        order: 2;
        width:50%;        
    }
    .prevNextWrap .txtWrap {position:relative;}
    .prevNextWrap .txtWrap.left::after {
        content:'';
        display:block;
        width:1px;
        height:100%;
        background-color:#ccc;
        position:absolute;
        top:0;
        right:0;
        opacity:0.5;
    }
    .prevNextWrap .txtWrap p {margin-top:5px;}
    .prevNextWrap .txtWrap {gap:15px;}
    .prevNextWrap .txtWrap img {width:10px;}
    .prevNextWrap .txtOmitWrap {
        width:calc(100% - 50px);
    }
    .prevNextWrap .listBtn {
        order: 3; 
        width: 100%; 
        margin:30px auto 0 auto;
        width:180px !important;
        font-size:16px;
        padding:17px 20px;
    }    

    .boardTabBtn {gap:10px;}
    .boardTabBtn li button {width:160px; height:50px; padding:0; font-size:17px;}
    
    .boardTabBtn {width:100%; margin:0 auto 30px auto;}
    .boardTabBtn li {width:100%; max-width:130px;}
    .boardTabBtn li button {width:100%; }
    .couponBox {flex-direction:column; padding:0; box-shadow:0 0 8px 0 rgba(0, 0, 0, 0.10);}
    .couponBox .lfTextBox {width:100%; padding:25px; box-sizing:border-box; margin-right:0;}
    .couponBox .lfTextBox .imgBox {width:250px; height:auto;}
    .boardTabBox02 .boardBox ul, .popularityBox {gap:15px;}
    .coupon-info {padding-left:30px;}
    .downBox {width:100%; padding:20px; border-radius:0;}
    .downBox p {font-size:16px;}
    .downBox img {width:40px; top:20px; right:20px;}

    .card-list {gap:20px;}
    .card-list li {width:calc((100% - 40px) / 3);}
    .card-list02 li {width:calc(50% - 13px);}
    .card-list03 {flex-direction:column; max-width:720px; margin:0 auto;}
    .card-list03 li {width:100%;}
}
@media screen and (max-width:980px) {
    .dim-container {width:calc(100% - 40px);}
    .dim-inner {padding:25px 20px;}
    .dim-desc {margin-bottom:20px;}
    .dim-header {padding:15px 20px;}
    .dim-title {font-size:17px;}
    .list-header {font-size:16px; padding:10px 0;}
    .list-body li button {font-size:15px; padding:5px 10px;}
    .dim .board,
    .dim .board .search-box02 {width:100%;}
    .btn-close {width:40px; height:40px; margin:15px auto 0 auto; background-size: 14px;}
    
    .coupon-card {
        border:2px solid #88D9FF;
        padding:20px;
    }
    .coupon-main-title {font-size:20px;}
    .coupon-sub-title {font-size:17px; margin-bottom:20px;}
    .brand-area .topLogo {display:none;}
    .info-item dt {width:60px; margin-right:10px; height:25px; border-radius:80px; font-size:15px;}
    .info-item dd {font-size:16px; width:calc(100% - 70px); word-break:keep-all; line-height:1.3;}
    .brand-area {flex-direction:column; justify-content:center; gap:10px; padding:10px 0;}
    .brand-name {font-size:20px;}
    .additional-txt {margin-top:15px; padding-top:15px; font-size:16px;}
    .couponDown {height:60px; font-size:17px;}

    .filter-list li button {font-size:14px; padding:7px 2px; letter-spacing:0.6px;}
    .filter-list li button span {font-size:12px; padding-top:3px;}
}
@media screen and (max-width:720px) {
    .board .sec .inner {padding:55px 0;}
    .board-search .search-item .type-list {
        display: grid;
        grid-template-columns: 1fr 1fr; /* 1:1 비율로 2열 배치 */
        gap: 10px; /* 간격 */
    }
    .board-search .search-item .type-list li {width:100%;}
    .brand-area .brand-name {max-width:100%;}
    .col-status li {gap:5px;}
    .icon-box {width:25px; height:25px;}
    .boardList li p {font-size:15px; letter-spacing:-0.6px;}
    .boardListTopTitle {display:none;}
    .boardList {border-top:1px solid #EEE;}
    .boardList li {gap:10px;}
    .boardList li p {padding:0; flex:initial; position:relative;}
    .boardList li {width:100%; min-height:initial; flex-wrap:wrap; padding:15px 0;}
    .boardList01 li .col-name {width:100%;}
    .boardList01 li .col-address,
    .boardList li p.col-date {width:calc(50% - 5px); flex:initial;}
    .boardList01 li .col-status,
    .boardList li p.col-hit {width:calc(50% - 5px); flex:initial; justify-content:flex-end; text-align:right;}
    .boardList01 li .col-type {width:100%;}    
    .col-status li {gap:3px;}
    .col-status li:not(:last-child) {margin-right:3px;}
    .col-status li p {font-size:13px;}

    .col-2 {flex:initial;}
    .boardList li .category {margin:0;}
    .boardList li .subject {width:100%; text-overflow: initial; white-space: normal; word-break:keep-all; padding:0;}
    .boardList li p {text-align:left;}
    .boardList li p.numText {font-weight:500; color:#000;}
    .boardList li .col-date span,
    .boardList li .col-hit span{
        display:inline-block;
        padding-right:4px;
        color: #444;
        font-size: 1em;
        font-weight: 300;
        line-height:1;    
    }    
    
    .btn-detail-toggle {width:160px; padding:12px 15px 12px 10px; font-size:17px; border-radius: 100px 0 0 0;}

    .board-search .search-item .type-list li button {padding:10px 0;}
    .board-search .search-item .type-list .icon {height:70px;}
    .board-search .search-item .type-list .icon01 img {
        width:55px;
    }
    .board-search .search-item .type-list .icon02 img {
        width:44px;
    }
    .board-search .search-item .type-list .icon03 img {
        width:52px;
    }
    .board-search .search-item .type-list .icon04 img {
        width:56px;
    }    
    .board-search .search-item .type-list p {font-size:16px; letter-spacing:-0.5px;}
    .board-search .search-item .type-list p span {font-size:14px;}

    .listSearch {flex-direction:column;}
    .listSearch .custom-select-wrapper,
    .listSearch .search-box {width:100%; max-width:480px;}

    .boardViewTopBox .tit {font-size:19px; margin-bottom:15px;}
    .boardViewTopBox .topInfoBox {gap:20px; padding:15px 0;}
    .boardViewTopBox .topInfoBox li dl {gap:10px;}
    .boardViewTopBox .fileDown {padding:15px;}
    .boardViewTopBox .fileDown a {font-size:14px;}
    .boardViewTopBox .fileDown a img {width:18px;}
    .boardViewCont .boardViewContInner {padding:30px 0;}
    .boardViewCont, .boardViewCont p {font-size:15px;}

    .couponBox .lfTextBox {padding:20px; flex-direction:column; justify-content:center;}
    .boardTabBox02 .boardBox ul, .popularityBox {gap:10px;}
    .couponBox .lfTextBox .imgBox {width:100%; max-width:280px; margin-bottom:20px;}
    .coupon-info {padding-left:0;}
    .coupon-info .info-row .label,
    .coupon-info .info-row .desc {font-size:15px;}
    .coupon-info .info-row .label::before {left:0; width:3px; height:3px;}
    .coupon-info .info-row .label {margin-left:0; width:60px; padding-left:7px;}
    .coupon-info .info-row .desc {padding-left:15px;}
    .downBox img {width:36px; top:-15px; right:10px;}

    .card-list {gap:15px;}
    .card-list li {width:calc((100% - 15px) / 2);}
    .card-list03 li {border-radius:15px; width:100%;}
    .card-list03 li a {height:140px; gap:20px; padding:15px;}
    .card-list03 li .imgBox {width:150px;}
    .card-list03 .textBox {width:calc(100% - 140px); padding:5px 0;}
    .card-list .title {font-size:16px; min-height:initial;}

    .card-list02 {gap:10px;}
    .card-list02 li {width:calc(50% - 5px);}

    .dim-desc {font-size:16px;}
}
@media screen and (max-width:480px) {
    .board .sec .inner {padding:30px 0 50px 0;}
    .card-list {gap:20px;}
    .card-list li {width:100%;}    
    .card-list03 {gap:15px;}
    .card-list03 li a {height:110px; gap:15px;}
    .card-list03 li .imgBox {width:120px; }
    .card-list03 .textBox {width:calc(100% - 110px); padding:0;}
    .card-list03 .title {font-size:15px;}
    .card-list .date, .card-list .views {font-size:14px;}

    .card-list02 {gap:20px;}
    .card-list02 li {width:100%;}    

    .boardTabBtn li button {font-size:15px; height:40px;}
    .select-trigger::after {right:15px;}
}
@media screen and (max-width:380px) {
    .board .search-box input, .board .search-box input::placeholder {font-size:13px;}
    .board .search-box input {max-width:calc(100% - 46px);}
}