/* ==========================================================================
   Detail Localizer Design System — v7 토큰 + 컴포넌트 (핸드오프 2026-06-10)
   --------------------------------------------------------------------------
   출처: Claude Design 핸드오프 (detail-localizer-design-system).
   prefix=--v7-* / .v7-* = 기존 --color-* 와 별개 네임스페이스 (충돌 0).
   폰트 Pretendard = index.html CDN/subset 재사용 (fonts.css @font-face 생략).
   base.css body 전역 리셋 = 기존 레이아웃 충돌 회피 위해 제외.
   진입점: index.html 에서 link. 색 변경은 아래 :root(colors) 한 곳만.
   ========================================================================== */

/* ==========================================================================
   컬러 토큰 (colors.css)
   --------------------------------------------------------------------------
   한국형 이커머스 SaaS 톤. 절제된 쿠팡 블루 + 중립 회색 + 의미색.
   핵심 콘셉트 = [중국 원본] ↔ [한국화 결과] 의 듀얼리티를 색으로 표현.
     · 중국 원본(origin)  = 빨강 계열
     · 한국화 결과        = 브랜드 블루
     · 검증 통과/안전     = 초록
   ========================================================================== */

:root {
  /* ---- 브랜드 (한국화 = 쿠팡 블루) ---- */
  --v7-color-brand:        #346aff;   /* 메인 브랜드 — 주요 버튼·강조·"한국화 결과" */
  --v7-color-brand-strong: #1f4fd1;   /* hover / press */
  --v7-color-brand-soft:   #e8efff;   /* 연한 강조 배경(선택 칩·소프트 배지) */
  --v7-color-brand-tint:   #f3f7ff;   /* 가장 옅은 브랜드 표면(패널 배경) */
  --v7-color-accent:       #00b2e3;   /* 하늘색 보조 강조(링크·아이콘·진행바) */

  /* ---- 듀얼리티: 중국 원본 ↔ 한국화 결과 ---- */
  --v7-color-source:        #e5392b;  /* 중국 원본(origin) — 빨강 배지 */
  --v7-color-source-strong: #c52a1e;  /* hover / press */
  --v7-color-source-soft:   #fdecea;  /* 원본 패널 옅은 배경 */
  --v7-color-localized:      var(--v7-color-brand);       /* 한국화 결과 = 브랜드 블루 */
  --v7-color-localized-soft: var(--v7-color-brand-soft);

  /* ---- 의미색 (한국 커머스 관습) ---- */
  --v7-color-success:      #16a34a;   /* 검증 통과 · 안전 신호 */
  --v7-color-success-soft: #e7f6ed;
  --v7-color-warn:         #ea8a00;   /* 주의 · 자르기 점선 = 주황 */
  --v7-color-warn-soft:    #fef2e0;
  --v7-color-danger:       #dc2626;   /* 차단 · 위험 */
  --v7-color-danger-soft:  #fdeaea;

  /* ---- 텍스트 ---- */
  --v7-text-strong:   #16181d;        /* 제목 */
  --v7-text:          #2b2f38;        /* 본문 */
  --v7-text-muted:    #6b7280;        /* 보조 설명·힌트 */
  --v7-text-faint:    #9aa1ad;        /* placeholder */
  --v7-text-on-brand: #ffffff;        /* 브랜드/위험 버튼 위 글자 */

  /* ---- 배경·표면 ---- */
  --v7-bg-page:       #f4f5f7;        /* 페이지 바닥 */
  --v7-surface:       #ffffff;        /* 카드·모달·패널 본체 */
  --v7-surface-sub:   #f7f8fa;        /* 살짝 들어간 표면(툴바·코드블록 바닥) */
  --v7-surface-hover: #eef1f5;        /* hover 표면 */
  --v7-surface-stage: #0e1116;        /* 어두운 이미지 무대(크게보기) */

  /* ---- 경계선 ---- */
  --v7-border:        #e3e6eb;        /* 기본 경계 */
  --v7-border-strong: #cdd2db;        /* 입력·강조 경계 */
  --v7-border-brand:  var(--v7-color-brand);

  /* ---- 오버레이(모달 뒤 딤) ---- */
  --v7-scrim: rgba(20, 24, 31, 0.55);

  /* ---- 상세페이지 도구 전용 의미색 ---- */
  --v7-color-gold:       #d99a17;   /* 가격·혜택·공식 판매처 배지 강조 */
  --v7-color-gold-soft:  #fbf0d6;
  --v7-banned-bg:        var(--v7-color-danger-soft);  /* 금지어·중국어 잔존 하이라이트 배경 */
  --v7-banned-text:      var(--v7-color-danger);        /* 금지어·중국어 잔존 텍스트 */

  /* 섹션 상태색 (결과 섹션 카드 테두리) */
  --v7-section-empty:      var(--v7-border);          /* 미생성 */
  --v7-section-generating: var(--v7-color-warn);      /* 생성 중(펄스) */
  --v7-section-done:       var(--v7-color-brand);     /* 완료 */
  --v7-section-locked:     var(--v7-color-success);   /* 잠금(확정) */

  /* 신뢰도 신호등 (안전분할 AI 추천선) */
  --v7-confidence-auto:   var(--v7-color-success);  /* 초록 = 자동 OK */
  --v7-confidence-qc:     var(--v7-color-warn);     /* 노랑 = 확인 권장 */
  --v7-confidence-human:  var(--v7-color-danger);   /* 빨강 = 꼭 검토 */

  /* A/S·스펙 다크 섹션(상세페이지 본문 관습) */
  --v7-color-as-bg:     #1a2744;
  --v7-color-as-accent: #64b5f6;

  /* ---- 의미 별칭(semantic aliases) ---- */
  --v7-surface-card:  var(--v7-surface);
  --v7-text-body:     var(--v7-text);
  --v7-text-heading:  var(--v7-text-strong);
  --v7-text-link:     var(--v7-color-accent);
}


