/* ============================================================
   diff-viewer.css — Stellia Diff Viewer 専用スタイル
   ------------------------------------------------------------
   色・形状は theme.css / base.css のデザイントークンを参照する。
   このファイルに色を直書きしない（差分の地色は既存 --diff-* を
   color-mix で薄めて使う）。エディターとペインの平仄を取る。
   ============================================================ */

/* レイアウトはエディターと同じ .app（base.css）に委譲。広告レール分の
   左右マージン（184px）も .app が持つので body 側のハックは不要。 */

/* ---- 上部バー ---- */
.dv-top {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 14px;
  background: var(--panel-translucent);
  border-bottom: 1px solid var(--border);
  box-shadow: var(--shadow);
}
.dv-brand {
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 800;
  color: var(--brand-ink);
  font-size: 15px;
  white-space: nowrap;
}
.dv-brand img { width: 24px; height: 24px; border-radius: 6px; }
.dv-actions { display: flex; align-items: center; gap: 8px; margin-left: auto; }

/* ---- ボタン（base のボタントークンに平仄）---- */
.dv-btn {
  border: 1px solid var(--border);
  background: var(--button-bg);
  color: var(--text);
  border-radius: var(--btn-radius-sm);
  font-size: var(--btn-font-sm);
  font-weight: var(--btn-weight);
  padding: 6px 12px;
  cursor: pointer;
  transition: var(--btn-transition);
}
.dv-btn:hover { background: var(--brand-tint-2); border-color: var(--brand-border); }
.dv-btn.primary {
  border-color: transparent;
  background: var(--button-primary-bg);
  color: #fff;
}
.dv-btn.primary:hover { background: var(--button-primary-bg-hover); }
.dv-btn:disabled { opacity: var(--btn-disabled-op); cursor: default; }
.dv-icon-btn {
  width: 32px; height: 32px; padding: 0;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 16px; line-height: 1;
}
.dv-theme {
  padding: 6px 26px 6px 10px;
  cursor: pointer;
  appearance: none;
  background-color: var(--surface);
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 12 12'%3E%3Cpath d='M2 4l4 4 4-4' fill='none' stroke='%237d7f85' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right 8px center;
  background-size: 11px;
}
.dv-theme[hidden] { display: none; }

/* ---- 2ファイル入力欄 ---- */
.dv-files {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
  padding: 10px 14px;
}
.dv-file {
  border: 1.5px dashed var(--border);
  border-radius: var(--radius);
  background: var(--surface);
  padding: 10px 12px;
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 52px;
  transition: var(--btn-transition);
}
.dv-file.dragover { border-color: var(--brand); background: var(--brand-tint-1); }
.dv-file.loaded { border-style: solid; }
.dv-side-tag {
  flex: none;
  width: 22px; height: 22px;
  display: inline-flex; align-items: center; justify-content: center;
  border-radius: 6px;
  font-weight: 800; font-size: 12px;
  background: var(--brand-tint-3); color: var(--brand-ink);
}
.dv-file-name {
  flex: 1 1 auto;
  min-width: 0;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
  color: var(--text); font-size: 13px; font-weight: 600;
}
.dv-file-name.empty { color: var(--muted); font-weight: 400; }
.dv-file-meta { flex: none; color: var(--muted); font-size: 11px; }

/* ---- 差分結果 ---- */
.dv-result {
  flex: 1 1 auto;
  min-height: 0;
  overflow: auto;
  background: var(--surface);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
}
.dv-empty {
  display: flex; align-items: center; justify-content: center;
  height: 100%; color: var(--muted); font-size: 14px; text-align: center;
  padding: 24px;
}
.dv-table {
  border-collapse: collapse;
  width: 100%;
  table-layout: fixed;
  font-family: var(--editor-font);
  font-size: 13px;
  line-height: 1.6;
}
.dv-table td {
  padding: 0 8px;
  vertical-align: top;
  white-space: pre-wrap;
  word-break: break-word;
}
.dv-table td.ln {
  width: 52px;
  text-align: right;
  color: var(--gutter-fg);
  background: var(--gutter-bg);
  border-right: 1px solid var(--border);
  user-select: none;
}
.dv-table td.tx { border-right: 1px solid transparent; }
.dv-table tr.row-add td.tx:last-child,
.dv-table tr.row-add td.ln:nth-child(3) { background: color-mix(in srgb, var(--diff-add) 15%, transparent); }
.dv-table tr.row-del td.tx:first-of-type,
.dv-table tr.row-del td.ln:first-child { background: color-mix(in srgb, var(--diff-del) 15%, transparent); }
.dv-table tr.row-change td.tx { background: color-mix(in srgb, var(--warn-border) 14%, transparent); }
.dv-table .wd-del { background: color-mix(in srgb, var(--diff-del) 38%, transparent); border-radius: 2px; }
.dv-table .wd-add { background: color-mix(in srgb, var(--diff-add) 38%, transparent); border-radius: 2px; }

/* inline（unified）表示 */
.dv-table.inline td.tx-b, .dv-table.inline td.ln-b { display: none; }
.dv-table.inline tr.row-del td.tx { background: color-mix(in srgb, var(--diff-del) 15%, transparent); }
.dv-table.inline tr.row-add td.tx { background: color-mix(in srgb, var(--diff-add) 15%, transparent); }

/* ---- サマリ帯 ---- */
/* 差分サマリ：エディター下部の「N 文字 · N 語 · N 行」と同じ見た目。
   右寄せ・薄いミュート文字・地色/区切り線なし・「·」区切り。 */
.dv-summary {
  display: flex;
  align-items: center;
  justify-content: flex-end; /* 右寄せ */
  height: 20px;
  padding: 0 4px;
  font-size: 12px;
  color: var(--muted);
}
.dv-summary > span { display: inline-flex; align-items: center; gap: 4px; }
.dv-summary > span:not(:first-child) { margin-left: 8px; }
.dv-summary > span:not(:first-child)::before { content: "·"; margin-right: 8px; color: var(--muted); }
.dv-summary b { font-weight: 700; }
.dv-summary .s-add { color: var(--ok); }
.dv-summary .s-del { color: var(--danger); }
.dv-summary .s-chg { color: var(--warn); }

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

/* ============================================================
   diff-dialog — エディターから iframe 埋め込みで開くモーダル
   （index.html 側で使用。ペインの平仄を取り、ほぼ全画面）
   ============================================================ */
.diff-dialog {
  width: min(1180px, 94vw);
  height: 88vh;
  max-width: 94vw;
  max-height: 92vh;
  padding: 0;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  background: var(--panel);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
}
.diff-dialog::backdrop { background: rgba(15, 23, 42, .38); }
.diff-dialog .diff-dialog-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--soft);
  border-bottom: 1px solid var(--border);
}
.diff-dialog-title { font-weight: 800; color: var(--brand-ink); font-size: 14px; }
.diff-dialog-actions { margin-left: auto; display: flex; gap: 6px; }
.diff-head-btn {
  width: 30px; height: 30px;
  display: inline-flex; align-items: center; justify-content: center;
  border: 1px solid var(--border);
  background: var(--button-bg);
  color: var(--text);
  border-radius: var(--btn-radius-sm);
  font-size: 15px; line-height: 1;
  cursor: pointer;
  transition: var(--btn-transition);
}
.diff-head-btn:hover { background: var(--brand-tint-2); border-color: var(--brand-border); }
.diff-dialog-frame {
  display: block;
  width: 100%;
  height: calc(88vh - 47px);
  border: 0;
  background: var(--surface);
}
