/**/
@import url('https://fonts.googleapis.com/css2?family=Lato:ital,wght@0,100;0,300;0,400;0,700;0,900;1,100;1,300;1,400;1,700;1,900&display=swap');

@font-face {
    font-family: 'pretendard';
    src: url(../font/PretendardVariable.woff2);
    src: url(../font/PretendardVariable.woff2) format("woff2");
}

@font-face {
    font-family: 'xeicon';
    src: url(../font/xeicon.woff2);
    src: url(../font/xeicon.woff2) format("woff2");
}

* {
    font-size: 16px;
    font-family: 'Lato', 'pretendard', serif;
    font-weight: 400;
    color: #222;
    padding: 0;
    margin: 0;
    border: 0;
    list-style: none;
    text-decoration: none;
    box-sizing: border-box;
    border-collapse: collapse;
}

body {
    min-width: 1700px;
    background: var(--input-background);
}

:root {
    --keyblue: #2585f8;
    --keygreen: #03ddb1;
    --keynavy: #11193f;
    --keyred: #e72a3c;
    --input-background: #f3f5f9;
    --input-line: #e5e5e5;
    --th-background: #e7e9f2;
    --td-line: #e6e8ed;
    --white: #fff;
    --readonly: #f5f5f5;
    --disabled: #f5f5f5;
}

nav::-webkit-scrollbar {
    width: 6px;
}

nav::-webkit-scrollbar-track {
    background: var(--keynavy);
}

nav::-webkit-scrollbar-thumb {
    background: #4c5cff;
    border-radius: 3px;
}

nav::-webkit-scrollbar-thumb:hover {
    background: #6675ff;
}

input[readonly], select[disabled] {
    background-color: var(--readonly);
    cursor: not-allowed;
}

/*header*/
#header {
    position: fixed;
    top: 0;
    left: 0;
    width: 280px;
    height: 100vh;
    background: var(--keynavy);
}

#header h1 {
    padding: 30px 24px;
}

#header h1 img {
    display: block;
    width: 180px;
}

#header nav {
    padding: 16px 16px 0;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
    height: calc(100vh - 150px);
    overflow-y: scroll;
}

#header nav .depth1 > li {
    padding: 3px 0;
}

#header nav .depth1 > li > a {
    display: flex;
    align-items: center;
    height: 48px;
    padding: 0 18px;
    border-radius: 30px;
}

#header nav .depth1 > li > a:hover,
#header nav .depth1 > li.active > a {
    background: rgba(255, 255, 255, 0.08);
}

#header nav .depth1 > li > a > i {
    font-size: 1.4em;
    color: rgba(255, 255, 255, 0.7);
}

#header nav .depth1 > li > a > span {
    display: block;
    padding-left: 12px;
    font-size: 1em;
    font-weight: 500;
    color: rgba(255, 255, 255, 0.7);
}

#header nav .depth1 > li > div {
    display: none;
    padding: 14px 0 0 18px;
}

#header nav .depth1 > li > div li {
    padding-bottom: 14px;
}

#header nav .depth1 > li > div a {
    font-size: 0.95em;
    color: #f0f0f0;
}

#header nav .depth1 > li > div a:hover,
#header nav .depth1 > li > div li.sel a {
    color: var(--keygreen);
}

#header .member {
    position: absolute;
    bottom: 0;
    left: 0;
    width: 100%;
    height: 50px;
    border-top: 1px solid rgba(255, 255, 255, 0.12);
}

#header .member a {
    display: block;
    width: 100%;
    height: 100%;
    line-height: 50px;
    text-align: center;
    font-size: 0.8em;
    color: var(--white);
}

#header .member a:hover {
    background: rgba(0, 0, 0, 0.1);
}


/*�α���*/
.login_wrap {
    width: 100vw;
    height: 100vh;
    display: flex;
    justify-content: center;
    align-items: center;
    background: url(../image/bg.jpg) no-repeat center center/cover;
}

.login_wrap .box {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 45vw;
    height: 70vh;
    min-width: 600px;
    min-height: 560px;
    background: var(--white);
    border-radius: 12px;
    box-shadow: 5px 15px 50px 0 rgba(0, 0, 0, 0.08);
}

.login_wrap .box .tit {
    padding-bottom: 40px;
}