/* ==========================================================================
   타이포그래피 토큰 (typography.css)
   --------------------------------------------------------------------------
   본문 = Pretendard. UI 전체 한국어. 14px 기본 본문, 정수 px 스케일.
   ========================================================================== */

:root {
  /* ---- 폰트 패밀리 ---- */
  --v7-font-sans: "Pretendard", -apple-system, BlinkMacSystemFont, "Segoe UI",
                  "Apple SD Gothic Neo", "Malgun Gothic", sans-serif;
  --v7-font-mono: "SFMono-Regular", "Consolas", ui-monospace, monospace;  /* 코드·JSON 미리보기 */

  /* ---- 폰트 크기 ---- */
  --v7-fs-xs:   12px;
  --v7-fs-sm:   13px;
  --v7-fs-base: 14px;   /* 기본 본문 */
  --v7-fs-md:   15px;
  --v7-fs-lg:   17px;
  --v7-fs-xl:   20px;   /* 모달·섹션 제목 */
  --v7-fs-2xl:  24px;
  --v7-fs-3xl:  30px;   /* 디스플레이 */
  --v7-fs-4xl:  38px;   /* 큰 디스플레이 */

  /* ---- 폰트 두께 ---- */
  --v7-fw-regular:  400;   /* @kind font */
  --v7-fw-medium:   500;   /* @kind font */
  --v7-fw-semibold: 600;   /* @kind font */
  --v7-fw-bold:     700;   /* @kind font */
  --v7-fw-extrabold:800;   /* @kind font */
  --v7-fw-black:    900;   /* @kind font */

  /* ---- 행간 ---- */
  --v7-lh-tight:   1.25;   /* @kind font */
  --v7-lh-snug:    1.4;    /* @kind font */
  --v7-lh-normal:  1.5;    /* @kind font */
  --v7-lh-relaxed: 1.65;   /* @kind font */

  /* ---- 자간 ---- */
  --v7-ls-tight:  -0.02em; /* @kind font */
  --v7-ls-normal: 0;       /* @kind font */
  --v7-ls-wide:   0.04em;  /* @kind font */ /* 작은 대문자 라벨(eyebrow)용 */
}


