/* ============================================================================
   VeriBrain Operations Hub — Component skeleton
   원칙: 절제된 엔터프라이즈 톤. 이모지 금지 · 버튼 원색 금지(딥톤/보더 위주)
        · 각진 형태(과한 라운드 금지) · 배지는 의미 있는 곳만.
   tokens.css 변수만 참조 (디자인 SSOT, raw hex 금지).
   ============================================================================ */

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scrollbar-gutter: stable; } /* S7: 세로 스크롤바 거터 예약 — 토픽바 우측(아바타) 겹침/잘림 방지(핸드오프 전역 안정화) */
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--fs-14);
  line-height: var(--lh-base);
  color: var(--ink);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
}
a { color: var(--brand-700); text-decoration: none; }
a:hover { text-decoration: underline; }
button, input, select, textarea { font: inherit; }
:root { --ctl-h: 36px; --ctl-h-sm: 30px; --ctl-h-touch: 44px; }

/* ── Typography utilities ──────────────────────────────────────────────────── */
.h1 { font-size: var(--fs-30); font-weight: var(--fw-bold); letter-spacing: -0.02em; line-height: var(--lh-tight); }
.h2 { font-size: var(--fs-24); font-weight: var(--fw-bold); letter-spacing: -0.01em; line-height: var(--lh-tight); }
.h3 { font-size: var(--fs-18); font-weight: var(--fw-semibold); }
.eyebrow { font-size: var(--fs-11); font-weight: var(--fw-bold); letter-spacing: 0.10em; text-transform: uppercase; color: var(--brand-600); }
.muted { color: var(--muted); }
.mono { font-family: var(--font-mono); font-size: 0.92em; font-variant-numeric: tabular-nums; }
/* 숫자/카운트/일시 컬럼 — 우정렬 + 자릿수 고정폭(행 간 정렬). 데이터 테이블 신뢰 표시. */
.num-cell { text-align: right; font-variant-numeric: tabular-nums; }

