/* ============================================================
   KooVIS Work — 공통 디자인 시스템 (단일 소스)
   신규/수정 페이지는 이 파일을 <head>에서 링크하고 토큰·컴포넌트를 재사용한다.
   <link rel="stylesheet" href="/work/koovis.css">
   ============================================================ */
@import url('https://cdn.jsdelivr.net/gh/orioncactus/pretendard/dist/web/static/pretendard.css');

:root {
  /* 표면·텍스트 */
  --bg: #f0f2f5;
  --surface: #ffffff;
  --surface2: #f7f8fa;
  --border: #e2e5ea;
  --border-accent: #00b09a;
  --text: #111827;
  --text-sub: #4b5563;
  --text-muted: #9ca3af;

  /* 브랜드 액센트 (전 페이지 통일값) */
  --accent: #00b09a;
  --accent-mid: #00a08c;
  --accent-dark: #008b7a;
  --accent-light: #e6f7f5;

  /* 보조 색 */
  --purple: #8b5cf6;
  --purple-bg: #f3effe;
  --blue: #3b82f6;

  /* 감성(VOC) */
  --pos: #10b981;  --pos-bg: #e7f7f1;
  --neu: #9ca3af;  --neu-bg: #f3f4f6;
  --neg: #ef4444;  --neg-bg: #fdecec;

  /* 그림자 */
  --s1: 0 1px 3px rgba(0,0,0,0.08), 0 1px 2px rgba(0,0,0,0.04);
  --s2: 0 4px 12px rgba(0,0,0,0.08), 0 2px 4px rgba(0,0,0,0.04);
  --s3: 0 12px 28px rgba(0,0,0,0.1), 0 4px 8px rgba(0,0,0,0.06);
  --shadow-sm: var(--s1);
  --shadow: var(--s2);
  --shadow-lg: var(--s3);

  /* 반경 */
  --radius-sm: 8px;
  --radius: 12px;
  --radius-lg: 16px;
}

/* ── 기본 ── */
.kv * { box-sizing: border-box; }
.kv-body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: 'Pretendard', system-ui, -apple-system, sans-serif;
  min-height: 100vh;
}

/* ── 네비게이션 ── */
.kv-nav {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  min-height: 56px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 6px;
  position: sticky;
  top: 0;
  z-index: 100;
  box-shadow: var(--s1);
}
.kv-nav-left { display: flex; align-items: center; gap: 12px; min-width: 0; }
.kv-nav-brand {
  font-size: 15px; font-weight: 800; color: var(--accent);
  text-decoration: none; letter-spacing: -0.3px; white-space: nowrap;
}
.kv-nav-back { font-size: 13px; color: var(--text-muted); text-decoration: none; }
.kv-nav-back:hover { color: var(--accent); }
.kv-nav-divider { color: var(--border); }
.kv-nav-title { font-size: 13px; color: var(--text-sub); font-weight: 600; white-space: nowrap; }
.kv-nav-links { display: flex; align-items: center; gap: 4px; flex-wrap: wrap; }
.kv-nav-link {
  font-size: 13px; color: var(--text-sub); text-decoration: none;
  padding: 6px 12px; border-radius: var(--radius-sm); min-height: 36px;
  display: inline-flex; align-items: center; transition: background .15s, color .15s;
}
.kv-nav-link:hover { background: var(--surface2); color: var(--text); }
.kv-nav-link.active { background: var(--accent-light); color: var(--accent-dark); font-weight: 700; }

/* ── 전역 상단 네비 (work-nav.js가 .nav-tabs를 채움 · 전 페이지 통일) ──
   페이지의 <style> 뒤에 이 파일을 링크하면 페이지별 .nav CSS를 덮어써 일관화됨.
   .tab은 .nav-tabs 하위로 스코프 → 페이지 내부 필터 탭(.tab)과 충돌 없음. */
