/* ══════════════════════════════════════════════════════════════
   HaccpSelo · AI 냄새 제거 Overrides
   (기존 main.css를 수정하지 않고 뒤에서 덮어쓴다)
   ══════════════════════════════════════════════════════════════ */

/* ─── 전역 색 기준 재정렬 ─── */
body {
  background: #FFFFFF;   /* 본문 순백 — 사이드바(웜 오프화이트)와 명확한 레이어 */
  color: var(--ink);
}

/* ─── 파란 Primary 버튼 전면 교체 ─── */
button,
.btn,
[class*="btn-primary"],
.login-btn,
#loginBtn,
.settings-save,
.pw-change-btn,
button[type="submit"] {
  font-family: var(--font-body);
}

/* 대표 CTA (검정 pill) */
.login-btn,
#loginBtn,
.btn-primary,
button.primary,
.pw-change-btn,
.settings-save,
.modal-confirm,
.ccp-modal-confirm,
.approval-request-btn,
button[type="submit"]:not(.subtle) {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: 0 !important;
  box-shadow: none !important;
  transition: background var(--t-normal), border-color var(--t-normal) !important;
}
.login-btn:hover,
#loginBtn:hover,
.btn-primary:hover,
button.primary:hover,
.pw-change-btn:hover,
.settings-save:hover,
.modal-confirm:hover,
.ccp-modal-confirm:hover,
.approval-request-btn:hover,
button[type="submit"]:not(.subtle):hover {
  background: var(--ink-soft) !important;
  border-color: var(--ink-soft) !important;
}

/* Secondary: 흰 + 보더 */
.btn-secondary,
button.secondary,
.modal-cancel,
.ccp-modal-cancel {
  background: #fff !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  font-weight: var(--weight-medium) !important;
  box-shadow: none !important;
  transition: border-color var(--t-normal), background var(--t-normal) !important;
}
.btn-secondary:hover,
button.secondary:hover,
.modal-cancel:hover,
.ccp-modal-cancel:hover {
  border-color: var(--hairline-strong) !important;
  background: var(--paper) !important;
}

/* ─── 일지 저장 버튼 (노랑 → 잉크) ─── */
.journal-save-btn,
#saveJournalBtn,
button.save-btn,
.jform-save-btn,
[data-action="save-journal"] {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
}

/* ─── 결재함 큰 버튼 (주황 그라데이션 → 잉크 카드) ─── */
.btn-approval,
.approval-quick-btn,
.approval-tray-btn,
#approvalTrayBtn,
.btn-approval-tray {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-whisper) !important;
  padding: var(--gap-4) var(--gap-5) !important;
  font-weight: var(--weight-medium) !important;
  transition: background var(--t-normal), border-color var(--t-normal) !important;
}
.btn-approval:hover,
.approval-quick-btn:hover,
.approval-tray-btn:hover,
#approvalTrayBtn:hover,
.btn-approval-tray:hover {
  background: var(--ink-soft) !important;
  border-color: var(--ink-soft) !important;
}
.btn-approval .approval-count,
.approval-count {
  background: rgba(255, 255, 255, 0.16) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-pill) !important;
  padding: 1px 8px !important;
  font-size: 11px !important;
  font-weight: var(--weight-medium) !important;
  font-variant-numeric: tabular-nums;
}

/* ─── 우측 프로필 카드 세부 ─── */
.profile-card {
  background: #fff !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-whisper) !important;
}
.profile-role {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px !important;
  font-size: var(--size-xs) !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: 0 !important;
  background-image: none !important;
  box-shadow: none !important;
}
.profile-edit-btn {
  color: var(--steel) !important;
  font-size: var(--size-xs) !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: var(--track-label) !important;
  text-transform: uppercase;
  border-bottom: 1px solid var(--hairline) !important;
  padding-bottom: 1px;
}
.profile-edit-btn:hover { border-bottom-color: var(--ink) !important; color: var(--ink) !important; }

.profile-meta-label {
  font-size: var(--size-xs) !important;
  color: var(--steel) !important;
  letter-spacing: var(--track-label) !important;
  text-transform: uppercase;
  font-weight: var(--weight-medium) !important;
}
.profile-meta-val {
  color: var(--ink) !important;
  font-weight: var(--weight-medium) !important;
  font-size: var(--size-sm) !important;
}

/* 공지사항 뱃지 — 잉크 */
.notice-avatar {
  background: var(--ink) !important;
  color: #fff !important;
  border-radius: var(--radius-sm) !important;
  font-size: 11px !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: var(--track-label) !important;
  width: auto !important;
  padding: 2px 7px !important;
}

/* ══════════════════════════════════════════════════
   우측 사이드바 — Editorial Column
   ══════════════════════════════════════════════════ */

.right-panel.rail {
  display: flex !important;
  flex-direction: column !important;
  padding: var(--gap-4) var(--gap-4) var(--gap-4) var(--gap-4) !important;
  background: transparent !important;
  gap: 0 !important;
  border-left: 1px solid var(--hairline);
}

.rail-sec {
  padding: var(--gap-3) 0 !important;
  border-top: 1px solid rgba(0,0,0,0.1);
  position: relative;
}
.rail-sec:first-child { border-top: none; padding-top: 0; }
.rail-sec:last-child  { padding-bottom: 0; }

.rail-eyebrow {
  display: flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  margin-bottom: var(--gap-2);
}
.rail-eyebrow svg {
  opacity: 0.6;
  flex-shrink: 0;
}
.rail-eyebrow-alert { color: var(--seal-red) !important; }
.rail-eyebrow-alert svg { opacity: 0.9; }

/* TODAY: 날짜 작게, 시계 대형 */
.rail-today {
  padding-top: 0 !important;
  padding-bottom: var(--gap-4) !important;
}
.rail-date {
  font-size: var(--size-xs);
  color: var(--steel);
  font-weight: var(--weight-regular);
  letter-spacing: 0;
  margin-bottom: 4px;
}
.rail-time {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
  font-size: 2.25rem;
  color: var(--ink);
  font-weight: var(--weight-bold);
  letter-spacing: var(--track-tight);
  line-height: 1;
}

/* ACCOUNT */
.rail-name-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--gap-2);
  margin-bottom: 2px;
}
.rail-name {
  font-size: var(--size-base);
  font-weight: var(--weight-bold);
  color: var(--ink);
  letter-spacing: var(--track-tight);
}
.rail-role {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: var(--weight-medium);
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}
.rail-company {
  font-size: var(--size-xs);
  color: var(--steel);
  margin-bottom: var(--gap-2);
}
.rail-meta-row {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: 6px 0;
  margin-bottom: var(--gap-2);
  border-top: 1px dashed rgba(0,0,0,0.08);
}
.rail-meta-label {
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
}
.rail-meta-val {
  font-size: var(--size-xs);
  color: var(--ink);
  font-weight: var(--weight-medium);
  font-variant-numeric: tabular-nums;
}

.rail-link {
  display: inline-block;
  font-size: var(--size-xs);
  color: var(--steel);
  letter-spacing: 0;
  font-weight: var(--weight-medium);
  cursor: pointer;
  text-decoration: none !important;
  transition: color var(--t-normal);
}
.rail-link:hover { color: var(--ink); }

/* SUBSCRIPTION */
.rail-lic .rail-lic-plan,
.rail-lic .profile-meta-val {
  display: block;
  font-size: var(--size-sm);
  color: var(--ink) !important;
  font-weight: var(--weight-medium);
  letter-spacing: 0;
  margin-bottom: 2px;
}
.rail-lic-meta {
  font-size: var(--size-xs);
  color: var(--steel);
  font-weight: var(--weight-regular);
  letter-spacing: 0;
}
.rail-lic-meta.is-urgent { color: var(--seal-red); font-weight: var(--weight-medium); }
.rail-plan-badge {
  display: inline-block;
  font-size: 9px;
  letter-spacing: 0.1em;
  font-weight: var(--weight-medium);
  background: var(--ink);
  color: #fff;
  padding: 1px 5px;
  border-radius: 2px;
  margin-left: 5px;
  vertical-align: 2px;
}

/* INBOX — 약간의 시각 강조 */
.rail-inbox {
  cursor: pointer;
  margin: var(--gap-2) calc(var(--gap-4) * -1) !important;
  padding: var(--gap-3) var(--gap-4) !important;
  border-top: 1px solid rgba(0,0,0,0.1);
  border-bottom: 1px solid rgba(0,0,0,0.1);
  background: rgba(0,0,0,0.02);
  transition: background var(--t-normal) !important;
}
.rail-inbox:hover { background: rgba(0,0,0,0.05); }
.rail-inbox-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--gap-3);
}
.rail-inbox-label {
  font-size: var(--size-sm);
  color: var(--ink);
  font-weight: var(--weight-medium);
  line-height: 1.3;
}
.rail-inbox-count {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
  font-size: 1.75rem;
  color: var(--ink);
  font-weight: var(--weight-bold);
  letter-spacing: var(--track-tight);
  line-height: 1;
}
.rail-inbox-go {
  font-size: 10px;
  color: var(--steel);
  letter-spacing: 0.1em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  margin-top: 2px;
}
.rail-inbox:hover .rail-inbox-go { color: var(--ink); }

/* UNDONE */
.rail-undone-list {
  font-size: var(--size-sm);
  color: var(--ink);
}
.rail-undone-list > * + * { margin-top: var(--gap-1); }

/* NOTICES 리스트 */
.rail-notices .notice-list {
  display: flex;
  flex-direction: column;
  gap: var(--gap-3);
  margin: var(--gap-2) 0;
}
.rail-notices .notice-item {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.rail-notices .notice-avatar { display: none !important; }
.rail-notices .notice-content {
  display: flex !important;
  flex-direction: column !important;
  gap: 2px !important;
  padding: 0 !important;
  background: transparent !important;
}
.rail-notices .notice-date {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
  font-size: 11px;
  color: var(--steel);
  letter-spacing: 0;
  order: 1;
}
.rail-notices .notice-title {
  font-size: var(--size-sm);
  color: var(--ink);
  font-weight: var(--weight-medium);
  overflow: hidden;
  text-overflow: ellipsis;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  white-space: normal !important;
  line-height: 1.4;
  order: 2;
}

.notice-more {
  color: var(--steel) !important;
  font-size: var(--size-xs) !important;
  letter-spacing: 0 !important;
  text-transform: none;
  font-weight: var(--weight-medium) !important;
  border-bottom: 1px solid var(--hairline);
  padding-bottom: 1px;
  display: inline-block;
  cursor: pointer;
}
.notice-more:hover { color: var(--ink) !important; border-bottom-color: var(--ink); }

/* ══════════════════════════════════════════════════
   모노 강조색 전면 제거
   ══════════════════════════════════════════════════ */

/* 좌측 사이드바 활성 메뉴: 주황/모노 강조색 하드코딩 완전 제거 */
.sidebar-item.active {
  color: #fff !important;
  background: rgba(255,255,255,0.07) !important;
  border-left-color: #fff !important;
  font-weight: var(--weight-medium) !important;
}
.sidebar-item.active::before,
.sidebar-sub-item.active::before {
  background: #fff !important;
}

/* 달력 셀 hover — 모노 강조색 잔재 제거, 잉크 tint */
.cal-cell:hover {
  background: rgba(0, 0, 0, 0.04) !important;
  box-shadow: inset 0 0 0 1px rgba(0, 0, 0, 0.12) !important;
}

/* 달력 카드 — 하단 여백 제거: 뷰포트 남은 공간을 그리드가 채움 */
#content-home.content-section.active {
  display: flex !important;
  flex-direction: column !important;
  min-height: calc(100vh - 180px) !important;
  max-height: calc(100vh - 80px) !important;
}
#content-home .content-grid {
  flex: 1 1 auto !important;
  min-height: 0 !important;
}
#mainCalCard {
  display: flex !important;
  flex-direction: column !important;
  height: 100% !important;
}
#mainCalCard .cal-grid {
  flex: 1 1 auto !important;
  display: flex !important;
  flex-direction: column !important;
  min-height: 0 !important;
}
#mainCalCard .cal-body {
  flex: 1 1 auto !important;
  grid-auto-rows: 1fr !important;
}
#mainCalCard .cal-cell {
  min-height: 0 !important;
}

/* 달력 오늘 셀 — 모노 강조색 배경/원 완전 제거 */
.cal-cell.today {
  background: rgba(0,0,0,0.03) !important;
  box-shadow: inset 0 0 0 1.5px var(--ink) !important;
}
.cal-cell.selected {
  background: rgba(0,0,0,0.04) !important;
  box-shadow: inset 0 0 0 1px var(--ink) !important;
}
.cal-date.today-num {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  font-weight: var(--weight-bold) !important;
}
.cal-date.sun-num { color: #C05050 !important; }
.cal-date.sat-num { color: #3A5878 !important; }

/* 달력 네비 버튼 hover 모노 강조색 → 잉크 */
.cal-nav-btn:hover {
  background: var(--ink) !important;
  color: #fff !important;
}

/* 뒤로가기·네비 버튼이 모노 강조색 그라데이션이면 잉크 pill로 */
.nav-back-btn, .back-btn, .btn-back,
.journal-back-btn,
button[onclick*="goBack"],
button[onclick*="history.back"] {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-sm) !important;
  box-shadow: none !important;
}

/* 모노 강조색 유틸 버튼 */
.dm-btn-mono,
.dm-btn-mono-outline {
  background: transparent !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
}
.dm-btn-mono:hover,
.dm-btn-mono-outline:hover {
  background: var(--paper) !important;
  border-color: var(--ink) !important;
}

/* 프로필 아바타 링 / 내부 모노 강조색 아이콘 제거 (HTML에서 사라졌지만 혹시) */
.profile-ring,
.profile-avatar-wrap,
.profile-avatar,
.profile-avatar-inner { display: none !important; }

/* 프로필 편집 버튼 (구 HTML에 남아있을 경우 대비) */
.profile-edit-btn {
  color: var(--steel) !important;
  border-bottom: 1px solid var(--hairline) !important;
}

/* 상단 유저 아바타 */
.topbar-avatar,
#topbarAvatar,
.user-dropdown-trigger .avatar,
.user-avatar,
.top-user-avatar,
.user-avatar-btn,
.header-user-avatar {
  background: var(--ink) !important;
  color: #F4F0E8 !important;
  background-image: none !important;
  border: 1px solid var(--ink) !important;
  font-weight: var(--weight-medium) !important;
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  overflow: hidden !important;
}
.topbar-avatar svg,
#topbarAvatar svg,
.dd-avatar svg {
  width: 78%;
  height: 78%;
  color: inherit;
  fill: currentColor;
}

/* 관리자 페이지 헤더 SVG stroke 모노 강조색 → 잉크 */
.admin-page-title svg[stroke="#8A8A92"],
.admin-panel-title svg[stroke="#8A8A92"] {
  stroke: var(--ink) !important;
}

/* 예전 직접 강조색 흔적 중화 */
.content-section [style*="color:#8A8A92"],
.content-section [style*="color: #8A8A92"] {
  color: var(--ink) !important;
}

/* ─── 뱃지 통일 (형광 노랑 담당자 → 뉴트럴 pill) ─── */
.role-badge,
.user-role-badge,
.profile-role,
[class*="badge-role"],
.profile-card .role {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px !important;
  font-size: var(--size-xs) !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: var(--track-label) !important;
  background-image: none !important;
  box-shadow: none !important;
}

/* 상태 뱃지: 배경 채색 제거, 좌측 dot로 표시 */
.status-badge,
.status-pill,
.approval-status,
.badge-status {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px 2px 18px !important;
  position: relative !important;
  font-size: var(--size-xs) !important;
  font-weight: var(--weight-medium) !important;
  background-image: none !important;
}
.status-badge::before,
.status-pill::before,
.approval-status::before,
.badge-status::before {
  content: "";
  position: absolute;
  left: 8px; top: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--steel);
  transform: translateY(-50%);
}
.status-badge.pending::before, .status-pill.pending::before,
.approval-status.pending::before, .badge-status.pending::before,
[data-status="대기중"]::before, [data-status="pending"]::before { background: var(--seal-amber) !important; }
.status-badge.approved::before, .status-pill.approved::before,
.approval-status.approved::before, .badge-status.approved::before,
[data-status="승인"]::before, [data-status="approved"]::before,
[data-status="검토완료"]::before { background: var(--seal-green) !important; }
.status-badge.rejected::before, .status-pill.rejected::before,
.approval-status.rejected::before, .badge-status.rejected::before,
[data-status="반려"]::before, [data-status="rejected"]::before { background: var(--seal-red) !important; }

/* 결재 상세 모달 — 승인/반려 버튼 슬레이트 톤 통일 */
.apv-action-btns .apv-approve-btn,
.apv-action-btns .apv-reject-btn {
  background: transparent !important;
  border: 1px solid #4B5563 !important;
  color: #4B5563 !important;
  border-radius: 2px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  padding: 11px 16px !important;
  transition: background 140ms ease, color 140ms ease !important;
}
.apv-action-btns .apv-approve-btn {
  background: #4B5563 !important;
  color: #FFFFFF !important;
}
.apv-action-btns .apv-approve-btn:hover {
  background: #374151 !important;
  border-color: #374151 !important;
  opacity: 1 !important;
}
.apv-action-btns .apv-reject-btn:hover {
  background: rgba(75, 85, 99, 0.08) !important;
  color: #1F2937 !important;
  opacity: 1 !important;
}

/* ─── 파란 인풋 포커스 → 잉크 ─── */
input:focus,
select:focus,
textarea:focus,
.ccp-modal input:focus,
.ccp-modal select:focus {
  outline: none !important;
  border-color: var(--ink) !important;
  box-shadow: 0 0 0 3px rgba(0, 0, 0, 0.08) !important;
}

/* ─── 설정 탭 (파란 활성 → 잉크) ─── */
.settings-tab.active,
.set-tab.active,
.settings-menu-item.active {
  color: var(--ink) !important;
  background: var(--paper) !important;
  border-left: 3px solid var(--ink) !important;
  font-weight: var(--weight-medium) !important;
}

/* ─── 좌측 사이드바 활성 메뉴: 모노 강조색 라인 ─── */
.sidebar-item.active {
  background: rgba(255, 255, 255, 0.04) !important;
  color: #fff !important;
  position: relative;
}
.sidebar-item.active::before {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0;
  width: 3px;
  background: var(--regalia);
}
.sidebar-sub-item.active {
  color: #fff !important;
}
.sidebar-sub-item.active::before {
  background: var(--regalia) !important;
}

/* 사이드바 섹션 라벨 */
.sidebar-group-label,
.sidebar-section-label {
  font-size: 11px !important;
  letter-spacing: var(--track-label) !important;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.4) !important;
  font-weight: var(--weight-medium) !important;
}

/* ─── 상단 모달 CTA (파란 예, 작업일입니다) ─── */
.ccp-modal-body button.primary,
.ccp-modal-body button[data-role="primary"],
.workday-modal button.yes,
.modal-btn-yes {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
}
.workday-modal button.no,
.modal-btn-no {
  background: #fff !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
}

/* ─── 결재함 통계 숫자 색 → 모노톤 ─── */
.approval-summary-num,
.summary-pending,
.summary-approved,
.summary-rejected {
  color: var(--ink) !important;
  font-weight: var(--weight-bold) !important;
  font-variant-numeric: tabular-nums;
}

/* ─── 결재 목록 좌측 색 스트라이프 → 얇은 보더 ─── */
.approval-item,
.approval-card {
  border-left: 1px solid var(--hairline) !important;
  border-radius: var(--radius-md) !important;
  background: #fff !important;
  box-shadow: var(--shadow-whisper) !important;
}
.approval-item.pending, .approval-card.pending { border-left-color: var(--seal-amber) !important; border-left-width: 3px !important; }
.approval-item.approved, .approval-card.approved { border-left-color: var(--seal-green) !important; border-left-width: 3px !important; }
.approval-item.rejected, .approval-card.rejected { border-left-color: var(--seal-red) !important; border-left-width: 3px !important; }

/* ─── "worker" 보라 / "CCP" 빨강 뱃지 → 통일 ─── */
.approval-type-badge,
.approval-role-badge,
[class*="type-worker"],
[class*="type-ccp"] {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px !important;
  font-size: 11px !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
  background-image: none !important;
}

/* ─── 공지사항 "비전" 칩 → 잉크 ─── */
.notice-badge,
.notice-tag,
.notice-prefix {
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  padding: 2px 8px !important;
  font-size: 11px !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
}

/* ─── 달력 오늘 강조 (노랑 박스 → 잉크 아웃라인) ─── */
.calendar-day.today,
.cal-day.today,
[data-today="true"] {
  background: transparent !important;
  color: var(--ink) !important;
  font-weight: var(--weight-bold) !important;
  box-shadow: inset 0 0 0 2px var(--ink) !important;
}

/* ─── 달력 토요일/일요일 한 톤 다운 ─── */
.calendar th:first-child,
.calendar td:first-child,
.cal-sun,
[data-dow="0"] { color: #C05050 !important; }

.calendar th:last-child,
.calendar td:last-child,
.cal-sat,
[data-dow="6"] { color: #3A5878 !important; }

/* ─── 드롭다운·셀렉트 보더 통일 ─── */
select,
.dropdown-menu {
  border-color: var(--hairline) !important;
  border-radius: var(--radius-sm) !important;
}

/* ─── 토스트 (성공/경고/에러) 모노톤 + 좌측 색 라인 ─── */
.toast,
#toast.toast {
  background: #fff !important;
  color: #444444 !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-left: 3px solid #444444 !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.12) !important;
  padding: 12px 20px !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
}
#toast.toast.toast-error {
  background: #fff !important;
  border-left-color: #B91C1C !important;
  color: #7B1D1D !important;
}
.toast.toast-success,
.toast.success { border-left-color: var(--seal-green) !important; }
.toast.toast-error,
.toast.error { border-left-color: var(--seal-red) !important; }
.toast.toast-warning,
.toast.warning { border-left-color: var(--seal-amber) !important; }

/* ─── 카드 공통 ─── */
.page-card,
.settings-panel,
.info-card,
.dash-card {
  background: #fff !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-whisper) !important;
}

/* ─── 번호·통계 숫자에 tabular-nums ─── */
.num, .stat-num, .summary-num, .big-number,
.approval-summary-num, .set-value {
  font-variant-numeric: tabular-nums;
}

/* ─── 링크 색 (블루 → 잉크) ─── */
a {
  color: var(--ink);
  text-decoration: none;
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-normal);
}
a:hover {
  border-bottom-color: var(--ink);
}

/* ─── "결재 완료/승인/반려" 등 상태 text-color 하드코딩 제압 ─── */
.status-approved, .text-approved { color: var(--seal-green) !important; }
.status-rejected, .text-rejected { color: var(--seal-red) !important; }
.status-pending,  .text-pending  { color: var(--seal-amber) !important; }

/* ─── 이모지 아이콘 숨김용 유틸 (HTML에서 치환 예정) ─── */
.no-emoji { font-family: var(--font-body) !important; }

/* ═══════════════════════════════════════════
   결재함 (.apv-*)
   ═══════════════════════════════════════════ */