/* ==========================================================================
   스페이싱·라운드·그림자·모션 토큰 (spacing.css)
   --------------------------------------------------------------------------
   4px 베이스 간격 스케일 + 라운드 + 부드러운 한국형 카드 그림자 + 모션.
   ========================================================================== */

:root {
  /* ---- 간격 (4px 베이스) ---- */
  --v7-space-0:  0;
  --v7-space-1:  4px;
  --v7-space-2:  8px;
  --v7-space-3:  12px;
  --v7-space-4:  16px;
  --v7-space-5:  20px;
  --v7-space-6:  24px;
  --v7-space-8:  32px;
  --v7-space-10: 40px;
  --v7-space-12: 48px;
  --v7-space-16: 64px;

  /* ---- 라운드(radius) ---- */
  --v7-radius-sm:   6px;
  --v7-radius-md:   10px;   /* 버튼·입력 */
  --v7-radius-lg:   14px;   /* 카드 */
  --v7-radius-xl:   20px;   /* 모달·큰 패널 */
  --v7-radius-full: 999px;  /* 칩·핀·토글 */

  /* ---- 그림자 (부드러운 한국형 카드) ---- */
  --v7-shadow-sm: 0 1px 2px rgba(20, 24, 31, 0.06),
                  0 1px 3px rgba(20, 24, 31, 0.08);
  --v7-shadow-md: 0 4px 12px rgba(20, 24, 31, 0.08),
                  0 2px 4px rgba(20, 24, 31, 0.06);
  --v7-shadow-lg: 0 12px 32px rgba(20, 24, 31, 0.14),
                  0 4px 10px rgba(20, 24, 31, 0.10);
  --v7-shadow-modal: 0 24px 64px rgba(16, 20, 28, 0.28),
                     0 8px 20px rgba(16, 20, 28, 0.16);
  --v7-shadow-focus: 0 0 0 3px var(--v7-color-brand-soft);  /* focus ring */

  /* ---- 모션 ---- */
  --v7-ease:       cubic-bezier(0.22, 0.61, 0.36, 1);  /* @kind other */
  --v7-dur-fast:   120ms;  /* @kind other */
  --v7-dur-normal: 200ms;  /* @kind other */
  --v7-dur-slow:   320ms;  /* @kind other */

  /* ---- z-index 단계 ---- */
  --v7-z-base:        0;     /* @kind other */
  --v7-z-sticky:      100;   /* @kind other */
  --v7-z-modal-scrim: 1000;  /* @kind other */
  --v7-z-modal:       1001;  /* @kind other */
  --v7-z-toast:       1100;  /* @kind other */
}

@media (prefers-reduced-motion: reduce) {
  :root {
    --v7-dur-fast: 0ms;   /* @kind other */
    --v7-dur-normal: 0ms; /* @kind other */
    --v7-dur-slow: 0ms;   /* @kind other */
  }
}


/* ==========================================================================
   컴포넌트 (components.css)
   --------------------------------------------------------------------------
   바닐라 HTML/CSS 컴포넌트 라이브러리. 클래스만 붙이면 통일된 UI.
   모든 값은 tokens/*.css 의 CSS 변수만 사용 (하드코딩 색 금지).
   prefix = .v7-*  (사장님 실제 코드와 drop-in 호환)
   ──────────────────────────────────────────────────────────────────────────
   목차
     1. 버튼 / 아이콘 버튼
     2. 폼 (필드·인풋·텍스트영역·셀렉트·토글·체크/라디오)
     3. 배지 / 태그 / 칩
     4. 카드 / 패널 / 모드 카드
     5. 듀얼리티 (원본 ↔ 한국화 비교)
     6. 진행 상태 / 게이트 / 스텝
     7. 탭 / 세그먼트
     8. 토스트
   ========================================================================== */