.login_wrap .box .tit img {
    display: block;
    width: 300px;
    margin: 0 auto 30px;
}

.login_wrap .box .tit p {
    font-size: 0.95em;
    text-align: center;
    color: #999;
}

.login_wrap .box form div {
    position: relative;
    width: 340px;
    margin-top: 10px;
}

.login_wrap .box form label {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    left: 20px;
    display: block;
    font-size: 0.9em;
    font-weight: 700;
    color: var(--keyblue);
}

.login_wrap .box form input {
    display: block;
    width: 100%;
    height: 50px;
    line-height: 50px;
    border-radius: 50px;
    padding: 0 10px 0 64px;
    background: var(--input-background);
}

.login_wrap .box form button {
    margin-top: 24px;
    display: block;
    width: 100%;
    height: 54px;
    line-height: 54px;
    border-radius: 54px;
    text-align: center;
    background: linear-gradient(50deg, var(--keyblue), var(--keygreen));
    color: var(--white);
    font-weight: 600;
    cursor: pointer;
}

/*contents*/

/*����Ÿ��Ʋ*/
#contents .subt {
    height: 98px;
    display: flex;
    align-items: center;
}

#contents .subt h2 {
    font-size: 1.7em;
    font-weight: 700;
}

#contents {
    padding: 0 40px 30px 320px;
}

#contents .search {
    padding: 14px 18px;
    margin-bottom: 14px;
    border-radius: 10px;
    background: var(--white);
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.05);
}

#contents .search .wrap {
    display: flex;
    gap: 20px;
}

#contents .search .wrap + .wrap {
    padding-top: 16px;
}

#contents .search .wrap > div {
    flex-basis: 0;
    flex-grow: 1;
}

#contents .search .wrap > div label {
    display: block;
    padding-bottom: 8px;
    font-size: 0.9em;
    font-weight: 500;
    color: #787878;
}

#contents .search .wrap > div input,
#contents .search .wrap > div select {
    display: block;
    width: 100%;
    height: 36px;
    line-height: 36px;
    padding: 0 8px;
    border: 1px solid #e0e0e0;
    border-radius: 3px;
    background: var(--white);
}

#contents .search .wrap > div .inputbox {
    display: flex;
}

#contents .search .wrap > div .inputbox button {
    width: 25%;
    min-width: 38px;
    margin-left: 4px;
    padding: 0 6px;
    height: 36px;
    line-height: 36px;
    border: 1px solid #c2c2c2;
    background: var(--white);
    font-size: 0.9em;
    border-radius: 3px;
    cursor: pointer;
}

#contents .search .btns {
    display: flex;
    justify-content: center;
    gap: 8px;
    margin-top: 14px;
    padding-top: 14px;
    border-top: 1px dashed #e2e2e2;
}

#contents .search .btns button,
#contents .search .btns a {
    display: block;
    height: 36px;
    line-height: 36px;
    padding: 0 12px;
    font-size: 0.92em;
    border-radius: 3px;
    cursor: pointer;
}

#contents .search .btns .btn_submit {
    background: var(--keyblue);
    color: var(--white);
}

#contents .search .btns .btn_normal {
    background: #333;
    color: var(--white);
}

#contents .search .btns .btn_clear {
    background: #f2f2f2;
}

#contents .pages {
    padding: 20px 18px;
    border-radius: 10px;
    background: var(--white);
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.05);
}

#contents .pages .tbl table {
    width: 100%;
}

#contents .pages .tbl table th,
#contents .pages .tbl table td {
    text-align: center;
    vertical-align: middle;
}

#contents .pages .tbl table thead th {
    padding: 18px 0;
    font-size: 0.9em;
    font-weight: 500;
    border-top: 1px solid #333;
    border-bottom: 1px solid #333;
}

#contents .pages .tbl table thead .line2 {
    background: #e5eaf3;
}

#contents .pages .tbl table thead .line2 th {
    padding: 10px 0;
}

#contents .pages .tbl table thead .line2 th select,
#contents .pages .tbl table thead .line2 th input {
    display: block;
    width: 92%;
    margin: 0 auto;
    height: 32px;
    line-height: 32px;
    border-radius: 5px;
    border: 1px solid #c4c9d1;
}

#contents .pages .tbl table tbody tr {
    cursor: pointer;
}