.apv-card {
  background: #fff !important;
  border: 1px solid var(--hairline) !important;
  border-left: 1px solid var(--hairline) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-whisper) !important;
  padding: var(--gap-4) var(--gap-5) !important;
  transition: border-color var(--t-normal) !important;
}
.apv-card:hover {
  transform: none !important;
  box-shadow: var(--shadow-whisper) !important;
  border-color: var(--hairline-strong) !important;
}
/* 전 상태 동일한 중립 보더 — 색 구분 없음. 상태는 우측 라벨로만 표현 */
.apv-card.pending,
.apv-card.approved,
.apv-card.rejected,
.apv-card.reviewed {
  border-left: 1px solid var(--hairline) !important;
  background: #fff !important;
}

.apv-card-title {
  color: var(--ink) !important;
  font-weight: var(--weight-medium) !important;
}
.apv-card-meta,
.apv-card-preview {
  color: var(--steel) !important;
}

/* 상태 뱃지 */
/* 2026-04-26: apv-status 4종 모노 통일 — 좌측 dot만 의미 색 유지, 라벨은 모노 */
.apv-status.pending,
.apv-status.reviewed,
.apv-status.approved,
.apv-status.rejected {
  background: var(--gray1, #f3f4f6) !important;
  color: var(--ink, #1a1a1a) !important;
  border-radius: 2px !important;
}
.apv-status {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px 2px 20px !important;
  position: relative !important;
  font-size: 11px !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: var(--track-label) !important;
}
.apv-status::before {
  content: "";
  position: absolute;
  left: 8px; top: 50%;
  width: 6px; height: 6px;
  border-radius: 50%;
  transform: translateY(-50%);
  background: var(--steel);
}
/* 상태 점만 색 복구 — pill·보더는 계속 중립 */
.apv-status.pending::before  { background: var(--seal-amber) !important; animation: apv-dot-pulse 1.8s ease-in-out infinite; }
.apv-status.reviewed::before { background: #1E40AF !important; }           /* 검토완료: 차분한 짙은 회색 */
.apv-status.approved::before { background: var(--seal-green) !important; }
.apv-status.rejected::before { background: var(--seal-red) !important; }

@keyframes apv-dot-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(146, 64, 14, 0.55); }
  50%      { box-shadow: 0 0 0 4px rgba(146, 64, 14, 0); }
}

/* 타입 칩 ("일지결재", "worker" 등) */
.apv-type-chip,
.apv-card span[style*="color:#fff"][style*="background"] {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 2px 10px !important;
  font-size: 11px !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
  background-image: none !important;
  box-shadow: none !important;
}

.apv-ccp-badge {
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: var(--radius-sm) !important;
  padding: 1px 6px !important;
  font-size: 10px !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
}

/* 결재 요약 카드 (상단 3/0/0) */
.apv-summary-wrap {
  display: grid !important;
  grid-template-columns: repeat(3, 1fr) !important;
  gap: var(--gap-3) !important;
  margin-bottom: var(--gap-5) !important;
}
.apv-summary-card {
  background: #fff !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-md) !important;
  box-shadow: var(--shadow-whisper) !important;
  padding: var(--gap-5) !important;
  text-align: center !important;
  background-image: none !important;
}
/* 요약 카드 상단 컬러 바 제거 — 순수 중립 카드 */
.apv-summary-card.sc-pending,
.apv-summary-card.sc-approved,
.apv-summary-card.sc-rejected {
  border-top: 1px solid var(--hairline) !important;
}

/* 결재 현황 카드 (우측) — 점만 상태색, 숫자는 ink */
.chk-score-card .chk-score-dot {
  width: 8px !important;
  height: 8px !important;
  border-radius: 50% !important;
  display: inline-block !important;
  margin-right: 8px !important;
  vertical-align: 1px;
  transition: transform var(--t-normal), box-shadow var(--t-normal);
}
/* 행별 점 색 — 구조: 전체(1) → 대기중(2) → 승인(3) → 반려(4) */
.chk-score-card .chk-score-rows .chk-score-row:nth-child(1) .chk-score-dot { background: var(--steel) !important; opacity: 0.5 !important; }
.chk-score-card .chk-score-rows .chk-score-row:nth-child(2) .chk-score-dot {
  background: var(--seal-amber) !important;
  animation: apv-dot-pulse 1.8s ease-in-out infinite;
}
.chk-score-card .chk-score-rows .chk-score-row:nth-child(3) .chk-score-dot { background: var(--seal-green) !important; }
.chk-score-card .chk-score-rows .chk-score-row:nth-child(4) .chk-score-dot { background: var(--seal-red) !important; }

.chk-score-card .chk-score-val {
  color: var(--ink) !important;
  transition: color var(--t-normal);
}
.chk-score-card .chk-score-row:hover .chk-score-dot {
  transform: scale(1.4);
}
/* 요약 카드 숫자도 중립 */
.apv-summary-card.sc-pending .apv-sc-num,
.apv-summary-card.sc-approved .apv-sc-num,
.apv-summary-card.sc-rejected .apv-sc-num {
  color: var(--ink) !important;
}
.apv-sc-num {
  font-size: var(--size-3xl) !important;
  font-weight: var(--weight-bold) !important;
  color: var(--ink) !important;
  font-variant-numeric: tabular-nums;
  letter-spacing: var(--track-tight) !important;
  line-height: 1 !important;
  margin-bottom: var(--gap-2) !important;
}
.apv-sc-label {
  font-size: var(--size-xs) !important;
  color: var(--steel) !important;
  letter-spacing: var(--track-label) !important;
  text-transform: uppercase;
  font-weight: var(--weight-medium) !important;
}

/* 결재 현황 사이드 (파란 그라데이션 → 잉크) */
.chk-score-head {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  font-size: var(--size-sm) !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
}
.chk-score-val {
  color: var(--ink) !important;
  font-weight: var(--weight-bold) !important;
  font-variant-numeric: tabular-nums;
}
.chk-score-row-label {
  color: var(--ink-soft) !important;
  font-weight: var(--weight-medium) !important;
}

/* 탭 ("내 결재요청" 검정, 나머지 보더만) */
.chk-tabs {
  gap: var(--gap-2) !important;
  border-bottom: 1px solid var(--hairline) !important;
  padding-bottom: 0 !important;
}
.chk-tab {
  background: transparent !important;
  border: none !important;
  border-bottom: 2px solid transparent !important;
  color: var(--steel) !important;
  border-radius: 0 !important;
  padding: var(--gap-3) var(--gap-4) !important;
  font-size: var(--size-sm) !important;
  font-weight: var(--weight-medium) !important;
  letter-spacing: 0 !important;
}
.chk-tab.active {
  background: transparent !important;
  color: var(--ink) !important;
  border-bottom-color: var(--ink) !important;
}

/* 오늘/이번 주/전체 토글 */
#apvDateTabs {
  display: flex !important;
  gap: var(--gap-2) !important;
  margin-bottom: var(--gap-4) !important;
}
#apvDateTabs > * {
  background: #fff !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: var(--radius-pill) !important;
  padding: 6px 14px !important;
  font-size: var(--size-xs) !important;
  letter-spacing: var(--track-label) !important;
  font-weight: var(--weight-medium) !important;
  cursor: pointer;
}
#apvDateTabs > .active {
  background: var(--ink) !important;
  color: #fff !important;
  border-color: var(--ink) !important;
}

/* 결재 요청 제출 버튼 */
.ccp-log-submit,
button.ccp-log-submit {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid var(--ink) !important;
  border-radius: var(--radius-pill) !important;
  box-shadow: none !important;
  background-image: none !important;
}

/* CCP 이탈 배지 (결재카드 내부) */
.apv-card .apv-ccp-badge {
  margin-left: 6px;
}

/* ══════════════════════════════════════════════════
   우측 사이드바 제거 (2026-04-23) — 헤더로 통합
   ══════════════════════════════════════════════════ */

/* 콘텐츠 단일 컬럼화 */
.content-grid {
  grid-template-columns: 1fr !important;
  gap: 0 !important;
}

/* 빈 상태 (결재 없음, 공지 없음 등) — 이모지 제거하고 차분한 편집톤 */
.apv-empty {
  display: flex !important;
  flex-direction: column;
  align-items: center;
  gap: 12px;
  padding: 48px 24px !important;
  color: var(--ink-soft) !important;
  font-size: var(--size-sm) !important;
  letter-spacing: 0.02em;
}
.apv-empty::before {
  content: '';
  width: 28px;
  height: 28px;
  background: center/contain no-repeat
    url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236E6E75' stroke-width='1.4' stroke-linecap='round' stroke-linejoin='round'><path d='M22 12h-6l-2 3h-4l-2-3H2'/><path d='M5.45 5.11L2 12v6a2 2 0 0 0 2 2h16a2 2 0 0 0 2-2v-6l-3.45-6.89A2 2 0 0 0 16.76 4H7.24a2 2 0 0 0-1.79 1.11z'/></svg>");
  opacity: 0.55;
}

/* 결재 상세 모달: "일지 원본 보기" 버튼 — 파랑 → 편집톤 고스트 pill */
.apv-detail-view-journal {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-top: 14px;
  padding: 7px 14px;
  background: var(--ink);
  color: #fff;
  border: 1px solid var(--ink);
  border-radius: var(--radius-pill);
  font-size: var(--size-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.apv-detail-view-journal:hover {
  background: #1F2C3E;
  border-color: #1F2C3E;
}
.apv-detail-view-journal svg { opacity: 0.9; }

/* ── 처리 이력: 상태 라벨 + 보기 버튼 (이모지 제거) ── */
.apv-hist-status {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: var(--size-sm);
  font-weight: var(--weight-medium);
  letter-spacing: -0.005em;
}
.apv-hist-status .apv-hist-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  flex-shrink: 0;
}
.apv-hist-status.approved { color: var(--seal-green); }
.apv-hist-status.approved .apv-hist-status-dot {
  background: var(--seal-green);
  box-shadow: 0 0 0 3px rgba(22, 101, 52, 0.12);
}
.apv-hist-status.rejected { color: var(--seal-red); }
.apv-hist-status.rejected .apv-hist-status-dot {
  background: var(--seal-red);
  box-shadow: 0 0 0 3px rgba(185, 28, 28, 0.12);
}
.apv-hist-view-btn {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 3px 11px;
  background: transparent;
  color: var(--ink);
  border: 1px solid rgba(0, 0, 0, 0.16);
  border-radius: var(--radius-pill);
  font-size: var(--size-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.02em;
  cursor: pointer;
  margin-right: 3px;
  transition: background var(--t-fast), border-color var(--t-fast);
}
.apv-hist-view-btn:hover {
  background: rgba(0, 0, 0, 0.05);
  border-color: rgba(0, 0, 0, 0.28);
}
.apv-hist-view-btn svg { opacity: 0.7; flex-shrink: 0; }
.apv-hist-view-btn:hover svg { opacity: 1; }

/* ── 일지 헤더바: 모노그레이 → 웜 차콜 + 고스트 버튼 ── */
.journal-header {
  background: #1F1D1A !important;             /* 웜 차콜 (파란 기 제거) */
  color: #F4F0E8 !important;                   /* 따뜻한 아이보리 */
  padding: 12px 18px !important;
  border-bottom: 1px solid rgba(255, 240, 200, 0.08) !important;
  border-radius: 0 !important;
}
.journal-header h2 {
  font-family: var(--font-display) !important;
  font-size: 15px !important;
  font-weight: 700 !important;
  letter-spacing: var(--track-tight) !important;
  color: #F4F0E8 !important;
}
.journal-header-btns { gap: 6px !important; }
.journal-header-btns button {
  display: inline-flex !important;
  align-items: center !important;
  gap: 6px !important;
  background: transparent !important;
  color: #FBF7ED !important;                        /* 아이보리 풀로드 — 검정 바 위에서 또렷 */
  border: 1px solid rgba(251, 247, 237, 0.45) !important;
  border-radius: var(--radius-pill) !important;
  padding: 5px 12px !important;
  font-size: 12.5px !important;
  font-weight: 700 !important;
  letter-spacing: -0.005em !important;
  transition: background var(--t-fast), border-color var(--t-fast), color var(--t-fast) !important;
}
.journal-header-btns .jhb-icon {
  flex: 0 0 auto;
  opacity: 1;
  stroke: currentColor;
}
.journal-header-btns .btn-jmore {
  padding: 5px 9px !important;
}
.j-more-dropdown button {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
}
.j-more-dropdown .jhb-icon { opacity: 0.8; flex: 0 0 auto; }
.journal-header-btns button:hover {
  background: rgba(251, 247, 237, 0.10) !important;
  color: #FFFFFF !important;
  border-color: rgba(251, 247, 237, 0.7) !important;
}
/* 주 액션 (저장) 만 솔리드로 강조 */
.journal-header-btns .btn-jsave,
.journal-header-btns .btn-jedit-save,
.journal-header-btns .btn-jdraft {
  background: #F4F0E8 !important;
  color: #1F1D1A !important;
  border-color: #F4F0E8 !important;
  font-weight: 700 !important;
}
.journal-header-btns .btn-jsave:hover,
.journal-header-btns .btn-jedit-save:hover,
.journal-header-btns .btn-jdraft:hover {
  background: #FFFFFF !important;
  border-color: #FFFFFF !important;
  color: #1F1D1A !important;            /* 호버 시에도 글씨·아이콘 진하게 유지 */
}
.journal-header-btns .btn-jsave:hover .jhb-icon,
.journal-header-btns .btn-jedit-save:hover .jhb-icon,
.journal-header-btns .btn-jdraft:hover .jhb-icon { opacity: 1; }
/* 기존 컬러 배경 모두 고스트화 */
.btn-jedit, .btn-jload, .btn-jpdf, .btn-jprint, .btn-jclose, .btn-jmore, .btn-jguide {
  background: transparent !important;
}
.btn-jedit:hover, .btn-jload:hover, .btn-jpdf:hover, .btn-jprint:hover,
.btn-jclose:hover, .btn-jmore:hover, .btn-jguide:hover {
  background: rgba(244, 240, 232, 0.08) !important;
}
/* 더보기 드롭다운도 동일 톤 */
.j-more-dropdown {
  background: #2A2724 !important;
  border: 1px solid rgba(244, 240, 232, 0.12) !important;
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35) !important;
}
/* 드롭다운 안에서는 모든 버튼(편집저장 포함)이 동일한 고스트 톤으로 통일 */
.j-more-dropdown .btn-jsave,
.j-more-dropdown .btn-jedit-save,
.j-more-dropdown .btn-jdraft,
.j-more-dropdown .btn-jedit,
.j-more-dropdown .btn-jload,
.j-more-dropdown .btn-jpdf,
.j-more-dropdown .btn-jprint {
  background: transparent !important;
  color: rgba(244, 240, 232, 0.92) !important;
  border-color: transparent !important;
  font-weight: 500 !important;
}
.j-more-dropdown .btn-jsave:hover,
.j-more-dropdown .btn-jedit-save:hover,
.j-more-dropdown .btn-jdraft:hover,
.j-more-dropdown .btn-jedit:hover,
.j-more-dropdown .btn-jload:hover,
.j-more-dropdown .btn-jpdf:hover,
.j-more-dropdown .btn-jprint:hover {
  background: rgba(244, 240, 232, 0.10) !important;
  color: #FFFFFF !important;
  border-color: transparent !important;
}
.j-more-dropdown button {
  color: rgba(244, 240, 232, 0.88) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}
.j-more-dropdown button:hover { background: rgba(244, 240, 232, 0.08) !important; }
.j-more-dropdown button + button { border-top-color: rgba(244, 240, 232, 0.08) !important; }

/* ── 주기별 일지 보드 (오늘 / 이번주 / 이번달) ── */
.home-jboard {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--gap-3);
  margin-bottom: var(--gap-4);
}
.home-jboard-col {
  background: #FFFFFF;                       /* 달력 카드와 동일한 화이트 */
  border: 1px solid var(--hairline);
  border-radius: var(--radius-md);
  padding: var(--gap-4) var(--gap-4) var(--gap-3);
  min-height: 120px;
  display: flex;
  flex-direction: column;
}
.home-jboard-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--gap-2);
  margin-bottom: var(--gap-3);
  padding-bottom: var(--gap-2);
  border-bottom: 1px solid var(--hairline);
}
.home-jboard-eyebrow {
  font-size: var(--size-sm);
  font-weight: var(--weight-bold);
  letter-spacing: var(--track-tight);
  color: #444444;
}
.home-jboard-count {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
  font-size: var(--size-xs);
  color: var(--ink-soft);
  font-weight: var(--weight-medium);
  letter-spacing: 0.02em;
}
.home-jboard-count.all-done { color: var(--seal-green); }
.home-jboard-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  flex: 1;
}
.jboard-item {
  display: flex;
  align-items: center;
  gap: var(--gap-2);
  padding: 7px 2px;
  font-size: var(--size-sm);
  color: var(--ink);
  border-bottom: 1px solid rgba(0, 0, 0, 0.04);
}
.jboard-item:last-child { border-bottom: none; }
.jboard-item .jboard-dot {
  flex: 0 0 auto;
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #DC2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.12);
}
.jboard-item .jboard-dot.done {
  background: var(--seal-green);
  box-shadow: 0 0 0 3px rgba(22, 101, 52, 0.12);
}
.jboard-item .jboard-name {
  flex: 1;
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: #444444;
  font-weight: var(--weight-medium);
}
.jboard-item.is-done .jboard-name {
  color: var(--ink-soft);
  text-decoration: line-through;
  text-decoration-color: rgba(0, 0, 0, 0.25);
}
.jboard-item .jboard-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: var(--size-xs);
  padding: 4px 11px;
  border: 1px solid rgba(0, 0, 0, 0.14);
  border-radius: var(--radius-pill);
  background: transparent;
  color: var(--ink);
  cursor: pointer;
  font-weight: var(--weight-medium);
  letter-spacing: 0.02em;
  transition: background var(--t-fast), border-color var(--t-fast);
  white-space: nowrap;
}
.jboard-item .jboard-btn-icon {
  opacity: 0.7;
  transition: opacity var(--t-fast), transform var(--t-fast);
}
.jboard-item .jboard-btn:hover .jboard-btn-icon {
  opacity: 1;
  transform: translate(-1px, 1px);  /* 연필이 종이 쪽으로 기울듯 */
}
.jboard-item .jboard-btn:hover {
  background: rgba(0, 0, 0, 0.05);
  border-color: rgba(0, 0, 0, 0.22);
}
.jboard-item .jboard-btn.done {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--ink-soft);
  border-color: rgba(0, 0, 0, 0.10);
  background: transparent;
  padding: 3px 6px 3px 10px;
  cursor: pointer;
}
.jboard-item .jboard-btn.done:hover {
  background: rgba(0, 0, 0, 0.03);
  border-color: rgba(0, 0, 0, 0.16);
}
.jboard-item .jboard-done-date {
  font-family: var(--font-body);
  font-feature-settings: "tnum" 1;
  font-size: var(--size-xs);
  font-weight: var(--weight-medium);
  letter-spacing: 0.01em;
  color: var(--ink-soft);
}
.jboard-item .jboard-done-label {
  font-size: 11px;
  letter-spacing: 0;
  text-transform: none;
  padding: 1px 7px;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--seal-green);
  font-weight: var(--weight-medium);
  border: 1px solid rgba(22, 101, 52, 0.22);
}
.jboard-empty {
  font-size: var(--size-xs);
  color: var(--ink-soft);
  text-align: center;
  padding: var(--gap-5) 0;
  letter-spacing: 0.06em;
}
@media (max-width: 900px) {
  .home-jboard { grid-template-columns: 1fr; }
}

/* 오늘 미작성 스트립 (홈 상단) */
.home-undone-strip {
  display: flex;
  flex-direction: column;
  gap: var(--gap-2);
  padding: var(--gap-3) var(--gap-4);
  margin-bottom: var(--gap-4);
  background: #F7F2E8;                        /* 크림 베이지 — 달력 카드와 한 패밀리 */
  border: 1px solid rgba(0, 0, 0, 0.08);
  border-radius: var(--radius-md);
}
.home-undone-eyebrow {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  font-weight: var(--weight-medium);
  color: var(--ink);                          /* 빨강 → 잉크 */
}
.home-undone-list {
  font-size: var(--size-sm);
  color: var(--ink);
  line-height: 1.5;
}
.home-undone-list > * + * { margin-top: var(--gap-1); }

/* 오늘 미작성 카드 내부 작성하기 링크 — 크림 톤에 맞춰 잉크로 */
.home-undone-strip .undone-btn,
#todayUndoneCard .undone-btn {
  color: var(--ink) !important;
  font-weight: var(--weight-medium) !important;
  font-size: var(--size-xs) !important;
  letter-spacing: 0.02em !important;
  padding: 4px 10px !important;
  border: 1px solid rgba(0, 0, 0, 0.14) !important;
  border-radius: var(--radius-pill) !important;
  background: transparent !important;
}
.home-undone-strip .undone-btn:hover,
#todayUndoneCard .undone-btn:hover {
  background: rgba(0, 0, 0, 0.05) !important;
  color: var(--ink) !important;
}
.home-undone-strip .undone-item,
#todayUndoneCard .undone-item {
  color: var(--ink) !important;
}

/* 상단바: 결재 인박스 버튼 */
.topbar-inbox {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 32px;
  padding: 0 12px;
  background: #1F2937 !important;
  color: #fff !important;
  border: 1px solid #1F2937 !important;
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: var(--size-xs);
  font-weight: var(--weight-bold);
  letter-spacing: 0.04em;
  cursor: pointer;
  transition: background var(--t-normal);
}
.topbar-inbox:hover { background: #111827 !important; border-color: #111827 !important; }
.topbar-inbox-label {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  opacity: 0.75;
}
.topbar-inbox-count {
  font-family: var(--font-numeric);
  font-variant-numeric: tabular-nums;
  font-size: 13px;
  font-weight: var(--weight-bold);
  line-height: 1;
  padding-left: 8px;
  border-left: 1px solid rgba(255, 255, 255, 0.25);
}

/* 상단바 프로필 드롭다운 — 풍부한 카드형 */
.topbar-dropdown.topbar-dd-profile {
  min-width: 280px;
  padding: 0;
  overflow: hidden;
  border-radius: var(--radius-md);
  border: 1px solid var(--hairline-strong);
  box-shadow: var(--shadow-lift);
  background: var(--paper);
}
.topbar-dd-head {
  padding: var(--gap-4) var(--gap-4) var(--gap-3);
  border-bottom: 1px solid var(--hairline);
}
.topbar-dd-name-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--gap-2);
  margin-bottom: 3px;
}
.topbar-dd-name {
  font-size: var(--size-base);
  font-weight: var(--weight-bold);
  color: var(--ink);
  letter-spacing: var(--track-tight);
}
.topbar-dd-role {
  font-size: 9px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: var(--weight-medium);
  background: transparent !important;
  border: none !important;
  padding: 0 !important;
}
.topbar-dd-company {
  font-size: var(--size-xs);
  color: var(--steel);
}
.topbar-dd-block {
  padding: var(--gap-3) var(--gap-4);
  border-bottom: 1px solid var(--hairline);
}
.topbar-dd-eyebrow {
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: var(--weight-medium);
  margin-bottom: 6px;
}
.topbar-dd-meta {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  padding: var(--gap-3) var(--gap-4);
}
.topbar-dd-meta-label {
  font-size: 10px;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: var(--weight-medium);
}
.topbar-dd-meta-val {
  font-size: var(--size-xs);
  color: var(--ink);
  font-weight: var(--weight-medium);
  font-variant-numeric: tabular-nums;
}
.topbar-dd-sep {
  height: 1px;
  background: var(--hairline);
}
.topbar-dropdown.topbar-dd-profile .topbar-dd-item {
  padding: 10px var(--gap-4);
  font-size: var(--size-sm);
  color: var(--ink);
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  transition: background var(--t-fast);
}
.topbar-dropdown.topbar-dd-profile .topbar-dd-item:hover { background: var(--mist); }
.topbar-dropdown.topbar-dd-profile .topbar-dd-item.danger { color: var(--seal-red); }
.topbar-dropdown.topbar-dd-profile .topbar-dd-item svg {
  opacity: 0.55;
  flex-shrink: 0;
}

