/* ============================================================
   산지니 승인요청 게시판 — Claude.ai 스타일 UI
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');

:root {
  --cl-bg:       #f5f4ef;
  --cl-surface:  #ffffff;
  --cl-surface-2:#f9f8f5;
  --cl-border:   #e8e6df;
  --cl-border-2: #d4d0c8;
  --cl-text:     #1a1a18;
  --cl-text-2:   #4a4a46;
  --cl-text-3:   #7a7a74;
  --cl-accent:   #da7756;
  --cl-accent-2: #c4613d;
  --cl-accent-bg:#fdf0ec;
  --st-wait-bg:  #fdf5e4; --st-wait-bd:  #e8c97a; --st-wait-tx:  #7a5010;
  --st-ok-bg:    #e8f5ee; --st-ok-bd:    #7ec8a0; --st-ok-tx:    #1f6b42;
  --st-rj-bg:    #faedeb; --st-rj-bd:    #e8a898; --st-rj-tx:    #a83020;
  --st-pn-bg:    #edf0fa; --st-pn-bd:    #9daee8; --st-pn-tx:    #2a3ea0;
  --r-sm: 8px; --r: 12px; --r-lg: 16px;
  --sh-sm: 0 1px 3px rgba(0,0,0,.06),0 1px 2px rgba(0,0,0,.04);
  --sh:    0 4px 12px rgba(0,0,0,.08),0 1px 4px rgba(0,0,0,.04);
  --sh-lg: 0 8px 24px rgba(0,0,0,.10),0 2px 8px rgba(0,0,0,.06);
  --font: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
}

.sanjini_write*,.sanjini_list*,.sanjini_view*,.sj_modal_wrap*{box-sizing:border-box;font-family:var(--font)}

/* ── 버튼 ── */
.sj_btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;cursor:pointer;text-decoration:none;border:1px solid transparent;transition:all .15s;white-space:nowrap}
.sj_btn_primary{background:var(--cl-accent);color:#fff;border-color:var(--cl-accent)}
.sj_btn_primary:hover{background:var(--cl-accent-2);border-color:var(--cl-accent-2);color:#fff}
.sj_btn_secondary{background:var(--cl-surface);color:var(--cl-text-2);border-color:var(--cl-border-2)}
.sj_btn_secondary:hover{background:var(--cl-surface-2);color:var(--cl-text)}
.sj_btn_danger{background:#fff;color:var(--st-rj-tx);border-color:var(--st-rj-bd)}
.sj_btn_danger:hover{background:var(--st-rj-bg)}
.sj_btn_cancel{background:transparent;color:var(--cl-text-3);border-color:var(--cl-border)}
.sj_btn_cancel:hover{background:var(--cl-surface-2);color:var(--cl-text-2)}
.sj_btn_submit{background:var(--cl-accent);color:#fff;font-size:14px;padding:10px 24px;font-weight:600}
.sj_btn_submit:hover{background:var(--cl-accent-2);color:#fff}
.sj_btn_sm{padding:5px 11px;font-size:12.5px}
.sj_btn_admin{background:var(--cl-surface-2);color:var(--cl-text-3);border-color:var(--cl-border)}

/* ── 입력 ── */
.sj_input,.frm_input.sj_input{width:100%;padding:9px 13px;border:1px solid var(--cl-border-2);border-radius:var(--r-sm);font-size:14px;color:var(--cl-text);background:var(--cl-surface);transition:border-color .15s,box-shadow .15s;outline:none}
.sj_input:focus,.frm_input.sj_input:focus{border-color:var(--cl-accent);box-shadow:0 0 0 3px rgba(218,119,86,.15)}
.sj_select{appearance:none;-webkit-appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237a7a74' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}
.sj_select_sm{padding:7px 32px 7px 11px;font-size:13px;border:1px solid var(--cl-border-2);border-radius:var(--r-sm);background-color:var(--cl-surface);color:var(--cl-text-2);cursor:pointer;appearance:none;-webkit-appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237a7a74' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center}

/* ── 배지 ── */
.sj_badge{display:inline-flex;align-items:center;gap:4px;padding:3px 10px;border-radius:99px;font-size:12px;font-weight:600;white-space:nowrap;border:1px solid}
.sj_badge_lg{padding:5px 14px;font-size:13px}
.badge_wait  {background:var(--st-wait-bg);color:var(--st-wait-tx);border-color:var(--st-wait-bd)}
.badge_ok    {background:var(--st-ok-bg);  color:var(--st-ok-tx);  border-color:var(--st-ok-bd)}
.badge_reject{background:var(--st-rj-bg);  color:var(--st-rj-tx);  border-color:var(--st-rj-bd)}
.badge_pnumall{background:var(--st-pn-bg); color:var(--st-pn-tx);  border-color:var(--st-pn-bd)}

/* ── 카드 ── */
.sj_section{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);padding:24px 28px;margin-bottom:16px;box-shadow:var(--sh-sm)}
.sj_section_title{font-size:14px;font-weight:600;color:var(--cl-text);margin:0 0 18px;display:flex;align-items:center;gap:10px;padding-bottom:14px;border-bottom:1px solid var(--cl-border)}
.sj_step{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--cl-accent);color:#fff;font-size:11px;font-weight:700;flex-shrink:0}
.req{color:var(--cl-accent);font-weight:600}
.sj_grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.sj_grid > .sj_field:not(.half){grid-column:span 2}
.sj_grid > .sj_field.sj_file_field{grid-column:span 2}
.sj_field{display:flex;flex-direction:column;gap:5px}
.sj_field label{font-size:13px;font-weight:500;color:var(--cl-text-2)}

/* ═══ WRITE ═══ */
.sanjini_write{max-width:780px;margin:0 auto;padding:24px 16px;background:var(--cl-bg);min-height:100vh}
.sj_write_header{margin-bottom:20px}
.sj_logo_badge{display:flex;align-items:center;gap:14px;padding:18px 24px;border-radius:var(--r-lg);background:var(--cl-surface);border:1px solid var(--cl-border);margin-bottom:12px;box-shadow:var(--sh-sm)}
.sj_icon{font-size:36px;line-height:1}
.sj_title{font-size:18px;font-weight:700;color:var(--cl-text);margin:0 0 2px}
.sj_subtitle{font-size:13px;color:var(--cl-text-3);margin:0}
.sj_notice_box{background:var(--cl-accent-bg);border:1px solid #f4c4b4;border-radius:var(--r-sm);padding:12px 16px;font-size:13px;color:var(--cl-accent-2)}
.sj_notice_box strong{display:block;margin-bottom:5px;font-weight:600}
.sj_notice_box ul{margin:0;padding-left:16px}
.sj_notice_box li{margin-bottom:2px;line-height:1.6}
.sj_radio_group{display:flex;gap:10px;padding-top:2px}
.sj_radio_label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:13.5px;padding:8px 14px;border:1px solid var(--cl-border-2);border-radius:var(--r-sm);background:var(--cl-surface);transition:all .15s;flex:1;justify-content:center}
.sj_radio_label input[type="radio"]{accent-color:var(--cl-accent)}
.sj_radio_label.checked{border-color:var(--cl-accent);background:var(--cl-accent-bg);color:var(--cl-accent-2);font-weight:500}
.sj_pnumall_notice{margin-top:12px;padding:11px 14px;background:var(--cl-surface-2);border:1px solid var(--cl-border);border-radius:var(--r-sm);font-size:12.5px;color:var(--cl-text-3)}
.sj_pnumall_notice strong{color:var(--cl-text-2)}
.tooltip_icon{cursor:help;font-size:12px}
.sj_file_tip{font-size:12px;color:var(--cl-text-3);font-weight:400}
.sj_file_wrap{display:flex;flex-direction:column;gap:6px}
.sj_file_input{padding:6px 0;font-size:13px}
.sj_existing_file{display:flex;align-items:center;gap:10px;padding:7px 11px;background:var(--cl-surface-2);border:1px solid var(--cl-border);border-radius:var(--r-sm);font-size:13px}
.sj_file_name{color:var(--cl-text-2);flex:1;font-size:12.5px}
.sj_file_del_label{cursor:pointer;color:var(--st-rj-tx);font-size:12px}
.sj_btn_wrap{display:flex;justify-content:flex-end;gap:10px;padding:20px 0 8px}
.sj_status_section{border-color:var(--st-wait-bd) !important;background:var(--st-wait-bg) !important}

/* ═══ LIST ═══ */
.sanjini_list{max-width:1100px;margin:0 auto;padding:24px 16px;background:var(--cl-bg);min-height:100vh}
.sj_list_header{display:flex;align-items:center;justify-content:space-between;padding:18px 24px;background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);margin-bottom:16px;box-shadow:var(--sh-sm);flex-wrap:wrap;gap:12px}
.sj_list_header_inner{display:flex;align-items:center;gap:14px}
.sj_list_icon{font-size:32px;line-height:1}
.sj_list_title{font-size:17px;font-weight:700;color:var(--cl-text);margin:0 0 2px}
.sj_list_desc{font-size:12.5px;color:var(--cl-text-3);margin:0}
.sj_status_legend{display:flex;gap:6px;flex-wrap:wrap}
.sj_list_topbar{display:flex;align-items:center;justify-content:space-between;padding:10px 0;margin-bottom:6px;flex-wrap:wrap;gap:8px}
.sj_total_count{font-size:13px;color:var(--cl-text-3)}
.sj_total_count strong{color:var(--cl-text);font-weight:600}
.sj_topbar_btns{display:flex;gap:7px;flex-wrap:wrap}
.sj_cat_filter{border-bottom:1px solid var(--cl-border);margin-bottom:18px;padding-bottom:0}
.sj_cat_filter ul{list-style:none;margin:0;padding:0;display:flex;gap:0}
.sj_cat_filter a{display:block;padding:8px 16px;font-size:13.5px;font-weight:500;color:var(--cl-text-3);text-decoration:none;border-bottom:2px solid transparent;margin-bottom:-1px;transition:all .15s}
.sj_cat_filter a:hover{color:var(--cl-text);border-color:var(--cl-border-2)}
.sj_cat_filter a.active{color:var(--cl-accent);border-color:var(--cl-accent);font-weight:600}

/* 갤러리 */
/* ══ 갤러리 그리드 ══ */
.sj_gallery_grid{list-style:none;margin:0;padding:0;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px}
@media(max-width:1100px){.sj_gallery_grid{grid-template-columns:repeat(3,1fr)}}
@media(max-width:800px){.sj_gallery_grid{grid-template-columns:repeat(2,1fr)}}
@media(max-width:480px){.sj_gallery_grid{grid-template-columns:1fr}}

/* ── 카드 ── */
.sj_gall_item{
  background:var(--cl-surface);border:1px solid var(--cl-border);
  border-radius:14px;overflow:hidden;
  box-shadow:0 2px 8px rgba(0,0,0,.06);
  transition:box-shadow .18s,transform .18s;
  display:flex;flex-direction:column;position:relative;
}
.sj_gall_item:hover{box-shadow:0 6px 24px rgba(0,0,0,.12);transform:translateY(-3px)}
.sj_gall_notice{border-color:var(--cl-accent)}

/* ── 이미지 영역 ── */
.sj_gall_thumb_link{display:block;position:relative}
.sj_gall_thumb{ width:100%;background:#f0f0ee; display:flex;align-items:center;justify-content:center;height: 180px; overflow:hidden;}
.sj_gall_thumb img{ width:100%;height:100%;object-fit: cover;display:block;transition:transform .3s ease;}
.sj_gall_item:hover .sj_gall_thumb img{transform:scale(1.04)}
.sj_gall_no_img{
  width:100%;min-height:180px;
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:linear-gradient(135deg,#f5f4f0,#ebe9e4);
  color:var(--cl-text-3);font-size:28px;text-align:center;line-height:1.5;
}
.sj_gall_no_img small{font-size:11px;display:block;color:var(--cl-text-3);margin-top:6px}
.sj_gall_notice_img{background:linear-gradient(135deg,var(--cl-accent-bg),#fde8e0);color:var(--cl-accent)}

/* 상태 뱃지: 좌상단 오버레이 */
.sj_gall_badge_overlay{
  position:absolute;top:10px;left:10px;z-index:2;
  filter:drop-shadow(0 1px 3px rgba(0,0,0,.18));
}

/* NEW 태그: 우상단 */
.sj_gall_new_tag{
  position:absolute;bottom:10px;right:10px;z-index:2;
  background:var(--cl-accent);color:#fff;
  font-size:10px;font-weight:700;
  padding:3px 8px;border-radius:5px;
  letter-spacing:.5px;
}

/* 체크박스: 우상단 원형 */
.sj_gall_chk_circle{
  position:absolute;top:12px;right:12px;z-index:4;
  width:26px;height:26px;cursor:pointer;
}
.sj_gall_chk_circle input{position:absolute;opacity:0;width:0;height:0}
.sj_chk_ring{
  display:flex;align-items:center;justify-content:center;
  width:26px;height:26px;border-radius:50%;
  background:rgba(255,255,255,.85);
  border:2px solid var(--cl-border-2);
  transition:all .13s;backdrop-filter:blur(2px);
}
.sj_gall_chk_circle input:checked ~ .sj_chk_ring{
  background:var(--cl-accent);border-color:var(--cl-accent);
}
.sj_chk_ring::after{
  content:'';display:none;
  width:6px;height:10px;
  border:2px solid #fff;border-top:none;border-left:none;
  transform:rotate(45deg) translate(-1px,-1px);
}
.sj_gall_chk_circle input:checked ~ .sj_chk_ring::after{display:block}

/* ── 카드 본문 ── */
.sj_gall_body{
  padding:12px 14px 12px;
  flex:1;display:flex;flex-direction:column;gap:8px;
  border-top:1px solid var(--cl-border);
}
.sj_gall_title{
  font-size:14px;font-weight:700;color:var(--cl-text);
  text-decoration:none;line-height:1.4;
  display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden;
}
.sj_gall_title:hover{color:var(--cl-accent)}
.sj_cmt_cnt{color:var(--cl-accent);font-size:12px;font-weight:700;margin-left:3px}

/* 담당자 행 */
.sj_gall_person{
  display:flex;align-items:center;gap:8px;
  font-size:12.5px;color:var(--cl-text-2);flex-wrap:wrap;
}
.sj_person_name{display:flex;align-items:center;gap:4px;font-weight:500}
.sj_person_contact{
  background:var(--cl-bg);border:1px solid var(--cl-border);
  border-radius:99px;padding:1px 9px;font-size:12px;color:var(--cl-text-3);
}

/* 하단 태그 + 날짜 */
.sj_gall_footer{
  display:flex;align-items:center;justify-content:space-between;
  margin-top:auto;padding-top:8px;border-top:1px solid var(--cl-border);
  gap:6px;
}
.sj_gall_tags{display:flex;gap:5px;flex-wrap:wrap}
.sj_gall_tag{font-size:11px;padding:2px 8px;border-radius:99px;font-weight:500;border:1px solid;display:flex;align-items:center;gap:3px}
.sj_tag_dept{background:#eef2fe;color:var(--st-pn-tx);border-color:#c0d0f8}
.sj_tag_type{background:var(--cl-accent-bg);color:var(--cl-accent-2);border-color:#f4c4b4}
.sj_tag_file{background:var(--cl-surface-2);color:var(--cl-text-3);border-color:var(--cl-border-2)}
.sj_gall_date{font-size:11.5px;color:var(--cl-text-3);white-space:nowrap;flex-shrink:0;margin-left:auto}

/* 1행: 태그+제목+상태 */
/* 신청 제목 행 */
.sj_gall_subject_row{padding:0 0 8px;border-bottom:none;margin-bottom:0}
.sj_gall_subject{display:block;font-size:15px;font-weight:700;color:var(--cl-text-1);text-decoration:none;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;line-height:1.5}
.sj_gall_subject:hover{color:var(--cl-accent)}
/* 학과+타입 행: subject 있을 때 위 패딩 */
.sj_gall_subject_row + .sj_gall_title_row{padding-top:0;margin-top:0}
.sj_gall_title_row{display:flex;align-items:center;gap:6px;padding-bottom:7px;border-bottom:0.5px solid var(--cl-border)}
.sj_gall_title_row .sj_gall_title{font-size:14px;font-weight:500;color:var(--cl-text-1);text-decoration:none;flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
/* 2행: 담당자 */
.sj_gall_person{display:flex;align-items:center;gap:6px;margin-top:7px;font-size:12px;color:var(--cl-text-3);flex-wrap:wrap}
.sj_person_sep{color:var(--cl-border-2)}
.sj_person_contact{color:var(--cl-text-3)}

/* 진행상태 뱃지 */
.sj_period_badge  {font-size:11px;font-weight:700;padding:2px 9px;border-radius:99px;white-space:nowrap;flex-shrink:0;margin-left:auto}
.sj_period_on     {background:#E6F1FB;color:#185FA5;border:0.5px solid #B5D4F4}
.sj_period_before {background:#EEEDFE;color:#3C3489;border:0.5px solid #AFA9EC}
.sj_period_over   {background:#f0f0f0;color:#888;border:0.5px solid #ddd}

.sj_gallery_empty{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);color:var(--cl-text-3)}
.sj_empty_icon{font-size:44px;display:block;line-height:1}.sj_empty_icon img{width:64px;height:64px;object-fit:contain}
.sj_gallery_empty p{font-size:14px;margin:0}

/* 검색 */
.sj_sch_wrap .bo_sch{padding:14px 18px;background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r);margin-bottom:12px;display:flex;align-items:center;gap:8px;flex-wrap:wrap}
.sj_sch_wrap .bo_sch form{display:flex;align-items:center;gap:8px;flex-wrap:wrap;width:100%}
.sj_sch_bar{display:flex;gap:6px;flex:1;align-items:center}
.sj_sch_bar .sj_input{flex:1}
.sj_sch_close{background:none;border:1px solid var(--cl-border);border-radius:var(--r-sm);padding:5px 10px;font-size:12px;cursor:pointer;color:var(--cl-text-3);transition:all .15s}
.sj_sch_close:hover{background:var(--cl-surface-2)}

/* ═══ VIEW ═══ */
.sanjini_view{max-width:840px;margin:0 auto;padding:24px 16px;background:var(--cl-bg);min-height:100vh}
.sj_view_status_bar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:12px 18px;border-radius:var(--r-sm);margin-bottom:16px;font-size:13px;border:1px solid;background:var(--st-wait-bg);border-color:var(--st-wait-bd)}
.sj_status_bar_left{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}
.sj_btn_status_change{background:rgba(255,255,255,.7);border:1px solid rgba(0,0,0,.12);color:var(--cl-text-2);font-size:12px;padding:5px 12px;border-radius:99px;cursor:pointer;transition:all .15s;white-space:nowrap;flex-shrink:0}
.sj_btn_status_change:hover{background:#fff;color:var(--cl-accent);border-color:var(--cl-accent)}
.sj_view_status_bar.status_ok    {background:var(--st-ok-bg); border-color:var(--st-ok-bd)}
.sj_view_status_bar.status_reject{background:var(--st-rj-bg); border-color:var(--st-rj-bd)}
.sj_view_status_bar.status_pnumall{background:var(--st-pn-bg);border-color:var(--st-pn-bd)}
.sj_view_status_date{color:var(--cl-text-3);font-size:12.5px}
.sj_pnumall_msg{color:var(--st-pn-tx);font-weight:500;font-size:12.5px}
.sj_view_header{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.sj_view_title{font-size:20px;font-weight:700;color:var(--cl-text);margin:0 0 12px;line-height:1.4}
.sj_view_meta{display:flex;gap:14px;flex-wrap:wrap;font-size:12.5px;color:var(--cl-text-3)}
.sj_view_meta span{display:flex;align-items:center;gap:4px}
.sj_view_btns{display:flex;gap:7px;align-items:center;margin-bottom:16px;flex-wrap:wrap}
.sj_view_btn_right{margin-left:auto;display:flex;gap:7px}
.sj_view_summary{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);margin-bottom:14px;overflow:hidden;box-shadow:var(--sh-sm)}
.sj_summary_grid{display:grid;grid-template-columns:1fr 1fr}
.sj_summary_item{padding:13px 20px;border-bottom:1px solid var(--cl-border);display:flex;flex-direction:column;gap:3px}
.sj_summary_item:nth-child(odd){border-right:1px solid var(--cl-border)}
.sj_summary_full{grid-column:span 2}
.sj_summary_label{font-size:11px;color:var(--cl-text-3);font-weight:500;text-transform:uppercase;letter-spacing:.5px}
.sj_summary_value{font-size:13.5px;color:var(--cl-text);font-weight:500}
.sj_summary_value.sj_highlight{color:var(--cl-accent);font-weight:600}
.sj_summary_value.sj_yes{color:var(--st-ok-tx);font-weight:600}
.sj_summary_value.sj_no{color:var(--st-rj-tx)}
#bo_v_con{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);padding:22px 24px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.sj_section_title_sm{font-size:13px;font-weight:600;color:var(--cl-text-2);margin:0 0 14px;padding-bottom:10px;border-bottom:1px solid var(--cl-border)}
.sj_view_content{font-size:14.5px;line-height:1.8;color:var(--cl-text);min-height:60px}
.sj_view_content img{max-width:100%;height:auto;border-radius:var(--r-sm)}

/* 이미지 갤러리 */
.sj_view_img_gallery{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);padding:20px 24px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.sj_img_grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin-top:12px}
.sj_img_item{border-radius:var(--r-sm);overflow:hidden;border:1px solid var(--cl-border);background:var(--cl-bg)}
.sj_img_link{display:block}
.sj_img_link img,.sj_inline_img{width:100%;display:block;max-height:260px;object-fit:cover;transition:opacity .2s}
.sj_img_link:hover img,.sj_img_link:hover .sj_inline_img{opacity:.85}
.sj_img_link > div img{width:100%;max-height:260px;object-fit:cover;display:block}
.sj_img_filename{padding:6px 10px;font-size:11px;color:var(--cl-text-3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin:0;background:var(--cl-surface-2)}

/* 파일 */
.sj_view_files{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);padding:18px 24px;margin-bottom:14px;box-shadow:var(--sh-sm)}
.sj_file_list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:8px}
.sj_file_item{display:flex;align-items:center;gap:10px;padding:10px 14px;background:var(--cl-surface-2);border:1px solid var(--cl-border);border-radius:var(--r-sm)}
.sj_file_type_badge{background:var(--cl-accent);color:#fff;padding:2px 9px;border-radius:4px;font-size:11px;font-weight:600;white-space:nowrap}
.sj_file_link{color:var(--cl-text-2);text-decoration:none;font-size:13.5px;font-weight:500;flex:1;display:flex;align-items:center;gap:6px}
.sj_file_link:hover{color:var(--cl-accent)}
.sj_file_size{color:var(--cl-text-3);font-size:12px}

/* 관리자 패널 */
.sj_admin_panel{background:#fffbf5;border:1px solid #f4c4b4;border-radius:var(--r-lg);padding:18px 22px;margin-bottom:14px}
.sj_admin_panel_title{font-size:13.5px;font-weight:600;color:var(--cl-accent-2);margin:0 0 6px}
.sj_admin_guide{font-size:12.5px;color:var(--cl-text-3);margin:0 0 12px}
.sj_admin_status_btns{display:flex;align-items:center;gap:12px;flex-wrap:wrap}

/* 이전/다음 */
.sj_prevnext{background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);overflow:hidden;margin-bottom:14px;box-shadow:var(--sh-sm)}
.sj_pn_item{display:flex;align-items:center;gap:14px;padding:12px 20px;border-bottom:1px solid var(--cl-border);font-size:13.5px}
.sj_pn_item:last-child{border-bottom:none}
.sj_pn_label{color:var(--cl-text-3);font-size:12px;font-weight:500;min-width:36px}
.sj_pn_item a{color:var(--cl-text-2);text-decoration:none;flex:1}
.sj_pn_item a:hover{color:var(--cl-accent)}

/* ═══ 모달 ═══ */
.sj_modal_wrap{position:fixed;inset:0;z-index:9999;display:flex;align-items:center;justify-content:center}
.sj_modal_overlay{position:absolute;inset:0;background:rgba(26,26,24,.4);backdrop-filter:blur(4px)}
.sj_modal_box{position:relative;z-index:1;background:var(--cl-surface);border:1px solid var(--cl-border);border-radius:var(--r-lg);width:100%;max-width:460px;margin:16px;box-shadow:var(--sh-lg);overflow:hidden;animation:sj_in .18s ease}
@keyframes sj_in{from{transform:scale(.94) translateY(8px);opacity:0}to{transform:none;opacity:1}}
.sj_modal_header{display:flex;align-items:center;justify-content:space-between;padding:18px 22px 14px;border-bottom:1px solid var(--cl-border)}
.sj_modal_header h3{font-size:16px;font-weight:700;color:var(--cl-text);margin:0}
.sj_modal_close{background:var(--cl-surface-2);border:1px solid var(--cl-border);border-radius:50%;width:30px;height:30px;font-size:13px;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--cl-text-3);transition:all .15s}
.sj_modal_close:hover{background:var(--cl-bg);color:var(--cl-text)}
.sj_modal_body{padding:18px 22px}
.sj_modal_desc{font-size:13px;color:var(--cl-text-3);margin:0 0 14px;display:flex;align-items:center;gap:8px}
.sj_modal_status_btns{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.sj_status_btn{display:flex;flex-direction:column;align-items:center;gap:4px;padding:16px 10px;border-radius:var(--r);border:1.5px solid var(--cl-border);background:var(--cl-surface);cursor:pointer;transition:all .15s;text-align:center}
.sj_status_btn:hover{border-color:var(--cl-accent);background:var(--cl-accent-bg)}
.sj_status_btn.active{box-shadow:0 0 0 2px var(--cl-accent)}
.sj_status_btn .sj_status_icon{font-size:22px;line-height:1}
.sj_status_btn strong{font-size:13.5px;font-weight:600;color:var(--cl-text)}
.sj_status_btn small{font-size:11px;color:var(--cl-text-3)}
.sj_status_wait.active  {border-color:var(--st-wait-bd);background:var(--st-wait-bg)}
.sj_status_ok.active    {border-color:var(--st-ok-bd);  background:var(--st-ok-bg)}
.sj_status_reject.active{border-color:var(--st-rj-bd);  background:var(--st-rj-bg)}
.sj_status_pnumall.active{border-color:var(--st-pn-bd); background:var(--st-pn-bg)}
.sj_modal_footer{display:flex;justify-content:flex-end;gap:8px;padding:14px 22px;border-top:1px solid var(--cl-border);background:var(--cl-surface-2)}

/* ═══ 페이지네이션 ═══ */
.pg_wrap{display:flex;gap:4px;flex-wrap:wrap;justify-content:center;padding:16px 0 4px}
.pg_wrap a,.pg_wrap strong{display:inline-flex;align-items:center;justify-content:center;min-width:32px;height:32px;padding:0 8px;border:1px solid var(--cl-border);border-radius:var(--r-sm);font-size:13px;text-decoration:none;color:var(--cl-text-2);background:var(--cl-surface);transition:all .15s}
.pg_wrap strong{background:var(--cl-accent);color:#fff;border-color:var(--cl-accent);font-weight:700}
.pg_wrap a:hover{border-color:var(--cl-accent);color:var(--cl-accent)}

/* ═══ 반응형 ═══ */
@media(max-width:720px){
  .sj_grid{grid-template-columns:1fr}
  .sj_grid > .sj_field:not(.half){grid-column:span 1}
  .sj_grid > .sj_field.sj_file_field{grid-column:span 1}
  .sj_summary_grid{grid-template-columns:1fr}
  .sj_summary_item:nth-child(odd){border-right:none}
  .sj_summary_full{grid-column:span 1}
  .sj_view_btns{gap:5px}
  .sj_list_header{flex-direction:column;align-items:flex-start}
  .sj_view_header{padding:16px 18px}
  .sj_view_title{font-size:17px}
  .sj_section{padding:18px 16px}
  .sj_radio_group{flex-direction:column}
  .sj_cat_filter a{padding:8px 10px;font-size:12.5px}
}

/* ══════════════════════════════════════════
   앱 레이아웃: 사이드바 + 메인
══════════════════════════════════════════ */
/* ══════════════════════════════════════════
   앱 레이아웃
══════════════════════════════════════════ */
.sj_app_wrap {
  display: flex; min-height: 100vh;
  background: var(--cl-bg); font-family: var(--font);
}

/* ── 사이드바: 기본 220px(펼침), 접힘시 52px ── */
.sj_sidebar {
  width: 220px; min-height: 100vh; flex-shrink: 0;
  background: var(--cl-surface-2); border-right: 1px solid var(--cl-border);
  display: flex; flex-direction: column;
  position: sticky; top: 0; height: 100vh;
  transition: width .22s cubic-bezier(.4,0,.2,1);
  z-index: 100; overflow-y: auto; overflow-x: hidden;
}
/* 접힌 상태: 클릭으로 토글 (.sj_sidebar_collapsed) */
.sj_app_wrap.sj_sidebar_collapsed .sj_sidebar {
  width: 52px;
}

/* 텍스트/레이블: 기본 표시, 접히면 숨김 */
.sj_sidebar_name,
.sj_sidebar_section_label,
.sj_nav_label { opacity: 1; width: auto; overflow: hidden; white-space: nowrap; pointer-events: auto; transition: opacity .15s .05s, width .15s; }
.sj_app_wrap.sj_sidebar_collapsed .sj_sidebar_name,
.sj_app_wrap.sj_sidebar_collapsed .sj_sidebar_section_label,
.sj_app_wrap.sj_sidebar_collapsed .sj_nav_label {
  opacity: 0; width: 0; pointer-events: none;
}

/* 로고 */
.sj_sidebar_logo {
  display: flex; align-items: center; gap: 10px;
  padding: 14px 13px; border-bottom: 1px solid var(--cl-border);
  min-height: 52px; flex-shrink: 0;
}
.sj_sidebar_icon { font-size: 24px; line-height: 1; flex-shrink: 0; }
.sj_sidebar_name { font-size: 13.5px; font-weight: 700; color: var(--cl-text); }

/* 섹션 레이블 */
.sj_sidebar_section_label {
  font-size: 10px; font-weight: 700; letter-spacing: .9px;
  text-transform: uppercase; color: var(--cl-text-3);
  padding: 14px 14px 4px; height: 36px; display: flex; align-items: flex-end;
}

/* 네비 */
.sj_sidebar_nav { display: flex; flex-direction: column; padding: 4px 6px; gap: 1px; }
.sj_nav_item {
  display: flex; align-items: center; gap: 0;
  padding: 9px 0; border-radius: var(--r-sm);
  font-size: 13.5px; color: var(--cl-text-2); text-decoration: none;
  transition: background .13s, color .13s; font-weight: 500;
  cursor: pointer; border: none; background: none;
  min-height: 38px; justify-content: flex-start;
  overflow: hidden;
}
.sj_nav_item i {
  width: 40px; text-align: center; font-size: 15px; flex-shrink: 0;
}
.sj_nav_label {
  font-size: 13.5px; font-weight: 500;
}
.sj_nav_item:hover { background: var(--cl-border); color: var(--cl-text); }
.sj_nav_item.active { background: var(--cl-accent-bg); color: var(--cl-accent); font-weight: 600; }

/* 접힌 상태: 아이콘만 가운데 정렬 */
.sj_app_wrap.sj_sidebar_collapsed .sj_nav_item {
  justify-content: center;
}

.sj_nav_write {
  background: var(--cl-accent) !important; color: #fff !important;
  margin: 6px 0 2px;
}
.sj_nav_write:hover { background: var(--cl-accent-2) !important; }

/* 부산대몰 바로가기 */
.sj_nav_pnumall {
  background: #1a4fa0 !important; color: #fff !important;
  margin: 2px 0;
}
.sj_nav_pnumall:hover { background: #153d80 !important; }
.sj_app_wrap.sj_sidebar_collapsed .sj_nav_pnumall { justify-content: center; }

/* 사이드바 하단 푸터 */
.sj_sidebar_footer {
  margin-top: auto;
  padding: 14px 14px 10px;
  border-top: 1px solid var(--cl-border);
  display: flex; flex-direction: column; gap: 5px;
}
.sj_sidebar_footer_url {
  font-size: 11.5px; font-weight: 600;
  color: var(--cl-accent); text-decoration: none;
  letter-spacing: .02em;
}
.sj_sidebar_footer_url:hover { text-decoration: underline; }
.sj_sidebar_copyright {
  font-size: 10.5px; color: var(--cl-text-3);
  line-height: 1.6; margin: 0;
}
.sj_app_wrap.sj_sidebar_collapsed .sj_sidebar_footer { display: none; }

/* 상태 도트 */
.sj_status_dot_wait   { color: var(--st-wait-tx) !important; }
.sj_status_dot_ok     { color: var(--st-ok-tx) !important; }
.sj_status_dot_reject { color: var(--st-rj-tx) !important; }
.sj_status_dot_pnumall{ color: var(--st-pn-tx) !important; }

/* 모바일 닫기 버튼: 데스크탑에서 숨김 */
.sj_sidebar_close_btn { display: none; }

.sj_sidebar_pin_btn {
  margin: auto 6px 12px;
  background: none; border: 1px solid var(--cl-border); border-radius: var(--r-sm);
  width: 36px; height: 30px; cursor: pointer; font-size: 12px;
  display: flex; align-items: center; justify-content: center;
  color: var(--cl-text-3); transition: all .15s; flex-shrink: 0;
  opacity: 1; pointer-events: auto;
}
.sj_app_wrap.sj_sidebar_collapsed .sj_sidebar_pin_btn {
  opacity: 1; pointer-events: auto; color: var(--cl-accent); border-color: var(--cl-accent);
}
.sj_sidebar_pin_btn:hover { background: var(--cl-bg); }

/* ── 메인 영역 ── */
.sj_main_area { flex: 1; min-width: 0; display: flex; flex-direction: column; }

/* ── 상단바 ── */
.sj_topbar {
  height: 52px; display: flex; align-items: center; justify-content: space-between;
  padding: 0 20px; background: var(--cl-surface);
  border-bottom: 1px solid var(--cl-border);
  position: sticky; top: 0; z-index: 50; gap: 12px;
}
.sj_topbar_left  { display: flex; align-items: center; gap: 10px; min-width: 0; flex: 1; }
.sj_topbar_right { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.sj_topbar_title {
  font-size: 14px; font-weight: 600; color: var(--cl-text);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; 
}
.sj_topbar_count {
  font-size: 12px; color: var(--cl-text-3);
  background: var(--cl-bg); border: 1px solid var(--cl-border);
  padding: 2px 8px; border-radius: 99px; white-space: nowrap;
}
.sj_sidebar_toggle {
  background: none; border: none; cursor: pointer;
  width: 32px; height: 32px; border-radius: var(--r-sm);
  display: flex; align-items: center; justify-content: center;
  color: var(--cl-text-3); font-size: 15px; transition: all .15s;
}
.sj_sidebar_toggle:hover { background: var(--cl-bg); color: var(--cl-text); }
.sj_icon_btn {
  background: none; border: 1px solid var(--cl-border); border-radius: var(--r-sm);
  width: 32px; height: 32px; cursor: pointer; display: flex; align-items: center;
  justify-content: center; color: var(--cl-text-3); font-size: 13px; transition: all .15s;
}
.sj_icon_btn:hover { background: var(--cl-bg); color: var(--cl-text); border-color: var(--cl-border-2); }

/* 벌크바 */
.sj_bulk_bar { display: flex; align-items: center; gap: 10px; padding: 8px 0 12px; margin-bottom: 4px; }
.sj_check_all { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--cl-text-2); cursor: pointer; }
.sj_check_all input { accent-color: var(--cl-accent); width: 15px; height: 15px; }

/* 콘텐츠 */
.sj_content { flex: 1; padding: 24px 24px 40px; }
.sj_content_view { padding: 20px 24px 40px; }
.sj_content .sanjini_write { padding: 0; background: transparent; }
.sj_content_view .sanjini_view { padding: 0; background: transparent; }

/* ══ 모바일 ══ */
@media (max-width: 768px) {
  /* 사이드바: 숨김 → 슬라이드 인 */
  .sj_sidebar {
    position: fixed; left: -260px; top: 0; bottom: 0; width: 220px !important;
    transition: left .22s cubic-bezier(.4,0,.2,1); box-shadow: none; z-index: 300;
    overflow-y: auto;
  }
  /* 모바일에서는 항상 텍스트 표시 */
  .sj_sidebar .sj_sidebar_name,
  .sj_sidebar .sj_sidebar_section_label,
  .sj_sidebar .sj_nav_label { opacity: 1; width: auto; pointer-events: auto; }
  .sj_sidebar .sj_nav_item { justify-content: flex-start; }

  /* 열린 상태 */
  .sj_app_wrap.sj_sidebar_open .sj_sidebar {
    left: 0; box-shadow: 8px 0 24px rgba(0,0,0,.18);
  }
  /* 딤 오버레이 */
  .sj_sidebar_dim {
    display: none; position: fixed; inset: 0; background: rgba(0,0,0,.35);
    z-index: 299; backdrop-filter: blur(1px);
  }
  .sj_app_wrap.sj_sidebar_open .sj_sidebar_dim { display: block; }

  /* 모바일 닫기 버튼 */
  .sj_sidebar_close_btn {
    display: flex; align-items: center; justify-content: center;
    position: absolute; top: 12px; right: 12px;
    width: 28px; height: 28px; border-radius: 50%;
    background: var(--cl-bg); border: 1px solid var(--cl-border);
    color: var(--cl-text-3); font-size: 12px; cursor: pointer;
    transition: all .15s; z-index: 10;
  }
  .sj_sidebar_close_btn:hover { background: var(--cl-border); color: var(--cl-text); }
  /* 핀 버튼 모바일 숨김 */
  .sj_sidebar_pin_btn { display: none; }

  .sj_content, .sj_content_view { padding: 14px; }
  .sj_topbar { padding: 0 12px; }
  .sj_topbar_title { font-size: 13px; max-width: 160px; }
  .sj_gallery_grid { grid-template-columns: repeat(2,1fr); gap: 10px; }
}
@media (max-width: 480px) {
  .sj_gallery_grid { grid-template-columns: 1fr; }
}

/* ── 이미지 압축 미리보기 ── */
.sj_img_compress_preview {
  display: none; align-items: center; gap: 12px;
  margin-top: 8px; padding: 10px 12px;
  background: var(--cl-surface-2); border: 1px solid var(--cl-border);
  border-radius: var(--r-sm); flex-wrap: wrap;
}
.sj_prev_img {
  width: 72px; height: 54px; object-fit: cover;
  border-radius: var(--r-sm); border: 1px solid var(--cl-border);
  flex-shrink: 0;
}
.sj_prev_info {
  font-size: 12px; color: var(--cl-text-2); flex: 1; min-width: 140px;
  line-height: 1.6;
}
.sj_prev_clear {
  background: none; border: 1px solid var(--cl-border-2);
  border-radius: var(--r-sm); padding: 4px 10px;
  font-size: 12px; color: var(--cl-text-3); cursor: pointer;
  transition: all .13s; white-space: nowrap; flex-shrink: 0;
}
.sj_prev_clear:hover { background: var(--st-rj-bg); color: var(--st-rj-tx); border-color: var(--st-rj-tx); }

/* ── 탑바 로그인 영역 ── */
.sj_topbar_login {
  display: flex; align-items: center; gap: 8px;
  padding-left: 10px; border-left: 1px solid var(--cl-border);
  flex-shrink: 0;
}
.sj_login_name {
  font-size: 12.5px; color: var(--cl-text-2); font-weight: 500;
  max-width: 80px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
@media (max-width: 480px) {
  .sj_login_name { display: none; }
  .sj_topbar_login { padding-left: 6px; }
}

/* ── 사이드바 로고 링크 ── */
.sj_logo_link {
  display: flex; align-items: center; gap: 10px;
  text-decoration: none; color: inherit; flex: 1; min-width: 0;
}
.sj_logo_link:hover .sj_sidebar_name { color: var(--cl-accent); }

/* ── 상태 뱃지 도트 색상 ── */
.badge_wait::before  { content:''; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--st-wait-tx); margin-right:5px; vertical-align:middle; }
.badge_ok::before    { content:''; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--st-ok-tx);   margin-right:5px; vertical-align:middle; }
.badge_reject::before{ content:''; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--st-rj-tx);   margin-right:5px; vertical-align:middle; }
.badge_pnumall::before{content:''; display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--st-pn-tx);   margin-right:5px; vertical-align:middle; }
/* 뱃지 내 텍스트 ● 제거 (::before로 대체) */
.sj_badge { font-size:11.5px; }

/* ── 전체선택 원형 체크박스 ── */
.sj_check_all_circle {
  display: flex; align-items: center; gap: 8px; cursor: pointer;
}
.sj_check_all_circle input { position: absolute; opacity: 0; width: 0; height: 0; }
.sj_chk_ring_all {
  display: flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%; flex-shrink: 0;
  background: var(--cl-surface); border: 2px solid var(--cl-border-2);
  transition: all .13s;
}
.sj_chk_ring_all::after {
  content: ''; display: none;
  width: 5px; height: 9px;
  border: 2px solid #fff; border-top: none; border-left: none;
  transform: rotate(45deg) translate(-1px,-1px);
}
.sj_check_all_circle input:checked ~ .sj_chk_ring_all {
  background: var(--cl-accent); border-color: var(--cl-accent);
}
.sj_check_all_circle input:checked ~ .sj_chk_ring_all::after { display: block; }
.sj_check_all_circle input:indeterminate ~ .sj_chk_ring_all {
  background: var(--cl-accent-bg); border-color: var(--cl-accent);
}
.sj_chkall_label { font-size: 13px; color: var(--cl-text-2); font-weight: 500; }

/* ── 검색창 드롭다운 (탑바 바로 아래) ── */
.sj_sch_wrap {
  border-bottom: 1px solid var(--cl-border);
  background: var(--cl-surface);
  padding: 0;
}
.sj_sch_inner {
  padding: 10px 20px;
}
.sj_sch_form {
  display: flex; align-items: center; gap: 8px; flex-wrap: wrap;
}
.sj_sch_input { flex: 1; min-width: 160px; }
/* 기존 bo_sch 스타일 덮어쓰기 */
.sj_sch_wrap fieldset { border: none; padding: 0; margin: 0; }
.sj_sch_wrap .bo_sch { display: block; }

/* ── 섹션 설명 텍스트 ── */
.sj_section_desc {
  font-size: 12.5px; color: var(--cl-text-3); margin: -8px 0 14px;
  line-height: 1.6;
}

/* ── 드래그앤드롭 파일 첨부 ── */
.sj_drop_zone {
  position: relative;
  border: 2px dashed var(--cl-border-2);
  border-radius: var(--r-md);
  background: var(--cl-surface-2);
  transition: border-color .15s, background .15s;
  cursor: pointer;
  overflow: hidden;
}
.sj_drop_zone:hover,
.sj_drop_zone.sj_drop_active {
  border-color: var(--cl-accent);
  background: color-mix(in srgb, var(--cl-accent) 6%, var(--cl-surface-2));
}
.sj_drop_inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  padding: 24px 16px;
  pointer-events: none;
  user-select: none;
}
.sj_drop_icon { font-size: 24px; line-height: 1; }
.sj_drop_text { font-size: 13px; color: var(--cl-text-2); font-weight: 500; }
.sj_drop_size  { font-size: 11px; color: var(--cl-text-3); }
.sj_drop_zone .sj_img_compress_preview {
  margin: 10px 12px 12px;
  display: none;
}
/* 비이미지 파일 첨부 후 inner 파일명 표시 */
.sj_drop_inner .sj_drop_text[data-file] { color: var(--cl-accent); }

/* ── 날짜 범위 ── */
.sj_delivery_range_wrap { grid-column: span 2; }
.sj_date_range {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.sj_date_range_item {
  display: flex;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 160px;
}
.sj_date_range_label {
  font-size: 12px;
  color: var(--cl-text-3);
  white-space: nowrap;
  min-width: 28px;
}
.sj_date_sep {
  font-size: 18px;
  color: var(--cl-text-3);
  font-weight: 300;
  flex-shrink: 0;
  padding-bottom: 2px;
}
@media (max-width: 560px) {
  .sj_delivery_range_wrap { grid-column: span 1; }
  .sj_date_range { flex-direction: column; align-items: stretch; }
  .sj_date_sep { text-align: center; padding: 0; }
}

/* ── 온라인 링크 필드 ── */
.sj_field_opt { font-size: 11px; color: var(--cl-text-3); font-weight: 400; margin-left: 4px; }

/* ── 온라인 링크 (view) ── */
.sj_online_link {
  color: var(--cl-accent);
  text-decoration: none;
  word-break: break-all;
  font-size: 13px;
}
.sj_online_link:hover { text-decoration: underline; }

/* ── 기존 파일 미리보기 (수정 모드) ── */
.sj_existing_preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  flex-wrap: wrap;
  transition: opacity .2s;
}
.sj_exist_img_wrap {
  flex-shrink: 0;
  display: block;
  border-radius: var(--r-sm);
  overflow: hidden;
  border: 1px solid var(--cl-border);
  line-height: 0;
}
.sj_exist_thumb {
  width: 120px;
  height: 90px;
  object-fit: cover;
  display: block;
  transition: opacity .15s;
}
.sj_exist_thumb:hover {
  opacity: .85;
}
.sj_exist_file_icon {
  font-size: 32px;
  flex-shrink: 0;
  width: 48px;
  text-align: center;
}
.sj_exist_info {
  display: flex;
  flex-direction: column;
  gap: 3px;
  flex: 1;
  min-width: 100px;
  overflow: hidden;
}
.sj_exist_name {
  font-size: 13px;
  color: var(--cl-text-1);
  font-weight: 500;
  word-break: break-all;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.sj_exist_size {
  font-size: 11px;
  color: var(--cl-text-3);
}
.sj_exist_actions {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  flex-shrink: 0;
}
.sj_exist_btn {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 5px 10px;
  border-radius: var(--r-sm);
  font-size: 12px;
  cursor: pointer;
  white-space: nowrap;
  text-decoration: none;
  border: 1px solid var(--cl-border-2);
  background: var(--cl-surface);
  color: var(--cl-text-2);
  transition: all .13s;
  user-select: none;
}
.sj_exist_btn:hover { border-color: var(--cl-accent); color: var(--cl-accent); background: color-mix(in srgb, var(--cl-accent) 6%, var(--cl-surface)); }
.sj_exist_btn input[type=checkbox] { display: none; }
.sj_exist_del_label.sj_del_active {
  background: var(--st-rj-bg);
  color: var(--st-rj-tx);
  border-color: var(--st-rj-tx);
}
.sj_exist_replace { }

/* ── 수정 모드 재입력 안내 ── */
.sj_refill_notice {
  background: #fff8e1;
  border: 1px solid #f0d070;
  border-left: 4px solid #f0a000;
  border-radius: var(--r-sm);
  padding: 12px 16px;
  margin-bottom: 18px;
  font-size: 13.5px;
  color: #7a5800;
  line-height: 1.6;
}

/* ── 관리자 경고 배너 ── */
.sj_admin_warn {
  background: #fff0f0;
  border: 1px solid #f5a0a0;
  border-left: 4px solid #e03030;
  border-radius: var(--r-sm);
  padding: 12px 16px;
  margin: 0 0 18px;
  font-size: 13px;
  color: #6a0000;
  line-height: 1.75;
}
.sj_admin_warn code {
  background: #fde;
  padding: 1px 6px;
  border-radius: 3px;
  font-size: 12px;
  font-family: monospace;
}
.sj_admin_warn_user {
  background: #fff8e1;
  border-color: #f0c040;
  border-left-color: #e09000;
  color: #6a4000;
}

/* ── 사이드바 스킨 설치 관리 버튼 ── */
.sj_nav_setup {
  color: #5c7cfa !important;
  border: 1.5px dashed #b8c8fa;
  border-radius: 8px;
  margin-top: 4px;
  background: #f5f7ff;
  transition: background .15s, border-color .15s;
}
.sj_nav_setup:hover {
  background: #eef0ff !important;
  border-color: #7c9cfa;
}
.sj_nav_setup i {
  color: #5c7cfa !important;
}

@media (max-width: 560px) {
  .m_none{ display: none; } 
}