﻿/* ============================================================
   Sellerina Admin - Design System v4
   타이포그래피 5단계 + 스페이싱 8px 그리드
   본문 16px + 사이드바-본문 64px 호흡
   ============================================================ */

/* ── 1. Design Tokens ──────────────────────────────────────── */
:root {
  /* Sellerina Color System v2 - Tokyo Couture Monochrome */
  --primary: #1A1A1A;
  --text-main: #1F1F1F;
  --text-sub: #8E8E8E;
  --mid-tone: #B5B5B5;
  --surface: #FAFAFA;
  --background: #FFFFFF;
  --border: #E5E5E5;

  /* Text semantics */
  --text-primary: var(--text-main);
  --text-secondary: var(--text-sub);
  --text-tertiary: var(--mid-tone);
  --text-disabled: var(--mid-tone);
  --text-inverse: var(--surface);

  /* Surface semantics */
  --surface-base: var(--background);
  --surface-elevated: var(--surface);
  --surface-overlay: rgba(26, 26, 26, 0.04);

  /* Border semantics */
  --border-subtle: var(--border);
  --border-default: var(--border);
  --border-strong: var(--mid-tone);
  --border-focus: var(--primary);

  /* Semantic states - tuned for monochrome UI */
  --color-success: #8A8A8A;
  --color-success-soft: #ECECEC;
  --color-success-deep: #4F4F4F;
  --color-warning: #9A9A9A;
  --color-warning-soft: #EFEFEF;
  --color-warning-deep: #5C5C5C;
  --color-danger: #FF0000;
  --color-danger-soft: rgba(255, 0, 0, 0.08);
  --color-danger-deep: #FF0000;
  --color-info: #8E8E8E;
  --color-info-soft: #E8E8E8;
  --color-info-deep: #555555;

  /* Legacy aliases mapped to Sellerina monochrome tokens */
  --brand-navy: var(--primary);
  --brand-navy-soft: #2C2C2C;
  --brand-gold: var(--primary);
  --brand-gold-soft: var(--surface);
  --brand-gold-dark: var(--text-main);
  --accent: var(--primary);
  --accent-light: var(--surface);
  --accent-dark: var(--text-main);
  --white: var(--background);
  --text: var(--text-main);
  --text-muted: var(--text-secondary);
  --success: var(--color-success);
  --danger: var(--color-danger);
  --warning: var(--color-warning);
  --info: var(--color-info);
  --blue: var(--color-info);

  /* Neutral aliases retained for existing components */
  --gray-0: var(--background);
  --gray-50: var(--surface);
  --gray-100: var(--surface);
  --gray-200: var(--border);
  --gray-300: var(--mid-tone);
  --gray-400: var(--mid-tone);
  --gray-500: var(--text-sub);
  --gray-600: #6B7280;
  --gray-700: var(--text-main);
  --gray-800: var(--text-main);
  --gray-900: var(--primary);

  /* Surface */
  --surface-primary: var(--background);
  --surface-secondary: var(--surface);
  --surface-tertiary: var(--surface);
  --bg: var(--surface);

  /* Border */
  --border-soft: var(--border);

  /* Typography - 5단계만 */
  --font-display: 'Jost', system-ui, -apple-system, sans-serif;
  --font-body: 'Pretendard', 'Pretendard Variable', system-ui, sans-serif;

  --font-sans: var(--font-body);
  --font-mono: 'JetBrains Mono', 'Fira Code', Consolas, Monaco, monospace;

  --font-display-size: 32.5px;
  --font-display-weight:700;
  --font-display-line:  1.2;
  --font-display-tracking: -0.02em;

  --font-heading-size: 20px;
  --font-heading-weight:600;
  --font-heading-line:  1.3;
  --font-heading-tracking: -0.01em;

  --font-body-size: 14.5px;
  --font-body-weight:   400;
  --font-body-line:     1.6;

  --font-label-size: 12.5px;
  --font-label-weight:  500;
  --font-label-line:    1.5;

  --font-caption-size: 11px;
  --font-caption-weight:600;
  --font-caption-line:  1.4;
  --font-caption-tracking: 0.06em;

  /* Spacing - 8px grid (5단계만) */
  --space-half: 4px;
  --space-1: 8px;
  --space-2: 16px;
  --space-3: 24px;
  --space-4: 40px;
  --space-5: 64px;

  /* Layout */
  --sidebar-w:   264px;
  --content-max: 1400px;  /* page-container 최대 너비 */

  /* Shadow */
  --shadow-xs: 0 1px 2px rgba(26, 26, 26, 0.04);
  --shadow-sm: 0 1px 3px rgba(26, 26, 26, 0.06), 0 1px 2px rgba(26, 26, 26, 0.04);
  --shadow-md: 0 4px 6px rgba(26, 26, 26, 0.04), 0 2px 4px rgba(26, 26, 26, 0.04);
  --shadow-lg: 0 10px 15px rgba(26, 26, 26, 0.06), 0 4px 6px rgba(26, 26, 26, 0.04);
  --shadow-focus: 0 0 0 3px rgba(26, 26, 26, 0.12);

  /* Transition */
  --t-fast:   120ms cubic-bezier(0.4, 0, 0.2, 1);
  --t-normal: 180ms cubic-bezier(0.4, 0, 0.2, 1);

  /* Radius */
  --radius-sm: 4px;
  --radius:    8px;
  --radius-lg: 12px;
}

/* ── 2. Reset ──────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth;
}
body {
  margin: 0;
  font-family: var(--font-sans);
  font-size: var(--font-body-size);
  line-height: var(--font-body-line);
  color: var(--text-primary);
  background: var(--bg);
  font-feature-settings: 'cv02','cv03','cv04','cv11','palt';
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-rendering: optimizeLegibility;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
img, svg { display: block; max-width: 100%; }
button { font-family: inherit; cursor: pointer; }
a { color: inherit; text-decoration: none; }
input, textarea, select, button { font-family: inherit; font-size: inherit; }
::selection { background: #0A84FF; color: #FFFFFF; }

/* Scrollbar */
::-webkit-scrollbar { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--gray-300); border-radius: 4px; }
::-webkit-scrollbar-thumb:hover { background: var(--gray-400); }

/* ── 3. Typography utilities (5단계만) ─────────────────────── */
.text-display {
  font-size: var(--font-display-size);
  font-weight: var(--font-display-weight);
  line-height: var(--font-display-line);
  letter-spacing: var(--font-display-tracking);
  font-feature-settings: 'tnum';
}
.text-heading {
  font-size: var(--font-heading-size);
  font-weight: var(--font-heading-weight);
  line-height: var(--font-heading-line);
  letter-spacing: var(--font-heading-tracking);
}
.text-body {
  font-size: var(--font-body-size);
  font-weight: var(--font-body-weight);
  line-height: var(--font-body-line);
}
.text-label {
  font-size: var(--font-label-size);
  font-weight: var(--font-label-weight);
  line-height: var(--font-label-line);
}
.text-caption {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  line-height: var(--font-caption-line);
  letter-spacing: var(--font-caption-tracking);
  text-transform: uppercase;
}
.text-secondary { color: var(--text-secondary); }
.text-tertiary  { color: var(--text-tertiary); }
.text-success   { color: var(--text-success); }
.text-warning   { color: var(--text-warning); }
.text-danger    { color: var(--text-danger); }

/* Headings default */
h1, h2, h3, h4, h5, h6 { margin: 0; color: var(--text-primary); }
h1 {
  font-size: var(--font-heading-size);
  font-weight: var(--font-heading-weight);
  line-height: var(--font-heading-line);
  letter-spacing: var(--font-heading-tracking);
}
h2 { font-size: 20px; font-weight: 600; line-height: 1.3; letter-spacing: -0.01em; }
h3 { font-size: 18px; font-weight: 600; line-height: 1.3; }
h4 {
  font-size: var(--font-label-size);
  font-weight: 600;
  line-height: var(--font-label-line);
}
p { margin: 0; }

code, pre {
  font-family: var(--font-mono);
  font-size: 13px;
  background: var(--gray-100);
  padding: 2px 6px;
  border-radius: var(--radius-sm);
}
pre { padding: var(--space-2); overflow-x: auto; line-height: 1.5; }
pre code { background: none; padding: 0; }

/* ── 4. Layout - 사이드바 + 본문 64px 호흡 ────────────────── */
.layout, .admin-layout {
  display: flex;
  min-height: 100vh;
  background: var(--bg);
}

.main, .main-content {
  flex: 1;
  margin-left: var(--sidebar-w);
  min-height: 100vh;
  padding: var(--space-4) var(--space-5);   /* 40px / 64px */
  max-width: var(--content-max);
}

@media (max-width: 1280px) {
  .main, .main-content { padding: var(--space-3) var(--space-4); }
}

/* ── 5. Sidebar ────────────────────────────────────────────── */
.sidebar {
  position: fixed;
  top: 0; left: 0; bottom: 0;
  width: var(--sidebar-w);
  background: var(--brand-navy);
  color: var(--gray-0);
  display: flex;
  flex-direction: column;
  z-index: 50;
  border-right: 1px solid rgba(255,255,255,0.04);
}
.sidebar-close {
  display: none !important;
  appearance: none !important;
  -webkit-appearance: none !important;
  background: transparent !important;
  border: 0 !important;
}

.sidebar-header {
  padding: 28px 24px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
  margin-bottom: var(--space-1);
}
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  text-decoration: none;
  color: var(--gray-0);
}
.sidebar-brand .sellerina-logo {
  display: block;
  width: 160px;
  height: auto;
}
.brand-icon {
  width: 36px;
  height: 36px;
  background: var(--brand-gold);
  color: var(--brand-navy);
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 16px;
  border-radius: var(--radius-sm);
  letter-spacing: -0.02em;
}
.brand-text { display: flex; flex-direction: column; gap: 2px; line-height: 1.2; }
.brand-text strong { font-size: 16px; font-weight: 600; letter-spacing: 0.04em; }
.brand-text small  {
  font-size: var(--font-label-size);
  font-weight: 500;
  color: rgba(255,255,255,0.55);
  letter-spacing: 0;
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  overflow-x: hidden;
  padding: 0 12px var(--space-2);
  display: flex;
  flex-direction: column;
}
.sidebar-nav::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.08); }

.nav-section-title {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  color: rgba(255,255,255,0.36);
  text-transform: uppercase;
  letter-spacing: var(--font-caption-tracking);
  padding: var(--space-2) 12px var(--space-1);
  margin-top: var(--space-1);
}
.nav-section-title:first-child { margin-top: var(--space-1); }

.sidebar-link {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 12px;                /* vertical 12px (가독성) */
  font-size: var(--font-label-size);
  font-weight: var(--font-label-weight);
  line-height: var(--font-label-line);
  color: rgba(255,255,255,0.72);
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.sidebar-link:hover {
  background: rgba(255,255,255,0.06);
  color: var(--gray-0);
}
.sidebar-link.active {
  background: var(--brand-gold);
  color: var(--brand-navy);
  font-weight: 600;
}
.sidebar-link svg {
  flex-shrink: 0;
  width: 18px; height: 18px;
  stroke-width: 2;
  opacity: 0.75;
  transition: var(--t-fast);
}
.sidebar-link:hover svg { opacity: 1; }
.sidebar-footer {
  padding: var(--space-2) var(--space-3);
  border-top: 1px solid rgba(255,255,255,0.06);
}

/* ── 6. Page header ────────────────────────────────────────── */
.page-header,
.topbar {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-bottom: var(--space-4);            /* 40px */
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border-subtle);
}
.page-header h1, .topbar h1, .page-title {
  font-size: var(--font-heading-size);
  font-weight: var(--font-heading-weight);
  line-height: var(--font-heading-line);
  letter-spacing: var(--font-heading-tracking);
  margin: 0;
}
.page-subtitle {
  margin-top: var(--space-half);
  font-size: var(--font-body-size);
  color: var(--text-secondary);
}

/* ── 7. Buttons ────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
  height: 40px;
  padding: 0 16px;
  font-size: var(--font-label-size);
  font-weight: 600;
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  cursor: pointer;
  transition: var(--t-fast);
  white-space: nowrap;
  user-select: none;
  background: var(--surface-primary);
  color: var(--text-primary);
  text-decoration: none;
  line-height: 1;
}
.btn:hover { background: var(--gray-50); border-color: var(--gray-300); }
.btn:focus-visible { outline: 2px solid var(--brand-gold); outline-offset: 2px; }
.btn:disabled, .btn[disabled] { opacity: 0.5; cursor: not-allowed; }

.btn-primary {
  background: var(--brand-navy);
  color: var(--text-inverse);
  border-color: var(--brand-navy);
}
.btn-primary:hover { background: var(--brand-navy-soft); border-color: var(--brand-navy-soft); }

.btn-accent {
  background: var(--brand-gold);
  color: var(--brand-navy);
  border-color: var(--brand-gold);
  font-weight: 600;
}
.btn-accent:hover { background: var(--brand-gold-dark); border-color: var(--brand-gold-dark); color: var(--text-inverse); }

.btn-ghost {
  background: transparent;
  border-color: transparent;
  color: var(--text-secondary);
}
.btn-ghost:hover { background: var(--gray-100); color: var(--text-primary); }

.btn-danger {
  background: var(--surface-primary);
  color: var(--text-danger);
  border-color: var(--border-subtle);
}
.btn-danger:hover { background: #FEF2F2; border-color: var(--text-danger); }

.btn-sm { height: 32px; padding: 0 12px; font-size: 13px; }
.btn-lg { height: 48px; padding: 0 24px; font-size: var(--font-body-size); }

/* ── 8. Forms ──────────────────────────────────────────────── */
.form-group { margin-bottom: var(--space-2); }
.form-label {
  display: block;
  font-size: var(--font-label-size);
  font-weight: var(--font-label-weight);
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}
.form-label .req { color: var(--text-danger); margin-left: 2px; }

/* 라벨 변형 클래스 - 모두 form-label과 동일 폰트로 통일 */
.text-label, .field-label, .input-label,
form label:not(.checkbox-label):not(.radio-label):not(.menu-main):not(.menu-sub) {
  font-size: var(--font-label-size);
  font-weight: var(--font-label-weight);
  line-height: var(--font-label-line);
  color: var(--text-primary);
}
.form-help {
  display: block;
  font-size: var(--font-label-size);
  color: var(--text-secondary);
  margin-top: var(--space-half);
  line-height: 1.5;
}

.input, .select, .textarea, .form-input, .form-textarea, .form-select,
input[type="text"], input[type="email"], input[type="password"],
input[type="number"], input[type="search"], input[type="url"], input[type="date"],
input[type="tel"], input[type="file"],
select, textarea {
  display: block;
  width: 100%;
  height: 40px;
  padding: 0 12px;
  /* 라벨/인풋/플레이스홀더 동일 폰트 사이즈 */
  font-size: var(--font-label-size);
  font-weight: 400;
  font-family: inherit;
  line-height: 1.5;
  color: var(--text-primary);
  background: var(--surface-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.input:focus, .select:focus, .textarea:focus,
.form-input:focus, .form-textarea:focus, .form-select:focus,
input:focus, select:focus, textarea:focus {
  outline: none;
  border-color: var(--brand-gold);
  box-shadow: var(--shadow-focus);
}
/* placeholder 도 라벨과 동일한 폰트 사이즈로 명시 */
input::placeholder, textarea::placeholder, select::placeholder,
.form-input::placeholder, .form-textarea::placeholder {
  color: var(--text-tertiary);
  font-size: var(--font-label-size);
  opacity: 1;
}
/* 비활성/읽기전용 인풋 */
input:disabled, select:disabled, textarea:disabled,
.form-input:disabled, .form-textarea:disabled, .form-select:disabled,
input[readonly], textarea[readonly], .form-input[readonly] {
  background: var(--surface-tertiary);
  color: var(--text-secondary);
  cursor: not-allowed;
}

textarea, .textarea, .form-textarea {
  height: auto;
  min-height: 96px;
  padding: 12px;
  font-size: var(--font-label-size);
  line-height: 1.5;
  resize: vertical;
}
select, .select {
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%236B7280' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 12px center;
  padding-right: 36px;
}
input[type="checkbox"], input[type="radio"] {
  width: 16px; height: 16px;
  accent-color: var(--brand-gold);
  cursor: pointer;
}

.form-row   { display: grid; grid-template-columns: repeat(2, 1fr); gap: var(--space-2); }
.form-row-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2); }

/* ── 9. Card / Panel ───────────────────────────────────────── */
.panel, .card {
  background: var(--surface-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  overflow: hidden;
}
.panel-header, .card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: var(--space-2) var(--space-3);
  border-bottom: 1px solid var(--border-soft);
}
.panel-header h2, .panel-header h3,
.card-header h2, .card-header h3 {
  font-size: var(--font-label-size);
  font-weight: 600;
}
.panel-body, .card-body { padding: var(--space-3); }

.panel:not(:has(.panel-header)),
.card:not(:has(.card-header)) {
  padding: var(--space-3);
}

.panel + .panel,
.card + .card { margin-top: var(--space-3); }

/* ── 10. Stat (KPI) card ───────────────────────────────────── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--space-3);                         /* 24px */
  margin-bottom: var(--space-4);               /* 40px */
}

.stat-card {
  background: var(--surface-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius-lg);
  padding: var(--space-3);                     /* 24px */
  position: relative;
  overflow: hidden;
  transition: var(--t-fast);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.stat-card:hover { box-shadow: var(--shadow-sm); }

.stat-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
  background: var(--gray-200);
}
.stat-card.accent::before  { background: var(--brand-gold); }
.stat-card.success::before { background: var(--text-success); }
.stat-card.warning::before { background: var(--text-warning); }
.stat-card.danger::before  { background: var(--text-danger); }
.stat-card.blue::before, .stat-card.info::before { background: var(--info); }

/* Stat 의 자식들이 새 타이포 클래스를 사용하도록 유도 */
.stat-label {
  font-size: var(--font-label-size);
  font-weight: var(--font-label-weight);
  color: var(--text-secondary);
  margin: 0;
}
.stat-value {
  font-size: var(--font-display-size);          /* 36px */
  font-weight: var(--font-display-weight);
  line-height: var(--font-display-line);
  letter-spacing: var(--font-display-tracking);
  color: var(--text-primary);
  font-feature-settings: 'tnum';
  margin-top: var(--space-1);                   /* 8px (라벨-값) */
}
.stat-sub {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  color: var(--text-tertiary);
  text-transform: uppercase;
  letter-spacing: var(--font-caption-tracking);
}
.stat-trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  font-size: var(--font-body-size);
  font-weight: 500;
}
.stat-trend.up   { color: var(--text-success); }
.stat-trend.down { color: var(--text-danger); }

/* ── 11. Table ─────────────────────────────────────────────── */
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: var(--font-body-size);
}
.table thead th {
  text-align: left;
  padding: 12px 14px;
  font-size: var(--font-label-size);
  font-weight: 600;
  color: var(--text-secondary);
  background: var(--gray-50);
  border-bottom: 1px solid var(--border-subtle);
  white-space: nowrap;
}
.table thead th:first-child { padding-left: var(--space-3); }
.table thead th:last-child  { padding-right: var(--space-3); }

.table tbody td {
  padding: 14px;
  border-bottom: 1px solid var(--border-soft);
  color: var(--text-primary);
  vertical-align: middle;
}
.table tbody td:first-child { padding-left: var(--space-3); }
.table tbody td:last-child  { padding-right: var(--space-3); }
.table tbody tr:last-child td { border-bottom: none; }
.table tbody tr:hover { background: var(--gray-50); }

/* ── 12. Badge ─────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  height: 24px;
  padding: 0 10px;
  font-size: 13px;
  font-weight: 600;
  line-height: 1;
  border-radius: var(--radius-sm);
  background: var(--gray-100);
  color: var(--gray-700);
  white-space: nowrap;
}
.badge-success { background: #ECFDF3; color: #166534; }
.badge-warning { background: #FFFAEB; color: #92400E; }
.badge-danger  { background: #FEF2F2; color: #991B1B; }
.badge-info    { background: #EFF4FF; color: #1E40AF; }
.badge-accent  { background: var(--brand-gold-soft); color: var(--brand-gold-dark); }

/* ── 13. Alert ─────────────────────────────────────────────── */
.alert {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: var(--space-2);
  font-size: var(--font-body-size);
  line-height: 1.5;
  border-radius: var(--radius);
  margin-bottom: var(--space-2);
  border: 1px solid var(--border-subtle);
  background: var(--surface-primary);
}
.alert strong { color: inherit; font-weight: 600; }
.alert-info    { background: #EFF4FF; border-color: #DBE7FF; color: #1E40AF; }
.alert-success { background: #ECFDF3; border-color: #BBF7D0; color: #166534; }
.alert-warning { background: #FFFAEB; border-color: #FDE68A; color: #92400E; }
.alert-danger,
.alert-error   { background: #FEF2F2; border-color: #FECACA; color: #991B1B; }

/* ── 14. Empty state ──────────────────────────────────────── */
.empty-state {
    width: 100%;
    background: var(--surface-primary);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    padding: var(--space-5) var(--space-3);
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: var(--space-2);
    color: var(--text-secondary);
  }
.empty-state-icon {
  width: 56px;
  height: 56px;
  margin: 0 auto var(--space-2);
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--gray-100);
  border-radius: 50%;
  color: var(--gray-400);
}
.empty-state h3 {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary);
  margin-bottom: var(--space-1);
}
.empty-state p {
  font-size: var(--font-body-size);
  color: var(--text-secondary);
  margin: 0 auto var(--space-3);
  max-width: 480px;
  line-height: var(--font-body-line);
}
.empty-state-steps {
  text-align: left;
  display: inline-block;
  font-size: var(--font-body-size);
  margin: 0 0 var(--space-3);
  padding: 0;
  list-style: none;
}
.empty-state-steps li { padding: var(--space-half) 0; color: var(--text-secondary); }
.empty-state-steps li.current { font-weight: 600; color: var(--brand-navy); }

/* ── 15. Workflow Pipeline ─────────────────────────────────── */
.wf-pipeline-title {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--font-caption-tracking);
  margin: 0 0 var(--space-2);
}
.wf-stages {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--space-1);                           /* 8px */
  align-items: stretch;
}
.wf-stage-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-1);
  padding: var(--space-2);                       /* 16px */
  background: var(--surface-primary);
  border: 1px solid var(--border-subtle);
  border-radius: var(--radius);
  text-decoration: none;
  color: var(--text-primary);
  transition: var(--t-fast);
  min-height: 132px;
}
.wf-stage-card:hover { border-color: var(--brand-gold); background: #FDF9F2; }
.wf-stage-card.is-bottleneck { border-color: var(--text-warning); background: #FFFAEB; }
.wf-stage-card.is-bottleneck-danger { border-color: var(--text-danger); background: #FEF2F2; }
.wf-stage-card.is-external { background: var(--gray-50); cursor: default; pointer-events: none; }

.wf-stage-icon {
  width: 32px; height: 32px;
  display: flex; align-items: center; justify-content: center;
  color: var(--text-secondary);
}
.wf-stage-card.is-external .wf-stage-icon { color: var(--gray-400); }

.wf-step-num {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  color: var(--text-secondary);
  text-transform: uppercase;
  letter-spacing: var(--font-caption-tracking);
}
.wf-stage-label {
  font-size: var(--font-body-size);
  font-weight: 500;
  line-height: var(--font-body-line);
  color: var(--text-primary);
  text-align: center;
}
.wf-stage-card.is-external .wf-stage-label { color: var(--text-secondary); }

.wf-stage-count {
  font-size: var(--font-heading-size);            /* 22px */
  font-weight: var(--font-heading-weight);
  line-height: var(--font-heading-line);
  letter-spacing: var(--font-heading-tracking);
  color: var(--brand-navy);
  font-feature-settings: 'tnum';
}
.wf-stage-count.is-zero {
  color: var(--gray-400);
  font-weight: 400;
}
.wf-stage-count.is-external {
  font-size: var(--font-caption-size);
  font-weight: var(--font-caption-weight);
  color: var(--gray-400);
  text-transform: uppercase;
  letter-spacing: var(--font-caption-tracking);
}
.wf-arrow-sep { display: none; }

/* ── 16. Workflow Breadcrumb ───────────────────────────────── */
.wf-breadcrumb {
  margin-bottom: var(--space-3);
  padding: var(--space-2) var(--space-2);
  background: var(--surface-primary);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius);
}
.wf-steps {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-half);
  list-style: none;
  padding: 0;
  margin: 0 0 var(--space-1);
}
.wf-step {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: var(--font-label-size);
}
.wf-step a {
  display: flex;
  align-items: center;
  gap: 6px;
  color: inherit;
  padding: var(--space-half) 6px;
  border-radius: var(--radius-sm);
  transition: var(--t-fast);
}
.wf-step a:hover { background: var(--gray-100); }
.wf-num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 22px; height: 22px;
  font-size: 11px;
  font-weight: 700;
  border-radius: 50%;
  border: 1.5px solid var(--gray-300);
  color: var(--text-secondary);
  background: var(--surface-primary);
  flex-shrink: 0;
}
.wf-lbl { font-size: var(--font-label-size); color: var(--text-secondary); white-space: nowrap; }

.wf-step.is-done .wf-num { background: var(--brand-navy); border-color: var(--brand-navy); color: var(--text-inverse); }
.wf-step.is-done .wf-lbl { color: var(--text-secondary); }
.wf-step.is-current .wf-num { background: var(--brand-gold); border-color: var(--brand-gold); color: var(--brand-navy); }
.wf-step.is-current .wf-lbl { color: var(--brand-navy); font-weight: 600; }
.wf-step.is-upcoming .wf-num { color: var(--gray-400); border-color: var(--gray-200); }
.wf-step.is-upcoming .wf-lbl { color: var(--gray-400); }
.wf-arrow { color: var(--gray-300); font-size: var(--font-label-size); }

.wf-context {
  font-size: var(--font-label-size);
  color: var(--text-secondary);
  margin: 0;
}
.wf-context strong { color: var(--brand-navy); font-weight: 600; }
.wf-context a { color: var(--brand-gold-dark); font-weight: 600; }
.wf-context a:hover { text-decoration: underline; }

/* ── 17. Activity feed ─────────────────────────────────────── */
.activity-feed { list-style: none; padding: 0; margin: 0; }
.activity-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border-soft);
  font-size: var(--font-body-size);
}
.activity-item:last-child { border-bottom: none; }
.activity-dot {
  width: 8px; height: 8px;
  border-radius: 50%;
  margin-top: 8px;
  flex-shrink: 0;
  background: var(--gray-300);
}
.activity-dot.product { background: var(--brand-navy); }
.activity-dot.vendor  { background: var(--brand-gold); }
.activity-dot.upload  { background: var(--text-success); }
.activity-label { flex: 1; }
.activity-label > div:first-child { font-weight: 500; color: var(--text-primary); }
.activity-time {
  font-size: var(--font-label-size);
  color: var(--text-secondary);
  font-feature-settings: 'tnum';
  flex-shrink: 0;
}

/* ── 18. HelpBox (재디자인) ───────────────────────────────── */
.help-box {
  margin-bottom: var(--space-3);
  background: var(--surface-secondary);          /* #F5F8FA */
  border: 1px solid var(--border-subtle);
  border-left: 3px solid var(--brand-gold);
  border-radius: var(--radius);
  padding: var(--space-2) var(--space-3);
  transition: var(--t-fast);
}
.help-toggle {
  display: flex;
  align-items: center;
  width: 100%;
  background: transparent;
  border: none;
  cursor: pointer;
  font-size: var(--font-body-size);
  font-weight: 600;
  color: var(--brand-navy);
  text-align: left;
  gap: var(--space-1);
  padding: 0;
  line-height: var(--font-body-line);
}
.help-toggle-arrow {
  margin-left: auto;
  color: var(--text-secondary);
  transition: transform var(--t-fast);
  font-size: var(--font-label-size);
}
.help-box.is-open .help-toggle-arrow { transform: rotate(180deg); }