/* ─── 알림 상태·테스트 버튼 (프로필 드롭다운 내) ─── */
.topbar-dd-notify-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-top: 6px;
}
.topbar-dd-notify-status {
  font-size: 12px;
  color: var(--ink);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  line-height: 1.4;
}
.topbar-dd-notify-status.off { color: var(--seal-red); }
.topbar-dd-notify-status.pending { color: var(--seal-amber); }
.push-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}
.push-dot.on      { background: var(--seal-green); box-shadow: 0 0 0 2px rgba(22,101,52,0.18); animation: apv-dot-pulse 2s ease-in-out infinite; }
.push-dot.off     { background: var(--seal-red); }
.push-dot.pending { background: var(--seal-amber); animation: apv-dot-pulse 1.4s ease-in-out infinite; }

.topbar-dd-notify-test {
  background: var(--ink);
  color: #fff;
  border: none;
  border-radius: var(--radius-pill);
  padding: 5px 12px;
  font-size: 11px;
  font-weight: var(--weight-medium);
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background var(--t-fast);
  flex-shrink: 0;
}
.topbar-dd-notify-test:hover:not(:disabled) { background: var(--ink-soft); }
.topbar-dd-notify-test:disabled { opacity: 0.6; cursor: default; }

/* ══════════════════════════════════════════════════
   프로필 드롭다운 리뉴얼 — 통계 카드 + 진행률 바
   ══════════════════════════════════════════════════ */
.topbar-dropdown.topbar-dd-profile {
  min-width: 340px !important;
  padding: 0 !important;
  overflow: hidden;
  animation: dd-slide-in 0.22s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes dd-slide-in {
  from { opacity: 0; transform: translateY(-6px) scale(0.985); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

/* 프로필 헤더 — 아바타 + 이름/역할/업체 */
.topbar-dd-profile .topbar-dd-head {
  display: flex;
  gap: 12px;
  align-items: center;
  padding: 18px 18px 14px;
  border-bottom: 1px solid rgba(0,0,0,0.08);
}
.dd-avatar {
  width: 44px; height: 44px;
  border-radius: 50%;
  background: linear-gradient(135deg, #6E6E75, #8A8A92);
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font-size: 17px;
  font-weight: 700;
  letter-spacing: -0.01em;
  flex-shrink: 0;
  box-shadow: 0 4px 12px rgba(0,0,0,0.18);
}
.dd-profile-info { flex: 1; min-width: 0; }

/* 통계 3장 그리드 */
.dd-stat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: rgba(0,0,0,0.06);
  padding: 1px 0;
}
.dd-stat-card {
  background: var(--paper);
  padding: 12px 10px;
  text-align: center;
  transition: background 0.15s;
}
.dd-stat-card:hover { background: #EDEFF3; }
.dd-stat-label {
  font-size: 10px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: 500;
  margin-bottom: 4px;
}
.dd-stat-value {
  font-size: 17px;
  font-weight: 800;
  color: var(--ink);
  letter-spacing: -0.02em;
  font-family: var(--font-numeric);
}
.dd-stat-unit {
  font-size: 10px;
  font-weight: 500;
  color: var(--steel);
  margin-left: 2px;
  font-family: var(--font-body);
}
.dd-stat-plan {
  font-size: 12px !important;
  font-family: var(--font-body) !important;
  color: var(--ink) !important;
  letter-spacing: -0.005em !important;
  display: flex;
  align-items: center;
  gap: 4px;
  flex-wrap: wrap;
}
.dd-stat-chip {
  display: inline-block;
  font-size: 9px;
  font-weight: 700;
  padding: 1px 5px;
  border: 1px solid rgba(0,0,0,0.18);
  border-radius: 3px;
  color: var(--steel);
  background: #fff;
  letter-spacing: 0;
  font-family: var(--font-body);
}
.dd-stat-value.urgent { color: var(--seal-red); }
.dd-stat-value.warn   { color: var(--seal-amber); }
.dd-stat-value.ok     { color: var(--seal-green); }

/* 진행률 바 */
.dd-sub-bar-block {
  padding: 14px 18px 14px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
  background: #FAFBFC;
}
.dd-sub-bar-row {
  display: flex; justify-content: space-between; align-items: baseline;
  margin-bottom: 8px;
}
.dd-sub-label {
  font-size: 12px;
  font-weight: 600;
  color: var(--ink);
}
.dd-sub-date {
  font-size: 11px;
  color: var(--steel);
  font-family: var(--font-numeric);
}
.dd-sub-progress {
  height: 6px;
  background: rgba(0,0,0,0.06);
  border-radius: var(--radius-pill);
  overflow: hidden;
  position: relative;
}
.dd-sub-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--ink), var(--ink-soft));
  border-radius: var(--radius-pill);
  width: 0%;
  transition: width 0.8s cubic-bezier(0.22, 1, 0.36, 1);
  position: relative;
  overflow: hidden;
}
.dd-sub-progress-fill::after {
  content: '';
  position: absolute;
  top: 0; right: 0; bottom: 0; width: 30px;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,0.45), transparent);
  animation: dd-progress-shimmer 2.2s ease-in-out infinite;
}
.dd-sub-progress-fill.warn { background: linear-gradient(90deg, var(--seal-amber), #B97316); }
.dd-sub-progress-fill.urgent { background: linear-gradient(90deg, var(--seal-red), #DC2626); }
@keyframes dd-progress-shimmer {
  0%   { transform: translateX(30px); opacity: 0; }
  50%  { opacity: 1; }
  100% { transform: translateX(-200px); opacity: 0; }
}

/* 섹션 (알림 등) */
.dd-section {
  padding: 14px 18px;
  border-bottom: 1px solid rgba(0,0,0,0.06);
}
.dd-section-head {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  letter-spacing: 0.14em;
  text-transform: uppercase;
  color: var(--steel);
  font-weight: 500;
  margin-bottom: 10px;
}
.dd-section-head svg { opacity: 0.6; }
.dd-section-head-clickable {
  cursor: pointer;
  padding: 4px 6px;
  margin: 0 -6px 8px;
  border-radius: var(--radius-sm);
  transition: background var(--t-fast), color var(--t-fast);
}
.dd-section-head-clickable:hover {
  background: rgba(0, 0, 0, 0.05);
  color: var(--ink);
}
.dd-section-head-clickable .dd-section-head-chevron {
  margin-left: auto;
  opacity: 0.5;
  transition: transform var(--t-fast), opacity var(--t-fast);
}
.dd-section-head-clickable:hover .dd-section-head-chevron {
  opacity: 0.9;
  transform: translateX(2px);
}

/* 기존 하단 액션 아이템 간격 */
.topbar-dd-profile .topbar-dd-item {
  transition: transform 0.12s, background 0.12s;
}
.topbar-dd-profile .topbar-dd-item:hover {
  transform: translateX(2px);
}

/* ══════════════════════════════════════════════════
   PWA 설치 배너 · iOS 가이드 · 알림 pre-prompt
   ══════════════════════════════════════════════════ */

/* ─── 하단 슬라이드업 설치 배너 ─── */
.pwa-install-banner {
  position: fixed;
  left: 50%;
  bottom: 20px;
  transform: translateX(-50%) translateY(140%);
  width: min(560px, calc(100vw - 32px));
  background: var(--paper);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-lift);
  padding: 14px 18px;
  display: flex;
  align-items: center;
  gap: 14px;
  z-index: 9998;
  transition: transform 0.35s cubic-bezier(0.22, 1, 0.36, 1);
}
.pwa-install-banner.show { transform: translateX(-50%) translateY(0); }
.pwa-banner-icon {
  flex-shrink: 0;
  width: 40px; height: 40px;
  display: flex; align-items: center; justify-content: center;
  background: var(--mist);
  color: var(--ink);
  border-radius: var(--radius-md);
}
.pwa-banner-text { flex: 1; min-width: 0; }
.pwa-banner-title {
  font-size: 14px;
  font-weight: var(--weight-bold);
  color: var(--ink);
  letter-spacing: var(--track-tight);
  line-height: 1.3;
  margin-bottom: 2px;
}
.pwa-banner-desc {
  font-size: 12px;
  color: var(--steel);
  line-height: 1.4;
}
.pwa-banner-actions {
  display: flex; gap: 6px;
  flex-shrink: 0;
}
.pwa-banner-later {
  background: transparent;
  color: var(--steel);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-pill);
  padding: 7px 14px;
  font-size: 12px;
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: background var(--t-fast);
}
.pwa-banner-later:hover { background: var(--mist); }
.pwa-banner-install {
  background: var(--ink);
  color: #fff;
  border: 1px solid var(--ink);
  border-radius: var(--radius-pill);
  padding: 7px 18px;
  font-size: 12px;
  font-weight: var(--weight-bold);
  cursor: pointer;
  letter-spacing: 0.02em;
  transition: background var(--t-fast);
}
.pwa-banner-install:hover { background: var(--ink-soft); }
.pwa-banner-close {
  position: absolute;
  top: 8px; right: 8px;
  width: 24px; height: 24px;
  display: flex; align-items: center; justify-content: center;
  background: transparent;
  border: none;
  color: var(--steel);
  cursor: pointer;
  border-radius: var(--radius-sm);
  opacity: 0.6;
  transition: opacity var(--t-fast), background var(--t-fast);
}
.pwa-banner-close:hover { opacity: 1; background: var(--mist); }
@media (max-width: 600px) {
  .pwa-install-banner { padding: 12px 14px; gap: 10px; }
  .pwa-banner-title { font-size: 13px; }
  .pwa-banner-desc { font-size: 11px; }
  .pwa-banner-actions { flex-direction: column-reverse; }
  .pwa-banner-later, .pwa-banner-install { padding: 6px 12px; font-size: 11px; }
}

/* ─── iOS 설치 가이드 오버레이 ─── */
.pwa-ios-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.48);
  backdrop-filter: blur(3px);
  z-index: 9999;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}
.pwa-ios-card {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 24px 22px 20px;
  max-width: 380px;
  width: 100%;
  box-shadow: var(--shadow-lift);
  position: relative;
}
.pwa-ios-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 18px;
}
.pwa-ios-title {
  font-size: 17px;
  font-weight: var(--weight-bold);
  color: var(--ink);
  letter-spacing: var(--track-tight);
}
.pwa-ios-close {
  background: transparent;
  border: none;
  color: var(--steel);
  cursor: pointer;
  padding: 4px;
  border-radius: var(--radius-sm);
  display: flex; align-items: center;
}
.pwa-ios-close:hover { background: var(--mist); color: var(--ink); }
.pwa-ios-steps {
  display: flex;
  flex-direction: column;
  gap: 14px;
  margin-bottom: 18px;
}
.pwa-ios-step {
  display: flex;
  gap: 12px;
  align-items: flex-start;
  font-size: 13.5px;
  color: var(--ink);
  line-height: 1.5;
}
.pwa-ios-num {
  flex-shrink: 0;
  width: 24px; height: 24px;
  background: var(--ink);
  color: #fff;
  border-radius: 50%;
  font-size: 12px;
  font-weight: var(--weight-bold);
  display: flex;
  align-items: center;
  justify-content: center;
}
.pwa-ios-note {
  font-size: 11px;
  color: var(--steel);
  padding-top: 14px;
  border-top: 1px solid var(--hairline);
  line-height: 1.5;
  text-align: center;
  letter-spacing: 0.01em;
}

/* ─── 알림 권한 pre-prompt ─── */
.pwa-preprompt-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.52);
  backdrop-filter: blur(4px);
  z-index: 10000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: pre-prompt-in 0.3s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes pre-prompt-in {
  from { opacity: 0; }
  to { opacity: 1; }
}
.pwa-preprompt-card {
  background: var(--paper);
  border-radius: var(--radius-lg);
  padding: 32px 28px 24px;
  max-width: 360px;
  width: 100%;
  box-shadow: var(--shadow-lift);
  text-align: center;
  animation: pre-prompt-scale 0.4s cubic-bezier(0.22, 1, 0.36, 1);
}
@keyframes pre-prompt-scale {
  from { transform: scale(0.92); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
.pwa-preprompt-icon {
  width: 72px; height: 72px;
  margin: 0 auto 18px;
  background: var(--mist);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink);
}
.pwa-preprompt-icon svg { animation: bell-wiggle 2.4s ease-in-out infinite; transform-origin: top center; }
@keyframes bell-wiggle {
  0%, 60%, 100% { transform: rotate(0); }
  5%  { transform: rotate(-8deg); }
  10% { transform: rotate(6deg); }
  15% { transform: rotate(-4deg); }
  20% { transform: rotate(2deg); }
  25% { transform: rotate(0); }
}
.pwa-preprompt-title {
  font-size: 19px;
  font-weight: var(--weight-bold);
  color: var(--ink);
  letter-spacing: var(--track-tight);
  margin-bottom: 10px;
}
.pwa-preprompt-desc {
  font-size: 13.5px;
  color: var(--steel);
  line-height: 1.6;
  margin-bottom: 24px;
}
.pwa-preprompt-actions {
  display: flex;
  gap: 8px;
}
.pwa-preprompt-later {
  flex: 1;
  background: transparent;
  color: var(--steel);
  border: 1px solid var(--hairline-strong);
  border-radius: var(--radius-pill);
  padding: 11px 0;
  font-size: 13px;
  font-weight: var(--weight-medium);
  cursor: pointer;
  transition: background var(--t-fast);
}
.pwa-preprompt-later:hover { background: var(--mist); }
.pwa-preprompt-allow {
  flex: 1.3;
  background: var(--ink);
  color: #fff;
  border: 1px solid var(--ink);
  border-radius: var(--radius-pill);
  padding: 11px 0;
  font-size: 13px;
  font-weight: var(--weight-bold);
  letter-spacing: 0.02em;
  cursor: pointer;
  transition: background var(--t-fast);
}
.pwa-preprompt-allow:hover { background: var(--ink-soft); }

/* ─── 달력 이벤트 — 알림 예약 자동 생성분 ─── */
/* 당일(D-day): 모노그레이 진한 칩 — "오늘 처리할 일" */
.cal-event.type-alert-due {
  background: #4B4D52 !important;
  color: #fff !important;
  font-weight: 700 !important;
  border: 1px solid #4B4D52 !important;
}
.cal-event.type-alert-due .cal-event-icon { color: #fff !important; }
/* 사전 알림(D-N): 밝은 회색 칩 + 좌측 보더 — "예고" 느낌으로 구분 */
.cal-event.type-alert-notify {
  background: #F4F5F7 !important;
  color: #4B5563 !important;
  font-weight: 700 !important;
  border: 1px solid rgba(75, 85, 99, 0.24) !important;
  border-left: 3px solid rgba(75, 85, 99, 0.55) !important;
  font-style: normal;
  opacity: 0.96 !important;
}
.cal-event.type-alert-notify .cal-event-icon { color: #6B7280 !important; }
.cal-event.type-alert-done {
  background: #F3F4F6;
  color: #6B7280;
  font-weight: var(--weight-medium);
  text-decoration: line-through;
  border: 1px solid rgba(75,85,99,0.18);
}
.cal-event.type-alert-done .cal-event-icon { color: #6B7280 !important; }

/* ─── 달력 (2026-04-27 날짜 숫자 축소 + 일정 영역 확보) ─── */
.cal-day-label {
  font-size: 12px !important;
  padding: 12px 0 8px !important;
  letter-spacing: 0.08em !important;
}
.cal-cell {
  min-height: 140px !important;
  padding: 6px 6px !important;
}
.cal-date {
  font-size: 12px !important;
  width: 22px !important;
  height: 22px !important;
  margin-bottom: 4px !important;
  font-weight: 600 !important;
}
.cal-date.today-num {
  font-size: 12px !important;
  background: var(--ink) !important;
  color: #fff !important;
  font-weight: 700 !important;
}
.cal-event {
  font-size: 12px !important;
  padding: 4px 8px !important;
  margin-bottom: 3px !important;
  gap: 5px !important;
  border-radius: 5px !important;
  display: flex !important;
  width: 100% !important;
  box-sizing: border-box !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}
.cal-event-icon { width: 16px !important; height: 16px !important; }
.cal-event-icon svg { width: 14px !important; height: 14px !important; }
/* 커스텀 카테고리 칩 — 아이콘 색을 칩 fg로 강제 (main.css의 rgba 회색 오버라이드) */
.cal-event[data-custom-color="1"] .cal-event-icon {
  color: inherit !important;
}
.cal-event[data-custom-color="1"] .cal-event-icon svg {
  stroke: currentColor !important;
}
.cal-event.type-alert-due span,
.cal-event.type-alert-notify span {
  box-shadow: 0 0 4px rgba(0,0,0,0.12);
}

/* ══════════════════════════════════════════════════
   좌측 사이드바 — 세이지 그린 (2026-04-23)
   Aesop/Loewe 계열 미드톤 웜 뉴트럴. 식품·자연 메타포.
   ══════════════════════════════════════════════════ */

:root {
  --sage:        #E1DED5;   /* 한 톤 짙게 — 본문과 확실한 분리 */
  --sage-deep:   #C8C4BA;   /* 보더·hover */
  --sage-soft:   rgba(0, 0, 0, 0.04);    /* hover */
  --sage-line:   rgba(0, 0, 0, 0.08);    /* 보더 */
  --sage-text:   #2A2E35;                   /* 차콜 잉크 */
  --sage-mute:   #6B6F78;                   /* 뮤트 그레이 */
}

.sidebar {
  width: 280px !important;
  background: var(--sage) !important;
  border-right: 1.5px solid rgba(0, 0, 0, 0.28) !important;
  box-shadow: 2px 0 0 rgba(0, 0, 0, 0.08), 10px 0 32px rgba(0, 0, 0, 0.12) !important;
  scrollbar-width: thin !important;
  scrollbar-color: rgba(0, 0, 0, 0.28) transparent !important;
}
.main-area { margin-left: 280px !important; }
@media (max-width: 900px) { .main-area { margin-left: 0 !important; } }
.sidebar::-webkit-scrollbar { width: 6px !important; background: transparent !important; }
.sidebar::-webkit-scrollbar-track { background: transparent !important; }
.sidebar::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.22) !important;
  border-radius: 999px !important;
  border: 1px solid transparent !important;
  background-clip: padding-box !important;
}
.sidebar::-webkit-scrollbar-thumb:hover { background: rgba(0, 0, 0, 0.38) !important; }

/* 메인 영역 스크롤바도 같은 톤 */
.main-area, .content-section, .ccp-page {
  scrollbar-width: thin;
  scrollbar-color: rgba(0, 0, 0, 0.18) transparent;
}
body::-webkit-scrollbar,
.main-area::-webkit-scrollbar,
.content-section::-webkit-scrollbar { width: 10px; background: transparent; }
body::-webkit-scrollbar-track,
.main-area::-webkit-scrollbar-track,
.content-section::-webkit-scrollbar-track { background: transparent; }
body::-webkit-scrollbar-thumb,
.main-area::-webkit-scrollbar-thumb,
.content-section::-webkit-scrollbar-thumb {
  background: rgba(0, 0, 0, 0.18);
  border-radius: 999px;
  border: 2px solid transparent;
  background-clip: padding-box;
}
body::-webkit-scrollbar-thumb:hover,
.main-area::-webkit-scrollbar-thumb:hover,
.content-section::-webkit-scrollbar-thumb:hover { background: rgba(0, 0, 0, 0.32); background-clip: padding-box; }

/* 로고 영역 — 사이드바와 동일 bg, 흰 로고 원본 사용 */
.sidebar-logo {
  background: transparent !important;
  border-bottom: 1px solid var(--sage-line) !important;
  padding: 18px var(--gap-4) !important;
  justify-content: center !important;
  position: relative;
}
.sidebar-logo::after { content: none !important; }
.sidebar-logo img,
.sidebar-logo-icon img {
  filter: invert(1) brightness(0.18) !important;  /* 흰 로고 → 차콜 잉크 */
  width: 150px !important;
  height: 150px !important;
  max-width: 150px !important;
  max-height: 150px !important;
  object-fit: contain !important;
}
.sidebar-logo-name { color: #2A2E35 !important; }
.sidebar-logo-sub  {
  color: #6B6F78 !important;
  letter-spacing: 0.14em !important;
  text-transform: uppercase;
  font-size: 9px !important;
}

/* 섹션 라벨 */
.sidebar-group-label,
.sidebar-section-label {
  color: #6E6E75 !important;
  font-size: 13px !important;
  letter-spacing: 0.06em !important;
  font-weight: 800 !important;
  text-transform: uppercase !important;
  border-top: 1px solid rgba(0, 0, 0, 0.14) !important;
  padding: 14px 16px 8px !important;
  margin-top: 0 !important;
}

.sidebar-period-label {
  color: var(--sage-mute) !important;
  border-top-color: var(--sage-line) !important;
}

/* 메뉴 아이템 */
.sidebar-item,
.sidebar #menu-temperature,
.sidebar #menu-temperature:hover,
.sidebar #menu-temperature.active {
  color: #444444 !important;
}
.sidebar-item {
  border-left: 2px solid transparent !important;
  font-size: 14.5px !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  padding: 11px var(--gap-4) !important;
  transition: background var(--t-fast), color var(--t-fast), border-left-color var(--t-fast) !important;
}
.sidebar-item:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: #444444 !important;
}
.sidebar-item.active {
  background: transparent !important;
  color: #444444 !important;
  border-left: 3px solid #444444 !important;
  font-weight: 900 !important;
}

/* 결재함 메뉴 — 어떤 상태/role 에서도 다른 메뉴와 동일한 톤 강제 */
#menu-approval,
#menu-approval:not(.active),
body.role-approver #menu-approval,
body.role-approver #menu-approval:not(.active) {
  background: transparent !important;
  color: #444444 !important;
  font-weight: 800 !important;
  opacity: 1 !important;
  border-radius: 0 !important;
}
#menu-approval .sidebar-item-icon,
#menu-approval .sidebar-item-icon svg,
body.role-approver #menu-approval .sidebar-item-icon,
body.role-approver #menu-approval .sidebar-item-icon svg {
  color: #444444 !important;
  stroke: #444444 !important;
  opacity: 1 !important;
}
.sidebar-item.active::before { display: none !important; content: none !important; }
.sidebar-item-icon { opacity: 0.95 !important; color: #444444 !important; }
.sidebar-item-icon svg { stroke: #444444 !important; }
.sidebar-item:hover .sidebar-item-icon,
.sidebar-item.active .sidebar-item-icon { opacity: 1 !important; }
/* 비상대응: 딥 마룬 — 읽히되 튀지 않게 */
.sidebar #menu-emergency,
.sidebar #menu-emergency:hover,
.sidebar #menu-emergency.active {
  color: #7F1D1D !important;
  font-weight: 800 !important;
}
.sidebar #menu-emergency .sidebar-item-icon,
.sidebar #menu-emergency .sidebar-item-icon svg {
  color: #7F1D1D !important;
  stroke: #7F1D1D !important;
  opacity: 1 !important;
}
.sidebar #menu-emergency.active { background: rgba(127, 29, 29, 0.08) !important; border-left-color: #7F1D1D !important; }