#contents .pages .tbl table tbody th,
#contents .pages .tbl table tbody td {
    border-bottom: 1px solid var(--td-line);
    padding: 10px 0;
}

#contents .pages .tbl table td.taL {
    text-align: left;
}

#contents .pages .tbl table td.taR {
    text-align: right;
}

#contents .pages .tbl table tbody td b {
    font-weight: 700;
}

#contents .pages .tbl table tbody tr:nth-child(even) th,
#contents .pages .tbl table tbody tr:nth-child(even) td {
    background: #f9f9fc;
}

#contents .pages .tbl table tbody tr:hover th,
#contents .pages .tbl table tbody tr:hover td {
    background: #f6f6fa;
}

#contents .pages .tbl table tbody td button {
    font-size: 0.88em;
    font-weight: 500;
    border: 1px solid #d2d2d2;
    padding: 3px 5px;
    cursor: pointer;
}

#contents .pages .tbl table tbody td .btn_enable {
    font-size: 0.88em;
    font-weight: 500;
    border: 1px solid #d2d2d2;
    padding: 3px 5px;
    cursor: pointer;
    background-color: #007bff;
    color: white;
}

#contents .pages .tbl table tbody td .btn_enable:hover {
    font-size: 0.88em;
    font-weight: 500;
    border: 1px solid #d2d2d2;
    padding: 3px 5px;
    cursor: pointer;
    background-color: #0056b3;
}

#contents .pages .tbl table tbody td .btn_disable {
    font-size: 0.88em;
    font-weight: 500;
    border: 1px solid #d2d2d2;
    padding: 3px 5px;
    background-color: #e0e0e0;
    color: #888;
    cursor: not-allowed;

}

#contents .pages .tbl table tfoot td {
    border-bottom: 1px solid var(--td-line);
    padding: 10px 0;
    background: var(--input-background);
}

#contents .pages .tbl table tbody tr.small {
}

#contents .pages .tbl table tbody tr.small.first td {
    border-top: 2px solid var(--keynavy);
}

#contents .pages .tbl table tbody tr.small td {
    padding: 6px 0;
    font-size: 0.88em;
}

#contents .pages .tbl.form h4 {
    padding-bottom: 12px;
}

#contents .pages .tbl + .tbl.form h4 {
    padding-top: 30px;
}

#contents .pages .tbl.form h4 i {
    display: inline-block;
    vertical-align: middle;
    font-size: 1.15em;
    padding-right: 4px;
}

#contents .pages .tbl.form h4 span {
    display: inline-block;
    vertical-align: middle;
    font-size: 1em;
    font-weight: 700;
}

#contents .pages .tbl.form table {
    width: 100%;
}

#contents .pages .tbl.form table th,
#contents .pages .tbl.form table td {
    padding: 8px;
    border: 1px solid #cccfdc;
    background: var(--white);
    text-align: left;
}

#contents .pages .tbl.form table tbody tr {
    cursor: default;
}

#contents .pages .tbl.form table th {
    font-size: 0.92em;
    font-weight: 500;
    text-align: center;
    background: var(--th-background) !important;
    color: #525567;
}

#contents .pages .tbl.form table td select,
#contents .pages .tbl.form table td input {
    display: block;
    width: 100%;
    height: 32px;
    line-height: 32px;
    padding: 0 6px;
    border: 1px solid var(--input-line);
}

#contents .pages .tbl.form table td textarea {
    display: block;
    width: 100%;
    height: 80px;
    padding: 6px;
    border: 1px solid var(--input-line);
    resize: none;
}

#contents .pages .tbl.form table td button.btn_normal {
    padding: 4px 6px;
    font-size: 0.9em;
    font-weight: 500;
    margin-top: 5px;
    border: 1px solid #c2c2c2;
    border-radius: 3px;
    background: var(--white);
    cursor: pointer;
}

#contents .pages .tbl.form table tbody tr:nth-child(even) th,
#contents .pages .tbl.form table tbody tr:nth-child(even) td {
    background: var(--white);
}

#contents .pages .tbl.form table tbody tr:hover th,
#contents .pages .tbl.form table tbody tr:hover td {
    background: inherit;
}

#contents .pages .form.btns {
    display: flex;
    justify-content: center;
    gap: 6px;
    padding-top: 24px;
}