.help-content {
  display: none;
  margin-top: var(--space-2);
  padding-top: var(--space-2);
  border-top: 1px solid var(--border-subtle);
  font-size: var(--font-body-size);
  line-height: var(--font-body-line);
}
.help-box.is-open .help-content { display: block; }
.help-content > * + * { margin-top: var(--space-1); }
.help-content p { color: var(--text-primary); }
.help-content strong { color: var(--brand-navy); font-weight: 600; }
.help-content ol, .help-content ul {
  margin: var(--space-1) 0 var(--space-1) 24px;
  padding: 0;
  color: var(--text-primary);
}
.help-content li { padding: 2px 0; }

.help-tip {
  display: flex;
  align-items: flex-start;
  gap: var(--space-1);
  margin-top: var(--space-2);
  padding: var(--space-1) 12px;
  background: var(--brand-gold-soft);
  color: var(--brand-navy);
  border-radius: var(--radius-sm);
  font-size: var(--font-label-size);
  line-height: var(--font-label-line);
}

/* ── 19. Login ─────────────────────────────────────────────── */
.login-page {
  min-height: 100vh;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  background: var(--brand-navy);
  padding: 100px var(--space-3) var(--space-3);
}
.login-card {
  width: 100%;
  max-width: 420px;
  background: var(--surface-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-4);
  box-shadow: var(--shadow-lg);
}
.login-brand {
  display: flex;
  justify-content: center;
  margin-bottom: var(--space-3);
}
.login-logo {
  display: block;
  width: min(100%, 320px);
  height: auto;
}
.login-card h1 {
  font-size: var(--font-heading-size);
  margin-bottom: var(--space-half);
}
.login-card .subtitle {
  font-size: var(--font-body-size);
  color: var(--text-secondary);
  margin-bottom: var(--space-3);
}

/* ── 20. Utilities ─────────────────────────────────────────── */
.hidden { display: none !important; }
.flex { display: flex; }
.flex-col { display: flex; flex-direction: column; }
.items-center { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-1 { gap: var(--space-1); }
.gap-2 { gap: var(--space-2); }
.gap-3 { gap: var(--space-3); }
.mt-1 { margin-top: var(--space-1); }
.mt-2 { margin-top: var(--space-2); }
.mt-3 { margin-top: var(--space-3); }
.mt-4 { margin-top: var(--space-4); }
.mb-1 { margin-bottom: var(--space-1); }
.mb-2 { margin-bottom: var(--space-2); }
.mb-3 { margin-bottom: var(--space-3); }
.mb-4 { margin-bottom: var(--space-4); }

/* ── 21. Responsive ────────────────────────────────────────── */
@media (max-width: 1280px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .wf-stages { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 768px) {
  .sidebar { transform: translateX(-100%); transition: transform var(--t-normal); }
  .sidebar.is-open { transform: translateX(0); }
  .main, .main-content { margin-left: 0; padding: var(--space-3); }
  .wf-stages { grid-template-columns: repeat(2, 1fr); }
  .form-row, .form-row-3 { grid-template-columns: 1fr; }
}

/* ── 22. Print ─────────────────────────────────────────────── */
@media print {
  .sidebar, .help-box, .wf-breadcrumb { display: none; }
  .main, .main-content { margin-left: 0; padding: 0; }
}

/* ── Page Container (LAYOUT_AND_LOCALIZATION v1.0) ──────── */
.page-container {
  width: 100%;
  max-width: var(--content-max);    /* 1400px */
  margin: 0 auto;
  padding: var(--space-4) var(--space-5) var(--space-5);  /* 40 / 64 / 64 */
  box-sizing: border-box;
}
.page-container > * + * {
  margin-top: var(--space-4);       /* 섹션 간 40px */
}
.page-container > .page-header + * {
  margin-top: var(--space-3);       /* 헤더 다음만 24px */
}
@media (max-width: 1024px) {
  .page-container {
    padding-left: var(--space-3);
    padding-right: var(--space-3);
  }
}

@media (max-width: 760px) {
  body .main-content input:not([type="file"]):not([type="hidden"]),
  body .main-content select,
  body .main-content textarea,
  body .main-content .form-input,
  body .main-content .form-select,
  body .main-content .form-textarea,
  body .main-content .input,
  body .main-content .select,
  body .main-content .textarea {
    font-size: 14px !important;
    line-height: 1.35 !important;
    font-weight: 400 !important;
  }

  body .main-content input::placeholder,
  body .main-content textarea::placeholder,
  body .main-content .form-input::placeholder,
  body .main-content .form-textarea::placeholder,
  body .main-content .input::placeholder,
  body .main-content .textarea::placeholder {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }
}

/* PC layout unification: keep every admin page on the same grid. */
@media (min-width: 821px) {
  :root {
    --admin-page-x: 32px;
    --admin-page-top: 20px;
    --admin-section-gap: 20px;
  }

  body .main,
  body .main-content {
    padding: var(--admin-page-top) var(--admin-page-x) var(--admin-page-x) !important;
  }

  body .main-content > .page-container,
  body .main-content main.page-container,
  body .page-container {
    padding: var(--admin-page-top) var(--admin-page-x) var(--admin-page-x) !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    width: 100% !important;
    max-width: none !important;
  }

  body .page-container > * + * {
    margin-top: var(--admin-section-gap) !important;
  }

  body .page-container > .masthead + *,
  body .page-container > .page-header + * {
    margin-top: var(--admin-section-gap) !important;
  }

  body .masthead {
    padding-top: 12px !important;
    padding-bottom: 12px !important;
    margin-top: 0 !important;
  }
}
@media (max-width: 640px) {
  .page-container {
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }
}
/* ─────────────────────────────────────────────────────────── */

/* ── 사이드바 메뉴 2줄 구조 ──────────────────────────── */
.sidebar-link {
  /* 아이콘과 텍스트 wrapper가 한 행에 정렬 */
  align-items: center;
  flex-wrap: nowrap;
}
.sidebar-link svg { flex-shrink: 0; }
.menu-text {
  /* main + sub 라벨이 같은 X 좌표에서 시작하는 column flex */
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.25;
}
.menu-main {
  font-size: var(--font-label-size);   /* 14px */
  font-weight: 500;
  line-height: 1.3;
  display: block;
  color: inherit;
}
.menu-main-only {
  /* 부제 없는 메뉴 - 메인을 살짝 위에 띄우지 않고 가운데 정렬 */
  line-height: 1.4;
}
.menu-sub {
  font-size: 11px;
  font-weight: 400;
  line-height: 1.3;
  display: block;
  color: rgba(255, 255, 255, 0.42);
  letter-spacing: 0.01em;
  margin-top: 1px;
  /* wrapper(.menu-text)가 같은 X에 정렬을 보장하므로 별도 padding 불필요 */
}
.sidebar-link.active .menu-sub,
.sidebar-link:hover .menu-sub {
  color: rgba(255, 255, 255, 0.7);
}
/* ──────────────────────────────────────────────────── */

/* ── 사이드바 SVG 아이콘 색상 (마스테라 키 컬러) ────── */
.sidebar-link svg {
  flex-shrink: 0;
  color: rgba(255, 255, 255, 0.55);   /* 평소 - 흐릿한 화이트 */
  transition: color 0.15s ease;
}
.sidebar-link:hover svg {
  color: rgba(255, 255, 255, 0.85);
}
.sidebar-brand .brand-icon {
  /* 좌측 상단 M 로고도 골드 톤 강화 */
  color: var(--brand-gold);
}
/* ────────────────────────────────────────────────── */

/* ── SPA View Transitions (메뉴 클릭 시 부드러운 전환) ───────── */
@view-transition { navigation: auto; }

/* 메인 콘텐츠는 페이드 in/out */
::view-transition-old(root),
::view-transition-new(root) {
  animation-duration: 0.18s;
  animation-timing-function: ease-out;
}

/* 사이드바 active 마커가 부드럽게 슬라이드되도록
   active 메뉴의 배경에 transition-name 부여 */
.sidebar-link.active {
  /* view-transition / transition 제거 - 즉시 active 표시로 변경 */
}

/* SPA 로딩 중 메인 영역에 살짝 비활성 표시 */
body.is-spa-loading .main-content {
  pointer-events: none;
  opacity: 0.85;
  transition: opacity 0.12s ease;
}
/* ────────────────────────────────────────────────────────── */

/* ── Masthead (페이지 상단 메뉴명 헤더) ───────────────────── */
.masthead {
    display: grid;
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto auto;
    column-gap: var(--space-3);
    row-gap: var(--space-1);
    padding: var(--space-3) 0 var(--space-2);
    border-bottom: 1px solid var(--border-subtle);
    margin: 0;
}
.masthead-titles {
    grid-column: 1 / -1;
    grid-row: 1;
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: var(--space-1) var(--space-2);
    margin: 0;
}
.masthead-title {
    margin: 0;
    font-size: var(--font-display-size);
    font-weight: var(--font-display-weight);
    color: var(--text-primary);
    letter-spacing: -0.01em;
    line-height: 1.2;
}
.masthead-sub {
    font-size: var(--font-label-size);
    color: var(--text-secondary);
    font-weight: 500;
    letter-spacing: 0.02em;
}
.masthead-context {
    margin-left: auto;
    font-size: var(--font-label-size);
    color: var(--text-secondary);
}
.masthead .wf-breadcrumb {
    grid-column: 1 / -1;
    grid-row: 2;
    margin: var(--space-1) 0 0;
}

/* ── 페이지 하단 도움말 영역 ────────────────────────────── */
.page-help {
    margin: var(--space-6) 0 var(--space-3);
    padding: var(--space-3) 0 0;
    border-top: 1px solid var(--border-subtle);
}
.page-help-title {
    margin: 0 0 var(--space-2);
    font-size: var(--font-heading-size);
    font-weight: var(--font-heading-weight);
    color: var(--text-secondary);
    letter-spacing: 0.04em;
    text-transform: uppercase;
}

/* 빈 page-header(예전 잔재)는 시각적으로 사라지게 */
.page-header:empty { display: none; }

/* ────────────────────────────────────────────────────── */

/* ── 사이드바 메뉴 옆 작업 순서 번호 ─────────────────── */
.sidebar-link {
    /* step 배지가 오른쪽 끝으로 가도록 */
    justify-content: flex-start;
}
.menu-step {
    margin-left: auto;
    flex-shrink: 0;
    min-width: 22px;
    height: 22px;
    padding: 0 6px;
    border-radius: 11px;
    background: rgba(255, 255, 255, 0.06);
    color: rgba(255, 255, 255, 0.55);
    font-size: 11px;
    font-weight: 600;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    letter-spacing: 0;
    transition: background 0.15s ease, color 0.15s ease;
}
.sidebar-link:hover .menu-step {
    background: rgba(255, 255, 255, 0.12);
    color: rgba(255, 255, 255, 0.9);
}
.sidebar-link.active .menu-step {
    background: var(--primary);
    color: var(--primary);
}
/* ────────────────────────────────────────────────────── */

/* ── 페이지 레이아웃 통일 (v2) ─── */
/* 페이지 컨테이너 자식 간 일관 간격 - 기존 룰을 명시적으로 보강 */
.page-container > * + * {
    margin-top: var(--space-4);
}

/* 마스트헤드 직후 첫 콘텐츠는 살짝 짧은 간격 (워크플로/카드 모두) */
.page-container > .masthead + * {
    margin-top: var(--space-3);
}

/* 페이지 액션 바 (예전 page-header 자리에서 H1 빠지고 버튼만 남은 그룹) */
.page-actions {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    flex-wrap: wrap;
    margin: 0;
    padding: 0;
    border: 0;
}

/* page-header (혹시 남은 것)는 더 이상 시각적 padding/border 부여 안 함 */
.page-header {
    margin: 0;
    padding: 0;
    border: 0;
}
.page-header:empty,
.page-actions:empty {
    display: none;
}

/* 페이지의 모든 첫 자식은 margin-top 0 (이중 spacing 방지) */
.page-container > *:first-child {
    margin-top: 0;
}
/* ────────────────────────────────────────────────── */

/* ── 메뉴 표시 설정 페이지 ─── */
.menu-vis-panel {
    padding: 0;
}
.menu-vis-section {
    padding: var(--space-2) var(--space-3);
    font-size: var(--font-caption-size);
    font-weight: var(--font-caption-weight);
    color: var(--text-tertiary);
    letter-spacing: var(--font-caption-tracking);
    text-transform: uppercase;
    background: var(--surface-secondary);
    border-bottom: 1px solid var(--border-subtle);
}
.menu-vis-row {
    display: flex;
    align-items: center;
    gap: var(--space-2);
    padding: var(--space-2) var(--space-3);
    border-bottom: 1px solid var(--border-soft);
    cursor: pointer;
    transition: background var(--t-fast);
}
.menu-vis-row:hover { background: var(--surface-secondary); }
.menu-vis-row.is-locked { cursor: default; }
.menu-vis-row.is-locked:hover { background: transparent; }

.menu-vis-icon {
    flex: 0 0 32px;
    width: 32px;
    height: 32px;
    display: flex;
    align-items: center;
    justify-content: center;
    background: var(--surface-tertiary);
    border-radius: var(--radius-sm);
    color: var(--text-secondary);
}
.menu-vis-icon svg { width: 16px; height: 16px; }

.menu-vis-info {
    flex: 1;
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2px;
}
.menu-vis-main {
    font-size: var(--font-label-size);
    font-weight: 500;
    color: var(--text-primary);
}
.menu-vis-sub {
    font-size: var(--font-caption-size);
    color: var(--text-secondary);
}
.menu-vis-href {
    font-family: 'SF Mono', Menlo, Consolas, monospace;
    font-size: 11px;
    color: var(--text-tertiary);
    margin-top: 2px;
    word-break: break-all;
}

.menu-vis-locked {
    flex: 0 0 auto;
    padding: 2px 8px;
    background: var(--surface-tertiary);
    color: var(--text-tertiary);
    font-size: 11px;
    border-radius: 999px;
}

/* iOS 스타일 토글 */
.toggle-switch {
    flex: 0 0 44px;
    position: relative;
    display: inline-block;
    width: 44px;
    height: 24px;
}
.toggle-switch input {
    position: absolute;
    opacity: 0;
    width: 100%;
    height: 100%;
    margin: 0;
    cursor: pointer;
    z-index: 2;
}
.toggle-switch input:disabled { cursor: not-allowed; }
.toggle-switch .toggle-slider {
    position: absolute;
    inset: 0;
    background: var(--gray-300);
    border-radius: 24px;
    transition: background var(--t-fast);
    pointer-events: none;
}
.toggle-switch .toggle-slider::before {
    content: "";
    position: absolute;
    height: 18px;
    width: 18px;
    left: 3px;
    top: 3px;
    background: #fff;
    border-radius: 50%;
    box-shadow: 0 1px 2px rgba(0,0,0,.2);
    transition: transform var(--t-fast);
}
.toggle-switch input:checked + .toggle-slider { background: var(--brand-gold); }
.toggle-switch input:checked + .toggle-slider::before { transform: translateX(20px); }
.toggle-switch input:disabled + .toggle-slider { opacity: .55; }

.menu-vis-actions {
    display: flex;
    gap: var(--space-1);
    padding: var(--space-3);
    border-top: 1px solid var(--border-subtle);
    background: var(--surface-secondary);
}
/* ────────────────────────────────────────────────── */

/* ── 사입/촬영 사진첩 ─── */
.filter-bar {
    margin-bottom: var(--space-3);
}
.filter-form {
    display: flex;
    gap: var(--space-1);
    flex-wrap: wrap;
}
.filter-form select {
    min-width: 160px;
}

.sourcing-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    gap: var(--space-3);
}
.sourcing-card {
    background: var(--surface-primary);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius);
    overflow: hidden;
    transition: transform var(--t-fast), box-shadow var(--t-fast);
    display: flex;
    flex-direction: column;
}
.sourcing-card:hover {
    transform: translateY(-2px);
    box-shadow: var(--shadow-md);
}
.sourcing-card.status-abandoned {
    opacity: 0.5;
}
.sourcing-card.status-registered {
    border-color: var(--brand-gold-soft);
}

.sourcing-thumb {
    position: relative;
    display: block;
    aspect-ratio: 1 / 1;
    background: var(--surface-secondary);
    overflow: hidden;
}
.sourcing-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}
.sourcing-thumb-empty {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--text-tertiary);
    font-size: var(--font-caption-size);
}
.sourcing-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    padding: 2px 8px;
    font-size: 11px;
    font-weight: 600;
    border-radius: 999px;
    backdrop-filter: blur(4px);
}
.sourcing-badge-registered {
    background: rgba(186, 144, 80, 0.92);
    color: #fff;
}
.sourcing-badge-abandoned {
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
}
.sourcing-count {
    position: absolute;
    bottom: 8px;
    right: 8px;
    padding: 2px 8px;
    font-size: 11px;
    background: rgba(0, 0, 0, 0.55);
    color: #fff;
    border-radius: 999px;
}