/* 아코디언 헤더 */
.sidebar-accordion-header {
  color: #444444 !important;
  font-size: 14.5px !important;
  font-weight: 800 !important;
  letter-spacing: -0.015em !important;
  background: transparent !important;
  border-radius: 0 !important;
  margin: 0 !important;
  padding: 10px var(--gap-4) !important;
  transition: background var(--t-fast), color var(--t-fast) !important;
}
.sidebar-accordion-header:hover {
  background: rgba(0, 0, 0, 0.06) !important;
  color: #444444 !important;
}
.sidebar-accordion-header.open { color: #444444 !important; font-weight: 800 !important; }
.sidebar-accordion-header.open + .sidebar-accordion-body {
  max-height: none !important;
  overflow: visible !important;
}
.sidebar-accordion-header.active {
  color: #444444 !important;
  background: rgba(0, 0, 0, 0.08) !important;
}
.sidebar-accordion-header svg,
.sidebar-accordion-header .sidebar-item-icon,
.sidebar-accordion-header .sidebar-item-icon svg {
  color: #444444 !important;
  stroke: #444444 !important;
  opacity: 0.95 !important;
}
.accordion-arrow { opacity: 0.6; }
.sidebar-accordion-header:hover .accordion-arrow,
.sidebar-accordion-header.open .accordion-arrow { opacity: 1; }

/* 서브 아이템 */
.sidebar-sub-item {
  color: #1A1F28 !important;
  font-size: 14.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  line-height: 1.35 !important;
  min-height: 40px !important;
  box-sizing: border-box !important;
  padding: 10px var(--gap-4) 10px 24px !important;
  margin: 0 !important;
  border-left: 2px solid transparent !important;
  border-radius: 0 !important;
  transition: background var(--t-fast), color var(--t-fast), border-left-color var(--t-fast) !important;
  /* 긴 제목은 한 줄로 축약 — 버튼 높이 통일 */
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  display: flex !important;
  align-items: center !important;
  min-width: 0 !important;
}
.sidebar-item.vfc-sidebar-standalone {
  gap: 12px !important;
}
.sidebar-sub-item > span:first-of-type,
.sidebar-sub-item > span:last-child {
  flex-shrink: 0;
}
.sidebar-sub-item > :not(span):not(svg) { min-width: 0; overflow: hidden; text-overflow: ellipsis; }
.sidebar-sub-item:hover {
  background: rgba(0, 0, 0, 0.04) !important;
  color: #6E6E75 !important;
  border-left-color: rgba(0, 0, 0, 0.10) !important;
}
.sidebar-sub-item.active {
  color: #6E6E75 !important;
  background: rgba(0, 0, 0, 0.07) !important;
  border-left: 2px solid #6E6E75 !important;
  font-weight: var(--weight-medium) !important;
}
.sidebar-sub-item.active::before { display: none !important; content: none !important; }

/* 일지 상태 점 — 고정 크기, 차분한 상태 표시 */
.sidebar-sub-item::before {
  content: '' !important;
  display: inline-block !important;
  width: 10px !important; height: 10px !important;
  border-radius: 50% !important;
  margin-right: 10px !important;
  flex-shrink: 0 !important;
  position: relative;
  transition: background var(--t-fast), border-color var(--t-fast), box-shadow var(--t-fast);
  /* 기본(발생시/입고시/미집계 일지): 비활성 회색이 아니라 "필요 시 작성" 표시 */
  background: #F8FAFC !important;
  border: 1.5px solid #9CA3AF !important;
  box-shadow: inset 0 0 0 2px rgba(255,255,255,0.92);
  animation: none !important;
}
.sidebar-sub-item.done::before {
  background: #3F8F6B !important;
  border-color: #3F8F6B !important;
  box-shadow: 0 0 0 2px rgba(63,143,107,0.12);
  animation: none !important;
}
.sidebar-sub-item.partial::before {
  background: #D6A13A !important;
  border-color: #D6A13A !important;
  box-shadow: 0 0 0 2px rgba(214,161,58,0.14);
  animation: none !important;
}
.sidebar-sub-item.undone::before {
  background: #C75C4A !important;
  border-color: #C75C4A !important;
  box-shadow: 0 0 0 2px rgba(199,92,74,0.14);
  animation: none !important;
}
.sidebar-sub-item:hover::before { transform: none !important; }

/* ── 완료: 부드러운 halo + 미세 스케일 ── */
@keyframes dot-done-glow {
  0%, 100% { transform: scale(1);    box-shadow: 0 0 0 0 rgba(22,101,52,0.4), 0 0 8px rgba(22,101,52,0.45); }
  50%      { transform: scale(1.05); box-shadow: 0 0 0 4px rgba(22,101,52,0.10), 0 0 11px rgba(22,101,52,0.6); }
}

/* ── 부분: 노란색 명확, 잔잔한 블링크 ── */
@keyframes dot-partial-blink {
  0%, 100% { opacity: 1;    box-shadow: 0 0 0 0 rgba(234,179,8,0.35), 0 0 9px rgba(234,179,8,0.55); }
  50%      { opacity: 0.65; box-shadow: 0 0 0 3px rgba(234,179,8,0.10), 0 0 11px rgba(234,179,8,0.65); }
}

/* ── 미작성: 한 겹 펄스 + 미세 박동 ── */
@keyframes dot-undone-pulse {
  0%   { transform: scale(1);    box-shadow: 0 0 0 0 rgba(220,38,38,0.55), 0 0 9px rgba(220,38,38,0.55); }
  50%  { transform: scale(1.05); }
  70%  { box-shadow: 0 0 0 5px rgba(220,38,38,0), 0 0 12px rgba(220,38,38,0.65); }
  100% { transform: scale(1);    box-shadow: 0 0 0 0 rgba(220,38,38,0), 0 0 9px rgba(220,38,38,0.55); }
}

.accordion-progress { color: var(--sage-mute) !important; }
.accordion-progress.all-done { color: #166534 !important; font-weight: 600 !important; }

/* 사이드바 배지 */
/* ── 흰색 하드코딩 override (main.css leak 방지) ── */
.sidebar .sidebar-logo-sub       { color: #6B6F78 !important; }
.sidebar .sidebar-accordion-header.open { color: #444444 !important; }
.sidebar .sidebar-sub-item,
.sidebar .sidebar-sub-item.partial,
.sidebar .sidebar-sub-item.done,
.sidebar .sidebar-sub-item.undone       { color: #1A1F28 !important; }
.sidebar .sidebar-period-label {
  color: #444444 !important;
  font-weight: 800 !important;
  font-size: 14.5px !important;
  letter-spacing: -0.005em !important;
  text-transform: none !important;
  padding: 12px 16px 8px !important;
  border-top: 1px solid rgba(0, 0, 0, 0.12) !important;
}
.sidebar-menu-group {
  border-top-color: rgba(0, 0, 0, 0.10) !important;
}
/* 인라인 style="border-top:rgba(255..." override */
.sidebar-menu-group[style*="rgba(255"] { border-top-color: rgba(0, 0, 0, 0.10) !important; }

.sidebar-badge {
  background: #1F2937 !important;
  color: #fff !important;
  font-weight: var(--weight-bold) !important;
  font-size: 10px !important;
  letter-spacing: 0 !important;
  min-width: 18px !important;
  height: 18px !important;
  padding: 0 6px !important;
  border-radius: var(--radius-pill) !important;
  align-items: center;
  justify-content: center;
  text-align: center;
  line-height: 18px;
}

/* 비상대응 — 세이지 배경 위 따뜻한 적갈색 */
#menu-emergency {
  color: #F4A6A6 !important;
}
#menu-emergency:hover {
  background: rgba(244, 166, 166, 0.14) !important;
  color: #fff !important;
}



/* ───────────────────────────────────────────────
   수정 이력 (audit history) — editorial / compliance
─────────────────────────────────────────────── */
.audit-page { padding: 28px 32px 40px; max-width: 1200px; margin: 0 auto; }
.audit-page-head {
  display: flex; align-items: flex-end; justify-content: space-between;
  flex-wrap: wrap; gap: 16px; margin-bottom: 22px;
  border-bottom: 1px solid rgba(0,0,0,0.12); padding-bottom: 14px;
}
.audit-page-title {
  font-size: 22px; font-weight: 700; letter-spacing: -0.02em;
  color: #444444;
}
.audit-filters { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.audit-select, .audit-date {
  padding: 7px 12px; border: 1px solid rgba(0,0,0,0.22); border-radius: 2px;
  background: transparent; color: #444444; font-size: 12.5px; font-weight: 500;
  font-family: Pretendard, -apple-system, sans-serif; letter-spacing: -0.005em;
  transition: border-color 140ms ease;
}
.audit-select:hover, .audit-date:hover { border-color: rgba(0,0,0,0.48); }
.audit-select:focus, .audit-date:focus { outline: none; border-color: #444444; }
.audit-date { font-variant-numeric: tabular-nums; }
.audit-date-sep { color: rgba(0,0,0,0.4); font-size: 13px; }

.audit-table-wrap { overflow-x: auto; }
.audit-table {
  width: 100%; border-collapse: collapse; font-size: 13px;
  font-family: Pretendard, -apple-system, sans-serif;
  color: #444444;
}
.audit-table thead tr {
  border-top: 1px solid #444444;
  border-bottom: 1px solid rgba(0,0,0,0.24);
}
.audit-table th {
  text-align: left; padding: 11px 14px;
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: rgba(0,0,0,0.6);
  white-space: nowrap;
}
.audit-table tbody tr { border-bottom: 1px solid rgba(0,0,0,0.08); }
.audit-table tbody tr:hover { background: rgba(0,0,0,0.025); }
.audit-table td { padding: 13px 14px; vertical-align: top; }

.audit-td-date {
  white-space: nowrap; font-variant-numeric: tabular-nums;
  color: rgba(0,0,0,0.7); font-size: 12.5px; font-weight: 500;
}
.audit-td-user { white-space: nowrap; }
.audit-user-name { color: #444444; font-weight: 600; font-size: 13px; }
.audit-user-role {
  display: inline-block; margin-left: 6px;
  color: rgba(0,0,0,0.5); font-size: 11px; font-weight: 500;
}
.audit-td-table {
  color: rgba(0,0,0,0.65); font-size: 12px; font-weight: 500;
  white-space: nowrap;
}
.audit-td-desc {
  color: #444444; font-size: 12.5px; font-weight: 500; line-height: 1.5;
  max-width: 520px;
}

.audit-action {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 3px 10px 3px 9px; border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.22);
  font-size: 11.5px; font-weight: 600; letter-spacing: -0.005em;
  color: #444444; white-space: nowrap;
}
.audit-action-dot {
  width: 5px; height: 5px; border-radius: 50%;
  background: rgba(0,0,0,0.35);
}
.audit-action-create  { border-color: rgba(34,122,84,0.35); color: #1F5A3C; }
.audit-action-create  .audit-action-dot { background: #4F9A6E; }
.audit-action-update  { border-color: rgba(52,94,150,0.35); color: #2E4B78; }
.audit-action-update  .audit-action-dot { background: #5C82B5; }
.audit-action-approve { border-color: rgba(52,94,150,0.35); color: #2E4B78; }
.audit-action-approve .audit-action-dot { background: #5C82B5; }
.audit-action-delete  { border-color: rgba(140,48,42,0.35); color: #7F1D1D; }
.audit-action-delete  .audit-action-dot { background: #B54B45; }
.audit-action-reject  { border-color: rgba(140,48,42,0.35); color: #7F1D1D; }
.audit-action-reject  .audit-action-dot { background: #B54B45; }
.audit-action-withdraw{ border-color: rgba(154,102,36,0.38); color: #6B4316; }
.audit-action-withdraw .audit-action-dot { background: #B58540; }
.audit-action-restore { border-color: rgba(89,61,123,0.35); color: #473160; }
.audit-action-restore .audit-action-dot { background: #7E5FA8; }

.audit-count {
  margin-top: 14px; text-align: right;
  font-size: 11.5px; font-weight: 500; color: rgba(0,0,0,0.55);
  font-variant-numeric: tabular-nums; letter-spacing: 0.02em;
}
.audit-empty {
  text-align: center; padding: 56px 24px;
  color: rgba(0,0,0,0.5); font-size: 13px; font-weight: 500;
  font-family: Pretendard, -apple-system, sans-serif;
}
.audit-empty-err { color: #7F1D1D; }

/* ───────────────────────────────────────────────
   사유 입력 피커 (수정 요청 / 결재 철회 공용)
─────────────────────────────────────────────── */
.reason-intro {
  font-size: 13px; color: rgba(0,0,0,0.72); line-height: 1.65;
  margin-bottom: 16px; padding-bottom: 14px;
  border-bottom: 1px solid rgba(0,0,0,0.1);
}
.reason-intro strong { color: #444444; font-weight: 700; }
.reason-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: rgba(0,0,0,0.55);
  margin-bottom: 8px;
}
.reason-chips {
  display: flex; flex-wrap: wrap; gap: 6px;
}
.reason-chip {
  padding: 6px 12px; border-radius: 999px;
  border: 1px solid rgba(0,0,0,0.22); background: transparent;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 12px; font-weight: 500; color: #444444;
  letter-spacing: -0.005em; cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease;
}
.reason-chip:hover {
  background: rgba(0,0,0,0.05); border-color: rgba(0,0,0,0.42);
}
.reason-textarea {
  width: 100%; padding: 11px 12px;
  border: 1px solid rgba(0,0,0,0.22); border-radius: 2px;
  background: #FBF7ED;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 13px; line-height: 1.55; color: #444444;
  resize: vertical; min-height: 72px;
  transition: border-color 140ms ease, background 140ms ease;
}
.reason-textarea:focus {
  outline: none; border-color: #444444; background: #fff;
}
.reason-textarea::placeholder { color: rgba(0,0,0,0.4); }
.reason-counter {
  margin-top: 6px; text-align: right;
  font-size: 11px; color: rgba(0,0,0,0.45);
  font-variant-numeric: tabular-nums;
}

/* 결재 철회 버튼 — editorial ghost */
.btn-withdraw-apv {
  padding: 7px 16px; border-radius: 999px;
  background: transparent; color: #7F1D1D;
  border: 1px solid rgba(140,48,42,0.42);
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 12.5px; font-weight: 600; letter-spacing: -0.005em;
  cursor: pointer;
  transition: background 140ms ease, border-color 140ms ease;
}
.btn-withdraw-apv:hover {
  background: rgba(140,48,42,0.06); border-color: rgba(140,48,42,0.68);
}

/* ───────────────────────────────────────────────
   처리이력 툴바 (검색 + 기간 + 빠른 기간)
─────────────────────────────────────────────── */
.apv-hist-toolbar {
  display: flex; align-items: center; gap: 10px;
  flex-wrap: wrap; margin-bottom: 16px;
  padding: 10px 12px;
  background: #F9FAFB !important;
  border: 1px solid #E5E7EB !important;
  border-radius: 2px;
}
.apv-hist-search {
  display: inline-flex; align-items: center; gap: 8px;
  min-width: 260px; flex: 1 1 260px;
  padding: 6px 10px 6px 12px;
  background: #fff !important;
  border: 1px solid rgba(75,85,99,0.22) !important;
  border-radius: 999px;
  transition: border-color 140ms ease;
}
.apv-hist-search:focus-within { border-color: #4B5563 !important; }
.apv-hist-search svg { color: rgba(75,85,99,0.55) !important; flex-shrink: 0; }
.apv-hist-search input {
  flex: 1; min-width: 0;
  border: none; outline: none; background: transparent;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 13px; font-weight: 500; color: #374151 !important;
  letter-spacing: -0.005em;
}
.apv-hist-search input::placeholder { color: rgba(75,85,99,0.45) !important; }
.apv-hist-search-clear {
  flex-shrink: 0; width: 20px; height: 20px;
  display: inline-flex; align-items: center; justify-content: center;
  border: none; background: transparent; cursor: pointer;
  color: rgba(75,85,99,0.5) !important; border-radius: 50%;
  transition: background 140ms ease, color 140ms ease;
}
.apv-hist-search-clear:hover { background: rgba(75,85,99,0.08) !important; color: #4B5563 !important; }
.apv-hist-search input:placeholder-shown ~ .apv-hist-search-clear { visibility: hidden; }

.apv-hist-range { display: inline-flex; align-items: center; gap: 6px; }
.apv-hist-range-label {
  font-size: 11px; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: #6B7280 !important;
}
.apv-hist-date {
  padding: 6px 10px;
  border: 1px solid rgba(75,85,99,0.22) !important; border-radius: 2px;
  background: #fff !important; color: #374151 !important;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 12.5px; font-weight: 500;
  font-variant-numeric: tabular-nums;
  transition: border-color 140ms ease;
}
.apv-hist-date:hover { border-color: rgba(75,85,99,0.48) !important; }
.apv-hist-date:focus { outline: none; border-color: #4B5563 !important; }
.apv-hist-range-sep { color: rgba(75,85,99,0.4) !important; font-size: 13px; }
.apv-hist-count { color: #6B7280 !important; }

.apv-hist-quick { display: inline-flex; gap: 4px; flex-wrap: wrap; }
.apv-hist-quick button {
  padding: 6px 11px;
  background: transparent !important; color: #6B7280 !important;
  border: 1px solid rgba(75, 85, 99, 0.22) !important; border-radius: 999px;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 12px; font-weight: 500; letter-spacing: -0.005em;
  cursor: pointer;
  transition: background 140ms ease, color 140ms ease, border-color 140ms ease;
}
.apv-hist-quick button:hover {
  background: rgba(75, 85, 99, 0.06) !important;
  color: #4B5563 !important;
  border-color: rgba(75, 85, 99, 0.42) !important;
}
.apv-hist-quick button.active {
  background: #4B5563 !important;
  color: #FFFFFF !important;
  border-color: #4B5563 !important;
  font-weight: 600 !important;
}

.apv-hist-count {
  margin-left: auto;
  font-size: 11.5px; font-weight: 500;
  color: rgba(0,0,0,0.55);
  font-variant-numeric: tabular-nums; letter-spacing: 0.02em;
}

/* ═══════════════════════════════════════════════════════
   일지 에디터 / 본문 테이블 — editorial 톤 (Phase 1)
   대상: .journal-toolbar / .journal-body / .jform-table
═══════════════════════════════════════════════════════ */

/* ── 툴바 ── */
.journal-toolbar {
  background: #ECECEA !important;
  border-bottom: 1px solid #C4C4C1 !important;
  padding: 14px 24px !important;
  gap: 14px !important;
}
.journal-toolbar label {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #4A4A48 !important;
}
.journal-toolbar input[type=date],
.journal-toolbar input[type=text],
.journal-toolbar input[type=number],
.journal-toolbar select {
  border: 1px solid #D4D4D1 !important;
  border-radius: 4px !important;
  padding: 8px 11px !important;
  font-family: Pretendard, -apple-system, sans-serif;
  font-size: 14.5px !important;
  font-weight: 500;
  color: #1A1A1A;
  background: #fff;
  letter-spacing: -0.005em;
  font-variant-numeric: tabular-nums;
  transition: border-color 140ms ease;
}
.journal-toolbar input:hover,
.journal-toolbar select:hover { border-color: #9A9A97 !important; }
.journal-toolbar input:focus,
.journal-toolbar select:focus {
  outline: none;
  border-color: #1A1A1A !important;
  box-shadow: 0 0 0 2px rgba(26,26,26,0.06);
}

/* ── 본문 ── */
.journal-body { padding: 22px 26px !important; background: #fff; }

/* ── 테이블 — 공문서 스타일 (뚜렷한 선) ── */
.jform-table {
  font-family: Pretendard, -apple-system, sans-serif !important;
  color: #1A1A1A !important;
  font-size: 14.5px !important;
  border: 1.5px solid #6B6B68 !important;
}
.jform-table td, .jform-table th {
  border: 1px solid #8C8C88 !important;
  padding: 10px 12px !important;
  font-weight: 500 !important;
}

/* 대제목 — 어두운 회색 바 (블랙 아님) */
.jform-table .jtitle {
  background: #4A4A48 !important;
  color: #fff !important;
  font-size: 18px !important;
  font-weight: 700 !important;
  letter-spacing: -0.005em !important;
  padding: 16px !important;
  border: 1.5px solid #4A4A48 !important;
}

/* 서브 타이틀 / 헤더 / 기간 — 미드 그레이 (선과 명확 대비) */
.jform-table .jsubtitle,
.jform-table .jhdr,
.jform-table .jperiod {
  background: #D8D8D4 !important;
  color: #1A1A1A !important;
  font-weight: 700 !important;
  font-size: 13.5px !important;
  letter-spacing: 0 !important;
  border-color: #8C8C88 !important;
}
.jform-table .jhdr { padding: 10px 8px !important; }

/* 테이블 내 input/select/textarea */
.jform-table input[type=text],
.jform-table input[type=number],
.jform-table input[type=date],
.jform-table input[type=time],
.jform-table select,
.jform-table textarea {
  border: 1px solid #8C8C88 !important;
  border-radius: 3px !important;
  padding: 6px 9px !important;
  font-family: Pretendard, -apple-system, sans-serif !important;
  font-size: 14px !important;
  color: #1A1A1A !important;
  background: #fff !important;
  font-variant-numeric: tabular-nums;
  transition: border-color 140ms ease, box-shadow 140ms ease;
}
.jform-table input:hover,
.jform-table select:hover,
.jform-table textarea:hover { border-color: #9A9A97 !important; }
.jform-table input:focus,
.jform-table select:focus,
.jform-table textarea:focus {
  outline: none !important;
  border-color: #1A1A1A !important;
  box-shadow: 0 0 0 2px rgba(26,26,26,0.06) !important;
  background: #fff !important;
}

/* 체크박스 / 라디오 */
.jform-table input[type=checkbox],
.jform-table input[type=radio] {
  accent-color: #2A2A28 !important;
  width: 17px; height: 17px; cursor: pointer;
}

.jform-table .jpass,
.jform-table .jfail,
.jform-table .jna {
  font-weight: 600 !important;
  letter-spacing: -0.005em;
}

.jform-table tbody tr:hover td:not(.jtitle):not(.jsubtitle):not(.jhdr):not(.jperiod) {
  background: #FAFAF9;
}

/* ── 비고 / 서명 ── */
.jform-note,
.journal-box .jform-signature {
  background: #ECECEA !important;
  border: 1px solid #C4C4C1 !important;
  border-radius: 4px !important;
  padding: 14px !important;
  margin-top: 16px !important;
}
.jform-note label,
.journal-box .jform-signature label {
  font-size: 14px !important;
  font-weight: 600 !important;
  color: #4A4A48 !important;
}
.jform-note textarea {
  width: 100%;
  border: 1px solid #D4D4D1 !important;
  border-radius: 4px !important;
  padding: 11px !important;
  font-family: Pretendard, -apple-system, sans-serif !important;
  font-size: 14.5px !important;
  color: #1A1A1A !important;
  background: #fff !important;
  resize: vertical;
  transition: border-color 140ms ease;
}
.jform-note textarea:focus {
  outline: none !important;
  border-color: #1A1A1A !important;
  background: #fff !important;
}

/* ── 일지 인라인 날짜/시간 입력 (jmonit) ── */
.jform-table td.jmonit {
  background: #F5F5F3 !important;
}
.jmonit-row {
  display: inline-flex; align-items: center; gap: 6px;
  flex-wrap: wrap; justify-content: center;
  font-size: 13.5px; color: #1A1A1A; font-weight: 600;
}
.jform-table input.jmonit-inp {
  width: 34px !important;
  min-width: 34px !important;
  text-align: center !important;
  padding: 3px 4px !important;
  font-size: 13px !important;
  font-variant-numeric: tabular-nums;
  border: 1px solid #8C8C88 !important;
  border-radius: 3px !important;
  background: #fff !important;
}
.jform-table input.jmonit-inp:focus {
  outline: none !important;
  border-color: #1A1A1A !important;
  box-shadow: 0 0 0 2px rgba(26,26,26,0.08) !important;
}

/* ══════════════════════════════════════════════════
   #4 전역 토큰 재정의 (2026-04-24)
   main.css 의 legacy 블루/오렌지/그린/레드를 에디토리얼 톤으로 일괄 치환.
   인라인 style="background:var(--primary)..." 가 여러 곳 남아있어
   루트에서 값 자체를 바꿔 한 번에 제압한다.
   ══════════════════════════════════════════════════ */
:root {
  --primary: #6E6E75;          /* 모노 그레이 — 버튼/액티브/포커스 통일 */
  --primary-light: #F4F6F9;    /* 연파랑 호버 → 페이퍼 */
  --warning: #92400E;          /* 주황 → 씰 앰버 */
  --warning-light: #F3E9D8;
  --success: #166534;          /* 그린 유지, 톤만 딥하게 */
  --success-light: #E5EFE6;
  --danger:  #B91C1C;          /* 레드 유지, 톤만 딥하게 */
  --danger-light: #F4E3E1;
  --mono-text: #6E6E75;          /* 모노 미디엄 그레이 (--primary와 동일) */
  --mono-accent: #8A8A92;        /* 모노 강조색 */
  --gray2:   rgba(0,0,0,0.10);
  --gray3:   #6E6E75;
}

/* 파란 그라데이션 전역 킬 — 잉크 flat */
[style*="linear-gradient(135deg,#3b82f6"],
[style*="linear-gradient(135deg,#1d4ed8"],
[style*="linear-gradient(135deg, #3b82f6"],
[style*="linear-gradient(135deg, #1d4ed8"] {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
}

/* 오렌지 그라데이션 킬 */
[style*="linear-gradient(135deg,#f59e0b"],
[style*="linear-gradient(135deg,#d97706"],
[style*="linear-gradient(135deg, #f59e0b"],
[style*="linear-gradient(135deg, #d97706"] {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
}

/* SVG 스트로크 블루(#2563eb) — 사이드바 아이콘·검교정 등 — 잉크로 */
.sidebar-item-icon svg[stroke="#2563eb"],
.sidebar-item-icon svg[stroke="#f59e0b"] { stroke: #2A2E35 !important; }
.cw-menu-item-icon svg[stroke="#2563eb"],
.cw-cat-icon svg[stroke="#2563eb"] { stroke: #444444 !important; }

/* "오늘" 인디케이터 작은 파랑 텍스트 — 잉크로 */
span[style*="color:#2563eb"][style*="font-size:10px"] {
  color: #444444 !important;
}

/* ─── showCustomModal (bundle-core.js) 파란 OK 버튼 잡기 ─── */
#vfcConfirmBtns #vfcOkBtn[style*="#1d4ed8"],
#vfcConfirmBtns button[style*="color:#1d4ed8"] {
  color: #444444 !important;
  font-weight: 800 !important;
}
#vfcConfirmBtns #vfcCancelBtn {
  color: #6E6E75 !important;
  border-right: 1px solid rgba(0,0,0,0.10) !important;
}

/* ─── 이모지가 붙은 "수정 후 재요청" 등 주황 버튼 마감 ─── */
button[onclick*="startReRequest"] {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  border-radius: 999px !important;
  letter-spacing: 0 !important;
  font-weight: 600 !important;
}

/* ─── 공통 라운드 축소: rounded-2xl 남발 제거 ─── */
button[style*="border-radius:12px"],
button[style*="border-radius: 12px"],
button[style*="border-radius:10px"],
button[style*="border-radius: 10px"] {
  border-radius: 999px !important;
}
button[style*="border-radius:8px"],
button[style*="border-radius: 8px"],
button[style*="border-radius:6px"],
button[style*="border-radius: 6px"] {
  border-radius: 999px !important;
}

/* ─── 원료수불대장 버튼 가독성 보정: HaccpSelo 모노그레이 토큰 기준 ─── */
#content-raw button {
  font-family: var(--font-body) !important;
  letter-spacing: 0 !important;
  text-decoration: none !important;
  line-height: 1.2 !important;
  -webkit-text-fill-color: currentColor !important;
}
#content-raw button svg {
  flex: 0 0 auto;
  stroke: currentColor !important;
}
#content-raw,
#content-raw .ccp-page,
#content-raw .raw-item-name,
#content-raw .raw-td-num,
#content-raw .raw-daily-worker label,
#content-raw .raw-daily-note label,
#content-raw .prod-form-field label {
  color: var(--ink) !important;
}
#content-raw .raw-date-label,
#content-raw .raw-input-unit,
#content-raw .raw-unit {
  color: var(--ink-soft) !important;
}
#content-raw .raw-daily-table thead,
#content-raw .raw-daily-table thead tr:hover {
  background: var(--paper) !important;
  color: var(--ink) !important;
}
#content-raw .raw-daily-wrap > div[style*="border-top:4px"] {
  border-top-color: var(--ink) !important;
}
#content-raw .raw-date-btn,
#content-sub .raw-date-btn {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 42px !important;
  height: 40px !important;
  padding: 0 13px !important;
  background: #FFFFFF !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
#content-raw .raw-date-btn:hover,
#content-sub .raw-date-btn:hover {
  background: var(--paper) !important;
  border-color: var(--hairline-strong) !important;
  color: var(--ink) !important;
}
#content-raw .raw-date-btn.today,
#content-sub .raw-date-btn.today {
  background: var(--paper) !important;
  color: var(--ink) !important;
  border-color: var(--hairline) !important;
}
#content-raw .raw-date-btn.copy {
  background: var(--paper) !important;
  color: var(--ink) !important;
  border-color: var(--hairline) !important;
}
#content-raw button[onclick="openRawMgmt()"],
#content-raw button[onclick="openRawMgmtAdd()"],
#content-raw button[onclick="addProdMat()"],
#content-raw button[onclick="toggleRawHistory()"] {
  background: #FFFFFF !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
}
#content-raw button[onclick="openSubMgmt()"],
#content-raw .raw-daily-save {
  background: var(--ink) !important;
  color: #FFFFFF !important;
  border: 1px solid var(--ink) !important;
}
#content-raw button[onclick="openRawMgmt()"]:hover,
#content-raw button[onclick="openRawMgmtAdd()"]:hover,
#content-raw button[onclick="addProdMat()"]:hover,
#content-raw button[onclick="toggleRawHistory()"]:hover {
  background: var(--paper) !important;
  border-color: var(--hairline-strong) !important;
  color: var(--ink) !important;
}
#content-raw button[onclick="openSubMgmt()"]:hover,
#content-raw .raw-daily-save:hover {
  background: var(--ink-soft) !important;
  border-color: var(--ink-soft) !important;
  color: #FFFFFF !important;
}
#content-raw #subDailyBodyInRaw button[onclick="openSubMgmt()"] {
  background: #FFFFFF !important;
  color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
  border: 1px solid var(--hairline-strong) !important;
}
#content-raw #subDailyBodyInRaw button[onclick="openSubMgmt()"]:hover {
  background: var(--paper) !important;
  color: var(--ink) !important;
  -webkit-text-fill-color: var(--ink) !important;
}
#content-raw button[onclick="openRawMgmtDel()"] {
  background: #FFFFFF !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
}
#content-raw button[onclick="openRawMgmtDel()"]:hover {
  background: var(--paper) !important;
  border-color: var(--hairline-strong) !important;
  color: var(--ink) !important;
}
#content-raw button[onclick="openRawMgmt()"],
#content-raw button[onclick="openSubMgmt()"],
#content-raw button[onclick="addProdMat()"],
#content-raw #subDailyBodyInRaw button,
#content-raw button[onclick="openRawMgmtAdd()"],
#content-raw button[onclick="openRawMgmtDel()"],
#content-raw button[onclick="toggleRawHistory()"],
#content-raw .raw-daily-save {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  gap: 6px !important;
  min-height: 40px !important;
  padding: 10px 16px !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
  box-shadow: none !important;
}
#content-raw .raw-daily-save {
  font-size: 14px !important;
}
#content-raw.raw-production-first #rawPanel-prod {
  margin-top: 18px !important;
}
#content-raw .raw-easy-guide {
  display: grid;
  grid-template-columns: minmax(220px, 1fr) auto auto;
  gap: 16px;
  align-items: center;
  margin-top: 18px;
  padding: 16px;
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-radius: 8px;
}
#content-raw .raw-easy-guide-kicker {
  color: var(--ink-soft);
  font-size: 12px;
  font-weight: 850;
  margin-bottom: 4px;
}
#content-raw .raw-easy-guide-title {
  color: var(--ink);
  font-size: 17px;
  font-weight: 850;
  line-height: 1.45;
}
#content-raw .raw-easy-steps {
  display: grid;
  grid-template-columns: repeat(3, minmax(120px, 1fr));
  gap: 8px;
}
#content-raw .raw-easy-step {
  display: grid;
  grid-template-columns: 32px 1fr;
  column-gap: 8px;
  row-gap: 2px;
  align-items: center;
  min-height: 58px;
  padding: 10px;
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: 8px;
}
#content-raw .raw-easy-step span {
  grid-row: 1 / 3;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 30px;
  height: 30px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  color: var(--ink);
  font-size: 14px;
  font-weight: 900;
}
#content-raw .raw-easy-step strong {
  color: var(--ink);
  font-size: 13px;
  font-weight: 850;
  line-height: 1.25;
}
#content-raw .raw-easy-step em {
  color: var(--ink-soft);
  font-size: 12px;
  font-style: normal;
  line-height: 1.25;
}
#content-raw .raw-easy-actions {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  min-width: 218px;
}
#content-raw .raw-history-shortcut {
  min-width: 92px !important;
  min-height: 46px !important;
  background: #FFFFFF !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  font-weight: 850 !important;
  white-space: nowrap !important;
}
#content-raw .raw-history-shortcut:hover {
  background: var(--paper) !important;
  border-color: var(--hairline-strong) !important;
}
#content-raw .raw-guide-start {
  min-width: 112px !important;
  min-height: 46px !important;
  background: var(--ink) !important;
  color: #FFFFFF !important;
  border: 1px solid var(--ink) !important;
  border-radius: 8px !important;
  font-size: 14px !important;
  font-weight: 850 !important;
}
#content-raw.raw-production-first #rawPanel-prod > .raw-daily-wrap {
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  box-shadow: none !important;
}
#content-raw .raw-direct-toggle-strip {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: 18px;
  padding: 14px 16px;
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-radius: 8px;
}
#content-raw .raw-direct-worker {
  align-items: end !important;
  background: #FFFFFF !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  padding: 12px !important;
}
#content-raw .raw-direct-worker .raw-daily-worker {
  max-width: 280px;
}
#content-raw .raw-direct-toggle-title {
  color: var(--ink);
  font-size: 14px;
  font-weight: 850;
}
#content-raw .raw-direct-toggle-copy {
  color: var(--ink-soft);
  font-size: 12px;
  line-height: 1.45;
  margin-top: 3px;
}
#content-raw .raw-direct-toggle {
  background: #FFFFFF !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  min-height: 40px !important;
  padding: 10px 15px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}
