/* 기본 레이아웃 + 모든 컴포넌트 스타일.
   모든 색/간격은 tokens.css 의 var(--*) 만 사용. */

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  min-height: 100vh;
  font-family: var(--font-primary);
  font-size: var(--text-base);
  color: var(--color-text-primary);
  background: var(--color-bg);
  -webkit-font-smoothing: antialiased;
}

button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, select, textarea { font-family: inherit; }
hr.field-divider {
  border: 0;
  border-top: 1px solid var(--color-border);
  margin: var(--space-5) 0 var(--space-4);
}

/* ── Top Bar ─────────────────────────────────────────────── */
.topbar {
  position: sticky;
  top: 0;
  z-index: 30;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) minmax(0, auto);
  align-items: center;
  height: var(--topbar-height);
  padding: 0 var(--space-4);
  gap: var(--space-3);
  background: var(--color-bg-sidebar);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-md);
}
.topbar-left  { display:flex; align-items:center; gap: var(--space-3); min-width: 0; }
.topbar-right {
  display:flex;
  align-items:center;
  justify-content:flex-end;
  gap: var(--space-2);
  min-width: 0;
  overflow-x: auto;
  overflow-y: hidden;
  scrollbar-width: thin;
}
.topbar-center { display:flex; align-items:center; justify-content:center; gap: var(--space-2); min-width: 0; }
.topbar-project-title {
  max-width: 360px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-text-inverse);
  cursor: pointer;
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  transition: background 0.15s;
  min-width: 80px;
}
.topbar-project-title:hover {
  background: rgba(255, 255, 255, 0.08);
}
.topbar-project-title:empty::before {
  content: "프로젝트명 (클릭)";
  color: rgba(255, 255, 255, 0.4);
  font-style: italic;
  font-weight: 400;
}
.topbar h1 {
  margin: 0;
  font-size: var(--text-lg);
  font-weight: var(--font-semibold);
  letter-spacing: -0.01em;
  cursor: pointer;
  user-select: none;
  transition: opacity var(--transition-base);
}
.topbar h1:hover { opacity: 0.75; }
.topbar nav { display: flex; align-items: center; gap: var(--space-2); font-size: var(--text-sm); }
.topbar-right .btn-sm,
.topbar-right .username {
  flex: 0 0 auto;
}
.topbar-right .btn-sm { padding-left: var(--space-3); padding-right: var(--space-3); }
.topbar nav .username { color: var(--color-text-muted); }
.topbar .btn-ghost { color: var(--color-text-inverse); opacity: 0.85; }
.topbar .btn-ghost:hover:not(:disabled) { opacity: 1; color: var(--color-text-inverse); background: rgba(255,255,255,0.08); border-radius: var(--radius-md); }
.topbar #btn-trash { color: var(--color-danger); opacity: 1; }
.topbar #btn-trash:hover:not(:disabled) { color: var(--color-text-inverse); background: var(--color-danger); border-radius: var(--radius-md); opacity: 1; }

@media (max-width: 1280px) {
  .topbar-project-title {
    max-width: 220px;
  }

  .topbar-right .btn-sm {
    padding-left: var(--space-2);
    padding-right: var(--space-2);
  }
}

@media (max-width: 980px) {
  .topbar {
    grid-template-columns: auto minmax(0, 1fr);
  }

  .topbar-center {
    display: none;
  }

  .topbar-right {
    justify-content: flex-end;
  }
}

/* Save Status */
.save-status {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-1) var(--space-3);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
}
.save-status.saving { background: var(--color-accent-light); color: var(--color-accent-hover); }
.save-status.saved  { background: #DCFCE7; color: var(--color-success); }
.save-status.dirty  { background: #FEE2E2; color: var(--color-danger); }

/* ── Buttons ─────────────────────────────────────────────── */
/* 사장님 결정 (2026-05-07): .btn 의 inline-flex 가 <button hidden> default display:none 깨뜨림.
   global [hidden] 강제 — 모든 element 의 hidden attribute 정상 작동 */
[hidden] { display: none !important; }
.btn {
  display: inline-flex; align-items: center; justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-6);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  transition: background var(--transition-base), color var(--transition-base), border-color var(--transition-base), opacity var(--transition-base);
  white-space: nowrap;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
/* 위험(빨강) 버튼 비활성 = 명확한 회색(사장님 2026-07-04: 선택 안 됐을 때 회색 비활성) */
.btn-danger:disabled { opacity: 1; background: #e5e7eb; color: #9ca3af; border-color: #e5e7eb; }

/* 사장님 룰 (2026-05-04): busy-guard 가 body.is-app-busy 토글 →
   AI 무거운 작업 진행 중 다른 AI 버튼 시각 비활성화 + 클릭 차단.
   ExecPlan 011 강화 (이전엔 toast.warn 만, 이제는 진짜 disabled).
   .btn-ghost 는 제외 — 닫기/취소 같은 가벼운 버튼은 작업 중에도 클릭 가능해야. */
body.is-app-busy .btn-primary,
body.is-app-busy .btn-secondary,
body.is-app-busy .btn-ai,
body.is-app-busy [data-ai-action] {
  opacity: 0.45 !important;
  pointer-events: none !important;
  cursor: wait !important;
  filter: grayscale(40%);
}
/* ghost / danger / 닫기·취소 류는 비활성화 X (사장님이 작업 도중 닫기 가능해야) */
body.is-app-busy .btn-ghost,
body.is-app-busy [data-busy-allow] {
  opacity: 1 !important;
  pointer-events: auto !important;
  cursor: pointer !important;
  filter: none;
}
body.is-app-busy::after {
  content: "⏳ " attr(data-busy-label) " 진행 중";
  position: fixed;
  bottom: 16px;
  left: 16px;
  z-index: 10000;
  padding: 8px 16px;
  background: rgba(15, 23, 42, 0.92);
  color: #fff;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  pointer-events: none;
  box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.btn-primary   { background: var(--color-primary); color: var(--color-text-inverse); }
.btn-primary:hover:not(:disabled) { background: var(--color-primary-hover); }
.btn-secondary { background: transparent; border: 1.5px solid var(--color-border); color: var(--color-text-primary); }
.btn-secondary:hover:not(:disabled) { border-color: var(--color-primary); color: var(--color-primary); }
.btn-ghost     { background: transparent; color: var(--color-text-secondary); }
.btn-ghost:hover:not(:disabled) { color: var(--color-text-primary); }
.btn-danger    { background: var(--color-danger); color: var(--color-text-inverse); }
.btn-success   { background: #10B981; color: #FFFFFF; border: 0; }
.btn-success:hover:not(:disabled) { background: #059669; }
.btn-outline   { background: var(--color-bg-card); border: 1.5px solid var(--color-primary); color: var(--color-primary); font-weight: var(--font-semibold); }
.btn-outline:hover:not(:disabled) { background: var(--color-primary); color: #FFFFFF; }
.btn-sm        { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); }
.btn-lg        { padding: var(--space-4) var(--space-8); font-size: var(--text-base); }
.btn-block     { width: 100%; }

/* ── Inputs ──────────────────────────────────────────────── */
.input-field {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-input);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.input-field::placeholder { color: var(--color-text-muted); }
.input-field:focus {
  outline: none;
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
  background: var(--color-bg-card);
}
.input-field.has-banned {
  border-color: var(--color-banned-border);
  background: var(--color-banned-bg);
}
textarea.input-field { line-height: var(--leading-normal); resize: vertical; }
select.input-field { appearance: none; background-image: linear-gradient(45deg, transparent 50%, var(--color-text-muted) 50%), linear-gradient(135deg, var(--color-text-muted) 50%, transparent 50%); background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50%; background-size: 5px 5px, 5px 5px; background-repeat: no-repeat; padding-right: var(--space-8); }

.field-group  { display: flex; flex-direction: column; margin-bottom: var(--space-4); }
.field-label  {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
}
.field-row    { display: grid; grid-template-columns: 1fr 1fr; gap: var(--space-3); }
.checkbox-row {
  display: inline-flex; align-items: center; gap: var(--space-2);
  margin-bottom: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
  user-select: none;
}
.checkbox-row input[type="checkbox"] { width: 16px; height: 16px; accent-color: var(--color-primary); }

.radio-row { display: flex; flex-direction: column; gap: var(--space-2); }
.radio-item {
  display: inline-flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-input);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  cursor: pointer;
  transition: border-color var(--transition-base), background var(--transition-base);
}
.radio-item:has(input:checked) {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  font-weight: var(--font-semibold);
}
.radio-item input[type="radio"] { width: 16px; height: 16px; accent-color: var(--color-primary); margin: 0; }

/* 가격 요약 (정가 자동 계산 + 할인율 배지) */
.price-summary {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin: calc(-1 * var(--space-2)) 0 var(--space-4);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-section);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
}
.price-summary-label { color: var(--color-text-secondary); font-weight: var(--font-medium); }
.price-original { color: var(--color-text-primary); font-weight: var(--font-semibold); flex: 1; }
.price-badge {
  display: inline-flex; align-items: center;
  padding: 2px 10px;
  background: var(--color-accent-light);
  color: var(--color-accent-hover);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  letter-spacing: 0.02em;
}

/* ── App Shell ───────────────────────────────────────────── */
.app-shell {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}
.app-body {
  flex: 1;
  display: grid;
  grid-template-columns: var(--sidebar-width) 1fr;
  min-height: calc(100vh - var(--topbar-height));
}
.left-panel {
  background: var(--color-bg-card);
  border-right: 1px solid var(--color-border);
  overflow-y: auto;
  padding: 0;
  height: calc(100vh - var(--topbar-height));
  position: sticky;
  top: var(--topbar-height);
}
.left-panel-inner { display: flex; flex-direction: column; }
.left-panel-header {
  position: sticky;
  top: 0;
  z-index: 2;
  padding: var(--space-4) var(--space-5);
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-border);
}
.autosave-hint {
  margin: var(--space-2) 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
}
.left-panel-empty {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  padding: var(--space-6) var(--space-3);
  text-align: center;
}
.app-main {
  padding: var(--space-6);
  background: var(--color-bg);
}

@media (max-width: 1280px) {
  .app-body { grid-template-columns: 1fr; }
  .left-panel { position: static; height: auto; }
}

/* 홈 화면 모드 — 좌측 패널 숨기고 본문 풀폭 */
.app-shell.home-view .left-panel { display: none; }
.app-shell.home-view .app-body { grid-template-columns: 1fr; }
.app-shell.home-view .app-main { padding: 0; }

/* ── Tabs (Left Panel) ───────────────────────────────────── */
.tab-nav {
  display: flex;
  margin: 0 var(--space-5) var(--space-4);
  border-bottom: 1.5px solid var(--color-border);
}
.tab-body { padding: 0 var(--space-5) var(--space-5); }
.tab-item {
  flex: 1;
  padding: var(--space-3) var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: all var(--transition-base);
  background: none;
  white-space: nowrap;
  text-align: center;
}
.tab-item:hover {
  color: var(--color-primary);
  background: var(--color-bg-input);
}
.tab-item.active {
  color: var(--color-primary);
  border-bottom-color: var(--color-primary);
  font-weight: var(--font-bold);
}

.panel-section-title {
  display: block;
  margin: var(--space-5) 0 var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-primary);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  color: var(--color-text-inverse);
  text-align: center;
  letter-spacing: 0.02em;
  box-shadow: var(--shadow-sm);
}

/* ── Section Cards ───────────────────────────────────────── */
.section-flow {
  max-width: 920px;
  margin: 0 auto;
}
.section-flow-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-4);
  margin-bottom: var(--space-6);
}
.section-flow-head h2 {
  margin: 0 0 var(--space-1);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
  letter-spacing: -0.02em;
}
.section-flow-sub {
  margin: 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
}
.section-flow-actions { display: flex; gap: var(--space-2); align-items: center; flex-wrap: wrap; }
.section-flow-actions.compact {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
  justify-items: end;
}
.flow-action-row {
  display: flex;
  align-items: center;
  justify-content: flex-end;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.flow-action-row.secondary {
  opacity: 0.92;
}

.watermark-settings {
  position: relative;
}
.flow-manage-menu {
  position: relative;
}
.flow-manage-menu > summary {
  list-style: none;
  cursor: pointer;
}
.flow-manage-menu > summary::-webkit-details-marker {
  display: none;
}
.flow-manage-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 20;
  display: grid;
  gap: var(--space-2);
  min-width: 180px;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
  box-shadow: var(--shadow-lg);
}
.flow-manage-panel .btn {
  width: 100%;
  justify-content: center;
}
.watermark-settings > summary {
  list-style: none;
  cursor: pointer;
}
.watermark-settings > summary::-webkit-details-marker {
  display: none;
}
.watermark-settings.is-enabled > summary {
  border-color: #2563eb;
  color: #2563eb;
  background: #eff6ff;
}
.watermark-panel {
  position: absolute;
  right: 0;
  top: calc(100% + 8px);
  z-index: 20;
  width: min(360px, 82vw);
  padding: var(--space-4);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  text-align: left;
}
.watermark-panel .compact {
  margin-bottom: var(--space-3);
}
.watermark-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.watermark-grid .field-label {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--text-xs);
}

/* ── 탭 끝 "다음" CTA 영역 ───────────────────────── */
.next-tab-cta {
  margin: var(--space-5) 0 var(--space-3);
  padding: var(--space-4);
  background: var(--color-bg-input);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  text-align: center;
}
.next-tab-cta .btn-block {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
}
.next-tab-cta .hint {
  margin-top: var(--space-2);
  margin-bottom: 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
/* 섹션설정 탭의 2단계 CTA */
.cta-2step .cta-flow-hint {
  margin: 0 0 var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-text);
  text-align: center;
  line-height: 1.6;
}
.cta-2step .cta-flow-hint strong {
  color: var(--color-primary);
}
.cta-progress {
  margin-top: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.cta-progress .progress-text {
  margin: var(--space-2) 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  text-align: center;
  font-variant-numeric: tabular-nums;
}

/* ── AI 카테고리 추천 박스 ──────────────────────── */
.cat-recommend-box {
  margin: var(--space-4) 0;
  padding: var(--space-4);
  background: linear-gradient(135deg, rgba(139,92,246,0.05), rgba(99,102,241,0.05));
  border: 1px solid color-mix(in srgb, #8B5CF6 30%, transparent);
  border-radius: var(--radius-md);
}
.cat-recommend-title {
  margin: 0 0 var(--space-2);
  font-weight: var(--font-bold);
  color: #6366F1;
  font-size: var(--text-sm);
}
.cat-current-path {
  margin: 0;
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--color-text);
}

/* ── 맞춤 프롬프트 적용 배지 ───────────────────────── */
.custom-prompt-badge {
  display: inline-block;
  margin-left: var(--space-2);
  padding: 1px 8px;
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  background: linear-gradient(135deg, #8B5CF6 0%, #6366F1 100%);
  color: #fff;
  border-radius: 999px;
}
.translate-status {
  font-size: var(--text-xs);
  margin-left: var(--space-2);
}

/* ── 풀 그리드 드래그&드롭 강조 ─────────────────────── */
.pool-drop-zone {
  position: relative;
  transition: background 0.15s ease, box-shadow 0.15s ease;
  min-height: 80px;
}
.pool-drop-zone.drag-over {
  background: color-mix(in srgb, var(--color-primary) 6%, transparent);
  box-shadow: inset 0 0 0 2px var(--color-primary);
  border-radius: var(--radius-md);
}
.pool-drop-zone.drag-over::after {
  content: "📎 풀에 직접 추가";
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-weight: var(--font-bold);
  color: var(--color-primary);
  pointer-events: none;
  font-size: var(--text-base);
}

/* ── 보기 모드 토글 (섹션 카드 1/2/3 컬럼) ───────────── */
.view-mode-divider {
  display: inline-block;
  width: 1px;
  height: 24px;
  background: var(--color-border);
  margin: 0 var(--space-2);
}
.view-mode-toggle {
  display: inline-flex;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-bg-card);
}
.view-mode-btn {
  border: 0;
  background: transparent;
  padding: 6px 10px;
  font-size: var(--text-base);
  cursor: pointer;
  color: var(--color-text-muted);
  transition: all var(--transition-base);
}
.view-mode-btn + .view-mode-btn { border-left: 1px solid var(--color-border); }
.view-mode-btn:hover { background: var(--color-bg-input); color: var(--color-text); }
.view-mode-btn.active {
  background: var(--color-primary);
  color: #ffffff;
}

.section-cards { display: grid; gap: var(--space-4); }
.section-cards.cols-1 { grid-template-columns: 1fr; }
.section-cards.cols-2 { grid-template-columns: repeat(2, 1fr); }
.section-cards.cols-3 { grid-template-columns: repeat(3, 1fr); }
/* 작은 모드 — 카피 텍스트 폰트 살짝 축소로 빡빡함 완화 */
.section-cards.cols-3 .section-card-copy { font-size: var(--text-sm); }
.section-cards.cols-3 .section-card-head h3 { font-size: var(--text-sm); }
@media (max-width: 1100px) {
  .section-cards.cols-3 { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 800px) {
  .section-cards.cols-2,
  .section-cards.cols-3 { grid-template-columns: 1fr; }
}

/* 전체 생성 진행 바 */
.generate-progress {
  margin-bottom: var(--space-5);
  padding: var(--space-4) var(--space-5);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.progress-bar {
  height: 8px;
  background: var(--color-bg-input);
  border-radius: var(--radius-full);
  overflow: hidden;
}
.progress-fill {
  height: 100%;
  width: 0%;
  background: linear-gradient(90deg, var(--color-primary), var(--color-accent));
  border-radius: var(--radius-full);
  transition: width var(--transition-slow);
}
.progress-text {
  margin: var(--space-2) 0 0;
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  font-family: var(--font-mono);
}
.section-card {
  background: var(--color-bg-card);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-xl);
  padding: var(--space-5);
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.section-card.locked     { border-color: var(--color-section-locked); background: #F0FDF4; }
.section-card.generating { border-color: var(--color-section-generating); animation: pulse-border 1.5s infinite; }
.section-card.done       { border-color: var(--color-section-done); }
.section-card.empty      { border-style: dashed; }

.section-card-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-3);
}
.section-card-title { display: flex; align-items: baseline; gap: var(--space-3); }
.section-card-num   {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 36px; height: 24px;
  padding: 0 var(--space-2);
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  letter-spacing: 0.02em;
}
.section-card-name   { font-size: var(--text-base); font-weight: var(--font-semibold); }
.section-card-status { font-size: var(--text-xs); color: var(--color-text-muted); font-weight: var(--font-medium); }

.section-card.locked .section-card-status     { color: var(--color-section-locked); }
.section-card.done .section-card-status       { color: var(--color-section-done); }
.section-card.generating .section-card-status { color: var(--color-section-generating); }

.section-card-preview {
  margin: var(--space-3) 0;
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  overflow: hidden;
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.section-card-preview.preview-clickable {
  cursor: zoom-in;
  outline: 0;
  transition: box-shadow var(--transition-base), transform var(--transition-base);
}
.section-card-preview.preview-clickable:hover,
.section-card-preview.preview-clickable:focus-visible {
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.22);
}
.section-card-preview.empty {
  padding: var(--space-6);
  background: transparent;
  border: 1px dashed var(--color-border);
}
.section-card-preview img {
  display: block;
  width: 100%;
  height: auto;
  border-radius: var(--radius-lg);
}
.overseas-guide-preview {
  position: relative;
  background: #f8fafc;
}
.section-upload-hint {
  margin: var(--space-2) 0 var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.section-upload-meta {
  position: absolute;
  left: var(--space-2);
  bottom: var(--space-2);
  padding: 4px 8px;
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}
.section-card-preview.multi {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: var(--space-2);
  padding: var(--space-2);
  background: var(--color-bg-input);
}
.section-card-preview.multi img {
  border-radius: var(--radius-md);
  aspect-ratio: 3/4;
  object-fit: cover;
}
.section-card.error { border-color: var(--color-danger); background: #FEF2F2; }
.section-card.error .section-card-status { color: var(--color-danger); }
.section-card.dragging { opacity: 0.5; outline: 2px dashed var(--color-primary); }
.section-card[draggable="true"] [data-drag-handle] { cursor: grab; }
.section-card[draggable="true"] [data-drag-handle]:active { cursor: grabbing; }
.section-card-grip {
  display: inline-block;
  margin-right: var(--space-2);
  color: var(--color-text-muted);
  font-weight: var(--font-bold);
  letter-spacing: -2px;
  user-select: none;
}
.section-flow-hint {
  margin: var(--space-1) 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* multi-cell (product_staging) */
.section-card-preview.multi { gap: var(--space-2); padding: var(--space-2); }
.section-card-preview .multi-cell {
  position: relative;
  border-radius: var(--radius-md);
  overflow: hidden;
  background: var(--color-bg-card);
}
.section-card-preview .multi-cell.empty {
  aspect-ratio: 3/4;
  display: grid;
  place-items: center;
  background: var(--color-bg-input);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.section-card-preview .multi-cell img {
  border-radius: 0;
  aspect-ratio: 3/4;
}
.section-card-preview .multi-regen {
  position: absolute;
  top: var(--space-1);
  right: var(--space-1);
  padding: 2px 8px;
  background: rgba(15, 23, 42, 0.7);
  color: var(--color-text-inverse);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
}
.section-card-preview .multi-regen:hover { background: var(--color-primary); }

/* 섹션 에디터 (카피 / 프롬프트) */
.section-editor { display: flex; flex-direction: column; gap: var(--space-2); margin: var(--space-3) 0; }
.section-editor details {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg);
}
.section-editor summary {
  cursor: pointer;
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
  color: var(--color-text-secondary);
  padding: var(--space-1) 0;
}
.section-editor summary:hover { color: var(--color-primary); }
.section-editor .hint {
  margin: var(--space-2) 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}
.section-editor .hint code {
  background: var(--color-bg-input);
  padding: 1px 4px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-family: var(--font-mono);
}
.section-editor textarea { font-family: var(--font-primary); }
.section-editor .copy-warn {
  margin: var(--space-2) 0 0;
  padding: var(--space-2) var(--space-3);
  background: var(--color-banned-bg);
  border-radius: var(--radius-sm);
  color: var(--color-banned-text);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
}

/* AI 다듬기 인라인 미리보기 + 적용/취소 */
.copy-refine-preview {
  margin-top: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg-section);
  border: 1px solid var(--color-primary-light);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-md);
}
.copy-refine-preview[hidden] { display: none; }
.copy-variants-preview[hidden] { display: none; }
.copy-refine-preview-head {
  display: flex;
  align-items: baseline;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.copy-refine-preview-head strong {
  font-size: var(--text-sm);
  color: var(--color-primary-dark);
}
.copy-refine-preview-head .hint { margin: 0; }
.copy-refine-preview-text {
  margin: 0 0 var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg-card);
  border-radius: var(--radius-sm);
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  line-height: var(--leading-relaxed);
  white-space: pre-wrap;
  word-wrap: break-word;
}
.copy-refine-preview-actions { display: flex; gap: var(--space-2); }
.copy-variants-list {
  display: grid;
  gap: var(--space-2);
}
.copy-variant-card {
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
}
.copy-variant-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.copy-variant-head strong {
  font-size: var(--text-xs);
  color: var(--color-primary);
}
.copy-variant-card pre {
  margin: 0;
  white-space: pre-wrap;
  font-family: var(--font-primary);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
}
.btn-inline-alt {
  border-color: color-mix(in srgb, #F59E0B 40%, transparent);
  color: #B45309;
  background: #FFFBEB;
}

/* 무드 카드 */
.mood-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--space-2);
}
.mood-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  min-height: 130px;
  padding: var(--space-3);
  border: 2px solid transparent;
  border-radius: var(--radius-lg);
  cursor: pointer;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
  user-select: none;
}
.mood-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.mood-card.selected { border-color: var(--color-primary); box-shadow: var(--shadow-focus); }
.mood-card-head { display: flex; align-items: center; justify-content: space-between; }
.mood-card-id {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  opacity: 0.7;
  letter-spacing: 0.05em;
}
.mood-card-swatch {
  width: 14px; height: 14px;
  border-radius: var(--radius-full);
  box-shadow: 0 0 0 1px rgba(255,255,255,0.4);
}
.mood-card-label {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  letter-spacing: -0.01em;
}
.mood-card-feel { font-size: var(--text-xs); opacity: 0.85; line-height: var(--leading-tight); }
.mood-card-tone {
  font-size: var(--text-xs);
  opacity: 0.7;
  line-height: var(--leading-tight);
  margin-top: auto;
  font-style: italic;
}
.mood-card-check {
  position: absolute;
  top: var(--space-2);
  right: var(--space-2);
  width: 22px; height: 22px;
  display: grid; place-items: center;
  background: var(--color-primary);
  color: var(--color-text-inverse);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  box-shadow: var(--shadow-sm);
}
.mood-card-rec {
  display: inline-flex;
  align-items: center;
  padding: 1px 8px;
  background: rgba(245, 158, 11, 0.95);
  color: #FFFFFF;
  border-radius: var(--radius-full);
  font-size: 10px;
  font-weight: var(--font-bold);
  letter-spacing: 0.05em;
  box-shadow: var(--shadow-sm);
}
.mood-rec-hint {
  margin: 0 0 var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}

/* 배치 모달 */
.modal.modal-wide { max-width: 760px; }
.batch-list { display: flex; flex-direction: column; gap: var(--space-2); }
.batch-item {
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.batch-item.running   { border-color: var(--color-primary); background: var(--color-primary-light); }
.batch-item.completed { border-color: var(--color-success); }
.batch-item.error     { border-color: var(--color-danger); background: #FEF2F2; }
.batch-item-row {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}
.batch-item-name { font-weight: var(--font-semibold); }
.batch-item-pid {
  margin-left: var(--space-2);
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.batch-item-status { font-size: var(--text-xs); color: var(--color-text-secondary); }
.batch-item-error {
  margin: var(--space-2) 0 0;
  font-size: var(--text-xs);
  color: var(--color-danger);
}

/* 공유 뷰어 */
.share-page {
  max-width: 920px;
  margin: 0 auto;
  padding: var(--space-6);
}
.share-head {
  text-align: center;
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--color-border);
}
.share-head h1 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-3xl);
  font-weight: var(--font-bold);
  letter-spacing: -0.02em;
}
.share-brand { margin: 0; font-size: var(--text-base); color: var(--color-text-secondary); }
.share-merged { text-align: center; margin-bottom: var(--space-10); }
.share-merged img {
  max-width: 100%;
  border-radius: var(--radius-xl);
  box-shadow: var(--shadow-lg);
  margin-bottom: var(--space-4);
}
.share-sections h2 {
  margin: 0 0 var(--space-5);
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
}
.share-section-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-4);
}
.share-section {
  padding: var(--space-4);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
}
.share-section.empty { background: transparent; border-style: dashed; }
.share-section header {
  display: flex; align-items: center; gap: var(--space-3);
  margin-bottom: var(--space-3);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
}
.share-section-num {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}
.share-section-imgs {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: var(--space-2);
}
.share-section-imgs img {
  width: 100%;
  border-radius: var(--radius-md);
}
.share-section-copy {
  margin: var(--space-3) 0 0;
  padding: var(--space-3);
  background: var(--color-bg-section);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  line-height: var(--leading-relaxed);
}
.share-foot {
  margin-top: var(--space-12);
  padding-top: var(--space-6);
  border-top: 1px solid var(--color-border);
  text-align: center;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.section-card-actions {
  display: flex; gap: var(--space-2); flex-wrap: wrap;
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
.section-card-actions.grouped {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-2);
}
.section-action-group {
  display: grid;
  gap: var(--space-2);
  min-width: 0;
}
.action-group-label {
  color: var(--color-text-muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}
.action-group-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.section-action-group.primary {
  padding-bottom: var(--space-2);
  border-bottom: 1px dashed var(--color-border);
}
.section-action-group.manage {
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
}
.section-action-group.danger {
  justify-items: start;
}
.section-action-more {
  padding-top: var(--space-2);
  border-top: 1px dashed var(--color-border);
}
.section-action-more summary {
  cursor: pointer;
  color: var(--color-text-muted);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  list-style: none;
}
.section-action-more summary::-webkit-details-marker { display: none; }
.section-action-more summary::after {
  content: " 펼치기";
  color: var(--color-primary);
  font-weight: var(--font-semibold);
}
.section-action-more[open] summary {
  margin-bottom: var(--space-2);
}
.section-action-more[open] summary::after {
  content: " 접기";
}

@keyframes pulse-border {
  0%, 100% { border-color: var(--color-section-generating); }
  50%      { border-color: transparent; }
}

/* ── Home Screen ────────────────────────────────────────── */
.home-shell {
  width: 100%;
  min-height: calc(100vh - var(--topbar-height));
  margin: 0;
  padding: 0;
  display: grid;
  grid-template-columns: 320px minmax(0, 1fr);
  gap: 0;
  align-items: stretch;
  background: var(--color-bg);
}
.home-shell.sidebar-collapsed {
  grid-template-columns: 64px minmax(0, 1fr);
}
.home-screen {
  width: min(1180px, 100%);
  margin: 0 auto;
  padding: var(--space-6) var(--space-6) var(--space-10);
}
.home-saved-sidebar {
  position: sticky;
  top: var(--topbar-height);
  z-index: 3;
  height: calc(100vh - var(--topbar-height));
  overflow-y: auto;
  overflow-x: hidden;
  border-right: 1px solid #E2E8F0;
  background: #F8FAFC;
  box-shadow: 8px 0 24px rgba(15, 23, 42, 0.04);
  padding: var(--space-4);
}
.home-saved-sidebar-head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-bottom: var(--space-4);
}
.home-saved-sidebar-toggle {
  width: 32px;
  height: 32px;
  display: grid;
  place-items: center;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-subtle);
  color: var(--color-text);
  font: inherit;
  font-weight: 900;
  cursor: pointer;
}
.home-saved-sidebar-toggle:hover {
  border-color: #94A3B8;
  background: #fff;
}
.home-saved-sidebar-title {
  min-width: 0;
  display: grid;
  gap: 2px;
}
.home-saved-sidebar-title strong {
  font-size: var(--text-sm);
}
.home-saved-sidebar-title span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.home-sidebar-section {
  display: grid;
  gap: var(--space-2);
  padding: var(--space-3) 0;
  border-top: 1px solid #E2E8F0;
}
.home-sidebar-section:first-of-type {
  border-top: 0;
  padding-top: 0;
}
.home-sidebar-label {
  color: #64748B;
  font-size: var(--text-xs);
  font-weight: 800;
  line-height: 1;
}
.home-sidebar-quick-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
}
.home-sidebar-action {
  min-width: 0;
  min-height: 38px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 var(--space-3);
  border: 1px solid #CBD5E1;
  border-radius: var(--radius-md);
  background: #fff;
  color: #1E293B;
  font: inherit;
  font-size: var(--text-xs);
  font-weight: 800;
  cursor: pointer;
  text-align: center;
  box-shadow: 0 1px 2px rgba(15, 23, 42, 0.04);
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base), background var(--transition-base);
}
.home-sidebar-action:hover:not(:disabled) {
  border-color: #2563EB;
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}
.home-sidebar-action:disabled {
  opacity: .6;
  cursor: wait;
  transform: none;
}
.home-sidebar-action.primary {
  border-color: #1D4ED8;
  background: #2563EB;
  color: #fff;
}
.home-sidebar-action.danger {
  border-color: #FCA5A5;
  color: #B91C1C;
  background: #FFF7F7;
}
.home-sidebar-manage .home-sidebar-action {
  width: 100%;
  min-height: 40px;
}
.home-sidebar-status {
  min-height: 16px;
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  word-break: keep-all;
  overflow-wrap: anywhere;
}
.home-sidebar-result-list {
  display: grid;
  gap: var(--space-2);
}
.home-sidebar-result {
  width: 100%;
  display: grid;
  gap: 2px;
  padding: var(--space-3);
  border: 1px solid #E2E8F0;
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}
.home-sidebar-result:hover {
  border-color: #2563EB;
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.08);
  transform: translateY(-1px);
}
.home-sidebar-result strong,
.home-sidebar-result span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.home-sidebar-result strong {
  font-size: var(--text-sm);
  font-weight: 800;
}
.home-sidebar-result span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.home-saved-sidebar[data-collapsed="true"] {
  width: 52px;
  overflow: visible;
  padding-inline: var(--space-3);
}
.home-saved-sidebar[data-collapsed="true"] .home-saved-sidebar-title,
.home-saved-sidebar[data-collapsed="true"] .home-sidebar-section {
  display: none;
}
.home-saved-sidebar[data-collapsed="true"] .home-saved-sidebar-icon {
  transform: rotate(180deg);
}
.home-saved-sidebar[data-collapsed="true"] .home-saved-sidebar-head {
  margin-bottom: 0;
  justify-content: center;
}
.home-head {
  text-align: center;
  margin-bottom: var(--space-10);
  padding: var(--space-8) 0;
}
.home-head h2 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-3xl);
  font-weight: var(--font-extrabold);
  letter-spacing: -0.02em;
}
.home-head p {
  margin: 0;
  font-size: var(--text-base);
  color: var(--color-text-secondary);
}
.home-section { margin-bottom: var(--space-10); }
.home-section-title {
  font-size: var(--text-xl);
  font-weight: var(--font-bold);
  margin: 0 0 var(--space-4);
  letter-spacing: -0.01em;
}
.home-count { color: var(--color-text-muted); font-weight: var(--font-medium); font-size: var(--text-base); }

.home-mode-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-4);
}
.home-mode-card,
.home-tool-card {
  min-width: 0;
  border: 1px solid var(--color-border);
  background: var(--color-bg-card);
  color: var(--color-text);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  cursor: default;
  text-align: left;
  transition: transform var(--transition-base), box-shadow var(--transition-base), border-color var(--transition-base);
}
.home-mode-card {
  min-height: 172px;
  padding: var(--space-5);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.home-mode-card:hover,
.home-tool-card:hover {
  transform: translateY(-2px);
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
}
.home-mode-card.primary {
  border-color: rgba(37,99,235,.42);
  background: linear-gradient(180deg, #EFF6FF 0%, #FFFFFF 100%);
}
.home-card-main {
  width: 100%;
  min-width: 0;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: var(--space-2);
  padding: 0;
  color: inherit;
  text-align: left;
  cursor: pointer;
}
.home-card-main:hover strong {
  color: var(--color-primary-dark);
}
.home-batch-btn {
  margin-top: auto;
  align-self: flex-start;
  min-height: 32px;
  padding: 0 var(--space-3);
}
.home-mode-kicker {
  width: fit-content;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  background: #E0E7FF;
  color: var(--color-primary-dark);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}
.home-mode-card strong {
  font-size: var(--text-xl);
  font-weight: var(--font-extrabold);
  letter-spacing: 0;
}
.home-mode-card small,
.home-tool-card small {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.home-tool-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
.home-tool-card {
  min-height: 126px;
  position: relative;
  padding: 22px 20px 18px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  justify-content: flex-start;
  gap: 8px;
}
.home-tool-icon {
  position: absolute;
  top: 16px;
  right: 16px;
  display: grid;
  place-items: center;
  width: 30px;
  height: 30px;
  border-radius: var(--radius-sm);
  background: #EEF2FF;
  font-size: 18px;
}
.home-tool-card strong {
  min-width: 0;
  max-width: calc(100% - 42px);
  font-size: var(--text-xl);
  font-weight: var(--font-extrabold);
  line-height: var(--leading-tight);
  letter-spacing: 0;
}
.home-tool-card small {
  max-width: calc(100% - 18px);
  color: var(--color-text-secondary);
}
@media (max-width: 920px) {
  .home-mode-grid,
  .home-tool-grid {
    grid-template-columns: 1fr;
  }
}
.tool-preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: var(--space-2);
  margin: var(--space-2) 0 var(--space-3);
}
.tool-preset-card {
  display: grid;
  gap: 4px;
  min-height: 104px;
  padding: 11px 12px;
  text-align: left;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #FFFFFF;
  color: var(--color-text);
  cursor: pointer;
  transition: border-color .15s ease, box-shadow .15s ease, background .15s ease;
}
.tool-preset-card strong {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  font-size: var(--text-sm);
  line-height: var(--leading-tight);
}
.tool-preset-default {
  display: inline-flex;
  align-items: center;
  width: fit-content;
  padding: 2px 6px;
  border-radius: 999px;
  background: #DBEAFE;
  color: #1D4ED8;
  font-size: 11px;
  font-weight: 700;
  line-height: 1.2;
}
.tool-preset-card span,
.tool-preset-card em {
  display: block;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  color: var(--color-text-muted);
  font-style: normal;
}
.tool-preset-card em {
  color: #475569;
}
.tool-preset-card:hover,
.tool-preset-card.active {
  border-color: var(--color-primary);
  background: #EFF6FF;
  box-shadow: 0 0 0 2px rgba(37, 99, 235, .12);
}

.tool-screen {
  max-width: 1440px;
  margin: 0 auto;
}
/* ExecPlan 028 (2026-05-05): 3열 워크샵 — max-width 풀기 (사장님 보고: "좌우 여백 많은데 공간활용 안해"). */
.workshop-screen-page.tool-screen {
  max-width: none;
}

/* 사장님 룰 (2026-05-05): 분석 결과의 위험 경고 — 빨간 박스 강제 표시.
 * 50Hz only / 전기 호환성 등 사장님 직접 확인 필수 항목. */
/* 사장님 결정 (2026-05-06): 답변 카드 끝의 추가 금지/지시 textarea */
/* 사장님 결정 (2026-05-06): 브랜드 옛 후보 모달 */
.brand-history-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
  padding: 24px;
}
/* 사장님 결정 (2026-05-08): .modal { max-width: 540px } 가 깎고 있어 specificity + !important 강제 */
.modal.brand-history-modal,
.brand-history-modal {
  background: #fff;
  border-radius: 12px;
  width: min(1800px, 96vw) !important;
  max-width: min(1800px, 96vw) !important;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 60px rgba(15, 23, 42, 0.3);
}
/* 사장님 결정 (2026-05-08): 옛 후보 모달 1행 5개 + 카드 가로 더 크게 */
.brand-history-modal .brand-logo-grid {
  grid-template-columns: repeat(5, 1fr);
  gap: 14px;
}
.brand-history-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid #e2e8f0;
}
/* 사장님 결정 (2026-05-07): 옛 후보 모달 헤더 액션 영역 (선택 삭제 + 닫기) */
.brand-history-head-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.brand-history-bulk-delete {
  background: #dc2626 !important;
  color: #fff !important;
  border-color: #b91c1c !important;
  font-weight: 600 !important;
}
.brand-history-bulk-delete:hover:not([disabled]) {
  background: #b91c1c !important;
  border-color: #991b1b !important;
}
.brand-history-bulk-delete[disabled] {
  background: #fca5a5 !important;
  border-color: #fca5a5 !important;
  color: #fff !important;
  opacity: 0.7;
  cursor: not-allowed;
}
/* 사장님 결정 (2026-05-07): 옛 후보 카드 체크박스 */
.brand-history-check {
  position: absolute;
  top: 6px;
  left: 6px;
  z-index: 3;
  cursor: pointer;
  width: 24px;
  height: 24px;
}
.brand-history-check input[type="checkbox"] {
  position: absolute;
  opacity: 0;
  width: 24px;
  height: 24px;
  margin: 0;
  cursor: pointer;
  z-index: 4;
}
.brand-history-check-box {
  display: block;
  width: 24px;
  height: 24px;
  border-radius: 6px;
  border: 2px solid #cbd5e1;
  background: rgba(255, 255, 255, 0.95);
  transition: background 0.15s, border-color 0.15s;
  position: relative;
}
.brand-history-check input[type="checkbox"]:checked + .brand-history-check-box {
  background: #dc2626;
  border-color: #b91c1c;
}
.brand-history-check input[type="checkbox"]:checked + .brand-history-check-box::after {
  content: "✓";
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  color: #fff;
  font-size: 16px;
  font-weight: 700;
  line-height: 1;
}
.brand-history-modal .brand-card-wrap.is-checked {
  outline: 2px solid #dc2626;
  outline-offset: -2px;
}
.brand-history-head h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: #0f172a;
}
.brand-history-body {
  padding: 16px 18px;
  overflow-y: auto;
  flex: 1 1 auto;
}
.brand-history-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
.brand-history-item {
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 8px;
  cursor: pointer;
  transition: all 0.1s;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.brand-history-item:hover {
  border-color: #6366f1;
  box-shadow: 0 4px 12px rgba(99, 102, 241, 0.15);
  transform: translateY(-1px);
}
.brand-history-item img {
  width: 100%;
  height: auto;
  border-radius: 4px;
  display: block;
}
.brand-history-style {
  font-size: 11px;
  color: #475569;
  text-align: center;
  font-weight: 500;
}
/* 사장님 결정 (2026-05-08): 옛 후보 모달 페이지네이션 (한 페이지 25개) */
.brand-history-pagination {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 12px;
  padding: 14px 0 6px;
}
.brand-history-page-status {
  font-size: 13px;
  color: #475569;
  font-weight: 600;
  min-width: 180px;
  text-align: center;
}
.brand-history-foot {
  display: flex;
  justify-content: flex-end;
  padding: 12px 18px;
  border-top: 1px solid #e2e8f0;
}

/* 사장님 결정 (2026-05-08): 별점 = 카드 X, 확대 모달 하단으로 이동.
   기존 brand-preview-reason 자리 차지 (의미 없는 안내문 폐기). */
.brand-preview-rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  padding: 14px 16px 16px;
  background: #FFFBEB;
  border-top: 1px solid #FDE68A;
}
.brand-preview-rating-label {
  font-size: 13px;
  color: #92400E;
  font-weight: 600;
  letter-spacing: 0;
}
.brand-preview-rating-stars {
  display: flex;
  gap: 8px;
}
.brand-rating-comment-row {
  display: flex;
  gap: 6px;
  align-items: center;
  width: 100%;
  max-width: 480px;
  margin-top: 4px;
}
.brand-rating-comment {
  flex: 1;
  padding: 6px 10px;
  border: 1px solid #FDE68A;
  border-radius: 6px;
  font-size: 13px;
  background: #FFF;
  color: #1F2937;
}
.brand-rating-comment:focus {
  outline: none;
  border-color: #F59E0B;
  box-shadow: 0 0 0 2px rgba(245, 158, 11, 0.2);
}
.brand-rating-comment-save {
  white-space: nowrap;
  font-size: 12px;
  padding: 6px 10px;
}
.brand-rating-comment-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  align-items: center;
  width: 100%;
  max-width: 480px;
  margin-top: 4px;
}
.brand-rating-chips-label {
  font-size: 12px;
  color: #92400E;
  font-weight: 600;
  margin-right: 2px;
}
.brand-rating-chip {
  display: inline-block;
  padding: 3px 9px;
  background: #FEF3C7;
  border: 1px solid #FDE68A;
  border-radius: 12px;
  font-size: 12px;
  color: #78350F;
  max-width: 240px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.brand-rating-star {
  background: none;
  border: none;
  font-size: 26px;
  cursor: pointer;
  filter: grayscale(1) opacity(0.5);
  transition: filter 0.12s, transform 0.12s;
  padding: 4px;
  line-height: 1;
}
.brand-rating-star:hover {
  filter: grayscale(0) opacity(1);
  transform: scale(1.2);
}
.brand-rating-star.rated {
  filter: grayscale(0) opacity(1);
}

/* 사장님 결정 (2026-05-07 D): high risk 빨강 경고 banner — details 위 + 클릭 시 펼침 */
.hallucination-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 10px 0 6px;
  padding: 10px 14px;
  background: #fef2f2;
  border: 2px solid #dc2626;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
}
.hallucination-banner:hover {
  background: #fee2e2;
}
.hallucination-banner-icon {
  font-size: 22px;
  color: #dc2626;
  flex-shrink: 0;
}
.hallucination-banner-text {
  font-size: 13px;
  color: #7f1d1d;
  line-height: 1.4;
}
.hallucination-banner-text b {
  color: #b91c1c;
  font-weight: 700;
}
.hallucination-banner-text u {
  color: #b91c1c;
  font-weight: 600;
}
.risk-count-badge {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 8px;
  font-size: 11px;
  color: #fff;
  background: #dc2626;
  border-radius: 4px;
  font-weight: 600;
}
.report-section-regen-btn {
  margin-top: 6px;
  font-size: 11px !important;
  padding: 3px 8px !important;
  background: linear-gradient(180deg, #f0f9ff 0%, #e0f2fe 100%) !important;
  color: #0c4a6e !important;
  border-color: #7dd3fc !important;
  font-weight: 600 !important;
}
.report-section-regen-btn:hover:not([disabled]) {
  background: #bae6fd !important;
  border-color: #38bdf8 !important;
}
/* 사장님 결정 (2026-05-07 ABC): 한국화 결과 카드 hallucination warning + 원본 근거 표시 */
.report-section-card.is-hallucination-risk {
  border: 1px solid #f59e0b;
  background: #fffbeb;
}
.role-unknown-badge {
  display: inline-block;
  font-size: 10px;
  color: #92400e;
  background: #fde68a;
  padding: 1px 6px;
  border-radius: 4px;
  font-weight: 600;
  margin-left: 4px;
  vertical-align: middle;
}
.hallucination-warning {
  display: block;
  margin: 4px 0;
  padding: 6px 8px;
  font-size: 11px;
  color: #92400e;
  background: #fef3c7;
  border-left: 3px solid #f59e0b;
  border-radius: 3px;
  line-height: 1.4;
}
.report-section-truth {
  margin-top: 4px;
}
.truth-toggle {
  font-size: 11px;
  color: #0369a1;
  cursor: pointer;
  list-style: none;
  font-weight: 600;
}
.truth-toggle::-webkit-details-marker { display: none; }
.truth-toggle::before {
  content: "▶ ";
  display: inline-block;
  font-size: 9px;
  transition: transform 0.15s;
}
.report-section-truth[open] .truth-toggle::before { transform: rotate(90deg); }
.truth-content {
  display: block;
  margin-top: 4px;
  padding: 6px 8px;
  font-size: 10px;
  color: #075985;
  background: #f0f9ff;
  border-left: 2px solid #7dd3fc;
  border-radius: 3px;
  line-height: 1.5;
}
/* 사장님 결정 (2026-05-07): 한국화 답변 dropdown 이 업로드 의도 시 file input 표시 */
.localization-upload-area {
  margin-top: 8px;
  padding: 10px 12px;
  background: #f0f9ff;
  border: 1px dashed #7dd3fc;
  border-radius: 8px;
}
.localization-upload-area[hidden] {
  display: none;
}
.localization-upload-area .field-label {
  display: block;
  font-size: 12px;
  color: #075985;
  font-weight: 600;
  margin-bottom: 6px;
}
.localization-upload-input {
  display: block;
  width: 100%;
  font-size: 12px;
}
.localization-upload-preview {
  margin-top: 6px;
  font-size: 12px;
  color: #475569;
}
.localization-upload-success {
  display: flex;
  align-items: center;
  gap: 8px;
  color: #047857;
  font-weight: 600;
  font-size: 12px;
}
.localization-extra-instruction {
  margin-top: 12px;
  padding: 10px 12px;
  background: #fff7ed;
  border: 1px dashed #fdba74;
  border-radius: 8px;
}
/* 사장님 결정 (2026-05-07): 추가 금지/지시 textarea 옆 [AI 다듬기] 버튼 */
.localization-extra-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}
.localization-extra-instruction .field-label {
  display: block;
  font-size: 12px;
  color: #9a3412;
  font-weight: 600;
  margin-bottom: 6px;
}
.localization-extra-instruction .field-label .optional {
  color: #b45309;
  font-weight: 400;
}
.localization-extra-instruction textarea {
  background: #fff;
  border: 1px solid #fed7aa;
  font-size: 12px;
}

/* 사장님 catch (2026-06-28): "답변 + 추가 지시 반영" = 최종 생성 전 꼭 눌러야 하는 필수 버튼인데
   기존 btn-secondary btn-sm 회색 = 눈에 안 띔 → 풀폭 강조 CTA(그라데이션 + 글로우 + 은은한 펄스). */
/* 사장님 2026-07-04: 두 CTA(합본·안전분할 미리보기 / 답변+추가지시 반영) 동일 디자인 통일.
   옛 초록 그라디언트+펄스(과함)·회색 밋밋 둘 다 폐기 → 은은한 강조(연초록 배경+실선 테두리, 모던·안 튀게). */
.tool-soft-cta {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  width: 100%;
  margin-top: 12px;
  padding: 11px 16px;
  border: 1.5px solid #34d399;
  border-radius: 10px;
  background: #f0fdf4;
  color: #047857;
  font-weight: 700;
  font-size: 14px;
  line-height: 1.3;
  letter-spacing: -0.1px;
  cursor: pointer;
  text-align: center;
  transition: background 0.12s ease, border-color 0.12s ease;
}
.tool-soft-cta .tsc-main {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.tool-soft-cta .tsc-icon { font-size: 15px; }
.tool-soft-cta .tsc-hint {
  font-size: 11px;
  font-weight: 500;
  color: #059669;
  opacity: 0.82;
  letter-spacing: 0;
}
.tool-soft-cta:hover { background: #dcfce7; border-color: #10b981; }
.tool-soft-cta:active { background: #bbf7d0; }

/* 사장님 (2026-06-28): 재생성 대기열 바 — 개별 "+대기열"로 모아 한번에 batch 재생성. */
.regen-queue-bar {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin: 10px 0;
  padding: 10px 12px;
  background: #eff6ff;
  border: 1px solid #bfdbfe;
  border-radius: 10px;
}
.regen-queue-label { font-weight: 700; font-size: 13px; color: #1d4ed8; white-space: nowrap; }
.regen-queue-chips { display: flex; flex-wrap: wrap; gap: 6px; flex: 1 1 auto; }
.regen-queue-chip {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 6px 3px 10px;
  background: #fff;
  border: 1px solid #93c5fd;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 600;
  color: #1e40af;
}
.regen-queue-x {
  border: none;
  background: #dbeafe;
  color: #1e40af;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 11px;
  line-height: 1;
  padding: 0;
}
.regen-queue-x:hover { background: #bfdbfe; }
/* 사장님 (2026-06-28): 재생성 엔진 글로벌 선택기 (전체·선택·대기열·개별 모두 적용). */
.localized-global-engine {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  font-weight: 700;
  color: #3730A3;
}
.localized-global-engine select { width: auto; }
/* "➕ 대기열" 누른 섹션 = 눌린 표시(초록 채움). 다시 누르면 빼기(토글). */
[data-localized-queue-add].queued {
  background: #16a34a;
  border-color: #16a34a;
  color: #fff;
  font-weight: 700;
}
[data-localized-queue-add].queued:hover {
  background: #15803d;
  border-color: #15803d;
}

.localization-question-row.is-warning-row {
  border: 2px solid #dc2626 !important;
  background: linear-gradient(180deg, #fef2f2, #fee2e2) !important;
  box-shadow: 0 4px 14px rgba(220, 38, 38, 0.15);
  position: relative;
}
.localization-question-row.is-warning-row .warning-banner {
  background: #dc2626;
  color: #fff;
  font-weight: 700;
  font-size: var(--text-sm);
  padding: 6px 12px;
  margin: -8px -8px 8px -8px;
  border-radius: 6px 6px 0 0;
  letter-spacing: -0.2px;
  animation: warning-pulse 1.6s ease-in-out infinite;
}
@keyframes warning-pulse {
  0%, 100% { background: #dc2626; }
  50% { background: #b91c1c; box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.25); }
}
.localization-question-row.is-warning-row [data-localization-question] {
  color: #991b1b !important;
  font-weight: 800 !important;
}

/* ExecPlan 030 (2026-05-05): 패널 접기 — 사장님 보고 "와이드 눈 아픔, 처리된 건 서랍 수납".
 * 접힌 상태 = 36px 세로 띠 + 90도 회전 라벨 (파일철 탭). 클릭으로 토글. */
.tool-panel { position: relative; }
/* 접기 버튼 — 삼각형 하나만, 패널마다 색상 (사장님 룰 2026-05-05) */
.tool-panel-collapse-btn {
  position: absolute;
  top: 12px;
  right: 12px;
  z-index: 2;
  width: 36px;
  height: 36px;
  padding: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: none;
  border-radius: 50%;
  cursor: pointer;
  font-size: 18px;
  line-height: 1;
  transition: all 0.18s cubic-bezier(0.4, 0, 0.2, 1);
}
.tool-panel-collapse-btn::before {
  content: "◀";
  display: inline-block;
  transition: transform 0.18s ease;
}
.tool-panel-collapse-btn:hover { transform: translateX(-2px); }
.tool-panel-collapse-btn:hover::before { transform: scale(1.15); }
.tool-panel-collapse-btn:active { transform: scale(0.92); }
/* spine 화살표 동작과 통일 — spine 의 ::after 박힌 ▶ 제거 (위쪽에 박을 거) */
.tool-panel-spine::after { content: none !important; }
/* 패널별 색상 */
.tool-panel[data-collapsible-panel="input"] .tool-panel-collapse-btn { color: #2563eb; background: rgba(37, 99, 235, 0.1); }
.tool-panel[data-collapsible-panel="input"] .tool-panel-collapse-btn:hover { background: rgba(37, 99, 235, 0.22); }
.tool-panel[data-collapsible-panel="result"] .tool-panel-collapse-btn { color: #d97706; background: rgba(217, 119, 6, 0.1); }
.tool-panel[data-collapsible-panel="result"] .tool-panel-collapse-btn:hover { background: rgba(217, 119, 6, 0.22); }
.tool-panel[data-collapsible-panel="final"] .tool-panel-collapse-btn { color: #059669; background: rgba(5, 150, 105, 0.1); }
.tool-panel[data-collapsible-panel="final"] .tool-panel-collapse-btn:hover { background: rgba(5, 150, 105, 0.22); }

/* 접힘 spine — 위쪽 ▶ 삼각형 (펼치기 의미) + 90도 라벨. 일관 통일성. */
.tool-panel-spine {
  display: none;
  cursor: pointer;
  padding: 14px 0;
  text-align: center;
  user-select: none;
  height: 100%;
  border-radius: var(--radius-lg);
  transition: all 0.18s ease;
  position: relative;
  flex-direction: column;
  align-items: center;
  gap: 12px;
}
.tool-panel-spine::before {
  content: "▶";
  font-size: 18px;
  line-height: 1;
}
.tool-panel-spine span {
  writing-mode: vertical-rl;
  display: inline-block;
  font-weight: 700;
  letter-spacing: 4px;
  font-size: var(--text-sm);
  white-space: nowrap;
}
/* 패널별 spine 색상 */
.tool-panel[data-collapsible-panel="input"][data-collapsed="true"] {
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.08), rgba(37, 99, 235, 0.04)) !important;
  border: 1px solid rgba(37, 99, 235, 0.2) !important;
}
.tool-panel[data-collapsible-panel="input"] .tool-panel-spine span,
.tool-panel[data-collapsible-panel="input"] .tool-panel-spine::after { color: #2563eb; }
.tool-panel[data-collapsible-panel="input"][data-collapsed="true"]:hover {
  background: linear-gradient(180deg, rgba(37, 99, 235, 0.16), rgba(37, 99, 235, 0.08)) !important;
}
.tool-panel[data-collapsible-panel="result"][data-collapsed="true"] {
  background: linear-gradient(180deg, rgba(217, 119, 6, 0.08), rgba(217, 119, 6, 0.04)) !important;
  border: 1px solid rgba(217, 119, 6, 0.2) !important;
}
.tool-panel[data-collapsible-panel="result"] .tool-panel-spine span,
.tool-panel[data-collapsible-panel="result"] .tool-panel-spine::after { color: #d97706; }
.tool-panel[data-collapsible-panel="result"][data-collapsed="true"]:hover {
  background: linear-gradient(180deg, rgba(217, 119, 6, 0.16), rgba(217, 119, 6, 0.08)) !important;
}
.tool-panel[data-collapsible-panel="final"][data-collapsed="true"] {
  background: linear-gradient(180deg, rgba(5, 150, 105, 0.08), rgba(5, 150, 105, 0.04)) !important;
  border: 1px solid rgba(5, 150, 105, 0.2) !important;
}
.tool-panel[data-collapsible-panel="final"] .tool-panel-spine span,
.tool-panel[data-collapsible-panel="final"] .tool-panel-spine::after { color: #059669; }
.tool-panel[data-collapsible-panel="final"][data-collapsed="true"]:hover {
  background: linear-gradient(180deg, rgba(5, 150, 105, 0.16), rgba(5, 150, 105, 0.08)) !important;
}
.tool-panel[data-collapsed="true"] {
  padding: 0 !important;
  background: var(--color-bg-section) !important;
  cursor: pointer;
}
.tool-panel[data-collapsible-panel][data-collapsed="true"] > *:not(.tool-panel-spine):not(.tool-panel-collapse-btn) {
  display: none !important;
}
.tool-panel[data-collapsed="true"] .tool-panel-collapse-btn { display: none; }
.tool-panel[data-collapsed="true"] .tool-panel-spine { display: flex; }
/* grid columns 자동 축소 — 접힌 패널 36px, 펼친 패널은 1fr 균등 (사장님 룰: 비율 유지). */
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="input"][data-collapsed="true"]) {
  grid-template-columns: 36px 1fr 1fr;
}
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="result"][data-collapsed="true"]) {
  grid-template-columns: 1fr 36px 1fr;
}
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="final"][data-collapsed="true"]) {
  grid-template-columns: 1fr 1fr 36px;
}
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="input"][data-collapsed="true"]):has(.tool-panel[data-collapsible-panel="result"][data-collapsed="true"]) {
  grid-template-columns: 36px 36px 1fr;
}
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="input"][data-collapsed="true"]):has(.tool-panel[data-collapsible-panel="final"][data-collapsed="true"]) {
  grid-template-columns: 36px 1fr 36px;
}
.tool-screen-layout:has(.tool-panel[data-collapsible-panel="result"][data-collapsed="true"]):has(.tool-panel[data-collapsible-panel="final"][data-collapsed="true"]) {
  grid-template-columns: 1fr 36px 36px;
}
.tool-screen-head {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: var(--space-4);
  align-items: start;
  margin-bottom: var(--space-5);
  padding: var(--space-5);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-card);
  box-shadow: var(--shadow-sm);
}
.tool-screen-badge {
  display: inline-flex;
  width: fit-content;
  padding: 4px 10px;
  border-radius: var(--radius-full);
  background: #DBEAFE;
  color: var(--color-primary-dark);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-2);
}
.tool-screen-head h2 {
  margin: 0;
  font-size: var(--text-2xl);
  font-weight: var(--font-extrabold);
  letter-spacing: 0;
}
.tool-screen-head p {
  margin: var(--space-1) 0 0;
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.tool-screen-layout {
  display: grid;
  grid-template-columns: 1fr 1fr 1fr;
  gap: var(--space-4);
  align-items: start;
}
@media (max-width: 1400px) {
  .tool-screen-layout {
    grid-template-columns: minmax(320px, .8fr) minmax(560px, 1.5fr);
  }
  .tool-final-panel { grid-column: 1 / -1; }
}
.workshop-screen-page .tool-flow {
  position: static;
  grid-column: 1 / -1;
}
.workshop-screen-page .tool-flow ol {
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.workshop-screen-page .tool-flow-note {
  margin-top: var(--space-3);
}
.tool-flow,
.tool-panel {
  min-width: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-card);
  box-shadow: var(--shadow-sm);
}
.tool-flow {
  position: sticky;
  top: calc(var(--topbar-height) + var(--space-4));
  padding: var(--space-4);
}
.tool-flow h3,
.tool-panel h3 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
}
.tool-flow ol {
  display: grid;
  gap: var(--space-3);
  margin: 0;
  padding: 0;
  list-style: none;
}
.tool-flow li {
  display: grid;
  gap: 2px;
  padding-left: var(--space-3);
  border-left: 3px solid #BFDBFE;
}
.tool-flow li strong {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.tool-flow li span,
.tool-flow-note {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.tool-flow-note {
  margin: var(--space-4) 0 0;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: #F8FAFC;
}
.tool-panel {
  padding: var(--space-5);
}
.tool-action-row {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-top: var(--space-4);
}
.tool-bridge-form {
  margin-top: var(--space-5);
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-subtle);
}
.tool-bridge-form h4 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-text);
}
.localize-option-box {
  margin-top: var(--space-5);
  padding: var(--space-4);
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-md);
  background: #F8FAFC;
}
.localize-option-head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: start;
  margin-bottom: var(--space-3);
}
.localize-option-head h4 {
  margin: 0 0 var(--space-1);
  font-size: var(--text-sm);
  color: var(--color-text);
}
.localize-option-head .field-label {
  min-width: 130px;
}
.localize-option-rows {
  display: grid;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.localize-option-row {
  display: grid;
  grid-template-columns: 32px 30px minmax(120px, .75fr) minmax(180px, 1.25fr) auto minmax(72px, auto);
  gap: var(--space-2);
  align-items: center;
}
/* 2026-05-23 사장님 신규: 옵션 row 의 일괄 적용 체크박스 (큰 + 시각 강조) */
.localize-option-select {
  display: flex;
  align-items: center;
  justify-content: center;
}
.localize-option-select input[type="checkbox"] {
  width: 20px;
  height: 20px;
  cursor: pointer;
  accent-color: #2563EB;
}
/* 2026-05-23 사장님 신규: 옵션 처리 모드 select + badge */
.localize-option-mode {
  min-width: 130px;
  font-size: 12px;
}
.localize-option-mode-badge {
  display: inline-block;
  padding: 3px 8px;
  border-radius: 4px;
  background: #eff6ff;
  color: #1d4ed8;
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
}
.localize-option-row[data-option-mode="clean"] .localize-option-mode-badge {
  background: #fef3c7;
  color: #92400e;
}
.localize-option-row[data-option-mode="original"] .localize-option-mode-badge {
  background: #f1f5f9;
  color: #475569;
}
/* 2026-05-23 사장님 catch: 일괄 적용 영역 시각 강조 (전체 선택 버튼 크게) */
.localize-option-bulk-bar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  margin: 12px 0;
  background: #f8fafc;
  border: 2px dashed #cbd5e1;
  border-radius: 8px;
  flex-wrap: wrap;
}
.localize-option-bulk-bar #tool-option-bulk-select-all {
  font-size: 14px !important;
  font-weight: 700;
  padding: 8px 14px !important;
  background: #ffffff !important;
  border: 1.5px solid #2563EB !important;
  color: #2563EB !important;
  border-radius: 6px;
  cursor: pointer;
}
.localize-option-bulk-bar #tool-option-bulk-select-all:hover {
  background: #2563EB !important;
  color: #ffffff !important;
}
.localize-option-bulk-sep {
  display: inline-block;
  width: 1px;
  height: 22px;
  background: #cbd5e1;
}
.localize-option-bulk-label {
  font-size: 13px;
  font-weight: 600;
  color: #334155;
}
.localize-option-bulk-bar #tool-option-bulk-mode {
  min-width: 150px;
  font-size: 13px;
  padding: 6px 10px;
}
.localize-option-bulk-bar #tool-option-bulk-apply {
  font-size: 13px !important;
  font-weight: 700;
  padding: 8px 16px !important;
}
/* 2026-05-24 사장님 = 옵션 row spinner + 완료 badge + busy/done state */
.localize-option-preview {
  position: relative;
}
.localize-option-busy {
  position: absolute;
  inset: 0;
  background: rgba(255, 255, 255, 0.85);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 6px;
  z-index: 5;
  border-radius: inherit;
}
.localize-option-spinner {
  width: 28px;
  height: 28px;
  border: 3px solid #E5E7EB;
  border-top-color: #DC2626;
  border-radius: 50%;
  animation: localize-option-spin 0.8s linear infinite;
}
@keyframes localize-option-spin {
  to { transform: rotate(360deg); }
}
.localize-option-busy-label {
  font-size: 12px;
  font-weight: 700;
  color: #DC2626;
}
.localize-option-done-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: #16A34A;
  color: #FFFFFF;
  padding: 4px 10px;
  border-radius: 12px;
  font-size: 11px;
  font-weight: 700;
  z-index: 4;
  box-shadow: 0 2px 4px rgba(22, 163, 74, 0.3);
  animation: localize-option-done-pop 0.3s ease-out;
}
@keyframes localize-option-done-pop {
  from { transform: scale(0.7); opacity: 0; }
  to { transform: scale(1); opacity: 1; }
}
.localize-option-row-busy {
  outline: 2px dashed #DC2626;
  outline-offset: -2px;
}
.localize-option-row-done {
  outline: 2px solid #16A34A;
  outline-offset: -2px;
  background: #F0FDF4;
  transition: background 0.3s ease, outline 0.3s ease;
}

/* 2026-05-24 사장님 = 적용 버튼 크기 정합 강제 (font 13px + weight 700 + padding 8px 16px) */
.localize-option-bulk-bar .localize-option-bulk-generate,
.localize-option-bulk-generate {
  font-size: 13px !important;
  font-weight: 700 !important;
  padding: 8px 16px !important;
  line-height: 1.2 !important;
  height: auto !important;
  min-height: 0 !important;
  background: linear-gradient(135deg, #DC2626 0%, #EF4444 100%) !important;
  color: #FFFFFF !important;
  border: 1px solid #B91C1C !important;
  border-radius: var(--radius-md, 10px) !important;
  box-shadow: 0 2px 6px rgba(220, 38, 38, 0.3) !important;
  letter-spacing: -0.01em;
  cursor: pointer;
  transition: transform 0.1s ease, box-shadow 0.1s ease;
}
.localize-option-bulk-generate:hover {
  background: linear-gradient(135deg, #B91C1C 0%, #DC2626 100%) !important;
  box-shadow: 0 4px 12px rgba(220, 38, 38, 0.5) !important;
  transform: translateY(-1px);
}
.localize-option-bulk-generate:active {
  transform: translateY(0);
  box-shadow: 0 1px 4px rgba(220, 38, 38, 0.3) !important;
}
.input-field-sm { font-size: 12px; padding: 4px 8px; }
.localize-option-index {
  display: grid;
  place-items: center;
  width: 28px;
  height: 28px;
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #FFFFFF;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}
.localize-option-upload {
  white-space: nowrap;
}
.localize-option-upload-status {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.tool-project-bridge {
  margin: var(--space-4) 0;
  padding: var(--space-4);
  border: 1px solid rgba(37, 99, 235, .24);
  border-radius: var(--radius-md);
  background: rgba(37, 99, 235, .06);
}
.tool-project-bridge h4 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-base);
}
.tool-project-bridge p {
  margin: 0 0 var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.tool-status {
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
}
.tool-report-list {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.tool-report-card {
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.tool-report-card.large {
  background: #F8FAFC;
  border-color: #BFDBFE;
}
.tool-report-card strong {
  display: block;
  font-size: var(--text-lg);
  font-weight: var(--font-bold);
  margin-bottom: var(--space-2);
}
.tool-report-card p {
  margin: 0 0 var(--space-3);
  color: var(--color-text-secondary);
  line-height: var(--leading-normal);
}
.tool-report-card h4 {
  margin: var(--space-3) 0 var(--space-2);
  font-size: var(--text-sm);
  color: var(--color-primary-dark);
}
.tool-report-card ol,
.tool-report-card ul {
  margin: 0;
  padding-left: var(--space-5);
  color: var(--color-text);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.reference-assist-panel {
  display: grid;
  gap: var(--space-3);
  margin: var(--space-3) 0;
  padding: var(--space-3);
  border: 1px solid #C7D2FE;
  border-radius: var(--radius-md);
  background: #EEF2FF;
}
.localization-review-panel {
  border-color: #A7F3D0;
  background: #ECFDF5;
}
.reference-assist-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
}
.reference-assist-head h4,
.reference-assist-head p {
  margin: 0;
}
.reference-assist-head p {
  color: #475569;
  font-size: var(--text-xs);
}
.reference-question-list {
  display: grid;
  gap: var(--space-3);
}

/* 2026-05-24 사장님 명시 = 같은 섹션 visual grouping (section header 1회 + sub-questions 카드 묶음) */
/* 2026-05-24 강화 = 분별력 강화 (border 2~3px + gradient header + chip badge + accent line) */
.localization-section-group {
  border: 2px solid #3B82F6;
  border-radius: var(--radius-lg, 12px);
  background: linear-gradient(180deg, #EFF6FF 0%, #FFFFFF 60px);
  padding: 0 0 var(--space-3);
  display: grid;
  gap: var(--space-2);
  box-shadow: 0 2px 8px rgba(59, 130, 246, 0.12);
  margin-bottom: var(--space-3);
  position: relative;
  overflow: hidden;
}
.localization-section-group::before {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 6px;
  height: 100%;
  background: linear-gradient(180deg, #3B82F6 0%, #1D4ED8 100%);
}
.localization-section-group-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-3) var(--space-3) calc(var(--space-3) + 8px);
  background: linear-gradient(135deg, #1D4ED8 0%, #3B82F6 100%);
  color: #FFFFFF;
  border-bottom: 3px solid #1E40AF;
  margin-bottom: var(--space-1);
}
/* 2026-06-28 사장님 승인: 섹션 수동 🚫제외 — 제외 섹션 dim + 배지 + 룰힌트. */
.localization-section-group.is-excluded { opacity: 0.62; filter: grayscale(0.35); }
.localization-section-group.is-excluded .localization-section-group-header {
  background: linear-gradient(135deg, #6B7280 0%, #9CA3AF 100%);
  border-bottom-color: #4B5563;
}
/* 제외 섹션의 유료 도구(이미지수정/카피교체)는 막되, 제외 버튼 자체는 항상 클릭 가능(다시 포함용). codex 자문 A. */
.localization-section-group.is-excluded .localization-section-toolbar > *:not(.localization-section-exclude-btn):not(.localization-section-exclude-hint),
.localization-section-group.is-excluded .reference-question-row {
  opacity: 0.5;
  pointer-events: none;
}
.localization-section-excluded-badge {
  background: #DC2626; color: #fff; font-weight: 700; font-size: var(--text-xs, 12px);
  padding: 2px 8px; border-radius: 999px; white-space: nowrap; flex-shrink: 0;
}
.localization-section-exclude-hint { font-size: var(--text-xs, 12px); line-height: 1.3; align-self: center; }
.localization-section-exclude-hint.hint-safe { color: #15803D; }
.localization-section-exclude-hint.hint-caution { color: #B45309; font-weight: 600; }
.localization-section-exclude-hint.hint-info { color: #6B7280; }

/* 2026-06-28 사장님 승인 (B1): 다른 셀러 상세 추가 다이얼로그 + 묶음 배지. */
.add-bundle-backdrop {
  position: fixed; inset: 0; z-index: 9995;
  background: rgba(17,24,39,0.55); display: flex; align-items: center; justify-content: center;
}
.add-bundle-modal {
  background: #fff; border-radius: 12px; padding: 20px; width: min(560px, 92vw);
  box-shadow: 0 20px 50px rgba(0,0,0,0.3); max-height: 88vh; overflow: auto;
}
.add-bundle-help { font-size: 13px; color: #374151; line-height: 1.5; margin: 0 0 10px; }
.add-bundle-label { display: block; font-size: 13px; font-weight: 600; margin-bottom: 4px; }
.add-bundle-label input { margin-left: 6px; width: 180px; }
.localized-bundle-badge {
  background: #7C3AED; color: #fff; font-size: 11px; font-weight: 700;
  padding: 1px 7px; border-radius: 999px; margin-left: 6px; white-space: nowrap;
}
.localization-section-group-header strong {
  color: #FFFFFF;
  font-weight: var(--font-bold);
  font-size: var(--text-lg, 18px);
  letter-spacing: -0.02em;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  white-space: nowrap;   /* 2026-06-28 사장님: "7번 섹션" 2줄로 깨지던 것 fix */
  flex-shrink: 0;
}
.localization-section-group-header strong::before {
  content: "📌";
  font-size: var(--text-md);
}
.localization-section-group-header small {
  color: #FFFFFF;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  background: #DC2626;
  padding: 4px 12px;
  border-radius: 999px;
  letter-spacing: 0.02em;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.2);
  white-space: nowrap;
}
.localization-section-group .reference-question-row {
  background: #FFFFFF;
  margin: 0 var(--space-3);
  border: 1px solid #DBEAFE;
  border-left: 4px solid #60A5FA;
  position: relative;
}

/* 2026-05-24 사장님 명시 = facts row 영역 "카피 문구" 단일 라벨 + 과장/완화 2 라인 비교 */
.localization-question-facts .localization-copy-pair {
  background: #FAFAFA;
  border-left: 3px solid #6366F1;
  padding: 8px 12px;
  border-radius: var(--radius-xs, 4px);
}
.localization-question-facts .localization-copy-pair b {
  color: #4338CA;
}
.localization-copy-lines {
  display: grid;
  gap: 6px;
  margin-top: 6px;
}
.localization-copy-line {
  display: block;
  padding: 6px 10px;
  border-radius: var(--radius-xs, 4px);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  word-break: break-word;
}
.localization-copy-line em {
  font-style: normal;
  font-weight: var(--font-bold);
  margin-right: 6px;
}
.localization-copy-literal {
  background: #FEF2F2;
  border-left: 3px solid #EF4444;
  color: #7F1D1D;
}
.localization-copy-literal em {
  color: #B91C1C;
}
.localization-copy-softened {
  background: #F0FDF4;
  border-left: 3px solid #22C55E;
  color: #14532D;
}
.localization-copy-softened em {
  color: #15803D;
}

/* 2026-05-24 사장님 catch = 영역 표시 강조 = thumb bbox overlay + location_hint highlight */
.localization-question-thumb {
  position: relative;
  box-sizing: border-box;
}
/* 2026-05-26 cycle 22-3 = codex 진단서 fix = thumb frame 강제 (= img displayed rect 영역 = bbox % 영역 기준).
   옛 = button 영역 기준 % = button padding/border 영역 catch X = wrong scale 위험.
   신규 = .localization-thumb-frame 영역 안 img + bbox span 영역 강제 = frame = img display rect. */
.localization-thumb-frame {
  position: relative;
  display: block;
  width: 100%;
  height: 100%;
  box-sizing: border-box;
  line-height: 0;
}
.localization-thumb-frame > img {
  display: block;
  width: 100%;
  height: 100%;
  /* 2026-05-26 cycle 56 fix = bbox 영역 위치 정확 강제 (= 사장님 dogfood 4 차 fix 후 fail 잔존 catch).
     옛 = object-fit: cover = img 영역 center crop = bbox 영역 % 좌표 영역 = cropped 영역 = 위치 부정확.
     신규 = object-fit: contain = letterbox 영역 catch 단 bbox 영역 위치 정확. */
  object-fit: contain;
}
.localization-thumb-bbox {
  position: absolute;
  box-sizing: border-box;
  border: 3px solid #EF4444;
  background: rgba(239, 68, 68, 0.18);
  pointer-events: none;
  box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8), 0 0 10px rgba(239, 68, 68, 0.8);
  border-radius: 3px;
  /* 2026-05-24 사장님 catch = bbox 너무 작음 시 (height 2.2% = 1-2 픽셀) 시각 X = min size 강제.
     2026-05-26 cycle 22-5 = min-size 영역 강제 단 위치 영역 중심 대칭 영역 = JS attachOrUpdateBbox 영역 강제 정합. */
  min-width: 12px;
  min-height: 12px;
  z-index: 10;
  animation: localization-bbox-pulse 1.6s ease-in-out infinite;
}
@keyframes localization-bbox-pulse {
  0%, 100% {
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.8), 0 0 8px rgba(239, 68, 68, 0.6);
  }
  50% {
    box-shadow: 0 0 0 2px rgba(255, 255, 255, 0.9), 0 0 16px rgba(239, 68, 68, 1);
  }
}
/* 2026-05-26 Phase E fallback UI = 빈 bbox 시 thumb 자체 외곽선 + "위치 확인 필요" 띠 */
.localization-question-thumb.no-bbox {
  outline: 2px dashed #EF4444;
  outline-offset: -2px;
  position: relative;
}
.localization-question-thumb.no-bbox::after {
  content: "위치 확인 필요";
  position: absolute;
  top: 4px;
  right: 4px;
  background: rgba(239, 68, 68, 0.92);
  color: #FFFFFF;
  font-size: 10px;
  font-weight: 600;
  padding: 2px 6px;
  border-radius: 3px;
  pointer-events: none;
  z-index: 10;
}
.localization-question-facts .localization-location-row {
  background: #FFF7ED;
  border-left: 3px solid #F97316;
  padding: 6px 10px;
  border-radius: var(--radius-xs, 4px);
}
.localization-question-facts .localization-location-row b {
  color: #C2410C;
}

/* 2026-05-24 사장님 명시 = 옵션 별 결과 list (dropdown 옵션 정합) */
.localization-copy-pair .localization-copy-line {
  background: #FFFFFF;
  border-left: 3px solid #6366F1;
  color: var(--color-text);
}
.localization-copy-pair .localization-copy-line em {
  color: #4338CA;
}
.localization-copy-pair .localization-copy-hint {
  background: #F9FAFB;
  border-left-color: #94A3B8;
  color: #64748B;
  font-style: italic;
}
.localization-copy-pair .localization-copy-hint em {
  color: #475569;
  font-style: normal;
}
.localization-section-group .reference-question-row + .reference-question-row {
  margin-top: var(--space-2);
}
.localization-section-group .reference-question-row::before {
  content: "";
  position: absolute;
  top: -12px;
  left: 12px;
  width: 2px;
  height: 12px;
  background: #BFDBFE;
}
.localization-section-group .reference-question-row:first-child::before {
  display: none;
}
.reference-question-row {
  display: grid;
  gap: 6px;
  padding: var(--space-3);
  border: 1px solid #CBD5E1;
  border-radius: var(--radius-sm);
  background: #FFFFFF;
}
.reference-question-row > span {
  color: var(--color-text);
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
}
.reference-question-row small {
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.reference-question-actions {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-2);
}
.reference-question-actions em {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-style: normal;
  overflow-wrap: anywhere;
}
.localization-question-row select,
.localization-question-row textarea {
  width: 100%;
  min-width: 0;
}
.localization-auto-rules {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.localization-auto-rules span {
  display: block;
  min-width: 0;
  padding: 10px 12px;
  border: 1px solid #A7F3D0;
  border-radius: var(--radius-sm);
  background: #ECFDF5;
  color: #334155;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.localization-auto-rules b {
  display: block;
  margin-bottom: 2px;
  color: #047857;
  font-size: var(--text-sm);
}
.localization-question-body {
  display: grid;
  grid-template-columns: 118px minmax(0, 1fr);
  gap: var(--space-3);
  align-items: start;
}
/* 사장님 룰 (2026-05-05): thumb 없는 질문 (예: section_index 빈 "전체 상세페이지")
   은 단일 column 으로 — 118px 빈 자리 + 좁아진 content 가 한 글자씩 wrap 되던 버그 fix. */
.localization-question-body.no-thumb {
  grid-template-columns: minmax(0, 1fr);
}
.localization-question-content,
.localization-question-content * {
  min-width: 0;
  word-break: keep-all;
  overflow-wrap: anywhere;
}
/* 2026-06-28 사장님: 검토질문 = 진짜 핵심(plain 요약)이 하단 작은 글씨에 묻혀 모호했음.
   → aiJudgment 요약을 카드 상단 헤드라인으로 승격(눈에 먼저 들어오게). */
.localization-question-summary {
  margin: 4px 0 6px;
  padding: 8px 11px;
  background: #fff7ed;
  border-left: 3px solid #fb923c;
  border-radius: 6px;
  font-size: 13.5px;
  line-height: 1.5;
  color: #7c2d12;
  /* 2026-06-28 사장님: 2줄 wrap 시 둘째 줄을 본문 시작에 정렬(행잉 인덴트) = label/body flex 분리. */
  display: flex;
  gap: 7px;
  align-items: baseline;
}
.localization-question-summary .lq-sum-label { font-weight: 700; white-space: nowrap; flex-shrink: 0; }
.localization-question-summary .lq-sum-body { flex: 1; min-width: 0; font-weight: 600; }
/* 2026-06-28 사장님: 검토카드 전면 재정리 — 중요한 것(요약→추천→결정) 먼저, 근거는 접기. */
.localization-question-recommend {
  margin: 0 0 6px;
  padding: 6px 11px;
  background: #ecfdf5;
  border-left: 3px solid #10b981;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.45;
  color: #065f46;
  display: flex;
  gap: 7px;
  align-items: baseline;
}
.localization-question-recommend .lq-rec-label { color: #047857; font-weight: 700; white-space: nowrap; flex-shrink: 0; }
.localization-question-recommend .lq-rec-body { flex: 1; min-width: 0; }
.localization-question-recommend .loc-conf {
  margin-left: 8px; font-size: 11px; color: #059669; opacity: 0.85;
}
.localization-question-content [data-localization-question] {
  font-size: 13.5px; font-weight: 600; color: #334155; line-height: 1.5; display: block; margin: 2px 0 8px;
}
.localization-decision {
  margin: 6px 0;
  padding: 10px 12px;
  background: #eff6ff;
  border: 1.5px solid #bfdbfe;
  border-radius: 8px;
}
.localization-decision-label {
  display: block; font-size: 12.5px; font-weight: 800; color: #1d4ed8; margin-bottom: 6px;
}
.localization-decision select.input-field { font-weight: 600; }
.localization-choice-previews {
  margin-top: 7px; display: flex; flex-direction: column; gap: 3px;
}
.localization-choice-previews .localization-copy-line {
  font-size: 12px; color: #475569; line-height: 1.4; padding: 2px 6px; border-radius: 4px;
}
.localization-choice-previews .localization-copy-line em { font-style: normal; font-weight: 700; color: #334155; }
.localization-choice-previews .localization-copy-line.is-selected { background: #dbeafe; color: #1e3a8a; }
.localization-choice-previews .localization-copy-line.is-selected em { color: #1d4ed8; }
.localization-choice-previews .localization-copy-hint { opacity: 0.6; }
.localization-question-detail { margin: 4px 0 6px; }
.localization-question-detail > summary {
  cursor: pointer; font-size: 12px; color: #64748b; font-weight: 600;
  list-style: none; padding: 3px 0; user-select: none;
}
.localization-question-detail > summary:hover { color: #334155; }
.localization-question-detail[open] > summary { margin-bottom: 4px; }
/* 2026-06-28 사장님: 현지화 검토 마법사(시안 A) — 한 질문씩 + 진행도 + 이전/다음 + 전체목록. */
.lwiz-top { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-bottom: 14px; }
.lwiz-progress { display: flex; align-items: center; gap: 10px; flex: 1; }
.lwiz-bar { flex: 1; height: 8px; background: #e2e8f0; border-radius: 999px; overflow: hidden; max-width: 440px; }
.lwiz-bar > span { display: block; height: 100%; width: 0; background: linear-gradient(90deg,#3b82f6,#1d4ed8); border-radius: 999px; transition: width .25s ease; }
.lwiz-count { font-weight: 800; color: #1d4ed8; white-space: nowrap; font-size: 14px; }
.lwiz-bottom { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 18px; }
.lwiz-bottom [data-lwiz-prev]:disabled { opacity: .4; cursor: default; }
/* 시안 A = 큰 썸네일 왼쪽 + 결정 오른쪽 (2단 그리드 강제 = 겹침 방지). */
.localization-wizard .localization-question-body { display: grid !important; grid-template-columns: 300px 1fr; gap: 18px; align-items: start; }
.localization-wizard .localization-question-thumb { width: 100% !important; height: 384px !important; }
.localization-wizard .localization-question-content { min-width: 0; }
.localization-wizard .localization-question-body.no-thumb { grid-template-columns: 1fr; }
/* 전체목록 오버레이 (§13-A 바깥클릭 닫기) */
.lwiz-overlay { position: fixed; inset: 0; background: rgba(15,23,42,.45); z-index: 1000; display: flex; align-items: center; justify-content: center; padding: 20px; }
.lwiz-ov-panel { background: #fff; border-radius: 14px; width: min(560px,94vw); max-height: 80vh; overflow: auto; box-shadow: 0 20px 60px rgba(0,0,0,.3); }
.lwiz-ov-head { display: flex; justify-content: space-between; align-items: center; padding: 14px 16px; border-bottom: 1px solid #e2e8f0; position: sticky; top: 0; background: #fff; }
.lwiz-ov-list { padding: 8px; }
.lwiz-ov-row { display: flex; align-items: center; gap: 10px; padding: 9px 11px; border-radius: 8px; cursor: pointer; font-size: 13.5px; }
.lwiz-ov-row:hover { background: #f1f5f9; }
.lwiz-ov-row.cur { background: #eff6ff; font-weight: 700; }
.lwiz-ov-st { width: 18px; text-align: center; font-weight: 700; }
.lwiz-ov-st.done { color: #1d4ed8; } .lwiz-ov-st.cur { color: #10b981; } .lwiz-ov-st.warn { color: #f59e0b; }
@media(max-width:760px){ .localization-wizard .localization-question-thumb { width: 100% !important; height: 260px !important; } .localization-wizard .localization-question-body { flex-direction: column; } }
/* 2026-06-28 사장님: 검토질문 섹션별 도구(이미지 수정/카피 교체) — 그 섹션만, 전체 재분석 X.
   레이아웃 재정비 = 파란 헤더 밖 별도 툴바(밝은 배경)로 분리(제목 눌림/되돌리기 묻힘 fix). */
.localization-section-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
  margin: 0 var(--space-3) 8px;
  padding: 8px 10px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-top: none;
  border-radius: 0 0 8px 8px;
}
.localization-section-toolbar-label {
  font-size: 12px;
  font-weight: 700;
  color: #475569;
  white-space: nowrap;
  margin-right: 2px;
}
.localization-section-toolbar .input-field-sm { width: auto; }
.localization-section-toolbar-sep {
  width: 1px;
  align-self: stretch;
  background: #cbd5e1;
  margin: 2px 4px;
}
/* 2026-06-28 사장님: 검토단계 카피가 화면에 없어 '카피 교체' 효과가 안 보였음 → 현재 카피 미리보기. */
.localization-section-copy-preview {
  margin: 2px 0 8px;
  padding: 7px 11px;
  background: #f0f9ff;
  border-left: 3px solid #38bdf8;
  border-radius: 6px;
  font-size: 13px;
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 10px;
  align-items: baseline;
}
.localization-section-copy-preview b { color: #0369a1; font-size: 11.5px; }
.localization-section-copy-preview [data-copy-headline] { font-weight: 700; color: #0c4a6e; }
.localization-section-copy-preview [data-copy-sub] { color: #475569; }
.localization-question-thumb {
  width: 118px;
  height: 156px;
  overflow: hidden;
  border: 1px solid #CBD5E1;
  border-radius: var(--radius-sm);
  background: #F8FAFC;
  cursor: zoom-in;
  padding: 0;
}
.localization-question-thumb img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: top center;
}
.localization-question-content {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.localization-question-content > span {
  color: var(--color-text);
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
}
.localization-question-content > strong {
  color: #0F172A;
  font-size: 15px;
  line-height: var(--leading-normal);
}
.localization-question-facts {
  display: grid;
  gap: 6px;
}
.localization-question-facts small {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 8px;
  padding: 8px 10px;
  border: 1px solid #E2E8F0;
  border-radius: var(--radius-sm);
  background: #F8FAFC;
  color: #475569;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.localization-question-facts b {
  color: #1E40AF;
  font-weight: 800;
}
@media (max-width: 720px) {
  .localization-auto-rules {
    grid-template-columns: 1fr;
  }
  .localization-question-body {
    grid-template-columns: 86px minmax(0, 1fr);
  }
  .localization-question-thumb {
    width: 86px;
    height: 118px;
  }
  .localization-question-facts small {
    grid-template-columns: 1fr;
    gap: 2px;
  }
}
.reference-tone-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
}
.reference-tone-card {
  display: grid;
  gap: 4px;
  min-width: 0;
  padding: var(--space-2);
  border: 1px solid #CBD5E1;
  border-radius: var(--radius-sm);
  background: #FFFFFF;
}
.reference-tone-card strong {
  margin: 0;
  font-size: var(--text-sm);
}
.reference-tone-card small {
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.reference-tone-swatch {
  display: block;
  width: 100%;
  height: 12px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--tone-primary), var(--tone-accent));
}
.reference-template-summary {
  display: grid;
  gap: 4px;
  padding: var(--space-2);
  border: 1px dashed #A5B4FC;
  border-radius: var(--radius-sm);
  background: rgba(255, 255, 255, .68);
  color: #334155;
  font-size: var(--text-xs);
}
.reference-template-summary b {
  color: var(--color-text);
}
.reference-template-summary span,
.reference-template-summary small {
  overflow-wrap: anywhere;
}
/* 2026-07-04 최종결과 다중버전: 슬롯 칩 스트립(회색조·안튀게, 활성=대비강조). */
.snap-strip {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  margin: 0 0 var(--space-3);
  padding: 8px 10px;
  border: 1px solid var(--border, #E5E7EB);
  border-radius: var(--radius-md);
  background: var(--surface-muted, #F9FAFB);
}
.snap-strip-label {
  font-size: 11px;
  font-weight: 800;
  color: var(--text-muted, #6B7280);
  letter-spacing: .02em;
  margin-right: 2px;
}
.snap-chip {
  display: inline-flex;
  align-items: stretch;
  border: 1px solid var(--border, #E5E7EB);
  border-radius: 999px;
  background: #fff;
  overflow: hidden;
  font-size: 12px;
  line-height: 1.15;
}
.snap-chip-load {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  padding: 5px 12px;
  border: none;
  background: transparent;
  cursor: pointer;
  color: var(--text, #374151);
}
.snap-chip-load:hover { background: rgba(0,0,0,.04); }
.snap-chip-name { font-weight: 700; white-space: nowrap; }
.snap-chip-meta { font-size: 10px; color: var(--text-muted, #9CA3AF); white-space: nowrap; }
.snap-chip.working {
  padding: 5px 12px;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  border-style: dashed;
  color: var(--text-muted, #6B7280);
}
.snap-chip.active {
  border-color: #059669;
  box-shadow: 0 0 0 1px #059669 inset;
}
.snap-chip.active .snap-chip-name { color: #047857; }
.snap-chip.draft { background: var(--surface-muted, #F3F4F6); }
.snap-chip.draft .snap-chip-name { font-weight: 600; }
.snap-chip-mini {
  border: none;
  border-left: 1px solid var(--border, #EEF0F2);
  background: transparent;
  padding: 0 8px;
  cursor: pointer;
  color: var(--text-muted, #9CA3AF);
  font-size: 11px;
}
.snap-chip-mini:hover { background: rgba(0,0,0,.05); color: var(--text, #374151); }
.snap-chip-del:hover { background: #FEE2E2; color: #DC2626; }
.snap-chip-add {
  padding: 6px 14px;
  border: 1px dashed var(--border, #D1D5DB);
  border-radius: 999px;
  background: #fff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted, #6B7280);
}
.snap-chip-add:hover { border-color: #059669; color: #047857; background: #ECFDF5; }
:root[data-theme="dark"] .snap-strip,
:root[data-theme="dark"] .snap-chip.draft { background: rgba(255,255,255,.03); border-color: rgba(255,255,255,.10); }
:root[data-theme="dark"] .snap-chip,
:root[data-theme="dark"] .snap-chip-add { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); }
:root[data-theme="dark"] .snap-chip-load,
:root[data-theme="dark"] .snap-chip.working { color: #D1D5DB; }
:root[data-theme="dark"] .snap-chip.active { border-color: #34D399; box-shadow: 0 0 0 1px #34D399 inset; }
:root[data-theme="dark"] .snap-chip.active .snap-chip-name { color: #6EE7B7; }
.snap-chip-compare {
  padding: 6px 14px;
  border: 1px solid #6366F1;
  border-radius: 999px;
  background: #EEF2FF;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: #4338CA;
}
.snap-chip-compare:hover { background: #E0E7FF; }
:root[data-theme="dark"] .snap-chip-compare { background: rgba(99,102,241,.15); border-color: #818CF8; color: #C7D2FE; }

/* 2026-07-04 결과 버전 = 한 줄 컴팩트 바 + 드롭다운(공간절약). */
.snap-dd { position: relative; }
.snap-dd-summary {
  list-style: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 10px;
  border: 1px solid var(--border, #D1D5DB);
  border-radius: 8px;
  background: #fff;
  font-size: 12px;
  color: var(--text, #374151);
  white-space: nowrap;
  max-width: 260px;
}
.snap-dd-summary::-webkit-details-marker { display: none; }
.snap-dd-summary::marker { content: ""; }
.snap-dd-cur { font-weight: 700; overflow: hidden; text-overflow: ellipsis; }
.snap-dd-cur.is-working { color: var(--text-muted, #9CA3AF); font-weight: 600; }
.snap-dd-count { background: #EEF2FF; color: #4338CA; border-radius: 999px; padding: 0 6px; font-size: 10px; font-weight: 800; }
.snap-dd-caret { font-size: 9px; color: var(--text-muted, #9CA3AF); transition: transform 120ms; }
.snap-dd[open] .snap-dd-caret { transform: rotate(180deg); }
.snap-dd-panel {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: 60;
  min-width: 280px;
  max-height: 340px;
  overflow-y: auto;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #E5E7EB);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,.18);
  padding: 4px;
}
.snap-dd-row { display: flex; align-items: stretch; border-radius: 7px; }
.snap-dd-row:hover { background: rgba(0,0,0,.04); }
.snap-dd-row.active { background: #ECFDF5; }
.snap-dd-load {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  border: none;
  background: transparent;
  cursor: pointer;
  padding: 7px 10px;
  text-align: left;
  color: var(--text, #374151);
}
.snap-dd-load--static { cursor: default; }
.snap-dd-name { font-weight: 700; font-size: 12px; white-space: nowrap; }
.snap-dd-meta { font-size: 10px; color: var(--text-muted, #9CA3AF); }
.snap-dd-row--working:hover { background: transparent; }
.snap-dd-mini { display: inline-flex; align-items: center; border: none; background: transparent; cursor: pointer; padding: 0 9px; color: var(--text-muted, #6B7280); font-size: 11px; font-weight: 600; white-space: nowrap; }
.snap-dd-mini:hover { background: rgba(0,0,0,.06); border-radius: 6px; color: var(--text, #374151); }
.snap-dd-copy:hover { background: #EEF2FF; color: #4338CA; }
.snap-dd-del:hover { background: #FEE2E2; color: #DC2626; }
.snap-dd-empty { padding: 12px; font-size: 11px; color: var(--text-muted, #9CA3AF); text-align: center; }
.snap-dd-check { flex: none; align-self: center; margin: 0 6px 0 8px; width: 16px; height: 16px; cursor: pointer; }
.snap-dd-copy:hover { background: #EEF2FF; color: #4338CA; }
.snap-dd-bulk { display: flex; gap: 6px; margin-top: 4px; }
.snap-dd-seldel {
  flex: 1;
  padding: 8px 10px;
  border: 1px solid var(--border, #E5E7EB);
  border-radius: 7px;
  background: transparent;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: #DC2626;
  text-align: center;
}
.snap-dd-seldel:hover:not(:disabled) { background: #FEE2E2; border-color: #FCA5A5; }
.snap-dd-seldel:disabled { color: var(--text-muted, #9CA3AF); cursor: default; opacity: .55; }
.snap-dd-bulk .snap-dd-new { margin-top: 0; flex: 1; }
:root[data-theme="dark"] .snap-dd-seldel:hover:not(:disabled) { background: rgba(220,38,38,.2); }
.snap-dd-new {
  display: block;
  width: 100%;
  margin-top: 4px;
  padding: 8px 10px;
  border: 1px dashed var(--border, #D1D5DB);
  border-radius: 7px;
  background: transparent;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted, #6B7280);
  text-align: center;
}
.snap-dd-new:hover { border-color: #6366F1; color: #4338CA; background: #EEF2FF; }
:root[data-theme="dark"] .snap-dd-new:hover { background: rgba(99,102,241,.15); color: #C7D2FE; }
.snap-mini-btn {
  padding: 5px 11px;
  border: 1px solid var(--border, #D1D5DB);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted, #6B7280);
  white-space: nowrap;
}
.snap-save-btn:hover { border-color: #059669; color: #047857; background: #ECFDF5; }
.snap-save-dd { position: relative; display: inline-block; }
.snap-save-dd > summary { list-style: none; }
.snap-save-dd > summary::-webkit-details-marker { display: none; }
.snap-save-panel {
  position: absolute;
  top: calc(100% + 4px);
  left: 0;
  z-index: 60;
  min-width: 240px;
  background: var(--surface, #fff);
  border: 1px solid var(--border, #E5E7EB);
  border-radius: 10px;
  box-shadow: 0 12px 32px rgba(0,0,0,.18);
  padding: 10px;
}
.snap-save-hint { font-size: 11px; color: var(--text-muted, #6B7280); margin-bottom: 8px; line-height: 1.4; }
.snap-save-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.snap-save-chip {
  flex: 1;
  min-width: 64px;
  padding: 8px 10px;
  border: 1px solid var(--border, #D1D5DB);
  border-radius: 8px;
  background: #fff;
  cursor: pointer;
  font-size: 12px;
  font-weight: 700;
  color: var(--text, #374151);
  white-space: nowrap;
}
.snap-save-chip:hover { border-color: #059669; background: #ECFDF5; color: #047857; }
:root[data-theme="dark"] .snap-save-panel { background: #1F2430; border-color: rgba(255,255,255,.12); }
:root[data-theme="dark"] .snap-save-chip { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); color: #D1D5DB; }
.snap-compare-btn { border-color: #6366F1; background: #EEF2FF; color: #4338CA; }
.snap-compare-btn:hover { background: #E0E7FF; }
/* 최종결과 헤더 = [최초 결과로 되돌리기](중립 남색) + [전체 삭제](빨강 btn-danger). 사장님 2026-07-04. */
.tool-result-header-actions { display: inline-flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.tool-restore-btn { background: #475569; color: #fff; font-weight: 700; border: none; box-shadow: 0 1px 3px rgba(0,0,0,.15); }
.tool-restore-btn:hover { background: #334155; }
:root[data-theme="dark"] .tool-restore-btn { background: #64748B; }
:root[data-theme="dark"] .tool-restore-btn:hover { background: #475569; }
:root[data-theme="dark"] .snap-dd-summary,
:root[data-theme="dark"] .snap-mini-btn { background: rgba(255,255,255,.05); border-color: rgba(255,255,255,.12); color: #D1D5DB; }
:root[data-theme="dark"] .snap-dd-panel { background: #1F2430; border-color: rgba(255,255,255,.12); }
:root[data-theme="dark"] .snap-dd-load { color: #D1D5DB; }
:root[data-theme="dark"] .snap-dd-row.active { background: rgba(16,185,129,.15); }
:root[data-theme="dark"] .snap-compare-btn { background: rgba(99,102,241,.15); border-color: #818CF8; color: #C7D2FE; }

/* 버전 비교뷰 모달(Phase2). modal-overlay 백드롭 위 자체 패널. */
.snap-compare-overlay { display: flex; align-items: center; justify-content: center; padding: 24px; }
.snapcmp-panel {
  background: var(--surface, #fff);
  color: var(--text, #111827);
  border-radius: 14px;
  width: min(1200px, 96vw);
  max-height: 92vh;
  display: flex;
  flex-direction: column;
  overflow: hidden;
  box-shadow: 0 24px 60px rgba(0,0,0,.35);
}
.snapcmp-panel--compare { width: min(1600px, 98vw); }
.snapcmp-head {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--border, #E5E7EB);
  flex-wrap: wrap;
}
.snapcmp-head > b { font-size: 15px; }
.snapcmp-sub { font-size: 12px; color: var(--text-muted, #6B7280); }
.snapcmp-head-right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.snapcmp-x { border: none; background: transparent; font-size: 18px; cursor: pointer; color: var(--text-muted, #9CA3AF); padding: 2px 6px; }
.snapcmp-x:hover { color: var(--text, #111827); }
.snapcmp-gallery {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
  padding: 16px;
  overflow-y: auto;
}
.snapcmp-card {
  border: 2px solid var(--border, #E5E7EB);
  border-radius: 10px;
  overflow: hidden;
  cursor: pointer;
  background: var(--surface-muted, #F9FAFB);
  position: relative;
  display: flex; flex-direction: column;
}
.snapcmp-card.on { border-color: #6366F1; box-shadow: 0 0 0 1px #6366F1 inset; }
.snapcmp-card input { position: absolute; top: 8px; left: 8px; width: 18px; height: 18px; z-index: 2; }
.snapcmp-thumb { height: 150px; overflow: hidden; background: #F3F4F6; display: flex; align-items: flex-start; justify-content: center; }
.snapcmp-thumb img { width: 100%; object-fit: cover; object-position: top center; }
.snapcmp-cap { padding: 8px 10px; font-size: 12px; display: flex; flex-direction: column; gap: 2px; }
.snapcmp-cap b { font-weight: 700; }
.snapcmp-cap span { color: var(--text-muted, #9CA3AF); font-size: 11px; }
.snapcmp-foot {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 12px 16px; border-top: 1px solid var(--border, #E5E7EB);
}
.snapcmp-count { font-size: 13px; color: var(--text-muted, #6B7280); }
.snapcmp-sync { font-size: 12px; display: inline-flex; align-items: center; gap: 5px; color: var(--text-muted, #6B7280); }
.snapcmp-zoom { display: inline-flex; align-items: center; gap: 6px; }
.snapcmp-zoom span { font-size: 12px; min-width: 40px; text-align: center; }
.snapcmp-cols { display: flex; gap: 10px; padding: 12px; overflow: hidden; flex: 1; min-height: 0; }
.snapcmp-col { flex: 1 1 0; min-width: 0; display: flex; flex-direction: column; border: 1px solid var(--border, #E5E7EB); border-radius: 8px; overflow: hidden; }
.snapcmp-col-head { padding: 8px 10px; border-bottom: 1px solid var(--border, #EEF0F2); font-size: 12px; display: flex; flex-direction: column; gap: 1px; background: var(--surface-muted, #F9FAFB); }
.snapcmp-col-head span { color: var(--text-muted, #9CA3AF); font-size: 11px; }
.snapcmp-col-scroll { flex: 1; overflow: auto; background: #F3F4F6; text-align: center; }
.snapcmp-col-img { width: 100%; display: block; margin: 0 auto; }
.snapcmp-col-inner { width: 100%; margin: 0 auto; transition: width 80ms ease; }
.snapcmp-sec { position: relative; margin: 0; border-bottom: 2px dashed rgba(99,102,241,.4); }
.snapcmp-sec:last-child { border-bottom: none; }
.snapcmp-sec img { display: block; width: 100%; }
.snapcmp-sec-no { position: absolute; top: 6px; left: 6px; z-index: 2; background: rgba(15,23,42,.8); color: #fff; font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 999px; pointer-events: none; }
:root[data-theme="dark"] .snapcmp-panel { background: #1F2430; color: #E5E7EB; }
:root[data-theme="dark"] .snapcmp-sec { border-bottom-color: rgba(129,140,248,.5); }
:root[data-theme="dark"] .snapcmp-card, :root[data-theme="dark"] .snapcmp-col-head { background: rgba(255,255,255,.04); }
:root[data-theme="dark"] .snapcmp-thumb, :root[data-theme="dark"] .snapcmp-col-scroll { background: #111827; }

.localized-result-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--space-2);
  margin: var(--space-3) 0 var(--space-4);
  padding: var(--space-3);
  border: 1px solid #DBEAFE;
  border-radius: var(--radius-md);
  background: #EFF6FF;
}
/* 2026-06-30 사장님: 결과 툴바 = 연관 버튼끼리 그룹화(재생성/보기/편집/내보내기) + 구분선 = 통일감. */
.ltb-group {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-wrap: wrap;
}
.ltb-label {
  font-size: 11px;
  font-weight: 700;
  color: #1E3A8A;
  opacity: 0.65;
  margin-right: 2px;
  letter-spacing: 0.02em;
  white-space: nowrap;
}
.ltb-sep {
  width: 1px;
  align-self: stretch;
  min-height: 28px;
  background: #BFDBFE;
  margin: 0 4px;
}
/* 2026-06-30 사장님: 결과 툴바 = 모든 컨트롤 높이·모양·정렬 통일(제각각 catch). */
.localized-result-toolbar .btn,
.localized-result-toolbar a.btn,
.localized-result-toolbar select,
.localized-result-toolbar .localized-global-engine {
  height: 32px;
  box-sizing: border-box;
  display: inline-flex;
  align-items: center;
  border-radius: 8px;
  font-size: 12px;
  line-height: 1;
  vertical-align: middle;
}
.localized-result-toolbar .btn,
.localized-result-toolbar a.btn {
  padding: 0 12px;
}
.localized-result-toolbar select {
  padding: 0 8px;
}
.localized-result-toolbar .localized-global-engine {
  gap: 4px;
  font-weight: 600;
  color: #1E3A8A;
  border-radius: 0;        /* 라벨 래퍼 = 배경 없음 */
}
/* 1·2·3장 세그먼트 박스 = 평평하게(별도 박스/패딩 제거) → 일반 버튼과 동일 높이·모양 */
.localized-result-toolbar .localized-view-switch {
  padding: 0;
  border: none;
  background: transparent;
  gap: 6px;
  height: 32px;
  align-items: center;
}
.localized-view-switch {
  display: inline-flex;
  gap: 4px;
  padding: 4px;
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-sm);
  background: #FFFFFF;
}
.localized-view-switch .btn.active {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #FFFFFF;
}
.localized-section-grid {
  display: grid;
  gap: var(--space-3);
}
.localized-section-grid.cols-1 {
  grid-template-columns: minmax(0, 1fr);
}
.localized-section-grid.cols-2 {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.localized-section-grid.cols-3 {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.localized-section-card {
  margin: 0;
  overflow: hidden;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #FFFFFF;
  box-shadow: var(--shadow-sm);
  /* 사장님 (2026-06-28): 이미지 높이가 달라도 같은 행 카드의 액션 바를 바닥 정렬.
     카드=flex칼럼 + figcaption이 남은 높이 채우고 actions를 margin-top:auto로 바닥에. */
  display: flex;
  flex-direction: column;
  height: 100%;
}
.localized-image-button {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: #F8FAFC;
  cursor: zoom-in;
  position: relative;
}
/* ExecPlan 031 (2026-05-06) — AI 보강 섹션 시각 badge */
.enrichment-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  padding: 3px 8px;
  background: rgba(99, 102, 241, 0.92);
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  border-radius: 4px;
  pointer-events: none;
  text-shadow: 0 1px 2px rgba(0, 0, 0, 0.2);
  z-index: 1;
}
.enrichment-prompt-peek,
.enrichment-prompt-peek-btn {
  display: inline-block;
  margin-left: 6px;
  padding: 2px 8px;
  background: rgba(99, 102, 241, 0.12);
  color: #6366f1;
  font-size: 10px;
  font-weight: 600;
  border-radius: 3px;
  cursor: pointer;
  font-family: inherit;
  border: 1px solid rgba(99, 102, 241, 0.3);
}
.enrichment-prompt-peek-btn:hover {
  background: rgba(99, 102, 241, 0.2);
}

/* 사장님 룰 (2026-05-06): enrichment 컷 [📝 prompt 보기 / 수정] 모달 */
.enrichment-prompt-modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9000;
}
.enrichment-prompt-modal {
  background: #fff;
  border-radius: 10px;
  width: min(720px, 92vw);
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  box-shadow: 0 20px 50px rgba(15, 23, 42, 0.25);
}
.enrichment-prompt-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid #e2e8f0;
}
.enrichment-prompt-head h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 700;
  color: #0f172a;
}
.enrichment-prompt-body {
  padding: 16px 18px;
  overflow-y: auto;
  flex: 1 1 auto;
}
.enrichment-prompt-field {
  margin-bottom: 14px;
}
.enrichment-prompt-field label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #334155;
  margin-bottom: 6px;
}
.enrichment-prompt-edit,
.enrichment-prompt-copy {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  resize: vertical;
}
.enrichment-prompt-copy {
  font-weight: 600;
  color: #1e3a8a;
  background: #f0f9ff;
}
.enrichment-prompt-copy-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}
.enrichment-prompt-copy-head label {
  margin: 0;
}
.enrichment-prompt-hint {
  margin: 6px 0 0;
  font-size: 11px;
  color: #64748b;
}
.enrichment-prompt-details {
  margin-top: 10px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  padding: 8px 12px;
}
.enrichment-prompt-details summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  color: #475569;
}
.enrichment-prompt-readonly {
  margin: 8px 0 0;
  padding: 10px 12px;
  background: #f8fafc;
  border-radius: 4px;
  font-size: 11px;
  font-family: ui-monospace, "Cascadia Code", monospace;
  color: #334155;
  white-space: pre-wrap;
  max-height: 280px;
  overflow-y: auto;
}
.enrichment-prompt-ko-list {
  margin: 8px 0 0;
  padding-left: 18px;
  font-size: 12px;
  color: #334155;
}
.enrichment-prompt-foot {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  padding: 12px 18px;
  border-top: 1px solid #e2e8f0;
}
/* 사장님 룰 (2026-05-06 v2): TOC 좁은 사이드바 — title 위 + 버튼 아래 (column flex) */
.merged-preview-toc-title-row {
  display: flex;
  flex-direction: row;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 6px;
  white-space: nowrap;
}
.merged-preview-toc-title-row .merged-preview-toc-title {
  margin: 0;
  white-space: nowrap;
  font-size: 11px;
}
/* 사장님 룰 (v7 2026-05-06): 사이드바 [🗑 임시삭제]/[🗑 휴지통] 과 동일 룰.
   .merged-preview-overlay.is-light .merged-preview-toc button (0,3,1) 가 항상 이기므로
   selector 로는 이길 수 없음 → !important 강제. 다크/라이트 모두 빨강 일관. */
.merged-preview-toc .merged-toc-bulk-delete {
  display: inline-block !important;
  width: auto !important;
  min-height: 0 !important;
  background: transparent !important;
  border: 0 !important;
  font-size: var(--text-xs) !important;
  font-weight: var(--font-semibold) !important;
  cursor: pointer;
  color: var(--color-danger) !important;
  padding: var(--space-1) var(--space-2) !important;
  border-radius: var(--radius-sm) !important;
  line-height: 1.3;
  transition: background var(--transition-fast), color var(--transition-fast), opacity var(--transition-fast);
  letter-spacing: 0.01em;
  white-space: nowrap;
  flex-shrink: 0;
}
.merged-preview-toc .merged-toc-bulk-delete:hover:not(:disabled) {
  background: var(--color-banned-bg) !important;
  color: var(--color-banned-text) !important;
}
.merged-preview-toc .merged-toc-bulk-delete:disabled {
  cursor: not-allowed;
  opacity: 0.45;
}
/* 사장님 룰 (v5 2026-05-06): 비교 목차 디자인 그대로 (.merged-preview-toc button 룰 활용)
   + 왼쪽에 체크박스만 추가. 기존 button 박스/번호 스타일 보존. */
.merged-preview-toc-item {
  display: flex;
  align-items: center;
  gap: 6px;
}
.merged-preview-toc-item button {
  flex: 1;
}
.merged-toc-checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #DC2626;
  flex-shrink: 0;
  margin: 0;
}

/* 사장님 룰 (v6 2026-05-06): 카드 어디든 잡고 drag 순서 변경 (핸들 X) */
.merged-preview-section[data-reorder-section] { cursor: grab; }
.merged-preview-section[data-reorder-section]:active { cursor: grabbing; }
.merged-preview-section.is-dragging { opacity: 0.4; transform: scale(0.97); }
.merged-preview-section.is-drop-target { position: relative; }
.merged-preview-section.is-drop-target.drop-before::before,
.merged-preview-section.is-drop-target.drop-after::after {
  content: "";
  position: absolute;
  left: 0;
  right: 0;
  height: 4px;
  background: #4F46E5;
  box-shadow: 0 0 0 2px rgba(79, 70, 229, 0.3);
  z-index: 10;
  pointer-events: none;
}
.merged-preview-section.is-drop-target.drop-before::before { top: -2px; }
.merged-preview-section.is-drop-target.drop-after::after { bottom: -2px; }
/* 사장님 룰 (v2 2026-05-06): 핸들에서만 drag 시작 — pointer-events:auto + cursor:grab + zoom panning 차단 */
.merged-reorder-handle {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 6px 10px;
  background: rgba(79, 70, 229, 0.92);
  color: #fff;
  font-size: 16px;
  font-weight: 800;
  border-radius: 6px;
  pointer-events: auto !important;
  cursor: grab;
  z-index: 100;
  letter-spacing: -2px;
  user-select: none;
  transition: background 0.12s, transform 0.12s;
}
.merged-reorder-handle:hover { background: rgba(79, 70, 229, 1); transform: scale(1.05); }
.merged-reorder-handle:active { cursor: grabbing; transform: scale(0.95); }

/* 사장님 룰 (2026-05-06): 1장 이어보기 + 아이콘 기능 안내문 — 결과 toolbar 위 */
.localized-help-hint {
  margin: 0 0 var(--space-2);
  padding: 7px 10px;
  background: linear-gradient(90deg, rgba(99, 102, 241, 0.06), rgba(168, 85, 247, 0.06));
  border: 1px solid rgba(99, 102, 241, 0.2);
  border-radius: 8px;
  font-size: 12px;
  line-height: 1.45;
  color: var(--color-text-secondary);
}
.localized-help-hint strong { color: var(--color-text); }
.localized-help-hint small { color: var(--color-text-muted); display: inline-block; margin-left: 6px; }
.hint-chip {
  display: inline-block;
  margin: 0 4px;
  padding: 2px 8px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font-size: 12px;
  font-weight: 500;
}
.hint-chip-ai {
  background: rgba(99, 102, 241, 0.08);
  border-color: rgba(99, 102, 241, 0.3);
  color: #4F46E5;
  font-weight: 600;
}

/* 사장님 룰 (2026-05-06): 다중 선택 질문 (충전 방식 등) checkbox group */
.localization-choice-group {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  padding: 8px 10px;
  background: #F8FAFC;
  border: 1px solid var(--color-border);
  border-radius: 6px;
}
.localization-choice-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  font-size: 13px;
  cursor: pointer;
  user-select: none;
  transition: all 0.12s ease;
}
.localization-choice-item:hover { background: #EEF2FF; border-color: #C7D2FE; }
.localization-choice-item input[type="checkbox"]:checked + span { color: #4F46E5; font-weight: 600; }
.localization-choice-item:has(input:checked) { background: #EEF2FF; border-color: #818CF8; }
.localized-image-button img {
  display: block;
  width: 100%;
  max-height: 520px;
  object-fit: contain;
}
.localized-section-card figcaption {
  display: grid;
  gap: 4px;
  padding: var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  /* 사장님 (2026-06-28): 푸터(체크박스 → 제목 → 액션) 블록을 통째로 카드 바닥에.
     이미지 높이가 달라도 같은 행 카드의 체크박스/액션 라인이 같은 높이에 정렬됨. */
  margin-top: auto;
}
.localized-section-card figcaption b {
  color: var(--color-text);
}
.localized-section-check {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  min-width: 0;
  cursor: pointer;
}
.localized-section-check input {
  flex: 0 0 auto;
  width: 16px;
  height: 16px;
  margin-top: 1px;
  accent-color: var(--color-primary);
}
.localized-selected-rerun-btn {
  border-color: #A5B4FC;
  background: #EEF2FF;
  color: #3730A3;
  font-weight: 800;
}
.localized-selected-rerun-btn:hover {
  border-color: #6366F1;
  background: #E0E7FF;
}
.localized-section-card figcaption a {
  color: var(--color-primary);
  font-weight: var(--font-semibold);
}
.localized-section-actions {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  margin-top: 6px;
}
.localized-section-rerun-btn {
  border-color: #C7D2FE;
  background: #EEF2FF;
  color: #3730A3;
  font-weight: 800;
}
.localized-section-rerun-btn:hover {
  border-color: #818CF8;
  background: #E0E7FF;
}
.localized-preview-overlay {
  position: fixed;
  inset: 0;
  z-index: 2200;
  display: grid;
  place-items: center;
  padding: var(--space-5);
  background: rgba(15, 23, 42, .86);
}
.localized-preview-shell {
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  width: min(980px, calc(100vw - 48px));
  height: min(92vh, 1100px);
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: #0F172A;
  box-shadow: var(--shadow-lg);
}
.localized-preview-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  color: #FFFFFF;
  border-bottom: 1px solid rgba(255,255,255,.12);
}
.localized-preview-body {
  overflow: auto;
  padding: var(--space-4);
  text-align: center;
  background: #111827;
}
.localized-preview-body img {
  max-width: 100%;
  height: auto;
  background: #FFFFFF;
}
/* 2026-06-14 사장님 = 옵션 이미지 수동 크롭 모달 (A옵션). 드래그로 영역 지정 → 흰 1000×1000. */
.option-crop-body {
  overflow: auto;
  padding: var(--space-4);
  background: #111827;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--space-3);
}
.option-crop-stage {
  position: relative;
  display: inline-block;
  line-height: 0;
  user-select: none;
}
.option-crop-image {
  display: block;
  max-width: 100%;
  max-height: 68vh;
  width: auto;
  height: auto;
  background: #FFFFFF;
  cursor: crosshair;
}
.option-crop-rect {
  position: absolute;
  border: 3px solid #a855f7;
  border-radius: 10px;
  background: rgba(168, 85, 247, .10);
  box-shadow: 0 0 0 9999px rgba(15, 23, 42, .45), 0 0 10px 2px rgba(236, 72, 153, .6);
  pointer-events: none;
}
.option-crop-hint {
  margin: 0;
  color: #CBD5E1;
  font-size: 12px;
  text-align: center;
}
/* 2026-05-24 사장님 명시: 옵션 카드 2열 고정 (auto-fit = 화면 넓으면 3+열 자동, 사장님 X) */
.localize-option-rows,
.localize-insert-rows {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: var(--space-3);
  align-items: start;
}
/* 2026-05-24 사장님 명시: 상단 URL + 옵션명 textarea paste → 자동 카드 생성 */
.localize-option-bulk-paste {
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  padding: 12px;
  margin-bottom: 12px;
}
.localize-option-bulk-paste-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
  margin-bottom: 10px;
}
.localize-option-bulk-paste-row textarea {
  resize: vertical;
  min-height: 80px;
  font-family: ui-monospace, SFMono-Regular, monospace;
  font-size: 12px;
  line-height: 1.4;
}
.localize-option-bulk-paste-actions {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}
@media (max-width: 768px) {
  .localize-option-bulk-paste-row { grid-template-columns: 1fr; }
}
.localize-option-row,
.localize-insert-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--space-3);
  align-items: stretch;
  padding: var(--space-3);
  border: 1px solid #D7E3F7;
  border-radius: var(--radius-md);
  background: #FFFFFF;
  box-shadow: var(--shadow-sm);
}
.localize-option-preview,
.localize-insert-preview {
  position: relative;
  display: grid;
  place-items: center;
  min-height: 136px;
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border: 1px dashed #ADC3E8;
  border-radius: var(--radius-sm);
  background: linear-gradient(135deg, #F8FAFC, #EEF4FF);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  text-align: center;
}
.localize-insert-preview {
  aspect-ratio: 780 / 520;
}
/* 2026-06-14 사장님 = 옵션 프리뷰는 정사각(상품 옵션 이미지 정합) + contain = 전체 크게 보임. */
.localize-option-preview {
  aspect-ratio: 1 / 1;
}
.localize-insert-preview img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
/* 2026-06-14 사장님 = 옵션 그리드 프리뷰는 전체 보여주기(crop X) — 하단 잘려서 미번역 중국어 못 보던 문제. */
.localize-option-preview img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  background: #f1f5f9;
}
.localize-option-preview .localize-option-index,
.localize-insert-preview .localize-option-index {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 1;
  box-shadow: 0 6px 16px rgba(37, 99, 235, .28);
}
.localize-option-empty {
  display: block;
  padding: 0 var(--space-3);
  line-height: var(--leading-normal);
  word-break: keep-all;
}
.localize-option-fields,
.localize-insert-fields {
  display: grid;
  gap: var(--space-2);
}
.localize-option-actions,
.localize-insert-position-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.localize-insert-position-row .input-field {
  flex: 1 1 120px;
  min-width: 0;
}
.localized-preview-overlay {
  padding: var(--space-3);
}
.localized-preview-overlay.is-light {
  background: rgba(241, 245, 249, .94);
}
.localized-preview-shell {
  width: min(1180px, calc(100vw - 24px));
  height: calc(100vh - 24px);
  border-radius: var(--radius-md);
}
.localized-preview-controls {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}
.localized-preview-scale {
  min-width: 48px;
  color: #FFFFFF;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  text-align: center;
}
.localized-preview-head .btn {
  color: #FFFFFF;
  border-color: rgba(255,255,255,.45);
  background: rgba(255,255,255,.12);
}
.localized-preview-head .btn:hover {
  background: rgba(255,255,255,.22);
}
.localized-preview-overlay.is-light .localized-preview-shell {
  background: #FFFFFF;
}
.localized-preview-overlay.is-light .localized-preview-head {
  color: var(--color-text);
  border-bottom-color: #E2E8F0;
}
.localized-preview-overlay.is-light .localized-preview-head .btn {
  color: var(--color-text);
  border-color: #CBD5E1;
  background: #FFFFFF;
}
.localized-preview-overlay.is-light .localized-preview-scale {
  color: var(--color-text);
}
.localized-preview-overlay.is-light .localized-preview-body {
  background: #FFFFFF;
}
.localized-preview-body {
  background: #0B1220;
}
.localized-preview-body img {
  max-width: none;
  width: 100%;
}
.localized-result-toolbar {
  gap: var(--space-3);
}
@media (max-width: 1180px) {
  .tool-screen-layout { grid-template-columns: 1fr; }
  .tool-flow { position: static; }
  .workshop-screen-page .tool-screen-layout { grid-template-columns: 1fr; }
  .workshop-screen-page .tool-flow ol { grid-template-columns: 1fr; }
  .localized-section-grid.cols-2,
  .localized-section-grid.cols-3 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 760px) {
  .tool-screen-head { grid-template-columns: 1fr; }
  .localized-section-grid.cols-1,
  .localized-section-grid.cols-2,
  .localized-section-grid.cols-3 { grid-template-columns: 1fr; }
  .localize-option-head { display: grid; }
  .localize-option-row,
  .localize-insert-row { grid-template-columns: 1fr; }
  .localize-option-row [data-option-url],
  .localize-option-upload,
  .localize-option-upload-status { grid-column: auto; }
}

.home-projects {
  display: flex;
  flex-direction: column;
  gap: var(--space-6);
}
.home-saved-sidebar .home-projects {
  gap: var(--space-3);
}
.home-saved-group-buttons {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
}
.home-saved-sidebar .home-saved-group-buttons {
  display: grid;
  grid-template-columns: 1fr;
}
.home-saved-group-button {
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: 0 var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  color: var(--color-text);
  font: inherit;
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  cursor: pointer;
  box-shadow: var(--shadow-sm);
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
}
.home-saved-sidebar .home-saved-group-button {
  justify-content: space-between;
  min-height: 46px;
  width: 100%;
  padding: 0 var(--space-3);
  border-color: #CBD5E1;
}
.home-saved-group-button:hover:not(:disabled) {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}
.home-saved-group-button em {
  min-width: 24px;
  height: 22px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 7px;
  border-radius: var(--radius-full);
  background: #E0E7FF;
  color: var(--color-primary);
  font-style: normal;
  font-size: var(--text-xs);
  line-height: 1;
}
.home-saved-group-button.is-empty,
.home-saved-group-button:disabled {
  opacity: .55;
  cursor: default;
  transform: none;
  box-shadow: none;
}
.home-saved-modal-overlay {
  background: rgba(15, 23, 42, 0.52);
}
.home-saved-modal {
  width: min(1500px, calc(100vw - 24px));
  max-width: none;
  height: min(940px, calc(100vh - 24px));
  max-height: calc(100vh - 24px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  border-radius: var(--radius-lg);
  background: #fff;
}
.home-saved-modal-head {
  align-items: flex-start;
  gap: var(--space-4);
  background: #fff;
}
.home-saved-modal-head p {
  margin: var(--space-1) 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.home-saved-modal-body {
  background: #fff;
  overflow: auto;
}
.home-project-grid-modal {
  grid-template-columns: repeat(auto-fill, 260px);
  align-items: start;
  justify-content: start;
}
/* 2026-05-24 사장님 catch: 복제 직후 신규 카드 = OLD 와 시각 동일 (100% 복제 정합) → marker 영역 강제.
   highlight 2.4s + scrollIntoView (JS 측 추가). */
.home-project-card-just-duplicated {
  animation: home-card-just-duplicated 2.4s ease-out;
  position: relative;
  z-index: 1;
}
.home-project-card-just-duplicated::after {
  content: "✓ 방금 복제됨";
  position: absolute;
  top: 6px;
  left: 6px;
  background: #16a34a;
  color: #fff;
  font-size: 11px;
  font-weight: 600;
  padding: 3px 8px;
  border-radius: 10px;
  box-shadow: 0 2px 6px rgba(22, 163, 74, 0.4);
  z-index: 2;
  animation: home-card-just-duplicated-badge 2.4s ease-out forwards;
}
@keyframes home-card-just-duplicated {
  0%   { box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.7), 0 0 20px rgba(34, 197, 94, 0.5); transform: scale(1.02); }
  60%  { box-shadow: 0 0 0 4px rgba(34, 197, 94, 0.4), 0 0 12px rgba(34, 197, 94, 0.25); transform: scale(1.01); }
  100% { box-shadow: 0 0 0 0 rgba(34, 197, 94, 0); transform: scale(1); }
}
@keyframes home-card-just-duplicated-badge {
  0%   { opacity: 1; }
  80%  { opacity: 1; }
  100% { opacity: 0; }
}
/* 카드 크기 고정 — 휴지통 첫 카드 기준 260×340.
   home-project-card 와 home-tool-result-card 가 같은 그리드에서 정렬되도록. */
.home-project-grid-modal .home-project-card,
.home-project-grid-modal .home-tool-result-card {
  width: 260px;
  height: 340px;
  overflow: hidden;
}
.home-project-grid-modal .home-project-thumb,
.home-project-grid-modal .home-tool-result-thumb {
  flex: 0 0 auto;
  aspect-ratio: 4 / 3;
}
.home-project-grid-modal .home-project-body,
.home-project-grid-modal .home-tool-result-main {
  flex: 1 1 auto;
  overflow: hidden;
}
.home-project-grid-modal .home-project-name,
.home-project-grid-modal .home-tool-result-main h4 {
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
@media (max-width: 720px) {
  .home-shell {
    width: 100%;
    display: block;
    min-height: auto;
    padding: 0;
  }
  .home-screen {
    padding: var(--space-4);
  }
  .home-saved-sidebar {
    position: static;
    height: auto;
    max-height: none;
    border-right: 0;
    border-bottom: 1px solid #E2E8F0;
    box-shadow: none;
  }
  .home-saved-sidebar[data-collapsed="true"] {
    width: auto;
  }
  .home-saved-sidebar[data-collapsed="true"] .home-saved-sidebar-title {
    display: grid;
  }
  .home-saved-sidebar[data-collapsed="true"] .home-saved-sidebar-head {
    justify-content: flex-start;
  }
  .home-sidebar-quick-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .home-saved-group-buttons {
    display: grid;
    grid-template-columns: 1fr;
  }
  .home-saved-group-button {
    justify-content: space-between;
  }
  .home-saved-modal {
    width: calc(100vw - 16px);
    height: calc(100vh - 16px);
    max-height: calc(100vh - 16px);
  }
  .home-project-grid-modal {
    grid-template-columns: 1fr;
  }
}
.home-project-group {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.home-project-group-head {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: var(--space-3);
  padding: 0 var(--space-1);
}
.home-project-group-head h4 {
  margin: 0;
  font-size: var(--text-base);
  font-weight: var(--font-extrabold);
}
.home-project-group-head h4 span {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 24px;
  height: 22px;
  margin-left: 6px;
  padding: 0 7px;
  border-radius: var(--radius-full);
  background: #E0E7FF;
  color: var(--color-primary);
  font-size: var(--text-xs);
}
.home-project-group-head p {
  margin: 0;
  max-width: 520px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  text-align: right;
}
.home-project-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: var(--space-4);
}
.home-group-empty {
  grid-column: 1 / -1;
  margin: 0;
  padding: var(--space-5);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-lg);
  background: #F8FAFC;
}
.home-project-card {
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.home-project-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.home-project-thumb {
  position: relative;
  aspect-ratio: 4/3;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-bg-section));
  display: grid;
  place-items: center;
  overflow: hidden;
}
.home-project-open-thumb,
.home-tool-open-thumb {
  border: 0;
  padding: 0;
  background: transparent;
  cursor: pointer;
  font: inherit;
  text-align: inherit;
  appearance: none;
  -webkit-appearance: none;
}
.home-project-card .home-project-open-thumb {
  width: 100%;
  min-height: 0;
}
.home-project-open-thumb:hover img,
.home-tool-open-thumb:hover img {
  transform: scale(1.025);
}
.home-project-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  position: absolute; inset: 0;
  transition: transform var(--transition-base);
}
.home-project-thumb-fallback {
  font-size: 48px;
  font-weight: var(--font-extrabold);
  color: var(--color-primary);
  opacity: 0.5;
}
/* 2026-05-24 사장님 catch: img 정상 시 fallback span ("흡" 첫글자) 영역 영역 동시 영역 표시 영역 = img 영역 가운데 영역 글자 영역 보임 영역.
   img sibling 영역 존재 시 = fallback span 영역 hide 영역. */
.home-project-thumb > img + .home-project-thumb-fallback,
.home-project-thumb img ~ .home-project-thumb-fallback {
  display: none;
}
.home-project-draft-badge {
  position: absolute;
  top: var(--space-2);
  left: var(--space-2);
  z-index: 1;
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 8px;
  border-radius: var(--radius-full);
  background: #FEF3C7;
  color: #92400E;
  font-size: var(--text-xs);
  font-weight: 900;
  box-shadow: 0 1px 4px rgba(146, 64, 14, 0.18);
}
.home-project-body {
  padding: var(--space-3) var(--space-4);
}
.home-project-name {
  margin: 0 0 var(--space-1);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.home-project-name-badge {
  display: inline-flex;
  align-items: center;
  margin-right: 6px;
  padding: 1px 6px;
  border-radius: var(--radius-full);
  background: #FEF3C7;
  color: #92400E;
  font-size: 10px;
  font-weight: 900;
  vertical-align: 1px;
}
.home-project-ts {
  margin: 0 0 var(--space-3);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.home-saved-at {
  display: flex;
  flex-direction: column;
  gap: 1px;
  line-height: 1.35;
}
.home-project-actions { display: flex; gap: var(--space-2); }

.home-tool-history {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(320px, 1fr));
  gap: var(--space-4);
}
/* 정식 결과물 카드 — 임시 (home-project-card) 와 동일한 세로형 레이아웃으로 통일.
   상단 4:3 썸네일 + 본문. 그리드에서 두 카드 종류가 같은 크기로 정렬된다. */
.home-tool-result-card {
  display: flex;
  flex-direction: column;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}
.home-tool-result-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.home-tool-result-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  border-radius: 0;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-bg-section));
  display: grid;
  place-items: center;
  min-width: 0;
  border: 0;
  padding: 0;
  cursor: pointer;
}
.home-tool-result-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--transition-base);
}
.home-tool-result-thumb span {
  position: relative;
  z-index: 1;
  font-size: var(--text-xl);
  font-weight: var(--font-extrabold);
  color: var(--color-primary);
  opacity: .55;
}
.home-tool-result-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-4) var(--space-3);
  flex: 1 1 auto;
}
.home-tool-result-badge {
  display: inline-flex;
  width: auto;
  max-width: 100%;
  min-width: 0;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  background: #E0E7FF;
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  line-height: 1.25;
  overflow-wrap: anywhere;
  word-break: keep-all;
}
.home-tool-result-main h4 {
  margin: 0;
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  line-height: 1.35;
  max-width: 100%;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: keep-all;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.home-tool-result-main p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  max-width: 100%;
  overflow: hidden;
  overflow-wrap: anywhere;
  word-break: keep-all;
  display: -webkit-box;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
}
.home-tool-result-actions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: auto;
}
.home-tool-result-actions .btn,
.home-tool-result-actions a.btn {
  min-height: 30px;
}
.home-tool-delete {
  color: var(--color-danger);
}
.home-tool-delete:hover:not(:disabled) {
  color: #B91C1C;
  background: #FEF2F2;
}

.trash-modal,
.modal.modal-fullscreen.trash-modal {
  /* 사장님 룰 (2026-05-06): 카드 1행에 5개 들어가는 사이즈로 (260px * 5 + gap 4 * 16 = 1364) */
  width: min(1408px, calc(100vw - 64px)) !important;
  max-width: min(1408px, calc(100vw - 64px)) !important;
  height: auto !important;
  max-height: calc(100vh - 64px) !important;
}

.trash-modal-head p {
  margin: var(--space-1) 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.trash-modal-body {
  max-height: calc(100vh - 180px);
  overflow: auto;
}

/* 휴지통 — 홈의 저장된 프로젝트 모달과 동일한 카드 그리드 형식.
   각 카드는 상단 썸네일(4:3) + 메타·타이틀 + 하단 액션 버튼 묶음.
   카드 크기는 휴지통 첫 카드 기준 260×340 으로 고정 (행마다 다른 높이 방지). */
.trash-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, 260px);
  gap: var(--space-3);
  align-items: start;
  justify-content: start;
}

.trash-item {
  display: flex;
  flex-direction: column;
  width: 260px;
  height: 340px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: transform var(--transition-base), box-shadow var(--transition-base);
}

.trash-item:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}

.trash-thumb {
  position: relative;
  width: 100%;
  aspect-ratio: 4 / 3;
  display: grid;
  place-items: center;
  overflow: hidden;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-bg-section));
  color: var(--color-text-muted);
  font-weight: var(--font-bold);
  font-size: var(--text-xl);
}

.trash-thumb img {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.trash-thumb span {
  position: relative;
  z-index: 1;
}

.trash-main {
  min-width: 0;
  padding: var(--space-3) var(--space-4) var(--space-2);
  flex: 1 1 auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
  overflow: hidden;
}

.trash-main h4 {
  margin: 0;
  font-size: var(--text-base);
  line-height: var(--leading-snug);
  overflow-wrap: anywhere;
  word-break: keep-all;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.trash-main p,
.trash-main small {
  display: block;
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.trash-meta-row {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  align-items: center;
  font-size: var(--text-xs);
}

.trash-kind {
  padding: 2px 8px;
  border-radius: var(--radius-sm);
  background: var(--color-primary-soft);
  color: var(--color-primary);
  font-weight: var(--font-bold);
}

.trash-expiry {
  color: var(--color-danger);
}

.trash-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
  padding: var(--space-2) var(--space-4) var(--space-3);
  border-top: 1px solid var(--color-border-soft, rgba(0, 0, 0, 0.04));
}

.trash-actions .btn {
  flex: 1 1 auto;
  justify-content: center;
}

.trash-empty {
  padding: var(--space-8);
  text-align: center;
  color: var(--color-text-muted);
}

.trash-empty strong {
  display: block;
  margin-bottom: var(--space-2);
  color: var(--color-text);
}

@media (max-width: 720px) {
  .trash-list {
    grid-template-columns: 1fr;
  }
}

/* ── Empty State ─────────────────────────────────────────── */
.empty-state {
  max-width: 480px;
  margin: 8vh auto;
  padding: var(--space-10) var(--space-8);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  text-align: center;
  box-shadow: var(--shadow-md);
}
.empty-state h3 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-2xl);
  font-weight: var(--font-bold);
}
.empty-state p {
  color: var(--color-text-secondary);
  font-size: var(--text-sm);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-6);
}

/* ── Modal (Project Picker) ──────────────────────────────── */
.modal-overlay {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(15, 23, 42, 0.45);
  display: grid; place-items: center;
  padding: var(--space-4);
}
.modal {
  width: 100%; max-width: 540px;
  max-height: calc(100vh - var(--space-8));
  display: flex; flex-direction: column;
  background: var(--color-bg-card);
  border-radius: var(--radius-2xl);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}
/* 풀스크린 변형 — 작업 보관함, 휴지통 등 목록형 모달이 좁아 답답한 경우 사용.
   사방 100px 씩 빈 공간을 둬서 바깥 영역 클릭으로 닫기가 편하다. */
.modal.modal-fullscreen {
  max-width: calc(100vw - 200px);
  width: calc(100vw - 200px);
  max-height: calc(100vh - 200px);
  height: calc(100vh - 200px);
}
.modal.modal-fullscreen .modal-body { padding: var(--space-6); }
/* 휴지통 / 작업 보관함 / 홈 저장된 프로젝트 모달의 헤더 액션 묶음 (전체 삭제 + 닫기) */
.trash-head-actions,
.picker-head-actions,
.home-saved-modal-head-actions {
  display: flex;
  gap: var(--space-2);
  align-items: center;
}
/* picker-modal 내부 grid 적당히 확장 */
.picker-modal .picker-list {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(360px, 1fr));
  gap: var(--space-3);
}
.picker-modal .picker-item {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  background: var(--color-bg-card);
  transition: box-shadow 0.15s ease, border-color 0.15s ease;
  /* 2026-05-24 사장님 catch image #30: 카드 높이 영역 고정 + 제목 2-3 줄 영역 */
  min-width: 0;
  overflow: hidden;
  min-height: 160px;
  justify-content: space-between;
}
.picker-modal .picker-item-name {
  /* 2026-05-24 사장님 catch image #31: 3 줄 wrap 영역 작동 X = root cause = base .picker-item-name (line 4379) white-space: nowrap 영역 inherit
     fix = white-space: normal !important 강제 + word-break: break-word + overflow-wrap: anywhere (영문 매우 긴 영역 강제 줄바꿈) */
  display: -webkit-box !important;
  -webkit-line-clamp: 3;
  -webkit-box-orient: vertical;
  width: 100%;
  max-width: 100%;
  min-width: 0;
  direction: ltr;
  white-space: normal !important;
  overflow: hidden;
  text-overflow: ellipsis;
  word-break: break-word !important;
  overflow-wrap: anywhere !important;
  line-height: 1.4;
  font-size: var(--text-base);
  font-weight: 600;
}
.picker-modal .picker-item-meta {
  /* 시간 영역 단일 줄 = 정확 */
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* 2026-05-24 사장님 catch image #30: 페이징 영역 신규 */
.picker-pagination {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3) 0;
  margin-top: var(--space-3);
}
.picker-pagination .page-info {
  font-size: var(--text-sm);
  color: var(--color-text-muted);
  min-width: 80px;
  text-align: center;
}
.picker-modal .picker-item:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
}
.picker-modal .picker-item.is-current {
  border-color: var(--color-primary);
  background: rgba(59, 130, 246, 0.04);
}
.picker-modal .picker-item-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  flex: 0 0 auto;
}
.modal-head h3 { margin: 0; font-size: var(--text-lg); font-weight: var(--font-bold); }
.modal-body {
  padding: var(--space-5);
  overflow-y: auto;
  flex: 1 1 auto;
  min-height: 0;
}
.html-export-modal {
  max-width: min(1180px, calc(100vw - 32px));
  width: 100%;
}
.html-export-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 0.9fr);
  gap: var(--space-4);
}
.html-export-frame {
  width: 100%;
  min-height: 68vh;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
}
.html-export-code {
  min-height: 68vh;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  line-height: 1.5;
  resize: none;
}
@media (max-width: 900px) {
  .html-export-body { grid-template-columns: 1fr; }
  .html-export-frame,
  .html-export-code { min-height: 42vh; }
}

/* 최종 조합 도구 */
.mixer-modal {
  width: min(1280px, calc(100vw - 32px));
  height: min(860px, calc(100vh - 32px));
}
.mixer-subtitle {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.mixer-page-shell {
  width: 100%;
  min-height: calc(100vh - 72px);
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: var(--space-5);
  background: var(--color-bg-app);
}
.mixer-page-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}
.mixer-page-head h2 {
  margin: 0;
  font-size: var(--text-xl);
}
.mixer-page-head p {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}
.mixer-page-actions {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  flex-wrap: wrap;
}
.mixer-body {
  display: grid;
  grid-template-columns: minmax(240px, 0.8fr) minmax(280px, 1fr) minmax(360px, 1.25fr);
  gap: var(--space-4);
  min-height: 0;
  height: calc(100% - 64px);
}
.mixer-page-body {
  flex: 1;
  height: auto;
  min-height: 0;
}
.mixer-panel,
.mixer-preview-panel {
  min-height: 0;
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
}
.mixer-panel-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}
.mixer-panel-head strong {
  color: var(--color-text-primary);
  font-size: var(--text-sm);
}
.mixer-source-list,
.mixer-selected-list {
  min-height: 0;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  padding-right: 2px;
}

/* mixer 검색 + 카테고리 필터 + 프로젝트 select + 그룹기준 (사장님 룰 2026-05-04) */
.mixer-filter-bar {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px 0 10px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 8px;
}
.mixer-filter-search { font-size: 13px; }
.mixer-filter-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.mixer-filter-project { flex: 1; min-width: 160px; font-size: 12px; }
.mixer-filter-groupby { display: inline-flex; gap: 0; border: 1px solid var(--color-border); border-radius: 6px; overflow: hidden; }
.mixer-groupby-btn {
  padding: 6px 10px;
  font-size: 11px;
  background: transparent;
  border: 0;
  cursor: pointer;
  color: var(--color-text-muted);
}
.mixer-groupby-btn.active { background: var(--color-primary, #2563eb); color: #fff; }
.mixer-filter-chips { display: flex; gap: 6px; flex-wrap: wrap; }
.mixer-chip {
  padding: 4px 10px;
  font-size: 11px;
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  cursor: pointer;
  color: var(--color-text-muted);
  transition: all 0.12s ease;
}
.mixer-chip:hover { border-color: var(--color-primary, #2563eb); }
.mixer-chip.active { background: var(--color-primary, #2563eb); color: #fff; border-color: var(--color-primary, #2563eb); }

/* mixer 그룹 헤더 (카테고리별 / 프로젝트별 묶음 + 접기/펼치기) */
.mixer-source-group { display: flex; flex-direction: column; gap: 6px; }
.mixer-group-head {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  background: var(--color-bg-secondary, #f1f5f9);
  border: 1px solid var(--color-border);
  border-radius: 6px;
  cursor: pointer;
  width: 100%;
  text-align: left;
  font-size: 12px;
  color: var(--color-text-primary);
}
.mixer-group-head:hover { background: var(--color-bg-hover, #e2e8f0); }
.mixer-group-arrow { width: 12px; color: var(--color-text-muted); }
.mixer-group-count {
  margin-left: auto;
  font-size: 11px;
  color: var(--color-text-muted);
  background: rgba(0, 0, 0, 0.06);
  padding: 1px 8px;
  border-radius: 999px;
}
.mixer-group-cards { display: flex; flex-direction: column; gap: var(--space-2); padding-left: 8px; }
.mixer-source-card,
.mixer-selected-card {
  display: grid;
  grid-template-columns: 56px minmax(0, 1fr) auto;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-2);
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.mixer-selected-card {
  grid-template-columns: 28px 58px minmax(0, 1fr) auto;
}
.mixer-source-card strong,
.mixer-selected-card strong {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: var(--text-sm);
}
.mixer-source-card span,
.mixer-selected-card span {
  display: block;
  margin-top: 2px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.mixer-order {
  display: inline-grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 999px;
  background: var(--color-primary);
  color: #fff !important;
  font-weight: var(--font-bold);
}
.mixer-thumb {
  width: 56px;
  height: 56px;
  overflow: hidden;
  display: grid;
  place-items: center;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
}
.mixer-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.mixer-thumb-html {
  color: var(--color-text-muted);
  font-size: 10px;
  font-weight: var(--font-bold);
}
.mixer-row-actions {
  display: flex;
  align-items: center;
  gap: 4px;
}
.mixer-preview-frame {
  flex: 1;
  min-height: 260px;
  width: 100%;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
}
.mixer-html-code {
  height: 170px;
  min-height: 120px;
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  resize: vertical;
}

@media (max-width: 1100px) {
  .mixer-body {
    grid-template-columns: 1fr;
    height: auto;
  }
  .mixer-modal {
    height: calc(100vh - 24px);
    overflow: auto;
  }
}

.static-tool-page {
  width: 100%;
  height: calc(100vh - 72px);
  min-height: 620px;
  background: #f1f5f9;
}
.static-tool-frame {
  display: block;
  width: 100%;
  height: 100%;
  border: 0;
  background: #fff;
}

.picker-list { display: flex; flex-direction: column; gap: var(--space-2); max-height: 50vh; overflow-y: auto; }
.picker-item {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-input);
  border: 1px solid transparent;
  border-radius: var(--radius-md);
}
.picker-item.is-current { border-color: var(--color-primary); background: var(--color-primary-light); }
.picker-item-main { min-width: 0; flex: 1; }
.picker-item-name { font-size: var(--text-sm); font-weight: var(--font-semibold); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.picker-item-meta { font-size: var(--text-xs); color: var(--color-text-muted); margin-top: 2px; }
.picker-item-actions { display: flex; gap: var(--space-1); }

.project-name-create-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: var(--space-2);
  align-items: center;
}
.product-name-suggestions {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.product-name-suggestion {
  width: 100%;
  text-align: left;
  border: 1px solid #DBEAFE;
  background: #FFFFFF;
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  cursor: pointer;
}
.product-name-suggestion:hover {
  border-color: var(--color-primary);
  background: var(--color-primary-light);
}
.product-name-suggestion-main {
  display: block;
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  color: var(--color-text);
  line-height: 1.45;
}
.product-name-suggestion-meta,
.product-name-suggestion-empty {
  display: block;
  margin-top: 2px;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: 1.45;
}

/* ── Drawer (Settings) ───────────────────────────────────── */
.drawer-overlay {
  position: fixed; inset: 0; z-index: 50;
  background: rgba(15, 23, 42, 0.4);
  display: flex; justify-content: flex-end;
}
.drawer {
  width: 100%; max-width: 520px; height: 100%;
  background: var(--color-bg-card);
  display: flex; flex-direction: column;
  box-shadow: var(--shadow-xl);
  animation: slide-in 0.2s ease;
}
@keyframes slide-in { from { transform: translateX(100%); } to { transform: translateX(0); } }
.drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.drawer-head h3 { margin: 0; font-size: var(--text-lg); font-weight: var(--font-bold); }
.drawer-body { padding: var(--space-5); overflow-y: auto; flex: 1; }
.drawer-actions { display: flex; gap: var(--space-2); justify-content: flex-end; margin-top: var(--space-6); }

.settings-section { margin-bottom: var(--space-8); }
.settings-section h4 {
  margin: 0 0 var(--space-3);
  font-size: var(--text-base);
  font-weight: var(--font-semibold);
}
.settings-help {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
  margin: 0 0 var(--space-4);
}
.settings-help code {
  font-family: var(--font-mono);
  background: var(--color-bg-input);
  padding: 1px 5px;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
}
.settings-error {
  margin-top: var(--space-3);
  font-size: var(--text-sm);
  color: var(--color-danger);
}
.settings-error:empty { display: none; }

.settings-result {
  margin: var(--space-3) 0 0;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-input);
  color: var(--color-text);
  font-size: var(--text-xs);
  line-height: 1.55;
}
.settings-result:empty { display: none; }
.settings-result a {
  color: var(--color-primary);
  font-weight: var(--font-semibold);
  text-decoration: underline;
}
.settings-result small {
  display: block;
  margin-top: var(--space-1);
  color: var(--color-text-muted);
  word-break: break-all;
}
.settings-maintenance-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
}

.field-warning {
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  border: 1px solid rgba(220, 38, 38, 0.32);
  border-radius: var(--radius-md);
  background: #FEF2F2;
  color: #B91C1C;
  font-size: var(--text-xs);
  font-weight: 700;
  line-height: 1.55;
}

/* ── Reference Image Grid ────────────────────────────────── */
.ref-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(120px, 1fr));
  gap: var(--space-2);
}
.ref-item {
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── 이미지 분석 그리드 ──────────────────────────────────── */
.image-thumb-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.img-thumb-card {
  position: relative;
  display: block;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  cursor: pointer;
  background: var(--color-bg-input);
  transition: border-color var(--transition-base);
}
.img-thumb-card:hover { border-color: var(--color-primary); }
.img-thumb-card.selected {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}
.img-thumb-card img {
  display: block;
  width: 100%;
  aspect-ratio: 1;
  object-fit: cover;
}
.img-thumb-card.ref { cursor: pointer; }
.img-thumb-card .img-reason {
  display: block;
  padding: 4px 8px;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: var(--color-bg-card);
  text-align: center;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  border-top: 1px solid var(--color-border);
  line-height: 1.3;
}
.img-thumb-card .img-reason strong { font-weight: var(--font-bold); }
.img-thumb-card .img-reason-neg { color: var(--color-banned-text); background: #FEF2F2; }
.img-thumb-card .img-reason-pos { color: var(--color-success); background: #ECFDF5; }

.img-grade-badge {
  position: absolute;
  top: var(--space-1);
  left: var(--space-1);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 10px;
  font-weight: var(--font-bold);
  letter-spacing: 0.02em;
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-sm);
}
.img-grade-good { background: var(--color-success); }
.img-grade-warn { background: var(--color-warning); color: #5C2E00; }
.img-grade-bad  { background: var(--color-danger); }
.img-grade-none { background: var(--color-text-muted); }

/* 분석 카드 하단 액션 바 (후처리/원본 복원) */
.img-actions-bar {
  position: absolute;
  bottom: 28px;
  left: 0;
  right: 0;
  display: flex;
  gap: 4px;
  padding: 4px;
  justify-content: center;
  background: linear-gradient(to bottom, transparent, rgba(0,0,0,0.45));
  z-index: 1;
  opacity: 0;
  transition: opacity var(--transition-base);
}
.img-thumb-card:hover .img-actions-bar { opacity: 1; }
.img-act-btn {
  padding: 3px 8px;
  font-size: 10px;
  font-weight: var(--font-semibold);
  border-radius: var(--radius-full);
  background: rgba(255,255,255,0.92);
  color: var(--color-text-primary);
  cursor: pointer;
  white-space: nowrap;
}
.img-act-btn:hover { background: var(--color-primary); color: var(--color-text-inverse); }

.img-spinner-overlay {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
  background: rgba(255,255,255,0.9);
  color: var(--color-primary);
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
  z-index: 3;
}
.img-spinner-overlay[hidden] { display: none; }

/* AI 상품정보 분석에 사용된 풀 이미지 표시 배지 */
.img-analyzed-badge {
  position: absolute;
  top: var(--space-1);
  left: var(--space-1);
  padding: 2px 8px;
  border-radius: var(--radius-full);
  font-size: 10px;
  font-weight: var(--font-bold);
  letter-spacing: 0.02em;
  background: var(--color-primary);
  color: var(--color-text-inverse);
  box-shadow: var(--shadow-sm);
  z-index: 1;
}
.img-select-check {
  position: absolute;
  top: var(--space-1);
  right: var(--space-1);
  width: 22px; height: 22px;
  margin: 0;
  accent-color: var(--color-primary);
  cursor: pointer;
  z-index: 1;
}
.img-remove {
  position: absolute;
  top: 30px;
  right: var(--space-1);
  width: 22px; height: 22px;
  background: rgba(15, 23, 42, 0.7);
  color: var(--color-text-inverse);
  border-radius: var(--radius-full);
  font-size: 12px;
  font-weight: var(--font-bold);
  display: grid; place-items: center;
  z-index: 1;
}
.img-remove:hover { background: var(--color-danger); }

/* ── AI 버튼 / 인라인 액션 ────────────────────────────── */
.input-with-action {
  display: flex;
  gap: var(--space-2);
}
.input-with-action .input-field { flex: 1; }
.btn-inline-ai {
  margin-left: var(--space-2);
  padding: 2px 8px;
  background: var(--color-accent-light);
  color: var(--color-accent-hover);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  cursor: pointer;
}
.btn-inline-ai:hover { background: var(--color-accent); color: var(--color-text-inverse); }
.btn-inline-ai:disabled { opacity: 0.5; cursor: not-allowed; }

.actions-row {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  align-items: center;
  margin-top: var(--space-2);
}

/* ── 분석 그리드 액션 (3단계 분리) ──────────────────── */
.analyzed-actions {
  display: flex;
  flex-direction: column;
  gap: var(--space-3);
  margin-top: var(--space-2);
  padding: var(--space-3);
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.stage-block {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.stage-block + .stage-block {
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-3);
}
.stage-label {
  margin: 0 0 var(--space-1);
  font-size: var(--text-xs);
  font-weight: var(--font-semibold);
  color: var(--color-text-muted);
  letter-spacing: 0.02em;
}
.stage-label.danger {
  color: var(--color-danger, #dc2626);
}
.stage-danger {
  background: color-mix(in srgb, var(--color-danger, #dc2626) 4%, transparent);
  margin: 0 calc(-1 * var(--space-3)) calc(-1 * var(--space-3));
  padding: var(--space-3);
  border-radius: 0 0 var(--radius-md) var(--radius-md);
}
.action-row {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  align-items: center;
}
.action-row-danger {
  justify-content: flex-end;
}
.action-divider {
  display: inline-block;
  width: 1px;
  height: 20px;
  background: var(--color-border);
  margin: 0 var(--space-1);
}
.action-spacer { flex: 1 1 auto; }
.action-progress {
  margin: 0;
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  font-variant-numeric: tabular-nums;
}

/* AI 그라디언트 버튼 (✨ 일괄 후처리 등) */
.btn-ai {
  background: linear-gradient(135deg, #8B5CF6 0%, #6366F1 100%);
  color: #FFFFFF;
  border: 0;
}
.btn-ai:hover:not(:disabled) {
  background: linear-gradient(135deg, #7C3AED 0%, #4F46E5 100%);
  color: #FFFFFF;
}
.btn-ai:disabled {
  background: linear-gradient(135deg, #C4B5FD 0%, #A5B4FC 100%);
  opacity: 0.6;
  cursor: not-allowed;
}

/* 입력 프리셋 칩 (A/S 기간/범위 등 빠른 선택) */
.chip-row {
  display: flex;
  gap: var(--space-1);
  flex-wrap: wrap;
  margin: calc(-1 * var(--space-2)) 0 var(--space-3);
}
.chip {
  padding: 4px 10px;
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-full);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  cursor: pointer;
  transition: background var(--transition-base), color var(--transition-base), border-color var(--transition-base);
  white-space: nowrap;
}
.chip:hover {
  background: var(--color-primary-light);
  color: var(--color-primary-dark);
  border-color: var(--color-primary);
}

.ai-spinner {
  display: inline-block;
  width: 12px; height: 12px;
  border: 2px solid currentColor;
  border-top-color: transparent;
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  vertical-align: -1px;
}
@keyframes spin { to { transform: rotate(360deg); } }

.banned-warn {
  margin: var(--space-2) 0 0;
  padding: var(--space-2) var(--space-3);
  background: var(--color-banned-bg);
  border-radius: var(--radius-sm);
  color: var(--color-banned-text);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
}
.banned-warn:empty { display: none; }

/* 카피 편집 — 금지어 실시간 하이라이트 (textarea + mirror 오버레이) */
.copy-highlight-wrap {
  position: relative;
  background: var(--color-bg-input);
  border: 1.5px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: border-color var(--transition-base), box-shadow var(--transition-base);
}
.copy-highlight-wrap:focus-within {
  border-color: var(--color-border-focus);
  box-shadow: var(--shadow-focus);
  background: var(--color-bg-card);
}
.copy-highlight-wrap .copy-highlight-mirror,
.copy-highlight-wrap .copy-highlight-textarea {
  font-family: inherit;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
  letter-spacing: 0;
  padding: var(--space-3) var(--space-4);
  margin: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
  overflow-wrap: break-word;
}
.copy-highlight-mirror {
  position: absolute;
  inset: 0;
  pointer-events: none;
  color: transparent;
  background: transparent;
  border: 0;
  overflow: hidden;
  border-radius: var(--radius-md);
}
.copy-highlight-mirror .banned-hl {
  background: var(--color-banned-bg);
  color: transparent;
  text-decoration: underline wavy var(--color-danger);
  text-decoration-skip-ink: none;
  border-radius: 2px;
}
.copy-highlight-wrap .copy-highlight-textarea {
  position: relative;
  z-index: 1;
  width: 100%;
  background: transparent;
  border: 0;
  outline: none;
  resize: vertical;
  color: var(--color-text-primary);
  caret-color: var(--color-text-primary);
}

/* 숏폼 자막 결과 */
.shortform-result {
  margin-top: var(--space-3);
  display: flex;
  flex-direction: column;
  gap: var(--space-1);
}
.shortform-result .subtitle-row {
  display: grid;
  grid-template-columns: 130px 1fr;
  gap: var(--space-3);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-input);
  border-radius: var(--radius-sm);
  font-size: var(--text-sm);
}
.shortform-result .subtitle-row .ts {
  font-family: var(--font-mono);
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
  align-self: center;
}
.shortform-result .subtitle-row .text {
  color: var(--color-text-primary);
  line-height: var(--leading-normal);
}

/* 스타일 레퍼런스 카드 — img-thumb-card 재사용, 약간 큰 사이즈 */
.img-thumb-card.style-ref img { aspect-ratio: 16/10; }

/* 스타일 레퍼런스 분석 결과 패널 */
.style-analysis {
  margin-top: var(--space-4);
  padding: var(--space-4);
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}
.style-analysis-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
}
.style-analysis-table {
  width: 100%;
  border-collapse: collapse;
  font-size: var(--text-xs);
}
.style-analysis-table th {
  width: 110px;
  padding: var(--space-2) var(--space-3) var(--space-2) 0;
  vertical-align: top;
  text-align: right;
  color: var(--color-text-muted);
  font-weight: var(--font-medium);
  font-size: var(--text-xs);
}
.style-analysis-table td {
  padding: var(--space-2) 0;
  vertical-align: top;
  color: var(--color-text-primary);
  line-height: var(--leading-relaxed);
}
.style-analysis-table tr + tr th,
.style-analysis-table tr + tr td {
  border-top: 1px dashed var(--color-border);
}
.style-analysis-table code {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-secondary);
  word-break: break-word;
}
.color-row { display: flex; align-items: center; gap: var(--space-1); margin-bottom: 2px; }
.color-chip {
  display: inline-block;
  width: 16px; height: 16px;
  border-radius: var(--radius-sm);
  border: 1px solid rgba(0,0,0,0.1);
  vertical-align: -3px;
}

/* ── 모달 헤더 액션 그룹 (히스토리 + 닫기) ───────────────── */
.modal-head-actions { display: flex; align-items: center; gap: var(--space-2); }

/* ── 모달 히스토리 슬라이드 패널 (썸네일/숏폼/스타일 공통) ─ */
.modal { position: relative; }
.history-panel {
  position: absolute;
  top: 0; right: 0; bottom: 0;
  width: 360px;
  max-width: 90%;
  background: var(--color-bg-card);
  border-left: 1px solid var(--color-border);
  box-shadow: -8px 0 24px rgba(15, 23, 42, 0.08);
  display: flex; flex-direction: column;
  transform: translateX(100%);
  transition: transform 0.22s ease;
  z-index: 2;
}
.history-panel.open { transform: translateX(0); }
.history-panel-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
  flex: 0 0 auto;
}
.history-panel-body {
  flex: 1 1 auto;
  overflow-y: auto;
  padding: var(--space-3);
  display: flex; flex-direction: column; gap: var(--space-2);
}
.history-card {
  display: flex; align-items: center; gap: var(--space-3);
  padding: var(--space-3);
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
}
.history-card-thumbs {
  display: flex; flex-wrap: wrap; gap: 2px;
  width: 64px; flex: 0 0 64px;
}
.history-thumb-mini {
  width: 30px; height: 30px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
}
.history-card-thumbs .history-thumb-mini:only-child {
  width: 64px; height: 64px;
}
.history-card-main {
  flex: 1 1 auto; min-width: 0;
}
.history-card-title {
  font-size: var(--text-sm);
  font-weight: var(--font-semibold);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.history-card-meta {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
}
.history-card-actions {
  display: flex; flex-direction: column; gap: 4px;
  flex: 0 0 auto;
}
.history-card.locked {
  border-color: var(--color-warning, #d97706);
  background: color-mix(in srgb, var(--color-warning, #d97706) 8%, var(--color-bg-input));
}
/* ── select 내 optgroup 가독성 (카테고리 그룹 헤더) ────── */
.input-field optgroup {
  font-weight: var(--font-bold);
  color: var(--color-text-muted);
  background: var(--color-bg-input);
  font-style: normal;
}
.input-field optgroup option {
  font-weight: var(--font-normal);
  color: var(--color-text);
  padding-left: var(--space-3);
}

/* ── 1장으로 이어보기 모달 (zoom/pan) ──────────────────── */
/* 사장님 룰 2026-05-04: 디폴트 = 페이지 톤 (light). 다크 톤 베이스 폐기. */
.merged-preview-overlay {
  background: rgba(226, 232, 240, 0.94);
  padding: 28px;
  align-items: center;
  justify-items: center;
  z-index: 2400;
}
.merged-preview-shell {
  width: min(1040px, calc(100vw - 56px));
  height: calc(100vh - 24px);
  display: grid;
  grid-template-rows: auto auto 1fr;
  background: #ffffff;
  border: 1px solid rgba(15, 23, 42, 0.14);
  border-radius: 14px;
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.24);
  overflow: hidden;
}
.merged-preview-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 20px;
  background: #f8fafc;
  color: #0f172a;
  border-bottom: 1px solid rgba(15, 23, 42, 0.1);
}
.merged-preview-title {
  font-weight: var(--font-bold);
  font-size: var(--text-base);
}
.merged-preview-controls {
  display: flex; align-items: center; gap: 8px;
}
.merged-preview-controls .btn {
  background: #ffffff;
  color: #0f172a;
  border: 1px solid rgba(15, 23, 42, 0.14);
}
.merged-preview-controls .btn:hover { background: #eff6ff; }
.merged-preview-scale {
  min-width: 56px;
  text-align: center;
  font-variant-numeric: tabular-nums;
  color: #334155;
  font-size: var(--text-sm);
}
.merged-preview-hint {
  padding: 8px 20px;
  background: #eff6ff;
  color: #1e3a8a;
  font-size: var(--text-xs);
  border-bottom: 1px solid rgba(15, 23, 42, 0.1);
  line-height: 1.5;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
/* ExecPlan 029 (2026-05-05) → 정정 (사장님 룰 2026-05-05):
 * 좌측 = 설명 (hint-text), 우측 = 토글 그룹 (휠/구분선/정렬). */
.merged-preview-hint-toggles {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  align-items: center;
  margin-left: auto;
  order: 2;
}
.merged-preview-hint-text {
  order: 1;
}
/* 섹션 구분선 토글 OFF — 1장 이어보기 / 비교 모달 둘 다 진짜 1장으로 쭉 이어보게 */
.merged-preview-stage.no-dividers .merged-section-divider,
.merged-preview-stage.no-dividers .merged-compare-divider,
.merged-preview-stage.no-dividers .merged-preview-bottom-add,
.merged-preview-stage.no-dividers .merged-compare-pane figcaption {
  display: none !important;
}
.merged-preview-stage.no-dividers .merged-compare-row,
.merged-preview-stage.no-dividers .merged-preview-section {
  margin: 0 !important;
  padding: 0 !important;
  gap: 0 !important;
}
.merged-preview-stage.no-dividers .merged-compare-pane {
  margin: 0 !important;
  padding: 0 !important;
}
.merged-preview-stage.no-dividers .merged-compare-pane img,
.merged-preview-stage.no-dividers .merged-preview-section img {
  display: block !important;
  margin: 0 !important;
  padding: 0 !important;
}
.merged-preview-canvas {
  position: relative;
  overflow: auto;  /* 스크롤바로 팬 + 마우스 드래그도 scroll 직접 변경 */
  background: #ffffff;  /* 사장님 룰 2026-05-04: 디폴트 흰배경 (캔버스만 토글로 어두운) */
  padding: 24px 0;
  cursor: grab;
  user-select: none;
}
.merged-preview-overlay.is-canvas-dark .merged-preview-canvas {
  background: #0f172a;  /* 토글 시 캔버스만 어두운 */
}
.merged-preview-overlay.is-light {
  background: rgba(226, 232, 240, 0.94);
}
.merged-preview-overlay.is-light .merged-preview-shell {
  background: #ffffff;
  border-color: rgba(15, 23, 42, 0.14);
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.24);
}
.merged-preview-overlay.is-light .merged-preview-head {
  background: #f8fafc;
  color: #0f172a;
  border-bottom-color: rgba(15, 23, 42, 0.1);
}
.merged-preview-overlay.is-light .merged-preview-controls .btn {
  background: #ffffff;
  color: #0f172a;
  border-color: rgba(15, 23, 42, 0.14);
}
.merged-preview-overlay.is-light .merged-preview-controls .btn:hover {
  background: #eff6ff;
}
.merged-preview-overlay.is-light .merged-preview-scale {
  color: #334155;
}
.merged-preview-overlay.is-light .merged-preview-hint {
  background: #eff6ff;
  color: #1e3a8a;
  border-bottom-color: rgba(15, 23, 42, 0.1);
}
.merged-preview-body {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  background: #f8fafc;  /* 사장님 룰 2026-05-04: 디폴트 light 톤 */
}
/* (제거됨 2026-05-04) is-light 시 캔버스 흰색 — 디폴트와 같아 중복.
   .is-canvas-dark 가 is-light 와 specificity 같아 정의 순서로 덮어쓰던 버그 수정. */
.merged-preview-overlay.is-light .merged-preview-body {
  background: #f8fafc;
}
.merged-preview-overlay.is-light .merged-preview-stage {
  box-shadow: 0 8px 30px rgba(15, 23, 42, 0.18);
}
.merged-preview-canvas.panning { cursor: grabbing; }
.merged-preview-stage {
  display: flex; flex-direction: column;
  margin: 0 auto;     /* 가로 중앙 (작은 줌 시) */
  width: 780px;       /* JS 가 scale 따라 변경 */
  background: white;
  box-shadow: 0 8px 30px rgba(0,0,0,0.4);
  overflow: hidden;
}
.merged-preview-section {
  position: relative;
}
.merged-preview-img,
.merged-preview-section img {
  display: block;
  width: 100%;        /* stage 폭에 맞춰 늘어남 */
  height: auto;
  pointer-events: none;
}
.merged-section-divider {
  position: absolute;
  left: 0;
  right: 0;
  top: 0;
  height: 0;
  border-top: 2px dashed rgba(249, 115, 22, 0.92);
  pointer-events: none;
  z-index: 6;
  filter: drop-shadow(0 1px 2px rgba(15, 23, 42, 0.28));
}
/* ExecPlan 031 Phase 3 (사장님 룰 2026-05-06): enrichment 진입 모달 + KB 직접 수정 */
.enrichment-modal-overlay {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 11500;
  padding: 24px;
}
.enrichment-modal {
  background: #fff;
  border-radius: 12px;
  width: 100%;
  max-width: 640px;  /* 사장님 결정 (2026-05-06): 컷별 카피 + AI 다듬기 추가 → 폭 확장 */
  max-height: 92vh;
  display: flex; flex-direction: column;
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.32);
  overflow: hidden;
}
.enrichment-scenario-row {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 10px 12px;
  background: #f8fafc;
  border-radius: 8px;
  border: 1px solid #e2e8f0;
  margin-bottom: 8px;
}
.enrichment-row-head {
  display: flex; align-items: center; gap: 8px;
  justify-content: space-between;
}
/* 사장님 결정 (2026-05-08): 컷별 모델 옵션 (race / gender / age) row */
.enrichment-row-model {
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f8fafc;
  padding: 7px 9px;
}
.enrichment-row-model summary {
  cursor: pointer;
  font-size: 11px;
  font-weight: 700;
  color: #64748b;
  list-style-position: inside;
}
.enrichment-row-model-controls {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 8px;
}
.enrichment-row-model select {
  flex: 1 1 0;
  min-width: 0;
  width: 100%;
  font-size: var(--text-sm);
  padding: var(--space-2) 32px var(--space-2) var(--space-3);
  height: auto;
  line-height: 1.4;
  text-overflow: ellipsis;
}
.enrichment-row-model select option:disabled {
  color: #94a3b8;
}
/* 사장님 결정 (2026-05-07): 모델 옵션 dropdown — lifestyle 모달 상단 */
.enrichment-model-options {
  background: #f8fafc;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  padding: 10px 12px;
}
.enrichment-model-options summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
  color: #0f172a;
  line-height: 1.45;
  list-style-position: inside;
}
.enrichment-model-options summary span {
  display: inline-block;
  margin-left: 6px;
  color: #2563eb;
  font-weight: 800;
}
.enrichment-model-options-body {
  margin-top: 10px;
}
.enrichment-model-options label {
  display: block;
  font-size: 12px;
  font-weight: 600;
  color: #475569;
  margin-bottom: 6px;
}
.enrichment-model-options-row {
  display: flex;
  gap: 6px;
}
.enrichment-model-options-row .input-field {
  flex: 1 1 0;
  min-width: 0;
  font-size: 12px;
  padding: 6px 8px;
}
.enrichment-product-refs {
  background: #fff7ed;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  padding: 10px 12px;
}
.enrichment-product-refs summary {
  cursor: pointer;
  font-size: 12px;
  font-weight: 800;
  color: #7c2d12;
  line-height: 1.45;
  list-style-position: inside;
}
.enrichment-product-refs summary span {
  display: inline-block;
  margin-left: 6px;
  color: #ea580c;
  font-weight: 800;
}
.enrichment-product-refs-body {
  margin-top: 10px;
}
.enrichment-product-ref-help,
.enrichment-product-ref-foot,
.enrichment-product-ref-empty {
  font-size: 11px;
  line-height: 1.45;
  color: #9a3412;
}
.enrichment-product-ref-empty {
  background: #ffedd5;
  border-radius: 6px;
  padding: 8px 10px;
}
.enrichment-product-ref-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin: 8px 0;
}
.enrichment-product-ref-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 6px;
  background: #ffffff;
  border: 1px solid #fed7aa;
  border-radius: 8px;
  cursor: pointer;
  min-width: 0;
}
.enrichment-product-ref-card.is-selected {
  border-color: #f97316;
  box-shadow: 0 0 0 2px rgba(249, 115, 22, 0.18);
}
/* 사장님 결정 (2026-05-08): AI 추천 카드 — 강조 + 배지 */
.enrichment-product-ref-card.is-recommended {
  border-color: #2563eb;
  background: linear-gradient(180deg, #eff6ff, #ffffff);
  box-shadow: 0 0 0 1px rgba(37, 99, 235, 0.15);
}
.enrichment-product-ref-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  background: #2563eb;
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  z-index: 2;
  pointer-events: none;
}
.enrichment-product-ref-thumb {
  position: relative;  /* 배지 절대 위치 기준 */
}
.enrichment-product-ref-card input {
  position: absolute;
  top: 8px;
  left: 8px;
  width: 16px;
  height: 16px;
  accent-color: #f97316;
  z-index: 1;
}
.enrichment-product-ref-thumb {
  display: block;
  aspect-ratio: 1 / 1;
  border-radius: 6px;
  overflow: hidden;
  background: #f8fafc;
}
.enrichment-product-ref-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.enrichment-product-ref-caption {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}
.enrichment-product-ref-caption strong {
  font-size: 11px;
  color: #0f172a;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.enrichment-product-ref-caption em {
  font-size: 10px;
  color: #64748b;
  font-style: normal;
}
@media (max-width: 560px) {
  .enrichment-product-ref-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
/* 사장님 결정 (2026-05-07): row-head 우측 [AI 다듬기] 버튼 — 시나리오 다듬기 */
.enrichment-scenario-polish-btn {
  font-size: 11px !important;
  padding: 3px 8px !important;
  background: linear-gradient(180deg, #fefce8 0%, #fef3c7 100%) !important;
  color: #92400e !important;
  border-color: #fcd34d !important;
  font-weight: 600 !important;
}
.enrichment-scenario-polish-btn:hover:not([disabled]) {
  background: #fde68a !important;
  border-color: #f59e0b !important;
}
.enrichment-row-label {
  font-size: 11px;
  font-weight: 700;
  color: #1e3a8a;
  background: rgba(99, 102, 241, 0.12);
  border-radius: 4px;
  padding: 2px 8px;
}
.enrichment-row-copy {
  margin-top: 4px;
  padding-top: 8px;
  border-top: 1px dashed #cbd5e1;
}
.enrichment-row-copy-head {
  display: flex; align-items: center; justify-content: space-between;
  gap: 8px;
  margin-bottom: 4px;
}
.enrichment-row-copy-head label {
  font-size: 11px;
  color: #475569;
  font-weight: 500;
  margin: 0;
}
.enrichment-row-copy-input {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid #cbd5e1;
  border-radius: 6px;
  font-size: 12px;
  font-family: inherit;
  background: #f0f9ff;
  resize: vertical;
}
.enrichment-kb-edit-modal { max-width: 720px; }
.enrichment-modal-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px;
  border-bottom: 1px solid var(--color-border);
  background: #f8fafc;
}
.enrichment-modal-head h3 { margin: 0; font-size: 15px; font-weight: 700; color: #0f172a; }
.enrichment-modal-body {
  padding: 16px 18px;
  display: flex; flex-direction: column; gap: 14px;
  overflow-y: auto;
}
.enrichment-modal-foot {
  display: flex; justify-content: flex-end; gap: 8px;
  padding: 12px 18px;
  border-top: 1px solid var(--color-border);
  background: #f8fafc;
}
.enrichment-field { display: flex; flex-direction: column; gap: 6px; }
.enrichment-field label { font-size: 12px; font-weight: 600; color: #334155; }
.enrichment-field input[type="text"],
.enrichment-field input[type="number"],
.enrichment-field select,
.enrichment-field textarea {
  width: 100%;
  padding: 8px 10px;
  border: 1px solid var(--color-border);
  border-radius: 6px;
  font-size: 13px;
  font-family: inherit;
  box-sizing: border-box;
}
.enrichment-field textarea { resize: vertical; min-height: 60px; line-height: 1.4; }
.enrichment-help { font-size: 11px; color: #64748b; }
.enrichment-empty-hint {
  font-size: 12px; color: #b45309;
  background: #FEF3C7;
  padding: 6px 10px;
  border-radius: 6px;
  border-left: 3px solid #F59E0B;
}
.enrichment-kb-preview {
  border: 1px solid var(--color-border);
  border-radius: 8px;
  background: #f8fafc;
}
.enrichment-kb-preview > summary {
  padding: 10px 14px;
  font-size: 12px; font-weight: 600;
  color: #475569;
  cursor: pointer;
  list-style: none;
}
.enrichment-kb-preview > summary::-webkit-details-marker { display: none; }
.enrichment-kb-preview[open] > summary { border-bottom: 1px solid var(--color-border); }
.enrichment-kb-body {
  padding: 12px 14px;
  display: flex; flex-direction: column; gap: 10px;
  font-size: 12px;
}
.enrichment-kb-body .kb-row { line-height: 1.5; }
.enrichment-kb-body .kb-row.muted { color: #94a3b8; font-style: italic; }
.enrichment-kb-body .kb-row strong { color: #1d4ed8; }
.enrichment-kb-body .kb-row ul { margin: 4px 0 0; padding-left: 18px; }
.enrichment-kb-body .kb-row li { padding: 1px 0; }

/* 사장님 룰 (2026-05-06): 00번 섹션 위에도 주황 라벨 표시.
   stage overflow:hidden 이 top:-24px 영역을 자르므로 .is-first 는 padding 안쪽으로 박음.
   - section :first-child padding-top: 28px → 첫 이미지 위 28px 공간 확보
   - .is-first divider top: 28px → ::after (top:-24px) 가 section 의 4px 자리에 박힘 (잘리지 X) */
.merged-preview-section:first-child { padding-top: 28px; }
.merged-section-divider.is-first {
  top: 28px;
  border-top: none;
  filter: none;
}
.merged-section-divider::after {
  content: attr(data-label);
  position: absolute;
  left: 8px;          /* 사장님 룰 (2026-05-04): + 아이콘과 안 겹치게 왼쪽으로 */
  right: auto;
  top: -24px;
  padding: 2px 8px;
  border-radius: 4px;
  background: #F97316;
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 900;
  line-height: 1.45;
  white-space: nowrap;
  box-shadow: 0 1px 4px rgba(0,0,0,.22);
}
/* 1장 이어보기 — 섹션 사이 + 아이콘 (사장님이 그 자리에서 새 섹션 추가) */
/* 사장님 룰 (2026-05-04 수정): 점선 끝 모서리 X. 안쪽 으로 이동 + 약간 큼지막. */
/* 사장님 룰 (v9 2026-05-06): 우상단 큰 원 X → 점선 가운데 작은 ＋. 점선이 흰 배경에 자연스럽게 끊김. */
.merged-section-divider .merged-inject-btn {
  pointer-events: auto;
  position: absolute;
  left: 50%;
  top: -11px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1.5px solid #F97316;
  background: #FFFFFF;
  color: #F97316;
  font-size: 13px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0;
  transform: translateX(-50%);
  transform-origin: center center;
  box-shadow: 0 1px 3px rgba(249,115,22,.35);
}
/* 맨 아래 +bottom 은 .merged-inject-bottom 별도 룰 (가운데 이미 박혀있음) */
.merged-inject-btn {
  pointer-events: auto;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  border: 3px solid #F97316;
  background: #FFFFFF;
  color: #F97316;
  font-size: 22px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  z-index: 11;
  display: flex;
  align-items: center;
  justify-content: center;
  box-shadow: 0 3px 10px rgba(0,0,0,.28);
  transition: transform 0.15s ease, box-shadow 0.15s ease, background 0.15s ease;
}
.merged-section-divider .merged-inject-btn:hover {
  transform: translateX(-50%) scale(1.18);
  box-shadow: 0 3px 10px rgba(249,115,22,.55);
  background: #F97316;
  color: #FFFFFF;
}
.merged-inject-btn:hover {
  transform: scale(1.15);
  box-shadow: 0 4px 14px rgba(249,115,22,.55);
  background: #F97316;
  color: #FFFFFF;
}
.merged-preview-bottom-add {
  display: flex;
  justify-content: center;
  align-items: center;
  padding: 28px 0 12px;
  position: relative;
}
.merged-inject-bottom {
  position: relative;
  right: auto;
  top: auto;
}
.merged-remove-insert-btn {
  position: absolute;
  top: 10px;
  right: 10px;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: none;
  background: rgba(239, 68, 68, 0.92);
  color: #FFFFFF;
  font-size: 14px;
  cursor: pointer;
  z-index: 11;
  pointer-events: auto;
  box-shadow: 0 1px 4px rgba(0,0,0,.22);
}
.merged-remove-insert-btn:hover {
  background: rgba(220, 38, 38, 1);
  transform: scale(1.08);
}
/* 2026-05-23 사장님 신규: ✂️ 자르기 — drag y1~y2 → backend crop */
.merged-crop-btn {
  position: absolute;
  top: 10px;
  right: 50px;
  background: rgba(245, 158, 11, 0.95);
  color: #FFFFFF;
  font-size: 12px;
  font-weight: 700;
  padding: 6px 10px;
  border-radius: 8px;
  border: none;
  cursor: pointer;
  z-index: 60;  /* 2026-05-24 사장님 catch: overlay z-index 50 보다 위 = 자르기 ON 시에도 클릭 가능 */
  pointer-events: auto;
  box-shadow: 0 2px 6px rgba(0,0,0,.22);
  white-space: nowrap;
}
.merged-crop-btn:hover {
  background: rgba(217, 119, 6, 1);
  transform: scale(1.05);
}
/* 2026-05-24 사장님 명시: 자르기 버튼 = 토글. ON 시 [✕ 취소] = 빨강 배경 (시각 명시) */
.merged-crop-btn--cancel {
  background: rgba(220, 38, 38, 0.95) !important;
}
.merged-crop-btn--cancel:hover { background: rgba(185, 28, 28, 1) !important; }
.merged-crop-btn-compact {
  position: static;
  margin-left: 8px;
  padding: 4px 8px;
  font-size: 11px;
}
.merged-inject-menu {
  background: #FFFFFF;
  border: 1px solid #cbd5e1;
  border-radius: 10px;
  padding: 14px;
  box-shadow: 0 8px 24px rgba(0,0,0,.22);
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 220px;
}
.merged-inject-menu-title {
  font-size: 12px;
  color: #475569;
  font-weight: 700;
  margin-bottom: 4px;
}

/* AI 폴백 시각 배지 — 1장 이어보기 모달 섹션 좌상단 (cd1bbc1 + entry.fallback_reason) */
.merged-section-fallback-badge {
  position: absolute;
  top: 8px;
  left: 8px;
  z-index: 5;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 700;
  color: #fff;
  background: rgba(217, 119, 6, 0.92);
  border-radius: 6px;
  box-shadow: 0 2px 6px rgba(0, 0, 0, 0.18);
  pointer-events: auto;
  cursor: help;
  letter-spacing: -0.2px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.merged-section-fallback-badge.is-info {
  color: #0f172a;
  background: rgba(224, 242, 254, 0.94);
  border: 1px solid rgba(14, 165, 233, 0.38);
}
/* ExecPlan 025 (2026-05-05): 폴백 4 액션 */
.merged-section-fallback-badge .fallback-label {
  display: block;
}
.merged-section-fallback-badge .fallback-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 4px;
}
.merged-section-fallback-badge .fallback-actions .btn {
  background: rgba(255, 255, 255, 0.95);
  color: #1f2937;
  font-size: 11px;
  padding: 2px 6px;
  border-radius: 4px;
  font-weight: 600;
  cursor: pointer;
}
.merged-section-fallback-badge .fallback-actions .btn:hover {
  background: #fff;
}
.merged-preview-section { position: relative; }

/* 1장 이어보기 모달 + 아이콘 → 특수 페이지 라이브러리 picker */
.special-picker-overlay { z-index: 11000; }
.special-picker-modal { max-width: 920px; width: 92vw; max-height: 88vh; }
.special-picker-body { display: flex; flex-direction: column; gap: 12px; overflow: auto; }
.special-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 14px;
}
.special-picker-card {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 8px;
  border: 1px solid #d8e1ef;
  border-radius: 12px;
  background: #ffffff;
  cursor: pointer;
  transition: transform 0.12s ease, box-shadow 0.12s ease, border-color 0.12s ease;
  text-align: left;
}
.special-picker-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(15, 23, 42, 0.12);
  border-color: #2563eb;
}
.special-picker-card img {
  width: 100%;
  aspect-ratio: 4 / 5;
  object-fit: cover;
  border-radius: 8px;
  background: #f1f5f9;
}
.special-picker-meta { display: flex; flex-direction: column; gap: 4px; padding: 0 4px 6px; }
.special-picker-meta strong { font-size: 13px; color: #0f172a; }
.special-picker-meta span { font-size: 11px; color: #64748b; line-height: 1.4; }

/* ExecPlan 016 — A+C 하이브리드 안전 분할 미리보기 모달 (재단사) */
.safe-split-overlay {
  align-items: stretch;
  justify-content: center;
  padding: 24px;
}
.safe-split-modal {
  width: min(1100px, calc(100vw - 48px));
  max-height: calc(100vh - 48px);
  display: flex;
  flex-direction: column;
}
.safe-split-hint {
  padding: 14px 22px;
  background: rgba(249, 115, 22, 0.08);
  border-bottom: 1px solid rgba(249, 115, 22, 0.22);
  color: #7c2d12;
  font-size: 13px;
  line-height: 1.55;
}
.safe-split-body {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
}
/* 2026-05-23 v4 zoom + pan: transform translate + scale 통합. scroll 의존 X. */
.safe-split-scroll {
  width: 100%;
  max-height: 70vh;
  height: 70vh;
  overflow: hidden;         /* transform 만 사용 (scroll 의존 X = 축소 후도 pan 동작) */
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f1f5f9;
  padding: 0;
  cursor: grab;             /* 빈 영역 hover = pan 가능 신호 */
  position: relative;
}
.safe-split-scroll--panning {
  cursor: grabbing;
  user-select: none;
}
.safe-split-canvas-wrap {
  display: block;
  width: 100%;
  transform-origin: 50% 50%;   /* 사장님 명시 = 전체가 가운데로 작아지는 느낌 */
  transition: transform 80ms linear;
}
.safe-split-canvas {
  position: relative;
  border: 1px solid #cbd5e1;
  border-radius: 8px;
  overflow: visible;     /* ✕ 버튼이 라인 위로 튀어나와도 잘리지 않게 */
  cursor: crosshair;
  user-select: none;
}
.safe-split-canvas img {
  display: block;
  width: 100%;
  height: auto;
  pointer-events: none;
}
.safe-split-overlay-layer {
  position: absolute;
  inset: 0;
  pointer-events: none;
}
.safe-split-line {
  position: absolute;
  left: 0;
  right: 0;
  height: 0;
  border-top: 2px dashed #F97316;
  pointer-events: auto;
  cursor: ns-resize;
  z-index: 5;
}
.safe-split-line-handle {
  position: absolute;
  left: 0; right: 0; top: -12px;
  height: 24px;
  cursor: ns-resize;
}
.safe-split-line-remove {
  /* 2026-05-23 사장님 명시 = 원래 위치(right:8px) 로 복원. zoom/pan 으로 viewport 정합. */
  position: absolute;
  top: -12px;
  right: 8px;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: none;
  background: rgba(239, 68, 68, 0.92);
  color: white;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  z-index: 6;
}
.safe-split-line-remove:hover {
  background: #dc2626;
  transform: scale(1.1);
}
.safe-split-line-label {
  position: absolute;
  top: -14px;
  left: 8px;
  padding: 2px 6px;
  background: #F97316;
  color: white;
  font-size: 10px;
  font-weight: 700;
  border-radius: 3px;
  white-space: nowrap;
  pointer-events: none;
}
/* 🧲 마그네틱 snap 발동 시 시각 표시 — 트레이딩뷰 magnetic mode 패턴 */
.safe-split-line--snapped {
  border-top-color: #10B981;
  border-top-style: solid;
  box-shadow: 0 0 0 1px rgba(16, 185, 129, 0.35);
}
.safe-split-line--snapped .safe-split-line-label {
  background: #10B981;
}
.safe-split-info {
  font-size: 12px;
  color: #475569;
  padding: 12px;
  background: #f8fafc;
  border-radius: 8px;
}
.safe-split-info p { margin: 0 0 8px; }
.safe-split-info .hint { color: #64748b; line-height: 1.6; }
.safe-split-actions {
  border-top: 1px solid #e2e8f0;
  padding: 14px 22px;
  display: flex;
  justify-content: flex-end;
  align-items: center;
  gap: 10px;
}
.safe-split-zoom {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  margin-right: auto;
  padding: 4px 8px;
  background: #f1f5f9;
  border-radius: 6px;
  border: 1px solid #e2e8f0;
}
.safe-split-zoom-level {
  font-size: 12px;
  font-weight: 600;
  color: #475569;
  min-width: 44px;
  text-align: center;
}
/* 사장님 룰 (ExecPlan 013): 휠 모드 토글 — Ctrl+휠 / 휠 두 모드 전환 체크 박스 */
/* 사장님 룰 (2026-05-04 수정): 오른쪽 끝으로 이동 + 여백 */
.merged-preview-hint {
  display: flex;
  align-items: center;
  gap: 12px;
  padding-right: 16px;
}
.wheel-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 999px;
  background: rgba(255, 255, 255, 0.12);
  border: 1px solid rgba(255, 255, 255, 0.22);
  color: #dc2626;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  margin-left: auto;   /* 오른쪽 끝으로 밀기 */
  user-select: none;
  flex-shrink: 0;
}
.wheel-mode-toggle input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
}
.wheel-mode-toggle:hover {
  background: rgba(255, 255, 255, 0.18);
}
.merged-compare-shell {
  width: min(1720px, calc(100vw - 56px));
}
.merged-compare-stage {
  width: 1580px;
  gap: 0;
}
.merged-compare-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px 20px;
  padding: 16px 22px 22px;
  background: #FFFFFF;
  position: relative;
}
.merged-compare-row:first-child {
  border-top: 0;
}
.merged-compare-divider {
  position: relative;
  grid-column: 1 / -1;
  left: auto;
  right: auto;
  top: auto;
  height: 28px;
  margin: 0 0 -2px;
  border-top-color: rgba(249, 115, 22, 0.78);
  filter: none;
  z-index: 1;
}
.merged-compare-divider::after {
  left: 50%;
  right: auto;
  top: -12px;
  transform: translateX(-50%);
  padding: 3px 10px;
  border: 1px solid rgba(249, 115, 22, 0.55);
  border-radius: 999px;
  background: rgba(255, 247, 237, 0.96);
  color: #C2410C;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.12);
}
.merged-compare-pane {
  display: grid;
  gap: 8px;
  margin: 0;
  min-width: 0;
  border: 0;
  border-radius: 0;
  overflow: visible;
  background: transparent;
}
.merged-compare-pane figcaption {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 28px;
  padding: 0 2px;
  background: transparent;
  color: #0F172A;
  font-size: 12px;
  line-height: 1.4;
}
.merged-compare-pane figcaption b {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 9px;
  border: 1px solid #CBD5E1;
  border-radius: 999px;
  background: #FFFFFF;
  color: #0F172A;
  font-size: 11px;
  font-weight: 900;
  box-shadow: 0 2px 8px rgba(15, 23, 42, 0.08);
}
.merged-compare-pane figcaption span {
  color: #475569;
  text-align: right;
  overflow-wrap: anywhere;
  font-size: 11px;
  font-weight: 700;
}
.merged-compare-pane img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid #E2E8F0;
  border-radius: 8px;
  background: #F8FAFC;
  pointer-events: none;
}
.merged-compare-empty {
  display: grid;
  place-items: center;
  min-height: 240px;
  color: #64748B;
  font-weight: var(--font-bold);
  background: #F8FAFC;  /* 사장님 룰 2026-05-04: 빗살무늬 → 단색 */
}
.localized-compare-note {
  margin: -6px 0 var(--space-3);
  padding: var(--space-2) var(--space-3);
  border: 1px solid #FED7AA;
  border-radius: var(--radius-sm);
  background: #FFF7ED;
  color: #9A3412;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.merged-preview-toc {
  min-height: 0;
  overflow: auto;
  padding: 14px 10px;
  border-left: 1px solid rgba(15, 23, 42, 0.1);
  background: #ffffff;  /* 사장님 룰 2026-05-04: 디폴트 light 톤 */
  /* 사장님 룰 (2026-05-06 v4): 폭 강제 X — 기존 자동 폭으로 복원 */
}
.merged-preview-toc-title {
  margin-bottom: 10px;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 900;
}
.merged-preview-toc-list {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}
.merged-preview-toc button {
  display: inline-grid;
  place-items: center;
  width: 100%;
  min-height: 34px;
  padding: 0;
  border: 1px solid #dbeafe;
  border-radius: 8px;
  background: #f8fafc;
  color: #0f172a;
  text-align: center;
  cursor: pointer;
}
.merged-preview-toc button:hover,
.merged-preview-toc button.active {
  border-color: #3b82f6;
  background: #eff6ff;
}
.merged-preview-toc button span {
  display: inline-grid;
  place-items: center;
  width: 100%;
  min-height: 32px;
  border-radius: inherit;
  background: transparent;
  color: #1d4ed8;
  font-size: 12px;
  font-weight: 900;
}
.merged-preview-overlay.is-light .merged-preview-toc {
  border-left-color: rgba(15, 23, 42, 0.1);
  background: #ffffff;
}
.merged-preview-overlay.is-light .merged-preview-toc-title {
  color: #1d4ed8;
}
.merged-preview-overlay.is-light .merged-preview-toc button {
  border-color: #dbeafe;
  background: #f8fafc;
  color: #0f172a;
}
.merged-preview-overlay.is-light .merged-preview-toc button:hover,
.merged-preview-overlay.is-light .merged-preview-toc button.active {
  border-color: #3b82f6;
  background: #eff6ff;
}
.merged-preview-overlay.is-light .merged-preview-toc button span {
  color: #1d4ed8;
}
@media (max-width: 980px) {
  .merged-preview-body {
    grid-template-columns: minmax(0, 1fr);
  }
  .merged-preview-toc {
    display: none;
  }
}

/* ── 이미지 라이트박스 (분석 그리드 / 풀 그리드 🔍 버튼) ─ */
/* 사장님 룰 2026-05-04: image-viewer 통일 + 디폴트 light 톤 frame */
.lightbox-overlay {
  /* 2026-06-14 사장님: 확대 모달 뒤 완전히 보이게. 오버레이는 'modal-overlay lightbox-overlay'
     두 클래스 → v7-skin .modal-overlay 의 backdrop-filter:blur(2px) + scrim 이 진짜 blur 원인.
     여기서 !important 로 완전 무효화. */
  background: transparent !important;
  backdrop-filter: none !important;
  -webkit-backdrop-filter: none !important;
  display: flex; align-items: center; justify-content: center;
  padding: 32px;
  cursor: default;
  z-index: 100;
}
.lightbox-viewer {
  width: min(1280px, calc(100vw - 96px));
  height: calc(100vh - 96px);
}
/* 사장님 룰 (2026-05-06): compact — 뒷배경 투명 + 더 작은 사이즈 */
.lightbox-overlay-compact { background: transparent !important; }
/* anchored — 가운데 X, 클릭한 thumb 의 약간 왼쪽에 위치 (JS 가 inline left/top 박음) */
.lightbox-overlay-anchored { display: block !important; }
.lightbox-overlay-compact .lightbox-viewer {
  width: min(560px, calc(100vw - 80px));
  height: auto;
  max-height: calc(100vh - 120px);
  border-radius: 14px;
  overflow: hidden;
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.24);
}
.lightbox-close {
  position: fixed;
  top: 16px; right: 16px;
  width: 40px; height: 40px;
  border-radius: 50%;
  border: 0;
  background: #ffffff;
  color: #0f172a;
  font-size: 20px;
  cursor: pointer;
  box-shadow: 0 4px 12px rgba(15, 23, 42, 0.18);
  z-index: 1;
}
.lightbox-close:hover { background: #eff6ff; }

/* 카드 우상단 🔍 줌 버튼 (✕ 옆) */
.img-zoom {
  position: absolute;
  top: 6px; right: 36px;  /* ✕ 가 오른쪽 6px → 줌은 한 칸 왼쪽 */
  width: 24px; height: 24px;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,0.95);
  color: #0f172a;
  font-size: 11px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  z-index: 2;
  box-shadow: 0 1px 3px rgba(0,0,0,0.2);
  padding: 0;
}
.img-zoom:hover { background: #ffffff; transform: scale(1.05); }

/* ── 페이지 우상단 스택형 토스트 (전역 alert 대체) ─────── */
.toast-host {
  position: fixed;
  top: 16px; right: 16px;
  display: flex; flex-direction: column;
  gap: 8px;
  z-index: 9999;
  pointer-events: none;
  max-width: min(420px, calc(100vw - 32px));
}
.toast {
  pointer-events: auto;
  display: flex; align-items: flex-start;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-3) var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  border: 1px solid;
  font-size: var(--text-sm);
  line-height: 1.5;
  box-shadow: 0 6px 16px rgba(15, 23, 42, 0.12);
  animation: toast-in 0.18s ease-out;
}
@keyframes toast-in {
  from { transform: translateX(8px); opacity: 0; }
  to   { transform: translateX(0);   opacity: 1; }
}
.toast.toast-out {
  animation: toast-out 0.2s ease-in forwards;
}
@keyframes toast-out {
  from { transform: translateX(0);   opacity: 1; }
  to   { transform: translateX(16px); opacity: 0; }
}
.toast-info    { background: #EFF6FF; border-color: #BFDBFE; color: #1E3A8A; }
.toast-success { background: #ECFDF5; border-color: #A7F3D0; color: #065F46; }
.toast-warn    { background: #FFFBEB; border-color: #FDE68A; color: #92400E; }
.toast-error   { background: #FEF2F2; border-color: #FECACA; color: #991B1B; }
.toast-text    { flex: 1 1 auto; white-space: pre-wrap; }
.toast-close {
  flex: 0 0 auto;
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0 4px;
  color: inherit;
  opacity: 0.65;
  font-size: var(--text-base);
}
.toast-close:hover { opacity: 1; }

/* ── 이미지 카드 인라인 토스트 ─────────────────────────── */
.img-toast {
  display: flex; align-items: center; justify-content: space-between;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  margin-top: var(--space-2);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  line-height: 1.4;
  border: 1px solid;
}
.img-toast[data-type="info"]    { background: #EFF6FF; border-color: #BFDBFE; color: #1E40AF; }
.img-toast[data-type="success"] { background: #ECFDF5; border-color: #A7F3D0; color: #065F46; }
.img-toast[data-type="warn"]    { background: #FFFBEB; border-color: #FDE68A; color: #92400E; }
.img-toast[data-type="error"]   { background: #FEF2F2; border-color: #FECACA; color: #991B1B; }
.img-toast-text { flex: 1 1 auto; }
.img-toast-close {
  background: transparent;
  border: 0;
  cursor: pointer;
  padding: 0 var(--space-1);
  font-size: var(--text-sm);
  color: inherit;
  opacity: 0.7;
  flex: 0 0 auto;
}
.img-toast-close:hover { opacity: 1; }

/* ── 섹션 면책 문구 토글 ─────────────────────────── */
.disclaimer-toggle {
  display: inline-flex;
  align-items: center;
  gap: var(--space-2);
  padding: var(--space-2) var(--space-3);
  margin: var(--space-2) 0;
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
  cursor: pointer;
  user-select: none;
}
.disclaimer-toggle input[type="checkbox"] {
  margin: 0;
  cursor: pointer;
}
.disclaimer-toggle:hover { border-color: var(--color-primary); }

/* ── 부분 수정 (inpaint) 모달 ─────────────────────────── */
.inpaint-overlay { padding: var(--space-3); align-items: stretch; }
.inpaint-modal { max-width: 1400px; width: 96vw; }
.inpaint-body {
  display: grid;
  grid-template-columns: 1fr 360px;
  gap: var(--space-4);
  padding: var(--space-4);
  height: calc(95vh - 80px);
  overflow: hidden;
}
.inpaint-canvas-wrap {
  display: flex; flex-direction: column;
  gap: var(--space-2);
  min-width: 0;
}
.inpaint-canvas-stage {
  flex: 1 1 auto;
  position: relative;
  background: #0f172a;  /* 사장님 룰 2026-05-04: 빗살무늬 → 단색 */
  border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  overflow: hidden;
  min-height: 360px;
}
.inpaint-canvas-stage canvas {
  cursor: crosshair;
  display: block;
  max-width: 100%;
  max-height: 100%;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #fff;
}
.inpaint-region-info {
  position: absolute;
  bottom: 8px; left: 8px;
  padding: 4px 10px;
  background: rgba(15, 23, 42, 0.85);
  color: #fff;
  font-size: var(--text-xs);
  border-radius: var(--radius-sm);
  font-variant-numeric: tabular-nums;
  pointer-events: none;
}
.inpaint-side {
  display: flex; flex-direction: column;
  gap: var(--space-3);
  overflow-y: auto;
  padding-right: var(--space-2);
}
.inpaint-ref-preview {
  margin-top: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  overflow: hidden;
}
.inpaint-ref-preview img {
  display: block;
  width: 100%;
  max-height: 200px;
  object-fit: contain;
  background: var(--color-bg-input);
}

/* ── 원본 ↔ 후처리 비교 모달 ────────────────────────────── */
.compare-overlay { padding-top: var(--space-4); align-items: start; }
.compare-modal { max-width: 1400px; }
.compare-body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-4); }
.compare-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-4);
}
.compare-pane {
  margin: 0;
  display: flex; flex-direction: column;
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
}
.compare-label {
  display: flex; align-items: center; gap: var(--space-2);
  padding: var(--space-3) var(--space-4);
  background: var(--color-bg-card);
  border-bottom: 1px solid var(--color-border);
  font-size: var(--text-sm);
}
.compare-label-name { font-weight: var(--font-bold); }
.compare-score {
  background: var(--color-primary-light, #DBEAFE);
  color: var(--color-primary, #1E40AF);
  padding: 2px 8px; border-radius: 99px;
  font-size: var(--text-xs); font-weight: var(--font-semibold);
}
.compare-diff {
  margin-left: auto;
  font-weight: var(--font-bold);
  font-size: var(--text-xs);
  padding: 2px 8px; border-radius: 99px;
}
.compare-diff.diff-up   { background: #ECFDF5; color: #065F46; }
.compare-diff.diff-down { background: #FEF2F2; color: #991B1B; }
.compare-img-wrap {
  flex: 1 1 auto;
  display: flex; align-items: center; justify-content: center;
  padding: var(--space-3);
  background: #F8FAFC;
  min-height: 320px;
}
.compare-img-wrap img {
  max-width: 100%; max-height: 60vh;
  object-fit: contain;
  display: block;
}
.compare-actions {
  display: flex; justify-content: center; gap: var(--space-3);
  border-top: 1px solid var(--color-border);
  padding-top: var(--space-4);
}

.history-notice {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  background: var(--color-bg-input);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2) var(--space-3);
  margin-bottom: var(--space-2);
  line-height: 1.5;
}

/* ── 썸네일 메이커 모달 ─────────────────────────────────── */
.thumbnail-overlay { padding-top: var(--space-4); align-items: start; }
.modal.modal-thumb { max-width: 1200px; width: 95%; }
.tool-page-shell {
  width: 100%;
  min-height: calc(100vh - var(--topbar-height) - (var(--space-6) * 2));
}
.tool-page-card {
  max-width: none;
  width: 100%;
  min-height: calc(100vh - var(--topbar-height) - (var(--space-6) * 2));
  max-height: none;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.tool-page-card .modal-body {
  max-height: none;
}
.thumb-body { padding: var(--space-5); display: flex; flex-direction: column; gap: var(--space-5); }
.thumb-section-title {
  font-size: var(--text-base);
  font-weight: var(--font-bold);
  margin: 0 0 var(--space-3);
  letter-spacing: -0.01em;
}
.thumb-template-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: var(--space-3);
}
.thumb-template-card {
  display: flex; flex-direction: column;
  background: var(--color-bg-card);
  border: 2px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  cursor: pointer;
  text-align: left;
  transition: border-color var(--transition-base), box-shadow var(--transition-base), transform var(--transition-base);
  padding: 0;
}
.thumb-template-card:hover { transform: translateY(-2px); box-shadow: var(--shadow-md); }
.thumb-template-card.selected { border-color: var(--color-primary); box-shadow: var(--shadow-focus); }
.thumb-template-img {
  position: relative;
  width: 100%;
  aspect-ratio: 1;
  background: linear-gradient(135deg, var(--color-primary-light), var(--color-bg-section));
  overflow: hidden;
}
.thumb-template-img img { width: 100%; height: 100%; object-fit: cover; display: block; }
.thumb-template-fallback {
  display: grid; place-items: center;
  width: 100%; height: 100%;
  font-family: var(--font-mono);
  color: var(--color-primary-dark);
  font-weight: var(--font-bold);
}
.thumb-template-meta {
  padding: var(--space-3);
  display: flex; flex-direction: column; gap: 2px;
}
.thumb-template-meta strong {
  font-family: var(--font-mono);
  font-size: var(--text-xs);
  color: var(--color-primary);
}
.thumb-template-meta span { font-size: var(--text-sm); font-weight: var(--font-semibold); }
.thumb-template-meta small { font-size: var(--text-xs); color: var(--color-text-muted); }

.thumb-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: var(--space-5);
}
.thumb-settings { min-width: 0; }
.thumb-preview { min-width: 0; }
.thumb-preview-frame {
  position: relative;
  aspect-ratio: 1;
  background: var(--color-bg-input);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  display: grid;
  place-items: center;
}
.thumb-preview-img { width: 100%; height: 100%; object-fit: cover; }
.thumb-preview-fallback { color: var(--color-text-muted); font-size: var(--text-sm); }

/* 배지 그리드 */
.thumb-badge-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.thumb-badge-group {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-2) var(--space-3);
  margin: 0;
}
.thumb-badge-group legend {
  padding: 0 var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-primary);
  font-weight: var(--font-bold);
}
.thumb-badge-item {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  padding: 2px 0;
  font-size: var(--text-xs);
  cursor: pointer;
  flex-wrap: wrap;
}
.thumb-badge-item input[type="checkbox"] { accent-color: var(--color-primary); }
.thumb-badge-item .thumb-badge-value {
  flex: 1;
  min-width: 80px;
  margin-left: auto;
  padding: 2px 6px;
  font-size: var(--text-xs);
}
.thumb-badge-help {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 16px; height: 16px;
  border-radius: var(--radius-full);
  background: var(--color-bg-input);
  color: var(--color-text-muted);
  font-size: 10px;
  cursor: help;
  margin-left: 2px;
  outline: none;
}
.thumb-badge-help:hover { background: var(--color-primary-light); color: var(--color-primary-dark); }
.thumb-badge-help:focus { box-shadow: var(--shadow-focus); }

/* JS 포털 툴팁 — body 직속, 커서 위쪽 충분히 띄움 (어떤 모달에도 잘리지 않음) */
.tip-portal {
  position: fixed;
  z-index: 99999;
  background: rgba(15, 23, 42, 0.97);
  color: #fff;
  padding: 8px 12px;
  border-radius: var(--radius-md);
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
  line-height: 1.45;
  letter-spacing: 0.01em;
  width: max-content;
  max-width: 280px;
  white-space: normal;
  text-align: center;
  box-shadow: 0 8px 24px rgba(0,0,0,0.35);
  pointer-events: none;
  opacity: 0;
  transition: opacity 0.12s ease;
}
.tip-portal.show { opacity: 1; }
.tip-portal::after {
  content: "";
  position: absolute;
  top: 100%;
  left: 50%;
  transform: translateX(-50%);
  border: 6px solid transparent;
  border-top-color: rgba(15, 23, 42, 0.97);
}
.tip-portal.below::after {
  top: auto;
  bottom: 100%;
  border-top-color: transparent;
  border-bottom-color: rgba(15, 23, 42, 0.97);
}

/* 사은품 추가 입력 영역 */
.gift-extras {
  width: 100%;
  margin-top: var(--space-2);
  padding: var(--space-2) var(--space-3);
  background: var(--color-bg-section);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.gift-extras[hidden] { display: none; }
.gift-name-input { font-size: var(--text-xs); }
.gift-image-row {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
}
.gift-image-status {
  font-size: var(--text-xs);
  color: var(--color-success);
  font-weight: var(--font-medium);
}

@media (max-width: 900px) {
  .thumb-main { grid-template-columns: 1fr; }
}

/* 미리보기 모달 */
.preview-modal { max-width: 860px; }
.preview-body { display: flex; flex-direction: column; gap: var(--space-4); }
.preview-frame {
  background: var(--color-bg-section);
  border-radius: var(--radius-lg);
  padding: var(--space-2);
  text-align: center;
}
.preview-frame img {
  max-width: 100%;
  border-radius: var(--radius-md);
}
.preview-copy {
  padding: var(--space-4) var(--space-5);
  background: var(--color-bg-card);
  border-left: 4px solid var(--color-primary);
  border-radius: var(--radius-md);
  font-size: var(--text-base);
  line-height: var(--leading-relaxed);
  color: var(--color-text-primary);
}

/* 히스토리 팝오버 */
.history-popover {
  position: absolute;
  z-index: 60;
  min-width: 480px;
  max-width: 640px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-xl);
  overflow: hidden;
}
.history-head {
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
  font-weight: var(--font-bold);
  font-size: var(--text-sm);
  background: var(--color-bg-section);
}
.history-list { max-height: 70vh; overflow-y: auto; }
.history-item {
  display: grid;
  grid-template-columns: 200px 1fr;
  gap: var(--space-3);
  align-items: flex-start;
  padding: var(--space-3) var(--space-4);
  border-bottom: 1px solid var(--color-border);
}
.history-item:last-child { border-bottom: 0; }
.history-thumb {
  position: relative;
  width: 56px; height: 56px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-bg-input);
}
/* 큰 미리보기 — 한 변 200px, 가로세로 비율 유지 */
.history-thumb-large {
  width: 200px; height: 200px;
  cursor: zoom-in;
}
.history-thumb-large img {
  object-fit: contain !important;
  background: var(--color-bg-input);
}
.history-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
}
.history-thumb .multi-tag {
  position: absolute;
  bottom: 2px; right: 2px;
  background: rgba(15,23,42,0.7);
  color: var(--color-text-inverse);
  border-radius: var(--radius-sm);
  font-size: 10px;
  padding: 1px 4px;
}
.history-thumb .thumb-empty {
  display: grid; place-items: center;
  width: 100%; height: 100%;
  color: var(--color-text-muted);
  font-size: 10px;
}
.history-meta { min-width: 0; }
.history-ts { font-size: var(--text-xs); color: var(--color-text-secondary); }
.history-copy {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ── Auth Screen (기존 유지) ─────────────────────────────── */
.auth-screen {
  min-height: 100vh;
  display: grid;
  place-items: center;
  padding: var(--space-6);
  background:
    radial-gradient(circle at 20% 0%, var(--color-primary-light), transparent 40%),
    radial-gradient(circle at 80% 100%, #FEF3C7, transparent 35%),
    var(--color-bg);
}
.auth-card {
  width: 100%; max-width: 420px;
  background: var(--color-bg-card);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-2xl);
  padding: var(--space-10) var(--space-8);
  box-shadow: var(--shadow-xl);
}
.auth-brand { text-align: center; margin-bottom: var(--space-8); }
.auth-brand .logo {
  display: inline-flex; align-items: center; justify-content: center;
  width: 56px; height: 56px;
  border-radius: var(--radius-xl);
  background: var(--color-primary);
  color: var(--color-text-inverse);
  font-weight: var(--font-extrabold);
  font-size: var(--text-2xl);
  margin-bottom: var(--space-4);
  box-shadow: var(--shadow-md);
}
.auth-brand h2 { margin: 0 0 var(--space-2); font-size: var(--text-xl); font-weight: var(--font-bold); letter-spacing: -0.02em; }
.auth-brand p  { margin: 0; font-size: var(--text-sm); color: var(--color-text-secondary); line-height: var(--leading-relaxed); }
.auth-tabs { display: flex; background: var(--color-bg-input); border-radius: var(--radius-lg); padding: var(--space-1); margin-bottom: var(--space-6); }
.auth-tabs button { flex: 1; padding: var(--space-2) var(--space-3); border-radius: var(--radius-md); font-size: var(--text-sm); font-weight: var(--font-medium); color: var(--color-text-secondary); transition: all var(--transition-base); }
.auth-tabs button.active { background: var(--color-bg-card); color: var(--color-text-primary); box-shadow: var(--shadow-sm); }
.auth-form { display: flex; flex-direction: column; gap: var(--space-4); }
.auth-form .field-group { margin-bottom: 0; }
.auth-error {
  margin: 0; padding: var(--space-3) var(--space-4);
  background: var(--color-banned-bg);
  border: 1px solid var(--color-banned-border);
  border-radius: var(--radius-md);
  color: var(--color-banned-text);
  font-size: var(--text-sm);
  font-weight: var(--font-medium);
}
.auth-error:empty { display: none; }
.auth-footer {
  margin-top: var(--space-6);
  text-align: center;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-relaxed);
}

/* ── Guided Workflow Panel ───────────────────────────── */
.workflow-panel {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
  padding: 0 var(--space-4) var(--space-6);
}
.workflow-sticky {
  margin: 0 calc(var(--space-4) * -1);
  padding: var(--space-4);
}
.wf-overview {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.wf-overview-title {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: var(--space-2);
  margin-bottom: var(--space-2);
}
.wf-overview-title strong {
  color: var(--color-text);
  font-size: var(--text-sm);
}
.wf-overview-title span {
  color: var(--color-text-muted);
  font-size: 11px;
  line-height: 1.35;
  text-align: right;
}
.wf-overview-steps {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 6px;
}
.wf-overview-step {
  display: grid;
  gap: 2px;
  min-width: 0;
  padding: 7px 6px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
  color: var(--color-text-secondary);
  text-decoration: none;
}
.wf-overview-step b {
  display: inline-grid;
  place-items: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-bg-input);
  color: var(--color-text-muted);
  font-size: 11px;
}
.wf-overview-step span {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 11px;
  font-weight: var(--font-bold);
}
.wf-overview-step em {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  color: var(--color-text-muted);
  font-size: 10px;
  font-style: normal;
}
.wf-overview-step.done {
  border-color: color-mix(in srgb, var(--color-primary) 42%, var(--color-border));
  background: var(--color-primary-soft);
}
.wf-overview-step.done b {
  background: var(--color-primary);
  color: #fff;
}
.wf-step-head {
  display: grid;
  grid-template-columns: 32px 1fr;
  gap: var(--space-3);
  align-items: start;
  margin-top: var(--space-3);
}
.wf-step-section {
  display: block;
}
.wf-step-section > summary {
  list-style: none;
}
.wf-step-section > summary::-webkit-details-marker {
  display: none;
}
.wf-step-summary {
  grid-template-columns: 32px 1fr auto;
  cursor: pointer;
  padding: var(--space-3);
  border-radius: var(--radius-md);
  border: 1px solid color-mix(in srgb, var(--color-primary) 18%, var(--color-border));
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.08), rgba(37, 99, 235, 0.02));
  transition: border-color 0.15s ease, background 0.15s ease, box-shadow 0.15s ease;
}
.wf-step-summary:hover {
  border-color: color-mix(in srgb, var(--color-primary) 45%, var(--color-border));
  box-shadow: 0 8px 20px rgba(37, 99, 235, 0.08);
}
.wf-step-summary::after {
  content: "접기";
  align-self: center;
  justify-self: end;
  min-width: 72px;
  padding: 7px 12px;
  border: 1px solid var(--color-primary);
  border-radius: var(--radius-full);
  background: var(--color-primary);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 700;
  text-align: center;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.22);
}
.wf-step-section:not([open]) > .wf-step-summary::after {
  content: "펼치기";
  color: #fff;
  border-color: var(--color-primary);
  background: linear-gradient(135deg, var(--color-primary), #1d4ed8);
}
.wf-step-section:not([open]) > .wf-step-summary {
  margin-bottom: 0;
}
.wf-step-content {
  display: flex;
  flex-direction: column;
  gap: var(--space-4);
}
.wf-step-bottom {
  display: flex;
  justify-content: flex-end;
  padding-top: var(--space-3);
  border-top: 1px dashed var(--color-border);
}
.wf-step-bottom [data-collapse-step] {
  border-color: var(--color-primary);
  background: var(--color-primary);
  color: #fff;
  font-weight: 700;
  box-shadow: 0 6px 14px rgba(37, 99, 235, 0.18);
}
.wf-step-bottom [data-collapse-step]:hover {
  background: #1d4ed8;
}
.wf-step-head > span {
  display: grid;
  place-items: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  font-weight: var(--font-bold);
}
.wf-step-head h3 {
  margin: 0;
  font-size: var(--text-base);
  color: var(--color-text);
}
.wf-step-head p {
  margin: 2px 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.wf-sub-step-head {
  margin-top: var(--space-2);
  padding: var(--space-3) var(--space-4);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-input);
}
.wf-sub-step-head h4 {
  margin: 0 0 3px;
  color: var(--color-text);
  font-size: var(--text-sm);
}
.wf-sub-step-head p {
  margin: 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.wf-card {
  border: 1px solid var(--color-border);
  background: var(--color-bg-card);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}
.wf-operation-status {
  position: sticky;
  top: var(--space-2);
  z-index: 32;
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid rgba(37, 99, 235, 0.28);
  border-radius: var(--radius-md);
  background: linear-gradient(135deg, rgba(37, 99, 235, 0.10), rgba(245, 158, 11, 0.08));
  box-shadow: 0 14px 28px rgba(15, 23, 42, 0.14);
  backdrop-filter: blur(10px);
}
.wf-operation-status.is-done {
  border-color: rgba(22, 163, 74, 0.35);
  background: linear-gradient(135deg, rgba(22, 163, 74, 0.12), rgba(37, 99, 235, 0.06));
}
.wf-operation-status.is-error {
  border-color: rgba(220, 38, 38, 0.35);
  background: linear-gradient(135deg, rgba(220, 38, 38, 0.12), rgba(245, 158, 11, 0.08));
}
.wf-operation-status.is-warning {
  border-color: rgba(245, 158, 11, 0.45);
  background: linear-gradient(135deg, rgba(245, 158, 11, 0.16), rgba(37, 99, 235, 0.06));
}
.wf-operation-head {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.wf-operation-head strong {
  color: var(--color-text-primary);
}
.wf-operation-head em {
  margin-left: auto;
  font-style: normal;
  font-weight: var(--font-bold);
  color: var(--color-primary);
}
.wf-status-dot {
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--color-primary);
  box-shadow: 0 0 0 4px rgba(37, 99, 235, 0.14);
  animation: wf-status-pulse 1.1s ease-in-out infinite;
}
.wf-operation-status.is-done .wf-status-dot {
  background: #16a34a;
  box-shadow: 0 0 0 4px rgba(22, 163, 74, 0.14);
  animation: none;
}
.wf-operation-status.is-error .wf-status-dot {
  background: #dc2626;
  box-shadow: 0 0 0 4px rgba(220, 38, 38, 0.14);
  animation: none;
}
.wf-operation-status.is-warning .wf-status-dot {
  background: #f59e0b;
  box-shadow: 0 0 0 4px rgba(245, 158, 11, 0.16);
  animation: none;
}
.wf-operation-title {
  margin-top: var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-text-primary);
}
.wf-operation-detail {
  margin-top: var(--space-1);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  color: var(--color-text-secondary);
}
.wf-operation-bar {
  position: relative;
  height: 7px;
  margin-top: var(--space-3);
  overflow: hidden;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.13);
}
.wf-operation-fill {
  display: block;
  height: 100%;
  min-width: 8%;
  border-radius: inherit;
  background: linear-gradient(90deg, #2563eb, #7c3aed, #f59e0b);
  transition: width 180ms ease;
}
.wf-operation-bar.is-indeterminate .wf-operation-fill {
  width: 42%;
  min-width: 42%;
  animation: wf-operation-slide 1.2s ease-in-out infinite;
}
@keyframes wf-status-pulse {
  0%, 100% { transform: scale(1); opacity: 0.7; }
  50% { transform: scale(1.25); opacity: 1; }
}
@keyframes wf-operation-slide {
  0% { transform: translateX(-120%); }
  100% { transform: translateX(260%); }
}
.wf-card-head {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  align-items: center;
  margin-bottom: var(--space-3);
}
.wf-card-head h4 { margin: 0; font-size: var(--text-sm); }
.wf-subtitle {
  margin: var(--space-2) 0 var(--space-2);
  font-size: var(--text-sm);
  font-weight: var(--font-bold);
  color: var(--color-primary);
}
.wf-actions {
  display: flex;
  gap: var(--space-2);
  flex-wrap: wrap;
  margin-top: var(--space-3);
}
.wf-actions.compact { margin-top: 0; }
.wf-actions.vertical { flex-direction: column; }
.wf-two-col {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-3);
}
.wf-four-col {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}
.wf-image-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-2);
}
.wf-img-card {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 6px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 6px;
  background: var(--color-bg);
}
.wf-img-preview {
  display: block;
  width: 100%;
  padding: 0;
  border: 0;
  background: transparent;
  border-radius: var(--radius-sm);
  cursor: zoom-in;
  overflow: hidden;
}
.wf-img-preview:focus-visible {
  outline: 2px solid var(--color-primary);
  outline-offset: 2px;
}
.wf-img-card img {
  width: 100%;
  aspect-ratio: 1 / 1;
  object-fit: cover;
  border-radius: var(--radius-sm);
  background: #fff;
  transition: transform .15s ease;
}
.wf-img-preview:hover img {
  transform: scale(1.03);
}
.wf-img-check {
  position: absolute;
  top: 8px;
  left: 8px;
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 3px 6px;
  border-radius: 999px;
  background: rgba(255,255,255,.92);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}
.wf-grade {
  position: absolute;
  top: 8px;
  right: 8px;
  padding: 3px 6px;
  border-radius: 999px;
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
  background: #e5e7eb;
  color: #374151;
}
.wf-grade.good { background: #dcfce7; color: #166534; }
.wf-grade.warn { background: #fef3c7; color: #92400e; }
.wf-grade.bad { background: #fee2e2; color: #991b1b; }
.wf-tag-select {
  min-height: 32px;
  padding: 5px 6px;
  font-size: var(--text-xs);
}
.wf-display-value {
  display: flex;
  flex-direction: column;
  justify-content: center;
  min-height: 44px;
  gap: 2px;
}
.wf-display-value strong {
  font-size: var(--text-sm);
  color: var(--color-text);
}
.wf-display-raw {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.wf-check-field .checkbox-row {
  min-height: 44px;
  align-items: center;
}
.wf-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin: calc(var(--space-2) * -1) 0 var(--space-3);
}
.wf-chip {
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
  border-radius: 999px;
  padding: 5px 10px;
  font-size: var(--text-xs);
  cursor: pointer;
}
.wf-chip:hover {
  border-color: var(--color-primary);
  color: var(--color-primary);
  background: var(--color-primary-soft);
}
.wf-option-cards {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-2);
  margin-bottom: var(--space-3);
}
.wf-option-card {
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  color: var(--color-text);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  text-align: left;
  cursor: pointer;
}
.wf-option-card strong {
  display: block;
  margin-bottom: 4px;
  font-size: var(--text-sm);
}
.wf-option-card span {
  display: block;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.wf-option-card.active {
  border-color: var(--color-primary);
  background: var(--color-primary-soft);
}
.wf-choice-list,
.wf-plan-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.wf-choice {
  border: 1px solid var(--color-border);
  background: var(--color-bg);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  text-align: left;
  cursor: pointer;
}
.wf-choice b,
.wf-choice span {
  display: block;
}
.wf-choice span {
  margin-top: 4px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.wf-choice.active {
  border-color: var(--color-primary);
  background: var(--color-primary-soft);
}
.wf-question {
  border-left: 3px solid var(--color-border);
  padding-left: var(--space-3);
  margin: var(--space-2) 0;
}
.wf-question.required { border-left-color: var(--color-danger); }
.wf-question.recommended { border-left-color: #F59E0B; }
.wf-question span {
  display: block;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.wf-question .planning-answer-text {
  margin-top: var(--space-2);
  min-height: 64px;
}
.wf-question-upload {
  display: flex;
  align-items: center;
  gap: var(--space-2);
  margin-top: var(--space-2);
  flex-wrap: wrap;
}
.wf-question-upload a,
.wf-question-upload small {
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.wf-collapsible > summary {
  cursor: pointer;
  list-style: none;
  margin-bottom: var(--space-3);
}
.wf-collapsible > summary::-webkit-details-marker {
  display: none;
}
.wf-collapsible > summary::after {
  content: "접기";
  margin-left: auto;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-weight: 700;
}
.wf-collapsible:not([open]) > summary {
  margin-bottom: 0;
}
.wf-collapsible:not([open]) > summary::after {
  content: "펼치기";
}
.wf-collapsible > summary span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.wf-truth-chat {
  border-color: rgba(37, 99, 235, 0.22);
  background: linear-gradient(180deg, rgba(239, 246, 255, 0.9), var(--color-bg));
}
.wf-chat-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
}
.wf-chat-head p {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.wf-gate {
  flex: 0 0 auto;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: var(--text-xs);
  font-weight: 700;
}
.wf-gate.ok {
  color: #047857;
  background: #D1FAE5;
}
.wf-gate.warn {
  color: #B45309;
  background: #FEF3C7;
}
.wf-chat-blockers {
  margin-top: var(--space-2);
  border: 1px solid #FCD34D;
  border-radius: var(--radius-sm);
  background: #FFFBEB;
  padding: var(--space-2);
}
.wf-chat-blockers p {
  margin: 0 0 4px;
  font-size: var(--text-xs);
  color: #92400E;
}
.wf-chat-history {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
  margin: var(--space-3) 0;
}
.wf-chat-msg {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  background: var(--color-surface);
}
.wf-chat-msg.assistant {
  border-color: rgba(37, 99, 235, 0.22);
  background: #F8FBFF;
}
.wf-chat-msg b,
.wf-chat-msg span {
  display: block;
}
.wf-chat-msg b {
  margin-bottom: 3px;
  font-size: var(--text-xs);
  color: var(--color-primary);
}
.wf-chat-msg span {
  white-space: pre-wrap;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.wf-plan-item {
  display: grid;
  grid-template-columns: 28px 1fr;
  gap: var(--space-2);
  align-items: start;
  padding: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
}
.wf-plan-item > span {
  display: grid;
  place-items: center;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  background: var(--color-primary-soft);
  color: var(--color-primary);
  font-size: var(--text-xs);
  font-weight: var(--font-bold);
}
.wf-plan-item p,
.wf-plan-item em {
  display: block;
  margin: 3px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  font-style: normal;
}
.wf-img-actions {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 4px;
}
.wf-img-actions .btn {
  min-height: 28px;
  padding: 4px 6px;
  font-size: 11px;
}
.spec-items {
  margin: var(--space-4) 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  padding: var(--space-3);
}
.spec-items-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-3);
}
.spec-items-head strong {
  display: block;
  font-size: var(--text-sm);
}
.spec-items-head p {
  margin: 3px 0 0;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
  line-height: var(--leading-normal);
}
.spec-items-list {
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.spec-item-row {
  display: grid;
  grid-template-columns: 1.05fr 1.35fr .55fr auto auto;
  gap: var(--space-2);
  align-items: center;
  padding: var(--space-2);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
}
.spec-item-row .spec-hint {
  grid-column: 1 / -1;
  min-height: 34px;
  font-size: var(--text-xs);
}
.spec-required {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  white-space: nowrap;
  font-size: var(--text-xs);
  color: var(--color-text-secondary);
}
.btn-xs {
  min-height: 30px;
  padding: 4px 8px;
  font-size: var(--text-xs);
}
.wf-result {
  margin: var(--space-3) 0;
  padding: var(--space-3);
  border-radius: var(--radius-sm);
  background: var(--color-bg);
  border: 1px solid var(--color-border);
}
.wf-result p {
  margin: 0 0 4px;
  font-size: var(--text-xs);
  color: var(--color-text-muted);
}
.wf-result strong {
  display: block;
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.wf-recommend-grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr;
  gap: var(--space-3);
  margin: var(--space-3) 0;
}
.wf-recommend-select small {
  display: block;
  margin-top: 4px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
@media (max-width: 900px) {
  .wf-two-col,
  .wf-four-col,
  .wf-recommend-grid,
  .wf-image-grid,
  .wf-option-cards,
  .spec-item-row { grid-template-columns: 1fr; }
}

@media (min-width: 901px) {
  .workflow-panel .wf-image-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}

.workflow-panel .wf-image-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
}

.home-dashboard {
  border: 1px solid var(--color-border);
  background: var(--color-surface);
  border-radius: var(--radius-md);
  padding: var(--space-4);
}

.home-dashboard-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-3);
}

.home-dashboard-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  background: #fff;
  position: relative;
}

.home-dashboard-card-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  min-height: 22px;
}

.home-dashboard-card-action {
  background: var(--color-danger, #DC2626);
  color: #fff;
  border: none;
  border-radius: 4px;
  padding: 3px 10px;
  font-size: var(--text-xs, 11px);
  cursor: pointer;
  white-space: nowrap;
  font-weight: 500;
  transition: background 0.15s ease;
}

.home-dashboard-card-action:hover {
  background: #B91C1C;
}

.home-dashboard-card-action:disabled {
  opacity: 0.5;
  cursor: wait;
}

.home-dashboard-card span,
.home-dashboard-card small {
  display: block;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.home-dashboard-card strong {
  display: block;
  margin: var(--space-1) 0;
  font-size: var(--text-xl);
}

.home-dashboard-latest {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  align-items: center;
  margin-top: var(--space-3);
}

.home-dashboard-latest strong {
  font-size: var(--text-sm);
}

.home-dashboard-latest span {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: 3px 8px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  background: #fff;
}

.wf-lock-panel {
  margin-top: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-3);
  background: #f8fafc;
}

.wf-lock-panel.has-lock {
  border-color: #22c55e;
  background: #f0fdf4;
}

.wf-lock-panel strong,
.wf-lock-panel p {
  margin: 0;
}

.wf-lock-panel p,
.wf-lock-panel li {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.wf-lock-panel ul {
  margin: var(--space-2) 0 0;
  padding-left: var(--space-4);
}

.wf-lock-warning {
  color: #b45309 !important;
}

.wf-img-card.is-canonical {
  border-color: #22c55e;
  box-shadow: 0 0 0 2px rgba(34, 197, 94, .14);
}

.spec-candidates {
  margin-top: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  background: #f8fafc;
}

.spec-candidate-list {
  display: grid;
  gap: var(--space-2);
  margin-top: var(--space-3);
}

.spec-candidate-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: var(--space-2);
  align-items: start;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  background: #fff;
}

.spec-candidate-row strong,
.spec-candidate-row em,
.spec-candidate-row small {
  display: block;
}

.spec-candidate-row em,
.spec-candidate-row small {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  font-style: normal;
}

.preflight-modal {
  width: min(1120px, 94vw);
  max-height: 92vh;
}

.preflight-body {
  overflow: auto;
}

.preflight-loading,
.preflight-score,
.preflight-panel {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
}

.preflight-loading {
  padding: var(--space-3);
  margin-bottom: var(--space-3);
  color: var(--color-text-muted);
}

.preflight-score {
  display: grid;
  grid-template-columns: 140px minmax(0, 1fr);
  gap: var(--space-4);
  align-items: center;
  padding: var(--space-4);
  margin-bottom: var(--space-4);
}

.preflight-score strong {
  display: block;
  font-size: 42px;
  line-height: 1;
}

.preflight-score span,
.preflight-score p {
  color: var(--color-text-muted);
  margin: 0;
}

.preflight-score.is-good {
  border-color: #22c55e;
  background: #f0fdf4;
}

.preflight-score.is-warn {
  border-color: #f59e0b;
  background: #fffbeb;
}

.preflight-score.is-bad {
  border-color: #ef4444;
  background: #fef2f2;
}

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

.preflight-panel {
  padding: var(--space-4);
}

.preflight-panel h4 {
  margin: 0 0 var(--space-3);
}

.preflight-panel ul {
  margin: 0;
  padding-left: var(--space-4);
}

.preflight-panel li {
  margin-bottom: var(--space-1);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
}

.preflight-kv {
  display: flex;
  justify-content: space-between;
  gap: var(--space-3);
  padding: var(--space-2) 0;
  border-bottom: 1px solid var(--color-border);
}

.preflight-pass {
  color: #15803d;
}

.preflight-warn {
  color: #b45309;
}

.preflight-action-list {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}

.preflight-log-list {
  display: grid;
  gap: var(--space-2);
}

.preflight-log {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  background: #f8fafc;
}

.preflight-log.is-error {
  border-color: #fecaca;
  background: #fef2f2;
}

.preflight-log strong,
.preflight-log span,
.preflight-log p {
  display: block;
  margin: 0;
}

.preflight-log span,
.preflight-log p {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.template-picker-modal {
  width: min(1040px, 94vw);
  max-height: 90vh;
}

.template-picker-body {
  overflow: auto;
}

.template-recommend-note {
  margin: 0 0 var(--space-3);
  color: #15803d;
  font-size: var(--text-sm);
}

.template-picker-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: var(--space-3);
}

.template-picker-card {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  padding: var(--space-3);
  background: #fff;
  display: grid;
  gap: var(--space-2);
}

.template-picker-card.recommended {
  border-color: #22c55e;
}

.template-picker-thumb {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: #f1f5f9;
}

.template-picker-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.template-picker-meta strong,
.template-picker-meta span {
  display: block;
}

.template-picker-meta span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.mixer-meta-panel {
  display: grid;
  grid-template-columns: minmax(180px, 1.2fr) minmax(140px, .8fr) minmax(160px, .9fr) auto minmax(180px, 1fr);
  gap: var(--space-3);
  align-items: end;
  padding: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  background: #f8fafc;
}

.mixer-meta-notes {
  min-width: 0;
}

.mixer-package-summary {
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  padding: var(--space-2);
  margin-bottom: var(--space-2);
  background: #fff;
}

.mixer-package-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: var(--space-2);
}

.mixer-package-grid span {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

.mixer-package-grid b {
  display: block;
  color: var(--color-text);
}

.mixer-package-summary p {
  margin: var(--space-2) 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}

@media (max-width: 980px) {
  .home-dashboard-grid,
  .preflight-grid,
  .mixer-package-grid {
    grid-template-columns: 1fr 1fr;
  }
  .mixer-meta-panel {
    grid-template-columns: 1fr 1fr;
  }
}

@media (max-width: 640px) {
  .home-dashboard-grid,
  .preflight-grid,
  .preflight-score,
  .mixer-package-grid,
  .mixer-meta-panel {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 520px) {
  .workflow-panel .wf-image-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
  }
}
.refine-action-row {
  justify-content: flex-end;
  margin-top: var(--space-2);
}

.btn-xs {
  min-height: 28px;
  padding: 4px 9px;
  font-size: 12px;
}

.wf-report {
  margin-top: var(--space-4);
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
  font-size: var(--text-xs);
}
.wf-report strong {
  display: block;
  margin-bottom: var(--space-2);
  font-size: var(--text-sm);
}
.wf-report p {
  margin: 4px 0;
  line-height: var(--leading-normal);
}
.wf-report-warn {
  margin-top: var(--space-2);
  color: #B45309;
}
.wf-report-pass {
  margin-top: var(--space-2);
  color: var(--color-success);
}
.tag-low-confidence {
  outline: 2px solid #F59E0B;
  outline-offset: 2px;
}
.wf-tag-reason {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--color-text-muted);
  line-height: 1.35;
}

.section-feedback-notes {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 0 var(--space-4) var(--space-3);
}
.section-feedback-notes span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 3px 8px;
  border-radius: var(--radius-full);
  background: #FEF3C7;
  color: #92400E;
  font-size: var(--text-xs);
  font-weight: var(--font-medium);
}
.section-quality-review {
  margin: 0 var(--space-4) var(--space-3);
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #F8FAFC;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.section-quality-review.high {
  border-color: #FCA5A5;
  background: #FEF2F2;
  color: #7F1D1D;
}
.section-quality-review.medium {
  border-color: #FCD34D;
  background: #FFFBEB;
  color: #78350F;
}
.section-quality-review.low {
  border-color: #86EFAC;
  background: #F0FDF4;
  color: #14532D;
}
.section-quality-review-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-2);
  margin-bottom: 4px;
}
.section-quality-review p {
  margin: 0;
}
.section-quality-review ul {
  margin: 6px 0 0;
  padding-left: 18px;
}
.section-quality-review li + li {
  margin-top: 3px;
}
.section-card.favorite {
  box-shadow: 0 0 0 2px #F59E0B inset, var(--shadow-sm);
}

/* 제작소 */
.workshop-modal {
  width: min(1120px, calc(100vw - 48px));
  max-height: calc(100vh - 56px);
}
.workshop-subtitle {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.workshop-tabs {
  display: flex;
  gap: var(--space-2);
  padding: 0 var(--space-5) var(--space-3);
  border-bottom: 1px solid var(--color-border);
}
.workshop-tab {
  min-height: 36px;
  padding: 0 var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: var(--color-bg-card);
  color: var(--color-text-secondary);
  font-weight: var(--font-semibold);
  cursor: pointer;
}
.workshop-tab.active {
  border-color: var(--color-primary);
  background: #EFF6FF;
  color: var(--color-primary);
}
.workshop-body {
  overflow: auto;
}
.workshop-grid {
  display: grid;
  grid-template-columns: minmax(360px, .9fr) minmax(420px, 1.1fr);
  gap: var(--space-4);
}
.workshop-panel {
  min-width: 0;
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg-card);
}
.workshop-panel h4 {
  margin: 0 0 var(--space-2);
  font-size: var(--text-lg);
}
.workshop-status {
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.workshop-mode-note {
  margin: 0 0 var(--space-3);
  padding: var(--space-3);
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-sm);
  background: #EFF6FF;
  color: var(--color-primary-dark);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.workshop-history {
  display: grid;
  gap: var(--space-3);
  margin-top: var(--space-3);
}
.workshop-card {
  display: grid;
  grid-template-columns: 128px minmax(0, 1fr);
  gap: var(--space-3);
  align-items: center;
  padding: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.workshop-card.large {
  grid-template-columns: 220px minmax(0, 1fr);
}
.workshop-card img {
  width: 100%;
  max-height: 260px;
  object-fit: contain;
  border-radius: var(--radius-sm);
  background: #F8FAFC;
  border: 1px solid var(--color-border);
}
.workshop-card strong,
.workshop-report strong {
  display: block;
  margin-bottom: 4px;
}
.workshop-card p,
.workshop-report p {
  margin: 0 0 var(--space-2);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.workshop-report {
  padding: var(--space-4);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-bg);
}
.workshop-report h5 {
  margin: var(--space-3) 0 var(--space-1);
  font-size: var(--text-sm);
}
.workshop-report ol,
.workshop-report ul {
  margin: 0;
  padding-left: 20px;
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
}
.workshop-report li + li {
  margin-top: 4px;
}

.tool-brand-recommend-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto auto;
  gap: var(--space-2);
  align-items: center;
}
/* 사장님 룰 (2026-05-06): 브랜드명 추천 버튼 색감 — brand-logo-actions 와 동일 맥락 */
.tool-brand-recommend-row > #tool-recommend-brand {
  background: linear-gradient(180deg, #6366f1 0%, #4f46e5 100%);
  color: #fff;
  border-color: #4338ca;
  font-weight: 500;
}
.tool-brand-recommend-row > #tool-recommend-brand:hover {
  background: linear-gradient(180deg, #4f46e5 0%, #4338ca 100%);
}
.tool-brand-recommend-row > #tool-reroll-brand {
  background: #f0f9ff;
  color: #0c4a6e;
  border-color: #bae6fd;
  font-weight: 500;
}
.tool-brand-recommend-row > #tool-reroll-brand:hover {
  background: #e0f2fe;
  border-color: #7dd3fc;
}
.brand-name-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.brand-name-suggestions[hidden] {
  display: none;
}
.brand-name-suggestions .suggestion-chip {
  border: 1px solid #BFDBFE;
  border-radius: 999px;
  background: #EFF6FF;
  color: var(--color-primary-dark);
  font-size: var(--text-xs);
  font-weight: 700;
  padding: 6px 10px;
}
.brand-logo-maker {
  margin-top: var(--space-3);
  padding: var(--space-3);
  border: 1px solid #D7E3FF;
  border-radius: var(--radius-md);
  background: linear-gradient(180deg, #FFFFFF 0%, #F8FAFF 100%);
}
.brand-logo-maker-head {
  /* 사장님 룰 (2026-05-06): 우측 actions 영역 좁아 버튼 잘림 → column stack.
     위 row = 제목 + 설명 (full width), 아래 row = 버튼 4개 grid (full width). */
  display: flex;
  flex-direction: column;
  gap: var(--space-2);
}
.brand-logo-maker-head strong {
  display: block;
  color: var(--color-text);
  font-size: var(--text-sm);
  margin-bottom: 2px;
}
/* 사장님 결정 (2026-05-06 → 2026-05-08 강제): 제목 바로 옆에 dropdown 딱 붙이기.
   2026-05-07 추가: 줄 오른쪽 맨끝에 직접 업로드 버튼 — width 100% + 업로드 label margin-left: auto. */
.brand-title-row {
  display: flex !important;
  flex-direction: row !important;
  align-items: center;
  gap: 8px;
  margin-bottom: 2px;
  width: 100%;
  flex-wrap: nowrap;
}
.brand-title-row .brand-upload-label {
  margin-left: auto;
  cursor: pointer;
  font-size: 12px;
  padding: 4px 10px;
  white-space: nowrap;
}
.brand-title-row > strong,
.brand-logo-maker-head .brand-title-row strong {
  display: inline-block !important;
  margin: 0 !important;
  vertical-align: baseline;
  white-space: nowrap;
}
/* 2026-07-01 브랜드 섹터 자동생성 cascade 셀렉트 (후보 패널). */
.brand-sector-autogen-row {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: var(--space-2);
  margin-top: var(--space-2);
}
.brand-sector-autogen-row > label {
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text);
}
.brand-sector-autogen-row select {
  height: 24px;
  padding: 1px 6px;
  font-size: 12px;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
}
.brand-sector-autogen-row .field-help {
  flex-basis: 100%;
  margin: 2px 0 0;
}

.brand-count-select {
  height: 22px;
  padding: 1px 4px;
  font-size: 12px;
  font-weight: 500;
  line-height: 1.2;
  border: 1px solid var(--color-border);
  border-radius: 4px;
  background: var(--color-surface);
  color: var(--color-text);
  cursor: pointer;
  vertical-align: baseline;
}
.brand-count-select:hover {
  border-color: var(--color-primary);
}
.brand-logo-actions {
  /* 사장님 룰 (2026-05-06): 1 row 4 buttons, 작은 버튼. */
  display: flex;
  flex-wrap: nowrap;
  gap: 6px;
  width: 100%;
}
.brand-logo-actions > .btn {
  flex: 1 1 0;
  min-width: 0;
  padding: 6px 8px;
  font-size: 12px;
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
/* 사장님 룰 (2026-05-06): 버튼 살짝 색감 — 메인 액션 강조 + 재추천/옛후보 부드러운 톤 */
/* 메인 액션 (첫 번째) — 인디고 강조 */
.brand-logo-actions > .btn:first-child {
  background: linear-gradient(180deg, #6366f1 0%, #4f46e5 100%);
  color: #fff;
  border-color: #4338ca;
}
.brand-logo-actions > .btn:first-child:hover {
  background: linear-gradient(180deg, #4f46e5 0%, #4338ca 100%);
}
/* 재추천 (비슷한/다른 스타일) — 연한 파란 톤 */
.brand-logo-actions > .btn:nth-child(2),
.brand-logo-actions > .btn:nth-child(3) {
  background: #f0f9ff;
  color: #0c4a6e;
  border-color: #bae6fd;
}
.brand-logo-actions > .btn:nth-child(2):hover,
.brand-logo-actions > .btn:nth-child(3):hover {
  background: #e0f2fe;
  border-color: #7dd3fc;
}
/* 옛 후보 — 연한 보라 톤 (📚 아카이브 느낌) */
.brand-logo-actions > .btn[data-act="open-brand-history"] {
  background: #faf5ff;
  color: #6b21a8;
  border-color: #e9d5ff;
}
.brand-logo-actions > .btn[data-act="open-brand-history"]:hover {
  background: #f3e8ff;
  border-color: #d8b4fe;
}
.brand-logo-selected-card {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: var(--space-3);
  align-items: center;
  margin-top: var(--space-3);
  padding: var(--space-2);
  border: 1px solid #93C5FD;
  border-radius: var(--radius-md);
  background: #EFF6FF;
}
.brand-logo-selected-card img {
  width: 82px;
  height: 56px;
  object-fit: contain;
  border-radius: var(--radius-sm);
  background: #FFFFFF;
}
.brand-logo-image-button {
  display: grid;
  place-items: center;
  padding: 0;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  cursor: zoom-in;
}
.brand-logo-selected-card strong,
.brand-logo-selected-card span {
  display: block;
}
.brand-logo-selected-card span {
  margin-top: 4px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.brand-logo-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(118px, 1fr));
  gap: var(--space-2);
  margin-top: var(--space-3);
}
.brand-logo-grid[hidden],
.brand-logo-selected[hidden] {
  display: none;
}
/* ExecPlan 026 (2026-05-05) — 현지화 결과 시각화 (사장님 보고: "누가 읽어")
 * 긴 텍스트 dump → 디폴트 접기 + 이미지 썸네일 카드 그리드 */
.report-collapse {
  margin-top: var(--space-3);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  background: #F8FAFC;
}
.report-collapse > summary {
  cursor: pointer;
  padding: 8px 12px;
  font-weight: 600;
  font-size: var(--text-sm);
  color: var(--color-text-primary);
  user-select: none;
  list-style: none;
}
.report-collapse > summary::-webkit-details-marker { display: none; }
.report-collapse > summary::before {
  content: "▶ ";
  display: inline-block;
  margin-right: 4px;
  transition: transform 0.15s;
}
.report-collapse[open] > summary::before { transform: rotate(90deg); }
.report-collapse > summary:hover { background: #F1F5F9; }
.report-collapse-hint {
  font-weight: 400;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
}
.report-collapse > * + * {  /* summary 외 자식들 */
  padding: 8px 12px 12px;
}
.report-section-cards {
  list-style: none;
  padding-left: 0 !important;
  margin: 0;
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}
.report-section-card {
  display: grid;
  grid-template-columns: 80px minmax(0, 1fr);
  gap: 10px;
  padding: 8px;
  background: #fff;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  align-items: start;
}
.report-section-thumb {
  width: 80px;
  height: 100px;
  object-fit: cover;
  object-position: top center;
  border-radius: var(--radius-sm);
  background: #F1F5F9;
  display: block;
}
.report-section-thumb-empty {
  width: 80px;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #F1F5F9;
  border-radius: var(--radius-sm);
  font-size: 24px;
  color: var(--color-text-muted);
}
.report-section-body {
  display: flex;
  flex-direction: column;
  gap: 3px;
  min-width: 0;
}
.report-section-headline {
  font-weight: 700;
  color: var(--color-text-primary);
  font-size: var(--text-sm);
}
.report-section-sub {
  color: var(--color-text-secondary);
  font-size: var(--text-xs);
}
.report-section-instruction {
  font-size: 11px;
  color: var(--color-text-muted);
  line-height: 1.4;
}

/* ExecPlan 031 (2026-05-05): 카드 영역 분리 — 이미지 (확대) + 텍스트 푸터 (선택 버튼).
 * 사장님 보고: "이미지/텍스트 클릭 의미 애매. 텍스트를 버튼처럼". */
.brand-card-wrap {
  position: relative;
  display: flex;
  flex-direction: column;
  border: 2px solid var(--color-border);
  border-radius: var(--radius-md);
  overflow: hidden;
  background: #fff;
  transition: border-color 0.18s, box-shadow 0.18s, transform 0.12s;
}
.brand-card-wrap:hover {
  border-color: var(--color-primary);
  box-shadow: 0 6px 16px rgba(37, 99, 235, 0.12);
  transform: translateY(-1px);
}
.brand-card-wrap.is-selected {
  border-color: #059669;
  box-shadow: 0 0 0 3px rgba(5, 150, 105, 0.18);
}
.brand-card-wrap.is-locked .brand-card-image {
  box-shadow: inset 0 0 0 3px #fbbf24;
}
.brand-card-image {
  position: relative;
  display: block;
  padding: 0;
  border: none;
  background: #F8FAFC;
  cursor: zoom-in;
  width: 100%;
}
.brand-card-image img {
  display: block;
  width: 100%;
  aspect-ratio: 5 / 3;
  object-fit: contain;
  background: #F8FAFC;
}
.brand-card-zoom-hint {
  position: absolute;
  top: 8px;
  right: 8px;
  background: rgba(15, 23, 42, 0.7);
  color: #fff;
  font-size: 11px;
  padding: 3px 8px;
  border-radius: 999px;
  opacity: 0;
  transition: opacity 0.15s;
  pointer-events: none;
}
.brand-card-image:hover .brand-card-zoom-hint { opacity: 1; }
.brand-card-select-btn {
  display: flex;
  flex-direction: column;
  align-items: stretch;
  gap: 2px;
  padding: 10px 12px;
  border: none;
  border-top: 1px solid var(--color-border);
  background: #f1f5f9;
  cursor: pointer;
  text-align: left;
  transition: background 0.15s;
}
.brand-card-select-btn:hover {
  background: var(--color-primary);
  color: #fff;
}
.brand-card-select-btn:hover .brand-card-style,
.brand-card-select-btn:hover .brand-card-action { color: #fff; }
.brand-card-select-btn.selected {
  background: #059669;
  color: #fff;
}
.brand-card-select-btn.selected .brand-card-style,
.brand-card-select-btn.selected .brand-card-action { color: #fff; }
.brand-card-style {
  font-weight: 700;
  font-size: var(--text-xs);
  color: var(--color-text-primary);
  letter-spacing: -0.2px;
}
.brand-card-action {
  font-size: 11px;
  color: var(--color-text-muted);
  font-weight: 600;
}

/* ExecPlan 022 — 후보 잠금 (재추천 시 보존) */
.brand-lock-bar {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 6px 10px;
  margin: var(--space-2) 0;
  background: #FEF3C7;
  border: 1px solid #FDE68A;
  border-radius: var(--radius-sm);
  font-size: var(--text-xs);
}
.brand-lock-bar[hidden] { display: none; }
.brand-lock-bar-status {
  font-weight: 600;
  color: #92400E;
}
.brand-lock-bar-buttons {
  display: flex;
  gap: 6px;
}
.brand-logo-card-wrap {
  position: relative;
}
.brand-logo-card-wrap.is-locked .brand-logo-card {
  border-color: #fbbf24;
  box-shadow: 0 0 0 2px rgba(251, 191, 36, 0.25);
}
.brand-lock-btn {
  position: absolute;
  top: 4px;
  left: 4px;
  z-index: 2;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1px solid rgba(15, 23, 42, 0.15);
  background: rgba(255, 255, 255, 0.92);
  font-size: 14px;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
}
.brand-lock-btn:hover {
  background: #fff;
  transform: scale(1.05);
}
.brand-lock-btn.locked {
  background: #fbbf24;
  border-color: #d97706;
  color: #1f2937;
}
/* 사장님 결정 (2026-05-08): 카드 우상단 ✕ 삭제 버튼 (옛 후보로 이동) */
.brand-delete-btn {
  position: absolute;
  top: 4px;
  right: 4px;
  z-index: 2;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  border: 1px solid rgba(220, 38, 38, 0.3);
  background: rgba(255, 255, 255, 0.92);
  color: #dc2626;
  font-size: 13px;
  font-weight: 700;
  line-height: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  padding: 0;
  transition: background 0.15s, border-color 0.15s, transform 0.1s;
}
.brand-delete-btn:hover {
  background: #fee2e2;
  border-color: #dc2626;
  transform: scale(1.1);
}
.brand-logo-card {
  display: grid;
  gap: 6px;
  padding: var(--space-2);
  border: 1px solid #E2E8F0;
  border-radius: var(--radius-md);
  background: #FFFFFF;
  text-align: left;
  cursor: pointer;
  transition: border-color .15s ease, box-shadow .15s ease, transform .15s ease;
}
.brand-logo-card:hover,
.brand-logo-card.selected {
  border-color: var(--color-primary);
  box-shadow: 0 10px 24px rgba(37, 99, 235, .14);
  transform: translateY(-1px);
}
.brand-logo-card img {
  width: 100%;
  aspect-ratio: 5 / 3;
  object-fit: contain;
  border-radius: var(--radius-sm);
  background: #F8FAFC;
}
.brand-logo-card span {
  color: var(--color-text);
  font-size: var(--text-xs);
  font-weight: 700;
  line-height: 1.35;
}
.brand-logo-card small {
  color: var(--color-text-muted);
  font-size: 11px;
  line-height: 1.3;
}
.brand-logo-card img {
  cursor: zoom-in;
}
.brand-logo-preview-shell {
  width: min(820px, calc(100vw - 48px));
  max-width: min(820px, calc(100vw - 48px));
  height: auto;
  max-height: calc(100vh - 64px);
  grid-template-rows: auto auto;
  background: #111827;
}
.brand-logo-preview-body {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: var(--space-3);
  justify-items: center;
  align-items: center;
  padding: var(--space-4);
  overflow: auto;
  background: #111827;
  position: relative;
}

/* 사장님 룰 (2026-05-04): 로고/섹터 미리보기 모달 양 사이드 화살표 nav */
.brand-preview-nav {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  border: 0;
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  font-size: 18px;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.12s ease;
}
.brand-preview-nav:hover:not(:disabled) {
  background: rgba(255, 255, 255, 0.32);
  transform: scale(1.08);
}
.brand-preview-nav:disabled {
  opacity: 0.3;
  cursor: not-allowed;
}
.brand-preview-counter {
  margin-left: 8px;
  padding: 2px 10px;
  font-size: 12px;
  font-weight: 600;
  color: #cbd5e1;
  background: rgba(255, 255, 255, 0.10);
  border-radius: 999px;
}
.brand-preview-reason {
  max-width: 680px;
  margin: 8px auto 12px;
  padding: 0 var(--space-4);
  color: #DBEAFE;
  text-align: center;
  font-size: var(--text-sm);
}
.brand-logo-preview-image {
  width: min(720px, 100%);
  max-height: 62vh;
  object-fit: contain;
  padding: var(--space-5);
  border-radius: var(--radius-lg);
  background: #FFFFFF;
  box-shadow: 0 18px 50px rgba(0, 0, 0, .28);
}
.brand-logo-preview-body p {
  max-width: 680px;
  margin: 0;
  color: #DBEAFE;
  text-align: center;
  font-size: var(--text-sm);
}

.localize-analysis-summary {
  margin: var(--space-3) 0;
  padding: var(--space-3);
  border: 1px solid #DBEAFE;
  border-radius: var(--radius-md);
  background: #F8FBFF;
  text-align: left;
}
.localize-analysis-summary summary {
  color: var(--color-primary-dark);
  font-size: var(--text-sm);
  font-weight: 800;
  cursor: pointer;
}
.localize-analysis-summary ol {
  margin: var(--space-3) 0 0;
  padding-left: 20px;
}
.localize-analysis-summary li + li {
  margin-top: var(--space-2);
}
.localize-analysis-summary span,
.localize-analysis-summary small {
  display: block;
  margin-top: 3px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.4;
}

.source-stage-panel {
  display: grid;
  gap: var(--space-3);
  padding: var(--space-4);
  border: 1px solid #BFDBFE;
  border-radius: var(--radius-lg);
  background: #F8FBFF;
}
.source-stage-panel[hidden] {
  display: none;
}
.source-stage-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
}
.source-stage-head strong,
.source-stage-group-head strong {
  display: block;
  color: var(--color-text);
  font-size: var(--text-base);
  line-height: 1.35;
}
.source-stage-head span,
.source-stage-group-head span,
.source-stage-summary {
  display: block;
  margin-top: 4px;
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: 1.5;
}
.source-stage-summary {
  padding: 10px 12px;
  border-radius: var(--radius-md);
  background: #EEF2FF;
  color: #3730A3;
  font-weight: 700;
}
.source-stage-group {
  display: grid;
  gap: var(--space-2);
}
.source-stage-group-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-3);
  padding-top: var(--space-2);
  border-top: 1px solid #DBEAFE;
}
.source-stage-strip {
  display: flex;
  gap: var(--space-2);
  overflow-x: auto;
  padding: 2px 0 4px;
  scrollbar-gutter: stable;
}
.source-stage-mini,
.source-stage-more {
  position: relative;
  flex: 0 0 86px;
  width: 86px;
  height: 112px;
  overflow: hidden;
  border: 1px solid #DBEAFE;
  border-radius: var(--radius-md);
  background:
    linear-gradient(45deg, rgba(148, 163, 184, .16) 25%, transparent 25% 75%, rgba(148, 163, 184, .16) 75%) 0 0 / 14px 14px,
    linear-gradient(45deg, rgba(148, 163, 184, .16) 25%, transparent 25% 75%, rgba(148, 163, 184, .16) 75%) 7px 7px / 14px 14px,
    #F8FAFC;
}
.source-stage-mini img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.source-stage-mini b {
  position: absolute;
  left: 5px;
  top: 5px;
  min-width: 24px;
  padding: 2px 6px;
  border-radius: 999px;
  background: rgba(37, 99, 235, .94);
  color: #fff;
  font-size: 10px;
  line-height: 1.4;
}
.source-stage-mini.is-disabled {
  opacity: .45;
}
.source-stage-more {
  height: 112px;
  display: grid;
  place-items: center;
  color: var(--color-primary);
  font-size: var(--text-sm);
  font-weight: 800;
}
.source-stage-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-3);
}
.source-stage-card {
  min-width: 0;
  padding: var(--space-2);
  border: 1px solid #D7E3F8;
  border-radius: var(--radius-md);
  background: #FFFFFF;
  box-shadow: 0 8px 18px rgba(15, 23, 42, 0.06);
}
.source-stage-image-wrap {
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-sm);
  background: #EEF2F7;
  aspect-ratio: 1 / 1;
}
.source-stage-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: contain;
  display: block;
}
.source-stage-image-wrap span {
  position: absolute;
  left: 6px;
  top: 6px;
  min-width: 28px;
  padding: 3px 7px;
  border-radius: 999px;
  background: rgba(37, 99, 235, 0.94);
  color: #FFFFFF;
  font-size: 11px;
  font-weight: 800;
  text-align: center;
}
.source-stage-actions {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-top: var(--space-2);
}
/* 사장님 결정 (2026-05-07): 최종 생성 버튼을 분석 panel 맨 하단으로 이동 — 흐름 직관 */
.tool-action-row-final {
  margin-top: var(--space-3);
  padding-top: var(--space-3);
  border-top: 1px solid var(--color-border);
}
/* 사장님 결정 (2026-05-08): [원본 구조 유지] vs [한국형 상세페이지] 두 모드 버튼 */
.tool-action-row-final-dual {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.tool-action-row-final-dual #tool-generate-final {
  flex: 1 1 280px;
  min-width: 240px;
  white-space: nowrap;
}
/* 사장님 결정 (2026-05-08): 분석 결과 헤더 행 — h3 좌측 + 초기화 버튼 우측 */
.tool-result-header-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-3);
  margin-bottom: var(--space-2);
}
.tool-result-header-row h3 {
  margin: 0;
}
.tool-analysis-clear-btn {
  white-space: nowrap;
  flex-shrink: 0;
  margin-right: 48px; /* 사장님 결정 (2026-05-08): 우측 접기 버튼과 간격 확보 */
}
/* 사장님 결정 (2026-05-07): step indicator — 단계 시각. 재활용 X 직관 ↑ */
.tool-step-indicator {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  padding: 8px 12px;
  margin-bottom: var(--space-2);
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
}
.tool-step {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 4px 10px;
  border-radius: 6px;
  transition: background 0.15s, color 0.15s;
}
.tool-step-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  font-size: 12px;
  font-weight: 700;
  background: #e2e8f0;
  color: #94a3b8;
  flex-shrink: 0;
}
.tool-step-label {
  font-size: 12px;
  font-weight: 600;
  color: #94a3b8;
  white-space: nowrap;
}
.tool-step[data-state="active"] {
  background: #dbeafe;
}
.tool-step[data-state="active"] .tool-step-num {
  background: #2563eb;
  color: #fff;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.2);
}
.tool-step[data-state="active"] .tool-step-label {
  color: #1e40af;
}
.tool-step[data-state="done"] .tool-step-num {
  background: #10b981;
  color: #fff;
  font-size: 0;
  position: relative;
}
.tool-step[data-state="done"] .tool-step-num::before {
  content: "✓";
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 14px;
  font-weight: 700;
  color: #fff;
}
.tool-step[data-state="done"] .tool-step-label {
  color: #047857;
}
.tool-step-arrow {
  color: #cbd5e1;
  font-size: 14px;
  flex-shrink: 0;
}
.source-stage-card p {
  margin: 8px 0 0;
  color: var(--color-text-muted);
  font-size: 11px;
  line-height: 1.35;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.source-stage-modal-overlay {
  position: fixed;
  inset: 0;
  z-index: 9970;
  display: grid;
  place-items: center;
  padding: 6px;
  /* 2026-06-14 사장님: 확대 모달에서 뒤 위치/내용 보면서 읽으려고 함 → 블러 제거 + 더 투명 */
  background: rgba(15, 23, 42, .38);
}
.source-stage-modal-shell {
  width: min(1480px, calc(100vw - 12px));
  height: calc(100vh - 12px);
  display: grid;
  grid-template-rows: auto minmax(0, 1fr);
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: #fff;
  box-shadow: 0 28px 90px rgba(15, 23, 42, .36);
}
.source-stage-modal-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--color-border);
}
.source-stage-modal-head strong {
  display: block;
  color: var(--color-text);
  font-size: var(--text-lg);
  line-height: 1.35;
}
.source-stage-modal-head p {
  margin: 4px 0 0;
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  line-height: var(--leading-normal);
}
.source-stage-modal-actions {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: var(--space-2);
}
.source-stage-modal-layout {
  min-height: 0;
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
}
.source-stage-modal-toc {
  min-height: 0;
  overflow-y: auto;
  padding: var(--space-3);
  border-right: 1px solid var(--color-border);
  background: #F8FAFC;
}
.source-stage-modal-toc button {
  width: 100%;
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: var(--space-2);
  align-items: center;
  min-height: 42px;
  padding: 6px 8px;
  border: 0;
  border-radius: var(--radius-sm);
  background: transparent;
  color: var(--color-text);
  text-align: left;
  cursor: pointer;
}
.source-stage-modal-toc button:hover {
  background: #E0E7FF;
}
.source-stage-modal-toc b {
  display: inline-flex;
  justify-content: center;
  color: var(--color-primary);
  font-size: var(--text-xs);
}
.source-stage-modal-toc span {
  min-width: 0;
  overflow: hidden;
  color: var(--color-text-muted);
  font-size: 11px;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.source-stage-modal-stream {
  min-height: 0;
  overflow: auto;
  display: block;
  padding: 28px;
  background: #E5E7EB;
  --stage-zoom: 1;
}
.source-stage-zoom-hint {
  position: sticky;
  top: 0;
  z-index: 8;
  width: max-content;
  margin: 0 auto 16px;
  padding: 8px 12px;
  border: 1px solid rgba(15, 23, 42, .1);
  border-radius: 999px;
  background: rgba(255, 255, 255, .92);
  color: #334155;
  font-size: var(--text-xs);
  font-weight: 900;
  box-shadow: 0 8px 24px rgba(15, 23, 42, .12);
  backdrop-filter: blur(8px);
}
.source-stage-page {
  /* 사장님 결정 (2026-05-07): 1장 이어보기처럼 — 카드 간격 0 + shadow 제거 */
  position: relative;
  width: clamp(360px, calc(780px * var(--stage-zoom, 1)), 1720px);
  margin: 0 auto;
  border: 0;
  border-radius: 0;
  background: #FFFFFF;
  overflow: visible;
  box-shadow: none;
}
.source-stage-page.is-disabled {
  opacity: .42;
}
.source-stage-page-number {
  position: absolute;
  top: 12px;
  left: 12px;
  z-index: 5;
  min-width: 42px;
  height: 32px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: rgba(249, 115, 22, .94);
  color: #fff;
  font-size: var(--text-xs);
  font-weight: 900;
  box-shadow: 0 8px 20px rgba(15, 23, 42, .18);
}
.source-stage-page-delete {
  position: absolute;
  top: 10px;
  right: 10px;
  z-index: 6;
  width: 46px;
  height: 46px;
  display: grid;
  place-items: center;
  border: 0;
  border-radius: 999px;
  background: rgba(239, 68, 68, .96);
  color: #FFFFFF;
  font-size: 34px;
  font-weight: 900;
  line-height: 1;
  cursor: pointer;
  box-shadow: 0 10px 24px rgba(127, 29, 29, .28);
}
.source-stage-page-delete:hover {
  background: #DC2626;
  transform: translateY(-1px);
}
.source-stage-page-url {
  margin: 0;
  padding: 10px 12px;
  border-top: 1px solid #E2E8F0;
  color: var(--color-text-muted);
  font-size: 11px;
  line-height: 1.35;
  overflow-wrap: anywhere;
}
.source-stage-modal-card {
  min-width: 0;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: #fff;
  overflow: hidden;
  box-shadow: var(--shadow-sm);
}
.source-stage-modal-card-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: var(--space-3);
  padding: var(--space-3);
  border-bottom: 1px solid var(--color-border);
  background: #F8FAFC;
}
.source-stage-modal-card-head strong {
  min-width: 38px;
  height: 30px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  background: #F97316;
  color: #fff;
  font-size: var(--text-xs);
}
.source-stage-modal-card-head div {
  display: flex;
  flex-wrap: wrap;
  gap: var(--space-2);
}
.source-stage-modal-image-frame {
  /* 사장님 결정 (2026-05-07): min-height 제거 — 이미지 자연 height 따름. 흰 여백 X */
  position: relative;
  display: block;
  overflow: visible;
  background: #FFFFFF;
}
.source-stage-modal-image-frame img {
  display: block;
  width: 100%;
  height: auto;
}
/* 옛 min-height 룰 폐기 — 이미지 자연 크기 박힘 */
.source-stage-modal-card.is-loading .source-stage-modal-image-frame::before,
.source-stage-modal-card.is-error .source-stage-modal-image-frame::before,
.source-stage-page.is-loading .source-stage-modal-image-frame::before,
.source-stage-page.is-error .source-stage-modal-image-frame::before {
  content: "이미지 불러오는 중";
  position: absolute;
  inset: 0;
  z-index: 1;
  display: grid;
  place-items: center;
  padding: var(--space-4);
  color: var(--color-text-muted);
  font-size: var(--text-sm);
  font-weight: 800;
  text-align: center;
  background: rgba(248, 250, 252, .86);
}
.source-stage-modal-card.is-error .source-stage-modal-image-frame::before {
  content: "이미지를 불러오지 못했습니다. URL을 확인하거나 제작을 실행해 서버 다운로드 결과를 확인하세요.";
}
.source-stage-page.is-error .source-stage-modal-image-frame::before {
  content: "이미지를 불러오지 못했습니다. URL을 확인하거나 제작을 실행해 서버 다운로드 결과를 확인하세요.";
}
.source-stage-modal-image-frame img {
  width: 100%;
  height: auto;
  max-height: none;
  object-fit: contain;
  display: block;
  margin: 0 auto;
}
.source-stage-modal-card > img {
  width: min(100%, 780px);
  min-height: 420px;
  height: auto;
  max-height: none;
  object-fit: contain;
  display: block;
  margin: 0 auto;
  background:
    linear-gradient(45deg, rgba(148, 163, 184, .13) 25%, transparent 25% 75%, rgba(148, 163, 184, .13) 75%) 0 0 / 18px 18px,
    linear-gradient(45deg, rgba(148, 163, 184, .13) 25%, transparent 25% 75%, rgba(148, 163, 184, .13) 75%) 9px 9px / 18px 18px,
    #F1F5F9;
}
.source-stage-modal-card.is-error .source-stage-modal-image-frame img {
  display: none;
}
.source-stage-page.is-error .source-stage-modal-image-frame img {
  display: none;
}
.source-stage-modal-card p {
  margin: 0;
  padding: var(--space-3);
  color: var(--color-text-muted);
  font-size: var(--text-xs);
  line-height: var(--leading-normal);
  overflow-wrap: anywhere;
}
.source-stage-modal-empty {
  margin: 0;
  padding: var(--space-6);
  border: 1px dashed var(--color-border);
  border-radius: var(--radius-md);
  background: #F8FAFC;
}

/* 사장님 룰 (2026-05-04 새벽): 작업 위젯을 *우측 상단* 으로 — 풀스크린 모달 X.
   사장님 명시: "이거 모달 우측 상단으로 좀 옮겨주라. 동일한 모달은 전부다" */
.global-work-overlay {
  /* 사장님 룰 2026-05-04: 우측 상단 토스트 위치 (우측 하단 X) — !important 로 다른 룰 덮어쓰기 방어 */
  position: fixed !important;
  top: 16px !important;
  right: 16px !important;
  bottom: auto !important;
  left: auto !important;
  inset: auto !important;
  z-index: 9990;
  display: block;
  padding: 0;
  pointer-events: none; /* 백드롭 X — 카드만 클릭 가능 */
}

/* 사장님 룰 (2026-05-06): dot 을 kicker 안 inline-flex ::before 로 — 텍스트 baseline 정렬.
   기존 absolute (card::before) → kicker 안 inline. 사장님 보고 "줄이 안 맞아 거슬림" fix. */
.global-work-card::before { display: none !important; }  /* 기존 absolute dot 비활성 */
.global-work-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding-left: 0;
}
.global-work-kicker::before {
  content: "";
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #2563eb;
  box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.18);
  flex-shrink: 0;
}
.global-work-overlay.is-done .global-work-kicker::before {
  background: #16a34a;
  box-shadow: 0 0 0 3px rgba(22, 163, 74, 0.22);
}
.global-work-overlay.is-error .global-work-kicker::before {
  background: #dc2626;
  box-shadow: 0 0 0 3px rgba(220, 38, 38, 0.22);
}
.global-work-overlay.is-done .global-work-card {
  border-color: rgba(22, 163, 74, 0.45);
  background: rgba(240, 253, 244, 0.98);
}
.global-work-overlay.is-done .global-work-message {
  color: #15803d;
  font-weight: 700;
}
.global-work-overlay.is-done .global-work-detail::after {
  content: " · 페이지 이동 OK";
  color: #16a34a;
  font-weight: 700;
}
.global-work-overlay.is-error .global-work-card {
  border-color: rgba(220, 38, 38, 0.5);
  background: rgba(254, 242, 242, 0.98);
}
.global-work-overlay.is-error .global-work-message {
  color: #b91c1c;
  font-weight: 700;
}
/* @keyframes global-work-dot-pulse 제거 — 사장님 룰 (2026-05-04): 깜빡임 X */
.global-work-overlay[hidden] {
  display: none;
}
.global-work-backdrop {
  display: none; /* 우측 상단 토스트 모드 — 백드롭 없음 */
}
/* 비상 탈출구 — 위젯 우상단 X 버튼 (사장님 hang 고질병 안전망)
 * 2026-05-06 v3: pointer-events / z-index 강제 — overlay 의 pointer-events:none 우회 보장. */
.global-work-close {
  position: absolute;
  top: 8px;
  right: 8px;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: none;
  background: rgba(15, 23, 42, 0.08);
  color: var(--color-text-muted);
  font-size: 14px;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  z-index: 9999 !important;
  pointer-events: auto !important;
  transition: background 0.15s, color 0.15s;
}
.global-work-close:hover {
  background: rgba(239, 68, 68, 0.15);
  color: var(--color-danger);
}
/* cycle 63 = 사장님 작업 중지 버튼 (= ✕ 닫기 옆 별도) */
.global-work-stop {
  display: block;
  width: 100%;
  margin-top: 12px;
  padding: 10px 14px;
  border: 1px solid rgba(239, 68, 68, 0.4);
  border-radius: 10px;
  background: rgba(239, 68, 68, 0.08);
  color: var(--color-danger, #DC2626);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s ease, transform 0.05s ease;
}
.global-work-stop:hover {
  background: rgba(239, 68, 68, 0.18);
  border-color: rgba(239, 68, 68, 0.6);
}
.global-work-stop:active {
  transform: scale(0.98);
}
.global-work-card {
  position: relative;
  width: min(360px, calc(100vw - 32px));
  max-height: calc(100vh - 32px);
  overflow-y: auto;
  pointer-events: auto;
  border: 1px solid rgba(255, 255, 255, 0.22);
  border-radius: 16px;
  background: rgba(255, 255, 255, 0.96);
  box-shadow: 0 24px 80px rgba(15, 23, 42, 0.34);
  padding: 28px;
  text-align: center;
}
/* 사장님 룰 (2026-05-04): 메시지 길이 따라 카드 높이 변동 → 시선 피로 fix.
   각 영역 min-height 고정 + 카드 전체 min-height. 1줄/2줄/3줄 변경되어도 떨림 X. */
.global-work-card {
  min-height: 280px;
  /* 미세 깜빡임 방지 — 카드 안 모든 transition/animation 제거 + layout 격리 */
  contain: layout style;
  will-change: contents;
}
.global-work-card,
.global-work-card * {
  transition: none !important;
  animation: none !important;
}
/* fade transition 제거됨 (사장님 거슬림 보고) — 정적 텍스트, dedup 으로 paint 최소화 */
.global-work-title  { min-height: 1.4em; margin: 0; }
.global-work-message { min-height: 2.6em; line-height: 1.4; margin: 8px 0; }
.global-work-detail  { min-height: 2.6em; line-height: 1.4; margin: 4px 0 12px; font-size: 12px; color: var(--color-text-muted); }
.global-work-progress-line { min-height: 1.4em; }
.global-work-timebox { min-height: 2.4em; }
@media (max-width: 900px) {
  .workshop-grid {
    grid-template-columns: 1fr;
  }
  .workshop-tabs {
    flex-wrap: wrap;
  }
  .source-stage-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .source-stage-head {
    flex-direction: column;
  }
  .source-stage-group-head,
  .source-stage-modal-head {
    flex-direction: column;
  }
  .source-stage-modal-layout {
    grid-template-columns: 1fr;
  }
  .source-stage-modal-toc {
    display: flex;
    gap: var(--space-2);
    overflow-x: auto;
    overflow-y: hidden;
    border-right: 0;
    border-bottom: 1px solid var(--color-border);
  }
  .source-stage-modal-toc button {
    flex: 0 0 160px;
  }
}

/* ── safe-split-modal-v2 v3 (Adobe Contextual Task Bar 패턴, 2026-05-23) ───── */
.ss2-toolbar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: #f8fafc;
  border-bottom: 1px solid #e2e8f0;
  font-size: 13px;
  flex-wrap: wrap;
  position: relative;
  z-index: 20;
}
.ss2-toolbar.ss2-toolbar--cut { background: #ecfdf5; border-bottom-color: #10B981; }
.ss2-toolbar button:disabled { opacity: 0.45; cursor: not-allowed; }
.ss2-tb-selection-info {
  font-weight: 600;
  color: #2563EB;
  padding: 4px 10px;
  background: #eff6ff;
  border-radius: 4px;
  min-width: 110px;
}
.ss2-tb-sep { display: inline-block; width: 1px; height: 20px; background: #cbd5e1; margin: 0 4px; }
.ss2-tb-zoom-level { display: inline-block; min-width: 44px; text-align: center; font-weight: 600; }
.ss2-hint {
  background: #fef3c7;
  color: #7c2d12;
  padding: 8px 14px;
  font-size: 12px;
  line-height: 1.55;
  border-bottom: 1px solid #fed7aa;
}
.ss2-scroll {
  width: 100%;
  height: 70vh;
  overflow: hidden;
  background: #f1f5f9;
  position: relative;
  cursor: grab;
}
.ss2-scroll--panning { cursor: grabbing; user-select: none; }
.ss2-zoom-wrap {
  transform-origin: 50% 0;
  transition: transform 80ms linear;
  padding: 16px;
}
.ss2-strip {
  --ss2-inv-scale: 2;
  display: flex; flex-direction: column;
}
.ss2-piece {
  position: relative;
  margin-bottom: 4px;
  border: 2px solid transparent;
  border-radius: 6px;
  overflow: visible;
  background: #fff;
  cursor: pointer;
}
/* 2026-07-04 사장님: 모달2 본문 섹션 = 드래그 순서변경 = 손모양(grab). 자르기 모드면 crosshair. */
.mp-shell-piece { cursor: grab; }
.mp-shell-piece:active { cursor: grabbing; }
.ss2-strip--cut .mp-shell-piece { cursor: crosshair; }
.ss2-piece--even { background: #fafafa; }
.ss2-piece--odd { background: #ffffff; }
.ss2-piece--merged { box-shadow: inset 0 0 0 1px #10B981; }
.ss2-piece--selected { border-color: #2563EB; box-shadow: 0 0 0 3px rgba(37, 99, 235, 0.35); }
.ss2-piece-tag {
  position: absolute;
  top: 4px; left: 4px;
  /* 사장님 2026-06-15: 어두운 남색 = 잘 안 보임 → 주황(눈에 확 띔). warn 은 amber 라 구분 유지. */
  background: rgba(234, 88, 12, 0.95);
  color: white;
  /* 사장님 2026-06-17: 기본 크기 너무 작음 → 약 3배 (11→30px, padding/radius 비례). counter-scale 없음 = 일정. */
  padding: 11px 20px;
  border-radius: 8px;
  font-size: 30px;
  font-weight: 700;
  z-index: 5;
  /* 사장님 2026-06-17: counter-scale(scale(1/z)) 가 스티커를 거꾸로 작아지게/커지게 만듦(스티커는
     줌 transform 에 의도대로 딸려가지 않는 위치) → transform 제거 = 자연 크기 그대로 = zoom 무관 일정. */
  pointer-events: none;
  white-space: nowrap;
}
.ss2-piece-img-wrap { position: relative; overflow: hidden; }
.ss2-piece-img-wrap img { display: block; width: 100%; height: auto; user-select: none; pointer-events: none; }
.ss2-strip--cut .ss2-piece-img-wrap { cursor: crosshair; }
.ss2-cut-overlay { position: absolute; inset: 0; pointer-events: auto; }
/* 2026-05-23 사장님 catch: 점선 색상 = 빨강(자르기 의도) 통일 + controls 가운데 정렬 */
/* 2026-05-24 (2 agent 전수조사 결론): height 0 + border-top 패턴 → height 28 박스 + child visual line.
   merged-preview-modal .merged-crop-line 검증 패턴 1:1 reuse. controls 의 height 0 quirk 회피.
   실제 HTML 구조 (safe-split-modal-v2.js 안 inline style) = 부모 28px 박스 + child div border-top + child controls. */
.safe-split-v2-modal .ss2-cut-line {
  cursor: ns-resize;
  pointer-events: auto;
}
.safe-split-v2-modal .ss2-cut-line--selected [data-line-visual] {
  border-top-color: #2563EB !important;
  border-top-style: solid !important;
}
/* 2026-05-23 사장님 catch: controls 우측 끝 → 가운데 정렬 (시각 일관성) */
.safe-split-v2-modal .ss2-cut-line-controls {
  position: absolute;
  top: -16px;
  left: 50%;
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transform: translateX(-50%) scale(var(--ss2-inv-scale));
  transform-origin: top center;
  background: rgba(255,255,255,0.96);
  padding: 3px 6px;
  border-radius: 4px;
  border: 1px solid #cbd5e1;
  box-shadow: 0 1px 4px rgba(0,0,0,0.12);
  white-space: nowrap;
  z-index: 6;
}
.safe-split-v2-modal .ss2-cut-line-label { font-size: 10px; color: #475569; padding: 0 4px; font-weight: 700; }
.safe-split-v2-modal .ss2-cut-line-apply {
  border: none; width: 20px; height: 20px;
  border-radius: 4px; background: #2563EB; color: white;
  cursor: pointer; font-size: 11px;
}
.safe-split-v2-modal .ss2-cut-line-apply:hover { background: #1d4ed8; }
.safe-split-v2-modal .ss2-cut-line-remove {
  border: none; width: 20px; height: 20px;
  border-radius: 4px; background: #ef4444; color: white;
  cursor: pointer; font-size: 11px;
}
.safe-split-v2-modal .ss2-cut-line-remove:hover { background: #dc2626; }
/* 사장님 2026-06-15: 휴지통 = 왼쪽 세로 사이드패널 고정(항상 표시). 내부 스크롤. */
.ss2-trash {
  grid-area: trash;
  padding: 12px;
  background: #fef2f2;
  border-right: 1px solid #fecaca;
  box-sizing: border-box;
  overflow-y: auto;
}
.ss2-trash-head { display: flex; flex-direction: column; gap: 6px; margin-bottom: 10px; }
.ss2-trash-head h4 { margin: 0; font-size: 13px; color: #7f1d1d; }
.ss2-trash-restore-all { width: 100%; font-size: 11px; }
.ss2-trash h4 { font-size: 13px; color: #7f1d1d; }

/* ── 메인 랜딩(허브) — Claude Designer 디자인 (2026-06-17 사장님 채택) ──
   모든 스타일 .main-landing 아래로 스코프. 토큰은 블록 내부 --c-* 로 자족. */
.main-landing {
  --c-primary: #2563EB;
  --c-primary-hover: #1D4ED8;
  --c-primary-light: #DBEAFE;
  --c-accent: #F59E0B;
  --c-bg: #F8FAFC;
  --c-card: #FFFFFF;
  --c-border: #E2E8F0;
  --c-text: #0F172A;
  --c-text-sub: #475569;
  --c-text-faint: #94A3B8;
  --c-success: #10B981;
  --c-danger: #EF4444;
  --r-md: 12px;
  --r-lg: 16px;
  --r-xl: 20px;
  --shadow-card: 0 1px 2px rgba(15,23,42,.04), 0 1px 3px rgba(15,23,42,.06);
  --shadow-hover: 0 12px 28px rgba(15,23,42,.10), 0 4px 8px rgba(15,23,42,.05);
  --shadow-primary: 0 14px 32px rgba(37,99,235,.18), 0 4px 10px rgba(37,99,235,.10);
  --ease: cubic-bezier(.22,.61,.36,1);
  box-sizing: border-box;
  min-height: 100%;
  padding: clamp(40px, 8vh, 96px) 24px 80px;
  background: var(--c-bg);
  font-family: "Pretendard", -apple-system, BlinkMacSystemFont, "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  color: var(--c-text);
  -webkit-font-smoothing: antialiased;
}
.main-landing *,
.main-landing *::before,
.main-landing *::after { box-sizing: border-box; }
.ml-shell { width: 100%; max-width: 940px; margin: 0 auto; }
.ml-head { text-align: center; margin-bottom: 40px; }
.ml-eyebrow {
  display: inline-block; margin-bottom: 14px; padding: 5px 12px; border-radius: 999px;
  background: var(--c-primary-light); color: var(--c-primary-hover);
  font-size: 12px; font-weight: 700; letter-spacing: .01em;
}
.ml-title { margin: 0; font-size: clamp(26px, 4vw, 34px); font-weight: 800; letter-spacing: -0.02em; color: var(--c-text); }
.ml-subtitle { margin: 10px 0 0; font-size: 15px; color: var(--c-text-sub); line-height: 1.6; }
.ml-mode-grid { display: grid; grid-template-columns: 1.1fr 1fr 1fr; gap: 20px; margin-bottom: 40px; }
.ml-mode-card {
  position: relative; display: flex; flex-direction: column; padding: 30px; min-height: 224px;
  border: 1.5px solid var(--c-border); border-radius: var(--r-xl); background: var(--c-card);
  box-shadow: var(--shadow-card); cursor: pointer; text-align: left;
  transition: transform .22s var(--ease), box-shadow .22s var(--ease), border-color .22s var(--ease);
}
.ml-mode-card:hover { transform: translateY(-3px); box-shadow: var(--shadow-hover); border-color: #CBD5E1; }
.ml-mode-card:focus-visible { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 4px var(--c-primary-light); }
.ml-mode-card.is-primary {
  border-color: rgba(37,99,235,.35);
  background: radial-gradient(120% 120% at 0% 0%, rgba(37,99,235,.07) 0%, rgba(37,99,235,0) 46%), var(--c-card);
}
.ml-mode-card.is-primary:hover { border-color: var(--c-primary); box-shadow: var(--shadow-primary); }
.ml-mode-badge {
  position: absolute; top: 22px; right: 22px; padding: 4px 11px; border-radius: 999px;
  background: var(--c-primary); color: #fff; font-size: 11px; font-weight: 800; letter-spacing: .02em;
}
.ml-mode-icon {
  display: grid; place-items: center; width: 54px; height: 54px; margin-bottom: 20px;
  border-radius: 14px; background: #F1F5F9; color: var(--c-text-sub);
}
.ml-mode-card.is-primary .ml-mode-icon { background: var(--c-primary); color: #fff; box-shadow: 0 8px 18px rgba(37,99,235,.30); }
.ml-mode-icon svg { width: 28px; height: 28px; }
.ml-mode-name { margin: 0 0 8px; font-size: 20px; font-weight: 800; letter-spacing: -0.01em; color: var(--c-text); }
.ml-mode-desc { margin: 0; font-size: 14px; line-height: 1.6; color: var(--c-text-sub); }
.ml-mode-foot {
  display: inline-flex; align-items: center; gap: 6px; margin-top: auto; padding-top: 22px;
  font-size: 13.5px; font-weight: 700; color: var(--c-text-faint);
  transition: color .2s var(--ease), gap .2s var(--ease);
}
.ml-mode-card.is-primary .ml-mode-foot { color: var(--c-primary); }
.ml-mode-foot svg { width: 16px; height: 16px; transition: transform .2s var(--ease); }
.ml-mode-card:hover .ml-mode-foot { gap: 10px; color: var(--c-primary); }
.ml-mode-card:hover .ml-mode-foot svg { transform: translateX(2px); }
.ml-tools-head { display: flex; align-items: center; gap: 14px; margin-bottom: 18px; }
.ml-tools-label { font-size: 13px; font-weight: 800; letter-spacing: .02em; color: var(--c-text-faint); white-space: nowrap; }
.ml-tools-rule { flex: 1; height: 1px; background: var(--c-border); }
.ml-tool-grid { display: grid; grid-template-columns: repeat(6, minmax(0, 1fr)); gap: 12px; }
.ml-tool-card {
  display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 20px 10px;
  border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-card);
  box-shadow: var(--shadow-card); cursor: pointer;
  transition: transform .18s var(--ease), box-shadow .18s var(--ease), border-color .18s var(--ease);
}
.ml-tool-card:hover { transform: translateY(-2px); border-color: var(--c-primary); box-shadow: var(--shadow-hover); }
.ml-tool-card:focus-visible { outline: none; border-color: var(--c-primary); box-shadow: 0 0 0 3px var(--c-primary-light); }
.ml-tool-icon {
  display: grid; place-items: center; width: 40px; height: 40px; border-radius: 10px;
  background: #F1F5F9; color: var(--c-text-sub);
  transition: background .18s var(--ease), color .18s var(--ease);
}
.ml-tool-icon svg { width: 22px; height: 22px; }
.ml-tool-card:hover .ml-tool-icon { background: var(--c-primary-light); color: var(--c-primary-hover); }
.ml-tool-card[data-tool="trash"]:hover { border-color: var(--c-danger); }
.ml-tool-card[data-tool="trash"]:hover .ml-tool-icon { background: #FEE2E2; color: var(--c-danger); }
.ml-tool-label { font-size: 13px; font-weight: 600; color: var(--c-text); text-align: center; line-height: 1.3; }
@media (max-width: 820px) {
  .ml-mode-grid { grid-template-columns: 1fr; }
  .ml-tool-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); }
}
@media (max-width: 460px) { .ml-tool-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* 2026-07-04 사장님: 메인 AI 호출 예상 비용 대시보드 (이번달/올해/전체 × 모델별) */
.ml-cost-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; margin-top: 4px; }
.ml-cost-card {
  border: 1px solid var(--c-border); border-radius: var(--r-md); background: var(--c-card);
  box-shadow: var(--shadow-card); padding: 16px 16px 12px;
}
.ml-cost-card[data-period="month"] { border-color: #fbbf24; background: linear-gradient(180deg, #fffbeb, var(--c-card)); }
.mlc-label { font-size: 12px; font-weight: 700; color: var(--c-text-sub); }
.mlc-total { font-size: 24px; font-weight: 800; color: #b45309; margin: 2px 0 8px; letter-spacing: -0.02em; }
.ml-cost-card[data-period="year"] .mlc-total,
.ml-cost-card[data-period="all"] .mlc-total { color: var(--c-text); }
.mlc-models { border-top: 1px dashed var(--c-border); padding-top: 8px; display: flex; flex-direction: column; gap: 3px; }
.mlc-mrow { display: flex; justify-content: space-between; font-size: 12px; color: var(--c-text-sub); gap: 8px; }
.mlc-mrow span:first-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.mlc-mrow span:last-child { font-weight: 600; white-space: nowrap; }
.mlc-empty { color: var(--c-text-faint); font-style: italic; }
.ml-cost-note { font-size: 11px; color: var(--c-text-faint); margin-top: 10px; line-height: 1.5; }
.ml-cost-note b { color: #b45309; }
@media (max-width: 820px) { .ml-cost-grid { grid-template-columns: 1fr; } }
.ss2-trash-empty { font-size: 11px; color: #b91c1c; opacity: 0.55; text-align: center; padding: 14px 4px; line-height: 1.6; }
/* 사이드패널 = 세로 카드, 복원 버튼은 full-width 라 절대 안 잘림(잘림 반복 문제 종결). */
.ss2-trash-item {
  display: flex; flex-direction: column; align-items: stretch; gap: 6px;
  margin: 0 0 8px; padding: 8px;
  background: #fff; border: 1px solid #fecaca; border-radius: 6px;
}
.ss2-trash-item img { max-width: 100%; max-height: 72px; object-fit: contain; border-radius: 4px; align-self: center; }
.ss2-trash-meta { font-size: 11px; color: #7f1d1d; text-align: center; }
.ss2-trash-item .btn { width: 100%; }
.ss2-footer-actions {
  border-top: 1px solid #e2e8f0;
  padding: 12px 22px;
  display: flex; align-items: center; gap: 10px;
}

/* ── 정리된 섹션 strip (Commit B, 메인 화면 옵션 그리드 위) ──────────── */
.ss2-confirmed-strip-panel {
  /* 2026-05-24 사장님 catch: 스크롤 시 sticky 가 아래 컨텐츠 가림 → static 으로 변경 */
  margin: 16px 0;
  padding: 12px 14px;
  background: #ecfdf5;
  border: 1px solid #10B981;
  border-radius: 8px;
  box-shadow: 0 2px 8px rgba(16,185,129,0.15);
}
.ss2-confirmed-head {
  display: flex; align-items: center; gap: 12px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.ss2-confirmed-head strong { color: #065f46; font-size: 14px; }
.ss2-confirmed-help { color: #047857; font-size: 12px; flex: 1; }
.ss2-confirmed-list {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.ss2c-item {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 6px;
  background: #fff;
  border: 1px solid #d1fae5;
  border-radius: 6px;
  cursor: grab;
  position: relative;
  width: 96px;
}
.ss2c-item:hover { border-color: #10B981; box-shadow: 0 1px 4px rgba(16,185,129,0.2); }
.ss2c-item:active { cursor: grabbing; }
.ss2c-item.ss2c-dragging { opacity: 0.4; }
.ss2c-item.ss2c-over { border-color: #2563EB; box-shadow: 0 0 0 2px rgba(37,99,235,0.3); }
.ss2c-del {
  position: absolute;
  top: -7px; right: -7px;
  width: 20px; height: 20px;
  border-radius: 50%;
  border: 2px solid white;
  background: #ef4444;
  color: white;
  font-size: 10px;
  font-weight: 800;
  cursor: pointer;
  z-index: 5;
  display: flex;
  align-items: center;
  justify-content: center;
  line-height: 1;
  padding: 0;
  opacity: 0;
  transition: opacity 80ms;
  box-shadow: 0 1px 3px rgba(0,0,0,0.25);
}
.ss2c-item:hover .ss2c-del { opacity: 1; }
.ss2c-del:hover { background: #dc2626; transform: scale(1.1); }
.ss2c-num { font-size: 11px; font-weight: 700; color: #065f46; }
.ss2c-thumb {
  width: 84px;
  max-height: 110px;
  object-fit: cover;
  border-radius: 4px;
  cursor: zoom-in;
  border: 1px solid #e5e7eb;
  pointer-events: auto;
}
.ss2c-meta { font-size: 10px; color: #6b7280; }
/* 세로 1500+ 경고 = 모바일 가독성 + AI 렌더 비용/성능 이유 (Fatkun 1500 권장 정합) */
.ss2c-item--warn { border-color: #f59e0b; background: #fffbeb; }
.ss2c-item--warn:hover { border-color: #d97706; box-shadow: 0 1px 4px rgba(245,158,11,0.3); }
.ss2c-meta--warn { color: #b45309; font-weight: 700; }
/* 사장님 2026-06-16: 스티커 색 전부 통일(주황). warn(1500+) 도 같은 주황 = 1·2번 색차 제거. 경고는 태그 안 ⚠1500+ 텍스트로 유지. */
/* drag-to-merge / reorder visual (2026-05-23 사장님 catch + 웹리서치 = TradingView/Figma 패턴) */
.ss2-piece[draggable="true"] { cursor: grab; }
.ss2-piece--dragging { opacity: 0.4; cursor: grabbing; }
.ss2-piece--drop-merge {
  outline: 3px solid #10B981;
  outline-offset: -3px;
  box-shadow: 0 0 0 4px rgba(16, 185, 129, 0.25);
  position: relative;
}
.ss2-piece--drop-reorder {
  outline: 3px dashed #2563EB;
  outline-offset: -3px;
}
.ss2-piece-drop-hint {
  position: absolute;
  top: 50%; left: 50%;
  transform: translate(-50%, -50%) scale(var(--ss2-inv-scale, 2));
  background: rgba(15, 23, 42, 0.9);
  color: white;
  padding: 8px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 700;
  z-index: 50;
  white-space: nowrap;
  pointer-events: none;
  opacity: 0;
  transition: opacity 80ms;
}
.ss2-piece--drop-merge .ss2-piece-drop-hint,
.ss2-piece--drop-reorder .ss2-piece-drop-hint { opacity: 1; }
.ss2-piece--drop-merge .ss2-piece-drop-hint { background: rgba(16, 185, 129, 0.95); }
.ss2-piece--drop-reorder .ss2-piece-drop-hint { background: rgba(37, 99, 235, 0.95); }
/* AI 추천 row 강조 (사장님 catch '추천 문구 위 표에도') */
.localization-recommend-row {
  background: linear-gradient(90deg, rgba(37,99,235,0.08), transparent);
  border-left: 3px solid #2563EB;
  padding-left: 8px !important;
}
.localization-recommend-row b { color: #2563EB !important; }

/* ── legacy v2 (사장님 새 안 1차, deprecated) ────────────────────────── */
.safe-split-v2-overlay {
  position: fixed; inset: 0;
  background: rgba(15, 23, 42, 0.55);
  display: flex; align-items: center; justify-content: center;
  z-index: 9000;
}
.modal.safe-split-v2-modal {
  width: min(1600px, 98vw);
  max-width: 98vw;        /* .modal.modal-wide 의 760px override */
  max-height: 95vh;
  display: flex; flex-direction: column;
  background: #fff;
  border-radius: 12px;
  overflow: hidden;
}
.safe-split-v2-hint {
  background: #fef3c7;
  color: #7c2d12;
  padding: 12px 22px;
  font-size: 13px;
  line-height: 1.55;
  border-bottom: 1px solid #fed7aa;
}
.safe-split-v2-body {
  flex: 1;
  min-height: 0;   /* ★ flex 함정 fix (사장님 2026-06-15): 없으면 body 가 콘텐츠(휴지통)만큼 커져 footer 를
                      모달 밖으로 밀어 footer 가 휴지통 위 겹침. min-height:0 = body 는 flex 공간만 차지. */
  overflow: hidden;
  padding: 0;
  display: grid;
  /* 사장님 2026-06-15: 휴지통 = 하단 가로바(footer 겹침/복원버튼 잘림 반복) 폐기 → 왼쪽 세로 사이드패널 고정. */
  grid-template-columns: 168px 1fr 260px;   /* 사장님 2026-06-16: 목차 200→260 (bulk 버튼 한 줄 유지) */
  grid-template-rows: 1fr;
  grid-template-areas:
    "trash scroll toc";
}
.safe-split-v2-body .ss2-scroll { grid-area: scroll; overflow-y: auto; padding: 20px; }
.safe-split-v2-body .ss2-toc { grid-area: toc; overflow-y: auto; }
.safe-split-v2-body .ss2-trash { grid-area: trash; }

/* 🌙 2026-06-30 사장님(여러번 지적): 공유 셸 다크 모드 = is-dark 에 실제 스타일 부여(규칙 자체가 없어서 테마버튼이 죽어있었음).
   테마버튼(data-shell="theme")이 .crop-shell-overlay 에 is-dark 토글 → 모달1·모달2 셸 공통. */
.crop-shell-overlay.is-dark .crop-shell-modal { background: #0e1116; color: #e5e7eb; }
.crop-shell-overlay.is-dark .modal-head { background: #0b0e13; border-bottom: 1px solid #2a2f3a; }
.crop-shell-overlay.is-dark .modal-head h3 { color: #f1f5f9; }
.crop-shell-overlay.is-dark .ss2-toolbar { background: #171b22; border-bottom-color: #2a2f3a; }
.crop-shell-overlay.is-dark .ss2-toolbar.ss2-toolbar--cut { background: #0f2a20; border-bottom-color: #10B981; }
.crop-shell-overlay.is-dark .ss2-toolbar .btn { color: #e5e7eb; background: #232a35; border-color: #2a2f3a; }
.crop-shell-overlay.is-dark .ss2-toolbar .btn:disabled { color: #64748b; }
.crop-shell-overlay.is-dark .ss2-tb-selection-info { color: #cbd5e1; }
.crop-shell-overlay.is-dark .ss2-hint { background: #1f2430; color: #cbd5e1; border-bottom-color: #2a2f3a; }
.crop-shell-overlay.is-dark .ss2-hint .wheel-mode-toggle,
.crop-shell-overlay.is-dark .merged-hk-hint { color: #cbd5e1; }
.crop-shell-overlay.is-dark .ss2-scroll { background: #0b0e13; }
.crop-shell-overlay.is-dark .ss2-toc { background: #12161d; border-left-color: #2a2f3a; color: #cbd5e1; }
.crop-shell-overlay.is-dark .ss2-toc-title { color: #e5e7eb; }
.crop-shell-overlay.is-dark .ss2-toc-item { background: #1a1f27; color: #cbd5e1; border-color: #2a2f3a; }
.crop-shell-overlay.is-dark .ss2-toc-item--active { background: #1e3a8a; color: #fff; }
.crop-shell-overlay.is-dark .ss2-trash { background: #12161d; }
.crop-shell-overlay.is-dark .ss2-piece--even { background: #1a1f27; }
.crop-shell-overlay.is-dark .ss2-piece--odd { background: #141821; }

/* ➕ 2026-06-30 사장님: 셸 섹션 추가 = 옛 모달2식(주황 점선 위 작은 ⊕). 밋밋 툴바버튼/큰 standalone ⊕(여백 폭발) 폐기. */
/* 옛 모달2 동일: divider = piece 안 absolute(시접 위 점선). 레이아웃 공간 0 = 별도 박스/여백 X. */
.ss2-strip .mp-shell-divider {
  position: absolute; top: -3px; left: 0; right: 0; height: 0; margin: 0;
  border-top: 2px dashed rgba(249, 115, 22, 0.92);
  z-index: 6; pointer-events: none;
  filter: drop-shadow(0 1px 2px rgba(15, 23, 42, 0.22));
}
/* 섹션 구분선 OFF = 점선+⊕ 통째 숨김 → 완전 1장 seamless(사장님 catch). */
.ss2-strip.ss2-strip--no-dividers .mp-shell-divider { display: none; }
.ss2-strip .mp-shell-inject {
  pointer-events: auto; position: absolute; left: 50%; top: -12px;
  transform: translateX(-50%) scale(var(--ss2-inv-scale, 1)); transform-origin: center center;
  width: 24px; height: 24px; border-radius: 50%; border: 1.5px solid #F97316;
  background: #fff; color: #F97316; font-size: 14px; font-weight: 900; line-height: 1;
  cursor: pointer; display: flex; align-items: center; justify-content: center; padding: 0;
  box-shadow: 0 1px 3px rgba(249, 115, 22, .35); z-index: 7;
}
.ss2-strip .mp-shell-inject:hover {
  background: #F97316; color: #fff;
  transform: translateX(-50%) scale(calc(var(--ss2-inv-scale, 1) * 1.18));
}
.ss2-strip .mp-shell-bottom-add { position: relative; display: flex; justify-content: center; padding: 14px 0 6px; }
.ss2-strip.ss2-strip--no-dividers .mp-shell-bottom-add { display: none; }
.ss2-strip .mp-shell-inject--bottom {
  position: relative; left: auto; top: auto;
  transform: scale(var(--ss2-inv-scale, 1)); width: 34px; height: 34px; font-size: 18px; border-width: 2px;
}
.ss2-strip .mp-shell-inject--bottom:hover { transform: scale(calc(var(--ss2-inv-scale, 1) * 1.12)); background: #F97316; color: #fff; }
.crop-shell-overlay.is-dark .ss2-strip .mp-shell-inject { background: #1a1f27; }

/* 모달1 동일: 위/아래 합치기 인라인 버튼 = 선택 섹션에서만 표시. */
.ss2-strip .ss2-merge-overlay { display: none; }
.ss2-strip .ss2-piece--selected .ss2-merge-overlay { display: block; }

/* 🌙 2026-06-30 사장님: 모달1(원본 정리=safe-split, 옛 비-셸 버전)에도 다크 모드. 헤더 🌙 버튼이 .safe-split-v2-overlay 에 is-dark 토글. */
.safe-split-v2-overlay.is-dark .safe-split-v2-modal { background: #0e1116; color: #e5e7eb; }
.safe-split-v2-overlay.is-dark .modal-head { background: #0b0e13; border-bottom: 1px solid #2a2f3a; }
.safe-split-v2-overlay.is-dark .modal-head h3 { color: #f1f5f9; }
.safe-split-v2-overlay.is-dark .ss2-toolbar { background: #171b22; border-bottom-color: #2a2f3a; }
.safe-split-v2-overlay.is-dark .ss2-toolbar.ss2-toolbar--cut { background: #0f2a20; border-bottom-color: #10B981; }
.safe-split-v2-overlay.is-dark .ss2-toolbar .btn { color: #e5e7eb; background: #232a35; border-color: #2a2f3a; }
.safe-split-v2-overlay.is-dark .ss2-toolbar .btn:disabled { color: #64748b; }
.safe-split-v2-overlay.is-dark .ss2-tb-selection-info { color: #cbd5e1; }
.safe-split-v2-overlay.is-dark .ss2-hint { background: #1f2430; color: #cbd5e1; border-bottom-color: #2a2f3a; }
.safe-split-v2-overlay.is-dark .ss2-hint .wheel-mode-toggle { color: #cbd5e1; }
.safe-split-v2-overlay.is-dark .ss2-scroll { background: #0b0e13; }
.safe-split-v2-overlay.is-dark .ss2-toc { background: #12161d; border-left-color: #2a2f3a; color: #cbd5e1; }
.safe-split-v2-overlay.is-dark .ss2-toc-title { color: #e5e7eb; }
.safe-split-v2-overlay.is-dark .ss2-toc-item { background: #1a1f27; color: #cbd5e1; }
.safe-split-v2-overlay.is-dark .ss2-toc-item--active { background: #1e3a8a; color: #fff; }
.safe-split-v2-overlay.is-dark .ss2-trash { background: #12161d; color: #cbd5e1; }
.safe-split-v2-overlay.is-dark .ss2-piece--even { background: #1a1f27; }
.safe-split-v2-overlay.is-dark .ss2-piece--odd { background: #141821; }

/* 🌙 2026-07-01 사장님: 다크모드 시인성 개선 + 모달1·2 통일(:is 로 셸·비셸 한 번에 = 단일 진실원천). 대비 ↑.
   기존 is-dark 블록과 같은 specificity → 소스 뒤라 이 값이 우선 적용. 저대비 회색·낮은 opacity 제거. */
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .crop-shell-modal,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .safe-split-v2-modal { background:#0d1117; color:#e6edf3; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .modal-head { background:#10151d; border-bottom:1px solid #313c4d; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .modal-head h3 { color:#f3f6fb; }
/* 툴바 = 버튼 명확(밝은 배경+또렷한 테두리+밝은 글자) */
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar { background:#1b2230; border-bottom-color:#313c4d; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar.ss2-toolbar--cut { background:#0f2a20; border-bottom-color:#10B981; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar .btn { color:#f3f6fb; background:#2d3850; border-color:#49566f; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar .btn:hover { background:#3a4763; border-color:#5d6c8e; color:#fff; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar .btn:disabled { color:#7d8799; background:#1e2632; border-color:#2c3645; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toolbar .btn.btn-danger { color:#fecaca; background:#4a2230; border-color:#7f3a48; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-tb-selection-info { color:#dbe3ee; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-zoom-level { color:#dbe3ee; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-tb-sep { background:#3a455a; }
/* 힌트줄 = 토글/칩 또렷이 */
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-hint { background:#222c3c; color:#dbe3ee; border-bottom-color:#313c4d; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-hint .wheel-mode-toggle,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .merged-hk-hint { color:#dbe3ee; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .crop-hk-chip { background:#2d3850 !important; border-color:#49566f !important; color:#e6edf3 !important; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-scroll { background:#0a0e14; }
/* 목차 = 패널/항목/숫자 또렷이, px 작은글자 opacity 복원 */
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc { background:#131a24; border-left-color:#313c4d; color:#e6edf3; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-title { color:#f3f6fb; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-bulk-merge,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-bulk-delete { color:#f3f6fb; background:#2d3850; border-color:#49566f; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-bulk-merge:disabled,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-bulk-delete:disabled { color:#7d8799; background:#1e2632; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item { background:#232d3d; color:#eef2f8; border-color:#3a4658; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item:hover { background:#2e3a4d; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item button,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item .ss2-toc-num { color:#eef2f8; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item small,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item .ss2-toc-meta { opacity:1 !important; color:#9fb0c6; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item--active { background:#2563eb; color:#fff; border-color:#3b82f6; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item--active small,
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-toc-item--active .ss2-toc-meta { color:#dbeafe !important; }
/* 휴지통 */
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-trash { background:#131a24; color:#cbd5e1; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-trash h4 { color:#f3f6fb; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-trash-empty { color:#8595ab; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-piece--even { background:#1a2230; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-piece--odd { background:#141a26; }
:is(.crop-shell-overlay,.safe-split-v2-overlay).is-dark .ss2-strip .mp-shell-inject { background:#1a2230; }
/* 2026-05-23 사장님 신규: piece TOC 우측 aside (1장 이어보기 패턴) */
.ss2-toc {
  background: #f8fafc;
  border-left: 1px solid #e2e8f0;
  padding: 12px;
}
.ss2-toc-title {
  font-size: 12px;
  font-weight: 700;
  color: #475569;
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.ss2-toc-list {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.ss2-toc-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 10px;
  border: 1px solid #e2e8f0;
  border-radius: 6px;
  background: #fff;
  cursor: pointer;
  font-size: 12px;
  text-align: left;
  transition: all 0.15s;
}
.ss2-toc-item:hover { background: #eff6ff; border-color: #93c5fd; }
.ss2-toc-item--active { background: #2563EB; color: white; border-color: #1d4ed8; font-weight: 700; }
.ss2-toc-num { font-weight: 700; min-width: 22px; }
.ss2-toc-meta { color: inherit; opacity: 0.7; font-size: 11px; }
.ss2-toc-item--active .ss2-toc-meta { opacity: 0.9; }
/* 2026-05-24 사장님 명시: 1장 이어보기 TOC 패턴 이식 — 체크박스 + 빨간 [삭제] bulk delete */
.ss2-toc-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 4px;
  /* 사장님 2026-06-16: wrap(아래줄 내려감) 싫음 → 목차 폭 260px 로 넓혀 한 줄 유지(nowrap). */
  flex-wrap: nowrap;
  padding-bottom: 6px;
  border-bottom: 1px solid #e2e8f0;
  margin-bottom: 6px;
  white-space: nowrap;
}
.ss2-toc-title-row .ss2-toc-title {
  margin: 0;
  margin-bottom: 0;
}
/* 2026-05-24 사장님 명시: 원본정리 TOC = 합치기 + 삭제 둘 다 (사장님 dogfood catch — 삭제도 필수) */
.ss2-toc-bulk-actions { display: inline-flex; gap: 4px; flex-wrap: nowrap; justify-content: flex-end; flex-shrink: 0; }
.ss2-toc-title-row .ss2-toc-title { min-width: 0; flex-shrink: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.ss2-toc-bulk-merge,
.ss2-toc-bulk-delete {
  background: transparent;
  border: 0;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  padding: 2px 8px;
  border-radius: 4px;
  line-height: 1.3;
  transition: background 0.15s, opacity 0.15s;
  white-space: nowrap;
  flex-shrink: 0;
}
.ss2-toc-bulk-merge { color: #2563EB; }
.ss2-toc-bulk-merge:hover:not(:disabled) { background: #eff6ff; color: #1d4ed8; }
.ss2-toc-bulk-delete { color: #dc2626; }
.ss2-toc-bulk-delete:hover:not(:disabled) { background: #fef2f2; color: #b91c1c; }
.ss2-toc-bulk-merge:disabled,
.ss2-toc-bulk-delete:disabled { cursor: not-allowed; opacity: 0.45; }
.ss2-toc-item-row {
  display: flex;
  align-items: center;
  gap: 6px;
}
.ss2-toc-item-row .ss2-toc-item { flex: 1; }
.ss2-toc-checkbox {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: #dc2626;
  flex-shrink: 0;
  margin: 0;
}
/* 2026-05-23 사장님 신규: 섹션 구분선 토글 (OFF = 완전 1장 이어보기, margin+border+radius 0) */
.ss2-strip--no-dividers .ss2-piece {
  margin: 0 !important;
  border: 0 !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}
.ss2-strip--no-dividers .ss2-piece-img-wrap { border-radius: 0 !important; }
/* 사장님 2026-06-28: 섹션 스티커(#N · WxH 태그) = 구분선과 분리 = 별도 체크박스(🏷 섹션 스티커)로 on/off.
   구분선 OFF여도 스티커 유지 가능(있어야 할 때 대비). 스티커 숨김은 .ss2-strip--no-stickers 가 담당. */
.ss2-strip--no-stickers .ss2-piece-tag { display: none !important; }
.ss2-strip--no-dividers .ss2-piece-img-wrap,
.ss2-strip--no-dividers .ss2-piece-img-wrap img { display: block; vertical-align: top; font-size: 0; line-height: 0; }
.ss2-strip--no-dividers { gap: 0 !important; }
/* 2026-05-23 사장님 신규: hint 영역 안 toggle 묶음. 2026-05-24 catch 정합 !important 강제 (다른 .ss2-hint flex override 회피) */
.safe-split-v2-modal .ss2-hint-toggles {
  display: flex !important;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 6px;
  align-items: center;
  width: 100%;
}
/* 2026-05-24 사장님 명시: 노란 영역(.ss2-hint) 안 두 체크박스 (휠로 확대/축소 + 섹션 구분선) 가운데 정렬 강제 */
.safe-split-v2-modal .ss2-hint-toggles--center { justify-content: center !important; }
.safe-split-v2-modal .ss2-hint { text-align: center; }
.ss2-hint-toggles .wheel-mode-toggle {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 12px;
  color: #475569;
  cursor: pointer;
}
.safe-split-v2-zoom-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  background: #f1f5f9;
  border-radius: 6px;
  margin-bottom: 8px;
  font-size: 12px;
}
.safe-split-v2-zoom-level {
  display: inline-block;
  min-width: 44px;
  text-align: center;
  font-weight: 600;
  color: #475569;
}
.ss2-zoom-help { color: #64748b; font-size: 11px; }
.safe-split-v2-scroll {
  width: 100%;
  max-height: 78vh;
  height: 78vh;
  overflow: hidden;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  background: #f1f5f9;
  padding: 16px;
}
.safe-split-v2-zoom-wrap {
  transform-origin: 50% 0;
  transition: transform 80ms linear;
}
/* 2026-05-24 사장님 catch: v1 safe-split-modal 의 .ss2-cut-line 정의 — v2 와 cascade 충돌 차단 위해 scope 명시. */
.safe-split-modal .ss2-cut-line {
  position: absolute;
  left: 0; right: 0;
  height: 0;
  border-top: 2px dashed #10B981;
  pointer-events: auto;
  cursor: ns-resize;
}
.safe-split-modal .ss2-cut-line::before {
  content: "";
  position: absolute;
  left: 0; right: 0;
  top: -8px;
  height: 16px;
  cursor: ns-resize;
}
.safe-split-modal .ss2-cut-line:hover { border-top-color: #059669; box-shadow: 0 0 0 1px rgba(16,185,129,0.3); }
.safe-split-modal .ss2-cut-line-label {
  position: absolute;
  top: -16px;
  left: 8px;
  background: #10B981;
  color: white;
  padding: 1px 5px;
  border-radius: 3px;
  font-size: 10px;
  font-weight: 700;
}
.safe-split-modal .ss2-cut-line-remove {
  position: absolute;
  top: -12px;
  right: 8px;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: none;
  background: rgba(239, 68, 68, 0.92);
  color: white;
  cursor: pointer;
  font-size: 11px;
  font-weight: 800;
}
.safe-split-modal .ss2-cut-line-apply {
  position: absolute;
  top: -12px;
  right: 36px;
  width: 22px; height: 22px;
  border-radius: 50%;
  border: none;
  background: #2563EB;
  color: white;
  cursor: pointer;
  font-size: 11px;
  font-weight: 800;
  z-index: 6;
}
.safe-split-modal .ss2-cut-line-apply:hover { background: #1d4ed8; transform: scale(1.1); }
/* ===== 작업 보관함 리디자인 (2026-06-10 사장님 지시) — 썸네일 카드 + 검색 + 필터 ===== */
.picker-count { font-size: 13px; color: var(--color-text-muted); font-weight: 400; margin-left: 6px; }
.picker-head-actions { display: flex; align-items: center; gap: 8px; }
.picker-search {
  width: 220px; padding: 7px 12px; font-size: 13px;
  border: 1px solid var(--color-border); border-radius: var(--radius-md);
  background: var(--color-bg, #fff);
}
.picker-search:focus { outline: 2px solid var(--color-primary, #2563eb); outline-offset: -1px; }
/* 2026-07-04 사장님 리디자인: 단일 컨트롤 바 = 분절(세그먼트) 컨트롤 + 좌(탐색·선택)/우(삭제) 그룹 명확 */
.picker-controls {
  display: flex; align-items: center; gap: 12px; margin-bottom: 14px; flex-wrap: wrap;
}
.picker-ctl-group { display: inline-flex; align-items: center; gap: 8px; flex: 0 0 auto; }
.picker-ctl-label { font-size: 12px; color: var(--color-text-muted); font-weight: 600; }
.picker-ctl-flex { flex: 1 1 auto; min-width: 8px; }
.picker-ctl-divider { width: 1px; align-self: stretch; min-height: 24px; background: var(--color-border); flex: 0 0 auto; }
/* 분절 컨트롤 = 연결된 세그먼트(느슨한 칩 → 한 덩어리로 정돈) */
.picker-segment {
  display: inline-flex; align-items: center; padding: 2px; gap: 2px;
  background: var(--color-bg-subtle, #f1f5f9); border: 1px solid var(--color-border);
  border-radius: var(--radius-full, 999px);
}
.picker-segment button, .picker-seg-btn {
  padding: 5px 13px; font-size: 13px; cursor: pointer; white-space: nowrap;
  border: 0; border-radius: var(--radius-full, 999px);
  background: transparent; color: var(--color-text-muted); transition: all .12s; font-weight: 500;
}
.picker-segment button:hover, .picker-seg-btn:hover { color: var(--color-primary, #2563eb); }
.picker-segment button.is-active, .picker-seg-btn.is-active {
  background: var(--color-primary, #2563eb); color: #fff; font-weight: 700;
  box-shadow: 0 1px 3px rgba(37,99,235,0.3);
}
.picker-card-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(200px, 1fr)); gap: 14px;
}
.picker-card {
  position: relative; cursor: pointer; overflow: hidden;
  border: 1px solid var(--color-border); border-radius: var(--radius-lg, 12px);
  background: var(--color-bg, #fff); transition: box-shadow .15s, transform .15s, border-color .15s;
}
.picker-card:hover { box-shadow: 0 6px 20px rgba(0,0,0,0.10); transform: translateY(-2px); border-color: var(--color-primary, #2563eb); }
.picker-card.is-current { border: 2px solid var(--color-primary, #2563eb); }
.picker-card-thumb { position: relative; aspect-ratio: 4/3; background: #f1f5f9; overflow: hidden; }
.picker-card-thumb img { width: 100%; height: 100%; object-fit: cover; object-position: top; display: block; }
.picker-card-thumb-fallback {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  font-size: 42px; background: linear-gradient(135deg, #f1f5f9, #e2e8f0);
}
.picker-badge {
  position: absolute; top: 8px; left: 8px; padding: 3px 9px;
  font-size: 11px; font-weight: 700; border-radius: var(--radius-full, 999px); color: #fff;
}
.picker-badge-localize { background: #dc2626; }
.picker-badge-etc { background: #64748b; }
.picker-badge-current { top: 8px; left: auto; right: 8px; background: var(--color-primary, #2563eb); }
.picker-badge-draft { top: 36px; left: 8px; background: #f59e0b; }
.picker-card-body { padding: 10px 12px 6px; }
.picker-card-name {
  font-size: 14px; font-weight: 600; line-height: 1.35;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden;
  min-height: 2.7em; white-space: normal;
}
.picker-card-meta { font-size: 12px; color: var(--color-text-muted); margin-top: 4px; }
.picker-card-actions {
  display: flex; justify-content: flex-end; gap: 2px; padding: 2px 8px 8px;
  opacity: 0; transition: opacity .12s;
}
.picker-card:hover .picker-card-actions, .picker-card:focus-within .picker-card-actions { opacity: 1; }
.picker-empty { grid-column: 1 / -1; text-align: center; padding: 60px 20px; color: var(--color-text-muted); }
.picker-empty-icon { font-size: 48px; margin-bottom: 12px; }

/* 2026-07-04 사장님: 상단 오른쪽 끝 비용 값 상시표시(버튼 아닌 인라인 값, 클릭=상세) */
.tool-cost-badge {
  display: inline-flex; align-items: center; gap: 4px; cursor: pointer;
  padding: 4px 10px; font-size: 13px; font-weight: 700;
  border: 1px solid var(--color-border); border-radius: var(--radius-full, 999px);
  background: var(--color-bg-subtle, #f8fafc); color: var(--color-text, #1e293b);
  transition: all .12s; white-space: nowrap;
}
.tool-cost-badge:hover { border-color: #f59e0b; }
.tool-cost-badge.has-cost { border-color: #f59e0b; background: #fff7ed; color: #b45309; }
/* 상단바 비용 표시(사장님 2026-07-04: 카드 말고 큰 공간에 회색 인라인 텍스트, 모던·심플·안 튀게) */
.tool-cost-panel {
  align-self: center; min-width: 0; max-width: none;
  border: none; background: transparent; padding: 0;
  display: flex; align-items: baseline; flex-wrap: wrap; gap: 4px 16px;
}
.tcp-title { display: inline-flex; align-items: baseline; gap: 7px; font-size: 12.5px; font-weight: 600; color: #64748b; }
.tcp-title > span { display: inline-flex; align-items: baseline; gap: 4px; white-space: nowrap; }
.tcp-title span b { color: #64748b; font-weight: 700; }
.tcp-proj-total { font-size: 13.5px; font-weight: 700; color: #475569; white-space: nowrap; }
.tcp-models { margin: 0; padding: 0; border: none; display: flex; flex-flow: row wrap; align-items: baseline; gap: 3px 16px; }
.tcp-mrow { display: inline-flex; align-items: baseline; font-size: 11.5px; color: #94a3b8; gap: 6px; }
.tcp-mrow span:first-child { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.tcp-mrow span:last-child { font-weight: 600; white-space: nowrap; color: #64748b; }
.tcp-mrow.tcp-empty { color: #94a3b8; font-style: normal; text-align: left; display: inline-block; }

/* 비용 드롭다운(🔥 배지 아래 오른쪽 정렬 패널) */
.cost-dropdown {
  background: var(--color-bg, #fff); border: 1px solid var(--color-border, #e5e7eb);
  border-radius: 12px; box-shadow: 0 12px 32px rgba(0,0,0,0.16); padding: 12px;
  animation: costDropIn .12s ease-out;
}
@keyframes costDropIn { from { opacity: 0; transform: translateY(-6px); } to { opacity: 1; transform: none; } }
.cost-dropdown-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 4px; }
.cost-dropdown-x {
  border: 0; background: transparent; cursor: pointer; font-size: 15px; color: var(--color-text-muted);
  padding: 2px 6px; border-radius: 6px; line-height: 1;
}
.cost-dropdown-x:hover { background: var(--color-bg-subtle, #f1f5f9); color: var(--color-text, #1e293b); }

/* ★ 페이지네이션 하단 고정: 모달 body를 flex column → 그리드만 스크롤, 페이지바는 항상 맨 아래 */
.picker-modal .modal-body { display: flex; flex-direction: column; overflow: hidden; }
.picker-modal .picker-controls { flex: 0 0 auto; }
.picker-modal .picker-card-grid { flex: 1 1 auto; overflow-y: auto; min-height: 0; align-content: start; padding-bottom: 4px; }
.picker-modal .picker-pagination { flex: 0 0 auto; margin-top: 0; padding-top: 12px; border-top: 1px solid var(--color-border); }
.picker-selectall {
  display: inline-flex; align-items: center; gap: 7px; cursor: pointer;
  font-size: 13px; font-weight: 600; color: var(--color-text, #1e293b); user-select: none;
}
.picker-selectall input { width: 18px; height: 18px; cursor: pointer; accent-color: var(--color-primary, #2563eb); margin: 0; }
/* 좁은 화면 = 컨트롤 바 줄바꿈 시 좌우 구분선·flex 스페이서는 숨겨 깔끔 유지 */
@media (max-width: 720px) {
  .picker-ctl-flex { flex-basis: 100%; height: 0; }
  .picker-ctl-divider { display: none; }
}

/* 카드 체크박스 (큼 = 큰 카드에서도 편함) */
.picker-card-check {
  position: absolute; top: 10px; right: 10px; z-index: 4; margin: 0;
  width: 26px; height: 26px; cursor: pointer;
  accent-color: var(--color-primary, #2563eb);
  background: rgba(255,255,255,.9); border-radius: 7px;
  box-shadow: 0 1px 5px rgba(0,0,0,.28);
}
.picker-card.is-selected { border-color: var(--color-primary, #2563eb); box-shadow: 0 0 0 2px var(--color-primary, #2563eb) inset; }
/* 썸네일=선택 / 하단=열기 = 영역별 커서·호버 어포던스 */
.picker-card-thumb { cursor: pointer; }
.picker-card-body { cursor: pointer; }
.picker-card-body:hover .picker-card-name { color: var(--color-primary, #2563eb); text-decoration: underline; text-underline-offset: 2px; }
/* 체크박스가 우상단이라 "현재 작업" 배지는 우하단으로 이동(충돌 회피) */
.picker-badge-current { top: auto; bottom: 8px; right: 8px; left: auto; }

/* 카드 크기 3단계 = 그리드 최소폭으로 조절 (중간=기본) */
.picker-card-grid.size-sm { grid-template-columns: repeat(auto-fill, minmax(150px, 1fr)); gap: 10px; }
.picker-card-grid.size-md { grid-template-columns: repeat(auto-fill, minmax(210px, 1fr)); gap: 14px; }
.picker-card-grid.size-lg { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); gap: 18px; }
.picker-card-grid.size-sm .picker-card-name { font-size: 13px; -webkit-line-clamp: 2; min-height: 2.4em; }
.picker-card-grid.size-sm .picker-card-check { width: 22px; height: 22px; top: 8px; right: 8px; }
.picker-card-grid.size-lg .picker-card-name { font-size: 15px; }
.picker-card-grid.size-lg .picker-card-check { width: 30px; height: 30px; }

/* 상품 AI 어시스턴트 채팅 패널 (gpt-5.5, finalResultCard 내장) */
.assistant-chat { margin-top: 18px; border: 1px solid var(--color-border, #e2e4ea); border-radius: 12px; background: var(--color-surface, #fff); overflow: hidden; }
.assistant-chat-head { display: flex; align-items: baseline; gap: 10px; padding: 12px 14px; background: linear-gradient(90deg, #f4f1ff, #eefaf5); border-bottom: 1px solid var(--color-border, #e2e4ea); }
.assistant-chat-head b { font-size: 14px; }
.assistant-chat-head small { color: var(--color-text-muted, #8a8f99); font-size: 11px; }
.assistant-chat-log { max-height: 420px; overflow-y: auto; padding: 14px; display: flex; flex-direction: column; gap: 10px; }
.assistant-empty { color: var(--color-text-muted, #8a8f99); font-size: 13px; text-align: center; padding: 24px 12px; margin: 0; }
.assistant-msg { display: flex; flex-direction: column; gap: 3px; max-width: 86%; }
.assistant-msg-me { align-self: flex-end; align-items: flex-end; }
.assistant-msg-ai { align-self: flex-start; align-items: flex-start; }
.assistant-msg-label { font-size: 10px; color: var(--color-text-muted, #8a8f99); }
.assistant-msg-content { padding: 9px 13px; border-radius: 14px; font-size: 13px; line-height: 1.55; white-space: pre-wrap; word-break: break-word; }
.assistant-msg-me .assistant-msg-content { background: #4c6ef5; color: #fff; border-bottom-right-radius: 4px; }
.assistant-msg-ai .assistant-msg-content { background: #f1f3f7; color: #1a1d24; border-bottom-left-radius: 4px; }
.assistant-chat-input { display: flex; gap: 8px; padding: 10px 12px; border-top: 1px solid var(--color-border, #e2e4ea); background: var(--color-surface-2, #fafbfc); }
.assistant-chat-input textarea { flex: 1; resize: vertical; min-height: 38px; max-height: 160px; padding: 8px 10px; border: 1px solid var(--color-border, #d6d9e0); border-radius: 8px; font: inherit; font-size: 13px; }
.assistant-chat-input button { align-self: flex-end; white-space: nowrap; }
.assistant-chat-input textarea:disabled { background: #f0f0f2; opacity: 0.7; }
/* 🎨 이미지 생성 모드 토글 + 이미지 말풍선 */
.assistant-chat-modebar { display: flex; align-items: center; gap: 12px; padding: 8px 12px 0; }
.assistant-imgmode { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--color-text-muted, #6b7280); cursor: pointer; user-select: none; }
.assistant-imgmode input { accent-color: #4c6ef5; }
.assistant-msg-content--img { background: transparent !important; padding: 0 !important; }
.assistant-msg-imgwrap { display: block; }
.assistant-msg-img { display: block; max-width: 320px; width: 100%; border-radius: 12px; border: 1px solid var(--color-border, #e2e4ea); }
.assistant-msg-cap { margin-top: 4px; font-size: 12px; color: var(--color-text-muted, #6b7280); }
.assistant-msg-dl { display: inline-block; margin-top: 4px; font-size: 11px; color: #4c6ef5; }
/* 이미지 옵션바(폭/다듬기) + 섹션삽입 버튼 */
.assistant-imgopts { display: inline-flex; align-items: center; gap: 12px; }
.assistant-wchips { display: inline-flex; gap: 3px; }
.assistant-wchip { padding: 3px 9px; font-size: 11px; border: 1px solid var(--color-border, #d6d9e0); border-radius: 999px; background: #fff; color: var(--color-text-muted, #6b7280); cursor: pointer; }
.assistant-wchip.is-active { background: #4c6ef5; color: #fff; border-color: #4c6ef5; }
.assistant-refine { display: inline-flex; align-items: center; gap: 5px; font-size: 12px; color: var(--color-text-muted, #6b7280); cursor: pointer; }
.assistant-refine input { accent-color: #4c6ef5; }
.assistant-msg-imgactions { display: flex; flex-wrap: wrap; align-items: center; gap: 8px; margin-top: 6px; }
.assistant-msg-insert { padding: 5px 11px; font-size: 12px; font-weight: 600; border: 1px solid #4c6ef5; border-radius: 8px; background: #eef1ff; color: #3b4fd1; cursor: pointer; }
.assistant-msg-insert:hover { background: #4c6ef5; color: #fff; }
.assistant-msg-insert:disabled { opacity: 0.6; cursor: default; }
/* 📋 복사 + ✍️ 섹션 적용 (§B-3·B-2) — AI 텍스트 말풍선 아래 작게 */
.assistant-msg-actions { display: flex; gap: 6px; margin-top: 2px; opacity: 0.65; transition: opacity .12s; }
.assistant-msg:hover .assistant-msg-actions { opacity: 1; }
.assistant-msg-copy, .assistant-msg-apply { padding: 2px 8px; font-size: 11px; border: 1px solid var(--color-border, #d6d9e0); border-radius: 999px; background: #fff; color: var(--color-text-muted, #6b7280); cursor: pointer; }
.assistant-msg-copy:hover { background: #f1f3f7; color: #3b4fd1; border-color: #4c6ef5; }
.assistant-msg-apply:hover { background: #fff4e6; color: #d9480f; border-color: #f08c00; }
/* 💬 비용·대화 카운터 (§B-5) — head 우측 */
.assistant-count { margin-left: auto; font-size: 11px; color: var(--color-text-muted, #8a8f99); white-space: nowrap; font-variant-numeric: tabular-nums; }
/* 🖼️ 멀티모달 첨부 (§B-1) */
.assistant-attach { display: flex; flex-wrap: wrap; gap: 8px; padding: 8px 12px 0; }
.assistant-attach-item { position: relative; width: 56px; height: 56px; border-radius: 8px; overflow: hidden; border: 1px solid var(--color-border, #e2e4ea); }
.assistant-attach-item img { width: 100%; height: 100%; object-fit: cover; display: block; }
.assistant-attach-x { position: absolute; top: 1px; right: 1px; width: 16px; height: 16px; line-height: 14px; padding: 0; font-size: 10px; border: none; border-radius: 50%; background: rgba(0,0,0,.6); color: #fff; cursor: pointer; }
.assistant-attach-btn { align-self: flex-end; display: inline-flex; align-items: center; justify-content: center; width: 34px; height: 34px; font-size: 16px; border: 1px solid var(--color-border, #d6d9e0); border-radius: 8px; background: #fff; cursor: pointer; user-select: none; }
.assistant-attach-btn:hover { background: #f1f3f7; border-color: #4c6ef5; }
.assistant-msg-attached { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 6px; }
.assistant-msg-attached img { width: 64px; height: 64px; object-fit: cover; border-radius: 8px; border: 1px solid rgba(255,255,255,.4); }
.assistant-chat.assistant-drag { outline: 2px dashed #4c6ef5; outline-offset: -4px; }
/* 💬 분석 단계 어시스턴트 안내 (§B-6) */
.assistant-stage-hint { margin: 12px 0 6px; padding: 8px 12px; font-size: 12px; line-height: 1.5; color: #3b4fd1; background: #eef1ff; border-radius: 8px; }

/* 💬 위치3 총괄 도우미 FAB 팝업 (자유분방 'AI 파트너' 패턴 채용). 바깥클릭 닫기 = 글로벌 §13-A */
.assistant-fab { position: fixed; right: 22px; bottom: 22px; z-index: 948; display: inline-flex; align-items: center; gap: 6px; padding: 11px 16px; border: none; border-radius: 999px; background: linear-gradient(90deg, #6b5bff, #4c6ef5); color: #fff; font-size: 13px; font-weight: 700; cursor: pointer; box-shadow: 0 6px 20px rgba(76,110,245,0.38); }
.assistant-fab:hover { filter: brightness(1.06); }
.assistant-fab-backdrop { position: fixed; inset: 0; background: transparent; z-index: 945; }
.assistant-fab-popup { position: fixed; right: 22px; bottom: 78px; z-index: 950; width: min(440px, calc(100vw - 32px)); max-height: min(76vh, 720px); display: flex; flex-direction: column; background: #fff; border: 1px solid var(--color-border, #e2e4ea); border-radius: 14px; box-shadow: 0 18px 48px rgba(20,24,40,0.28); overflow: hidden; }
.assistant-fab-close { position: absolute; top: 8px; right: 10px; z-index: 2; width: 26px; height: 26px; border: none; border-radius: 50%; background: rgba(0,0,0,0.06); color: #444; font-size: 14px; cursor: pointer; }
.assistant-fab-close:hover { background: rgba(0,0,0,0.12); }
.assistant-fab-body { overflow-y: auto; }
.assistant-fab-body .assistant-chat { margin-top: 0; border: none; border-radius: 0; }
.assistant-fab-body .assistant-chat-log { max-height: 46vh; }

/* 검토질문 원문/근거 = 중국어 옆 한국어 뜻 병기 (2026-06-15 사장님 catch) */
.loc-src-ko { color: #2563eb; font-weight: 600; }

/* 🎨 위치2 섹션 빌더 = 섹션 선택 칩 (2026-06-15 사장님 = AI가 묻고 선택하게) */
.assistant-section-chips { display: flex; flex-wrap: wrap; align-items: center; gap: 6px; padding: 8px 12px 0; }
.assistant-section-chips .asc-label { font-size: 12px; font-weight: 700; color: #6b7280; margin-right: 2px; }
.asc-chip { padding: 5px 10px; border: 1px solid #d6d9e0; border-radius: 999px; background: #fff; font-size: 12px; cursor: pointer; white-space: nowrap; transition: all .12s; }
.asc-chip:hover { border-color: #4c6ef5; background: #eef1ff; color: #3b4fd1; }
.assistant-imgmode-hint { font-size: 11px; color: #9aa0aa; }

/* ── 가로 보드 모드 (safe-split board, 2026-06-17 사장님) ─────────────────────
   풀스크린 오버레이로 섹션을 펼쳐 순서변경·삭제. 같은 state.pieces 공유. 세로 CSS 불변.
   ▦ 여러 줄(auto-fill, 세로 스크롤) / ▭ 한 줄(nowrap, 가로 스크롤). 슬라이더=카드 너비. */
.ssb-overlay {
  position: fixed; inset: 0; z-index: 100000;
  background: rgba(0,0,0,0.4);
  display: flex; align-items: center; justify-content: center;
  padding: 1.2vh 1vw; box-sizing: border-box;
}
.ssb-panel {
  width: 100%; height: 100%;
  background: #f8fafc; border-radius: 12px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.45);
  display: flex; flex-direction: column; overflow: hidden;
}
.ssb-bar { position: relative; display: flex; align-items: center; gap: 10px; padding: 12px 18px; background: #fff; border-bottom: 1px solid #e2e8f0; flex-wrap: wrap; }
.ssb-title { font-weight: 800; font-size: 15px; color: #0f172a; }
.ssb-count { font-size: 13px; color: #64748b; font-weight: 600; }
.ssb-lay-group { display: inline-flex; border: 1px solid #cbd5e1; border-radius: 7px; overflow: hidden; }
.ssb-lay-btn { padding: 6px 12px; border: none; background: #f1f5f9; cursor: pointer; font-size: 12px; font-weight: 700; color: #334155; }
.ssb-lay-btn + .ssb-lay-btn { border-left: 1px solid #cbd5e1; }
.ssb-lay-btn--active { background: #2563EB; color: #fff; }
.ssb-size-label { font-size: 12px; color: #64748b; margin-left: 4px; }
.ssb-size-slider { width: 160px; cursor: pointer; accent-color: #2563EB; }
.ssb-close { margin-left: 6px; padding: 6px 14px; border: none; background: #0f172a; color: #fff; border-radius: 7px; cursor: pointer; font-weight: 700; font-size: 13px; }
.ssb-close:hover { background: #1e293b; }
.ssb-scroll { flex: 1; overflow: auto; padding: 16px 18px; }
.ssb-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(var(--ssb-w, 240px), 1fr)); gap: 14px; align-content: start; }
.ssb-grid--row { display: flex; flex-wrap: nowrap; gap: 14px; align-items: flex-start; }
.ssb-grid--row .ssb-card { flex: 0 0 var(--ssb-w, 240px); }
.ssb-card { position: relative; background: #fff; border: 2px solid #e2e8f0; border-radius: 10px; overflow: hidden; cursor: grab; user-select: none; transition: border-color .12s, box-shadow .12s, transform .12s; }
.ssb-card:hover { border-color: #94a3b8; box-shadow: 0 4px 14px rgba(0,0,0,0.12); }
.ssb-card--merged { border-color: #f59e0b; }
.ssb-card--dragging { opacity: .55; cursor: grabbing; pointer-events: none; }
.ssb-card--dropzone { border-color: #2563EB; box-shadow: 0 0 0 3px rgba(37,99,235,0.25); transform: scale(1.02); }
.ssb-card-tag { position: absolute; top: 6px; left: 6px; z-index: 2; background: rgba(234,88,12,0.95); color: #fff; font-size: 11px; font-weight: 700; padding: 2px 7px; border-radius: 5px; pointer-events: none; white-space: nowrap; }
.ssb-card-del { position: absolute; top: 6px; right: 6px; z-index: 3; width: 24px; height: 24px; border: none; border-radius: 6px; background: rgba(239,68,68,0.95); color: #fff; font-size: 13px; font-weight: 700; cursor: pointer; display: flex; align-items: center; justify-content: center; line-height: 1; }
.ssb-card-del:hover { background: #dc2626; }
.ssb-card-imgwrap { height: 360px; display: flex; align-items: center; justify-content: center; background: #fff; overflow: hidden; }
.ssb-card-imgwrap img { max-width: 100%; max-height: 100%; object-fit: contain; display: block; pointer-events: none; }
.ssb-card-missing { color: #94a3b8; font-size: 13px; padding: 24px; }
.ssb-hint { padding: 9px 18px; background: #fff; border-top: 1px solid #e2e8f0; font-size: 12px; color: #64748b; text-align: center; }
.ssb-empty { grid-column: 1 / -1; text-align: center; color: #94a3b8; padding: 60px; font-size: 14px; }

/* Shift+휠 횡스크롤 안내 — 상단바 정중앙, 섬세한 키캡 스타일 (사장님 2026-06-17) */
.ssb-scroll-tip {
  position: absolute; left: 50%; top: 50%; transform: translate(-50%, -50%);
  pointer-events: none; z-index: 1;
  display: inline-flex; align-items: center; gap: 6px;
  font-family: "Pretendard", system-ui, -apple-system, sans-serif;
  font-size: 12.5px; font-weight: 600; letter-spacing: 0.01em;
  color: #b4bdc9; white-space: nowrap;
  transition: color .15s ease;
}
.ssb-scroll-tip kbd {
  font-family: inherit; font-size: 11px; font-weight: 700; line-height: 1.4;
  color: #64748b; background: #f8fafc;
  border: 1px solid #e2e8f0; border-bottom-width: 2px; border-radius: 5px;
  padding: 1px 7px; transition: all .15s ease;
}
.ssb-scroll-tip .ssb-tip-plus { color: #cbd5e1; font-weight: 500; }
.ssb-scroll-tip .ssb-tip-txt { margin-left: 2px; color: #94a3b8; }
.ssb-scroll-tip--hot { color: #2563EB; }
.ssb-scroll-tip--hot kbd { color: #2563EB; background: #eff6ff; border-color: #bfdbfe; }
.ssb-scroll-tip--hot .ssb-tip-txt { color: #2563EB; }
.ssb-scroll-tip--hot .ssb-tip-plus { color: #93c5fd; }