/* ──────────────────────────────────────────────────────────────────────────
   1. 버튼
   ────────────────────────────────────────────────────────────────────────── */
.v7-btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--v7-space-2);
  height: 38px;
  padding: 0 var(--v7-space-4);
  font-family: var(--v7-font-sans);
  font-size: var(--v7-fs-base);
  font-weight: var(--v7-fw-semibold);
  line-height: 1;
  color: var(--v7-text);
  background: var(--v7-surface);
  border: 1px solid var(--v7-border-strong);
  border-radius: var(--v7-radius-md);
  cursor: pointer;
  white-space: nowrap;
  transition: background var(--v7-dur-fast) var(--v7-ease),
              border-color var(--v7-dur-fast) var(--v7-ease),
              color var(--v7-dur-fast) var(--v7-ease),
              transform var(--v7-dur-fast) var(--v7-ease);
}
.v7-btn:hover  { background: var(--v7-surface-hover); }
.v7-btn:active { transform: translateY(1px); }
.v7-btn:disabled { opacity: 0.45; cursor: not-allowed; }
.v7-btn:disabled:active { transform: none; }

.v7-btn--primary {
  color: var(--v7-text-on-brand);
  background: var(--v7-color-brand);
  border-color: var(--v7-color-brand);
}
.v7-btn--primary:hover { background: var(--v7-color-brand-strong); border-color: var(--v7-color-brand-strong); }

.v7-btn--ghost {
  background: transparent;
  border-color: transparent;
  color: var(--v7-text-muted);
}
.v7-btn--ghost:hover { background: var(--v7-surface-hover); color: var(--v7-text); }

.v7-btn--danger {
  color: var(--v7-text-on-brand);
  background: var(--v7-color-danger);
  border-color: var(--v7-color-danger);
}
.v7-btn--danger:hover { filter: brightness(0.94); }

.v7-btn--source {
  color: var(--v7-text-on-brand);
  background: var(--v7-color-source);
  border-color: var(--v7-color-source);
}
.v7-btn--source:hover { background: var(--v7-color-source-strong); border-color: var(--v7-color-source-strong); }

.v7-btn--sm  { height: 32px; padding: 0 var(--v7-space-3); font-size: var(--v7-fs-sm); }
.v7-btn--lg  { height: 46px; padding: 0 var(--v7-space-6); font-size: var(--v7-fs-md); }
.v7-btn--block { width: 100%; }

/* 아이콘 전용 버튼(닫기 ✕ 등) — 정사각 hit-zone */
.v7-iconbtn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  padding: 0;
  font-size: var(--v7-fs-lg);
  color: var(--v7-text-muted);
  background: transparent;
  border: none;
  border-radius: var(--v7-radius-md);
  cursor: pointer;
  transition: background var(--v7-dur-fast) var(--v7-ease), color var(--v7-dur-fast) var(--v7-ease);
}
.v7-iconbtn:hover { background: var(--v7-surface-hover); color: var(--v7-text-strong); }
.v7-iconbtn--sm { width: 28px; height: 28px; font-size: var(--v7-fs-base); }

/* ──────────────────────────────────────────────────────────────────────────
   2. 폼
   ────────────────────────────────────────────────────────────────────────── */
.v7-field { margin-bottom: var(--v7-space-4); }
.v7-field__label {
  display: block;
  font-size: var(--v7-fs-sm);
  font-weight: var(--v7-fw-semibold);
  color: var(--v7-text-strong);
  margin-bottom: var(--v7-space-2);
}
.v7-field__label .req { color: var(--v7-color-danger); margin-left: 2px; }
.v7-field__hint { margin-top: var(--v7-space-2); font-size: var(--v7-fs-xs); color: var(--v7-text-faint); }