#content-raw .raw-direct-toggle:hover {
  background: var(--paper) !important;
  border-color: var(--hairline-strong) !important;
}
#content-raw.raw-production-first:not(.raw-direct-open) .raw-direct-panel,
#content-raw.raw-production-first:not(.raw-direct-open) .raw-direct-worker {
  display: none !important;
}
#content-raw.raw-production-first.raw-direct-open .raw-direct-panel,
#content-raw.raw-production-first.raw-direct-open .raw-direct-worker {
  display: block !important;
}
#content-raw .raw-sync-preview {
  grid-column: 1 / -1;
  background: #FFFFFF;
  border: 1px solid var(--hairline);
  border-radius: 8px;
  padding: 14px;
}
#content-raw .raw-sync-preview-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
#content-raw .raw-sync-preview-title {
  color: var(--ink);
  font-size: 14px;
  font-weight: 850;
}
#content-raw .raw-sync-preview-sub,
#content-raw .raw-sync-preview-empty,
#content-raw .raw-sync-preview-note {
  color: var(--ink-soft);
  font-size: 12px;
  line-height: 1.45;
}
#content-raw .raw-sync-preview-badge {
  color: var(--ink-soft);
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: 999px;
  padding: 4px 9px;
  font-size: 11px;
  font-weight: 800;
  white-space: nowrap;
}
#content-raw .raw-sync-preview-body {
  display: grid;
  gap: 6px;
}
#content-raw .raw-sync-preview-row {
  display: grid;
  grid-template-columns: 92px 1fr auto;
  gap: 10px;
  align-items: center;
  min-height: 32px;
  padding: 7px 9px;
  background: var(--paper);
  border: 1px solid var(--hairline);
  border-radius: 7px;
}
#content-raw .raw-sync-preview-kind {
  color: var(--ink-soft);
  font-size: 11px;
  font-weight: 800;
}
#content-raw .raw-sync-preview-name {
  color: var(--ink);
  font-size: 13px;
  font-weight: 800;
  min-width: 0;
}
#content-raw .raw-sync-preview-qty {
  color: var(--ink);
  font-size: 13px;
  font-weight: 850;
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}
#content-raw .prod-ccp-btn {
  min-height: 38px !important;
  background: #FFFFFF !important;
  color: var(--ink-soft) !important;
  border: 1px solid var(--hairline) !important;
  border-radius: 8px !important;
  font-size: 13px !important;
  font-weight: 800 !important;
  white-space: nowrap !important;
}
#content-raw .prod-ccp-btn.ok.sel {
  background: var(--ink) !important;
  color: #FFFFFF !important;
  border-color: var(--ink) !important;
}
#content-raw .prod-ccp-btn.fail.sel {
  background: var(--paper) !important;
  color: var(--ink) !important;
  border-color: var(--hairline-strong) !important;
}
#content-raw .raw-daily-table button,
#content-raw .ccp-log-table button,
#content-raw .prod-mat-del {
  color: var(--ink) !important;
  -webkit-text-fill-color: currentColor !important;
}
#content-raw input,
#content-raw select,
#content-raw textarea {
  color: var(--ink) !important;
}
.raw-guide-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 20000;
  background: rgba(18, 18, 20, 0.08);
  pointer-events: none;
}
.raw-guide-overlay.open {
  display: block;
}
.raw-guide-spotlight {
  display: none;
}
.raw-guide-beam {
  display: none;
}
#content-raw .raw-guide-example-value {
  color: #B91C1C !important;
  -webkit-text-fill-color: #B91C1C !important;
  background: #FFE4E6 !important;
  border-color: #B91C1C !important;
  font-weight: 900 !important;
  cursor: not-allowed !important;
  caret-color: transparent !important;
  outline: none !important;
  box-shadow: inset 0 0 0 2px rgba(185,28,28,0.20) !important;
  animation: rawGuideExampleBlink .62s ease-in-out 4;
}
@keyframes rawGuideExampleBlink {
  0%, 100% {
    opacity: 1;
    filter: none;
    border-color: #B91C1C;
    box-shadow: inset 0 0 0 2px rgba(185,28,28,0.20), inset 0 0 0 999px rgba(255,255,255,0);
  }
  50% {
    opacity: .74;
    filter: brightness(0.92) saturate(1.18);
    border-color: #7F1D1D;
    box-shadow: inset 0 0 0 3px rgba(185,28,28,0.44), inset 0 0 16px rgba(185,28,28,0.32);
  }
}
#content-raw .raw-guide-history-example td {
  background: #FFE4E6 !important;
  color: #7F1D1D !important;
  font-weight: 850 !important;
  box-shadow: inset 0 0 0 1px rgba(185,28,28,0.28) !important;
  animation: rawGuideExampleBlink .62s ease-in-out 4;
}
#content-raw .raw-guide-history-example span {
  color: #7F1D1D !important;
  font-weight: 900 !important;
}
.raw-guide-panel {
  position: fixed;
  left: 50%;
  top: 14px;
  transform: translateX(-50%);
  z-index: 20003;
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 14px;
  align-items: center;
  width: min(760px, calc(100vw - 28px));
  min-height: 68px;
  padding: 12px 58px 12px 16px;
  background: #3F4046;
  border: 1px solid #5C5D63;
  border-radius: 8px;
  box-shadow: 0 14px 36px rgba(0,0,0,0.24);
  pointer-events: auto;
  animation: rawGuidePanelIn .22s cubic-bezier(0.2, 0.8, 0.2, 1);
}
.raw-guide-panel.raw-guide-step-animate {
  animation: rawGuidePanelStep .24s cubic-bezier(0.2, 0.8, 0.2, 1);
}
@keyframes rawGuidePanelIn {
  from { opacity: 0; transform: translateX(-50%) translateY(-8px); }
  to { opacity: 1; transform: translateX(-50%) translateY(0); }
}
@keyframes rawGuidePanelStep {
  from { opacity: .74; transform: translateX(-50%) translateY(-5px); }
  to { opacity: 1; transform: translateX(-50%) translateY(0); }
}
.raw-guide-copy {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  align-items: center;
  min-width: 0;
}
.raw-guide-close {
  position: absolute;
  top: 10px;
  right: 12px;
  width: 34px;
  height: 34px;
  border: 1px solid rgba(255,255,255,0.18);
  border-radius: 8px;
  background: rgba(255,255,255,0.08);
  color: #F3F4F6;
  font-size: 20px;
  line-height: 1;
  cursor: pointer;
}
.raw-guide-count {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  height: 32px;
  padding: 0 8px;
  border-radius: 999px;
  background: rgba(255,255,255,0.10);
  border: 1px solid rgba(255,255,255,0.18);
  color: #F3F4F6;
  font-size: 12px;
  font-weight: 850;
}
.raw-guide-title {
  color: #FFFFFF;
  font-size: 15px;
  font-weight: 900;
  line-height: 1.35;
}
.raw-guide-text {
  color: #D8DADF;
  font-size: 13px;
  line-height: 1.45;
  margin-top: 3px;
}
.raw-guide-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 12px;
}
.raw-guide-actions button {
  min-height: 44px;
  padding: 10px 16px;
  border-radius: 8px;
  font-size: 14px;
  font-weight: 850;
  cursor: pointer;
}
.raw-guide-secondary {
  display: none;
}
.raw-guide-primary {
  background: #F3F4F6;
  color: #3F4046;
  border: 1px solid #F3F4F6;
}
.raw-guide-target {
  position: relative;
  isolation: isolate;
  outline: none !important;
  background-color: rgba(107,114,128,0.04) !important;
  box-shadow:
    inset 0 0 10px rgba(107,114,128,0.08) !important;
  transition: box-shadow .18s ease, background-color .18s ease, filter .18s ease;
}
.raw-guide-target::before {
  content: "" !important;
  position: absolute !important;
  inset: 0 !important;
  z-index: 3 !important;
  border: 2px solid rgba(107,114,128,0.34) !important;
  border-radius: inherit !important;
  box-shadow: inset 0 0 12px rgba(107,114,128,0.08) !important;
  pointer-events: none !important;
}
.raw-guide-focus {
  position: relative;
  z-index: 4;
  outline: none !important;
  background-color: rgba(255,228,230,0.38) !important;
  box-shadow:
    inset 0 0 0 3px rgba(127,29,29,0.78),
    inset 0 0 18px rgba(185,28,28,0.24) !important;
}
.raw-guide-target.raw-guide-target-pulse {
  animation: rawGuideTargetPulse .68s ease-in-out 4;
}
.raw-guide-focus.raw-guide-target-pulse {
  animation: rawGuideTargetPulse .68s ease-in-out 4;
}
@keyframes rawGuideTargetPulse {
  0% {
    filter: brightness(1);
    background-color: rgba(255,228,230,0.18);
    box-shadow:
      inset 0 0 0 2px rgba(127,29,29,0.52),
      inset 0 0 10px rgba(185,28,28,0.12);
  }
  50% {
    filter: brightness(0.96);
    background-color: rgba(255,228,230,0.44);
    box-shadow:
      inset 0 0 0 4px rgba(127,29,29,0.88),
      inset 0 0 24px rgba(185,28,28,0.34);
  }
  100% {
    filter: brightness(1);
    background-color: rgba(255,228,230,0.26);
    box-shadow:
      inset 0 0 0 3px rgba(127,29,29,0.72),
      inset 0 0 20px rgba(185,28,28,0.18);
  }
}
#content-raw .raw-guide-target::after {
  content: none;
  display: none;
  font-weight: 900;
  line-height: 1;
  text-align: center;
  box-shadow: 0 8px 18px rgba(0,0,0,0.16);
  pointer-events: none;
}
#content-raw [style*="color:var(--mono-text)"],
#content-raw [style*="color: var(--mono-text)"] {
  color: var(--ink) !important;
}
#content-raw [style*="background:var(--mono-text)"],
#content-raw [style*="background: var(--mono-text)"] {
  background: var(--ink) !important;
  color: #FFFFFF !important;
  border-color: var(--ink) !important;
}
#content-raw [style*="background:var(--mono-accent)"],
#content-raw [style*="background: var(--mono-accent)"] {
  background: var(--paper) !important;
  color: var(--ink) !important;
  border: 1px solid var(--hairline) !important;
}
#content-raw [style*="border:2px solid var(--mono-accent)"],
#content-raw [style*="border: 2px solid var(--mono-accent)"] {
  border-color: var(--hairline-strong) !important;
}
#content-raw svg[stroke="var(--mono-accent)"],
#content-raw svg[stroke="var(--mono-text)"] {
  stroke: var(--ink-soft) !important;
}
@media (max-width: 768px) {
  #content-raw .raw-date-nav {
    gap: 8px !important;
  }
  #content-raw .raw-date-nav > div[style*="display:flex"] {
    width: 100% !important;
    flex-wrap: wrap !important;
  }
  #content-raw button[onclick="openRawMgmt()"],
  #content-raw button[onclick="openSubMgmt()"],
  #content-raw button[onclick="addProdMat()"],
  #content-raw button[onclick="openRawMgmtAdd()"],
  #content-raw button[onclick="openRawMgmtDel()"] {
    flex: 1 1 150px !important;
  }
  #content-raw .raw-direct-toggle-strip,
  #content-raw .raw-sync-preview-head,
  #content-raw .raw-easy-guide {
    align-items: stretch;
    flex-direction: column;
  }
  #content-raw .raw-easy-guide {
    display: flex;
  }
  #content-raw .raw-easy-steps {
    grid-template-columns: 1fr;
  }
  #content-raw .raw-easy-actions {
    width: 100%;
    min-width: 0;
  }
  #content-raw .raw-history-shortcut,
  #content-raw .raw-guide-start {
    flex: 1 1 0;
  }
  #content-raw .raw-direct-toggle {
    width: 100%;
  }
  #content-raw .raw-sync-preview-row {
    grid-template-columns: 1fr;
    gap: 3px;
  }
}