#contents .pages .form.btns button {
    display: block;
    height: 48px;
    padding: 0 22px;
    border-radius: 3px;
    cursor: pointer;
}

#contents .pages .form.btns button i {
    display: inline-block;
    vertical-align: middle;
    color: var(--white);
    padding-right: 4px;
}

#contents .pages .form.btns button span {
    display: inline-block;
    vertical-align: middle;
    font-size: 1em;
    font-weight: 600;
    color: var(--white);
}

#contents .pages .form.btns button.blue {
    background: var(--keyblue);
}

#contents .pages .calendar .month {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 24px;
    padding-bottom: 20px;
}

#contents .pages .calendar .month h3 {
    font-size: 1.8em;
    font-weight: 700;
}

#contents .pages .calendar .month span {
    display: flex;
    justify-content: center;
    align-items: center;
    width: 28px;
    height: 28px;
    border-radius: 50%;
    background: var(--keynavy);
    cursor: pointer;
}

#contents .pages .calendar .month span i {
    font-size: 0.9em;
    color: var(--white);
}

#contents .pages .calendar table tbody td {
    border: 1px solid var(--td-line);
    padding: 22px 14px;
    text-align: left;
}

#contents .pages .calendar table tbody td em {
    display: block;
    padding-bottom: 12px;
    font-size: 1.15em;
    font-weight: 600;
    font-style: normal;
}

#contents .pages .calendar table tbody td div p {
    font-size: 0.95em;
    line-height: 160%;
}

#contents .btns_system {
    display: flex;
    justify-content: right;
    gap: 10px;
    padding-top: 24px;
}

#contents .btns_system a {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 5px;
    height: 48px;
    padding: 0 16px;
    border-radius: 5px;
}

#contents .btns_system a span {
    font-size: 0.92em;
    font-weight: 500;
}

#contents .btns_system a.navy {
    background: var(--keynavy);
}

#contents .btns_system a.red {
    background: var(--keyred);
}

#contents .btns_system a i {
    color: var(--white);
}

#contents .btns_system a span {
    color: var(--white);
}

#contents #overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5);
}

#contents #modalpop {
    display: none;
    position: fixed;
    top: 50%;
    left: calc(50% + 140px);
    transform: translate(-50%, -50%);
    width: 800px;
    height: 680px;
    overflow-y: scroll;
    padding: 30px;
    background: var(--white);
}

#contents #modalpop h3 {
    padding-bottom: 20px;
    font-size: 1.25em;
    font-weight: 700;
}

#contents #modalpop .con + h3 {
    padding-top: 32px;
}

#contents #modalpop .tbl table {
    width: 100%;
}

#contents #modalpop .tbl table th,
#contents #modalpop .tbl table td {
    padding: 8px;
    border: 1px solid #cccfdc;
}

#contents #modalpop .tbl table th {
    font-size: 0.92em;
    font-weight: 500;
    text-align: center;
    background: var(--th-background);
    color: #525567;
}

#contents #modalpop .tbl table td select,
#contents #modalpop .tbl table td input {
    display: block;
    width: 100%;
    height: 32px;
    line-height: 32px;
    padding: 0 6px;
    border: 1px solid var(--input-line);
}

#contents #modalpop .tbl table td textarea {
    display: block;
    width: 100%;
    height: 80px;
    padding: 6px;
    border: 1px solid var(--input-line);
    resize: none;
}

#contents #modalpop .tbl table tbody td .btn_gray {
    display: inline-block;
    padding: 3px 4px;
    font-size: 0.9em;
    font-weight: 500;
    border-radius: 3px;
    border: 1px solid #ccc;
    cursor: pointer;
    margin-top: 3px;
}

#contents #modalpop .tbl_list {
    padding-top: 12px;
}

#contents #modalpop .tbl_list table {
    width: 100%;
}

#contents #modalpop .tbl_list table th,
#contents #modalpop .tbl_list table td {
    padding: 6px;
    border: 1px solid #ddd;
    text-align: center;
    font-size: 0.9em;
}

#contents #modalpop .tbl_list table thead th {
    padding: 7px 0;
    font-size: 0.88em;
    font-weight: 600;
    color: #888;
}

#contents #modalpop .tbl_list table tbody td {
    background: #f9f9fa;
}

#contents #modalpop .btns {
    display: flex;
    justify-content: center;
    gap: 6px;
    padding-top: 20px;
}