.v7-input, .v7-textarea, .v7-select {
  width: 100%;
  padding: 9px 11px;
  font-family: var(--v7-font-sans);
  font-size: var(--v7-fs-base);
  color: var(--v7-text);
  background: var(--v7-surface);
  border: 1.5px solid var(--v7-border-strong);
  border-radius: var(--v7-radius-md);
  transition: border-color var(--v7-dur-fast) var(--v7-ease), box-shadow var(--v7-dur-fast) var(--v7-ease);
}
.v7-input { height: 40px; }
.v7-textarea { min-height: 80px; resize: vertical; line-height: var(--v7-lh-normal); }
.v7-input::placeholder, .v7-textarea::placeholder { color: var(--v7-text-faint); }
.v7-input:focus, .v7-textarea:focus, .v7-select:focus {
  outline: none;
  border-color: var(--v7-color-brand);
  box-shadow: var(--v7-shadow-focus);
}
.v7-input:disabled, .v7-textarea:disabled, .v7-select:disabled {
  background: var(--v7-surface-sub); color: var(--v7-text-faint); cursor: not-allowed;
}
.v7-input--invalid, .v7-textarea--invalid { border-color: var(--v7-color-danger); }
.v7-input--invalid:focus { box-shadow: 0 0 0 3px var(--v7-color-danger-soft); }

.v7-select {
  height: 40px;
  appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 11px center;
  padding-right: 34px;
  cursor: pointer;
}

/* 토글 스위치 */
.v7-toggle { display: inline-flex; align-items: center; gap: var(--v7-space-2); cursor: pointer; user-select: none; }
.v7-toggle input { display: none; }
.v7-toggle__track {
  width: 38px; height: 22px; flex: 0 0 auto;
  border-radius: var(--v7-radius-full);
  background: var(--v7-border-strong);
  position: relative;
  transition: background var(--v7-dur-fast) var(--v7-ease);
}
.v7-toggle__track::after {
  content: ""; position: absolute; top: 2px; left: 2px;
  width: 18px; height: 18px; border-radius: var(--v7-radius-full);
  background: #fff; box-shadow: var(--v7-shadow-sm);
  transition: transform var(--v7-dur-fast) var(--v7-ease);
}
.v7-toggle input:checked + .v7-toggle__track { background: var(--v7-color-brand); }
.v7-toggle input:checked + .v7-toggle__track::after { transform: translateX(16px); }
.v7-toggle input:disabled + .v7-toggle__track { opacity: 0.5; }
.v7-toggle__label { font-size: var(--v7-fs-sm); color: var(--v7-text); }

/* 체크박스 / 라디오 (커스텀) */
.v7-check, .v7-radio { display: inline-flex; align-items: center; gap: var(--v7-space-2); cursor: pointer; user-select: none; font-size: var(--v7-fs-sm); color: var(--v7-text); }
.v7-check input, .v7-radio input { display: none; }
.v7-check__box, .v7-radio__box {
  width: 18px; height: 18px; flex: 0 0 auto;
  border: 2px solid var(--v7-border-strong);
  background: var(--v7-surface);
  position: relative;
  transition: border-color var(--v7-dur-fast) var(--v7-ease), background var(--v7-dur-fast) var(--v7-ease);
}
.v7-check__box { border-radius: var(--v7-radius-sm); }
.v7-radio__box { border-radius: var(--v7-radius-full); }
.v7-check input:checked + .v7-check__box {
  background: var(--v7-color-brand); border-color: var(--v7-color-brand);
}
.v7-check input:checked + .v7-check__box::after {
  content: ""; position: absolute; left: 5px; top: 1px;
  width: 4px; height: 9px; border: solid #fff; border-width: 0 2px 2px 0;
  transform: rotate(45deg);
}
.v7-radio input:checked + .v7-radio__box { border-color: var(--v7-color-brand); }
.v7-radio input:checked + .v7-radio__box::after {
  content: ""; position: absolute; inset: 3px; border-radius: var(--v7-radius-full);
  background: var(--v7-color-brand);
}

/* ──────────────────────────────────────────────────────────────────────────
   3. 배지 / 태그 / 칩
   ────────────────────────────────────────────────────────────────────────── */