.nav {
  background: var(--surface); border-bottom: 1px solid #e8e8ec;
  padding: 0 24px; min-height: 52px;
  display: flex; align-items: center; justify-content: flex-start; gap: 8px; flex-wrap: wrap;
  position: sticky; top: 0; z-index: 100; box-shadow: var(--s1);
  font-family: 'Pretendard', system-ui, -apple-system, sans-serif;
}
.nav-left { display: flex; align-items: center; gap: 10px; min-width: 0; flex-shrink: 0; }
.nav-brand, .nav-logo {
  font-size: 15px; font-weight: 800; color: var(--accent);
  text-decoration: none; letter-spacing: -0.3px; white-space: nowrap;
}
.nav-logo span { color: var(--accent); }
.nav-back { font-size: 13px; color: var(--text-muted); text-decoration: none; }
.nav-back:hover { color: var(--accent); }
.nav-divider { color: #d1d1d6; }
.nav-title { font-size: 13px; color: #6b6b6b; font-weight: 400; white-space: nowrap; }
.nav-tabs { display: flex; gap: 3px; flex-wrap: wrap; width: 100%; }
.nav-tabs .tab {
  padding: 6px 12px; border-radius: 8px; font-size: 12.5px; font-weight: 500;
  color: #6b6b6b; text-decoration: none; white-space: nowrap; line-height: 1.4;
  background: none; border: none; cursor: pointer; transition: all .15s;
}
.nav-tabs .tab:hover { background: var(--accent-light); color: var(--accent); }
.nav-tabs .tab.active { background: #1a1a1a; color: #fff; }
.nav-tabs .nav-sep, .nav-sep { color: #d1d5db; font-size: 13px; padding: 0 3px; align-self: center; user-select: none; }
@media (max-width: 640px) {
  .nav { padding: 0 14px; min-height: 48px; }
  .nav-tabs { gap: 2px; }
  .nav-tabs .tab { padding: 5px 9px; font-size: 11.5px; }
}

/* ── 카드 ── */
.kv-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--s1);
  padding: 18px;
}
.kv-card-title { font-size: 14px; font-weight: 700; color: var(--text); margin: 0 0 10px; }

/* ── 버튼 ── */
.kv-btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  min-height: 40px; padding: 9px 16px;
  background: var(--text); color: #fff; border: none;
  border-radius: var(--radius-sm); font-size: 14px; font-weight: 600;
  cursor: pointer; transition: opacity .15s;
}
.kv-btn:hover { opacity: .85; }
.kv-btn-accent { background: var(--accent); }
.kv-btn-ghost { background: var(--surface); color: var(--text-sub); border: 1px solid var(--border); }

/* ── 칩/필터 (터치 타깃 ≥36px) ── */
.kv-chip {
  display: inline-flex; align-items: center; min-height: 32px;
  padding: 6px 12px; border-radius: 999px; font-size: 12px; font-weight: 600;
  background: var(--surface2); color: var(--text-sub);
  border: 1px solid var(--border); cursor: pointer; transition: all .15s;
}
.kv-chip.active { background: var(--accent); color: #fff; border-color: var(--accent); }

/* ── 탭 ── */
.kv-tab {
  padding: 8px 14px; font-size: 13px; font-weight: 600; color: var(--text-sub);
  background: none; border: none; border-radius: var(--radius-sm);
  min-height: 38px; cursor: pointer; transition: all .15s;
}
.kv-tab.active { background: var(--text); color: #fff; }

/* ── 상태 ── */
.kv-loading, .kv-empty {
  text-align: center; padding: 32px; color: var(--text-muted); font-size: 13px;
}
.kv-error { text-align: center; padding: 24px; color: var(--neg); font-size: 13px; }

/* ── 접근성: 키보드 포커스 ── */
.kv-nav-link:focus-visible, .kv-btn:focus-visible, .kv-chip:focus-visible, .kv-tab:focus-visible {
  outline: 2px solid var(--accent); outline-offset: 2px;
}

/* ── 모바일 ── */
@media (max-width: 640px) {
  .kv-nav { padding: 0 14px; }
  .kv-nav-links { gap: 2px; }
  .kv-nav-link { padding: 6px 9px; font-size: 12px; }
  .kv-card { padding: 14px; }
}