/* ── Button ───── 원색 없음: primary=딥톤 1색, 나머지=보더/고스트 ───────────── */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--sp-2);
  height: 36px; padding: 0 var(--sp-4);
  border: 1px solid transparent; border-radius: var(--r-md);
  font-size: var(--fs-14); font-weight: var(--fw-semibold);
  cursor: pointer; transition: background .15s var(--ease), border-color .15s var(--ease), color .15s var(--ease);
  white-space: nowrap;
}
.btn:focus-visible { outline: none; box-shadow: var(--ring); }
.btn-primary   { background: var(--brand-800); color: #fff; border-color: var(--brand-800); }
.btn-primary:hover { background: var(--brand-900); border-color: var(--brand-900); }
.btn-secondary { background: var(--surface); color: var(--brand-800); border-color: var(--line-strong); }
.btn-secondary:hover { border-color: var(--brand-400); background: var(--brand-50); }
.btn-ghost     { background: transparent; color: var(--ink-2); border-color: transparent; }
.btn-ghost:hover { background: var(--surface-2); }
.btn-danger    { background: var(--surface); color: var(--danger); border-color: var(--line-strong); }
.btn-danger:hover { border-color: var(--danger); background: var(--danger-soft); }
.btn-sm { height: 30px; padding: 0 var(--sp-3); font-size: var(--fs-13); }
.btn-lg { height: 44px; padding: 0 var(--sp-6); font-size: var(--fs-16); }
.btn[disabled], .btn:disabled {
  background: var(--surface-2); color: var(--muted); cursor: not-allowed; border-color: var(--line); opacity: 1;
}

/* ── Status tag ───── 각진 미니멀. 상태 스캔용 작은 점만. data-status=enum값 ── */
.status {
  display: inline-flex; align-items: center; gap: 7px; height: 22px; padding: 0 8px;
  border-radius: var(--r-tag); font-size: var(--fs-12); font-weight: var(--fw-semibold); line-height: 1;
  border: 1px solid transparent; white-space: nowrap;
}
.status::before { content: ""; width: 6px; height: 6px; border-radius: 2px; background: currentColor; }
.status[data-status="DRAFT"]     { color: var(--st-DRAFT);     background: var(--st-DRAFT-soft);     border-color: var(--line); }
.status[data-status="SCHEDULED"] { color: var(--st-SCHEDULED); background: var(--st-SCHEDULED-soft); border-color: var(--brand-100); }
.status[data-status="DONE"]      { color: var(--st-DONE);      background: var(--st-DONE-soft); }
.status[data-status="CANCELLED"] { color: var(--st-CANCELLED); background: var(--st-CANCELLED-soft); }
.status[data-status="ARCHIVED"]  { color: var(--st-ARCHIVED);  background: var(--st-ARCHIVED-soft);  border-color: var(--line); }
.status[data-status="SUBMITTED"] { color: var(--st-SUBMITTED); background: var(--st-SUBMITTED-soft); border-color: var(--brand-100); }
.status[data-status="RETURNED"]  { color: var(--st-RETURNED);  background: var(--st-RETURNED-soft); }
.status[data-status="APPROVED"]  { color: var(--st-APPROVED);  background: var(--st-APPROVED-soft); }
.status[data-status="OPEN"]      { color: var(--st-OPEN);      background: var(--st-OPEN-soft);      border-color: var(--line); }
.status[data-status="IN_REVIEW"] { color: var(--st-IN_REVIEW); background: var(--st-IN_REVIEW-soft); }
.status[data-status="MATERIAL_PENDING"]     { color: var(--st-MATERIAL_PENDING);     background: var(--st-MATERIAL_PENDING-soft);     border-color: var(--line); }
.status[data-status="SUPPLEMENT_REQUESTED"] { color: var(--st-SUPPLEMENT_REQUESTED); background: var(--st-SUPPLEMENT_REQUESTED-soft); }
.status[data-status="FINAL_PENDING"]        { color: var(--st-FINAL_PENDING);        background: var(--st-FINAL_PENDING-soft);        border-color: var(--brand-100); }
.status[data-status="FINAL_REVIEW"]         { color: var(--st-FINAL_REVIEW);         background: var(--st-FINAL_REVIEW-soft); }
.status[data-status="CONFIRMED"]            { color: var(--st-CONFIRMED);            background: var(--st-CONFIRMED-soft); }
.status[data-status="SYNCED"]               { color: var(--st-SYNCED);               background: var(--st-SYNCED-soft);               border-color: var(--line); }
.status[data-status="ACTIVE"]    { color: var(--st-ACTIVE);    background: var(--st-ACTIVE-soft); }
.status[data-status="EXPIRED"]   { color: var(--st-EXPIRED);   background: var(--st-EXPIRED-soft);   border-color: var(--line); }
.status[data-status="REVOKED"]   { color: var(--st-REVOKED);   background: var(--st-REVOKED-soft); }
.status[data-status="LOCKED"]    { color: var(--st-LOCKED);    background: var(--st-LOCKED-soft); }

/* role label — 각진, 보더 위주(채움 최소) */
.role-chip { display: inline-flex; align-items: center; height: 22px; padding: 0 8px;
  border-radius: var(--r-tag); font-size: var(--fs-12); font-weight: var(--fw-semibold);
  background: transparent; color: var(--brand-800); border: 1px solid var(--brand-200); }
.role-chip.super { color: #fff; background: var(--brand-800); border-color: var(--brand-800); }

/* ── Form ──────────────────────────────────────────────────────────────────── */
.field { display: flex; flex-direction: column; gap: 6px; min-width: 0; } /* 그리드/플렉스 셀이 콘텐츠 최소너비 아래로 축소되도록(오버플로우 방지) */
.label { font-size: var(--fs-13); font-weight: var(--fw-semibold); color: var(--ink-2); }
.input, .select, .textarea {
  width: 100%; height: 38px; padding: 0 var(--sp-3);
  box-sizing: border-box; min-width: 0; /* padding/border 가 width:100% 안에 포함(넘침 방지) + 셀 축소 허용 */
  border: 1px solid var(--line-strong); border-radius: var(--r-md);
  background: var(--surface); color: var(--ink); transition: border-color .15s, box-shadow .15s;
}
.textarea { height: auto; min-height: 84px; padding: var(--sp-3); resize: vertical; }
.input:focus, .select:focus, .textarea:focus { outline: none; border-color: var(--brand-400); box-shadow: var(--ring); }
.input::placeholder { color: var(--muted); }
.input:disabled, .select:disabled, .textarea:disabled {
  background: var(--surface-2); color: var(--muted); cursor: not-allowed; border-color: var(--line);
}
/* 컴팩트 변형(테이블 행·추가행 인라인) — 제어 높이 토큰 30px 로 통일(단차 방지). */
.input-sm, .select-sm { height: var(--ctl-h-sm); }
.hint { font-size: var(--fs-12); color: var(--muted); }
.req { color: var(--danger); }

/* ── Card / panel ──────────────────────────────────────────────────────────── */
.card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); }
.card-pad { padding: var(--sp-5); }
.card-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--line); }
.stat { padding: var(--sp-5); }
.stat .num { font-size: var(--fs-30); font-weight: var(--fw-bold); letter-spacing: -0.02em; color: var(--ink); }
.stat .lbl { font-size: var(--fs-13); color: var(--muted); font-weight: var(--fw-semibold); margin-top: 2px; }
.stat .lbl b { color: var(--brand-700); font-weight: var(--fw-semibold); }

/* ── Table ─────────────────────────────────────────────────────────────────── */
.table { width: 100%; border-collapse: collapse; font-size: var(--fs-13); }
.table thead th { text-align: left; padding: var(--sp-3) var(--sp-4); color: var(--muted);
  font-weight: var(--fw-semibold); font-size: var(--fs-12); letter-spacing: 0.02em;
  background: var(--surface-2); border-bottom: 1px solid var(--line); }
.table tbody td { padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--line); color: var(--ink-2); }
.table tbody tr:last-child td { border-bottom: 0; }
.table tbody tr:hover td { background: var(--surface-2); }
.table tbody td strong { color: var(--ink); font-weight: var(--fw-semibold); }

/* ── App shell ─────────────────────────────────────────────────────────────── */
.app { min-height: 100vh; display: grid; grid-template-columns: var(--sidebar-w) minmax(0, 1fr); }
.sidebar { position: sticky; top: 0; height: 100vh; overflow: auto;
  background: var(--brand-900); color: #b9cdd4; padding: var(--sp-5) var(--sp-4);
  border-right: 1px solid var(--brand-800);
  scrollbar-width: none; -ms-overflow-style: none; } /* 스크롤바 숨김(스크롤 기능 유지) */