.v7-badge {
  display: inline-flex; align-items: center; gap: 4px;
  height: 22px; padding: 0 var(--v7-space-2);
  font-size: var(--v7-fs-xs); font-weight: var(--v7-fw-bold);
  border-radius: var(--v7-radius-full);
  color: var(--v7-text-muted); background: var(--v7-surface-hover);
  white-space: nowrap;
}
.v7-badge--brand    { color: var(--v7-color-brand);   background: var(--v7-color-brand-soft); }
.v7-badge--source   { color: var(--v7-color-source);  background: var(--v7-color-source-soft); }
.v7-badge--success  { color: var(--v7-color-success); background: var(--v7-color-success-soft); }
.v7-badge--warn     { color: var(--v7-color-warn);    background: var(--v7-color-warn-soft); }
.v7-badge--danger   { color: var(--v7-color-danger);  background: var(--v7-color-danger-soft); }
.v7-badge--solid    { color: #fff; background: var(--v7-color-brand); }
.v7-badge--dot::before {
  content: ""; width: 6px; height: 6px; border-radius: var(--v7-radius-full);
  background: currentColor; flex: 0 0 auto;
}

/* 태그(닫기 가능) */
.v7-tag {
  display: inline-flex; align-items: center; gap: 6px;
  height: 26px; padding: 0 var(--v7-space-3);
  font-size: var(--v7-fs-xs); font-weight: var(--v7-fw-semibold);
  color: var(--v7-text); background: var(--v7-surface-sub);
  border: 1px solid var(--v7-border);
  border-radius: var(--v7-radius-full);
}
.v7-tag__x { cursor: pointer; color: var(--v7-text-faint); font-size: var(--v7-fs-sm); }
.v7-tag__x:hover { color: var(--v7-color-danger); }

/* 칩(선택형) */
.v7-chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px var(--v7-space-3);
  font-size: var(--v7-fs-xs); font-weight: var(--v7-fw-semibold);
  color: var(--v7-text);
  background: var(--v7-surface);
  border: 1.5px solid var(--v7-border-strong);
  border-radius: var(--v7-radius-full);
  cursor: pointer; user-select: none;
  transition: border-color var(--v7-dur-fast) var(--v7-ease), background var(--v7-dur-fast) var(--v7-ease);
}
.v7-chip:hover { border-color: var(--v7-color-brand); background: var(--v7-color-brand-soft); }
.v7-chip.is-active { border-color: var(--v7-color-brand); background: var(--v7-color-brand-soft); color: var(--v7-color-brand-strong); }

/* ──────────────────────────────────────────────────────────────────────────
   4. 카드 / 패널 / 모드 카드
   ────────────────────────────────────────────────────────────────────────── */
.v7-card {
  background: var(--v7-surface);
  border: 1px solid var(--v7-border);
  border-radius: var(--v7-radius-lg);
  box-shadow: var(--v7-shadow-sm);
}
.v7-card--pad { padding: var(--v7-space-5); }
.v7-card--flat { box-shadow: none; }
.v7-card--hover { transition: box-shadow var(--v7-dur-normal) var(--v7-ease), transform var(--v7-dur-normal) var(--v7-ease); }
.v7-card--hover:hover { box-shadow: var(--v7-shadow-md); transform: translateY(-2px); }

.v7-panel {
  background: var(--v7-surface);
  border: 1px solid var(--v7-border);
  border-radius: var(--v7-radius-xl);
  box-shadow: var(--v7-shadow-md);
}