#contents #modalpop .btns button {
    display: block;
    height: 31px;
    padding: 0 12px;
    border-radius: 3px;
    font-size: 0.92em;
    background: var(--white);
    cursor: pointer;
}

#contents #modalpop .btns button.blue {
    background: var(--keyblue);
    color: var(--white);
}

#contents #modalpop .btns button.gray {
    color: #888;
    border: 1px solid #999;
}

#contents #modalpop .btns button.red {
    color: var(--keyred);
    border: 1px solid var(--keyred);
}

#contents #details {
    display: none;
    margin-top: 30px;
    padding-top: 30px;
    border-top: 1px dashed rgba(0, 0, 0, 0.25);
}

#contents #details .tit {
    padding-bottom: 16px;
}

#contents #details .tit span {
    display: inline-block;
    font-size: 1.1em;
    font-weight: 700;
}

#contents #details .con {
    background: var(--white);
}

#contents #details .pages .tbl tbody td {
    font-size: 0.9em;
}

.pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    list-style: none;
    padding: 10px;
    margin-top: 20px;
}

.pagination li {
    margin: 0 3px;
}

.pagination a {
    text-decoration: none;
    color: #1A2B50;
    padding: 6px 10px;
    font-size: 14px;
    border: 1px solid #1A2B50;
    border-radius: 5px;
    background-color: white;
    transition: all 0.3s ease;
    display: flex;
    align-items: center;
    justify-content: center;
}

.pagination a:hover {
    background-color: rgba(17, 25, 63, 0.8);
    color: white;
}

.pagination .active a {
    background-color: var(--keynavy);
    color: white;
    border: 1px solid var(--keynavy);
}

.pagination .disabled a {
    color: #ccc;
    pointer-events: none;
}

.pagination a i {
    font-size: 14px;
}

.btn_search {
    display: block; /* 또는 block; 상황에 따라 조절 */
    padding: 8px 12px; /* 적절한 패딩으로 클릭 영역 확보 */
    font-size: 1em; /* 현재 body 폰트 크기 기준 */
    font-weight: 500; /* body font-weight 고려 */
    color: var(--white); /* 검색 버튼 텍스트 색상 (주로 흰색) */
    background-color: var(--keyblue); /* 주요 파란색 */
    border-radius: 3px; /* input의 border-radius 고려 */
    cursor: pointer; /* 마우스 오버 시 커서 변경 */
    transition: background-color 0.3s ease; /* 호버 효과 */
    margin-bottom: 10px; /* 입력 필드와의 간격 (기존 margin-bottom 고려) */
    width: 100%;
}

/* ====================================================================== */
/* ==================== 공용 검색 팝업 스타일 추가 ===================== */
/* ====================================================================== */

.common-popup-overlay {
    display: none; /* JS로 제어 */
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.5); /* #contents #overlay 와 동일 */
    z-index: 1050; /* 다른 팝업들과 겹치지 않도록 충분히 높은 값 */
}

.common-popup-modal {
    display: none; /* JS로 제어 */
    position: fixed;
    top: 50%;
    left: 50%; /* #contents #modalpop 은 left: calc(50% + 140px) 이었으나, 일반적인 중앙 정렬을 위해 50% 사용 */
    transform: translate(-50%, -50%);
    width: 600px; /* 기본 너비, #contents #modalpop width: 800px 보다 작게 설정 */
    max-width: 90%; /* 화면 작은 경우 대비 */
    background: var(--white);
    z-index: 1051;
    border-radius: 8px; /* #contents .search border-radius: 10px 와 유사하게 부드러운 값 */
    box-shadow: 0 5px 15px rgba(0, 0, 0, 0.15); /* #contents .search box-shadow 와 유사 */
    /* #contents #modalpop 의 padding: 30px; 는 각 섹션에서 관리 */
}

.common-popup-header {
    padding: 15px 20px; /* #contents #modalpop h3 padding-bottom: 20px 참고 */
    border-bottom: 1px solid var(--input-line); /* CSS 변수 활용 */
    display: flex;
    justify-content: space-between;
    align-items: center;
}

