@charset "UTF-8";

/* 모달 스타일 */
.modal {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  overflow: hidden;
  background-color: rgba(0, 0, 0, 0.3);
  z-index: var(--z-index-modal);
}

/* 텍스트 선택 방지 */
.modal.fade {
  user-select: none;
  -webkit-user-select: none;
  -ms-user-select: none;
}

/* 모달 content 박스 */
.modal-content {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background-color: var(--color-white);
  border-radius: var(--border-radius-large);
  max-width: 90%; /* 화면의 너비보다 커지지 않도록 최대 너비 설정 */
  max-height: 90%; /* 화면의 높이보다 커지지 않도록 최대 높이 설정 */
  overflow-y: auto; /* 내용이 넘칠 경우 세로 스크롤바 표시 */
}

/* 로딩 모달 스타일 */
.loading-overlay {
  display: none;
  position: fixed;
  left: 0;
  top: 0;
  width: 100%;
  height: 100%;
  background-color: rgba(0, 0, 0, 0.5);
  z-index: var(--z-index-tooltip);
}

.loading-gif {
  width: 100px;
  height: 100px;
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

/* 닫기 버튼 스타일 */
.close-modal {
  position: absolute;
  top: 30px;
  right: 50px;
  font-size: 36px;
  color: #cfcfcf;
  cursor: pointer;
}

/* popup */
/* 파일 목록 스타일 */
.selectorBtn_box {
  display: flex;
  flex-wrap: wrap;
  column-gap: 10px;
  width: 100%;
}

.selectorBtn_box .selectorBtn {
  position: relative;
  padding: 10px 35px 10px 20px;
  margin-top: 10px;
  background-color: #ededed;
  border-radius: var(--border-radius-large);
  font-weight: 500;
  cursor: pointer;
}

.selectorBtn_box .xBtn {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
}

.xBtn {
  padding: 5px; /* 버튼의 여백 */
  cursor: pointer; /* 클릭 가능하다는 커서 스타일 */
}

/* 팝업 버튼 박스(단일) */
.popup-btnBox {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  margin-top: 16px;
}

/* 팝업 버튼 박스(복합) */
.popup-btnBox_left {
  display: flex;
  justify-content: flex-start;
  gap: 8px;
}
.popup-btnBox_right {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
}

.popup_flex_td {
  display: flex;
  flex-wrap: wrap;
  width: 100%;
}

/* popup_table */
.popup-wrapper {
  padding: 40px;
  overflow-x: auto;
}

.popup_title {
  font-size: 28px;
  font-weight: 500;
  margin-bottom: 20px;
}

.popup_table {
  width: 100%;
  border-spacing: 6px 4px;
}

.popup_table.tb_fixed {
  table-layout: fixed;
}

.popup_table tr {
  border-collapse: collapse;
  width: 100%;
  /* margin-top: 20px; */
  border: none;
}

.popup_table th {
  color: #1c4004;
  font-weight: 600;
  font-size: 14px;
  /* background-color: var(--color-secondary-green); */
  background-color: var(--color-background-gray);
  border-radius: var(--border-radius-medium);
  width: 20%;
  min-width: 100px;
  text-align: left;
  padding: 16px 24px;
}

.popup_table tr td {
  padding: 4px 0;
}

.popup_table .tb_text {
  display: block;
  width: 100%;
  min-height: 40px; /* 원하는 최소 높이 설정 */
  padding: 13px;
  border: 1px solid var(--color-border-gray);
  border-radius: var(--border-radius-medium);
  text-align: left;
}

.popup_table .align_center {
  text-align: center;
}

.popup_table input,
.popup_table select,
.popup_table textarea {
  width: 100%;
}

.popup_table input[type="radio"] {
  width: fit-content;
}

.popup_table option {
  display: block;
  min-height: 1.2em;
  padding: 0px 2px 1px;
  white-space: nowrap;
}

.popup_table label {
  display: block;
}

.pointRed {
  color: var(--color-system-point);
}

.popup_flex {
  display: flex;
  align-items: center;
  gap: 5px 10px;
}

.popup_flex--date .date_item {
  width: calc(50% - 5px);
  text-align: left;
}

.popup_flex--date .date_item label {
  padding: 0 0 10px 5px;
}

/*  팝업 하단 테이블 - 결재 처리 이력 */
.popup_data_table {
  width: 100%;
  border-collapse: collapse;
  text-align: center;
}

.popup_data_table th {
  padding: 15px 10px;
  background-color: var(--color-secondary-green);
  border-bottom: 1px solid var(--color-primary-green-100);
  font-weight: 600;
  white-space: nowrap;
}

.popup_data_table td {
  padding: 18px 10px;
  border-bottom: 1px solid var(--color-disabled-bg);
  box-sizing: border-box;
}

/* No 셀 width 지정 */
.popup_data_table td.td_num {
  width: 65px;
}

/* 비고 셀 width 지정 */
.popup_data_table td.td_note {
  width: 300px;
}

/* 날짜 셀 width 지정 */
.popup_data_table td.td_date {
  width: 150px;
}

/* popBtn */
.registerBtn_popup {
  background-color: var(--color-primary-green-100);
  padding: 12px 30px;
  border-radius: var(--border-radius-medium);
  color: var(--color-white);
  display: flex;
}

/* 행 추가 버튼 생성 */
.rowAddBtnTd {
  padding: 6px 0;
  background-color: var(--color-background-gray);
  border-radius: 0;
  text-align: center;

  cursor: pointer;
}

.rowAddBtnTd button img {
  vertical-align: middle;
}

/* 행 삭제 버튼 생성 */
.dynamicRow,
.rowDelTd {
  position: relative;
}

.dynamicRow .rowDelBtn,
.rowDelTd button {
  width: 24px;
  height: 24px;
  position: absolute;
  top: 50%;
  left: calc(100% + 4px);
  transform: translateY(-50%);
}

/* 파일 업로드 */
.file_upload_wrap {
  display: flex;
  align-items: center;
  column-gap: 10px;
}

.file_upload_wrap .file_content {
  width: calc(100% - 130px);
  height: 40px;
  line-height: 40px;
  padding: 0 20px;
  border: 1px solid var(--color-border-gray);
  background-color: var(--color-white);
  border-radius: var(--border-radius-small);
  overflow: hidden;
}

.file_upload_wrap .file_label {
  width: 120px;
  height: 40px;
  line-height: 39px;
  font-weight: 500;
  background-color: var(--color-white);
  border: 1px solid var(--color-primary-blue-100);
  border-radius: var(--border-radius-medium);
  text-align: center;
  cursor: pointer;
  flex-shrink: 0;
}

.file_upload_wrap .file_input {
  display: none;
}

.file_list_box,
.file_txt_list_box {
  width: 100%;
  gap: 10px;

  display: flex;
  flex-wrap: wrap;

  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;

  padding: 10px 0;
  margin-right: 2px;
}

.file_list_item {
  position: relative;
  width: 100%;
  max-width: fit-content;
  line-height: 34px;
  padding: 0 40px 0 20px;
  background-color: #ededed;
  border-radius: var(--border-radius-large);
}

.file_list_item .file_item_name {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  word-wrap: normal;
}

.file_list_item .file_item_btn {
  position: absolute;
  top: 50%;
  right: 10px;
  width: 24px;
  height: 24px;
  margin-top: -12px;
}
