:root {
  --bg: #f4f5f7;
  --card: #ffffff;
  --ink: #1a1f2e;
  --muted: #6b7280;
  --primary: #0b3d91;
  --primary-ink: #ffffff;
  --border: #e5e7eb;
  --ok: #047857;
  --err: #b91c1c;
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; background: var(--bg); color: var(--ink); font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif; }
body { padding: env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left); }

header { padding: 24px 20px 8px; }
header h1 { margin: 0; font-size: 24px; }
.muted { color: var(--muted); margin: 4px 0 0; font-size: 13px; }

main { padding: 12px 16px 24px; max-width: 600px; margin: 0 auto; }

.step { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 16px; margin-bottom: 12px; }
.step h2 { margin: 0 0 12px; font-size: 16px; font-weight: 600; display: flex; align-items: center; gap: 10px; }
.num { display: inline-flex; width: 24px; height: 24px; border-radius: 50%; background: var(--primary); color: var(--primary-ink); align-items: center; justify-content: center; font-size: 13px; }

.file-drop { display: block; border: 2px dashed var(--border); border-radius: 10px; padding: 18px; text-align: center; cursor: pointer; color: var(--muted); }
.file-drop input { display: none; }
.file-drop.has-file { border-color: var(--primary); color: var(--ink); background: #f0f5ff; }

.file-list { list-style: none; padding: 0; margin: 12px 0 0; font-size: 14px; }
.file-list li { display: flex; justify-content: space-between; padding: 6px 0; border-bottom: 1px solid var(--border); }
.file-list li:last-child { border-bottom: 0; }
.file-list .size { color: var(--muted); font-size: 12px; }

.row { display: grid; grid-template-columns: 1fr 1fr; gap: 12px; }
label { display: block; font-size: 13px; color: var(--muted); }
label input { width: 100%; margin-top: 4px; padding: 10px; font-size: 16px; border: 1px solid var(--border); border-radius: 8px; background: white; color: var(--ink); }

button.primary { width: 100%; padding: 14px; font-size: 16px; font-weight: 600; background: var(--primary); color: var(--primary-ink); border: 0; border-radius: 12px; margin-top: 4px; }
button.primary:disabled { opacity: 0.5; }

.status { margin-top: 16px; padding: 14px; border-radius: 10px; font-size: 14px; }
.status.info { background: #eff6ff; color: #1e3a8a; }
.status.ok { background: #ecfdf5; color: var(--ok); }
.status.err { background: #fef2f2; color: var(--err); white-space: pre-wrap; }
.hidden { display: none; }

footer { text-align: center; color: var(--muted); padding: 12px; font-size: 11px; }

/* ===== Review view ===== */
#review-view { padding: 8px 12px 90px; max-width: 760px; margin: 0 auto; }
.review-bar { display: flex; align-items: center; gap: 10px; padding: 8px 4px; position: sticky; top: 0; background: var(--bg); z-index: 5; }
.review-bar strong { flex: 1; font-size: 16px; }
button.ghost { background: none; border: 0; color: var(--primary); font-size: 15px; font-weight: 600; }
button.small { width: auto; padding: 9px 14px; font-size: 14px; margin: 0; }

.tabs { display: flex; gap: 6px; margin: 4px 0 12px; }
.tab { flex: 1; padding: 10px; border: 1px solid var(--border); background: var(--card); border-radius: 10px; font-size: 14px; font-weight: 600; color: var(--muted); }
.tab.active { background: var(--primary); color: #fff; border-color: var(--primary); }

.panel { }
.prompt-box { background: var(--card); border: 1px solid var(--border); border-radius: 12px; padding: 12px; margin-bottom: 12px; }
.prompt-box textarea { width: 100%; border: 1px solid var(--border); border-radius: 8px; padding: 10px; font-size: 15px; resize: vertical; font-family: inherit; }
.prompt-actions { display: flex; align-items: center; gap: 12px; margin-top: 8px; flex-wrap: wrap; }
.chk { font-size: 13px; color: var(--muted); display: flex; align-items: center; gap: 6px; }

.field { background: var(--card); border: 1px solid var(--border); border-radius: 10px; padding: 10px 12px; margin-bottom: 8px; }
.field.missing { border-color: #f59e0b; background: #fffbeb; }
.field-label { font-size: 12px; font-weight: 700; color: var(--primary); text-transform: uppercase; letter-spacing: .02em; margin-bottom: 6px; }
.field textarea { width: 100%; border: 1px solid var(--border); border-radius: 8px; padding: 8px; font-size: 15px; font-family: inherit; resize: vertical; }

.docx-host { background: #fff; border: 1px solid var(--border); border-radius: 8px; margin-top: 10px; overflow: auto; max-height: 70vh; }
.docx-host .docx-wrapper { background: #fff; padding: 0; }
.docx-host section.docx { box-shadow: none !important; margin: 0 auto !important; }

.export-bar { position: fixed; left: 0; right: 0; bottom: 0; padding: 10px 14px calc(10px + env(safe-area-inset-bottom)); background: var(--card); border-top: 1px solid var(--border); }
.export-bar button { max-width: 760px; margin: 0 auto; display: block; }