.sidebar::-webkit-scrollbar { width: 0; height: 0; display: none; }
.brand-lock { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-1) var(--sp-2) var(--sp-5);
  border-bottom: 1px solid rgba(255,255,255,0.08); margin-bottom: var(--sp-3); }
.brand-lock .mark { width: 30px; height: 30px; flex: none; color: #fff; }
.brand-lock .wm { font-size: var(--fs-16); font-weight: var(--fw-bold); color: #fff; letter-spacing: -0.01em; }
.brand-lock .wm small { display: block; font-size: var(--fs-11); font-weight: var(--fw-medium); color: var(--brand-300); letter-spacing: 0.02em; }
.nav-group { margin: var(--sp-5) var(--sp-2) var(--sp-2); font-size: var(--fs-11); font-weight: var(--fw-bold);
  letter-spacing: 0.08em; text-transform: uppercase; color: var(--brand-400); }
.nav-item { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3);
  width: 100%; min-height: 36px; padding: 0 var(--sp-3); margin-bottom: 1px;
  border: 0; border-radius: var(--r-md); background: transparent; color: #b9cdd4;
  font-size: var(--fs-14); font-weight: var(--fw-medium); cursor: pointer; text-align: left; }
.nav-item:hover { background: rgba(255,255,255,0.05); color: #fff; }
.nav-item.active { background: var(--brand-700); color: #fff; font-weight: var(--fw-semibold); }
.nav-item .count { font-size: var(--fs-12); font-weight: var(--fw-semibold); color: #cfe0e6;
  background: rgba(255,255,255,0.10); border-radius: var(--r-tag); padding: 1px 7px; }
.main { display: flex; flex-direction: column; min-width: 0; }
.topbar { position: sticky; top: 0; z-index: 5; height: var(--topbar-h);
  display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4);
  padding: 0 var(--sp-6); background: var(--surface); border-bottom: 1px solid var(--line); }
.content { padding: var(--sp-6); max-width: var(--content-max); width: 100%; }
.avatar { width: 32px; height: 32px; border-radius: var(--r-md); background: var(--brand-50);
  color: var(--brand-800); display: grid; place-items: center; font-weight: var(--fw-semibold); font-size: var(--fs-13);
  border: 1px solid var(--brand-100); }

/* layout helpers */
.row { display: flex; align-items: center; gap: var(--sp-3); }
.between { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); }
.grid { display: grid; gap: var(--sp-4); }
.swatches { display: grid; grid-template-columns: repeat(auto-fill, minmax(104px, 1fr)); gap: var(--sp-3); }
.swatch { border: 1px solid var(--line); border-radius: var(--r-md); overflow: hidden; background: var(--surface); }
.swatch .chip { height: 52px; }
.swatch .meta { padding: 7px 9px; font-size: var(--fs-12); border-top: 1px solid var(--line); }
.swatch .meta b { display: block; font-weight: var(--fw-semibold); }
.swatch .meta span { color: var(--muted); font-family: var(--font-mono); font-size: var(--fs-11); }

/* ============================================================================
   Composite components — app.css 에서 승격(verbatim). 2026-06-23.
   실제 운영 콘솔(app.css)이 쓰는 복합 패턴을 DS 로 이관 → claude.ai/design 동기화.
   톤 동일: 절제·각진·브랜드 #216E84, 이모지/원색 금지.
   ============================================================================ */

/* ── Page head / pill / embed head ─────────────────────────────────────── */
.page-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-4); margin-bottom: var(--sp-4); min-height: 44px; }
.page-head > div:first-child { min-width: 0; display: flex; flex-direction: column; gap: 2px; }
.page-head > div:last-child { flex-shrink: 0; white-space: nowrap; }
.page-head .h2 { overflow-wrap: anywhere; }
.page-head .sub { color: var(--muted); font-size: var(--fs-13); }
.pill { font-size: var(--fs-11); color: var(--muted); border: 1px solid var(--line); border-radius: var(--r-tag); padding: 2px 8px; }
.embed-head { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-3); min-height: 34px; }
.embed-head .sub { color: var(--muted); font-size: var(--fs-13); }

/* ── Tabs (허브/QC) + group ─────────────────────────────────────────────── */
.mtabs { display: flex; flex-wrap: wrap; gap: 0; border-bottom: 1px solid var(--line); margin-bottom: var(--sp-4); }
.mtab { border: 0; background: none; padding: 9px 16px; font-size: var(--fs-13); font-weight: var(--fw-semibold); color: var(--muted); cursor: pointer; border-bottom: 2px solid transparent; margin-bottom: -1px; }
.mtab:hover { color: var(--ink); }
.mtab.on { color: var(--brand-800); border-bottom-color: var(--brand-700); }
.tab-count { display: inline-block; margin-left: 6px; padding: 0 6px; min-width: 18px; border-radius: 9px; background: var(--surface-2); color: var(--muted); font-size: var(--fs-11, 11px); font-weight: var(--fw-semibold); line-height: 17px; text-align: center; }
.mtab.on .tab-count { background: var(--brand-50, var(--surface-2)); color: var(--brand-800); }
.mtab-group { align-self: center; padding: 0 12px 0 4px; font-size: var(--fs-11, 11px); font-weight: var(--fw-semibold); color: var(--muted); letter-spacing: .02em; opacity: .75; }
.mtab-group:not(:first-child) { border-left: 1px solid var(--line); margin-left: 6px; }