.common-popup-header .popup-title {
    font-size: 1.2em; /* #contents #modalpop h3 font-size: 1.25em 와 유사 */
    font-weight: 700; /* #contents #modalpop h3 font-weight: 700 와 동일 */
    color: #222; /* 기본 텍스트 색상 */
    margin: 0;
}

.common-popup-header .btn-close-popup {
    background: none;
    border: none;
    font-size: 1.8em;
    font-weight: bold; /* 더 잘보이게 */
    color: #888; /* #contents #modalpop .btns button.gray color 와 유사 */
    cursor: pointer;
    padding: 0 5px; /* 클릭 영역 확보 */
    line-height: 1;
}

.common-popup-header .btn-close-popup:hover {
    color: #555;
}

.common-popup-content {
    padding: 20px;
    /* #contents #modalpop 의 overflow-y: scroll; 은 table-wrap 에서 처리 */
}

.common-popup-content .search-area {
    display: flex;
    gap: 8px; /* #contents .search .btns gap: 8px 와 유사 */
    margin-bottom: 15px; /* #contents .search margin-bottom: 14px 와 유사 */
}

.common-popup-content .search-area input[type="text"] {
    flex-grow: 1;
    height: 36px; /* #contents .search .wrap > div input height 와 동일 */
    line-height: 34px; /* border 고려 */
    padding: 0 10px; /* #contents .search .wrap > div input padding 과 유사 */
    border: 1px solid var(--input-line); /* #contents .pages .tbl.form table td input border 와 동일 */
    border-radius: 3px; /* #contents .search .wrap > div input border-radius 와 동일 */
    background: var(--white); /* #contents .search .wrap > div input background 와 동일 */
}

.common-popup-content .search-area input[type="text"]:focus {
    border-color: var(--keyblue); /* 포커스 시 강조 */
    outline: none;
}

.common-popup-content .search-area .btn-search-popup {
    height: 36px; /* #contents .search .btns button height 와 동일 */
    line-height: 36px;
    padding: 0 15px; /* #contents .search .btns button padding 과 유사 */
    font-size: 0.92em; /* #contents .search .btns button font-size 와 동일 */
    font-weight: 500; /* 가독성 위해 추가 */
    border-radius: 3px; /* #contents .search .btns button border-radius 와 동일 */
    cursor: pointer;
    background: var(--keyblue); /* #contents .search .btns .btn_submit background 와 동일 */
    color: var(--white); /* #contents .search .btns .btn_submit color 와 동일 */
    border: none; /* 버튼 기본 테두리 제거 */
}

.common-popup-content .search-area .btn-search-popup:hover {
    background: #1e73d3; /* keyblue 보다 약간 어둡게 */
}

.common-popup-table-wrap {
    max-height: calc(60vh - 150px); /* 팝업 높이에 따라 유동적으로 (헤더,푸터,검색창 제외한 높이) */
    overflow-y: auto;
    border: 1px solid var(--td-line); /* #contents .pages .tbl table tbody td border-bottom 과 유사 */
}

.common-popup-table {
    width: 100%; /* #contents #modalpop .tbl_list table width 와 동일 */
}

.common-popup-table thead th {
    padding: 10px 8px; /* #contents .pages .tbl table tbody td padding 과 유사하게 조정 */
    font-size: 0.9em; /* #contents #modalpop .tbl_list table thead th font-size:0.88em 와 유사 */
    font-weight: 600; /* #contents #modalpop .tbl_list table thead th font-weight 와 동일 */
    color: #525567; /* #contents #modalpop .tbl table th color 와 유사 */
    background: var(--th-background); /* #contents #modalpop .tbl table th background 와 동일 */
    border-bottom: 1px solid var(--td-line); /* #contents .pages .tbl table tbody td border-bottom 과 유사 */
    text-align: center; /* #contents #modalpop .tbl_list table th text-align 와 동일 */
    position: sticky; /* 스크롤 시 헤더 고정 */
    top: 0;
    z-index: 1; /* 다른 내용 위로 */
}

.common-popup-table tbody td {
    padding: 10px 8px; /* #contents .pages .tbl table tbody td padding 과 유사 */
    font-size: 0.9em; /* #contents #modalpop .tbl_list table td font-size 와 동일 */
    border-bottom: 1px solid var(--td-line); /* #contents .pages .tbl table tbody td border-bottom 과 유사 */
    text-align: center; /* #contents #modalpop .tbl_list table td text-align 와 동일 */
    background: var(--white);
}