.sourcing-meta {
    padding: var(--space-1) var(--space-2);
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.sourcing-meta-row {
    display: flex;
    align-items: center;
    gap: var(--space-1);
    flex-wrap: wrap;
}
.sourcing-vendor {
    font-size: var(--font-label-size);
    font-weight: 600;
    color: var(--text-primary);
    margin-right: auto;
}
.sourcing-date {
    font-size: var(--font-caption-size);
    color: var(--text-tertiary);
}
.sourcing-name {
    font-size: var(--font-body-size);
    color: var(--text-primary);
    line-height: 1.35;
}
.sourcing-price {
    font-size: var(--font-caption-size);
    font-weight: 600;
    color: var(--brand-navy);
}
.sourcing-tag {
    display: inline-block;
    padding: 1px 6px;
    background: var(--surface-tertiary);
    color: var(--text-secondary);
    font-size: 11px;
    border-radius: var(--radius-sm);
}
.sourcing-memo {
    font-size: var(--font-caption-size);
    color: var(--text-secondary);
    line-height: 1.4;
}

.sourcing-actions {
    display: flex;
    gap: 4px;
    padding: var(--space-1) var(--space-2);
    border-top: 1px solid var(--border-subtle);
    background: var(--surface-secondary);
}
.sourcing-actions .btn {
    padding: 4px 10px;
    font-size: var(--font-caption-size);
}

/* 사입 등록/편집 폼 */
.sourcing-form .form-section {
    margin-bottom: var(--space-3);
}
.sourcing-form .form-section:last-child {
    margin-bottom: 0;
}
.sourcing-form .form-grid {
    display: grid;
    gap: var(--space-2);
    margin-bottom: var(--space-3);
}
.sourcing-form .form-grid-2 {
    grid-template-columns: 1fr 1fr;
}
.sourcing-form .form-grid-3 {
    grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 720px) {
    .sourcing-form .form-grid-2,
    .sourcing-form .form-grid-3 { grid-template-columns: 1fr; }
}
.sourcing-form .form-actions {
    display: flex;
    gap: var(--space-1);
    padding-top: var(--space-2);
    border-top: 1px solid var(--border-subtle);
    margin-top: var(--space-2);
}
.sourcing-form .form-hint {
    margin: 4px 0 0;
    font-size: var(--font-caption-size);
    color: var(--text-tertiary);
}
.form-label-required::after {
    content: ' *';
    color: var(--danger, #d33);
    font-weight: 700;
}

/* 사입 편집의 다중 이미지 미리보기 */
.sourcing-edit-images {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
    gap: var(--space-1);
}
.sourcing-edit-images img {
    width: 100%;
    aspect-ratio: 1 / 1;
    object-fit: cover;
    border-radius: var(--radius-sm);
    border: 1px solid var(--border-subtle);
}

/* alert-info */
.alert-info {
    background: #e6f1f9;
    border: 1px solid #b6d6ec;
    color: #1d4f74;
    padding: var(--space-2);
    border-radius: var(--radius);
    margin-bottom: var(--space-3);
}
.alert-info strong { color: #0d3a5c; }
.alert-info details { margin-top: 6px; }
.alert-info summary { cursor: pointer; font-size: var(--font-caption-size); }
/* ────────────────────────────────────────────────── */

/* ── 판매 중 카드 보강 ─── */
.sourcing-card.status-live {
    border-color: var(--brand-gold-soft);
}
.sourcing-badge-live {
    background: rgba(46, 125, 50, 0.92);
    color: #fff;
}
.filter-count {
    margin-left: auto;
    font-size: var(--font-caption-size);
    color: var(--text-tertiary);
    align-self: center;
}
/* ────────────────────────────────────────── */

/* ── page-actions in masthead ─── */
/* JS가 masthead 안으로 이동시킨 page-actions (워크플로 우측 하단) */
.masthead .page-actions.in-masthead {
    grid-column: 2;
    grid-row: 3;
    justify-self: end;
    align-self: center;
    margin: 0;
    padding: 0;
    border: 0;
    flex-wrap: nowrap;
}
/* 워크플로가 없는 페이지에서는 row 3 위치라도 자연스럽게 우측에 정렬 */
.masthead:not(:has(.wf-breadcrumb)) .page-actions.in-masthead {
    grid-row: 1;
    justify-self: end;
    align-self: center;
}
@media (max-width: 720px) {
    .masthead .page-actions.in-masthead {
        grid-column: 1 / -1;
        justify-self: stretch;
        margin-top: var(--space-1);
    }
    .masthead .page-actions.in-masthead .btn {
        flex: 1;
    }
}
/* 마스트헤드 다음 콘텐츠와의 여백을 일관 (var(--space-3) 24px) */
.page-container > .masthead + * {
    margin-top: var(--space-3) !important;
}
/* ────────────────────────────────────── */


/* ── [v21] 활성 사이드바 아이콘은 반드시 navy (골드 배경 위 가독성 보장) ── */
.sidebar .sidebar-link.active svg {
  color: var(--brand-navy) !important;
  stroke: var(--brand-navy) !important;
  opacity: 1 !important;
}
.sidebar .sidebar-link svg {
  fill: none;
}


/* ──────────────────────────────────────────────────────── */
/* [mobile-v22] 모바일 우선 (≤ 760px) - 사이드바 슬라이드, 헤더, 폼 */
/* ──────────────────────────────────────────────────────── */

/* 모바일 상단 헤더 (햄버거 + 타이틀) - 데스크탑에서는 숨김 */
.mobile-topbar {
  display: none;
}
.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.4);
  z-index: 30;
}

@media (max-width: 760px) {
  /* 1) 모바일 상단 바 */
  .mobile-topbar {
    display: flex;
    align-items: center;
    gap: 12px;
    position: sticky;
    top: 0;
    z-index: 40;
    height: 52px;
    padding: 0 12px;
    background: var(--brand-navy);
    color: #fff;
    border-bottom: 1px solid rgba(255,255,255,0.06);
  }
  .mobile-topbar .hamburger {
    width: 40px; height: 40px;
    display: inline-flex; align-items: center; justify-content: center;
    background: transparent; border: none; cursor: pointer;
    color: rgba(255,255,255,0.85);
    -webkit-tap-highlight-color: rgba(255,255,255,0.1);
    border-radius: 6px;
  }
  .mobile-topbar .hamburger:active { background: rgba(255,255,255,0.08); }
  .mobile-topbar .brand {
    font-weight: 600;
    font-size: 14px;
    letter-spacing: 0.02em;
  }
  .mobile-topbar .brand small {
    display: block;
    font-size: 11px;
    color: rgba(255,255,255,0.55);
    font-weight: 400;
    letter-spacing: 0;
  }

  /* 2) 사이드바: 기본 숨김, .is-open 시 슬라이드 */
  .sidebar {
    transform: translateX(-100%);
    transition: transform 0.22s ease;
    z-index: 50;
    box-shadow: 0 0 30px rgba(0,0,0,0.35);
    width: min(86vw, 320px);
  }
  .sidebar.is-open {
    transform: translateX(0);
  }
  .sidebar-backdrop.is-open {
    display: block;
    z-index: 45;
  }

  /* 3) 메인 콘텐츠: 사이드바 폭 보정 제거 */
  .layout {
    display: block;
  }
  .main-content {
    margin-left: 0 !important;
    padding: 14px;
    min-height: calc(100vh - 52px);
  }

  /* 4) 마스트헤드 / 페이지 액션 모바일 정렬 */
  .masthead {
    grid-template-columns: 1fr !important;
    grid-template-rows: auto auto auto !important;
    gap: 8px;
  }
  .masthead .page-titles h1 {
    font-size: 22px;
    line-height: 1.25;
  }
  .masthead .page-titles .page-sub {
    font-size: 13px;
  }
  .masthead .page-actions.in-masthead,
  .page-actions {
    justify-content: flex-start;
    flex-wrap: wrap;
    gap: 6px;
  }
  .masthead .page-actions.in-masthead .btn,
  .page-actions .btn {
    flex: 1 1 auto;
    min-height: 40px;
  }
  .workflow-breadcrumb {
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    padding-bottom: 4px;
  }

  /* 5) 폼 입력 - iOS 자동 줌 방지 (≥16px) + 충분한 터치 영역 */
  input[type="text"], input[type="email"], input[type="tel"],
  input[type="password"], input[type="number"], input[type="search"],
  input[type="url"], input[type="date"], input[type="datetime-local"],
  input[type="time"], textarea, select {
    font-size: 16px !important;
    min-height: 44px;
    padding: 10px 12px;
  }
  textarea {
    min-height: 88px;
  }
  .btn, button.btn, a.btn {
    min-height: 44px;
    padding: 10px 14px;
    font-size: 14px;
  }

  /* 6) 카드/그리드 모바일 1열 */
  .form-row,
  .vton-grid,
  .vton-meta-grid,
  .engine-grid,
  .sourcing-form-grid,
  .kv-table {
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }

  /* 7) 데이터 테이블 - 가로 스크롤 */
  .data-table {
    display: block;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    white-space: nowrap;
  }

  /* 8) 사진첩 그리드: 작은 카드 */
  .sourcing-grid {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 10px;
  }

  /* 9) 비교 그리드 */
  .vton-compare-grid {
    grid-template-columns: 1fr !important;
  }

  /* 10) help-box */
  .help-box {
    padding: 10px 12px;
  }

  /* 11) modal/dialog overflow 방지 */
  body.sidebar-open {
    overflow: hidden;
  }
}

/* 더 작은 폰 (≤ 380px) */
@media (max-width: 380px) {
  .main-content { padding: 10px; }
  .masthead .page-titles h1 { font-size: 20px; }
  .sourcing-grid { grid-template-columns: 1fr !important; }
}


/* [list-count v1] 페이지 액션 안의 카운트 라벨 (마스트헤드 타이틀과 충돌 방지) */
.page-actions .list-count {
  font-size: 13px;
  color: var(--text-muted);
  align-self: center;
  margin-right: auto;
  letter-spacing: 0.01em;
}
.page-actions .list-count strong {
  font-weight: 600;
  color: var(--text-primary);
  font-variant-numeric: tabular-nums;
  margin: 0 2px;
}

/* ===== [api-mgmt v1] API 관리 페이지 ===== */
.api-summary { padding: 16px; }
.api-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
}
.api-summary-grid > div {
  display: flex; flex-direction: column; gap: 4px;
  padding: 12px 14px;
  border: 1px solid var(--border, #e5e7eb);
  border-radius: 8px;
  background: rgba(0,0,0,0.015);
}
.api-summary-label {
  font-size: 12px; color: var(--text-muted, #6b7280);
  letter-spacing: 0.02em;
}
.api-summary-grid strong {
  font-size: 18px;
  font-weight: 600;
  color: var(--text-primary, #18181b);
  font-variant-numeric: tabular-nums;
}

.api-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 14px;
}
.api-card {
  display: flex; flex-direction: column;
  padding: 16px;
  border-left: 3px solid var(--border, #e5e7eb);
  transition: border-color 0.15s ease;
}
.api-card.is-on { border-left-color: var(--primary); }
.api-card.is-off { border-left-color: var(--border, #e5e7eb); }
.api-card-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 10px; margin-bottom: 4px;
}
.api-card-title {
  font-size: 15px; font-weight: 600; margin: 0;
  color: var(--text-primary);
}
.api-card-short {
  margin: 0 0 12px; font-size: 12.5px; color: var(--text-muted);
  line-height: 1.5;
}
.api-card-meta {
  display: grid; grid-template-columns: 76px 1fr; gap: 4px 10px;
  font-size: 12.5px; margin: 0 0 12px;
}
.api-card-meta dt { color: var(--text-muted); padding: 2px 0; }
.api-card-meta dd { margin: 0; padding: 2px 0; word-break: break-all; }
.api-card-meta code {
  font-size: 12px; background: rgba(0,0,0,0.04);
  padding: 1px 5px; border-radius: 3px;
}
.api-mask {
  font-family: 'JetBrains Mono', 'Fira Code', monospace;
  font-size: 12px; padding: 1px 6px;
  background: rgba(26, 26, 26, 0.04);
  border: 1px solid rgba(26, 26, 26, 0.12);
  border-radius: 3px; margin-left: 4px;
  letter-spacing: 0.05em;
}
.api-model {
  display: inline-block; margin: 1px 4px 1px 0;
  font-size: 11.5px;
}
.api-usedin {
  margin: 0; padding-left: 16px; line-height: 1.6;
}
.api-usedin a { color: var(--text-primary); text-decoration: none; border-bottom: 1px dotted var(--text-muted); }
.api-usedin a:hover { color: var(--brand-gold); border-bottom-color: var(--brand-gold); }
.api-card-actions {
  display: flex; gap: 6px; flex-wrap: wrap;
  margin-top: auto; padding-top: 10px;
  border-top: 1px dashed var(--border, #e5e7eb);
}
.api-card-actions .btn { padding: 6px 12px; font-size: 12px; min-height: 30px; }

.flash { padding: 10px 14px; margin-bottom: 12px; }
.flash-success { border-left: 3px solid #10b981; background: rgba(16,185,129,0.06); }
.flash-warn    { border-left: 3px solid #f59e0b; background: rgba(245,158,11,0.06); }
.flash-error   { border-left: 3px solid #dc2626; background: rgba(220,38,38,0.06); }

.filter-row {
  display: flex; gap: 12px; align-items: end; flex-wrap: wrap;
}
.filter-row label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 12px; color: var(--text-muted);
}
.filter-row select {
  min-width: 140px;
  padding: 8px 10px;
  border: 1px solid var(--border, #d4d4d8);
  border-radius: 6px;
  font-size: 13px;
  background: #fff;
}

.bar {
  height: 8px; min-width: 2px;
  background: linear-gradient(90deg, var(--primary), rgba(26, 26, 26, 0.12));
  border-radius: 2px;
}

.text-error { color: #dc2626; font-weight: 600; }

@media (max-width: 760px) {
  .api-summary-grid { grid-template-columns: repeat(2, 1fr); }
  .api-grid { grid-template-columns: 1fr; }
}

/* ===== [form-unify v1] 폼 input 디자인 통합 (label 위, input 아래) =====
 * 기준: 두번째 스크린샷(사입/촬영)의 vertical stack 스타일.
 * - .form-row 자체를 vertical stack 기본으로 변경 (이전 2열 grid 무력화)
 * - 한 행에 2/3개를 두려면 .form-grid-2 / .form-grid-3 사용
 * - 라벨/인풋 폰트 사이즈 12px / 14px 통일, 패딩 11px 12px
 * ============================================================= */

/* form-row: vertical stack 기본 */
.form-row,
.form-row-3 {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
  padding: 0;
}

/* 한 행에 여러 input 배치 */
.form-grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.form-grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.form-grid-2 > .form-row,
.form-grid-3 > .form-row { margin-bottom: 0; }

/* 라벨 - 12px, 약간 진한 회색 */
.form-row > label,
.form-row .form-label,
.form-grid-2 > .form-row > label,
.form-grid-3 > .form-row > label {
  display: block;
  font-size: 12px;
  font-weight: 500;
  color: var(--text-muted, #6b7280);
  letter-spacing: 0.01em;
  margin-bottom: 0;
  line-height: 1.4;
}

/* 라벨 안에 input이 있는 경우 (filter-row 같은 경우): 자식만 vertical */
.form-row > label > input,
.form-row > label > select,
.form-row > label > textarea {
  margin-top: 4px;
}

/* 필수 표시 */
.form-row .required,
.form-row .form-label .required {
  color: #dc2626;
  margin-left: 2px;
  font-weight: 600;
}

/* input/select/textarea 통일 */
.form-row input[type="text"],
.form-row input[type="email"],
.form-row input[type="password"],
.form-row input[type="number"],
.form-row input[type="search"],
.form-row input[type="url"],
.form-row input[type="date"],
.form-row input[type="tel"],
.form-row input[type="time"],
.form-row input[type="datetime-local"],
.form-row select,
.form-row textarea,
.form-row .form-input,
.form-grid-2 .form-row input,
.form-grid-2 .form-row select,
.form-grid-2 .form-row textarea,
.form-grid-3 .form-row input,
.form-grid-3 .form-row select,
.form-grid-3 .form-row textarea {
  display: block;
  width: 100%;
  padding: 10px 12px;
  font-size: 14px;
  line-height: 1.4;
  color: var(--text-primary, #18181b);
  background: #fff;
  border: 1px solid var(--border, #d4d4d8);
  border-radius: 6px;
  transition: border-color 0.15s ease, box-shadow 0.15s ease;
  box-sizing: border-box;
  font-family: inherit;
}
.form-row textarea {
  min-height: 80px;
  resize: vertical;
  line-height: 1.55;
}
.form-row input:focus,
.form-row select:focus,
.form-row textarea:focus,
.form-grid-2 .form-row input:focus,
.form-grid-2 .form-row select:focus,
.form-grid-2 .form-row textarea:focus {
  outline: none;
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(200, 168, 106, 0.12);
}
.form-row input::placeholder,
.form-row textarea::placeholder,
.form-grid-2 .form-row input::placeholder,
.form-grid-2 .form-row textarea::placeholder {
  color: #9ca3af;
  font-size: 13.5px;
}

/* form-section: 섹션 제목 + 그 안의 row들 */
.form-section { margin-bottom: 24px; }
.form-section-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #18181b);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border, #e5e7eb);
  letter-spacing: 0.01em;
}

/* form-actions: 등록/취소 버튼 정렬 */
.form-actions {
  display: flex;
  gap: 10px;
  align-items: center;
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px dashed var(--border, #e5e7eb);
}
.form-actions .btn { min-width: 96px; }

/* hint - input 아래 안내 텍스트 */
.form-row .form-hint {
  font-size: 11.5px;
  color: var(--text-muted, #6b7280);
  margin-top: 2px;
  line-height: 1.4;
}

@media (max-width: 760px) {
  .form-grid-2,
  .form-grid-3 { grid-template-columns: 1fr; gap: 0; }
  .form-grid-2 > .form-row,
  .form-grid-3 > .form-row { margin-bottom: 16px; }
}

/* ===== [wf-context-align v1] 워크플로우 안내문 오른쪽 정렬 ===== */
.wf-breadcrumb .wf-context {
  text-align: right !important;
  margin-top: 8px !important;
  padding-right: 2px !important;
}
.wf-breadcrumb .wf-context strong {
  font-weight: 600;
}

/* ===== [mobile-typography v1] 모바일 상단 여백 절반 + 폰트 3단계 (14/16/18) =====
 * 기준: '.form-section-title' = 14px ('도매처 등록' 의 사이즈)
 *  - 18px : 페이지 제목 (masthead h1)
 *  - 16px : input (iOS 자동 줌 방지) + 옵션 강조
 *  - 14px : 섹션 제목, 본문, 라벨, 버튼, 메타 (기본)
 */
@media (max-width: 760px) {
  /* (a) 페이지 상단 여백 절반으로 압축 */
  .main-content {
    padding-top: 6px !important;
  }
  .masthead {
    padding-top: 6px !important;
    padding-bottom: 8px !important;
    row-gap: 4px !important;
    gap: 4px !important;
  }
  .masthead-titles { gap: 2px; }
  .page-container > .masthead + * { margin-top: 8px !important; }
  .wf-breadcrumb { margin-top: 4px !important; margin-bottom: 8px !important; padding-bottom: 2px !important; }
  .page-header { padding: 0 !important; margin: 0 0 4px !important; }

  /* (b) 페이지 제목: 22 -> 18 (size-3) */
  .masthead .page-titles h1,
  .masthead-title,
  .page-title,
  .page-header h1,
  .topbar h1 {
    font-size: 18px !important;
    line-height: 1.3 !important;
    font-weight: 600 !important;
    letter-spacing: -0.01em;
  }
  /* 페이지 부제 / 마스트헤드 sub: 14 (기준) */
  .masthead .page-titles .page-sub,
  .masthead-sub,
  .page-subtitle,
  .masthead-context {
    font-size: 14px !important;
    line-height: 1.45 !important;
  }

  /* (c) 섹션/카드 제목: 14 (기준) - 도매처 등록과 동일 */
  .form-section-title,
  .card h2,
  .card h3,
  .form-card h2 {
    font-size: 14px !important;
    font-weight: 600 !important;
    letter-spacing: 0.005em;
  }

  /* (d) 본문 / 라벨 / 버튼 / 메타: 14 통일 */
  body, p, li, dl, dt, dd,
  .help-box, .help-box * ,
  .form-row label, .form-row .form-hint, .muted, .form-hint,
  .alert, .badge,
  .btn, button.btn, a.btn,
  .data-table, .data-table th, .data-table td,
  .wf-step, .wf-context,
  .pill, .tag {
    font-size: 14px;
    line-height: 1.5;
  }
  .badge, .pill, .tag { line-height: 1.3; }

  /* (e) 작은 보조 텍스트는 14 유지 (별도 size-4 두지 않음 - 변동 최소화)
   *     단, 매우 빽빽한 곳(아이콘 옆 메타)만 13으로 한 번 더 톤다운 */
  .list-count,
  .breadcrumb-meta,
  small {
    font-size: 13px;
    line-height: 1.45;
  }

  /* (f) input/select/textarea: 16 유지 (iOS 자동 줌 방지) - 기존 룰 그대로 */

  /* (g) 380px 이하 페이지 제목 더 작게 막기 - 18 고정 */
}
@media (max-width: 380px) {
  .masthead .page-titles h1,
  .masthead-title,
  .page-title { font-size: 18px !important; }
}
/* ===== /mobile-typography v1 ===== */

/* ===== [sidebar-sub-hide v1] sub 라벨 전역 숨김 - 메뉴 단순화 =====
 * 향후 다시 보이려면 이 블록 1개만 제거하면 됨 */
.sidebar .menu-sub {
  display: none !important;
}
.sidebar .menu-main,
.sidebar .menu-main-only {
  font-size: 13.5px;
  line-height: 1.35;
  font-weight: 500;
}

/* ===== [dropzone-style v2] dropzone 기본 박스 스타일 (점선 테두리 + 중앙 정렬) ===== */
.dropzone {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 18px 16px 20px !important;
  min-height: 140px;
  border: 1.5px dashed var(--border, #d4d4d8);
  border-radius: 10px;
  background: rgba(0, 0, 0, 0.012);
  text-align: center;
  cursor: pointer;
  transition: border-color 0.18s ease, background-color 0.18s ease;
  outline: none;
}
.dropzone:hover,
.dropzone:focus-visible {
  border-color: var(--primary);
  background: rgba(200, 168, 106, 0.04);
}
.dropzone.is-dragover {
  border-color: var(--primary);
  background: rgba(200, 168, 106, 0.08);
  border-style: solid;
}
.dropzone-icon {
  color: var(--text-muted, #71717a);
  margin-bottom: 4px;
}
.dropzone-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--text-primary, #18181b);
  line-height: 1.4;
}
.dropzone-sub {
  font-size: 12.5px;
  color: var(--text-muted, #71717a);
  line-height: 1.4;
  margin-bottom: 8px;
}
.dropzone-buttons {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 4px;
  width: auto;
  max-width: 100%;
}
.dropzone .photo-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  min-height: 38px;
  font-size: 13px;
  font-weight: 500;
  border-radius: 8px;
  cursor: pointer;
  user-select: none;
  -webkit-user-select: none;
}
.dropzone .photo-btn svg {
  width: 16px;
  height: 16px;
  flex-shrink: 0;
}
/* 라벨 안의 file input 절대 보이지 않도록 (글로벌 input 룰 무력화) */
.dropzone input[type="file"],
.photo-btn input[type="file"],
input[type="file"][hidden] {
  position: absolute !important;
  left: -9999px !important;
  top: -9999px !important;
  width: 1px !important;
  height: 1px !important;
  padding: 0 !important;
  margin: 0 !important;
  border: 0 !important;
  opacity: 0 !important;
  overflow: hidden !important;
  clip: rect(0 0 0 0) !important;
  pointer-events: none !important;
  display: block !important;
  visibility: visible !important;
}
/* 사진 미리보기 영역 빈 상태 */
.photo-preview { margin-top: 12px; }
.photo-empty {
  margin: 0;
  padding: 14px 12px;
  text-align: center;
  font-size: 12.5px;
  color: var(--text-muted, #71717a);
  border: 1px dashed var(--border-subtle, #e5e7eb);
  border-radius: 8px;
  background: rgba(0, 0, 0, 0.012);
}

/* ── 모바일 (≤760px) ── */
@media (max-width: 760px) {
  .dropzone {
    padding: 14px 12px 16px !important;
    min-height: 120px;
  }
  .dropzone-icon { margin-bottom: 2px; }
  .dropzone-title { font-size: 14px; }
  .dropzone-sub { font-size: 12.5px; margin-bottom: 6px; }
  .dropzone .photo-btn {
    flex: 1 1 calc(50% - 6px);
    justify-content: center;
    min-height: 40px;
  }
}
/* ===== /dropzone-style v2 ===== */

/* ===== [step-pill v1] STEP 번호 pill 디자인 - 사이드바 + 워크플로우 ===== */

/* 사이드바 menu-step */
.sidebar-link .menu-step {
  min-width: auto !important;
  width: auto !important;
  padding: 1px 8px !important;
  height: 20px !important;
  font-size: 10px !important;
  font-weight: 700 !important;
  letter-spacing: 0.04em !important;
  border-radius: 10px !important;
  display: inline-flex;
  align-items: center;
  gap: 3px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

/* 워크플로우 브레드크럼 wf-num: 원 -> pill */
.wf-step .wf-num {
  width: auto !important;
  min-width: 56px;
  height: 22px;
  padding: 0 9px !important;
  border-radius: 11px !important;
  font-size: 10.5px !important;
  letter-spacing: 0.04em;
  gap: 4px;
  white-space: nowrap;
}
.wf-num-prefix {
  font-size: 9.5px;
  font-weight: 700;
  letter-spacing: 0.05em;
  opacity: 0.85;
}

/* 모바일에서는 prefix 숨겨서 공간 절약 */
@media (max-width: 760px) {
  .wf-num-prefix { display: none; }
  .wf-step .wf-num {
    min-width: 22px;
    width: 22px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    justify-content: center;
  }
  .sidebar-link .menu-step {
    padding: 1px 6px !important;
    font-size: 10px !important;
  }
}
/* ===== /step-pill v1 ===== */

/* ===== [status-i18n v1] 상품/잡 status 영문 -> 한국어 표기 ===== */
/* CSS만으로 영문 status 텍스트를 한국어로 가시화
 * (HTML 변경 없이 어느 페이지에서든 일관 표시) */

/* 1) badge.badge-<status> - 안의 텍스트 자체를 한국어로 치환 */
.badge.badge-draft,
.badge.badge-generating,
.badge.badge-qc_pending,
.badge.badge-qc_passed,
.badge.badge-approved,
.badge.badge-uploaded,
.badge.badge-rejected,
.badge.badge-failed,
.badge.badge-queued,
.badge.badge-processing,
.badge.badge-passed {
  font-size: 0 !important;
}
.badge.badge-draft::before        { content: "초안";          }
.badge.badge-generating::before   { content: "AI 생성 중";     }
.badge.badge-qc_pending::before   { content: "검수 대기";      }
.badge.badge-qc_passed::before    { content: "검수 통과";      }
.badge.badge-approved::before     { content: "최종 승인";      }
.badge.badge-uploaded::before     { content: "업로드 완료";    }
.badge.badge-rejected::before     { content: "반려";           }
.badge.badge-failed::before       { content: "실패";           }
.badge.badge-queued::before       { content: "대기 중";        }
.badge.badge-processing::before   { content: "처리 중";        }
.badge.badge-passed::before       { content: "통과";           }
.badge[class*="badge-"][class*="badge-"]::before {
  font-size: 11.5px !important;
  font-weight: 600;
  letter-spacing: 0.01em;
}

/* 2) 색상 매핑 (없는 것만) */
.badge-generating { background: rgba(245,158,11,0.10); color: #b45309; border: 1px solid rgba(245,158,11,0.25); }
.badge-qc_pending { background: var(--color-info-soft); color: var(--color-info-deep); border: 1px solid var(--color-info); }
.badge-qc_passed,
.badge-passed     { background: rgba(16,185,129,0.10); color: #047857; border: 1px solid rgba(16,185,129,0.25); }
.badge-approved   { background: rgba(34,197,94,0.12);  color: #15803d; border: 1px solid rgba(34,197,94,0.30); }
.badge-uploaded   { background: rgba(8,145,178,0.10);  color: #0e7490; border: 1px solid rgba(8,145,178,0.25); }
.badge-rejected,
.badge-failed     { background: rgba(220,38,38,0.10);  color: #b91c1c; border: 1px solid rgba(220,38,38,0.25); }
.badge-queued     { background: rgba(113,113,122,0.10);color: #52525b; border: 1px solid rgba(113,113,122,0.25); }
.badge-processing { background: rgba(245,158,11,0.10); color: #b45309; border: 1px solid rgba(245,158,11,0.25); }
.badge-draft      { background: rgba(0,0,0,0.04);      color: #52525b; border: 1px solid rgba(0,0,0,0.10); }
/* ===== /status-i18n v1 ===== */

/* ===== [generators-form v1] AI 사진 생성 - 가상모델 / 내 사진 공용 폼 ===== */
/* dispatch.php (가상모델+배경) 와 userphoto.php (내 사진 사용) 가 동일한
 * 카드/제목/그리드/입력/이미지 사이즈를 공유하도록 표준화. 인라인 스타일 제거 시 적용. */

/* 1) 모드 탭 (탭 영역 정렬/색) */
.gf-tabs {
  display: flex;
  gap: 8px;
  margin: 12px 0 var(--space-3);
  border-bottom: 1px solid var(--border, var(--surface-tertiary));
}
.gf-tab {
  padding: 10px 16px;
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 500;
  text-decoration: none;
  border-bottom: 2px solid transparent;
  transition: color .15s, border-color .15s;
}
.gf-tab:hover { color: var(--text-secondary); }
.gf-tab.active {
  color: var(--text-primary);
  font-weight: 600;
  border-bottom-color: var(--primary);
}

/* 2) 2-컬럼 그리드 */
.gf-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  align-items: start;
}
@media (max-width: 1100px) { .gf-grid { grid-template-columns: 1fr; } }

/* 우측 폼 컬럼 - fieldset 간 일정 간격 */

.gf-selected-product-card {
  position: sticky;
  top: 88px;
  align-self: start;
  z-index: 2;
}
.gf-selected-product-card .gf-product-image {
  max-height: 360px;
}
@media (max-width: 1100px) {
  .gf-selected-product-card {
    position: static;
    top: auto;
  }
}

.gf-col-right {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}

/* 3) 카드 (인라인 background/padding 대체) */
.gf-card {
  background: var(--surface-primary);
  border-radius: var(--radius-lg);
  padding: var(--space-3);
  box-shadow: var(--shadow-sm);
  border: 0;
}
.gf-card + .gf-card { margin-top: 0; }

/* 4) 섹션 제목 (h2 / legend 양쪽 적용) */
.gf-section-title,
.gf-card > legend {
  font-size: var(--font-body-size, 16px);
  font-weight: 600;
  color: var(--text-primary);
  margin: 0 0 var(--space-2) 0;
  padding: 0 0 var(--space-1) 0;
  border-bottom: 1px solid var(--surface-tertiary);
  letter-spacing: -0.005em;
  display: block;
  width: 100%;
}
.gf-card > legend { padding-left: 0; padding-right: 0; }

/* 5) 제품 이미지 */
.gf-product-image {
  display: block;
  width: 100%;
  max-width: 100%;
  max-height: 240px;
  margin-top: var(--space-1);
  border-radius: var(--radius);
  object-fit: contain;
  background: #f7f7f7;
}

/* 6) Key-Value 표 */
.gf-kv {
  margin-top: var(--space-1);
  width: 100%;
  border-collapse: collapse;
  font-size: 13.5px;
}
.gf-kv th {
  width: 78px;
  padding: 4px 8px 4px 0;
  color: var(--text-muted);
  font-weight: 400;
  vertical-align: top;
  text-align: left;
}
.gf-kv td { padding: 4px 0; color: var(--text-primary); }

/* 7) 도움말 (hint) - 두 페이지 동일 */
.gf-hint {
  font-size: 12.5px;
  color: var(--text-muted);
  margin: 4px 0 var(--space-1);
  line-height: 1.5;
}

/* 8) 폼 행: 1-3 컬럼 자동 */
.gf-row {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-1);
  margin-top: var(--space-1);
}
.gf-row.gf-row-2 { grid-template-columns: 1fr 1fr; }
.gf-row.gf-row-1 { grid-template-columns: 1fr; }
@media (max-width: 600px) {
  .gf-row, .gf-row.gf-row-2 { grid-template-columns: 1fr 1fr; }
  .gf-row.gf-row-1 { grid-template-columns: 1fr; }
}

/* 9) 폼 라벨/입력/셀렉트 - 폰트 14 통일 */
.gf-row label,
.gf-field label {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 13px;
  color: var(--text-secondary);
  font-weight: 500;
}
.gf-row input,
.gf-row select,
.gf-row textarea,
.gf-field input,
.gf-field select,
.gf-field textarea,
.gf-card input[type="text"],
.gf-card input[type="number"],
.gf-card input[type="email"],
.gf-card input[type="file"],
.gf-card select,
.gf-card textarea {
  width: 100%;
  font-size: 14px;
  font-family: inherit;
  padding: 8px 10px;
  border: 1px solid var(--border, var(--surface-tertiary));
  border-radius: var(--radius, 6px);
  background: #fff;
  color: var(--text-primary);
  line-height: 1.4;
}
.gf-card textarea { min-height: 64px; resize: vertical; }
.gf-card input:focus,
.gf-card select:focus,
.gf-card textarea:focus {
  outline: none;
  border-color: var(--brand-gold);
  box-shadow: 0 0 0 2px rgba(26, 26, 26, 0.12);
}
/* file input 은 padding 다르게 */
.gf-card input[type="file"] { padding: 6px 8px; background: #fafafa; cursor: pointer; }

/* 10) 체크박스 카드 (페르소나/씬 선택지) */
.gf-check-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1.5px solid var(--border-subtle, var(--surface-tertiary));
  border-radius: var(--radius);
  margin-bottom: var(--space-1);
  cursor: pointer;
  transition: border-color .15s, background .15s;
}
.gf-check-card:hover { border-color: var(--brand-gold); }
.gf-check-card:has(input:checked) {
  border-color: var(--brand-gold);
  background: rgba(26, 26, 26, 0.04);
}
.gf-check-card input[type="checkbox"] { flex-shrink: 0; margin: 0; }
.gf-check-title  { font-weight: 600; font-size: 14px; color: var(--text-primary); }
.gf-check-meta   { font-size: 12.5px; color: var(--text-secondary); margin-top: 2px; }

/* 11) 엔진 선택 - 2-컬럼 카드 */
.gf-engine-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-1);
  margin-top: var(--space-1);
}
@media (max-width: 700px) { .gf-engine-grid { grid-template-columns: 1fr; } }
.gf-engine-grid .gf-check-card { margin-bottom: 0; align-items: flex-start; }
.gf-engine-cost {
  font-size: 11.5px;
  color: var(--text-muted);
  margin-top: 4px;
  font-variant-numeric: tabular-nums;
}

/* 12) 제출 버튼 */
.gf-submit {
  width: 100%;
  padding: 14px;
  font-size: var(--font-body-size, 16px);
  font-weight: 600;
  margin-top: var(--space-1);
}

/* 13) 결과 알림 박스 */
.gf-alert {
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-lg);
  margin-bottom: var(--space-2);
}
.gf-alert h2 { margin: 0 0 var(--space-half) 0; font-size: var(--font-body-size); }
.gf-alert.success { background: rgba(56,192,128,0.08); border: 1px solid rgba(56,192,128,0.30); color: #2d8a5b; }
.gf-alert.error   { background: rgba(220,80,80,0.08); border: 1px solid rgba(220,80,80,0.30); color: #b04040; }
.gf-alert .gf-alert-meta { font-size: var(--font-label-size); color: var(--text-secondary); margin-top: var(--space-half); }

/* ===== /generators-form v1 ===== */

/* === fix(2026-05-02): form label as button (e.g. dropzone photo-btn) ===
   line 435 의 "form label { color: var(--text-primary) }" 가
   <label class="btn btn-primary"> 의 흰 텍스트를 검게 덮어쓰는 문제 해결.
   각 .btn 변종별로 명시적 색상 지정. */
form label.btn-primary,
form label.btn-primary span { color: var(--text-inverse, #fff) !important; }
form label.btn-primary svg { stroke: var(--text-inverse, #fff); }
form label.btn-accent,
form label.btn-accent span { color: var(--text-inverse, #fff) !important; }
form label.btn-danger,
form label.btn-danger span { color: var(--text-danger, #DC2626) !important; }
form label.btn-ghost,
form label.btn-ghost span,
form label.btn:not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost),
form label.btn:not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost) span {
  color: var(--text-primary, #18181b);
}

/* === fix(2026-05-03): WorkflowBreadcrumb — 페이지 이동 시 step 좌우 흔들림 방지 ===
   각 step 을 flex 1 1 0 으로 균등 너비, 모든 lbl 의 font-weight 를 600 으로 통일해
   active 상태일 때 bold 로 변하면서 width 가 늘어나는 현상을 제거. */
.wf-breadcrumb .wf-steps {
  flex-wrap: nowrap;
  overflow-x: auto;
  gap: 4px;
}
.wf-breadcrumb .wf-step {
  flex: 1 1 0;
  min-width: 0;
  justify-content: flex-start;
}
.wf-breadcrumb .wf-step a {
  display: flex;
  align-items: center;
  gap: 6px;
  width: 100%;
  min-width: 0;
}
.wf-breadcrumb .wf-step .wf-lbl,
.wf-breadcrumb .wf-step.is-current .wf-lbl,
.wf-breadcrumb .wf-step.is-done .wf-lbl,
.wf-breadcrumb .wf-step.is-upcoming .wf-lbl {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  min-width: 0;
}
.wf-breadcrumb .wf-arrow {
  flex: 0 0 auto;
}

/* ============================================================
   fix(2026-05-03): 모바일 종합 최적화 — 여백 최소화 + 한눈 가시성
   - 640px 이하: 페이지/카드/폼/KPI/워크플로우 모두 압축
   - 380px 이하: 더 타이트
   ============================================================ */
@media (max-width: 640px) {
  /* === 페이지 컨테이너 === */
  .page-container {
    padding: 12px 12px 16px !important;
    max-width: 100% !important;
  }
  .page-container > * + * { margin-top: 12px !important; }
  .page-actions { gap: 6px !important; flex-wrap: wrap !important; padding: 0 !important; }
  .page-actions .btn { padding: 8px 10px !important; font-size: 12px !important; }

  /* === HelpBox === */
  .help-box { padding: 10px 12px !important; margin-bottom: 10px !important; border-radius: 8px !important; }
  .help-box-toggle, .help-box-content { font-size: 13px !important; line-height: 1.5 !important; }

  /* === Breadcrumb: 현재 단계만 라벨 표시, 나머지는 번호만 === */
  .wf-breadcrumb { padding: 8px 8px !important; margin-bottom: 10px !important; }
  .wf-breadcrumb .wf-steps { gap: 2px !important; flex-wrap: nowrap !important; }
  .wf-breadcrumb .wf-step { min-width: 0 !important; flex: 0 0 auto !important; }
  .wf-breadcrumb .wf-step.is-current { flex: 1 1 auto !important; min-width: 0 !important; }
  .wf-breadcrumb .wf-step:not(.is-current) .wf-lbl { display: none !important; }
  .wf-breadcrumb .wf-step.is-current .wf-lbl { font-size: 13px !important; padding-left: 4px !important; }
  .wf-breadcrumb .wf-num { width: 22px !important; height: 22px !important; font-size: 10px !important; }
  .wf-breadcrumb .wf-num-prefix { display: none !important; }
  .wf-breadcrumb .wf-arrow { font-size: 12px !important; padding: 0 1px !important; }

  /* === KPI 카드 그리드 — 4열 → 2열, 작게 === */
  .stat-grid,
  div[style*="grid-template-columns:repeat(4"] {
    grid-template-columns: repeat(2, 1fr) !important;
    gap: 8px !important;
    margin-bottom: 14px !important;
  }
  .stat-card { padding: 12px !important; min-height: auto !important; }
  .stat-label { font-size: 11px !important; line-height: 1.3 !important; margin-bottom: 6px !important; }
  .stat-value {
    font-size: 22px !important; line-height: 1.1 !important;
    white-space: nowrap !important; word-break: keep-all !important;
    overflow: hidden !important; text-overflow: ellipsis !important;
  }
  .stat-sub { font-size: 10px !important; margin-top: 2px !important; }

  /* === 워크플로우 단계 카드 (대시보드) === */
  .wf-pipeline-title { font-size: 12px !important; margin: 0 0 8px !important; }
  .wf-stages { gap: 6px !important; }
  .wf-stage-card { padding: 10px 8px !important; gap: 4px !important; }
  .wf-stage-card svg { width: 18px !important; height: 18px !important; }
  .wf-step-num { font-size: 9px !important; margin: 4px 0 2px !important; padding: 2px 6px !important; }
  .wf-stage-label { font-size: 12px !important; line-height: 1.2 !important; }
  .wf-stage-count { font-size: 18px !important; line-height: 1 !important; }
  .wf-arrow-sep { display: none !important; }

  /* 하단 2열 (1fr 340px / 1fr 360px) → 1열 */
  div[style*="grid-template-columns:1fr 340px"],
  div[style*="grid-template-columns:1fr 360px"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }

  /* === Panel === */
  .panel { padding: 12px !important; border-radius: 10px !important; }
  .panel h3 { font-size: 13px !important; margin: 0 0 10px !important; }

  /* === 카드/폼 카드 === */
  .card, .form-card, .gf-card {
    padding: 14px !important; border-radius: 10px !important;
    margin-bottom: 10px !important;
  }
  .gf-section-title, .form-section-title {
    font-size: 14px !important; margin: 0 0 12px !important; padding-bottom: 8px !important;
  }

  /* === 폼 필드 === */
  .form-group, .form-field { margin-bottom: 12px !important; }
  form > * + * { margin-top: 12px !important; }
  .form-label, form label:not(.btn):not(.checkbox-label):not(.radio-label):not(.menu-main):not(.menu-sub) {
    font-size: 12px !important; margin-bottom: 4px !important; display: block !important;
  }
  .input, .form-input, .select, .form-select, .textarea, .form-textarea,
  input[type="text"], input[type="email"], input[type="password"],
  input[type="tel"], input[type="number"], input[type="search"], input[type="url"], input[type="date"],
  select, textarea {
    font-size: 14px !important; padding: 10px 12px !important; min-height: 40px !important;
  }
  textarea { min-height: 80px !important; }
  .form-help, .gf-hint { font-size: 11px !important; margin-top: 3px !important; }

  /* === 데이터 테이블 — 컴팩트 + 가로 스크롤 === */
  .data-table, table.table, .table-wrap {
    font-size: 12px !important;
  }
  .data-table th, .data-table td,
  table.table th, table.table td { padding: 6px 8px !important; }
  .table-wrap, .data-table-wrap { overflow-x: auto !important; }

  /* === 버튼 — 너무 큰 거 정리 === */
  .btn { padding: 8px 14px !important; font-size: 13px !important; min-height: 40px !important; }
  .btn-sm { padding: 6px 10px !important; font-size: 12px !important; min-height: 32px !important; }

  /* === 페이지 헤더 (h1 + 부제) === */
  .masthead, .page-header {
    padding: 8px 0 !important; margin-bottom: 8px !important;
  }
  .masthead h1, .page-title { font-size: 18px !important; }

  /* === 사이드바 모바일 (이미 토글이지만 폭 조정) === */
  .sidebar.is-open { width: min(280px, 80vw) !important; }
}

/* === 매우 좁은 화면 (≤ 380px) 추가 압축 === */
@media (max-width: 380px) {
  .page-container { padding: 10px 8px 12px !important; }
  .stat-value { font-size: 19px !important; }
  .wf-stages { grid-template-columns: 1fr !important; }
  .stat-grid { gap: 6px !important; }
  .stat-card { padding: 10px !important; }
}

/* === fix(2026-05-03): product-list-table — 상품 관리 + AI 사진 생성 공통 === */
.product-list-table { width: 100%; border-collapse: collapse; }
.product-list-table th { font-weight: 600; font-size: 12px; color: var(--text-secondary, #6B7280);
  text-align: left; padding: 8px 10px; border-bottom: 1px solid var(--border-subtle, #E5E7EB);
  white-space: nowrap; }
.product-list-table th.th-thumb { width: 80px; }
.product-list-table th.text-right, .product-list-table td.text-right { text-align: right; }
.product-list-table td { padding: 10px; vertical-align: middle;
  border-bottom: 1px solid var(--border-soft, #F3F4F6); font-size: 13px; }
.product-list-table tr.product-row:hover td { background: rgba(0,0,0,.02); }
.product-list-table .text-mono { font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: 12px; color: var(--text-secondary); }
.product-list-table .thumb-cell { width: 80px; padding: 6px 10px; }
.product-list-table .product-thumb {
  width: 64px; height: 84px; object-fit: cover; border-radius: 6px; display: block;
  background: #F3F4F6; box-shadow: 0 1px 2px rgba(0,0,0,.06);
}
.product-list-table .product-thumb-empty {
  width: 64px; height: 84px; background: #F3F4F6; border-radius: 6px;
  display: flex; align-items: center; justify-content: center;
  color: #9CA3AF; font-size: 11px;
}
.product-list-table .name-cell { min-width: 220px; }
.product-list-table .product-name {
  font-weight: 600; color: var(--text-primary, #18181b);
  font-size: 14px; line-height: 1.35; display: flex; align-items: center; gap: 6px;
}
.product-list-table .product-meta-line {
  margin-top: 4px; display: flex; align-items: center; gap: 6px; flex-wrap: wrap;
  font-size: 11px;
}
.product-list-table .product-meta-line code {
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
  background: #F3F4F6; color: var(--text-secondary, #6B7280);
  padding: 1px 6px; border-radius: 4px; font-size: 11px;
}
.product-list-table .product-memo-icon {
  display: inline-block; cursor: help; opacity: .55; font-size: 13px; line-height: 1;
  transition: opacity .12s;
}
.product-list-table .product-memo-icon:hover { opacity: 1; }

/* 모바일 - 가로 스크롤 + 썸네일 작게 */
@media (max-width: 640px) {
  .product-list-table { font-size: 12px; }
  .product-list-table th, .product-list-table td { padding: 6px 8px; }
  .product-list-table .product-thumb,
  .product-list-table .product-thumb-empty { width: 48px; height: 64px; }
  .product-list-table th.th-thumb, .product-list-table .thumb-cell { width: 56px; }
  .product-list-table .product-name { font-size: 13px; }
  .product-list-table .name-cell { min-width: 170px; }
}

/* === fix(2026-05-03 v2): 더 공격적인 모바일 압축 ===
   - 폼: label 왼쪽 + input 오른쪽 (인라인) - 세로 공간 절약
   - 가로 스크롤 회피: 상품 테이블에서 부수 컬럼 숨김
   - 섹션/카드 여백 추가 축소 */
@media (max-width: 640px) {

  /* === 폼 인라인 레이아웃 (label 90px + input 1fr) === */
  .form-group, .form-field, .form-row {
    display: grid !important;
    grid-template-columns: minmax(80px, 100px) 1fr !important;
    align-items: center !important;
    gap: 10px !important;
    margin-bottom: 8px !important;
    padding-bottom: 0 !important;
    border-bottom: 0 !important;
  }
  .form-group > label, .form-field > label, .form-row > label,
  .form-group > .form-label, .form-field > .form-label, .form-row > .form-label {
    margin-bottom: 0 !important;
    font-size: 12px !important;
    line-height: 1.3 !important;
    text-align: left !important;
    padding: 0 !important;
  }
  /* 첫 번째 자식이 input/select 면 자동으로 1fr column 차지 */
  .form-group > input, .form-group > select, .form-group > .form-input, .form-group > .form-select,
  .form-field > input, .form-field > select, .form-field > .form-input, .form-field > .form-select,
  .form-row > input, .form-row > select, .form-row > .form-input, .form-row > .form-select {
    margin: 0 !important;
  }

  /* textarea 가 있는 폼 그룹은 stacked (label 위 + textarea 아래 풀폭) */
  .form-group:has(textarea), .form-field:has(textarea), .form-row:has(textarea) {
    grid-template-columns: 1fr !important;
    gap: 4px !important;
  }
  .form-group:has(textarea) > label, .form-field:has(textarea) > label, .form-row:has(textarea) > label {
    margin-bottom: 4px !important;
  }

  /* form-grid-2 (2열) → 1열 */
  .form-grid-2 { grid-template-columns: 1fr !important; gap: 8px !important; }

  /* === form section 제목/구분선 컴팩트 === */
  .form-section-title, .gf-section-title {
    font-size: 13px !important;
    margin: 0 0 8px !important;
    padding-bottom: 6px !important;
  }

  /* form 카드 자체 padding 축소 */
  .card.form-card, .gf-card, .form-card {
    padding: 12px !important;
    margin-bottom: 8px !important;
  }

  /* form-help / hint 위치 — input 아래 col2 자리 */
  .form-help, .form-hint, .gf-hint {
    grid-column: 2 / -1 !important;
    margin: 2px 0 0 !important;
    font-size: 11px !important;
  }
  .form-group:has(textarea) .form-help,
  .form-group:has(textarea) .form-hint { grid-column: 1 / -1 !important; }

  /* form-actions 버튼 한 줄로 */
  .form-actions {
    grid-column: 1 / -1 !important;
    display: flex !important; gap: 6px !important; flex-wrap: wrap !important;
    margin-top: 4px !important;
  }
  .form-actions .muted { width: 100% !important; font-size: 11px !important; margin-left: 0 !important; }

  /* === 대시보드 워크플로우 카드 — 더 작게 + 아이콘 숨김 (세로 절약) === */
  .wf-pipeline-title { font-size: 11px !important; margin: 0 0 6px !important; }
  .wf-stages { gap: 6px !important; }
  .wf-stage-card {
    padding: 8px 6px !important;
    gap: 2px !important;
    min-height: auto !important;
  }
  .wf-stage-card .wf-stage-icon, .wf-stage-card svg { display: none !important; }
  .wf-step-num {
    font-size: 9px !important;
    margin: 0 0 2px !important;
    padding: 2px 6px !important;
    line-height: 1 !important;
  }
  .wf-stage-label { font-size: 12px !important; line-height: 1.2 !important; }
  .wf-stage-count { font-size: 16px !important; line-height: 1 !important; margin-top: 2px !important; }

  /* === KPI 카드 더 작게 === */
  .stat-card { padding: 10px !important; }
  .stat-value { font-size: 18px !important; }
  .stat-label { font-size: 10px !important; margin-bottom: 4px !important; }
  .stat-sub { font-size: 9px !important; margin-top: 1px !important; }

  /* === Empty state 컴팩트 === */
  .empty-state {
    padding: 24px 16px !important;
  }
  .empty-state h3 { font-size: 14px !important; margin: 6px 0 4px !important; }
  .empty-state p { font-size: 12px !important; margin: 0 !important; }

  /* === Panel 여백 압축 === */
  .panel { padding: 10px !important; margin-bottom: 8px !important; }
  .panel h3 { font-size: 12px !important; margin: 0 0 6px !important; }

  /* === 상품 테이블 — 모바일에서 부수 컬럼 숨겨서 가로 스크롤 회피 === */
  .product-list-table th:nth-child(3),  /* 카테고리 */
  .product-list-table td:nth-child(3),
  .product-list-table th:nth-child(4),  /* 등록일 */
  .product-list-table td:nth-child(4),
  .product-list-table th:nth-child(5),  /* 사입일 */
  .product-list-table td:nth-child(5),
  .product-list-table th:nth-child(6),  /* 도매처 */
  .product-list-table td:nth-child(6),
  .product-list-table th:nth-child(7),  /* 사입가 */
  .product-list-table td:nth-child(7),
  .product-list-table th:nth-child(8),  /* 색상 */
  .product-list-table td:nth-child(8),
  .product-list-table th:nth-child(9),  /* 사이즈 */
  .product-list-table td:nth-child(9) {
    display: none !important;
  }
  /* 모바일에서 보이는 컬럼: 이미지(1) / 상품명(2) / 상태(10) / 액션(11) */
  .product-list-table .name-cell { min-width: 100px !important; }
  .table-scroll { overflow-x: visible !important; }

  /* === HelpBox — 모바일에서 기본 접힘 톤 === */
  .help-box { padding: 8px 10px !important; }

  /* === wf-breadcrumb 숫자 원 더 작게 === */
  .wf-breadcrumb { padding: 6px 8px !important; }
  .wf-breadcrumb .wf-num { width: 18px !important; height: 18px !important; font-size: 9px !important; }
  .wf-breadcrumb .wf-step.is-current .wf-lbl { font-size: 12px !important; }

  /* === 페이지 컨테이너 padding 추가 축소 === */
  .page-container { padding: 10px 12px 14px !important; }
  .page-container > * + * { margin-top: 8px !important; }
}

@media (max-width: 380px) {
  .form-group, .form-field, .form-row {
    grid-template-columns: minmax(70px, 84px) 1fr !important;
    gap: 8px !important;
  }
}

/* === fix(2026-05-03 v3): 폼 타이포 통일 ===
   - 섹션 제목 / 필드 라벨 / 인풋 플레이스홀더 = 동일 font-size
   - 위계는 font-weight 으로만 구분 (700 / 600 / 400)
   - 데스크톱 14px, 모바일(≤640) 13px 로 일관 */

/* 섹션 제목 (기본 정보, 연락처, 사입 채널, 메모 등) — Weight 700 */
.form-section-title,
.gf-section-title,
.card.form-card > h2,
.card.form-card > h3,
.gf-card > h2,
.gf-card > h3,
.panel > h3,
form > h2,
form > h3,
form section > h2,
form section > h3,
form fieldset > legend {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  color: var(--text-primary, #18181b) !important;
  letter-spacing: 0 !important;
}

/* 필드 라벨 (도매처 이름, 전화번호, ...) — Weight 600 */
.form-label,
.form-group > label,
.form-field > label,
.form-row > label,
form label:not(.btn):not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost):not(.btn-sm):not(.btn-lg):not(.checkbox-label):not(.radio-label):not(.menu-main):not(.menu-sub):not(.gf-check-card):not(.photo-btn) {
  font-size: 14px !important;
  font-weight: 600 !important;
  line-height: 1.4 !important;
  color: var(--text-primary, #18181b) !important;
}

/* 인풋 자체 + 플레이스홀더 — 같은 14px, Weight 400 */
.input, .form-input, .form-select, .select, .form-textarea, .textarea,
input[type="text"], input[type="email"], input[type="password"],
input[type="tel"], input[type="number"], input[type="search"],
input[type="url"], input[type="date"],
select, textarea {
  font-size: 14px !important;
  font-weight: 400 !important;
  line-height: 1.5 !important;
}

/* 플레이스홀더 — 같은 size, weight 400, 회색 */
.input::placeholder, .form-input::placeholder, .form-textarea::placeholder, .textarea::placeholder,
input::placeholder, textarea::placeholder {
  font-size: 14px !important;
  font-weight: 400 !important;
  color: var(--text-3, #9CA3AF) !important;
  opacity: 1 !important;
}

/* select 의 placeholder-같은 첫 옵션 (선택...) */
select { color: inherit !important; }

/* 모바일에서는 같은 위계 유지하면서 한 단계 작게 (13px) */
@media (max-width: 640px) {
  .form-section-title, .gf-section-title,
  .card.form-card > h2, .card.form-card > h3,
  .gf-card > h2, .gf-card > h3, .panel > h3,
  form > h2, form > h3, form section > h2, form section > h3, form fieldset > legend {
    font-size: 13px !important;
  }
  .form-label, .form-group > label, .form-field > label, .form-row > label,
  form label:not(.btn):not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost):not(.btn-sm):not(.btn-lg):not(.checkbox-label):not(.radio-label):not(.menu-main):not(.menu-sub):not(.gf-check-card):not(.photo-btn) {
    font-size: 13px !important;
  }
  .input, .form-input, .form-select, .select, .form-textarea, .textarea,
  input[type="text"], input[type="email"], input[type="password"],
  input[type="tel"], input[type="number"], input[type="search"],
  input[type="url"], input[type="date"],
  select, textarea,
  .input::placeholder, .form-input::placeholder, .form-textarea::placeholder, .textarea::placeholder,
  input::placeholder, textarea::placeholder {
    font-size: 13px !important;
  }
}

/* ============================================================
   fix(2026-05-03 v4): 통합 패스 — 도움말 헤딩, 폼 2-col, 버튼 가운데, 테이블 PC 가독성, 모바일 카드뷰
   ============================================================ */

/* === 1. 도움말 헤딩 — 페이지 title 과 동일 스케일 (작게) === */
.page-help { margin-top: var(--space-3, 24px); }
.page-help-title {
  font-size: 16px !important;
  font-weight: 700 !important;
  margin: 0 0 10px !important;
  letter-spacing: 0 !important;
  color: var(--text-primary, #18181b) !important;
}

/* === 2. 폼 form-actions 버튼 가운데 정렬 === */
.form-actions {
  display: flex !important;
  justify-content: center !important;
  align-items: center !important;
  gap: 8px !important;
  margin-top: 16px !important;
  flex-wrap: wrap !important;
}

/* === 3. 데이터 테이블 (vendor/product) PC 가독성 — 행 높이/패딩 + 호버 === */
.data-table { width: 100%; border-collapse: collapse; }
.data-table thead th {
  padding: 10px 12px !important;
  font-size: 12px !important;
  font-weight: 600 !important;
  color: var(--text-secondary, #6B7280) !important;
  text-align: left !important;
  border-bottom: 1px solid var(--border-subtle, #E5E7EB) !important;
  background: var(--gray-50, #FAFAFA);
  white-space: nowrap;
}
.data-table tbody td {
  padding: 12px !important;
  font-size: 13px !important;
  border-bottom: 1px solid var(--border-soft, #F3F4F6) !important;
  vertical-align: middle;
  line-height: 1.5;
}
.data-table tbody tr:hover td { background: rgba(0,0,0,.02); }
.data-table small.text-muted, .data-table .text-muted {
  font-size: 11px;
  color: var(--text-secondary, #6B7280);
}

/* === 4. 모바일: 폼 2-col 유지 + form-grid-2 안의 form-row 는 stacked === */
@media (max-width: 640px) {
  .form-grid-2 {
    grid-template-columns: 1fr 1fr !important;
    gap: 8px !important;
  }
  .form-grid-2 .form-row,
  .form-grid-2 .form-group,
  .form-grid-2 .form-field {
    display: block !important;
    grid-template-columns: none !important;
    margin-bottom: 0 !important;
  }
  .form-grid-2 .form-row > label,
  .form-grid-2 .form-group > label,
  .form-grid-2 .form-field > label {
    display: block !important;
    margin-bottom: 4px !important;
    font-size: 12px !important;
  }

  /* === 5. 모바일 vendor-list-table — 카드 레이아웃 (가로 스크롤 회피) === */
  .vendor-list-table thead { display: none !important; }
  .vendor-list-table, .vendor-list-table tbody, .vendor-list-table tr { display: block !important; }
  .vendor-list-table tr {
    border: 1px solid var(--border-subtle, #E5E7EB) !important;
    border-radius: 8px !important;
    margin-bottom: 8px !important;
    padding: 10px !important;
    background: var(--surface, #fff);
  }
  .vendor-list-table td {
    display: flex !important;
    justify-content: space-between !important;
    align-items: baseline !important;
    padding: 4px 0 !important;
    border: 0 !important;
    font-size: 13px !important;
    gap: 10px !important;
  }
  .vendor-list-table td::before {
    content: attr(data-label);
    color: var(--text-secondary, #6B7280) !important;
    font-size: 12px !important;
    font-weight: 600 !important;
    flex: 0 0 auto;
  }
  .vendor-list-table td:first-child {
    display: block !important;
    border-bottom: 1px solid var(--border-soft, #F3F4F6) !important;
    padding-bottom: 8px !important;
    margin-bottom: 6px !important;
    font-size: 14px !important;
    font-weight: 700 !important;
  }
  .vendor-list-table td:first-child::before { content: none; }
  .vendor-list-table td.vendor-actions-cell {
    display: flex !important;
    justify-content: center !important;
    gap: 6px !important;
    border-top: 1px solid var(--border-soft, #F3F4F6) !important;
    margin-top: 6px !important;
    padding-top: 8px !important;
  }
  .vendor-list-table td.vendor-actions-cell::before { content: none; }
  .table-scroll { overflow-x: visible !important; }
}

/* === 6. PC vendor-list-table 가독성 === */
@media (min-width: 641px) {
  .vendor-list-table tbody td { padding: 14px 12px !important; }
  .vendor-list-table tbody tr td:first-child { min-width: 140px; }
  .vendor-list-table tbody tr td:nth-child(5) { min-width: 130px; }  /* 연락처 */
  .vendor-list-table tbody tr:hover td { background: var(--gray-50, #FAFAFA); }
}

/* === fix(2026-05-03 v5): 표 헤더(필드명) 가운데 정렬 === */
.data-table thead th,
.product-list-table thead th,
.vendor-list-table thead th,
table.table thead th {
  text-align: center !important;
}
/* 데이터 셀은 자연스러운 정렬 유지 (왼쪽 기본, .num은 오른쪽, .text-right 등 유지) */

/* === fix(2026-05-03 v6): qc-pipeline 모바일 — 가로 스크롤 제거, 2x2 그리드 === */
@media (max-width: 640px) {
  .qc-pipeline {
    display: grid !important;
    grid-template-columns: repeat(2, 1fr) !important;
    overflow-x: visible !important;
    flex-wrap: unset !important;
    padding: 0 !important;
    gap: 6px !important;
    margin-bottom: 12px !important;
  }
  /* 그리드에서 화살표 separator 숨김 */
  .qc-pipeline > div[aria-hidden="true"] { display: none !important; }
  .qc-pipeline > a {
    min-width: 0 !important;
    padding: 10px 8px !important;
    flex: unset !important;
  }
}

/* 매우 좁은 화면(≤380)도 2x2 유지 */
@media (max-width: 380px) {
  .qc-pipeline > a { padding: 8px 6px !important; }
  .qc-pipeline > a > div:nth-child(1) { font-size: 12px !important; }
  .qc-pipeline > a > div:nth-child(2) > span:first-child { font-size: 18px !important; }
}

/* === fix(2026-05-03 v7): vendor-list-table 모바일 카드 — 여백/폰트 정돈 === */
@media (max-width: 640px) {
  /* 카드 자체 padding 축소 */
  .vendor-list-table tr {
    padding: 10px 12px !important;
    margin-bottom: 8px !important;
  }
  /* 카드 헤더 (도매처명) — 컴팩트 */
  .vendor-list-table td:first-child {
    padding: 0 0 8px !important;
    margin-bottom: 6px !important;
    font-size: 13px !important;
    line-height: 1.3 !important;
    border-bottom: 1px solid var(--border-soft, #F3F4F6) !important;
  }
  .vendor-list-table td:first-child a strong { font-size: 14px !important; }
  .vendor-list-table td:first-child small,
  .vendor-list-table td:first-child .text-muted {
    font-size: 11px !important; line-height: 1.3 !important;
  }
  /* 일반 데이터 행 — 더 타이트 */
  .vendor-list-table td {
    padding: 3px 0 !important;
    font-size: 12px !important;
    line-height: 1.4 !important;
    min-height: 0 !important;
    gap: 8px !important;
  }
  .vendor-list-table td::before {
    font-size: 11px !important;
    font-weight: 500 !important;
    color: var(--text-secondary, #6B7280) !important;
  }
  /* 신뢰도 select 작게 */
  .vendor-list-table td select {
    padding: 3px 6px !important;
    font-size: 11px !important;
    height: auto !important;
    min-height: 0 !important;
    width: auto !important;
  }
  /* 상태 badge 작게 */
  .vendor-list-table td .badge { font-size: 10px !important; padding: 2px 6px !important; }
  /* 액션 행 — 버튼 더 작게 */
  .vendor-list-table td.vendor-actions-cell {
    margin-top: 6px !important;
    padding-top: 8px !important;
    gap: 8px !important;
  }
  .vendor-list-table td.vendor-actions-cell .btn,
  .vendor-list-table td.vendor-actions-cell .btn-sm {
    padding: 5px 14px !important;
    font-size: 12px !important;
    min-height: 30px !important;
    height: auto !important;
  }
  /* contact_phone 두 줄(이름 + 전화) 컴팩트 */
  .vendor-list-table td small { font-size: 11px !important; line-height: 1.3 !important; }
}

/* === fix(2026-05-03 v8): product-list-table 모바일 — 이미지 좌측 + 정보 우측 카드형 (가로스크롤 제거) === */
@media (max-width: 640px) {
  .product-list-table thead { display: none !important; }
  .product-list-table tbody { display: block !important; }
  .product-list-table tr.product-row {
    display: grid !important;
    grid-template-columns: 64px 1fr !important;
    grid-auto-flow: row !important;
    column-gap: 12px !important;
    row-gap: 4px !important;
    border: 1px solid var(--border-subtle, #E5E7EB) !important;
    border-radius: 8px !important;
    padding: 10px !important;
    margin-bottom: 8px !important;
    background: var(--surface, #fff) !important;
    align-items: start !important;
  }
  /* 1열 이미지 — 다른 cells 의 row span 만큼 차지 */
  .product-list-table td:nth-child(1) {
    display: block !important;
    grid-column: 1 !important;
    grid-row: 1 / span 4 !important;
    padding: 0 !important;
    border: 0 !important;
  }
  /* 2, 10, 11번째 cells = 2열 stack */
  .product-list-table td:nth-child(2),
  .product-list-table td:nth-child(10),
  .product-list-table td:nth-child(11) {
    display: block !important;
    grid-column: 2 !important;
    padding: 0 !important;
    border: 0 !important;
  }
  /* 상태 + 액션 살짝 간격 */
  .product-list-table td:nth-child(10) { margin-top: 4px !important; }
  .product-list-table td:nth-child(11) { margin-top: 6px !important; }

  /* 이미지 사이즈 */
  .product-list-table .product-thumb,
  .product-list-table .product-thumb-empty {
    width: 64px !important;
    height: 84px !important;
  }

  /* 텍스트 컴팩트 */
  .product-list-table .name-cell .product-name { font-size: 13px !important; line-height: 1.35 !important; }
  .product-list-table .product-meta-line { font-size: 10px !important; gap: 4px !important; }
  .product-list-table .product-meta-line code { padding: 1px 4px !important; font-size: 10px !important; }
  .product-list-table .badge { font-size: 10px !important; padding: 2px 6px !important; }
  .product-list-table .btn-sm { padding: 4px 12px !important; font-size: 12px !important; min-height: 28px !important; height: auto !important; }

  /* 가로 스크롤 wrapper 제거 */
  .table-scroll { overflow-x: visible !important; }
}

/* ============================================================
   fix(2026-05-03 v9): 전체 폰트 통일 — 페이지 전반
   - 모든 본문 텍스트 14px (모바일 13px)
   - 위계: 700 / 600 / 400 (weight only)
   - line-height 1.5~1.6 통일 (1.9 같은 비정상 값 강제 보정)
   ============================================================ */

/* === 본문/콘텐츠 영역의 텍스트 통일 === */
body .card, body .panel, body .gf-card, body .form-card,
body .product-edit-grid, body .preview-card, body .help-content {
  font-size: 14px;
  line-height: 1.6;
}

/* h3 섹션 제목 (예: "평면컷 이미지", "제품 정보") — 14px / 700 */
body .panel > h3,
body .card > h3,
body .form-card > h3,
body section > h3,
body .product-edit-grid h3 {
  font-size: 14px !important;
  font-weight: 700 !important;
  line-height: 1.4 !important;
  letter-spacing: 0 !important;
  color: var(--text-primary, #18181b) !important;
}

/* meta-row (카테고리/핏/시즌 라벨+값) === */
body .meta-row,
body .meta-row dt,
body .meta-row dd {
  font-size: 14px !important;
  line-height: 1.5 !important;
}
body .meta-row dt { font-weight: 500 !important; color: var(--text-secondary, #6B7280) !important; }
body .meta-row dd { font-weight: 600 !important; color: var(--text-primary, #18181b) !important; }

/* description 영역 — line-height 1.9 → 1.6 으로 정상화 */
body .desc-textarea,
body .preview-card {
  font-size: 14px !important;
  line-height: 1.6 !important;
  font-weight: 400 !important;
}

/* desc-status, desc-meta 등 부속 텍스트 */
body .desc-status, body .desc-meta { font-size: 13px !important; line-height: 1.5 !important; }

/* HelpBox 내용 텍스트 */
body .help-content,
body .help-content p,
body .help-content li,
body .help-content ol,
body .help-content ul {
  font-size: 14px !important;
  line-height: 1.6 !important;
}
body .help-toggle-label { font-size: 14px !important; font-weight: 700 !important; }

/* Caption-급 작은 텍스트 (보조 정보) — 12px 유지 */
body .text-muted, body .muted, body .gf-hint, body .form-hint, body .form-help {
  font-size: 12px !important;
  line-height: 1.5 !important;
}

/* 모바일 한 단계 작게 (13px) */
@media (max-width: 640px) {
  body .card, body .panel, body .gf-card, body .form-card,
  body .product-edit-grid, body .preview-card, body .help-content {
    font-size: 13px !important;
  }
  body .panel > h3, body .card > h3, body .form-card > h3, body section > h3,
  body .product-edit-grid h3 { font-size: 13px !important; }
  body .meta-row, body .meta-row dt, body .meta-row dd { font-size: 13px !important; }
  body .desc-textarea, body .preview-card { font-size: 13px !important; }
  body .help-content, body .help-content p, body .help-content li,
  body .help-toggle-label { font-size: 13px !important; }
  body .text-muted, body .muted, body .gf-hint, body .form-hint, body .form-help { font-size: 11px !important; }
}

/* === fix(2026-05-03 v10): 평면컷 썸네일 (뒷면/옆면/디테일) — 섹션 안쪽으로 정확히 정렬 === */
.image-thumbs {
  display: grid !important;
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important; /* minmax(0,1fr) = 셀이 부모 폭 넘지 않게 */
  gap: 8px !important;
  width: 100% !important;
  margin-top: 8px !important;
  box-sizing: border-box;
}
.dropzone.dz-thumb {
  aspect-ratio: 4/3 !important;       /* 1:1 → 4:3 (세로 짧게) */
  min-width: 0 !important;
  min-height: 0 !important;
  max-width: 100% !important;
}
.dropzone.dz-thumb .placeholder {
  font-size: 12px !important;
}

/* 모바일 좁은 화면에서는 더 컴팩트 */
@media (max-width: 640px) {
  .image-thumbs { gap: 6px !important; }
  .dropzone.dz-thumb { aspect-ratio: 1/1 !important; }
  .dropzone.dz-thumb .placeholder { font-size: 11px !important; }
}

/* === fix(2026-05-03 v11): 표 데이터 셀 — 상품명(name-cell)을 제외하고 가운데 정렬 === */
.product-list-table tbody td { text-align: center !important; vertical-align: middle !important; }
.product-list-table tbody td.name-cell { text-align: left !important; }
.product-list-table tbody td.text-right { text-align: right !important; }

.vendor-list-table tbody td { text-align: center !important; vertical-align: middle !important; }
/* 도매처명은 왼쪽 정렬 (식별자 셀) */
.vendor-list-table tbody td:first-child { text-align: left !important; }
.vendor-list-table tbody td.num { text-align: center !important; }

/* 일반 .data-table 도 같은 규칙 적용 (단, .num/.text-right 우선) */
.data-table tbody td { vertical-align: middle !important; }

/* 모바일 카드 레이아웃에서는 가운데 정렬 룰 무력화 (기존 카드 디자인 유지) */
@media (max-width: 640px) {
  .product-list-table tbody td,
  .vendor-list-table tbody td { text-align: left !important; }
}

/* === mobile-first polish 2026-05-05: AI Fashion 390/430 baseline === */
@media (max-width: 820px) {
  :root {
    --mtr-mobile-page-pad: 16px;
    --mtr-mobile-card-pad: 18px;
    --mtr-mobile-card-radius: 20px;
    --mtr-mobile-field-h: 48px;
    --mtr-mobile-gap: 14px;
  }

  html, body {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: hidden !important;
    background: #F5F6F8 !important;
    -webkit-text-size-adjust: 100%;
  }

  .mobile-topbar {
    display: flex !important;
    height: 56px !important;
    padding: 0 16px !important;
    align-items: center !important;
    justify-content: space-between !important;
    background: rgba(255,255,255,.94) !important;
    border-bottom: 1px solid #EEF0F4 !important;
    backdrop-filter: blur(14px) !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1200 !important;
  }
  .mobile-topbar .hamburger {
    width: 42px !important;
    height: 42px !important;
    border-radius: 14px !important;
  }
  .mobile-topbar .brand { font-size: 15px !important; font-weight: 900 !important; }
  .mobile-topbar .brand small { display: none !important; }

  .sidebar {
    width: min(304px, 84vw) !important;
    max-width: 84vw !important;
    transform: translateX(-105%) !important;
    z-index: 1300 !important;
    border-radius: 0 24px 24px 0 !important;
  }
  .sidebar.is-open { transform: translateX(0) !important; }
  .sidebar-backdrop.is-open { display: block !important; opacity: 1 !important; }

  .main-content, .admin-main, main {
    margin-left: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    padding-top: 0 !important;
    overflow-x: hidden !important;
  }
  .page-container, .admin-content, .content, .content-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: var(--mtr-mobile-page-pad) !important;
    overflow-x: hidden !important;
  }
  .page-container > * + * { margin-top: var(--mtr-mobile-gap) !important; }

  .masthead, .page-header, .admin-page-header {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
    margin: 8px 0 12px !important;
  }
  .masthead h1, .page-header h1, .admin-page-header h1,
  h1 {
    font-size: 28px !important;
    line-height: 1.18 !important;
    letter-spacing: -0.04em !important;
  }
  .masthead p, .page-subtitle, .admin-page-header p {
    font-size: 13px !important;
    line-height: 1.45 !important;
    color: #6B7280 !important;
  }

  .wf-breadcrumb, .gf-tabs, .ma-tabs, .page-actions {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
    padding-bottom: 2px !important;
  }
  .wf-breadcrumb::-webkit-scrollbar,
  .gf-tabs::-webkit-scrollbar,
  .ma-tabs::-webkit-scrollbar,
  .page-actions::-webkit-scrollbar { display: none !important; }
  .wf-breadcrumb a, .gf-tab, .ma-tab, .page-actions .btn {
    flex: 0 0 auto !important;
    min-height: 40px !important;
    border-radius: 999px !important;
    white-space: nowrap !important;
  }

  .panel, .card, .gf-card, .form-card, .help-box,
  section.panel, section.card, div.panel, div.card {
    width: 100% !important;
    max-width: 100% !important;
    box-sizing: border-box !important;
    padding: var(--mtr-mobile-card-pad) !important;
    border-radius: var(--mtr-mobile-card-radius) !important;
    border: 1px solid #EAEDF2 !important;
    background: #fff !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
    overflow: hidden !important;
  }
  .panel h2, .panel h3, .card h2, .card h3, .gf-card h2, .gf-card h3,
  .gf-section-title {
    font-size: 17px !important;
    line-height: 1.35 !important;
    letter-spacing: -0.02em !important;
    margin-bottom: 14px !important;
  }

  label, .form-label {
    font-size: 13px !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
    color: #111827 !important;
    margin-bottom: 7px !important;
  }
  input, select, textarea,
  .input, .select, .textarea, .form-input, .form-select, .form-textarea,
  .gf-card input[type="text"], .gf-card input[type="number"], .gf-card select, .gf-card textarea {
    width: 100% !important;
    min-height: var(--mtr-mobile-field-h) !important;
    font-size: 16px !important;
    line-height: 1.35 !important;
    border-radius: 14px !important;
    padding: 12px 14px !important;
    box-sizing: border-box !important;
    border: 1px solid #E4E7EC !important;
    background: #fff !important;
  }
  textarea, .textarea, .form-textarea, .gf-card textarea { min-height: 96px !important; }
  input::placeholder, textarea::placeholder { color: #A3AAB7 !important; }

  .btn, button, .toolbar-btn, .btn-sm, .btn-primary, .btn-ghost {
    min-height: 44px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
    padding: 10px 14px !important;
    box-sizing: border-box !important;
  }
  .btn-sm { min-height: 38px !important; padding: 8px 12px !important; }

  .gf-grid, .panel-grid, .form-grid, .settings-grid,
  .dispatch-grid, .edit-grid, .meta-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: var(--mtr-mobile-gap) !important;
  }
  .form-row, .toolbar-filters, .admin-toolbar, .desc-toolbar {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 10px !important;
  }
  [style*="grid-template-columns:1fr 1fr"],
  [style*="grid-template-columns: 1fr 1fr"],
  [style*="grid-template-columns:repeat(2"],
  [style*="grid-template-columns: repeat(2"],
  [style*="grid-template-columns:repeat(3"],
  [style*="grid-template-columns: repeat(3"] {
    grid-template-columns: 1fr !important;
  }

  .photo-grid, .image-thumbs, .ai-passed-strip, .passed-grid, .edit-grid-images {
    gap: 10px !important;
  }
  img { max-width: 100%; height: auto; }
}

@media (max-width: 430px) {
  :root {
    --mtr-mobile-page-pad: 14px;
    --mtr-mobile-card-pad: 16px;
    --mtr-mobile-card-radius: 18px;
  }
  .masthead h1, .page-header h1, .admin-page-header h1, h1 { font-size: 26px !important; }
  .panel, .card, .gf-card, .form-card, .help-box { padding: 16px !important; }
}

@media (min-width: 700px) and (max-width: 1024px) {
  .page-container, .admin-content, .content, .content-wrapper { padding: 24px !important; }
  .panel, .card, .gf-card, .form-card { padding: 22px !important; border-radius: 22px !important; }
  .gf-grid, .panel-grid { grid-template-columns: 1fr !important; }
}

/* === ai-fashion workflow mobile cards 2026-05-05 === */
@media (max-width: 820px) {
  .sourcing-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .sourcing-grid > *, .sourcing-card {
    border-radius: 20px !important;
    padding: 16px !important;
    background: #fff !important;
    border: 1px solid #EAEDF2 !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
  }
  .sourcing-grid img, .sourcing-photo, .photo-preview {
    border-radius: 16px !important;
    overflow: hidden !important;
  }
  .sourcing-meta, .sourcing-memo, .sourcing-date {
    font-size: 13px !important;
    line-height: 1.45 !important;
  }
  .sourcing-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    align-items: stretch !important;
    margin-top: 12px !important;
  }
  .sourcing-actions .btn, .sourcing-actions button, .sourcing-actions form {
    width: 100% !important;
  }
  .dropzone {
    min-height: 188px !important;
    padding: 26px 16px !important;
    border-radius: 18px !important;
  }
  .dropzone-buttons, .form-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
  }
  .form-grid-2 {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }

  .dispatch-product-card .table-scroll,
  .product-list-page .table-scroll,
  .ai-product-panel .table-scroll,
  .table-scroll {
    width: 100% !important;
    max-width: 100% !important;
    overflow-x: visible !important;
  }
  .dispatch-product-card .product-list-table,
  .product-list-page .product-list-table,
  .ai-product-panel .product-list-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    table-layout: auto !important;
    border-collapse: separate !important;
    border-spacing: 0 !important;
  }
  .dispatch-product-card .product-list-table thead,
  .product-list-page .product-list-table thead,
  .ai-product-panel .product-list-table thead {
    display: none !important;
  }
  .dispatch-product-card .product-list-table tbody,
  .product-list-page .product-list-table tbody,
  .ai-product-panel .product-list-table tbody {
    display: block !important;
    width: 100% !important;
  }
  .dispatch-product-card .product-list-table tr.product-row,
  .product-list-page .product-list-table tr.product-row,
  .ai-product-panel .product-list-table tr.product-row {
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 8px 14px !important;
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 16px !important;
    margin: 0 0 12px !important;
    background: #fff !important;
    border: 1px solid #EAEDF2 !important;
    border-radius: 20px !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
  }
  .dispatch-product-card .product-list-table td,
  .product-list-page .product-list-table td,
  .ai-product-panel .product-list-table td {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    white-space: normal !important;
    overflow: visible !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(2),
  .product-list-page .product-list-table tr.product-row > td:nth-child(2),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 1 / span 6 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(1),
  .product-list-page .product-list-table tr.product-row > td:nth-child(1),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(1) {
    grid-column: 2 !important;
    grid-row: 1 !important;
    align-self: start !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(3),
  .product-list-page .product-list-table tr.product-row > td:nth-child(3),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
    font-size: 12px !important;
    color: #6B7280 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(4),
  .product-list-page .product-list-table tr.product-row > td:nth-child(4),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(4) {
    grid-column: 2 !important;
    grid-row: 3 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(5) {
    grid-column: 2 !important;
    grid-row: 4 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(6) {
    grid-column: 2 !important;
    grid-row: 5 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(7),
  .dispatch-product-card .product-list-table td:nth-child(8) {
    grid-column: 1 / -1 !important;
  }
  .dispatch-product-card .product-list-table td:nth-child(7) { margin-top: 8px !important; }
  .dispatch-product-card .product-list-table td:nth-child(7) .btn,
  .dispatch-product-card .product-list-table td:nth-child(8) button,
  .dispatch-product-card .product-list-table td:nth-child(8) form {
    width: 100% !important;
  }
  .dispatch-product-card .product-thumb,
  .product-list-page .product-thumb,
  .ai-product-panel .product-thumb,
  .product-thumb-link {
    width: 104px !important;
    height: 139px !important;
    min-width: 104px !important;
    border-radius: 16px !important;
    overflow: hidden !important;
  }
  .product-thumb img, .product-thumb-link img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }
  .product-name, .name-cell {
    font-size: 15px !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
    color: #111827 !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .dispatch-ai-counts, .ai-status-cell .ai-section-counts {
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 5px !important;
  }

  .product-list-page .product-list-table tr.product-row > td:nth-child(n+5):nth-child(-n+11),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(n+5):nth-child(-n+11) {
    display: none !important;
  }
  .product-list-page .product-list-table tr.product-row > td:nth-child(12),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(12) {
    grid-column: 2 !important;
    grid-row: 4 !important;
  }
  .product-list-page .product-list-table tr.product-row > td:nth-child(13),
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(13) {
    grid-column: 1 / -1 !important;
    grid-row: 7 !important;
    margin-top: 8px !important;
  }
  .product-list-page .product-list-table tr.product-row > td:nth-child(13) .btn,
  .ai-product-panel .product-list-table tr.product-row > td:nth-child(13) .btn {
    width: 100% !important;
  }
  .ai-passed-row,
  .ai-passed-row > td,
  .ai-gallery-cell {
    display: block !important;
    width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
  }
  .ai-passed-row { margin: -4px 0 12px !important; }
  .ai-passed-strip {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    padding: 0 2px 14px !important;
    overflow: hidden !important;
  }
  .ai-gallery-card {
    width: 100% !important;
    min-width: 0 !important;
    aspect-ratio: 3 / 4 !important;
    border-radius: 14px !important;
    overflow: hidden !important;
  }
  .ai-gallery-card img {
    width: 100% !important;
    height: 100% !important;
    object-fit: cover !important;
  }

  .qc-pipeline {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .qc-pipeline > * {
    border-radius: 20px !important;
    padding: 16px !important;
  }
  .qc-thumb {
    width: 100% !important;
    max-height: none !important;
    border-radius: 16px !important;
  }
  .qc-pipeline form, .qc-pipeline .btn,
  .qcb-actions form, .qcb-actions .btn, .qcb-actions a {
    width: 100% !important;
  }
  .qcb-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
    padding: 12px !important;
  }
  .qcb-modal, .qcb-lightbox, .qcb-dialog {
    width: calc(100vw - 24px) !important;
    max-width: calc(100vw - 24px) !important;
    max-height: calc(100vh - 24px) !important;
    border-radius: 20px !important;
  }

  .product-edit-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .image-thumbs {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
  }
  .dropzone.dz-main, .preview-card, .passed-card, .cropped-card {
    border-radius: 18px !important;
  }
  .desc-toolbar, .passed-actions {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .desc-textarea { min-height: 220px !important; }
}

@media (max-width: 640px) {
  .data-table:not(.product-list-table) {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
  }
  .data-table:not(.product-list-table) thead { display: none !important; }
  .data-table:not(.product-list-table) tbody,
  .data-table:not(.product-list-table) tr,
  .data-table:not(.product-list-table) td {
    display: block !important;
    width: 100% !important;
    box-sizing: border-box !important;
  }
  .data-table:not(.product-list-table) tr {
    padding: 14px !important;
    margin-bottom: 10px !important;
    border: 1px solid #EAEDF2 !important;
    border-radius: 18px !important;
    background: #fff !important;
  }
  .data-table:not(.product-list-table) td {
    padding: 6px 0 !important;
    border: 0 !important;
    font-size: 14px !important;
    line-height: 1.45 !important;
  }
  .data-table:not(.product-list-table) td .btn,
  .data-table:not(.product-list-table) td button {
    width: 100% !important;
    margin-top: 4px !important;
  }
}

@media (max-width: 380px) {
  .dispatch-product-card .product-list-table tr.product-row,
  .product-list-page .product-list-table tr.product-row,
  .ai-product-panel .product-list-table tr.product-row {
    grid-template-columns: 92px minmax(0, 1fr) !important;
    gap: 8px 12px !important;
    padding: 14px !important;
  }
  .dispatch-product-card .product-thumb,
  .product-list-page .product-thumb,
  .ai-product-panel .product-thumb,
  .product-thumb-link {
    width: 92px !important;
    height: 123px !important;
    min-width: 92px !important;
  }
  .ai-passed-strip { grid-template-columns: repeat(2, minmax(0, 1fr)) !important; }
}

/* === product-management mobile list override 2026-05-05 === */
@media (max-width: 820px) {
  .card:not(.dispatch-product-card) .table-scroll {
    overflow-x: visible !important;
    overflow-y: visible !important;
  }
  .card:not(.dispatch-product-card) .product-list-table {
    display: block !important;
    width: 100% !important;
    min-width: 0 !important;
    table-layout: auto !important;
  }
  .card:not(.dispatch-product-card) .product-list-table thead { display: none !important; }
  .card:not(.dispatch-product-card) .product-list-table tbody { display: block !important; width: 100% !important; }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row {
    display: grid !important;
    grid-template-columns: 104px minmax(0, 1fr) !important;
    gap: 8px 14px !important;
    width: 100% !important;
    padding: 16px !important;
    margin: 0 0 12px !important;
    border: 1px solid #EAEDF2 !important;
    border-radius: 20px !important;
    background: #fff !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
    box-sizing: border-box !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td {
    display: block !important;
    width: auto !important;
    min-width: 0 !important;
    max-width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
    background: transparent !important;
    overflow: visible !important;
    white-space: normal !important;
    box-sizing: border-box !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(2) {
    grid-column: 1 !important;
    grid-row: 1 / span 6 !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(1) {
    grid-column: 2 !important;
    grid-row: 1 !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(3) {
    grid-column: 2 !important;
    grid-row: 2 !important;
    font-size: 12px !important;
    color: #6B7280 !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(4) {
    grid-column: 2 !important;
    grid-row: 3 !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(n+5):nth-child(-n+11) {
    display: none !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(12) {
    grid-column: 2 !important;
    grid-row: 4 !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(13) {
    grid-column: 1 / -1 !important;
    grid-row: 7 !important;
    margin-top: 8px !important;
  }
  .card:not(.dispatch-product-card) .product-list-table tr.product-row > td:nth-child(13) .btn {
    width: 100% !important;
  }
  .card:not(.dispatch-product-card) .product-list-table .ai-passed-row {
    display: block !important;
    width: 100% !important;
    margin: -2px 0 12px !important;
  }
  .card:not(.dispatch-product-card) .product-list-table .ai-passed-row > td {
    display: block !important;
    width: 100% !important;
    padding: 0 !important;
    border: 0 !important;
  }
  .card:not(.dispatch-product-card) .ai-section-head {
    display: none !important;
  }
  .card:not(.dispatch-product-card) .ai-passed-strip {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
    padding: 0 0 14px !important;
    overflow: hidden !important;
  }
  .card:not(.dispatch-product-card) .ai-gallery-card {
    width: 100% !important;
    min-width: 0 !important;
    aspect-ratio: 3 / 4 !important;
  }
}

/* === secondary admin mobile polish 2026-05-05 === */
@media (max-width: 820px) {
  .settings-card, .stat-card, .summary-card, .vendor-card, .brand-card,
  .persona-card, .scene-card, .api-card, .saas-card, .trash-card {
    width: 100% !important;
    box-sizing: border-box !important;
    padding: 16px !important;
    border-radius: 20px !important;
    border: 1px solid #EAEDF2 !important;
    background: #fff !important;
    box-shadow: 0 8px 24px rgba(15,23,42,.04) !important;
  }
  .stats-grid, .summary-grid, .vendor-grid, .brand-grid,
  .persona-grid, .scene-grid, .api-grid, .saas-grid, .trash-grid {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .filter-row, .filters, .search-row, .list-toolbar {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    width: 100% !important;
  }
  .filter-row > *, .filters > *, .search-row > *, .list-toolbar > * {
    width: 100% !important;
    min-width: 0 !important;
  }
  .empty-state {
    padding: 32px 18px !important;
    border-radius: 20px !important;
  }
  .empty-state-icon {
    width: 52px !important;
    height: 52px !important;
    border-radius: 18px !important;
  }
  .pagination {
    display: flex !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    gap: 8px !important;
  }
  .pagination a, .pagination span {
    min-width: 40px !important;
    min-height: 40px !important;
    border-radius: 12px !important;
  }
  .badge, .ai-inline-badge, .status, .brand-pill {
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.25 !important;
  }
  .text-mono {
    word-break: break-all !important;
  }
}

@media (min-width: 700px) and (max-width: 1024px) {
  .stats-grid, .summary-grid, .vendor-grid, .brand-grid,
  .persona-grid, .scene-grid, .api-grid, .saas-grid, .trash-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
  .filter-row, .filters, .search-row, .list-toolbar {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}

/* === mobile hamburger visibility fix 2026-05-05 === */
@media (max-width: 820px) {
  .mobile-topbar .hamburger,
  #mobileHamburger {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    height: 42px !important;
    flex: 0 0 42px !important;
    color: #111827 !important;
    background: #F3F4F6 !important;
    border: 1px solid #E5E7EB !important;
    border-radius: 14px !important;
    opacity: 1 !important;
    visibility: visible !important;
  }
  .mobile-topbar .hamburger svg,
  #mobileHamburger svg {
    display: block !important;
    width: 24px !important;
    height: 24px !important;
    color: #111827 !important;
    stroke: currentColor !important;
    opacity: 1 !important;
    visibility: visible !important;
  }
  .mobile-topbar .hamburger:active,
  #mobileHamburger:active {
    background: #E5E7EB !important;
  }
}

/* === typography normalization and tip label fix 2026-05-05 === */
:root {
  --mtr-type-display: 28px;
  --mtr-type-title: 20px;
  --mtr-type-section: 17px;
  --mtr-type-body: 14px;
  --mtr-type-meta: 13px;
  --mtr-type-caption: 12px;
  --mtr-type-micro: 11px;
  --mtr-line-tight: 1.25;
  --mtr-line-base: 1.5;
}

.type-display, .type-page-title { font-size: var(--mtr-type-display) !important; line-height: var(--mtr-line-tight) !important; letter-spacing: -0.04em !important; font-weight: 900 !important; }
.type-title, .type-card-title { font-size: var(--mtr-type-title) !important; line-height: 1.32 !important; letter-spacing: -0.025em !important; font-weight: 800 !important; }
.type-section, .type-field-title { font-size: var(--mtr-type-section) !important; line-height: 1.35 !important; font-weight: 800 !important; }
.type-body { font-size: var(--mtr-type-body) !important; line-height: var(--mtr-line-base) !important; }
.type-meta { font-size: var(--mtr-type-meta) !important; line-height: 1.45 !important; }
.type-caption { font-size: var(--mtr-type-caption) !important; line-height: 1.45 !important; }
.type-micro { font-size: var(--mtr-type-micro) !important; line-height: 1.35 !important; }

.help-tip {
  display: grid !important;
  grid-template-columns: auto minmax(0, 1fr) !important;
  align-items: start !important;
  gap: 10px !important;
  padding: 12px 14px !important;
  border-radius: 14px !important;
  font-size: var(--mtr-type-body) !important;
  line-height: var(--mtr-line-base) !important;
  word-break: keep-all !important;
  overflow-wrap: anywhere !important;
}
.help-tip strong {
  display: inline-flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 34px !important;
  flex: 0 0 auto !important;
  white-space: nowrap !important;
  word-break: normal !important;
  overflow-wrap: normal !important;
  letter-spacing: .04em !important;
  font-size: var(--mtr-type-meta) !important;
  line-height: 1.2 !important;
  font-weight: 900 !important;
}
.help-tip span { min-width: 0 !important; }

.alert, .gf-alert, .page-help, .help-content,
.help-content p, .help-content li,
.panel, .card, .gf-card, .form-card,
.product-edit-grid, .preview-card,
.data-table td, .product-list-table td {
  font-size: var(--mtr-type-body) !important;
  line-height: var(--mtr-line-base) !important;
}

.masthead h1, .page-header h1, .admin-page-header h1,
h1.page-title, .page-title {
  font-size: var(--mtr-type-display) !important;
  line-height: var(--mtr-line-tight) !important;
  letter-spacing: -0.04em !important;
  font-weight: 900 !important;
}
.panel h2, .card h2, .gf-card h2, .form-card h2,
.gf-section-title, .form-section-title,
.page-help-title {
  font-size: var(--mtr-type-section) !important;
  line-height: 1.35 !important;
  font-weight: 800 !important;
}
.panel h3, .card h3, .gf-card h3, .form-card h3 {
  font-size: var(--mtr-type-body) !important;
  line-height: 1.4 !important;
  font-weight: 800 !important;
}
label, .form-label, .gf-check-title,
.product-name, .name-cell .product-name {
  font-size: var(--mtr-type-body) !important;
  line-height: 1.4 !important;
}
.form-help, .form-hint, .gf-hint, .text-muted, .muted,
.desc-meta, .desc-status, .gf-check-meta,
.product-meta-line, .ai-gallery-empty,
small {
  font-size: var(--mtr-type-caption) !important;
  line-height: 1.45 !important;
}
.badge, .ai-inline-badge, .ai-kind-badge, .brand-pill, .status,
.product-list-table th, .data-table th,
.text-mono, code {
  font-size: var(--mtr-type-caption) !important;
  line-height: 1.3 !important;
}
.btn, button, .btn-primary, .btn-ghost, .toolbar-btn {
  font-size: var(--mtr-type-body) !important;
  line-height: 1.25 !important;
}
.btn-sm, .api-card-actions .btn {
  font-size: var(--mtr-type-caption) !important;
}

@media (max-width: 820px) {
  :root {
    --mtr-type-display: 26px;
    --mtr-type-title: 19px;
    --mtr-type-section: 17px;
    --mtr-type-body: 14px;
    --mtr-type-meta: 13px;
    --mtr-type-caption: 12px;
    --mtr-type-micro: 11px;
  }
  .help-tip {
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
  }
  .help-tip strong {
    min-width: 34px !important;
    white-space: nowrap !important;
  }
  input, select, textarea,
  .form-input, .form-select, .form-textarea,
  .desc-textarea {
    font-size: 16px !important;
    line-height: 1.4 !important;
  }
}

@media (max-width: 430px) {
  :root {
    --mtr-type-display: 25px;
    --mtr-type-title: 18px;
    --mtr-type-section: 16px;
    --mtr-type-body: 14px;
    --mtr-type-meta: 13px;
    --mtr-type-caption: 12px;
    --mtr-type-micro: 11px;
  }
}

/* === mobile hamburger minimal brand color 2026-05-05 === */
@media (max-width: 820px) {
  .mobile-topbar .hamburger,
  #mobileHamburger {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 42px !important;
    height: 42px !important;
    flex: 0 0 42px !important;
    color: var(--primary) !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    border-radius: 0 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }
  .mobile-topbar .hamburger svg,
  #mobileHamburger svg {
    display: block !important;
    width: 29px !important;
    height: 29px !important;
    color: var(--primary) !important;
    stroke: currentColor !important;
    stroke-width: 2.2 !important;
    opacity: 1 !important;
    visibility: visible !important;
  }
  .mobile-topbar .hamburger:active,
  #mobileHamburger:active {
    background: transparent !important;
    opacity: .72 !important;
  }
}

/* === mobile minimum readable font size 2026-05-05 === */
@media (max-width: 820px) {
  :root {
    --mtr-type-caption: 13px;
    --mtr-type-micro: 13px;
  }
  .main-content :where(p, span, small, li, label, a, button, td, th, strong, em, code, div),
  .admin-main :where(p, span, small, li, label, a, button, td, th, strong, em, code, div),
  main :where(p, span, small, li, label, a, button, td, th, strong, em, code, div) {
    font-size: max(13px, 1em) !important;
  }
  .stat-label,
  .stat-sub,
  .wf-pipeline-title,
  .wf-step-num,
  .wf-stage-label,
  .form-help,
  .form-hint,
  .gf-hint,
  .text-muted,
  .muted,
  .desc-meta,
  .desc-status,
  .product-meta-line,
  .badge,
  .ai-inline-badge,
  .brand-pill,
  .status,
  .data-table th,
  .product-list-table th,
  .data-table td,
  .product-list-table td,
  .text-mono,
  code,
  small {
    font-size: 13px !important;
    line-height: 1.45 !important;
  }
  .btn-sm,
  .page-actions .btn,
  .api-card-actions .btn {
    font-size: 13px !important;
  }
}

/* === mobile label and step font unification 2026-05-05 === */
@media (max-width: 820px) {
  .main-content label,
  .main-content .form-label,
  .main-content .form-section-title,
  .main-content .gf-section-title,
  .main-content .panel h2,
  .main-content .panel h3,
  .main-content .card h2,
  .main-content .card h3,
  .main-content .gf-card h2,
  .main-content .gf-card h3,
  .main-content .page-help-title,
  .main-content .wf-lbl,
  .main-content .wf-step,
  .main-content .wf-step span,
  .main-content .wf-stage-label,
  .main-content .dropzone-title,
  .main-content .help-toggle-label,
  .admin-main label,
  .admin-main .form-label,
  .admin-main .form-section-title,
  .admin-main .gf-section-title,
  .admin-main .panel h2,
  .admin-main .panel h3,
  .admin-main .card h2,
  .admin-main .card h3,
  .admin-main .gf-card h2,
  .admin-main .gf-card h3,
  .admin-main .page-help-title,
  .admin-main .wf-lbl,
  .admin-main .wf-step,
  .admin-main .wf-step span,
  .admin-main .wf-stage-label,
  .admin-main .dropzone-title,
  .admin-main .help-toggle-label {
    font-size: 16px !important;
    line-height: 1.4 !important;
    font-weight: 800 !important;
    letter-spacing: -0.015em !important;
  }

  .main-content .wf-num,
  .main-content .wf-step-num,
  .main-content .menu-step,
  .admin-main .wf-num,
  .admin-main .wf-step-num,
  .admin-main .menu-step {
    font-size: 13px !important;
    line-height: 1 !important;
    letter-spacing: 0 !important;
  }

  .main-content input,
  .main-content select,
  .main-content textarea,
  .main-content .form-input,
  .main-content .form-select,
  .main-content .form-textarea,
  .main-content .btn,
  .main-content button,
  .admin-main input,
  .admin-main select,
  .admin-main textarea,
  .admin-main .form-input,
  .admin-main .form-select,
  .admin-main .form-textarea,
  .admin-main .btn,
  .admin-main button {
    font-size: 16px !important;
  }

  .main-content .form-help,
  .main-content .form-hint,
  .main-content .gf-hint,
  .main-content .text-muted,
  .main-content .muted,
  .main-content small,
  .main-content label span,
  .admin-main .form-help,
  .admin-main .form-hint,
  .admin-main .gf-hint,
  .admin-main .text-muted,
  .admin-main .muted,
  .admin-main small,
  .admin-main label span {
    font-size: 13px !important;
    line-height: 1.45 !important;
    font-weight: 500 !important;
    letter-spacing: 0 !important;
  }
}

/* === mobile no-awkward-label-wrap and masthead spacing 2026-05-05 === */
@media (max-width: 820px) {
  .masthead-titles,
  .masthead .masthead-titles {
    display: flex !important;
    flex-direction: row !important;
    align-items: baseline !important;
    flex-wrap: wrap !important;
    column-gap: 10px !important;
    row-gap: 6px !important;
  }
  .masthead-title,
  .masthead .masthead-title {
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    flex: 0 0 auto !important;
  }
  .masthead-sub,
  .masthead-context,
  .page-subtitle,
  .masthead .masthead-sub,
  .masthead .masthead-context {
    margin-left: 2px !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
    flex: 0 0 auto !important;
  }
  .masthead .wf-breadcrumb,
  .wf-breadcrumb {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    white-space: nowrap !important;
    -webkit-overflow-scrolling: touch !important;
  }
  .wf-step,
  .wf-lbl,
  .wf-stage-label,
  .wf-pipeline-title,
  .gf-section-title,
  .form-section-title,
  .dropzone-title,
  .help-toggle-label,
  .panel h2,
  .panel h3,
  .card h2,
  .card h3,
  .gf-card h2,
  .gf-card h3,
  label,
  .form-label,
  .btn,
  button,
  .btn-sm,
  .page-actions .btn,
  .badge,
  .ai-inline-badge,
  .brand-pill,
  .status,
  .menu-main,
  .menu-main-only {
    word-break: keep-all !important;
    overflow-wrap: normal !important;
  }
  .wf-lbl,
  .wf-stage-label,
  .wf-pipeline-title,
  .dropzone-title,
  .btn,
  button,
  .btn-sm,
  .page-actions .btn,
  .badge,
  .ai-inline-badge,
  .brand-pill,
  .status,
  .menu-main,
  .menu-main-only {
    white-space: nowrap !important;
  }
  .wf-stage-card {
    min-width: 0 !important;
  }
  .wf-stage-label {
    max-width: 100% !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
  }
  .alert strong,
  .help-tip strong {
    white-space: nowrap !important;
    word-break: keep-all !important;
  }
  .alert {
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
  }
}

/* === mobile short metric labels stay on one line 2026-05-05 === */
@media (max-width: 820px) {
  .stat-label,
  .metric-label,
  .kpi-label,
  .summary-label,
  .dashboard-stat-label,
  .activity-time,
  .activity-status,
  .activity-label > div,
  .wf-step-num,
  .wf-num,
  .wf-stage-count,
  .list-count,
  .card-head-row h2,
  .card-head-row h3 {
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
  }
  .stat-label,
  .metric-label,
  .kpi-label,
  .summary-label,
  .dashboard-stat-label {
    font-size: 13px !important;
    line-height: 1.35 !important;
  }
}

/* === global short label nowrap polish 2026-05-05 === */
.masthead-titles { column-gap: 10px !important; row-gap: 6px !important; }
.masthead-title,
.masthead-sub,
.masthead-context,
.page-subtitle,
.stat-label,
.metric-label,
.kpi-label,
.summary-label,
.dashboard-stat-label,
.stat-sub,
.wf-lbl,
.wf-step,
.wf-stage-label,
.wf-step-num,
.wf-num,
.wf-stage-count,
.badge,
.ai-inline-badge,
.brand-pill,
.status,
.btn,
.btn-sm,
button,
.dropzone-title,
.form-section-title,
.gf-section-title,
.card-head-row h2,
.card-head-row h3,
.list-count {
  white-space: nowrap !important;
  word-break: keep-all !important;
  overflow-wrap: normal !important;
}
.wf-stage-label,
.stat-label,
.metric-label,
.kpi-label,
.summary-label,
.dashboard-stat-label {
  max-width: 100% !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

/* === mobile form control size refinement 2026-05-05 === */
@media (max-width: 820px) {
  .main-content input,
  .main-content select,
  .main-content textarea,
  .main-content .form-input,
  .main-content .form-select,
  .main-content .form-textarea,
  .admin-main input,
  .admin-main select,
  .admin-main textarea,
  .admin-main .form-input,
  .admin-main .form-select,
  .admin-main .form-textarea {
    font-size: 15px !important;
    line-height: 1.4 !important;
  }

  .main-content .btn,
  .main-content button,
  .main-content .btn-sm,
  .main-content .page-actions .btn,
  .admin-main .btn,
  .admin-main button,
  .admin-main .btn-sm,
  .admin-main .page-actions .btn {
    font-size: 14px !important;
    line-height: 1.25 !important;
    letter-spacing: -0.01em !important;
  }

  .main-content .btn-primary,
  .main-content .gf-submit,
  .main-content .form-actions .btn,
  .main-content .sourcing-action-ai,
  .admin-main .btn-primary,
  .admin-main .gf-submit,
  .admin-main .form-actions .btn,
  .admin-main .sourcing-action-ai {
    font-size: 15px !important;
  }

  .main-content .form-row button,
  .main-content .form-grid-2 button,
  .main-content .dropzone-buttons .btn,
  .main-content .photo-btn,
  .admin-main .form-row button,
  .admin-main .form-grid-2 button,
  .admin-main .dropzone-buttons .btn,
  .admin-main .photo-btn {
    font-size: 14px !important;
    font-weight: 800 !important;
  }
}

/* === mobile comprehensive page polish 2026-05-05 === */
@media (max-width: 820px) {
  [style*="grid-template-columns:repeat(4"],
  [style*="grid-template-columns: repeat(4"],
  [style*="grid-template-columns:repeat(5"],
  [style*="grid-template-columns: repeat(5"],
  [style*="grid-template-columns:repeat(6"],
  [style*="grid-template-columns: repeat(6"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }

  .stat-grid,
  .kpi-grid,
  .summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }
  .stat-card,
  .kpi-card,
  .summary-card {
    padding: 16px 14px !important;
    border-radius: 18px !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: flex-start !important;
    gap: 6px !important;
  }
  .stat-card .stat-label,
  .kpi-card .kpi-label,
  .summary-card .summary-label {
    font-size: 13px !important;
    line-height: 1.35 !important;
    font-weight: 700 !important;
    color: #6B7280 !important;
    white-space: normal !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    min-height: 36px !important;
    max-width: 100% !important;
  }
  .stat-card .stat-value,
  .kpi-card .kpi-value {
    font-size: 26px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    letter-spacing: -0.03em !important;
  }
  .stat-card .stat-sub,
  .kpi-card .kpi-sub {
    font-size: 12px !important;
    color: #9CA3AF !important;
    font-weight: 500 !important;
    margin-top: 0 !important;
  }

  .wf-stages {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
  .wf-stage-card {
    padding: 14px 10px !important;
    border-radius: 16px !important;
    min-height: 0 !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 4px !important;
  }
  .wf-stage-card .wf-stage-icon {
    width: 22px !important;
    height: 22px !important;
    margin-bottom: 2px !important;
  }
  .wf-stage-card .wf-stage-icon svg {
    width: 22px !important;
    height: 22px !important;
  }
  .wf-stage-card .wf-step-num {
    font-size: 11px !important;
    color: #9CA3AF !important;
    font-weight: 700 !important;
    letter-spacing: 0.08em !important;
  }
  .wf-stage-card .wf-stage-label {
    font-size: 14px !important;
    line-height: 1.25 !important;
    font-weight: 800 !important;
    color: #1F2937 !important;
    text-align: center !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
    white-space: normal !important;
  }
  .wf-stage-card .wf-stage-count {
    font-size: 22px !important;
    line-height: 1.1 !important;
    font-weight: 900 !important;
    margin-top: 2px !important;
  }

  .activity-feed {
    margin: 0 0 0 -4px !important;
    padding: 0 !important;
    list-style: none !important;
  }
  .activity-item {
    display: grid !important;
    grid-template-columns: 8px minmax(0, 1fr) auto !important;
    align-items: center !important;
    gap: 10px !important;
    padding: 12px 0 !important;
    border-bottom: 1px solid #F3F4F6 !important;
  }
  .activity-item:last-child { border-bottom: 0 !important; }
  .activity-dot {
    width: 8px !important;
    height: 8px !important;
    border-radius: 999px !important;
    background: var(--primary) !important;
  }
  .activity-label > div:first-child {
    font-size: 14px !important;
    font-weight: 700 !important;
    color: #1F2937 !important;
    line-height: 1.35 !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }
  .activity-label > div:last-child {
    font-size: 13px !important;
    color: #6B7280 !important;
    font-weight: 500 !important;
    margin-top: 2px !important;
  }
  .activity-time {
    font-size: 12px !important;
    color: #9CA3AF !important;
    font-weight: 500 !important;
    white-space: nowrap !important;
  }

  .data-table:not(.product-list-table) {
    font-size: 14px !important;
  }

  .panel,
  .card,
  .gf-card,
  .form-card,
  .help-box {
    padding: 18px !important;
    border-radius: 18px !important;
    box-shadow: 0 6px 20px rgba(15,23,42,.04) !important;
  }
  .panel + .panel,
  .card + .card,
  .gf-card + .gf-card {
    margin-top: 14px !important;
  }
  .page-container > * + * {
    margin-top: 14px !important;
  }

  .alert {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
    margin-bottom: 14px !important;
  }
  .alert strong {
    margin-right: 4px !important;
  }

  .masthead {
    padding: 14px 0 12px !important;
    margin: 6px 0 14px !important;
    row-gap: 6px !important;
    column-gap: 10px !important;
  }
  .masthead-title {
    font-size: 26px !important;
    line-height: 1.2 !important;
    letter-spacing: -0.04em !important;
    font-weight: 900 !important;
  }
  .masthead-sub {
    font-size: 13px !important;
    color: #6B7280 !important;
    font-weight: 600 !important;
  }
  .masthead-context {
    font-size: 12px !important;
    color: #9CA3AF !important;
    font-weight: 500 !important;
  }

  .wf-breadcrumb {
    display: flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 8px 4px !important;
  }
  .wf-step {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 6px 10px !important;
    border-radius: 999px !important;
    background: #F3F4F6 !important;
  }
  .wf-step.is-current {
    background: #FAEFD7 !important;
  }
  .wf-num {
    width: 22px !important;
    height: 22px !important;
    font-size: 11px !important;
  }
  .wf-lbl {
    font-size: 13px !important;
    line-height: 1.25 !important;
  }
  .wf-arrow {
    font-size: 12px !important;
    color: #D1D5DB !important;
  }

  .empty-state {
    padding: 36px 18px !important;
    border-radius: 18px !important;
    gap: 10px !important;
  }
  .empty-state-icon {
    width: 48px !important;
    height: 48px !important;
    border-radius: 16px !important;
  }
  .empty-state h3 {
    font-size: 16px !important;
    line-height: 1.3 !important;
    font-weight: 800 !important;
  }
  .empty-state p {
    font-size: 13px !important;
    color: #6B7280 !important;
    line-height: 1.5 !important;
  }

  .pagination {
    gap: 6px !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    padding: 16px 0 8px !important;
  }
  .pagination a,
  .pagination span,
  .pagination strong {
    min-width: 38px !important;
    min-height: 38px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    padding: 8px 10px !important;
  }

  .filter-row,
  .filters,
  .toolbar-filters {
    display: grid !important;
    grid-template-columns: 1fr !important;
    gap: 10px !important;
    margin-bottom: 14px !important;
  }
  .filter-row > *,
  .filters > * {
    width: 100% !important;
    min-width: 0 !important;
  }

  .card-head-row {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 10px !important;
    flex-wrap: wrap !important;
    margin-bottom: 12px !important;
  }
  .card-head-row h2,
  .card-head-row h3,
  .list-count {
    font-size: 16px !important;
    line-height: 1.35 !important;
    font-weight: 800 !important;
    margin: 0 !important;
  }

  .api-card,
  .vendor-card,
  .brand-card,
  .persona-card,
  .scene-card,
  .saas-card,
  .trash-card {
    padding: 16px !important;
    border-radius: 18px !important;
  }
  .api-card-actions {
    display: flex !important;
    flex-wrap: wrap !important;
    gap: 8px !important;
    margin-top: 10px !important;
  }
  .api-card-actions .btn {
    flex: 1 1 auto !important;
    min-height: 38px !important;
    padding: 8px 12px !important;
  }

  .sourcing-card {
    padding: 14px !important;
    border-radius: 18px !important;
    gap: 10px !important;
  }
  .sourcing-meta {
    font-size: 13px !important;
    line-height: 1.45 !important;
    color: #6B7280 !important;
  }
  .sourcing-memo {
    font-size: 13px !important;
    line-height: 1.5 !important;
    color: #4B5563 !important;
  }
  .sourcing-actions {
    margin-top: 12px !important;
    gap: 8px !important;
  }
  .sourcing-action-ai,
  .sourcing-action-edit,
  .sourcing-action-trash {
    width: 100% !important;
    min-height: 42px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    font-weight: 800 !important;
  }
  .sourcing-action-trash {
    color: #DC2626 !important;
    border-color: #FCA5A5 !important;
  }

  .qc-thumb {
    border-radius: 14px !important;
  }
  .just-passed-badge {
    font-size: 11px !important;
    padding: 4px 8px !important;
    border-radius: 999px !important;
  }
  .qc-pipeline > a > div {
    padding: 12px !important;
    border-radius: 16px !important;
  }
  .qc-pipeline > a > div:nth-child(2) {
    flex-direction: row !important;
    align-items: baseline !important;
    gap: 6px !important;
  }
  .qc-pipeline > a > div:nth-child(2) > span:first-child {
    font-size: 22px !important;
    font-weight: 900 !important;
  }

  .product-edit-grid {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  .preview-card,
  .desc-textarea {
    font-size: 14px !important;
    line-height: 1.7 !important;
    border-radius: 14px !important;
  }
  .desc-toolbar,
  .passed-actions {
    gap: 8px !important;
  }
  .image-thumbs,
  .ai-passed-strip {
    gap: 8px !important;
  }

  .help-toggle {
    padding: 12px 14px !important;
    font-size: 15px !important;
  }
  .help-content {
    padding: 0 14px 14px !important;
    font-size: 14px !important;
    line-height: 1.6 !important;
  }
  .help-content ol,
  .help-content ul {
    margin: 8px 0 8px 18px !important;
    padding: 0 !important;
  }
  .help-content li {
    padding: 4px 0 !important;
  }
  .help-tip {
    margin-top: 12px !important;
    padding: 12px 14px !important;
    border-radius: 12px !important;
    font-size: 14px !important;
    line-height: 1.5 !important;
  }

  .mobile-topbar .brand,
  .mobile-topbar .brand strong {
    font-size: 15px !important;
    font-weight: 900 !important;
    letter-spacing: -0.01em !important;
  }
}

@media (max-width: 430px) {
  .masthead-title { font-size: 24px !important; }
  .stat-card { padding: 14px !important; }
  .stat-card .stat-value, .kpi-card .kpi-value { font-size: 24px !important; }
  .wf-stage-card .wf-stage-count { font-size: 20px !important; }
  .panel, .card, .gf-card, .form-card { padding: 16px !important; }
}

/* === mobile per-page inline override 2026-05-05 === */
@media (max-width: 820px) {
  [style*="grid-template-columns:1fr 340px"],
  [style*="grid-template-columns:1fr 360px"],
  [style*="grid-template-columns:1fr 380px"],
  [style*="grid-template-columns:340px 1fr"],
  [style*="grid-template-columns:360px 1fr"],
  [style*="grid-template-columns:380px 1fr"] {
    grid-template-columns: 1fr !important;
    gap: 14px !important;
  }
  [style*="grid-template-columns:repeat(auto-fill,minmax(200px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(200px"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }
  [style*="grid-template-columns:repeat(auto-fill,minmax(120px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(120px"] {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .main-content [style*="font-size:9px"],
  .main-content [style*="font-size: 9px"],
  .main-content [style*="font-size:10px"],
  .main-content [style*="font-size: 10px"],
  .main-content [style*="font-size:11px"],
  .main-content [style*="font-size: 11px"],
  .main-content [style*="font-size:12px"],
  .main-content [style*="font-size: 12px"],
  .main-content [style*="font-size:12.5px"],
  .main-content [style*="font-size: 12.5px"],
  .admin-main [style*="font-size:9px"],
  .admin-main [style*="font-size: 9px"],
  .admin-main [style*="font-size:10px"],
  .admin-main [style*="font-size: 10px"],
  .admin-main [style*="font-size:11px"],
  .admin-main [style*="font-size: 11px"],
  .admin-main [style*="font-size:12px"],
  .admin-main [style*="font-size: 12px"] {
    font-size: 13px !important;
  }
  .main-content [style*="font-size:13px"],
  .main-content [style*="font-size: 13px"],
  .admin-main [style*="font-size:13px"],
  .admin-main [style*="font-size: 13px"] {
    font-size: 14px !important;
  }

  .main-content [style*="font-size:14px"][style*="font-weight:700"],
  .admin-main [style*="font-size:14px"][style*="font-weight:700"] {
    font-size: 15px !important;
  }

  .main-content [style*="width:48px;height:64px"],
  .main-content [style*="width:48px; height:64px"] {
    width: 64px !important;
    height: 84px !important;
  }
  .main-content [style*="width:56px;height:74px"],
  .main-content [style*="width:56px; height:74px"] {
    width: 64px !important;
    height: 84px !important;
  }
  .main-content [style*="width:64px;height:84px"],
  .main-content [style*="width:64px; height:84px"] {
    width: 72px !important;
    height: 96px !important;
  }

  .main-content [style*="min-width:150px"],
  .main-content [style*="min-width: 150px"],
  .admin-main [style*="min-width:150px"],
  .admin-main [style*="min-width: 150px"] {
    min-width: 0 !important;
    width: 100% !important;
  }
  .main-content [style*="min-width:260px"],
  .main-content [style*="min-width: 260px"],
  .admin-main [style*="min-width:260px"],
  .admin-main [style*="min-width: 260px"] {
    min-width: 0 !important;
  }

  .main-content [style*="width:190px"],
  .main-content [style*="width: 190px"] {
    width: 100% !important;
  }

  /* alert/info banners with custom inline */
  .main-content [style*="background:var(--color-info-soft)"][style*="border-left"],
  .main-content [style*="background:#ECFDF5"][style*="border-left"],
  .main-content [style*="background:#FEF2F2"][style*="border-left"],
  .main-content [style*="background:#FFFBEB"][style*="border-left"],
  .main-content [style*="background:#F0F9FF"][style*="border-left"] {
    padding: 14px 16px !important;
    border-radius: 14px !important;
    font-size: 14px !important;
    line-height: 1.55 !important;
  }

  /* sticky filter on dispatch becomes not sticky on mobile - too tall */
  .main-content [style*="position:sticky"][style*="top:0"] {
    position: static !important;
  }

  /* full-screen modals */
  .main-content [style*="width:min(520px"] {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 18px !important;
    padding: 18px !important;
  }

  /* qc-review category navigation */
  .main-content [style*="overflow-x:auto"][style*="display:flex"] {
    gap: 8px !important;
    padding: 6px 0 10px !important;
  }
  .main-content [style*="overflow-x:auto"][style*="display:flex"] > * {
    flex: 0 0 auto !important;
  }

  /* qc-review per-card padding */
  .qc-thumb [style*="padding: var(--space-1)"] {
    padding: 10px !important;
  }

  /* product edit image overlay buttons remain compact but readable */
  .main-content [style*="padding:6px 8px"][style*="border-radius:4px"] {
    padding: 8px 10px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
  }

  /* sourcing card upload thumbnail title */
  .main-content [style*="font-size:18px"] {
    font-size: 17px !important;
    line-height: 1.3 !important;
  }
}

/* generic tightening for very narrow phones */
@media (max-width: 390px) {
  .stat-grid, .kpi-grid { gap: 10px !important; }
  .stat-card { padding: 14px 12px !important; }
  .stat-card .stat-value, .kpi-card .kpi-value { font-size: 22px !important; }
  .wf-stage-card .wf-stage-count { font-size: 20px !important; }
  .panel, .card, .gf-card, .form-card, .help-box { padding: 14px !important; border-radius: 16px !important; }
  .masthead-title { font-size: 22px !important; }
}

/* === mobile final UX touches 2026-05-05 === */
@media (max-width: 820px) {
  /* products/edit overlay actions: always visible, full row */
  .passed-card { overflow: visible !important; }
  .passed-actions {
    position: static !important;
    opacity: 1 !important;
    background: transparent !important;
    padding: 8px !important;
    gap: 6px !important;
    display: flex !important;
    flex-wrap: wrap !important;
  }
  .passed-actions [type="button"],
  .passed-actions button,
  .passed-actions .btn {
    flex: 1 1 auto !important;
    min-height: 36px !important;
    padding: 8px 10px !important;
    border-radius: 8px !important;
    font-size: 13px !important;
    font-weight: 800 !important;
    letter-spacing: 0 !important;
  }

  /* cropped-card overlay/cropped badge made always visible */
  .cropped-card .cropped-badge { opacity: 1 !important; }

  /* qc-review pipeline tabs - readable + spacing */
  .qc-pipeline {
    gap: 8px !important;
    padding: 6px 0 12px !important;
  }
  .qc-pipeline > a > div:first-child,
  .qc-pipeline > a {
    min-width: 120px !important;
    padding: 12px 14px !important;
    border-radius: 14px !important;
  }
  .qc-pipeline > a > div > div:first-child { font-size: 14px !important; line-height: 1.3 !important; }
  .qc-pipeline > a span[style*="font-size:24px"] { font-size: 22px !important; }

  /* sourcing dropzone label & buttons */
  .dropzone {
    padding: 22px 16px !important;
    border-radius: 18px !important;
    min-height: 140px !important;
  }
  .dropzone-title {
    font-size: 15px !important;
    line-height: 1.4 !important;
  }
  .dropzone-sub {
    font-size: 13px !important;
    line-height: 1.5 !important;
  }

  /* product list table area: ensure no horizontal overflow */
  .product-list-page .product-list-table { font-size: 14px !important; }
  .product-list-page .filter-bar input,
  .product-list-page .filter-bar select {
    height: 42px !important;
    border-radius: 12px !important;
  }
  .product-list-page .filter-bar .btn {
    height: 42px !important;
    border-radius: 12px !important;
  }

  /* uniform tap targets */
  a, button, .btn, .photo-btn, .sourcing-action-ai, .sourcing-action-edit, .sourcing-action-trash {
    min-height: 38px !important;
  }
  .data-table a, .data-table button, .data-table .btn {
    min-height: 0 !important;
  }

  /* dispatch product card image: bigger thumbnail */
  .dispatch-product-card .thumb,
  .dispatch-product-card img:not(.opt-example) {
    border-radius: 10px !important;
  }

  /* AI ????/?? dark crop editor: stack elements vertically when too narrow */
  #qcrop-toolbar,
  #qcrop-toolbar > div,
  #qcrop-stage + div {
    flex-wrap: wrap !important;
    overflow-x: auto !important;
    gap: 8px !important;
  }

  /* image edit modal: full screen on mobile */
  #aiedit-modal > div,
  #aiedit-modal [style*="max-width:560px"] {
    max-width: 100% !important;
    border-radius: 18px 18px 0 0 !important;
    max-height: 92vh !important;
  }

  /* sourcing modal width 360 too */
  [style*="width:min(360px"] {
    width: 100% !important;
    max-width: 100% !important;
    border-radius: 18px !important;
    padding: 18px !important;
  }

  /* uniformly smooth scroll */
  html { scroll-behavior: smooth; }
}

/* === mobile secondary page polish 2026-05-05 === */
@media (max-width: 820px) {
  /* persona/scene/b2b card grids */
  [style*="grid-template-columns:repeat(auto-fill,minmax(260px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(260px"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(280px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(280px"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(300px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(300px"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(320px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(320px"] {
    grid-template-columns: 1fr !important;
    gap: 12px !important;
  }
  [style*="grid-template-columns:repeat(auto-fill,minmax(180px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(180px"],
  [style*="grid-template-columns:repeat(auto-fill,minmax(160px"],
  [style*="grid-template-columns:repeat(auto-fill, minmax(160px"] {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 10px !important;
  }

  /* small-hint inline width selects */
  .main-content select[style*="height:28px"],
  .admin-main select[style*="height:28px"] {
    height: 40px !important;
    font-size: 14px !important;
    padding: 0 10px !important;
    border-radius: 10px !important;
  }
  .main-content select[style*="width:64px"],
  .admin-main select[style*="width:64px"] {
    width: 84px !important;
    font-size: 14px !important;
    padding: 8px 10px !important;
  }

  /* var(--font-caption-size), var(--font-label-size) on inline mostly */
  .main-content [style*="font-size: var(--font-caption-size)"],
  .main-content [style*="font-size:var(--font-caption-size)"],
  .admin-main [style*="font-size: var(--font-caption-size)"],
  .admin-main [style*="font-size:var(--font-caption-size)"] {
    font-size: 13px !important;
  }
  .main-content [style*="font-size: var(--font-label-size)"],
  .main-content [style*="font-size:var(--font-label-size)"],
  .admin-main [style*="font-size: var(--font-label-size)"],
  .admin-main [style*="font-size:var(--font-label-size)"] {
    font-size: 14px !important;
  }
  .main-content [style*="font-size: var(--font-body-size)"],
  .main-content [style*="font-size:var(--font-body-size)"],
  .admin-main [style*="font-size: var(--font-body-size)"],
  .admin-main [style*="font-size:var(--font-body-size)"] {
    font-size: 15px !important;
    font-weight: 800 !important;
  }
  .main-content [style*="font-size: var(--font-display-size)"],
  .main-content [style*="font-size:var(--font-display-size)"],
  .admin-main [style*="font-size: var(--font-display-size)"],
  .admin-main [style*="font-size:var(--font-display-size)"] {
    font-size: 22px !important;
    font-weight: 900 !important;
  }
  .main-content [style*="font-size: var(--font-heading-size)"],
  .admin-main [style*="font-size: var(--font-heading-size)"] {
    font-size: 18px !important;
  }

  /* persona/scene cards: nicer padding/border */
  .main-content [style*="background:var(--surface-primary)"][style*="border-radius: var(--radius-lg)"],
  .admin-main [style*="background:var(--surface-primary)"][style*="border-radius: var(--radius-lg)"] {
    padding: 16px !important;
    border-radius: 18px !important;
    box-shadow: 0 6px 20px rgba(15,23,42,.04) !important;
  }

  /* persona tab nav */
  .main-content a[href*="?tab="][style*="padding:10px 16px"] {
    padding: 10px 14px !important;
    font-size: 14px !important;
  }

  /* trash table: thumb cell stays comfortable */
  .product-list-page .product-list-table td .thumb,
  .product-list-page .product-list-table td img {
    width: 64px !important;
    height: 84px !important;
    border-radius: 10px !important;
  }

  /* admin form inputs (b2b) */
  .main-content input[style*="padding:10px"][style*="border-radius: var(--radius)"],
  .main-content textarea[style*="padding:10px"][style*="border-radius: var(--radius)"] {
    padding: 12px !important;
    font-size: 15px !important;
    border-radius: 12px !important;
    min-height: 44px !important;
  }
  .main-content label[style*="padding:10px"][style*="border-radius: var(--radius)"] {
    padding: 12px 14px !important;
    border-radius: 14px !important;
  }

  /* progress bars stay slim */
  .main-content [style*="height:6px"][style*="border-radius: var(--radius-sm)"] {
    height: 8px !important;
    border-radius: 999px !important;
  }
}

/* === mobile final wrap policy 2026-05-05 (must be last) === */
@media (max-width: 820px) {
  /* Labels & titles: allow up to 2-line wrap with Korean-friendly word-break */
  .stat-label,
  .metric-label,
  .kpi-label,
  .summary-label,
  .dashboard-stat-label,
  .wf-stage-label,
  .wf-pipeline-title,
  .wf-lbl,
  .activity-label > div:first-child,
  .activity-name,
  .product-name,
  .name-cell,
  .card-head-row h2,
  .card-head-row h3,
  .panel h2, .panel h3,
  .card h2, .card h3,
  .gf-card h2, .gf-card h3,
  .gf-section-title,
  .form-section-title,
  .dropzone-title,
  .help-toggle-label {
    white-space: normal !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
    text-overflow: clip !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    max-width: 100% !important;
  }

  /* Numeric values stay single line, can shrink */
  .stat-value,
  .kpi-value,
  .summary-value,
  .wf-stage-count {
    white-space: nowrap !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }

  /* Short pills/chips/badges/dates/buttons: keep nowrap */
  .badge,
  .ai-inline-badge,
  .ai-kind-badge,
  .brand-pill,
  .status,
  .stat-sub,
  .wf-step-num,
  .wf-num,
  .activity-time,
  .activity-status,
  .list-count,
  .masthead-context,
  .help-tip strong,
  .alert strong {
    white-space: nowrap !important;
    word-break: keep-all !important;
    overflow-wrap: normal !important;
  }

  /* Masthead title: usually short Korean phrases, allow wrap if needed */
  .masthead-title,
  .masthead .masthead-title,
  .masthead-sub,
  .masthead .masthead-sub {
    white-space: normal !important;
    word-break: keep-all !important;
    overflow-wrap: break-word !important;
  }
}

@media (max-width: 390px) {
  .stat-label,
  .kpi-label,
  .wf-stage-label {
    font-size: 12.5px !important;
    line-height: 1.3 !important;
  }
}

/* ============================================================
   Sellerina Color System v2 - Dashboard rollout
   Tokyo Couture Monochrome
   ============================================================ */
body {
  background: var(--surface) !important;
  color: var(--text-main) !important;
}
.main-content,
.page-container {
  background: transparent !important;
  color: var(--text-main) !important;
}

/* Sidebar */
.sidebar {
  background: var(--primary) !important;
  color: var(--surface) !important;
  border-right: 1px solid rgba(250, 250, 248, 0.06) !important;
}
.brand-icon,
.sidebar-brand .brand-icon {
  background: var(--surface) !important;
  color: var(--primary) !important;
  border-radius: var(--radius-sm) !important;
}
.brand-text small {
  color: var(--text-sub) !important;
}
.nav-section-title {
  color: var(--text-sub) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
}
.sidebar-link {
  color: var(--mid-tone) !important;
  border-left: 0 !important;
}
.sidebar-link svg {
  color: currentColor !important;
  opacity: 0.86 !important;
}
.sidebar-link:hover {
  background: rgba(250, 250, 248, 0.06) !important;
  color: var(--surface) !important;
}
.sidebar-link.active {
  background: rgba(250, 250, 248, 0.10) !important;
  color: var(--surface) !important;
  font-weight: 500 !important;
}
.sidebar-link.active svg,
.sidebar-link:hover svg {
  color: currentColor !important;
  opacity: 1 !important;
}
.menu-step {
  border-color: rgba(250, 250, 248, 0.14) !important;
  color: var(--mid-tone) !important;
}
.sidebar-link.active .menu-step,
.sidebar-link:hover .menu-step {
  color: var(--surface) !important;
  border-color: rgba(250, 250, 248, 0.22) !important;
}

/* Cards / panels */
.panel,
.card,
.stat-card,
.empty-state {
  background: var(--background) !important;
  border: 1px solid var(--border) !important;
  border-radius: 12px !important;
  box-shadow: none !important;
}
.panel:hover,
.card:hover,
.stat-card:hover {
  box-shadow: var(--shadow-sm) !important;
}
.panel-header,
.card-header {
  border-bottom-color: var(--border) !important;
}

/* KPI cards */
.stat-card::before {
  display: none !important;
}
.stat-label {
  color: var(--text-sub) !important;
  font-size: 11px !important;
  font-weight: 500 !important;
  letter-spacing: 0.06em !important;
  text-transform: uppercase !important;
}
.stat-value {
  color: var(--text-main) !important;
  font-size: 24px !important;
  font-weight: 500 !important;
}
.stat-sub {
  color: var(--mid-tone) !important;
  font-size: 12px !important;
  font-weight: 500 !important;
}

/* Workflow cards */
.wf-stage-card {
  background: var(--background) !important;
  border-color: var(--border) !important;
  color: var(--text-main) !important;
}
.wf-stage-card:hover:not(.is-external) {
  background: var(--background) !important;
  border-color: var(--mid-tone) !important;
  box-shadow: var(--shadow-sm) !important;
}
.wf-stage-card.is-external,
.wf-stage-card:has(.wf-stage-count.is-zero) {
  background: var(--surface) !important;
  color: var(--mid-tone) !important;
}
.wf-stage-card.is-bottleneck {
  background: var(--color-warning-soft) !important;
  border-color: var(--color-warning) !important;
}
.wf-stage-card.is-bottleneck-danger {
  background: var(--color-danger-soft) !important;
  border-color: var(--color-danger) !important;
}
.wf-step-num,
.wf-stage-icon,
.wf-stage-card.is-external .wf-stage-icon,
.wf-stage-card.is-external .wf-stage-label,
.wf-stage-count.is-zero,
.wf-stage-count.is-external {
  color: var(--mid-tone) !important;
}
.wf-stage-label,
.wf-stage-count {
  color: var(--text-main) !important;
}

/* Help box */
.help-box {
  background: var(--surface) !important;
  border: 1px solid var(--border) !important;
  border-left: 3px solid var(--primary) !important;
  border-radius: 0 8px 8px 0 !important;
}
.help-toggle {
  color: var(--text-main) !important;
  font-size: 16px !important;
  font-weight: 500 !important;
}
.help-content,
.help-content p,
.help-content li {
  color: var(--text-secondary) !important;
}
.help-content strong {
  color: var(--text-main) !important;
}
.help-tip {
  background: var(--background) !important;
  color: var(--text-secondary) !important;
  border: 1px solid var(--border) !important;
}

/* Buttons */
.btn-primary,
.btn-accent {
  background: var(--primary) !important;
  color: var(--text-inverse) !important;
  border: 1px solid var(--primary) !important;
}
.btn-primary:hover,
.btn-accent:hover {
  background: #2C2C2C !important;
  border-color: #2C2C2C !important;
}
.btn-secondary,
.btn:not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost) {
  background: var(--background) !important;
  color: var(--text-main) !important;
  border: 1px solid var(--border) !important;
}
.btn-secondary:hover,
.btn:not(.btn-primary):not(.btn-accent):not(.btn-danger):not(.btn-ghost):hover {
  background: var(--surface) !important;
  border-color: var(--mid-tone) !important;
}
.btn-ghost {
  background: transparent !important;
  color: var(--text-secondary) !important;
  border: 1px solid transparent !important;
}
.btn-ghost:hover {
  background: var(--surface-overlay) !important;
  color: var(--text-main) !important;
}
.btn-danger {
  background: var(--color-danger) !important;
  color: var(--text-inverse) !important;
  border: 1px solid var(--color-danger) !important;
}

/* Forms */
input,
select,
textarea,
.input,
.select,
.textarea,
.form-input,
.form-select,
.form-textarea {
  background: var(--background) !important;
  border-color: var(--border) !important;
  color: var(--text-main) !important;
}
input::placeholder,
textarea::placeholder,
.form-input::placeholder,
.form-textarea::placeholder {
  color: var(--text-tertiary) !important;
}
input:hover,
select:hover,
textarea:hover,
.input:hover,
.select:hover,
.textarea:hover {
  border-color: var(--mid-tone) !important;
}
input:focus,
select:focus,
textarea:focus,
.input:focus,
.select:focus,
.textarea:focus,
.form-input:focus,
.form-select:focus,
.form-textarea:focus {
  border-color: var(--primary) !important;
  box-shadow: var(--shadow-focus) !important;
}
input[type="checkbox"],
input[type="radio"] {
  accent-color: var(--primary) !important;
}

/* Tables */
.table {
  background: var(--background) !important;
  border-color: var(--border) !important;
}
.table thead th {
  background: var(--surface) !important;
  color: var(--text-secondary) !important;
  font-size: 14px !important;
  font-weight: 500 !important;
  border-bottom-color: var(--border) !important;
}
.table tbody td {
  border-bottom-color: var(--border-subtle) !important;
  color: var(--text-main) !important;
}
.table tbody tr:hover {
  background: var(--surface-overlay) !important;
}

/* Empty, activity, badges */
.empty-state-icon {
  color: var(--mid-tone) !important;
  background: var(--surface) !important;
}
.empty-state h3 { color: var(--text-main) !important; }
.empty-state p { color: var(--text-secondary) !important; }
.activity-dot,
.activity-dot.product,
.activity-dot.vendor,
.activity-dot.upload {
  background: var(--primary) !important;
}
.activity-time,
.activity-label [style*="var(--text-muted)"] {
  color: var(--text-secondary) !important;
}
.badge-success { background: var(--color-success-soft) !important; color: var(--color-success-deep) !important; }
.badge-warning { background: var(--color-warning-soft) !important; color: var(--color-warning-deep) !important; }
.badge-danger,
.badge-error { background: var(--color-danger-soft) !important; color: var(--color-danger-deep) !important; }
.badge-info { background: var(--color-info-soft) !important; color: var(--color-info-deep) !important; }
.badge,
.badge-accent {
  background: var(--surface) !important;
  color: var(--text-secondary) !important;
  border: 1px solid var(--border) !important;
}
.alert-success { background: var(--color-success-soft) !important; border-color: var(--color-success) !important; color: var(--color-success-deep) !important; }
.alert-warning { background: var(--color-warning-soft) !important; border-color: var(--color-warning) !important; color: var(--color-warning-deep) !important; }
.alert-danger,
.alert-error { background: var(--color-danger-soft) !important; border-color: var(--color-danger) !important; color: var(--color-danger-deep) !important; }
.alert-info { background: var(--color-info-soft) !important; border-color: var(--color-info) !important; color: var(--color-info-deep) !important; }

/* ============================================================
   Sellerina contrast fixes - captured audit pass 1
   ============================================================ */
:root {
  --text-sub: #6B7280;
  --mid-tone: #8E8B88;
}

/* Prevent black-on-black in workflow breadcrumb/current steps. */
.wf-step.is-current .wf-num,
.wf-step.is-done .wf-num,
.wf-step.is-current a .wf-num,
.wf-step.is-done a .wf-num {
  background: var(--primary) !important;
  border-color: var(--primary) !important;
  color: var(--text-inverse) !important;
}
.wf-step.is-current .wf-num *,
.wf-step.is-done .wf-num * {
  color: var(--text-inverse) !important;
}
.wf-step.is-current .wf-lbl,
.wf-step.is-done .wf-lbl,
.wf-step.is-upcoming .wf-lbl,
.wf-step.is-upcoming .wf-num,
.wf-step.is-upcoming .wf-num * {
  color: var(--text-secondary) !important;
}

/* Small caption text needs stronger contrast than the original warm gray. */
.stat-sub,
.stat-label,
.wf-step-num,
.wf-stage-count.is-zero,
.wf-stage-count.is-external,
.wf-stage-card.is-external .wf-stage-label,
.wf-stage-card.is-external .wf-stage-icon,
.wf-stage-card:has(.wf-stage-count.is-zero),
.activity-time,
.masthead-sub,
.page-subtitle,
.text-tertiary {
  color: var(--text-secondary) !important;
}

/* Warning cards need readable label contrast on warning-soft background. */
.wf-stage-card.is-bottleneck .wf-step-num,
.wf-stage-card.is-bottleneck .wf-stage-icon,
.wf-stage-card.is-bottleneck .wf-stage-label,
.wf-stage-card.is-bottleneck .wf-stage-count,
.wf-stage-card.is-bottleneck-danger .wf-step-num,
.wf-stage-card.is-bottleneck-danger .wf-stage-icon,
.wf-stage-card.is-bottleneck-danger .wf-stage-label,
.wf-stage-card.is-bottleneck-danger .wf-stage-count {
  color: var(--text-main) !important;
}

.product-thumb-empty,
.empty-state-icon {
  color: var(--text-secondary) !important;
}

/* ============================================================
   Sellerina contrast fixes - captured audit pass 2
   ============================================================ */
.sidebar .nav-section-title,
.sidebar .menu-step,
.sidebar-link .menu-step {
  color: #B5B2AF !important;
}
.sidebar-link.active .menu-step,
.sidebar-link:hover .menu-step {
  color: var(--surface) !important;
}

.alert-warning,
.alert.alert-warning,
[style*="var(--color-warning-soft)"] {
  color: var(--text-main) !important;
}
[style*="var(--color-danger-soft)"] {
  color: var(--color-danger-deep) !important;
}
[style*="color:var(--color-danger)"] {
  color: var(--color-danger-deep) !important;
}

/* Menu visibility/settings page: route captions and locked labels must stay readable. */
.menu-vis-section,
.menu-vis-href,
.menu-vis-locked,
.menu-vis-row.is-locked .menu-vis-href,
.menu-vis-row.is-locked .menu-vis-locked {
  color: var(--text-secondary) !important;
}
.menu-vis-row.is-locked {
  background: var(--surface) !important;
}

/* Form hints, metadata, and small neutral captions. */
.form-help,
.gf-hint,
.text-muted,
.sourcing-date,
.sourcing-meta,
.sourcing-meta-row,
.sourcing-card small,
.form-section small,
.form-row small,
[style*="color:var(--text-tertiary)"],
[style*="color:#9CA3AF"],
[style*="color:rgb(156, 163, 175)"] {
  color: var(--text-secondary) !important;
}

/* Tiny placeholders should not be lighter than secondary text. */
.product-thumb-empty,
.empty-state-icon,
[style*="color:var(--mid-tone)"] {
  color: var(--text-secondary) !important;
}

/* Final captured contrast fix: product image placeholder. */
.product-thumb-empty,
.ai-gallery-empty {
  color: var(--text-main) !important;
}

/* ============================================================
   Sellerina layout consistency + sidebar active icon contrast
   ============================================================ */
@media (min-width: 821px) {
  :root {
    --content-max: none;
  }
  .main,
  .main-content {
    width: calc(100vw - var(--sidebar-w)) !important;
    max-width: none !important;
    margin-left: var(--sidebar-w) !important;
    padding-left: var(--space-4) !important;
    padding-right: var(--space-4) !important;
    box-sizing: border-box !important;
  }
  .page-container {
    width: 100% !important;
    max-width: none !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
    box-sizing: border-box !important;
  }
  .page-container > .panel,
  .page-container > .card,
  .page-container > form.panel,
  .page-container > .stat-grid,
  .page-container > .table-wrap,
  .page-container > [style*="display:grid"],
  .page-container > [style*="display: grid"] {
    width: 100% !important;
    max-width: none !important;
  }
}

.sidebar-link.active,
.sidebar-link.active *,
.sidebar-link.active svg,
.sidebar-link.active .menu-main,
.sidebar-link.active .menu-main-only,
.sidebar-link.active .menu-text,
.sidebar-link.active .menu-step {
  color: var(--text-inverse) !important;
  stroke: currentColor !important;
  fill: none;
}
.sidebar-link.active {
  background: rgba(250, 250, 248, 0.16) !important;
}
.sidebar-link.active svg {
  opacity: 1 !important;
  filter: none !important;
}

/* ============================================================
   Sellerina layout consistency - flex item hard clamp
   ============================================================ */
@media (min-width: 821px) {
  .main,
  .main-content {
    flex: 0 0 calc(100vw - var(--sidebar-w)) !important;
    width: calc(100vw - var(--sidebar-w)) !important;
    min-width: 0 !important;
    max-width: calc(100vw - var(--sidebar-w)) !important;
    overflow-x: hidden !important;
  }
  .page-container {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    overflow-x: visible !important;
  }
  .table-scroll,
  .data-table-wrap,
  .card,
  .panel {
    max-width: 100% !important;
  }
}

.sidebar .sidebar-link.active svg,
.sidebar-link.active svg,
.sidebar-link.active svg *,
.sidebar-link.active svg path,
.sidebar-link.active svg line,
.sidebar-link.active svg polyline,
.sidebar-link.active svg circle,
.sidebar-link.active svg rect {
  color: var(--text-inverse) !important;
  stroke: var(--text-inverse) !important;
}

/* Mobile hamburger icon scale-up (1.5x). */
@media (max-width: 820px) {
  .mobile-topbar .hamburger,
  #mobileHamburger {
    width: 56px !important;
    height: 56px !important;
    flex: 0 0 56px !important;
  }
  .mobile-topbar .hamburger svg,
  #mobileHamburger svg {
    width: 44px !important;
    height: 44px !important;
    stroke-width: 2.2 !important;
  }
}


/* Sellerina Jost display font usage */
.brand-icon,
.brand-text strong,
.mobile-topbar .brand,
.login-card h1,
.text-display {
  font-family: var(--font-display);
}

/* Sellerina SVG logo system */
.sidebar-header {
  padding: 28px 24px !important;
}
.sidebar-brand {
  color: var(--surface) !important;
}
.sidebar-brand-orbit {
  position: relative;
  display: block;
  width: 100%;
  color: var(--surface);
}
.sellerina-lockup {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  color: var(--surface);
}
.sellerina-mark-wrap {
  position: relative;
  width: 44px;
  height: 44px;
  flex: 0 0 44px;
  color: currentColor;
  filter: drop-shadow(0 8px 18px rgba(0, 0, 0, 0.12));
}
.sellerina-mark {
  position: relative;
  z-index: 1;
  width: 44px;
  height: 44px;
  flex-shrink: 0;
}
.sellerina-text {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.sellerina-wordmark {
  font-family: var(--font-display);
  font-size: 28px;
  font-weight: 600;
  font-style: italic;
  letter-spacing: -0.04em;
  line-height: 1;
}
.sellerina-tagline {
  font-family: var(--font-body);
  font-size: 11px;
  font-weight: 400;
  letter-spacing: 0.01em;
  color: #B8B8B2;
  line-height: 1;
  white-space: nowrap;
}
.sellerina-logo {
  display: block;
  overflow: visible;
}
.sidebar-brand .sellerina-logo {
  width: 100%;
  height: auto;
}
.sidebar-brand .sellerina-logo text {
  font-weight: 600 !important;
}
.sidebar-slogan {
  margin-top: 5px;
  margin-left: 44px;
  color: rgba(250, 250, 248, 0.66);
  font-size: 7.5px;
  font-weight: 500;
  line-height: 1.35;
  letter-spacing: -0.045em;
  white-space: nowrap;
}
.mobile-topbar-logo {
  display: inline-flex;
  align-items: center;
  color: var(--surface);
  text-decoration: none;
}
.mobile-topbar-logo .sellerina-logo {
  width: 150px;
  height: auto;
}
.login-page {
  align-items: center !important;
  padding: var(--space-3) !important;
}
.login-brand {
  display: flex !important;
  justify-content: center !important;
  margin-bottom: var(--space-3) !important;
}
.login-logo {
  width: min(100%, 320px);
  height: auto;
  color: var(--primary);
}

/* Login-specific Sellerina lockup */
.login-page {
  background:
    radial-gradient(circle at 28% 14%, rgba(255, 255, 255, 0.96) 0, rgba(255, 255, 255, 0) 30%),
    linear-gradient(135deg, #F7F7F5 0%, #D8D8D4 36%, #F2F1EE 58%, #C7C7C3 100%) !important;
  min-height: 100vh;
  min-height: 100dvh;
}
.login-card {
  background: rgba(250, 250, 248, 0.92) !important;
  border: 1px solid rgba(26, 26, 26, 0.08) !important;
  box-shadow: 0 24px 70px rgba(26, 26, 26, 0.16) !important;
  backdrop-filter: blur(14px);
}
.login-logo-lockup {
  color: var(--primary);
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
}
.login-mark-orbit {
  position: relative;
  width: 42px;
  height: 42px;
  margin-bottom: 12px;
  color: var(--primary);
  filter: drop-shadow(0 8px 18px rgba(26, 26, 26, 0.10));
}
.login-mark {
  position: relative;
  z-index: 1;
  width: 42px;
  height: 42px;
}
.orbit-light {
  position: absolute;
  left: 50%;
  top: 50%;
  z-index: 2;
  width: 5px;
  height: 5px;
  margin: -2.5px 0 0 -2.5px;
  border-radius: 999px;
  background: #FFFFFF;
  border: 1px solid rgba(26, 26, 26, 0.18);
  box-shadow:
    0 0 0 1px rgba(255, 255, 255, 0.85),
    0 0 10px rgba(255, 255, 255, 0.95),
    0 0 18px rgba(26, 26, 26, 0.22);
  transform-origin: center;
  animation: sellerina-orbit-outer 4.8s linear infinite, sellerina-sparkle 1.45s ease-in-out infinite;
}
.orbit-light--inner {
  width: 4px;
  height: 4px;
  margin: -2px 0 0 -2px;
  animation: sellerina-orbit-inner 3.4s linear infinite reverse, sellerina-sparkle 1.1s ease-in-out infinite 0.25s;
}
@keyframes sellerina-orbit-outer {
  from { transform: rotate(0deg) translateX(17.7px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(17.7px) rotate(-360deg); }
}
@keyframes sellerina-orbit-inner {
  from { transform: rotate(38deg) translateX(10.5px) rotate(-38deg); }
  to { transform: rotate(398deg) translateX(10.5px) rotate(-398deg); }
}
@keyframes sellerina-sparkle {
  0%, 100% {
    opacity: 0.62;
    filter: brightness(0.95);
  }
  42% {
    opacity: 1;
    filter: brightness(1.45);
  }
  68% {
    opacity: 0.78;
    filter: brightness(1.1);
  }
}
.login-wordmark {
  font-family: var(--font-display);
  font-size: 38px;
  font-style: italic;
  font-weight: 600;
  letter-spacing: -0.04em;
  line-height: 1;
}
.login-slogan {
  margin-top: 12px;
  color: var(--text-subtle);
  font-size: 13px;
  font-weight: 500;
  letter-spacing: -0.01em;
  line-height: 1.45;
}

@media (max-width: 760px) {
  html,
  body {
    overscroll-behavior: none;
    touch-action: manipulation;
    -webkit-text-size-adjust: 100%;
  }

  input[type="text"],
  input[type="email"],
  input[type="password"],
  input[type="number"],
  input[type="search"],
  input[type="url"],
  input[type="tel"],
  input[type="date"],
  textarea,
  select {
    font-size: 16px !important;
  }

  .login-page {
    align-items: center !important;
    padding: 18px !important;
  }
}

@media (prefers-reduced-motion: reduce) {
  .orbit-light {
    animation: none;
  }
}

/* Dashboard chrome finish + sidebar orbit logo */
body {
  background:
    radial-gradient(circle at 42% 0%, rgba(255, 255, 255, 0.86) 0, rgba(255, 255, 255, 0) 34%),
    linear-gradient(135deg, #F8F9F9 0%, #E4E7E8 38%, #F1F3F4 62%, #CCD2D5 100%) !important;
}
.main-content,
.page-container {
  background: transparent !important;
}
@media (min-width: 821px) {
  .main,
  .main-content {
    padding-left: var(--space-4) !important;
    padding-right: var(--space-4) !important;
  }
  .page-container {
    padding-left: var(--space-5) !important;
    padding-right: var(--space-5) !important;
  }
}
.sidebar {
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.18) 0, rgba(255, 255, 255, 0) 34%),
    linear-gradient(145deg, #3F4447 0%, #2B3033 45%, #52585B 100%) !important;
  border-right: 1px solid rgba(250, 250, 248, 0.16) !important;
  box-shadow: inset -1px 0 0 rgba(255, 255, 255, 0.06), 18px 0 48px rgba(26, 26, 26, 0.08);
}
.sidebar-header {
  padding: 28px 22px 24px !important;
}
.sidebar-orbit-light {
  left: 22px;
  top: 22px;
}
.sidebar-orbit-light--outer {
  width: 4px;
  height: 4px;
  margin: -2px 0 0 -2px;
  animation: sellerina-sidebar-orbit-outer 5.4s linear infinite, sellerina-sparkle 1.55s ease-in-out infinite;
}
.sidebar-orbit-light--inner {
  width: 3px;
  height: 3px;
  margin: -1.5px 0 0 -1.5px;
  animation: sellerina-sidebar-orbit-inner 3.9s linear infinite reverse, sellerina-sparkle 1.2s ease-in-out infinite 0.2s;
}
@keyframes sellerina-sidebar-orbit-outer {
  from { transform: rotate(0deg) translateX(19px) rotate(0deg); }
  to { transform: rotate(360deg) translateX(19px) rotate(-360deg); }
}
@keyframes sellerina-sidebar-orbit-inner {
  from { transform: rotate(42deg) translateX(11px) rotate(-42deg); }
  to { transform: rotate(402deg) translateX(11px) rotate(-402deg); }
}

/* Sidebar neutral contrast pass */
.sidebar {
  color: #F6F6F6 !important;
}
.sellerina-tagline {
  color: #B8B8B8 !important;
}
.sidebar-api-credit {
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
}
.sidebar-api-credit,
.sidebar-api-credit span {
  color: rgba(255, 255, 255, 0.78) !important;
}
.sidebar-api-credit a {
  color: #FFFFFF !important;
}
.sidebar .nav-section-title,
.nav-section-title {
  color: rgba(255, 255, 255, 0.66) !important;
}
.sidebar-link,
.sidebar-footer .sidebar-link {
  color: rgba(255, 255, 255, 0.78) !important;
}
.sidebar-link svg {
  color: rgba(255, 255, 255, 0.72) !important;
  opacity: 1 !important;
}
.menu-main,
.menu-main-only,
.menu-text {
  color: inherit !important;
}
.menu-sub {
  color: rgba(255, 255, 255, 0.64) !important;
}
.menu-step,
.sidebar-link .menu-step {
  background: rgba(255, 255, 255, 0.09) !important;
  border-color: rgba(255, 255, 255, 0.16) !important;
  color: rgba(255, 255, 255, 0.74) !important;
}
.sidebar-link:hover,
.sidebar-link.active {
  background: rgba(255, 255, 255, 0.14) !important;
  color: #FFFFFF !important;
}
.sidebar-link:hover svg,
.sidebar-link.active svg,
.sidebar-link:hover .menu-sub,
.sidebar-link.active .menu-sub,
.sidebar-link:hover .menu-step,
.sidebar-link.active .menu-step {
  color: #FFFFFF !important;
}
.sidebar-link:hover .menu-step,
.sidebar-link.active .menu-step {
  background: rgba(255, 255, 255, 0.18) !important;
  border-color: rgba(255, 255, 255, 0.28) !important;
}

/* Global zero-saturation state colors.
   Only destructive/error/failure states stay red. */
.text-success,
.text-warning,
.text-info,
.stat-trend.up,
.wf-context a {
  color: #555555 !important;
}
.stat-card.accent::before,
.stat-card.success::before,
.stat-card.warning::before,
.stat-card.blue::before,
.stat-card.info::before,
.activity-dot.vendor,
.activity-dot.upload,
.activity-dot.product {
  background: #8E8E8E !important;
}
.badge-success,
.badge-warning,
.badge-info,
.badge-accent,
.badge-generating,
.badge-qc_pending,
.badge-qc_passed,
.badge-passed,
.badge-approved,
.badge-uploaded,
.badge-queued,
.badge-processing,
.badge-draft,
.badge.badge-generating,
.badge.badge-qc_pending,
.badge.badge-qc_passed,
.badge.badge-passed,
.badge.badge-approved,
.badge.badge-uploaded,
.badge.badge-queued,
.badge.badge-processing,
.badge.badge-draft {
  background: #ECECEC !important;
  color: #4F4F4F !important;
  border-color: #CFCFCF !important;
}
.badge-danger,
.badge-error,
.badge-rejected,
.badge-failed,
.badge.badge-rejected,
.badge.badge-failed {
  background: #FEF2F2 !important;
  color: #B91C1C !important;
  border-color: #FECACA !important;
}
.alert-success,
.alert-warning,
.alert-info,
.gf-alert.success,
.flash-success,
.flash-warn {
  background: #EFEFEF !important;
  border-color: #CFCFCF !important;
  color: #4F4F4F !important;
}
.alert-danger,
.alert-error,
.flash-error,
.text-error,
.text-danger {
  color: #B91C1C !important;
}
.alert-danger,
.alert-error,
.flash-error {
  background: #FEF2F2 !important;
  border-color: #FECACA !important;
}

/* Pure red for destructive/error/failure states */
.text-danger,
.text-error,
.required,
[style*="var(--color-danger)"],
[style*="var(--color-danger-deep)"] {
  color: #FF0000 !important;
}
.badge-danger,
.badge-error,
.badge-rejected,
.badge-failed,
.badge.badge-rejected,
.badge.badge-failed {
  background: rgba(255, 0, 0, 0.08) !important;
  color: #FF0000 !important;
  border-color: rgba(255, 0, 0, 0.24) !important;
}
.alert-danger,
.alert-error,
.flash-error,
.wf-stage-card.is-bottleneck-danger {
  background: rgba(255, 0, 0, 0.08) !important;
  border-color: rgba(255, 0, 0, 0.28) !important;
  color: #FF0000 !important;
}
.wf-stage-card:hover,
.wf-stage-card.is-bottleneck {
  background: #F3F3F3 !important;
  border-color: #B8B8B8 !important;
}
.wf-stage-card.is-bottleneck-danger {
  background: #FEF2F2 !important;
  border-color: #DC2626 !important;
}
.wf-step.is-current .wf-num,
.wf-step.is-done .wf-num {
  background: #2F2F2F !important;
  border-color: #2F2F2F !important;
  color: #FFFFFF !important;
}
.wf-step.is-current .wf-lbl,
.wf-context strong,
.help-content strong {
  color: #1F1F1F !important;
}
.help-tip,
.help-box,
.empty-state-steps li.current {
  border-color: #CFCFCF !important;
}
input[type="checkbox"],
input[type="radio"] {
  accent-color: #4F4F4F !important;
}

/* Mobile 390px polish: tighter gutters, visible copy, native touch scroll */
@media (max-width: 760px) {
  html,
  body {
    overflow-y: auto !important;
    overflow-x: hidden !important;
    overscroll-behavior-y: contain;
    touch-action: pan-y !important;
    -webkit-overflow-scrolling: touch;
  }

  body:not(.sidebar-open) {
    position: static !important;
  }

  body.sidebar-open {
    overflow: hidden !important;
    touch-action: none !important;
  }

  .main,
  .main-content {
    padding-left: 7px !important;
    padding-right: 7px !important;
  }

  .page-container,
  .main-content > .page-container,
  .main-content .page-container,
  main.page-container,
  .admin-content,
  .content,
  .content-wrapper {
    padding-left: 7px !important;
    padding-right: 7px !important;
  }

  .mobile-topbar {
    padding-left: 7px !important;
    padding-right: 7px !important;
  }

  .masthead-context,
  .masthead-sub,
  .page-subtitle,
  .page-sub,
  .page-header p {
    max-width: 100% !important;
    white-space: normal !important;
    overflow: visible !important;
    text-overflow: clip !important;
    overflow-wrap: anywhere !important;
    word-break: keep-all !important;
  }

  .wf-breadcrumb {
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
  }

  .wf-breadcrumb .wf-step,
  .wf-breadcrumb .wf-step.is-current {
    flex: 0 0 auto !important;
    min-width: 48px !important;
  }

  .wf-breadcrumb .wf-step.is-current .wf-lbl,
  .wf-breadcrumb .wf-lbl {
    display: inline-block !important;
    width: auto !important;
    max-width: none !important;
    min-width: 0 !important;
    overflow: visible !important;
    text-overflow: clip !important;
    white-space: nowrap !important;
    word-break: keep-all !important;
  }

  .wf-breadcrumb .wf-step:not(.is-current) .wf-lbl {
    display: none !important;
  }

  .btn,
  button,
  a,
  label,
  th,
  td,
  .badge,
  .pill,
  .tag {
    overflow-wrap: anywhere;
  }

  .data-table,
  .table,
  .product-list-table {
    max-width: 100% !important;
  }

  .data-table th,
  .data-table td,
  table.table th,
  table.table td {
    padding-left: 4px !important;
    padding-right: 4px !important;
    font-size: 12px !important;
  }

  .data-table .btn-sm,
  table.table .btn-sm {
    min-width: 38px !important;
    padding-left: 6px !important;
    padding-right: 6px !important;
    white-space: nowrap !important;
  }

  /* Mobile top workflow steps: circular chrome chips */
  .wf-breadcrumb {
    background: rgba(255, 255, 255, 0.72) !important;
    border-color: #D9DDE0 !important;
    border-radius: 8px !important;
    padding: 8px 7px !important;
    box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.72);
  }

  .wf-breadcrumb .wf-steps {
    display: flex !important;
    align-items: center !important;
    flex-wrap: nowrap !important;
    gap: 6px !important;
    margin: 0 !important;
    min-width: max-content !important;
  }

  .wf-breadcrumb .wf-step,
  .wf-breadcrumb .wf-step.is-current {
    display: inline-flex !important;
    align-items: center !important;
    flex: 0 0 auto !important;
    min-width: 0 !important;
    gap: 6px !important;
    padding: 0 !important;
    background: transparent !important;
    border-radius: 0 !important;
  }

  .wf-breadcrumb .wf-step a {
    display: inline-flex !important;
    align-items: center !important;
    gap: 6px !important;
    padding: 0 !important;
    background: transparent !important;
  }

  .wf-breadcrumb .wf-num {
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    border: 0 !important;
    background: linear-gradient(145deg, #F4F5F6 0%, #E1E4E6 100%) !important;
    color: #6B6F73 !important;
    box-shadow:
      inset 0 1px 0 rgba(255, 255, 255, 0.86),
      0 1px 2px rgba(26, 26, 26, 0.05) !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 34px !important;
    letter-spacing: -0.02em !important;
  }

  .main-content .wf-breadcrumb .wf-num,
  .main-content .wf-breadcrumb .wf-step .wf-num,
  .main-content .wf-breadcrumb .wf-step span.wf-num,
  .admin-main .wf-breadcrumb .wf-num {
    font-size: 14px !important;
    line-height: 34px !important;
    font-weight: 700 !important;
  }

  .wf-breadcrumb .wf-step.is-current .wf-num,
  .wf-breadcrumb .wf-step.is-done .wf-num {
    background: linear-gradient(145deg, #3C3F42 0%, #232629 100%) !important;
    color: #FFFFFF !important;
    border: 0 !important;
  }

  .wf-breadcrumb .wf-step.is-current {
    gap: 7px !important;
  }

  .wf-breadcrumb .wf-step.is-current .wf-lbl {
    display: inline-block !important;
    color: #1F1F1F !important;
    font-size: 14px !important;
    font-weight: 700 !important;
    line-height: 34px !important;
    white-space: nowrap !important;
    max-width: none !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }

  .wf-breadcrumb .wf-step:not(.is-current) .wf-lbl {
    display: none !important;
  }

  .wf-breadcrumb .wf-arrow {
    color: #C6C9CC !important;
    font-size: 13px !important;
    padding: 0 !important;
    line-height: 34px !important;
  }

  /* Mobile form value text: match placeholder scale */
  .main-content input,
  .main-content select,
  .main-content textarea,
  .main-content .input,
  .main-content .select,
  .main-content .textarea,
  .main-content .form-input,
  .main-content .form-select,
  .main-content .form-textarea,
  .admin-main input,
  .admin-main select,
  .admin-main textarea,
  .admin-main .input,
  .admin-main .select,
  .admin-main .textarea,
  .admin-main .form-input,
  .admin-main .form-select,
  .admin-main .form-textarea {
    font-size: 14px !important;
    line-height: 1.35 !important;
    font-weight: 400 !important;
    -webkit-text-size-adjust: none !important;
  }

  .main-content input::placeholder,
  .main-content textarea::placeholder,
  .main-content .input::placeholder,
  .main-content .textarea::placeholder,
  .main-content .form-input::placeholder,
  .main-content .form-textarea::placeholder,
  .admin-main input::placeholder,
  .admin-main textarea::placeholder,
  .admin-main .input::placeholder,
  .admin-main .textarea::placeholder,
  .admin-main .form-input::placeholder,
  .admin-main .form-textarea::placeholder {
    font-size: 14px !important;
    line-height: 1.35 !important;
  }
}

/* Zero-saturation background pass */
:root {
  --surface: #FAFAFA;
  --background: #FFFFFF;
  --bg: #FAFAFA;
  --surface-secondary: #FAFAFA;
  --surface-tertiary: #F2F2F2;
  --surface-elevated: #FAFAFA;
}

body {
  background:
    radial-gradient(circle at 42% 0%, rgba(255, 255, 255, 0.86) 0, rgba(255, 255, 255, 0) 34%),
    linear-gradient(135deg, #F8F8F8 0%, #E6E6E6 38%, #F2F2F2 62%, #D0D0D0 100%) !important;
}

.login-page {
  background:
    radial-gradient(circle at 28% 14%, rgba(255, 255, 255, 0.96) 0, rgba(255, 255, 255, 0) 30%),
    linear-gradient(135deg, #F7F7F7 0%, #D9D9D9 36%, #F1F1F1 58%, #C8C8C8 100%) !important;
}

.main-content,
.page-container {
  background-color: transparent;
}

.sidebar {
  background:
    radial-gradient(circle at 0% 0%, rgba(255, 255, 255, 0.18) 0, rgba(255, 255, 255, 0) 34%),
    linear-gradient(145deg, #444444 0%, #303030 45%, #575757 100%) !important;
}

/* PC workflow step alignment */
@media (min-width: 821px) {
  .wf-breadcrumb {
    display: flex !important;
    justify-content: center !important;
  }

  .wf-breadcrumb .wf-steps {
    width: 100% !important;
    margin: 0 !important;
    justify-content: center !important;
    align-items: center !important;
    gap: 6px !important;
    overflow-x: hidden !important;
    flex-wrap: nowrap !important;
  }

  .wf-breadcrumb .wf-step {
    flex: 1 1 0 !important;
    min-width: 0 !important;
    justify-content: center !important;
    text-align: center !important;
  }

  .wf-breadcrumb .wf-step a {
    justify-content: center !important;
  }

  .wf-breadcrumb .wf-lbl,
  .wf-breadcrumb .wf-step .wf-lbl,
  .wf-breadcrumb .wf-step.is-current .wf-lbl,
  .wf-breadcrumb .wf-step.is-done .wf-lbl,
  .wf-breadcrumb .wf-step.is-upcoming .wf-lbl {
    overflow: visible !important;
    text-overflow: clip !important;
    max-width: none !important;
  }

  .wf-breadcrumb .wf-arrow {
    flex: 0 0 auto !important;
    font-size: 19px !important;
    line-height: 1 !important;
    color: #A8A8A8 !important;
    padding: 0 3px !important;
  }
}

/* Only the current workflow step gets the black active pill. */
.wf-breadcrumb .wf-step.is-current .wf-num,
.wf-breadcrumb .wf-step.is-current a .wf-num {
  background: #1A1A1A !important;
  border-color: #1A1A1A !important;
  color: #FFFFFF !important;
}

.wf-breadcrumb .wf-step.is-current .wf-num *,
.wf-breadcrumb .wf-step.is-current a .wf-num * {
  color: #FFFFFF !important;
}

.wf-breadcrumb .wf-step.is-done .wf-num,
.wf-breadcrumb .wf-step.is-done a .wf-num {
  background: #ECECEC !important;
  border-color: #CFCFCF !important;
  color: #4F4F4F !important;
}

.wf-breadcrumb .wf-step.is-done .wf-num *,
.wf-breadcrumb .wf-step.is-done a .wf-num * {
  color: #4F4F4F !important;
}

.sidebar-quota-widget {
  display: block;
  margin: 8px 14px 14px;
  padding: 12px;
  border: 1px solid rgba(255,255,255,0.10);
  border-radius: 16px;
  background: linear-gradient(145deg, rgba(255,255,255,0.08), rgba(255,255,255,0.03));
  color: rgba(255,255,255,0.86);
  text-decoration: none;
}
.sidebar-quota-widget:hover {
  background: linear-gradient(145deg, rgba(255,255,255,0.12), rgba(255,255,255,0.05));
  color: #FFFFFF;
}
.quota-widget-head,
.quota-widget-label {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}
.quota-widget-head {
  margin-bottom: 10px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: 0.08em;
  text-transform: uppercase;
}
.quota-widget-head strong {
  color: rgba(255,255,255,0.58);
  font-size: 10px;
  font-weight: 800;
}
.quota-widget-row + .quota-widget-row {
  margin-top: 9px;
}
.quota-widget-label {
  font-size: 10.5px;
  line-height: 1.25;
  color: rgba(255,255,255,0.72);
}
.quota-widget-label strong {
  color: rgba(255,255,255,0.92);
  font-size: 10px;
  white-space: nowrap;
}
.quota-widget-bar {
  height: 5px;
  margin-top: 5px;
  border-radius: 999px;
  background: rgba(255,255,255,0.12);
  overflow: hidden;
}
.quota-widget-bar span {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: #E8E8E8;
}

/* Mobile QA polish - 390 x 844 baseline */
@media (max-width: 820px) {
  :root {
    --mtr-mobile-edge: 16px;
    --mtr-mobile-section-gap: 16px;
    --mtr-mobile-card-pad: 18px;
  }

  html,
  body {
    overflow-x: hidden !important;
    -webkit-text-size-adjust: 100% !important;
  }

  body {
    background:
      radial-gradient(circle at 42% 0%, rgba(255,255,255,.88) 0, rgba(255,255,255,0) 36%),
      linear-gradient(135deg, #F8F8F8 0%, #E7E7E7 42%, #F4F4F4 68%, #D2D2D2 100%) !important;
  }

  .layout {
    display: block !important;
    min-width: 0 !important;
  }

  .mobile-topbar {
    display: flex !important;
    align-items: center !important;
    justify-content: flex-start !important;
    gap: 10px !important;
    height: auto !important;
    min-height: 50px !important;
    padding: 7px var(--mtr-mobile-edge) 5px !important;
    background: rgba(255,255,255,.86) !important;
    border-bottom: 1px solid rgba(26,26,26,.06) !important;
    backdrop-filter: blur(14px) !important;
    position: sticky !important;
    top: 0 !important;
    z-index: 1200 !important;
  }

  .mobile-topbar .hamburger,
  #mobileHamburger {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 32px !important;
    height: 34px !important;
    flex: 0 0 32px !important;
    margin: 0 !important;
    padding: 0 !important;
    color: #1A1A1A !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 10px !important;
    box-shadow: none !important;
  }

  .mobile-topbar .hamburger svg,
  #mobileHamburger svg {
    width: 30px !important;
    height: 30px !important;
    stroke-width: 1.8 !important;
  }

  .sidebar,
  .sidebar.is-open {
    top: 0 !important;
    bottom: 0 !important;
    height: 100dvh !important;
    max-height: 100dvh !important;
    width: min(336px, 86vw) !important;
    max-width: 86vw !important;
    display: flex !important;
    flex-direction: column !important;
    overflow: hidden !important;
    border-radius: 0 22px 22px 0 !important;
  }

  .sidebar-close {
    display: none !important;
  }

  .sidebar.is-open .sidebar-close {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    position: absolute !important;
    top: 14px !important;
    right: 14px !important;
    width: 34px !important;
    height: 34px !important;
    min-height: 34px !important;
    max-height: 34px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    border: 1px solid rgba(255,255,255,.24) !important;
    background: rgba(255,255,255,.10) !important;
    color: #FFFFFF !important;
    z-index: 3 !important;
    font-size: 24px !important;
    line-height: 1 !important;
    font-weight: 300 !important;
    backdrop-filter: blur(6px) !important;
  }

  .sidebar-close span {
    transform: translateY(-1px);
  }

  .sidebar-header {
    flex: 0 0 auto !important;
    padding: 28px 56px 18px 22px !important;
    margin-bottom: 4px !important;
  }

  .sidebar-nav {
    flex: 1 1 auto !important;
    min-height: 0 !important;
    overflow-y: auto !important;
    overflow-x: hidden !important;
    padding: 0 12px 12px !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .sidebar-footer {
    flex: 0 0 auto !important;
    padding: 10px 22px 14px !important;
    border-top: 1px solid rgba(255,255,255,.08) !important;
    background: linear-gradient(180deg, rgba(47,47,47,0), rgba(47,47,47,.52)) !important;
  }

  .sidebar-quota-widget {
    display: block !important;
    height: auto !important;
    min-height: 124px !important;
    margin: 8px 8px 14px !important;
    padding: 12px 12px 11px !important;
    overflow: visible !important;
  }

  .quota-widget-row + .quota-widget-row {
    margin-top: 9px !important;
  }

  .quota-widget-row {
    display: block !important;
    min-height: 22px !important;
  }

  .quota-widget-label {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 8px !important;
    font-size: 10px !important;
    line-height: 1.2 !important;
  }

  .quota-widget-label span,
  .quota-widget-label strong {
    line-height: 1.2 !important;
  }

  .quota-widget-bar {
    height: 4px !important;
    margin-top: 5px !important;
  }

  .sidebar-backdrop.is-open {
    display: block !important;
    position: fixed !important;
    inset: 0 !important;
    z-index: 1240 !important;
    background: rgba(0,0,0,.36) !important;
  }

  .mobile-topbar-logo {
    display: none !important;
  }

  .main,
  .main-content,
  .admin-main,
  main {
    margin-left: 0 !important;
    padding: 0 !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: hidden !important;
  }

  .page-container,
  .main-content > .page-container,
  .main-content .page-container,
  main.page-container,
  .admin-content,
  .content,
  .content-wrapper {
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    padding: var(--mtr-mobile-edge) !important;
    margin: 0 !important;
    box-sizing: border-box !important;
    overflow-x: hidden !important;
  }

  .page-container > * + * {
    margin-top: var(--mtr-mobile-section-gap) !important;
  }

  .masthead,
  .page-header,
  .admin-page-header {
    width: 100% !important;
    margin: 0 0 var(--mtr-mobile-section-gap) !important;
    padding: 0 !important;
    gap: 12px !important;
    align-items: stretch !important;
  }

  .masthead-titles {
    display: flex !important;
    align-items: baseline !important;
    gap: 8px !important;
    width: 100% !important;
    min-width: 0 !important;
    flex-wrap: nowrap !important;
  }

  .masthead-title,
  .masthead h1,
  .page-header h1,
  .admin-page-header h1,
  h1 {
    font-size: 25px !important;
    line-height: 1.18 !important;
    letter-spacing: -0.045em !important;
    font-weight: 900 !important;
  }

  .masthead-sub,
  .masthead-context,
  .page-subtitle {
    font-size: 12.5px !important;
    line-height: 1.25 !important;
    font-weight: 700 !important;
    color: #7A7A7A !important;
    white-space: nowrap !important;
    overflow: hidden !important;
    text-overflow: ellipsis !important;
    min-width: 0 !important;
  }

  .masthead .wf-breadcrumb,
  .wf-breadcrumb {
    width: 100% !important;
    max-width: 100% !important;
    margin: 0 !important;
    padding: 12px 10px !important;
    border: 1px solid #E2E2E2 !important;
    border-radius: 10px !important;
    background: rgba(255,255,255,.72) !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.82) !important;
    overflow-x: auto !important;
    overflow-y: hidden !important;
    -webkit-overflow-scrolling: touch !important;
    scrollbar-width: none !important;
  }

  .wf-breadcrumb::-webkit-scrollbar {
    display: none !important;
  }

  .wf-breadcrumb .wf-steps {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 0 !important;
    min-width: 0 !important;
    width: 100% !important;
    margin: 0 !important;
    padding: 0 !important;
    flex-wrap: nowrap !important;
  }

  .wf-breadcrumb .wf-step,
  .wf-breadcrumb .wf-step.is-current,
  .wf-breadcrumb .wf-step a {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 6px !important;
    min-width: 0 !important;
    padding: 0 !important;
    background: transparent !important;
    border: 0 !important;
    border-radius: 0 !important;
    white-space: nowrap !important;
  }

  .wf-breadcrumb .wf-step {
    flex: 1 1 0 !important;
  }

  .wf-breadcrumb .wf-step.is-current {
    flex: 1.85 1 0 !important;
  }

  .wf-breadcrumb .wf-step a {
    width: 100% !important;
  }

  .wf-breadcrumb .wf-num,
  .wf-breadcrumb .wf-step .wf-num,
  .main-content .wf-breadcrumb .wf-step span.wf-num {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 34px !important;
    min-width: 34px !important;
    height: 34px !important;
    padding: 0 !important;
    border-radius: 50% !important;
    font-size: 14px !important;
    line-height: 1 !important;
    font-weight: 800 !important;
    letter-spacing: -0.02em !important;
    background: linear-gradient(145deg, #F5F5F5 0%, #E2E2E2 100%) !important;
    color: #6A6A6A !important;
    border: 0 !important;
    box-shadow: inset 0 1px 0 rgba(255,255,255,.85), 0 1px 2px rgba(26,26,26,.05) !important;
  }

  .wf-breadcrumb .wf-step.is-current .wf-num {
    background: #1A1A1A !important;
    color: #FFFFFF !important;
  }

  .wf-breadcrumb .wf-step.is-done .wf-num {
    background: linear-gradient(145deg, #F0F0F0 0%, #DEDEDE 100%) !important;
    color: #5A5A5A !important;
  }

  .wf-breadcrumb .wf-num-prefix {
    display: none !important;
  }

  .wf-breadcrumb .wf-lbl,
  .wf-breadcrumb .wf-step.is-current .wf-lbl {
    font-size: 14px !important;
    line-height: 1.2 !important;
    font-weight: 800 !important;
    color: #1F1F1F !important;
    white-space: nowrap !important;
    max-width: 92px !important;
    overflow: visible !important;
    text-overflow: clip !important;
  }

  .wf-breadcrumb .wf-step:not(.is-current) .wf-lbl {
    display: none !important;
  }

  .wf-breadcrumb .wf-arrow {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    height: 34px !important;
    padding: 0 2px !important;
    font-size: 16px !important;
    line-height: 1 !important;
    color: #B8B8B8 !important;
    flex: 0 0 12px !important;
  }

  .panel,
  .card,
  .gf-card,
  .form-card,
  .help-box,
  section.panel,
  section.card,
  div.panel,
  div.card {
    padding: var(--mtr-mobile-card-pad) !important;
    border-radius: 18px !important;
  }

  body .main-content > main.page-container > .masthead,
  body .main-content > .page-container > .masthead,
  body main.page-container > .masthead,
  body .page-container > .masthead {
    margin: 0 0 var(--mtr-mobile-section-gap) !important;
    padding: 0 !important;
  }

  body .page-container > .dispatch-product-card,
  body .page-container > .product-list-page,
  body .page-container > .ai-product-panel,
  body .page-container > .card,
  body .page-container > .panel {
    max-width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }

  body .page-container > .dispatch-product-card {
    margin-top: 0 !important;
    margin-bottom: var(--mtr-mobile-section-gap) !important;
  }

  body .dispatch-product-card .product-list-table tr.product-row,
  body .product-list-page .product-list-table tr.product-row,
  body .ai-product-panel .product-list-table tr.product-row {
    width: 100% !important;
    margin-left: 0 !important;
    margin-right: 0 !important;
  }
}