/* ── Filter bar ─────────────────────────────────────────────────────────── */
.filterbar { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.filterbar .select, .filterbar .input, .fb .select, .fb .input { height: var(--ctl-h); min-width: 150px; }
.fb { justify-content: space-between; min-height: var(--ctl-h); flex-wrap: wrap; }
.fb-left { display: flex; flex-wrap: wrap; align-items: center; gap: var(--sp-3); min-width: 0; }
.fb-right { display: flex; align-items: center; gap: var(--sp-3); flex: none; }
.fb-count { font-size: var(--fs-13); color: var(--muted); font-variant-numeric: tabular-nums; }
.fb-sep { margin: 0 2px; opacity: .6; }

/* ── Modal + confirm body ───────────────────────────────────────────────── */
.modal-back { position: fixed; inset: 0; background: rgba(19, 58, 71, 0.32); display: grid; place-items: center; z-index: 80; }
.modal { width: 460px; max-width: calc(100vw - 32px); max-height: calc(100vh - 48px); overflow: auto; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow-lg); }
.modal-head { display: flex; align-items: center; justify-content: space-between; padding: var(--sp-4) var(--sp-5); border-bottom: 1px solid var(--line); }
.modal-head h3 { margin: 0; font-size: var(--fs-16); font-weight: var(--fw-bold); }
.modal-body { padding: var(--sp-5); display: grid; gap: var(--sp-3); }
.modal-foot { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--line); }
.modal-foot .err { color: var(--danger); font-size: var(--fs-13); }
.cm-body { font-size: var(--fs-14); color: var(--ink-2); line-height: var(--lh-base); }
.grid2 { display: grid; grid-template-columns: 1fr 1fr; gap: var(--sp-3); }
.two { display: grid; grid-template-columns: minmax(0, 1fr) 340px; gap: var(--sp-5); align-items: start; }

/* ── Drawer — form/detail right panel ──────────────────────────────────── */
.drawer-scrim { position: fixed; inset: 0; background: rgba(19, 58, 71, 0.32); opacity: 0; pointer-events: none; transition: opacity .2s; z-index: 60; }
.drawer-scrim.open { opacity: 1; pointer-events: auto; }
.drawer { position: fixed; top: 0; right: 0; height: 100vh; width: 460px; max-width: 92vw; background: var(--surface); box-shadow: var(--shadow-lg); display: flex; flex-direction: column; transform: translateX(100%); transition: transform .24s cubic-bezier(.4, 0, .2, 1); }
.drawer-wide { width: 640px; max-width: 94vw; }
.drawer-scrim.open .drawer { transform: translateX(0); }
.drawer-head { position: relative; padding: var(--sp-5) var(--sp-5) var(--sp-4); border-bottom: 1px solid var(--line); }
.drawer-head h3 { margin: 0; padding-right: 32px; font-size: var(--fs-16); font-weight: var(--fw-bold); color: var(--ink); }
.drawer-head .drawer-x { position: absolute; top: var(--sp-4); right: var(--sp-4); }
.drawer-status { margin-top: var(--sp-2); }
.drawer-body { padding: var(--sp-5); overflow: auto; flex: 1; display: grid; gap: var(--sp-4); align-content: start; }
.drawer-foot { display: flex; align-items: center; gap: var(--sp-3); padding: var(--sp-4) var(--sp-5); border-top: 1px solid var(--line); }
.drawer-foot-left, .drawer-foot-right { display: flex; align-items: center; gap: var(--sp-2); }
.drawer-foot-right { margin-left: auto; justify-content: flex-end; flex: 1; }
.drawer-foot > .btn { flex: 1; }
.drawer-foot-left .btn, .drawer-foot-right .btn { flex: 0 1 auto; }
.drawer-foot .err { color: var(--danger); font-size: var(--fs-12); flex: none; }

/* ── User menu (topbar dropdown) ───────────────────────────────────────── */
.usermenu { position: relative; }
.usermenu-btn { display: flex; align-items: center; gap: var(--sp-2); height: 42px; padding: 0 8px 0 6px; background: transparent; border: 1px solid transparent; border-radius: var(--r-md); cursor: pointer; }
.usermenu-btn:hover { background: var(--surface-2); border-color: var(--line); }
.usermenu-meta { display: flex; flex-direction: column; align-items: flex-start; line-height: 1.15; gap: 1px; }
.usermenu-meta .role-chip { height: 16px; padding: 0 5px; font-size: var(--fs-11); }
.usermenu-caret { width: 14px; height: 14px; color: var(--muted); }
.usermenu-pop { position: absolute; top: calc(100% + 6px); right: 0; min-width: 184px; background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--shadow-lg); padding: 4px; z-index: 30; display: grid; gap: 1px; }
.usermenu-item { display: flex; align-items: center; width: 100%; height: 36px; padding: 0 10px; background: transparent; border: 0; border-radius: var(--r-sm); font-size: var(--fs-13); font-weight: var(--fw-medium); color: var(--ink-2); cursor: pointer; text-align: left; }
.usermenu-item:hover { background: var(--surface-2); color: var(--ink); }
.usermenu-item.danger-txt { color: var(--danger); }