/* 모드 선택 카드(라디오형 큰 카드) */
.v7-mode {
  display: flex; align-items: flex-start; gap: var(--v7-space-3);
  padding: var(--v7-space-4);
  border: 1.5px solid var(--v7-border);
  border-radius: var(--v7-radius-lg);
  background: var(--v7-surface);
  cursor: pointer;
  transition: border-color var(--v7-dur-fast) var(--v7-ease), background var(--v7-dur-fast) var(--v7-ease);
}
.v7-mode:hover { border-color: var(--v7-border-strong); }
.v7-mode.is-active { border-color: var(--v7-color-brand); background: var(--v7-color-brand-soft); }
.v7-mode.is-disabled { opacity: 0.55; cursor: not-allowed; }
.v7-mode.is-disabled:hover { border-color: var(--v7-border); }
.v7-mode__radio {
  flex: 0 0 auto; width: 18px; height: 18px; margin-top: 2px;
  border: 2px solid var(--v7-border-strong); border-radius: var(--v7-radius-full);
  position: relative;
}
.v7-mode.is-active .v7-mode__radio { border-color: var(--v7-color-brand); }
.v7-mode.is-active .v7-mode__radio::after {
  content: ""; position: absolute; inset: 3px; border-radius: var(--v7-radius-full);
  background: var(--v7-color-brand);
}
.v7-mode__name { font-size: var(--v7-fs-md); font-weight: var(--v7-fw-bold); color: var(--v7-text-strong); }
.v7-mode__desc { margin-top: 3px; font-size: var(--v7-fs-sm); color: var(--v7-text-muted); line-height: var(--v7-lh-normal); }

/* ──────────────────────────────────────────────────────────────────────────
   5. 듀얼리티 — 원본(중국) ↔ 한국화 결과 비교
   ────────────────────────────────────────────────────────────────────────── */
.v7-compare { display: grid; grid-template-columns: 1fr 1fr; gap: var(--v7-space-5); }
.v7-compare__col { display: flex; flex-direction: column; gap: var(--v7-space-3); min-width: 0; }
.v7-compare__head {
  display: flex; align-items: center; gap: var(--v7-space-2);
  font-size: var(--v7-fs-sm); font-weight: var(--v7-fw-bold);
}
.v7-compare__col--source .v7-compare__head { color: var(--v7-color-source); }
.v7-compare__col--localized .v7-compare__head { color: var(--v7-color-brand); }
.v7-compare__frame {
  border: 1px solid var(--v7-border);
  border-radius: var(--v7-radius-lg);
  overflow: hidden;
  background: var(--v7-surface-sub);
}
.v7-compare__col--source .v7-compare__frame { border-color: color-mix(in srgb, var(--v7-color-source) 35%, var(--v7-border)); }
.v7-compare__col--localized .v7-compare__frame { border-color: color-mix(in srgb, var(--v7-color-brand) 35%, var(--v7-border)); }
@media (max-width: 720px) { .v7-compare { grid-template-columns: 1fr; } }

/* ──────────────────────────────────────────────────────────────────────────
   6. 진행 상태 / 게이트 / 스텝
   ────────────────────────────────────────────────────────────────────────── */
.v7-progress { padding: var(--v7-space-4); border: 1px solid var(--v7-border); border-radius: var(--v7-radius-lg); background: var(--v7-surface-sub); }
.v7-progress__label { display: flex; justify-content: space-between; margin-bottom: var(--v7-space-2); font-size: var(--v7-fs-sm); }
.v7-progress__label .pct { font-weight: var(--v7-fw-bold); color: var(--v7-color-brand); }
.v7-progress__bar { height: 8px; border-radius: var(--v7-radius-full); background: var(--v7-border); overflow: hidden; }
.v7-progress__fill {
  height: 100%; width: 0%;
  background: linear-gradient(90deg, var(--v7-color-brand), var(--v7-color-accent));
  transition: width var(--v7-dur-slow) var(--v7-ease);
}

/* 스텝 목록 */
.v7-step { display: flex; align-items: center; gap: var(--v7-space-2); font-size: var(--v7-fs-sm); color: var(--v7-text-muted); }
.v7-step .dot { width: 7px; height: 7px; border-radius: var(--v7-radius-full); background: var(--v7-border-strong); flex: 0 0 auto; }
.v7-step.is-active { color: var(--v7-text); font-weight: var(--v7-fw-semibold); }
.v7-step.is-active .dot { background: var(--v7-color-warn); }
.v7-step.is-done { color: var(--v7-text); }
.v7-step.is-done .dot { background: var(--v7-color-success); }

