:root{
  --paper:#F4F3EE;       /* nền giấy lạnh */
  --card:#FFFFFF;
  --ink:#1B1B19;         /* mực gần đen */
  --ink-soft:#56544E;
  --line:#DEDCD3;
  --red:#8A1C1C;         /* đỏ công vụ trầm */
  --red-deep:#6E1414;
  --gold:#9A7B2E;        /* dấu son trầm */
  --ok:#1F6B3B;
  --bg-soft:#ECEAE2;
  --radius:10px;
  --shadow:0 1px 2px rgba(27,27,25,.05),0 8px 24px rgba(27,27,25,.06);
  --mono:"SFMono-Regular",Consolas,"Liberation Mono",monospace;
  --sans:"Inter",system-ui,-apple-system,"Segoe UI",Roboto,"Helvetica Neue",Arial,sans-serif;
  --serif:"Times New Roman",Times,serif;
}
*{box-sizing:border-box}
html,body{margin:0}
body{
  font-family:var(--sans);color:var(--ink);background:var(--paper);
  line-height:1.55;font-size:15px;-webkit-font-smoothing:antialiased;
}
a{color:var(--red);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- Letterhead / header ---------- */
.masthead{border-bottom:2px solid var(--ink);background:var(--paper)}
.masthead__inner{max-width:1040px;margin:0 auto;padding:18px 20px;display:flex;align-items:center;gap:14px;flex-wrap:wrap}
.seal{width:38px;height:38px;border-radius:50%;border:2px solid var(--red);
  display:grid;place-items:center;color:var(--red);font-weight:800;font-size:18px;flex:none}
.brand{display:flex;flex-direction:column;line-height:1.2}
.brand b{font-size:18px;letter-spacing:.2px}
.brand span{font-size:12px;color:var(--ink-soft);text-transform:uppercase;letter-spacing:.12em}
.masthead__right{margin-left:auto;font-size:12px;color:var(--ink-soft);text-align:right}

/* ---------- Tabs ---------- */
.tabs{max-width:1040px;margin:0 auto;padding:0 20px;display:flex;gap:2px;border-bottom:1px solid var(--line)}
.tab{appearance:none;border:0;background:transparent;cursor:pointer;
  padding:14px 18px;font:inherit;font-weight:600;color:var(--ink-soft);
  border-bottom:2px solid transparent;margin-bottom:-1px}
.tab .n{font-family:var(--mono);font-size:11px;color:var(--gold);margin-right:8px}
.tab:hover{color:var(--ink)}
.tab[aria-selected="true"]{color:var(--ink);border-bottom-color:var(--red)}

/* ---------- Layout ---------- */
.wrap{max-width:1040px;margin:0 auto;padding:26px 20px 60px}
.panel{display:none}
.panel[data-active="true"]{display:block;animation:rise .25s ease}
@keyframes rise{from{opacity:0;transform:translateY(6px)}to{opacity:1;transform:none}}
.lede{color:var(--ink-soft);max-width:62ch;margin:0 0 22px}
.grid{display:grid;grid-template-columns:1fr 1fr;gap:24px}
@media(max-width:880px){.grid{grid-template-columns:1fr}}

/* ---------- Form ---------- */
.field{margin-bottom:14px}
.field label{display:block;font-size:13px;font-weight:600;margin-bottom:6px}
.field .hint{font-weight:400;color:var(--ink-soft);font-size:12px}
input[type=text],textarea,select{
  width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:8px;
  font:inherit;background:var(--card);color:var(--ink)}
textarea{resize:vertical;min-height:90px}
input:focus,textarea:focus,select:focus{outline:2px solid var(--red);outline-offset:-1px;border-color:var(--red)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:12px}
@media(max-width:520px){.row{grid-template-columns:1fr}}

.btn{appearance:none;border:0;cursor:pointer;font:inherit;font-weight:700;
  padding:11px 20px;border-radius:8px;background:var(--red);color:#fff;
  display:inline-flex;align-items:center;gap:8px}
.btn:hover{background:var(--red-deep)}
.btn:disabled{opacity:.55;cursor:progress}
.btn--ghost{background:transparent;color:var(--ink);border:1px solid var(--line)}
.btn--ghost:hover{background:var(--bg-soft)}

/* ---------- Preview = giấy thật ---------- */
.preview{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow);padding:26px 30px;font-family:var(--serif);font-size:15px;min-height:200px}
.preview .ph{color:var(--ink-soft);font-family:var(--sans);font-style:italic;text-align:center;padding:50px 0}
.pv-head{display:flex;justify-content:space-between;gap:20px;font-size:13.5px;text-align:center;border-bottom:0}
.pv-head .col{flex:1}
.pv-caps{text-transform:uppercase}
.pv-b{font-weight:700}
.pv-sec{font-weight:700;margin:10px 0 2px}
.pv-p{margin:6px 0;text-align:justify;text-indent:1.2em}
.pv-cc{margin:6px 0;text-align:justify;text-indent:1.2em}
.pv-kg{text-align:center;margin:14px 0}
.pv-end{margin:10px 0;text-align:justify;text-indent:1.2em}

.result{margin-top:18px;padding:14px 16px;border-radius:8px;border:1px solid var(--line);
  background:var(--bg-soft);display:none;align-items:center;gap:12px;flex-wrap:wrap}
.result[data-show="true"]{display:flex}
.result.err{background:#fbecec;border-color:#e7c3c3;color:var(--red-deep)}
.result .file{font-family:var(--mono);font-size:13px}

.note{font-size:12.5px;color:var(--ink-soft);margin-top:6px}
.badge{display:inline-block;font-size:11px;font-weight:700;padding:2px 8px;border-radius:20px;
  background:var(--bg-soft);color:var(--ink-soft);text-transform:uppercase;letter-spacing:.06em}
.badge--free{background:#e7f0e9;color:var(--ok)}
.dz{border:1.5px dashed var(--line);border-radius:8px;padding:18px;text-align:center;color:var(--ink-soft);background:var(--card)}
.dz input{display:none}
.files-list{margin:8px 0 0;font-size:13px}
.files-list div{padding:3px 0;border-bottom:1px dashed var(--line)}
.spinner{width:15px;height:15px;border:2px solid #fff;border-top-color:transparent;border-radius:50%;display:inline-block;animation:sp .7s linear infinite}
@keyframes sp{to{transform:rotate(360deg)}}
.status-box{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:16px;margin-top:14px;display:none}
.status-box[data-show="true"]{display:block}
.st-row{display:flex;justify-content:space-between;padding:5px 0;border-bottom:1px dashed var(--line);font-size:14px}
.st-pill{font-weight:700}
.st-new{color:var(--gold)} .st-doing{color:var(--red)} .st-done{color:var(--ok)}

/* Hộp hướng dẫn từng module (admin sửa được qua trang quản trị) */
.guidebox{border-left:3px solid var(--red);background:var(--bg-soft);border-radius:8px;
  padding:12px 14px;margin:0 0 18px;font-size:13px;line-height:1.55;color:var(--ink)}
.guidebox:empty{display:none}