/* ── Toast (비차단 피드백) ──────────────────────────────────────────────── */
.toast-host { position: fixed; top: var(--sp-4); right: var(--sp-4); z-index: 80; display: grid; gap: var(--sp-2); width: 340px; max-width: calc(100vw - 32px); pointer-events: none; }
.toast { pointer-events: auto; display: flex; align-items: flex-start; gap: var(--sp-2); padding: 10px 12px; background: var(--surface); border: 1px solid var(--line); border-left: 4px solid var(--muted); border-radius: var(--r-md); box-shadow: var(--shadow-md); font-size: var(--fs-13); color: var(--ink); animation: toast-in .18s var(--ease); }
.toast.out { animation: toast-out .18s var(--ease) forwards; }
.toast-success { border-left-color: var(--success); } .toast-success .toast-ico { color: var(--success); }
.toast-error   { border-left-color: var(--danger); }  .toast-error .toast-ico   { color: var(--danger); }
.toast-info    { border-left-color: var(--brand-600); } .toast-info .toast-ico  { color: var(--brand-600); }
.toast-ico { flex: none; display: grid; place-items: center; margin-top: 1px; }
.toast-msg { flex: 1; min-width: 0; }
.toast-x { flex: none; background: none; border: 0; color: var(--muted); cursor: pointer; padding: 0; display: grid; place-items: center; }
.toast-x:hover { color: var(--ink); }
@keyframes toast-in  { from { opacity: 0; transform: translateX(12px); } to { opacity: 1; transform: none; } }
@keyframes toast-out { to { opacity: 0; transform: translateX(12px); } }