/* 번호 스텝 핀(섹션 헤더용) */
.v7-stepnum {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: var(--v7-radius-full);
  background: var(--v7-color-brand); color: #fff;
  font-size: 11px; font-weight: var(--v7-fw-bold); flex: 0 0 auto;
}
.v7-stepnum--idle    { background: var(--v7-border-strong); }
.v7-stepnum--running { background: var(--v7-color-warn); }
.v7-stepnum--done    { background: var(--v7-color-success); }
.v7-stepnum--error   { background: var(--v7-color-danger); }

/* 게이트(검증) 행 */
.v7-gate {
  display: flex; align-items: center; gap: var(--v7-space-2);
  padding: var(--v7-space-3) var(--v7-space-4);
  border-radius: var(--v7-radius-md);
  font-size: var(--v7-fs-sm);
}
.v7-gate--pass  { background: var(--v7-color-success-soft); color: var(--v7-color-success); }
.v7-gate--warn  { background: var(--v7-color-warn-soft);    color: var(--v7-color-warn); }
.v7-gate--block { background: var(--v7-color-danger-soft);  color: var(--v7-color-danger); }
.v7-gate b { font-weight: var(--v7-fw-bold); }

/* 등급 배지(S/A/B/C) */
.v7-grade {
  display: inline-flex; align-items: center; justify-content: center;
  width: 52px; height: 52px; border-radius: var(--v7-radius-lg);
  font-size: 28px; font-weight: var(--v7-fw-black); color: #fff; flex: 0 0 auto;
}
.v7-grade--s { background: var(--v7-color-brand); }
.v7-grade--a { background: var(--v7-color-success); }
.v7-grade--b { background: var(--v7-color-warn); }
.v7-grade--c { background: var(--v7-color-danger); }

/* ──────────────────────────────────────────────────────────────────────────
   7. 탭 / 세그먼트
   ────────────────────────────────────────────────────────────────────────── */
.v7-tabs { display: flex; align-items: center; gap: 2px; border-bottom: 1px solid var(--v7-border); }
.v7-tab {
  padding: 12px var(--v7-space-4);
  font-size: var(--v7-fs-sm); font-weight: var(--v7-fw-semibold);
  color: var(--v7-text-muted); cursor: pointer;
  border-bottom: 2px solid transparent;
  transition: color var(--v7-dur-fast) var(--v7-ease), border-color var(--v7-dur-fast) var(--v7-ease);
  user-select: none;
}
.v7-tab:hover { color: var(--v7-text); }
.v7-tab.is-active { color: var(--v7-color-brand); border-bottom-color: var(--v7-color-brand); }

/* 세그먼트 컨트롤 */
.v7-segment { display: inline-flex; padding: 3px; gap: 2px; background: var(--v7-surface-sub); border: 1px solid var(--v7-border); border-radius: var(--v7-radius-md); }
.v7-segment__item {
  padding: 6px var(--v7-space-4); border-radius: var(--v7-radius-sm);
  font-size: var(--v7-fs-sm); font-weight: var(--v7-fw-semibold);
  color: var(--v7-text-muted); cursor: pointer; user-select: none;
  transition: background var(--v7-dur-fast) var(--v7-ease), color var(--v7-dur-fast) var(--v7-ease);
}
.v7-segment__item.is-active { background: var(--v7-surface); color: var(--v7-text-strong); box-shadow: var(--v7-shadow-sm); }

/* ──────────────────────────────────────────────────────────────────────────
   8. 토스트
   ────────────────────────────────────────────────────────────────────────── */
.v7-toast {
  display: inline-flex; align-items: center; gap: var(--v7-space-2);
  padding: var(--v7-space-3) var(--v7-space-5);
  border-radius: var(--v7-radius-md);
  background: var(--v7-text-strong); color: #fff; font-size: var(--v7-fs-sm);
  box-shadow: var(--v7-shadow-lg);
}
.v7-toast--success { background: var(--v7-color-success); }
.v7-toast--error   { background: var(--v7-color-danger); }