.common-popup-table tbody tr:nth-child(even) td {
    background: #f9f9fc; /* #contents .pages .tbl table tbody tr:nth-child(even) td background 와 동일 */
}

.common-popup-table tbody tr.common-search-result-row:hover td { /* JS에서 추가하는 클래스명 고려 */
    background: #f0f4ff; /* #contents .pages .tbl table tbody tr:hover td background 보다 연하게 */
    cursor: pointer;
}

.common-popup-table tbody td.no-data {
    padding: 30px 10px; /* 패딩 조정 */
    text-align: center;
    color: #777;
    background: var(--white) !important; /* 다른 배경 스타일 오버라이드 */
    font-size: 0.9em;
}

.common-popup-table tbody input[type="radio"] {
    vertical-align: middle; /* 라디오 버튼 정렬 */
    cursor: pointer;
}

.common-popup-footer {
    display: flex;
    justify-content: center; /* #contents #modalpop .btns justify-content 와 동일 */
    gap: 10px; /* #contents #modalpop .btns gap: 6px 보다 약간 넓게 */
    padding: 15px 20px; /* 위쪽 패딩은 헤더와 동일하게, 아래쪽은 좀 더 여유있게 */
    border-top: 1px solid var(--input-line); /* 헤더와 동일한 구분선 */
}

.common-popup-footer button {
    height: 36px; /* 검색 버튼과 높이 통일 */
    line-height: 34px; /* border 고려 */
    padding: 0 18px; /* #contents #modalpop .btns button padding: 0 12px 보다 넓게 */
    border-radius: 3px; /* #contents #modalpop .btns button border-radius 와 동일 */
    font-size: 0.92em; /* #contents #modalpop .btns button font-size 와 동일 */
    font-weight: 500; /* 가독성 위해 추가 */
    cursor: pointer;
    border: 1px solid transparent; /* 기본 테두리 투명 처리 */
}

.common-popup-footer .btn-select-popup {
    background: var(--keyblue); /* #contents #modalpop .btns button.blue background 와 동일 */
    color: var(--white); /* #contents #modalpop .btns button.blue color 와 동일 */
    border-color: var(--keyblue);
}

.common-popup-footer .btn-select-popup:hover:not(:disabled) {
    background: #1e73d3; /* keyblue 보다 약간 어둡게 */
    border-color: #1e73d3;
}

.common-popup-footer .btn-select-popup:disabled {
    background: #aacfff; /* 비활성화 시 연한 파란색 */
    border-color: #aacfff;
    color: var(--white);
    cursor: not-allowed;
}

.common-popup-footer .btn-cancel-popup {
    background: var(--white); /* #contents #modalpop .btns button.gray background 와 동일 */
    color: #555; /* #contents #modalpop .btns button.gray color:#888 보다 진하게 */
    border: 1px solid #ccc; /* #contents #modalpop .btns button.gray border 와 유사 */
}

.common-popup-footer .btn-cancel-popup:hover {
    background: #f0f0f0; /* 약간의 호버 효과 */
    border-color: #bbb;
}

.datagrid-form-layout {
    padding: 20px 18px;
    background: var(--white);
}

.datagrid-form-layout h4 {
    padding-bottom: 12px;
    color: #222;
}

.datagrid-form-layout h4 i {
    display: inline-block;
    vertical-align: middle;
    padding-right: 4px;
}

.datagrid-form-layout h4 span {
    display: inline-block;
    vertical-align: middle;
}

#contents .summary_wrap {
    padding: 18px 20px; /* #contents .search 와 유사하게, 내부 콘텐츠 여백 확보 */
    margin-bottom: 20px; /* 테이블과의 간격 */
    border-radius: 10px; /* #contents .search, .pages 와 동일 */
    background: var(--white); /* #contents .search, .pages 와 동일 */
    box-shadow: 0 2px 5px 0 rgba(0, 0, 0, 0.05); /* #contents .search, .pages 와 동일 */
}

#contents .summary_wrap .summary_title {
    font-size: 1.15em; /* #contents .pages .tbl.form h4 span (1em) 보다 약간 크게 */
    font-weight: 700;
    color: #333; /* 기본 제목 색상 */
    padding-bottom: 10px;
    margin-bottom: 15px;
    border-bottom: 1px solid var(--input-line); /* #contents .search .btns border-top 과 유사 */
}