/* ── Skeleton ───────────────────────────────────────────────────────────── */
.sk { overflow: hidden; }
.sk-bar, .sk-cell, .sk-th { background: linear-gradient(90deg, var(--surface-2), var(--line), var(--surface-2)); background-size: 200% 100%; animation: ux-shimmer 1.2s infinite linear; border-radius: var(--r-sm); }
.sk-row { display: flex; gap: var(--sp-4); padding: var(--sp-3) var(--sp-4); border-bottom: 1px solid var(--line); }
.sk-row:last-child { border-bottom: 0; }
.sk-th { height: 10px; width: 30%; margin: var(--sp-3) var(--sp-4); }
.sk-cell { height: 64px; border-radius: var(--r-md); }
@keyframes ux-shimmer { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* ── Empty state ────────────────────────────────────────────────────────── */
.empty-state { padding: var(--sp-8) var(--sp-5); text-align: center; display: grid; justify-items: center; gap: 6px; }
.empty-ico { color: var(--brand-600); display: grid; place-items: center; width: 44px; height: 44px; border-radius: var(--r-lg); background: var(--brand-50); border: 1px solid var(--brand-100); }
.empty-state.filtered .empty-ico { color: var(--muted); background: var(--surface-2); border-color: var(--line); }
.empty-state.error .empty-ico { color: var(--danger); background: var(--danger-soft); border-color: color-mix(in srgb, var(--danger) 25%, var(--line)); }
.empty-ico .ico { width: 24px; height: 24px; }
.empty-title { font-size: var(--fs-14); font-weight: var(--fw-semibold); color: var(--ink); }
.empty-desc { font-size: var(--fs-13); color: var(--muted); max-width: 360px; }
.empty-act { margin-top: var(--sp-2); }

/* ── Id badge / copy row / pw rules / mfa qr ───────────────────────────── */
.id-badge { display: inline-flex; align-items: center; gap: 6px; padding: 5px 10px; margin-bottom: var(--sp-3); background: var(--brand-50); border: 1px solid var(--brand-100); border-radius: var(--r-md); font-size: var(--fs-12); color: var(--brand-800); }
.id-badge b { font-weight: var(--fw-semibold); }
.id-badge .ico { color: var(--brand-600); }
.copy-row { display: flex; gap: var(--sp-2); align-items: stretch; }
.copy-row .input { flex: 1; min-width: 0; }
.copy-row .btn { flex: none; white-space: nowrap; }
.pw-rules { list-style: none; margin: 6px 0 var(--sp-3); padding: 0; display: grid; gap: 4px; }
.pw-rule { display: flex; align-items: center; gap: 6px; font-size: var(--fs-12); color: var(--muted); }
.pw-rule .ico { color: var(--muted); }
.pw-rule.ok { color: var(--success); }
.pw-rule.ok .ico { color: var(--success); }
.mfa-qr { display: inline-block; background: #fff; padding: 8px; border: 1px solid var(--c-border, #e2e6e8); border-radius: 4px; }
.mfa-qr svg { display: block; width: 168px; height: 168px; }

/* ── Calendar — toolbar / seg / month grid / time grid / legend ────────── */
.cal-toolbar { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); margin-bottom: var(--sp-4); }
.cal-nav { display: flex; align-items: center; gap: var(--sp-2); }
.cal-nav .period { font-size: var(--fs-18); font-weight: var(--fw-bold); min-width: 168px; }
.iconbtn { width: 32px; height: 32px; display: grid; place-items: center; border: 1px solid var(--line-strong); border-radius: var(--r-md); background: var(--surface); color: var(--ink-2); cursor: pointer; }
.iconbtn:hover { background: var(--surface-2); border-color: var(--brand-300); }
.seg { display: inline-flex; border: 1px solid var(--line-strong); border-radius: var(--r-md); overflow: hidden; }
.seg button { height: var(--ctl-h); padding: 0 14px; border: 0; background: var(--surface); color: var(--ink-2); font-size: var(--fs-13); font-weight: var(--fw-semibold); cursor: pointer; }
.seg button + button { border-left: 1px solid var(--line); }
.seg button.on { background: var(--brand-800); color: #fff; }
.seg-sm button { height: var(--ctl-h-sm); padding: 0 11px; font-size: var(--fs-12); }
.seg-sm button.on { background: var(--brand-50); color: var(--brand-800); }
.cal-month { border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); }
.cal-dow { display: grid; grid-template-columns: repeat(7, 1fr); background: var(--surface-2); border-bottom: 1px solid var(--line); }
.cal-dow div { padding: 8px 10px; font-size: var(--fs-12); font-weight: var(--fw-semibold); color: var(--muted); text-align: left; }
.cal-dow div:first-child { color: var(--danger); }
.cal-grid { display: grid; grid-template-columns: repeat(7, 1fr); grid-auto-rows: minmax(108px, 1fr); }
.cal-cell { border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 6px; cursor: pointer; min-width: 0; position: relative; }
.cal-cell:nth-child(7n) { border-right: 0; }
.cal-cell:hover { background: var(--brand-50); }
.cal-cell.other { background: var(--surface-2); color: var(--muted); }
.cal-cell.today .daynum { background: var(--brand-700); color: #fff; }
.cal-cell .daynum { display: inline-grid; place-items: center; min-width: 22px; height: 22px; border-radius: var(--r-tag); font-size: var(--fs-12); font-weight: var(--fw-semibold); padding: 0 5px; }
.cal-cell.sun .daynum { color: var(--danger); }
.ev { display: flex; align-items: center; gap: 5px; margin-top: 4px; padding: 2px 6px; border-radius: var(--r-tag); font-size: var(--fs-12); font-weight: var(--fw-medium); background: var(--surface-2); color: var(--ink-2); border: 1px solid var(--line); cursor: pointer; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }
.ev::before { content: ""; width: 6px; height: 6px; border-radius: 2px; flex: none; background: var(--brand-600); }
.ev:hover { border-color: var(--brand-400); }
.ev[data-status="DONE"]::before { background: var(--success); }
.ev[data-status="CANCELLED"]::before, .ev[data-status="ARCHIVED"]::before { background: var(--muted); }
.ev[data-status="DRAFT"]::before { background: var(--line-strong); }
.ev[data-track="EXTERNAL_SITE_VISIT"] { border-left: 3px solid var(--brand-600); }
.ev[data-track="REFERRAL_ASSESSMENT"] { border-left: 3px solid #8a6d3b; }
.ev .t { color: var(--muted); font-variant-numeric: tabular-nums; }
.tg { border: 1px solid var(--line); border-radius: var(--r-lg); overflow: hidden; background: var(--surface); }
.tg-scroll { max-height: 620px; overflow-y: auto; }
.tg-row { display: grid; grid-template-columns: 56px repeat(var(--tg-cols), 1fr); }
.tg-head { position: sticky; top: 0; z-index: 2; background: var(--surface-2); border-bottom: 1px solid var(--line); }
.tg-corner { border-right: 1px solid var(--line); }
.tg-dh { padding: 8px 4px; text-align: center; font-size: var(--fs-12); font-weight: var(--fw-semibold); color: var(--ink-2); border-left: 1px solid var(--line); }
.tg-dh.today { color: var(--brand-800); background: var(--brand-50); }
.tg-dh .dow { color: var(--muted); font-weight: var(--fw-medium); }
.tg-gutter { border-right: 1px solid var(--line); }
.tg-hl { font-size: var(--fs-11); color: var(--muted); text-align: right; padding: 1px 6px 0 0; box-sizing: border-box; border-top: 1px solid var(--line); font-variant-numeric: tabular-nums; }
.tg-hl:first-child { border-top: 0; }
.tg-col { position: relative; border-left: 1px solid var(--line); cursor: pointer; }
.tg-col.today { background: var(--brand-50); }
.tg-hrow { border-top: 1px solid var(--line); box-sizing: border-box; }
.tg-hrow:first-child { border-top: 0; }
.tg-ev { position: absolute; left: 3px; right: 3px; box-sizing: border-box; border-radius: 3px; border: 1px solid var(--line); border-left: 3px solid var(--brand-600); background: var(--surface); color: var(--ink-2); padding: 1px 6px; font-size: var(--fs-11); line-height: 1.35; overflow: hidden; cursor: pointer; }
.tg-ev:hover { border-color: var(--brand-400); z-index: 1; }
.tg-ev .t { font-weight: var(--fw-semibold); color: var(--brand-800); }
.tg-ev[data-track="EXTERNAL_SITE_VISIT"] { border-left-color: var(--brand-600); }
.tg-ev[data-track="REFERRAL_ASSESSMENT"] { border-left-color: #8a6d3b; }
.tg-ev[data-status="DONE"] { background: var(--success-bg, #eef6f0); }
.tg-ev[data-status="CANCELLED"], .tg-ev[data-status="ARCHIVED"] { background: var(--surface-2); color: var(--muted); text-decoration: line-through; }
.tg-ev[data-status="DRAFT"] { opacity: .68; }
.cal-legend { display: flex; gap: 16px; align-items: center; font-size: var(--fs-12); color: var(--muted); margin-bottom: 8px; }
.cal-legend .lg { display: inline-flex; align-items: center; gap: 5px; }
.cal-legend .sw { width: 12px; height: 0; border-top: 3px solid var(--brand-600); display: inline-block; }
.cal-legend .sw.ref { border-top-color: #8a6d3b; }

/* ── Compact KPI ──────────────────────────────────────────────────────── */
.kpi-strip { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--sp-3); }
.kpi-strip-compact { display: flex; flex-wrap: wrap; align-items: stretch; gap: 8px; }
.kpi-card { background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); padding: var(--sp-4) var(--sp-5); display: block; }
.kpi-card-compact { display: inline-flex; align-items: baseline; gap: 7px; min-width: 132px; padding: 8px 12px; border-radius: var(--r-md); }
.kpi-num { font-size: var(--fs-30); font-weight: var(--fw-bold); color: var(--ink); font-variant-numeric: tabular-nums; line-height: 1.1; }
.kpi-card-compact .kpi-num { font-size: var(--fs-18); letter-spacing: 0; }
.kpi-lbl { font-size: var(--fs-13); color: var(--muted); font-weight: var(--fw-semibold); margin-top: 2px; }
.kpi-card-compact .kpi-lbl { font-size: var(--fs-12); margin-top: 0; white-space: nowrap; }
.kpi-card.alert .kpi-num { color: var(--danger); }

/* ── QC — stepper / thread / dropzone / deliver / rows / kv ─────────────── */
.qc-steps { display: flex; align-items: flex-start; }
.qc-step { flex: 1; display: flex; flex-direction: column; align-items: center; gap: 5px; position: relative; text-align: center; }
.qc-step::before { content: ""; position: absolute; top: 9px; left: -50%; width: 100%; height: 2px; background: var(--line); z-index: 0; }
.qc-step:first-child::before { display: none; }
.qc-step .dot { width: 20px; height: 20px; border-radius: 50%; border: 2px solid var(--line-strong); background: var(--surface); display: grid; place-items: center; font-size: 10px; font-weight: var(--fw-bold); color: var(--muted); position: relative; z-index: 1; }
.qc-step .lbl { font-size: var(--fs-11); color: var(--muted); line-height: 1.25; }
.qc-step.done .dot { border-color: var(--brand-600); background: var(--brand-600); color: #fff; }
.qc-step.done::before { background: var(--brand-600); }
.qc-step.now .dot { border-color: var(--brand-700); color: var(--brand-800); box-shadow: 0 0 0 3px var(--brand-50); }
.qc-step.now .lbl { color: var(--brand-800); font-weight: var(--fw-semibold); }
.qc-step.loop .dot { border-color: var(--warning); color: var(--warning); }
.qc-step.loop .lbl { color: var(--warning); }
.qc-thread { display: grid; gap: 8px; border-top: 1px solid var(--line); padding-top: 10px; }
.qc-round { font-size: var(--fs-11, 11px); font-weight: var(--fw-semibold); color: var(--muted); letter-spacing: .02em; margin-top: 4px; }
.qc-cmt { background: var(--surface-2); border-radius: var(--r-tag, 6px); padding: 7px 10px; font-size: var(--fs-13); }
.qc-cmt-h { font-size: var(--fs-12); margin-bottom: 2px; }
.qc-atts { display: grid; gap: 4px; }
.qc-att { font-size: var(--fs-13); }
.qc-att.superseded { color: var(--muted); text-decoration: line-through; }
.dz { border: 1px solid var(--brand-200); background: var(--brand-50); border-radius: var(--r-lg); padding: var(--sp-4); display: grid; gap: var(--sp-3); }
.dz .now-line { font-size: var(--fs-13); font-weight: var(--fw-bold); color: var(--brand-800); display: flex; align-items: center; gap: 8px; }
.dz .now-line .dot { width: 7px; height: 7px; border-radius: 2px; background: var(--brand-700); flex: none; }
.dz .err { color: var(--danger); font-size: var(--fs-13); }
.dz .err:empty { display: none; }
.deliver { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); background: var(--surface); border: 1px solid var(--line); border-radius: var(--r-md); padding: 10px var(--sp-3); }
.deliver .meta { font-size: var(--fs-13); }
.deliver .meta .muted { font-size: var(--fs-12); }
.qc-row { cursor: pointer; }
.qc-row:hover td { background: var(--surface-2); }
.qc-row.sel td { background: var(--brand-50); }
.kv { display: grid; grid-template-columns: 64px 1fr; gap: 7px var(--sp-3); font-size: var(--fs-13); margin: 0; }
.kv dt { color: var(--muted); }
.kv dd { margin: 0; }
.qc-cancelled { color: var(--danger); font-size: var(--fs-13); font-weight: var(--fw-semibold); padding: var(--sp-2) 0; }

/* ── Report / schedule — badges / today card / due pill / checklist / visit card ── */
.ev-rep { display: inline-block; width: 6px; height: 6px; border-radius: 50%; background: var(--success, #2e7d32); margin-left: 5px; vertical-align: middle; }
.ev-rep.noshow { background: var(--warning); }
.rep-badge { display: inline-block; font-size: var(--fs-12); padding: 1px 7px; border-radius: 3px; border: 1px solid var(--line); }
.rep-badge.done { color: var(--success, #2e7d32); border-color: color-mix(in srgb, var(--success, #2e7d32) 35%, var(--line)); }
.rep-badge.none { color: var(--muted); }
.rep-badge.noshow { color: var(--warning); border-color: color-mix(in srgb, var(--warning) 35%, var(--line)); }
.rep-badge.result-pending { color: var(--warning); border-color: color-mix(in srgb, var(--warning) 35%, var(--line)); }
.rep-badge.result-done { color: var(--success, #2e7d32); border-color: color-mix(in srgb, var(--success, #2e7d32) 35%, var(--line)); }
.rep-sec { margin-top: 4px; }
.rep-none { color: var(--muted); font-size: var(--fs-13); }
.rep-head { font-size: var(--fs-13); color: var(--muted); margin-bottom: 4px; }
.rep-list { list-style: none; margin: 0; padding: 0; display: grid; gap: 3px; }
.rep-item { font-size: var(--fs-13); }
.rep-item .rep-ic { display: inline-block; min-width: 38px; font-size: var(--fs-12); font-weight: var(--fw-semibold); }
.rep-item.done .rep-ic { color: var(--success, #2e7d32); }
.rep-item.miss .rep-ic { color: var(--danger, #b3261e); }
.today-sect-lbl { font-size: var(--fs-11); font-weight: var(--fw-bold); letter-spacing: .08em; text-transform: uppercase; color: var(--muted); margin: var(--sp-5) 0 var(--sp-2); }
.today-card.urgent { border-left: 4px solid var(--warning); }
.due-pill { display: inline-flex; align-items: center; gap: 5px; height: 20px; padding: 0 7px; border-radius: var(--r-tag); font-size: var(--fs-11); font-weight: var(--fw-semibold); border: 1px solid transparent; }
.due-pill .due-dot { width: 6px; height: 6px; border-radius: 2px; background: currentColor; }
.due-pill.over { color: var(--danger); background: var(--danger-soft); }
.due-pill.soon { color: var(--warning); background: var(--warning-soft); }
.due-pill.up { color: var(--muted); background: var(--surface-2); border: 1px solid var(--line); }
.rpt-row { display: flex; align-items: center; justify-content: space-between; gap: var(--sp-3); padding: 9px 0; border-bottom: 1px solid var(--line); }
.rpt-chk { display: flex; align-items: center; gap: 8px; font-size: var(--fs-14); font-weight: var(--fw-semibold); cursor: pointer; }
.rpt-chk input { width: 16px; height: 16px; accent-color: var(--brand-700); }
.rpt-state { font-size: var(--fs-12); color: var(--muted); }
.rpt-reason { margin: 6px 0 4px; }
.rpt-reason[hidden] { display: none; }
.vcard { padding: 0; margin-bottom: var(--sp-3); overflow: hidden; }
.vhead { display: flex; align-items: center; justify-content: space-between; padding: 9px var(--sp-4); border-bottom: 1px solid var(--line); background: var(--surface-2); }
.vcard .table { margin: 0; }

/* ── Mobile shell — bottom tabs / pc note / drawer ─────────────────────── */
.mobile-tabs { display: none; }
.pc-note { display: flex; align-items: center; gap: 6px; padding: 8px 12px; margin-bottom: var(--sp-3); background: var(--warning-soft); color: var(--warning); border-radius: var(--r-md); font-size: var(--fs-12); font-weight: var(--fw-semibold); }
.pc-note .ico { flex: none; }
.drawer-toggle { display: none; }
.nav-backdrop { display: none; }
@media (max-width: 720px) {
  .mobile-tabs { display: grid; grid-template-columns: repeat(3, 1fr); position: fixed; bottom: 0; left: 0; right: 0; z-index: 40; height: 56px; background: var(--surface); border-top: 1px solid var(--line); box-shadow: var(--shadow-md); }
  .mtab-btn { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 2px; background: none; border: 0; color: var(--muted); font-size: var(--fs-11); font-weight: var(--fw-semibold); cursor: pointer; }
  .mtab-btn .ico { width: 20px; height: 20px; }
  .mtab-btn.on { color: var(--brand-700); }
  .drawer-toggle { display: grid; }
  .nav-backdrop { display: block; position: fixed; inset: 0; z-index: 55; background: rgba(19, 58, 71, 0.4); }
  .btn { min-height: var(--ctl-h-touch); }
  .btn-sm { min-height: var(--ctl-h); }
  .input, .select { height: var(--ctl-h-touch); }
  .iconbtn { width: var(--ctl-h-touch); height: var(--ctl-h-touch); }
  .mtab, details > summary { min-height: var(--ctl-h-touch); display: flex; align-items: center; }
  .drawer { top: auto; bottom: 0; right: 0; width: 100%; max-width: 100%; height: 85vh; transform: translateY(100%); border-radius: var(--r-lg) var(--r-lg) 0 0; }
  .drawer-scrim.open .drawer { transform: translateY(0); }
  .drawer-foot { flex-wrap: wrap; }
  .drawer-foot-left, .drawer-foot-right { width: 100%; }
  .drawer-foot-right { margin-left: 0; }
  .kpi-card-compact { width: 100%; justify-content: space-between; }
}