/* ─── 드롭다운 패널 공통 ─── */
.dropdown-menu,
.topbar-dropdown,
.cw-menu-panel,
.noti-panel {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 8px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.10) !important;
}
.dropdown-menu .item:hover,
.topbar-dd-item:hover,
.cw-menu-item:hover,
.noti-panel .noti-item:hover {
  background: #F4F6F9 !important;
}

/* ─── 토스트 한번 더 — 배경 #fff 고정, 좌측 3px 라인만 ─── */
#vfcToastHost .toast,
.vfc-toast,
.toast-container .toast {
  background: #fff !important;
  color: #444444 !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-left: 3px solid #444444 !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.06), 0 8px 24px rgba(0,0,0,0.12) !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
}

/* ─── 형광 노랑/민트 배경 뱃지 류 남은 것 억제 ─── */
[style*="background:#fef3c7"],
[style*="background: #fef3c7"],
[style*="background:#fff3cd"] {
  background: #F3E9D8 !important;
}
[style*="background:#dcfce7"],
[style*="background: #dcfce7"] {
  background: #E5EFE6 !important;
}
[style*="background:#fee2e2"],
[style*="background: #fee2e2"] {
  background: #F4E3E1 !important;
}
[style*="background:#dbeafe"],
[style*="background: #dbeafe"] {
  background: #EAECEF !important;
}

/* ─── 관리자 PIN 2차 인증 오버레이 — 다크 그라데이션 → 페이퍼 화이트 ─── */
#adminPinOverlay,
#adminPinSetup {
  background: #FAFAF8 !important;
  background-image: none !important;
  color: #444444 !important;
}
#adminPinOverlay img,
#adminPinSetup img {
  filter: invert(1) brightness(0.18) !important;  /* 흰 로고 → 차콜 */
  width: 160px !important;
}
#adminPinTitle,
#adminPinSetup > div:nth-child(3) {
  color: #444444 !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  font-size: 22px !important;
}
#adminPinMsg,
#adminPinSetup > div:nth-child(4),
#adminPinSetup > div:nth-child(5) {
  color: #6E6E75 !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
}
.admin-pin-input,
.setup-pin-input {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.18) !important;
  color: #444444 !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
  font-weight: 700 !important;
}
.admin-pin-input:focus,
.setup-pin-input:focus {
  border-color: #444444 !important;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.10) !important;
}
#adminPinError {
  color: #B91C1C !important;
  font-weight: 600 !important;
}
#adminPinOverlay button,
#adminPinSetup button {
  background: #fff !important;
  color: #444444 !important;
  border: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 999px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  padding: 12px 0 !important;
}
#adminPinOverlay button:hover,
#adminPinSetup button:hover {
  background: #F4F6F9 !important;
  border-color: rgba(0,0,0,0.28) !important;
}

/* ══════════════════════════════════════════════════
   #6 일지 작성 허브 / 탭 내비게이션 / 최근 작성 리스트
   main.css의 모노그레이 그라데이션 + 모노 강조색 언더라인 AI 톤 제거
   ══════════════════════════════════════════════════ */
.jwrite-card {
  background: #fff !important;
  background-image: none !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 6px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.04) !important;
  padding: 18px 22px !important;
  margin-bottom: 18px !important;
}
.jwrite-card-title {
  color: #444444 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
  margin-bottom: 14px !important;
}
.jwrite-btn {
  background: #fff !important;
  color: #444444 !important;
  border: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 999px !important;
  padding: 8px 16px !important;
  font-size: 12.5px !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  transition: border-color var(--t-normal), background var(--t-normal) !important;
}
.jwrite-btn:hover {
  background: #F4F6F9 !important;
  border-color: rgba(0,0,0,0.28) !important;
  transform: none !important;
}

/* 탭 네비게이션 — 모노 강조색 언더라인 → 잉크 */
.jtab-nav {
  border-bottom: 1px solid rgba(0,0,0,0.12) !important;
  gap: 2px !important;
}
.jtab-nav button {
  color: #6E6E75 !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  padding: 10px 16px !important;
}
.jtab-nav button:hover { color: #444444 !important; }
.jtab-nav button.active {
  color: #444444 !important;
  border-bottom-color: #444444 !important;
  font-weight: 700 !important;
}

/* 서브/카테고리 라벨 — 모노 강조색 → 뮤트 그레이 */
.jtab-sub-label {
  color: #6E6E75 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.08em !important;
  text-transform: uppercase !important;
}
.jtab-cat-label {
  color: #444444 !important;
  border-bottom: 1px solid rgba(0,0,0,0.14) !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  letter-spacing: -0.01em !important;
  padding-bottom: 8px !important;
  margin: 20px 0 12px !important;
}

/* 일지 팝업 헤더 — 모노그레이 그라데이션 → 잉크 flat */
.journal-header {
  background: var(--ink) !important;
  background-image: none !important;
}

/* "최근 작성한 일지" 블록 */
#recentJournalList {
  font-size: 13px !important;
  color: #444444 !important;
}
#recentJournalList > div,
#recentJournalList > a {
  padding: 10px 12px !important;
  border-bottom: 1px solid rgba(0,0,0,0.06) !important;
  color: #444444 !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  transition: background var(--t-normal) !important;
}
#recentJournalList > div:hover,
#recentJournalList > a:hover {
  background: #F4F6F9 !important;
}

/* ══════════════════════════════════════════════════
   #8 구독 관리 패널 — 모노그레이/모노 강조색/🔒 제거, 에디토리얼 카드
   ══════════════════════════════════════════════════ */
#subManageWrap {
  background: #FAFAF8 !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 8px !important;
  padding: 22px 26px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.02) !important;
}
#subManagePlan {
  color: #444444 !important;
  font-size: 14.5px !important;
  font-weight: 800 !important;
  letter-spacing: -0.01em !important;
}
#subManageExpiry {
  color: #6E6E75 !important;
  font-size: 12px !important;
  letter-spacing: 0 !important;
}
#subManagePrice {
  color: #444444 !important;
  font-size: 22px !important;
  font-weight: 800 !important;
  font-variant-numeric: tabular-nums !important;
  letter-spacing: -0.02em !important;
}
#subManageOptions {
  border-top: 1px solid rgba(0,0,0,0.10) !important;
  padding-top: 16px !important;
  gap: 10px !important;
}
/* 각 옵션 카드 (업종추가·Care+) */
#subManageOptions > div {
  background: #fff !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 6px !important;
  padding: 14px 16px !important;
  margin-top: 0 !important;
}
#subManageOptions > div > div > div:first-child {
  color: #444444 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: -0.01em !important;
}
#subManageOptions > div > div > div:last-child {
  color: #6E6E75 !important;
  font-size: 11.5px !important;
  margin-top: 3px !important;
}
/* 옵션 카드 우측: 추가 버튼 또는 "🔒 가격" 뱃지 */
#subManageOptions button {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid #444444 !important;
  border-radius: 999px !important;
  padding: 8px 18px !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}
#subManageOptions button:hover {
  background: #2A2E35 !important;
  border-color: #2A2E35 !important;
}
/* "🔒 +100,000원/월" 잠금 뱃지 */
#subManageOptions span {
  color: #6E6E75 !important;
  font-size: 11px !important;
  font-weight: 600 !important;
  letter-spacing: 0 !important;
  font-variant-numeric: tabular-nums !important;
}
/* 자물쇠 이모지 숨김 — 잉크 "가입됨" 뱃지 느낌으로 */
#subManageOptions span:first-letter { font-size: 0 !important; }

/* 구독 취소 신청 링크 */
#subManageCancelWrap button {
  color: #6E6E75 !important;
  font-size: 11.5px !important;
  opacity: 0.8 !important;
  letter-spacing: -0.01em !important;
}
#subManageCancelWrap button:hover {
  color: #B91C1C !important;
  opacity: 1 !important;
}

/* ══════════════════════════════════════════════════
   #7 설정 페이지 — 좌측 탭 + 패널 에디토리얼 톤 통일
   ══════════════════════════════════════════════════ */
/* 좌측 세로 탭 네비 */
.set-nav-item {
  color: #6E6E75 !important;
  font-weight: 500 !important;
  font-size: 13px !important;
  letter-spacing: -0.01em !important;
  border-left: 2px solid transparent !important;
  padding: 11px 20px !important;
  transition: background var(--t-normal), color var(--t-normal), border-left-color var(--t-normal) !important;
}
.set-nav-item:hover {
  background: #F4F6F9 !important;
  color: #444444 !important;
}
.set-nav-item.active {
  color: #444444 !important;
  font-weight: 800 !important;
  border-left-color: #444444 !important;
  background: #ECECEA !important;
  background-image: none !important;
}

/* 섹션 헤더·라벨 */
.settings-label {
  color: #444444 !important;
  font-size: 13px !important;
  font-weight: 700 !important;
  letter-spacing: 0.02em !important;
  text-transform: uppercase !important;
}
.settings-section {
  border-bottom: 1px solid rgba(0,0,0,0.08) !important;
  padding: 18px 0 !important;
}
.settings-desc {
  color: #6E6E75 !important;
  font-size: 12.5px !important;
  line-height: 1.55 !important;
}
.set-field-label {
  color: #6E6E75 !important;
  font-size: 11px !important;
  font-weight: 700 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}

/* 입력 필드 */
.set-input {
  border: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 4px !important;
  background: #fff !important;
  color: #444444 !important;
  font-size: 13.5px !important;
  padding: 10px 12px !important;
  box-shadow: 0 1px 2px rgba(0,0,0,0.02) !important;
}
.set-input:focus {
  border-color: #444444 !important;
  box-shadow: 0 0 0 2px rgba(0,0,0,0.10) !important;
  outline: none !important;
}

/* 저장 / 아웃라인 버튼 */
.set-btn {
  background: var(--ink) !important;
  color: #fff !important;
  border: 1px solid #444444 !important;
  border-radius: 999px !important;
  padding: 10px 22px !important;
  font-size: 12.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}
.set-btn:hover {
  background: #2A2E35 !important;
  border-color: #2A2E35 !important;
  opacity: 1 !important;
}
.set-btn-outline {
  background: #fff !important;
  color: #444444 !important;
  border: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 999px !important;
  padding: 7px 16px !important;
  font-size: 11.5px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
}
.set-btn-outline:hover {
  background: #F4F6F9 !important;
  border-color: rgba(0,0,0,0.32) !important;
}

/* 테마·토글 버튼 (라이트/다크 선택기가 남아있다면 잉크 pill) */
.set-theme-btn, .theme-btn {
  background: #fff !important;
  color: #6E6E75 !important;
  border: 1px solid rgba(0,0,0,0.14) !important;
  border-radius: 999px !important;
  font-weight: 500 !important;
}
.set-theme-btn.active, .theme-btn.active {
  background: var(--ink) !important;
  color: #fff !important;
  border-color: #444444 !important;
  font-weight: 700 !important;
}

/* 토글 스위치 — off 회색, on 잉크 */
.set-toggle-slider {
  background: rgba(0,0,0,0.18) !important;
}
.set-toggle input:checked + .set-toggle-slider {
  background: var(--ink) !important;
}

/* 전자서명 카드 */
.set-sign-card {
  background: #FAFAF8 !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 6px !important;
}
.set-sign-card img {
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-radius: 3px !important;
}

/* 설정 페이지 모바일 세로탭 보정 (main.css 2825 참조) */
@media (max-width: 900px) {
  .set-nav-item.active {
    border-left-color: transparent !important;
    border-bottom-color: #444444 !important;
  }
}

/* ══════════════════════════════════════════════════
   홈 캘린더 (HACCP 일정) — 모노 강조색 hover → 잉크 에디토리얼
   ══════════════════════════════════════════════════ */