#contents .summary_wrap .summary_list {
    display: flex;
    flex-wrap: wrap; /* 항목이 많아지면 다음 줄로 */
    gap: 15px 25px; /* row-gap column-gap (세로 간격, 가로 간격) */
    list-style: none;
    padding: 0;
    margin: 0;
}

#contents .summary_wrap .summary_item {
    font-size: 0.92em; /* #contents .search .btns button font-size 와 유사 */
    color: #555;
    display: flex;
    align-items: baseline; /* 레이블과 값의 baseline 정렬 */
}

#contents .summary_wrap .summary_item .label {
    font-weight: 500; /* #contents .search .wrap > div label font-weight 와 동일 */
    color: #4a4a4a; /* #contents .search .wrap > div label color 보다 약간 진하게 */
    margin-right: 8px;
}

#contents .summary_wrap .summary_item .value {
    font-weight: 700; /* 강조 */
    color: var(--keyblue); /* 주요 값은 포인트 색상 사용 */
    font-size: 1.05em; /* 값을 약간 더 크게 */
}

#contents .summary_wrap .summary_item .unit {
    font-size: 0.9em; /* 단위는 값보다 약간 작게 */
    color: #666;
    margin-left: 3px;
}

#contents .info-box {
    background-color: #ffffff;
    padding: 24px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08);
    margin-bottom: 30px;
}

#contents .info-box h3 {
    padding-bottom: 20px;
    font-size: 1.25em;
    font-weight: 700;
}

#contents .info-box .con + h3 {
    padding-top: 32px;
}

#contents .info-box .tbl table {
    width: 100%;
}

#contents .info-box .tbl table th,
#contents .info-box .tbl table td {
    padding: 8px;
    border: 1px solid #cccfdc;
}

#contents .info-box .tbl table th {
    font-size: 0.92em;
    font-weight: 500;
    text-align: center;
    background: var(--th-background);
    color: #525567;
}

#contents .info-box button {
    display: block;
    height: 31px;
    padding: 0 12px;
    border-radius: 3px;
    font-size: 0.92em;
    background: var(--white);
    cursor: pointer;
}

#contents .info-box button.blue {
    background: var(--keyblue);
    color: var(--white);
}

.preserve-whitespace {
    white-space: pre-wrap;
}

/* 메인 페이지 공지 팝업 스타일 */
.notice-popup-overlay {
    display: none;
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background: rgba(0, 0, 0, 0.6); /* #overlay 보다 약간 어둡게 설정 */
    z-index: 1010; /* 다른 팝업보다 위에 오도록 조정 */
}

.notice-popup-modal {
    display: none;
    position: fixed;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
    width: 500px;
    max-width: 90%;
    background: var(--white);
    z-index: 1011;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.08); /* .info-box 와 유사한 그림자 */
}

.notice-popup-modal h3 {
    font-size: 1.25em; /* #modalpop h3 와 동일 */
    font-weight: 700; /* #modalpop h3 와 동일 */
    margin-top: 0;
    margin-bottom: 15px;
    padding-bottom: 10px;
    border-bottom: 1px solid var(--input-line); /* CSS 변수 사용 */
}

.notice-popup-modal .content {
    margin-bottom: 20px;
    max-height: 400px;
    overflow-y: auto;
    /* white-space: pre-wrap; 는 .preserve-whitespace 클래스로 대체 */
}

.notice-popup-modal .popup-footer {
    text-align: right;
}

.notice-popup-modal .popup-footer button {
    display: inline-block;
    height: 36px;
    line-height: 34px; /* for 1px border */
    padding: 0 16px;
    font-size: 0.92em;
    font-weight: 500;
    border-radius: 3px;
    cursor: pointer;
    border: 1px solid;
    transition: background-color 0.2s, border-color 0.2s;
}

.notice-popup-modal .popup-footer .btn_submit {
    background-color: var(--keyblue);
    color: var(--white);
    border-color: var(--keyblue);
}

.notice-popup-modal .popup-footer .btn_clear {
    background-color: #f2f2f2;
    color: #333;
    border-color: #ddd;
}

.notice-popup-modal .popup-footer .close-today {
    margin-right: 8px; /* .btns gap 과 유사하게 */
}