.cal-cell:hover {
  background: #F4F6F9 !important;
  box-shadow: inset 0 0 0 1px rgba(0,0,0,0.18) !important;
}
.cal-cell.today {
  background: #EEECE4 !important;
  box-shadow: inset 0 0 0 1.5px rgba(0,0,0,0.32) !important;
}
.cal-date { color: #444444 !important; }
.cal-date.today-num {
  background: var(--ink) !important;
  background-image: none !important;
  color: #fff !important;
  font-weight: 800 !important;
}
.cal-date.sun-num { color: #C05050 !important; }
.cal-date.sat-num { color: #3A5878 !important; }

/* 캘린더 이벤트 뱃지 — 파스텔 팝 → 뉴트럴 씰 */
.cal-event {
  font-size: 10px !important;
  font-weight: 600 !important;
  letter-spacing: -0.01em !important;
  border-radius: 3px !important;
  padding: 2px 6px !important;
  border: 1px solid transparent !important;
}
.cal-event.type-ccp    { background: #EAECEF !important; color: #444444 !important; border-color: rgba(0,0,0,0.12) !important; }
.cal-event.type-haccp  { background: #F3E9D8 !important; color: #7A5410 !important; border-color: rgba(122,84,16,0.18) !important; }
.cal-event.type-check  { background: #E5EFE6 !important; color: #166534 !important; border-color: rgba(22,101,52,0.18) !important; }
.cal-event.type-warn   { background: #F4E3E1 !important; color: #7B1D1D !important; border-color: rgba(185,28,28,0.22) !important; }

/* 요일 헤더 셀 */
.cal-day-label.sun { color: #C05050 !important; }
.cal-day-label.sat { color: #3A5878 !important; }

/* ─── 일지 페이지 탭(1~10 / 11~20 …) 파란 active → 잉크 ─── */
.j-page-tabs {
  border-bottom: 1px solid rgba(0,0,0,0.12) !important;
  gap: 2px !important;
}
.j-page-tab {
  background: #F4F6F9 !important;
  border: 1px solid rgba(0,0,0,0.10) !important;
  border-bottom: none !important;
  color: #6E6E75 !important;
  font-weight: 500 !important;
  letter-spacing: -0.01em !important;
  border-radius: 6px 6px 0 0 !important;
}
.j-page-tab:hover {
  background: #ECECEA !important;
  color: #444444 !important;
}
.j-page-tab.active {
  background: var(--ink) !important;
  border-color: #444444 !important;
  color: #fff !important;
  font-weight: 700 !important;
}

/* ── 처리이력/수정이력 탭 (2026-04-26) ── */
.apv-subtab-nav {
  display: inline-flex;
  gap: 0;
  border-bottom: 1px solid var(--line, #e8e8e4);
}
.apv-subtab {
  padding: 8px 18px;
  background: transparent;
  border: none;
  border-bottom: 2px solid transparent;
  font-size: 14px;
  font-weight: 600;
  color: var(--gray3, #6b7280);
  cursor: pointer;
  letter-spacing: 0.02em;
  margin-bottom: -1px;
  transition: color .15s, border-color .15s;
}
.apv-subtab:hover {
  color: var(--ink, #1a1a1a);
}
.apv-subtab.active {
  color: var(--ink, #1a1a1a);
  border-bottom-color: var(--ink, #1a1a1a);
  font-weight: 700;
}

/* ── 데이터 로그 페이지 톤 통일 (2026-04-26) ── */
.audit-page-title {
  font-size: 22px !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em !important;
  color: var(--ink, #1a1a1a) !important;
  margin-bottom: 4px;
}
.audit-page-sub {
  font-size: 12.5px;
  color: var(--gray3, #6b7280);
  font-weight: 500;
  letter-spacing: 0.01em;
  margin-bottom: 4px;
}
.audit-page-head {
  border-bottom: 1px solid var(--line, #e8e8e4) !important;
  padding-bottom: 18px !important;
  margin-bottom: 26px !important;
}
.audit-select, .audit-date {
  border-color: var(--line, #d1d5db) !important;
  color: var(--ink, #1a1a1a) !important;
  background: #fff !important;
  border-radius: 2px !important;
}
.audit-select:focus, .audit-date:focus {
  border-color: var(--ink, #1a1a1a) !important;
  outline: none !important;
}
.audit-date-sep {
  color: var(--gray3, #94a3b8) !important;
}

/* ── 온도기록 페이지 모노 톤 (2026-04-26) ── */
.temp-defrost-btn {
  border: 1px solid var(--ink, #1a1a1a) !important;
  border-radius: 2px !important;
  background: #fff !important;
  color: var(--ink, #1a1a1a) !important;
}
.temp-defrost-btn:hover {
  background: var(--gray1, #f3f4f6) !important;
  border-color: var(--ink, #1a1a1a) !important;
}
.temp-defrost-btn.active {
  background: var(--ink, #1a1a1a) !important;
  color: #fff !important;
  border-color: var(--ink, #1a1a1a) !important;
  box-shadow: none !important;
}
/* 제상 표시 — 노랑 형광펜 효과 (HACCP 시각 식별성 유지) */
.temp-defrost-marked {
  background: linear-gradient(180deg, transparent 0%, transparent 18%, #fde047 18%, #fde047 82%, transparent 82%) !important;
  color: var(--ink, #1a1a1a) !important;
  font-weight: 700 !important;
  outline: none !important;
}

/* ── ccp-page-title-icon: 모노 강조색 그라데이션 → 다크 모노 박스 ── */
.ccp-page-title-icon {
  background: var(--ink, #1a1a1a) !important;
  border-radius: 4px !important;
}
.ccp-page-title-icon svg {
  stroke: #fff !important;
}

/* =========================================================
   어드민 영역 — 모노 그레이톤 통일 (var(--primary) 파란색 → 슬레이트)
   대상: CDP 직원 설정/팀원 조직도, 일지 카드 variant 표시, 일반 어드민 버튼·탭
   ========================================================= */

/* CDP 탭 (직책 설정 / 팀원 조직도) — 파란 액센트 → 슬레이트 */
button[onclick*="_cdpSwitchRolesTab"] {
  border-bottom-color: transparent !important;
  color: #6B7280 !important;
}
button[onclick*="_cdpSwitchRolesTab"][style*="primary"] {
  border-bottom-color: #1F2937 !important;
  color: #1F2937 !important;
}

/* 어드민 영역에서 var(--primary) 사용 버튼 → 슬레이트 */
#page-admin-main .cj-cat-count,
#page-admin-main [style*="var(--primary)"][style*="font-weight"] {
  color: #4B5563 !important;
}

/* 일지 카드 variantLabel 표시 — primary blue → slate */
#page-admin-main .cj-jcard div[style*="var(--primary)"] {
  color: #4B5563 !important;
}

/* 어드민 사이드바 활성 항목 — 슬레이트 */
.admin-sidebar .admin-nav-item.active {
  background: rgba(0,0,0,0.06) !important;
  color: #444444 !important;
  border-left: 3px solid #1F2937 !important;
}

/* 어드민 panel head 액션 버튼 — primary → slate */
#page-admin-main .admin-panel button[style*="var(--primary)"]:not([disabled]),
#page-admin-main button.btn-primary:not([disabled]) {
  background: #1F2937 !important;
  border-color: #1F2937 !important;
  color: #fff !important;
}

/* CDP 액션 — 파란 보더/배경 → 슬레이트 */
.cdp-section input[type="radio"]:checked + label,
.cdp-section [style*="2px solid var(--primary)"] {
  border-color: #1F2937 !important;
}
.cdp-section [style*="background:var(--primary)"]:not(:disabled),
.cdp-section [style*="background: var(--primary)"]:not(:disabled) {
  background: #1F2937 !important;
}
.cdp-section [style*="color:var(--primary)"]:not(:disabled),
.cdp-section [style*="color: var(--primary)"]:not(:disabled) {
  color: #4B5563 !important;
}

/* 토글 스위치 (cj-toggle 등) — 파랑 → 슬레이트 */
#page-admin-main label > span[style*="background:var(--primary)"],
#page-admin-main label > span[style*="background: var(--primary)"] {
  background: #1F2937 !important;
}

/* 변형 picker 카드 (파란 보더 선택 표시) — 슬레이트 */
#cjVPickerOverlay [style*="2px solid var(--primary)"] {
  border-color: #1F2937 !important;
}
#cjVPickerOverlay [style*="rgba(75,141,248,0.06)"] {
  background: rgba(31,41,55,0.04) !important;
}
#cjVPickerOverlay [style*="color:var(--primary)"] {
  color: #1F2937 !important;
}

/* =========================================================
   모바일 일지 카드뷰 (≤768px)
   - 데스크톱·인쇄·PDF는 영향 없음 (미디어 쿼리 안에서만 동작)
   - JS pass(_decorateJournalCardView)가 data-cardrole / data-group-label / data-check-label 부여
   ========================================================= */
@media (max-width: 768px) {
  .jform-table[data-mobile-cards="1"] {
    display: block !important;
    width: 100% !important;
    border: none !important;
    border-collapse: separate !important;
  }
  .jform-table[data-mobile-cards="1"] colgroup,
  .jform-table[data-mobile-cards="1"] col,
  .jform-table[data-mobile-cards="1"] thead,
  .jform-table[data-mobile-cards="1"] tfoot {
    display: none !important;
  }
  .jform-table[data-mobile-cards="1"] tbody {
    display: block !important;
  }

  /* 메타 행(타이틀·서브타이틀·헤더 전용)은 숨김 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="meta"] {
    display: none !important;
  }

  /* 그룹 시작 — 카드 위에 섹션 헤더 출력 */
  .jform-table[data-mobile-cards="1"] tr[data-group-start="1"]::before {
    content: attr(data-group-label);
    display: block;
    margin: 18px 4px 8px;
    padding: 0 0 6px;
    font-family: 'Pretendard', -apple-system, sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #6B7280;
    text-transform: none;
    border-bottom: 1px solid #E5E7EB;
  }

  /* 카드 행 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] {
    display: grid !important;
    grid-template-columns: 1fr 1fr;
    grid-auto-rows: auto;
    column-gap: 8px;
    row-gap: 10px;
    padding: 14px;
    margin: 0 0 10px;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 4px;
    box-shadow: none;
  }

  /* 카드 안 셀 기본 리셋 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] > td {
    border: none !important;
    padding: 0 !important;
    background: transparent !important;
    text-align: left !important;
    height: auto !important;
    min-height: 0 !important;
    vertical-align: top !important;
  }

  /* 구분(rowspan)·헤더 셀 — 카드 안에선 숨김 (그룹 헤더가 대체) */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jperiod,
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jhdr {
    display: none !important;
  }

  /* 항목 텍스트 — 카드 상단 풀폭 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jitem {
    display: block !important;
    grid-column: 1 / -1;
    font-family: 'Pretendard', -apple-system, sans-serif;
    font-size: 14px;
    line-height: 1.55;
    color: #1F2937;
    font-weight: 500;
  }

  /* 양호/불량 토글 셀 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck {
    display: block !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 3px;
    background: #F9FAFB !important;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
    cursor: pointer;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck label {
    display: flex !important;
    align-items: center;
    justify-content: center;
    gap: 6px;
    width: 100%;
    min-height: 44px;
    padding: 8px 0;
    margin: 0 !important;
    font-family: 'Pretendard', -apple-system, sans-serif;
    font-size: 14px;
    font-weight: 700;
    color: #6B7280;
    cursor: pointer;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck label::before {
    content: attr(data-check-label);
  }
  /* 네이티브 체크박스는 작은 점으로 (체크 상태 시각화는 셀 배경으로 처리) */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck input[type="checkbox"] {
    appearance: none;
    -webkit-appearance: none;
    width: 16px;
    height: 16px;
    margin: 0 !important;
    border: 1.5px solid currentColor;
    border-radius: 2px;
    background: transparent;
    flex-shrink: 0;
    pointer-events: none;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck input[type="checkbox"]:checked {
    background: currentColor;
    border-color: currentColor;
  }

  /* 체크된 상태 — 양호/불량 별 색감 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck[data-check-kind="ok"]:has(input:checked) {
    background: #1F2937 !important;
    border-color: #1F2937 !important;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck[data-check-kind="ok"]:has(input:checked) label {
    color: #fff;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck[data-check-kind="ng"]:has(input:checked) {
    background: #fff !important;
    border-color: #7f1d1d !important;
  }
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck[data-check-kind="ng"]:has(input:checked) label {
    color: #7f1d1d;
  }

  /* 카드 안 입력 필드 (jinput / textarea / select) — 풀폭 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td input[type="text"],
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td input[type="number"],
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td textarea,
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td select {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box;
    text-align: left !important;
    font-size: 14px;
    padding: 8px 10px;
    border: 1px solid #E5E7EB;
    border-radius: 3px;
  }

  /* 셀 라벨 (간이 헤더가 없는 경우 항목 텍스트가 곧 라벨) */
  .jform-table[data-mobile-cards="1"] {
    background: transparent !important;
  }

  /* 일지 본문 컨테이너도 모바일에선 패딩 축소 */
  #journalBody {
    padding: 8px 10px !important;
  }

  /* 특이사항 노트 카드 톤 */
  .jform-note {
    margin-top: 14px;
    padding: 12px;
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 4px;
  }
  .jform-note label {
    display: block;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #6B7280;
    margin-bottom: 6px;
  }
  .jform-note textarea {
    width: 100% !important;
    box-sizing: border-box;
    min-height: 80px;
    padding: 8px 10px;
    border: 1px solid #E5E7EB;
    border-radius: 3px;
    font-size: 14px;
  }
}

/* =========================================================
   범용 모바일 폼 렌더러 (≤768px)
   - 위저드가 적용 안 된 복잡한 폼(j101/j102/j104/j105 등) 대상
   - 표 숨김 + 행마다 카드 + 컬럼 헤더 라벨 자동 추출
   ========================================================= */
.j-mobile-generic { display: none; }

@media (max-width: 768px) {
  /* 범용 렌더러 적용 시 원본 표 강제 숨김 (specificity 보강) */
  table.jform-table[data-mobile-generic="1"] {
    display: none !important;
    visibility: hidden !important;
    height: 0 !important;
    overflow: hidden !important;
  }

  .j-mobile-generic {
    display: block;
    padding: 8px 4px 24px;
    font-family: 'Pretendard', -apple-system, sans-serif;
  }

  .jmg-summary {
    padding: 8px 12px;
    margin: -8px -4px 12px;
    background: #fff;
    border-bottom: 1px solid #E5E7EB;
    position: sticky;
    top: 0;
    z-index: 12;
    font-size: 12px;
    font-weight: 700;
    color: #4B5563;
    letter-spacing: 0.04em;
  }

  .jmg-card {
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 4px;
    padding: 14px;
    margin: 0 4px 10px;
    position: relative;
  }
  .jmg-card-num {
    position: absolute;
    top: 10px;
    right: 12px;
    font-size: 11px;
    font-weight: 700;
    color: #9CA3AF;
    letter-spacing: 0.06em;
  }
  .jmg-context {
    display: inline-block;
    margin: 0 6px 8px 0;
    padding: 3px 8px;
    background: #F3F4F6;
    color: #4B5563;
    font-size: 11px;
    font-weight: 700;
    border-radius: 2px;
    letter-spacing: 0.04em;
  }
  .jmg-field {
    margin-top: 12px;
  }
  .jmg-field:first-of-type {
    margin-top: 0;
  }
  .jmg-label {
    font-size: 11px;
    font-weight: 700;
    color: #6B7280;
    letter-spacing: 0.06em;
    margin-bottom: 6px;
    text-transform: none;
  }
  .jmg-input-slot input[type="text"],
  .jmg-input-slot input[type="number"],
  .jmg-input-slot input:not([type]),
  .jmg-input-slot textarea,
  .jmg-input-slot select {
    width: 100% !important;
    box-sizing: border-box;
    padding: 10px 12px !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 3px;
    font-family: inherit !important;
    font-size: 14.5px !important;
    color: #1F2937;
    background: #fff !important;
    text-align: left !important;
    min-height: 0 !important;
    height: auto !important;
  }
  .jmg-input-slot textarea {
    min-height: 60px !important;
    resize: vertical;
  }
  .jmg-input-slot select {
    appearance: none;
    -webkit-appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6' viewBox='0 0 10 6'%3E%3Cpath fill='%236B7280' d='M5 6L0 0h10z'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 12px center !important;
    padding-right: 32px !important;
  }

  /* 체크박스 → 큰 토글 버튼 */
  .jmg-toggle {
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid #E5E7EB;
    border-radius: 3px;
    background: #F9FAFB;
    color: #6B7280;
    font-family: inherit;
    font-size: 14px;
    font-weight: 700;
    padding: 12px 16px;
    cursor: pointer;
    width: 100%;
    min-height: 44px;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
    -webkit-tap-highlight-color: transparent;
  }
  .jmg-toggle.active {
    background: #1F2937;
    border-color: #1F2937;
    color: #fff;
  }
  .jmg-toggle input[type="checkbox"] {
    display: none !important;
  }
}

/* 인쇄·PDF는 항상 표 형태 보장 (혹시 모를 카드 속성을 무력화) */
@media print {
  .jform-table[data-mobile-cards="1"] { display: table !important; }
  .jform-table[data-mobile-cards="1"] tbody { display: table-row-group !important; }
  .jform-table[data-mobile-cards="1"] tr { display: table-row !important; }
  .jform-table[data-mobile-cards="1"] td { display: table-cell !important; }
  .jform-table[data-mobile-cards="1"] tr[data-group-start="1"]::before { content: none !important; }
  .j-mobile-wizard { display: none !important; }
  .j-mobile-generic { display: none !important; }
  .j-mobile-ccp { display: none !important; }
  .jform-table.j-table-hidden-on-mobile { display: table !important; }
}

/* 모바일 사이드바 닫기 버튼 — 데스크톱에선 무조건 숨김 */
.sidebar-mobile-close { display: none; }

/* =========================================================
   CCP 모니터링 위저드 — j101 (모바일 ≤768px)
   배치 카드 + 한계기준 안내 카드
   ========================================================= */
.j-mobile-ccp { display: none; }
@media (max-width: 768px) {
  .jform-table[data-mobile-ccp="1"] { display: none !important; visibility: hidden; height: 0; overflow: hidden; }
  .j-mobile-ccp {
    display: block;
    margin: 8px 0 16px;
    font-family: 'Pretendard', -apple-system, sans-serif;
    color: #1F2937;
  }
  /* 한 줄 기준 표시 (큰 안내 박스 X) */
  .jmccp-criteria {
    font-size: 11px;
    color: #6B7280;
    padding: 6px 4px 8px;
    line-height: 1.4;
    word-break: keep-all;
  }
  /* j101 모바일 — 페이지 탭은 그대로 유지, 활성 페이지의 모든 배치 카드 다 펼침 */
  .j-page-sec:not(:first-of-type) .j-mobile-ccp .jmccp-criteria { display: none; }
  .jmccp-card.jmccp-hidden { display: block !important; }
  .jmccp-add-batch { display: none !important; }

  /* 온도 미달 시 빨간 테두리 (한계기준 위반 표시) */
  .jmccp-slot input.jmccp-warn,
  .jmccp-slot input.jmccp-warn:focus,
  .jmg-input-slot input.jmg-warn,
  .jmg-input-slot input.jmg-warn:focus {
    border-color: #C53030 !important;
    background: #FFF5F5 !important;
  }
  /* 제네릭 라벨 힌트 배지 (95℃ 이상 등) */
  .jmg-hint-pill {
    display: inline-block;
    margin-left: 6px;
    font-size: 10px;
    font-weight: 500;
    color: #9CA3AF;
    background: #F3F4F6;
    padding: 1px 6px;
    border-radius: 2px;
  }
  .jmg-unit-mark {
    flex: 0 0 auto;
    font-size: 12px;
    font-weight: 600;
    color: #4B5563;
    padding-right: 4px;
  }

  /* 다음 배치 추가 버튼 */
  .jmccp-add-batch {
    display: block;
    width: 100%;
    margin-top: 6px;
    padding: 12px 16px;
    background: #FFFFFF;
    border: 1.5px dashed #9CA3AF;
    color: #4B5563;
    font-size: 13px;
    font-weight: 600;
    cursor: pointer;
    font-family: inherit;
  }
  .jmccp-add-batch:active { background: #F3F4F6; }

  /* (legacy) 작성 방법 안내 — 더 이상 사용 안 함, 호환용 무력화 */
  .jmccp-guide { display: none !important; }
  .jmccp-meta { display: none !important; }
  .jmccp-summary { display: none !important; }
  .jmccp-guide_legacy {
    background: #FFFCF5;
    border: 1px solid #E8DDB8;
    border-left: 3px solid #8B6F2C;
    padding: 12px 14px 10px;
    margin-bottom: 12px;
  }
  .jmccp-guide-title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #6B5418;
    text-transform: uppercase;
    margin-bottom: 8px;
  }
  .jmccp-guide-steps {
    list-style: none;
    margin: 0;
    padding: 0;
    counter-reset: jmccp-guide;
  }
  .jmccp-guide-steps li {
    display: flex;
    align-items: flex-start;
    gap: 10px;
    padding: 5px 0;
    font-size: 12.5px;
    line-height: 1.55;
    color: #1F2937;
  }
  .jmccp-guide-steps li + li { border-top: 1px dashed #EBDFB8; }
  .jmccp-step-num {
    flex: 0 0 20px;
    height: 20px;
    width: 20px;
    border-radius: 50%;
    background: #1F1D1A;
    color: #F4F0E8;
    font-size: 11px;
    font-weight: 800;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin-top: 1px;
    font-variant-numeric: tabular-nums;
  }
  .jmccp-guide-steps b { font-weight: 700; color: #444444; }

  .jmccp-meta {
    background: #F9FAFB;
    border: 1px solid #E5E7EB;
    border-left: 3px solid #444444;
    padding: 12px 14px;
    margin-bottom: 14px;
  }
  .jmccp-meta-title {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.08em;
    color: #6B7280;
    margin-bottom: 8px;
    text-transform: uppercase;
  }
  .jmccp-meta-row {
    display: flex;
    gap: 10px;
    padding: 4px 0;
    font-size: 13px;
    line-height: 1.5;
  }
  .jmccp-meta-row + .jmccp-meta-row { border-top: 1px dashed #E5E7EB; }
  .jmccp-meta-lbl {
    flex: 0 0 80px;
    font-weight: 600;
    color: #4B5563;
  }
  .jmccp-meta-val {
    flex: 1;
    color: #1F2937;
    word-break: keep-all;
  }
  .jmccp-summary {
    font-size: 12px;
    color: #6B7280;
    margin: 12px 2px 8px;
    font-weight: 600;
    letter-spacing: 0.04em;
  }
  .jmccp-card {
    background: #FFFFFF;
    border: 1px solid #E5E7EB;
    border-left: 3px solid #2D2D2D;
    margin-bottom: 8px;
    overflow: hidden;
  }
  .jmccp-card.collapsed { border-left-color: #E5E7EB; }
  .jmccp-card-head {
    background: #F9FAFB;
    border-bottom: 1px solid #E5E7EB;
    padding: 9px 12px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    border: 0;
    cursor: pointer;
    font-family: inherit;
  }
  .jmccp-card.collapsed .jmccp-card-head { border-bottom: 0; }
  .jmccp-card-num {
    font-size: 13.5px;
    font-weight: 700;
    color: #1F2937;
    letter-spacing: 0.02em;
  }
  .jmccp-card.collapsed .jmccp-card-num { color: #6B7280; font-weight: 600; }
  .jmccp-card-toggle {
    font-size: 18px;
    color: #6B7280;
    line-height: 1;
    transform: rotate(45deg);
    transition: transform 0.18s;
  }
  .jmccp-card.collapsed .jmccp-card-toggle { transform: rotate(0); }
  .jmccp-card-body {
    padding: 10px 14px 14px;
  }
  .jmccp-card.collapsed .jmccp-card-body { display: none; }
  /* 시간+온도 페어를 한 줄에 */
  .jmccp-row-pair {
    display: flex;
    gap: 10px;
    padding: 6px 0;
    border-top: 1px solid #F3F4F6;
  }
  .jmccp-card-body > .jmccp-row-pair:first-child { border-top: 0; }
  .jmccp-row-pair .jmccp-field {
    flex: 1 1 0;
    min-width: 0;
    padding: 0 !important;
    border-top: 0 !important;
  }
  .jmccp-row-pair .jmccp-slot input { max-width: none !important; }
  /* 인라인 기준 힌트 (95℃ 이상) */
  .jmccp-hint {
    display: inline-block;
    margin-left: 6px;
    font-size: 10px;
    font-weight: 500;
    color: #9CA3AF;
    background: #F3F4F6;
    padding: 1px 6px;
    border-radius: 2px;
    letter-spacing: 0;
  }
  .jmccp-field {
    display: flex;
    flex-direction: column;
    padding: 8px 0;
  }
  .jmccp-field + .jmccp-field { border-top: 1px solid #F3F4F6; }
  .jmccp-label {
    font-size: 11px;
    font-weight: 600;
    color: #6B7280;
    margin-bottom: 6px;
    letter-spacing: 0.04em;
  }
  .jmccp-slot {
    display: flex;
    align-items: center;
    gap: 6px;
  }
  .jmccp-slot input,
  .jmccp-slot select,
  .jmccp-slot textarea {
    flex: 1 1 0;
    width: 100%;
    min-width: 0;
    max-width: 100%;
    min-height: 36px;
    padding: 6px 8px;
    border: 1px solid #D1D5DB;
    background: #FFFFFF;
    font-size: 14px;
    color: #1F2937;
    font-family: inherit;
    border-radius: 0;
    box-sizing: border-box;
  }
  .jmccp-slot input:focus,
  .jmccp-slot select:focus,
  .jmccp-slot textarea:focus {
    outline: none;
    border-color: #444444;
    background: #FFFFFF;
  }
  .jmccp-slot input[type="time"] { font-variant-numeric: tabular-nums; }
  .jmccp-slot input[type="number"] { text-align: right; font-variant-numeric: tabular-nums; }
  .jmccp-unit {
    font-size: 13px;
    font-weight: 600;
    color: #4B5563;
    flex: 0 0 auto;
    padding-right: 4px;
  }
  /* 페어 안에서는 input이 슬롯 폭에 맞게 줄어들도록 — max-width 제한 제거 */
  .jmccp-field .jmccp-slot input { max-width: 100% !important; min-width: 0 !important; }
  .jmccp-row-pair { overflow: hidden; }
  .jmccp-row-pair .jmccp-field { overflow: hidden; }
}

/* =========================================================
   모바일 전반 컴팩트 스케일 (≤768px)
   - 데스크톱 무영향 (모든 룰 @media 내부)
   - 폰트·패딩 일괄 축소, "보일 정도로만" 원칙
   ========================================================= */
@media (max-width: 768px) {
  /* 일지 헤더 영역 (작성일자·담당자 등) */
  .journal-header,
  .journal-meta,
  .jform-meta,
  .journal-box .journal-info {
    padding: 8px 12px !important;
    font-size: 12px !important;
    gap: 6px !important;
  }
  .journal-header label,
  .jform-meta label,
  .journal-box .journal-info label {
    font-size: 11px !important;
    color: #6B7280 !important;
    font-weight: 600 !important;
  }
  .journal-header input[type="date"],
  .jform-meta input[type="date"],
  .journal-box .journal-info input[type="date"],
  .journal-box .journal-info input[type="text"] {
    font-size: 13px !important;
    padding: 6px 8px !important;
    height: auto !important;
  }

  /* 일지 오버레이/박스 패딩 압축 */
  .journal-box {
    padding: 0 !important;
  }
  #journalBody {
    padding: 6px 8px !important;
  }

  /* 사이드바 메뉴 항목 폰트 축소 (이전 14.5px → 13.5px) */
  .sidebar-item {
    font-size: 13.5px !important;
    padding: 12px 16px !important;
    min-height: 44px;
  }
  .sidebar-item-icon svg {
    width: 16px !important;
    height: 16px !important;
  }
  .sidebar-logo-name {
    font-size: 13.5px !important;
  }
  .sidebar-logo-sub {
    font-size: 10px !important;
  }

  /* 위저드 카드 폰트 축소 */
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jitem,
  .jmw-text {
    font-size: 13.5px !important;
  }
  .jmw-toggle,
  .jform-table[data-mobile-cards="1"] tr[data-cardrole="item"] td.jcheck label {
    font-size: 13px !important;
    min-height: 42px !important;
  }
  .jmw-group-label {
    font-size: 11px !important;
    padding: 6px 10px !important;
  }
  .jmw-item {
    padding: 12px !important;
    margin: 0 4px 8px !important;
  }

  /* 범용 카드 폰트 축소 */
  .jmg-card {
    padding: 12px !important;
    margin: 0 4px 8px !important;
  }
  .jmg-context {
    font-size: 10.5px !important;
    padding: 2px 7px !important;
  }
  .jmg-label {
    font-size: 10.5px !important;
    margin-bottom: 4px !important;
  }
  .jmg-input-slot input,
  .jmg-input-slot textarea,
  .jmg-input-slot select {
    font-size: 13.5px !important;
    padding: 8px 10px !important;
  }
  .jmg-toggle {
    font-size: 13px !important;
    padding: 10px 12px !important;
    min-height: 40px !important;
  }
  .jmg-summary {
    font-size: 11px !important;
    padding: 6px 10px !important;
  }

  /* 상단 헤더(앱바) 압축 */
  .topbar {
    padding: 6px 10px !important;
    min-height: 44px !important;
  }
  .topbar-title {
    font-size: 14px !important;
  }
  .topbar-btn {
    width: 32px !important;
    height: 32px !important;
  }

  /* 콘텐츠 영역 패딩 축소 */
  .content {
    padding: 12px !important;
  }
  .content-section {
    padding: 0 8px !important;
  }

  /* =========================================================
     일지같은 느낌 (A·B·E)
     - A: 일지 헤더 (폼명 + 작성일자/작성자/검토자/승인자) 정돈
     - B: 섹션 번호 + 큰 헤더 (CSS counter)
     - E: 항목 줄번호 (CSS counter)
     - 좌측 슬레이트 라인으로 장부 효과
     ========================================================= */

  /* A — 일지 상단 헤더 (모바일) — 한 줄로 압축, 제목+버튼 같은 라인 */
  .journal-header {
    background: #1F1D1A !important;
    color: #F4F0E8 !important;
    border-bottom: 1px solid #0a0a0a !important;
    padding: 5px 8px !important;
    position: static !important;
    box-shadow: 0 1px 0 rgba(0,0,0,0.12) !important;
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    flex-wrap: nowrap !important;
  }
  .journal-header h2 {
    font-size: 11px !important;
    font-weight: 700 !important;
    letter-spacing: -0.01em;
    color: #F4F0E8 !important;
    line-height: 1.25 !important;
    flex: 1 1 auto !important;
    margin: 0 !important;
    min-width: 0 !important;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  /* 버튼 가로 스크롤 — 더 슬림 */
  .journal-header-btns {
    display: flex !important;
    gap: 4px !important;
    flex-wrap: nowrap !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch;
    margin-top: 0 !important;
    scrollbar-width: none;
    flex: 0 0 auto !important;
  }
  .journal-header-btns::-webkit-scrollbar { display: none; }
  .journal-header-btns button {
    min-height: 26px !important;
    padding: 3px 8px !important;
    font-size: 10.5px !important;
    font-weight: 600 !important;
    flex: 0 0 auto !important;
    white-space: nowrap !important;
    line-height: 1.2 !important;
  }
  .journal-header-btns .jhb-icon {
    width: 11px !important;
    height: 11px !important;
  }
  .journal-header-btns .btn-jsave,
  .journal-header-btns .btn-jedit-save,
  .journal-header-btns .btn-jdraft {
    background: #F4F0E8 !important;
    color: #1F1D1A !important;
    border: 1px solid #F4F0E8 !important;
    font-weight: 700 !important;
    padding: 3px 10px !important;
  }

  /* 일지 본문 위 메타정보 — 2열 그리드(라벨 / 입력) × 자동 행수, 페어 분리 X */
  .journal-overlay.open .journal-toolbar,
  .journal-toolbar {
    background: #FAFAF8 !important;
    border: 1px solid #E5E7EB !important;
    border-left: 2px solid #1F2937 !important;
    border-radius: 0 !important;
    padding: 5px 10px !important;
    margin: 0 !important;
    font-size: 11px !important;
    line-height: 1.25 !important;
    display: grid !important;
    grid-template-columns: 1fr 1fr !important;
    grid-template-areas:
      "l1 l1"
      "i1 i1"
      "l2 l3"
      "i2 i3" !important;
    column-gap: 8px !important;
    row-gap: 2px !important;
    align-items: center !important;
    min-height: 0 !important;
  }
  .journal-toolbar > * { margin: 0 !important; }
  .journal-toolbar br { display: none !important; }
  .journal-toolbar label {
    font-size: 10px !important;
    color: #6B7280 !important;
    margin: 0 !important;
    font-weight: 600 !important;
    line-height: 1.2 !important;
    white-space: nowrap !important;
  }
  .journal-toolbar input[type="date"],
  .journal-toolbar input[type="text"],
  .journal-toolbar select {
    font-size: 11px !important;
    padding: 1px 5px !important;
    height: 22px !important;
    line-height: 20px !important;
    width: 100% !important;
    min-width: 0 !important;
    max-width: none !important;
    box-sizing: border-box !important;
    border: 1px solid #D1D5DB !important;
    background: #fff !important;
  }
  .journal-toolbar #journalCreatedAtDisplay { display: none !important; }
  /* 스택 배치: 라벨 위, 입력 아래. 작성일자는 한 줄 풀폭, 담당자/검토자는 2 컬럼 */
  .journal-toolbar > *:nth-child(1) { grid-area: l1; }
  .journal-toolbar > *:nth-child(2) { grid-area: i1; }
  .journal-toolbar > *:nth-child(3) { grid-area: l2; }
  .journal-toolbar > *:nth-child(4) { grid-area: i2; }
  .journal-toolbar > *:nth-child(5) { grid-area: l3; }
  .journal-toolbar > *:nth-child(6) { grid-area: i3; }

  /* 좌/중/우 같은 체크 그룹 — 가로 배치 */
  .jmg-field.jmg-field-group .jmg-toggles-row {
    display: flex !important;
    gap: 5px !important;
    flex-wrap: nowrap !important;
  }
  .jmg-field.jmg-field-group .jmg-toggle-cell {
    flex: 1 1 0 !important;
    min-width: 0 !important;
  }
  .jmg-field.jmg-field-group .jmg-toggle-cell .jmg-toggle {
    width: 100% !important;
  }

  /* ── 모노 그레이 토글 (체크박스 어포던스 강함) ── */
  .jmg-toggle {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 7px !important;
    width: 100% !important;
    min-height: 38px !important;
    padding: 7px 10px !important;
    background: #FFFFFF !important;
    color: #4B5563 !important;
    border: 1.5px solid #D1D5DB !important;
    border-radius: 0 !important;
    font-size: 12.5px !important;
    font-weight: 600 !important;
    font-family: inherit !important;
    cursor: pointer !important;
    transition: background 0.12s, border-color 0.12s, color 0.12s !important;
  }
  .jmg-toggle .jmg-toggle-box {
    flex: 0 0 16px;
    width: 16px;
    height: 16px;
    border: 1.5px solid #9CA3AF;
    background: #fff;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    transition: background 0.12s, border-color 0.12s;
    position: relative;
  }
  .jmg-toggle .jmg-toggle-text {
    flex: 0 1 auto;
    line-height: 1.2;
  }
  .jmg-toggle:hover {
    border-color: #6B7280 !important;
    color: #1F2937 !important;
  }
  .jmg-toggle.active {
    background: #2D2D2D !important;
    color: #F5F5F4 !important;
    border-color: #2D2D2D !important;
  }
  .jmg-toggle.active .jmg-toggle-box {
    background: #F5F5F4;
    border-color: #F5F5F4;
  }
  .jmg-toggle.active .jmg-toggle-box::after {
    content: '';
    position: absolute;
    width: 5px;
    height: 9px;
    border-right: 2px solid #2D2D2D;
    border-bottom: 2px solid #2D2D2D;
    transform: rotate(45deg) translate(-1px, -1px);
  }
  /* 그룹 토글은 좀 더 컴팩트하게 */
  .jmg-field-group .jmg-toggle {
    min-height: 36px !important;
    padding: 6px 8px !important;
    font-size: 12px !important;
    gap: 5px !important;
  }
  .jmg-field-group .jmg-toggle .jmg-toggle-box {
    flex: 0 0 14px;
    width: 14px;
    height: 14px;
  }

  /* B — 위저드 그룹 헤더: 번호 + 굵게 + 큼 */
  .j-mobile-wizard {
    counter-reset: jmw-section;
  }
  .jmw-group {
    counter-increment: jmw-section;
    counter-reset: jmw-item;
  }
  .jmw-group-label {
    font-size: 14px !important;
    padding: 10px 12px !important;
    color: #444444 !important;
    background: #fff !important;
    border: 1px solid #1F2937 !important;
    border-radius: 0 !important;
    border-left-width: 4px !important;
    margin-bottom: 12px !important;
    letter-spacing: -0.01em !important;
  }
  .jmw-group-label::before {
    content: counter(jmw-section) ". ";
    font-weight: 900;
    color: #1F2937;
    margin-right: 4px;
  }

  /* E — 위저드 카드 항목 번호 */
  .jmw-item {
    counter-increment: jmw-item;
    border-left: 3px solid #E5E7EB !important;
    border-radius: 0 3px 3px 0 !important;
    padding: 12px 14px !important;
  }
  .jmw-item:has(.jmw-toggle.active) {
    border-left-color: #1F2937 !important;
  }
  .jmw-text::before {
    content: counter(jmw-item) ". ";
    color: #6B7280;
    font-weight: 700;
    margin-right: 2px;
  }

  /* 범용 렌더러 카드 — 같은 장부 효과 */
  .j-mobile-generic {
    counter-reset: jmg-card;
  }
  .jmg-card {
    counter-increment: jmg-card;
    border-left: 3px solid #E5E7EB !important;
    border-radius: 0 3px 3px 0 !important;
  }
  .jmg-card-num {
    color: #1F2937 !important;
    font-weight: 900 !important;
    font-size: 12px !important;
  }
  .jmg-summary {
    font-weight: 700 !important;
    color: #444444 !important;
    border-left: 3px solid #1F2937 !important;
    padding-left: 10px !important;
  }
}

/* =========================================================
   [모바일 1/8] 사이드 메뉴 → 풀스크린 드로워 + 햄버거 톤 정리
   - 데스크톱(>768px) 무영향
   - 기존 .sidebar.open 메커니즘 활용, 톤·폭·터치타겟만 강화
   ========================================================= */
@media (max-width: 768px) {
  /* 사이드바 폭 확장 + 슬레이트 토널 */
  .sidebar {
    width: min(86vw, 320px) !important;
    max-width: 320px !important;
    background: #fff !important;
    border-right: 1px solid #E5E7EB !important;
    box-shadow: 8px 0 24px -12px rgba(0,0,0,0.18);
    z-index: 1000 !important;
  }

  /* 오버레이 색감 + z-index */
  .sidebar-overlay {
    background: rgba(0,0,0,0.5) !important;
    z-index: 999 !important;
  }

  /* 햄버거 아이콘 슬레이트 톤 + 큰 터치 타겟 */
  .topbar-hamburger {
    width: 40px;
    height: 40px;
    padding: 10px !important;
    margin-right: 4px;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    gap: 4px !important;
    border-radius: 4px;
    -webkit-tap-highlight-color: transparent;
  }
  .topbar-hamburger:active {
    background: #F3F4F6;
  }
  .topbar-hamburger span {
    width: 18px !important;
    height: 1.5px !important;
    background: #1F2937 !important;
  }

  /* 로고 영역 — 닫기 버튼용 여백 확보 */
  .sidebar-logo {
    padding: 14px 50px 12px 16px !important;
    justify-content: flex-start !important;
    position: relative;
  }
  .sidebar-logo-name {
    font-size: 15px !important;
  }

  /* 사이드바 우상단 닫기 버튼 (JS가 주입) */
  .sidebar-mobile-close {
    display: flex !important;
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: #6B7280;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    z-index: 5;
    border-radius: 4px;
    -webkit-tap-highlight-color: transparent;
    padding: 0;
    font-family: inherit;
  }
  .sidebar-mobile-close:active { background: #F3F4F6; }

  /* 메뉴 항목 — 큰 터치 타겟 */
  .sidebar-item {
    padding: 14px 18px !important;
    min-height: 48px;
    font-size: 14.5px !important;
    border-radius: 0 !important;
    margin: 0 !important;
  }
  .sidebar-item-icon {
    width: 22px !important;
    height: 22px !important;
    margin-right: 12px !important;
  }
  .sidebar-item-icon svg {
    width: 18px !important;
    height: 18px !important;
  }

  /* 메뉴 그룹 구분선 */
  .sidebar-menu-group {
    padding: 4px 0 !important;
    border-bottom: 1px solid #F3F4F6;
  }
  .sidebar-menu-group:last-child {
    border-bottom: none;
  }

  /* 사이드바 슬라이드 애니메이션 (더 부드럽게) */
  .sidebar {
    transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1) !important;
  }

  /* 메인 영역이 드로워 열려있을 때 스크롤 방지를 위한 보조 클래스 — JS에서 body에 추가 */
  body.sidebar-drawer-open {
    overflow: hidden;
  }

  /* PC 전용 메뉴 — 모바일에선 햄버거에서 숨김 (PC 안내) */
  .sidebar #menu-haccp-team,
  .sidebar #menu-audit,
  .sidebar #labRequestBtn {
    display: none !important;
  }
}

/* Android 태블릿PC 강제 모바일 앱 레이아웃
   Lenovo Idea Tab 12.7처럼 화면폭이 넓어도 Android 터치 태블릿이면 JS가 이 클래스를 붙인다. */
html.vfc-tablet-mobile .main-area,
body.vfc-tablet-mobile .main-area {
  margin-left: 0 !important;
}
html.vfc-tablet-mobile .sidebar.collapsed ~ .main-area,
body.vfc-tablet-mobile .sidebar.collapsed ~ .main-area {
  margin-left: 0 !important;
}
html.vfc-tablet-mobile .topbar-hamburger,
body.vfc-tablet-mobile .topbar-hamburger {
  display: flex !important;
  width: 40px;
  height: 40px;
  padding: 10px !important;
  margin-right: 4px;
  box-sizing: border-box;
  align-items: center;
  justify-content: center;
  gap: 4px !important;
  border-radius: 4px;
  -webkit-tap-highlight-color: transparent;
}
html.vfc-tablet-mobile .topbar-hamburger:active,
body.vfc-tablet-mobile .topbar-hamburger:active {
  background: #F3F4F6;
}
html.vfc-tablet-mobile .topbar-hamburger span,
body.vfc-tablet-mobile .topbar-hamburger span {
  width: 18px !important;
  height: 1.5px !important;
  background: #1F2937 !important;
}
html.vfc-tablet-mobile .sidebar,
body.vfc-tablet-mobile .sidebar {
  width: min(86vw, 320px) !important;
  max-width: 320px !important;
  background: #fff !important;
  border-right: 1px solid #E5E7EB !important;
  box-shadow: 8px 0 24px -12px rgba(0,0,0,0.18) !important;
  z-index: 1000 !important;
  transform: translateX(-100%);
  transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1) !important;
}
html.vfc-tablet-mobile .sidebar.open,
body.vfc-tablet-mobile .sidebar.open {
  transform: translateX(0);
}
html.vfc-tablet-mobile .sidebar-overlay,
body.vfc-tablet-mobile .sidebar-overlay {
  background: rgba(0,0,0,0.5) !important;
  z-index: 999 !important;
}
html.vfc-tablet-mobile .sidebar-logo,
body.vfc-tablet-mobile .sidebar-logo {
  padding: 14px 50px 12px 16px !important;
  justify-content: flex-start !important;
  position: relative;
}
html.vfc-tablet-mobile .sidebar-logo-name,
body.vfc-tablet-mobile .sidebar-logo-name {
  font-size: 15px !important;
}
html.vfc-tablet-mobile .sidebar-mobile-close,
body.vfc-tablet-mobile .sidebar-mobile-close {
  display: flex !important;
  position: absolute;
  top: 12px;
  right: 12px;
  width: 36px;
  height: 36px;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  color: #6B7280;
  font-size: 24px;
  line-height: 1;
  cursor: pointer;
  z-index: 5;
  border-radius: 4px;
  -webkit-tap-highlight-color: transparent;
  padding: 0;
  font-family: inherit;
}
html.vfc-tablet-mobile .sidebar-item,
body.vfc-tablet-mobile .sidebar-item {
  padding: 14px 18px !important;
  min-height: 48px;
  font-size: 14.5px !important;
  border-radius: 0 !important;
  margin: 0 !important;
}
html.vfc-tablet-mobile .sidebar-item-icon,
body.vfc-tablet-mobile .sidebar-item-icon {
  width: 22px !important;
  height: 22px !important;
  margin-right: 12px !important;
}
html.vfc-tablet-mobile .sidebar-item-icon svg,
body.vfc-tablet-mobile .sidebar-item-icon svg {
  width: 18px !important;
  height: 18px !important;
}
html.vfc-tablet-mobile .sidebar-menu-group,
body.vfc-tablet-mobile .sidebar-menu-group {
  padding: 4px 0 !important;
  border-bottom: 1px solid #F3F4F6;
}
html.vfc-tablet-mobile .content,
body.vfc-tablet-mobile .content {
  padding: 12px !important;
}
html.vfc-tablet-mobile .content-section,
body.vfc-tablet-mobile .content-section {
  padding: 0 8px !important;
}
html.vfc-tablet-mobile .content-grid,
body.vfc-tablet-mobile .content-grid {
  grid-template-columns: 1fr !important;
}
html.vfc-tablet-mobile .right-panel,
body.vfc-tablet-mobile .right-panel {
  order: -1;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
html.vfc-tablet-mobile .topbar,
body.vfc-tablet-mobile .topbar {
  padding: 6px 10px !important;
  min-height: 44px !important;
}
html.vfc-tablet-mobile .topbar-title,
body.vfc-tablet-mobile .topbar-title {
  font-size: 14px !important;
}
html.vfc-tablet-mobile .topbar-btn,
body.vfc-tablet-mobile .topbar-btn {
  width: 32px !important;
  height: 32px !important;
}
body.vfc-tablet-mobile.sidebar-drawer-open {
  overflow: hidden;
}
body.vfc-tablet-mobile .sidebar #menu-haccp-team,
body.vfc-tablet-mobile .sidebar #menu-audit,
body.vfc-tablet-mobile .sidebar #labRequestBtn {
  display: none !important;
}

/* 스마트폰 차단: HaccpSelo 앱은 패드/PC 사용을 기준으로 한다. */
.phone-blocker {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 2147483000;
  background: #F6F7F8;
  color: #2F3033;
  align-items: center;
  justify-content: center;
  padding: 24px;
  box-sizing: border-box;
}
.phone-blocker-card {
  width: min(100%, 420px);
  padding: 34px 28px;
  background: #FFFFFF;
  border: 1px solid #E2E4E7;
  border-radius: 16px;
  box-shadow: 0 22px 60px rgba(28, 30, 34, 0.14);
  text-align: center;
}
.phone-blocker-mark {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
  margin-bottom: 22px;
  padding: 0 16px;
  border: 1px solid #DADDE1;
  border-radius: 999px;
  color: #5E6066;
  font-size: 12px;
  font-weight: 900;
  letter-spacing: 0.08em;
}
.phone-blocker h1 {
  margin: 0 0 12px;
  color: #2F3033;
  font-size: 23px;
  line-height: 1.35;
  font-weight: 900;
  letter-spacing: 0;
}
.phone-blocker p {
  margin: 0;
  color: #6E7076;
  font-size: 15px;
  line-height: 1.65;
  word-break: keep-all;
}
.phone-blocker-note {
  margin-top: 14px !important;
  color: #45474C !important;
  font-weight: 800;
}
html.vfc-phone-blocked,
body.vfc-phone-blocked {
  overflow: hidden !important;
  height: 100% !important;
}
html.vfc-phone-blocked .phone-blocker,
body.vfc-phone-blocked .phone-blocker {
  display: flex !important;
}
body.vfc-phone-blocked > *:not(.phone-blocker):not(script):not(style) {
  pointer-events: none !important;
  user-select: none !important;
}

/* VFC sidebar drawer unification
   PC/태블릿도 모바일과 같은 햄버거 드로워 방식으로 통일한다. */
@media (min-width: 769px) {
  .main-area,
  .sidebar.collapsed ~ .main-area {
    margin-left: 0 !important;
  }

  .topbar-hamburger {
    display: flex !important;
    width: 40px;
    height: 40px;
    padding: 10px !important;
    margin-right: 4px;
    box-sizing: border-box;
    align-items: center;
    justify-content: center;
    gap: 4px !important;
    border-radius: 4px;
    -webkit-tap-highlight-color: transparent;
  }
  .topbar-hamburger:hover,
  .topbar-hamburger:active {
    background: #F3F4F6;
  }
  .topbar-hamburger span {
    width: 18px !important;
    height: 1.5px !important;
    background: #1F2937 !important;
  }

  .sidebar,
  .sidebar.collapsed {
    width: min(86vw, 320px) !important;
    max-width: 320px !important;
    background: #fff !important;
    border-right: 1px solid #E5E7EB !important;
    box-shadow: 8px 0 24px -12px rgba(0,0,0,0.18) !important;
    z-index: 1000 !important;
    transform: translateX(-100%) !important;
    transition: transform 0.25s cubic-bezier(0.32, 0.72, 0, 1) !important;
  }
  .sidebar.open,
  .sidebar.collapsed.open {
    transform: translateX(0) !important;
  }
  .sidebar-overlay {
    background: rgba(0,0,0,0.5) !important;
    z-index: 999 !important;
  }
  body.sidebar-drawer-open {
    overflow: hidden;
  }
  .sidebar-collapse-toggle,
  .sidebar.open .sidebar-collapse-toggle,
  .sidebar.collapsed.open .sidebar-collapse-toggle {
    display: none !important;
  }
  .sidebar.open .sidebar-mobile-close,
  .sidebar.collapsed.open .sidebar-mobile-close {
    display: flex !important;
    position: absolute;
    top: 12px;
    right: 12px;
    width: 36px;
    height: 36px;
    align-items: center;
    justify-content: center;
    background: transparent;
    border: none;
    color: #6B7280;
    font-size: 24px;
    line-height: 1;
    cursor: pointer;
    z-index: 5;
    border-radius: 4px;
    -webkit-tap-highlight-color: transparent;
    padding: 0;
    font-family: inherit;
  }
  .sidebar.open .sidebar-mobile-close:hover,
  .sidebar.open .sidebar-mobile-close:active,
  .sidebar.collapsed.open .sidebar-mobile-close:hover,
  .sidebar.collapsed.open .sidebar-mobile-close:active {
    background: #F3F4F6;
  }

  .sidebar.collapsed .sidebar-logo,
  .sidebar.collapsed .sidebar-group-label,
  .sidebar.collapsed .sidebar-accordion-header,
  .sidebar.collapsed .sidebar-accordion-body,
  .sidebar.collapsed .sidebar-badge {
    display: revert !important;
  }
  .sidebar.collapsed .sidebar-logo {
    display: flex !important;
  }
  .sidebar.collapsed .sidebar-accordion-header {
    display: flex !important;
  }
  .sidebar.collapsed .sidebar-item {
    font-size: 14.5px !important;
    padding: 14px 18px !important;
    justify-content: flex-start !important;
    gap: 0 !important;
  }
  .sidebar.collapsed .sidebar-item-icon {
    width: 22px !important;
    height: 22px !important;
    margin-right: 12px !important;
  }
  .sidebar.collapsed .sidebar-item.active {
    border-left-color: transparent !important;
    padding-left: 18px !important;
  }
  .sidebar-collapse-toggle .vfc-sidebar-bars {
    display: inline-flex;
    flex-direction: column;
    gap: 3px;
    width: 15px;
    align-items: stretch;
  }
  .sidebar-collapse-toggle .vfc-sidebar-bars i {
    display: block;
    height: 1.5px;
    background: currentColor;
    border-radius: 999px;
  }
}

/* =========================================================
   모바일 체크리스트 위저드 (≤768px)
   - 순수 체크리스트 폼(j103/j203/j238 등)에서만 활성
   - 표를 숨기고 모바일 전용 UI로 대체. 표 input은 DOM에 남아있어 저장 로직 무변경.
   ========================================================= */
.j-mobile-wizard { display: none; }

@media (max-width: 768px) {
  html.vfc-mobile-call-active,
  body.vfc-mobile-call-active {
    overflow: hidden !important;
  }
  html.vfc-mobile-call-active .phone-blocker,
  body.vfc-mobile-call-active .phone-blocker {
    display: none !important;
  }
  .vfc-mobile-call {
    position: fixed;
    inset: 0;
    z-index: 2147483647;
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 22px;
    background: #f5f5f5;
    font-family: 'Pretendard', -apple-system, BlinkMacSystemFont, sans-serif;
    color: #242424;
  }
  .vfc-mobile-call-card {
    width: min(100%, 430px);
    padding: 28px 24px 24px;
    background: #fff;
    border: 1px solid #e2e2e2;
    border-radius: 8px;
    box-shadow: 0 18px 50px rgba(0,0,0,0.12);
  }
  .vfc-mobile-call-kicker {
    font-size: 13px;
    font-weight: 800;
    color: #6e6e75;
    margin-bottom: 14px;
  }
  .vfc-mobile-call h1 {
    margin: 0 0 22px;
    font-size: 25px;
    line-height: 1.28;
    letter-spacing: 0;
    color: #1f1f1f;
  }
  .vfc-mobile-call-reason {
    padding: 16px;
    background: #f7f7f7;
    border: 1px solid #e5e5e5;
    border-radius: 6px;
  }
  .vfc-mobile-call-label {
    font-size: 12px;
    font-weight: 900;
    color: #6e6e75;
    margin-bottom: 8px;
  }
  .vfc-mobile-call-reason p {
    margin: 0;
    font-size: 16px;
    line-height: 1.55;
    font-weight: 700;
    color: #2f2f2f;
  }
  .vfc-mobile-call-guide {
    margin-top: 16px;
    font-size: 14px;
    line-height: 1.55;
    color: #5f5f66;
  }
  .vfc-mobile-call-actions {
    display: grid;
    gap: 10px;
    margin-top: 22px;
  }
  .vfc-mobile-call-actions button {
    min-height: 52px;
    border-radius: 6px;
    font-family: inherit;
    font-size: 16px;
    font-weight: 900;
    cursor: pointer;
  }
  .vfc-mobile-call-primary {
    border: 0;
    background: #2f2f2f;
    color: #fff;
  }
  .vfc-mobile-call-secondary {
    border: 1px solid #d7d7d7;
    background: #fff;
    color: #3a3a3a;
  }

  .jform-table.j-table-hidden-on-mobile { display: none !important; }

  .j-mobile-wizard {
    display: block;
    padding: 8px 4px 24px;
    font-family: 'Pretendard', -apple-system, sans-serif;
  }

  /* 진행률 바 */
  .jmw-progress {
    position: sticky;
    top: 0;
    z-index: 12;
    display: flex;
    align-items: center;
    gap: 12px;
    padding: 10px 12px;
    background: #fff;
    border-bottom: 1px solid #E5E7EB;
    margin: -8px -4px 14px;
  }
  .jmw-progress-num {
    font-size: 12px;
    font-weight: 700;
    color: #1F2937;
    letter-spacing: 0.04em;
    flex-shrink: 0;
    min-width: 56px;
  }
  .jmw-progress-bar {
    flex: 1;
    height: 4px;
    background: #F3F4F6;
    border-radius: 2px;
    overflow: hidden;
  }
  .jmw-progress-fill {
    display: block;
    height: 100%;
    background: #1F2937;
    transition: width 0.2s ease-out;
  }

  /* 그룹 */
  .jmw-group {
    margin-top: 18px;
  }
  .jmw-group:first-of-type {
    margin-top: 0;
  }
  .jmw-group-label {
    position: sticky;
    top: 44px;
    z-index: 11;
    padding: 8px 12px;
    margin: 0 0 10px;
    background: #F9FAFB;
    border: 1px solid #E5E7EB;
    border-radius: 3px;
    font-size: 12px;
    font-weight: 700;
    color: #4B5563;
    letter-spacing: 0.06em;
  }

  /* 항목 카드 */
  .jmw-item {
    background: #fff;
    border: 1px solid #E5E7EB;
    border-radius: 4px;
    padding: 14px;
    margin: 0 4px 10px;
  }
  .jmw-text {
    font-size: 14.5px;
    line-height: 1.55;
    color: #1F2937;
    font-weight: 500;
    margin-bottom: 12px;
  }

  /* 양호/불량 토글 */
  .jmw-toggle-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 8px;
  }
  .jmw-toggle {
    appearance: none;
    -webkit-appearance: none;
    border: 1px solid #E5E7EB;
    border-radius: 3px;
    background: #F9FAFB;
    color: #6B7280;
    font-family: inherit;
    font-size: 14.5px;
    font-weight: 700;
    padding: 14px 0;
    cursor: pointer;
    min-height: 48px;
    transition: background 0.12s, border-color 0.12s, color 0.12s;
    -webkit-tap-highlight-color: transparent;
  }
  .jmw-toggle.ok.active {
    background: #1F2937;
    border-color: #1F2937;
    color: #fff;
  }
  .jmw-toggle.ng.active {
    background: #fff;
    border-color: #7f1d1d;
    color: #7f1d1d;
  }
  .jmw-toggle:active:not(.active) {
    background: #F3F4F6;
  }

  /* 위저드 활성 시 표 카드뷰 CSS는 작동 안 해야 함 — 표 자체가 hidden이므로 자동 무력화 */
}
